Githubの導入についてはこちらを参照
(初めての)AndroidStudioからGitHubにプロジェクト作成
この記事ではチーム開発でのリポジトリの共有、クローン、コミット、プル、プッシュの仕方について解説します。
まず、Githubでプロジェクトを管理するときはリポジトリ(プロジェクトの入れ物)にこんな風に入っています。
出典:TeckAcademy 今さら聞けない!GitHubの使い方【超初心者向け】
Githubに新規のリポジトリを作成した後、
・各端末にレポジトリを複製する(クローン)
・各自のソースコードの変更をローカルレポジトリに反映させる(コミット)
・メンバーのソースコードの変更を自分のローカルレポジトリに反映させる(プル)
・自分のソースコードの変更をリモートレポジトリに反映させる(プッシュ)
という作業を行うので、それぞれ解説していきます。
####リポジトリへの招待
チーム開発を始めるには、大本の制作者がリポジトリを作成後、クローン等を行う権限をチームメンバーに渡さなければいけません。公式ヘルプページにスクショ付きの超わかりやすい解説が載っています。
GitHub ヘルプ - コラボレーターを個人リポジトリに招待する
招待を受けると、Githubのトップページ左側に該当のレポジトリが表示されるので確認してください。
####クローン
リポジトリに招待された側はそれぞれの端末にローカルリポジトリを作成し、Github上のリモートリポジトリから、データをまるっと持ってくる必要があります。
これをクローンといい、最初の一回だけ必要な作業です。(この記事の後で触れるプルが上手くいかないと何回もやるハメになります)
Githubのリポジトリを開くと右中央にClone or DownloadというボタンがあるのでクリックしてHTTPアドレスをコピーします。
※git@~~から始まるアドレスが表示される場合は枠の右上にUse HTTPSと表示されているので、そこをクリックすると直ります。
ここからは全てAndroidStudioの方で操作していきます。
新規で適当にプロジェクトを作成してください。
『The directry already exists and it is not empty』というエラーメッセージが出る時は既に作成済みのディレクトリ名が指定されてるので新規で指定します。
『Check out from version control』というウィンドウが出てくるのでYes
(持ってきたプロジェクトを開きます)
『Sync android SDKs』というウィンドウが出てくるのでOK
(リモートリポジトリのプロジェクトとローカルリポジトリのプロジェクトのパスが一致しないのでAndroidStudioの方で勝手に合わせてくれます)
これで最初にやることはおしまいです。プロジェクトを更新しながら行う手順に入っていきましょう。
####コミット
ソースコードの変更を自分のPC上のローカルリポジトリに反映させます。この時点ではリモートリポジトリのソースコードは変更されません。また、コミットした後でないとプル、プッシュができません。
メニューバー - VCS - commit を選択
commit message が空白だとエラーが出るので自分がソースコードに変更を加えた内容を明記します。
そしてcommit。出てくるウィンドウでもcommit
左下の方に緑色の枠でcommit messageが表示されたら成功です。
####プル
他のメンバーが変更したリモートリポジトリのソースコードを、自分のローカルリポジトリに持ってきます。この作業は自分のローカルリポジトリのコミットとチームのコミットと、どちらを優先させるか設定することが可能です。
メニューバー VCS - Git - pull を選択
出てくるウィンドウでもpullを選択
右下に↓のようなエラーが出たらコミットを忘れているのでコミットしてください。
リモートリポジトリとローカルリポジトリのどちらを優先するか聞かれます。
ファイルごとチームを優先させるならAccept Theirs
ファイルごと自分を優先させるならAccept Yours
コードをいい感じに混ぜるならMerge
この時、自分がコミットした状態とpullで持ってきた状態を、どちらもブランチとして持っています。
そして今は自分のコミットを記憶しているブランチに存在しているので、これからpullしてきた方に移動します。
画面下の方でVersion Controlタブ - Logタブ を開きます。
オレンジの玉が付いているブランチがリモートリポジトリにに存在している最新版なので、今回は『画像変更』のコミットに移動します。
該当のコミットを右クリックReset Current Branch to Hereを選択します。
このようなウィンドウが表示されるのでMixedを選択してReset
同じ箇所を修正してるなんて残念なことがなければ、AndroidStudioが自動的にそれぞれのコミットを反映してくれます。
左下にReset Successfulと表示されたらOKです。
が、ここで完了ではないので注意です!
pullの時にパスなども反映してしまってbuildがおかしくなってしまうので、一度AndroidStudioをリスタートします。
メニューバー file - Invalidate Caches / Restart - Just Restart を選択すると正常にビルドされます。
参考記事:[Android Studio] エラー吐き地獄に陥った時に試してほしい事
これでプルは完了です。
####プッシュ
自分のローカルリポジトリが反映済みのソースコードをリモートリポジトリに反映させます。
コミットをする時のcommit changesウィンドウでcommitのボタンのオプションを開きcommit and pushするか、もしくは
メニューバー VCS - Git - push を選択したください
出てきたウィンドウでpushを選択します。