docs/platforms/mac/child-process.md
The macOS app manages the Gateway via launchd by default and does not spawn
the Gateway as a child process. It first tries to attach to an already-running
Gateway on the configured port; if none is reachable, it enables the launchd
service via the external openclaw CLI (no embedded runtime). This gives you
reliable auto-start at login and restart on crashes.
Child-process mode (Gateway spawned directly by the app) is not in use today. If you need tighter coupling to the UI, run the Gateway manually in a terminal.
ai.openclaw.gateway
(or ai.openclaw.<profile> when using --profile/OPENCLAW_PROFILE; legacy com.openclaw.* is supported).Common commands:
launchctl kickstart -k gui/$UID/ai.openclaw.gateway
launchctl bootout gui/$UID/ai.openclaw.gateway
Replace the label with ai.openclaw.<profile> when running a named profile.
scripts/restart-mac.sh --no-sign is for fast local builds when you don't have
signing keys. To prevent launchd from pointing at an unsigned relay binary, it:
~/.openclaw/disable-launchagent.Signed runs of scripts/restart-mac.sh clear this override if the marker is
present. To reset manually:
rm ~/.openclaw/disable-launchagent
To force the macOS app to never install or manage launchd, launch it with
--attach-only (or --no-launchd). This sets ~/.openclaw/disable-launchagent,
so the app only attaches to an already running Gateway. You can toggle the same
behavior in Debug Settings.
Remote mode never starts a local Gateway. The app uses an SSH tunnel to the remote host and connects over that tunnel.
If a true child-process mode is ever needed again, it should be documented as a separate, explicit dev-only mode.