Awesome-omni-skill create-agents-md

Create or rewrite AGENTS.md files for Open Mercato packages and modules. Use this skill when adding a new package, creating a new module, or when an existing AGENTS.md needs to be created or refactored. Ensures prescriptive tone, MUST rules, checklists, and consistent structure across all agent guidelines.

install
source · Clone the upstream repo
git clone https://github.com/diegosouzapw/awesome-omni-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/create-agents-md" ~/.claude/skills/diegosouzapw-awesome-omni-skill-create-agents-md-60f02d && rm -rf "$T"
manifest: skills/development/create-agents-md/SKILL.md
source content

Create prescriptive, action-oriented AGENTS.md files that tell agents what to DO, what to REUSE, and what rules to FOLLOW. Never write descriptive documentation — write instructions.

Core Philosophy

AGENTS.md files are not documentation. They are instruction sets for coding agents. Every sentence should either:

  • Tell the agent what to do ("Use X when...")
  • Constrain the agent's behavior ("MUST NOT...")
  • Give a step-by-step procedure ("1. Create... 2. Add... 3. Run...")

File Structure Template

Every AGENTS.md follows this structure. Adapt sections based on file size (small: 40-80 lines, medium: 80-150 lines, large: 150+ lines).

# {Name} — Agent Guidelines

{One-line imperative directive: "Use X for Y." or "Use the Z module for A, B, and C."}

## MUST Rules

1. **MUST ...** — {consequence or rationale}
2. **MUST NOT ...** — {what to do instead}
3. **MUST ...** — {consequence or rationale}

## {Primary Task Section — "When You Need X" or "Adding a New Y"}

{Numbered checklist or decision table}

## {Secondary Sections}

{Tables with "When to use" / "When to modify" columns}

## Structure

{Directory tree — keep brief}

## {Cross-References} (if applicable)

- **For X**: `path/to/AGENTS.md` → Section

Prescriptive Tone Rules

NEVER start a section with

  • "The module provides..."
  • "This package is..."
  • "This document describes..."
  • "X is a Y that..."

ALWAYS start sections with

  • Imperative verbs: "Use", "Add", "Create", "Configure", "Declare", "Follow", "Resolve"
  • Conditional directives: "When you need X, do Y"
  • Constraints: "MUST", "MUST NOT"

Transform Patterns

Descriptive (BAD)Prescriptive (GOOD)
"The cache module provides multi-strategy caching""Use
@open-mercato/cache
for all caching needs. MUST NOT use raw Redis directly."
"Products are core entities with media""Products — core entities. MUST have at least a name"
"Events support local and async dispatch""When
QUEUE_STRATEGY=async
, persistent events dispatch through BullMQ"
"The pricing system uses layered overrides""Price layers compose in order: base → channel → customer → promotional"
Description column in tables"When to use" or "When to modify" column

MUST Rules Requirements

File sizeMinimum MUST rules
Small (< 80 lines)3
Medium (80-150 lines)5
Large (150+ lines)8+

Writing Effective MUST Rules

Each MUST rule follows this pattern:

**MUST [verb]** — [rationale or consequence]

Good examples:

  • **MUST resolve via DI** — always use container.resolve('cacheService'), never instantiate directly
  • **MUST NOT reimplement pricing logic** — use selectBestPrice and the resolver pipeline
  • **MUST export metadata** with { queue, id?, concurrency? } from every worker file
  • **MUST follow document flow**: Quote → Order → Invoice — no skipping steps

Bad examples:

  • **MUST** follow best practices
    (too vague)
  • **MUST** be careful with...
    (not actionable)
  • **MUST** use the correct approach
    (says nothing)

Table Column Conventions

NEVER use these column headers

  • "Description"
  • "Purpose" (as standalone — use "Purpose / MUST rules" instead)
  • "Details"

ALWAYS use these column headers

ContextColumn headers to use
Feature/strategy tables"When to use", "Configuration"
Directory listings"When to modify"
Entity/data modelConstraint-framed bullets: "Entity — description. MUST [constraint]"
File reference tables"When you need", "Copy from"
API/endpoint tables"When to use", "MUST rules"
Environment variables"When to configure"
DI tokens / imports"When to use", "Import path"

Checklist Sections

Include numbered checklists for common tasks. Pattern: "Adding a New X" or "Checklist: Do Y"

## Adding a New Worker

1. Create worker file in `src/modules/<module>/workers/<worker-name>.ts`
2. Export `metadata` with `{ queue: '<queue-name>', id: '<worker-id>', concurrency: <n> }`
3. Export default async handler function
4. Ensure handler is idempotent — check state before mutating
5. Run `npm run modules:prepare` to register the worker
6. Test with `QUEUE_STRATEGY=local` in development

Every checklist MUST:

  • Use numbered steps (not bullets)
  • Start each step with an imperative verb
  • Include the
    npm run modules:prepare
    step when adding module files
  • End with a testing/verification step

Data Model Sections

Convert entity lists to constraint-framed bullets:

## Data Model Constraints

- **Products** — core entities with media. MUST have at least a name
- **Categories** — hierarchical. MUST maintain parent-child integrity (no circular references)
- **Variants** — linked via `product_id`. MUST reference valid option schemas
- **Prices** — multi-tier with channel scoping. MUST use `selectBestPrice` for resolution

Pattern:

**Entity** — brief description. MUST [constraint]

Cross-Reference Rules

When two AGENTS.md files cover related topics:

  1. Pick one authoritative source for each topic — never duplicate full content
  2. Use condensed quick-references in the non-authoritative file
  3. Add a Cross-Reference section at the bottom linking to related guides
  4. Keep the Task Router in root AGENTS.md accurate with descriptive task names

Example:

## Cross-Reference

- **Declaring events in a module**: `packages/core/AGENTS.md` → Events
- **Queue worker contract**: `packages/queue/AGENTS.md`

File Size Guidelines

TypeTarget linesExamples
Small package40–80cache, content, queue, events
Medium module60–100catalog, sales, customers, onboarding
Large package80–150shared, create-app, specs
Very large (tone rewrite)Keep original lengthai-assistant (~1100), search (~700)

Sizing Rules

  • Keep small files focused — do not pad with unnecessary sections
  • Large files: keep ALL technical content, only reframe tone
  • Root AGENTS.md: MUST stay under 230 lines

Code Examples in AGENTS.md

  • Include code examples only for contracts (worker metadata, event declaration, subscriber export)
  • Keep examples minimal — 3-5 lines max for inline snippets
  • For full API examples, cross-reference the relevant module or spec
  • MUST NOT include implementation details — only show the interface/pattern

Verification Checklist

After writing an AGENTS.md, verify:

  1. Tone: Every section starts with imperative verb or "When you need..."
  2. MUST audit: File has required number of MUST rules (3+ small, 5+ medium, 8+ large)
  3. No descriptive openers: No section starts with "The module provides..." or similar
  4. Tables: All tables use "When to use" / "When to modify" columns, never "Description"
  5. Checklists: Common tasks have numbered step-by-step procedures
  6. Data models: Entity lists are constraint-framed with MUST rules
  7. Cross-references: No duplicated content between files; clear pointers instead
  8. Structure section: Directory tree is present and brief
  9. Opening line: File starts with one-line imperative directive, not a description

Anti-Patterns

  1. Explaining how things work instead of telling agents what to do
  2. Listing features instead of listing constraints
  3. Duplicating content across multiple AGENTS.md files
  4. Writing paragraphs where a checklist would be clearer
  5. Adding changelog sections to small/medium files (only for large files with complex history)
  6. Over-documenting internals — AGENTS.md guides usage, not implementation
  7. Missing the "when" framing — every table/section should answer "when do I use this?"

Reference Examples

Study these files as reference implementations:

SizeFileWhy it's good
Small
packages/cache/AGENTS.md
Clean structure, 5 MUST rules, decision table, checklist
Small
packages/queue/AGENTS.md
Concurrency guidelines table, idempotency rule, worker contract
Medium
packages/core/src/modules/sales/AGENTS.md
Data model constraints, document flow MUST rules, "MUST NOT modify directly"
Medium
packages/core/src/modules/customers/AGENTS.md
"Copy from here" directive, reference files table, module checklist
Large
packages/search/AGENTS.md
Strategy decision guide, dual checklists, DI token reference
Large
packages/ai-assistant/AGENTS.md
Common tasks up front, auth MUST rules, session debugging steps

When Updating Root AGENTS.md Task Router

After creating a new AGENTS.md, update the Task Router table in root

AGENTS.md
:

  1. Add a row with descriptive task keywords (not just the package name)
  2. Include specific function names, patterns, and task verbs an agent would search for
  3. Keep the root file under 230 lines