へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
TortoiseGit
›
TortoiseGit で SubTree を使用する
2018/10/16
TortoiseGit で SubTree を使用する
update
event_note
label
Git
label
TortoiseGit
と書いておいて何ですが、現時点では TortoiseGit は SubTree に対応してませんので、コマンドで実行する必要があります。
## 対象とするモデル 以下のようなモデルを例とします。 **SubTree で他のリポジトリを取り込む側(親プロジェクト)** - SubTreeTest_Parent1 - SubTreeTest_Parent2 **SubTree で他のリポジトリに取り込まれる側(子プロジェクト)** - SubTreeTest_Child ## 親プロジェクトに子プロジェクトのリモートリポジトリを登録 ```sh git remote add
``` 今回は以下のようにしました。 ```sh git remote add child http://xxx/ ``` 尚、これは TortoiseGit でも設定可能です。 **TortoiseGit でのやり方** 右クリック > [TortoiseGit] > [設定] を選択します。 サイドメニューから [リモート] を選択し、`リモート` に任意の名前を、`URL` にリポジトリの URL を入力し、[新規に追加]を押します。
## 親プロジェクトに子プロジェクトをサブディレクトリとして追加 親プロジェクトに子プロジェクトのリモートリポジトリを登録したら、次に子プロジェクトをサブディレクトリとして追加します。 ```sh git subtree add --prefix=
--squash
``` `
` には子プロジェクトを取り込んだ際のディレクトリ名を指定します。 既存のディレクトリ名と重複しないようにします。 `
` は前述のリモートリポジトリの登録で `
` に指定したリポジトリ名です。 `
` はコミットまたはブランチ名です。 また、`--squash` オプションをつけると、親プロジェクトに取り込む際にコミットを一つにまとめてくれます。 今回は以下のようにしました。 ```sh git subtree add --prefix=SubTree_Child --squash child master ``` 親プロジェクト内に `SubTree_Child` というフォルダが作成され、その中に子プロジェクトの中身が入っているのが確認できると思います。 ここまでで SubTree による子プロジェクトの取り込みは完了です。 ## 親プロジェクト内で子プロジェクトの変更を行う 上記までの SubTree の設定が完了していれば、あとは親プロジェクト内で子プロジェクトも自由に変更できます。 コミットやプッシュも通常通りできますが、親プロジェクト内で変更した子プロジェクトの内容を、子プロジェクトのリモートリポジトリに反映させる(プッシュする)場合には、以下のコマンドを実行します。 ```sh git subtree push --prefix=
``` `
` `
` は `git subtree add` を実行したときと同じです。 `
` にはプッシュしたい子プロジェクトのブランチを指定します。 ```sh git subtree push --prefix=SubTree_Child child master ``` ## 子プロジェクトの変更を親プロジェクト内に反映する 子プロジェクトのリモートリポジトリが更新されていた場合、その変更内容を親プロジェクト内の子プロジェクトに反映させる(プルする)場合には、以下のコマンドを実行します。 ```sh git subtree pull --prefix=
--squash ``` `
` `
` `
` は `subtree push` のときと同じです。 `--squash` も `subtree add` のときと同じです。 ```sh git subtree pull --prefix=SubTree_Child child master --squash ```
## 参考 URL - http://qiita.com/takahashi-kazuki/items/0c34b3bc5da6700d38a5 - http://japan.blogs.atlassian.com/2014/03/alternatives-to-git-submodule-git-subtree/
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
TortoiseGit でコミットメッセージを変更する
image
NO IMAGE
smbclient で session setup failed: NT_STATUS_LOGON_FAILURE が表示される
Docker for Windows の設定
image
NO IMAGE
マージ元ブランチとマージ先ブランチ
image
NO IMAGE
TortoiseSVN ロック状態のチェック
image
NO IMAGE
Visual Studio で文字がにじむ(ぼやける)
TortoiseGit でブランチ間の差分を見る
image
NO IMAGE
AsciidocFX をビルドする
image
NO IMAGE
PowerShellでブレークポイントが設定できない場合
[Python] 文字列の判定で、None と空文字を同時に判定する
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
80
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
2
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
1
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(18)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
►
2023
(30)
►
12月
(3)
►
11月
(5)
►
10月
(2)
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
►
3月
(2)
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
►
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
►
9月
(10)
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
►
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
►
4月
(17)
►
3月
(9)
►
2月
(6)
►
1月
(8)
▼
2018
(100)
►
12月
(1)
►
11月
(11)
▼
10月
(8)
NLog の 例外情報内のスタックトレースの改行を無効化する
Word のフィールドの自動更新に関するオプションの挙動
[C#] 例外メッセージボックス
Word でフィールド更新しても相互参照が更新されない
Visual Studio で保存時にコードを自動整形する
TortoiseGit で SubTree を使用する
[C#] Math.Round で四捨五入
[C#] Cryptowatch API で取得した JSON をデシリアライズする
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
►
2017
(117)
►
12月
(14)
►
11月
(20)
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)