diff --git a/data/fixtures/recorded/fallback/takeToken2.yml b/data/fixtures/recorded/fallback/takeToken2.yml new file mode 100644 index 0000000000..bdcb9f8ce8 --- /dev/null +++ b/data/fixtures/recorded/fallback/takeToken2.yml @@ -0,0 +1,24 @@ +languageId: plaintext +focusedElementType: textEditor +command: + version: 7 + spokenForm: take token + action: + name: setSelection + target: + type: primitive + modifiers: + - type: containingScope + scopeType: {type: token} + usePrePhraseSnapshot: true +initialState: + documentContents: foo + selections: + - anchor: {line: 0, character: 0} + active: {line: 0, character: 0} + marks: {} +finalState: + documentContents: foo + selections: + - anchor: {line: 0, character: 0} + active: {line: 0, character: 3} diff --git a/packages/common/src/FakeCommandServerApi.ts b/packages/common/src/FakeCommandServerApi.ts index 8a96f44527..8ea7b91009 100644 --- a/packages/common/src/FakeCommandServerApi.ts +++ b/packages/common/src/FakeCommandServerApi.ts @@ -10,7 +10,6 @@ export class FakeCommandServerApi implements CommandServerApi { constructor() { this.signals = { prePhrase: { getVersion: async () => null } }; - this.focusedElementType = "textEditor"; } async getFocusedElementType(): Promise { diff --git a/packages/common/src/types/CommandServerApi.ts b/packages/common/src/types/CommandServerApi.ts index 96f1ecb3ae..0d3fdaa890 100644 --- a/packages/common/src/types/CommandServerApi.ts +++ b/packages/common/src/types/CommandServerApi.ts @@ -9,7 +9,7 @@ export interface CommandServerApi { }; } -export type FocusedElementType = "textEditor" | "terminal"; +export type FocusedElementType = "textEditor" | "terminal" | "other"; export interface InboundSignal { getVersion(): Promise; diff --git a/packages/common/src/types/TestCaseFixture.ts b/packages/common/src/types/TestCaseFixture.ts index 7b366e694a..c3030e2b40 100644 --- a/packages/common/src/types/TestCaseFixture.ts +++ b/packages/common/src/types/TestCaseFixture.ts @@ -15,7 +15,7 @@ interface TestCaseFixtureBase { /** * The type of element that is focused before the command is executed. If undefined default to text editor. */ - focusedElementType?: FocusedElementType | "other"; + focusedElementType?: FocusedElementType; /** * A list of marks to check in the case of navigation map test otherwise undefined diff --git a/packages/cursorless-engine/src/core/getCommandFallback.ts b/packages/cursorless-engine/src/core/getCommandFallback.ts index d69a4b86dc..941a02c0eb 100644 --- a/packages/cursorless-engine/src/core/getCommandFallback.ts +++ b/packages/cursorless-engine/src/core/getCommandFallback.ts @@ -14,10 +14,9 @@ export async function getCommandFallback( runAction: (actionDescriptor: ActionDescriptor) => Promise, command: CommandComplete, ): Promise { - if ( - commandServerApi == null || - (await commandServerApi.getFocusedElementType()) === "textEditor" - ) { + const focusedElementType = await commandServerApi?.getFocusedElementType(); + + if (focusedElementType == null || focusedElementType === "textEditor") { return null; } diff --git a/packages/cursorless-engine/src/testCaseRecorder/TestCase.ts b/packages/cursorless-engine/src/testCaseRecorder/TestCase.ts index 0dd2dad532..2d4959b496 100644 --- a/packages/cursorless-engine/src/testCaseRecorder/TestCase.ts +++ b/packages/cursorless-engine/src/testCaseRecorder/TestCase.ts @@ -141,9 +141,9 @@ export class TestCase { const fixture: EnforceUndefined = { languageId: this.languageId, focusedElementType: - this.focusedElementType !== "textEditor" - ? this.focusedElementType ?? "other" - : undefined, + this.focusedElementType === "textEditor" + ? undefined + : this.focusedElementType, postEditorOpenSleepTimeMs: undefined, postCommandSleepTimeMs: undefined, command: this.command, diff --git a/packages/cursorless-vscode-e2e/src/endToEndTestSetup.ts b/packages/cursorless-vscode-e2e/src/endToEndTestSetup.ts index a6fab13c66..4cfc633ecd 100644 --- a/packages/cursorless-vscode-e2e/src/endToEndTestSetup.ts +++ b/packages/cursorless-vscode-e2e/src/endToEndTestSetup.ts @@ -28,7 +28,9 @@ export function endToEndTestSetup(suite: Mocha.Suite) { const title = this.test!.fullTitle(); retryCount = title === previousTestTitle ? retryCount + 1 : 0; previousTestTitle = title; - ({ ide, injectIde } = (await getCursorlessApi()).testHelpers!); + const testHelpers = (await getCursorlessApi()).testHelpers!; + ({ ide, injectIde } = testHelpers); + testHelpers.commandServerApi.setFocusedElementType(undefined); spy = new SpyIDE(ide); injectIde(spy); }); diff --git a/packages/cursorless-vscode-e2e/src/suite/recorded.vscode.test.ts b/packages/cursorless-vscode-e2e/src/suite/recorded.vscode.test.ts index 22258d170c..5a759ce956 100644 --- a/packages/cursorless-vscode-e2e/src/suite/recorded.vscode.test.ts +++ b/packages/cursorless-vscode-e2e/src/suite/recorded.vscode.test.ts @@ -104,11 +104,7 @@ async function runTest(file: string, spyIde: SpyIDE) { // spyIde.clipboard.writeText(fixture.initialState.clipboard); } - commandServerApi.setFocusedElementType( - fixture.focusedElementType === "other" - ? undefined - : fixture.focusedElementType ?? "textEditor", - ); + commandServerApi.setFocusedElementType(fixture.focusedElementType); // Ensure that the expected hats are present await hatTokenMap.allocateHats(