사용자 도구

사이트 도구


git:gitignore

.gitignore 문법

  • 공백 → no files
  • #로 시작하는 line → 주석
  • \를 통해 escape 할 수 있다.
  • ! → 이전 패턴에 의해 exclude 되었던 파일을 다시 include한다.
  • 상위 디렉토리가 exclude된 경우 해당 파일은 include 할 수 없다.
  • (git은 excluded files를 관리하지 않기 때문에 !가 영향을 주지 못한다.)
  • / → 디렉토리 간 구분자로 사용된다.
  • / 위치에 따른 규칙 존재
  • bar → 디렉토리 위치에 관계 없이 bar 이라는 디렉토리 하위의 파일 혹은 디렉토리를 무시
  • /bar → 현재 디렉토리 (.gitignore 위치 기준) 에 위치한 bar 하위의 파일 혹은 디렉토리를 무시
  • bar/ → bar은 디렉토리에만 매칭 (즉, bar이라는 파일에는 매칭 X)
  • bar → bar는 디렉토리거나 파일이름일 수 있다.
  • * → /를 제외한 모든 것에 매칭
  • ? → /를 제외한 한 글자에 매칭
  • → 디렉토리 사이의 전체 경로에 매칭 * e.g. /bar//foo/ 라고 하면 현재 경로에서 bar 하위의 여러 디렉토리를(infinite depth) 거쳐 발견된 foo 디렉토리에 매칭된다.
    • e.g. bar/** 라고 하면 bar 디렉토리 하위의 모든 것(infinite depth)에 매칭된다.

.gitignore 규칙

  • .gitignore에 작성된 내용은 이미 tracked되고 있는 파일에는 영향을 주지 못한다.
  • 우선순위는 아래의 순서에 따른다.
    • 1. command line을 통해 입력된 패턴
    • 2. .gitignore 파일에 작성된 패턴
      • (하위 디렉토리에 작성된 .gitignore은 상위 디렉토리에 작성된 .gitignore의 내용을 override 한다.)
    • 3. $GIT_DIR/info/exclude에 작성된 패턴
    • 4. 깃 설정 변수인 core.excludesFile에 작성된 패턴

위 우선순위 레벨 중 한 레벨 내에서는 가장 마지막에 작성된 내용이 우선순위를 갖는다.

예를 들어 아래의 경우 모든 디렉토리의 bar.txt를 추적되지 않도록 exclude 하지만 현재 디렉토리의 bar.txt은 다시 include하게 된다.

.gitignore
# exclude
bar.txt
 
# include
!/bar.txt
git/gitignore.txt · 마지막으로 수정됨: 2025/04/15 10:05 저자 127.0.0.1