Git uses blob object to store the conent of file of each version, the blog file name is SHA1 value of content of file.git
Git uses tree object to store the filename/path and corresponding blob data.app
git ls-files -s, to list all filesui
git ls-remote, to list remotes and branchs url
The default file .gitignore who contains the ignore files in each folder.spa
HEAD is a reference to the last commit in the currently check-out branch..net
downstream when you copy (clone, checkout, etc) from a repositorycode
upstream generally refers to the original repo that you have forkedorm
create a remote repository in local fileserver
in folder, git init --bare
blog
The first step
in the selected folder
git init
git remote add origin remote-address
or
git clone remote address
or git clone -b branchname remoteaddress
Note that, git clone also can clone two folders in local. for instance, git clone oldfolder newfolder
==========================================
Add a new file
git add files
git commit -m"comments"
git push
While a already commited file is modified, just git commit and git push are enough.
delete files
git rm files
git commit -m"comments"
git push
rename file or folder
git mv oldfile newfile
git push
show status
git status, show the new folders/files under current folder
git status --untracked-files = all , show all folders incluing sub-folder
git branch -aav to see the branch information including the remote and local
check the history
git log
git log --oneline, show the change in one line comprehensive
git show 9da581d910c9c4ac93557ca4859e767f5caf5169/or short name to see what's the detail changes
git show-branch to get the sumary of current development branch
git diff 9da581d910c9c4ac93557ca4859e767f5caf5169 9da581d910c9c4ac93557ca4859e767f5caf5199 to check the difference between two commits.
gitk the graph view of changes
git log -p filename, it view the history of the file.
git log --graph --oneline, graph way to display with log
git reset
reset the commit before push to service
git reset --hard xxxx, xxx is the commit tag.
git diff
git diff --name-only master origin/master
Configuration
git config --global user.name "your name here"
git config --global user.email "your email here"
git config -l list all configured
.gitignore
.gitignore file
Ignoring the file everywhere by adding it to the .gitignore file in the topmost directory of repository. Multi .gitignore file in different directories is accepted, it only applies for current directory and sub directoies.
To ignore .o files, place *.o in your top level .gitignore
branch
git branch newbranchname [start-commit], it will create a branch name, but still system still working in current branch, the [start-commit] is to select which branch as the starting of the new branch, it is option, the default the current working branch.
git show-branch, shows the branch in local and remote
git checkout newworkbranch switch to work branch
example:
git branch Sprint-1
git show-branch
the current working branch is master (*)
git checkout Sprint-1
now, it switches to Sprint-1(*)
commit somefile with git add ., git commit
push to server, git push, the errro will be indicated:
git checkout -b newbranchname [start-point], create and switch to new branch
git branch -d branchname, delete a branch
git branch -vv to track and show local and remote branchs
general working flow:
create a branch in local, git checkout -b newbranchname
work as you want, git add . git commit .
git push -u origin newbrachname, it will auto push to remote with newbranchname
merge
git merge development master //merge local development to local master, but now we still in the development branch git push origin master //push to remote, the orgin master
Show which tag/branch
git show 46659f7deb962f55c728e70597e37c2a3ab6326d
commit 46659f7deb962f55c728e70597e37c2a3ab6326d (tag: v237)
Merge: 82c8e3e650 31751f7e2a
Author: Lennart Poettering <lennart@poettering.net>
Date: Sun Jan 28 16:58:17 2018 +0100
Merge pull request #8030 from keszybz/another-news-update
NEWS: reword one sentence
===========================================================
problems Solve
fatal: refusing to merge unrelated histories
git pull --allow-unrelated-histories
visit local reponsitory without proxy: fatal: repository 'http://server:8080/tfs/DefaultCollection/_git/PlayProject/' not found
git config --local remote.origin.proxy ""
the "origin" is alias of remote.
git config --list, to list all configurations
git remote show origin, it is to show the URL of remote/origin
in case the error is shown when run git remote show origin,
we can use command to fix it. git remote set-url origin theremoteurl