mirror of
https://github.com/catlog22/Claude-Code-Workflow.git
synced 2026-02-05 01:50:27 +08:00
- Implemented unit tests for the Tokenizer class, covering various text inputs, edge cases, and fallback mechanisms. - Created performance benchmarks comparing tiktoken and pure Python implementations for token counting. - Developed extensive tests for TreeSitterSymbolParser across Python, JavaScript, and TypeScript, ensuring accurate symbol extraction and parsing. - Added configuration documentation for MCP integration and custom prompts, enhancing usability and flexibility. - Introduced a refactor script for GraphAnalyzer to streamline future improvements.
3.7 KiB
3.7 KiB
Custom Prompts
Custom prompts turn your repeatable instructions into reusable slash commands, so you can trigger them without retyping or copy/pasting. Each prompt is a Markdown file that Codex expands into the conversation the moment you run it.
Where prompts live
- Location: store prompts in
$CODEX_HOME/prompts/(defaults to~/.codex/prompts/). SetCODEX_HOMEif you want to use a different folder. - File type: Codex only loads
.mdfiles. Non-Markdown files are ignored. Both regular files and symlinks to Markdown files are supported. - Naming: The filename (without
.md) becomes the prompt name. A file calledreview.mdregisters the promptreview. - Refresh: Prompts are loaded when a session starts. Restart Codex (or start a new session) after adding or editing files.
- Conflicts: Files whose names collide with built-in commands (like
init) stay hidden in the slash popup, but you can still invoke them with/prompts:<name>.
File format
-
Body: The file contents are sent verbatim when you run the prompt (after placeholder expansion).
-
Frontmatter (optional): Add YAML-style metadata at the top of the file to improve the slash popup.
--- description: Request a concise git diff review argument-hint: FILE=<path> [FOCUS=<section>] ---descriptionshows under the entry in the popup.argument-hint(orargument_hint) lets you document expected inputs, though the current UI ignores this metadata.
Placeholders and arguments
- Numeric placeholders:
$1–$9insert the first nine positional arguments you type after the command.$ARGUMENTSinserts all positional arguments joined by a single space. Use$$to emit a literal dollar sign (Codex leaves$$untouched). - Named placeholders: Tokens such as
$FILEor$TICKET_IDexpand fromKEY=valuepairs you supply. Keys are case-sensitive—use the same uppercase name in the command (for example,FILE=...). - Quoted arguments: Double-quote any value that contains spaces, e.g.
TICKET_TITLE="Fix logging". - Invocation syntax: Run prompts via
/prompts:<name> .... When the slash popup is open, typing eitherprompts:or the bare prompt name will surface/prompts:<name>suggestions. - Error handling: If a prompt contains named placeholders, Codex requires them all. You will see a validation message if any are missing or malformed.
Running a prompt
- Start a new Codex session (ensures the prompt list is fresh).
- In the composer, type
/to open the slash popup. - Type
prompts:(or start typing the prompt name) and select it with ↑/↓. - Provide any required arguments, press Enter, and Codex sends the expanded content.
Examples
Example 1: Basic named arguments
File: ~/.codex/prompts/ticket.md
---
description: Generate a commit message for a ticket
argument-hint: TICKET_ID=<id> TICKET_TITLE=<title>
---
Please write a concise commit message for ticket $TICKET_ID: $TICKET_TITLE
Usage:
/prompts:ticket TICKET_ID=JIRA-1234 TICKET_TITLE="Fix login bug"
Expanded prompt sent to Codex:
Please write a concise commit message for ticket JIRA-1234: Fix login bug
Note: Both TICKET_ID and TICKET_TITLE are required. If either is missing, Codex will show a validation error. Values with spaces must be double-quoted.
Example 2: Mixed positional and named arguments
File: ~/.codex/prompts/review.md
---
description: Review code in a specific file with focus area
argument-hint: FILE=<path> [FOCUS=<section>]
---
Review the code in $FILE. Pay special attention to $FOCUS.
Usage:
/prompts:review FILE=src/auth.js FOCUS="error handling"
Expanded prompt:
Review the code in src/auth.js. Pay special attention to error handling.