这是我已经确定的解决方案。它远非理想,但比我考虑过的其他选择要好。
我创建了一个 Autohotkey 脚本,它执行以下操作:
- 将存储库中检测到更改的 MS Access 文件还原为 .orig 文件
- 读取 .orig 文件(有更改的文件)
- 读取现有文件(存储库中已存在的文件)
- 将两个文件的文本转换为小写
- 比较文件的小写内容
- 如果文件仍然不同,则恢复 .orig 文件,以便将其提交到存储库
- 如果文件相同(即,它们仅在大小写不同时,.orig 文件将被删除,因为我们不关心这些更改)
对于具有我们关心的实际更改的文件,我仍然可以看到所做的案例更改。如果这会导致很多噪音,我会在允许不区分大小写比较的比较工具中打开文件(例如,kdiff)。
这不是一个完美的解决方案,但它为我消除了大约 90% 的挫败感。
这是我的脚本。请注意,该脚本包括另一个 Autohotkey 脚本 ConsoleApp.ahk,它提供了一个名为ConsoleApp_RunWait()
. 这是一个 3rd 方脚本,它不再适用于 64 位 AHK,所以我没有将它作为我的答案的一部分。任何执行命令行并将输出作为字符串返回的 AHK 函数就足够了。
; This script checks an MS Access source directory and reverts all files whose only modifications are to the
; case of the characters within the file.
#Include %A_ScriptDir%\ConsoleApp.ahk
#NoEnv ; Recommended for performance and compatibility with future AutoHotkey releases.
SendMode Input ; Recommended for new scripts due to its superior speed and reliability.
SetWorkingDir %A_ScriptDir% ; Ensures a consistent starting directory.
; Allow for custom path to hg (support for moving to TortoiseHg 2.0)
IniRead hg, %A_ScriptDir%\LocalSettings\Settings.cfg, TortoiseHg, hg_path, hg
if 0 < 1 ; The left side of a non-expression if-statement is always the name of a variable.
{
MsgBox Usage:`n`HgIgnoreCase DirectoryWithFilesToScrub
ExitApp
}
SrcDir = %1%
StringReplace SrcDir, SrcDir, ", , All
StringRight test, SrcDir, 1 ; add trailing slash if necessary
ifnotequal test, \
SrcDir = %SrcDir%\
RestoreOriginals(SrcDir)
RevertCaseChangeModifiedFiles(SrcDir)
RevertCaseChangeModifiedFiles(SrcDir) {
global hg
includes = -I "*.form" -I "*.bas" -I "*.report" -I "*.table"
cmdline = %hg% revert --all %includes%
;Don't revert items that have been removed completely
Loop 3
{
Result := ConsoleApp_RunWait(hg . " status -nrd " . includes, SrcDir)
If (Result)
Break
}
Loop parse, Result, `n, `r
{
if (A_LoopField)
cmdline = %cmdline% -X "%A_LoopField%"
}
Result =
;msgbox %cmdline%
;revert all modified forms, reports, and code modules
Loop 3
{
Result := ConsoleApp_RunWait(cmdline, SrcDir)
If (Result)
Break
}
;MsgBox %Result%
Loop parse, Result, `n, `r
{
StringLeft FileStatus, A_LoopField, 9
If (FileStatus = "reverting")
{
StringMid FName, A_LoopField, 11
FullPath = %SrcDir%%FName%
ToolTip Checking %FullPath%
RestoreIfNotEqual(FullPath, FullPath . ".orig")
}
}
ToolTip
}
RestoreIfNotEqual(FName, FNameOrig) {
FileRead File1, %FName%
FileRead File2, %FNameOrig%
StringLower File1, File1
StringLower File2, File2
;MsgBox %FName%`n%FNameOrig%
If (File1 = File2)
FileDelete %FNameOrig%
Else
FileMove %FNameOrig%, %FName%, 1
}
RestoreOriginals(SrcDir) {
Loop %SrcDir%*.orig
{
;MsgBox %A_LoopFileLongPath%`n%NewName%
NewName := SubStr(A_LoopFileLongPath, 1, -5)
FileMove %A_LoopFileLongPath%, %NewName%, 1
}
while FileExist(SrcDir . "*.orig")
Sleep 10
}