validate-piles-notation
À propos
Cette compétence analyse et valide les chaînes de notation PILES utilisées pour définir les groupes de fusion de pièces dans jigsawR. Elle effectue la validation syntaxique, convertit les chaînes en listes de groupes structurées et peut vérifier l'adjacence par rapport aux résultats du puzzle. Utilisez-la pour valider les entrées utilisateur avant `generate_puzzle()`, déboguer les groupes de fusion ou tester la sérialisation aller-retour.
Installation rapide
Claude Code
Recommandénpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/validate-piles-notationCopiez et collez cette commande dans Claude Code pour installer cette compétence
Documentation
Validate PILES Notation
Parse + validate PILES strings → puzzle piece fusion groups.
Use When
- Validate user PILES → before
generate_puzzle() - Debug fusion issues (wrong pieces merged, unexpected results)
- Explain PILES → user plain language
- Test round-trip: parse → groups → serialize → parse
In
- Required: PILES string (e.g.,
"1-2-3,4-5") - Optional: Puzzle result obj (adjacency valid + keyword resolution)
- Optional: Puzzle type (keyword support
"center","ring1","R1")
Do
Step 1: Syntax Valid
library(jigsawR)
result <- validate_piles_syntax("1-2-3,4-5")
# Returns TRUE if valid, error message if invalid
Common syntax errs:
- Unmatched parens:
"1-2(-3)-4"w/ mismatched() - Invalid chars: only digits,
-,,,:,(,)+ keywords - Empty groups:
"1-2,,3-4"(double comma)
Got: TRUE for valid syntax, descriptive err for invalid.
If err: Print exact PILES string + valid err msg.
Step 2: Parse → Groups
groups <- parse_piles("1-2-3,4-5")
# Returns: list(c(1, 2, 3), c(4, 5))
W/ ranges:
groups <- parse_piles("1:6,7-8")
# Returns: list(c(1, 2, 3, 4, 5, 6), c(7, 8))
Got: List of int vectors, one per fusion group, correct piece IDs + boundaries.
If err: Check syntax valid passed Step 1. Unexpected groups → verify - separates pieces in group, , separates groups, : expands inclusive endpoints.
Step 3: Explain Plain Language
Per group:
"1-2-3,4-5"→ "Group 1: fuse pieces 1, 2, 3. Group 2: fuse 4, 5.""1:6"→ "Group 1: fuse pieces 1 through 6 (6 pieces).""center,ring1"→ "Group 1: center piece. Group 2: all pieces ring 1."
Got: Each group described plain w/ piece counts + IDs → understandable to non-tech.
If err: Keywords can't be explained ("ring1" no clear meaning) → notation needs puzzle result for ctx. Advise user provide puzzle type or numeric IDs.
Step 4: Validate vs Puzzle Result (Optional)
If puzzle result available, verify:
# Generate the puzzle first
puzzle <- generate_puzzle(type = "hexagonal", grid = c(3), size = c(200))
# Parse with puzzle context (resolves keywords)
groups <- parse_fusion("center,ring1", puzzle)
Check:
- All piece IDs exist in puzzle
- Keywords resolve to valid piece sets
- Fused pieces actually adjacent (warn if not)
Got: All piece IDs valid. Adjacent pieces fuse cleanly.
If err: List invalid piece IDs or non-adjacent pairs.
Step 5: Round-Trip
Verify parse/serialize fidelity:
original <- "1-2-3,4-5"
groups <- parse_piles(original)
roundtrip <- to_piles(groups)
# roundtrip should equal original (or canonical equivalent)
groups2 <- parse_piles(roundtrip)
identical(groups, groups2) # Must be TRUE
Got: Round-trip → identical group lists, confirming parse_piles() + to_piles() are inverses.
If err: Round-trip differs → check serializer normalization (sorting IDs, ranges → explicit lists). Canonical diffs OK if identical(groups, groups2) returns TRUE.
PILES Quick Reference
# Basic syntax
"1-2" # Fuse pieces 1 and 2
"1-2-3,4-5" # Two groups: (1,2,3) and (4,5)
"1:6" # Range: pieces 1 through 6
# Keywords (require puzzle_result)
"center" # Center piece (hex/concentric)
"ring1" # All pieces in ring 1
"R1" # Row 1 (rectangular)
"boundary" # All boundary pieces
# Functions
parse_piles("1-2-3,4-5") # Parse PILES string
parse_fusion("1-2-3", puzzle) # Auto-detect format
to_piles(list(c(1,2), c(3,4))) # Convert to PILES
validate_piles_syntax("1-2(-3)-4") # Validate syntax
Check
-
validate_piles_syntax()returns TRUE for valid strings -
parse_piles()returns correct group lists - Round-trip serialization preserves groups
- Keywords resolve correctly w/ puzzle ctx
- Invalid syntax → clear err msgs
Traps
- Keyword w/o puzzle ctx:
"center"requires puzzle result. Pass toparse_fusion(), notparse_piles(). - 1-indexed pieces: Piece IDs start at 1, not 0.
- Adjacent vs non-adjacent fusion: Non-adjacent fusion works but may produce unexpected visuals. Validate adjacency when possible.
- Range notation:
"1:6"includes both endpoints (1, 2, 3, 4, 5, 6).
→
generate-puzzle— generate puzzles w/ fusion groupsadd-puzzle-type— new types need PILES/fusion supportrun-puzzle-tests— test PILES parsing w/ full suite
Dépôt GitHub
Compétences associées
content-collections
MétaCette compétence propose une configuration éprouvée en production pour Content Collections, un outil axé sur TypeScript qui transforme des fichiers Markdown/MDX en collections de données typées de manière sûre avec une validation Zod. Utilisez-la lors de la création de blogs, de sites de documentation ou d'applications Vite + React riches en contenu pour garantir la sécurité de typage et la validation automatique du contenu. Elle couvre tout, de la configuration du plugin Vite et de la compilation MDX à l'optimisation des déploiements et la validation des schémas.
polymarket
MétaCette compétence permet aux développeurs de créer des applications avec la plateforme de marchés prédictifs Polymarket, incluant l'intégration d'API pour le trading et les données de marché. Elle fournit également une diffusion de données en temps réel via WebSocket pour surveiller les transactions en direct et l'activité du marché. Utilisez-la pour mettre en œuvre des stratégies de trading ou pour créer des outils traitant les mises à jour de marché en direct.
creating-opencode-plugins
MétaCette compétence aide les développeurs à créer des plugins OpenCode qui s'interconnectent avec plus de 25 types d'événements tels que les commandes, les fichiers et les opérations LSP. Elle fournit la structure du plugin, les spécifications de l'API événementielle et les modèles d'implémentation pour les modules JavaScript/TypeScript. Utilisez-la lorsque vous avez besoin d'intercepter, de surveiller ou d'étendre le cycle de vie de l'assistant IA OpenCode avec une logique personnalisée pilotée par les événements.
sglang
MétaSGLang est un framework de service LLM haute performance spécialisé dans la génération rapide et structurée pour les workflows JSON, regex et agentiques grâce à son cache de préfixe RadixAttention. Il offre une inférence nettement plus rapide, particulièrement pour les tâches avec des préfixes répétés, ce qui le rend idéal pour les sorties complexes et structurées ainsi que les conversations multi-tours. Choisissez SGLang plutôt que des alternatives comme vLLM lorsque vous avez besoin d'un décodage contraint ou que vous construisez des applications avec un partage étendu de préfixes.
