Git 初心者です。AndroidStudio から初めて Git 接続する方法を書いています。
前提
- Windows10 (MacでもGitのダウンロードリンクが異なるだけで問題なく行えます。また、文章中に出てくる「コマンドプロンプト」を適宜「ターミナル」に読み替えて進めてください。)
- AndroidStudio 3.5.3 (2020/01/07 最新版)を使用。
- GitHubアカウントを持っている。(以下の3つが必要になります。)
- アカウント名
- E-mail アドレス
- パスワード
- Git が Windows にインストールされていない。(されていても問題ないですが、パスの設定によって「動かない!」という人の参考にはならないかと思います。)
では、始めて行きましょう。
0. プロジェクトの作成
まず、練習のためのプロジェクトを作成します。ここでは EmptyActivity で作成します。(プロジェクト名はここでは"GitTestApp"としています。)プロジェクトの内容は今回重要でないためそのまま何もせず GitHub との連携を行っていきましょう。
1. AndroidStudio と Git の連携(1st トライ)
タブの VCS → Enable Version Control Integration(バージョンコントロールの統合を可能にする)をクリック。ちなみにこの操作は今回のような AndroidStudio とGitHubを初めて結びつけるときではなく、Project と GitHub を連携させる、つまりリモートリポジトリに置く際は毎回使用する操作です。
以下のようなウィンドウが現れるので、Gitを選択してOKをクリック。
右下に以下のような Cannot Run Git(Gitを実行できません)と出ます。
こうなる理由として、
- そもそもの Git が入っていない
- Git が PATH に設定されていない
等の可能性が考えられますが、今回は1のパターンを想定しているので、そのままウィンドウに表示されている Download(青字)をクリックしましょう。すると Git のダウンロードページに飛びます。
#2 Git をダウンロードする
Git のダウンロードページに飛ぶと以下のような画面が表示ます。(Windows なので勝手に Windows 向けのダウンロードリンクに飛ばされています。)
右の Download 2.24.1 for Windows をクリックしてダウンロードしていきます。ダウンロードした.exe ファイルを開くと以下のような画面が表示されます。
そのまま Next(次へ)。ディレクトリもデフォルトのままでOKです。
どんどん Next をクリックしていき、そのまま Finish すれば、Git のダウンロードが終了します。
一応ダウンロードできているか確認しておきましょう。この状態でコマンドプロンプトへ行きましょう。
このとき、すでにコマンドプロンプトを立ち上げていた場合は必ず再起動してください。 また、AndroidStudio も再起動しましょう。
そうしないと、たった今インストールした Git を認識してもらえません。ちなみに、再起動をしないと、コマンドプロンプトの場合、以下のように表示されてしまします。
C:\Users\GitTestApp>git
'git'は、内部コマンドまたは外部コマンド、
操作可能なプログラムまたはバッチ ファイルとして認識されていません
では、再起動が終わった状態で、コマンドプロンプト上で git と打って、以下のような感じで色々と表示されたインストール成功しています。
![68747470733a2f2f71696974612d696d6167652d73746f72652e73332e61702d6e6f727468656173742d312e616d617a6f6e6177732e636f6d2f302f3536323937382f35363162323965352d633733632d323165362d336365312d3935633961313838353732652e6a706567.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F9abffedb-2f83-3e9a-a950-19d61a9165be.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=636a08a6c62766b1ad39605648a6f151)
3. AndroidStudio と Git の連携(2nd トライ)
git のインストールが終わったら AndroidStudio を再起動しましょう。(もちろん上記で行っている場合は不要です。)
もう一度 1 のプロセス、タブの VCS → Enable Version Control Integration(バージョンコントロールの統合を可能にする)をクリック → Git を選択して OK をクリック。すると今度は成功するはずです。下の方に黒色の背景に、緑色の文字で "Successfully....(表示時間が短くてスクショ取れませんでした。。すみません。)と表示されます。
さらに、以下のようにファイル名が赤字になっているのが確認でききれば、無事バージョンコントロール下に置かれた状態になっているということです。(一度 Android Studio から Git 連携ができると、この色でコミットしていないファイル、変更があったファイル、等の区別がつくようになっています。)
![Oritinal11_1_HowToFigureOutItsSuccessfull.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F18abbdbd-da27-6348-3c46-143a5839b4f6.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=2bdf501efc8dfab55af692f79ff4e187)
では、この状態で VCS -> Import into Version Control(バージョンコントロールにインポートする)をクリックします。
4. Android Studio への GitHub アカウントの登録
まだこの AndroidStudio から一度も GitHub にアクセスしていないのでログインするようにプロンプトが出ます。AndroidStudio に対して GitHub にアクセスする際に用いるアカウントを教えてあげるイメージです。Login: の部分はアカウント名ではなく登録時に使用したメールアドレスを入力します。また、この操作は Android Studio として初回のGit Hub へのアクセスである今回のみで、今後新しいプロジェクトを作成して GitHub に上げる場合は、ここで登録した GitHub のアカウント情報を用いて AndroidStudio から直接 Git 操作をしていくことになるので、今回だけ我慢して打ちましょう。
![68747470733a2f2f71696974612d696d6167652d73746f72652e73332e61702d6e6f727468656173742d312e616d617a6f6e6177732e636f6d2f302f3536323937382f30356564373235332d623662652d656236662d393661302d6266613436323537613337312e6a706567.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F90cac833-7456-4643-b3ef-c856449ca1f8.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=5ded91f1045c577c562f0731c350aba6)
5. リポジトリの作成
上記の Log In を押すと "Share Project On GitHub(GitHubにプロジェクトを共有する)" のプロンプトが出てきます。以下の情報を入力していきましょう。また、ここではローカルリポジトリの作成と同時に GitHub 上にもリモートリポジトリも作成されます。
- Repository name: リポジトリ名です。ここで入力した名前で GitHub 上にリポジトリが作成されます。
- Private: GitHub 上でプロジェクトを非公開にするか否かのチェックです。非公開にする場合はチェックしましょう。
- Remote: 今回最初のコミットになるので、origin で OK です。
- Description: プロジェクトの説明を書く部分です。
![Original13_ShareProjectOnGitHub.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F63572986-145e-28c0-c8c8-533aa3beb652.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=b82688fdfd377777058d3ddc9e43dfd9)
5. コミット(1st トライ)
以上を入力し終えて、Share をクリックすると、GitHub にあげるファイルの選択画面が出てきます。ここではデフォルトで選択されているものをそのまま Add していきます。
![Original14_AddFilesForInitialCommit.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F1796be55-a0fc-f8ab-afb4-20ff4edc958c.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=c2d7c8708306f344d419ba143ccc297e)
すると右下のウィンドウに、Can't finish GitHub sharing process. Successfully created project 'GitTestApp' on GitHub, but initial commit failed.(GitHub の共有プロセスを終了できませんでした。プロジェクト"GitTestApp"の作成には成功しましたが、最初のコミットが失敗しました。)と出ます。
![Original15_initialCommitFail.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F1cb0b469-18e9-0aee-5259-46d49b900761.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=3d7a115f015da36969a6979458419af0)
クリックして詳細も見てみましょう。
![Original16_initialCommitFail_detail.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2Fc05d7e85-33e9-d178-f4e9-ebaa59f6b26b.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=fc6cb77e0252ef97e90eff5375790b4f)
ユーザー名とパスワードを登録してくださいと言っています。先ほど、リポジトリの作成には成功していましたね。リポジトリの作成とコミットはまた別の話だということを理解しないといけません。
リポジトリの作成はAndroid Studio に登録した GitHub アカウント情報から行うことが可能です。一方、コミットする際にその情報として変更内容・変更日時・コミットしたユーザー情報等が登録されます。この時にユーザー情報として、Git に登録されているユーザー情報が使われます。Windows にいれた Git を使ってコミットするわけです。今はただ単にパソコンにインストールしただけなので、GitHub へのアクセスする情報がない状態になっているからです。
6. Git への GitHub アカウント情報の登録
ということで、Git に GitHub のアカウント情報を教えてあげましょう。Git の本家のページも参考にしつつコマンドプロンプトに以下のコマンドを打っていきます。ここではユーザー名とメールアドレス が必要になってきます。(パスワードは必要ありません。)
$ git config --global user.name "GitHub でのユーザー名"
$ git config --global user.email GitHubに登録したメールアドレス
こうするとこで、コミットする際に登録されるユーザ情報を Git に教えてあげることができました。
7. コミット(2nd トライ)
この状態でもう一度コミットすると、、、
図だとerrorが0とwarningsが6つあるが大丈夫か?と聞いています。これはこのまま Commit で大丈夫です。すると、Console log のところに以下のように表示されて Commit が成功します。
8. プッシュ
コミット、つまりローカルで変更して、その変更を確定しただけの状態なので、まだリモートリポジトリであるGitHubの方には反映されていません。なので、それをGitHub上でも反映させるために、Push するところまでやっておきましょう。
これまでと同じく VCS → Git → Push と進みます。
すると右下にウィンドウが現れ、以下のようにpushが成功したというメッセージが表示されます。
念のため、GitHub上でも確認しておきましょう。画像だと、24秒前にUpdateされているのが確認できます。
![68747470733a2f2f71696974612d696d6167652d73746f72652e73332e61702d6e6f727468656173742d312e616d617a6f6e6177732e636f6d2f302f3536323937382f62326334393238622d663161612d633635302d336339352d3138353563363336666261392e6a706567.jpg](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F562978%2F9b12618d-e934-5cf3-8eb2-18eddd724858.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=c2f83eca5738ceb7b073ee7acd92932a)
以上です!!