From f8b861a9db291ea5a7b74a36b4b5fae328c54ab3 Mon Sep 17 00:00:00 2001 From: Anthony Kim <62267334+anthonykim1@users.noreply.github.com> Date: Mon, 23 Sep 2024 14:52:03 -0400 Subject: [PATCH] Change PYTHONSTARTUP setting name to Python.terminal.shell integration.enabled (#24153) Resolves: https://github.com/microsoft/vscode-python/issues/24143 /cc @cwebster-99 @Tyriar --------- Co-authored-by: Daniel Imms <2193314+Tyriar@users.noreply.github.com> --- package.json | 4 ++-- package.nls.json | 2 +- src/client/common/configSettings.ts | 1 + src/client/common/types.ts | 2 +- src/client/terminals/pythonStartup.ts | 2 +- src/test/terminals/codeExecution/helper.test.ts | 1 - src/test/terminals/codeExecution/smartSend.test.ts | 1 - 7 files changed, 6 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index 940409ede228..eb197afee69b 100644 --- a/package.json +++ b/package.json @@ -658,9 +658,9 @@ "scope": "resource", "type": "array" }, - "python.REPL.enableShellIntegration": { + "python.terminal.shellIntegration.enabled": { "default": false, - "description": "%python.REPL.enableShellIntegration.description%", + "description": "%python.terminal.shellIntegration.enabled.description%", "scope": "resource", "type": "boolean", "tags": [ diff --git a/package.nls.json b/package.nls.json index f032f3d7c275..c92e21be5b61 100644 --- a/package.nls.json +++ b/package.nls.json @@ -65,10 +65,10 @@ "python.pixiToolPath.description": "Path to the pixi executable.", "python.EnableREPLSmartSend.description": "Toggle Smart Send for the Python REPL. Smart Send enables sending the smallest runnable block of code to the REPL on Shift+Enter and moves the cursor accordingly.", "python.REPL.sendToNativeREPL.description": "Toggle to send code to Python REPL instead of the terminal on execution. Turning this on will change the behavior for both Smart Send and Run Selection/Line in the Context Menu.", - "python.REPL.enableShellIntegration.description": "Enable Shell Integration for Python Terminal REPL. Shell Integration enhances the terminal experience by allowing command decorations, run recent command, and improving accessibility for Python REPL in the terminal.", "python.tensorBoard.logDirectory.description": "Set this setting to your preferred TensorBoard log directory to skip log directory prompt when starting TensorBoard.", "python.tensorBoard.logDirectory.markdownDeprecationMessage": "Tensorboard support has been moved to the extension [Tensorboard extension](https://marketplace.visualstudio.com/items?itemName=ms-toolsai.tensorboard). Instead use the setting `tensorBoard.logDirectory`.", "python.tensorBoard.logDirectory.deprecationMessage": "Tensorboard support has been moved to the extension Tensorboard extension. Instead use the setting `tensorBoard.logDirectory`.", + "python.terminal.shellIntegration.enabled.description": "Enable [shell integration](https://code.visualstudio.com/docs/terminal/shell-integration) for the terminals running python. Shell integration enhances the terminal experience by enabling command decorations, run recent command, improving accessibility among other things.", "python.terminal.activateEnvInCurrentTerminal.description": "Activate Python Environment in the current Terminal on load of the Extension.", "python.terminal.activateEnvironment.description": "Activate Python Environment in all Terminals created.", "python.terminal.executeInFileDir.description": "When executing a file in the terminal, whether to use execute in the file's directory, instead of the current open folder.", diff --git a/src/client/common/configSettings.ts b/src/client/common/configSettings.ts index 6cae60c9fb97..1b637e7aac2d 100644 --- a/src/client/common/configSettings.ts +++ b/src/client/common/configSettings.ts @@ -368,6 +368,7 @@ export class PythonSettings implements IPythonSettings { launchArgs: [], activateEnvironment: true, activateEnvInCurrentTerminal: false, + enableShellIntegration: false, }; this.REPL = pythonSettings.get('REPL')!; diff --git a/src/client/common/types.ts b/src/client/common/types.ts index 283319fd6cec..035e6ec4638b 100644 --- a/src/client/common/types.ts +++ b/src/client/common/types.ts @@ -197,12 +197,12 @@ export interface ITerminalSettings { readonly launchArgs: string[]; readonly activateEnvironment: boolean; readonly activateEnvInCurrentTerminal: boolean; + readonly enableShellIntegration: boolean; } export interface IREPLSettings { readonly enableREPLSmartSend: boolean; readonly sendToNativeREPL: boolean; - readonly enableShellIntegration: boolean; } export interface IExperiments { diff --git a/src/client/terminals/pythonStartup.ts b/src/client/terminals/pythonStartup.ts index 9a6b956d7f6e..542a2e6a6355 100644 --- a/src/client/terminals/pythonStartup.ts +++ b/src/client/terminals/pythonStartup.ts @@ -8,7 +8,7 @@ import { EXTENSION_ROOT_DIR } from '../constants'; export async function registerPythonStartup(context: ExtensionContext): Promise { const config = getConfiguration('python'); - const pythonrcSetting = config.get('REPL.enableShellIntegration'); + const pythonrcSetting = config.get('terminal.shellIntegration.enabled'); if (pythonrcSetting) { const storageUri = context.storageUri || context.globalStorageUri; diff --git a/src/test/terminals/codeExecution/helper.test.ts b/src/test/terminals/codeExecution/helper.test.ts index e15c41957726..ebadd153705e 100644 --- a/src/test/terminals/codeExecution/helper.test.ts +++ b/src/test/terminals/codeExecution/helper.test.ts @@ -116,7 +116,6 @@ suite('Terminal - Code Execution Helper', () => { enableREPLSmartSend: false, REPLSmartSend: false, sendToNativeREPL: false, - enableShellIntegration: true, })); configurationService.setup((x) => x.getSettings(TypeMoq.It.isAny())).returns(() => pythonSettings.object); configurationService diff --git a/src/test/terminals/codeExecution/smartSend.test.ts b/src/test/terminals/codeExecution/smartSend.test.ts index 594db361f51e..f315bc004d4e 100644 --- a/src/test/terminals/codeExecution/smartSend.test.ts +++ b/src/test/terminals/codeExecution/smartSend.test.ts @@ -113,7 +113,6 @@ suite('REPL - Smart Send', () => { enableREPLSmartSend: true, REPLSmartSend: true, sendToNativeREPL: false, - enableShellIntegration: true, })); configurationService.setup((x) => x.getSettings(TypeMoq.It.isAny())).returns(() => pythonSettings.object);