* Fix Git URL in README for package installation
Updated the Git URL for adding the package to include the branch name.
* fix: Clean up Claude Code config from all scopes to prevent stale config conflicts (#664)
- Add RemoveFromAllScopes helper to remove from local/user/project scopes
- Use explicit --scope local when registering
- Update manual snippets to show multi-scope cleanup
- Handle legacy 'unityMCP' naming in all scopes
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: Make Claude Code status check thread-safe (#664)
The background thread status check was accessing main-thread-only Unity
APIs (Application.platform, EditorPrefs via HttpEndpointUtility and
AssetPathUtility), causing "GetString can only be called from main thread"
errors.
Now all main-thread-only values are captured before Task.Run() and passed
as parameters to CheckStatusWithProjectDir().
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: Persist client dropdown selection and remove dead IO code
- Remember last selected client in EditorPrefs so it restores on window
reopen (prevents hiding config issues by defaulting to first client)
- Remove dead Outbound class, _outbox BlockingCollection, and writer
thread that was never used (nothing ever enqueued to outbox)
- Keep only failure IO logs, remove verbose success logging
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* feat: Auto-detect beta package to enable UseBetaServer + workflow updates
- Add IsPreReleaseVersion() helper to detect beta/alpha/rc package versions
- UseBetaServer now defaults to true only for prerelease package versions
- Main branch users get false default, beta branch users get true default
- Update beta-release.yml to set Unity package version with -beta.1 suffix
- Update release.yml to merge beta → main and strip beta suffix
- Fix CodexConfigHelperTests to explicitly set UseBetaServer for determinism
- Use EditorConfigurationCache consistently for UseBetaServer access
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: Address code review feedback for thread-safety and validation
- Add thread-safe overloads for GetBetaServerFromArgs/List that accept
pre-captured useBetaServer and gitUrlOverride parameters
- Use EditorConfigurationCache.SetUseBetaServer() in McpAdvancedSection
for atomic cache + EditorPrefs update
- Add semver validation guard in beta-release.yml before version arithmetic
- Add semver validation guard in release.yml after stripping prerelease suffix
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: Complete thread-safety for GetBetaServerFromArgs overloads
- Add packageSource parameter to thread-safe overloads to avoid calling
GetMcpServerPackageSource() (which uses EditorPrefs) from background threads
- Apply quoteFromPath logic to gitUrlOverride and packageSource paths to
handle local paths with spaces correctly
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: Patch legacy connection pool in transport tests to prevent real Unity discovery
The auto-select tests were failing because they only patched PluginHub
but not the fallback legacy connection pool discovery. When PluginHub
returns no results, the middleware falls back to discovering instances
via get_unity_connection_pool(), which found the real running Unity.
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>