사용자 도구

사이트 도구


git

차이

문서의 선택한 두 판 사이의 차이를 보여줍니다.

차이 보기로 링크

양쪽 이전 판 이전 판
다음 판
이전 판
git [2020/07/01 14:01]
kwon37xi [Directory별 Include 설정]
git [2023/10/14 13:47] (현재)
kwon37xi
줄 2: 줄 2:
   * http://git-scm.com/   * http://git-scm.com/
   * [[git:cheatsheet|Git Cheatsheet]]   * [[git:cheatsheet|Git Cheatsheet]]
 +  * [[git:credential|git credential]]
 +  * [[https://ohmygit.org|OhMyGit]] - 게임으로 Git 배우기
 +
 +===== Ubuntu 최신 버전 install =====
 +  * [[https://itsfoss.com/install-git-ubuntu/|How to Install the Latest Git Version on Ubuntu]]
 +  * [[https://launchpad.net/~git-core/+archive/ubuntu/ppa|git-core/ppa]]
 +<code sh>
 +sudo add-apt-repository ppa:git-core/ppa
 +sudo apt update
 +sudo apt install git
 +</code>
  
 ===== Client 설정 ===== ===== Client 설정 =====
줄 15: 줄 26:
 git config --global core.filemode false git config --global core.filemode false
  
-# Mac OS X 유니코드 문제 +# Mac OS X 유니코드 문제? 아직도 발생하나? 
-git config --global core.precomposeunicode true +git config --global core.precomposeunicode true 
  
 </code> </code>
줄 45: 줄 56:
 </code> </code>
  
 +===== diff & difftool =====
 +  * ''git diff'' 명령에서 실행하는 것이 ''[diff]의 external'' 항목, ''git difftool''에서 실행하는 것이 ''[diff]의 tool'' 항목이다.
 +  * ''diff''는 기본값 그대로 두고 ''difftool''을 바꾸자. ''diff''는 pager 를 끼고 실행되는데, GUI diff 를 사용할 경우 pager가 중간에 끼어든다. "pager = " 설정으로 페이저를 없앨 수 있지만, log 등을 볼 때 페이저가 없어서 문제가 된다.
 +  * ''-t <difftool/mergetool이름>'' : diff/mergetool을 여러개 지정하고 원하는 이름의 tool 호출
  
-===== Password Cache ===== +<code sh> 
-  * HTTP(S) 프로토콜의 경우 명령행에서는 비밀번호 저장해두기가 곤란하다. 그래서 캐시를 사용한다. +git difftool -t meld 
-  * [[http://dogfeet.github.io/articles/2013/git-password-caching.html|Git Password Caching]] +git mergetool -t kdiff3
-  * Linux에서는 다음 처리로 간편하게 캐시가 끝난다.<code sh> +
-# 기본 캐시 시간 15분 +
-git config --global credential.helper cache +
- +
-# 캐시 시간 지정 +
-git config --global credential.helper 'cache --timeout=7200'+
 </code> </code>
- +===== Git Diff/Merge -> kdiff3 ===== 
-===== Password with Gnome-Keyring  ===== +  * [[https://docs.kde.org/trunk5/en/extragear-utils/kdiff3/git.html|Using KDiff3 as a Git Diff and Merging Tool]] 
-  * [[http://blog.iqandreas.com/git/storing-https-authentication-in-ubuntu-and-arch-linux/|GIT: Storing HTTPS Authentication in Ubuntu (and Arch Linux) - The Programming Blog of Andreas Renberg (IQAndreas)]]<code sh> +  * 파일 삭제 diff시에 잘 작동 안함. 
-# on Ubuntu +    * https://github.com/KDE/kdiff3/blob/master/ChangeLog :  Version 1.8.3 부터 해결됨. 
-sudo apt-get install libgnome-keyring-dev +<code> 
-sudo make --directory=/usr/share/doc/git/contrib/credential/gnome-keyring +[diff] 
-git config --global credential.helper /usr/share/doc/git/contrib/credential/gnome-keyring/git-credential-gnome-keyring+        tool = kdiff3 
 +[difftool "kdiff3"
 +        path = /usr/bin/kdiff3 
 +[difftool] 
 +        prompt = false 
 +        keepBackup = false 
 +        trustExitCode = false 
 +[merge] 
 +        tool = kdiff3 
 +[mergetool] 
 +        prompt = false 
 +        keepBackup = false 
 +        keepTemporaries = false 
 +[mergetool "kdiff3"
 +        path = /usr/bin/kdiff3
 </code> </code>
  
-===== Windows ===== +===== Git Difftool/Mergetool -> meld ===== 
-  * [[https://github.com/Microsoft/Git-Credential-Manager-for-Windows|Git credential manager for windows]] +  * http://wiredforcode.com/blog/2011/06/04/git-with-meld-diff-viewer-on-ubuntu/ : ''diff''를 바꾸는 방식 
-  * Unicode 깨짐 문제가 발생함 [[https://stackoverflow.com/questions/41139067/git-log-output-encoding-issues-on-windows-10-command-prompt|git log output encoding issues on Windows 10 command prompt - Stack Overflow]]<code sh> +  * [[https://stackoverflow.com/a/34119867/1051402|Git difftool의 기본과 meld설정에 대한 자세한 설명]] 
-# cmd +  * [[http://blog.marcinchwedczuk.pl/use-meld-as-git-merge-diff-tool|How to use Meld as git merge and diff tool]] : ''meld''를 difftool과 mergetool로 사용하는 간결한 설정.
-set LC_ALL=C.UTF-8+
  
-powershell +<code> 
-$env:LC_ALL='C.UTF-8'+------------------ M E R G E ------------------------- 
 +[merge] 
 +    tool meld
  
-# 시스템 환경변수에 넣어둘 것 +[mergetool "meld"] 
-</code>+    cmd = meld --auto-merge \"$LOCAL\" \"$BASE\" \"$REMOTE\" --output \"$MERGED\" --label \"MERGE (REMOTE BASE MY)\" 
 +    trustExitCode = false
  
-===== Git Diff -> meld ===== +[mergetool] 
-  * http://wiredforcode.com/blog/2011/06/04/git-with-meld-diff-viewer-on-ubuntu/ +    don't ask if we want to skip merge 
-  * ''git-diff-meld.sh''<code sh> +    prompt = false
-#!/bin/sh +
-meld "$2" "$5" > /dev/null 2>&+
-</code> +
-  * add to ''~/.gitconfig''<code> +
-git config --global diff.external '/path/to/git-diff-meld.sh' +
-</code>+
  
-===== Git Mergetool -> meld ====+    # don't create backup *.orig files 
-  * 전역 설정 <code sh> +    keepBackup false 
-git config --global merge.tool meld+ 
 +------------------ D I F F ------------------------- 
 +[diff] 
 +    guitool meld 
 + 
 +[difftool "meld"
 +    cmd = meld \"$LOCAL\" \"$REMOTE\" --label \"DIFF (ORIGINAL MY)\"
 </code> </code>
  
 ===== Git Diff -> vimdiff ===== ===== Git Diff -> vimdiff =====
 +  * [[vim:vimdiff|vimdiff]]
   * [[http://technotales.wordpress.com/2009/05/17/git-diff-with-vimdiff/|Git Diff with Vimdiff]]   * [[http://technotales.wordpress.com/2009/05/17/git-diff-with-vimdiff/|Git Diff with Vimdiff]]
   * ''~/.gitconfig''<code>   * ''~/.gitconfig''<code>
줄 106: 줄 132:
   * 설정의 external 무시하고 vim을 pager로<code sh>   * 설정의 external 무시하고 vim을 pager로<code sh>
 git diff --no-ext-diff -w | vim -R - git diff --no-ext-diff -w | vim -R -
 +</code>
 +  * 그냥 명령을 직접 주기<code sh>
 +git diff -y -t vimdiff
 +# -y 는 no prompt
 </code> </code>
 ===== .gitignore ===== ===== .gitignore =====
줄 131: 줄 161:
 </code> </code>
  
-===== Git hook ===== 
-  * 기본적으로는 ''projectdir/.git/hooks''에 후킹 파일을 둔다. 
-  * 2.9 부터는 ''projectdir/.githooks'' 에 후킹 스크립트를 넣는다. 
-  * 전역 Hook 파일 설정 (git 2.9+)<code sh> 
-git config --global core.hooksPath /path/to/my/centralized/hooks 
-</code> 
-  * [[https://git-scm.com/book/ko/v2/Git%EB%A7%9E%EC%B6%A4-Git-Hooks|Git Hooks]] 
  
 ===== Commit Template ===== ===== Commit Template =====
줄 230: 줄 253:
   * [[https://live.gnome.org/giggle|Giggle]] GTK+ Git 관리   * [[https://live.gnome.org/giggle|Giggle]] GTK+ Git 관리
   * [[https://live.gnome.org/Gitg|Gitg]] GTK+ 리포지토리 브라우저   * [[https://live.gnome.org/Gitg|Gitg]] GTK+ 리포지토리 브라우저
-  * [[http://jonas.nitro.dk/tig/|tig]] 콘솔 기반 리포지토리 브라우저+  * [[git:tig|tig]] 콘솔 기반 리포지토리 브라우저
   * [[https://github.com/FredrikNoren/ungit|ungit]] 웹기반 Git 인터페이스   * [[https://github.com/FredrikNoren/ungit|ungit]] 웹기반 Git 인터페이스
   * [[http://gitignore.io/|gitignore.io]] 자동으로 ''.gitignore'' 파일을 생성해준다.   * [[http://gitignore.io/|gitignore.io]] 자동으로 ''.gitignore'' 파일을 생성해준다.
줄 237: 줄 260:
   * [[http://yobi.io/|Yobi]] Git 지원 협업 프로젝트 관리 툴   * [[http://yobi.io/|Yobi]] Git 지원 협업 프로젝트 관리 툴
   * [[http://www.maketecheasier.com/6-useful-graphical-git-client-for-linux/|6 Useful Graphical Git Client for Linux]]   * [[http://www.maketecheasier.com/6-useful-graphical-git-client-for-linux/|6 Useful Graphical Git Client for Linux]]
 +  * [[https://gogs.io|gogs]] self hosted git server
  
 ===== 빈 디렉토리 (empty directory) 유지 ===== ===== 빈 디렉토리 (empty directory) 유지 =====
줄 253: 줄 277:
   * commit 한다.   * commit 한다.
  
 +===== shallow update not allowed =====
 +  * ''clone --depth=x'' 로 클론한 로컬 리포지토리에서 수정해서 push 하면 ''! [remote rejected] master -> master (shallow update not allowed)'' 오류가 발생한다.
 +  * [[https://stackoverflow.com/questions/28983842/remote-rejected-shallow-update-not-allowed-after-changing-git-remote-url|! [remote rejected] master -> master (shallow update not allowed)]]
 +
 +<code sh>
 +git fetch --unshallow origin
 +
 +# 이후에
 +git push
 +</code>
 +
 +
 +===== git blame ignore =====
 +  * [[https://www.moxio.com/blog/43/ignoring-bulk-change-commits-with-git-blame|Ignoring bulk change commits with git blame - Moxio]]
 +  * bulk 갱신, 포맷팅 변경 같은 경우 blame 에 자꾸 나오면 오히려 불편함. 특정 commit 을 blame에서 제외하기
 +  * [[https://akrabat.com/ignoring-revisions-with-git-blame/|Ignoring mass reformatting commits with git blame – Rob Allen's DevNotes]]
 +
 +===== submodules =====
 +  * git 에서 다른 리포지토리를 디렉토리로 링크할 수 있음.
 +  * https://git-scm.com/book/en/v2/Git-Tools-Submodules
 +  * submodule 이 있는 리포지토리를 올바로 clone 하려면 ''--recursive'' 옵션 필요
 +
 +<code sh>
 +git clone --recursive <repos-url>
 +</code>
  
 ===== 문제 해결 ===== ===== 문제 해결 =====
줄 283: 줄 332:
   * [[https://www.javacodegeeks.com/2019/10/git-essentials-crash-course.html|Git Essentials Crash Course | Java Code Geeks - 2019]]   * [[https://www.javacodegeeks.com/2019/10/git-essentials-crash-course.html|Git Essentials Crash Course | Java Code Geeks - 2019]]
   * [[https://github.com/mingrammer/git-tips|Git Tips]]   * [[https://github.com/mingrammer/git-tips|Git Tips]]
 +  * [[https://github.com/ingydotnet/git-subrepo|ingydotnet/git-subrepo]]
 +  * [[https://subicura.com/git/|Git / GitHub 안내서]]
git.1593579664.txt.gz · 마지막으로 수정됨: 2020/07/01 14:01 저자 kwon37xi