AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题

问题[git](coding)

Martin Hope
Piotr Siupa
Asked: 2025-04-30 17:24:29 +0800 CST

`--no-atomic` 是否保证在出现错误的引用之前更新引用?

  • 5

该标志--atomic保证git push命令是否成功或没有更新引用。

它是否--no-atomic只是关闭了这个保证,还是建立了相反的保证 - 即使存在一些错误,所有可能的引用都将被更新(或者至少在错误的引用之前的引用将被更新)?

例如,如果我运行命令git push --no-atomic origin foo bar,foo即使出现问题,也会在远程更新吗bar?

git
  • 1 个回答
  • 32 Views
Martin Hope
David Beaumont
Asked: 2025-04-28 18:47:05 +0800 CST

如何在创建分支时设置自定义上游?

  • 5

我有一个工作流程,其中本地分支的名称最终我并不想在远程存储库中显示。我希望在创建本地分支时设置上游名称,这样在使用时就不需要记住这样做了git push。

我在这里查看了很多问题/答案,并且看到了两条关于设置上游分支名称的建议:

  1. 使用git config --local remote.origin.push LOCAL_BRANCH:REMOTE_BRANCH
  2. 使用git branch --set-upstream-to REMOTE_BRANCH
  3. 使用git push -u或git push origin LOCAL_BRANCH:REMOTE_BRANCH

第一个“有点工作”,因为如果我推送本地分支,它会推送到预期的远程,但它也会重置该配置条目中的任何现有值,而这是我不想要的。

当远程分支不存在时,第二个不起作用,给我:

fatal: the requested upstream branch 'foobar' does not exist
hint: 
hint: If you are planning on basing your work on an upstream
hint: branch that already exists at the remote, you may need to
hint: run "git fetch" to retrieve it.
hint: 
hint: If you are planning to push out a new local branch that
hint: will track its remote counterpart, you may want to use
hint: "git push -u" to set the upstream config as you push.
hint: Disable this message with "git config advice.setUpstreamFailure false"

第三个显然不是我想要的,因为我希望这在分支创建时发生。

我尝试推送到一个新的(不同名称的)远程并设置以下条目出现在本地配置中:

branch.foo.remote=origin
branch.foo.upstream=foobar
branch.foo.merge=refs/heads/foobar

但是,如果我删除它们,并使用不同的名称手动重新创建它们,当我推送它(没有-u)时,它只想使用本地分支名称。

所以我开始认为实际上没有好的方法来做到这一点。

再次重申一下,我想要的是:

一种配置新本地分支的方法,使其在首次推送时具有不同的远程分支名称,而无需在首次推送时明确设置该名称

这可能吗?

编辑:事实证明,虽然给出的答案适用于命令行 git,但它似乎不适用于 IntelliJ(也许 IntelliJ 缓存了 git 配置信息?)。

git
  • 1 个回答
  • 89 Views
Martin Hope
mastupristi
Asked: 2025-04-25 06:04:04 +0800 CST

`--reference-if-able` 如何影响克隆中的 `git fetch` 和 `git push` 传播?

  • 7

我有两个相同远程存储库的本地克隆(urlA):

  1. 镜像/ – 创建于
    git clone --mirror urlA mirror
    
  2. dirB/ – 创建于
    git clone --reference-if-able ../mirror urlA dirB
    

在dirB中,当我运行时:

git fetch
git push

镜像/会被任一命令更新吗?

我的理解是,它--reference-if-able只是通过重用参考仓库中的对象来加速对象下载,并没有将参考仓库转换为实际接收fetch或的远程仓库push。然而,我在其他地方看到一条评论,暗示它可能会传播命令。

问题:
参考存储库中 是否--reference[-if-able]触发过fetch或?如果没有,我该如何配置 Git,以便dirB中的push单个git push或也能更新我的本地镜像克隆?git fetch

git
  • 1 个回答
  • 32 Views
Martin Hope
JackLThornton
Asked: 2025-04-23 00:42:09 +0800 CST

如何向 git 询问实际的当前分支名称[重复]

  • 0
这个问题已经有答案了:
如何在 Git 中获取当前分支名称? (55 个答案)
12 小时前关闭。

我编写了一个实用程序,用于收集测试前后的“指标”(即运行后端和前端测试的结果),并将结果存储在以测试分支命名的子文件夹中(此子文件夹位于特定的用户定义文件夹中,而不是“项目”文件夹中——用户可自行决定何时清理旧子文件夹)。该实用程序执行的所有操作都与当前工作目录相关,而当前工作目录被假定为正在测试的 git 仓库本地存储的根目录或“项目”文件夹。

该实用程序会向 git 询问 CWD 上的当前分支名称。我使用“git name-rev --name-only HEAD”来获取该名称。只要我至少向该分支提交过一次,它就能完美运行。但是,实际用例是,当您切出新分支时运行该实用程序,然后在准备好合并请求时再次运行它;然后将前后指标复制到我们使用的 MR 模板中。但是,当第一次切出分支时,上述命令返回的是我从中切出的分支的名称,而不是新分支的实际名称。除了运行“git status”并解析输出之外,还有其他方法可以可靠地使用其他 git 命令获取正确的分支名称吗?

git
  • 1 个回答
  • 51 Views
Martin Hope
Maarten Derickx
Asked: 2025-04-20 19:50:59 +0800 CST

如何让 GitHub 桌面默认使用 ssh?

  • 8

有时我会使用 GitHub 上文档中提到的“使用 GitHub Desktop 打开”功能按钮来克隆 GitHub上的仓库。但是,此功能默认始终使用 https 而不是 ssh 进行克隆。

所以每次我克隆东西时都需要手动更改 URL。有没有办法告诉 GitHub,我永远不想用 https 克隆,而是一直想用 ssh 克隆?

git
  • 1 个回答
  • 47 Views
Martin Hope
kef_rem
Asked: 2025-04-16 09:19:40 +0800 CST

如何移除/删除新分支上的唯一提交?[重复]

  • 5
这个问题已经有答案了:
如何在本地和远程删除 Git 分支? (41 个回答)
16 小时前关闭。

我创建了一个新分支,想在不影响主分支的情况下修改代码。结果什么也没做,所以我回到了主分支继续工作,没有带上任何修改。新分支上只有一个提交,但我希望它从提交历史记录中移除!

提交已推送至远程仓库,因此其中存在一个源指针。我不确定这是否与此有关。求助!

标记的哈希是我想要删除的提交

git rebase -i <commit id>它对我没有任何作用,只是提示我修改较新的分支。我尝试在提交的分支和父分支上运行它。

git
  • 4 个回答
  • 60 Views
Martin Hope
goweon
Asked: 2025-04-16 02:53:32 +0800 CST

强制 git 将嵌套存储库视为常规文件夹而不是子模块,但仍将其保留为 git 存储库

  • 4

这是一个示例目录结构

ParentRepo/
    .git/
    parent_file
    ChildRepo/
        .git/
        child_file
        child_untracked

我希望 ParentRepo 跟踪其自身下所有文件的更改(跟踪parent_file、child_file、child_untracked但不跟踪ChildRepo/.git),就好像ChildRepo它不是 git 存储库一样,但我需要将其保留ChildRepo为 git 存储库

有三个硬性要求

  • ChildRepo 的内容必须直接在 ParentRepo 中跟踪,而不是作为对 ChildRepo 提交的引用。例如,我必须能够ChildRepo/仅使用目录中的信息在 ParentRepo 历史记录中的任何时间点删除和恢复其内容ParentRepo/.git/,而无需使用来自其他服务器或备份的 ChildRepo 外部副本。将 ChildRepo 添加为 ParentRepo 的子模块是不够的,因为如果整个目录 ChildRepo 被删除,则无法仅使用 ParentRepo 中的信息进行恢复。ChildRepo/.git/无需恢复
  • ChildRepo 必须保留为一个 git repo,并拥有独立于 ParentRepo 的开发历史;我们不能删除该ChildRepo/.git/文件夹
  • ParentRepo 必须能够跟踪从未提交给 ChildRepo 的更改,例如,child_untracked可能永远不会进入 ChildRepo 的历史记录,但仍然可以从 ParentRepo 跟踪它

目前,git 将任何带有 .git/ 子目录的目录视为 git repo,我需要绕过这种行为

这些是奇怪的冲突要求的原因

  • 任何先前版本的完整构建都必须是可能的,但 ChildRepo 的上游副本无法保证将来可用。如果将来 ChildRepo 从 ParentRepo 中移除,则可能会破坏依赖于 ChildRepo 的先前构建,因为其内容未存储在 ParentRepo 中,并且上游已被永久删除。至于为什么 ChildRepo 不能单独备份,因为没有办法强制要求 ChildRepo 的副本必须与 ParentRepo 一起存储,以备 ParentRepo 的整个未来使用;而且,例如,如果 ChildRepo 的历史记录被重写,也无法保证 ChildRepo 的副本包含 ParentRepo 引用的所有提交。保存先前的构建是主要目标,并且在此至关重要,因此父级仓库必须跟踪所有依赖项的内容,而不仅仅是版本。
  • ChildRepo 必须独立于 ParentRepo 追踪自己的开发历史
  • 这并不总是有意义的,也不总是能够在我需要提交 ParentRepo 的确切时刻提交 ChildRepo
git
  • 1 个回答
  • 53 Views
Martin Hope
Sam
Asked: 2025-04-14 22:13:56 +0800 CST

git 忽略除具有特定扩展名的文件之外的整个目录

  • 7

我希望.gitignore文件中有一些行忽略整个目录及其子目录,除了以 .pdf 结尾的任何文件(及其文件夹结构)

目前我使用;

outputs/*
!outputs/**/*.pdf

这排除了输出目录,然后似乎包括随机选择的子目录和.csv和.png。

文件夹结构并非固定到PDF文件(可能是1到8个子目录深度),但我只想让.pdf文件只保留在该outputs/文件夹中。说实话,我觉得自己做的是对的!

git
  • 1 个回答
  • 55 Views
Martin Hope
Erebus1841
Asked: 2025-04-14 17:03:37 +0800 CST

当我尝试使用变量而不是硬编码值作为输入时,为什么我的 git 命令输出空白到文本文件?

  • 5

我正在编写一个Windows批处理文件来简化一些文档的生成,我对此还比较陌生。其中一部分涉及查询我的git存储库以查找两个最新的发布标签。一旦我获得了这些标签,我打算使用git log命令将输出写入另一个目录中的文本文件。

如果我将标签名称作为常量写入 git log 命令,我就能够将 git log 的输出写入文本文件,但是当我使用存储了标签名称的变量时,我只能在 cmd 窗口中看到输出,并且生成的文本文件是空白的。

使用下面已知的标签运行将在命令窗口和文本文件中输出

git log --format="%%s" OLD_RELEASE..NEW_RELEASE > "C:\Documentation\Commits.txt"

命令窗口和输出文本文件中的输出如下所示,并与 git 中的注释一致(我知道注释很差,但我试图故意使这些信息保持模糊)

V3.1.2.0 19 Sept
V3.1.1.2 6 August
V3.1.1.1 16 July 
V3.1.1.1 15 July 
V3.1.2.0 14 July 
535 indicator added to setup screen
fault 4 severity level reduced from non-threatening

但是,如果我首先搜索标签以确定两个标签名称并将它们设置为变量“OldTag”和“NewTag”,然后使用相同的命令但格式如下,我会在命令窗口和提交消息列表中看到正确的相同命令,但输出文本文件是空白的。

git log --format="%%s" %OldTag%..%NewTag% > "C:\Documentation\Commits.txt" 

我发现,运行一个混合命令,其中第二个变量被用作硬编码值,似乎可以与写入文本文件的输出兼容。因此,似乎第二个变量的使用阻止了输出命令的运行

git log --format="%%s" %OldTag%..NEW_RELEASE > "C:\Documentation\Commits.txt"
git
  • 1 个回答
  • 71 Views
Martin Hope
mike rodent
Asked: 2025-04-10 15:15:18 +0800 CST

如何让 git diff 在两次提交之间产生更简单的输出?

  • 5

我查看了很多关于git diffbetween 2 commits 功能的解释,但我仍然对得到的输出感到困惑。我相信我看到的是“组合格式”,据说是“默认”格式,但如果是这样的话,我不知道还有哪些其他可用的格式。

例子:

>git diff af738ab0..bbbec26d > gitdiff_2025-04-09B.diff

通常我会遇到这样的情况:

...
+diff --git a/src/core/history_table_view.py b/src/core/history_table_view.py
+index 5b18236..05b262a 100644
+--- a/src/core/history_table_view.py
++++ b/src/core/history_table_view.py
+@@ -14,188 +14,279 @@ class HistoryTableView(QtWidgets.QTableView):
+     @thread_check(True)
+     def __init__(self, *args):
+         super().__init__(*args)
+-        self.setObjectName('history table')
+-        self.setSelectionMode(QtWidgets.QAbstractItemView.SingleSelection)
+-        self.horizontalHeader().setStretchLastSection(True)
+-        self.horizontalHeader().hide()
+-        self.verticalHeader().hide()
+-        self.setModel(HistoryTableModel(self))
...

...在此部分输出中,它将第一次提交中的文件 history_table_view.py 与第二次提交中的相同文件进行比较。

上述所有行都存在于两个文件中。那么为什么这一行

+     def __init__(self, *args):    

以一个简单的“+”开头,而这一行

+-        self.setObjectName('history table')

以“+-”开头?这是什么意思?正如我所说,这两行在该文件的两个版本中都存在。我原则上希望 agit diff不会显示任何这些行(尽管在包含文本的行之间,空行方面存在一些差异)。

其次,当我看到一个简单的介绍git diff,比如这个,演示者在git diff两次提交时做了一个,在视频的 4:40 处我们看到了输出……但在这种情况下,他看到的不是行首的双符号,而是简单的“+”或“-”,也就是说,据我所知,这就是在diff两个文件之间执行 BASH 命令时可能出现的。我想要的就是这种简单的格式。

我怀疑可能有其他方法可以替代git diff“组合格式”,确实能产生这种更简单的输出,但我一直没找到。其次,我上面提到的视频是7个月前制作的:为什么那个Youtube用户在比较两个提交时默认得到的是简单的git输出(对我来说完全可以理解),而我得到的却是(对我来说)难以理解的输出?我的git版本是:

git version 2.48.1.windows.1

一个简单的链接,指向一个页面,它git diff用清晰的术语真正解释了比较两个提交的具体操作,并且关键地展示了如何获得一个简单的diff,这或许就是我需要的。我搜索了很久,却没有找到。

稍后。
请问 daoh-nvohter 能否解释一下为什么这个问题不值得问?

git
  • 1 个回答
  • 49 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve