i18n/de/skills/validate-piles-notation/SKILL.md
PILES-Notation (Puzzle Input Line Entry System) fuer die Spezifikation von Teilefusionsgruppen in jigsawR parsen und validieren. Umfasst Syntaxvalidierung, Parsen in Gruppenlisten, Klartext-Erklaerung, Adjazenzverifikation gegen Puzzleergebnisse und Round-Trip-Serialisierung. Anwenden beim Validieren benutzerdefinierter PILES-Zeichenketten vor der Uebergabe an generate_puzzle(), beim Debuggen von Fusionsgruppen-Problemen, beim Erklaeren der Notation fuer Benutzer, oder beim Testen der Round-Trip-Parse/Serialize-Treue.
npx skillsauth add pjt222/agent-almanac validate-piles-notationInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
PILES-Notationszeichenketten fuer Puzzle-Teilefusionsgruppen parsen und validieren.
generate_puzzle() validieren"1-2-3,4-5")"center", "ring1", "R1")library(jigsawR)
result <- validate_piles_syntax("1-2-3,4-5")
# Gibt TRUE zurueck wenn gueltig, Fehlermeldung wenn ungueltig
Auf haeufige Syntaxfehler pruefen:
"1-2(-3)-4" mit nicht zusammenpassenden ()-, ,, :, (, ) und Schluesselwoerter erlaubt"1-2,,3-4" (doppeltes Komma)Erwartet: TRUE fuer gueltige Syntax, beschreibender Fehler fuer ungueltige.
Bei Fehler: Die genaue PILES-Zeichenkette und die Validierungsfehlermeldung ausgeben.
groups <- parse_piles("1-2-3,4-5")
# Gibt zurueck: list(c(1, 2, 3), c(4, 5))
Fuer Zeichenketten mit Bereichen:
groups <- parse_piles("1:6,7-8")
# Gibt zurueck: list(c(1, 2, 3, 4, 5, 6), c(7, 8))
Erwartet: Liste von Integer-Vektoren, einer pro Fusionsgruppe, mit korrekten Teil-IDs und Gruppengrenzen.
Bei Fehler: Zuerst pruefen ob die PILES-Zeichenkette die Syntaxvalidierung in Schritt 1 bestanden hat. Wenn das Parsen unerwartete Gruppen zurueckgibt, ueberpruefen ob - Teile innerhalb einer Gruppe trennt und , Gruppen trennt, und dass die Bereichsnotation (:) zu inklusiven Endpunkten expandiert.
Jede Gruppe fuer den Benutzer beschreiben:
"1-2-3,4-5" -> "Gruppe 1: Teile 1, 2 und 3 fusionieren. Gruppe 2: Teile 4 und 5 fusionieren.""1:6" -> "Gruppe 1: Teile 1 bis 6 fusionieren (6 Teile).""center,ring1" -> "Gruppe 1: Mittelteil. Gruppe 2: alle Teile in Ring 1."Erwartet: Jede Fusionsgruppe wird in Klartext beschrieben mit Teilezahlen und Bezeichnern, sodass die Notation fuer nicht-technische Benutzer verstaendlich wird.
Bei Fehler: Wenn Schluesselwoerter nicht erklaert werden koennen (z.B. hat "ring1" keine klare Bedeutung), braucht die Notation moeglicherweise ein Puzzle-Ergebnisobjekt fuer Kontext. Den Benutzer empfehlen den Puzzletyp anzugeben oder stattdessen numerische Teil-IDs zu verwenden.
Wenn ein Puzzle-Ergebnisobjekt verfuegbar ist, verifizieren:
# Zuerst das Puzzle generieren
puzzle <- generate_puzzle(type = "hexagonal", grid = c(3), size = c(200))
# Mit Puzzle-Kontext parsen (loest Schluesselwoerter auf)
groups <- parse_fusion("center,ring1", puzzle)
Pruefen:
Erwartet: Alle Teil-IDs gueltig. Benachbarte Teile fusionieren sauber.
Bei Fehler: Ungueltige Teil-IDs oder nicht benachbarte Paare auflisten.
Parse/Serialize-Treue verifizieren:
original <- "1-2-3,4-5"
groups <- parse_piles(original)
roundtrip <- to_piles(groups)
# roundtrip sollte gleich original sein (oder kanonisch aequivalent)
groups2 <- parse_piles(roundtrip)
identical(groups, groups2) # Muss TRUE sein
Erwartet: Der Round-Trip erzeugt identische Gruppenlisten, was bestaetigt dass parse_piles() und to_piles() zueinander invers sind.
Bei Fehler: Wenn der Round-Trip abweicht, pruefen ob der Serialisierer die Notation normalisiert (z.B. Teil-IDs sortiert oder Bereiche in explizite Listen konvertiert). Kanonische Unterschiede sind akzeptabel solange identical(groups, groups2) TRUE zurueckgibt.
# Grundsyntax
"1-2" # Teile 1 und 2 fusionieren
"1-2-3,4-5" # Zwei Gruppen: (1,2,3) und (4,5)
"1:6" # Bereich: Teile 1 bis 6
# Schluesselwoerter (benoetigen puzzle_result)
"center" # Mittelteil (hex/concentric)
"ring1" # Alle Teile in Ring 1
"R1" # Reihe 1 (rectangular)
"boundary" # Alle Randteile
# Funktionen
parse_piles("1-2-3,4-5") # PILES-Zeichenkette parsen
parse_fusion("1-2-3", puzzle) # Format automatisch erkennen
to_piles(list(c(1,2), c(3,4))) # In PILES konvertieren
validate_piles_syntax("1-2(-3)-4") # Syntax validieren
validate_piles_syntax() gibt TRUE fuer gueltige Zeichenketten zurueckparse_piles() gibt korrekte Gruppenlisten zurueck"center" benoetigen ein Puzzle-Ergebnisobjekt. Es an parse_fusion() uebergeben, nicht an parse_piles()."1:6" schliesst beide Endpunkte ein (1, 2, 3, 4, 5, 6).generate-puzzle — Puzzles mit Fusionsgruppen generierenadd-puzzle-type — neue Typen brauchen PILES/Fusions-Unterstuetzungrun-puzzle-tests — PILES-Parsing mit der vollstaendigen Suite testentesting
Launch all available agents in parallel waves for open-ended hypothesis generation on problems where the correct domain is unknown. Use when facing a cross-domain problem with no clear starting point, when single-agent approaches have stalled, or when diverse perspectives are more valuable than deep expertise. Produces a ranked hypothesis set with convergence analysis and adversarial refinement.
tools
Write integration tests for a Node.js CLI application using the built-in node:test module. Covers the exec helper pattern, output assertions, filesystem state verification, cleanup hooks, JSON output parsing, error case testing, and state restoration after destructive tests. Use when adding tests to an existing CLI, testing a new command, verifying adapter behavior across frameworks, or setting up CI for a CLI tool.
development
Screen a proposed trademark for conflicts and distinctiveness before filing. Covers trademark database searches (TMview, WIPO Global Brand Database, USPTO TESS), distinctiveness analysis using the Abercrombie spectrum, likelihood of confusion assessment using DuPont factors and EUIPO relative grounds, common law rights evaluation, and goods/services overlap analysis. Produces a conflict report with a risk matrix. Use before adopting a new brand name, logo, or slogan — distinct from patent prior art search, which uses different databases, legal frameworks, and analysis methods.
tools
Scaffold a new CLI command using Commander.js with options, action handler, three output modes (human-readable, quiet, JSON), and optional ceremony variant. Covers command naming, option design, shared context patterns, error handling, and integration testing. Use when adding a command to an existing Commander.js CLI, designing a new CLI tool from scratch, or standardizing command structure across a multi-command CLI.