- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
由于您只有 Scala 之间的源兼容性- 不幸的是你需要编译像 scalatest 这样的库的版本或 scalamock对于他们支持的每个 Scala 版本。令我感到困惑的是,这些库提供了大量 Artifact (scalatest_2.9.0、scalatest_2.9.1、scalatest_2.10 等)——每个 scala 版本都有一个,因此 maven 存储库中散布着许多从构建的 Artifact 同一个来源。我的直觉告诉我,宁愿为每个 Scala 版本使用一个带有分类器的 Artifact 。 (事实上,maven pom reference 提到这有时是用 jdk14 和 jdk15 分类器来完成的,这似乎与我很相似。)那么,为什么 Scala 人会去追求许多人工制品的矫枉过正:-) 呢?
最佳答案
我可能错了,但如果分类器的目的是“区分由相同 POM 构建但内容不同的 Artifact ”,那么我看到了一个很好的理由 不是 将它们用于 scala 版本控制:scala 版本不仅仅是二进制不兼容,它们很可能是 源不兼容 .
例如,当将 scala 从 2.7 升级到 2.8 时,我不得不对代码库进行一些重大更改。如果我想同时保留 Scala 2.7 和 2.8 版本,我将需要创建一个并行分支,并且两个分支肯定不会具有相同的源代码。
当我读到“来自同一个 POM”时,我明白这也意味着来自同一个源代码,这两个代码分支显然不是这种情况。
另一个更重要的原因是分类器本质上是一个单一的字符串,它已经被用于很多事情。或多或少的标准分类器包括“sources”、“javadoc”或“resources”。这些分类器的含义在 scala 项目中是相同的,并且与 scala 版本完全正交,我将尝试展示。
Maven 的文档建议使用诸如“jdk15”或“jdk14”之类的分类器来表示二进制 Artifact 是针对哪个 jvm 版本编译的。
鉴于 java 代码向后兼容,原则上具有两个分类器(“jdk15”或“jdk14”)的 Artifact 是从相同的源代码编译的。这就是为什么你不需要为“源” Artifact 复制分类器,或者换句话说你不要需要有一个名为“sources-jdk14”和“sources-jdk15”的分类器。
但是您不能将相同的基本原理应用于 scala 版本:考虑到您可能需要不同的源代码,无论您是针对 scala 2.7 还是 scala 2.8 进行编译,您确实需要两个不同的具有分类器的 Artifact ,例如“sources-scala2.7”或“源-scala2.8"。所以我们已经有了复合分类器。
至于二进制 Artifact ,您不仅需要区分目标 jvm 版本(请记住,您可以编译 scala 代码以针对不同的 jvm 版本),还需要区分编译它所针对的 scala 版本。所以你最终会得到类似“jdk14-scala2.7”或“jdk14-scala2.8”或“jdk15-scala2.7”或“jdk15-scala2.8”之类的东西。又一组复合分类器。
所以带回家的信息是,scala 版本确实是一种对 Artifact 进行分类的单独方式,它与所有现有的分类器完全正交。
是的,我们真的可以像上面那样使用复合分类器(例如“sources-scala2.7”),但是我们不会使用标准分类器,这本身就足够令人困惑,但还需要修改围绕分类器的所有工具:如果我使用一个不了解 scala(只有 java)但知道如何自动发布“源” Artifact 的构建工具怎么办?我是否需要修改这个构建工具,以便他知道发布一个“sources-scala2.7” Artifact ?另一方面,如果我在(基本) Artifact 名称中对 scala 版本进行编码并将其提供给构建工具,则一切正常,并且我得到一个带有“源”分类器的 Artifact 。
总而言之,与直接直觉相反,在名称中编码 Scala 版本允许 更好 集成到现有的 Java 构建生态系统中。
关于scala - 为什么 Scala Maven Artifact 为每个 Scala 版本都有一个 Artifact ,而不是每个 Scala 版本都有一个分类器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15097600/
对于 Nexus 中的 Artifact ,我想找出类路径,即该 Artifact 是针对哪个 Artifact 的哪个版本构建的。当然,解析pom会给出一些提示,但由于我们有父POM、依赖管理等,这
我想将库部署到公司的远程存储库。 这是我第一次要将库项目部署到远程存储库。 我收到以下错误消息: org.sonatype.aether.transfer.ArtifactNotFoundExcept
在我们的 Artifact 上,我们有POM文件为 commons-lang commons-lang 2.6 4.0.0 commons-lang commons-la
我们使用 Maven 来构建我们的项目,并使用 Nexus 作为存储库管理器。 有没有办法知道一个 Artifact 在哪里是另一个 Artifact 的依赖项? 例如,我们想知道我们的发布存储库中的
我已经重新初始化了我的 pom.xml,但是我得到了: ArtifactDescriptorException: Failed to read artifact descriptor for org.
将maven Android 项目导入eclipse 时出现以下错误: Could not update project assistance configuration me.gladwell.
假设,ArtifactA 依赖于 ArtifactB,ArtifactC 也依赖于 ArtifactB 我知道“mvn dependency plugin”可以帮助列出项目/Artifact 的依赖项
在我的 Maven 构建结束时,一个用于此明确目的的模块从各种其他模块收集 Artifact ,并使用 Assembly 插件将它们压缩到一个存档中。完成后,它会使用 Deploy 插件将它们部署到
我有一个我正在尝试构建的相对较新的项目。 Gradle 同步正常,但每当我尝试构建时,都会收到如下错误: Execution failed for task ':app:kaptGenerateStu
我在 Azure DevOps 中设置了 Gradle 构建,它在 Azure DevOps git 存储库中编译代码,然后将生成的 JAR(作为 Maven Artifact )发布到 Azure
提出这个问题的另一种方式是: 如何验证maven使用 Azure 进行项目 personal access token这样Maven构建就可以下载artifacts发表于Azure Artifacts
提出这个问题的另一种方式是: 如何验证maven使用 Azure 进行项目 personal access token这样Maven构建就可以下载artifacts发表于Azure Artifacts
这与具有类似错误的现有问题有点不同 - 我不认为这是重复的。 我有项目 A,我使用 mvn clean install 在本地成功构建并安装了该项目。 我验证了director中存在jar和pom~/
我有一个包含此存储库的 Artifact 服务器 发布 锁定版本 我必须将一些 Artifact (大约 50.000 个)从版本移至锁定版本... 我需要识别具有精确版本的 Artifact : 例
我正在升级一个拥有 3000 多个 java maven 项目和 repos 的庞大系统,从 Java 7 部署到 Java 8。我们将尝试一次迁移部分系统,这意味着一些 Artifact 会使用 j
所以我遇到了一个错误 Failed to read artifact descriptor对于已部署到我本地 Nexus 的插件。我检查了 Nexus 上的 pom。 这个插件依赖于 Maven 2.
在 Azure DevOps 中,我们有 Download/Publish构建工件任务和 Download/Publish管道工件任务。 构建工件任务和管道工件任务之间有什么区别,我们什么时候会选择一
我有一个由 Maven 管理的原始 java webapp(因此会生成一个 WAR 文件),我们称它为 webapp。 我喜欢保持其 Maven 配置不变,但有时我需要通过操作其内容(或以任何方式对其
我有一个 Artifact abc,它有一些测试。我的存储库中有不同版本的 abc。我现在希望能够针对项目的“旧版本”运行最新的测试。 我试图将 Artifact 本身添加到测试依赖项中,但这(当然)
我目前有一个用 Maven 构建的 Java 测试库,并作为 jar 分发。我的项目依赖于一个非常常见的库 (Objectweb ASM),而且我遇到了一些问题,即类路径中已经存在较早且不兼容的 AS
我是一名优秀的程序员,十分优秀!