-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathU-git.py
263 lines (207 loc) · 11.8 KB
/
U-git.py
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
**************************************************************************** initialization
# check current configuration
git config user.name
git config user.email
# create new configuration
git config --global user.name "user"
git config --global user.email "email"
# before try git init, check:
git status # make sure you not create a new init(repo) in an existing init(repo), no warming, but enventually will break
#initialization, use once per project
git init
# github - public vs private
# public
git clone https://github.com/guochen-code/my_second_repo.git
# private
git clone https://github.com/guochen-code/my_private_repo.git
#above command will not work, will show could not find the repo
# clone syntax with PAT: # go to developer setting in github and generate token
git clone https://<token@>github.com/guochen-code/my_private_repo.git
**************************************************************************** local -- git add and git commit
git add file_one.txt file_two.txt
git commit -m "add file_one and file_two"
git add . # all all files in the directory
# press q button to quit the log view
# unstage - staged but not committed
git reset HEAD target_file.txt
# undo commit - move committed back to staging area
git reset --soft HEAD^ --> Undo last commit and all the changes
git reset --hard HEAD^^ --> Undo last two commits
**************************************************************************** github -- git remote and git push
git remote add origin https://github.com/guochen-code/my_second_repo.git # origin is default name by convention
# not everyone is allowed to upload files to github, need a token. so above origin will not work. correct command is:
git remote add origin https://<token@>github.com/guochen-code/my_second_repo.git
git remote remove origin # remove the origin
git remote -v # check what is the remote origin
git push -u origin master # push from local to github
**************************************************************************** git fetch and git pull (==git fetch and git merge)
# git fetch makes sense when you are working with others and not ready to override your own files in your local computer
# when you are travelling, you added a new file on github.
# when you back home, you want to see this files from your local machine through your IDE like pycharm instead ot web browser
git checkout origin/master # must have this origin in place # need to run git fetch prior to this command!!!!!!!!
# so correct steps will be:
git fetch
git checkout origin/master
# after above, you now are able to see the new file created on github. BUT NOTE up to now it didnot override your local working directory, you can just see it
# to undo, switch back to where we were
git switch master. # failed in my case, we can discard this new file by running: git checkout github_file.txt and then switch back to master and then can pull
# alternatively
git pull
**************************************************************************** git branch: create/switch/delete
git branch <my_branch_name>
git switch <my_branch_new>
git branch -d <my_branch_name> # use this one, because it will alert you if this branch is not merged before deleting it
git branch -D <my_branch_name> # will be forced to delete
**************************************************************************** merge
# fast forward merge: why fast forward? master have no commits, all the commits happened in the new_branch
# multiple branch commit merge with no conflict: if starting point the same, then create a new file in new branch, create a new file in master, merge, no conflict
# multiple branch commit merger with a conflict
# first to be on master branch
git merge <my_branch_name> # if with conflict, need to solve before auto merge can be executed. use PROPER editor to solve the conflict!!!!!!!!
**************************************************************************** git diff
# check your current files vs your latest commiited files
# when you make some changes but have not committed, you go away and come back from a coffee break, you don't remember what you did.
# use: (this is in the same branch)
git diff # difference between working directory and staged
git diff --staged # difference between staged and local commit
git status -v -V # give a complete information inlcuding all above, which are changes to be committed and changes not staged
# how to use git diff for different branches?
git diff <branch_1> <branch_2>
**************************************************************************** git checkout: just go back and view the old files, not change anything
# easier way to find hash instead of use git log
git log --oneline
git checkout <hash_number>
# how to undo
git checkout master # go back to master and latest commit
**************************************************************************** undoing: git restore
# git restore filename # you change the file but not commit, use restore
# git restore --source HEAD~N filename # if you at 3rd commit, N=2 means you go back to the 1st commit
# git restore --staged filename # after execute git add filename, you want to revoke this action
**************************************************************************** undoing: git reset
# you just reset the commit, the news files still there!!!!!!!!!!
# this is useful if you accidentally committed to the wrong branch (for example, maybe you forgot to
# run git switch right after creating a new branch, accidentally committing to the original branch).
git reset <hash>
# what if you want the files to change:
git reset <hash> --hard
# application - mistakely commit on main branch, which is not supposed to be
(1) you have multiple commits 1-6
(2) you go and checkout commit 4
(3) you make some changes on code
(4) you find you did not switch to a new branch
(5) git reset to commit 4
(6) switch to the new branch
(7) add and commit in new branch
# git reset goes back and removes the commits and (changes files if its --hard)
**************************************************************************** undoing: git revert (encourage to use git revert over git reset whenever you can)
# imagine sb just created a branch off of one of the comnits we just got rid of, you can lose shared history !!!!!!
# this makes merge branches harder, definitely not impossible.
# git revert not change he project history, safe for commits that have already been published to a shared repo
# git revert creates a new commit that matches the historical state of previous commit
# git revert is a safer alternative to git reset in regards to losing work !!!!!!!!!
git revert <hash> # the code will be gone under the hash, but the commit hash still in the log!!!!!!!!!!!!!!!
# log if revert commit 2:
'''
commit-4 revert buggy commit # this is a new commit created !!!!!! so this state matches with commit-1 before buggy commit
commit-3
commit-2 buggy commit
commit-1
'''
**************************************************************************** git stash
# case context:
# when you are working on sth, on a new branch, not finished. you boss wants you to quickly switch to master branch to check sth.
# if you switch to the master, these changes will go along with you to the master, although not committed, but you can see them, not what we want
# so we want to stash these changes into a box, and reuse them later, when we back to the new branch from the master
# so in the new branch
git stash
# when you back to the new branch, you want these things back
(1) git stash pop # normal use case, they will be back
(2) git stash apply # memory fuzzy, you want them to be referred, not lose them.
**************************************************************************** github pull request and fork
(1) if you are collaborator, you are allowed to push to the github, so you can clone locally and make changes and send the pull request
(2) if you are not collaborator, you can fork the repo in your own github account, now I can push to forked repo because I own this copy.
clone locally, make some changes, push to the forked repo. and from forked repo, send pull request to the origin repo
********************************************************************************************* extra aws
# ------ initialization
mkdir my_git_folder
cd my_git_folder
git init
git remote add origin https://git-codecommit.ap-south-1-1.amazonaws.com/v1/repos/my-website
git clone https://git-codecommit.ap-south-1-1.amazonaws.com/v1/repos/my-website
git remote -v # display remote repositories
# create another remotes
git remote add dev2 <addresss>
# remove remotes
git remote rm <name>
git push -u <name> <branch> # for example: git push -u origin master
# ------ amend / reset / revert
# change most recent git commit message
git commit --amend -m "an uopdated commit message"
# change most recent git commit - for example, you need to commit A.py and B.py, but you only did commit A.py, how to fix:
git add B.py
git commit --amend -m "combine A.py and B.py in a single commit"
git reset --hard HEAD^ --> undo last commit and all the changes
git reset --hard HEAD^^ --> undo last two commits
git revert <commit id> # the difference between this and above is that it generates new commit id and keep all the old commits history while
# git reset will delete one of the old commits.
# ------ cloning & branching
git clone <repo link>
git clone <repo link> <folder nam>
git remote -v # points to clone URL
git branch <branch name>
git branch # display all branches
git checkout <branch name> # switch to branch from master
git push -u origin dev # new branch in remote repo
# merge to master
git checkout master
git merge dev
git push -u origin master
# remove branch after merge
git branch -d dev --> remove a branch
git push -d origin dev
git branch -D dev --> remove unmerged branch
# if branch is unmerged, when run: git branch -d dev, it will error out
# ------ git conflicts
# create and activate new branch
git checkout -b <new_branch_name>
# error out due to conflicts in merging. But master is still in merging mode, waiting for you to solve conflicts. you can abort this:
git merge --abort
# to solve the conflicts, open the code file, make the changes - manually
git add.
git commit -m "Fixed conflicts"
# you will notice (master|MERGING) becomes (master)
# ------ git rebase
master and new branch both on commit #0
master branch: commit # 0, commit # 1, commit #2
dev branch: commit #0, commit # 3,
# before git rebase
(master) git log --oneline
commit #2
commit #1
commit #0
(dev) git log --oneline
commit #3 (id:123)
commit #0
# after git rebase
(dev) git rebase master
(dev) git long --oneline
commit #3 (id:456, id will change)
commit #2
commit #1
commit #0
# in addition, the tree graph will be completely linear, only one line. Merge is two lines merge into one line. It's different.
# In summary, rebase is an action in git that allows you to rewrite commits from one branch onto another branch. Essentially,
# git is deleting commits from one branch and adding them onto another.
# primary reason is to main linear project history.
# warning: Never rebase commits once they've been pushed to a public repository.
# The rebase would replace the old commits with new ones and it would look like that part of your project history abruptly vanished!!!!
# ------ git stash
git stash save "stash messag"
git stash list # list the stashed changes
git stash apply <stashid> # apply but stash is still there on the stash list
git stash pop # apply the top changes to my file and also remove from stash list
git stash drop <stashid> # dropping the stash, for example: git stash drop 0
git stash clear # dropping all stashes
git checkout -- . # roll back to last commit after some changes that you don't want to reserve
# another application: you made changes on master but then realize it should be done on dev branch
# you can stash in one branch and apply those stashes in another branch