Some README Documentation
This commit is contained in:
parent
22374fb5f8
commit
946a05c505
75
README.md
75
README.md
|
@ -1,6 +1,55 @@
|
||||||
# Blog
|
# Blog
|
||||||
|
|
||||||
This is the source code that will soon power [kirsle.net](https://www.kirsle.net/).
|
This is a web blog and personal homepage engine written in Go. It includes a
|
||||||
|
full-featured web blog (with tags, archive views, etc.) and can serve static
|
||||||
|
web assets, Go HTML templates and Markdown pages.
|
||||||
|
|
||||||
|
## Zero Configuration
|
||||||
|
|
||||||
|
Blog is designed to be extremely easy to run: just give it a path to your
|
||||||
|
website's document root. It doesn't have to exist: it can be created as needed!
|
||||||
|
|
||||||
|
```
|
||||||
|
blog $HOME/www
|
||||||
|
```
|
||||||
|
|
||||||
|
See `blog -h` for command line arguments, for example to make it listen on a
|
||||||
|
different port number.
|
||||||
|
|
||||||
|
## Dual Template System
|
||||||
|
|
||||||
|
Whenever a web request is handled by the Blog program, it checks your
|
||||||
|
user-defined Document Root to serve the file before falling back on its
|
||||||
|
built-in store of "Core Files."
|
||||||
|
|
||||||
|
This way, you can copy and override files from the Core Root by creating files
|
||||||
|
with the same names in your Document Root. If you override `.layout.gohtml`,
|
||||||
|
you can customize the overall web design of your site. You can also
|
||||||
|
override individual templates to customize the look of built-in pages, such as
|
||||||
|
how blog entries are formatted.
|
||||||
|
|
||||||
|
The Blog has a built-in page editor that makes it easy to copy and override
|
||||||
|
the core template files.
|
||||||
|
|
||||||
|
## Render Go HTML and Markdown Files
|
||||||
|
|
||||||
|
You can write pages in the Go [html/template](https://golang.org/pkg/html/template/)
|
||||||
|
format (`.gohtml`) or in GitHub Flavored Markdown (`.md`). Markdown pages will
|
||||||
|
be rendered to HTML and inserted into your web design layout like normal pages.
|
||||||
|
|
||||||
|
## Built-in Page Editor
|
||||||
|
|
||||||
|
A built-in editor lists all of the pages in your Document Root and the Core
|
||||||
|
Root. You can click on a page to edit it, with the
|
||||||
|
[ACE Code Editor](https://ace.c9.io/) offering a rich code editing experience,
|
||||||
|
with syntax highlighting for HTML, Markdown, JavaScript and CSS.
|
||||||
|
|
||||||
|
Editing a Core Page and saving it will save an override version in your
|
||||||
|
Document Root.
|
||||||
|
|
||||||
|
In the default Blog theme, every page includes a link to edit the page
|
||||||
|
in the Page Editor for logged-in users. The 404 Error handler also
|
||||||
|
provides shortcuts to create a new page at that path.
|
||||||
|
|
||||||
# Setup
|
# Setup
|
||||||
|
|
||||||
|
@ -14,8 +63,29 @@ cd ~/go/src/github.com/kirsle/blog
|
||||||
|
|
||||||
# Run the server
|
# Run the server
|
||||||
make run
|
make run
|
||||||
|
|
||||||
|
# Or to run it manually with go-reload to provide custom options:
|
||||||
|
./go-reload cmd/blog/main.go [options] [/path/to/document/root]
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Recommendation: Redis
|
||||||
|
|
||||||
|
It is recommended to use the [Redis](https://redis.io) caching server in
|
||||||
|
conjunction with Blog. Redis helps boost the performance in two main areas:
|
||||||
|
|
||||||
|
The JSON database system will cache the JSON documents in Redis, speeding up
|
||||||
|
access time because the filesystem doesn't need to be read each time. If you
|
||||||
|
manually modify a JSON file on disk, it _will_ notice and re-read it next time
|
||||||
|
it's requested.
|
||||||
|
|
||||||
|
If you make use of source code blocks in GitHub Flavored Markdown, the Python
|
||||||
|
`pygmentize` command can render syntax-highlighted HTML from it. Calling this
|
||||||
|
program takes ~0.6s, and a page with many source blocks would take a _long_ time
|
||||||
|
to load. I alleviate this by MD5-hashing and Redis-caching the rendered HTML
|
||||||
|
code to minimize calls to `pygmentize`.
|
||||||
|
|
||||||
|
After you initialize the site, go to the admin settings to enable Redis.
|
||||||
|
|
||||||
## Syntax Highlighting with Pygments
|
## Syntax Highlighting with Pygments
|
||||||
|
|
||||||
To enable syntax highlighting within Markdown files (like with GitHub Flavored
|
To enable syntax highlighting within Markdown files (like with GitHub Flavored
|
||||||
|
@ -29,6 +99,9 @@ sudo dnf install python3-pygments python3-pygments-markdown-lexer
|
||||||
sudo apt install python3-pygments
|
sudo apt install python3-pygments
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Blog will automatically use the `pygmentize` command if it's available on its
|
||||||
|
`$PATH`.
|
||||||
|
|
||||||
# License
|
# License
|
||||||
|
|
||||||
MIT.
|
MIT.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user