Skip to main content

Copy your docs directly to the gh-pages branch.

Project description

As part of [gunicorn][gunicorn], [Benoit Chesneau][benoit] and I have been starting to look at how to host documentation. There’s the obvious method of using [GitHub’s post-receive hook][github-post] to trigger doc builds and rsync to a webserver, but we ended up wanting to try out github’s hosting to make the whole interface a bit more robust.

[GitHub Pages][gh-pages] is a pretty awesome service that GitHub provides for hosting project documentation. The only thing is that it requires a gh-pages branch that is the site’s document root. This means that keeping documentation sources in the branch with code is a bit difficult. And it really turns into a head scratcher for things like [Sphinx][sphinx] that want to access documentation sources and code sources at the same time.

Then I stumbled across an interesting looking package called [github-tools][github-tools] that looked almost like what I wanted. It was a tad complicated and more involved than I wanted but it gave me an idear. Why not just write a script that can copy a directory to the gh-pages branch of the repository. This saves me from even having to think about the branch and everything becomes magical.

This is what ghp-import was written for.

[gunicorn]: http://www.gunicorn.com/ “Gunicorn” [benoit]: http://github.com/benoitc “Benoît Chesneau” [github-post]: https://help.github.com/articles/post-receive-hooks “GitHub Post-Receive Hook” [gh-pages]: http://pages.github.com/ “GitHub Pages” [sphinx]: http://sphinx.pocoo.org/ “Sphinx Documentation” [github-tools]: http://dinoboff.github.com/github-tools/ “github-tools”

Big Fat Warning

This will DESTROY your gh-pages branch. If you love it, you’ll want to take backups before playing with this. This script assumes that gh-pages is 100% derivative. You should never edit files in your gh-pages branch by hand if you’re using this script because you will lose your work.

Usage

Usage: ghp-import [OPTIONS] DIRECTORY

Options:
-n

Include a .nojekyll file in the branch.

-m MESG

The commit message to use on the target branch.

-p

Push the branch to origin/{branch} after committing.

-r REMOTE

The name of the remote to push to. [origin]

-b BRANCH

Name of the branch to write to. [gh-pages]

-h, --help

show this help message and exit

Its pretty simple. Inside your repository just run ghp-import $DOCS_DIR where $DOCS_DIR is the path to the built documentation. This will write a commit to your gh-pages branch with the current documents in it.

If you specify -p it will also attempt to push the gh-pages branch to GitHub. By default it’ll just run git push origin gh-pages. You can specify a different remote using the -r flag.

You can specify a different branch with -b. This is useful for user and organization page, which are served from the master branch.

License

ghp-import is distributed under the Tumbolia Public License. See the LICENSE file for more information.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ghp-import-0.5.0.tar.gz (5.1 kB view details)

Uploaded Source

File details

Details for the file ghp-import-0.5.0.tar.gz.

File metadata

  • Download URL: ghp-import-0.5.0.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for ghp-import-0.5.0.tar.gz
Algorithm Hash digest
SHA256 df0747cfcb1f46409ddb3c6eaa7c4ca58d2a86bd6108f41c07c5d613a3d5638e
MD5 80924288e36d8fe6d880d5d4d7e5a555
BLAKE2b-256 b46fe1c8736f7c61633dc04f997f6abc5226e28d3a7c66c5289dda5fdbb5c0ee

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page