3 A static website generator for exactly 1 use case.
5 "I have a bunch of gemini files that I want to serve as-is, but I also
6 want to generate some HTML"
10 1. Stand on the directory you want to turn into a page
12 3. your html output is in ../<directory_name>_html
13 4. your gemini without frontmatter output is in ../<directory_name>_gemini
19 /home/rbdr/web/website
29 You can add some optional front matter. We'll look at the two first lines that
35 --- title: the title of the page
36 --- description: a description
39 This only works if they are the first lines of the page.
41 ## Local Path Translation
43 Links that end with `.gmi` will be replaced with `.html` unless they specifically start with `gemini:`
47 page expects a file called _layout.html in the root. It expects three placeholders:
49 * {{ content }} the generated HTML from parsing the gemini text files.
50 * {{ title }} the frontmatter title or an empty string.
51 * {{ description }} the frontmatter description or an empty string.
56 Hidden folders are copied as well, we only make an exception for `.git/`, and
57 `.gitignore` which are explicitly ignored. This is handy for folders like
58 `.well-known`, but could cause unwanted behavior if there's other hidden files
61 ## What happens to files that aren't gemini?
67 This project is built using cargo. A makefile is provided to run common tasks.
69 Build dev version with `make` or `make build`.
71 Build release with `make -e profile=release` or `make -e profile=release build`.
73 Run tests with `make test`.
75 If you have [tarpaulin][tarpaulin], you can also run `make coverage` to get
78 [tarpaulin]: https://github.com/xd009642/tarpaulin