- 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/
我正在使用 Selenium Web 驱动程序 3.0,并且想要从打开的两个对话框(一个在后台,第二个在前台)的 Activity 对话框中单击“确定”按钮。如何从 html 下面的父 div 单击前
actions: [ FlatButton( onPressed: () {
我有一个问题有点超出我的范围(我真的很高兴我是 Beta)涉及重复项(所以 GROUP BY, HAVING, COUNT),通过将解决方案保留在 SQLite 附带的标准函数中而变得更加复杂。我正在
使用DBI是否可以确定SELECT语句的已执行语句句柄是否返回任何行而不从中获取行? IE。就像是: use DBI; ... my $sth = $dbh->prepare("SELECT ..."
是否可以为“确定”和“关闭”按钮指定回调函数? 如果是JQuery Modal,则可以在初始化时使用按钮字典指定回调函数。 Semantic-ui模态是否提供类似的功能?按下确定后,我该如何寻求其他逻
我想阅读警报中的消息。 示例:如果警报显示“错误的电子邮件地址”。怎么读呢?意味着我想将该消息存储在字符串中。 如何在“警报”中单击“确定”...?? 如何使用 Selenium 来做到这一点? 最佳
我有一个删除按钮: 我试图首先查明是否已选择一个网站,如果已选择一个网站,我需要确定是否已选择一个或多个列表项,如果是,则继续删除这些项目。 我的 if 语句不断返回“您必须首先选择您的列表”,即使它
部分出于好奇——我们想知道在我们的应用程序中发生了什么——部分是因为我们需要在我们的代码中找到一些潜在的问题,我喜欢在我们的网络应用程序运行时跟踪一些一般值。这尤其包括某些对象图的分配内存。 我们的应
我将 SweetAlert 与 Symfony 结合使用,我希望用户在完成删除操作之前进行确认。 发生的情况是,当用户单击删除按钮时,SweetAlert 会弹出,然后立即消失,并且该项目被删除。 在
我们有一个应用程序可以生成不包括字母 O 的随机基数 35 [0-9A-Z]。我正在寻找一种解决方案来查找包含任何淫秽英语单词的代码,而无需搜索包含 10,000 个条目的列表每个生成的代码。每秒生成
这是我做的: #include #include int betweenArray(int a, int b){ int *arr,i,range; range = b - a +
我知道如何创建 警报和确认框,但我不知道如何做的是实际单击“确定”。我有一个弹出确认框的页面。 我想使用 Java Script 插件单击“确定”。基本上,我希望我的代码单击页面上的链接,然后在出现提
代码: swal('Your ORDER has been placed Successfully!!!'); window.location="index.php"; 甜蜜警报工
>>> import re >>> s = "These are the words in a sentence" >>> regex = re.compile('are|words') >>> [m
使用确定的理想散列函数给出随机期望线性时间算法两个数组 A[1..n] 和 B[1..n] 是否不相交,即 A 的元素是否也是 B 的元素。 谁能告诉我如何做到这一点,甚至如何开始考虑它? 最佳答案
我在计算机科学课上有这段代码: int input=15; while (input < n ) { input = input *3;} 这段代码有 log3(n/15) 次循环的上限。我们怎样才能
我有一个允许 2 位玩家玩 TicTacToe 的程序。在每个玩家移动之后,它应该在那个点显示棋盘并返回一个名为 Status 的枚举,显示玩家是否应该继续,如果玩家赢了,还是平局。但是,该算法要么返
给定一个 y 值数组,例如 [-3400, -1000, 500, 1200, 3790],我如何确定“好的”Y 轴标签并将它们放置在网格上? ^ ---(6,000)-|---
假设我有一个检查用户登录的 SQL 语句: SELECT * FROM users WHERE username='test@example.com', password='abc123', expi
teradata中有返回表中哪一列被定义为主索引的命令吗?我没有制作一些我正在处理的表,也没有尝试优化我对这些表的连接。谢谢! 最佳答案 有dbc.IndicesV,其中IndexNumber=1表示
我是一名优秀的程序员,十分优秀!