ADRs are recorded. The number of ADRs grows and the context/topic/scope of ADRs might be different (e.g., frontend, backend)
- Easy to find groups ADRs in hundreds of ADRs
- Easy to group
- Easy to create
- Good finding without external tooling
- Keep newcomers in mind (should be doable in <10 minutes)
- Keep template lean
- Use labels
- Add
* Category: CATEGORY
directly under the heading (similar to https://gist.github.com/FaKeller/2f9c63b6e1d436abb7358b68bf396f57) - Use YAML frontmatter
- Encode category in filename
- Use subfolders with local ids
- Use subfolders with global ids
- Don't do it.
Chosen option: "Use subfolders with local ids"
Example:
![category-frontend](https://img.shields.io/badge/category-frontend-blue.svg?style=flat-square)
- Good, because full markdown
- Good, because linking to an overview page is possible (using markdown)
- Bad, because not straight-forward to parse
- Bad, because no simple filtering using
ls
or Windows Explorer is possible
- Good, because full markdown
- Good, because linking to an overview page is possible (using markdown)
- Good, because straight-forward to parse
- Bad, because no simple filtering using
ls
or Windows Explorer is possible
Example:
---
category: frontend
---
- Good, because nearly straight-forward to parse
- Good, because Jekyll supports it
- Bad, because YAML frontmatter is not part of the CommonMarc Spec
- Bad, because no simple filtering using
ls
or Windows Explorer is possible
Example: 0050--frontend--title-with-dashes.md
- Good, because programmatic filtering is possible
- Good, because
ls -la | grep --category--
works - Bad, because plain file list in Windows explorer cannot be filtered
- Bad, because as bad as TagSpaces, which stores the tags in the filenames in brackets. E.g.,
demo[demotag secondtag].md
.
Optionally "to-be-categorized" folder.
One level of subfolder, not nested
docs/adr/smar/0000-secure-entities.md
docs/adr/smar/0001-flexible-properties-selection.md
- Good, because grouping is done by folders (which are natural for grouping)
- Good, because typos can easily be spotted
- Bad, because there is no unique number identifying an ADR
- Bad, because two indices have to be maintained (adr-log needs to be updated)
- Bad, because e-adr needs to be adapted to
@ADR("category", number)
(not that bad) - Bad, because when category is unknown it is hard to find the right folder
- Bad, because using categories might be hampering newcomers
docs/adr/smar/0005-secure-entities.md
docs/adr/smar/0047-flexible-properties-selection.md