Skip to content

Add GitHub Copilot as a built-in provider#3076

Open
huxcrux wants to merge 99 commits into
pingdotgg:mainfrom
huxcrux:hux-copliot-fix
Open

Add GitHub Copilot as a built-in provider#3076
huxcrux wants to merge 99 commits into
pingdotgg:mainfrom
huxcrux:hux-copliot-fix

Conversation

@huxcrux

@huxcrux huxcrux commented Jun 14, 2026

Copy link
Copy Markdown
Contributor

This PR supersedes #2185. It includes the full Copilot integration from that PR plus the fixes and hardening discovered while testing it against the current codebase.

What Changed

  • Added GitHub Copilot as a first-class provider using the official Copilot SDK.
  • Wired Copilot through the server runtime for auth/status checks, model discovery, session start/resume, turn sending, permission replies, request handling, and event streaming.
  • Added Copilot-backed git text generation for commit messages, PR descriptions, branch names, and thread titles.
  • Added Copilot provider settings, defaults, model traits, reasoning effort, context window handling, and persisted configuration.
  • Updated the web UI so Copilot appears in provider/model pickers, settings, icons, context window selection, task rendering, and git writing model selection.
  • Hardened Copilot runtime behavior for queued turns, duplicate completions, tool-only turns, empty diffs, missing checkpoint refs, stale resume cursors, failed sends, task completions, and rollback-safe checkpointing.
  • Added regression coverage for the Copilot adapter, provider probing, text generation, context window handling, and related projection flows.

Why

T3 Code supports multiple agent providers, but did not have GitHub Copilot support. This adds Copilot end to end in the same shape as the existing providers, so users can configure Copilot, select Copilot models, use Copilot for git text generation, and rely on the same session/runtime flows as other providers.

The extra hardening keeps Copilot predictable under real usage: turns complete once, tool output and reasoning project correctly, diffs are only emitted when meaningful, permission replies resolve cleanly, checkpoint handling is safer, and provider status/model data stays accurate.

UI Changes

  • Added Copilot to the provider/model picker.
  • Added Copilot settings and model configuration surfaces.
  • Added Copilot icons, reasoning/context-window controls, and task output rendering.

Updated model picker:
image

Provider settings:
image

Checklist

  • This PR is small and focused
  • I explained what changed and why
  • I included before/after screenshots for any UI changes
  • I included a video for animation/interaction changes

Note

Medium Risk
Touches checkpoint revert ordering and provider conversation rollback (filesystem + provider state), plus turn-completion matching logic that affects session readiness across providers.

Overview
Adds GitHub Copilot as a server provider via a new CopilotDriver and @github/copilot / @github/copilot-sdk dependencies, wiring snapshot, adapter, and text generation like other built-in drivers.

Checkpoint revert now verifies the target ref exists, restores the filesystem before calling provider rollback, and skips rollback when filesystem restore fails. If rollback fails after a successful restore, it attempts to restore the current checkpoint, refreshes workspace entries, and records a failure activity instead of leaving a half-applied revert.

Runtime ingestion accepts turn.completed events without a turnId when the active turn still matches the provider session (or the provider has already cleared the active turn), and maps content.delta streams into reasoning and tool output activities.

First-turn orchestration queues title/branch generation on a drainable worker (with retries), broadens when auto-generated titles may replace truncated or provider-expanded seeds, and keeps latestTurnId on thread.session-set when activeTurnId is null.

Reviewed by Cursor Bugbot for commit 790af4a. Bugbot is set up for automated code reviews on this repo. Configure here.

Note

Add GitHub Copilot as a built-in provider with full text generation and adapter support

  • Registers a new copilot provider driver (CopilotDriver.ts) and wires it into the built-in driver registry, making GitHub Copilot selectable in the UI alongside other providers.
  • Adds CopilotTextGeneration.ts for commit messages, PR content, branch names, and thread titles (titles are generated locally without starting a Copilot SDK session).
  • Implements CopilotAdapter.ts and CopilotProvider.ts for session lifecycle, status probing, auth snapshots, and periodic refresh.
  • Adds CopilotToolClassification.ts to map Copilot tool events to typed lifecycle categories (file change, command execution, web search, etc.).
  • Extends contracts (settings.ts, model.ts) with Copilot-specific settings schema, default models (gpt-4.1), and display name mappings.
  • Fixes deriveLatestContextWindowSnapshot to prefer the latest bounded window snapshot, stop at compaction events, and fall back to token-only snapshots when no limit is available.
  • Fixes non-effort select descriptors (e.g. contextTier, variant) from incorrectly setting promptEffort in the composer state.

Macroscope summarized 790af4a.

@coderabbitai

coderabbitai Bot commented Jun 14, 2026

Copy link
Copy Markdown

Important

Review skipped

Auto reviews are disabled on this repository. Please check the settings in the CodeRabbit UI or the .coderabbit.yaml file in this repository. To trigger a single review, invoke the @coderabbitai review command.

⚙️ Run configuration

Configuration used: Repository UI

Review profile: CHILL

Plan: Pro

Run ID: c5c40333-565c-4003-915c-d7234a1351d8

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

Use the checkbox below for a quick retry:

  • 🔍 Trigger review
✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands.

@github-actions github-actions Bot added size:XXL 1,000+ changed lines (additions + deletions). vouch:unvouched PR author is not yet trusted in the VOUCHED list. labels Jun 14, 2026
Comment thread apps/server/src/orchestration/Layers/CheckpointReactor.ts
Comment thread packages/shared/src/providerToolClassification.ts Outdated
Comment thread apps/server/src/orchestration/Layers/CheckpointReactor.ts
@macroscopeapp

macroscopeapp Bot commented Jun 14, 2026

Copy link
Copy Markdown
Contributor

Approvability

Verdict: Needs human review

Diff is too large for automated approval analysis. A human reviewer should evaluate this PR.

You can customize Macroscope's approvability policy. Learn more.

Comment thread apps/server/src/orchestration/Layers/CheckpointReactor.ts
Comment thread packages/shared/src/providerToolClassification.ts Outdated
Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts Outdated
Comment thread pnpm-workspace.yaml Outdated
Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts Outdated
Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts
Comment thread apps/server/src/provider/copilotRuntime.ts Outdated
Comment thread packages/contracts/src/settings.ts
Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts
Comment thread apps/server/src/orchestration/Layers/ProviderCommandReactor.ts Outdated
@huxcrux huxcrux force-pushed the hux-copliot-fix branch 4 times, most recently from 5ae2460 to acf1c04 Compare June 18, 2026 01:41
Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts
Comment thread apps/server/src/orchestration/Layers/ProviderRuntimeIngestion.ts

@cursor cursor Bot left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Cursor Bugbot has reviewed your changes using high effort and found 1 potential issue.

Fix All in Cursor

❌ Bugbot Autofix is OFF. To automatically fix reported issues with cloud agents, enable autofix in the Cursor dashboard.

Reviewed by Cursor Bugbot for commit fd59d96. Configure here.

Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts

@macroscopeapp macroscopeapp Bot left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Effect service conventions review for the new GitHub Copilot provider. The previously-flagged import-namespace, CopilotCliPathResolutionError, and TextGenerationShape items now look resolved at this head. Two error-convention issues remain in changed scope.

Posted via Macroscope — Effect Service Conventions

Comment thread apps/server/src/provider/copilotRuntime.ts Outdated
Comment thread apps/server/src/provider/Layers/CopilotAdapter.ts Outdated
@huxcrux huxcrux force-pushed the hux-copliot-fix branch from fd59d96 to 7e42706 Compare July 3, 2026 10:44

@macroscopeapp macroscopeapp Bot left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Effect service conventions: one new finding in CopilotTextGeneration.ts. Previously flagged issues (CopilotProbePromiseError in copilotRuntime.ts and the inline error-construction helpers in CopilotAdapter.ts) remain unaddressed but are not re-commented here to avoid duplication.

Posted via Macroscope — Effect Service Conventions

Comment thread apps/server/src/textGeneration/CopilotTextGeneration.ts Outdated
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:XXL 1,000+ changed lines (additions + deletions). vouch:unvouched PR author is not yet trusted in the VOUCHED list.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants