Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
1521 commits
Select commit Hold shift + click to select a range
bc50606
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 19, 2025
a475cd3
feat(telemetry): add telemetry event handling through webview messages
mini2s Dec 19, 2025
2dec78c
fix: refresh models button not flushing cache properly (#9870)
pdecat Dec 19, 2025
3f1f8be
feat(vertex): add 1M context window beta support for Claude Sonnet 4 …
hannesrudolph Dec 19, 2025
61903f9
feat(providers): add native tool calling support to LM Studio and Qwe…
hannesrudolph Dec 19, 2025
6e2b852
ux: improve API error handling and visibility (#10204)
brunobergher Dec 19, 2025
ae41af6
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 19, 2025
bb358fb
ux: add downloadable error diagnostics from chat errors (#10188)
brunobergher Dec 19, 2025
397328c
feat: merge native tool defaults for openai-compatible provider (#10213)
hannesrudolph Dec 19, 2025
aabee0f
fix: force additionalProperties false for strict mode compatibility (…
daniel-lxs Dec 19, 2025
bade932
fix: enable native tool calls for Requesty provider (ROO-235) (#10211)
daniel-lxs Dec 19, 2025
ccbb25d
Release v3.36.15 (#10218)
cte Dec 19, 2025
f7adc4b
Changeset version bump (#10219)
github-actions[bot] Dec 19, 2025
5c798a9
fix: normalize tool schemas for VS Code LM API to fix error 400 (#10221)
hannesrudolph Dec 20, 2025
d2814da
Release v3.36.16 (#10224)
mrubens Dec 20, 2025
78dc344
Changeset version bump (#10225)
github-actions[bot] Dec 20, 2025
6cf7be6
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 20, 2025
37765c8
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 20, 2025
f3ca7c4
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 21, 2025
5ae4d4d
Custom tool calling (#10083)
cte Dec 21, 2025
3beeac6
Remove the "test" custom tools (#10255)
cte Dec 21, 2025
2bb3755
Add custom tool definitions to @roo-code/types (#10233)
cte Dec 21, 2025
fb9245f
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 22, 2025
6b755ed
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 22, 2025
f23e9ac
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 22, 2025
08eed65
fix(evals): add missing packages/core to Dockerfile.runner (#10272)
hannesrudolph Dec 22, 2025
a148b0b
feat: add Cloud Team page with comprehensive team features (#10267)
roomote-v0[bot] Dec 22, 2025
e3cd031
feat: remove parallel_tool_calls parameter from litellm provider (#10…
roomote-v0[bot] Dec 22, 2025
c800c67
feat(build): add types package bundling and alias support
mini2s Dec 22, 2025
149e78e
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 22, 2025
a7d258b
update(settings): change default tool protocol to XML
mini2s Dec 22, 2025
529e0d7
fix: enable Requesty refresh models with credentials (#10273)
daniel-lxs Dec 22, 2025
6b141fb
fix: disable strict mode for MCP tools to preserve optional parameter…
daniel-lxs Dec 22, 2025
7fae76e
fix: move array-specific properties into anyOf variant in normalizeTo…
daniel-lxs Dec 22, 2025
24d988d
refactor(custom-tools): improve tool loading and instance consistency
mini2s Dec 22, 2025
a144a37
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 22, 2025
f462eeb
fix(chutes): add graceful fallback for model parsing (#10279)
hannesrudolph Dec 22, 2025
9b06a98
fix: emit tool_call_end events in OpenAI handler when streaming ends …
daniel-lxs Dec 22, 2025
0d3e81d
feat(core): add support for custom tool parsing in AssistantMessagePa…
mini2s Dec 23, 2025
2c5a4c8
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 23, 2025
d00d9ed
feat: deprecate XML tool protocol selection, force native for new tas…
daniel-lxs Dec 23, 2025
b37b387
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 23, 2025
518a440
feat(zai): add GLM-4.7 model with thinking mode support (#10282)
hannesrudolph Dec 23, 2025
44a7ba5
fix: improve reasoning_details accumulation and serialization (#10285)
hannesrudolph Dec 23, 2025
bd78a63
feat(evals): add message log deduper utility (#10286)
hannesrudolph Dec 23, 2025
e7c1851
feat(minimax): move environment_details to system message for thinkin…
hannesrudolph Dec 23, 2025
f21ec12
fix: add CRLF line ending normalization to search_replace and search_…
hannesrudolph Dec 23, 2025
eeaf33c
refactor(zai): merge environment_details into tool result instead of …
hannesrudolph Dec 23, 2025
edee332
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 23, 2025
2997566
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 23, 2025
061ae14
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 23, 2025
a8ac2ce
fix: emit tool_call_end events in BaseOpenAiCompatibleProvider (#10293)
hannesrudolph Dec 23, 2025
89e9261
fix: preserve reasoning_content in condense summary for DeepSeek-reas…
hannesrudolph Dec 23, 2025
dd44f8f
Release v3.37.0 (#10295)
mrubens Dec 23, 2025
30090de
Changeset version bump (#10296)
github-actions[bot] Dec 23, 2025
a7c1d24
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 23, 2025
71f312b
feat: enable mergeToolResultText for Roo Code Cloud provider (#10301)
hannesrudolph Dec 23, 2025
ddc0c01
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 23, 2025
044d502
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 23, 2025
0f3df0e
feat: add grace retry for empty assistant messages (#10297)
hannesrudolph Dec 23, 2025
40812dc
Release: v1.95.0 (#10309)
jr Dec 23, 2025
9b99890
feat(prompts): strengthen native tool-use guidance (#10311)
hannesrudolph Dec 23, 2025
ded6486
feat: enable mergeToolResultText for all OpenAI-compatible providers …
hannesrudolph Dec 23, 2025
53e1ff0
fix: preserve reasoning_details shape to prevent malformed responses …
hannesrudolph Dec 23, 2025
dfa7c35
fix(task): drain queued messages while waiting for ask (#10315)
hannesrudolph Dec 23, 2025
6afc59b
fix(openai): send native tool definitions by default (#10314)
hannesrudolph Dec 23, 2025
57cafa5
ux: Provider-centric signup (#10306)
brunobergher Dec 23, 2025
5c7939b
chore: add changeset for v3.37.1 (#10316)
mrubens Dec 23, 2025
1e71015
Changeset version bump (#10317)
github-actions[bot] Dec 23, 2025
efe97f7
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 24, 2025
d29555b
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 24, 2025
ae7d014
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 24, 2025
6d8be95
refactor: simplify tool protocol resolution logic
mini2s Dec 24, 2025
62a4ebf
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 25, 2025
02996f8
refactor: optimize stream rendering and file reading limits
mini2s Dec 25, 2025
ab0aff3
refactor(tools): simplify extractTextFromFile parameters
mini2s Dec 25, 2025
4a8f2bc
feat(chat): add tool protocol display to task header
mini2s Dec 25, 2025
e83f568
fix(test): respect user toolProtocol preference over model capabilities
mini2s Dec 25, 2025
66ef6d8
update(provider): update zgsm model handling and native tool protocol…
mini2s Dec 25, 2025
355f27b
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 25, 2025
446b7db
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 25, 2025
a07d28c
feat: remove OpenRouter Transforms feature (#10341)
roomote-v0[bot] Dec 25, 2025
a510223
feat: remove simpleReadFileTool completely (#10254)
roomote-v0[bot] Dec 25, 2025
8bce6cb
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 26, 2025
343d5e9
Add support for skills (#10335)
mrubens Dec 26, 2025
da4cf6d
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 26, 2025
c081410
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 26, 2025
6f16528
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 26, 2025
0d50ed6
Add support for npm packages and .env files to custom tools (#10336)
cte Dec 26, 2025
2eebf3c
fix: capture extended thinking signatures for tool use continuations …
daniel-lxs Dec 26, 2025
13370a2
feat: add optional mode field to slash command front matter (#10344)
roomote-v0[bot] Dec 27, 2025
72c142b
refactor(core,webview): improve code review types and performance
mini2s Dec 27, 2025
41637d2
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 27, 2025
510af82
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 27, 2025
c61dd7a
Remove the mergeToolResultText in the Roo provider for now (#10359)
mrubens Dec 27, 2025
25f76ce
Revert "fix: capture extended thinking signatures for tool use contin…
mrubens Dec 27, 2025
5c5ddd3
Release v3.38.0 (#10361)
mrubens Dec 27, 2025
ba1dd3c
Changeset version bump (#10362)
github-actions[bot] Dec 27, 2025
7980cd3
fix: enforce maxConcurrentFileReads limit in read_file tool (#10363)
roomote-v0[bot] Dec 27, 2025
c46532a
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 28, 2025
8cf3acc
refactor(zgsm): optimize native protocol handling and model ID usage
mini2s Dec 28, 2025
add06a2
docs: clarify path to Security Settings in privacy policy (#10367)
roomote-v0[bot] Dec 28, 2025
a18c9b7
Improve error message when read_file is used on directory (#10371)
roomote-v0[bot] Dec 29, 2025
1011064
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 29, 2025
b90e6cf
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 29, 2025
6948ed7
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 29, 2025
a42387e
Handle custom tool use similarly to MCP tools for ipc schema purposes…
jr Dec 29, 2025
e851b93
fix: correct GitHub repository URL in marketing page (#10377)
roomote-v0[bot] Dec 29, 2025
6ba7931
Revert "feat: enable mergeToolResultText for all OpenAI-compatible pr…
hannesrudolph Dec 29, 2025
ca8fd5c
fix: flush pending tool results before condensing context (#10379)
daniel-lxs Dec 29, 2025
958705a
chore: add changeset for v3.38.1 (#10384)
mrubens Dec 29, 2025
c193f59
Changeset version bump (#10385)
github-actions[bot] Dec 29, 2025
19b7dac
fix: update Cerebras maxTokens to 16384 (#10387)
sebastiand-cerebras Dec 30, 2025
0e9a765
docs: Replace Todo Lists video with Context Management video (#10375)
SannidhyaSah Dec 30, 2025
6d8fa39
Release: v1.96.0 (#10395)
jr Dec 30, 2025
9539553
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 30, 2025
f2abc39
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Dec 30, 2025
d33cdef
fix(utils): add optional chaining for provider settings
mini2s Dec 30, 2025
ed13921
feat(skills): align with Agent Skills spec (#10409)
hannesrudolph Dec 30, 2025
c37aa02
chore: remove human-relay provider (#10388)
hannesrudolph Dec 30, 2025
ca1bc18
Fix rate limit wait display (#10389)
hannesrudolph Dec 31, 2025
ca41119
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Dec 31, 2025
dea33f9
fix: prevent write_to_file from creating files at truncated paths (#1…
mrubens Dec 31, 2025
1179662
Release v3.38.2 (#10416)
mrubens Dec 31, 2025
2068531
Changeset version bump (#10417)
github-actions[bot] Dec 31, 2025
3074ccc
fix(claude-code): stop frequent sign-ins by hardening OAuth refresh (…
hannesrudolph Jan 1, 2026
586cf47
fix: add type check for lastMessage.text in TTS useEffect (#10431)
roomote-v0[bot] Jan 1, 2026
f05dada
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 2, 2026
277ec1b
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 2, 2026
787a257
feat(chat): add collapsible markdown blocks and improve protocol erro…
mini2s Jan 2, 2026
d24a1d6
refactor(task): restructure conversation history handling
mini2s Jan 3, 2026
08c3431
feat: recursively load .roo/rules and AGENTS.md from subdirectories (…
mrubens Jan 3, 2026
1459f01
Release: v1.99.0 (#10447)
mrubens Jan 3, 2026
c307dc7
fix: add maxConcurrentFileReads limit to native read_file tool schema…
roomote-v0[bot] Jan 4, 2026
b4302c7
chore: add changeset for v3.38.3 (#10450)
mrubens Jan 4, 2026
d23824d
Changeset version bump (#10451)
github-actions[bot] Jan 4, 2026
b6053fa
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 4, 2026
bf764aa
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 4, 2026
cbc0ae4
feat: add image support documentation to read_file native tool descri…
roomote-v0[bot] Jan 5, 2026
0bb551d
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 5, 2026
6d55b6a
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 5, 2026
f2276be
fix: add explicit deduplication for duplicate tool_result blocks (#10…
roomote-v0[bot] Jan 5, 2026
30dd454
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 5, 2026
b11d53a
VSCode shim + basic cli (#10452)
cte Jan 5, 2026
0397470
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 5, 2026
424bce6
Add an option to use our cli for evals (#10456)
cte Jan 5, 2026
3fb1c70
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 5, 2026
3fdb575
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 6, 2026
6f09481
fix: preserve tool_use blocks for all tool_results in kept messages d…
daniel-lxs Jan 6, 2026
6b13d1d
fix: add additionalProperties: false to MCP tool schemas for OpenAI R…
daniel-lxs Jan 6, 2026
361a8ba
feat(cli): add zgsm provider support
mini2s Jan 6, 2026
2269c55
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 6, 2026
861139c
Add a cli installer (#10474)
cte Jan 6, 2026
6440048
feat(zgsm): add debug mode and fix tool name handling
mini2s Jan 6, 2026
cd06643
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 6, 2026
d42e293
feat(i18n): add debug status to custom config label
mini2s Jan 6, 2026
4f423d1
refactor: improve terminal encoding handling and UI styling
mini2s Jan 6, 2026
c4c050c
feat(ui): add automatically focus option for chat input
mini2s Jan 6, 2026
503f402
feat(proxy): add debug-mode proxy routing (#10467)
hannesrudolph Jan 6, 2026
b504ab2
feat(terminal): enhance compilation markers and output handling
mini2s Jan 6, 2026
62eac59
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 6, 2026
741b268
fix: prevent duplicate tool_result blocks causing API errors (#10497)
daniel-lxs Jan 6, 2026
f51c987
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 7, 2026
781ed1e
feat: add Kimi K2 thinking model to Fireworks AI provider (#9202)
roomote-v0[bot] Jan 7, 2026
7f2978a
fix: add missing description fields for debugProxy configuration (#10…
roomote-v0[bot] Jan 7, 2026
d55c6d4
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 7, 2026
8493410
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 7, 2026
2d22804
Tweak the style of the follow up suggestion modes (#9260)
mrubens Jan 7, 2026
d0991af
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 7, 2026
41c5ff6
feat(web-evals): remember last Roo model selection + add evals skill …
hannesrudolph Jan 7, 2026
7bbdcdf
feat: rename YOLO to BRRR (#10507)
roomote-v0[bot] Jan 7, 2026
4d99e1d
refactor: migrate ZGSM env vars to COSTRICT
mini2s Jan 7, 2026
962f905
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 7, 2026
9700eab
feat: implement sticky provider profile for task-level API config per…
hannesrudolph Jan 7, 2026
494bbd6
feat(settings): move CHAT_SEARCH from experimental to UI settings
mini2s Jan 7, 2026
e287a82
fix: remove legacy Claude 2 series models from Bedrock provider (#10501)
roomote-v0[bot] Jan 7, 2026
43f7ce0
feat: add support for image file @mentions (#10189)
hannesrudolph Jan 7, 2026
b5301f2
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 7, 2026
d7d3f40
fix: handle PowerShell ENOENT error in os-name on Windows (#9897)
roomote-v0[bot] Jan 7, 2026
e3b90fb
feat: add xhigh reasoning effort to OpenAI compatible endpoints (#10061)
roomote-v0[bot] Jan 7, 2026
7552581
feat: filter @ mention file search results using .rooignore (#10174)
roomote-v0[bot] Jan 7, 2026
ca0c901
fix: use task stored API config as fallback for rate limit (#10266)
roomote-v0[bot] Jan 8, 2026
1573edf
fix: make command chaining examples shell-aware for Windows compatibi…
roomote-v0[bot] Jan 8, 2026
0cf883a
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 8, 2026
6f8db42
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 8, 2026
710e7dd
feat(types): add zai-glm-4.7 to Cerebras models (#10500)
sebastiand-cerebras Jan 8, 2026
06a990d
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 8, 2026
b2941d5
πŸ› Fix glitchy kangaroo bounce animation on welcome screen (#10035)
objectiveSee Jan 8, 2026
290605e
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 8, 2026
f84bead
Release v3.39.0 (#10537)
mrubens Jan 8, 2026
2ea72f3
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 8, 2026
3222c40
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 8, 2026
a10b450
feat: Change "Get Started" button label to "Create Roo Account" (#10543)
roomote-v0[bot] Jan 8, 2026
9ddbc9b
fix: add @roo-code/cli to changeset ignore list (#10545)
mrubens Jan 8, 2026
2cd4c2e
Changeset version bump (#10546)
github-actions[bot] Jan 8, 2026
a34dcf9
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 8, 2026
93bccfe
Update changelog for version 3.39.0 release
mrubens Jan 8, 2026
4881333
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 8, 2026
1d9f7f2
fix: change minItems from 2 to 1 for Anthropic API compatibility (#10…
daniel-lxs Jan 8, 2026
e3c0cd6
fix: disable Gemini thought signature persistence to prevent corrupte…
daniel-lxs Jan 8, 2026
ef4b950
fix: stabilize file paths during native tool call streaming (#10555)
daniel-lxs Jan 8, 2026
58b0441
Release v3.39.1 (#10557)
mrubens Jan 8, 2026
eb7d8f4
Changeset version bump (#10558)
github-actions[bot] Jan 8, 2026
caa3779
chore(cli): change default model to anthropic/claude-opus-4.5 (#10544)
mrubens Jan 8, 2026
9ac4499
fix: ensure assistant message content is never undefined for Gemini c…
daniel-lxs Jan 9, 2026
3c14252
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 9, 2026
2ff08b5
Update Terms of Service (effective January 9, 2026) (#10568)
mrubens Jan 9, 2026
debecc6
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 9, 2026
c37f4e6
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 9, 2026
ade10e2
fix(vscode-lm): order text parts before tool calls in assistant messa…
daniel-lxs Jan 9, 2026
7b771a2
fix: merge approval feedback into tool result instead of pushing dupl…
daniel-lxs Jan 9, 2026
b7bd859
feat: improve error messaging for stream termination errors from prov…
daniel-lxs Jan 9, 2026
4697b08
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 9, 2026
ad08efa
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 9, 2026
907b94b
fix(openai): remove convertToSimpleMessages to fix tool calling for O…
daniel-lxs Jan 9, 2026
19b7264
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 9, 2026
b51ae78
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 9, 2026
3171ffc
Move more types to @roo-code/types (for the cli) (#10583)
cte Jan 9, 2026
a4eb15b
Add some functionality to @roo-code/core for the cli (#10584)
cte Jan 9, 2026
237fa89
Add some slash commands that are useful for cli development (#10586)
cte Jan 9, 2026
108f78d
feat: add debug setting to settings page (#10580)
hannesrudolph Jan 9, 2026
168cfca
fix: round-trip Gemini thought signatures for tool calls (#10590)
hannesrudolph Jan 10, 2026
e39abbf
fix: make edit_file matching more resilient (#10585)
hannesrudolph Jan 10, 2026
8478944
chore(gemini): stop overriding tool allow/deny lists (#10592)
hannesrudolph Jan 10, 2026
d97e540
fix(cerebras): ensure all tools have consistent strict mode values (#…
roomote-v0[bot] Jan 10, 2026
5a82c33
chore: disable edit_file tool for Gemini/Vertex (#10594)
hannesrudolph Jan 10, 2026
658da2c
Release v3.39.2 (#10595)
mrubens Jan 10, 2026
1e62b5d
Changeset version bump (#10596)
github-actions[bot] Jan 10, 2026
ea9717d
Add a TUI (#10480)
cte Jan 10, 2026
e8ed344
Allow the cli release script to install locally for testing (#10597)
cte Jan 10, 2026
640b78e
feat(ipc): add retry mechanism and error handling
mini2s Jan 10, 2026
fc21101
More file organization for the cli (#10599)
cte Jan 10, 2026
4a71dbb
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 10, 2026
5672fdf
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 10, 2026
87856e1
refactor: rename roo-cli to cos-cli and update related references
mini2s Jan 10, 2026
a33117a
Some cleanup in ExtensionHost (#10600)
cte Jan 10, 2026
602f4f7
refactor: optimize response rendering and tool call handling
mini2s Jan 10, 2026
75d8958
Rename Roo Code Cloud Provider to Roo Code Router (#10560)
roomote-v0[bot] Jan 10, 2026
f99d116
chore: bump version to v1.102.0 (#10604)
mrubens Jan 10, 2026
fa7b041
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 10, 2026
fc1fc34
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 10, 2026
fa5fe75
Update router name in types (#10605)
mrubens Jan 10, 2026
352616a
Update Roo Code Router service name (#10607)
mrubens Jan 10, 2026
9c91fb3
chore: add changeset for v3.39.3 (#10608)
mrubens Jan 10, 2026
f1bbd29
Update router name in types (#10610)
mrubens Jan 10, 2026
611bb70
Changeset version bump (#10609)
github-actions[bot] Jan 10, 2026
f15d4e4
Merge branch 'main' of github.com:zgsm-ai/costrict into roo-to-main
mini2s Jan 10, 2026
82f9913
Merge remote-tracking branch 'upstream/main' into roo-to-main
mini2s Jan 10, 2026
f157e36
feat: add debug mode configuration and state management
mini2s Jan 10, 2026
4380b1c
fix(settings): add debug condition for ZgsmAI custom config
mini2s Jan 10, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion packages/types/npm/package.metadata.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@roo-code/types",
"version": "1.102.0",
"version": "1.103.0",
"description": "TypeScript type definitions for Roo Code.",
"publishConfig": {
"access": "public",
Expand Down
1 change: 1 addition & 0 deletions packages/types/src/global-settings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ export const globalSettingsSchema = z.object({
currentApiConfigName: z.string().optional(),
listApiConfigMeta: z.array(providerSettingsEntrySchema).optional(),
pinnedApiConfigs: z.record(z.string(), z.boolean()).optional(),
debug: z.boolean().optional(),
// Auto cleanup settings
autoCleanup: z
.object({
Expand Down
2 changes: 1 addition & 1 deletion packages/types/src/provider-settings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -738,7 +738,7 @@ export const MODELS_BY_PROVIDER: Record<
models: Object.keys(openAiNativeModels),
},
"qwen-code": { id: "qwen-code", label: "Qwen Code", models: Object.keys(qwenCodeModels) },
roo: { id: "roo", label: "Roo Code Cloud", models: [] },
roo: { id: "roo", label: "Roo Code Router", models: [] },
sambanova: {
id: "sambanova",
label: "SambaNova",
Expand Down
21 changes: 1 addition & 20 deletions packages/types/src/vscode-extension-host.ts
Original file line number Diff line number Diff line change
@@ -1,23 +1,3 @@
// import type {
// GlobalSettings,
// ProviderSettingsEntry,
// ProviderSettings,
// HistoryItem,
// ModeConfig,
// TelemetrySetting,
// Experiments,
// ClineMessage,
// ModelInfo,
// MarketplaceItem,
// TodoItem,
// CloudUserInfo,
// CloudOrganizationMembership,
// OrganizationAllowList,
// ShareVisibility,
// QueuedMessage,
// IZgsmModelResponseData,
// SerializedCustomToolDefinition,
// } from "@roo-code/types"
import { z } from "zod"

import type { GlobalSettings, RooCodeSettings } from "./global-settings.js"
Expand Down Expand Up @@ -248,6 +228,7 @@ export type ExtensionState = Pick<
| "alwaysAllowReadOnlyOutsideWorkspace"
| "alwaysAllowWrite"
| "autoCleanup"
| "debug"
| "alwaysAllowWriteOutsideWorkspace"
| "alwaysAllowWriteProtected"
| "alwaysAllowBrowser"
Expand Down
8 changes: 4 additions & 4 deletions src/api/providers/utils/response-render-config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,22 +9,22 @@ export const renderModes = {
interval: 5,
},
fast: {
limit: isJetbrains ? 10 : 5,
limit: 5,
interval: isJetbrains ? 20 : 10,
},
medium: {
limit: isJetbrains ? 20 : 10,
limit: 10,
interval: isJetbrains ? 40 : 20,
},
slow: {
limit: isJetbrains ? 40 : 20,
limit: 20,
interval: isJetbrains ? 80 : 40,
},
}

export function getApiResponseRenderMode() {
if (isJetbrains) {
return renderModes.medium
return renderModes.fast
}
const apiResponseRenderMode = vscode.workspace
.getConfiguration("zgsm")
Expand Down
3 changes: 3 additions & 0 deletions src/core/costrict/activate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,17 +49,20 @@ import prettyBytes from "pretty-bytes"
import { ensureProjectWikiSubtasksExists } from "./wiki/projectWikiHelpers"
import { isCliPatform, isJetbrainsPlatform } from "../../utils/platform"
import type { ModelInfo, ModelRecord } from "@roo-code/types"
import { updateDefaultDebug } from "../../utils/getDebugState"

const HISTORY_WARN_SIZE = 1000 * 1000 * 1000 * 3

/**
* Initialization entry
*/
async function initialize(provider: ClineProvider, logger: ILogger) {
const oldDebug = provider.getValue("debug")
const oldEnabled = provider.getValue("zgsmCodebaseIndexEnabled")
if (oldEnabled == null) {
await provider.setValue("zgsmCodebaseIndexEnabled", true)
}
updateDefaultDebug(oldDebug ?? false)
//
ZgsmAuthStorage.setProvider(provider)
ZgsmAuthApi.setProvider(provider)
Expand Down
5 changes: 3 additions & 2 deletions src/core/webview/ClineProvider.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2196,6 +2196,7 @@ export class ClineProvider
featureRoomoteControlEnabled,
isBrowserSessionActive,
autoCleanup,
debug,
// Messages,
} = await this.getState()

Expand Down Expand Up @@ -2230,14 +2231,14 @@ export class ClineProvider
// Check if there's a system prompt override for the current mode
const currentMode = mode ?? defaultModeSlug
const hasSystemPromptOverride = await this.hasFileBasedSystemPromptOverride(currentMode)
const debug = vscode.workspace.getConfiguration(Package.name).get<boolean>("debug", false)
if (!debug) {
apiConfiguration.useZgsmCustomConfig = false
}
return {
version: this.context.extension?.packageJSON?.version ?? "",
apiConfiguration,
autoCleanup,
debug,
customInstructions,
alwaysAllowReadOnly: alwaysAllowReadOnly ?? false,
alwaysAllowReadOnlyOutsideWorkspace: alwaysAllowReadOnlyOutsideWorkspace ?? false,
Expand Down Expand Up @@ -2378,7 +2379,6 @@ export class ClineProvider
openRouterImageApiKey,
openRouterImageGenerationSelectedModel,
featureRoomoteControlEnabled,
debug,
claudeCodeIsAuthenticated: await (async () => {
try {
const { claudeCodeOAuthManager } = await import("../../integrations/claude-code/oauth.js")
Expand Down Expand Up @@ -2500,6 +2500,7 @@ export class ClineProvider
// Return the same structure as before.
providerSettings.openAiHeaders = providerSettings.openAiHeaders ?? {}
return {
debug: stateValues.debug ?? false,
autoCleanup: stateValues.autoCleanup ?? DEFAULT_AUTO_CLEANUP_SETTINGS,
apiConfiguration: providerSettings,
lastShownAnnouncementId: stateValues.lastShownAnnouncementId,
Expand Down
2 changes: 2 additions & 0 deletions src/core/webview/webviewMessageHandler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@ import delay from "delay"
// import { ensureProjectWikiSubtasksExists } from "../costrict/wiki/projectWikiHelpers"
import { setPendingTodoList } from "../tools/UpdateTodoListTool"
import { getEditorType } from "../../utils/getEditorType"
import { updateDefaultDebug } from "../../utils/getDebugState"

export const webviewMessageHandler = async (
provider: ClineProvider,
Expand Down Expand Up @@ -2469,6 +2470,7 @@ export const webviewMessageHandler = async (
await vscode.workspace
.getConfiguration(Package.name)
.update("debug", message.bool ?? false, vscode.ConfigurationTarget.Global)
updateDefaultDebug(message.bool ?? false)
await provider.postStateToWebview()
break
}
Expand Down
2 changes: 2 additions & 0 deletions src/shared/api.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ export type ApiHandlerOptions = Omit<ProviderSettings, "apiProvider"> & {
* When undefined, Ollama will use the model's default num_ctx from the Modelfile.
*/
ollamaNumCtx?: number

debug?: boolean
}

// RouterName
Expand Down
12 changes: 9 additions & 3 deletions src/utils/getDebugState.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
import * as vscode from "vscode"
import { Package } from "../shared/package"
import { isJetbrainsPlatform } from "./platform"
export let defaultDebug = false

export const isDebug = () =>
vscode.workspace.getConfiguration(Package.name).get<boolean>("debug", isJetbrainsPlatform())
export const updateDefaultDebug = (debug: boolean) => {
defaultDebug = debug
}

export const isDebug = () => {
const debug = vscode.workspace.getConfiguration(Package.name).get<boolean>("debug", defaultDebug)
return debug
}
4 changes: 3 additions & 1 deletion webview-ui/src/components/settings/SettingsView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -225,6 +225,7 @@ const SettingsView = forwardRef<SettingsViewRef, SettingsViewProps>(({ onDone, t
includeCurrentCost,
maxGitStatusFiles,
autoCleanup,
debug,
} = cachedState

const apiConfiguration = useMemo(() => cachedState.apiConfiguration ?? {}, [cachedState.apiConfiguration])
Expand Down Expand Up @@ -448,6 +449,7 @@ const SettingsView = forwardRef<SettingsViewRef, SettingsViewProps>(({ onDone, t
zgsmCodebaseIndexEnabled: zgsmCodebaseIndexEnabled ?? true,
maxReadCharacterLimit: maxReadCharacterLimit ?? 40000,
autoCleanup,
debug,
},
})
// These have more complex logic so they aren't (yet) handled
Expand Down Expand Up @@ -944,7 +946,7 @@ const SettingsView = forwardRef<SettingsViewRef, SettingsViewProps>(({ onDone, t
<About
telemetrySetting={telemetrySetting}
setTelemetrySetting={setTelemetrySetting}
debug={cachedState.debug}
debug={debug}
setDebug={setDebug}
/>
)}
Expand Down
4 changes: 2 additions & 2 deletions webview-ui/src/components/settings/providers/Roo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -58,8 +58,8 @@ export const Roo = ({
defaultModelId={rooDefaultModelId}
models={routerModels?.roo ?? {}}
modelIdKey="apiModelId"
serviceName="Roo Code Cloud"
serviceUrl="https://roocode.com"
serviceName="Roo Code Router"
serviceUrl="https://app.roocode.com"
organizationAllowList={organizationAllowList}
errorMessage={modelValidationError}
simplifySettings={simplifySettings}
Expand Down
2 changes: 1 addition & 1 deletion webview-ui/src/components/settings/providers/ZgsmAI.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,7 @@ export const ZgsmAI = ({
)}
</>
)}
{!fromWelcomeView && useZgsmCustomConfig && (
{!fromWelcomeView && useZgsmCustomConfig && debug && (
<>
<R1FormatSetting
onChange={handleInputChange("openAiR1FormatEnabled", noTransform)}
Expand Down
9 changes: 9 additions & 0 deletions webview-ui/src/context/ExtensionStateContext.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,8 @@ export interface ExtensionStateContextType extends ExtensionState {
routerModels?: RouterModels
autoCleanup?: AutoCleanupSettings
setAutoCleanup: (value: AutoCleanupSettings) => void
debug?: boolean
setDebug: (value: boolean) => void
includeDiagnosticMessages?: boolean
setIncludeDiagnosticMessages: (value: boolean) => void
maxDiagnosticMessages?: number
Expand Down Expand Up @@ -216,6 +218,7 @@ export const ExtensionStateContextProvider: React.FC<{ children: React.ReactNode
apiConfiguration: {},
version: "",
autoCleanup: DEFAULT_AUTO_CLEANUP_SETTINGS,
debug: false,
clineMessages: [],
taskHistory: [],
shouldShowAnnouncement: false,
Expand Down Expand Up @@ -398,6 +401,10 @@ export const ExtensionStateContextProvider: React.FC<{ children: React.ReactNode
if ((newState as any).autoCleanup !== undefined) {
setState((prevState) => ({ ...prevState, autoCleanup: (newState as any).autoCleanup }))
}
// Update debug if present in state message
if ((newState as any).debug !== undefined) {
setState((prevState) => ({ ...prevState, debug: (newState as any).debug }))
}
// Handle marketplace data if present in state message
if (newState.marketplaceItems !== undefined) {
setMarketplaceItems(newState.marketplaceItems)
Expand Down Expand Up @@ -670,6 +677,8 @@ export const ExtensionStateContextProvider: React.FC<{ children: React.ReactNode
setCondensingApiConfigId: (value) => setState((prevState) => ({ ...prevState, condensingApiConfigId: value })),
autoCleanup: state.autoCleanup ?? DEFAULT_AUTO_CLEANUP_SETTINGS,
setAutoCleanup: (value) => setState((prevState) => ({ ...prevState, autoCleanup: value })),
debug: state.debug ?? false,
setDebug: (value) => setState((prevState) => ({ ...prevState, debug: value })),
setCustomCondensingPrompt: (value) =>
setState((prevState) => ({ ...prevState, customCondensingPrompt: value })),
setProfileThresholds: (value) => setState((prevState) => ({ ...prevState, profileThresholds: value })),
Expand Down