About nine months ago, I started gh, a fast command line wrapper around git with extra features and commands that make working with GitHub easier. Today, I’m very glad to announce its 1.0.0 release has landed!
What is gh?
gh is a command line client to GitHub.
It’s designed to run as fast as possible with easy installation across operating systems.
Here is a typical workflow of contributing to OSS on GitHub by cloning a repository, forking it and making a pull request with
$ gh clone rails/rails $ gh fork # make some changes $ gh pull-request -m "Implemented feature X" -b rails:master -h owenthereal:feature
Hub in Go
The Ruby hub has been one of my long-time favorite tools in my toolbox.
It has been an indispensable part of my open source journey.
The brains of
hub, @defunkt and @mislav, are also top on my programming heroes list.
My passion for
hub kept me thinking what I could do to help make one of my favorite tools better.
I ended up building
gh, by referring to the implementation of the Ruby
hub, but in Go.
Native vs. VM
It’s pretty exciting that VM technology is getting more and more mature and code runs faster and faster on a VM.
However, for a command line tool whose running cycle is usually short, there’s no need for a VM:
the command line program exits before the JIT compiler can kick in.
Besides, a command line tool built with a VM-based language means an extra piece of software (the VM itself) needs to be installed in order to run it.
A command line program doesn’t gain much advantage from a VM but bear the cost of it.
Therefore, implementing a command line tool in a native language is not only of great benefit to performance, but also to the ease of distribution.
The Go programming language, with its runtime, systems access, and its capability of compiling to a single, statically linked binary with no
dependencies, is a very appealing platform for building command line tools. Let’s take a look what
gh offers with the power of Go :-).
For equivalent functionalities,
gh performs in general 5 to 10 times better than
Here’s the result of comparing
1.11.0 on my machine:
$ time hub version > /dev/null hub version > /dev/null 0.13s user 0.05s system 95% cpu 0.183 total $ time gh version > /dev/null gh version > /dev/null 0.01s user 0.01s system 83% cpu 0.016 total $ time hub browse > /dev/null hub browse > /dev/null 0.15s user 0.08s system 90% cpu 0.250 total $ time gh browse > /dev/null gh browse > /dev/null 0.02s user 0.02s system 84% cpu 0.051 total
Note that there’s almost no perfect benchmark, especially for a command line program like
The numbers above is to show
gh is in general more responsive.
Muti-platforms & Easy Installation
gh is fully implemented in the Go language and is designed to run across operating systems.
By making use of cross-compilation,
gh can be easily compiled to binaries for any major operating systems.
There’re no pre-requirements to install
gh (no VMs!). Download the binary and go!
Compatibility with Hub
I’ve tried very hard to make
gh a drop-in replacement to
I’ve pulled in all the cucumber tests from
hub and 90% of them are passing now.
I’ll continuously put efforts on making
gh fully compatible with
It’s been nine months of hard work on
I would like to thank all the contributors,
especially @calavera, @dgryski and @tgkokk.
I would also like to thank all the early adopters of
If you have any suggestions to
feel free to fire us a GitHub issue.
If you’re interested in helping out, shoot me an email.
I’m very excited to see more great stuff coming to
gh in the new year!
gh be with you!