在 Go 项目中使用从别人那里克隆(Fork)出来的项目
今天从 GitHub 克隆了一个别人的 Golang Markdown 项目,作了些修改,想使用自己的版本,发现不行,因为模块的路径不对,导致导入出错。
原来的模块路径和文件(go.mod):
1 2 3 |
|
克隆后的模块路径和文件:
1 2 3 |
|
只是路径变了,go.mod 里面的内容是不变的。
同样,代码里面使用的当前项目的子模块的引用路径肯定也没变。这样一定会导致各种引用混乱。所以当前 Go 语言为什么没有引入导入相对路径的模块?🤔
尝试在测试项目里面使用我自己的克隆版本:
1 2 3 4 5 6 7 |
|
发现会报错:
1 2 3 4 |
|
所以,怎么办?不可能把人家的路径全部给改了吧?
突然想到了 replace
指令。
以前为了引入一个在本地正在开发的模块,经常 replace
路径为本地路径:
replace github.com/movsb/taorm => /Users/tao/code/taorm
实际上 replace 也可以用来替换掉非本地的模块路径。
代码里面导入原来的仓库路径:
1 2 3 4 5 6 7 |
|
在 go.mod
里面 replace 掉。require 原来的,replace 成自己的:
1 2 3 4 5 6 |
|
如果要更新版本,可以把 v1.1.30
换成新版本,或者 git 的提交号(commit-id):
1 2 |
|
如果第二形式编辑器报错,可忽略。然后在终端执行:
1
|
|
参考: