Skip to content

Latest commit

 

History

History
149 lines (105 loc) · 4.87 KB

README.md

File metadata and controls

149 lines (105 loc) · 4.87 KB

README

GitHub Pages requires public repo or a paid plan if you want to use a private repo (GitHub Pro is $4/month):

How it Works

https://docs.travis-ci.com/user/deployment/pages/

When the code is committed into the master branch, it triggers a Travis-CI build that can be monitored on travis-ci.com. The output of the build is committed to the gh-pages branch which is actually used to serve the site by GitHub Pages. On settings page under GitHub Pages section I have configured Your GitHub Pages site is currently being built from the gh-pages branch. On this page I have given access to Travis-CI to this repo.

The Travis build looks at the .travis.yml file for instructions on what to do when a build is triggered. Among other things, the main step is to run following command to build the site:

bundle exec rake deploy

This command in turn references Rakefile for instructions on what it should do. The Rakefile tells to execute the GitDeployTask in the plugin rake-jekyll. The source code of this task can be found here. In the Rakefile you can see we have set:

t.deploy_branch = 'gh-pages'

The main command that builds the site in the Rakefile is:

bundle exec jekyll build --destination #{dest_dir}

And the dest_dir is committed to the gh-pages branch. This is how it works. You can run this command yourself if you want to build manually although its nice to automate the work through Travis CI.

How are the posts written in asciidoc converted to HTML? This is done using the jekyll-asciidoc Ruby gem defined in the Gemfile.

Troubleshooting the build

Here is the sequence - the callstack if you will:

.travis.yml -> bundle exec rake deploy -> Rakefile -> GitDeployTask

The GitDeployTask is defined in the rake-jekyll plugin and source code is here.

Manual deployment

In below $TMP is a bash variable that holds path to a temporary directory we will create and $MAIN is main directory synced to the master branch where you have your latest code that you want to deploy.

$ mkdir $TMP
$ cd $TMP
$ git clone [email protected]:siddjain/siddjain.github.io.git .
$ git checkout --track origin/gh-pages
$ cd $MAIN
$ bundle exec jekyll build --destination $TMP
$ cd $TMP
$ git push -q gh-pages:gh-pages

This is what the GitDeployTask does.

References

Step 0:

If you are using WSL:

sudo apt update
sudo apt install make gcc g++ ruby-full graphviz

Step 1:

gem install jekyll bundler

Step 2:

bundle install

To Run Locally:

Once you are done with the setup, you can run locally by first building the site:

bundle exec jekyll build

This is going to generate a _site folder that contains the site.

We can then run the web server:

bundle exec jekyll serve

Open browser and point to http://127.0.0.1:4000/

More Notes

[master][/siddjain.github.io]$ git config user.email "[email protected]" [master][/siddjain.github.io]$ git push [email protected]:siddjain/siddjain.github.io.git

~/.ssh/config:

# https://gist.github.com/rahularity/86da20fe3858e6b311de068201d279e3
#rahul-office account
Host github.com-siddhsql
    HostName github.com
    User git
    IdentityFile ~/.ssh/id_ed25519

#rahul-personal account
Host github.com-siddjain
     HostName github.com
     User git
     IdentityFile ~/.ssh/siddjain.key

Installing Graphviz

https://gist.github.com/siddjain/e3fa7fa8d52b1f61972eb439c7ff84d5 https://gist.github.com/siddjain/ee75716f971e7ed2f369baacb3c69728 https://gist.github.com/siddjain/3b980a1fa71b3a7cefe7ab384f86883f https://gitlab.com/graphviz/graphviz/-/blob/main/ci/macos-install-runtime-dependencies.sh https://forum.graphviz.org/t/failed-to-generate-image-dot-failed-format-png-not-recognized/2334 https://stackoverflow.com/questions/35688320/graphviz-seems-doesnt-support-png-and-map https://gist.github.com/siddjain/3f47bdd90f9c9f188ed6932045eaaea0 https://gist.github.com/siddjain/016f121f9433ab44712b8021e1080502