質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

Q&A

解決済

1回答

7485閲覧

Windows版Gitでの差分抽出エラー

chieeeeno

総合スコア217

Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

0グッド

0クリップ

投稿2016/03/31 07:20

WindowsのGitで差分ファイルを抽出する際に、大量の差分ファイルがある時にエラーが発生します。
エラーの原因はgit archiveする時に Argument list too long と出ていたので、
引数に渡している値の数が多すぎるのが原因かと思いますが、
何か回避する方法は無いでしょうか?

ちなみに、下記のサイトではコマンドに「xargs」オプションを渡して回避したと書いてありましたが、
Windowsではこのオプションに対応していなかったため、無理でした。。

【参考サイト】
gitで差分のエクスポート

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

MSYSいれれば、git\bin\bash.exe上でxargsも使えるようになりますがあんまりスマートじゃないですよね。

追記

差分ファイルエクスポートだけなら、TortoiseGitで出来そうです。
ログを表示→納品したいリビジョン範囲を選択→右クリック→リビジョンを比較→ファイルを全て選択→右クリック→選択をエクスポート

また、コマンドラインで行う場合は以下のようになります。
コマンドライン上でzip圧縮できるexeが提供されてないので、代替手段として、7zipコマンドライン版(インストール不要)を使う場合の例を書いてておきます。
listfile.txtに圧縮対象のファイル名の一覧が入る形になるので、引数にファイルパスのテキストを受け付ける圧縮ソフトであればどれでもかまわないです。

DOS

1git diff --name-only --diff-filter=AMCR 5256250 76466ab > listfile.txt 27za a -tzip archive.zip @listfile.txt 3del listfile.txt

投稿2016/03/31 07:55

編集2016/04/04 23:06
umed0025

総合スコア851

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

chieeeeno

2016/04/03 18:27

返信が遅くなってすみません。 MSYSですか・・・ これが入れられたらなんとかなるとは思っていたのですが、 会社ではインストールが難しそうなので、諦めておりました。。。 もう少し他の方のご意見を伺いたいと思います。
umed0025

2016/04/04 01:31

会社PCだとインストールできるソフトウェアに制限はいるのできびしいですよね。 追加の代替案を追記しました。
chieeeeno

2016/04/04 16:02 編集

代替案を提示いただきありがとうございます! 頂いた案はまだ試せていないんですが、 batファイルで行っている処理はこういうことでしょうか? 1行目では追加・更新・リネーム・修正をしたものだけにフィルターをかけ、 「5256250」と「76466ab」の差分を出してlistfile.txtに出力。 2行目では、listfile.txtに出力したファイルをアーカイブ化を行っている。 3行目でlistfile.txtを削除。 「TortoiseGit」でも差分を出せるということでしたが、 こちらを使えば、上記のコマンドを使わずに差分が取れるのでしょうか? 普段MacでSourceTreeというソフトを使っていたため、 Windowsのクライアントソフトや、コマンドラインでGitを使うことがなかったため、 これら、ご教授いただけると幸いです。 よろしくお願いします。
umed0025

2016/04/04 23:07

バッチファイルについてはその認識であってます。 また、TortoiseGitを使った場合の操作について追記しました。
chieeeeno

2016/04/05 15:11

本日、ご提案いただいた方法を試してみました。 TottoiseGitは、以前TorroiseSVNを使用していたことがあったので、 使い方はすぐに分かりました! また、バッチファイルについてもご返答頂きありがとうございました! これで何とかWindowsでもうまく差分が扱えそうです! ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問