Init Context Reference
Generate project-specific AGENTS.md files with custom context derived from project analysis or user description.
Overview
The init-agents workflow creates tailored AGENTS.md files that provide project-specific instructions for AI agents. It operates in two modes: automatic inference (derives context from project files) or guided mode (uses user description to focus content).
Workflow Steps
1. Check Arguments
Determine operating mode:
- Automatic inference mode: No arguments provided - derive context from project analysis
- Guided mode: Arguments provided - use description to focus content generation
Guided mode examples:
/md-docs:init-agents TypeScript monorepo with strict type safety and functional patterns/md-docs:init-agents Foundry smart contract project with security-first mindset
2. Check Existing AGENTS.md
Check for existing files:
- Run
test -f AGENTS.md && echo "exists" || echo "none"
If existing file found:
- Read the existing file
- Use
AskUserQuestionwith options:- Overwrite: Replace existing file completely
- Merge: Append new context to existing file
- Abort: Cancel operation
- Wait for user response before proceeding
3. Gather Project Context
Read available project files (skip if missing):
package.json- stack, scripts, dependenciesREADME.md- project overview, purposepyproject.toml,Cargo.toml,go.mod- language-specific contextfoundry.toml,hardhat.config.ts- smart contract context.gitignore- exclusion patternsfd -t f -d 2- quick directory layout
Analyze to understand:
- Primary language/framework
- Project type (library, app, contracts, monorepo)
- Build/test tools
- Architecture hints
4. Generate AGENTS.md Content
Writing Style Requirements
- Terse and direct - No fluff, straight to point
- Expert-to-expert - Assume high competency
- Imperative mood - Commands ("Use", "Follow", "Avoid")
- Active voice - "Run tests before committing" not "Tests should be run"
- Minimal markdown:
##for major sections###for subsections- Bullet points for lists
- Inline code for technical terms
- Bold for emphasis
Content Structure
Adapt structure to context - no predefined template. Common patterns (use only if relevant):
- Tech stack - Languages, frameworks, tools
- Architecture - Patterns, conventions, structure
- Commands - Build, test, lint, deploy
- Code style - Naming, formatting, patterns
- Constraints - Security, performance, compliance
- Workflows - Git flow, PR process, testing
Content Patterns Example
## Stack
- TypeScript 5.x with strict mode
- pnpm workspaces
- Vitest for testing
- BiomeJS for linting
## Code Style
- Functional patterns over classes
- Explicit return types on exported functions
- No `any` types - use `unknown` and type guards
- Prefer `const` and immutability
## Commands
- `pnpm test` - Run tests across all packages
- `pnpm build` - Build all packages
- `pnpm lint` - Run BiomeJS
Guided Mode (Arguments Provided)
Analyze arguments for:
- Keywords - "security", "testing", "monorepo", "contracts"
- Constraints - "strict", "functional", "minimal", "fast"
- Tools - "Foundry", "Next.js", "React", "Viem"
- Priorities - What matters most to the user
Generate sections matching intent. Example: "security-first Foundry project" emphasizes:
- Security tools (Slither, tests)
- Audit requirements
- Safe patterns
- Test coverage requirements
Automatic Inference Mode (No Arguments)
Derive context entirely from STEP 3 analysis:
- Primary language/framework → tech stack and code style sections
- Project type → architecture patterns
- Build/test tools detected → commands section
- Detected patterns → code style recommendations
- Dependencies and tooling → workflow suggestions
Infer priorities from project signals:
foundry.tomlor security deps → security focus- Extensive test setup → testing emphasis
- Multiple packages → monorepo patterns
- Strict TypeScript config → type safety focus
5. Write AGENTS.md
Location
./AGENTS.md (root)
Write Operation
Overwrite or no existing file:
- Write complete new AGENTS.md with generated content
Merge mode:
- Read existing content
- Append separator:
\n---\n\n# Auto-generated Context\n\n - Append generated content
- Write combined content
Confirmation
Success:
- Display file path
- Show first 10 lines as preview
- Success message:
✓ Created AGENTS.md at ./AGENTS.md
Failure:
- Check permissions
- Suggest specific fix
- DO NOT retry automatically
Create CLAUDE.md Symlink
After writing AGENTS.md, create a symlink for Claude Code compatibility:
ln -sf AGENTS.md CLAUDE.md
- Creates relative symlink
CLAUDE.md -> AGENTS.md - Use
-fto overwrite existing symlink - Confirm symlink creation:
✓ Created CLAUDE.md symlink
6. Optional Project Import Suggestions
Check for commonly useful files:
- README.md exists → Suggest adding
@README.md - package.json exists → Suggest adding
@package.json
Format suggestion:
💡 Tip: Consider importing project files into AGENTS.md:
@README.md # Project overview
@package.json # Available scripts
Add these lines to AGENTS.md to auto-load context.
Key Principles
- Case-by-case content - No rigid template, adapt to user's description
- Import awareness - AGENTS.md can use
@path/to/filesyntax to import other files - Hierarchy context - Project AGENTS.md supplements (not replaces) user/enterprise AGENTS.md
- Writing style matches user - Analyzed from existing agents/commands/skills