【iOS开发笔记】git pull问题的解释和解决方案

2022-10-17  本文已影响0人  Mr_Ten

一、背景

今天更新了SourceThree,更新后合并代码时遇到了以下问题

hint: Pulling without specifying how to reconcile divergent branches is
hint: discouraged. You can squelch this message by running one of the following
hint: commands sometime before your next pull:
hint:
hint:   git config pull.rebase false  # merge 
hint:   git config pull.rebase true   # rebase
hint:   git config pull.ff only       # fast-forward only
hint:
hint: You can replace "git config" with "git config --global" to set a default
hint: preference for all repositories. You can also pass --rebase, --no-rebase,
hint: or --ff-only on the command line to override the configured default per
hint: invocation.

翻译如下:

warning: 不建议在没有为偏离分支指定合并策略时执行pull操作。
您可以在执行下一次pull操作之前执行下面一条命令来抑制本消息:

git config pull.rebase false  # 合并
git config pull.rebase true   # 变基
git config pull.ff only       # 仅快进

您可以将 "git config" 替换为 "git config --global" 以便为所有仓库设置
缺省的配置项。您也可以在每次执行 pull 命令时添加 --rebase、--no-rebase,
或者 --ff-only 参数覆盖缺省设置。

出现问题的主要原因应该是因为更新SourceThree时将git版本也一并更新了,查看后发现git版本为2.37.0

二、相关知识

通过上面的问题提示,可以看到,主要涉及两个Git的配置信息pull.rebasepull.ff

1. pull.ff

2. pull.rebase

那么git pull命令的各个选项到底有什么意义呢?

3. git pull

4. git pull的选项及作用

综上所述,直接执行git pull时,Git不知道我们到底想要采用哪种合并策略来执行git pull,因此会出现最开始提到的问题,建议我们通过git config来进行基本设置,制定不带任何选项的git pull执行哪种策略。那么下面再讲一下Git的配置。

5. git的配置

5.1 三个配置等级

Git一共有三个配置文件,可以通过git config命令修改,它们的权重为1>2>3,会优先选择--local对应的配置策略进行。

  1. 仓库级配置文件--local
  2. 全局级配置文件--global
  3. 系统级配置文件--system
5.2 查看配置文件

查看配置文件的命令为-l或者采用--list

  1. 查看仓库级的配置:git config --local -l
  2. 查看全局级的配置:git config --global -l
  3. 查看系统级的配置:git config --system -l
  4. 查看当前生效的所有配置:git config -l
5.3 编辑配置文件

编辑配置文件的命令为-e或者采用--edit

  1. 编辑仓库级的配置:git config --local -e
  2. 编辑全局级的配置:git config --global -e
  3. 编辑系统级的配置:git config --system -e
5.4 新增一个配置项

新增配置项的命令为--add,默认添加在--local配置中。其中section.key为要添加的配置项,value是配置项的值。

  1. 新增仓库级的配置项:git config --local --add section.key value
  2. 新增全局级的配置项:git config --global --add section.key value
  3. 新增系统级的配置项:git config --system --add section.key value
5.5 获取一个配置项

获取配置项的命令为--get

  1. 获取仓库级的配置项:git config --local --get section.key
  2. 获取全局级的配置项:git config --global --get section.key
  3. 获取系统级的配置项:git config --system --get section.key
5.6 删除一个配置项

删除配置项的命令为--unset

  1. 删除仓库级的配置项:git config --local --unset section.key
  2. 删除全局级的配置项:git config --global --unset section.key
  3. 删除系统级的配置项:git config --system --unset section.key

6. 其他定义

三、解决问题

SourceThree的合并代码本质上也是git pull命令,通过上面的学习我们可以了解到,出现问题的原因就是因为git pull的歧义。因此,我们只需要在Git中配置pull.rebasepull.ff的参数即可。

git config --global --add pull.rebase false
上一篇下一篇

猜你喜欢

热点阅读