我正在使用导入到不同项目中的多个包,这些包包括用于我的业务逻辑的自定义适配器,这些适配器由 lambda 和谷歌云函数以及其他公共(public)包共享。我现在这样做的方式是我出售它们并将它们包含在云功能中。对于可以在虚拟机上编译部署的应用,我都是单独编译的。这对我来说很好,但是,开发这些模块很痛苦。
如果我更新包中的方法签名和名称,我必须将我的更改推送到 github/gitlab(我的包路径类似于 gitlab.com/groupName/projectName/pkg/packageName),然后执行 go get -u <pacakgeName> 以更新包。
这也并没有真正更新它,有时会卡在旧版本上而不知道如何更新它。我想知道有没有更简单的方法来处理这个问题。
为了清楚起见:
导出包1 路径:gitlab.com/some/name/group/pkg/clients/psql
psql-client
|
|_ pkg
|
|_psql.go
应用程序 1 使用 psql-client 路径:gitlab.com/some/name/app1
应用2使用psql-client 路径:gitlab.com/some/name/app2
最佳答案
我的理解是 (a) 您正在使用 new Go modules system ,并且 (b) 部分问题是,当您进行本地开发时,您不想在不同的存储库中不断将更改推送到 github 或 gitlab。
换句话说,如果您在本地进行更改,听起来您不想通过 github/gitlab 往返这些更改,以便这些更改在您在本地处理的相关存储库中可见.
最重要的建议
在单个存储库中有 > 1 个模块会使您的工作流程变得非常复杂。
如您的示例所示,一般来说,在单个存储库中拥有 > 1 个模块几乎总是需要持续进行更多工作。也很难做到正确。对于大多数人来说,成本几乎总是不值得的。此外,好处通常不是人们所期望的,或者在某些情况下,在 repo 协议(protocol)中拥有 > 1 个模块没有实际好处。
我肯定会建议您遵循通常遵循的“1 个代码库 == 1 个模块”规则,至少现在是这样。 This answer有关于原因的更多详细信息。
使用多个存储库
鉴于您正在使用 Go 模块,一种方法是您可以将 replace 指令添加到模块的 go.mod 文件中,该文件通知 Go 模块关于磁盘上的其他 Go 模块的位置。
示例结构
例如,如果您有三个存储库 repo1、repo2、repo3,您可以克隆它们,以便它们都坐在一起本地磁盘上的其他:
myproject/
├── repo1
├── repo2
└── repo3
然后,如果 repo1 依赖于 repo2 和 repo3,你可以设置 go.mod 文件repo1 了解其他两个模块在磁盘上的相对位置:
repo1 go.mod:
replace github.com/me/repo2 => ../repo2
replace github.com/me/repo3 => ../repo3
当您在 repo1 目录或其任何子目录中时,go 命令如 go build 或 go test ./.... 将使用 repo2 和 repo3 的磁盘版本。
repo2 go.mod:
如果repo2依赖于repo3,你还可以设置:
replace github.com/me/repo3 => ../repo3
repo3 go.mod:
例如,如果 repo3 不依赖于 repo1 或 repo2,那么您不需要添加 replace 到它的 go.mod。
其他详细信息
replace 指令在 replace FAQ 中有更详细的介绍。在模块 wiki 上。
最后,这取决于您的具体用例,但此时常见的解决方案是使用 gohack ,它会自动执行此过程的一部分。特别是,它会创建依赖项的可变副本(默认情况下在 $HOME/gohack 中,但位置由 $GOHACK 变量控制)。 gohack 还将您当前的 go.mod 文件设置为 replace指向该可变副本的指令。
关于go - 有没有更简单的方法来更新本地 Go 包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57415724/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个奇怪的问题:我在rvm上安装了rubyonrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(