git diff --s
时间: 2023-09-30 09:05:46 浏览: 144
`git diff --s`是一个常用的Git命令,用于显示当前工作目录(Working Directory)与暂存区(Staging Area)之间的差异(即尚未提交的更改)。通过使用`--s`选项,可以使git diff命令以简洁的方式显示差异结果。它会显示出文件名和路径,而不会显示详细的具体更改内容。这在某些情况下可能很有用,特别是当你只关心文件更改的概览而不需要详细的更改内容时。
相关问题
execute_process(COMMAND sh -c "git symbolic-ref --short -q HEAD" OUTPUT_VARIABLE GIT_BRANCH OUTPUT_STRIP_TRAILING_WHITESPACE) execute_process(COMMAND sh -c "git rev-list HEAD --abbrev=8 --abbrev-commit --max-count=1" OUTPUT_VARIABLE GIT_LAST_COMMIT OUTPUT_STRIP_TRAILING_WHITESPACE) execute_process(COMMAND sh -c "git rev-list HEAD --count" OUTPUT_VARIABLE GIT_COMMITS_NUM OUTPUT_STRIP_TRAILING_WHITESPACE) execute_process(COMMAND sh -c "git status --short --untracked-files=no | wc -l" OUTPUT_VARIABLE GIT_DIFF_STATUS OUTPUT_STRIP_TRAILING_WHITESPACE) if ( ${GIT_DIFF_STATUS} EQUAL "0" ) set(BUILD_VERSION "R${GIT_LAST_COMMIT}_${GIT_BRANCH}") else() set(BUILD_VERSION "R${GIT_LAST_COMMIT}M_${GIT_BRANCH}") endif() #build date string(TIMESTAMP DATETIME "%Y%m%d%H%M%S") #enable gdb debug symbol if (NOT CMAKE_BUILD_TYPE) set(CMAKE_BUILD_TYPE "Release") message (STATUS "No CMAKE_BUILD_TYPE selected, defaulting to ${CMAKE_BUILD_TYPE}") endif() message (STATUS "The CMAKE_BUILD_TYPE is selected to ${CMAKE_BUILD_TYPE}") set(CMAKE_CXX_FLAGS_BASE "$ENV{CXXFLAGS} -pipe -Wall -Wno-unknown-pragmas -Wno-format-zero-length -lrt -Wno-ignored-attributes") #set(CMAKE_CXX_FLAGS_BASE "${CMAKE_CXX_FLAGS_BASE} -save-temps") set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_BASE} -O2 -g") set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_BASE} -O3") #set(CMAKE_DEBUG_POSTFIX _D) set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE "${CMAKE_COMMAND} -E time") set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK "${CMAKE_COMMAND} -E time")
这段代码执行了一系列的命令,获取了与Git相关的信息,并设置了构建的版本号和日期。
首先,使用`execute_process`命令执行了一系列的`git`命令来获取Git的分支、最后一次提交、提交数量和文件差异状态的信息,并将结果保存到相应的变量中。
接下来,使用条件语句判断`${GIT_DIFF_STATUS}`的值是否为0。如果是0,说明没有文件差异,那么将构建版本号设置为"R${GIT_LAST_COMMIT}_${GIT_BRANCH}";否则,将构建版本号设置为"R${GIT_LAST_COMMIT}M_${GIT_BRANCH}"。
然后,使用`string(TIMESTAMP ...)`命令获取当前的日期和时间,并将结果保存到`DATETIME`变量中。
接着,检查是否定义了`CMAKE_BUILD_TYPE`变量。如果没有定义,将其设置为"Release",并输出一条消息表示默认使用了该选项。
然后,设置了编译器的基本选项`CMAKE_CXX_FLAGS_BASE`,包括一些通用的编译选项和库链接选项。
接着,根据构建类型设置了不同的编译选项。对于Debug类型,使用`-O2 -g`,表示开启优化级别2和调试符号。对于Release类型,使用`-O3`,表示开启优化级别3。
最后,通过`set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ...)`和`set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ...)`命令设置了编译和链接命令的时间控制,用于输出编译和链接的时间信息。
总之,这段代码通过执行Git相关的命令获取了版本和日期信息,并设置了相应的变量和编译选项。
git diff快捷键
`git diff` 是 Git 中用于查看文件差异或提交之间差异的强大命令。在终端中,你可以使用以下快捷键:
- `d` 或 `D`: 这通常用于选择要添加到暂存区(即将被下次 commit 的更改)的部分区域,然后回车执行。例如,`d` 后跟空间选择行,`D` 可选行添加到暂存区。
- `u`: 这个快捷键用于在文本模式下编辑差异,可以用来直接修改文件内容。
- `i` 或 `a`: 分别用于插入和添加新行。`i` 在当前光标前插入一行,`a` 在当前光标后添加一行。
- `c` 或 `C`: 用于切换到字符插入模式,这样你可以在单个字符级别编辑差异。
- `e` 或 `E`: 进入交互式编辑模式,提供更多的编辑选项。
- `s` 或 `S`: 删除差异中的某行,`s` 删除选定行,`S` 删除所有匹配的行。
请注意,这些快捷键可能因配置和环境而略有不同,特别是当使用像 tmux 这样的终端管理器时。你可以在 Git 官方文档中找到完整的键盘交互说明:https://git-scm.com/docs/git-diff#_keyboard_shortcuts
阅读全文