9

I'm a .NET developer who needs to use the Java platform for a new project.

"Solutions" are a useful Visual Studio concept. How do I break my Java solution into "projects" (I guess Java packages) which have build interdependencies in the same source control repository?

We're planning to use Maven for third-party dependencies, and Scala for writing some of the libraries.

We also need to be IDE-independent.

Recommendations gratefully received!

Edit: Let us assume the solution will contain a web application, a console application, and a library written in Scala.

4

7 回答 7

10

我建立了一个类似的模型,你可以学习。

通过使用 Maven,它将尽可能地与 IDE 无关。您不必在 VCS 中存储任何特定的 IDE 设置,只需存储源代码和 pom 文件即可。每个开发人员将启动他的 IDE 并指向顶部的 pom,并且项目应该加载。将创建本地设置,但在提交到 VCS 时应忽略。

首先,多模块 Maven 项目的布局肯定与 C# 解决方案及其项目非常相似。具有 parent-pom 的顶级文件夹将类似于具有共享配置和构建顺序等的解决方案。然后具有子 pom 的子文件夹将匹配项目定义与其他项目之间的依赖关系。

directory layout

+- pom.xml
+- scala
| +- pom.xml
| +- src
|   +- main
|     +- scala
+- console
| +- pom.xml
| +- src
|   +- main
|     +- java
+- web
  +- pom.xml
  +- src
    +- main
     +- java
     +- resources
     +- webapp
       +- WEB-INF
         -- web.xml

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.stackoverflow</groupId>
    <artifactId>Q11226363</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>pom</packaging>

    <name>${project.artifactId}-${project.version}</name>

    <properties>
        <scala.version>2.9.2</scala.version>
    </properties>

    <modules>
        <module>scala</module>
        <module>web</module>
        <module>console</module>
    </modules>

    <dependencyManagement>
        <dependencies>
            <!-- Inter-Module dependencies -->
            <dependency>
                <groupId>com.stackoverflow</groupId>
                <artifactId>Q11226363-scala</artifactId>
                <version>${project.version}</version>
            </dependency>
            <dependency>
                <groupId>org.scala-lang</groupId>
                <artifactId>scala-library</artifactId>
                <version>${scala.version}</version>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <repositories>
        <repository>
            <id>scala-tools.org</id>
            <name>Scala Tools Maven2 Repository</name>
            <url>http://scala-tools.org/repo-releases</url>
        </repository>
    </repositories>
    <pluginRepositories>
        <pluginRepository>
            <id>scala-tools.org</id>
            <name>Scala Tools Maven2 Repository</name>
            <url>http://scala-tools.org/repo-releases</url>
        </pluginRepository>
    </pluginRepositories>

</project>

scala/pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>com.stackoverflow</groupId>
        <artifactId>Q11226363</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <artifactId>Q11226363-scala</artifactId>

    <name>${project.artifactId}-${project.version}</name>

    <dependencies>
        <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-library</artifactId>
        </dependency>
    </dependencies>

    <build>
        <sourceDirectory>src/main/scala</sourceDirectory>

        <plugins>
            <plugin>
                <groupId>org.scala-tools</groupId>
                <artifactId>maven-scala-plugin</artifactId>
                <executions>
                    <execution>
                        <id>compile</id>
                        <goals>
                            <goal>compile</goal>
                        </goals>
                        <phase>compile</phase>
                    </execution>
                    <execution>
                        <id>test-compile</id>
                        <goals>
                            <goal>testCompile</goal>
                        </goals>
                        <phase>test-compile</phase>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

console/pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>com.stackoverflow</groupId>
        <artifactId>Q11226363</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <artifactId>Q11226363-console</artifactId>

    <name>${project.artifactId}-${project.version}</name>

    <dependencies>
        <dependency>
            <groupId>com.stackoverflow</groupId>
            <artifactId>Q11226363-scala</artifactId>
        </dependency>
    </dependencies>

</project>

web/pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>com.stackoverflow</groupId>
        <artifactId>Q11226363</artifactId>
        <version>1.0-SNAPSHOT</version>
    </parent>

    <artifactId>Q11226363-web</artifactId>
    <packaging>war</packaging>

    <name>${project.artifactId}-${project.version}</name>

    <dependencies>
        <dependency>
            <groupId>com.stackoverflow</groupId>
            <artifactId>Q11226363-scala</artifactId>
        </dependency>
    </dependencies>

    <build>
        <finalName>webapp</finalName>

        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.2</version>
            </plugin>
        </plugins>
    </build>

</project>

scala/src/main/scala/com/stackoverflow/Q11226363/ScalaApp.scala

/**
 * @author maba, 2012-06-28
 */
package com.stackoverflow.Q11226363

class ScalaApp {
  def helloScala():String = "Hello from Scala!"
}

console/src/main/java/com/stackoverflow/Q11226363/JavaApp.java

package com.stackoverflow.Q11226363;

/**
 * @author maba, 2012-06-28
 */
public class JavaApp {
    public static void main(String[] args) {
        ScalaApp scalaApp = new ScalaApp();
        System.out.println("Scala says: " + scalaApp.helloScala());
    }
}

这是我测试过的。当然可以对 pom 文件和依赖项进行一些改进,但这是一个好的开始。

如果您查看,web/target您会发现webapp.war其中包含所需的依赖项。

当然可以将所有这些模块拆分并单独构建它们,并且它们之间仍然存在依赖关系,但正如我所说,这是一个很好的起点。

于 2012-06-28T08:53:18.277 回答
2

我个人的方法是同时使用 Maven:

  • 第三方依赖(通常通过 Maven Central)
  • 不同项目之间的相互依赖关系(通常通过本地存储库)

这工作得很好,我相信它是独立于 IDE 的(虽然我只在 Eclipse 上测试过)

笔记:

如果您有一个团队一起处理相同的工件,您将需要某种方式来拥有一个包含它们的共享存储库,尽管这可以通过以下方式非常简单地完成:

  • 将存储库放在共享文件服务器上(请参阅:http ://maven.apache.org/guides/introduction/introduction-to-repositories.html )
  • 在 GitHub 上托管存储库(参见:http ://cemerick.com/2010/08/24/hosting-maven-repos-on-github/ )
于 2012-06-27T12:41:25.160 回答
2

使用gradle,您将创建一个超级项目并将各种模块创建为子项目。从那里,您可以为各种 IDE 创建工作区/项目描述。

由于 gradle 与 Maven 风格的存储库完全兼容,@mikera 对存储库的评论也是有效的。

于 2012-06-27T12:44:41.330 回答
1

在项目结构的根目录中使用一个多模块(pom-packaging)Maven 项目来使用 Maven 构建所有源代码。

然后使用工作区 (Eclipse) 或组 (NetBeans) 来显示您想要使用的项目子集。

于 2012-06-27T12:44:50.710 回答
0

您实际上创建了不同的项目,这些项目将部署为不同的 jar 文件;然后,使用 Maven,可以在需要的地方添加这些依赖项。

Maven 还带来了 IDE 独立性;有针对不同 IDE 的插件。例如与

mvn idea:idea

Maven 自动为 Intellij IDE 创建项目文件。

于 2012-06-27T12:43:33.817 回答
0

您的 C# 解决方案依赖于 Visual Studio,就像 Java 解决方案依赖于它的工具一样。

答案还取决于打包:JAR 用于桌面,WAR 用于 Web,EAR 用于具有 EJB 的企业。

如果您决定朝那个方向发展(例如目录结构等),Maven 会为您提供很多选择。

Eclipse 和 IntelliJ 都会以不同的方式做这件事。IntelliJ 使用了一个我觉得效果很好的模块概念。我更喜欢它而不是 Eclipse;我现在不熟悉它在那个 IDE 中是如何完成的。

于 2012-06-27T12:40:59.207 回答
-1

解决方案是 Visual Studio 而非 .Net 的属性。将来,eclipse 可能会支持解决方案(可能是)。

您可以使用Eclipse中的WORKSPACE概念来模拟解决方案的想法

  1. 创建新工作区
  2. 导入所有项目(确保选中“将项目复制到工作区,以便创建物理副本)
  3. 现在,无论何时打开此工作区,您始终可以看到所有项目。

您还可以使用 Build->Configure Build Path -> Project 和 Add Projects 引用工作区中的其他项目

如果要“从解决方案中排除”,可以通过“关闭项目”在 Eclipse 中执行相同操作

于 2012-06-27T12:44:20.490 回答