git-svn環境でいろいろやる時に、黒い画面使うよりもデザイナさんにとってはGUIで書かれたアプリを使う方が気軽に使えるんじゃないかとおもって、少しだけ探したのですが、qiitaで見つけた記事がいい感じだと思ったので実際に試してみました。
それで、よく使う作業は具体的にどう操作すればよいか調べてみました。
こちらのqiitaの記事を参考にさせて頂きました。
http://qiita.com/items/263577c8cc4e1c65b19b
#1.インストール
こちらから。
http://www.sourcetreeapp.com/
#2.ターミナルでgit svn clone
する
git svn clone -s http://hogehoge [フォルダ名]
#3.SourceTreeで開く
「ファイル→開く」で開く
#4.作業について
僕が思った3パターンを想定して書いてます。
##1.masterを変更してsvnのtrunkに反映させる場合
※個人的には、svnのtrunkの内容を取ってきてmasterに反映させて、ローカルブランチを切って、作業が終わったらmasterにmergeしてsvnのtrunkに反映するのが無難かと思います。コンフリクトとか起きるといろいろと面倒くさそうなので。。。ほんのちょっとの変更であれば大丈夫だと思いますが、、、
- svnのtrunkの最新の内容を取得する
プルをクリックする。git svn rebase
と同じ意味のはず。 - ファイルの編集
自由に編集して下さい。 - masterにコミットする
- 説明の「Uncommited changes」をクリック
- 「作業ツリーのファイル」に変更されたファイルが表示される。
- 確認し、問題がなければ「Index」にステージされたファイルに移動する。
- 変更されたファイルを全て確認したら、コミットボタンを押す。
- コミットメッセージを記入して、コミット。
- svnのtrunkに変更を反映させる
- svnの最新の内容をローカルに取り込むため、「プル」ボタンを押す
※git svn rebase
とかと同じ - コンフリクトが発生したら。。。以下の手順で解消する。
1.発生したファイルを修正
2.作業ツリーのファイル→indexにステージしたファイルへドラッグ
3.再度「プル」ボタンをクリック。リベースを処理中。。。というメッセージが出るので、「リベースを続ける」をクリック
4.もし再度コンフリクトが発生したら、1.に戻って再度コンフリクトの解消を行う。
※もしどうしてもコンフリクトを解消出来なくて、どうしようもなくなってしまったら、git rebase --abort
すればrebaseする直前に戻れます。自分はstashして退避させて、branch切ってpopしてからmasterにmergeしたら安全だと思ってます。。。 - 「プッシュ」ボタンをクリックして、trunkへ最新の内容を反映させる!!
##2.masterからローカルブランチ切って作業してmasterにマージしてtrunkに反映する場合。
※自分の場合は、出来れば毎回こうしたらいいんじゃないかなぁと思ってます。
- svnのtrunkの最新の内容を取得する
「プル」をクリックする。git svn rebase
と同じ意味のはず。 - ローカルブランチを切る。
- 「ブランチ」をクリック。
- 「新規ブランチ」にブランチ名を入れて、「ブランチを作成」をクリック。
- 「svnブランチを作成しますか?」と聞かれて、2択を迫られるので、「Gitのローカルブランチを作成」をクリックする。
※デフォルトで「新規ブランチをチェックアウト」にチェックが入っているはずなので、自動的に作成したブランチに切り替わる。 - 作業する。
- 変更内容をローカルブランチにコミット
- 説明の「Uncommited changes」をクリック
- 「作業ツリーのファイル」に変更されたファイルが表示される。
- 確認し、問題がなければ「Indexにステージされたファイル」に移動する。
- 変更されたファイルを全て確認したら、コミットボタンを押す。
- コミットメッセージを記入して、コミット。
- マスターにローカルブランチの内容をマージする。
- マスターに現在の切り替える。
サイドバーの、「master」をダブルクリック→「ブランチ切り替えの確認」が表示されるので、OKをクリック - 最新のtrunkの情報を更新する。
「プル」をクリック - 作業したローカルブランチの内容をマスターにマージする。
「マージ」をクリック - マージしたい説明の部分をクリック。
- 変更箇所が出てくるので、確認してOKをクリックする。
- 「Subversionのリポジトリへマージすることをお勧めできません」って出るけど、「続ける(推奨しません)」をクリックする。
- マージ完了!
##3.trunkからsvnのブランチ切って作業して複数人数で作業してからtrunkに反映する場合
※今までは基本的に1人で作業する事を想定して書いてましたが、複数人数で作業する場合はこれになると思います。ってか、むしろこれが普通なのか。
- 「2.masterからローカルブランチ切って作業してmasterにマージしてtrunkに反映する場合」の項目の、1〜4までは同じ。masterからローカルブランチ切って作業してコミットした後。
- 途中でsvnのブランチ切って複数人数で作業する事になった!
- trunkからsvnのブランチを作成する
- masterへブランチを切り替える。
左サイドバーのmasterをダブルクリックする。 - 「プル」をクリックして最新の情報を取得
- 「ブランチ」をクリック→新規ブランチにブランチ名を入れる→「ブランチを作成」をクリック
- 「Subversionブランチを作成しますか?」と聞かれて、「Subversionブランチを作成」をクリックする。
- svnのブランチが作成される。
- 作成したsvnのブランチと、ローカルで作業してたブランチをマージする。
- 「マージ」をクリック
- 一覧から、マージしたいローカルブランチを選択
- 「Subversionのリポジトリへマージする事をお勧め出来ません」のメッセージが出るが、無視して「続ける」をクリック
- プッシュをクリックしてマージした内容をsvnのブランチに反映させる。
- svnのブランチへ変更を反映させる。
- プッシュをクリック
- プッシュ先のリポジトリがSubversionになっている事を確認して、「ok」をクリック
- 「Subversionにプッシュしますか?」というメッセージが出るので、「OK」をクリック
- 変更がsvnのブランチに反映される。
- svnのブランチの変更内容を取得する。
「プル」をクリックして最新の内容を取得する。 - いろいろ作業する。
- 変更を、masterにマージする。
- 作業してたブランチ上でプルをクリックし、更新の取得漏れがないか確認する。
- masterブランチへ切り替え
左サイドバーのmasterをダブルクリック - 最新の更新内容を取得する為に、プルをクリックして取得する。
- 「マージ」をクリック
- マージする対象を選択する。(ジャンプ先をマージしたい作業してたブランチを選択すると間違えにくい)
※誤ってsvnのブランチの方を選択しないように注意! - 「ok」をクリック
- 「Subversion のリポジトリへマージすることをお勧めできません」と出るが「続ける(推奨しません)」をクリック
- masterにマージされる。
- 変更内容をsvnのtrunkにアップする。
- 「プッシュ」をクリック
- プッシュ先のリポジトリを確認して、trunkになっていたらOKをクリック
- 「Subversion にプッシュしますか?」と出るので、OKをクリック
#5.終わりー
SourceTreeでgit-svnを使ってて、ある程度想定されるパターンについて実際に使ってみて、書いてみたけど、長ったらしくなった上にわかりにくくなってしまった。。。
結構使いやすいツールだと思うので是非使ってみる事をオススメします!