Windows - 대소문자 구분이 가능한 파일 시스템
일례로, WSL 환경에서 대소문자 구분이 있는 파일을 윈도우로 복사하면,
$ pwd
/tmp/testdir
$ echo test > test.txt
$ echo Test > Test.txt
$ cp -r . /mnt/c/temp/testdir
cp: cannot create regular file '/mnt/c/temp/testdir/Test.txt': File exists
첫 번째 test.txt 파일은 복사가 되지만, 두 번째 Test.txt 파일은 복사가 되지 않습니다. 잘 아시는 것처럼, 윈도우의 파일 시스템은 대소문자를 구분하지 않기 때문입니다.
이게 딱히 그동안 문제가 되지는 않았는데, 위에서 설명한 사례처럼 WSL과의 연동이 되다 보니 문제로 부각된 것 같습니다. 그리고, 이런 문제로 인해 윈도우도 디렉터리에 대소문자를 구분할 수 있는 설정을 지원하게 되었습니다.
// Windows 10, build 17107 이후부터 지원
Adjust case sensitivity
; https://learn.microsoft.com/en-us/windows/wsl/case-sensitivity
The Windows file system supports setting case sensitivity with attribute flags per directory.
그래서 다음과 같은 명령어로 특정 디렉터리에 한해 대소문자 구분을 가능하게 합니다.
fsutil.exe file setCaseSensitiveInfo <path>
결국 위에서 문제가 됐던 상황이라면 이렇게 해결할 수 있습니다.
// 현재는 대소문자 구분이 안 되지만,
c:\temp> fsutil.exe file queryCaseSensitiveInfo c:\temp\testdir
Case sensitive attribute on directory c:\temp\testdir is disabled.
// 대소문자 구분하도록 설정 (변경은 관리자 권한만 가능)
c:\temp> fsutil.exe file setCaseSensitiveInfo c:\temp\testdir
Case sensitive attribute on directory c:\temp\testdir is enabled.
// 다시 대소문자 구분 없음으로 변경하려면 disable 옵션만 추가
c:\temp> fsutil.exe file setCaseSensitiveInfo c:\temp\testdir disable
이후 다시 복사를 해보면,
$ cp -r . /mnt/c/temp/testdir
test.txt와 Test.txt 파일이 모두 복사됩니다.
c:\temp\testdir> dir /b
Test.txt
test.txt
c:\temp\testdir> type Test.txt
Test
c:\temp\testdir> type test.txt
test
이렇게 대소문자 구분이 되는 경우, 당연히 프로그램 측에서도 대소문자를 잘 구분해야 합니다. 가령, C#에서 위의 파일을 접근하는 경우,
internal class Program
{
static void Main(string[] args)
{
Console.WriteLine(File.ReadAllText(@"C:\temp\testdir\Test.txt")); // OK
Console.WriteLine(File.ReadAllText(@"C:\temp\testdir\test.txt")); // OK
Console.WriteLine(File.ReadAllText(@"C:\temp\testdir\tEst.txt")); // Unhandled exception. System.IO.FileNotFoundException: Could not find file 'C:\temp\testdir\tEst.txt'.
}
}
해당 디렉터리에 대해 정확히 대소문자를 지정해야만 파일이 열리므로 주의해야 합니다.
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]