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
    • 最新
    • 标签
主页 / unix / 问题 / 750901
Accepted
jian
jian
Asked: 2023-07-07 21:53:53 +0800 CST2023-07-07 21:53:53 +0800 CST 2023-07-07 21:53:53 +0800 CST

创建新的 git 分支时自动化

  • 772

https://wiki.postgresql.org/wiki/Working_with_Git#Using_git_hooks
我想快速测试我的想法(快速失败)。
所以无论我改变什么,都致力于当地分支机构。然后我使用切换到一个新分支

git checkout -b test1

我可以快速获取本地最新版本和远程版本(主分支),然后进行新的更改。

如何使用 git hooks 自动执行此操作。


https://postgresql.life/post/andrey_borodin/

我认为我所做的是一种反模式。我在 $HOME 目录下有 postgres0、postgres1、postgres2…postgresE、postgresF、postgres10…每当我不明白我在 postgresX 中更改的内容时 - 我会执行 git clone https://github.com/postgres/postgres postgresX+ 1。

是的,我知道 git 的发明是有原因的。但要给分支命名,我至少需要对更改的目的有一个微妙的了解。

基本上,当我创建新分支时,我可以自动获取最新的遥控器。但是在我切换之前如果旧分支没有提交,旧分支会丢失吗?(所以我需要防止这种情况发生)。


我想确保每次使用“git checkout -b”时,新分支的本地内容与最新的远程内容一样新鲜。(这意味着稍后当我进行一些更改或破坏某些内容时,这都是我的错)而且,前一个分支的更改仍然存在。(我想自动化这个)。

git
  • 1 1 个回答
  • 49 Views

1 个回答

  • Voted
  1. Best Answer
    icarus
    2023-07-15T01:07:40+08:002023-07-15T01:07:40+08:00

    经过聊天讨论后,我们澄清了 OP 的需求。

    假设上游已提交 R1、R2 和 R3。本地分支 1 有这些(R1、R2、R3)以及一些本地提交 L1 和 L2。

    对远程 (R4) 进行了另一次提交。

    然后在本地创建一个新分支(branch2)并选择。问题是如何使用 git hooks 使branch2相对于远程来说是最新的,实际上是自动执行的git fetch。

    这不适合 git hooks。有人可能会说它也不适合 git 别名,因为在创建分支时不知道远程是否可访问。

    无论如何,所需的命令序列是(假设遥控器被称为传统的origin

    # get the changes from origin/master
    git fetch origin
    # If you want a linear history, with the local changes, create the
    # new branch
    git switch -c branch2
    git rebase origin/master
    

    如果 L1+L2 和 R4 之间存在编辑冲突,它们将在变基中报告并需要修复。

    这将使branch1成为R1-R2-R3-L1-L2,branch2成为R1-R2-R3-R4-L1'-L2'。

    • 1

相关问题

  • 从 GitHub 下载的最短途径

  • 如何从 git 版本服务器获取修改后的文件(之前和之后)?

  • 如何让 git 单独选择当前目录中的 txt 文件

  • 无法使用 git 克隆 https 网址

  • git:仅在 GUI 中使用视觉差异(融合)

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve