git clone & pull without changing directories
19 May 2008
If you’re trying to configure git commands in a directory that isn’t pwd, you’ll have to deal with clone and pull a little differently. Clone works like this:
git clone [source location] [destination location]An example clone into my application’s vendor directory:
clone git://github.com/rails/rails.git ~/rails/myapp/vendor/railsPull works like this:
git-dir=/path/to/destination/.git pullAn example pull in the already initiated local rails repository:
git-dir=~/rails/myapp/vendor/rails/.git pullUsing these approaches, you can simplify your capistrano recipes. here is an example snippet:
set :rails_source, "git://github.com/rails/rails.git"
desc "git the latest rails"
task :git_rails do
  run "mkdir -p #{shared_path}/vendor"
  result = run_and_return "ls #{shared_path}/vendor"
  if result.match(/rails/)
    run "git --git-dir=#{shared_path}/vendor/rails/.git pull"
  else
    run "git clone #{rails_source} #{shared_path}/vendor/rails"
  end
endSee man git-clone and man git-pull for more details.