Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 데이터 타입
- 변수 선언
- REP
- seq
- 데이터 입출력
- R 기초
- 문자열처리
- 함수
- :
- 네이버 영화 댓글
- Data Structure
- Crawling
- 스크래핑
- vector 연산
- data frame
- 데이터 타입의 우선순위
- CSV
- length
- factor
- scraping
- R 개요
- 연습문제
- TXT
- vector 비교
- stringr
- working directory
- c()
- Names
- 정규표현식
- ROTTEN TOMATOES
Archives
- Today
- Total
study blog
Git 추가설명 본문
Git 추가설명
1. commit
commit을 통해 이력을 확정하면 hash 값이 부여되며, 이 값을 통해 동일한 커밋인지를 확인한다.
# WD 변화 X, staging area 변화 X
# 변경사항 X
$ git commit
noting to commit, working tree clean
# WD 변화 O, staging area 비어있을 때
$ touch lee.txt
$ git commit
Untracked files:
lee.txt
nothing added to commit but untracked files present
commit 메시지 작성하기
부제: vim 활용법
$ git commit # 메시지없이 commit하면
편집모드(
i
)- 문서 편집 가능
명령모드(
esc
)dd
: 해당 줄 삭제:wq
: 저장 및 종료w
: write(저장)q
: quit(종료)
:q!
: 강제 종료q
: quit!
: 강제
log 활용하기
$ git log
$ git log --oneline
$ git log -1 # 가장 최근 1개의 commit 메시지
$ git log -1 --oneline
$ git log --oneline --graph
# 옵션은 섞어서 사용 가능!
HEAD
: 현재 작업하고 있는 커밋 이력 및 브랜치에 대한 포인터a26b82b (HEAD -> master) Add lee.txt # 나는 현재 master 브랜치에 있고, # a26b82b 커밋의 상태에 있다.
예시)
$ git log --oneline 6b00165 (HEAD -> master) Add lee.txt bd6580f (feature/signout) Complete signout 97871d5 (origin/master) 집 = main.html
# 나는 master 브랜치에서 6b00165 커밋을 했고, # feature/signout 브랜치는 bd6580f 이력이고, # 원격저장소 (origin/master)는 97871d5 이력이다.
직전 커밋 메시지 수정
아래의 명령어는 커밋 이력을 변경하기 때문에 조심해야 한다. 공개된 저장소에(원격 저장소) 이미 push 된 이력이라면 절대 해서는 안된다.
$ git commit --amend
# 하고나서 commit 이름 수정 후 git log --oneline -1하면 변해있음
커밋시 특정 파일을 빠뜨렸을 때
만약, staging area에 특정 파일(omit_file.txt
)을 올리지 않아서 커밋이 되지 않았을 때!
$ git add omit_file.txt # 상황을 다시 만들고
$ git commit --amend # 사진을 다시 찍는다.(이름을 바꾼다)
# commit 메시지 작성 후 사진찍기 전으로 돌아가서 저장 순간 사진이 찍힌다고 생각하면 됨
2. staging area
커밋 이력이 있는 파일 수정한 경우
$ git status On branch master # 마스터 브랜치에 있다. Changes not staged for commit: # staged가 아닌 변경사항들 # staged로 바꾸려면 (use "git add <file>..." to update what will be committed) # WD에 있는 변화를 버리려면 # (커밋 이후에 변경된 사항을 모두 없애버림) (use "git restore <file>..." to discard changes in working directory) modified: 2.txt # staging area가 비어있습니다. # (커밋에 추가될 변화가 없다.) no changes added to commit (use "git add" and/or "git commit -a") # git commit -a : add+commit같이 하는 것. 뒤에 메시지 쓰면 됨 # git commit -am 'h1'
$ git add 2.txt $ git status On branch master # 커밋이 될 변화 # (커밋 명령어 했을 때, 아래의 내용이 이력에 남는다.) Changes to be committed: # unstage하기 위해서 (add의 반대작업) (use "git restore --staged <file>..." to unstage) modified: 2.txt
커밋 이력이 없는 파일인 경우
$ git status On branch master # tracking 되고 있지 않는 파일 -> commit(이력)에 한 번도 관련된 적 없다. Untracked files: (use "git add <file>..." to include in what will be committed) c.txt # 커밋할 것도 없고(staging area가 비어있고), # 트래킹 되고 있지 않는 파일도 있다. nothing added to commit but untracked files present (use "git add" to track)
add 취소하기
$ git restore --staged <file>
구버전 git에서는 아래의 명령어를 사용해서 한다.
$ git reset HEAD <file>
Working directory 변화 삭제하기
git에서는 모든 commit된 내용은 되돌릴 수 있다.
다만, 아래의 working directory(WD)내용을 삭제하는 것은 되돌릴 수 없다.
(커밋되지 않았기 때문에)
$ git restore <file>
구버전 git에서는 아래의 명령어를 사용해야 한다.
$ git checkout -- <file>
Stash
Stash는 변경사항을 임시로 저장해두는 공간이다.
1. feature branch에서 a.txt를 변경 후 커밋
2. master branch에서 a.txt를 수정 (add/commit X)
3. merge
$ git merge test
# 현재 merge 명령어로 인해 덮어쓰여질 수 있다.
error: Your local changes to the following files would be overwritten by merge:
a.txt
# commit을 하거나 -> 이력 확정을 해서 merge시 충돌 나는 상황으로
# stash 해라 -> Working directory를 잠시 비워놓음
Please commit your changes or stash them before you merge.
Aborting
Updating 1c44158..3f1625b
명령어
$ git stash # stash 공간에 저장
Saved working directory and index state WIP on master: 1c44158 a.txt
$ git stash list # stash 공간 내용 확인
stash@{0}: WIP on master: 1c44158 a.txt
$ git stash pop # stash 공간에서 적용(apply)하고 목록에서 삭제(drop)하기 (다시 가져오기)
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: a.txt
no changes added to commit (use "git add" and/or "git commit -a")
Dropped refs/stash@{0} (a590515c9e6a7cc8021d02b56f06d89532043280)
예시상황 해결
$ git stash
$ git merge test
$ git stash pop
# 충돌 해결 후 작업 이어나가기
<<<<<<< Updated upstream
첫 번째 내용
git checkout -b test : test branch 생성 - test 브랜치 내용
=======
a.txt를 브랜치에서 수정 후 commit
master branch에서 수정 중
>>>>>>> Stashed changes
reset vs revert
commit 이력을 되돌리는 작업을 한다.
reset
: 이력을 삭제한다.--mixed
: 기본 옵션. 해당 커밋 이후 변경사항 staging area에 보관--hard
: 해당 커밋 이후 변경사항 모두 삭제. 주의--soft
: 해당 커밋 이후 변경사항 및 working directory 내용까지 모두 보관
$ git log --oneline 5f53027 (HEAD -> master) t 3f1625b (test) a.txt test 1c44158 a.txt
revert
: 되돌렸다는 이력을 남긴다.$ git log --oneline 4820e15 (HEAD -> master) b.txt 5945c23 Revert "a.txt test" 5f53027 t 3f1625b (test) a.txt test 1c44158 a.txt
'Git' 카테고리의 다른 글
Git branch (0) | 2020.01.28 |
---|
Comments