.claude/skills/xcode-file-management/SKILL.md
Use when adding, removing, moving, or renaming Swift source files in the dd-sdk-ios Xcode project. Use when the task involves file creation, deletion, or relocation in any module (DatadogRUM, DatadogLogs, DatadogCore, etc.). Use when you would otherwise reach for Write, Bash mv/mkdir/rm, or manual pbxproj editing for file management.
npx skillsauth add DataDog/dd-sdk-ios dd-sdk-ios:xcode-file-managementInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
The dd-sdk-ios project is both an SPM package and an Xcode workspace with .pbxproj files. SPM builds discover files automatically, but Xcode does not — it requires explicit registration in .pbxproj. The Xcode MCP server (available from Xcode 26.3+) handles this automatically. Always use it.
The Xcode MCP server requires Xcode 26.3+ and must be enabled in Claude Code settings. Verify it's active by checking that XcodeListWindows is available. If not, stop and ask the user to enable the Xcode MCP server before proceeding with file operations.
Never use Write, Bash mv/mkdir/rm, or Edit for file creation, deletion, or movement in this project.
Use Xcode MCP tools instead — they update the filesystem AND the .pbxproj in one atomic operation.
Target membership is implicit — Xcode MCP infers the target from the navigator path where the file is placed. A file added under DatadogLogs/ is automatically assigned to the DatadogLogs target. No explicit target specification is needed.
| Operation | Use This Tool | Never Use |
|-----------|--------------|-----------|
| Create file | XcodeWrite | Write, Bash touch/cat |
| Delete file | XcodeRM | Bash rm |
| Move / rename | XcodeMV | Bash mv |
| Create directory/group | XcodeMakeDir | Bash mkdir |
| Read file | XcodeRead | (either is fine) |
| Search files | XcodeGlob, XcodeGrep | (either is fine) |
| Excuse | Reality |
|--------|---------|
| "SPM auto-discovers files, pbxproj doesn't matter" | The Xcode workspace has .pbxproj files. They must stay in sync or Xcode breaks. |
| "It's faster to use bash" | A file invisible to Xcode causes build failures and confuses teammates. |
| "I'll update pbxproj manually after" | pbxproj is binary-adjacent XML; manual edits cause merge conflicts and corruption. |
| "The file is just temporary" | Temporary files still break the build if Xcode can't see them. |
# ✅ Add a new source file
XcodeWrite(
tabIdentifier: <tab>,
filePath: "DatadogLogs/Sources/LogBatcher.swift",
content: "..."
)
# → Creates file on disk AND registers it in pbxproj + target membership
# ✅ Move a file
XcodeMV(
tabIdentifier: <tab>,
sourcePath: "DatadogLogs/Sources/LogBatcher.swift",
destinationPath: "DatadogLogs/Sources/Batching/LogBatcher.swift"
)
# → Moves file on disk AND updates pbxproj reference
# ❌ Wrong — file created on disk but invisible to Xcode
Write(file_path: ".../DatadogLogs/Sources/LogBatcher.swift", content: "...")
XcodeListWindows() # → returns tabIdentifier for open workspace
Xcode MCP uses project navigator paths, not filesystem paths. Use XcodeLS to discover them:
XcodeLS(tabIdentifier: <tab>, path: "DatadogLogs")
# → ["ConsoleLogger.swift", "Feature/LogsFeature.swift", ...]
# Note: paths are relative to the Xcode group, not the filesystem root
To create DatadogLogs/Sources/Foo.swift on disk, use the navigator path DatadogLogs/Foo.swift.
After adding files to a module, verify the build still works:
BuildProject(tabIdentifier: <tab>)
tools
Use when asked to run tests in the dd-sdk-ios project — whether a full module suite, a specific test class, or a single test method. Use when choosing between make, xcodebuild, or Xcode MCP for running iOS/tvOS/visionOS tests.
development
Use when creating a pull request in dd-sdk-ios. Use when writing PR titles, PR body, or choosing the target branch.
development
Use when committing changes in dd-sdk-ios. Use when writing commit messages, signing commits, or staging files before a commit.
development
Use when creating a new branch in dd-sdk-ios for a JIRA ticket or feature. Use when choosing a branch name or base branch for development work.