13

我有一种情况,我需要一个包含 Java 源的文件夹,用作树结构中几个“彼此相邻”的 maven 项目的源文件夹。由于 maven 项目的依赖差异,我无法创建包含源代码编译版本的工件,但需要让每个项目除了 src/main/java 之外将其视为源文件夹。

显然 Maven 可以通过添加位于“../foo/src”中的另一个源文件夹来轻松地做到这一点,但 m2e 拒绝这样做,并且为了对我们很好地工作,我需要让它在 Eclipse 中工作。

我将如何拥有这样的结构:

/common/src
/a/pom.xml  (add source folder ../common/src)
/a/src/main/java/...
/b/pom.xml  (add source folder ../common/src)
/b/src/main/java/....

并让它在 Eclipse 中工作?

(注意:我知道http://dev.eclipse.org/mhonarc/lists/m2e-users/msg01988.html - 但是,它是从 2011 年开始的)

4

6 回答 6

10

你不应该那样做。

如果您想在不同的模块中使用该代码,那么它也应该是一个 Maven 模块,用作其他模块的依赖项。

您尝试做的主要问题是,即使它不是两个模块之间源的实际复制/粘贴,最终它的行为就像一个。一旦你建立了两个罐子会发生什么?你会有重复的类,所以如果你在同一个应用程序中使用它们,类路径会有点错误。

那么,你想要完成的究竟是什么?

  • 在两个不同的模块中重用一些代码?然后将其用作依赖jar。
  • 在两个不同的模块中重用代码,但您不想以多个 jar 结尾?然后您可以使用maven-shade-plugin将依赖项嵌入到最终工件中。
  • 构建同一个库的两个略有不同的版本?然后,您可以再次使用 maven-shade-plugin 来扩展一个带有其他源的 jar。或者,您可以使用aspectj-maven-plugin将方面注入到一组基本类中。
  • 有一个会触发循环依赖的代码设计,因为模块依赖于公共代码,而公共代码又依赖于每个模块的代码?正确的解决方法是从模块中提取通用 API,该 API 将进入共享依赖项,并由每个模块以不同方式实现。

如果您真的必须将其保留为共享源目录而不是共享依赖项,那么您可以查看这个答案

于 2013-06-01T16:00:03.907 回答
3

文件系统的小技巧怎么样?只需对文件夹进行符号链接,您可能会没事:)

对于 NTFS,您可以尝试mklink从命令行执行。更多解释:http ://en.wikipedia.org/wiki/NTFS_symbolic_link

于 2013-05-31T11:06:34.490 回答
1

为什么不在<dependency />其他项目中简单地将公共库设为 Maven,pom.xml并在依赖项目中使用 m2e 的“解决工作区项目中的依赖项”功能(我相信这是默认设置)(右键单击项目 => 项目属性=> Maven)?

这样,依赖项目将自动在 IDE 中查看公共库的类,而您实际上不必将公共库工件构建/安装到 maven 存储库(本地或远程)。

由于您使用的是 Git,因此分支可能会让您轻松提供公共库的不同版本(版本与 pom.xml 中的版本相同),并在相关项目的<dependency />元素中相应地引用这些版本。

于 2013-06-03T20:25:36.020 回答
1

您应该能够使用相对路径和Maven Build Helper作为解决方案。

在每个项目中,或者在它们都继承自的“父”pom.xml 中,添加以下内容:

  <plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>build-helper-maven-plugin</artifactId>
    <version>1.8</version>
    <executions>
      <execution>
        <id>add-source</id>
        <phase>generate-sources</phase>
        <goals>
          <goal>add-source</goal>
        </goals>
        <configuration>
          <sources>
            <source>${basedir}/../../common/src</source>
          </sources>
        </configuration>
      </execution>
    </executions>
  </plugin>
于 2013-05-24T18:05:24.717 回答
1

如果您使用 Subversion,最方便的方法可能是将共享源文件夹保存在单独的存储库中,并将其添加到所有需要它的项目中svn:externals。另一方面,这会使创建标签和分支更加复杂。

Mercurial 子存​​储库可能会实现类似的功能,但不会那么方便。

于 2013-05-31T12:24:44.920 回答
1

我会使用NTFS Junction

我在我的项目中使用它们来在项目之间共享资源,而无需实际复制它们。连接就像驱动器和文件系统之间的黑洞。它们的行为与硬链接相同,但可以引用文件夹,即使在不同的驱动器(包括网络驱动器)上也是如此。从您的角度来看,它看起来就像在您的项目文件夹中有 /common/src 文件夹(然后您可以告诉 Eclipse 将其用作源文件夹)。当然,您可以重命名连接点,以便在 project 中看到 /common/srca将被调用common

/common/src
/a/src
/a/common <- this is a junction to /common/src

为了简化 Junction 的创建,我真的很喜欢使用这个 shell 扩展

于 2013-06-04T08:35:47.223 回答