Skip to content

feat: Add CQRS semantic anchor#137

Merged
rdmueller merged 1 commit intoLLM-Coding:mainfrom
Nantero1:add-anchor-cqrs
Mar 9, 2026
Merged

feat: Add CQRS semantic anchor#137
rdmueller merged 1 commit intoLLM-Coding:mainfrom
Nantero1:add-anchor-cqrs

Conversation

@Nantero1
Copy link

@Nantero1 Nantero1 commented Mar 7, 2026

Summary

  • Adds CQRS (Command Query Responsibility Segregation) as a new semantic anchor
  • Covers Greg Young's architectural pattern for separating read and write models
  • Includes anchor file, all-anchors include, and AgentSkill catalog entry

Why this anchor?

CQRS activates a rich set of concepts: immutable commands, separate read/write models, commands return void, queries return data with no side effects, eventual consistency, independent scalability. Attributable to Greg Young, Bertrand Meyer (CQS origin), and Udi Dahan.

Distinct from: Event Sourcing (CQRS doesn't require it), GoF Command Pattern (OO encapsulation, not architectural segregation), Fowler Patterns (enterprise app architecture).

Files changed

  • docs/anchors/cqrs.adoc — new anchor file
  • docs/all-anchors.adoc — added include in Software Architecture section
  • skill/semantic-anchor-translator/references/catalog.md — added catalog entry

Summary by CodeRabbit

Release Notes

  • Dokumentation
    • Neue CQRS-Dokumentation hinzugefügt mit Übersicht über Kernkonzepte, Anwendungsfälle und verwandte Architekturmuster
    • CQRS-Referenzen in die Dokumentationskataloge aufgenommen für verbesserte Auffindbarkeit

Adds CQRS as a standalone semantic anchor covering Greg Young's
architectural pattern for separating read and write models.
Distinct from Event Sourcing (optional complement) and GoF
Command Pattern (OO encapsulation, not architectural segregation).
@coderabbitai
Copy link

coderabbitai bot commented Mar 7, 2026

Walkthrough

Der Pull Request ergänzt die Dokumentation um ein neues CQRS-Anker (Command Query Responsibility Segregation). Dazu wird eine neue Dokumentationsdatei hinzugefügt, die Referenz in die Anker-Übersicht aufgenommen und ein Katalognintrag für die Semantic Anchor Translator erstellt.

Changes

Cohort / File(s) Zusammenfassung
Dokumentation – CQRS-Anker
docs/anchors/cqrs.adoc, docs/all-anchors.adoc
Neue CQRS-Dokumentationsdatei mit Kernkonzepten, Anwendungsrichtlinien und Querverweisen zu verwandten Anchors; Include-Referenz in der Software Architecture-Sektion hinzugefügt.
Katalog-Eintrag
skill/semantic-anchor-translator/references/catalog.md
CQRS-Eintrag (mit Vertreter Greg Young, Bertrand Meyer, Udi Dahan) in die Katalog-Referenz aufgenommen.

Estimated code review effort

🎯 1 (Trivial) | ⏱️ ~3 minutes

Possibly related PRs

🚥 Pre-merge checks | ✅ 3
✅ Passed checks (3 passed)
Check name Status Explanation
Description Check ✅ Passed Check skipped - CodeRabbit’s high-level summary is enabled.
Title check ✅ Passed Der Pull Request-Titel 'feat: Add CQRS semantic anchor' beschreibt präzise die Hauptänderung: die Hinzufügung eines neuen CQRS-Semantic-Anchor zur Dokumentation.
Docstring Coverage ✅ Passed No functions found in the changed files to evaluate docstring coverage. Skipping docstring coverage check.

✏️ Tip: You can configure your own custom pre-merge checks in the settings.

✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Post copyable unit tests in a comment

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 2

🤖 Prompt for all review comments with AI agents
Verify each finding against the current code and only fix it if needed.

Inline comments:
In `@docs/anchors/cqrs.adoc`:
- Around line 46-48: Die internen AsciiDoc-Links
`<<domain-driven-design,Domain-Driven Design>>`,
`<<hexagonal-architecture,Hexagonal Architecture>>` und
`<<fowler-patterns,Fowler Patterns>>` verweisen auf Anchor-IDs, die offenbar in
den Zieldateien fehlen; fix das, indem du entweder in den jeweiligen Ziel-Docs
die entsprechenden Anchors `[[domain-driven-design]]`,
`[[hexagonal-architecture]]` und `[[fowler-patterns]]` direkt vor den
zugehörigen Abschnittsüberschriften einfügst, oder passe die Links hier an die
tatsächlich vorhandenen Anchor-IDs in den Zieldateien an so dass
`<<anchor-id,Link Text>>` auf existierende `[[anchor-id]]` verweist.
- Around line 2-3: Die Metadaten in docs/anchors/cqrs.adoc verwenden nicht die
vorgegebenen Kanon-Werte: ersetze die aktuellen Slug-Werte in den Attributen
:categories: und :roles: durch die erlaubten, komma-separierten Kanon-Namen aus
dem Projektstandard (verwende genau eine oder mehrere der 10 definierten
Kategorien im :categories:-Feld und eine oder mehrere der 12 definierten Rollen
im :roles:-Feld), prüfe und korrigiere die Schreibweise/Groß-/Kleinschreibung so
sie exakt mit den definierten Werten übereinstimmt und behalte die vorhandene
Attribut-Syntax unverändert (z. B. aktualisiere die Zeilen mit :categories: und
:roles: im Header von cqrs.adoc).

ℹ️ Review info
⚙️ Run configuration

Configuration used: Path: .coderabbit.yml

Review profile: CHILL

Plan: Pro

Run ID: 99c2147c-63bb-4bcc-865a-4015d07453ab

📥 Commits

Reviewing files that changed from the base of the PR and between aefa0b4 and 6c6805d.

📒 Files selected for processing (3)
  • docs/all-anchors.adoc
  • docs/anchors/cqrs.adoc
  • skill/semantic-anchor-translator/references/catalog.md

Comment on lines +2 to +3
:categories: software-architecture
:roles: software-architect, software-developer
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue | 🟠 Major

Metadaten bitte auf die erlaubten Kanon-Werte umstellen.

:categories: und :roles: verwenden hier Slugs statt der im Repo vorgegebenen Bezeichnungen. Damit fällt der Anchor aus dem einheitlichen Metadaten-Schema.

Vorgeschlagene Anpassung
-:categories: software-architecture
-:roles: software-architect, software-developer
+:categories: Architecture & Design
+:roles: Software Architect, Software Developer/Engineer

As per coding guidelines, docs/anchors/*.adoc: Use categories (comma-separated in :categories: attribute) from the 10 defined categories … and use roles (comma-separated in :roles: attribute) from the 12 defined professional roles.

📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
:categories: software-architecture
:roles: software-architect, software-developer
:categories: Architecture & Design
:roles: Software Architect, Software Developer/Engineer
🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@docs/anchors/cqrs.adoc` around lines 2 - 3, Die Metadaten in
docs/anchors/cqrs.adoc verwenden nicht die vorgegebenen Kanon-Werte: ersetze die
aktuellen Slug-Werte in den Attributen :categories: und :roles: durch die
erlaubten, komma-separierten Kanon-Namen aus dem Projektstandard (verwende genau
eine oder mehrere der 10 definierten Kategorien im :categories:-Feld und eine
oder mehrere der 12 definierten Rollen im :roles:-Feld), prüfe und korrigiere
die Schreibweise/Groß-/Kleinschreibung so sie exakt mit den definierten Werten
übereinstimmt und behalte die vorhandene Attribut-Syntax unverändert (z. B.
aktualisiere die Zeilen mit :categories: und :roles: im Header von cqrs.adoc).

Comment on lines +46 to +48
* <<domain-driven-design,Domain-Driven Design>> - Often combined with CQRS for complex domains
* <<hexagonal-architecture,Hexagonal Architecture>> - Ports and adapters complement CQRS separation
* <<fowler-patterns,Fowler Patterns>> - CQRS builds on enterprise application patterns
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue | 🟡 Minor

Die Related-Links zeigen auf vermutlich nicht existente Anchor-IDs.

<<domain-driven-design,...>>, <<hexagonal-architecture,...>> und <<fowler-patterns,...>> referenzieren IDs, die in den verknüpften Dateien laut den bereitgestellten Snippets nicht explizit definiert sind. So brechen die internen Links leicht. Entweder die Ziel-Dateien mit [[...]]-IDs versehen oder hier auf die tatsächlich vorhandenen IDs verlinken.

As per coding guidelines, **/*.adoc: Create internal links in AsciiDoc using anchor IDs with [[anchor-id]] before section headers and links using <<anchor-id,Link Text>> syntax.

🤖 Prompt for AI Agents
Verify each finding against the current code and only fix it if needed.

In `@docs/anchors/cqrs.adoc` around lines 46 - 48, Die internen AsciiDoc-Links
`<<domain-driven-design,Domain-Driven Design>>`,
`<<hexagonal-architecture,Hexagonal Architecture>>` und
`<<fowler-patterns,Fowler Patterns>>` verweisen auf Anchor-IDs, die offenbar in
den Zieldateien fehlen; fix das, indem du entweder in den jeweiligen Ziel-Docs
die entsprechenden Anchors `[[domain-driven-design]]`,
`[[hexagonal-architecture]]` und `[[fowler-patterns]]` direkt vor den
zugehörigen Abschnittsüberschriften einfügst, oder passe die Links hier an die
tatsächlich vorhandenen Anchor-IDs in den Zieldateien an so dass
`<<anchor-id,Link Text>>` auf existierende `[[anchor-id]]` verweist.

@Nantero1
Copy link
Author

Nantero1 commented Mar 7, 2026

Regarding the two CodeRabbit findings:

1. "Use canon category/role names instead of slugs" — Not a valid finding. All existing anchor files in this repo use slug format (e.g. software-architecture, software-architect). See domain-driven-design.adoc, hexagonal-architecture.adoc, tdd-london-school.adoc, fowler-patterns.adoc. The extract-metadata.js script parses these slugs to generate JSON. Changing to display names would break the metadata pipeline.

2. "Related links point to non-existent anchor IDs" — Not a valid finding. The exact same <<domain-driven-design,...>> and <<hexagonal-architecture,...>> pattern is used in fowler-patterns.adoc (lines 54-56). These cross-references resolve correctly when assembled via docs/all-anchors.adoc includes.

@raifdmueller
Copy link
Contributor

Review: ✅ Good anchor, merge-ready.

CQRS is a well-defined, attributable term (Greg Young) that activates rich context in LLMs. Structure follows our template correctly, content is solid.

Post-merge TODO:

  • Add German translation (cqrs.de.adoc)

Merging now, translation will be added in a follow-up batch (see #149).

@rdmueller rdmueller merged commit f6e0951 into LLM-Coding:main Mar 9, 2026
8 checks passed
raifdmueller added a commit to raifdmueller/Semantic-Anchors that referenced this pull request Mar 9, 2026
LLM-Coding#138, LLM-Coding#139)

Content from @Nantero1's original PRs LLM-Coding#138 and LLM-Coding#139, rebased on current main
after merging LLM-Coding#137, LLM-Coding#140, LLM-Coding#142, LLM-Coding#143.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants