repo和git配合使用
2023-06-05 https://www.cnblogs.com/NJ-Leon/
一、命令行快捷键
“Ctrl-”表示按住 Ctrl 键的同时键入其后所指定的字符。“Esc-”表示按下并释放 Esc 键,然后键入其后所指定的字符。“Ctrl-[”等效于“Esc”。
快捷键
|
目的
|
Ctrl-B
|
将光标后移一个字符(左向)
|
Ctrl-F
|
将光标前移一个字符(右向)
|
Esc-B / Alt-B
|
将光标后移一个词(左向)
|
Esc-F / Alt-F
|
将光标前移一个词(右向)
|
Ctrl-A
|
将光标移到行首
|
Ctrl-E
|
将光标移到行尾
|
Ctrl-U
|
删除从行首到光标处的命令行内容并将其保存到剪切缓冲区中
|
Ctrl-K
|
删除从光标到行尾的命令行内容并将其保存到剪切缓冲区中
|
Esc-D / Alt-D
|
删除从光标到下一个词尾的命令行内容并将其保存到剪切缓冲区中
|
Ctrl-W
|
删除光标前面的词并将其保存到剪切缓冲区中
|
Ctrl-Y
|
提取剪切缓冲区的内容并将其推送到光标处的命令行中
|
Ctrl-H
|
删除光标前面的字符
|
Ctrl-D
|
删除光标处的字符
|
Ctrl-C
|
清除行 / 终止命令
|
Ctrl-L
|
清除屏幕
|
Ctrl-P
|
将命令行的当前内容替换为历史记录列表中的前一个条目
|
Ctrl-N
|
将命令行的当前内容替换为历史记录列表中的下一个条目
|
Alt-U
|
从光标处更改为全部大写的单词
|
Alt + L
|
从光标处更改为全部小写的单词
|
Alt + T
|
交换光标处和之前的单词
|
Ctrl + R
|
逆向搜索命令历史
|
Ctrl + G
|
从历史搜索模式退出
|
二、常用 Git 命令清单
一般来说,日常使用只要记住下图6个命令,就可以了。但是熟练使用,恐怕要记住60~100个命令。
- Workspace:工作区
- Index / Stage:暂存区
- Repository:仓库区(或本地仓库)
- Remote:远程仓库
新建代码库
|
|
$ git init
|
在当前目录新建一个Git代码库
|
$ git init [project-name]
|
新建一个目录,将其初始化为Git代码库
|
$ git clone [url]
|
下载一个项目和它的整个代码历史
|
配置
Git的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)。
|
|
$ git config --list
|
显示当前的Git配置
|
$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]"
|
设置提交代码时的用户信息
|
增加 / 删除文件
|
|
$ git add [file1] [file2] ...
|
添加指定文件到暂存区
|
$ git add [dir]
|
添加指定目录到暂存区,包括子目录
|
$ git add .
|
添加当前目录所有被修改和新建的文件到暂存区,但不包括被删除的文件
|
$ git add -u
|
添加当前目录所有被修改和被删除的文件到暂存区,但不包括新建的文件
|
$ git add -A
|
添加当前目录所有tracked文件中被修改过或已删除文件和所有untracked的文件到暂存区
|
$ git rm [file1] [file2] ...
|
删除工作区文件,并且将这次删除放入暂存区
|
$ git rm --cached [file]
|
停止追踪指定文件,但该文件会保留在工作区
|
$ git mv [file-original] [file-renamed]
|
改名文件,并且将这个改名放入暂存区
|
代码提交
|
|
$ git commit -m [message]
|
提交暂存区到仓库区
|
$ git commit [file1] [file2] ... -m [message]
|
提交暂存区的指定文件到仓库区
|
$ git commit -a
|
提交工作区自上次commit之后的变化,直接到仓库区
|
$ git commit -v
|
提交时显示所有diff信息
|
$ git commit --amend -m [message]
|
使用一次新的commit,替代上一次提交。如果代码没有任何新变化,则用来改写上一次commit的提交信息
|
$ git commit --amend [file1] [file2] ...
|
重做上一次commit,并包括指定文件的新变化
|
分支
|
|
$ git branch
|
列出所有本地分支
|
$ git branch -r
|
列出所有远程分支
|
$ git branch -a
|
列出所有本地分支和远程分支
|
$ git branch [branch-name]
|
新建一个分支,但依然停留在当前分支
|
$ git checkout -b [branch]
|
新建一个分支,并切换到该分支
|
$ git branch [branch] [commit]
|
新建一个分支,指向指定commit
|
$ git branch --track [branch] [remote-branch]
|
新建一个分支,与指定的远程分支建立追踪关系
|
$ git checkout [branch-name]
|
切换到指定分支,并更新工作区
|
$ git checkout -
|
切换到上一个分支
|
$ git branch --set-upstream [branch] [remote-branch]
|
建立追踪关系,在现有分支与指定的远程分支之间
|
$ git merge [branch]
|
合并指定分支到当前分支
|
$ git rebase [branch]
|
|
$ git cherry-pick [commit]
|
选择一个commit,合并进当前分支
|
$ git branch -m oldName newName
|
分支重命名
|
$ git branch -d [branch-name]
|
删除分支
|
$ git push origin --delete [branch-name]
|
删除远程分支
|
标签
|
|
$ git tag
|
列出所有tag
|
$ git tag [tag]
|
新建一个tag在当前commit
|
$ git tag [tag] [commit]
|
新建一个tag在指定commit
|
$ git tag -d [tag]
|
删除本地tag
|
$ git push origin :refs/tags/[tagName]
|
删除远程tag
|
$ git show [tag]
|
查看tag信息
|
$ git push [remote] [tag]
|
提交指定tag
|
$ git push [remote] --tags
|
提交所有tag
|
$ git checkout -b [branch] [tag]
|
新建一个分支,指向某个tag
|
查看信息
|
|
$ git status
|
显示有变更的文件
|
$ git log
|
显示当前分支的版本历史
|
$ git log --stat
|
显示commit历史,以及每次commit发生变更的文件
|
$ git log -p
|
显示commit历史,以及每次commit内容变化
|
$ git log -p [file]
|
显示指定文件相关的每一次diff
|
$ git log -5 --pretty --oneline
|
显示过去5次提交
|
$ git shortlog -sn
|
显示所有提交过的用户,按提交次数排序
|
$ git blame [file]
|
显示指定文件是什么人在什么时间修改过
|
$ git diff
|
显示暂存区和工作区的差异
|
$ git diff --cached [file]
|
显示暂存区和上一个commit的差异
|
$ git diff HEAD
|
显示工作区与当前分支最新commit之间的差异
|
$ git diff [first-branch]...[second-branch]
|
显示两次提交之间的差异
|
$ git diff --shortstat "@{0 day ago}"
|
显示今天你写了多少行代码
|
$ git diff branch1 branch2 --stat
|
显示出所有有差异的文件列表
|
$ git diff branch1 branch2 文件名(带路径)
|
显示指定文件的详细差异
|
$ git diff branch1 branch2
|
显示出所有有差异的文件的详细差异
|
$ git show [commit]
|
显示某次提交的元数据和内容变化
|
$ git show --name-only [commit]
|
显示某次提交发生变化的文件
|
$ git show [commit]:[filename]
|
显示某次提交时,某个文件的内容
|
$ git reflog
|
可以查看所有分支的所有操作记录(包括已经被删除的 commit 记录和 reset 的操作)
帮助恢复误操作的数据
|
远程同步
|
|
$ git fetch [remote]
|
下载远程仓库的所有变动
|
$ git fetch remote remote_branch
|
下载远程仓库指定远程分支的所有变动
|
$ git fetch remote remote_branch:local_branch
|
下载远程仓库指定的远程分支的所有变动,并在本地创建local_branch本地分支保存所有数据
|
$ git remote -v
|
显示所有远程仓库
|
$ git remote show [remote]
|
显示某个远程仓库的信息
|
$ git remote add [shortname] [url]
|
增加一个新的远程仓库,并命名
|
$ git pull [remote] [remote_branch]
|
取回远程仓库的变化,并与本地分支合并
|
git push origin 本地分支:远程新分支
|
上传本地指定分支到远程新分支,origin指的是远程主机名
|
$ git push [remote] [local_branch]
|
上传本地指定分支到远程仓库
如果远程分支被省略,则表示将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
|
$ git push [remote] --force
|
强行推送当前分支到远程仓库,即使有冲突
|
$ git push [remote] --all
|
推送所有分支到远程仓库
|
撤销
|
|
$ git restore --staged [file]
|
恢复暂存区的指定文件到工作区
|
$ git checkout [commit] [file]
|
恢复某个commit的指定文件到暂存区和工作区
|
$ git restore --staged .
|
恢复暂存区的所有文件到工作区
|
$ git reset [file]
|
重置暂存区的指定文件,与上一次commit保持一致,但工作区不变
|
$ git restore [file]
|
重置工作区的指定文件,与暂存区或者上一次commit保持一致
|
$ git reset --hard
|
重置暂存区与工作区,与上一次commit保持一致
|
$ git reset [commit]
|
重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
|
$ git reset --hard [commit]
|
重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
|
$ git reset --soft [commit]
|
重置当前HEAD为指定commit,但保持暂存区和工作区不变
|
$ git reset HEAD
|
重置暂存区
|
$ git reset --hard HEAD
|
重置暂存区和工作区
|
$ git revert [commit]
|
新建一个commit,用来撤销指定commit
后者的所有变化都将被前者抵消,并且应用到当前分支
|
$ git stash
|
暂时将未提交的变化保存至堆栈中 git stash详解
|
$ git stash pop
|
从堆栈中恢复 git stash详解
|
三、repo工具
repo是一种谷歌开发的代码版本管理工具,它是由一系列的Python脚本组成,封装了一系列的Git命令,用来统一管理多个Git仓库。
-
repo init
repo init -u ssh://xxx/manifest -b master -m master.xml
初始化repo仓库。
选项:
-u: 指定Manifest库的Git访问路径。
-b: 指定要使用Manifest仓库中的某个特定分支。
-m: 指定要使用的Manifest文件。
-
repo sync
下载新的更改并更新本地环境中的工作文件。如果您在未使用任何参数的情况下运行 repo sync,则该操作会同步所有项目的文件。
运行 repo sync 后,将出现以下情况:
-
-
- 如果目标项目从未同步过,则 repo sync 相当于 git clone。远程代码库中的所有分支都会复制到本地项目目录中。
- 如果目标项目已同步过,则 repo sync 相当于以下命令:
-
$ git remote update
$ git rebase origin/<BRANCH>
其中 <BRANCH> 是本地项目目录中当前已检出的分支。如果本地分支没有在跟踪远程代码库中的分支,则相应项目不会发生任何同步。
-
-
- 如果 git rebase 操作导致合并冲突,那么您需要使用普通 Git 命令(例如 git rebase --continue)来解决冲突。
-
repo sync 运行成功后,指定项目中的代码会与远程代码库中的代码保持同步。
-
repo status [.]
尾随句点 (.) 代表当前工作目录中的项目,可选项。
执行 repo status 如下:
未被跟踪的新文件旁边会有一个--标记,已暂存的新文件会有A标记,而已修改的文件则会有一个M标记,等等。实际上,文件列表旁边的标记是分成两列的,左列标明了文件是否已暂存,而右列表明了文件是否已修改。以上面的命令行输出为例,工作目录下的pin_mux.h文件已被修改,但还没有被暂存。另一个board_pinmux_gt3.c文件是已修改而且已暂存的状态。而board_bsd.c文件则是已修改并被添加到暂存区,之后又被修改过,因此暂存区和工作区都包含了该文件的变更。
-
repo diff [.]
使用
git diff
显示最近一次提交与工作树之间的详细更改。-
repo forall -c <git_command>
在每个项目中运行指定的 shell 命令。