CARVIEW |
Select Language
HTTP/2 200
date: Tue, 22 Jul 2025 03:46:38 GMT
content-type: text/html; charset=utf-8
vary: X-PJAX, X-PJAX-Container, Turbo-Visit, Turbo-Frame, X-Requested-With,Accept-Encoding, Accept, X-Requested-With
x-robots-tag: none
etag: W/"808dd053746d1dc7fdd536471d2b35a3"
cache-control: max-age=0, private, must-revalidate
strict-transport-security: max-age=31536000; includeSubdomains; preload
x-frame-options: deny
x-content-type-options: nosniff
x-xss-protection: 0
referrer-policy: no-referrer-when-downgrade
content-security-policy: default-src 'none'; base-uri 'self'; child-src github.githubassets.com github.com/assets-cdn/worker/ github.com/assets/ gist.github.com/assets-cdn/worker/; connect-src 'self' uploads.github.com www.githubstatus.com collector.github.com raw.githubusercontent.com api.github.com github-cloud.s3.amazonaws.com github-production-repository-file-5c1aeb.s3.amazonaws.com github-production-upload-manifest-file-7fdce7.s3.amazonaws.com github-production-user-asset-6210df.s3.amazonaws.com *.rel.tunnels.api.visualstudio.com wss://*.rel.tunnels.api.visualstudio.com objects-origin.githubusercontent.com copilot-proxy.githubusercontent.com proxy.individual.githubcopilot.com proxy.business.githubcopilot.com proxy.enterprise.githubcopilot.com *.actions.githubusercontent.com wss://*.actions.githubusercontent.com productionresultssa0.blob.core.windows.net/ productionresultssa1.blob.core.windows.net/ productionresultssa2.blob.core.windows.net/ productionresultssa3.blob.core.windows.net/ productionresultssa4.blob.core.windows.net/ productionresultssa5.blob.core.windows.net/ productionresultssa6.blob.core.windows.net/ productionresultssa7.blob.core.windows.net/ productionresultssa8.blob.core.windows.net/ productionresultssa9.blob.core.windows.net/ productionresultssa10.blob.core.windows.net/ productionresultssa11.blob.core.windows.net/ productionresultssa12.blob.core.windows.net/ productionresultssa13.blob.core.windows.net/ productionresultssa14.blob.core.windows.net/ productionresultssa15.blob.core.windows.net/ productionresultssa16.blob.core.windows.net/ productionresultssa17.blob.core.windows.net/ productionresultssa18.blob.core.windows.net/ productionresultssa19.blob.core.windows.net/ github-production-repository-image-32fea6.s3.amazonaws.com github-production-release-asset-2e65be.s3.amazonaws.com insights.github.com wss://alive.github.com api.githubcopilot.com api.individual.githubcopilot.com api.business.githubcopilot.com api.enterprise.githubcopilot.com; font-src github.githubassets.com; form-action 'self' github.com gist.github.com copilot-workspace.githubnext.com objects-origin.githubusercontent.com; frame-ancestors 'none'; frame-src viewscreen.githubusercontent.com notebooks.githubusercontent.com; img-src 'self' data: blob: github.githubassets.com media.githubusercontent.com camo.githubusercontent.com identicons.github.com avatars.githubusercontent.com private-avatars.githubusercontent.com github-cloud.s3.amazonaws.com objects.githubusercontent.com release-assets.githubusercontent.com secured-user-images.githubusercontent.com/ user-images.githubusercontent.com/ private-user-images.githubusercontent.com opengraph.githubassets.com copilotprodattachments.blob.core.windows.net/github-production-copilot-attachments/ github-production-user-asset-6210df.s3.amazonaws.com customer-stories-feed.github.com spotlights-feed.github.com objects-origin.githubusercontent.com *.githubusercontent.com; manifest-src 'self'; media-src github.com user-images.githubusercontent.com/ secured-user-images.githubusercontent.com/ private-user-images.githubusercontent.com github-production-user-asset-6210df.s3.amazonaws.com gist.github.com; script-src github.githubassets.com; style-src 'unsafe-inline' github.githubassets.com; upgrade-insecure-requests; worker-src github.githubassets.com github.com/assets-cdn/worker/ github.com/assets/ gist.github.com/assets-cdn/worker/
server: github.com
content-encoding: gzip
accept-ranges: bytes
set-cookie: _gh_sess=PTfur564msHv2uKDQRNWfEeadxttfMaV52i6uyP5GB9FcWrh0m7wL6sP2JiR%2BmmPZhmamkNKcHupfalg8xuMZj%2FQmjNAMZ2f4P2aL8DN%2FuSHGX9iJsT1Ix8U%2BT9duxQgKx1ptpYSOFC4A5l8tB%2FhWFk7HKfS63vS4oqJr5gHw2EEaguHkn1cC2Nst1pm0gPL%2F05vbEHBrwOaBusrwBvnBo5gNHHnP%2F5F9bEXGZMNugOptgmSnRL4MsfM5fulda852%2BkAi9XMv8xFLfWBp%2B4lng%3D%3D--jWQyGIS6X3VsOR62--cTpYL244c1Cje6ZtMlrmJA%3D%3D; Path=/; HttpOnly; Secure; SameSite=Lax
set-cookie: _octo=GH1.1.242191106.1753155998; Path=/; Domain=github.com; Expires=Wed, 22 Jul 2026 03:46:38 GMT; Secure; SameSite=Lax
set-cookie: logged_in=no; Path=/; Domain=github.com; Expires=Wed, 22 Jul 2026 03:46:38 GMT; HttpOnly; Secure; SameSite=Lax
x-github-request-id: B200:804EF:F1587:157C2F:687F099E
Addon API · lifeart/ember-language-server Wiki · GitHub
Skip to content
Navigation Menu
{{ message }}
forked from ember-tooling/ember-language-server
-
Notifications
You must be signed in to change notification settings - Fork 16
Addon API
Alex Kanunnikov edited this page May 11, 2020
·
3 revisions
import { Definition, FileChangeType, Diagnostic, TextDocument, Location, TextDocumentIdentifier, Position, CompletionItem, CodeActionParams } from 'vscode-languageserver';
import Server from '../server';
import ASTPath from './../glimmer-utils';
type Executor = (server: Server, command: string, args: any[]) => any;
type Linter = (document: TextDocument) => Diagnostic[];
type Watcher = (uri: string, change: FileChangeType) => any;
type MatchResultType =
| 'helper'
| 'service'
| 'route'
| 'controller'
| 'modifier'
| 'template'
| 'component'
| 'model'
| 'transform'
| 'adapter'
| 'serializer';
interface MatchResult {
type: MatchResultType;
name: string;
}
interface Project {
root: string; // project entry path
addCommandExecutor(key: string, fn: Executor): void;
addLinter(fn: Linter): void;
addWatcher(fn: Watcher): void;
matchPathToType(filePath: string): null | MatchResult;
}
interface Registry {
component: {
[componentName: string]: string[] // files, related to component
},
service: {
[serviceName: string]: string[] // files, related to service
},
routePath: {
[routePath: string]: string[] // files, related to route (templates, controllers, routes)
}
}
interface Command {
command: string // els.executeInEmberCLI
arguments: any[] // first argument - file path / project root, if command scoped to project
}
interface Server {
getRegistry(projectRoot: string): Registry;
onExecute(command: Command): any;
getUsages(normalizedName: string): string[]; // return list of files, related to token
}
interface BaseAPIParams {
server: Server;
textDocument: TextDocumentIdentifier;
position: Position;
}
interface ExtendedAPIParams {
focusPath: ASTPath;
type: 'script' | 'template';
}
interface ReferenceFunctionParams extends BaseAPIParams {
results: Location[];
}
interface CompletionFunctionParams extends ExtendedAPIParams {
results: CompletionItem[];
}
interface DefinitionFunctionParams extends ExtendedAPIParams {
results: Location[];
}
interface CodeActionFunctionParams extends CodeActionParams {
results: (Command | CodeAction)[];
server: Server;
document: TextDocument
}
type ReferenceResolveFunction = (root: string, params: ReferenceFunctionParams) => Promise<Location[]>;
type CompletionResolveFunction = (root: string, params: CompletionFunctionParams) => Promise<CompletionItem[]>;
type DefinitionResolveFunction = (root: string, params: DefinitionFunctionParams) => Promise<Location[]>;
type CodeActionResolveFunction = (root: string, params: CodeActionParams) => Promise<(Command | CodeAction)[] | undefined | null>;
type InitCallback = (server: Server, project: Project) => void;
export interface AddonAPI {
onReference: undefined | ReferenceResolveFunction;
onComplete: undefined | CompletionResolveFunction;
onDefinition: undefined | DefinitionResolveFunction;
onCodeAction: undefined | CodeActionResolveFunction;
onInit: undefined | InitCallback;
}
Clone this wiki locally
You can’t perform that action at this time.