Système de formulaires de documentation typés

VérifiéSûr

Guide de référence pour les annotations searchables et les formulaires doc du système The Fold en Scheme. Couvre la syntaxe (doc ...), les tags standards, les commandes de recherche et l'intégration du vérificateur de types.

Spar Skills Guide Bot
DocumentationIntermédiaire
2002/06/2026
Claude Code
#doc-forms#typed-comments#scheme-annotations#code-metadata

Recommandé pour

Notre avis

Ce skill fournit une référence pour les formulaires de documentation typés (doc ...) utilisés dans le système The Fold, permettant d'ajouter des annotations, des types, des métadonnées et des commentaires structurés au code Scheme.

Points forts

  • Les annotations sont introspectables et survivent dans le code source.
  • Intégration avec le vérificateur de types et le LSP pour une priorité élevée des types déclarés.
  • Balises standardisées pour les descriptions, todo, dépréciations, etc.
  • Commandes de recherche pour extraire les annotations (lf-todo, lf-types).

Limites

  • Limité au dialecte Scheme de The Fold.
  • Syntaxe non standard qui peut dérouter les nouveaux venus.
  • Ne génère pas de documentation externe automatiquement.
Quand l'utiliser

Utilisez ce skill pour ajouter des annotations structurées, des types et des métadonnées directement dans le code Scheme de The Fold, en particulier pour les déclarations de types et le suivi des tâches locales.

Quand l'éviter

Ne l'utilisez pas pour documenter du code en dehors de l'écosystème The Fold, ou lorsque vous préférez un système de documentation séparé (ex. Doxygen).

Analyse de sécurité

Sûr
Score qualité95/100

The skill is documentation about a Scheme documentation system and does not instruct any code execution or dangerous operations.

Aucun point d'attention détecté

Exemples

Add type and description to a function
Add a type annotation and description to the 'binary-search' function using doc forms. The function takes a sorted vector of integers and a target integer, and returns an optional index.
Find all todos and type annotations
Search for all todo annotations and type declarations in the current file using lf-todo and lf-types.

name: doc-forms description: Reference for The Fold's typed comments and doc forms system. Use when adding type annotations, documentation, todos, or other metadata to Scheme code. Covers (doc ...) syntax, standard tags, search commands, and type checker integration. allowed-tools: Bash(./fold:*), Read, Edit, Grep, Glob

Doc Forms (Typed Comments)

The Fold uses (doc ...) forms for searchable, introspectable annotations that survive in source code.

Basic Syntax

Contextual (belongs to enclosing definition)

(define (add x y)
  (doc 'type (-> Int Int Int))
  (doc 'description "Adds two numbers")
  (+ x y))

Targeted (names what it documents)

(doc factorial 'type (-> Int Int))
(define (factorial n)
  (if (= n 0) 1 (* n (factorial (- n 1)))))

Semantics

| Property | Behavior | |----------|----------| | Arguments | NOT evaluated (pure metadata) | | Return value | void — use in sequences, not value positions | | Normalization | Stripped — code with/without docs hashes identically | | Extraction | Tooling reads from source (lf-todo, lf-types) | | Type authority | Authoritative(doc f 'type ...) takes precedence over inference |

Standard Tags

| Tag | Purpose | Example | |-----|---------|---------| | 'type | Type signature | (doc 'type (-> Int Int)) | | 'description | Human-readable description | (doc 'description "Adds two numbers") | | 'param | Parameter documentation | (doc 'param 'x "The first operand") | | 'returns | Return value description | (doc 'returns "The sum") | | 'todo | Work to be done | (doc 'todo "Optimize for large inputs") | | 'fixme | Known issue | (doc 'fixme "Edge case with negative numbers") | | 'deprecated | Deprecation notice | (doc 'deprecated "Use add-safe instead") | | 'since | Version introduced | (doc 'since "1.2.0") | | 'see | Related items | (doc 'see 'subtract) | | 'note | Implementation note | (doc 'note "Uses memoization internally") |

Search Commands

After loading lattice/meta/docs.ss:

(lf-todo)           ; Find all todos in codebase
(lf-types)          ; Find all type annotations
(docs-for 'symbol)  ; Find docs for specific target
(doc-stats)         ; Count docs by tag

Type Checker Integration

Doc type annotations integrate with both the LSP and type inference:

| Component | Behavior | |-----------|----------| | LSP hover | Shows doc-declared types with highest priority | | Type inference | Uses declared types via lookup-declared-type in core/types/infer.ss | | Bridge | load-doc-types-into-checker! populates type checker from doc index |

Example: Declaring Types for Inference

;; The type checker will trust this annotation
(doc my-complex-fn 'type (-> (List Int) (Maybe Int)))
(define (my-complex-fn lst)
  ;; Complex implementation...
  )

Todos vs BBS Issues

| Use Case | When to Use | |----------|-------------| | (doc 'todo ...) | Colocated with code, for localized improvements (performance, refactoring, cleanup) | | BBS issue | Tracked work items, features, bugs, cross-cutting concerns, things needing scheduling |

Rule of thumb: If it needs to be scheduled or tracked across sessions, use BBS. If it's a note-to-self next to the code, use (doc 'todo ...).

Examples

Full Function Documentation

(define (binary-search vec target)
  (doc 'type (-> (Vector Int) Int (Maybe Int)))
  (doc 'description "Binary search for target in sorted vector")
  (doc 'param 'vec "Sorted vector of integers")
  (doc 'param 'target "Value to find")
  (doc 'returns "Index wrapped in Just, or Nothing if not found")
  (doc 'todo "Add bounds checking")
  ;; implementation...
  )

Deprecation

(doc old-api 'deprecated "Use new-api instead. Will be removed in 2.0")
(define (old-api x) (new-api x))

Module-Level Documentation

;; At top of file
(doc 'description "Matrix operations for linear algebra")
(doc 'since "1.0.0")
(doc 'see 'linalg/vec)
Skills similaires