Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'editors/code/src/commands.ts')
-rw-r--r--editors/code/src/commands.ts75
1 files changed, 74 insertions, 1 deletions
diff --git a/editors/code/src/commands.ts b/editors/code/src/commands.ts
index 2d5272d199..98ccd50dc0 100644
--- a/editors/code/src/commands.ts
+++ b/editors/code/src/commands.ts
@@ -8,10 +8,18 @@ import { applySnippetWorkspaceEdit, applySnippetTextEdits } from "./snippets";
import { spawnSync } from "child_process";
import { RunnableQuickPick, selectRunnable, createTask, createArgs } from "./run";
import { AstInspector } from "./ast_inspector";
-import { isRustDocument, isCargoTomlDocument, sleep, isRustEditor } from "./util";
+import {
+ isRustDocument,
+ isCargoTomlDocument,
+ sleep,
+ isRustEditor,
+ RustEditor,
+ RustDocument,
+} from "./util";
import { startDebugSession, makeDebugConfig } from "./debug";
import { LanguageClient } from "vscode-languageclient/node";
import { LINKED_COMMANDS } from "./client";
+import { DependencyId } from "./dependencies_provider";
export * from "./ast_inspector";
export * from "./run";
@@ -266,6 +274,71 @@ export function openCargoToml(ctx: CtxInit): Cmd {
};
}
+export function revealDependency(ctx: CtxInit): Cmd {
+ return async (editor: RustEditor) => {
+ if (!ctx.dependencies?.isInitialized()) {
+ return;
+ }
+ const documentPath = editor.document.uri.fsPath;
+ const dep = ctx.dependencies?.getDependency(documentPath);
+ if (dep) {
+ await ctx.treeView?.reveal(dep, { select: true, expand: true });
+ } else {
+ await revealParentChain(editor.document, ctx);
+ }
+ };
+}
+
+/**
+ * This function calculates the parent chain of a given file until it reaches it crate root contained in ctx.dependencies.
+ * This is need because the TreeView is Lazy, so at first it only has the root dependencies: For example if we have the following crates:
+ * - core
+ * - alloc
+ * - std
+ *
+ * if I want to reveal alloc/src/str.rs, I have to:
+
+ * 1. reveal every children of alloc
+ * - core
+ * - alloc\
+ *  |-beches\
+ *  |-src\
+ *  |- ...
+ * - std
+ * 2. reveal every children of src:
+ * core
+ * alloc\
+ *  |-beches\
+ *  |-src\
+ *   |- lib.rs\
+ * &emsp;&emsp;|- str.rs <------- FOUND IT!\
+ * &emsp;&emsp;|- ...\
+ * &emsp;|- ...\
+ * std
+ */
+async function revealParentChain(document: RustDocument, ctx: CtxInit) {
+ let documentPath = document.uri.fsPath;
+ const maxDepth = documentPath.split(path.sep).length - 1;
+ const parentChain: DependencyId[] = [{ id: documentPath.toLowerCase() }];
+ do {
+ documentPath = path.dirname(documentPath);
+ parentChain.push({ id: documentPath.toLowerCase() });
+ if (parentChain.length >= maxDepth) {
+ // this is an odd case that can happen when we change a crate version but we'd still have
+ // a open file referencing the old version
+ return;
+ }
+ } while (!ctx.dependencies?.contains(documentPath));
+ parentChain.reverse();
+ for (const idx in parentChain) {
+ await ctx.treeView?.reveal(parentChain[idx], { select: true, expand: true });
+ }
+}
+
+export async function execRevealDependency(e: RustEditor): Promise<void> {
+ await vscode.commands.executeCommand("rust-analyzer.revealDependency", e);
+}
+
export function ssr(ctx: CtxInit): Cmd {
return async () => {
const editor = vscode.window.activeTextEditor;