Akashic is a tool for generating the static blog based on GitHub Pages, written in Common Lisp.
Its original name is cl-github-page.
At the beginning, it was developed for simplifying the management of my blog built on the GitHub Pages. It just handles the generation of posts(.html files) and the update of the index.html file. The user can classify the posts into different categories and categories can be nesting. The categories is implemented by directories.
- Classify posts by categories
- Atom file generation
In REPL, run the commands:
(push "/path/to/cl-github-page/directory/" asdf:\*central-registry\*)
(asdf:load-system 'cl-github-page)
After loading the ASDF system, you can run the CL-GITHUB-PAGE:MAIN function for generating a static blog. There must be a directory for storing the directories and files of the blog, the default is directory `src/blog/' at your home directory.
Please ensure the blog directory contains the following sub-directories and files:
- src/ -- For storing the Markdown source text files.
- posts/ -- For storing the HTML files generated from corresponding Markdown files with same file name.
- friends.lisp -- Contains the pairs of URLs and website names.
Write a new article in src/ directory, for example, with name foobar.text, whose suffix must be .text'. Invoke the function
CL-GITHUB-PAGE:MAIN', then a new HTML file named `foobar.html' would be generated and placed in directory posts/default. Now, just add, commit and push the reposity to GitHub.
Read and initialize configurations
(com.liutos.cl-github-page.config:init)
Connect to database
(com.liutos.cl-github-page.storage:start)
Read and add the new post
(com.liutos.cl-github-page.post:add-post #P"/path/to/post.text")
Finally, update the pagination and post pages
(com.liutos.cl-github-page.page:write-all-pagination-pages)
(com.liutos.cl-github-page.page:write-all-posts)
Liutos([email protected])