The Ultimate Git Course - with Applications in Unreal Engine Fast-forward Merge 현재 Branch 포인터를 Merge할 Branch 포인터와 동일한 commit을 가리키도록 한다. 현재 Branch 포인터가 가리키는 commit이 Merge할 Branch 포인터가 가리키는 commit의 조상일 때 새로운 Branch를 만든 후 기존 Branch에서는 변경 사항이 없었다는 뜻이다. 3-way (Recursive) Merge 파일을 라인, 블록 단위로 비교하여 병합한다. 현재 Branch 포인터가 가리키는 commit이 Merge할 Branch 포인터가 가리키는 commit의 조상이 아닐 때 LCA (최소 공통 조상)에서 둘 다 변경 사항이 있었..
The Ultimate Git Course - with Applications in Unreal Engine Git은 데이터를 여러 개의 스냅샷으로 관리한다. commit할 때 commit 오브젝트가 생성된다. commit 오브젝트 Staging Area (Index)에 있던 변경 사항들로 구성된 스냅샷에 대한 포인터 Author, Committer, 타임스탬프 등 기타 정보 부모 commit의 포인터 Branch 포인터 현재 Branch에서 가장 마지막 commit을 가리키는 포인터 새로운 commit이 생성될 때마다 자동으로 갱신된다. 새로운 Branch를 생성하는 것은 가장 마지막 commit을 가리키는 또 다른 포인터를 만드는 것이다. 현재 어떤 Branch에 있는지는 HEAD 포인터에 의해 결정..
The Ultimate Git Course - with Applications in Unreal Engine 정규 표현식과 유사한 Glob 패턴 매칭을 사용한다. # main.exe 무시 main.exe # Logs 폴더 무시 Logs/ # 모든 .exe 파일 무시 *.exe # 모든 .o, .a 파일 무시 *.[oa]
The Ultimate Git Course - with Applications in Unreal Engine Blob 버전 관리 하에 있는 파일들 Data chunk Tree 폴더의 구조를 나타낸다. Blob과 하위 폴더에 대한 포인터를 갖고 있다. Commit Tree에 대한 포인터를 갖고 있다. Author, 타임스탬프, commit 메시지, 부모 commit에 대한 참조 등을 포함한다. Tag SHA-1 문자열 형식이다. commit을 구분하기 위한 용도로 사용된다. 파일과 폴더의 빠른 비교를 위한 Checksum 용도로도 사용된다.
The Ultimate Git Course - with Applications in Unreal Engine 1. some.file 파일을 생성 Stage 되지 않은 상태 2. git add some.file 변경 사항을 Stage (commit할 준비) Staging Area에 저장 3. git commit Staged 상태에 있는 파일들을 로컬 Repository에 적용 Staging Area에서 삭제되고 .git 폴더에 적용 4. git push 원격 메인 Repository에 commit을 적용 5. git pull 다른 사람이 원격 메인 Repository에 commit한 내용을 나의 로컬 Repository에 적용
The Ultimate Git Course - with Applications in Unreal Engine 로컬: 해당 Repository만 적용 (기본값) # 우선순위 가장 높음 git config --local 글로벌: 현재 사용자만 적용 # local 다음 우선순위 git config --global 시스템: 현재 컴퓨터(모든 사용자)에 적용 # 가장 낮은 우선순위 git config --system