User Tools

Site Tools


git_notes

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
Last revisionBoth sides next revision
git_notes [2021/03/17 13:35] – [pull related] rajugit_notes [2023/03/28 15:18] – [amend last commits] raju
Line 1: Line 1:
 +===== workflow =====
 +==== Updating feature branch with the latest development branch ====
 +tags | bring feature branch up to date with development branch
 +
 +Situation 1:
 +  * User 1 raised a merge request to merge feature1 to development branch
 +  * Before the merge request is accepted, development branch is updated by User 2
 +
 +Situation 2:
 +  * Say you forked from development branch a while ago to work on a feature and created a branch called "feature1".
 +  * After a while, development branch might have progressed and may have new changes added to it.
 +
 +Task:
 +  * Bring the feature1 branch up to date with the latest development branch.
 +
 +Solution:
 +
 +Get the latest versions of development and feature branches in the local repository.
 +<code>
 +git checkout development
 +git pull
 +git checkout feature1
 +git pull
 +</code> 
 +
 +Merge development branch into the feature branch and resolve any conflicts that may arise.
 +<code>
 +git merge development
 +</code> 
 +Push the changes to the remote.
 +<code>
 +git push
 +</code> 
 +
 +Note:- The "git merge development" command works even if you have local changes not committed to feature1.
 +
 +===== Tasks =====
 +==== Initializing git for version control ====
 +<code>
 +git config --global user.name "Kamaraju S. Kusumanchi"
 +git config --global user.email "kamaraju@gmail.com"
 +git config --global push.default matching
 +git config --global alias.co checkout
 +git init
 +</code>
 +
 +Ref:- https://codemy.com/git
 +
 ===== dummy ===== ===== dummy =====
 +==== git resources ====
 +  * https://learngitbranching.js.org/ - Very good resource to learn git branching.
 +
 ==== stackoverflow answers I came across ==== ==== stackoverflow answers I came across ====
   * ignore all directories with a specific name - https://stackoverflow.com/questions/1470572/ignoring-any-bin-directory-on-a-git-project   * ignore all directories with a specific name - https://stackoverflow.com/questions/1470572/ignoring-any-bin-directory-on-a-git-project
Line 24: Line 75:
 git grep -i --all-match -e '\^.*\^' -e '|.*|' git grep -i --all-match -e '\^.*\^' -e '|.*|'
 </code> </code>
 +
 +===== Commits related =====
 +==== amend last commit =====
 +
 +<code>
 +export EDITOR=vim
 +git commit --amend --author="Kamaraju S. Kusumanchi <kamaraju@gmail.com>"
 +git config user.email "kamaraju@gmail.com"
 +
 +git config --get-all --show-scope user.email
 +git config --get-all --show-origin user.email
 +</code>
 +
 +===== Configuration related =====
 +==== configuration files ====
 +  * https://git-scm.com/docs/git-config#FILES - talks about which files 'git config' reads from. High information density. Easy to understand.
  
 ===== git commands usage ===== ===== git commands usage =====
git_notes.txt · Last modified: 2023/05/05 14:55 by admin