How to reference javadocs to dependencies in Maven's eclipse plugin when javadoc not attached to dependency

后端 未结 6 1635
遥遥无期
遥遥无期 2020-11-30 19:31

I use Eclipse, Maven, and Java in my development. I use Maven to download dependencies (jar files and javadoc when available) and Maven\'s eclipse plug-in to generate the .p

相关标签:
6条回答
  • 2020-11-30 20:02

    You might consider just avoiding this problem completely by installing the javadoc jar into your local repository manually using the install-file goal and passing in the -Dclassifier=javadoc option. Once you do that the .classpath that mvn generates should be correct.

    If you use a remote repo as a proxy to central you could also deploy the javadocs to that repo and then everyone else who uses that proxy will now get the javadocs automatically as well.

    0 讨论(0)
  • 2020-11-30 20:06

    I'm running STS 2.8.1 which is basically eclipse + spring tools; In an existing maven project, I right clicked on the project -> maven -> Download Sources and Download JavaDocs

    0 讨论(0)
  • 2020-11-30 20:09

    From the Maven Eclipse Plugin FAQ

    The following example shows how to do this in the command-line:

    mvn eclipse:eclipse -DdownloadSources=true  -DdownloadJavadocs=true 
    

    or in your pom.xml:

    <project>
      [...]
      <build>
        [...]
        <plugins>
          [...]
          <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-eclipse-plugin</artifactId>
            <configuration>
              <downloadSources>true</downloadSources>
              <downloadJavadocs>true</downloadJavadocs>
            </configuration>
          </plugin>
          [...]
        </plugins>
        [...]
      </build>
      [...]
    </project>
    
    0 讨论(0)
  • 2020-11-30 20:21

    Would having the sources for the dependency help? You can tell the eclipse plugin to download those (and refer to them in the .classpath) with -DdownloadSources=true

    0 讨论(0)
  • 2020-11-30 20:24

    Generally Javadocs are not primarily used as dependency . Because these are neither required at compile nor runtime. It’s just to help the developer while developing or debugging.

    Assuming using the java IDE Eclipse we can use the java docs as referenced. Following are the approaches we can associate the javadocs/sources with the respective jars.

    1. If it’s non-maven project :

    Download the javadocs jar or zipped file, whatever available and placed it in some directory. Right click on the application project in the IDE Eclipse, click Properties and choose Java Build Path then select tab Libraries under the Java Build Path. Now expand the jar you want to link with java docs/source. Select the Javadoc location link and click on Edit button, a new window appears where we need to choose the javadocs jar path. Click OK and we have linked the javadoc/source with the respective jars.

    2. If it’s a maven project

    If we are using the Maven project then go to jar files under the Maven dependency under the project in Project Explorer view as shown below. Now right click on the jar file you want to add the Javadoc/source,  choose Maven then click on Javadoc or Source you want to link with the project. Now IDE will automatically download the required javadoc/source and will link it with the respective jar in the project.

    You can verify this by right click on the project in the IDE and click on Java Build Path and select the Libraries tab under the Java Build Path and then expand the desired jar, here when you click the Edit button you will see the linked path of the Javadoc/Source with the respective jar as shown below in the image.

    3. If it’s Maven project and we are setting the default behavior:

    Eclipse will aquatically download the javadoc/source along with the main required jar at the starting. By default setting instruction to Maven to download the Javadoc/sources for all the jars linked in the project.

    Click Windows – preferences – select Maven and click the checkbox Download Artifact Javadoc as shown below

    Now click on apply and save it and now when you create new Maven project , by default the Javadocs will get downloaded and linked with all the dependent jars in the project.
    You can verify by right click on the project and Properties and under Java Build path can see the javadocs are linked with all the jars as shown below.

    If your project is Maven project then It’s always best to use 2nd approach because by using this approach the IDE and Maven, takes care of downloading the correct version of the Javadoc/source and linked it with the relative jar as well.

    Approach 3rd is bit costly because the javadoc/sources will be downloaded for-all the dependent jars, may be you are not interested for javadocs/sources for all the dependent jars.

    0 讨论(0)
  • 2020-11-30 20:27

    As mentioned in How to download sources and javadoc artifacts with Maven Eclipse plugin from other repository?, you can do this:

    In Eclipse go to Windows-> Preferences-> Maven. Check the box that says "Download Artifact Javadoc." That has worked well for me.

    Maven Preferences

    0 讨论(0)
提交回复
热议问题