vscode#IndentAction TypeScript Examples
The following examples show how to use
vscode#IndentAction.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: extension.ts From plugin-vscode with Apache License 2.0 | 6 votes |
registerPreInitHandlers(): any {
// We need to restart VSCode if we change plugin configurations.
workspace.onDidChangeConfiguration((params: ConfigurationChangeEvent) => {
if (params.affectsConfiguration(BALLERINA_HOME) ||
params.affectsConfiguration(OVERRIDE_BALLERINA_HOME)) {
this.showMsgAndRestart(CONFIG_CHANGED);
}
});
languages.setLanguageConfiguration('ballerina', {
onEnterRules: [
{
beforeText: new RegExp('^\\s*#'),
action: {
appendText: '# ',
indentAction: IndentAction.None,
}
}
]
});
}
Example #2
Source File: client.ts From vscode-q with MIT License | 4 votes |
export function activate(context: ExtensionContext): void {
// extra language configurations
languages.setLanguageConfiguration('q', {
onEnterRules: [
{
// eslint-disable-next-line no-useless-escape
beforeText: /^(?!\s+).*[\(\[{].*$/,
afterText: /^[)}\]]/,
action: {
indentAction: IndentAction.None,
appendText: '\n '
}
},
{
// eslint-disable-next-line no-useless-escape
beforeText: /^\s[)}\]];?$/,
action: {
indentAction: IndentAction.Outdent
}
},
{
// eslint-disable-next-line no-useless-escape
beforeText: /^\/.*$/,
action: {
indentAction: IndentAction.None,
appendText: '/ '
}
}
]
});
// append space to start [,(,{
languages.registerDocumentFormattingEditProvider('q', {
provideDocumentFormattingEdits(document: TextDocument): TextEdit[] {
const textEdit: TextEdit[] = [];
for (let i = 0; i < document.lineCount; i++) {
const line = document.lineAt(i);
if (line.isEmptyOrWhitespace) {
continue;
}
if (line.text.match('^[)\\]}]')) {
textEdit.push(TextEdit.insert(line.range.start, ' '));
}
}
return textEdit;
}
});
// <-- init
QStatusBarManager.create(context);
QStatusBarManager.updateConnStatus(undefined);
// q-server-explorer
const qServers = new QServerTree('root', null);
const qRoot = new QDictTreeItem('root', null);
const qHistory = HistoryTreeItem.createHistoryTree();
window.registerTreeDataProvider('q-servers', qServers);
qServers.refresh();
window.registerTreeDataProvider('q-explorer', qRoot);
window.registerTreeDataProvider('q-history', qHistory);
qHistory.refresh();
QueryConsole.createOrGet();
QueryView.setExtensionPath(context.extensionPath);
QueryGrid.setExtensionPath(context.extensionPath);
AddServer.setExtensionPath(context.extensionPath);
ChartView.setExtensionPath(context.extensionPath);
// --> init
// <-- configuration
const queryMode = workspace.getConfiguration().get('q-client.queryMode');
QConnManager.setQueryMode(queryMode as string);
// -->
commands.registerCommand(
'q-client.refreshEntry', () => qServers.refresh());
commands.registerCommand(
'q-explorer.toggleAutoRefresh', () => {
QConnManager.autoRefreshExplorer = !QConnManager.autoRefreshExplorer;
window.showInformationMessage(`Auto Refresh Explorer ${QConnManager.autoRefreshExplorer ? 'On' : 'Off'}`);
});
// q cfg input
commands.registerCommand(
'q-client.addEntry',
() => {
AddServer.createOrShow();
});
commands.registerCommand(
'q-client.editEntry',
(qConn: QConn) => {
AddServer.createOrShow();
AddServer.update(qConn);
});
commands.registerCommand(
'q-client.deleteEntry',
(qConn: QConn) => {
window.showInputBox(
{ prompt: `Confirm to Remove Server '${qConn.uniqLabel.replace(',', '-')}' (Y/n)` }
).then(value => {
if (value === 'Y') {
QConnManager.current?.removeCfg(qConn.uniqLabel);
}
});
});
commands.registerCommand(
'q-client.reactions',
async () => {
const option = await window.showQuickPick(
['1 - Raising an Issue', '2 - Writing a Review', '3 - Creating a Pull Request', '4 - Buying Me a Beer', '5 - Q & A'],
{ placeHolder: 'Contribute to vscode-q by' });
switch (option?.[0]) {
case '1':
env.openExternal(Uri.parse('https://github.com/jshinonome/vscode-q/issues'));
break;
case '2':
env.openExternal(Uri.parse('https://marketplace.visualstudio.com/items?itemName=jshinonome.vscode-q&ssr=false#review-details'));
break;
case '3':
env.openExternal(Uri.parse('https://github.com/jshinonome/vscode-q/blob/master/CONTRIBUTING.md'));
break;
case '4':
env.openExternal(Uri.parse('https://www.buymeacoffee.com/jshinonome'));
break;
case '5':
env.openExternal(Uri.parse('https://github.com/jshinonome/vscode-q/discussions'));
}
});
commands.registerCommand(
'q-client.connectEntry',
async () => {
const connManager = QConnManager.current;
if (connManager) {
const quickPickItems: QuickPickItem[] = connManager.qCfg.map(qcfg => {
return {
label: qcfg.uniqLabel,
description: `\`:${qcfg.host}:${qcfg.port}`
};
});
const recentlyUsedItems: QuickPickItem[] = Array.from(connManager.qConnPool.values())
.filter(qConn => !(qConn.conn == undefined))
.map(qConn => {
return {
label: qConn.uniqLabel,
description: `\`:${qConn.host}:${qConn.port}`
};
});
const allItems: QuickPickItem[] = [
{
label: 'Connected',
kind: QuickPickItemKind.Separator
},
...recentlyUsedItems,
{
label: 'Process',
kind: QuickPickItemKind.Separator
},
...quickPickItems
];
const item = await window.showQuickPick(
allItems,
{ placeHolder: 'Connect to a q process' });
if (item) {
commands.executeCommand('q-client.connect', item.label);
return item.label;
}
}
});
commands.registerCommand(
'q-client.connect',
uniqLabel => {
QConnManager.current?.connect(uniqLabel);
});
commands.registerCommand(
'q-client.tagEntry',
async (qConn: QConn) => {
qConn.tags = await window.showInputBox({
prompt: `Tags for '${qConn.label}' separate by ',' (e.g. 'dev,quant,tca')`
}) ?? '';
QConnManager.current?.addCfg(qConn);
});
commands.registerCommand(
'q-client.switchMode',
async () => {
const mode = await window.showQuickPick(['Console', 'Grid', 'Visualization'],
{ placeHolder: 'Please choose a query mode from the list below' });
if (mode) {
window.showInformationMessage(`Switch to Query ${mode} Mode`);
QConnManager.setQueryMode(mode);
QStatusBarManager.updateQueryModeStatus();
}
});
commands.registerCommand(
'q-client.toggleLimitQuery',
() => {
QConnManager.current?.toggleLimitQuery();
});
commands.registerCommand(
'q-client.abortQuery',
() => {
QConnManager.current?.abortQuery();
});
commands.registerCommand(
'q-client.exportServers',
() => {
QConnManager.current?.exportCfg();
});
commands.registerCommand(
'q-client.importServers',
() => {
QConnManager.current?.importCfg();
});
commands.registerCommand(
'q-explorer.refreshEntry', () => qRoot.refresh());
const previewQueryLimit = workspace.getConfiguration().get('q-client.expl.prevQueryLimit');
commands.registerCommand('q-explorer.preview', (item: TreeItem) => {
switch (item.contextValue) {
case 'qtable':
QConnManager.current?.sync(
`{[t;l]$[@[{x in value \`.Q.pt};t;{'"preview feature requires v3.5+ kdb"}];select from t where date=last date, i<l;select from t where i<l]}[\`${item.label};${previewQueryLimit}]`);
break;
case 'qfunction':
QueryConsole.current?.append((item as QFunctionTreeItem).getBody(), 0, 'cached');
break;
default:
if (item.label)
QConnManager.current?.sync(item.label as string);
}
});
commands.registerCommand('q-explorer.click', label => {
console.log(label);
});
context.subscriptions.push(
commands.registerCommand('q-history.rerun', (history) => {
if (QConnManager.current?.activeConn?.uniqLabel === history.uniqLabel)
QConnManager.current?.sync(history.query);
else
QConnManager.current?.connect(history.uniqLabel, history.query);
})
);
enum QueryCodeType {
Line,
Selection,
Block
}
enum QueryTarget {
Process,
Terminal
}
async function queryCode(code: QueryCodeType, target: QueryTarget): Promise<void> {
const editor = window.activeTextEditor;
if (editor) {
let n = 0;
let query = '';
const params = {
textDocument: {
uri: editor.document.uri.toString(),
},
position: editor.selection.active,
};
switch (code) {
case QueryCodeType.Line:
n = editor.selection.active.line;
query = editor.document.lineAt(n).text;
n = 0;
break;
case QueryCodeType.Selection:
query = editor?.document.getText(
new Range(editor.selection.start, editor.selection.end)
);
break;
case QueryCodeType.Block:
({ query, n } = await client.sendRequest('onQueryBlock', params));
break;
}
if (query) {
if (code === QueryCodeType.Line && query.startsWith('/<=>')) {
const uniqLabel = query.substring(4).trim();
commands.executeCommand('q-client.connect', uniqLabel);
} else {
switch (target) {
case QueryTarget.Process:
QConnManager.current?.sync(query);
break;
case QueryTarget.Terminal:
sendToCurrentTerm(query.replace(/(\r\n|\n|\r)/gm, ''));
break;
}
}
}
if (n > 0) {
let line = editor.document.lineAt(n).text;
while (n < editor.document.lineCount && (line === '' || line.startsWith('/'))) {
n++;
line = editor.document.lineAt(n).text;
}
const range = editor.document.lineAt(n).range;
editor.selection = new Selection(range.start, range.start);
editor.revealRange(new Range(range.start, range.start));
}
}
}
context.subscriptions.push(
commands.registerCommand('q-client.queryCurrentLine', async () => {
queryCode(QueryCodeType.Line, QueryTarget.Process);
})
);
context.subscriptions.push(
commands.registerCommand('q-client.querySelection', () => {
queryCode(QueryCodeType.Selection, QueryTarget.Process);
})
);
context.subscriptions.push(
commands.registerCommand('q-client.queryBlock', () => {
queryCode(QueryCodeType.Block, QueryTarget.Process);
})
);
context.subscriptions.push(
commands.registerCommand('q-term.sendCurrentLine', () => {
queryCode(QueryCodeType.Line, QueryTarget.Terminal);
})
);
context.subscriptions.push(
commands.registerCommand('q-term.sendSelection', () => {
queryCode(QueryCodeType.Selection, QueryTarget.Terminal);
})
);
context.subscriptions.push(
commands.registerCommand('q-term.sendBlock', () => {
queryCode(QueryCodeType.Block, QueryTarget.Terminal);
})
);
context.subscriptions.push(
commands.registerCommand('q-client.terminal.run', () => {
const filepath = window.activeTextEditor?.document.fileName;
if (filepath)
runQFile(filepath);
})
);
context.subscriptions.push(
commands.registerCommand('q-client.insertActiveConnLabel', () => {
const editor = window.activeTextEditor;
if (editor) {
editor.edit(editBuilder => {
if (QConnManager.current?.activeConn?.uniqLabel) {
editBuilder.insert(editor.selection.active, '/<=>' + QConnManager.current?.activeConn?.uniqLabel);
}
});
}
})
);
if (window.registerWebviewPanelSerializer) {
// Make sure we register a serializer in activation event
window.registerWebviewPanelSerializer(QueryView.viewType, {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
async deserializeWebviewPanel(webviewPanel: WebviewPanel) {
QueryView.revive(webviewPanel, context.extensionPath);
}
});
}
workspace.onDidChangeConfiguration(e => {
if (e.affectsConfiguration('q-client') && !e.affectsConfiguration('q-client.term')) {
window.showInformationMessage('Reload/Restart vscode to Make the Configuration Take Effect.');
} else if (e.affectsConfiguration('q-server')) {
const cfg = workspace.getConfiguration('q-server.sourceFiles');
client.sendNotification('analyzeSourceCode', { globsPattern: cfg.get('globsPattern'), ignorePattern: cfg.get('ignorePattern') });
}
});
// q language server
const qls = path.join(context.extensionPath, 'dist', 'server.js');
// The debug options for the server
// runs the server in Node's Inspector mode for debugging
const debugOptions = { execArgv: ['--nolazy', '--inspect=6018'] };
// If launched in debug mode then the debug server options are used
// Otherwise the run options are used
const serverOptions: ServerOptions = {
run: { module: qls, transport: TransportKind.ipc },
debug: {
module: qls,
transport: TransportKind.ipc,
options: debugOptions
}
};
// Options to control the language client
const clientOptions: LanguageClientOptions = {
// Register the server for plain text documents
documentSelector: [{ scheme: 'file', language: 'q' }],
synchronize: {
// Notify the server about q file changes
fileEvents: workspace.createFileSystemWatcher('**/*.q')
}
};
// Create the language client and start the client.
const client = new LanguageClient(
'qLangServer',
'q Language Server',
serverOptions,
clientOptions
);
context.subscriptions.push(
commands.registerCommand('q-client.sendServerCache', code => {
client.sendNotification('analyzeServerCache', code);
})
);
context.subscriptions.push(
commands.registerCommand('q-client.sendOnHover', hoverItems => {
client.sendNotification('prepareOnHover', hoverItems);
})
);
client.start().then(() => {
const cfg = workspace.getConfiguration('q-server.sourceFiles');
client.sendNotification('analyzeSourceCode', { globsPattern: cfg.get('globsPattern'), ignorePattern: cfg.get('ignorePattern') });
});
}
Example #3
Source File: extension.ts From language-tools with MIT License | 4 votes |
export function activateSvelteLanguageServer(context: ExtensionContext) { warnIfOldExtensionInstalled(); const runtimeConfig = workspace.getConfiguration('svelte.language-server'); const { workspaceFolders } = workspace; const rootPath = Array.isArray(workspaceFolders) ? workspaceFolders[0].uri.fsPath : undefined; const tempLsPath = runtimeConfig.get<string>('ls-path'); // Returns undefined if path is empty string // Return absolute path if not already const lsPath = tempLsPath && tempLsPath.trim() !== '' ? path.isAbsolute(tempLsPath) ? tempLsPath : path.join(rootPath as string, tempLsPath) : undefined; const serverModule = require.resolve(lsPath || 'svelte-language-server/bin/server.js'); console.log('Loading server from ', serverModule); // Add --experimental-modules flag for people using node 12 < version < 12.17 // Remove this in mid 2022 and bump vs code minimum required version to 1.55 const runExecArgv: string[] = ['--experimental-modules']; let port = runtimeConfig.get<number>('port') ?? -1; if (port < 0) { port = 6009; } else { console.log('setting port to', port); runExecArgv.push(`--inspect=${port}`); } const debugOptions = { execArgv: ['--nolazy', '--experimental-modules', `--inspect=${port}`] }; const serverOptions: ServerOptions = { run: { module: serverModule, transport: TransportKind.ipc, options: { execArgv: runExecArgv } }, debug: { module: serverModule, transport: TransportKind.ipc, options: debugOptions } }; const serverRuntime = runtimeConfig.get<string>('runtime'); if (serverRuntime) { serverOptions.run.runtime = serverRuntime; serverOptions.debug.runtime = serverRuntime; console.log('setting server runtime to', serverRuntime); } const clientOptions: LanguageClientOptions = { documentSelector: [{ scheme: 'file', language: 'svelte' }], revealOutputChannelOn: RevealOutputChannelOn.Never, synchronize: { // TODO deprecated, rework upon next VS Code minimum version bump configurationSection: [ 'svelte', 'prettier', 'emmet', 'javascript', 'typescript', 'css', 'less', 'scss' ], fileEvents: workspace.createFileSystemWatcher('{**/*.js,**/*.ts}', false, false, false) }, initializationOptions: { configuration: { svelte: workspace.getConfiguration('svelte'), prettier: workspace.getConfiguration('prettier'), emmet: workspace.getConfiguration('emmet'), typescript: workspace.getConfiguration('typescript'), javascript: workspace.getConfiguration('javascript'), css: workspace.getConfiguration('css'), less: workspace.getConfiguration('less'), scss: workspace.getConfiguration('scss') }, dontFilterIncompleteCompletions: true, // VSCode filters client side and is smarter at it than us isTrusted: (workspace as any).isTrusted } }; let ls = createLanguageServer(serverOptions, clientOptions); context.subscriptions.push(ls.start()); ls.onReady().then(() => { const tagRequestor = (document: TextDocument, position: Position) => { const param = ls.code2ProtocolConverter.asTextDocumentPositionParams( document, position ); return ls.sendRequest(TagCloseRequest.type, param); }; const disposable = activateTagClosing( tagRequestor, { svelte: true }, 'html.autoClosingTags' ); context.subscriptions.push(disposable); }); workspace.onDidSaveTextDocument(async (doc) => { const parts = doc.uri.toString(true).split(/\/|\\/); if ( [ /^tsconfig\.json$/, /^jsconfig\.json$/, /^svelte\.config\.(js|cjs|mjs)$/, // https://prettier.io/docs/en/configuration.html /^\.prettierrc$/, /^\.prettierrc\.(json|yml|yaml|json5|toml)$/, /^\.prettierrc\.(js|cjs)$/, /^\.prettierrc\.config\.(js|cjs)$/ ].some((regex) => regex.test(parts[parts.length - 1])) ) { await restartLS(false); } }); context.subscriptions.push( commands.registerCommand('svelte.restartLanguageServer', async () => { await restartLS(true); }) ); let restartingLs = false; async function restartLS(showNotification: boolean) { if (restartingLs) { return; } restartingLs = true; await ls.stop(); ls = createLanguageServer(serverOptions, clientOptions); context.subscriptions.push(ls.start()); await ls.onReady(); if (showNotification) { window.showInformationMessage('Svelte language server restarted.'); } restartingLs = false; } function getLS() { return ls; } addDidChangeTextDocumentListener(getLS); addFindFileReferencesListener(getLS, context); addRenameFileListener(getLS); addCompilePreviewCommand(getLS, context); addExtracComponentCommand(getLS, context); languages.setLanguageConfiguration('svelte', { indentationRules: { // Matches a valid opening tag that is: // - Not a doctype // - Not a void element // - Not a closing tag // - Not followed by a closing tag of the same element // Or matches `<!--` // Or matches open curly brace // increaseIndentPattern: // eslint-disable-next-line max-len, no-useless-escape /<(?!\?|(?:area|base|br|col|frame|hr|html|img|input|link|meta|param)\b|[^>]*\/>)([-_\.A-Za-z0-9]+)(?=\s|>)\b[^>]*>(?!.*<\/\1>)|<!--(?!.*-->)|\{[^}"']*$/, // Matches a closing tag that: // - Follows optional whitespace // - Is not `</html>` // Or matches `-->` // Or closing curly brace // // eslint-disable-next-line no-useless-escape decreaseIndentPattern: /^\s*(<\/(?!html)[-_\.A-Za-z0-9]+\b[^>]*>|-->|\})/ }, // Matches a number or word that either: // - Is a number with an optional negative sign and optional full number // with numbers following the decimal point. e.g `-1.1px`, `.5`, `-.42rem`, etc // - Is a sequence of characters without spaces and not containing // any of the following: `~!@$^&*()=+[{]}\|;:'",.<>/ // wordPattern: // eslint-disable-next-line max-len, no-useless-escape /(-?\d*\.\d\w*)|([^\`\~\!\@\$\#\^\&\*\(\)\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\s]+)/g, onEnterRules: [ { // Matches an opening tag that: // - Isn't an empty element // - Is possibly namespaced // - Isn't a void element // - Isn't followed by another tag on the same line // // eslint-disable-next-line no-useless-escape beforeText: new RegExp( `<(?!(?:${EMPTY_ELEMENTS.join( '|' )}))([_:\\w][_:\\w-.\\d]*)([^/>]*(?!/)>)[^<]*$`, 'i' ), // Matches a closing tag that: // - Is possibly namespaced // - Possibly has excess whitespace following tagname afterText: /^<\/([_:\w][_:\w-.\d]*)\s*>/i, action: { indentAction: IndentAction.IndentOutdent } }, { // Matches an opening tag that: // - Isn't an empty element // - Isn't namespaced // - Isn't a void element // - Isn't followed by another tag on the same line // // eslint-disable-next-line no-useless-escape beforeText: new RegExp( `<(?!(?:${EMPTY_ELEMENTS.join('|')}))(\\w[\\w\\d]*)([^/>]*(?!/)>)[^<]*$`, 'i' ), action: { indentAction: IndentAction.Indent } } ] }); return { getLS }; }