mthds-build

Build new AI method from scratch using the MTHDS standard (.mthds bundle files). Use when user says "create a pipeline", "build a workflow", "new .mthds file", "make a method", "design a pipe", or wants to create any new method from scratch. Guides the user through a 10-phase construction process.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "mthds-build" with this command: npx skills add mthds-ai/skills/mthds-ai-skills-mthds-build

Build AI Method using the MTHDS standard

Create new MTHDS bundles through an adaptive, phase-based approach. This skill guides you through drafting (markdown), structuring (CLI/JSON), and assembling complete .mthds bundles.

Philosophy

  1. Drafting phases: Generate human-readable markdown documents
  2. Structuring phases: Use agent CLI commands for JSON-to-TOML conversion
  3. Visualization: Present ASCII graphs at overview and detail levels
  4. Iterative: Refine at each phase before proceeding

Mode Selection

How mode is determined

  1. Explicit override: If the user states a preference, always honor it:

    • Automatic signals: "just do it", "go ahead", "automatic", "quick", "don't ask"
    • Interactive signals: "walk me through", "help me", "guide me", "step by step", "let me decide"
  2. Skill default: Each skill defines its own default based on the nature of the task.

  3. Request analysis: If no explicit signal and no strong skill default, assess the request:

    • Detailed, specific requirements → automatic
    • Brief, ambiguous, or subjective → interactive

Mode behavior

Automatic mode:

  • State assumptions briefly before proceeding
  • Make reasonable decisions at each step
  • Present the result when done
  • Pause only if a critical ambiguity could lead to wasted work

Interactive mode:

  • Ask clarifying questions at the start
  • Present options at decision points
  • Confirm before proceeding at checkpoints
  • Allow the user to steer direction

Mode switching

  • If in automatic mode and the user asks a question or gives feedback → switch to interactive for the current phase
  • If in interactive mode and the user says "looks good, go ahead" or similar → switch to automatic for remaining phases

Default: Automatic for simple-to-moderate methods. Interactive for complex multi-step methods or when the user's request is ambiguous.

Detection heuristics:

  • User provides a clear one-sentence goal → automatic
  • User describes a complex multi-step process → interactive
  • User mentions batching, conditions, or parallel execution → interactive
  • User says "create a pipeline for X" with no elaboration → automatic

Step 0 — CLI Check (mandatory, do this FIRST)

Run mthds-agent --version. The minimum required version is 0.1.2 (declared in this skill's front matter as min_mthds_version).

  • If the command is not found: STOP. Do not proceed. Tell the user:

The mthds-agent CLI is required but not installed. Install it with:

npm install -g mthds

Then re-run this skill.

  • If the version is below 0.1.2: STOP. Do not proceed. Tell the user:

This skill requires mthds-agent version 0.1.2 or higher (found X.Y.Z). Upgrade with:

npm install -g mthds@latest

Then re-run this skill.

  • If the version is 0.1.2 or higher: proceed to the next step.

Do not write .mthds files manually, do not scan for existing methods, do not do any other work. The CLI is required for validation, formatting, and execution — without it the output will be broken.

No backend setup needed: This skill works without configuring inference backends or API keys. You can start building/validating methods right away. Backend configuration is only needed to run methods with live inference — use /pipelex-setup when you're ready.


Existing Method Detection

Goal: Before starting a new build, check whether the project already contains methods that overlap with the user's request.

When to check: Always, before entering automatic or interactive mode — with these exceptions:

  • Skip entirely if the user's request signals intent to create something new. This includes phrases like "new method", "a new method", "brand new", "from scratch", "create a method", or similar.
  • Targeted search if the user references a specific existing method by name or path, search specifically for that method instead of scanning broadly. If the specific method cannot be found, fall back to the general search approach below.

For the general case, scan mthds-wip/ and any other directories containing .mthds files in the project.

How to check:

  1. List all .mthds files in the project (glob for **/*.mthds)
  2. For each file found, read the file header (domain, main pipe code, description) to understand what it does
  3. Compare with the user's current request — look for overlap in topic, domain, or purpose

If no existing methods overlap: Proceed normally with the build.

If one or more existing methods overlap, present the user with three options:

I found an existing method that seems related to what you're asking for:

  • <path/to/bundle.mthds><brief description of what it does>

How would you like to proceed?

  1. Start fresh — Create a wholly new method from scratch (ignoring the existing one)
  2. Use the existing method — It already does what you need; cancel this build
  3. Build upon it — Extend the existing method by adding pipes before or after the current flow

Handling each choice:

  • Start fresh: Proceed with the build as normal (automatic or interactive path below).
  • Use the existing method: End the build. Remind the user they can run it with /mthds-run and point them to its inputs.json if available.
  • Build upon it: Switch to the /mthds-edit skill, framing the task as an extension — ask the user what additional processing they want to add (e.g., a preprocessing step before the main pipe, a postprocessing step after, or additional parallel branches). Pass the existing .mthds file path to the edit workflow.

Phase 1: Understand Requirements

Goal: Gather complete information before planning.

Ask the user:

  • What are the method's inputs? (documents, images, text, structured data)
  • What outputs should it produce?
  • What transformations are needed?
  • Are there conditional branches or parallel operations?
  • Should items be processed in batches?

Output: Requirements summary (keep in context)


Phase 2: Draft the Plan

Goal: Create a pseudo-code narrative of the method.

Draft a plan in markdown that describes:

  • The overall flow from inputs to outputs
  • Each processing step with its purpose
  • Variable names (snake_case) for inputs and outputs of each step
  • Where structured data or lists are involved

Rules:

  • Name variables consistently across steps
  • Use plural names for lists (e.g., documents), singular for items (e.g., document)
  • Don't detail types yet - focus on the flow

Show ASCII Overview — see Manual Build Phases for the diagram template.

Output: Plan draft (markdown)


Phase 3: Draft Concepts

Goal: Identify all data types needed in the method.

From the plan, identify input, intermediate, and output concepts.

For each concept, draft:

  • Name: PascalCase, singular noun (e.g., Invoice not Invoices)
  • Description: What it represents
  • Type: Either refines: NativeConcept OR structure: {...}

Native concepts (built-in, do NOT redefine): Text, Html, Image, Document, Number, Page, TextAndImages, ImgGenPrompt, JSON, SearchResult, Anything, Dynamic. See MTHDS Language Reference — Native Concepts

Note: Document is the native concept for any document (PDF, Word, etc.). Image is for any image format (JPEG, PNG, etc.). File formats like "PDF" or "JPEG" are not concepts.

Each native concept has accessible attributes (e.g., Image has url, public_url, filename, caption...; Document has url, public_url, filename...; Page has text_and_images and page_view). See Native Content Types for the full attribute reference — essential for $var.field prompts and construct blocks.

Concept naming rules:

  • No adjectives: Article not LongArticle
  • No circumstances: Argument not CounterArgument
  • Always singular: Employee not Employees

Output: Concepts draft (markdown)


Phase 4: Structure Concepts

Goal: Convert concept drafts to validated TOML using the CLI.

Prepare JSON specs for all concepts, then convert them in parallel by making multiple concurrent tool calls.

Example (3 concepts converted in parallel):

# Call all three in parallel (single response, multiple tool calls):
mthds-agent pipelex concept --spec '{"the_concept_code": "Invoice", "description": "A commercial invoice document", "structure": {"invoice_number": "The unique identifier", "vendor_name": {"type": "text", "description": "Vendor name", "required": true}, "total_amount": {"type": "number", "description": "Total amount", "required": true}}}'
mthds-agent pipelex concept --spec '{"the_concept_code": "LineItem", "description": "A single line item on an invoice", "structure": {"description": "Item description", "quantity": {"type": "integer", "required": true}, "unit_price": {"type": "number", "required": true}}}'
mthds-agent pipelex concept --spec '{"the_concept_code": "Summary", "description": "A text summary of content", "refines": "Text"}'

Field types: text, integer, boolean, number, date, concept, list

Choices (enum-like constrained values):

status = {choices = ["pending", "processing", "completed"], description = "Order status", required = true}
score = {type = "number", choices = ["0", "0.5", "1", "1.5", "2"], description = "Score on a half-point scale"}

When choices is present, type defaults to text if omitted. You can also pair choices with integer or number types explicitly.

Nested concept references in structures:

field = {type = "concept", concept_ref = "my_domain.OtherConcept", description = "...", required = true}
items = {type = "list", item_type = "concept", item_concept_ref = "my_domain.OtherConcept", description = "..."}

Output: Validated concept TOML fragments

Partial failures: If some commands fail, fix the failing specs using the error JSON (error_domain: "input" means the spec is wrong). Re-run only the failed commands.


Phase 5: Draft the Flow

Goal: Design the complete pipeline structure with controller selection.

Controller Selection Guide

ControllerUse WhenKey Pattern
PipeSequenceSteps must execute in orderstep1 → step2 → step3
PipeBatchSame operation on each list itemmap(items, transform)
PipeParallelIndependent operations run togetherfork → join
PipeConditionRoute based on data valuesif-then-else

Operator Selection Guide

OperatorUse When
PipeLLMGenerate text or structured objects with AI
PipeExtractExtract content from PDF/Image → Page[]
PipeComposeTemplate text or construct objects
PipeImgGenGenerate images from text prompts
PipeSearchSearch the web for information → SearchResult
PipeFuncCustom Python logic

Critical — PipeImgGen requires a prompt field: The prompt field is required for PipeImgGen. It is a template that defines the text sent to the image generation model — use $variable syntax to insert inputs. Examples:

  • Direct passthrough: prompt = "$img_prompt" — uses the input as-is
  • Template with context: prompt = "A black and white sketch of $description" — wraps the input in a richer prompt

Even if the input already contains the full prompt text, you must still declare the prompt field. Without it, validation fails with missing required fields: 'prompt'.

Note: Page[] outputs from PipeExtract automatically convert to text when inserted into prompts using @variable.

Show detailed ASCII flow — see Manual Build Phases for all controller flow diagrams.

Output: Flow draft with pipe contracts (markdown)


Phase 6: Review & Refine

Goal: Validate consistency before structuring.

Check:

  • Main pipe is clearly identified and handles method inputs
  • Variable names are consistent across all pipes
  • Input/output types match between connected pipes
  • PipeBatch branches receive singular items, not lists
  • PipeBatch: input_item_name (singular) differs from input_list_name (plural) and all inputs keys
  • PipeSequence batch steps: batch_as (singular) differs from batch_over (plural)
  • PipeImgGen has a prompt field (template that references inputs, e.g., prompt = "$description" or prompt = "A watercolor painting of $subject") — required even when the input IS the prompt
  • PipeImgGen inputs are text-compatible (add PipeLLM if needed to craft the prompt first)
  • No circular dependencies

Confirm with user before proceeding to structuring.


Phase 7: Structure Pipes

Goal: Convert pipe drafts to validated TOML using the CLI.

Use talent names (left column) from Talents and Presets. Do NOT use model preset names (right column, prefixed with $ or @) — those are internal identifiers. For example, use creative-writer, not writing-creative or $writing-creative. Only look up specific model presets when the user has explicit instructions about model choice. In all cases, verify that referenced presets exist:

mthds-agent pipelex models --type llm          # when structuring PipeLLM pipes
mthds-agent pipelex models --type extract      # when structuring PipeExtract pipes
mthds-agent pipelex models --type img_gen      # when structuring PipeImgGen pipes
mthds-agent pipelex models --type search       # when structuring PipeSearch pipes

Prepare JSON specs for all pipes, then convert them in parallel by making multiple concurrent tool calls.

Exact field names for --spec JSON: type (not pipe_type), pipe_code (not the_pipe_code), and the talent field matching the pipe type: llm_talent for PipeLLM, extract_talent for PipeExtract, img_gen_talent for PipeImgGen, search_talent for PipeSearch. Do NOT use generic names like talent_name.

PipeImgGen prompt is required: The prompt field must be included in the --spec JSON. It is a template — use $variable to insert inputs. Examples: "prompt": "$img_prompt" (passthrough) or "prompt": "A black and white sketch of $description" (template with context). Omitting prompt causes a validation error.

For detailed CLI examples for each pipe type (PipeLLM, PipeSequence, PipeBatch, PipeCondition, PipeCompose, PipeParallel, PipeExtract, PipeImgGen, PipeSearch), see Manual Build Phases.

Output: Validated pipe TOML fragments

Partial failures: Fix failing specs using the error JSON. Re-run only the failed commands.


Phase 8: Assemble Bundle

Goal: Combine all parts into a complete .mthds file.

Save location: Always save method bundles to mthds-wip/. Do not ask the user for the save location.

Procedure:

  1. Create the output directory: mkdir -p mthds-wip/<bundle_dir>/
  2. Save concept TOML from Phase 4 to mthds-wip/<bundle_dir>/concepts.toml using the Write tool
  3. Save pipe TOML from Phase 7 to mthds-wip/<bundle_dir>/pipes.toml using the Write tool
  4. Run assemble with file paths (not inline content):
    mthds-agent pipelex assemble \
      --domain <domain> \
      --main-pipe <main_pipe_code> \
      --description "<description>" \
      --concepts mthds-wip/<bundle_dir>/concepts.toml \
      --pipes mthds-wip/<bundle_dir>/pipes.toml
    
  5. Parse the toml field from the JSON response and save it using the Write tool to mthds-wip/<bundle_dir>/bundle.mthds — this triggers the PostToolUse hook for automatic lint/format/validate.
  6. Clean up the intermediate files (concepts.toml, pipes.toml) — they are no longer needed.

IMPORTANT: Never pass TOML content inline via process substitution or heredocs. Always write to files first, then pass file paths to the CLI.

For additional examples, see Manual Build Phases.


Phase 9: Validate & Test

Goal: Ensure the bundle is valid and works correctly.

Always use -L pointing to the bundle's own directory to avoid namespace collisions with other bundles in the project.

# Validate and generate flowchart (isolated from other bundles)
mthds-agent pipelex validate bundle mthds-wip/pipeline_01/bundle.mthds -L mthds-wip/pipeline_01/ --graph

# Generate example inputs
mthds-agent pipelex inputs bundle mthds-wip/pipeline_01/bundle.mthds -L mthds-wip/pipeline_01/

On success, dry_run.html is saved next to the bundle. The JSON output includes the path in graph_files.

Fix any validation errors and re-validate. If validation fails unexpectedly or errors are unclear, re-run with --log-level debug for additional context:

mthds-agent --log-level debug pipelex validate bundle mthds-wip/pipeline_01/bundle.mthds -L mthds-wip/pipeline_01/

Phase 10: Deliver

Goal: Generate input template after a successful build.

After validation passes (Phase 9), generate the input template:

# Input template (extracts the input schema as JSON)
mthds-agent pipelex inputs bundle <mthds_file> -L <output_dir>/

Replace <mthds_file> and <output_dir> with actual paths from the build output.

Present Results

After the command succeeds:

  1. Input template: Show the inputs JSON from the inputs command output. Save it to <output_dir>/inputs.json for the user to fill in.

  2. Flowchart: Tell the user that an interactive flowchart (dry_run.html) was generated during validation next to the bundle.

  3. Next steps — test with mock inference: If the method requires inputs, the saved inputs.json still contains placeholder values, so suggest a dry run to test with mock inference:

    To test this method with mock inference, use /mthds-run or from the terminal:

    mthds run bundle <output_dir>/ --dry-run --mock-inputs
    
  4. Next steps — run with real data: Explain how to prepare real inputs, then run for real:

    To run with real data, use /mthds-inputs to prepare your inputs (provide your own files, or generate synthetic test data), then:

    mthds run bundle <output_dir>/
    

    Replace <output_dir> with the actual output directory path used throughout the build.


Quick Reference

Multiplicity Notation

  • Text - single item
  • Text[] - variable-length list
  • Text[3] - exactly 3 items

Prompt Variables

  • @variable - Block insertion (multi-line, with delimiters)
  • $variable - Inline insertion (short text)
  • @?variable - Conditional block insertion (only renders if variable is truthy)
  • $var.field - Access nested field (dotted paths work with all three patterns)
  • Raw Jinja2 {{ }} / {% %} also supported
  • These work in PipeLLM, PipeImgGen, PipeSearch, and PipeCompose templates

Naming Conventions

  • Domain: snake_case
  • Concepts: PascalCase, singular
  • Pipes: snake_case
  • Variables: snake_case

Reference

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

mthds-explain

No summary provided by upstream source.

Repository SourceNeeds Review
General

mthds-edit

No summary provided by upstream source.

Repository SourceNeeds Review
General

mthds-check

No summary provided by upstream source.

Repository SourceNeeds Review
General

mthds-inputs

No summary provided by upstream source.

Repository SourceNeeds Review
mthds-build | V50.AI