Disclaimer: This is not exhaustive, only for hitchhiking
- Download git
sudo get-apt install git
- Setup Git Proxy (if required)
git config --global http.proxy http://proxyuser:proxypwd@proxy.server.com:8080
- Set your Git username for every repository on your computer
git config --global user.name "Your name"
- Set your Git email for every repository on your computer
git config --global user.email "github-account@gmail.com"
If you want to get a copy of an existing Git repository — for example, a project you’d like to contribute to.
- Open a terminal and go to folder where you want to download the repo
cd /path/to/folder
- Go to the repo on GitHub and get the URL 'Clone or Download > Clone with HTTPS' Copy the URL (It will be something like https://github.com/path/to/repo')
- Clone a repo from GitHub using the URL
git clone https://github.com/path/to/repo
This creates a new subdirectory which has the repo
If you have a project directory that is currently not under version control and you want to start controlling it with Git
- Open a terminal and go to folder
cd /path/to/folder
- Initialize a git repo locally
git init
This creates a new subdirectory named .git that contains all of your necessary repository files. - Go to the repo on GitHub and get the URL. (Create a new repo, if you haven't done it) 'Clone or Download > Clone with HTTPS' Copy the URL (It will be something like https://github.com/path/to/repo')
- Setup remote which is where your local repo will be pushed and fetched
git remote add origin https://github.com/path/to/repo
. To update the url fororigin
usegit remote set-url origin
instead. - Check the remote
git remote -v
To discard all local changes. git reset --hard origin/master
.
OR
- After making changes, Add the files in your local repository. This stages them for the commit.
git add .
This adds all files to be tracked - Now commit the files on the staging area. As a convention, commit after making meaniful changes (like fixed bug, added feature), even if it is a one code line change
git commit -m "Initial Commit"
- Push all changes
git push origin master
- Pull latest
git pull origin master
Used to ignore log files, build files .pyc
, .o
etc
- At the root of your repo make
.gitignore
file and add a list of the file to be ignored. - Some Git ignore patterns https://www.atlassian.com/git/tutorials/saving-changes/gitignore
Making an existing repo as your starting point
- For the repo on GitHub and clone the foked version repo
- Ensure the fetch and push path point correctly. I use origin as my forked repo and upstream as the original repo.
$ git remote -v
> origin https://github.com/YOUR_USERNAME/YOUR_FORK.git (fetch)
> origin https://github.com/YOUR_USERNAME/YOUR_FORK.git (push)
> upstream https://github.com/ORIGINAL_OWNER/ORIGINAL_REPOSITORY.git (fetch)
> upstream https://github.com/ORIGINAL_OWNER/ORIGINAL_REPOSITORY.git (push)
- To update url of existing remote
git remote set-url origin https://github.com/USERNAME/REPOSITORY.git
- To add a new remote
git remote add upstream https://github.com/ORIGINAL_OWNER/ORIGINAL_REPOSITORY.git
- https://git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository
- https://help.github.com/articles/adding-an-existing-project-to-github-using-the-command-line/
- desktop/desktop#2789
- https://help.github.com/articles/setting-your-username-in-git/
- https://help.github.com/en/articles/fork-a-repo
- https://help.github.com/en/articles/changing-a-remotes-url