S eda1a14b50ee24bcab19b62f40858e76 git-svn

git-svn

gitからsvnにコミットしたりアップデートしたりできる。逆はできない。

これを覚えればなんとかなる

$ sudo port install git-core +svn

# svn checkout のようなもの
$ git svn clone -s http://server:port/repo/project 

# svn commit のようなもの
$ git svn dcommit

# svn up のようなもの
$ git svn rebase
http://d.hatena.ne.jp/idesaku/20090323/123...

git svn rebase は git pull とは全然違うようだ。
rebaseするとsvnと同期してなかった部分のコミットIDが書き換わるのに注意

Gitでpatchを作成して適用する手順のメモ

git-svn dcommit できなかったのでコミットID見たら、違うIDになってた...。というわけでpatchを作成。
http://blog.s21g.com/articles/680

dcommit

ローカルに未コミットの変更があるけどgit-svn-dcommitしたい
・> stashを使う
http://runeleaf.wordpress.com/2009/01/08/g...


その他 Subversionからの移行について

svn:externalsのようなこと

svn:externalsの代わりgit submodule。でもイコールではないっぽい。
git submoduleは今のところそこまで面倒と感じたことはない。

移行スクリプト。でもうまくいかなかった…
http://github.com/garbas/garbasgit.svnexte...
(via http://d.hatena.ne.jp/Sixeight/20090210/12... )

空のディレクトリはバージョン管理できない

.gitignoreとか何でもいいから空ファイルを作成すればOK。

部分的なチェックアウトできない

svn checkout はパスを指定すればどの階層でもワーキングコピーを作成できる。
git clone すると今までの履歴含め、全てをコピーしなければならない。

なのでプロジェクト/モジュールごとにリポジトリを作成するのがベストだろう。

あと、ディレクトリ同士のマージができない。これはちょっと何とかしたい。

複数のモジュールを含むSubversionリポジトリをGitへ移行する
http://iteman.jp/blog/2009/02/subversiongi...

trunk, branches, tags

Subversionはディレクトリ構造として表現
Gitはbranchesとtagsが別のシステムになっている。

もしかして

    他の人の「git-svn」

    S eda1a14b50ee24bcab19b62f40858e76

    無所属ソフトウェアエンジニア

    (1722words)

    最新

      最新エントリ

        関連ツイート