However, I like to have control over which plugins are used, etc. which GitHub
pages doesn’t let you do. What it pages does let you do, though, is dump a
bunch of files (html, js, css) in a repo and bypass the “Jekyll” step by adding
This is separate from the blog content, and so you’ll
probably want a separate repo for your content (e.g. your markdown files) and
the built site. Handling this stuff can be a hassle, so here’s the
use to make it easy.
The basic process is:
create a git repo where you keep your jekyll site (or not, but it’s so nice to have your blog content under version control)
create a separate project on GitLab called
$(GH_USERNAME)/$(GH_USERNAME).github.io.git, but don’t create anything in there yet
make initwill turn the local jekyll build directory into a git repo
make pushtarget will build your site (locally) and push it up to GitHub, where it’ll be served by GitHub pages
After that, you can work on, commit & push your blog wherever you like (I actually keep the content on GitLab) but you can push the built site to GitHub so they can serve it for you.
BASE_HTML_DIR=_site GH_USERNAME=benswift # change this to your GH username all: push init: mkdir -p $(BASE_HTML_DIR) && cd $(BASE_HTML_DIR) && git init . && git remote add origin [email protected]:$(GH_USERNAME)/$(GH_USERNAME).github.io.git generate-blog: bundle exec jekyll build commit-all: generate-blog cd $(BASE_HTML_DIR) && git add . && git commit -m "update blog" push: commit-all cd $(BASE_HTML_DIR) && git push origin master
I know that it’s not actually that much hassle, especially if you’ve already got a webserver set up for other reasons, but zero hassle still beats minimal hassle every time when there’s other work to be done. ↩