我们已经使用 Ivy 几个月了,并且在办公室的 Web 服务器上拥有我们自己托管的“Ivy Repo”。我们所有的项目都配置为转到此 repo 以解决依赖关系。
我们有几个“通用”类型的 JAR,供我们的许多项目使用。正因为如此,并且因为我们只有 1 个 repo 协议(protocol),我们发现来自以下场景的大量丑陋开销:
这对我们的团队来说变得荒谬和痛苦。
对我来说,显而易见的解决方案是在每个项目中提供 ant 目标,允许开发人员在本地发布/解析(到他们的文件系统或从他们的文件系统)。这样他们就可以将 Common jar 打破 9 种方式到星期天,而不会在等待 Common 发布时浪费 2 - 4 天。这样,开发人员对 Project 1 和 Common 都进行了本地更改,并且代码同时通过了我们的升级过程。
我知道 Ivy 可以做到这一点,但我对它太陌生了,我什至不知道从哪里开始。
目前,我们为所有项目使用全局 ivy.settings 文件。在设置文件中,我们使用一个链式解析,其中包含 1 个 url 解析器,它连接到我们的“ivy repo”。
我相信以下是唯一必要的更改,但我不是 100% 确定:
ivy.settings 中,我们需要添加一个本地文件系统解析器 before 调用 url 解析器;通过这种方式,我们在继续使用 ivy 存储库(网络服务器)之前检查本地文件系统的依赖关系ivy.xml本地发布 目标,该目标可以执行上述选项我相信这些更改将使我们能够:(1) 在查找 Web 服务器之前始终在本地查找依赖项,(2) 作为构建选项(目标)在本地发布。
如果这不是真的,或者如果我遗漏了任何步骤,请指教!否则,我可能可以从 Ivy 文档中找出如何添加文件系统解析器,但我不知道如何让 publish-locally 目标工作。有任何想法吗?提前致谢!
最佳答案
我也更喜欢 Marks 方法。
至于publish-locally,您可以告诉发布任务使用哪个解析器(resolver="local")。这样它就可以发布到本地文件系统或任何定义的解析器。
<ivy:publish
resolver="local"
overwrite="true"
revision="${project.version}">
<artifacts pattern="dist/[artifact]-[revision].[type]" />
</ivy:publish>
如果您使用链式解析器,您应该设置 returnFirst="true" 以便在本地找到某些内容时解析将停止。
关于java - Ivy:在本地解析和发布 JAR,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8865187/
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在使用ruby1.9解析以下带有MacRoman字符的csv文件#encoding:ISO-8859-1#csv_parse.csvName,main-dialogue"Marceu","Giveittohimóhe,hiswife."我做了以下解析。require'csv'input_string=File.read("../csv_parse.rb").force_encoding("ISO-8859-1").encode("UTF-8")#=>"Name,main-dialogue\r\n\"Marceu\",\"Giveittohim\x97he,hiswife.\"\
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht