WSL 개발 환경을 위한 git 파일 별로 CR/LF 설정하기
개요
OS 별 개행 문자 차이는 svn 이나 git 같은 버전관리 시스템을 사용할 경우 여러가지 문제를 야기합니다.
다행히 git 은 Windows 와 Unix 계열의 CR/LF 차이로 인한 문제를 해결하기 위한 방법을 제공하고 있으므로 간단하게 설정 하나로 이 문제를 해결할 수 있었습니다.
최근에 Windows 에서 Linux 지원이 좋아지면서 IDE는 Windows 에서 실행하고 개발/테스트는 WSL(Windows Subsystem For Linux) 환경에서 구동하는데
이 경우 CR/LF 를 auto 설정해 놓았다면 Windows 에서 실행하는 IDE 는 개행을 CR/LF 로 설정하고 WSL 에서는 개항을 LF 로 인식하게 됩니다.
일반적인 소스 파일은 문제가 없지만 shell script 를 실행할 경우 CR 로 인해 다음과 같은 에러를 발생시킵니다.
$'\r': command not found
이 문제를 해결하려면 .gitattributes 에 파일 별로 CR/LF 여부를 설정해 주면 됩니다.
예로 Linux 에서 실행할 shell script 는 LF 만 개행으로 사용해야 하므로 다음과 같이 .sh 확장자에 대해 EOL 을 LF로 설정합니다.
.gitattributes
*.sh eol=lf
Windows 에서만 실행하는 batch file 이나 PowerShell 스크립트의 경우는 아래처럼 CR/LF 를 사용하도록 설정하면 됩니다.
.gitattributes
*.cmd eol=crlf *.bat eol=crlf *.ps1 eol=crlf