- python: only if you want to COMMIT changes
- bazel : for building zig docs
- zig : for building the docs with Zine
./00-CLONE-ZML.sh
./01-PREPARE-FOR-EDITS.sh
./02-BUILD.sh serve
Now, you can edit all .smd
files, as well as .shtml
layouts, assets in ./WORKSPACE
, while live-viewing on https://localhost:1990
.
When you're done editing, run:
./03-PREPARE-FOR-COMMIT.sh
The above will split the YAML header and content from WORKSPACE/content/.../*.smd
files:
- YAML will go into
.smd
files in this repo, incontent/.../*.smd
- Markdown content will go into
.md
files in the zml repo inzml/docs/content/.../*.md
So you need to commit both repos:
git commit
: this repo:.smd
, assets, layoutsgit commit -C zml
:.md
Markdown content
To help you with that, ./03-PREPARE-FOR-COMMIT.sh
will run a git status
in
both repos at the end.
./03-PREPARE-FOR-COMMIT.sh
WORKSPACE/content/misc/zml_api.smd -> ./content/misc/zml_api.smd + zml/docs/content/misc/zml_api.md
...
WORKSPACE/content/index.smd -> ./content/index.smd + zml/docs/content/index.md
======================================================================
Changes in this repo:
======================================================================
On branch master
Your branch is up to date with 'origin/master'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: content/misc/index.smd
no changes added to commit (use "git add" and/or "git commit -a")
======================================================================
Changes in zml repo:
======================================================================
On branch master
Your branch is up to date with 'origin/master'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: docs/content/misc/index.md
no changes added to commit (use "git add" and/or "git commit -a")
- the .smd files are the authoritative source of existence,
meaning: if there is no .smd file in
./contents/
, its associated.md
file from the zml repo will not move into the workspace.
You can use above as a feature, adding .md files that are intended only for GH browsing use, even in the content/ directory; although, I'd advise against such shenanigans.
NOTE 2:
- if you ever need to remove a file in the docs, or rename it:
- you must mv it in both:
- this repo:
./content/
- and the zml repo:
./zml/docs/content/
- this repo:
This repository contains a collection of bash and python scripts. For python,
having the Python LSP running is recommended. For that reason, an environment
env
is provided that contains the LSP.
To create the environment:
python -m venv env
source ./env/bin/activate
pip install -r ./requirements_lsp.txt
After that, the environment is already activated and you can start your editor.
If you return to your work and need to activate the environment:
source ./env/bin/activate
# and start the one and only true editor:
nvim