Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

IntelliJ gradle add module dependency

Using IntelliJ 2016.2.
Using Gradle 2.14.1

I have 2 projects, each with their own build.gradle files and separate directory structures:

myLib (meant to be jarred and used by others)   - build.gradle   - settings.gradle   - src/main/java/...  sandbox (spring boot web app)   - build.gradle   - settings.gradle   - src/main/java/...   - src/main/resources/... 

Hopefully, you get the picture. Within IntelliJ, I have the following module structure, at the same level (no subprojects):

- myLib - sandbox 

Simple request ... I want to use myLib within the sandbox app. I want both modules in the same project in order to develop both.

I've tried adding a module dependency to sandbox for myLib within IntelliJ. No dice. I've tried adding a jar reference, no dice.

I believe I need to add a dependency in the build.gradle file but cannot figure out how. I've tried compile files '<path to myLib.jar>', etc. No dice.

like image 836
emiles Avatar asked Aug 10 '16 15:08

emiles


People also ask

How do I specify a module in IntelliJ?

Select the top-level directory in the Project tool window and press Alt+Insert or select New | Module from the context menu. The New Module wizard opens. From the list on the left, select a module type. Name the new module.

How do I get Gradle dependency tree in IntelliJ?

To view Gradle dependencies as a diagram, click on the Show Dependencies icon on the Gradle tool window toolbar or use the shortcut Alt+Shift+Ctrl+U on Linux and Windows / Alt+Shift+Cmd+U on macOS.


2 Answers

Local Modules

This is a pattern followed by most Gradle projects where there is a library, then a sample app that uses that library - ref Gradle docs

 - app/     - build.gradle     - src/main/java  # where your main class would be   - library/     - build.gradle     - src/main/java  # dependencies of the app module   - settings.gradle  - build.gradle 

In that top-level settings.gradle you have

include ':library', ':app' 

And in the app/build.gradle, you compile that included project

dependencies {     compile project(':library') } 

Basically, the top-level build.gradle, is a wrapper for all common configs of the sub projects and variables. For example, it's most commonly used for a repositories { } section for Maven urls, for example. Full details on that are at Gradle - Multi-project builds

Remotes Modules

The above is fine for working locally, but let's say you wanted to share your repo with many other developers without making them download extra source code. Then your would publish the other libraries to a remote server.

This is what you already doing when you add these lines to your project

implementation("org:artifact:version") 

If your projects are public on GitHub, use a service like jitpack.io. You can also setup an account on Bintray OSS or Maven Central to have your libraries be available like most others.

If your projects are private within your company, you will need some Maven type server, whether that is a generic web server, or Nexus or Artifactory, you can add that with an addition to the repositories block.

repositories {     maven { url "http://some.maven.site/" } } 

Then add the compile or implementation sources, as normal

like image 51
OneCricketeer Avatar answered Oct 08 '22 14:10

OneCricketeer


Finally Gradle 3.1 has sorted out this issue. Composite builds are now supported natively. More here. In short add this line to sandbox settings.gradle file-

includeBuild '<PATH>/myLib' 

If you can't upgrade Gradle, then the only hope for you is to publish mylib artifact to local maven repo and add mavenLocal() to sandbox/build.gradle.

like image 20
darwinbaisa Avatar answered Oct 08 '22 16:10

darwinbaisa