Move expand macro to the new context

This commit is contained in:
Aleksey Kladov 2019-12-30 19:30:30 +01:00
parent 68f47a5b10
commit 94be27fc44
5 changed files with 53 additions and 75 deletions

View file

@ -37,7 +37,7 @@ export function analyzerStatus(ctx: Ctx): Cmd {
class TextDocumentContentProvider class TextDocumentContentProvider
implements vscode.TextDocumentContentProvider { implements vscode.TextDocumentContentProvider {
ctx: Ctx; private ctx: Ctx;
uri = vscode.Uri.parse('rust-analyzer-status://status'); uri = vscode.Uri.parse('rust-analyzer-status://status');
eventEmitter = new vscode.EventEmitter<vscode.Uri>(); eventEmitter = new vscode.EventEmitter<vscode.Uri>();

View file

@ -1,60 +1,23 @@
import * as vscode from 'vscode'; import * as vscode from 'vscode';
import { Position, TextDocumentIdentifier } from 'vscode-languageclient'; import * as lc from 'vscode-languageclient';
import { Server } from '../server';
export const expandMacroUri = vscode.Uri.parse( import { Ctx, Cmd } from '../ctx';
'rust-analyzer://expandMacro/[EXPANSION].rs',
);
export class ExpandMacroContentProvider
implements vscode.TextDocumentContentProvider {
public eventEmitter = new vscode.EventEmitter<vscode.Uri>();
public provideTextDocumentContent(
_uri: vscode.Uri,
): vscode.ProviderResult<string> {
async function handle() {
const editor = vscode.window.activeTextEditor;
if (editor == null) {
return '';
}
const position = editor.selection.active;
const request: MacroExpandParams = {
textDocument: { uri: editor.document.uri.toString() },
position,
};
const expanded = await Server.client.sendRequest<ExpandedMacro>(
'rust-analyzer/expandMacro',
request,
);
if (expanded == null) {
return 'Not available';
}
return code_format(expanded);
}
return handle();
}
get onDidChange(): vscode.Event<vscode.Uri> {
return this.eventEmitter.event;
}
}
// Opens the virtual file that will show the syntax tree // Opens the virtual file that will show the syntax tree
// //
// The contents of the file come from the `TextDocumentContentProvider` // The contents of the file come from the `TextDocumentContentProvider`
export function createHandle(provider: ExpandMacroContentProvider) { export function expandMacro(ctx: Ctx): Cmd {
const tdcp = new TextDocumentContentProvider(ctx);
ctx.pushCleanup(
vscode.workspace.registerTextDocumentContentProvider(
'rust-analyzer',
tdcp,
),
);
return async () => { return async () => {
const uri = expandMacroUri; const document = await vscode.workspace.openTextDocument(tdcp.uri);
tdcp.eventEmitter.fire(tdcp.uri);
const document = await vscode.workspace.openTextDocument(uri);
provider.eventEmitter.fire(uri);
return vscode.window.showTextDocument( return vscode.window.showTextDocument(
document, document,
vscode.ViewColumn.Two, vscode.ViewColumn.Two,
@ -63,11 +26,6 @@ export function createHandle(provider: ExpandMacroContentProvider) {
}; };
} }
interface MacroExpandParams {
textDocument: TextDocumentIdentifier;
position: Position;
}
interface ExpandedMacro { interface ExpandedMacro {
name: string; name: string;
expansion: string; expansion: string;
@ -81,3 +39,37 @@ function code_format(expanded: ExpandedMacro): string {
return result; return result;
} }
class TextDocumentContentProvider
implements vscode.TextDocumentContentProvider {
private ctx: Ctx;
uri = vscode.Uri.parse('rust-analyzer://expandMacro/[EXPANSION].rs');
eventEmitter = new vscode.EventEmitter<vscode.Uri>();
constructor(ctx: Ctx) {
this.ctx = ctx;
}
async provideTextDocumentContent(_uri: vscode.Uri): Promise<string> {
const editor = vscode.window.activeTextEditor;
if (editor == null) return '';
const position = editor.selection.active;
const request: lc.TextDocumentPositionParams = {
textDocument: { uri: editor.document.uri.toString() },
position,
};
const expanded = await this.ctx.client.sendRequest<ExpandedMacro>(
'rust-analyzer/expandMacro',
request,
);
if (expanded == null) return 'Not available';
return code_format(expanded);
}
get onDidChange(): vscode.Event<vscode.Uri> {
return this.eventEmitter.event;
}
}

View file

@ -6,7 +6,7 @@ import { joinLines } from './join_lines';
import { onEnter } from './on_enter'; import { onEnter } from './on_enter';
import { parentModule } from './parent_module'; import { parentModule } from './parent_module';
import { syntaxTree } from './syntax_tree'; import { syntaxTree } from './syntax_tree';
import * as expandMacro from './expand_macro'; import { expandMacro } from './expand_macro';
import * as inlayHints from './inlay_hints'; import * as inlayHints from './inlay_hints';
import * as runnables from './runnables'; import * as runnables from './runnables';

View file

@ -66,10 +66,9 @@ interface SyntaxTreeParams {
class TextDocumentContentProvider class TextDocumentContentProvider
implements vscode.TextDocumentContentProvider { implements vscode.TextDocumentContentProvider {
ctx: Ctx; private ctx: Ctx;
uri = vscode.Uri.parse('rust-analyzer://syntaxtree'); uri = vscode.Uri.parse('rust-analyzer://syntaxtree');
eventEmitter = new vscode.EventEmitter<vscode.Uri>(); eventEmitter = new vscode.EventEmitter<vscode.Uri>();
syntaxTree: string = 'Not available';
constructor(ctx: Ctx) { constructor(ctx: Ctx) {
this.ctx = ctx; this.ctx = ctx;
@ -86,8 +85,8 @@ class TextDocumentContentProvider
range = editor.selection.isEmpty range = editor.selection.isEmpty
? undefined ? undefined
: this.ctx.client.code2ProtocolConverter.asRange( : this.ctx.client.code2ProtocolConverter.asRange(
editor.selection, editor.selection,
); );
} }
const request: SyntaxTreeParams = { const request: SyntaxTreeParams = {

View file

@ -2,7 +2,6 @@ import * as vscode from 'vscode';
import * as lc from 'vscode-languageclient'; import * as lc from 'vscode-languageclient';
import * as commands from './commands'; import * as commands from './commands';
import { ExpandMacroContentProvider } from './commands/expand_macro';
import { HintsUpdater } from './commands/inlay_hints'; import { HintsUpdater } from './commands/inlay_hints';
import { StatusDisplay } from './commands/watch_status'; import { StatusDisplay } from './commands/watch_status';
import * as events from './events'; import * as events from './events';
@ -20,6 +19,7 @@ export async function activate(context: vscode.ExtensionContext) {
ctx.registerCommand('joinLines', commands.joinLines); ctx.registerCommand('joinLines', commands.joinLines);
ctx.registerCommand('parentModule', commands.parentModule); ctx.registerCommand('parentModule', commands.parentModule);
ctx.registerCommand('syntaxTree', commands.syntaxTree); ctx.registerCommand('syntaxTree', commands.syntaxTree);
ctx.registerCommand('expandMacro', commands.expandMacro);
function disposeOnDeactivation(disposable: vscode.Disposable) { function disposeOnDeactivation(disposable: vscode.Disposable) {
context.subscriptions.push(disposable); context.subscriptions.push(disposable);
@ -65,25 +65,12 @@ export async function activate(context: vscode.ExtensionContext) {
params => watchStatus.handleProgressNotification(params), params => watchStatus.handleProgressNotification(params),
], ],
]; ];
const expandMacroContentProvider = new ExpandMacroContentProvider();
// The events below are plain old javascript events, triggered and handled by vscode // The events below are plain old javascript events, triggered and handled by vscode
vscode.window.onDidChangeActiveTextEditor( vscode.window.onDidChangeActiveTextEditor(
events.changeActiveTextEditor.makeHandler(), events.changeActiveTextEditor.makeHandler(),
); );
disposeOnDeactivation(
vscode.workspace.registerTextDocumentContentProvider(
'rust-analyzer',
expandMacroContentProvider,
),
);
registerCommand(
'rust-analyzer.expandMacro',
commands.expandMacro.createHandle(expandMacroContentProvider),
);
const startServer = () => Server.start(allNotifications); const startServer = () => Server.start(allNotifications);
const reloadCommand = () => reloadServer(startServer); const reloadCommand = () => reloadServer(startServer);