summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2025-04-21fix: use relative imports within the same package (#93)Brandon Keiji
2025-04-21sandbox.sh utility to easily log into or execute commands in a sandbox, set ↵Olcan
hostname and SANDBOX env var to container name (#92)
2025-04-21Remove dead methods from ToolRegistry (#91)Jaana Dogan
* getToolSchemas is deprecated. * listAvailableTools is now getAllTools.
2025-04-21Remove dead comments (#90)Jaana Dogan
2025-04-21Remove duplicate CLI tools module, remove the global tool registry (#89)Jaana Dogan
2025-04-21enable debugging through sandbox (#88)Olcan
2025-04-21Remove redundant else branches (#86)Jaana Dogan
Else branches are an anti pattern especially if you can easily return from the previous branch. Over time, else branches cause deep nesting and make code unreadable and unmaintainable. Remove elses where possible.
2025-04-21fix flags via sandbox (again) (#87)Olcan
2025-04-21Remove gemini-stream.ts (#84)Jaana Dogan
This module is no longer needed and the types can be provided from types.
2025-04-21Fix confirmations.Taylor Mullen
- This fixes what it means to get confirmations in GC. Prior to this they had just been accidentally unwired as part of all of the refactorings to turns + to server/core. - The key piece of this is that we wrap the onConfirm in the gemini stream hook in order to resubmit function responses. This isn't 100% ideal but gets the job done for now. - Fixed history not updating properly with confirmations. Fixes https://b.corp.google.com/issues/412323656
2025-04-21don't assume .env file (#83)Olcan
2025-04-21Ignore grep error if .env doesn't exist (#82)Jaana Dogan
.env file is optional. If it doesn't exist, the current script outputs "grep: .env: No such file or directory".
2025-04-21More license headers, add a CONTRIBUTING.md file (also fix README.md ↵Tyler
formatting) (#81)
2025-04-21make sandbox attachable, document in README (#80)Olcan
2025-04-21added sandbox section to readme (#79)Olcan
2025-04-21Fix Gemini Code's (GC) smarts.Taylor Mullen
- The tl;dr; is that GC couldn't see what the user was saying when tool call events happened in response. The rason why this was happening was because we were instantly invoking tools that the model told us to invoke and then instantly re-requesting. This resulted in the bug because the genai APIs can't update the chat history before a full response has been completed (doesn't know how to update if it's incomplete). - To address the above issue I had to do quite the large refactor. The gist is that now turns truly drive everything on the server (vs. a server client split). This ensured that when we got tool invocations we could control when/how re-requesting would happen and then also ensure that history was updated. This change also meant that the server would act as an event publisher to enable the client to react to events rather than try and weave in complex logic between the events. - A BIG change that this changeset incudes is the removal of all of the CLI tools in favor of the server tools. - Removed some dead code as part of this - **NOTE: Confirmations are still broken (they were broken prior to this); however, I've set them up to be able to work in the future, I'll dot hat in a follow up to be less breaking to others.** Fixes https://b.corp.google.com/issues/412320087
2025-04-21feat: add custom eslint rule for cross-package imports (#77)Brandon Keiji
2025-04-21seamless sandboxing (just set GEMINI_CODE_SANDBOX=true in .env) (#76)Olcan
2025-04-20Revert debug undo.Taylor Mullen
2025-04-20Update README to reflect current state of the world.Taylor Mullen
- We now have CI/CD - We have linting support (so added a section) - Fixed `npm run debug` to allow debugging again.
2025-04-20fix passing of flags through start scripts (#73)Olcan
2025-04-20Fix read-file from exploding with path not found error.Taylor Mullen
- There were a few hiccups here. Somehow 2.5-flash wasn't actually abiding by our tool schema. Instead it was inferring `path`. To semi-combat this I've renamed `file_path` -> `path`. - We weren't elevating errors that were created via schema validation. Instead both the `glob` and `read-file.ts` now surface this. - In error scenarios (like failing schema) we were improperly surfacing these as success cases because we were overriding tool status.
2025-04-20fix function calling for gemini 2.5 series (#65)Olcan
2025-04-20add linter for checking license headers (and eslint --fix target to match, ↵Tyler
and fix missing license headers while we're here) (#62)
2025-04-20drop /dist suffix no longer needed (#71)Olcan
2025-04-20start and debug scripts (will enable seamless container use later), strict ↵Olcan
error handling in bash scripts (#63) #61
2025-04-20use /sandbox/<proj_name> instead of /project as workdir in container (#64)Olcan
2025-04-20Make model-generated code copyable (#70)Juliette Love
2025-04-20Add terminal clear (#69)Juliette Love
2025-04-20fix: remove 'dist' suffix from start_container.sh command (#67)Brandon Keiji
2025-04-20Adds shell command allowlist (#68)Juliette Love
* Wire through passthrough commands * Add default passthrough commands * Clean up config passing to useGeminiStream
2025-04-20refactor: clean up build output (#53)Brandon Keiji
* refactor: clean up build output * refactor: add index.ts to package roots
2025-04-20Simple debug mode for CLI side (#66)Juliette Love
* Adds debug mode config flag. * Wire through debug lines * Add debug mode logging example * Run format * Run format again
2025-04-20Minimal container setup. Install docker (or podman), build container with ↵Olcan
scripts/build_container.sh, then start with scripts/start_container.sh. Exit with ^C for now. (#61)
2025-04-19Enable `npm run debug` from root.Taylor Mullen
2025-04-19Give Gemini Code a face lift.Taylor Mullen
- This utilizes `ink-gradient` to render GEMINI CODE in amazing colors. - Added a shared color configuration for UX (should this be in config?). It's very possible that we shouldn't be talking about the specific colors and instead be mentioning "foreground"/"background"/inlineCode etc. type colors. - Updated existing color usages to utilize `Colors.*` Fixes https://b.corp.google.com/issues/411385593
2025-04-19Starting to modularize into separate cli / server packages. (#55)Evan Senter
* Starting to move a lot of code into packages/server * More of the massive refactor, builds and runs, some issues though. * Fixing outstanding issue with double messages. * Fixing a minor UI issue. * Fixing the build post-merge. * Running formatting. * Addressing comments.
2025-04-19Adding some simple tests. (#54)Evan Senter
2025-04-19Fix the double warning for iterm. (#51)Allen Hutchison
2025-04-19Quick fix gitignore (#49)Allen Hutchison
* Command line flags got broke. Now to run with flags run: npm run start -- -m model-id -d data/dir * Add *.tsbuildinfo to git ignore.
2025-04-19Adding in a history buffer (#38)Evan Senter
Up and down arrows traverse the command history.
2025-04-19fix formatjlove29
2025-04-19Add direct execution of shell commandsjlove29
2025-04-18Take the turn management out of GeminiClient (#42)Jaana Dogan
2025-04-18Show error when GEMINI_API_KEY is not set (#52)Jaana Dogan
Also fix the bug where the API key is used accidentally as the model name.
2025-04-18Add apache2 SPDX headers to all source files (#48)Tyler
2025-04-18All the pipes (#47)Allen Hutchison
* Bump the character limit to web fetch. * Piped Input Hook. First step in bringing in STDIN piping. * Fix linting errors. * Remove incorrect comment.
2025-04-18Command line flags got broke. Now to run with flags run: (#46)Allen Hutchison
npm run start -- -m model-id -d data/dir
2025-04-18minor lint fix (#45)Olcan
2025-04-18fix: point server 'main' to dist folder (#44)Brandon Keiji