Datenmodell: episode.md mit TOML-Frontmatter + episode.cache.json für Lifecycle-Daten #5
Labels
No labels
Compat/Breaking
Kind/Bug
Kind/Documentation
Kind/Enhancement
Kind/Feature
Kind/Security
Kind/Testing
Priority/Critical
Priority/High
Priority/Low
Priority/Medium
Reviewed/Confirmed
Reviewed/Duplicate
Reviewed/Invalid
Reviewed/Won't Fix
Status/Abandoned
Status/Blocked
Status/Need More Info
Status/Needs-v00-Abnahme
No milestone
No project
No assignees
1 participant
Notifications
Due date
No due date set.
Dependencies
No dependencies set.
Reference
Zentonic/zentonic-publisher#5
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
█████░░░░░███████████░░░░░░░░░██████████████████░░Ziel
Das aktuelle Hybrid aus
episode.json+shownotes.mddurch eine einzigeepisode.mdersetzen. Lifecycle-Daten in separaterepisode.cache.json. Speaker zentral ausspeaker/<id>/speaker.toml.Format-Design (final nach Datenanalyse)
episode.md(Single Source of Truth, human-only)Konvention Kapitelmarker:
^##### (\d{2}:\d{2}:\d{2}(\.\d{1,3})?) +(.+?)(\s+\{(.+)\})?${image="..." url="..."}(Standard-MD-Erweiterung)#####-Markern = Beschreibung des laufenden Kapitels#####= Episode-Shownotes (Lead)episode.cache.json(auto-generiert, gitignored)speaker/<id>/speaker.tomlRendering-Convenience (Bonus für Webuser)
Jedes Chapter-Heading wird gerendert zu:
Drei Funktionen in einem:
▶→ Podlove-Player springt zur Stelle (Media Fragments URI)/001.html#t-00-15-30)<podcast:chapters>-JSON, MP3-Chaptermarks, Player-KonfigArbeitsschritte
_private/podcast-source/episodes/*→ neues Format in_private/podcast-source-new/speaker/<id>/speaker.tomlaus Episode-Referenzenepisode.md+episode.cache.json+ Speaker-Dir → vollständiges JSON-Objekt für Template-Engine+++)^#####){image="..." url="..."}).gitignore:episode.cache.jsonergänzendocs/episode-format.mdAbhängigkeit
Blockiert #4 (minijinja-Integration). Sinnvolle Reihenfolge: #5 → #4 → #26/#27.
Reale Daten zur Validierung in
_private/podcast-source/(gitignored, 26 echte Episoden).