2025-04-18 17:44:24 -07:00
|
|
|
|
/**
|
|
|
|
|
|
* @license
|
|
|
|
|
|
* Copyright 2025 Google LLC
|
|
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
Initial commit of Gemini Code CLI
This commit introduces the initial codebase for the Gemini Code CLI, a command-line interface designed to facilitate interaction with the Gemini API for software engineering tasks.
The code was migrated from a previous git repository as a single squashed commit.
Core Features & Components:
* **Gemini Integration:** Leverages the `@google/genai` SDK to interact with the Gemini models, supporting chat history, streaming responses, and function calling (tools).
* **Terminal UI:** Built with Ink (React for CLIs) providing an interactive chat interface within the terminal, including input prompts, message display, loading indicators, and tool interaction elements.
* **Tooling Framework:** Implements a robust tool system allowing Gemini to interact with the local environment. Includes tools for:
* File system listing (`ls`)
* File reading (`read-file`)
* Content searching (`grep`)
* File globbing (`glob`)
* File editing (`edit`)
* File writing (`write-file`)
* Executing bash commands (`terminal`)
* **State Management:** Handles the streaming state of Gemini responses and manages the conversation history.
* **Configuration:** Parses command-line arguments (`yargs`) and loads environment variables (`dotenv`) for setup.
* **Project Structure:** Organized into `core`, `ui`, `tools`, `config`, and `utils` directories using TypeScript. Includes basic build (`tsc`) and start scripts.
This initial version establishes the foundation for a powerful CLI tool enabling developers to use Gemini for coding assistance directly in their terminal environment.
---
Created by yours truly: __Gemini Code__
2025-04-15 21:41:08 -07:00
|
|
|
|
import React from 'react';
|
|
|
|
|
|
import { Box, Text } from 'ink';
|
2025-04-19 12:38:09 -04:00
|
|
|
|
import { Colors } from '../colors.js';
|
2025-06-25 05:41:11 -07:00
|
|
|
|
import { shortenPath, tildeifyPath, tokenLimit } from '@google/gemini-cli-core';
|
2025-05-22 10:36:44 -07:00
|
|
|
|
import { ConsoleSummaryDisplay } from './ConsoleSummaryDisplay.js';
|
2025-05-30 22:18:01 +00:00
|
|
|
|
import process from 'node:process';
|
|
|
|
|
|
import { MemoryUsageDisplay } from './MemoryUsageDisplay.js';
|
Initial commit of Gemini Code CLI
This commit introduces the initial codebase for the Gemini Code CLI, a command-line interface designed to facilitate interaction with the Gemini API for software engineering tasks.
The code was migrated from a previous git repository as a single squashed commit.
Core Features & Components:
* **Gemini Integration:** Leverages the `@google/genai` SDK to interact with the Gemini models, supporting chat history, streaming responses, and function calling (tools).
* **Terminal UI:** Built with Ink (React for CLIs) providing an interactive chat interface within the terminal, including input prompts, message display, loading indicators, and tool interaction elements.
* **Tooling Framework:** Implements a robust tool system allowing Gemini to interact with the local environment. Includes tools for:
* File system listing (`ls`)
* File reading (`read-file`)
* Content searching (`grep`)
* File globbing (`glob`)
* File editing (`edit`)
* File writing (`write-file`)
* Executing bash commands (`terminal`)
* **State Management:** Handles the streaming state of Gemini responses and manages the conversation history.
* **Configuration:** Parses command-line arguments (`yargs`) and loads environment variables (`dotenv`) for setup.
* **Project Structure:** Organized into `core`, `ui`, `tools`, `config`, and `utils` directories using TypeScript. Includes basic build (`tsc`) and start scripts.
This initial version establishes the foundation for a powerful CLI tool enabling developers to use Gemini for coding assistance directly in their terminal environment.
---
Created by yours truly: __Gemini Code__
2025-04-15 21:41:08 -07:00
|
|
|
|
|
|
|
|
|
|
interface FooterProps {
|
2025-05-28 23:30:05 +00:00
|
|
|
|
model: string;
|
|
|
|
|
|
targetDir: string;
|
|
|
|
|
|
branchName?: string;
|
2025-04-20 20:20:40 +01:00
|
|
|
|
debugMode: boolean;
|
|
|
|
|
|
debugMessage: string;
|
2025-05-17 21:57:27 -07:00
|
|
|
|
corgiMode: boolean;
|
2025-05-22 10:36:44 -07:00
|
|
|
|
errorCount: number;
|
|
|
|
|
|
showErrorDetails: boolean;
|
2025-05-30 22:18:01 +00:00
|
|
|
|
showMemoryUsage?: boolean;
|
2025-06-15 11:15:53 -07:00
|
|
|
|
promptTokenCount: number;
|
Initial commit of Gemini Code CLI
This commit introduces the initial codebase for the Gemini Code CLI, a command-line interface designed to facilitate interaction with the Gemini API for software engineering tasks.
The code was migrated from a previous git repository as a single squashed commit.
Core Features & Components:
* **Gemini Integration:** Leverages the `@google/genai` SDK to interact with the Gemini models, supporting chat history, streaming responses, and function calling (tools).
* **Terminal UI:** Built with Ink (React for CLIs) providing an interactive chat interface within the terminal, including input prompts, message display, loading indicators, and tool interaction elements.
* **Tooling Framework:** Implements a robust tool system allowing Gemini to interact with the local environment. Includes tools for:
* File system listing (`ls`)
* File reading (`read-file`)
* Content searching (`grep`)
* File globbing (`glob`)
* File editing (`edit`)
* File writing (`write-file`)
* Executing bash commands (`terminal`)
* **State Management:** Handles the streaming state of Gemini responses and manages the conversation history.
* **Configuration:** Parses command-line arguments (`yargs`) and loads environment variables (`dotenv`) for setup.
* **Project Structure:** Organized into `core`, `ui`, `tools`, `config`, and `utils` directories using TypeScript. Includes basic build (`tsc`) and start scripts.
This initial version establishes the foundation for a powerful CLI tool enabling developers to use Gemini for coding assistance directly in their terminal environment.
---
Created by yours truly: __Gemini Code__
2025-04-15 21:41:08 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-04-20 20:20:40 +01:00
|
|
|
|
export const Footer: React.FC<FooterProps> = ({
|
2025-05-28 23:30:05 +00:00
|
|
|
|
model,
|
|
|
|
|
|
targetDir,
|
|
|
|
|
|
branchName,
|
2025-04-20 20:20:40 +01:00
|
|
|
|
debugMode,
|
|
|
|
|
|
debugMessage,
|
2025-05-17 21:57:27 -07:00
|
|
|
|
corgiMode,
|
2025-05-22 10:36:44 -07:00
|
|
|
|
errorCount,
|
|
|
|
|
|
showErrorDetails,
|
2025-05-30 22:18:01 +00:00
|
|
|
|
showMemoryUsage,
|
2025-06-29 20:44:33 -04:00
|
|
|
|
promptTokenCount,
|
2025-06-15 11:15:53 -07:00
|
|
|
|
}) => {
|
|
|
|
|
|
const limit = tokenLimit(model);
|
2025-06-29 20:44:33 -04:00
|
|
|
|
const percentage = promptTokenCount / limit;
|
2025-04-21 14:43:43 -07:00
|
|
|
|
|
2025-06-15 11:15:53 -07:00
|
|
|
|
return (
|
|
|
|
|
|
<Box marginTop={1} justifyContent="space-between" width="100%">
|
|
|
|
|
|
<Box>
|
|
|
|
|
|
<Text color={Colors.LightBlue}>
|
|
|
|
|
|
{shortenPath(tildeifyPath(targetDir), 70)}
|
|
|
|
|
|
{branchName && <Text color={Colors.Gray}> ({branchName}*)</Text>}
|
2025-05-07 20:03:29 -07:00
|
|
|
|
</Text>
|
2025-06-15 11:15:53 -07:00
|
|
|
|
{debugMode && (
|
|
|
|
|
|
<Text color={Colors.AccentRed}>
|
|
|
|
|
|
{' ' + (debugMessage || '--debug')}
|
|
|
|
|
|
</Text>
|
|
|
|
|
|
)}
|
|
|
|
|
|
</Box>
|
|
|
|
|
|
|
|
|
|
|
|
{/* Middle Section: Centered Sandbox Info */}
|
|
|
|
|
|
<Box
|
|
|
|
|
|
flexGrow={1}
|
|
|
|
|
|
alignItems="center"
|
|
|
|
|
|
justifyContent="center"
|
|
|
|
|
|
display="flex"
|
|
|
|
|
|
>
|
|
|
|
|
|
{process.env.SANDBOX && process.env.SANDBOX !== 'sandbox-exec' ? (
|
|
|
|
|
|
<Text color="green">
|
|
|
|
|
|
{process.env.SANDBOX.replace(/^gemini-(?:cli-)?/, '')}
|
|
|
|
|
|
</Text>
|
|
|
|
|
|
) : process.env.SANDBOX === 'sandbox-exec' ? (
|
|
|
|
|
|
<Text color={Colors.AccentYellow}>
|
|
|
|
|
|
MacOS Seatbelt{' '}
|
|
|
|
|
|
<Text color={Colors.Gray}>({process.env.SEATBELT_PROFILE})</Text>
|
|
|
|
|
|
</Text>
|
|
|
|
|
|
) : (
|
|
|
|
|
|
<Text color={Colors.AccentRed}>
|
2025-06-22 16:54:10 +01:00
|
|
|
|
no sandbox <Text color={Colors.Gray}>(see /docs)</Text>
|
2025-06-15 11:15:53 -07:00
|
|
|
|
</Text>
|
|
|
|
|
|
)}
|
|
|
|
|
|
</Box>
|
2025-04-21 14:43:43 -07:00
|
|
|
|
|
2025-06-15 11:15:53 -07:00
|
|
|
|
{/* Right Section: Gemini Label and Console Summary */}
|
|
|
|
|
|
<Box alignItems="center">
|
|
|
|
|
|
<Text color={Colors.AccentBlue}>
|
|
|
|
|
|
{' '}
|
|
|
|
|
|
{model}{' '}
|
|
|
|
|
|
<Text color={Colors.Gray}>
|
|
|
|
|
|
({((1 - percentage) * 100).toFixed(0)}% context left)
|
|
|
|
|
|
</Text>
|
2025-05-17 21:57:27 -07:00
|
|
|
|
</Text>
|
2025-06-15 11:15:53 -07:00
|
|
|
|
{corgiMode && (
|
|
|
|
|
|
<Text>
|
|
|
|
|
|
<Text color={Colors.Gray}>| </Text>
|
|
|
|
|
|
<Text color={Colors.AccentRed}>▼</Text>
|
|
|
|
|
|
<Text color={Colors.Foreground}>(´</Text>
|
|
|
|
|
|
<Text color={Colors.AccentRed}>ᴥ</Text>
|
|
|
|
|
|
<Text color={Colors.Foreground}>`)</Text>
|
|
|
|
|
|
<Text color={Colors.AccentRed}>▼ </Text>
|
|
|
|
|
|
</Text>
|
|
|
|
|
|
)}
|
|
|
|
|
|
{!showErrorDetails && errorCount > 0 && (
|
|
|
|
|
|
<Box>
|
|
|
|
|
|
<Text color={Colors.Gray}>| </Text>
|
|
|
|
|
|
<ConsoleSummaryDisplay errorCount={errorCount} />
|
|
|
|
|
|
</Box>
|
|
|
|
|
|
)}
|
|
|
|
|
|
{showMemoryUsage && <MemoryUsageDisplay />}
|
|
|
|
|
|
</Box>
|
2025-04-21 14:43:43 -07:00
|
|
|
|
</Box>
|
2025-06-15 11:15:53 -07:00
|
|
|
|
);
|
|
|
|
|
|
};
|