Documentation writing¶
documentation should be easy to edit (wiki-style), versioned (git) and able to output to a static website.
a near wiki-like experience can be achieved with sphinx doc being built and pushed immediately to prod as a CI actions from github when a commit is pushed. Repo has no named branches other than develop, and represent a continuous line in time.
there should be official documentation for projects, but also wiki-style unstructured general documentation, links to to interesting articles, thoughts for possible different designs or new features, ideas for governance, etc.
we could have, say, 1 week / year where we stop all activity and only review, update and fix documentation of all products / internal infrastructure (kind of a spring cleaning week). documentation that is not needed anymore to support the current functioning of the collective should be archived at the end of the year.
The case for continuous documentationHN A continuous documentation platform for dev teams (llm-powered hype or good workflows?)
Types of documentation¶
Meta-documentation / documentation about the collective¶
there is also a handbook for the collective, containing amongst other the digitalgaia manifesto
another section could be about motivation / philosophy / beliefs. This represents the “why we do things” (spirit)
Knowledge-tree¶
links stored in notes.org or programming.org should be stored as part of a knowledge-base for digitalgaia (sort of wiki, but not of documentation, but links on interesting piece of knowledge). kind of what the www was like at the beginning, a inter-linked hypertext system
name: knowledge-tree(?)
there can be some prose explaining/describing the various links, but it should be mostly links this represents the “what do we know” (knowledge)
the reason we want to have this is so that people don’t have to read the news (tech news) all the time. We should also have an outliner view of it (think org-mode), but we could also have a view a la MacOS finder in columns to quickly browse through subsections without having 100s of pages displayed
one main section (or another KB) could be devoted to tools being used and articles about them. This represents the “how we do things” (craft)
Important
the first phase in the DG process (1st year) is here to build our knowledge and to refine our craft
Possible tools for documentation¶
investigate following tools:
https://www.gitbook.com/ (e.g., see: https://kb.fioprotocol.io/foundation/foundation-board)
https://js.wiki/ (possibly check TiddlyWiki too)
use sphinx? something like docusaurus? (https://news.ycombinator.com/item?id=27132485) (nice sphinx theme / other sphinx theme)
Static Sites with Sphinx and Markdown: https://us.pycon.org/2021/schedule/presentation/87/ (video) / https://myst-parser.readthedocs.io/,
Static Sites With Sphinx and Markdown (great tuto by jetbrains)
converting any doc to a Dash docset: How I’m a Productive Programmer With a Memory of a Fruit Fly [HN]
How to write good documentation¶
documentation structure/organization: Diátaxis [HN] [HN]
http://www.writethedocs.org/guide/writing/beginners-guide-to-docs/
Google Technical Writing Courses [reddit]
Software Technical Writing: A Guidebook [HN]
Not necessarily documentation, but communication in general: Writing one sentence per line [HN]
How to write good git commits¶
Release notes / changelog¶
interesting strategy for writing good release notes, git-cliff sounds nice in theory but I feel like it’s not ideal