如何使用分类器访问jar?

时间:2014-06-10 16:10:07

标签: java scala maven jar sbt

我有一个maven项目,可以将两个jar作为工件构建。版本号为0.7,一个工件以“默认”方式构建,第二个具有分类器。因此,在我的存储库中,它们看起来像这样:

Tue Jun 10 08:06:12 MST 2014    14915   gokenizer-0.7.pom   
Tue Jun 10 08:06:12 MST 2014    40  gokenizer-0.7-core.jar.sha1 
Tue Jun 10 08:06:12 MST 2014    40  gokenizer-0.7.pom.sha1  
Tue Jun 10 08:06:12 MST 2014    32  gokenizer-0.7.jar.md5   
Tue Jun 10 08:06:12 MST 2014    32  gokenizer-0.7.pom.md5   
Tue Jun 10 08:06:12 MST 2014    37969843    gokenizer-0.7.jar   
Tue Jun 10 08:06:12 MST 2014    41887392    gokenizer-0.7-core.jar  
Tue Jun 10 08:06:12 MST 2014    32  gokenizer-0.7-core.jar.md5  
Tue Jun 10 08:06:12 MST 2014    40  gokenizer-0.7.jar.sha1

如您所见,具有分类器的jar具有“核心”作为其分类器。

存储库的路径是:

http://myhostname/plugin/repository/project/DomainIQCore/LastSuccessful/repository/com/example/domain/gokenizer/0.7/

一切都好吗?那么在构建项目时,如何实际指定我想要带有“核心”分类器的jar?

在我的build.scala文件中,我尝试了这个:

  libraryDependencies ++= Seq(
    "com.example.domain" % "gokenizer" % "0.7" % "core"
  ),

但后来我收到了这个错误:

java.lang.IllegalArgumentException: Cannot add dependency 'com.example.domain#gokenizer;0.7' to configuration 'core' of module com.example#domainiq_2.10;0.1.0-SNAPSHOT because this configuration doesn't exist!

当我尝试这个时:

  libraryDependencies ++= Seq(
    "com.example.domain" % "gokenizer" % "0.7-core"
  ),

它显然错误地构建了存储库的路径:

http://myhostname/plugin/repository/project/DomainIQCore/LastSuccessful/repository/com/example/domain/gokenizer/0.7-core/gokenizer-0.7-core.pom

显然我必须做错事。我认为第一种方式(以第4个字段为“核心”)是方式,但我不知道“因为这个配置不存在”意味着什么。既然它似乎甚至没有试图进入存储库,似乎我必须告诉SBT“核心”是什么意思?这对我来说没有意义,因为我认为它只是路径的一部分,而不是“配置”。

当我删除第4个字段时,它正确获取了jar的非分类器版本,所以我知道存储库在那里并正在工作......

帮助?

1 个答案:

答案 0 :(得分:1)

当然,一如既往,发布问题并找到答案;)

多次说“分类器”让我在Great Google Machine上尝试不同的搜索,这让我得到了答案。

        "com.example.domain" % "gokenizer" % "0.7" classifier "core"

不是百分号。 “分类器”作为关键字。我不知道。现在它编译。<​​/ p>