- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有时我会找到 monorepo GitHub 上有多个 npm 包,我想对其进行一些修改并在我的项目中使用。但是 npm 从 git 子目录安装包比从 git 存储库安装包要难得多[ 1 ][ 2 ]。由于我会自己进行修改,我想知道如何设置自己的 git 存储库,以便 npm 易于安装,并便于我 merge 上游更改。
目前,我使用 this guide从 GitHub 将包从 monorepo 的其余部分拆分出来,即
git filter-branch --prune-empty --subdirectory-filter FOLDER-NAME BRANCH-NAME
Npm 可以轻松安装 repo,但我发现很难 merge 任何上游更改。
有人做过吗?有什么想法吗?
最佳答案
实际上,我想我错过了一些东西 - merge 上游更改并不像我想象的那么难,因为 git subtree split 是确定性的,即无论该过程重复多少次,它都会为相同的子树拆分生成相同的 SHA1。
所以这是我的解决方案:
将默认分支 (master) 重命名为其他名称,例如上游
git checkout master
git branch -m upstream
从monorepo中拆分子目录
git checkout upstream
git subtree split -P <subdirectory path> -b master
现在我们有一个主分支,其中只有与子目录路径相关的提交。
(可选)设置master分支的远程并推送到GitHub。
现在如果上游 monorepo 添加了一些更改:
检查上游分支并 pull 更改
git checkout upstream
git pull
再次 split
git subtree split -P <subdirectory path> -b upstream-patch
查看修订图,您会看到新分支(upstream-patch)与master相关。
gitk master upstream-patch
现在只需将新分支 merge 到master
git checkout master
git merge upstream-patch
手动解决任何 merge 冲突。
关于git - 如何 fork monorepo 的一部分并仍然能够 merge 上游提交?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51414772/
我正在使用 Java 编写一个时钟程序,该程序能够“滴答作响”,但它存在问题。我认为它与 getter 和 setter 或 toString() 方法有关。 计数器类 package clock;
const Index = () => { // Ref Links const frefLinks = { 1: useRef(1), 2: useRef(2), 3: useRef(3
所以我读了here不能 pickle 装饰函数。确实: import multiprocessing as mp def deco(f): def wrapper(*args, **kwarg
我在go1.11.2 linux/amd64 版本。当包godog使用 go get github.com/DATA-DOG/godog/ 安装,godog 可执行文件在 $GOPATH/bin/中创
如何正确压缩字符串,以便 PHP 能够解压缩? 我试过这个: public static byte[] compress(String string) throws IOException {
我们这里的问题是表明 在测试中使用 Kleene 代数。 在 b 的值由 p 保留的情况下,我们有交换条件 bp = pb;两个程序之间的等价性简化为等式 在 b 的值不被 p 保留的情况下,我们有交
我有一个与我的网络相关的非常奇怪的问题,我在具有多个接口(interface)的 VirtualBox 上安装了 RDO Grizzly OpenStack。 虚拟盒子: eth0 - managem
我正在尝试使用 Passport.js授权谷歌OAuth2在 Node.js .我整个星期都在尝试让它工作,但不知道为什么它不工作,所以现在我求助于 stack 寻求一些潜在的帮助。我已经尝试了所有在
我是一名优秀的程序员,十分优秀!