-
Notifications
You must be signed in to change notification settings - Fork 446
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to handle extra classpath from generated code #177
Comments
Are you using Maven or Gradle? Could you please attach a sample project? |
@minkyn ping. See previous comment |
I have the same problem when using Maven to generate protocol buffer sources. Source files are generated like so in the pom: <plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>3.0.1</version>
<executions>
<execution>
<id>unpack-proto-dependencies</id>
<phase>generate-sources</phase>
<goals>
<goal>unpack-dependencies</goal>
</goals>
<configuration>
<includeArtifactIds>artifact-name-here</includeArtifactIds>
<excludeTransitive>true</excludeTransitive>
<overWrite>true</overWrite>
<outputDirectory>${project.build.directory}/generated-sources/proto</outputDirectory>
<overWriteReleases>true</overWriteReleases>
<overWriteSnapshots>true</overWriteSnapshots>
</configuration>
</execution>
</executions>
</plugin> we event try to add it to the test class path like so (not needed for <plugin>
<!-- a hint for IDE's to add the java sources to the classpath -->
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>3.0.0</version>
<executions>
<execution>
<id>01-add-test-sources</id>
<phase>generate-test-sources</phase>
<goals>
<goal>add-test-source</goal>
</goals>
<configuration>
<sources>
<source>${project.build.directory}/generated-sources/protobuf/java</source>
</sources>
</configuration>
</execution>
</executions>
</plugin> |
The problem is compounded by interaction with #322. Since I often need to close VSCode to get tests to run, the classpath gets messed up often. |
There seems to be support specifically for |
Same here. We generate Pojos for XML schemas using the jaxb2-maven-plugin. By default does classes are placed in Is there a chance to add a classpath by hand in VC code? |
@fbricon Any comments on the above? I have this work project that places a few packages inside |
Hello, Any hope this issue gets addressed? It prevents to use java-templating plugin, CXF plugins, and a bunch of other plugins. Thanks a lot for the hard work, |
Sure, we'll investigate this in the near feature. Can't commit to a timeframe though. |
Guys, if you want to make sure your use case is covered eventually, please add some small sample projects using various maven plugins contributing source folders. |
@fbricon here it is https://github.com/rmannibucau/generated-sources-demo, just try to code/compile in Main.java through vscode (works in CLI), it will miss the two generated folder created by java-templating and wadl cxf plugin. |
@rmannibucau I cloned it, ran a CLI build, opened vscode, the source folders have been added to the classpath automatically: <?xml version="1.0" encoding="UTF-8"?>
<classpath>
<classpathentry kind="src" output="target/classes" path="src/main/java">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="src" output="target/classes" path="target/generated-sources/java-templates">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="src" output="target/classes" path="target/generated/src/main/java">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="src" output="target/test-classes" path="src/test/java">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
<attribute name="test" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8">
<attributes>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
<attributes>
<attribute name="maven.pomderived" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="src" path="target/generated-sources/annotations">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
<attribute name="ignore_optional_problems" value="true"/>
<attribute name="m2e-apt" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="src" output="target/test-classes" path="target/generated-test-sources/test-annotations">
<attributes>
<attribute name="optional" value="true"/>
<attribute name="maven.pomderived" value="true"/>
<attribute name="ignore_optional_problems" value="true"/>
<attribute name="m2e-apt" value="true"/>
<attribute name="test" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="output" path="target/classes"/>
</classpath> |
Hmm, does it mean it needs m2 lifecycle mapping plugin? Or do you use a dev version? |
for the sources to be regenerated on incremental build, an m2e lifecycle mapping/connector would need to be required yes. |
I seem to have a slightly different issue, but related, I think. I'm not a Java developer and my Java/Maven knowledge is very limited. But my team inherited this Java project which we'll be working on the frontend side only. The project works fine with IntelliJ and we can use that to work on the project but I'm trying to setup this with VS Code cause it's our editor of choice for frontend. The problem is that this Java project is configured with an internal Maven plugin that generates sources (so I can't post a sample project) and places them at Maybe the issue here is that the generated sources come from a custom internal plugin and not something like I was able to workaround it with something like this: <plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>3.0.0</version>
<executions>
<execution>
<id>addSource</id>
<phase>generate-sources</phase>
<goals>
<goal>add-source</goal>
</goals>
<configuration>
<sources>
<source>${project.basedir}/target/generated-sources/java</source>
</sources>
</configuration>
</execution>
</executions>
</plugin> But it would be much better if, somehow, this plugin could pick whatever is at |
No it's not a standard folder. Multiple plugins generate different content in subdirectories of ${project.basedir}/target/generated-sources. Having 2 plugins writing content to the same directory (target/generated-sources/java) might cause some issues (one plugin overwriting the other one's output) |
This is a common default for annotation processors but not for generating sources plugin so nothing better than adding a source folder in vscode or supporting lifecycle mapping - but not sure it is that great to use eclipse here :s |
Not sure what you mean by this, but I only have 1 plugin writing content to |
Similar issue here. We do a <plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>3.0.0</version>
<executions>
<execution>
<id>add-integration-test-source</id>
<phase>generate-test-sources</phase>
<goals>
<goal>add-test-source</goal>
</goals>
<configuration>
<sources>
<source>src/integration-test/java</source>
</sources>
</configuration>
</execution>
<execution>
<id>add-integration-test-resource</id>
<phase>generate-test-resources</phase>
<goals>
<goal>add-test-resource</goal>
</goals>
<configuration>
<resources>
<resource>
<directory>src/integration-test/resources</directory>
</resource>
</resources>
</configuration>
</execution>
</executions>
</plugin> When trying to run/debug tests from within VSCode that fall under |
Same issue with Apache NiFi: https://github.com/apache/nifi
It ends up putting generated sources in |
I was rereading the thread and found out, this was actually working for @rfgamaral. I looked more into it and noticed the error messages are looking more like this: #551. The actual issue was interference of a linting plugin, that wasn't aware of the generated sources. (Also I'm using the <plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<executions>
<execution>
<id>generated-folder</id>
<goals>
<goal>add-source</goal>
</goals>
<configuration>
<sources>
<source>${basedir}/src-gen/main/java</source>
</sources>
</configuration>
</execution>
</executions>
</plugin> |
@fbricon Here is a grpc example: https://github.com/jackielii/grpc-java-example The problem I see is not that the generated sources are not added in the .classpath, but the grpc files are not generated. Whenever I re-open the project, it removes the generated sources... |
This issue is causing one of my team members to move off of VS Code as well. We are using the gRPC protobuf plugin which places generated files here: |
same here, with gradle google protobuf plugin, the generated folder is no way to recognized |
Same here with auto-generated jooq sources. Manually editing |
Hi all. I'm having the same issues this GWT, that generates some classes and puts it in
But apparently vscode doesn't add anything in the A working demo can be found at https://github.com/lorthirk/kapua/tree/change-generatedSourcesMaven/console |
I experience the same problem, when generating sources for a GraphQL-project (via |
@tim-hilt please attach a sample project reproducing the issue |
Otherwise vscode complains about undefined symbols, see redhat-developer/vscode-java#177 (comment)
Solved!
It is a great clue. However, the
|
Not to add clutter to this issue, but I also cannot come up with a workaround for my gradle project. I have one generated source code folder and I would like to add it as a one off, but I don't want to mess up any of the other auto class path generation. Lots of talk about Maven but not much about gradle :/ This is an existing intellij project that I really want to run in vs code because I love vs code 😭 |
Problem also occurs when using javaCC, even when m2e execution hint is added to pom.xml. <plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>javacc-maven-plugin</artifactId>
<version>3.0.1</version>
<executions>
<execution>
<?m2e execute onConfiguration,onIncremental?>
<goals>
<goal>javacc</goal>
</goals>
</execution>
</executions>
<configuration>
<!-- See usage on maven site from link above for details -->
</configuration>
</plugin>
<plugin>
<!-- a hint for IDE's to add the java sources to the classpath -->
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>3.0.0</version>
<executions>
<execution>
<?m2e execute onConfiguration,onIncremental?>
<id>add-sources</id>
<phase>generate-sources</phase>
<goals>
<goal>add-source</goal>
</goals>
<configuration>
<sources>
<source>${project.build.directory}/generated-sources/javacc/</source>
</sources>
</configuration>
</execution>
<execution>
<?m2e execute onConfiguration,onIncremental?>
<id>add-test-sources</id>
<phase>generate-test-sources</phase>
<goals>
<goal>add-test-source</goal>
</goals>
<configuration>
<sources>
<source>${project.build.directory}/generated-sources/javacc/</source>
</sources>
</configuration>
</execution>
</executions>
</plugin> |
Still completely broken |
I found a workaround using this sample repo: https://github.com/jackielii/grpc-java-example. Using coc.nvim, in CocLocalConfig or global one, set:
This will disable There should be a similar option in vscode-java as coc-java is forked from this. |
I'd like to reference this comment with a repro project. The generated sources are correctly generated by vscode but cannot be referenced in user code. |
Same issue here - was using VScode just fine until a new dependency wrote to |
The main thing i wanted to resolve was getting the tests to be able to run individually within the vscode ide
I found this helpful too, I think it helps with some vs-code server logic with working out how to package the classes in generated-sources with a snippet from pom
This was a useful resource to collate the discussion topics on this issue |
I'm using Google's AutoValue and Protocol Buffer, both which generate source code under build/generated/source/.... However, each time I start vscode, this java plugin would automatically create a new .classpath file that overrides my manual edit.
Is the plugin going to handle the generated source code? Is there a workaround for now? Thanks.
The text was updated successfully, but these errors were encountered: