data:image/s3,"s3://crabby-images/838cc/838cc2aa6b82198c74f6751d0706727d4efa224b" alt="RStudio-Git-GitHub-logo"
RStudioとGitHubを連携させて使えるようになるまでの道のり。
- RとRStudioのインストール
- Gitのインストール
- RStudioの情報をGitへ伝える(Configuration)
- RStudioでローカルリポジトリの作成とGitの「Initial commit」
- GitHubのアカウント作成
- SSH鍵の設定と認証(※optional)
- GitHubでリポジトリを作成
- GitHubのリポジトリをRStudioに「Clone」
- RStudioで作成したスクリプトを「Commit」→「GitHubにPush」
- GitHubのリポジトリからRStudioにPull
- GitHubのブランチ(Branch)を作って作業する
- GitHub Copilot と ChatGPT を取り込む(※ optional)
前回までに、RStudioとGit/GitHubとの連携が終了し、RStudioとGitHub間のコードのやり取り(Pull/Push)を行いました。
もう一人用のアーカイブとしてはこれで十分だと思いますが、一応、ブランチの作成までさらっと記録に残しておきます。
ブランチ(Branch)を作る必要性のある場面
ブランチが威力を発揮するのは、主に複数人で一つのプロジェクトを共同作業している場合。
一つのコードを複数で共有して、それぞれでコードを修正し、メインのブランチでまとめる(Merge)というイメージ。
今回は、GitHubからとRStudioから、それぞれBranchを作る方法と、Merge、Pullするところあたりをさらっと。
GitHubでブランチを作る場合
「New branch」から作る場合
例えば、"test2"というプロジェクトがある。Branchのところを確認すると、
data:image/s3,"s3://crabby-images/1d600/1d600836047cba25a6995eacff7d3e680628ef61" alt="branch-1"
デフォルトの「main」のみ。
右上の「New branch」のボタンを押すと、新しいブランチが作られる。
data:image/s3,"s3://crabby-images/f693a/f693adffdb1c097a672e916e05e3dc4c828de951" alt="branch-2"
名前(今回は"branch-1")を入れて、「Create new branch」をクリック。
data:image/s3,"s3://crabby-images/eb6d4/eb6d44de277a95eb56691da2c48f9f4a3fdfc075" alt="branch-3"
「main」の他に「branch-1」というブランチができた。
data:image/s3,"s3://crabby-images/04193/04193063acb357c31699e52724cbd79ba3416e91" alt="branch-4"
コードを先に編集した後にブランチを作る場合
前回、GitHub上でコードを編集した後、「main」ブランチで直接修正するか、新たにブランチを作るか問われた。
ここで、「Create a new branch for this commit and start pull request」を選択して「Propose changes」を押すと、
data:image/s3,"s3://crabby-images/e96cf/e96cf6b43bd0c90f9c83da68ea84a75e944326af" alt="pull-8"
新しいブランチ名でPull request画面が現れる。
説明を記載して「Create pull request」。
data:image/s3,"s3://crabby-images/47c18/47c184b4a65e728cba00f91e59700637d985d1d8" alt="pull-9"
"main"ブランチの「Pull request」とコンフリクトが生じる場合は、その部分を調整してPull requestを「Merge」する。
data:image/s3,"s3://crabby-images/d74bb/d74bb5c53c8341c70b62a6571515157e6013c87c" alt="pull-10"
RStudioからブランチを作る場合
RStudioからもブランチを作ることができる。
Gitタブにある「New Branch」のボタンをクリックして、
data:image/s3,"s3://crabby-images/170fd/170fdd1ea98d2132a665f069f46bdf26fe65bf0a" alt="branch-5"
ブランチ名を記載。必要があれば「Add remote」でリモート名もつける。
data:image/s3,"s3://crabby-images/75c2c/75c2cf3a5d49096b8043e687ad0743332a640602" alt="branch-8"
ブランチからPushしてみる
適当にコードを書いて、保存。
data:image/s3,"s3://crabby-images/6a62d/6a62d9743ca7339589ad20a1489d20c846fa74cb" alt="branch-9"
Gitのタブにパスが現れるので、「□Staged」に☑を入れて「Commit」。
data:image/s3,"s3://crabby-images/a0285/a0285a5e617eb0f3161b9eeaf2f13b00f2c2b306" alt="branch-10"
Commentを入力して、「Commit」。
「Push」でGitHubに送信。
data:image/s3,"s3://crabby-images/e1d1e/e1d1ee7c536c0a34de2e7600a428bade0c590598" alt="branch-11"
GitHubを開くと、新たに「branch-2」から「Compare & pull request」が届いていた。
data:image/s3,"s3://crabby-images/f35cc/f35ccce32e85e25e0a10e08f7f2544a0495ab69e" alt="branch-12"
コードを「Merge」
特に他で作成したコードとコンフリクトがなければ、そのまま「Merge」して「Pull request」。
data:image/s3,"s3://crabby-images/d4f35/d4f35a7fdc0c2301f1113fae62cd4077d9c8a3b8" alt="branch-13"
data:image/s3,"s3://crabby-images/0c9d8/0c9d8317ca640f7915c6d75e35347baf75ca13bf" alt="branch-14"
data:image/s3,"s3://crabby-images/3d935/3d935c1b13b89a971bcd8722ef8b32e7f482eab2" alt="branch-15"
Merge成功。
data:image/s3,"s3://crabby-images/6109b/6109b0aa5f97b0add09d07ff4c92ad28ff1ad09f" alt="branch-16"
※ コンフリクトが生じる場合は、調整して「Merge」。