input examples are now given as ```bash input $ARG1 ``` While outputs use md's '> ' sign as a quote.
		
			
				
	
	
		
			231 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			231 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| title: "git"
 | |
| tags: [ "Documentation", "data" ]
 | |
| ---
 | |
| # Starting
 | |
| 
 | |
| ## New Machines
 | |
| 
 | |
| ```bash
 | |
| git config --global user.email "$YOUR_EMAIL"
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git config --global user.name "$YOUR_NAME"
 | |
| ```
 | |
| 
 | |
| # New Git
 | |
| 
 | |
| Start a git in directory `$DIR`:
 | |
| 
 | |
| ```bash
 | |
| mkdir $DIR && cd $DIR
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git init
 | |
| ```
 | |
| 
 | |
| Make a file explaining what the project does:
 | |
| 
 | |
| ```bash
 | |
| vim README.md
 | |
| ```
 | |
| 
 | |
| Add this to the git:
 | |
| 
 | |
| ```bash
 | |
| git add README.md
 | |
| ```
 | |
| 
 | |
| Then make the initial commit, explaining the change you just made:
 | |
| 
 | |
| ```bash
 | |
| git commit
 | |
| ```
 | |
| 
 | |
| # Working
 | |
| 
 | |
| Once you make a change to some file, add it and make a commit explaining it.
 | |
| 
 | |
| ```bash
 | |
| git add $FILE
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git commit -m"change $FILE"
 | |
| ```
 | |
| 
 | |
| Check your history:
 | |
| 
 | |
| ```bash
 | |
| git log
 | |
| ```
 | |
| 
 | |
| # Remotes
 | |
| 
 | |
| If you want to keep a copy on a public site such as Gitlab, so others can see it, then go there and create a blank project (no readme, nothing).
 | |
| Give it the same name as the `$DIR` directory, above.
 | |
| 
 | |
| Add this as a remote:
 | |
| 
 | |
| ```bash
 | |
| REMOTE=gitlab
 | |
| git remote add $REMOTE  https://gitlab.com/$USERNAME/$DIR
 | |
| ```
 | |
| 
 | |
| Tell git you're pushing the branch "master" to the remote repo "origin": 
 | |
| 
 | |
| ```bash
 | |
| git push -u master origin
 | |
| ```
 | |
| 
 | |
| If someone makes a change on the remote, pull it down with:
 | |
| 
 | |
| ```bash
 | |
| git pull
 | |
| ```
 | |
| 
 | |
| # Branches
 | |
| 
 | |
| A branch is a full copy of the project to test additional ideas.
 | |
| You can make a new branch called 'featurez' like this:
 | |
| 
 | |
| ```bash
 | |
| git branch *featurez*
 | |
| ```
 | |
| 
 | |
| Have a look at all your branches:
 | |
| 
 | |
| ```bash
 | |
| git branch
 | |
| ```
 | |
| 
 | |
| Switch to your new branch:
 | |
| 
 | |
| ```bash
 | |
| git checkout *featurez*
 | |
| ```
 | |
| 
 | |
| And if your changes are rubbish, checkout the "master" branch again, then delete "featurez":
 | |
| 
 | |
| ```bash
 | |
| git branch -D *featurez*
 | |
| ```
 | |
| 
 | |
| Or if it's a good branch, push it to the remote:
 | |
| 
 | |
| ```bash
 | |
| git push *origin* *featurez*
 | |
| ```
 | |
| 
 | |
| ## Merging
 | |
| 
 | |
| Once you like the feature, merge it into the main branch.  Switch to master then merge it:
 | |
| 
 | |
| ```bash
 | |
| git merge *featurez*
 | |
| ```
 | |
| 
 | |
| and delete `featurez` as you've already merged it:
 | |
| 
 | |
| ```bash
 | |
| git branch -d featurez
 | |
| ```
 | |
| 
 | |
| # Subtree
 | |
| 
 | |
| ## Pulling another git repo into a subtree
 | |
| 
 | |
| ```bash
 | |
| git subtree add -P config git@gitlab.com:bindrpg/config.git master
 | |
| ```
 | |
| 
 | |
| ## Pulling a Subtree from an existing git
 | |
| 
 | |
| The project has subdirectories sub-1,sub-2,sub-3.  The first should be its own repository, but should also retain its own history.
 | |
| 
 | |
| First, we extract its history as an independent item, and make that into a seprate branch.
 | |
| 
 | |
| ```bash
 | |
| git subtree split --prefix=sub-1 -b sub
 | |
| ```
 | |
| 
 | |
| If you want something a few directories deep, you can use `--prefix=sub-1/dir-2/dir-3
 | |
| 
 | |
| Then go and create a new git somewhere else:
 | |
| 
 | |
| ```bash
 | |
| cd ..;mkdir sub-1;cd sub-1;git init --bare
 | |
| ```
 | |
| 
 | |
| Then go back to your initial git repo, and do the following:
 | |
| 
 | |
| git push ../subtest sub:master
 | |
| 
 | |
| Finally, you can clone this repo from your original.
 | |
| 
 | |
| ```bash
 | |
| git clone ../subtest
 | |
| ```
 | |
| 
 | |
| # Tricks
 | |
| 
 | |
| ## Delete All History
 | |
| 
 | |
| ```bash
 | |
| git checkout --orphan temp
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git add -A
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git commit -am "release the commits!"
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git branch -D master
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git branch -m master
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git push -f origin master
 | |
| ```
 | |
| 
 | |
| Gitlab requires more changes, such as going to `settings > repository` and switching the main branch, then stripping protection.
 | |
| 
 | |
| ## Clean up Bloated Repo
 | |
| 
 | |
| ```bash
 | |
| git fsck --full
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git gc --prune=now --aggressive
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| git repack
 | |
| ```
 | |
| 
 | |
| ## Find Binary Blobs
 | |
| 
 | |
| ```bash
 | |
| git rev-list --objects --all \
 | |
| | git cat-file --batch-check='%(objecttype) %(objectname) %(objectsize) %(rest)' \
 | |
| | sed -n 's/^blob //p' \
 | |
| | sort --numeric-sort --key=2 \
 | |
| | cut -c 1-12,41- \
 | |
| | $(command -v gnumfmt || echo numfmt) --field=2 --to=iec-i --suffix=B --padding=7 --round=nearest
 | |
| 
 | |
| ```
 | |
| 
 | |
| # More
 | |
| 
 | |
| For big binary files (like images), see [git large-file-storage](git-lfs.md)
 |