- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个程序,用于检查几个克隆的git存储库的状态。
如何确定我的存储库是否需要“ git pull”或“ git push”?
最佳答案
首先,pull
只是fetch
,然后是merge
(或rebase
)。这很重要,因为您首先想要的是一个相关的,更简单的问题的答案:与某些远程存储库相比,本地存储库领先和/或落后多远? (对于TL; DR答案,请跳到下面的第一个标头部分。)
还有其他潜在的复杂性,但是这里要做的简单的事情是对照其他一些git存储库检查分支提示。让我们给它们起一些名字以供说明。我们可以将您的存储库称为“ L”(对于本地),假设还有两个附加存储库“ RA”(远程A)和“ RB”,它们的URL以远程名称RA和RB存储在本地存储库L中。
一次获得您可能需要的所有内容的简单方法是在RA和RB上同时运行git fetch
(或git remote update
)。 (尽管我不确定其中是否有任何实际价值,但我们稍后会看到一种推迟获取的方法。)
给定一个典型的设置,同时获取两个遥控器将复制其本地分支为您自己的“远程分支”。假设RA具有master
和dev
,而RB具有master
和feature
,因此在获取完成之后:
L$ git rev-parse --short refs/remotes/RA/master
feedbee
L$ git rev-parse --short refs/remotes/RA/dev
feedbee
L$ git rev-parse --short refs/remotes/RB/master
badf00d
L$ git rev-parse --short refs/remotes/RB/feature
c0ffee1
--short
。而且,您可以缩写分支名称,而忽略
refs/remotes/
-在下面,
refs/heads/
—只要它们没有歧义。不过,如果您正在编写脚本,则以防万一,使用全名可能更明智。
L$ git rev-parse --short refs/heads/master
feedbee
master
与RA的
master
与其
dev
同步。因此,那里没有任何要推送或获取的内容(尽管您已经为了获取该内容而已经获取了内容),因此也没有要合并或变基的内容。
master
指向提交
badf00d
而未同步。这是否意味着您需要合并或推送?也许(也许不是):这是带来复杂性的地方。如果需要手动合并,Git并不能提供太多帮助,但是您可以通过查看提交如何确定RB是否处于“领先”,“处于落后”或两者兼而有之。图相互堆叠。
... - o <-- RB/master: tip-most commit = badf00d
\
o - o <-- master: tip commit = feedbee
git status
给您的术语中,L是回购RB所在的位置“前面2”。如果您对RB进行了推送,则git会将最后两次提交交给RB,并告诉它请将其
master
设置为
feedbee
,这将使其赶上来。
... - o <-- master
\
o - o <-- RB/master
RB/master
带入
master
,则git会看到一个快进操作,并将您的master设置为
badf00d
。此时,回购RA可能会落后,您可能希望将其推到那里。
... - o - o <-- master
\
o - o <-- RB/master
...
部分中没有共同的祖先):
... - o <-- master
... - o <-- RB/master
git merge-base
可能是合理的。但是我会请从现在开始忽略它。)
$ ahead=$(git rev-list --count origin/master..master)
$ behind=$(git rev-list --count master..origin/master)
gitrevisions
range syntax选择本地分支提示(由
master
标识的提交)可访问的修订版本,而不是远程分支提示(由
origin/master
标识)的可达版本。
git push
。如果您不落后,但可以安全地
git merge
快速前进(此时,使用
pull
是没有意义的,因为您已经完成了
fetch
步骤)。如果您同时处于领先地位和落后地位,以至于两个计数都不为零,则必须决定是合并还是变基,以及如果合并或变基失败,该怎么办。当然,如果两个计数都为零,则两个分支提示将标识相同的SHA-1,因此无需执行任何操作。
git fetch
怎么办?
git fetch
。但是,如果愿意,可以从
git ls-remote
开始,它会列出SHA-1和refname的列表:
$ git ls-remote
From [url redacted]
a17c56c056d5fea0843b429132904c429a900229 HEAD
ca00f80b58d679e59fc271650f68cd25cdb72b09 refs/heads/maint
a17c56c056d5fea0843b429132904c429a900229 refs/heads/master
0029c496ce1b91f10b75ade16604b8e9f5d8d20b refs/heads/next
fcd56459647e0c41f2ea9c5b7e2ed827f701fc95 refs/heads/pu
e8f6847178db882bd42d5572439333ca4cb3222e refs/heads/todo
d5aef6e4d58cfe1549adef5b436f3ace984e8c86 refs/tags/gitgui-0.10.0
3d654be48f65545c4d3e35f5d3bbed5489820930 refs/tags/gitgui-0.10.0^{}
[mass snippage]
master
指向提交
a17c56c056d5fea0843b429132904c429a900229
。如果有(我没有),我可以将其用作
git rev-list --count
中的指定符之一,以找出距遥控器多远的距离。因为我没有,所以我几乎可以肯定落后了:我不知道多少,但是我需要获取,然后合并或变基(我不知道自己是否也领先于我取)。
git for-each-ref
,它需要使用很多参数。例如,要找到自己的本地分支机构:
$ git for-each-ref --format='%(refname)' refs/heads
refs/heads/master
refs/heads/precious
refs/heads/stash-exp
origin
的分支:
$ git for-each-ref --format='%(refname)' refs/remotes/origin
refs/remotes/origin/maint
refs/remotes/origin/master
refs/remotes/origin/next
refs/remotes/origin/pu
refs/remotes/origin/todo
关于git - git:如何以编程方式确定是否需要 pull 或 push ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31666641/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!