Notre avis
Référence pour le système de commentaires typés et de formes doc de The Fold, permettant d'ajouter des annotations de type, de la documentation et des métadonnées au code Scheme.
Points forts
- Syntaxe intuitive et contextuelle avec (doc ...) pour annoter les définitions.
- Les annotations sont autoritatives pour le type checker, surpassant l'inférence.
- Recherche intégrée via lf-todo, lf-types et autres commandes.
Limites
- Spécifique à The Fold, non portable à d'autres dialectes Scheme.
- Les annotations ne sont pas évaluées, ce qui limite leur utilisation dans des expressions complexes.
- La documentation doit être maintenue manuellement pour rester synchronisée avec le code.
Utilisez ce système pour documenter et typer explicitement les fonctions dans un projet The Fold, en particulier pour les API publiques ou les algorithmes complexes.
Ne l'utilisez pas pour des scripts rapides ou du code expérimental où la documentation lourde n'est pas nécessaire.
Analyse de sécurité
SûrThe skill provides documentation about a documentation system; no destructive or exfiltrating actions are instructed. Allowed tools are limited to safe file operations within the project scope.
Aucun point d'attention détecté
Exemples
Add a doc form to the function 'add' that specifies its type as (-> Int Int Int) and a description 'Adds two numbers'.Run the lf-todo command to find all todos in the current The Fold project.Mark the function 'old-api' as deprecated with a notice to use 'new-api' instead, and specify it will be removed in version 2.0.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)
Generateur de Documentation API
Documentation
Genere automatiquement de la documentation API OpenAPI/Swagger.
Rédacteur Technique
Documentation
Rédige de la documentation technique claire selon les meilleurs style guides.
Système de formulaires de documentation typés
Documentation
Utilisez la syntaxe `(doc ...)` pour ajouter des annotations typées, des descriptions, des tâches (todo) et d'autres métadonnées directement dans le code Scheme. Les annotations sont extractibles via des commandes comme lf-todo et lf-types, et s'intègrent au vérificateur de types, où les déclarations de type dans les doc prennent le pas sur l'inférence. Idéal pour documenter les fonctions, marquer des déprécations ou lister des améliorations localisées sans recourir à un système externe.