Git uses the command line pager, Less, to page through all of the information. The important keys for Less are:
- to scroll down by a line, use j or ↓
- to scroll up by a line, use k or ↑
- to scroll down by a page, use the spacebar or the Page Down button
- to scroll up by a page, use b or the Page Up button
- to quit, use q
$ git log --oneline
This command:
- lists one commit per line
- shows the first 7 characters of the commit's SHA
- shows the commit's message
To recap, the --stat flag is used to alter how git log displays information:
$ git log --stat
This command:
- displays the file(s) that have been modified
- displays the number of lines that have been added/removed
- displays a summary line with the total number of modified files and lines that have been added/removed
To recap, the -p flag (which is the same as the --patch flag) is used to alter how git log displays information:
$ git log -p
This command adds the following to the default output:
- displays the files that have been modified
- displays the location of the lines that have been added/removed
- displays the actual changes that have been made
to display details for a specific commit:
$ git log -p fdf5493
The git add command is used to move files from the Working Directory to the Staging Index.
$ git add <file1> <file2> … <fileN>
This command:
- takes a space-separated list of file names
- alternatively, the period . can be used in place of a list of files to tell Git to add the current directory (and all nested files)
The git commit command takes files from the Staging Index and saves them in the repository.
$ git commit
This command:
- will open the code editor that is specified in your configuration
- (check out the Git configuration step from the first lesson to configure your editor)
Inside the code editor:
- a commit message must be supplied
- lines that start with a # are comments and will not be recorded
- save the file after adding a commit message
- close the editor to make the commit
To recap, the git diff command is used to see changes that have been made but haven't been committed, yet:
$ git diff
This command displays:
- the files that have been modified
- the location of the lines that have been added/removed
- the actual changes that have been made
To recap, the .gitignore file is used to tell Git about the files that Git should not track. This file should be placed in the same directory that the .git directory is in.
Globbing lets you use special characters to match patterns/characters. In the .gitignore file, you can use the following:
- blank lines can be used for spacing
- # - marks line as a comment
- * - matches 0 or more characters
- ? - matches 1 character
- [abc] - matches a, b, or c
- ** - matches nested directories - a/**/z matches:
- a/z
- a/b/z
- a/b/c/z
To recap, the git tag command is used to add a marker on a specific commit. The tag does not move around as new commits are added.
$ git tag -a beta
This command will:
- add a tag to the most recent commit
- add a tag to a specific commit if a SHA is passed
To recap, the git branch command is used to manage branches in Git:
# to list all branches
$ git branch
# to create a new "footer-fix" branch
$ git branch footer-fix
# to delete the "footer-fix" branch
$ git branch -d footer-fix
This command is used to:
- list out local branches
- create new branches
- remove branches
shortcut to create and move to new branch:
$ git checkout -b amend-my-name
display all the history if a pseudo graphical way:
$ git log --oneline --decorate --graph --all
To recap, the git merge command is used to combine branches in Git:
$ git merge <other-branch>
There are two types of merges:
- Fast-forward merge – the branch being merged in must be ahead of the checked out branch. The checked out branch's pointer will just be moved forward to point to the same commit as the other branch.
- the regular type of merge
- two divergent branches are combined
- a merge commit is created
The editor has the following merge conflict indicators:
- <<<<<<< HEAD everything below this line (until the next indicator) shows you what's on the current branch
- ||||||| merged common ancestors everything below this line (until the next indicator) shows you what the original lines were
- ======= is the end of the original lines, everything that follows (until the next indicator) is what's on the branch that's being merged in
- >>>>>>> heading-update is the ending indicator of what's on the branch that's being merged in (in this case, the heading-update branch)
A merge conflict happens when the same line or lines have been changed on different branches that are being merged. Git will pause mid-merge telling you that there is a conflict and will tell you in what file or files the conflict occurred. To resolve the conflict in a file:
- locate and remove all lines with merge conflict indicators
- determine what to keep
- save the file(s)
- stage the file(s)
- make a commit
Be careful that a file might have merge conflicts in multiple parts of the file, so make sure you check the entire file for merge conflict indicators - a quick search for <<< should help you locate all of them.
To recap, the git revert command is used to reverse a previously made commit:
$ git revert <SHA-of-commit-to-revert>
To recap, the git reset command is used erase commits:
$ git reset <reference-to-commit>
It can be used to:
- move the HEAD and current branch pointer to the referenced commit
- erase commits with the --hard flag
- moves committed changes to the staging index with the --soft flag
- unstages committed changes --mixed flag
Typically, ancestry references are used to indicate previous commits. The ancestry references are:
- ^ – indicates the parent commit
- ~ – indicates the first parent commit
$ git remote add repo-on-GitHub https://github.com/richardkalehoff/RichardsFantasticProject.git
A remote repository is a repository that's just like the one you're using but it's just stored at a different location. To manage a remote repository, use the git remote command:
$ git remote
- It's possible to have links to multiple different remote repositories.
- A shortname is the name that's used to refer to a remote repository's location. Typically the location is a URL, but it could be a file path on the same computer.
- git remote add is used to add a connection to a new remote repository.
- git remote -v is used to see the details about a connection to a remote.
Rename a remote:
$ git remote rename mine origin
$ git remote rename source-repo upstream
You can think of the git pull command as doing two things:
- fetching remote changes (which adds the commits to the local repository and moves the tracking branch to point to them)
- merging the local branch with the tracking branch The git fetch command is just the first step. It just retrieves the commits and moves the tracking branch. It does not merge the local
branch with the tracking branch. The same information provided to git pull is passed to git fetch:
- the shorname of the remote repository
- the branch with commits to retrieve
$ git fetch origin master
A quick way that we can see how many commits each contributor has added to the repository
$ git shortlog
flags:
- -s to show just the number of commits (rather than each commit's message).
- -n to sort them numerically (rather than alphabetically by author name).
$ git shortlog -s -n
Filter By Author:
$ git log --author=aladin02dz
for author name with multiple words:
git log --author="Paul Lewis"
looking at commit:
$ git show 5966b66
filter down to just the commits that reference the word "bug":
$ git log --grep=bug
$ git log --grep bug
$ git log --grep="border radius issue in Safari"
The git rebase command is used to do a great many things.
# interactive rebase
$ git rebase -i <base>
# interactively rebase the commits to the one that's 3 before the one we're on
$ git rebase -i HEAD~3
Inside the interactive list of commits, all commits start out as pick, but you can swap that out with one of the other commands (reword, edit, squash, fixup, exec, and drop).
I recommend that you create a backup branch before rebasing, so that it's easy to return to your previous state. If you're happy with the rebase, then you can just delete the backup branch!
Before you start doing any work, make sure to look for the project's CONTRIBUTING.md file.
Next, it's a good idea to look at the GitHub issues for the project
- look at the existing issues to see if one is similar to the change you want to contribute
- if necessary create a new issue
- communicate the changes you'd like to make to the project maintainer in the issue
When you start developing, commit all of your work on a topic branch:
- do not work on the master branch
- make sure to give the topic branch clear, descriptive name
As a general best practice for writing commits:
- make frequent, smaller commits
- use clear and descriptive commit messages
- update the README file, if necessary
A pull request is a request for the source repository to pull in your commits and merge them with their project. To create a pull request, a couple of things need to happen:
- you must fork the source repository
- clone your fork down to your machine
- make some commits (ideally on a topic branch!)
- push the commits back to your fork
- create a new pull request and choose the branch that has your new commits