Fundamentals
시스템 프롬프트
OpenClaw는 모든 에이전트 실행마다 사용자 지정 시스템 프롬프트를 빌드합니다. 프롬프트는 OpenClaw 소유이며 pi-coding-agent 기본 프롬프트를 사용하지 않습니다.
프롬프트는 OpenClaw가 조합하고 각 에이전트 실행에 주입합니다.
공급자 Plugin은 전체 OpenClaw 소유 프롬프트를 대체하지 않고도 캐시 인식 프롬프트 지침을 제공할 수 있습니다. 공급자 런타임은 다음을 수행할 수 있습니다.
- 명명된 소수의 핵심 섹션(
interaction_style,tool_call_style,execution_bias)을 대체 - 프롬프트 캐시 경계 위에 안정적인 접두사 주입
- 프롬프트 캐시 경계 아래에 동적 접미사 주입
모델 패밀리별 튜닝에는 공급자 소유 기여를 사용하세요. 기존 before_prompt_build 프롬프트 변이는 호환성이나 진정한 전역 프롬프트 변경을 위해 유지하고, 일반적인 공급자 동작에는 사용하지 마세요.
OpenAI GPT-5 패밀리 오버레이는 핵심 실행 규칙을 작게 유지하고 페르소나 고정, 간결한 출력, 도구 규율, 병렬 조회, 산출물 범위, 검증, 누락된 컨텍스트, 터미널 도구 위생에 대한 모델별 지침을 추가합니다.
구조
프롬프트는 의도적으로 간결하며 고정 섹션을 사용합니다.
- 도구: 구조화된 도구의 단일 출처 알림과 런타임 도구 사용 지침.
- 실행 성향: 간결한 후속 실행 지침: 실행 가능한 요청은 턴 안에서 처리하고, 완료되거나 차단될 때까지 계속하며, 약한 도구 결과에서 복구하고, 가변 상태를 실시간으로 확인하며, 최종화 전에 검증합니다.
- 안전: 권력 추구 행동이나 감독 우회를 피하라는 짧은 가드레일 알림.
- Skills(사용 가능한 경우): 모델에 필요 시 skill 지침을 로드하는 방법을 알려줍니다.
- OpenClaw 자체 업데이트:
config.schema.lookup으로 구성을 안전하게 검사하고,config.patch로 구성을 패치하며,config.apply로 전체 구성을 대체하고, 명시적인 사용자 요청이 있을 때만update.run을 실행하는 방법. 소유자 전용gateway도구도 보호된 exec 경로로 정규화되는 기존tools.bash.*별칭을 포함하여tools.exec.ask/tools.exec.security재작성을 거부합니다. - 작업공간: 작업 디렉터리(
agents.defaults.workspace). - 문서: OpenClaw 문서의 로컬 경로(저장소 또는 npm 패키지)와 읽어야 하는 시점.
- 작업공간 파일(주입됨): 부트스트랩 파일이 아래에 포함됨을 나타냅니다.
- 샌드박스(활성화된 경우): 샌드박스 런타임, 샌드박스 경로, elevated exec 사용 가능 여부를 나타냅니다.
- 현재 날짜 및 시간: 시간대만 포함합니다(캐시 안정적이며, 실시간 시계는
session_status에서 제공됨). - 답장 태그: 지원되는 공급자를 위한 선택적 답장 태그 구문.
- Heartbeat: 기본 에이전트에 Heartbeat가 활성화된 경우 Heartbeat 프롬프트와 확인 동작.
- 런타임: 호스트, OS, Node, 모델, 저장소 루트(감지된 경우), 사고 수준(한 줄).
- 추론: 현재 가시성 수준 + /reasoning 토글 힌트.
OpenClaw는 프로젝트 컨텍스트를 포함한 큰 안정적 콘텐츠를 내부 프롬프트 캐시 경계 위에 유지합니다. Control UI 임베드 지침, 메시징, 음성, 그룹 채팅 컨텍스트, 반응, Heartbeat, 런타임처럼 변동성이 큰 채널/세션 섹션은 해당 경계 아래에 추가되어, 접두사 캐시가 있는 로컬 백엔드가 채널 턴 사이에서 안정적인 작업공간 접두사를 재사용할 수 있게 합니다. 도구 설명도 허용된 스키마가 이미 해당 런타임 세부 정보를 담고 있다면 현재 채널 이름을 포함하지 않아야 합니다.
도구 섹션에는 장시간 실행 작업을 위한 런타임 지침도 포함됩니다.
- 향후 후속 작업(
check back later, 알림, 반복 작업)에는execsleep 루프,yieldMs지연 기법, 반복적인process폴링 대신 Cron 사용 - 지금 시작되어 백그라운드에서 계속 실행되는 명령에만
exec/process사용 - 자동 완료 깨우기가 활성화된 경우 명령을 한 번 시작하고, 출력이 발생하거나 실패할 때 push 기반 깨우기 경로에 의존
- 실행 중인 명령을 검사해야 할 때 로그, 상태, 입력, 개입에는
process사용 - 작업이 더 크면
sessions_spawn선호; 하위 에이전트 완료는 push 기반이며 요청자에게 자동으로 다시 알림 - 완료를 기다리기 위해
subagents list/sessions_list를 루프로 폴링하지 않음
실험적 update_plan 도구가 활성화된 경우, 도구 섹션은 모델에 이를 사소하지 않은 다단계 작업에만 사용하고, 정확히 하나의 in_progress 단계만 유지하며, 각 업데이트 후 전체 계획을 반복하지 말라고도 알려줍니다.
시스템 프롬프트의 안전 가드레일은 권고 사항입니다. 모델 동작을 안내하지만 정책을 강제하지는 않습니다. 강제 적용에는 도구 정책, exec 승인, 샌드박싱, 채널 허용 목록을 사용하세요. 운영자는 설계상 이를 비활성화할 수 있습니다.
기본 승인 카드/버튼이 있는 채널에서는 런타임 프롬프트가 이제 에이전트에게 해당 기본 승인 UI를 먼저 사용하라고 알려줍니다. 도구 결과가 채팅 승인을 사용할 수 없다고 하거나 수동 승인이 유일한 경로라고 할 때만 수동 /approve 명령을 포함해야 합니다.
프롬프트 모드
OpenClaw는 하위 에이전트를 위해 더 작은 시스템 프롬프트를 렌더링할 수 있습니다. 런타임은 각 실행마다 promptMode를 설정합니다(사용자에게 노출되는 구성은 아님).
full(기본값): 위의 모든 섹션을 포함합니다.minimal: 하위 에이전트에 사용됩니다. Skills, 메모리 회상, OpenClaw 자체 업데이트, 모델 별칭, 사용자 ID, 답장 태그, 메시징, 무음 답장, Heartbeat를 생략합니다. 도구, 안전, 작업공간, 샌드박스, 현재 날짜 및 시간(알려진 경우), 런타임, 주입된 컨텍스트는 계속 사용할 수 있습니다.none: 기본 ID 줄만 반환합니다.
promptMode=minimal일 때 추가로 주입된 프롬프트는 그룹 채팅 컨텍스트 대신 하위 에이전트 컨텍스트로 표시됩니다.
채널 자동 답장 실행의 경우, 직접/그룹 채팅 컨텍스트에 이미 해석된 대화별 NO_REPLY 동작이 포함되어 있으면 OpenClaw는 일반 무음 답장 섹션을 생략할 수 있습니다. 이렇게 하면 전역 시스템 프롬프트와 채널 컨텍스트 양쪽에서 토큰 메커니즘이 반복되는 것을 피할 수 있습니다.
프롬프트 스냅샷
OpenClaw는 Codex 런타임 정상 경로를 위한 커밋된 프롬프트 스냅샷을 test/fixtures/agents/prompt-snapshots/codex-runtime-happy-path/ 아래에 보관합니다. 이 스냅샷은 선택된 앱 서버 스레드/턴 매개변수와 Telegram 직접, Discord 그룹, Heartbeat 턴을 위한 재구성된 모델 바인딩 프롬프트 레이어 스택을 렌더링합니다. 해당 스택에는 Codex 모델 카탈로그/캐시 형태에서 생성된 고정 Codex gpt-5.5 모델 프롬프트 fixture, Codex 정상 경로 권한 개발자 텍스트, OpenClaw 개발자 지침, OpenClaw가 제공하는 경우 턴 범위 협업 모드 지침, 사용자 턴 입력, 동적 도구 사양에 대한 참조가 포함됩니다.
고정 Codex 모델 프롬프트 fixture는 pnpm prompt:snapshots:sync-codex-model로 새로 고치세요. 기본적으로 스크립트는 Codex의 런타임 캐시를 $CODEX_HOME/models_cache.json, 그다음 ~/.codex/models_cache.json에서 찾고, 그다음에야 유지관리자 Codex 체크아웃 관례인 ~/code/codex/codex-rs/models-manager/models.json으로 폴백합니다. 이 소스가 하나도 없으면 명령은 커밋된 fixture를 변경하지 않고 종료됩니다. 특정 models_cache.json 또는 models.json 파일에서 새로 고치려면 --catalog <path>를 전달하세요.
이 스냅샷은 여전히 바이트 단위로 동일한 원시 OpenAI 요청 캡처가 아닙니다. Codex는 OpenClaw가 스레드와 턴 매개변수를 보낸 후 Codex 런타임 내부에서 AGENTS.md, 환경 컨텍스트, 메모리, 앱/Plugin 지침, 내장 기본 협업 모드 지침 같은 런타임 소유 작업공간 컨텍스트를 추가할 수 있습니다.
pnpm prompt:snapshots:gen으로 다시 생성하고 pnpm prompt:snapshots:check로 드리프트를 검증하세요. CI는 추가 경계 샤드에서 드리프트 검사를 실행하여 프롬프트 변경과 스냅샷 업데이트가 같은 PR에 연결되도록 합니다.
작업공간 부트스트랩 주입
부트스트랩 파일은 모델이 명시적으로 읽지 않아도 ID와 프로필 컨텍스트를 볼 수 있도록 잘려서 프로젝트 컨텍스트 아래에 추가됩니다.
AGENTS.mdSOUL.mdTOOLS.mdIDENTITY.mdUSER.mdHEARTBEAT.mdBOOTSTRAP.md(완전히 새로운 작업공간에서만)- 존재하는 경우
MEMORY.md
파일별 게이트가 적용되지 않는 한 이 모든 파일은 매 턴마다 컨텍스트 창에 주입됩니다. 기본 에이전트에 Heartbeat가 비활성화되어 있거나 agents.defaults.heartbeat.includeSystemPromptSection이 false이면 일반 실행에서 HEARTBEAT.md는 생략됩니다. 주입되는 파일은 간결하게 유지하세요. 특히 MEMORY.md는 시간이 지나며 커질 수 있고 예상보다 높은 컨텍스트 사용량과 더 잦은 Compaction으로 이어질 수 있습니다.
세션이 네이티브 Codex 하네스에서 실행될 때 Codex는 자체 프로젝트 문서 발견을 통해 AGENTS.md를 로드합니다. OpenClaw는 여전히 나머지 부트스트랩 파일을 해석하고 Codex 구성 지침으로 전달하므로, SOUL.md, TOOLS.md, IDENTITY.md, USER.md, HEARTBEAT.md, BOOTSTRAP.md, MEMORY.md는 AGENTS.md를 중복하지 않으면서 동일한 작업공간 컨텍스트 역할을 유지합니다.
큰 파일은 마커와 함께 잘립니다. 파일당 최대 크기는 agents.defaults.bootstrapMaxChars(기본값: 12000)로 제어됩니다. 파일 전체에 걸쳐 주입되는 부트스트랩 콘텐츠 총량은 agents.defaults.bootstrapTotalMaxChars(기본값: 60000)로 제한됩니다. 누락된 파일은 짧은 누락 파일 마커를 주입합니다. 잘림이 발생하면 OpenClaw는 간결한 시스템 프롬프트 경고 알림을 주입할 수 있습니다. 이는 agents.defaults.bootstrapPromptTruncationWarning(off, once, always; 기본값: once)으로 제어하세요. 상세한 원본/주입 카운트는 /context, /status, doctor, 로그 같은 진단에 유지됩니다.
하위 에이전트 세션은 AGENTS.md와 TOOLS.md만 주입합니다(다른 부트스트랩 파일은 하위 에이전트 컨텍스트를 작게 유지하기 위해 필터링됩니다).
내부 훅은 agent:bootstrap을 통해 이 단계를 가로채 주입된 부트스트랩 파일을 변이하거나 대체할 수 있습니다(예: SOUL.md를 대체 페르소나로 교체).
에이전트가 덜 일반적으로 들리게 만들고 싶다면 SOUL.md 성격 가이드부터 시작하세요.
각 주입 파일이 얼마나 기여하는지(원본 대비 주입, 잘림, 도구 스키마 오버헤드 포함)를 검사하려면 /context list 또는 /context detail을 사용하세요. 컨텍스트를 참고하세요.
시간 처리
사용자 시간대를 알고 있으면 시스템 프롬프트에 전용 현재 날짜 및 시간 섹션이 포함됩니다. 프롬프트 캐시를 안정적으로 유지하기 위해 이제 시간대만 포함합니다(동적 시계나 시간 형식 없음).
에이전트에 현재 시간이 필요하면 session_status를 사용하세요. 상태 카드에는 타임스탬프 줄이 포함됩니다. 같은 도구는 선택적으로 세션별 모델 재정의도 설정할 수 있습니다(model=default는 이를 지웁니다).
다음으로 구성하세요.
agents.defaults.userTimezoneagents.defaults.timeFormat(auto|12|24)
전체 동작 세부 정보는 날짜 및 시간을 참고하세요.
Skills
대상 Skills가 있으면 OpenClaw는 각 skill의 파일 경로를 포함하는 간결한 사용 가능한 Skills 목록(formatSkillsForPrompt)을 주입합니다. 프롬프트는 나열된 위치(작업공간, 관리형 또는 번들)에서 SKILL.md를 로드하기 위해 read를 사용하라고 모델에 지시합니다. 대상 Skills가 없으면 Skills 섹션은 생략됩니다.
대상 여부에는 skill 메타데이터 게이트, 런타임 환경/구성 검사, 그리고 agents.defaults.skills 또는 agents.list[].skills가 구성된 경우 유효 에이전트 skill 허용 목록이 포함됩니다.
Plugin 번들 Skills는 소유 Plugin이 활성화된 경우에만 대상이 됩니다. 이를 통해 도구 Plugin은 모든 도구 설명에 해당 지침을 직접 포함하지 않고도 더 깊은 운영 가이드를 노출할 수 있습니다.
<available_skills>
<skill>
<name>...</name>
<description>...</description>
<location>...</location>
</skill>
</available_skills>
이렇게 하면 기본 프롬프트를 작게 유지하면서도 대상 지정된 skill 사용을 가능하게 할 수 있습니다.
Skills 목록 예산은 Skills 서브시스템이 소유합니다:
- 전역 기본값:
skills.limits.maxSkillsPromptChars - 에이전트별 재정의:
agents.list[].skillsLimits.maxSkillsPromptChars
일반적인 제한된 런타임 발췌는 다른 표면을 사용합니다:
agents.defaults.contextLimits.*agents.list[].contextLimits.*
이 분리는 memory_get, 실시간 도구 결과, Compaction 이후 AGENTS.md 새로고침과 같은 런타임 읽기/주입 크기와 Skills 크기 산정을 분리해 둡니다.
문서
시스템 프롬프트에는 문서 섹션이 포함됩니다. 로컬 문서를 사용할 수 있으면 로컬 OpenClaw 문서 디렉터리(Git 체크아웃의 docs/ 또는 번들된 npm 패키지 문서)를 가리킵니다. 로컬 문서를 사용할 수 없으면 https://docs.openclaw.ai로 대체됩니다.
같은 섹션에는 OpenClaw 소스 위치도 포함됩니다. Git 체크아웃은 에이전트가 코드를 직접 검사할 수 있도록 로컬 소스 루트를 노출합니다. 패키지 설치에는 GitHub 소스 URL이 포함되며, 문서가 불완전하거나 오래된 경우 에이전트에게 해당 위치에서 소스를 검토하라고 안내합니다. 또한 프롬프트는 공개 문서 미러, 커뮤니티 Discord, Skills 발견을 위한 ClawHub(https://clawhub.ai)도 언급합니다. 모델에게 OpenClaw 동작, 명령, 구성 또는 아키텍처에 대해서는 먼저 문서를 참조하고, 가능하면 openclaw status를 직접 실행하라고 안내합니다(접근 권한이 없을 때만 사용자에게 요청). 특히 구성의 경우 정확한 필드 수준 문서와 제약 조건을 위해 에이전트에게 gateway 도구 작업 config.schema.lookup을 가리킨 다음, 더 폭넓은 안내를 위해 docs/gateway/configuration.md 및 docs/gateway/configuration-reference.md를 참조하게 합니다.