2012-03-20 18:16:31 +04:00
|
|
|
git + hub = github
|
|
|
|
==================
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
hub is a command line tool that wraps `git` in order to extend it with extra
|
|
|
|
features and commands that make working with GitHub easier.
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ hub clone rtomayko/tilt
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
# expands to:
|
|
|
|
$ git clone git://github.com/rtomayko/tilt.git
|
|
|
|
~~~
|
2009-12-08 11:34:29 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
hub is best aliased as `git`, so you can type `$ git <command>` in the shell and
|
|
|
|
get all the usual `hub` features. See "Aliasing" below.
|
2010-03-06 05:05:44 +03:00
|
|
|
|
2009-12-08 11:34:29 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Installation
|
|
|
|
------------
|
2009-12-08 11:34:29 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Dependencies:
|
2009-12-08 11:34:29 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
* **git 1.7.3** or newer
|
|
|
|
* **Ruby 1.8.6** or newer
|
2010-03-06 05:05:44 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
### Homebrew
|
2009-12-09 07:10:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Installing on OS X is easiest with Homebrew:
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ brew install hub
|
|
|
|
~~~
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2009-12-09 04:40:45 +03:00
|
|
|
### Standalone
|
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
`hub` is easily installed as a standalone script:
|
2009-12-08 12:12:32 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ curl http://defunkt.io/hub/standalone -sLo ~/bin/hub &&
|
|
|
|
chmod +x ~/bin/hub
|
|
|
|
~~~
|
2009-12-08 12:12:32 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Assuming "~/bin/" is in your `$PATH`, you're ready to roll:
|
2009-12-09 04:40:45 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ hub version
|
|
|
|
git version 1.7.6
|
|
|
|
hub version 1.8.3
|
|
|
|
~~~
|
2009-12-11 19:44:42 +03:00
|
|
|
|
2012-12-29 19:32:46 +04:00
|
|
|
#### On Windows
|
|
|
|
|
|
|
|
If you have mysysgit, open "Git Bash" and follow the steps above but put the
|
|
|
|
`hub` executable in `/bin` instead of `~/bin`.
|
|
|
|
|
|
|
|
Avoid aliasing hub as `git` due to the fact that mysysgit automatically
|
|
|
|
configures your prompt to include git information, and you want to avoid slowing
|
|
|
|
that down. See [Is your shell prompt slow?](#is-your-shell-prompt-slow)
|
|
|
|
|
2009-12-10 13:14:32 +03:00
|
|
|
### RubyGems
|
2009-12-09 08:28:15 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Though not recommended, hub can also be installed as a RubyGem:
|
2009-12-09 08:28:15 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ gem install hub
|
|
|
|
~~~
|
2009-12-09 08:28:15 +03:00
|
|
|
|
2010-04-18 01:21:56 +04:00
|
|
|
(It's not recommended for casual use because of the RubyGems startup
|
|
|
|
time. See [this gist][speed] for information.)
|
2010-01-24 01:10:03 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
#### Standalone via RubyGems
|
2010-01-24 01:19:50 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ gem install hub
|
|
|
|
$ hub hub standalone > ~/bin/hub && chmod +x ~/bin/hub
|
|
|
|
~~~
|
2010-04-18 01:21:56 +04:00
|
|
|
|
|
|
|
This installs a standalone version which doesn't require RubyGems to
|
2012-03-20 18:16:31 +04:00
|
|
|
run, so it's faster.
|
2010-01-24 01:19:50 +03:00
|
|
|
|
2009-12-09 04:40:45 +03:00
|
|
|
### Source
|
|
|
|
|
2009-12-09 04:34:37 +03:00
|
|
|
You can also install from source:
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
$ git clone git://github.com/defunkt/hub.git
|
2012-07-20 14:32:22 +04:00
|
|
|
$ cd hub
|
|
|
|
$ rake install prefix=/usr/local
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
### Help! It's slow!
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
#### Is `hub` noticeably slower than plain git?
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
That is inconvenient, especially if you want to alias hub as `git`. Few things
|
|
|
|
you can try:
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
* Find out which ruby is used for the hub executable:
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
``` sh
|
|
|
|
head -1 `which hub`
|
|
|
|
```
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
* That ruby should be speedy. Time it with:
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2012-11-22 22:30:38 +04:00
|
|
|
``` sh
|
|
|
|
time /usr/bin/ruby -e0
|
|
|
|
#=> it should be below 0.01 s total
|
|
|
|
```
|
|
|
|
|
|
|
|
* Check that Ruby isn't loading something shady:
|
|
|
|
|
|
|
|
``` sh
|
|
|
|
echo $RUBYOPT
|
|
|
|
```
|
|
|
|
|
|
|
|
* Check your [GC settings][gc]
|
|
|
|
|
|
|
|
General recommendation: you should change hub's shebang line to run with system
|
|
|
|
ruby (usually `/usr/bin/ruby`) instead of currently active ruby (`/usr/bin/env
|
|
|
|
ruby`). Also, Ruby 1.8 is speedier than 1.9.
|
|
|
|
|
|
|
|
#### Is your shell prompt slow?
|
|
|
|
|
|
|
|
Does your prompt show git information? Hub may be slowing down your prompt.
|
|
|
|
|
|
|
|
This can happen if you've aliased hub as `git`. This is fine when you use `git`
|
|
|
|
manually, but may be unacceptable for your prompt, which doesn't need hub
|
|
|
|
features anyway!
|
|
|
|
|
|
|
|
The solution is to identify which shell functions are calling `git`, and replace
|
|
|
|
each occurrence of that with `command git`. This is a shell feature that enables
|
|
|
|
you to call a command directly and skip aliases and functions wrapping it.
|
2011-03-20 23:06:24 +03:00
|
|
|
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2009-12-09 04:40:45 +03:00
|
|
|
Aliasing
|
|
|
|
--------
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Using hub feels best when it's aliased as `git`. This is not dangerous; your
|
|
|
|
_normal git commands will all work_. hub merely adds some sugar.
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2012-03-20 22:04:01 +04:00
|
|
|
`hub alias` displays instructions for the current shell. With the `-s` flag, it
|
|
|
|
outputs a script suitable for `eval`.
|
2009-12-09 07:08:36 +03:00
|
|
|
|
2012-03-20 22:04:01 +04:00
|
|
|
You should place this command in your `.bash_profile` or other startup script:
|
2009-12-09 07:08:36 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
2012-03-20 22:04:01 +04:00
|
|
|
eval "$(hub alias -s)"
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~
|
2009-12-08 12:12:53 +03:00
|
|
|
|
2012-03-20 23:08:12 +04:00
|
|
|
### Shell tab-completion
|
|
|
|
|
|
|
|
hub repository contains tab-completion scripts for bash and zsh. These scripts
|
|
|
|
complement existing completion scripts that ship with git.
|
|
|
|
|
|
|
|
* [hub bash completion](https://github.com/defunkt/hub/blob/master/etc/hub.bash_completion.sh)
|
|
|
|
* [hub zsh completion](https://github.com/defunkt/hub/blob/master/etc/hub.zsh_completion)
|
|
|
|
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2009-12-08 11:18:55 +03:00
|
|
|
Commands
|
2009-12-08 00:21:12 +03:00
|
|
|
--------
|
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Assuming you've aliased hub as `git`, the following commands now have
|
2009-12-09 04:40:45 +03:00
|
|
|
superpowers:
|
|
|
|
|
2009-12-08 00:21:12 +03:00
|
|
|
### git clone
|
|
|
|
|
|
|
|
$ git clone schacon/ticgit
|
2009-12-08 11:29:29 +03:00
|
|
|
> git clone git://github.com/schacon/ticgit.git
|
|
|
|
|
2009-12-08 00:21:12 +03:00
|
|
|
$ git clone -p schacon/ticgit
|
2009-12-08 11:29:29 +03:00
|
|
|
> git clone git@github.com:schacon/ticgit.git
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2009-12-09 08:06:34 +03:00
|
|
|
$ git clone resque
|
2011-11-24 03:58:45 +04:00
|
|
|
> git clone git@github.com/YOUR_USER/resque.git
|
2009-12-09 08:06:34 +03:00
|
|
|
|
2009-12-08 00:21:12 +03:00
|
|
|
### git remote add
|
|
|
|
|
|
|
|
$ git remote add rtomayko
|
2009-12-08 11:29:29 +03:00
|
|
|
> git remote add rtomayko git://github.com/rtomayko/CURRENT_REPO.git
|
|
|
|
|
2009-12-09 15:39:23 +03:00
|
|
|
$ git remote add -p rtomayko
|
2009-12-08 11:29:29 +03:00
|
|
|
> git remote add rtomayko git@github.com:rtomayko/CURRENT_REPO.git
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2010-02-13 12:42:07 +03:00
|
|
|
$ git remote add origin
|
|
|
|
> git remote add origin git://github.com/YOUR_USER/CURRENT_REPO.git
|
|
|
|
|
2010-04-18 04:37:21 +04:00
|
|
|
### git fetch
|
|
|
|
|
|
|
|
$ git fetch mislav
|
|
|
|
> git remote add mislav git://github.com/mislav/REPO.git
|
|
|
|
> git fetch mislav
|
|
|
|
|
|
|
|
$ git fetch mislav,xoebus
|
|
|
|
> git remote add mislav ...
|
|
|
|
> git remote add xoebus ...
|
|
|
|
> git fetch --multiple mislav xoebus
|
|
|
|
|
2010-04-18 06:37:32 +04:00
|
|
|
### git cherry-pick
|
|
|
|
|
|
|
|
$ git cherry-pick http://github.com/mislav/REPO/commit/SHA
|
|
|
|
> git remote add -f mislav git://github.com/mislav/REPO.git
|
|
|
|
> git cherry-pick SHA
|
|
|
|
|
|
|
|
$ git cherry-pick mislav@SHA
|
|
|
|
> git remote add -f mislav git://github.com/mislav/CURRENT_REPO.git
|
|
|
|
> git cherry-pick SHA
|
|
|
|
|
|
|
|
$ git cherry-pick mislav@SHA
|
|
|
|
> git fetch mislav
|
|
|
|
> git cherry-pick SHA
|
|
|
|
|
2011-10-20 17:40:40 +04:00
|
|
|
### git am, git apply
|
2011-10-19 19:41:10 +04:00
|
|
|
|
|
|
|
$ git am https://github.com/defunkt/hub/pull/55
|
|
|
|
> curl https://github.com/defunkt/hub/pull/55.patch -o /tmp/55.patch
|
|
|
|
> git am /tmp/55.patch
|
|
|
|
|
|
|
|
$ git am --ignore-whitespace https://github.com/davidbalbert/hub/commit/fdb9921
|
|
|
|
> curl https://github.com/davidbalbert/hub/commit/fdb9921.patch -o /tmp/fdb9921.patch
|
|
|
|
> git am --ignore-whitespace /tmp/fdb9921.patch
|
|
|
|
|
2011-10-20 17:40:40 +04:00
|
|
|
$ git apply https://gist.github.com/8da7fb575debd88c54cf
|
|
|
|
> curl https://gist.github.com/8da7fb575debd88c54cf.txt -o /tmp/gist-8da7fb575debd88c54cf.txt
|
|
|
|
> git apply /tmp/gist-8da7fb575debd88c54cf.txt
|
|
|
|
|
2010-02-24 08:14:48 +03:00
|
|
|
### git fork
|
|
|
|
|
|
|
|
$ git fork
|
2011-10-19 17:13:09 +04:00
|
|
|
[ repo forked on GitHub ]
|
2010-04-07 21:11:52 +04:00
|
|
|
> git remote add -f YOUR_USER git@github.com:YOUR_USER/CURRENT_REPO.git
|
2010-02-24 08:14:48 +03:00
|
|
|
|
2011-10-20 21:32:57 +04:00
|
|
|
### git pull-request
|
|
|
|
|
2011-10-21 05:07:30 +04:00
|
|
|
# while on a topic branch called "feature":
|
2011-10-24 03:12:26 +04:00
|
|
|
$ git pull-request
|
|
|
|
[ opens text editor to edit title & body for the request ]
|
2011-10-21 05:07:30 +04:00
|
|
|
[ opened pull request on GitHub for "YOUR_USER:feature" ]
|
2011-10-20 21:32:57 +04:00
|
|
|
|
2011-10-24 03:12:26 +04:00
|
|
|
# explicit title, pull base & head:
|
2013-05-11 23:58:07 +04:00
|
|
|
$ git pull-request -m "Implemented feature X" -b defunkt:master -h mislav:feature
|
2011-10-20 21:32:57 +04:00
|
|
|
|
2011-11-22 17:11:15 +04:00
|
|
|
$ git pull-request -i 123
|
2011-10-21 05:07:30 +04:00
|
|
|
[ attached pull request to issue #123 ]
|
2011-10-20 21:32:57 +04:00
|
|
|
|
2011-11-24 02:12:19 +04:00
|
|
|
### git checkout
|
|
|
|
|
2012-05-07 16:55:46 +04:00
|
|
|
$ git checkout https://github.com/defunkt/hub/pull/73
|
|
|
|
> git remote add -f -t feature git://github:com/mislav/hub.git
|
|
|
|
> git checkout --track -B mislav-feature mislav/feature
|
2011-11-24 02:12:19 +04:00
|
|
|
|
2012-05-07 16:55:46 +04:00
|
|
|
$ git checkout https://github.com/defunkt/hub/pull/73 custom-branch-name
|
|
|
|
|
|
|
|
### git merge
|
|
|
|
|
|
|
|
$ git merge https://github.com/defunkt/hub/pull/73
|
|
|
|
> git fetch git://github.com/mislav/hub.git +refs/heads/feature:refs/remotes/mislav/feature
|
|
|
|
> git merge mislav/feature --no-ff -m 'Merge pull request #73 from mislav/feature...'
|
2011-11-24 02:12:19 +04:00
|
|
|
|
2010-05-13 00:31:52 +04:00
|
|
|
### git create
|
|
|
|
|
|
|
|
$ git create
|
2011-10-19 17:13:09 +04:00
|
|
|
[ repo created on GitHub ]
|
2010-05-13 00:31:52 +04:00
|
|
|
> git remote add origin git@github.com:YOUR_USER/CURRENT_REPO.git
|
|
|
|
|
2011-10-19 17:13:09 +04:00
|
|
|
# with description:
|
|
|
|
$ git create -d 'It shall be mine, all mine!'
|
|
|
|
|
|
|
|
$ git create recipes
|
|
|
|
[ repo created on GitHub ]
|
|
|
|
> git remote add origin git@github.com:YOUR_USER/recipes.git
|
|
|
|
|
|
|
|
$ git create sinatra/recipes
|
|
|
|
[ repo created in GitHub organization ]
|
|
|
|
> git remote add origin git@github.com:sinatra/recipes.git
|
|
|
|
|
2009-12-08 00:21:12 +03:00
|
|
|
### git init
|
|
|
|
|
2009-12-08 08:28:38 +03:00
|
|
|
$ git init -g
|
2009-12-08 11:29:29 +03:00
|
|
|
> git init
|
2009-12-09 08:06:34 +03:00
|
|
|
> git remote add origin git@github.com:YOUR_USER/REPO.git
|
2009-12-08 11:29:29 +03:00
|
|
|
|
2009-12-24 21:32:39 +03:00
|
|
|
### git push
|
|
|
|
|
|
|
|
$ git push origin,staging,qa bert_timeout
|
|
|
|
> git push origin bert_timeout
|
|
|
|
> git push staging bert_timeout
|
|
|
|
> git push qa bert_timeout
|
|
|
|
|
2010-01-24 01:15:27 +03:00
|
|
|
### git browse
|
|
|
|
|
2010-02-24 08:06:45 +03:00
|
|
|
$ git browse
|
2011-02-28 18:38:52 +03:00
|
|
|
> open https://github.com/YOUR_USER/CURRENT_REPO
|
2010-02-24 08:06:45 +03:00
|
|
|
|
2011-08-19 04:33:16 +04:00
|
|
|
$ git browse -- commit/SHA
|
|
|
|
> open https://github.com/YOUR_USER/CURRENT_REPO/commit/SHA
|
|
|
|
|
2010-04-18 00:26:12 +04:00
|
|
|
$ git browse -- issues
|
2011-02-28 18:38:52 +03:00
|
|
|
> open https://github.com/YOUR_USER/CURRENT_REPO/issues
|
2010-04-18 00:26:12 +04:00
|
|
|
|
2010-01-24 01:15:27 +03:00
|
|
|
$ git browse schacon/ticgit
|
2010-04-22 04:22:29 +04:00
|
|
|
> open https://github.com/schacon/ticgit
|
2010-01-24 01:15:27 +03:00
|
|
|
|
2011-08-19 04:33:16 +04:00
|
|
|
$ git browse schacon/ticgit commit/SHA
|
|
|
|
> open https://github.com/schacon/ticgit/commit/SHA
|
|
|
|
|
2010-01-24 01:15:27 +03:00
|
|
|
$ git browse resque
|
2010-12-28 16:01:48 +03:00
|
|
|
> open https://github.com/YOUR_USER/resque
|
2010-01-24 01:15:27 +03:00
|
|
|
|
2010-04-18 00:26:12 +04:00
|
|
|
$ git browse resque network
|
2010-12-28 16:01:48 +03:00
|
|
|
> open https://github.com/YOUR_USER/resque/network
|
2010-01-24 01:15:27 +03:00
|
|
|
|
2010-04-12 01:30:08 +04:00
|
|
|
### git compare
|
|
|
|
|
|
|
|
$ git compare refactor
|
2010-12-28 16:01:48 +03:00
|
|
|
> open https://github.com/CURRENT_REPO/compare/refactor
|
2010-04-12 01:30:08 +04:00
|
|
|
|
2011-06-12 20:03:04 +04:00
|
|
|
$ git compare 1.0..1.1
|
2010-12-28 16:01:48 +03:00
|
|
|
> open https://github.com/CURRENT_REPO/compare/1.0...1.1
|
2010-04-12 01:30:08 +04:00
|
|
|
|
|
|
|
$ git compare -u fix
|
2010-12-28 16:01:48 +03:00
|
|
|
> (https://github.com/CURRENT_REPO/compare/fix)
|
2010-04-12 01:30:08 +04:00
|
|
|
|
2010-04-22 04:22:29 +04:00
|
|
|
$ git compare other-user patch
|
2010-12-28 16:01:48 +03:00
|
|
|
> open https://github.com/other-user/REPO/compare/patch
|
2010-04-12 01:30:08 +04:00
|
|
|
|
2010-04-22 02:42:17 +04:00
|
|
|
### git submodule
|
2010-04-22 04:22:29 +04:00
|
|
|
|
2010-04-22 02:42:17 +04:00
|
|
|
$ hub submodule add wycats/bundler vendor/bundler
|
|
|
|
> git submodule add git://github.com/wycats/bundler.git vendor/bundler
|
|
|
|
|
|
|
|
$ hub submodule add -p wycats/bundler vendor/bundler
|
|
|
|
> git submodule add git@github.com:wycats/bundler.git vendor/bundler
|
|
|
|
|
2013-01-19 22:57:57 +04:00
|
|
|
$ hub submodule add -b ryppl --name pip ryppl/pip vendor/pip
|
|
|
|
> git submodule add -b ryppl --name pip git://github.com/ryppl/pip.git vendor/pip
|
2010-04-22 02:42:17 +04:00
|
|
|
|
2013-01-20 22:43:28 +04:00
|
|
|
### git ci-status
|
|
|
|
|
2013-04-26 20:21:59 +04:00
|
|
|
$ hub ci-status [commit]
|
|
|
|
> (prints CI state of commit and exits with appropriate code)
|
2013-01-20 22:43:28 +04:00
|
|
|
> One of: success (0), error (1), failure (1), pending (2), no status (3)
|
|
|
|
|
2010-04-22 02:42:17 +04:00
|
|
|
|
2009-12-08 11:29:29 +03:00
|
|
|
### git help
|
|
|
|
|
|
|
|
$ git help
|
|
|
|
> (improved git help)
|
2009-12-10 23:59:01 +03:00
|
|
|
$ git help hub
|
|
|
|
> (hub man page)
|
2009-12-08 00:21:12 +03:00
|
|
|
|
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
Configuration
|
|
|
|
-------------
|
|
|
|
|
2012-04-17 11:20:01 +04:00
|
|
|
### GitHub OAuth authentication
|
2009-12-09 04:40:45 +03:00
|
|
|
|
2012-04-17 11:20:01 +04:00
|
|
|
Hub will prompt for GitHub username & password the first time it needs to access
|
|
|
|
the API and exchange it for an OAuth token, which it saves in "~/.config/hub".
|
2009-12-09 04:40:45 +03:00
|
|
|
|
2012-05-05 02:37:53 +04:00
|
|
|
### HTTPS instead of git protocol
|
2009-12-24 21:55:07 +03:00
|
|
|
|
2011-10-25 18:55:35 +04:00
|
|
|
If you prefer using the HTTPS protocol for GitHub repositories instead of the git
|
|
|
|
protocol for read and ssh for write, you can set "hub.protocol" to "https".
|
2009-12-24 21:55:07 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
~~~ sh
|
|
|
|
# default behavior
|
|
|
|
$ git clone defunkt/repl
|
|
|
|
< git clone >
|
2009-12-24 21:55:07 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
# opt into HTTPS:
|
|
|
|
$ git config --global hub.protocol https
|
|
|
|
$ git clone defunkt/repl
|
|
|
|
< https clone >
|
|
|
|
~~~
|
2009-12-08 00:21:12 +03:00
|
|
|
|
|
|
|
|
2009-12-08 11:18:55 +03:00
|
|
|
Contributing
|
|
|
|
------------
|
|
|
|
|
2012-07-20 14:32:22 +04:00
|
|
|
These instructions assume that _you already have hub installed_ and aliased as
|
2012-03-20 18:16:31 +04:00
|
|
|
`git` (see "Aliasing").
|
2011-10-27 15:48:42 +04:00
|
|
|
|
|
|
|
1. Clone hub:
|
2012-03-20 18:16:31 +04:00
|
|
|
`git clone defunkt/hub && cd hub`
|
2012-07-20 14:32:22 +04:00
|
|
|
1. Ensure Bundler is installed:
|
|
|
|
`which bundle || gem install bundler`
|
2012-03-20 18:16:31 +04:00
|
|
|
1. Install development dependencies:
|
|
|
|
`bundle install`
|
|
|
|
2. Verify that existing tests pass:
|
|
|
|
`bundle exec rake`
|
2011-10-27 15:48:42 +04:00
|
|
|
3. Create a topic branch:
|
2012-03-20 18:16:31 +04:00
|
|
|
`git checkout -b feature`
|
|
|
|
4. **Make your changes.** (It helps a lot if you write tests first.)
|
2011-10-27 15:48:42 +04:00
|
|
|
5. Verify that tests still pass:
|
2012-03-20 18:16:31 +04:00
|
|
|
`bundle exec rake`
|
2011-10-27 15:48:42 +04:00
|
|
|
6. Fork hub on GitHub (adds a remote named "YOUR_USER"):
|
|
|
|
`git fork`
|
|
|
|
7. Push to your fork:
|
2012-03-20 18:16:31 +04:00
|
|
|
`git push -u YOUR_USER feature`
|
2011-10-27 15:48:42 +04:00
|
|
|
8. Open a pull request describing your changes:
|
|
|
|
`git pull-request`
|
|
|
|
|
2009-12-08 11:18:55 +03:00
|
|
|
|
2009-12-08 08:28:38 +03:00
|
|
|
Meta
|
|
|
|
----
|
2009-12-08 00:21:12 +03:00
|
|
|
|
2011-10-27 15:48:42 +04:00
|
|
|
* Home: <https://github.com/defunkt/hub>
|
|
|
|
* Bugs: <https://github.com/defunkt/hub/issues>
|
|
|
|
* Gem: <https://rubygems.org/gems/hub>
|
2012-03-20 18:16:31 +04:00
|
|
|
* Authors: <https://github.com/defunkt/hub/contributors>
|
|
|
|
|
|
|
|
### Prior art
|
2009-12-08 11:18:55 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
These projects also aim to either improve git or make interacting with
|
|
|
|
GitHub simpler:
|
2009-12-08 11:18:55 +03:00
|
|
|
|
2012-03-20 18:16:31 +04:00
|
|
|
* [eg](http://www.gnome.org/~newren/eg/)
|
|
|
|
* [github-gem](https://github.com/defunkt/github-gem)
|
2009-12-08 11:18:55 +03:00
|
|
|
|
|
|
|
|
2010-01-24 01:10:03 +03:00
|
|
|
[speed]: http://gist.github.com/284823
|
2011-03-22 21:26:40 +03:00
|
|
|
[gc]: https://twitter.com/brynary/status/49560668994674688
|