public abstract class IdeaModule
extends java.lang.Object
Example of use with a blend of most possible properties. Typically you don't have to configure this model directly because Gradle configures it for you.
 plugins {
     id 'java'
     id 'idea'
 }
 //for the sake of this example, let's introduce a 'performanceTestCompile' configuration
 configurations {
   performanceTestCompile
   performanceTestCompile.extendsFrom(testCompile)
 }
 dependencies {
   //performanceTestCompile "some.interesting:dependency:1.0"
 }
 idea {
   //if you want parts of paths in resulting files (*.iml, etc.) to be replaced by variables (Files)
   pathVariables GRADLE_HOME: file('~/cool-software/gradle')
   module {
     //if for some reason you want to add an extra sourceDirs
     sourceDirs += file('some-extra-source-folder')
     //and some extra test source dirs
     testSources.from(file('some-extra-test-dir'))
     //and some extra resource dirs
     resourceDirs += file('some-extra-resource-dir')
     //and some extra test resource dirs
     testResources.from(file('some-extra-test-resource-dir'))
     //and hint to mark some of existing source dirs as generated sources
     generatedSourceDirs += file('some-extra-source-folder')
     //and some extra dirs that should be excluded by IDEA
     excludeDirs += file('some-extra-exclude-dir')
     //if you don't like the name Gradle has chosen
     name = 'some-better-name'
     //if you prefer different output folders
     inheritOutputDirs = false
     outputDir = file('muchBetterOutputDir')
     testOutputDir = file('muchBetterTestOutputDir')
     //if you prefer different SDK than the one inherited from IDEA project
     jdkName = '1.6'
     //put our custom test dependencies onto IDEA's TEST scope
     scopes.TEST.plus += [ configurations.performanceTestCompile ]
     //if 'content root' (as IDEA calls it) of the module is different
     contentRoot = file('my-module-content-root')
     //if you love browsing Javadoc
     downloadJavadoc = true
     //and hate reading sources :)
     downloadSources = false
   }
 }
 
 For tackling edge cases, users can perform advanced configuration on the resulting XML file.
 It is also possible to affect the way the IDEA plugin merges the existing configuration
 via beforeMerged and whenMerged closures.
 
 beforeMerged and whenMerged closures receive a Module parameter
 
Examples of advanced configuration:
 plugins {
     id 'java'
     id 'idea'
 }
 idea {
   module {
     iml {
       //if you like to keep *.iml in a secret folder
       generateTo = file('secret-modules-folder')
       //if you want to mess with the resulting XML in whatever way you fancy
       withXml {
         def node = it.asNode()
         node.appendNode('iLoveGradle', 'true')
         node.appendNode('butAlso', 'I find increasing pleasure tinkering with output *.iml contents. Yeah!!!')
       }
       //closure executed after *.iml content is loaded from existing file
       //but before gradle build information is merged
       beforeMerged { module ->
         //if you want skip merging exclude dirs
         module.excludeFolders.clear()
       }
       //closure executed after *.iml content is loaded from existing file
       //and after gradle build information is merged
       whenMerged { module ->
         //you can tinker with Module
       }
     }
   }
 }
 | Modifier and Type | Field | Description | 
|---|---|---|
| protected IdeaLanguageLevel | languageLevel | |
| protected JavaVersion | targetBytecodeVersion | 
| Constructor | Description | 
|---|---|
| IdeaModule(Project project,
          IdeaModuleIml iml) | 
| Modifier and Type | Method | Description | 
|---|---|---|
| java.io.File | getContentRoot() | The content root directory of the module. | 
| java.util.Set<java.io.File> | getExcludeDirs() | Directories to be excluded. | 
| java.util.Set<java.io.File> | getGeneratedSourceDirs() | The directories containing the generated sources (both production and test sources). | 
| IdeaModuleIml | getIml() | See  iml(Action) | 
| java.lang.Boolean | getInheritOutputDirs() | If true, output directories for this module will be located below the output directory for the project;
 otherwise, they will be set to the directories specified by  getOutputDir()andgetTestOutputDir(). | 
| java.lang.String | getJdkName() | The JDK to use for this module. | 
| IdeaLanguageLevel | getLanguageLevel() | The module specific language Level to use for this module. | 
| java.lang.String | getName() | Configures module name, that is the name of the *.iml file. | 
| java.io.File | getOutputDir() | The output directory for production classes. | 
| java.io.File | getOutputFile() | Configures output *.iml file. | 
| PathFactory | getPathFactory() | |
| java.util.Map<java.lang.String,java.io.File> | getPathVariables() | The variables to be used for replacing absolute paths in the iml entries. | 
| Project | getProject() | An owner of this IDEA module. | 
| java.util.Set<java.io.File> | getResourceDirs() | The directories containing resources. | 
| java.util.Map<java.lang.String,java.util.Map<java.lang.String,java.util.Collection<Configuration>>> | getScopes() | The keys of this map are the IDEA scopes. | 
| java.util.Map<java.lang.String,java.lang.Iterable<java.io.File>> | getSingleEntryLibraries() | |
| java.util.Set<java.io.File> | getSourceDirs() | The directories containing the production sources. | 
| JavaVersion | getTargetBytecodeVersion() | The module specific bytecode version to use for this module. | 
| java.io.File | getTestOutputDir() | The output directory for test classes. | 
| java.util.Set<java.io.File> | getTestResourceDirs() | Deprecated. | 
| ConfigurableFileCollection | getTestResources() | The complete and up-to-date collection of test resource directories. | 
| java.util.Set<java.io.File> | getTestSourceDirs() | Deprecated. | 
| ConfigurableFileCollection | getTestSources() | The complete and up-to-date collection of test source directories
 This should be preferred to  getTestSourceDirs()as it will include late changes to default directories. | 
| void | iml(Closure closure) | Enables advanced configuration like tinkering with the output XML or affecting the way existing *.iml content is merged with gradle build information. | 
| void | iml(Action<? super IdeaModuleIml> action) | Enables advanced configuration like tinkering with the output XML or affecting the way existing *.iml content is merged with gradle build information. | 
| boolean | isDownloadJavadoc() | Whether to download and add javadoc associated with the dependency jars. | 
| boolean | isDownloadSources() | Whether to download and add sources associated with the dependency jars. | 
| boolean | isOffline() | If true then external artifacts (e.g. | 
| void | mergeXmlModule(Module xmlModule) | |
| java.util.Set<Dependency> | resolveDependencies() | Resolves and returns the module's dependencies. | 
| void | setContentRoot(java.io.File contentRoot) | |
| void | setDownloadJavadoc(boolean downloadJavadoc) | |
| void | setDownloadSources(boolean downloadSources) | |
| void | setExcludeDirs(java.util.Set<java.io.File> excludeDirs) | |
| void | setGeneratedSourceDirs(java.util.Set<java.io.File> generatedSourceDirs) | |
| void | setInheritOutputDirs(java.lang.Boolean inheritOutputDirs) | |
| void | setJdkName(java.lang.String jdkName) | |
| void | setLanguageLevel(IdeaLanguageLevel languageLevel) | |
| void | setName(java.lang.String name) | |
| void | setOffline(boolean offline) | |
| void | setOutputDir(java.io.File outputDir) | |
| void | setOutputFile(java.io.File newOutputFile) | |
| void | setPathFactory(PathFactory pathFactory) | |
| void | setPathVariables(java.util.Map<java.lang.String,java.io.File> pathVariables) | |
| void | setResourceDirs(java.util.Set<java.io.File> resourceDirs) | Sets the directories containing resources. | 
| void | setScopes(java.util.Map<java.lang.String,java.util.Map<java.lang.String,java.util.Collection<Configuration>>> scopes) | |
| void | setSingleEntryLibraries(java.util.Map<java.lang.String,java.lang.Iterable<java.io.File>> singleEntryLibraries) | |
| void | setSourceDirs(java.util.Set<java.io.File> sourceDirs) | |
| void | setTargetBytecodeVersion(JavaVersion targetBytecodeVersion) | |
| void | setTestOutputDir(java.io.File testOutputDir) | |
| void | setTestResourceDirs(java.util.Set<java.io.File> testResourceDirs) | Deprecated. | 
| void | setTestSourceDirs(java.util.Set<java.io.File> testSourceDirs) | Deprecated. | 
protected IdeaLanguageLevel languageLevel
protected JavaVersion targetBytecodeVersion
@Inject public IdeaModule(Project project, IdeaModuleIml iml)
public java.lang.String getName()
It's optional because the task should configure it correctly for you. By default it will try to use the project.name or prefix it with a part of a project.path to make sure the module name is unique in the scope of a multi-module build. The 'uniqueness' of a module name is required for correct import into IDEA and the task will make sure the name is unique.
since 1.0-milestone-2
 If your project has problems with unique names it is recommended to always run gradle idea from the
 root, i.e. for all subprojects.
 If you run the generation of the IDEA module only for a single subproject then you may have different results
 because the unique names are calculated based on IDEA modules that are involved in the specific build run.
 
 If you update the module names then make sure you run gradle idea from the root, e.g. for all
 subprojects, including generation of IDEA project.
 The reason is that there may be subprojects that depend on the subproject with amended module name.
 So you want them to be generated as well because the module dependencies need to refer to the amended project
 name.
 Basically, for non-trivial projects it is recommended to always run gradle idea from the root.
 
 For example see docs for IdeaModule
public void setName(java.lang.String name)
public java.util.Set<java.io.File> getSourceDirs()
IdeaModulepublic void setSourceDirs(java.util.Set<java.io.File> sourceDirs)
public java.util.Set<java.io.File> getGeneratedSourceDirs()
 For example see docs for IdeaModule
public void setGeneratedSourceDirs(java.util.Set<java.io.File> generatedSourceDirs)
public java.util.Map<java.lang.String,java.util.Map<java.lang.String,java.util.Collection<Configuration>>> getScopes()
Configuration objects. The files of the
 plus configurations are added minus the files from the minus configurations. See example below...
 Example how to use scopes property to enable 'performanceTestCompile' dependencies in the output *.iml file:
 plugins {
     id 'java'
     id 'idea'
 }
 configurations {
   performanceTestCompile
   performanceTestCompile.extendsFrom(testCompile)
 }
 dependencies {
   //performanceTestCompile "some.interesting:dependency:1.0"
 }
 idea {
   module {
     scopes.TEST.plus += [ configurations.performanceTestCompile ]
   }
 }
 public void setScopes(java.util.Map<java.lang.String,java.util.Map<java.lang.String,java.util.Collection<Configuration>>> scopes)
public boolean isDownloadSources()
 For example see docs for IdeaModule
public void setDownloadSources(boolean downloadSources)
public boolean isDownloadJavadoc()
 For example see docs for IdeaModule
public void setDownloadJavadoc(boolean downloadJavadoc)
public java.io.File getContentRoot()
 For example see docs for IdeaModule
public void setContentRoot(java.io.File contentRoot)
@Deprecated public java.util.Set<java.io.File> getTestSourceDirs()
getTestSources() should be preferred.
 For example see docs for IdeaModule
 This field is @Deprecated, please use getTestSources() instead.@Deprecated public void setTestSourceDirs(java.util.Set<java.io.File> testSourceDirs)
@Deprecated, please use getTestSources() instead to access the new collection property.public ConfigurableFileCollection getTestSources()
getTestSourceDirs() as it will include late changes to default directories.public java.util.Set<java.io.File> getResourceDirs()
 For example see docs for IdeaModule
public void setResourceDirs(java.util.Set<java.io.File> resourceDirs)
 For example see docs for IdeaModule
@Deprecated public java.util.Set<java.io.File> getTestResourceDirs()
 For example see docs for IdeaModule
 This field is @Deprecated, please use getTestResources() instead.
@Deprecated public void setTestResourceDirs(java.util.Set<java.io.File> testResourceDirs)
 For example see docs for IdeaModule
 This field is @Deprecated, please use getTestResources() instead to access the new collection property.
public ConfigurableFileCollection getTestResources()
getTestResourceDirs() as it will include late changes to default directories.public java.util.Set<java.io.File> getExcludeDirs()
 For example see docs for IdeaModule
public void setExcludeDirs(java.util.Set<java.io.File> excludeDirs)
public java.lang.Boolean getInheritOutputDirs()
getOutputDir() and getTestOutputDir().
 
 For example see docs for IdeaModule
public void setInheritOutputDirs(java.lang.Boolean inheritOutputDirs)
public java.io.File getOutputDir()
null, no entry will be created.
 
 For example see docs for IdeaModule
public void setOutputDir(java.io.File outputDir)
public java.io.File getTestOutputDir()
null, no entry will be created.
 
 For example see docs for IdeaModule
public void setTestOutputDir(java.io.File testOutputDir)
public java.util.Map<java.lang.String,java.io.File> getPathVariables()
GRADLE_USER_HOME variable to point to the Gradle user home dir.
 
 For example see docs for IdeaModule
public void setPathVariables(java.util.Map<java.lang.String,java.io.File> pathVariables)
public java.lang.String getJdkName()
null, the value of the existing or default ipr XML (inherited) is used.
 If it is set to inherited, the project SDK is used.
 Otherwise the SDK for the corresponding value of java version is used for this module.
 
 For example see docs for IdeaModule
public void setJdkName(java.lang.String jdkName)
public IdeaLanguageLevel getLanguageLevel()
null, the module will inherit the language level from the idea project.
 
 The Idea module language level is based on the sourceCompatibility settings for the associated Gradle project.
public void setLanguageLevel(IdeaLanguageLevel languageLevel)
public JavaVersion getTargetBytecodeVersion()
null, the module will inherit the bytecode version from the idea project.
 
 The Idea module bytecode version is based on the targetCompatibility settings for the associated Gradle project.
public void setTargetBytecodeVersion(JavaVersion targetBytecodeVersion)
public IdeaModuleIml getIml()
iml(Action)public Project getProject()
If IdeaModule requires some information from gradle this field should not be used for this purpose. IdeaModule instances should be configured with all necessary information by the plugin or user.
public PathFactory getPathFactory()
public void setPathFactory(PathFactory pathFactory)
public boolean isOffline()
public void setOffline(boolean offline)
public java.util.Map<java.lang.String,java.lang.Iterable<java.io.File>> getSingleEntryLibraries()
public void setSingleEntryLibraries(java.util.Map<java.lang.String,java.lang.Iterable<java.io.File>> singleEntryLibraries)
public void iml(@DelegatesTo(IdeaModuleIml.class) Closure closure)
 For example see docs for IdeaModule.
public void iml(Action<? super IdeaModuleIml> action)
 For example see docs for IdeaModule.
public java.io.File getOutputFile()
Please refer to documentation on moduleName property. In IntelliJ IDEA the module name is the same as the name of the *.iml file.
public void setOutputFile(java.io.File newOutputFile)
public java.util.Set<Dependency> resolveDependencies()
public void mergeXmlModule(Module xmlModule)