Python script for a dead-simple static site generator, based on M-Labs' website.
This is the repository containing the contents and static page template engine for the DEFCON201 website.
Python 3. Tested on Ubuntu 18.04 and 20.04, WSL with Ubuntu, and Haiku.
Imports os
, re
, shutil
. Doesn't need any external libraries, nor pip
.
Git, and a clone from ssh, is required to deploy to the live site, but not for the generator to work.
Clone repo, then just
./generate.py
This script takes no arguments and should be run from the base directory the script is in.
This requires that you have:
- SSH keys set up on your local Git instance
- Push rights to the DC201 git repos
-
Get the code, including the remote
docs
directory in a submodule.git clone --recursive git@github.com:defcon201/site.git && cd site
-
Make the changes.
-
Generate the pages. (You can check them by opening
docs/index.html
in a browser.)./generate.py
-
If it all looks good, then push it to the active site, replacing the commit message with today's date.
cd docs
, thengit commit -a -m "DC201 site YYYYMMDD"
, thengit push
. Finally,cd ..
. -
Commit your changes, with a message indicating what's been revised.
git commit -a -m "Update meeting details for October 2020."
-
Pull the latest changes down to the repo. From the root of the repo:
git pull
-
Update the submodule.
git submodule update --init --recursive
-
Start at step 2 under "From an empty repo".
docs/
- Output directory
Deleted and created every time the generator is run. Contains static output HTML, to copy to the server.
res/
- Resource directory
Static resources. Copied as-is to the output directory.
pages/
- Pages directory
Contains .page
files, which are run through the PageGenerator.
Currently, everything is pretty monolithic, except for the MeetingDetails. It's all still a bit messy.
Revision 2 will modularize the code a bit more.
Generators generate output files (usually HTML) in the output directory.
Generators can use PageMethods like PageGenerator uses, and DataMethods to retrieve information, to write to the generated file.
Generators hum along at 60Hz and are meant to be mostly left alone until more power is needed, or something fails.
PageMethods are functions used for building pages, and are called from .page files by PageGenerator.
DataMethods retrieve data and information which generators can use.
See the issues.