DevSpace brings a Codex-style coding-agent loop to ChatGPT and other MCP hosts: inspect the repo, follow local instructions, make scoped edits, run verification, and show the user what changed.
ChatGPT should call open_workspace once for a project folder:
{
"path": "~/work/my-project"
}The result includes a workspaceId. All later file, search, edit, show-changes,
and shell calls should reuse that same workspaceId.
Do not reopen the same folder unless:
- the
workspaceIdis rejected as unknown - the user switches to another folder
- the user switches between checkout and worktree mode
- the user explicitly asks to reopen
Checkout mode is the default. DevSpace opens the actual directory:
{
"path": "~/work/my-project"
}Use this when the user wants ChatGPT to work in the current checkout.
Use worktree mode for isolated parallel work:
{
"path": "~/work/my-project",
"mode": "worktree"
}Managed worktrees are created under:
~/.devspace/worktrees
Worktree mode requires a Git repository with at least one commit. It starts from
HEAD unless baseRef is provided.
Uncommitted source checkout changes are not copied into the managed worktree. DevSpace reports when the source checkout was dirty so the model can decide how to proceed with the user.
When a workspace opens, DevSpace loads root-level instruction files:
AGENTS.mdAGENTS.MDCLAUDE.mdCLAUDE.MD
Nested instruction files are returned as availableAgentsFiles. The model
should read the relevant nested file before working under that directory.
This keeps instructions explicit and inspectable instead of silently injecting new context during later tool calls.
Skills are enabled by default for coding-agent workflows.
DevSpace discovers skills from:
DEVSPACE_AGENT_DIR, which defaults to~/.codex- project
.pi/skills - optional paths from
DEVSPACE_SKILL_PATHS
When open_workspace returns matching skills, the model should read the
advertised SKILL.md before following that skill.
Skill paths may be outside the workspace. DevSpace only permits reading:
- advertised
SKILL.mdfiles - files under a skill directory after that skill's
SKILL.mdhas been read
Set DEVSPACE_SKILLS=0 to hide skills from workspace output.
Short names are the default:
open_workspacereadwriteeditbash
By default, DevSpace also runs in DEVSPACE_TOOL_MODE=minimal, so dedicated
grep, glob, and ls tools are hidden. Use bash with command-line tools
such as rg, find, and ls for search and directory inspection.
Legacy names are available with DEVSPACE_TOOL_NAMING=legacy:
open_workspaceread_filewrite_fileedit_filerun_shell
Use DEVSPACE_TOOL_MODE=full to restore dedicated search and directory tools.
By default, DEVSPACE_WIDGETS=full.
In that mode, DevSpace attaches widget UI to the exposed workspace, file, edit,
and shell tools. The aggregate show_changes tool is not exposed by default.
Use DEVSPACE_WIDGETS=off to disable widget UI, or DEVSPACE_WIDGETS=changes
to expose the aggregate show-changes flow.
The shell tool is for commands that belong in a terminal:
- tests
- builds
- git inspection
- package scripts
- environment checks
File writes should go through the edit/write tools rather than shell
redirection, heredocs, tee, sed -i, or generated scripts.