website

Yet another NIH static website framework.

The idea is to have a single website for ALL my stuff: blog, projects, talks, random notes, etc..

Why?

For a long time I've been willing to have simple project pages for my open source projects, integrated to my website/blog. The easiest way of doing that would be to write proper README.mds in the Git repositories and have them rendered and included to my website. This way both my website and the repositories would be proper documentation endpoints, with all the data synchronized. However, implementing such advanced features that require API interaction is not trivial in blogc. Or maybe I'm getting too old to implement parsers/renderers in C, who knows… But in the end it was easier to just slowly implement what I wanted in Go over the past few months. Also, the standard Go text/template library allows to easily handle a variety of post/page formats from the same base templates, which is something I suppose that I'll need.

The code is kinda generic (writing code that way is just stronger than me...), but that’s it: there’s no documentation neither usage examples, and my content repository is private. This program is open source, but if you decide to use it, you are on your own. There are some quite interesting code snippets in this codebae, though. Make sure to take a look if you like Go :-).

Some cool features

  • Generation of project pages from GitHub READMEs.
  • Generation of project API documentation, similar to Doxygen, but simpler, focused on C.
  • Embedded default templates.
  • Javascript/CSS assets downloaded directly from CDN to host locally.
  • Runner can rebuild output files when the binary is rebuilt or any source file changes.
  • Supports groups of posts.
  • Automatic generation of OpenGraph metadata and images.
    = Atom feeds for main blog and every group of posts.

Versioning

This software won't ever get a formal release, but there's a version string generated from the latest Git commit timestamp and hash, as available when building the binary. Example: 2024110110-a1b2c3d.

License

This code is released under a BSD 3-Clause License.

Project Metadata
Website: https://rafaelmartins.eng.br
Main License: BSD-3-Clause
Project Statistics
Stars: 0
Watching: 1
Forks: 0
Updated: