アップデート
Windows ユーザーだけが問題を抱えている理由がわかりました。
$ git ls-files | grep -i class.bat
etc/apps/phpsysinfo/plugins/BAT/class.BAT.inc.php
etc/apps/phpsysinfo/plugins/bat/class.bat.inc.php
Git インデックス ファイルには、大文字と小文字の両方のバージョンが存在します。Linux では大文字と小文字が区別され、そのまま 2 つの別個のファイルとして扱われるため、Linux ユーザーは両方のファイルをチェックアウトしていることに気付かないはずです。
ただし、Windowsはファイルパスに関して大文字と小文字を区別しないため、それらは同じファイルであると見なされ、インデックスからファイルシステムに両方をチェックアウトしようとすると、Windowsおよび/またはGitが混乱します。両方のバージョンのファイルを Windows でチェックアウトしても驚かないでしょう。
git config core.ignorecase false && \
git rm -r . && \
git reset --hard HEAD
古い大文字のファイルはリポジトリから削除する必要があります。変更をアップストリームにプルリクエストしてください。プロジェクトの所有者はきっと感謝するでしょう。
古い回答
core.ignorecase
(Windows)Gitのデフォルトをtrueに設定してこれを試しました:
$ git diff --name-only | xargs git rm -f
これにより、すべての大文字のファイルが削除されます (そして、Git インデックスでこれらの変更がステージングされます)。その後、次のコマンドを実行しましたgit status
。
$ git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# deleted: etc/apps/phpsysinfo/includes/mb/class.Coretemp.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.HDDTemp.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.HWSensors.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.Healthd.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.IPMI.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.K8Temp.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.LMSensors.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.MBM5.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.MBMon.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.Sensors.inc.php
# deleted: etc/apps/phpsysinfo/includes/ups/class.Apcupsd.inc.php
# deleted: etc/apps/phpsysinfo/includes/ups/class.Nut.inc.php
# deleted: etc/apps/phpsysinfo/plugins/BAT/class.BAT.inc.php
# deleted: etc/apps/phpsysinfo/plugins/BAT/js/BAT.js
# deleted: etc/apps/phpsysinfo/plugins/BAT/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/BAT/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/BAT/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/class.MDStatus.inc.php
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/css/MDStatus.css
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/js/MDStatus.js
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/MDStatus/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/PS/class.PS.inc.php
# deleted: etc/apps/phpsysinfo/plugins/PS/js/PS.js
# deleted: etc/apps/phpsysinfo/plugins/PS/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/PS/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/PS/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/PS/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/class.PSStatus.inc.php
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/css/PSStatus.css
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/js/PSStatus.js
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/PSStatus/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/Quotas/class.Quotas.inc.php
# deleted: etc/apps/phpsysinfo/plugins/Quotas/css/Quotas.css
# deleted: etc/apps/phpsysinfo/plugins/Quotas/js/Quotas.js
# deleted: etc/apps/phpsysinfo/plugins/Quotas/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/Quotas/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/Quotas/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/Quotas/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/SMART/class.SMART.inc.php
# deleted: etc/apps/phpsysinfo/plugins/SMART/css/SMART.css
# deleted: etc/apps/phpsysinfo/plugins/SMART/js/SMART.js
# deleted: etc/apps/phpsysinfo/plugins/SMART/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/SMART/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/SMART/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/SNMPPInfo/class.SNMPPInfo.inc.php
# deleted: etc/apps/phpsysinfo/plugins/SNMPPInfo/js/SNMPPInfo.js
# deleted: etc/apps/phpsysinfo/plugins/SNMPPInfo/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/SNMPPInfo/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/SNMPPInfo/lang/pl.xml
# deleted: etc/apps/phpsysinfo/plugins/UpdateNotifier/class.UpdateNotifier.inc.php
# deleted: etc/apps/phpsysinfo/plugins/UpdateNotifier/js/UpdateNotifier.js
# deleted: etc/apps/phpsysinfo/plugins/UpdateNotifier/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/UpdateNotifier/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/UpdateNotifier/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/UpdateNotifier/lang/pl.xml
#
# Changes not staged for commit:
# (use "git add/rm <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# deleted: etc/apps/phpsysinfo/includes/mb/class.coretemp.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.hddtemp.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.healthd.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.hwsensors.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.ipmi.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.k8temp.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.lmsensors.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.mbm5.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.mbmon.inc.php
# deleted: etc/apps/phpsysinfo/includes/mb/class.sensors.inc.php
# deleted: etc/apps/phpsysinfo/includes/ups/class.apcupsd.inc.php
# deleted: etc/apps/phpsysinfo/includes/ups/class.nut.inc.php
# deleted: etc/apps/phpsysinfo/plugins/bat/class.bat.inc.php
# deleted: etc/apps/phpsysinfo/plugins/bat/js/bat.js
# deleted: etc/apps/phpsysinfo/plugins/bat/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/bat/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/bat/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/class.mdstatus.inc.php
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/css/mdstatus.css
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/js/mdstatus.js
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/mdstatus/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/ps/class.ps.inc.php
# deleted: etc/apps/phpsysinfo/plugins/ps/js/ps.js
# deleted: etc/apps/phpsysinfo/plugins/ps/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/ps/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/ps/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/ps/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/psstatus/class.psstatus.inc.php
# deleted: etc/apps/phpsysinfo/plugins/psstatus/css/psstatus.css
# deleted: etc/apps/phpsysinfo/plugins/psstatus/js/psstatus.js
# deleted: etc/apps/phpsysinfo/plugins/psstatus/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/psstatus/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/psstatus/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/psstatus/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/quotas/class.quotas.inc.php
# deleted: etc/apps/phpsysinfo/plugins/quotas/css/quotas.css
# deleted: etc/apps/phpsysinfo/plugins/quotas/js/quotas.js
# deleted: etc/apps/phpsysinfo/plugins/quotas/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/quotas/lang/de.xml
# deleted: etc/apps/phpsysinfo/plugins/quotas/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/quotas/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/smart/class.smart.inc.php
# deleted: etc/apps/phpsysinfo/plugins/smart/css/smart.css
# deleted: etc/apps/phpsysinfo/plugins/smart/js/smart.js
# deleted: etc/apps/phpsysinfo/plugins/smart/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/smart/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/smart/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/snmppinfo/class.snmppinfo.inc.php
# deleted: etc/apps/phpsysinfo/plugins/snmppinfo/js/snmppinfo.js
# deleted: etc/apps/phpsysinfo/plugins/snmppinfo/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/snmppinfo/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/snmppinfo/lang/pl.xml
# deleted: etc/apps/phpsysinfo/plugins/updatenotifier/class.updatenotifier.inc.php
# deleted: etc/apps/phpsysinfo/plugins/updatenotifier/js/updatenotifier.js
# deleted: etc/apps/phpsysinfo/plugins/updatenotifier/lang/cz.xml
# deleted: etc/apps/phpsysinfo/plugins/updatenotifier/lang/en.xml
# deleted: etc/apps/phpsysinfo/plugins/updatenotifier/lang/fr.xml
# deleted: etc/apps/phpsysinfo/plugins/updatenotifier/lang/pl.xml
#
ご覧のとおり、大文字のファイルはコミット用にステージングされていますが、同じ名前の小文字のファイルもあることがわかりますが、まだステージングされていません。
それで、大文字のファイルの削除をコミットしました。
$ git commit -m "Delete upper-case files"
次に、ハードリセットを行いました:
$ git reset --hard head
次にステータスを実行しましたが、変更はありません:
$ git status
# On branch master
nothing to commit, working directory clean
そして、find
小文字のファイルの 1 つに対してa を実行すると、次のようになります。
$ find . -name class.bat.inc.php
./etc/apps/phpsysinfo/plugins/BAT/class.bat.inc.php
まだ作業ディレクトリにあります。ただし、これが問題を解決する正しい方法であるかどうかはわかりません。問題の性質が何であるかはまだわかりません。明らかに、これは Windows でファイルの大文字と小文字が区別されないことと関係がありますが、なぜ Windows ユーザーには問題があり、Unix ユーザーには問題がないのか、私にはよくわかりません。
ちなみに、 phpsysinfo プロジェクトがSVN リポジトリではなくGitHubにあるため、zpanelx の作成者はそれを サブモジュールにすることに関心があるかもしれません。たぶん、それは将来この種の問題を回避するのに役立ちますか?
実際、それはプロジェクト オーナーのためにできることではないでしょうか。リポジトリから全体を削除し./etc/apps/phpsysinfo
、コミットしてから、サブモジュールとして再度追加してください。オリジンにプッシュしてからプルリクエストを作成すれば、出来上がりです!