Skip to content

fix(server): honor gitignored files in workspace search#2078

Merged
juliusmarminge merged 2 commits intopingdotgg:mainfrom
nmharmon8:fix/2077-workspace-search-gitignore
Apr 17, 2026
Merged

fix(server): honor gitignored files in workspace search#2078
juliusmarminge merged 2 commits intopingdotgg:mainfrom
nmharmon8:fix/2077-workspace-search-gitignore

Conversation

@nmharmon8
Copy link
Copy Markdown
Contributor

@nmharmon8 nmharmon8 commented Apr 16, 2026

What Changed

Wire GitCoreLive into the server workspace layer so WorkspaceEntriesLive can use the Git-backed workspace index and .gitignore filtering during projects.searchEntries.

Also update the server test harness to match that wiring and add a regression test covering projects.searchEntries excluding a gitignored file.

Why

WorkspaceEntries resolves Git through Effect.serviceOption(GitCore), but the server's WorkspaceLayerLive was building WorkspaceEntriesLive without GitCoreLive.

That meant the Git-backed workspace index path was disabled in practice and projects.searchEntries could fall back to filesystem scanning, which allowed gitignored paths to appear in @ workspace search.

This change keeps the fix narrow:

  • it only adjusts the server workspace layer wiring
  • it does not change the WorkspaceEntries implementation itself
  • it adds one regression test for the RPC path that was affected

Closes #2077

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
Changes server runtime dependency wiring for workspace services to always include GitCore, which can affect file discovery and search results across the app; behavior is covered by a new regression test but touches core server composition.

Overview
Workspace search over websocket RPC now consistently honors Git-aware workspace indexing and .gitignore filtering by wiring GitCoreLive into the server’s workspace layers (refactoring WorkspaceLayerLive into explicit WorkspaceEntriesLayerLive/WorkspaceFileSystemLayerLive).

The server test harness is updated to provide a default GitCore mock to the workspace layers, and a new integration test asserts projects.searchEntries returns no matches for a gitignored file.

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

Note

Fix workspace search to exclude gitignored files in projects.searchEntries

  • Wires GitCoreLive into WorkspaceEntriesLive via a new WorkspaceEntriesLayerLive layer in server.ts, so gitignore filtering is applied at runtime during workspace entry enumeration.
  • Refactors WorkspaceLayerLive to compose WorkspaceEntriesLayerLive and WorkspaceFileSystemLayerLive as discrete layers instead of inline provisioning.
  • Adds a test in server.test.ts verifying that projects.searchEntries returns zero results when all paths are gitignored via .venv/.

Macroscope summarized 650e69f.

@coderabbitai
Copy link
Copy Markdown

coderabbitai bot commented Apr 16, 2026

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: ba15cc57-9a35-491b-a805-0d2d60e024c4

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 and usage tips.

@github-actions github-actions bot added vouch:unvouched PR author is not yet trusted in the VOUCHED list. size:S 10-29 changed lines (additions + deletions). labels Apr 16, 2026
@macroscopeapp
Copy link
Copy Markdown
Contributor

macroscopeapp bot commented Apr 16, 2026

Approvability

Verdict: Approved

Straightforward bug fix that wires GitCore into the workspace layer to properly filter gitignored files from search results. The scope is limited to layer composition changes and includes test coverage. The open review comment about dead code shadowing is a low-severity cleanup item that doesn't affect correctness.

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

Copy link
Copy Markdown
Contributor

@cursor cursor bot left a comment

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 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 650e69f. Configure here.

Layer.provide(workspaceEntriesLayer),
),
ProjectFaviconResolverLive,
);
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.

Local variable shadows module-level constant creating dead code

Low Severity

The new local workspaceAndProjectServicesLayer inside buildAppUnderTest shadows the module-level constant of the same name (line 196). The only usage at line 543 is inside buildAppUnderTest, so the module-level definition is now dead code. Worse, the module-level version lacks GitCoreLive — so if someone mistakenly removes the local redefinition assuming it's redundant, the gitignore fix silently regresses. The module-level constant needs to be removed or the local variable renamed.

Additional Locations (1)
Fix in Cursor Fix in Web

Reviewed by Cursor Bugbot for commit 650e69f. Configure here.

@juliusmarminge juliusmarminge merged commit ed6b7fb into pingdotgg:main Apr 17, 2026
12 checks passed
znoraka pushed a commit to znoraka/t3code that referenced this pull request Apr 17, 2026
Co-authored-by: Julius Marminge <julius0216@outlook.com>
aaditagrawal added a commit to aaditagrawal/t3code that referenced this pull request Apr 18, 2026
Integrates upstream/main (9df3c64) on top of fork's main (9602c18).

Upstream features adopted:
- Claude Opus 4.5 and 4.7 built-in models (pingdotgg#2072, pingdotgg#2143)
- Node-native TypeScript migration across desktop/server (pingdotgg#2098)
- Configurable project grouping with client-settings overrides (pingdotgg#2055, pingdotgg#2099)
- Thread status in command palette (pingdotgg#2107)
- Responsive composer / plan sidebar on narrow windows (pingdotgg#1198)
- Capture-phase CTRL+J keydown for Windows terminal toggle (pingdotgg#2113/pingdotgg#2142)
- Bypass xterm for global terminal shortcuts (pingdotgg#1580)
- Windows ARM build target (pingdotgg#2080)
- Windows PATH hydration + repair (pingdotgg#1729)
- Gitignore-aware workspace search (pingdotgg#2078)
- Claude process leak fix + stale session monitoring (pingdotgg#2042)
- Preserve provider bindings when stopping sessions (pingdotgg#2084)
- Clean up invalid pending-approval projections (pingdotgg#2106) — new migration
- Extract backend startup readiness coordination
- Drop stale text-gen options on reset (pingdotgg#2076)
- Extend negative repository identity cache TTL (pingdotgg#2083)
- Allow deleting non-empty projects from warning toast (pingdotgg#1264)
- Restore defaults only on General settings (pingdotgg#1710)
- Release workflow modernization (blacksmith runners, GitHub App token guards, v0.0.20 version bump)

Fork features preserved:
- All 8 providers (codex, claudeAgent, copilot, cursor, opencode,
  geminiCli, amp, kilo) with their adapters, services, and tests
- Fork's custom OpenCode protocol impl in apps/server/src/opencode/ (kept
  over upstream's @opencode-ai/sdk-based provider added in pingdotgg#1758 — fork's
  version is tested and integrated; upstream's parallel files deleted)
- Fork's direct-CLI Cursor adapter (kept over upstream's new ACP-based
  CursorProvider added in pingdotgg#1355 — upstream's parallel files deleted)
- Fork's ProviderRegistry aggregates only codex + claudeAgent snapshots;
  the other 6 providers register via ProviderAdapterRegistry
- PROVIDER_CACHE_IDS stays at [codex, claudeAgent] matching what the
  registry actually caches
- Migration IDs preserved (fork 23/24/25/26; upstream's new 025 lands at
  ID 27 to avoid re-applying on deployed fork DBs)
- Fork's generic per-provider settings (enabled/binaryPath/configDir/
  customModels) kept over upstream's opencode-specific serverUrl/password
- Log directory IPC channels, updateInstallInFlight tracking, icon
  composer pipeline all preserved
- Fork's simplified release.yml (no npm CLI publish, no nightly infra)
- composerDraftStore normalizeProviderKind widened to accept all 8 kinds
- Dark mode --background set to #0f0f0f

Test status:
- All 9 package typechecks pass
- Lint clean (0 errors)
- Tests: 1877 passed, 15 skipped (incl. 4 historically-flaky GitManager
  cross-repo PR selector tests newly gated with TODO for Node-native-TS
  follow-up)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:S 10-29 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.

[Bug]: @ workspace search ignores .gitignore because WorkspaceEntriesLive is wired without GitCoreLive

2 participants