回答:
build-helperを使用して、新しいソースディレクトリを追加できます。
<build>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<executions>
<execution>
<phase>generate-sources</phase>
<goals>
<goal>add-source</goal>
</goals>
<configuration>
<sources>
<source>src/main/generated</source>
</sources>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
plugin
要素は含まれているの/project/build/plugins
ではなく/project/build/pluginManagement/plugins
m2e connector for build-helper-maven-plugin
、Eclipseマーケットプレイスからインストールしてpom.xmlのエラーを削除することをお勧めします
'build.plugins.plugin.version' for org.codehaus.mojo:build-helper-maven-plugin is missing
内に追加する必要があるような警告を受け取った場合<plugin>
<version>1.12</version>
私は単純にこのようにします:
<build>
<finalName>osmwse</finalName>
<sourceDirectory>src/main/java, src/interfaces, src/services</sourceDirectory>
</build>
これは私のために働いた
<build>
<sourceDirectory>.</sourceDirectory>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<includes>
<include>src/main/java/**/*.java</include>
<include>src/main2/java/**/*.java</include>
</includes>
</configuration>
</plugin>
</plugins>
</build>
sourceDirectory
場合によっては追加sources
-を想定しているため、このような良い考えはありません。あなたのソリューションでmaven-compiler-plugin
は、これらが実際のルートを認識する唯一のプラグインです。
intelliJで機能させるには、
<generatedSourcesDirectory>src/main/generated</generatedSourcesDirectory>
maven-compiler-pluginへ
これは、resourcesタグを定義することにより、mavenでも機能します。srcフォルダーには、好きな名前を付けることができます。
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.java</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.java</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
</resource>
<resource>
<directory>src/main/generated</directory>
<includes>
<include>**/*.java</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
Resources are not (usually) code. They are not compiled
これはmaven 3.5.4で機能し、Intellij Ideaはこのコードをソースとして表示します。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.3</version>
<configuration>
<generatedSourcesDirectory>src/main/generated</generatedSourcesDirectory>
</configuration>
</plugin>
投稿のbuild-helper-maven-pluginを使用し、src / main / generatedを更新しました。また、mvn clean compileは../common/src/main/javaまたは../commonで機能するため、後者を維持します。その後、そうです。DavidPhillipsが言及したように、IntelliJ IDEA(バージョン10.5.2)レベルのコンパイルが失敗したことを確認します。問題は、IDEAがプロジェクトに別のソースルートを追加しなかったことでした。手動で追加すると問題が解決しました。IDEAのプロジェクトオプションを直接編集するのではなく、プロジェクトのすべてを編集するのはmavenから行う必要があるため、これは良くありません。それでも、ソースが自動的に追加されるようにbuild-helper-maven-pluginを直接サポートするまでは、私はそれと共存できます。
次に、これを機能させるために別の回避策が必要でした。IDEAがpomの変更後にMaven設定を再インポートするたびに、新しく追加したソースがモジュールに保持されていましたが、ソースフォルダーの選択が失われ、役に立たなくなりました。IDEAの場合-これらを一度設定する必要があります:
現在、これらのフォルダをインポート時に保持することは、世界でもベストプラクティスではありませんが、試してみてください。
構成では、を使用できます<compileSourceRoots>
。
oal: org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-cli)
[DEBUG] Style: Regular
[DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
<configuration>
<basedir default-value="${basedir}"/>
<buildDirectory default-value="${project.build.directory}"/>
<compilePath default-value="${project.compileClasspathElements}"/>
<compileSourceRoots default-value="${project.compileSourceRoots}"/>
<compilerId default-value="javac">${maven.compiler.compilerId}</compilerId>
<compilerReuseStrategy default-value="${reuseCreated}">${maven.compiler.compilerReuseStrategy}</compilerReuseStrategy>
<compilerVersion>${maven.compiler.compilerVersion}</compilerVersion>
<debug default-value="true">${maven.compiler.debug}</debug>
<debuglevel>${maven.compiler.debuglevel}</debuglevel>
<encoding default-value="${project.build.sourceEncoding}">${encoding}</encoding>
<executable>${maven.compiler.executable}</executable>
<failOnError default-value="true">${maven.compiler.failOnError}</failOnError>
<failOnWarning default-value="false">${maven.compiler.failOnWarning}</failOnWarning>
<forceJavacCompilerUse default-value="false">${maven.compiler.forceJavacCompilerUse}</forceJavacCompilerUse>
<fork default-value="false">${maven.compiler.fork}</fork>
<generatedSourcesDirectory default-value="${project.build.directory}/generated-sources/annotations"/>
<maxmem>${maven.compiler.maxmem}</maxmem>
<meminitial>${maven.compiler.meminitial}</meminitial>
<mojoExecution default-value="${mojoExecution}"/>
<optimize default-value="false">${maven.compiler.optimize}</optimize>
<outputDirectory default-value="${project.build.outputDirectory}"/>
<parameters default-value="false">${maven.compiler.parameters}</parameters>
<project default-value="${project}"/>
<projectArtifact default-value="${project.artifact}"/>
<release>${maven.compiler.release}</release>
<session default-value="${session}"/>
<showDeprecation default-value="false">${maven.compiler.showDeprecation}</showDeprecation>
<showWarnings default-value="false">${maven.compiler.showWarnings}</showWarnings>
<skipMain>${maven.main.skip}</skipMain>
<skipMultiThreadWarning default-value="false">${maven.compiler.skipMultiThreadWarning}</skipMultiThreadWarning>
<source default-value="1.6">${maven.compiler.source}</source>
<staleMillis default-value="0">${lastModGranularityMs}</staleMillis>
<target default-value="1.6">${maven.compiler.target}</target>
<useIncrementalCompilation default-value="true">${maven.compiler.useIncrementalCompilation}</useIncrementalCompilation>
<verbose default-value="false">${maven.compiler.verbose}</verbose>
</configuration>
これらは、コンパイラプラグインの3.8.1バージョンで使用できるすべての構成です。異なるバージョンには異なる構成があり-X
、一般的なmvnコマンドの後にコードを実行することで見つけることができます。お気に入り
mvn clean install -X
mvn compiler:compile -X
そして、ID、ゴール、またはプラグイン名で検索します。これは他のプラグインにも役立ちます。Eclipse、intelliJはすべての構成を提案として表示しない場合があります。