reset
29 :login:Penguin[sage]:2008/02/10(日) 03:36:35 id:HUyz7WXT
git で、svn revert に相当するコマンドは何でしょうか。
git revert filename とすると、fatal: can't find hoge.c と言われます。
30 :login:Penguin[sage]:2008/02/10(日) 03:38:43 id:HUyz7WXT
>>29
書いたとたん、git reset というのを見つけてしまったorz
31 :login:Penguin[sage]:2008/02/10(日) 14:09:33 id:irmoOUSW
>>30
gitはreset、rebase、cherry-pickを使い始めると、かなり良い感じになってくると思うヨ
らしいっす。最後にコミットしたときの状態に戻すには、resetを使えばOK。
git reset --hard HEAD
gitをインストール
仕事ではSubversionを使っているケースがほとんどだけど、ローカルなリポジトリが欲しいときがどんどん増えてきたので、はやりのgitを使うことにしました。
続きを読むはじめてのgit
とりあえず、なにかコミットしてみようと思って http://www8.atwiki.jp/git_jp/pub/Documentation.ja/tutorial.html を参考にやってみます。
まずは、チュートリアルにある通り、ユーザー名とメールアドレスを設定。
$ git config --global user.name akimatter $ git config --global user.email "[email protected]"
んで、既存のコードのあるデリレクトリに移動して
$ git init Initialized empty Git repository in .git/
次は
$ git add .
んで、とりあえずコミットしようと思って
$ git commit
したら、エディタが立ち上がって、コメントを入れるように促されるけど、対象になっているファイルには .rb~とかのバックアップも含まれてるじゃん!エディタを抜けて、こいつらをコミット対象から外さねば。svnみたいにignoreの設定ってどうやるんだろう?って検索したらこちらが見つかりました。
http://ogijun.g.hatena.ne.jp/secondlife/20080306/1204774860
なるほど。で、なにがリポジトリに追加されようとしているのかを確認するのはどうやるんだ?って思ったときに、bash_completionを入れてたのを思い出し、
$ git[tab]
とやったら、こんだけ出てきた。
$ git Display all 140 possibilities? (y or n) git git-cvsserver git-init git-pack-redundant git-sh-setup git-add git-daemon git-init-db git-pack-refs git-shell git-add--interactive git-describe git-instaweb git-parse-remote git-shortlog git-am git-diff git-log git-patch-id git-show git-annotate git-diff-files git-lost-found git-peek-remote git-show-branch git-apply git-diff-index git-ls-files git-prune git-show-index git-archimport git-diff-tree git-ls-remote git-prune-packed git-show-ref git-archive git-fast-export git-ls-tree git-pull git-stash git-bisect git-fast-import git-mailinfo git-push git-status git-blame git-fetch git-mailsplit git-quiltimport git-stripspace git-branch git-fetch--tool git-merge git-read-tree git-submodule git-bundle git-fetch-pack git-merge-base git-rebase git-svn git-cat-file git-filter-branch git-merge-file git-rebase--interactive git-symbolic-ref git-check-attr git-fmt-merge-msg git-merge-index git-receive-pack git-tag git-check-ref-format git-for-each-ref git-merge-octopus git-reflog git-tar-tree git-checkout git-format-patch git-merge-one-file git-relink git-unpack-file git-checkout-index git-fsck git-merge-ours git-remote git-unpack-objects git-cherry git-fsck-objects git-merge-recursive git-repack git-update-index git-cherry-pick git-gc git-merge-resolve git-repo-config git-update-ref git-citool git-get-tar-commit-id git-merge-stupid git-request-pull git-update-server-info git-clean git-grep git-merge-subtree git-rerere git-upload-archive git-clone git-gui git-merge-tree git-reset git-upload-pack git-commit git-hash-object git-mergetool git-rev-list git-var git-commit-tree git-help--browse git-mktag git-rev-parse git-verify-pack git-config git-http-fetch git-mktree git-revert git-verify-tag git-count-objects git-http-push git-mv git-rm git-whatchanged git-cvsexportcommit git-imap-send git-name-rev git-send-email git-write-tree git-cvsimport git-index-pack git-pack-objects git-send-pack gitk
でもちょっと待て。git addとかハイフン入ってないよね?というわけで今度はスペースを入れてやってみた。
$ git [tab] add checkout-index diff imap-send mv revert tag am cherry fast-export init name-rev rm var annotate cherry-pick fetch instaweb pull send-email verify-pack apply citool filter-branch log push shortlog whatchanged archive clean format-patch lost-found rebase show bisect clone fsck ls-files relink show-branch blame commit gc ls-remote remote show-ref branch config get-tar-commit-id ls-tree repack stash bundle count-objects grep merge request-pull status checkout describe gui mergetool reset submodule
とりあえず、lsだよね、っていうわけで
$ git ls-files
やっぱり~付きも入ってるねー。revertできないかなー?ってやってみたけど、コミットされてないからか、fatal: Cannot find ファイル名って怒られた。
$ git revert usage: git-revert [options] <commit-ish> -n, --no-commit don't automatically commit -e, --edit edit the commit message -x append commit name when cherry-picking -r no-op (backward compatibility) -m, --mainline <n> parent number
じゃあ、rmかな?と思って、rmの使い方を見てみる。
$ git rm usage: git-rm [options] [--] <file>... -n, --dry-run dry run -q, --quiet be quiet --cached only remove from the index -f override the up-to-date check -r allow recursive removal --ignore-unmatch exit with a zero status even if nothing matched
実ファイルを消す必要はないので、--cachedを付ければいいのかな?
$ git-rm --cached *.*~
で、git ls-filesしてみたらちゃんとコミット対象から消えてました。
という訳でめでたく最初のgitのコミットをしてみる。
git commit
エディタが起動するのでコメントを入力してエディタを抜けると、めでたくコミットされたメッセージが表示されました。よかったよかった。
って、ぜんぜんチュートリアルよんでないじゃん!
gitとsvnの連携
gitをsvnと連携するには既存のsvnのワーキングデリレクトリで、git initするだけじゃダメで、ちゃんと空のディレクトリから作らないとだめらしい。
http://www.flavio.castelli.name/howto_use_git_with_svn を参考にやってみる。
まずは空のディレクトリを作成して、そのディレクトリで
$ git-svn init http://xxxxx.com/to/svn/repogitory/
を実行。*1
つぎは、git-svn fetch -rREVISIONって書いてあるけど、リビジョン番号調べるのなんて面倒なので、HEADを指定。
git-svn fetch -rHEAD
これでsvnのリポジトリからがっつりファイルを取得してくれます。
svn updateに当たるのが、git-svn rebaseで、svn commit に当たるのは、git-svn dcommitらしいっす。この辺はぼちぼちやっていきましょう。
*1:20080510 initが抜けていたので、訂正