|
検索
タグ
ASP.NET
.NET
ASP.NET MVC
F#
Visual Studio
ASP.NET Core
Azure
ライトニングトーク
Plone
Selenium
AJAX
C#
jQuery
JavaScript
SQL Server
ADO.NET Entity Framework
WebMatrix
LINQ
EFCore
TypeScript
カテゴリ
最新の記事
最新のコメント
記事ランキング
最新のトラックバック
以前の記事
2026年 03月 2026年 02月 2026年 01月 2025年 12月 2025年 11月 2025年 10月 2025年 09月 2025年 08月 2025年 07月 2025年 06月 2025年 05月 2025年 04月 2025年 03月 2025年 02月 2024年 12月 2024年 11月 2024年 10月 2024年 09月 2024年 08月 2024年 04月 2024年 03月 2024年 02月 2024年 01月 2023年 12月 2023年 11月 2023年 10月 2023年 09月 2023年 08月 2023年 07月 2023年 06月 2023年 05月 2023年 04月 2023年 03月 2023年 02月 2023年 01月 2022年 12月 2022年 11月 2022年 10月 2022年 09月 2022年 08月 2022年 07月 2022年 06月 2022年 05月 2022年 04月 2022年 03月 2022年 02月 2022年 01月 2021年 12月 2021年 11月 2021年 10月 2021年 09月 2021年 08月 2021年 07月 2021年 06月 2021年 05月 2021年 04月 2021年 03月 2021年 02月 2021年 01月 2020年 12月 2020年 11月 2020年 10月 2020年 09月 2020年 08月 2020年 07月 2020年 06月 2020年 05月 2020年 04月 2020年 03月 2020年 02月 2020年 01月 2019年 12月 2019年 11月 2019年 10月 2019年 09月 2019年 08月 2019年 07月 2019年 06月 2019年 05月 2019年 04月 2019年 03月 2019年 02月 2019年 01月 2018年 12月 2018年 11月 2018年 10月 2018年 09月 2018年 08月 2018年 07月 2018年 06月 2018年 05月 2018年 04月 2018年 03月 2018年 02月 2018年 01月 2017年 12月 2017年 11月 2017年 10月 2017年 09月 2017年 08月 2017年 07月 2017年 06月 2017年 05月 2017年 04月 2017年 02月 2017年 01月 2016年 12月 2016年 11月 2016年 10月 2016年 09月 2016年 08月 2016年 07月 2016年 06月 2016年 05月 2016年 04月 2016年 03月 2016年 02月 2016年 01月 2015年 12月 2015年 11月 2015年 10月 2015年 09月 2015年 08月 2015年 07月 2015年 05月 2015年 04月 2015年 03月 2015年 02月 2015年 01月 2014年 12月 2014年 11月 2014年 10月 2014年 09月 2014年 08月 2014年 06月 2014年 04月 2014年 03月 2014年 02月 2014年 01月 2013年 12月 2013年 10月 2013年 09月 2013年 08月 2013年 07月 2013年 06月 2013年 05月 2013年 04月 2013年 03月 2013年 02月 2013年 01月 2012年 12月 2012年 11月 2012年 10月 2012年 09月 2012年 08月 2012年 07月 2012年 06月 2012年 05月 2012年 04月 2012年 03月 2012年 02月 2012年 01月 2011年 12月 2011年 11月 2011年 10月 2011年 09月 2011年 08月 2011年 07月 2011年 06月 2011年 05月 2011年 04月 2011年 03月 2011年 02月 2011年 01月 2010年 12月 2010年 11月 2010年 10月 2010年 09月 2010年 08月 2010年 07月 2010年 06月 2010年 05月 2010年 04月 2010年 03月 2010年 02月 2010年 01月 2009年 12月 2009年 10月 2009年 09月 2009年 07月 2009年 06月 2009年 05月 2009年 04月 2009年 03月 2009年 02月 2009年 01月 2008年 12月 2008年 11月 2008年 10月 2008年 09月 2008年 08月 2008年 07月 2008年 06月 2008年 05月 2008年 04月 2008年 03月 2008年 02月 2008年 01月 2007年 12月 2007年 11月 2007年 04月 2007年 03月 2007年 02月 2007年 01月 2006年 11月 2006年 10月 2006年 09月 2006年 08月 2006年 07月 |
2023年 09月 17日
Windows 上で Git によるバージョン管理を使っているとあるプログラムのソースコードの受け渡しの話。 説明が面倒なのでどのような事情か詳細を省くが、どのようにソースコードを変更していったかの履歴情報込みで、そのソースコード一式をメール添付で送信する必要が発生した。Git は分散型バージョン管理システムということで、ローカルの履歴情報はすべて .git サブフォルダ以下に収録されている。なので、その .git サブフォルダごと Zip 圧縮してメールに添付すれば、目的を達成することができる。 ただ今回は、バージョン管理というよりは、コードをどのように変更していったのかその履歴から学んでもらうような学習用コンテンツだったので、rebase、reset、cherrypick、squash を駆使して、履歴を整理した。そのためこのローカルリポジトリには、ブランチからは到達不可能なコミットとそのオブジェクトが含まれていることになる。せっかくなので、そのような不要な履歴情報はすべてきれいに削除された状態で Zip して送ろうと考え、以下のように reflog の全削除と prune による到達不可能なコミットの削除、および再圧縮を実施。 git reflog expire --expire=now --expire-unreachable=now --all git gc --aggressive --prune=now その上で当該フォルダを .git サブフォルダ込みで Windows エクスプローラーで Zip して送付した。 解凍先で履歴が表示できないそのようにして作成した Zip ファイルだったのだが、これを受け取り解凍した側で、肝心の変更履歴が閲覧できない、との予期せぬ事態が発生。 git log fatal: not a git repository (or any of the parent directories): .git 上記のエラーメッセージのとおり、そもそも解凍先フォルダが Git のローカルリポジトリとして見なされていないようなのである。 原因は Zip 内に .git/refs フォルダが存在しないこと連絡を受けて、慌てて、Zip されたファイルの中身と、圧縮元のファイル・フォルダ一式とを目視で比較していったところ、Zip ファイルの中身には、.git/refs サブフォルダ以下が収録されていないことを発見。圧縮元側を確認すると、.git/refs/heads および .git/refs/tags というサブフォルダが実在しているのだが、いずれのサブフォルダも空のフォルダであった。 Zip ファイルに .git/refs サブフォルダが収録されていない以上の差異を見つけられなかったので、Zip ファイルを受け取った側に、手動で .git/refs サブフォルダを作ってもらったところ、 mkdir ./.git/refs git log --oneline 57213e4 (HEAD -> main) Initial Commit これでどうやら正しい Git ローカルリポジトリと認識されたようで、無事、履歴が表示されるようになった。 Windows のエクスプローラーによる Zip 圧縮機能の振る舞いWindows のエクスプローラーでは空フォルダは Zip に圧縮できないという仕様であるのはうっすら知ってはいた。実際、一階層の空フォルダを Windows のエクスプローラーで Zip 圧縮しようとすると、「空のフォルダは Zip 圧縮できない」というメッセージが表示される。ところが今回のように、「サブフォルダの中に、空のサブフォルダがある」状態だと、このメッセージが表示されずにさくっと Zip 圧縮処理が完了してしまうようなのだ。そのため、そもそも .git/refs サブフォルダの必要性がわかっていたとしても、気づかずにその Zip ファイルをそのまま送ってしまったかもしれない。 ちなみに、今回のケースで .git/refs サブフォルダ以下にひとつもファイルが存在しなかったのは、"git gc" コマンドによる整理による結果である。commit や checkout 等、何かしら Git の操作をしたあとであれば、.git/refs/head/main などのファイルができあがっているはずで、その場合は Zip 圧縮~解凍しても、今回のような事態にはならないはずだ。
by developer-adjust
| 2023-09-17 22:04
| その他IT系
|
ファン申請 |
||