本文整理汇总了TypeScript中vscode.languages.registerCodeActionsProvider方法的典型用法代码示例。如果您正苦于以下问题:TypeScript languages.registerCodeActionsProvider方法的具体用法?TypeScript languages.registerCodeActionsProvider怎么用?TypeScript languages.registerCodeActionsProvider使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类vscode.languages
的用法示例。
在下文中一共展示了languages.registerCodeActionsProvider方法的14个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: DefinitionMetadataDocumentProvider
disposables.push(server.onServerStart(() => {
// register language feature provider on start
const definitionMetadataDocumentProvider = new DefinitionMetadataDocumentProvider();
definitionMetadataDocumentProvider.register();
localDisposables.push(definitionMetadataDocumentProvider);
localDisposables.push(vscode.languages.registerDefinitionProvider(documentSelector, new DefinitionProvider(server, definitionMetadataDocumentProvider)));
localDisposables.push(vscode.languages.registerImplementationProvider(documentSelector, new ImplementationProvider(server)));
localDisposables.push(vscode.languages.registerCodeLensProvider(documentSelector, new CodeLensProvider(server)));
localDisposables.push(vscode.languages.registerDocumentHighlightProvider(documentSelector, new DocumentHighlightProvider(server)));
localDisposables.push(vscode.languages.registerDocumentSymbolProvider(documentSelector, new DocumentSymbolProvider(server)));
localDisposables.push(vscode.languages.registerReferenceProvider(documentSelector, new ReferenceProvider(server)));
localDisposables.push(vscode.languages.registerHoverProvider(documentSelector, new HoverProvider(server)));
localDisposables.push(vscode.languages.registerRenameProvider(documentSelector, new RenameProvider(server)));
localDisposables.push(vscode.languages.registerDocumentRangeFormattingEditProvider(documentSelector, new FormatProvider(server)));
localDisposables.push(vscode.languages.registerOnTypeFormattingEditProvider(documentSelector, new FormatProvider(server), '}', ';'));
localDisposables.push(vscode.languages.registerCompletionItemProvider(documentSelector, new CompletionItemProvider(server), '.', '<'));
localDisposables.push(vscode.languages.registerWorkspaceSymbolProvider(new WorkspaceSymbolProvider(server)));
localDisposables.push(vscode.languages.registerSignatureHelpProvider(documentSelector, new SignatureHelpProvider(server), '(', ','));
const codeActionProvider = new CodeActionProvider(server);
localDisposables.push(codeActionProvider);
localDisposables.push(vscode.languages.registerCodeActionsProvider(documentSelector, codeActionProvider));
localDisposables.push(reportDiagnostics(server, advisor));
localDisposables.push(forwardChanges(server));
}));
示例2: CompositeDisposable
disposables.add(server.onServerStart(() => {
// register language feature provider on start
localDisposables = new CompositeDisposable();
const definitionMetadataDocumentProvider = new DefinitionMetadataDocumentProvider();
definitionMetadataDocumentProvider.register();
localDisposables.add(definitionMetadataDocumentProvider);
const definitionProvider = new DefinitionProvider(server, definitionMetadataDocumentProvider);
localDisposables.add(vscode.languages.registerDefinitionProvider(documentSelector, definitionProvider));
localDisposables.add(vscode.languages.registerDefinitionProvider({ scheme: definitionMetadataDocumentProvider.scheme }, definitionProvider));
localDisposables.add(vscode.languages.registerImplementationProvider(documentSelector, new ImplementationProvider(server)));
const testManager = new TestManager(server, eventStream);
localDisposables.add(testManager);
localDisposables.add(vscode.languages.registerCodeLensProvider(documentSelector, new CodeLensProvider(server, testManager, optionProvider)));
localDisposables.add(vscode.languages.registerDocumentHighlightProvider(documentSelector, new DocumentHighlightProvider(server)));
localDisposables.add(vscode.languages.registerDocumentSymbolProvider(documentSelector, new DocumentSymbolProvider(server)));
localDisposables.add(vscode.languages.registerReferenceProvider(documentSelector, new ReferenceProvider(server)));
localDisposables.add(vscode.languages.registerHoverProvider(documentSelector, new HoverProvider(server)));
localDisposables.add(vscode.languages.registerRenameProvider(documentSelector, new RenameProvider(server)));
if (options.useFormatting) {
localDisposables.add(vscode.languages.registerDocumentRangeFormattingEditProvider(documentSelector, new FormatProvider(server)));
localDisposables.add(vscode.languages.registerOnTypeFormattingEditProvider(documentSelector, new FormatProvider(server), '}', ';'));
}
localDisposables.add(vscode.languages.registerCompletionItemProvider(documentSelector, new CompletionItemProvider(server), '.', ' '));
localDisposables.add(vscode.languages.registerWorkspaceSymbolProvider(new WorkspaceSymbolProvider(server, optionProvider)));
localDisposables.add(vscode.languages.registerSignatureHelpProvider(documentSelector, new SignatureHelpProvider(server), '(', ','));
const codeActionProvider = new CodeActionProvider(server, optionProvider);
localDisposables.add(codeActionProvider);
localDisposables.add(vscode.languages.registerCodeActionsProvider(documentSelector, codeActionProvider));
localDisposables.add(reportDiagnostics(server, advisor));
localDisposables.add(forwardChanges(server));
localDisposables.add(trackVirtualDocuments(server, eventStream));
localDisposables.add(vscode.languages.registerFoldingRangeProvider(documentSelector, new StructureProvider(server)));
}));
示例3: activate
export function activate(context: vsc.ExtensionContext) {
const logger = new Logger();
const config = new Configuration(logger);
const azureClient = new AzureClient(config, logger);
const sessionStore = new SessionStore(azureClient, config, logger);
const publishCommand = new PublishCommand(sessionStore, azureClient, logger, config);
const alphabet = [...'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'];
const activityDiagnostics = new ActivityDiagnostics(sessionStore);
activityDiagnostics.register();
context.subscriptions.push(...[
logger,
config,
vsc.commands.registerCommand(Commands.publish, publishCommand.publish, publishCommand),
vsc.languages.registerCompletionItemProvider(documentSelector, new ActivityCompletionProvider(sessionStore, logger), ...alphabet),
vsc.languages.registerCompletionItemProvider(documentSelector, new SnippetCompletionProvider(config), ...alphabet),
vsc.languages.registerCompletionItemProvider(documentSelector, new IterationCompletionProvider(sessionStore, logger), '#'),
vsc.languages.registerCompletionItemProvider(documentSelector, new UserStoryCompletionProvider(sessionStore, logger), '#'),
vsc.languages.registerCodeLensProvider(documentSelector, new PublishCodeLensProvider()),
vsc.languages.registerCodeActionsProvider(documentSelector, new ActivityCodeActionProvider(sessionStore, logger)),
activityDiagnostics
]);
}
示例4: activate
export function activate(context: ExtensionContext): any {
context.subscriptions.push(languages.registerCompletionItemProvider('todo', new TodoCompletionItemProvider(), '@'));
context.subscriptions.push(languages.registerCodeActionsProvider('todo', new TodoCodeActionProvider()));
languages.setLanguageConfiguration('todo', {
wordPattern: /(-?\d*\.\d\w*)|([^\-\`\~\!\#\%\^\&\*\(\)\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\?\s]+)/g,
indentationRules: {
increaseIndentPattern: /^\s*\w+.+:\s*$/,
decreaseIndentPattern: /^\uffff$/ //Does not match any
}
});
let todoCommands= new TodoCommands();
context.subscriptions.push(todoCommands.registerNewTaskCommand());
context.subscriptions.push(todoCommands.registerCompleteTaskCommand());
context.subscriptions.push(todoCommands.registerCancelTaskCommand());
context.subscriptions.push(workspace.onDidChangeTextDocument((e: TextDocumentChangeEvent) => {
_decorateEditor(true);
}));
window.onDidChangeActiveTextEditor(editor => {
_decorateEditor();
}, null, context.subscriptions);
_decorateEditor();
}
示例5: activate
export function activate(context: vscode.ExtensionContext) {
let rootDir = context.asAbsolutePath('.');
let pythonSettings = settings.PythonSettings.getInstance();
telemetryHelper.sendTelemetryEvent(telemetryContracts.EVENT_LOAD, {
CodeComplete_Has_ExtraPaths: pythonSettings.autoComplete.extraPaths.length > 0 ? 'true' : 'false',
Format_Has_Custom_Python_Path: pythonSettings.pythonPath.length !== 'python'.length ? 'true' : 'false'
});
lintingOutChannel = vscode.window.createOutputChannel(pythonSettings.linting.outputWindow);
formatOutChannel = lintingOutChannel;
if (pythonSettings.linting.outputWindow !== pythonSettings.formatting.outputWindow) {
formatOutChannel = vscode.window.createOutputChannel(pythonSettings.formatting.outputWindow);
formatOutChannel.clear();
}
if (pythonSettings.linting.outputWindow !== pythonSettings.unitTest.outputWindow) {
unitTestOutChannel = vscode.window.createOutputChannel(pythonSettings.unitTest.outputWindow);
unitTestOutChannel.clear();
}
sortImports.activate(context, formatOutChannel);
activateSetInterpreterProvider();
activateExecInTerminalProvider();
activateSimplePythonRefactorProvider(context, formatOutChannel);
context.subscriptions.push(activateFormatOnSaveProvider(PYTHON, pythonSettings, formatOutChannel, vscode.workspace.rootPath));
// Enable indentAction
vscode.languages.setLanguageConfiguration(PYTHON.language, {
onEnterRules: [
{
beforeText: /^\s*(?:def|class|for|if|elif|else|while|try|with|finally|except|async).*?:\s*$/,
action: { indentAction: vscode.IndentAction.Indent }
}
]
});
let renameProvider = new PythonRenameProvider(context);
context.subscriptions.push(vscode.languages.registerRenameProvider(PYTHON, renameProvider));
context.subscriptions.push(vscode.languages.registerHoverProvider(PYTHON, new PythonHoverProvider(context)));
context.subscriptions.push(vscode.languages.registerDefinitionProvider(PYTHON, new PythonDefinitionProvider(context)));
context.subscriptions.push(vscode.languages.registerReferenceProvider(PYTHON, new PythonReferenceProvider(context)));
context.subscriptions.push(vscode.languages.registerCompletionItemProvider(PYTHON, new PythonCompletionItemProvider(context), '.'));
context.subscriptions.push(vscode.languages.registerDocumentSymbolProvider(PYTHON, new PythonSymbolProvider(context, renameProvider.JediProxy)));
if (pythonSettings.devOptions.indexOf('DISABLE_SIGNATURE') === -1) {
context.subscriptions.push(vscode.languages.registerSignatureHelpProvider(PYTHON, new PythonSignatureProvider(context, renameProvider.JediProxy), '(', ','));
}
const formatProvider = new PythonFormattingEditProvider(context, formatOutChannel, pythonSettings, vscode.workspace.rootPath);
context.subscriptions.push(vscode.languages.registerDocumentFormattingEditProvider(PYTHON, formatProvider));
context.subscriptions.push(vscode.languages.registerDocumentRangeFormattingEditProvider(PYTHON, formatProvider));
context.subscriptions.push(new LintProvider(context, lintingOutChannel, vscode.workspace.rootPath));
context.subscriptions.push(vscode.languages.registerCodeActionsProvider(PYTHON, new PythonCodeActionsProvider(context)));
tests.activate(context, unitTestOutChannel);
// Possible this extension loads before the others, so lets wait for 5 seconds
setTimeout(disableOtherDocumentSymbolsProvider, 5000);
}
示例6: activate
export function activate(context: vscode.ExtensionContext) {
//console.log('Congratulations, your extension "vsc-spellchecker" is now active!');
const global = new Global();
global.activate(context);
for (let i = 0; i < global.settings.languageIDs.length; i++) {
vscode.languages.registerCodeActionsProvider(global.settings.languageIDs[i], new SpellProvider(global));
}
}
示例7: WorkspaceSymbolProvider
this.description.modeIds.forEach(modeId => {
let selector: DocumentFilter = { scheme: 'file', language: modeId };
languages.registerCompletionItemProvider(selector, this.completionItemProvider, '.');
languages.registerHoverProvider(selector, hoverProvider);
languages.registerDefinitionProvider(selector, definitionProvider);
languages.registerDocumentHighlightProvider(selector, documentHighlightProvider);
languages.registerReferenceProvider(selector, referenceProvider);
languages.registerDocumentSymbolProvider(selector, documentSymbolProvider);
languages.registerSignatureHelpProvider(selector, signatureHelpProvider, '(', ',');
languages.registerRenameProvider(selector, renameProvider);
languages.registerOnTypeFormattingEditProvider(selector, this.formattingProvider, ';', '}', '\n');
languages.registerWorkspaceSymbolProvider(new WorkspaceSymbolProvider(client, modeId));
if (client.apiVersion.has213Features()) {
languages.registerCodeActionsProvider(selector, new CodeActionProvider(client, modeId));
}
languages.setLanguageConfiguration(modeId, {
indentationRules: {
// ^(.*\*/)?\s*\}.*$
decreaseIndentPattern: /^(.*\*\/)?\s*\}.*$/,
// ^.*\{[^}"']*$
increaseIndentPattern: /^.*\{[^}"']*$/
},
wordPattern: /(-?\d*\.\d\w*)|([^\`\~\!\@\#\%\^\&\*\(\)\-\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\?\s]+)/g,
onEnterRules: [
{
// e.g. /** | */
beforeText: /^\s*\/\*\*(?!\/)([^\*]|\*(?!\/))*$/,
afterText: /^\s*\*\/$/,
action: { indentAction: IndentAction.IndentOutdent, appendText: ' * ' }
},
{
// e.g. /** ...|
beforeText: /^\s*\/\*\*(?!\/)([^\*]|\*(?!\/))*$/,
action: { indentAction: IndentAction.None, appendText: ' * ' }
},
{
// e.g. * ...|
beforeText: /^(\t|(\ \ ))*\ \*(\ ([^\*]|\*(?!\/))*)?$/,
action: { indentAction: IndentAction.None, appendText: '* ' }
},
{
// e.g. */|
beforeText: /^(\t|(\ \ ))*\ \*\/\s*$/,
action: { indentAction: IndentAction.None, removeText: 1 }
},
{
// e.g. *-----*/|
beforeText: /^(\t|(\ \ ))*\ \*[^/]*\*\/\s*$/,
action: { indentAction: IndentAction.None, removeText: 1 }
}
]
});
});
示例8: activate
export function activate(context: ExtensionContext) {
registerCommands(context);
diagnosticCollection = languages.createDiagnosticCollection('npm-script-runner');
context.subscriptions.push(diagnosticCollection);
workspace.onDidChangeConfiguration(_event => loadConfiguration(context), null, context.subscriptions);
loadConfiguration(context);
outputChannel = window.createOutputChannel('npm');
context.subscriptions.push(outputChannel);
context.subscriptions.push(languages.registerCodeActionsProvider('json', new NpmCodeActionProvider()));
}
示例9: activate
export function activate(context: vscode.ExtensionContext) {
var editorContext = new EditorContext();
var pscIde = new PscIde(editorContext);
var buildProvider = new BuildActionProvider()
context.subscriptions.push(
vscode.languages.registerHoverProvider('purescript', new PscHoverProvider(pscIde)),
vscode.languages.registerCompletionItemProvider('purescript', new PscCompletionProvider(pscIde)),
vscode.languages.registerCodeActionsProvider('purescript', buildProvider),
vscode.Disposable.from(pscIde),
vscode.Disposable.from(editorContext),
vscode.commands.registerCommand("purescript.build", function() {
build().then(result => buildProvider.setBuildResults(result))
}),
vscode.Disposable.from(new CodeActionCommands())
);
pscIde.activate();
}
示例10: WorkspaceSymbolProvider
this.description.modeIds.forEach(modeId => {
let selector: DocumentFilter = { scheme: 'file', language: modeId };
languages.registerCompletionItemProvider(selector, this.completionItemProvider, '.');
languages.registerHoverProvider(selector, hoverProvider);
languages.registerDefinitionProvider(selector, definitionProvider);
languages.registerTypeDefinitionProvider(selector, typeDefinitionProvider);
languages.registerDocumentHighlightProvider(selector, documentHighlightProvider);
languages.registerReferenceProvider(selector, referenceProvider);
languages.registerDocumentSymbolProvider(selector, documentSymbolProvider);
languages.registerSignatureHelpProvider(selector, signatureHelpProvider, '(', ',');
languages.registerRenameProvider(selector, renameProvider);
languages.registerOnTypeFormattingEditProvider(selector, this.formattingProvider, ';', '}', '\n');
languages.registerWorkspaceSymbolProvider(new WorkspaceSymbolProvider(client, modeId));
if (client.apiVersion.has213Features()) {
languages.registerCodeActionsProvider(selector, new CodeActionProvider(client, modeId));
}
languages.setLanguageConfiguration(modeId, {
indentationRules: {
// ^(.*\*/)?\s*\}.*$
decreaseIndentPattern: /^(.*\*\/)?\s*\}.*$/,
// ^.*\{[^}"']*$
increaseIndentPattern: /^.*\{[^}"']*$/
},
wordPattern: /(-?\d*\.\d\w*)|([^\`\~\!\@\#\%\^\&\*\(\)\-\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\?\s]+)/g,
onEnterRules: [
{
// e.g. /** | */
beforeText: /^\s*\/\*\*(?!\/)([^\*]|\*(?!\/))*$/,
afterText: /^\s*\*\/$/,
action: { indentAction: IndentAction.IndentOutdent, appendText: ' * ' }
},
{
// e.g. /** ...|
beforeText: /^\s*\/\*\*(?!\/)([^\*]|\*(?!\/))*$/,
action: { indentAction: IndentAction.None, appendText: ' * ' }
},
{
// e.g. * ...|
beforeText: /^(\t|(\ \ ))*\ \*(\ ([^\*]|\*(?!\/))*)?$/,
action: { indentAction: IndentAction.None, appendText: '* ' }
},
{
// e.g. */|
beforeText: /^(\t|(\ \ ))*\ \*\/\s*$/,
action: { indentAction: IndentAction.None, removeText: 1 }
},
{
// e.g. *-----*/|
beforeText: /^(\t|(\ \ ))*\ \*[^/]*\*\/\s*$/,
action: { indentAction: IndentAction.None, removeText: 1 }
}
]
});
const EMPTY_ELEMENTS: string[] = ['area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'menuitem', 'meta', 'param', 'source', 'track', 'wbr'];
languages.setLanguageConfiguration('jsx-tags', {
wordPattern: /(-?\d*\.\d\w*)|([^\`\~\!\@\$\^\&\*\(\)\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\s]+)/g,
onEnterRules: [
{
beforeText: new RegExp(`<(?!(?:${EMPTY_ELEMENTS.join('|')}))([_:\\w][_:\\w-.\\d]*)([^/>]*(?!/)>)[^<]*$`, 'i'),
afterText: /^<\/([_:\w][_:\w-.\d]*)\s*>$/i,
action: { indentAction: IndentAction.IndentOutdent }
},
{
beforeText: new RegExp(`<(?!(?:${EMPTY_ELEMENTS.join('|')}))(\\w[\\w\\d]*)([^/>]*(?!/)>)[^<]*$`, 'i'),
action: { indentAction: IndentAction.Indent }
}
],
});
});
示例11: activate
export function activate(context: vs.ExtensionContext) {
let extensionStartTime = new Date();
sdks = util.findSdks();
if (sdks.dart == null) {
if (util.isFlutterProject) {
vs.window.showErrorMessage("Could not find a Flutter SDK to use. " +
"Please add it to your PATH or set FLUTTER_HOME and reload.",
"Go to Flutter Downloads"
).then(selectedItem => {
if (selectedItem)
util.openInBrowser(FLUTTER_DOWNLOAD_URL);
});
}
else {
vs.window.showErrorMessage("Could not find a Dart SDK to use. " +
"Please add it to your PATH or configure the 'dart.sdkPath' setting and reload.",
"Go to Dart Downloads"
).then(selectedItem => {
if (selectedItem)
util.openInBrowser(DART_DOWNLOAD_URL);
});
}
analytics.logSdkDetectionFailure();
return; // Don't set anything else up; we can't work like this!
}
// Show the SDK version in the status bar.
let sdkVersion = util.getDartSdkVersion(sdks.dart);
if (sdkVersion) {
let versionStatusItem = vs.window.createStatusBarItem(vs.StatusBarAlignment.Right, Number.MIN_VALUE);
versionStatusItem.text = sdkVersion;
versionStatusItem.tooltip = "Dart SDK Version";
versionStatusItem.show();
context.subscriptions.push(versionStatusItem);
if (config.checkForSdkUpdates && !util.isFlutterProject) {
util.getLatestSdkVersion().then(version => {
if (util.isOutOfDate(sdkVersion, version))
vs.window.showWarningMessage(
`Version ${version} of the Dart SDK is available (you have ${sdkVersion}). Some features of Dart Code may not work correctly with an old SDK.`,
"Go to Dart Downloads"
).then(selectedItem => {
if (selectedItem)
util.openInBrowser(DART_DOWNLOAD_URL);
});
}, util.logError);
}
analytics.sdkVersion = sdkVersion;
}
// Fire up the analyzer process.
let analyzerStartTime = new Date();
const analyzerPath = config.analyzerPath || path.join(sdks.dart, util.analyzerPath);
analyzer = new Analyzer(path.join(sdks.dart, util.dartVMPath), analyzerPath);
context.subscriptions.push(analyzer);
// Log analysis server startup time when we get the welcome message/version.
let connectedEvents = analyzer.registerForServerConnected(sc => {
analytics.analysisServerVersion = sc.version;
let analyzerEndTime = new Date();
analytics.logAnalyzerStartupTime(analyzerEndTime.getTime() - analyzerStartTime.getTime());
connectedEvents.dispose();
});
// Log analysis server first analysis completion time when it completes.
var analysisStartTime: Date;
let analysisCompleteEvents = analyzer.registerForServerStatus(ss => {
// Analysis started for the first time.
if (ss.analysis && ss.analysis.isAnalyzing && !analysisStartTime)
analysisStartTime = new Date();
// Analysis ends for the first time.
if (ss.analysis && !ss.analysis.isAnalyzing && analysisStartTime) {
let analysisEndTime = new Date();
analytics.logAnalyzerFirstAnalysisTime(analysisEndTime.getTime() - analysisStartTime.getTime());
analysisCompleteEvents.dispose();
}
});
// TODO: Check if EventEmitter<T> would be more appropriate than our own.
// Set up providers.
context.subscriptions.push(vs.languages.registerHoverProvider(DART_MODE, new DartHoverProvider(analyzer)));
context.subscriptions.push(vs.languages.registerDocumentFormattingEditProvider(DART_MODE, new DartFormattingEditProvider(analyzer)));
context.subscriptions.push(vs.languages.registerOnTypeFormattingEditProvider(DART_MODE, new DartTypeFormattingEditProvider(analyzer), "}", ";"));
context.subscriptions.push(vs.languages.registerCompletionItemProvider(DART_MODE, new DartCompletionItemProvider(analyzer), ".", ":", " ", "=", "("));
context.subscriptions.push(vs.languages.registerDefinitionProvider(DART_MODE, new DartDefinitionProvider(analyzer)));
context.subscriptions.push(vs.languages.registerDocumentSymbolProvider(DART_MODE, new DartDocumentSymbolProvider(analyzer)));
context.subscriptions.push(vs.languages.registerReferenceProvider(DART_MODE, new DartReferenceProvider(analyzer)));
context.subscriptions.push(vs.languages.registerWorkspaceSymbolProvider(new DartWorkspaceSymbolProvider(analyzer)));
context.subscriptions.push(vs.languages.registerDocumentHighlightProvider(DART_MODE, new DartDocumentHighlightProvider(analyzer)));
context.subscriptions.push(vs.languages.registerCodeActionsProvider(DART_MODE, new DartCodeActionProvider(analyzer)));
context.subscriptions.push(vs.languages.registerRenameProvider(DART_MODE, new DartRenameProvider(analyzer)));
context.subscriptions.push(vs.languages.setLanguageConfiguration(DART_MODE.language, new DartLanguageConfiguration()));
context.subscriptions.push(new AnalyzerStatusReporter(analyzer));
// Set up diagnostics.
let diagnostics = vs.languages.createDiagnosticCollection("dart");
context.subscriptions.push(diagnostics);
let diagnosticsProvider = new DartDiagnosticProvider(analyzer, diagnostics);
//.........这里部分代码省略.........
示例12: activate
export function activate(context: vscode.ExtensionContext) {
let linter = new HaskellLintingProvider();
linter.activate(context.subscriptions);
vscode.languages.registerCodeActionsProvider('haskell', linter);
}
示例13: activate
//.........这里部分代码省略.........
context.subscriptions.push(formattingEditProvider);
const completionItemProvider = new DartCompletionItemProvider(analyzer);
const referenceProvider = new DartReferenceProvider(analyzer);
const documentHighlightProvider = new DartDocumentHighlightProvider(analyzer);
const sourceCodeActionProvider = new SourceCodeActionProvider();
const renameProvider = new DartRenameProvider(analyzer);
const implementationProvider = new DartImplementationProvider(analyzer);
const activeFileFilters = [DART_MODE];
if (config.analyzeAngularTemplates && analyzer.capabilities.supportsAnalyzingHtmlFiles) {
// Analyze Angular2 templates, requires the angular_analyzer_plugin.
activeFileFilters.push(HTML_MODE);
}
// This is registered with VS Code further down, so it's metadata can be collected from all
// registered providers.
const rankingCodeActionProvider = new RankingCodeActionProvider();
const triggerCharacters = ".(${'\"/\\".split("");
context.subscriptions.push(vs.languages.registerHoverProvider(activeFileFilters, hoverProvider));
formattingEditProvider.registerDocumentFormatter(activeFileFilters);
context.subscriptions.push(vs.languages.registerCompletionItemProvider(activeFileFilters, completionItemProvider, ...triggerCharacters));
context.subscriptions.push(vs.languages.registerDefinitionProvider(activeFileFilters, referenceProvider));
context.subscriptions.push(vs.languages.registerReferenceProvider(activeFileFilters, referenceProvider));
context.subscriptions.push(vs.languages.registerDocumentHighlightProvider(activeFileFilters, documentHighlightProvider));
rankingCodeActionProvider.registerProvider(new AssistCodeActionProvider(activeFileFilters, analyzer));
rankingCodeActionProvider.registerProvider(new FixCodeActionProvider(activeFileFilters, analyzer));
rankingCodeActionProvider.registerProvider(new RefactorCodeActionProvider(activeFileFilters, analyzer));
context.subscriptions.push(vs.languages.registerRenameProvider(activeFileFilters, renameProvider));
// Some actions only apply to Dart.
formattingEditProvider.registerTypingFormatter(DART_MODE, "}", ";");
context.subscriptions.push(vs.languages.registerCodeActionsProvider(DART_MODE, sourceCodeActionProvider, sourceCodeActionProvider.metadata));
rankingCodeActionProvider.registerProvider(new IgnoreLintCodeActionProvider(activeFileFilters));
context.subscriptions.push(vs.languages.registerImplementationProvider(DART_MODE, implementationProvider));
if (config.showTestCodeLens) {
const codeLensProvider = new TestCodeLensProvider(analyzer);
context.subscriptions.push(codeLensProvider);
context.subscriptions.push(vs.languages.registerCodeLensProvider(DART_MODE, codeLensProvider));
}
// Register the ranking provider from VS Code now that it has all of its delegates.
context.subscriptions.push(vs.languages.registerCodeActionsProvider(activeFileFilters, rankingCodeActionProvider, rankingCodeActionProvider.metadata));
// Task handlers.
if (config.previewBuildRunnerTasks) {
context.subscriptions.push(vs.tasks.registerTaskProvider("pub", new PubBuildRunnerTaskProvider(sdks)));
}
// Snippets are language-specific
context.subscriptions.push(vs.languages.registerCompletionItemProvider(DART_MODE, new SnippetCompletionItemProvider("snippets/dart.json", (_) => true)));
context.subscriptions.push(vs.languages.registerCompletionItemProvider(DART_MODE, new SnippetCompletionItemProvider("snippets/flutter.json", (uri) => util.isInsideFlutterProject(uri))));
context.subscriptions.push(vs.languages.setLanguageConfiguration(DART_MODE.language, new DartLanguageConfiguration()));
const statusReporter = new AnalyzerStatusReporter(analyzer, workspaceContext, analytics);
// Set up diagnostics.
const diagnostics = vs.languages.createDiagnosticCollection("dart");
context.subscriptions.push(diagnostics);
const diagnosticsProvider = new DartDiagnosticProvider(analyzer, diagnostics);
// Set the roots, handling project changes that might affect SDKs.
context.subscriptions.push(vs.workspace.onDidChangeWorkspaceFolders((f) => recalculateAnalysisRoots()));
// TODO: Currently calculating analysis roots requires the version to check if
示例14: activate
export function activate(ctx: vscode.ExtensionContext) {
const elmFormatStatusBar = vscode.window.createStatusBarItem(
vscode.StatusBarAlignment.Left,
);
ctx.subscriptions.push(
vscode.workspace.onDidSaveTextDocument((document: vscode.TextDocument) => {
runLinter(document, elmAnalyse);
}),
);
activateRepl().forEach((d: vscode.Disposable) => ctx.subscriptions.push(d));
activateReactor().forEach((d: vscode.Disposable) =>
ctx.subscriptions.push(d),
);
activateMake().forEach((d: vscode.Disposable) => ctx.subscriptions.push(d));
activatePackage().forEach((d: vscode.Disposable) =>
ctx.subscriptions.push(d),
);
activateClean().forEach((d: vscode.Disposable) => ctx.subscriptions.push(d));
activateCodeActions().forEach((d: vscode.Disposable) =>
ctx.subscriptions.push(d),
);
elmAnalyse
.activateAnalyse()
.forEach((d: vscode.Disposable) => ctx.subscriptions.push(d));
let workspaceProvider = new ElmWorkspaceSymbolProvider(ELM_MODE);
ctx.subscriptions.push(
vscode.languages.setLanguageConfiguration('elm', configuration),
);
ctx.subscriptions.push(
vscode.languages.registerHoverProvider(ELM_MODE, new ElmHoverProvider()),
);
ctx.subscriptions.push(
vscode.languages.registerCompletionItemProvider(
ELM_MODE,
new ElmCompletionProvider(),
'.',
),
);
ctx.subscriptions.push(
vscode.languages.registerDocumentSymbolProvider(
ELM_MODE,
new ElmSymbolProvider(),
),
);
ctx.subscriptions.push(
vscode.languages.registerDefinitionProvider(
ELM_MODE,
new ElmDefinitionProvider(ELM_MODE, workspaceProvider),
),
);
ctx.subscriptions.push(
vscode.languages.registerCodeActionsProvider(
ELM_MODE,
new ElmCodeActionProvider(),
),
);
ctx.subscriptions.push(
vscode.languages.registerDocumentFormattingEditProvider(
ELM_MODE,
new ElmFormatProvider(elmFormatStatusBar),
),
);
ctx.subscriptions.push(
vscode.languages.registerWorkspaceSymbolProvider(workspaceProvider),
);
vscode.workspace.onDidSaveTextDocument((document: vscode.TextDocument) => {
if (
document === vscode.window.activeTextEditor.document &&
document.languageId === ELM_MODE.language
) {
workspaceProvider.update(document);
}
});
}