@google/gemini-cli 0.1.15 → 0.1.16

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (114) hide show
  1. package/README.md +32 -0
  2. package/dist/google-gemini-cli-0.1.15.tgz +0 -0
  3. package/dist/package.json +2 -2
  4. package/dist/src/config/config.d.ts +4 -2
  5. package/dist/src/config/config.js +36 -14
  6. package/dist/src/config/config.js.map +1 -1
  7. package/dist/src/config/extension.d.ts +1 -0
  8. package/dist/src/config/extension.js +4 -0
  9. package/dist/src/config/extension.js.map +1 -1
  10. package/dist/src/config/settings.d.ts +6 -0
  11. package/dist/src/config/settings.js +34 -18
  12. package/dist/src/config/settings.js.map +1 -1
  13. package/dist/src/gemini.d.ts +2 -0
  14. package/dist/src/gemini.js +30 -3
  15. package/dist/src/gemini.js.map +1 -1
  16. package/dist/src/generated/git-commit.d.ts +1 -1
  17. package/dist/src/generated/git-commit.js +1 -1
  18. package/dist/src/nonInteractiveCli.js +15 -40
  19. package/dist/src/nonInteractiveCli.js.map +1 -1
  20. package/dist/src/services/BuiltinCommandLoader.js +8 -1
  21. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  22. package/dist/src/services/CommandService.d.ts +8 -4
  23. package/dist/src/services/CommandService.js +24 -8
  24. package/dist/src/services/CommandService.js.map +1 -1
  25. package/dist/src/services/FileCommandLoader.d.ts +15 -3
  26. package/dist/src/services/FileCommandLoader.js +64 -35
  27. package/dist/src/services/FileCommandLoader.js.map +1 -1
  28. package/dist/src/ui/App.js +29 -16
  29. package/dist/src/ui/App.js.map +1 -1
  30. package/dist/src/ui/commands/chatCommand.js +39 -1
  31. package/dist/src/ui/commands/chatCommand.js.map +1 -1
  32. package/dist/src/ui/commands/directoryCommand.d.ts +8 -0
  33. package/dist/src/ui/commands/directoryCommand.js +116 -0
  34. package/dist/src/ui/commands/directoryCommand.js.map +1 -0
  35. package/dist/src/ui/commands/ideCommand.js +101 -105
  36. package/dist/src/ui/commands/ideCommand.js.map +1 -1
  37. package/dist/src/ui/commands/initCommand.d.ts +7 -0
  38. package/dist/src/ui/commands/initCommand.js +76 -0
  39. package/dist/src/ui/commands/initCommand.js.map +1 -0
  40. package/dist/src/ui/commands/memoryCommand.js +2 -1
  41. package/dist/src/ui/commands/memoryCommand.js.map +1 -1
  42. package/dist/src/ui/commands/setupGithubCommand.d.ts +7 -0
  43. package/dist/src/ui/commands/setupGithubCommand.js +49 -0
  44. package/dist/src/ui/commands/setupGithubCommand.js.map +1 -0
  45. package/dist/src/ui/commands/types.d.ts +1 -0
  46. package/dist/src/ui/components/ContextSummaryDisplay.d.ts +2 -2
  47. package/dist/src/ui/components/ContextSummaryDisplay.js +8 -8
  48. package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
  49. package/dist/src/ui/components/DebugProfiler.d.ts +6 -0
  50. package/dist/src/ui/components/DebugProfiler.js +26 -0
  51. package/dist/src/ui/components/DebugProfiler.js.map +1 -0
  52. package/dist/src/ui/components/Footer.js +3 -2
  53. package/dist/src/ui/components/Footer.js.map +1 -1
  54. package/dist/src/ui/components/Help.js +2 -2
  55. package/dist/src/ui/components/Help.js.map +1 -1
  56. package/dist/src/ui/components/IDEContextDetailDisplay.d.ts +4 -3
  57. package/dist/src/ui/components/IDEContextDetailDisplay.js +6 -13
  58. package/dist/src/ui/components/IDEContextDetailDisplay.js.map +1 -1
  59. package/dist/src/ui/components/InputPrompt.js +8 -1
  60. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  61. package/dist/src/ui/components/messages/ToolConfirmationMessage.js +15 -4
  62. package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
  63. package/dist/src/ui/components/messages/UserMessage.js +4 -1
  64. package/dist/src/ui/components/messages/UserMessage.js.map +1 -1
  65. package/dist/src/ui/components/shared/text-buffer.js +9 -14
  66. package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
  67. package/dist/src/ui/editors/editorSettingsManager.js +6 -13
  68. package/dist/src/ui/editors/editorSettingsManager.js.map +1 -1
  69. package/dist/src/ui/hooks/atCommandProcessor.js +56 -48
  70. package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
  71. package/dist/src/ui/hooks/slashCommandProcessor.js +12 -2
  72. package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
  73. package/dist/src/ui/hooks/useCompletion.d.ts +1 -1
  74. package/dist/src/ui/hooks/useCompletion.js +142 -126
  75. package/dist/src/ui/hooks/useCompletion.js.map +1 -1
  76. package/dist/src/ui/hooks/useGeminiStream.js +5 -2
  77. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  78. package/dist/src/ui/hooks/usePhraseCycler.js +1 -0
  79. package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
  80. package/dist/src/ui/hooks/useReactToolScheduler.js +0 -1
  81. package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
  82. package/dist/src/ui/utils/updateCheck.d.ts +7 -1
  83. package/dist/src/ui/utils/updateCheck.js +46 -8
  84. package/dist/src/ui/utils/updateCheck.js.map +1 -1
  85. package/dist/src/utils/gitUtils.d.ts +10 -0
  86. package/dist/src/utils/gitUtils.js +24 -0
  87. package/dist/src/utils/gitUtils.js.map +1 -0
  88. package/dist/src/utils/handleAutoUpdate.d.ts +11 -0
  89. package/dist/src/utils/handleAutoUpdate.js +98 -0
  90. package/dist/src/utils/handleAutoUpdate.js.map +1 -0
  91. package/dist/src/utils/installationInfo.d.ts +23 -0
  92. package/dist/src/utils/installationInfo.js +154 -0
  93. package/dist/src/utils/installationInfo.js.map +1 -0
  94. package/dist/src/utils/sandbox-macos-permissive-closed.sb +6 -0
  95. package/dist/src/utils/sandbox-macos-permissive-open.sb +6 -0
  96. package/dist/src/utils/sandbox-macos-permissive-proxied.sb +6 -0
  97. package/dist/src/utils/sandbox-macos-restrictive-closed.sb +6 -0
  98. package/dist/src/utils/sandbox-macos-restrictive-open.sb +6 -0
  99. package/dist/src/utils/sandbox-macos-restrictive-proxied.sb +6 -0
  100. package/dist/src/utils/sandbox.d.ts +2 -2
  101. package/dist/src/utils/sandbox.js +35 -11
  102. package/dist/src/utils/sandbox.js.map +1 -1
  103. package/dist/src/utils/spawnWrapper.d.ts +7 -0
  104. package/dist/src/utils/spawnWrapper.js +8 -0
  105. package/dist/src/utils/spawnWrapper.js.map +1 -0
  106. package/dist/src/utils/updateEventEmitter.d.ts +11 -0
  107. package/dist/src/utils/updateEventEmitter.js +12 -0
  108. package/dist/src/utils/updateEventEmitter.js.map +1 -0
  109. package/dist/src/validateNonInterActiveAuth.d.ts +1 -1
  110. package/dist/src/validateNonInterActiveAuth.js +7 -5
  111. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  112. package/dist/tsconfig.tsbuildinfo +1 -1
  113. package/package.json +3 -3
  114. package/dist/google-gemini-cli-0.1.13.tgz +0 -0
@@ -3,27 +3,8 @@
3
3
  * Copyright 2025 Google LLC
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
- import { executeToolCall, shutdownTelemetry, isTelemetrySdkInitialized, } from '@google/gemini-cli-core';
6
+ import { executeToolCall, shutdownTelemetry, isTelemetrySdkInitialized, GeminiEventType, ToolErrorType, } from '@google/gemini-cli-core';
7
7
  import { parseAndFormatApiError } from './ui/utils/errorParsing.js';
8
- function getResponseText(response) {
9
- if (response.candidates && response.candidates.length > 0) {
10
- const candidate = response.candidates[0];
11
- if (candidate.content &&
12
- candidate.content.parts &&
13
- candidate.content.parts.length > 0) {
14
- // We are running in headless mode so we don't need to return thoughts to STDOUT.
15
- const thoughtPart = candidate.content.parts[0];
16
- if (thoughtPart?.thought) {
17
- return null;
18
- }
19
- return candidate.content.parts
20
- .filter((part) => part.text)
21
- .map((part) => part.text)
22
- .join('');
23
- }
24
- }
25
- return null;
26
- }
27
8
  export async function runNonInteractive(config, input, prompt_id) {
28
9
  await config.initialize();
29
10
  // Handle EPIPE errors when the output is piped to a command that closes early.
@@ -35,39 +16,35 @@ export async function runNonInteractive(config, input, prompt_id) {
35
16
  });
36
17
  const geminiClient = config.getGeminiClient();
37
18
  const toolRegistry = await config.getToolRegistry();
38
- const chat = await geminiClient.getChat();
39
19
  const abortController = new AbortController();
40
20
  let currentMessages = [{ role: 'user', parts: [{ text: input }] }];
41
21
  let turnCount = 0;
42
22
  try {
43
23
  while (true) {
44
24
  turnCount++;
45
- if (config.getMaxSessionTurns() > 0 &&
25
+ if (config.getMaxSessionTurns() >= 0 &&
46
26
  turnCount > config.getMaxSessionTurns()) {
47
27
  console.error('\n Reached max session turns for this session. Increase the number of turns by specifying maxSessionTurns in settings.json.');
48
28
  return;
49
29
  }
50
30
  const functionCalls = [];
51
- const responseStream = await chat.sendMessageStream({
52
- message: currentMessages[0]?.parts || [], // Ensure parts are always provided
53
- config: {
54
- abortSignal: abortController.signal,
55
- tools: [
56
- { functionDeclarations: toolRegistry.getFunctionDeclarations() },
57
- ],
58
- },
59
- }, prompt_id);
60
- for await (const resp of responseStream) {
31
+ const responseStream = geminiClient.sendMessageStream(currentMessages[0]?.parts || [], abortController.signal, prompt_id);
32
+ for await (const event of responseStream) {
61
33
  if (abortController.signal.aborted) {
62
34
  console.error('Operation cancelled.');
63
35
  return;
64
36
  }
65
- const textPart = getResponseText(resp);
66
- if (textPart) {
67
- process.stdout.write(textPart);
37
+ if (event.type === GeminiEventType.Content) {
38
+ process.stdout.write(event.value);
68
39
  }
69
- if (resp.functionCalls) {
70
- functionCalls.push(...resp.functionCalls);
40
+ else if (event.type === GeminiEventType.ToolCallRequest) {
41
+ const toolCallRequest = event.value;
42
+ const fc = {
43
+ name: toolCallRequest.name,
44
+ args: toolCallRequest.args,
45
+ id: toolCallRequest.callId,
46
+ };
47
+ functionCalls.push(fc);
71
48
  }
72
49
  }
73
50
  if (functionCalls.length > 0) {
@@ -83,11 +60,9 @@ export async function runNonInteractive(config, input, prompt_id) {
83
60
  };
84
61
  const toolResponse = await executeToolCall(config, requestInfo, toolRegistry, abortController.signal);
85
62
  if (toolResponse.error) {
86
- const isToolNotFound = toolResponse.error.message.includes('not found in registry');
87
63
  console.error(`Error executing tool ${fc.name}: ${toolResponse.resultDisplay || toolResponse.error.message}`);
88
- if (!isToolNotFound) {
64
+ if (toolResponse.errorType === ToolErrorType.UNHANDLED_EXCEPTION)
89
65
  process.exit(1);
90
- }
91
66
  }
92
67
  if (toolResponse.responseParts) {
93
68
  const parts = Array.isArray(toolResponse.responseParts)
@@ -1 +1 @@
1
- {"version":3,"file":"nonInteractiveCli.js","sourceRoot":"","sources":["../../src/nonInteractiveCli.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"nonInteractiveCli.js","sourceRoot":"","sources":["../../src/nonInteractiveCli.ts"],"names":[],"mappings":"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"}
@@ -12,10 +12,12 @@ import { compressCommand } from '../ui/commands/compressCommand.js';
12
12
  import { copyCommand } from '../ui/commands/copyCommand.js';
13
13
  import { corgiCommand } from '../ui/commands/corgiCommand.js';
14
14
  import { docsCommand } from '../ui/commands/docsCommand.js';
15
+ import { directoryCommand } from '../ui/commands/directoryCommand.js';
15
16
  import { editorCommand } from '../ui/commands/editorCommand.js';
16
17
  import { extensionsCommand } from '../ui/commands/extensionsCommand.js';
17
18
  import { helpCommand } from '../ui/commands/helpCommand.js';
18
19
  import { ideCommand } from '../ui/commands/ideCommand.js';
20
+ import { initCommand } from '../ui/commands/initCommand.js';
19
21
  import { mcpCommand } from '../ui/commands/mcpCommand.js';
20
22
  import { memoryCommand } from '../ui/commands/memoryCommand.js';
21
23
  import { privacyCommand } from '../ui/commands/privacyCommand.js';
@@ -25,6 +27,8 @@ import { statsCommand } from '../ui/commands/statsCommand.js';
25
27
  import { themeCommand } from '../ui/commands/themeCommand.js';
26
28
  import { toolsCommand } from '../ui/commands/toolsCommand.js';
27
29
  import { vimCommand } from '../ui/commands/vimCommand.js';
30
+ import { setupGithubCommand } from '../ui/commands/setupGithubCommand.js';
31
+ import { isGitHubRepository } from '../utils/gitUtils.js';
28
32
  /**
29
33
  * Loads the core, hard-coded slash commands that are an integral part
30
34
  * of the Gemini CLI application.
@@ -52,19 +56,22 @@ export class BuiltinCommandLoader {
52
56
  copyCommand,
53
57
  corgiCommand,
54
58
  docsCommand,
59
+ directoryCommand,
55
60
  editorCommand,
56
61
  extensionsCommand,
57
62
  helpCommand,
58
63
  ideCommand(this.config),
64
+ initCommand,
65
+ mcpCommand,
59
66
  memoryCommand,
60
67
  privacyCommand,
61
- mcpCommand,
62
68
  quitCommand,
63
69
  restoreCommand(this.config),
64
70
  statsCommand,
65
71
  themeCommand,
66
72
  toolsCommand,
67
73
  vimCommand,
74
+ ...(isGitHubRepository() ? [setupGithubCommand] : []),
68
75
  ];
69
76
  return allDefinitions.filter((cmd) => cmd !== null);
70
77
  }
@@ -1 +1 @@
1
- {"version":3,"file":"BuiltinCommandLoader.js","sourceRoot":"","sources":["../../../src/services/BuiltinCommandLoader.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAE1D;;;GAGG;AACH,MAAM,OAAO,oBAAoB;IACX;IAApB,YAAoB,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAE7C;;;;;;OAMG;IACH,KAAK,CAAC,YAAY,CAAC,OAAoB;QACrC,MAAM,cAAc,GAA+B;YACjD,YAAY;YACZ,WAAW;YACX,UAAU;YACV,WAAW;YACX,YAAY;YACZ,eAAe;YACf,WAAW;YACX,YAAY;YACZ,WAAW;YACX,aAAa;YACb,iBAAiB;YACjB,WAAW;YACX,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC;YACvB,aAAa;YACb,cAAc;YACd,UAAU;YACV,WAAW;YACX,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC;YAC3B,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,UAAU;SACX,CAAC;QAEF,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,EAAuB,EAAE,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;IAC3E,CAAC;CACF"}
1
+ {"version":3,"file":"BuiltinCommandLoader.js","sourceRoot":"","sources":["../../../src/services/BuiltinCommandLoader.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AACtE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D;;;GAGG;AACH,MAAM,OAAO,oBAAoB;IACX;IAApB,YAAoB,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAE7C;;;;;;OAMG;IACH,KAAK,CAAC,YAAY,CAAC,OAAoB;QACrC,MAAM,cAAc,GAA+B;YACjD,YAAY;YACZ,WAAW;YACX,UAAU;YACV,WAAW;YACX,YAAY;YACZ,eAAe;YACf,WAAW;YACX,YAAY;YACZ,WAAW;YACX,gBAAgB;YAChB,aAAa;YACb,iBAAiB;YACjB,WAAW;YACX,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC;YACvB,WAAW;YACX,UAAU;YACV,aAAa;YACb,cAAc;YACd,WAAW;YACX,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC;YAC3B,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,UAAU;YACV,GAAG,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;SACtD,CAAC;QAEF,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,EAAuB,EAAE,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;IAC3E,CAAC;CACF"}
@@ -28,13 +28,17 @@ export declare class CommandService {
28
28
  *
29
29
  * This factory method orchestrates the entire command loading process. It
30
30
  * runs all provided loaders in parallel, aggregates their results, handles
31
- * name conflicts by letting the last-loaded command win, and then returns a
31
+ * name conflicts for extension commands by renaming them, and then returns a
32
32
  * fully constructed `CommandService` instance.
33
33
  *
34
+ * Conflict resolution:
35
+ * - Extension commands that conflict with existing commands are renamed to
36
+ * `extensionName.commandName`
37
+ * - Non-extension commands (built-in, user, project) override earlier commands
38
+ * with the same name based on loader order
39
+ *
34
40
  * @param loaders An array of objects that conform to the `ICommandLoader`
35
- * interface. The order of loaders is significant: if multiple loaders
36
- * provide a command with the same name, the command from the loader that
37
- * appears later in the array will take precedence.
41
+ * interface. Built-in commands should come first, followed by FileCommandLoader.
38
42
  * @param signal An AbortSignal to cancel the loading process.
39
43
  * @returns A promise that resolves to a new, fully initialized `CommandService` instance.
40
44
  */
@@ -28,13 +28,17 @@ export class CommandService {
28
28
  *
29
29
  * This factory method orchestrates the entire command loading process. It
30
30
  * runs all provided loaders in parallel, aggregates their results, handles
31
- * name conflicts by letting the last-loaded command win, and then returns a
31
+ * name conflicts for extension commands by renaming them, and then returns a
32
32
  * fully constructed `CommandService` instance.
33
33
  *
34
+ * Conflict resolution:
35
+ * - Extension commands that conflict with existing commands are renamed to
36
+ * `extensionName.commandName`
37
+ * - Non-extension commands (built-in, user, project) override earlier commands
38
+ * with the same name based on loader order
39
+ *
34
40
  * @param loaders An array of objects that conform to the `ICommandLoader`
35
- * interface. The order of loaders is significant: if multiple loaders
36
- * provide a command with the same name, the command from the loader that
37
- * appears later in the array will take precedence.
41
+ * interface. Built-in commands should come first, followed by FileCommandLoader.
38
42
  * @param signal An AbortSignal to cancel the loading process.
39
43
  * @returns A promise that resolves to a new, fully initialized `CommandService` instance.
40
44
  */
@@ -49,12 +53,24 @@ export class CommandService {
49
53
  console.debug('A command loader failed:', result.reason);
50
54
  }
51
55
  }
52
- // De-duplicate commands using a Map. The last one found with a given name wins.
53
- // This creates a natural override system based on the order of the loaders
54
- // passed to the constructor.
55
56
  const commandMap = new Map();
56
57
  for (const cmd of allCommands) {
57
- commandMap.set(cmd.name, cmd);
58
+ let finalName = cmd.name;
59
+ // Extension commands get renamed if they conflict with existing commands
60
+ if (cmd.extensionName && commandMap.has(cmd.name)) {
61
+ let renamedName = `${cmd.extensionName}.${cmd.name}`;
62
+ let suffix = 1;
63
+ // Keep trying until we find a name that doesn't conflict
64
+ while (commandMap.has(renamedName)) {
65
+ renamedName = `${cmd.extensionName}.${cmd.name}${suffix}`;
66
+ suffix++;
67
+ }
68
+ finalName = renamedName;
69
+ }
70
+ commandMap.set(finalName, {
71
+ ...cmd,
72
+ name: finalName,
73
+ });
58
74
  }
59
75
  const finalCommands = Object.freeze(Array.from(commandMap.values()));
60
76
  return new CommandService(finalCommands);
@@ -1 +1 @@
1
- {"version":3,"file":"CommandService.js","sourceRoot":"","sources":["../../../src/services/CommandService.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH;;;;;;;;;;GAUG;AACH,MAAM,OAAO,cAAc;IAKY;IAJrC;;;OAGG;IACH,YAAqC,QAAiC;QAAjC,aAAQ,GAAR,QAAQ,CAAyB;IAAG,CAAC;IAE1E;;;;;;;;;;;;;;OAcG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CACjB,OAAyB,EACzB,MAAmB;QAEnB,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,UAAU,CACtC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CACrD,CAAC;QAEF,MAAM,WAAW,GAAmB,EAAE,CAAC;QACvC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;gBAClC,WAAW,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,0BAA0B,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;QAED,gFAAgF;QAChF,2EAA2E;QAC3E,6BAA6B;QAC7B,MAAM,UAAU,GAAG,IAAI,GAAG,EAAwB,CAAC;QACnD,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACrE,OAAO,IAAI,cAAc,CAAC,aAAa,CAAC,CAAC;IAC3C,CAAC;IAED;;;;;;;OAOG;IACH,WAAW;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;CACF"}
1
+ {"version":3,"file":"CommandService.js","sourceRoot":"","sources":["../../../src/services/CommandService.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH;;;;;;;;;;GAUG;AACH,MAAM,OAAO,cAAc;IAKY;IAJrC;;;OAGG;IACH,YAAqC,QAAiC;QAAjC,aAAQ,GAAR,QAAQ,CAAyB;IAAG,CAAC;IAE1E;;;;;;;;;;;;;;;;;;OAkBG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CACjB,OAAyB,EACzB,MAAmB;QAEnB,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,UAAU,CACtC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CACrD,CAAC;QAEF,MAAM,WAAW,GAAmB,EAAE,CAAC;QACvC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;gBAClC,WAAW,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,0BAA0B,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,GAAG,EAAwB,CAAC;QACnD,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,IAAI,SAAS,GAAG,GAAG,CAAC,IAAI,CAAC;YAEzB,yEAAyE;YACzE,IAAI,GAAG,CAAC,aAAa,IAAI,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBAClD,IAAI,WAAW,GAAG,GAAG,GAAG,CAAC,aAAa,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC;gBACrD,IAAI,MAAM,GAAG,CAAC,CAAC;gBAEf,yDAAyD;gBACzD,OAAO,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC;oBACnC,WAAW,GAAG,GAAG,GAAG,CAAC,aAAa,IAAI,GAAG,CAAC,IAAI,GAAG,MAAM,EAAE,CAAC;oBAC1D,MAAM,EAAE,CAAC;gBACX,CAAC;gBAED,SAAS,GAAG,WAAW,CAAC;YAC1B,CAAC;YAED,UAAU,CAAC,GAAG,CAAC,SAAS,EAAE;gBACxB,GAAG,GAAG;gBACN,IAAI,EAAE,SAAS;aAChB,CAAC,CAAC;QACL,CAAC;QAED,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACrE,OAAO,IAAI,cAAc,CAAC,aAAa,CAAC,CAAC;IAC3C,CAAC;IAED;;;;;;;OAOG;IACH,WAAW;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;CACF"}
@@ -21,16 +21,28 @@ export declare class FileCommandLoader implements ICommandLoader {
21
21
  private readonly projectRoot;
22
22
  constructor(config: Config | null);
23
23
  /**
24
- * Loads all commands, applying the precedence rule where project-level
25
- * commands override user-level commands with the same name.
24
+ * Loads all commands from user, project, and extension directories.
25
+ * Returns commands in order: user project extensions (alphabetically).
26
+ *
27
+ * Order is important for conflict resolution in CommandService:
28
+ * - User/project commands (without extensionName) use "last wins" strategy
29
+ * - Extension commands (with extensionName) get renamed if conflicts exist
30
+ *
26
31
  * @param signal An AbortSignal to cancel the loading process.
27
- * @returns A promise that resolves to an array of loaded SlashCommands.
32
+ * @returns A promise that resolves to an array of all loaded SlashCommands.
28
33
  */
29
34
  loadCommands(signal: AbortSignal): Promise<SlashCommand[]>;
35
+ /**
36
+ * Get all command directories in order for loading.
37
+ * User commands → Project commands → Extension commands
38
+ * This order ensures extension commands can detect all conflicts.
39
+ */
40
+ private getCommandDirectories;
30
41
  /**
31
42
  * Parses a single .toml file and transforms it into a SlashCommand object.
32
43
  * @param filePath The absolute path to the .toml file.
33
44
  * @param baseDir The root command directory for name calculation.
45
+ * @param extensionName Optional extension name to prefix commands with.
34
46
  * @returns A promise resolving to a SlashCommand, or null if the file is invalid.
35
47
  */
36
48
  private parseAndAdaptFile;
@@ -42,55 +42,78 @@ export class FileCommandLoader {
42
42
  this.projectRoot = config?.getProjectRoot() || process.cwd();
43
43
  }
44
44
  /**
45
- * Loads all commands, applying the precedence rule where project-level
46
- * commands override user-level commands with the same name.
45
+ * Loads all commands from user, project, and extension directories.
46
+ * Returns commands in order: user project extensions (alphabetically).
47
+ *
48
+ * Order is important for conflict resolution in CommandService:
49
+ * - User/project commands (without extensionName) use "last wins" strategy
50
+ * - Extension commands (with extensionName) get renamed if conflicts exist
51
+ *
47
52
  * @param signal An AbortSignal to cancel the loading process.
48
- * @returns A promise that resolves to an array of loaded SlashCommands.
53
+ * @returns A promise that resolves to an array of all loaded SlashCommands.
49
54
  */
50
55
  async loadCommands(signal) {
51
- const commandMap = new Map();
56
+ const allCommands = [];
52
57
  const globOptions = {
53
58
  nodir: true,
54
59
  dot: true,
55
60
  signal,
56
61
  follow: true,
57
62
  };
58
- try {
59
- // User Commands
60
- const userDir = getUserCommandsDir();
61
- const userFiles = await glob('**/*.toml', {
62
- ...globOptions,
63
- cwd: userDir,
64
- });
65
- const userCommandPromises = userFiles.map((file) => this.parseAndAdaptFile(path.join(userDir, file), userDir));
66
- const userCommands = (await Promise.all(userCommandPromises)).filter((cmd) => cmd !== null);
67
- for (const cmd of userCommands) {
68
- commandMap.set(cmd.name, cmd);
63
+ // Load commands from each directory
64
+ const commandDirs = this.getCommandDirectories();
65
+ for (const dirInfo of commandDirs) {
66
+ try {
67
+ const files = await glob('**/*.toml', {
68
+ ...globOptions,
69
+ cwd: dirInfo.path,
70
+ });
71
+ const commandPromises = files.map((file) => this.parseAndAdaptFile(path.join(dirInfo.path, file), dirInfo.path, dirInfo.extensionName));
72
+ const commands = (await Promise.all(commandPromises)).filter((cmd) => cmd !== null);
73
+ // Add all commands without deduplication
74
+ allCommands.push(...commands);
69
75
  }
70
- // Project Commands (these intentionally override user commands)
71
- const projectDir = getProjectCommandsDir(this.projectRoot);
72
- const projectFiles = await glob('**/*.toml', {
73
- ...globOptions,
74
- cwd: projectDir,
75
- });
76
- const projectCommandPromises = projectFiles.map((file) => this.parseAndAdaptFile(path.join(projectDir, file), projectDir));
77
- const projectCommands = (await Promise.all(projectCommandPromises)).filter((cmd) => cmd !== null);
78
- for (const cmd of projectCommands) {
79
- commandMap.set(cmd.name, cmd);
76
+ catch (error) {
77
+ if (error.code !== 'ENOENT') {
78
+ console.error(`[FileCommandLoader] Error loading commands from ${dirInfo.path}:`, error);
79
+ }
80
80
  }
81
81
  }
82
- catch (error) {
83
- console.error(`[FileCommandLoader] Error during file search:`, error);
82
+ return allCommands;
83
+ }
84
+ /**
85
+ * Get all command directories in order for loading.
86
+ * User commands → Project commands → Extension commands
87
+ * This order ensures extension commands can detect all conflicts.
88
+ */
89
+ getCommandDirectories() {
90
+ const dirs = [];
91
+ // 1. User commands
92
+ dirs.push({ path: getUserCommandsDir() });
93
+ // 2. Project commands (override user commands)
94
+ dirs.push({ path: getProjectCommandsDir(this.projectRoot) });
95
+ // 3. Extension commands (processed last to detect all conflicts)
96
+ if (this.config) {
97
+ const activeExtensions = this.config
98
+ .getExtensions()
99
+ .filter((ext) => ext.isActive)
100
+ .sort((a, b) => a.name.localeCompare(b.name)); // Sort alphabetically for deterministic loading
101
+ const extensionCommandDirs = activeExtensions.map((ext) => ({
102
+ path: path.join(ext.path, 'commands'),
103
+ extensionName: ext.name,
104
+ }));
105
+ dirs.push(...extensionCommandDirs);
84
106
  }
85
- return Array.from(commandMap.values());
107
+ return dirs;
86
108
  }
87
109
  /**
88
110
  * Parses a single .toml file and transforms it into a SlashCommand object.
89
111
  * @param filePath The absolute path to the .toml file.
90
112
  * @param baseDir The root command directory for name calculation.
113
+ * @param extensionName Optional extension name to prefix commands with.
91
114
  * @returns A promise resolving to a SlashCommand, or null if the file is invalid.
92
115
  */
93
- async parseAndAdaptFile(filePath, baseDir) {
116
+ async parseAndAdaptFile(filePath, baseDir, extensionName) {
94
117
  let fileContent;
95
118
  try {
96
119
  fileContent = await fs.readFile(filePath, 'utf-8');
@@ -115,17 +138,23 @@ export class FileCommandLoader {
115
138
  const validDef = validationResult.data;
116
139
  const relativePathWithExt = path.relative(baseDir, filePath);
117
140
  const relativePath = relativePathWithExt.substring(0, relativePathWithExt.length - 5);
118
- const commandName = relativePath
141
+ const baseCommandName = relativePath
119
142
  .split(path.sep)
120
143
  // Sanitize each path segment to prevent ambiguity. Since ':' is our
121
144
  // namespace separator, we replace any literal colons in filenames
122
145
  // with underscores to avoid naming conflicts.
123
146
  .map((segment) => segment.replaceAll(':', '_'))
124
147
  .join(':');
148
+ // Add extension name tag for extension commands
149
+ const defaultDescription = `Custom command from ${path.basename(filePath)}`;
150
+ let description = validDef.description || defaultDescription;
151
+ if (extensionName) {
152
+ description = `[${extensionName}] ${description}`;
153
+ }
125
154
  const processors = [];
126
155
  // Add the Shell Processor if needed.
127
156
  if (validDef.prompt.includes(SHELL_INJECTION_TRIGGER)) {
128
- processors.push(new ShellProcessor(commandName));
157
+ processors.push(new ShellProcessor(baseCommandName));
129
158
  }
130
159
  // The presence of '{{args}}' is the switch that determines the behavior.
131
160
  if (validDef.prompt.includes(SHORTHAND_ARGS_PLACEHOLDER)) {
@@ -135,13 +164,13 @@ export class FileCommandLoader {
135
164
  processors.push(new DefaultArgumentProcessor());
136
165
  }
137
166
  return {
138
- name: commandName,
139
- description: validDef.description ||
140
- `Custom command from ${path.basename(filePath)}`,
167
+ name: baseCommandName,
168
+ description,
141
169
  kind: CommandKind.FILE,
170
+ extensionName,
142
171
  action: async (context, _args) => {
143
172
  if (!context.invocation) {
144
- console.error(`[FileCommandLoader] Critical error: Command '${commandName}' was executed without invocation context.`);
173
+ console.error(`[FileCommandLoader] Critical error: Command '${baseCommandName}' was executed without invocation context.`);
145
174
  return {
146
175
  type: 'submit_prompt',
147
176
  content: validDef.prompt, // Fallback to unprocessed prompt
@@ -1 +1 @@
1
- {"version":3,"file":"FileCommandLoader.js","sourceRoot":"","sources":["../../../src/services/FileCommandLoader.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"FileCommandLoader.js","sourceRoot":"","sources":["../../../src/services/FileCommandLoader.ts"],"names":[],"mappings":"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"}
@@ -53,24 +53,25 @@ import { useVim } from './hooks/vim.js';
53
53
  import * as fs from 'fs';
54
54
  import { UpdateNotification } from './components/UpdateNotification.js';
55
55
  import { isProQuotaExceededError, isGenericQuotaExceededError, UserTierId, } from '@google/gemini-cli-core';
56
- import { checkForUpdates } from './utils/updateCheck.js';
57
56
  import ansiEscapes from 'ansi-escapes';
58
57
  import { OverflowProvider } from './contexts/OverflowContext.js';
59
58
  import { ShowMoreLines } from './components/ShowMoreLines.js';
60
59
  import { PrivacyNotice } from './privacy/PrivacyNotice.js';
60
+ import { setUpdateHandler } from '../utils/handleAutoUpdate.js';
61
61
  import { appEvents, AppEvent } from '../utils/events.js';
62
62
  const CTRL_EXIT_PROMPT_DURATION_MS = 1000;
63
63
  export const AppWrapper = (props) => (_jsx(SessionStatsProvider, { children: _jsx(VimModeProvider, { settings: props.settings, children: _jsx(App, { ...props }) }) }));
64
64
  const App = ({ config, settings, startupWarnings = [], version }) => {
65
65
  const isFocused = useFocus();
66
66
  useBracketedPaste();
67
- const [updateMessage, setUpdateMessage] = useState(null);
67
+ const [updateInfo, setUpdateInfo] = useState(null);
68
68
  const { stdout } = useStdout();
69
69
  const nightly = version.includes('nightly');
70
- useEffect(() => {
71
- checkForUpdates().then(setUpdateMessage);
72
- }, []);
73
70
  const { history, addItem, clearItems, loadHistory } = useHistory();
71
+ useEffect(() => {
72
+ const cleanup = setUpdateHandler(addItem, setUpdateInfo);
73
+ return cleanup;
74
+ }, [addItem]);
74
75
  const { consoleMessages, handleNewMessage, clearConsoleMessages: clearConsoleMessagesState, } = useConsoleMessages();
75
76
  useEffect(() => {
76
77
  const consolePatcher = new ConsolePatcher({
@@ -109,12 +110,12 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
109
110
  const [showPrivacyNotice, setShowPrivacyNotice] = useState(false);
110
111
  const [modelSwitchedFromQuotaError, setModelSwitchedFromQuotaError] = useState(false);
111
112
  const [userTier, setUserTier] = useState(undefined);
112
- const [openFiles, setOpenFiles] = useState();
113
+ const [ideContextState, setIdeContextState] = useState();
113
114
  const [isProcessing, setIsProcessing] = useState(false);
114
115
  useEffect(() => {
115
- const unsubscribe = ideContext.subscribeToOpenFiles(setOpenFiles);
116
+ const unsubscribe = ideContext.subscribeToIdeContext(setIdeContextState);
116
117
  // Set the initial value
117
- setOpenFiles(ideContext.getOpenFilesContext());
118
+ setIdeContextState(ideContext.getIdeContext());
118
119
  return unsubscribe;
119
120
  }, []);
120
121
  useEffect(() => {
@@ -146,14 +147,19 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
146
147
  const { isThemeDialogOpen, openThemeDialog, handleThemeSelect, handleThemeHighlight, } = useThemeCommand(settings, setThemeError, addItem);
147
148
  const { isAuthDialogOpen, openAuthDialog, handleAuthSelect, isAuthenticating, cancelAuthentication, } = useAuthCommand(settings, setAuthError, config);
148
149
  useEffect(() => {
149
- if (settings.merged.selectedAuthType) {
150
+ if (settings.merged.selectedAuthType && !settings.merged.useExternalAuth) {
150
151
  const error = validateAuthMethod(settings.merged.selectedAuthType);
151
152
  if (error) {
152
153
  setAuthError(error);
153
154
  openAuthDialog();
154
155
  }
155
156
  }
156
- }, [settings.merged.selectedAuthType, openAuthDialog, setAuthError]);
157
+ }, [
158
+ settings.merged.selectedAuthType,
159
+ settings.merged.useExternalAuth,
160
+ openAuthDialog,
161
+ setAuthError,
162
+ ]);
157
163
  // Sync user tier from config when authentication changes
158
164
  useEffect(() => {
159
165
  // Only sync when not currently authenticating
@@ -171,7 +177,8 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
171
177
  text: 'Refreshing hierarchical memory (GEMINI.md or other context files)...',
172
178
  }, Date.now());
173
179
  try {
174
- const { memoryContent, fileCount } = await loadHierarchicalGeminiMemory(process.cwd(), config.getDebugMode(), config.getFileService(), settings.merged, config.getExtensionContextFilePaths(), config.getFileFilteringOptions());
180
+ const { memoryContent, fileCount } = await loadHierarchicalGeminiMemory(process.cwd(), config.getDebugMode(), config.getFileService(), settings.merged, config.getExtensionContextFilePaths(), settings.merged.memoryImportFormat || 'tree', // Use setting or default to 'tree'
181
+ config.getFileFilteringOptions());
175
182
  config.setUserMemory(memoryContent);
176
183
  config.setGeminiMdFileCount(fileCount);
177
184
  setGeminiMdFileCount(fileCount);
@@ -270,6 +277,7 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
270
277
  }
271
278
  // Switch model for future use but return false to stop current retry
272
279
  config.setModel(fallbackModel);
280
+ config.setFallbackMode(true);
273
281
  logFlashFallback(config, new FlashFallbackEvent(config.getContentGeneratorConfig().authType));
274
282
  return false; // Don't continue with current prompt
275
283
  };
@@ -365,7 +373,10 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
365
373
  handleSlashCommand(newValue ? '/mcp desc' : '/mcp nodesc');
366
374
  }
367
375
  }
368
- else if (key.ctrl && input === 'e' && ideContext) {
376
+ else if (key.ctrl &&
377
+ input === 'e' &&
378
+ config.getIdeMode() &&
379
+ ideContextState) {
369
380
  setShowIDEContextDetail((prev) => !prev);
370
381
  }
371
382
  else if (key.ctrl && (input === 'c' || input === 'C')) {
@@ -505,13 +516,13 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
505
516
  const placeholder = vimModeEnabled
506
517
  ? " Press 'i' for INSERT mode and 'Esc' for NORMAL mode."
507
518
  : ' Type your message or @path/to/file';
508
- return (_jsx(StreamingContext.Provider, { value: streamingState, children: _jsxs(Box, { flexDirection: "column", width: "90%", children: [updateMessage && _jsx(UpdateNotification, { message: updateMessage }), _jsx(Static, { items: [
519
+ return (_jsx(StreamingContext.Provider, { value: streamingState, children: _jsxs(Box, { flexDirection: "column", width: "90%", children: [_jsx(Static, { items: [
509
520
  _jsxs(Box, { flexDirection: "column", children: [!settings.merged.hideBanner && (_jsx(Header, { terminalWidth: terminalWidth, version: version, nightly: nightly })), !settings.merged.hideTips && _jsx(Tips, { config: config })] }, "header"),
510
521
  ...history.map((h) => (_jsx(HistoryItemDisplay, { terminalWidth: mainAreaWidth, availableTerminalHeight: staticAreaMaxItemHeight, item: h, isPending: false, config: config }, h.id))),
511
522
  ], children: (item) => item }, staticKey), _jsx(OverflowProvider, { children: _jsxs(Box, { ref: pendingHistoryItemRef, flexDirection: "column", children: [pendingHistoryItems.map((item, i) => (_jsx(HistoryItemDisplay, { availableTerminalHeight: constrainHeight ? availableTerminalHeight : undefined, terminalWidth: mainAreaWidth,
512
523
  // TODO(taehykim): It seems like references to ids aren't necessary in
513
524
  // HistoryItemDisplay. Refactor later. Use a fake id for now.
514
- item: { ...item, id: 0 }, isPending: true, config: config, isFocused: !isEditorDialogOpen }, i))), _jsx(ShowMoreLines, { constrainHeight: constrainHeight })] }) }), showHelp && _jsx(Help, { commands: slashCommands }), _jsxs(Box, { flexDirection: "column", ref: mainControlsRef, children: [startupWarnings.length > 0 && (_jsx(Box, { borderStyle: "round", borderColor: Colors.AccentYellow, paddingX: 1, marginY: 1, flexDirection: "column", children: startupWarnings.map((warning, index) => (_jsx(Text, { color: Colors.AccentYellow, children: warning }, index))) })), shellConfirmationRequest ? (_jsx(ShellConfirmationDialog, { request: shellConfirmationRequest })) : isThemeDialogOpen ? (_jsxs(Box, { flexDirection: "column", children: [themeError && (_jsx(Box, { marginBottom: 1, children: _jsx(Text, { color: Colors.AccentRed, children: themeError }) })), _jsx(ThemeDialog, { onSelect: handleThemeSelect, onHighlight: handleThemeHighlight, settings: settings, availableTerminalHeight: constrainHeight
525
+ item: { ...item, id: 0 }, isPending: true, config: config, isFocused: !isEditorDialogOpen }, i))), _jsx(ShowMoreLines, { constrainHeight: constrainHeight })] }) }), showHelp && _jsx(Help, { commands: slashCommands }), _jsxs(Box, { flexDirection: "column", ref: mainControlsRef, children: [updateInfo && _jsx(UpdateNotification, { message: updateInfo.message }), startupWarnings.length > 0 && (_jsx(Box, { borderStyle: "round", borderColor: Colors.AccentYellow, paddingX: 1, marginY: 1, flexDirection: "column", children: startupWarnings.map((warning, index) => (_jsx(Text, { color: Colors.AccentYellow, children: warning }, index))) })), shellConfirmationRequest ? (_jsx(ShellConfirmationDialog, { request: shellConfirmationRequest })) : isThemeDialogOpen ? (_jsxs(Box, { flexDirection: "column", children: [themeError && (_jsx(Box, { marginBottom: 1, children: _jsx(Text, { color: Colors.AccentRed, children: themeError }) })), _jsx(ThemeDialog, { onSelect: handleThemeSelect, onHighlight: handleThemeHighlight, settings: settings, availableTerminalHeight: constrainHeight
515
526
  ? terminalHeight - staticExtraHeight
516
527
  : undefined, terminalWidth: mainAreaWidth })] })) : isAuthenticating ? (_jsxs(_Fragment, { children: [_jsx(AuthInProgress, { onTimeout: () => {
517
528
  setAuthError('Authentication timed out. Please try again.');
@@ -522,7 +533,9 @@ const App = ({ config, settings, startupWarnings = [], version }) => {
522
533
  ? undefined
523
534
  : thought, currentLoadingPhrase: config.getAccessibility()?.disableLoadingPhrases
524
535
  ? undefined
525
- : currentLoadingPhrase, elapsedTime: elapsedTime }), _jsxs(Box, { marginTop: 1, display: "flex", justifyContent: "space-between", width: "100%", children: [_jsxs(Box, { children: [process.env.GEMINI_SYSTEM_MD && (_jsx(Text, { color: Colors.AccentRed, children: "|\u2310\u25A0_\u25A0| " })), ctrlCPressedOnce ? (_jsx(Text, { color: Colors.AccentYellow, children: "Press Ctrl+C again to exit." })) : ctrlDPressedOnce ? (_jsx(Text, { color: Colors.AccentYellow, children: "Press Ctrl+D again to exit." })) : (_jsx(ContextSummaryDisplay, { openFiles: openFiles, geminiMdFileCount: geminiMdFileCount, contextFileNames: contextFileNames, mcpServers: config.getMcpServers(), blockedMcpServers: config.getBlockedMcpServers(), showToolDescriptions: showToolDescriptions }))] }), _jsxs(Box, { children: [showAutoAcceptIndicator !== ApprovalMode.DEFAULT &&
526
- !shellModeActive && (_jsx(AutoAcceptIndicator, { approvalMode: showAutoAcceptIndicator })), shellModeActive && _jsx(ShellModeIndicator, {})] })] }), showIDEContextDetail && (_jsx(IDEContextDetailDisplay, { openFiles: openFiles })), showErrorDetails && (_jsx(OverflowProvider, { children: _jsxs(Box, { flexDirection: "column", children: [_jsx(DetailedMessagesDisplay, { messages: filteredConsoleMessages, maxHeight: constrainHeight ? debugConsoleMaxHeight : undefined, width: inputWidth }), _jsx(ShowMoreLines, { constrainHeight: constrainHeight })] }) })), isInputActive && (_jsx(InputPrompt, { buffer: buffer, inputWidth: inputWidth, suggestionsWidth: suggestionsWidth, onSubmit: handleFinalSubmit, userMessages: userMessages, onClearScreen: handleClearScreen, config: config, slashCommands: slashCommands, commandContext: commandContext, shellModeActive: shellModeActive, setShellModeActive: setShellModeActive, focus: isFocused, vimHandleInput: vimHandleInput, placeholder: placeholder }))] })), initError && streamingState !== StreamingState.Responding && (_jsx(Box, { borderStyle: "round", borderColor: Colors.AccentRed, paddingX: 1, marginBottom: 1, children: history.find((item) => item.type === 'error' && item.text?.includes(initError))?.text ? (_jsx(Text, { color: Colors.AccentRed, children: history.find((item) => item.type === 'error' && item.text?.includes(initError))?.text })) : (_jsxs(_Fragment, { children: [_jsxs(Text, { color: Colors.AccentRed, children: ["Initialization Error: ", initError] }), _jsxs(Text, { color: Colors.AccentRed, children: [' ', "Please check API key and configuration."] })] })) })), _jsx(Footer, { model: currentModel, targetDir: config.getTargetDir(), debugMode: config.getDebugMode(), branchName: branchName, debugMessage: debugMessage, corgiMode: corgiMode, errorCount: errorCount, showErrorDetails: showErrorDetails, showMemoryUsage: config.getDebugMode() || config.getShowMemoryUsage(), promptTokenCount: sessionStats.lastPromptTokenCount, nightly: nightly, vimMode: vimModeEnabled ? vimMode : undefined })] })] }) }));
536
+ : currentLoadingPhrase, elapsedTime: elapsedTime }), _jsxs(Box, { marginTop: 1, display: "flex", justifyContent: "space-between", width: "100%", children: [_jsxs(Box, { children: [process.env.GEMINI_SYSTEM_MD && (_jsx(Text, { color: Colors.AccentRed, children: "|\u2310\u25A0_\u25A0| " })), ctrlCPressedOnce ? (_jsx(Text, { color: Colors.AccentYellow, children: "Press Ctrl+C again to exit." })) : ctrlDPressedOnce ? (_jsx(Text, { color: Colors.AccentYellow, children: "Press Ctrl+D again to exit." })) : (_jsx(ContextSummaryDisplay, { ideContext: ideContextState, geminiMdFileCount: geminiMdFileCount, contextFileNames: contextFileNames, mcpServers: config.getMcpServers(), blockedMcpServers: config.getBlockedMcpServers(), showToolDescriptions: showToolDescriptions }))] }), _jsxs(Box, { children: [showAutoAcceptIndicator !== ApprovalMode.DEFAULT &&
537
+ !shellModeActive && (_jsx(AutoAcceptIndicator, { approvalMode: showAutoAcceptIndicator })), shellModeActive && _jsx(ShellModeIndicator, {})] })] }), showIDEContextDetail && (_jsx(IDEContextDetailDisplay, { ideContext: ideContextState, detectedIdeDisplay: config
538
+ .getIdeClient()
539
+ .getDetectedIdeDisplayName() })), showErrorDetails && (_jsx(OverflowProvider, { children: _jsxs(Box, { flexDirection: "column", children: [_jsx(DetailedMessagesDisplay, { messages: filteredConsoleMessages, maxHeight: constrainHeight ? debugConsoleMaxHeight : undefined, width: inputWidth }), _jsx(ShowMoreLines, { constrainHeight: constrainHeight })] }) })), isInputActive && (_jsx(InputPrompt, { buffer: buffer, inputWidth: inputWidth, suggestionsWidth: suggestionsWidth, onSubmit: handleFinalSubmit, userMessages: userMessages, onClearScreen: handleClearScreen, config: config, slashCommands: slashCommands, commandContext: commandContext, shellModeActive: shellModeActive, setShellModeActive: setShellModeActive, focus: isFocused, vimHandleInput: vimHandleInput, placeholder: placeholder }))] })), initError && streamingState !== StreamingState.Responding && (_jsx(Box, { borderStyle: "round", borderColor: Colors.AccentRed, paddingX: 1, marginBottom: 1, children: history.find((item) => item.type === 'error' && item.text?.includes(initError))?.text ? (_jsx(Text, { color: Colors.AccentRed, children: history.find((item) => item.type === 'error' && item.text?.includes(initError))?.text })) : (_jsxs(_Fragment, { children: [_jsxs(Text, { color: Colors.AccentRed, children: ["Initialization Error: ", initError] }), _jsxs(Text, { color: Colors.AccentRed, children: [' ', "Please check API key and configuration."] })] })) })), _jsx(Footer, { model: currentModel, targetDir: config.getTargetDir(), debugMode: config.getDebugMode(), branchName: branchName, debugMessage: debugMessage, corgiMode: corgiMode, errorCount: errorCount, showErrorDetails: showErrorDetails, showMemoryUsage: config.getDebugMode() || config.getShowMemoryUsage(), promptTokenCount: sessionStats.lastPromptTokenCount, nightly: nightly, vimMode: vimModeEnabled ? vimMode : undefined })] })] }) }));
527
540
  };
528
541
  //# sourceMappingURL=App.js.map