情况是这样的,现在有一个基础包 X,其中 go.mod 类似如下
replace A => B
require A // 包地址已失效
这时候 Y 工程去引用包 X,因为 X 引用了 A,就会去找 A 包,但实际是找不到的,就会报错。这种情况只能手动去添加 Y 工程 go.mod 的 replace 吗? 那如果看不到包 X 的 go.mod 源码岂不是无解了?
研究了小半天,不知道是不是自己没用对
1
lostpg 2020-07-30 21:01:20 +08:00 via Android
确实会导致 X 编译失败吧,解决方法是把 A folk 到本地,手动修改 go.mod ,然后在 X 的 go.mod 中添加 A 的 replace 规则
|
2
Leigg 2020-07-30 21:20:10 +08:00 via Android
编译的时候会爆出来,replace 加到 Y 的 mod
|
3
banishee 2020-07-31 10:53:25 +08:00
我记得 replace 只能在当前的工程生效
|
4
linvon OP |
5
kuro1 2020-07-31 15:03:13 +08:00
这种以来不可靠的场景,可以用 vendor
|
6
linvon OP @kuro1 #5 vendor 也没办法吧,即使 X 包已经打包好了 vendor,但实际 Y 包引用 X 的时候只看它的 require,不看 vendor 也不看 replace,并不会从 X 的 vendor 中加载包而是根据 require 重新拉取,还是会失败
|
7
kuro1 2020-07-31 15:28:30 +08:00
go build -mod=vendor
|
9
kuro1 2020-07-31 16:29:25 +08:00
和 X 的 vendor 有什么关系,所有的依赖都在 Y 的 verdor 下管理,没有用过以前的 govendor ?
|
10
linvon OP @kuro1 #9 那你说的不是同一个问题了。。我说的是 Y 引用 X 时获取 X 的依赖失败,跟 vendor 没关系了
|
11
AmrtaShiva 2020-08-01 22:35:27 +08:00 via iPhone
只能一个一个 clone 到本地 然后 replace
|