Different commands and options to make your life with Git easier

Or how to write a way too long title...

man pages

man git-*command*

Example: man git-commit

--patch / -p option

To see the diff of what is read

git log -> git log -p

git show -> git show -p

In "read" commands

git stash show -> git stash show -p

git stash list -> git stash list -p

To manipulate patches instead of files

Used in git add

But also with git reset, git checkout, git stash!

In "write" commands

In "write" commands

git pull --rebase

Runs git fetch + git rebase origin/your-branch
 

instead of git fetch + git merge origin/your-branch

git pull --rebase

If branch diverged, local work will be on top of remote, with no merge commit

If branch did not diverge, same as git pull

git merge --no-ff

Forces the creation of a merge commit when merging a branch in another

By default, if the branch to merge is ahead of destination, git fast-forwards the destination to the branch to merge

git merge --no-ff

git merge --no-ff

Merge of a branch without --no-ff

git merge --no-ff

Merge of a branch with --no-ff

Stash

Stash the changes in a dirty working directory away

Stash

Works like a stack

Can be popped, cleared....

To stash away your work: git stash / git stash --patch

To retrieve the most recent stash, but leave the stash unchanged: git stash apply

To remove the most recent element of your stash stack: git stash drop

To retrieve the most recent stash without leaving it in the stack: git stash pop

To clear your stash stack: git stash clear

To create a named stash: git stash save "some message"

To list your stashes: git stash list

To remove the #th stash: git stash drop stash@{#}

to see a specific stash: git stash show stash@{#}

To clear your stash stack: git stash clear

Hooks

programs you can place in a hooks directory to trigger actions at certain points in git's execution

Hooks

Scripts located in .git/hooks

Examples:
   pre-commit
   prepare-commit-msg
   post-commit
   pre-rebase
 .....

Hooks

Must:

be executable

return 0 in case of success

return != 0 in case of error

Hooks

Can:

be written in any language you fancy

Hooks

Example of hooks:

pre-commit: Check that the code about to be commited is validated by the linter

post-commit: Take a picture of you each time you commit

Hooks

Problem: Hooks are per workspace... how to automatically have them in every workspaces?

Solution: Templates!

Hooks templates

Create a folder in your computer containing all the hooks you would like to automatically have in all your projects

Run: 

git config --global init.templatedir 'path/to/the/folder/you/created'

 

To link the template directory to Git

Hooks templates

To add the hooks in existing projects, run:

 

git init

 

in the projects

Git aliases

git config --global alias.st status 

Or edit your ~/.gitconfig

git config --global alias.ba "branch -v -a"

Patches

git format-patch from-commit to-commit

Commit can be recreated with:

 

git am *patch-files*

Generates one file per commit 

Patches

git format-patch master..HEAD

git format-patch master HEAD~5..HEAD

Example:

Patches

Useful to send a change to someone so he can apply it directly, while keeping you as commiter

More

  • git notes: to annotate your commits
  • git cherry-pick: to pick a commit and add it on top of HEAD
  • git grep: To seach in your project
  • --stat, shortstat (git diff, git show, git log...)
  • git status --porcelain
  • .....
Made with Slides.com