Remove idea-ext plugin, replace with 1 internal gradle api. Vastly improves import performance.
This commit is contained in:
		
							parent
							
								
									ab21e0e550
								
							
						
					
					
						commit
						e4244dc895
					
				
					 2 changed files with 5 additions and 47 deletions
				
			
		|  | @ -37,9 +37,6 @@ repositories { | |||
| 		url = 'https://maven.fabricmc.net/' | ||||
| 	} | ||||
| 	mavenCentral() | ||||
| 	maven { | ||||
| 		url = 'https://plugins.gradle.org/m2/' | ||||
| 	} | ||||
| 	mavenLocal() | ||||
| } | ||||
| 
 | ||||
|  | @ -95,9 +92,6 @@ dependencies { | |||
| 	// source code remapping | ||||
| 	implementation ('net.fabricmc:mercury:0.2.4') | ||||
| 
 | ||||
| 	// IDEA support | ||||
| 	implementation ('gradle.plugin.org.jetbrains.gradle.plugin.idea-ext:gradle-idea-ext:1.1.1') | ||||
| 
 | ||||
| 	// Kapt integration | ||||
| 	compileOnly('org.jetbrains.kotlin:kotlin-gradle-plugin:1.6.0') | ||||
| 
 | ||||
|  |  | |||
|  | @ -24,19 +24,11 @@ | |||
| 
 | ||||
| package net.fabricmc.loom.configuration.ide.idea; | ||||
| 
 | ||||
| import java.util.Objects; | ||||
| import java.util.List; | ||||
| 
 | ||||
| import org.gradle.api.NamedDomainObjectContainer; | ||||
| import org.gradle.api.Project; | ||||
| import org.gradle.api.plugins.ExtensionAware; | ||||
| import org.gradle.api.tasks.TaskProvider; | ||||
| import org.gradle.plugins.ide.idea.model.IdeaModel; | ||||
| import org.gradle.plugins.ide.idea.model.IdeaProject; | ||||
| import org.jetbrains.gradle.ext.ActionDelegationConfig; | ||||
| import org.jetbrains.gradle.ext.IdeaExtPlugin; | ||||
| import org.jetbrains.gradle.ext.ProjectSettings; | ||||
| import org.jetbrains.gradle.ext.RunConfiguration; | ||||
| import org.jetbrains.gradle.ext.TaskTriggersConfig; | ||||
| import org.gradle.execution.taskgraph.TaskExecutionGraphInternal; | ||||
| 
 | ||||
| public class IdeaConfiguration { | ||||
| 	public static void setup(Project project) { | ||||
|  | @ -48,36 +40,8 @@ public class IdeaConfiguration { | |||
| 			return; | ||||
| 		} | ||||
| 
 | ||||
| 		project.getPlugins().apply(IdeaExtPlugin.class); | ||||
| 		project.getPlugins().withType(IdeaExtPlugin.class, ideaExtPlugin -> { | ||||
| 			if (project != project.getRootProject()) { | ||||
| 				// Also ensure it's applied to the root project. | ||||
| 				project.getRootProject().getPlugins().apply(IdeaExtPlugin.class); | ||||
| 			} | ||||
| 
 | ||||
| 			final IdeaModel ideaModel = project.getRootProject().getExtensions().findByType(IdeaModel.class); | ||||
| 
 | ||||
| 			if (ideaModel == null) { | ||||
| 				return; | ||||
| 			} | ||||
| 
 | ||||
| 			final IdeaProject ideaProject = ideaModel.getProject(); | ||||
| 
 | ||||
| 			if (ideaProject == null) { | ||||
| 				return; | ||||
| 			} | ||||
| 
 | ||||
| 			final ProjectSettings settings = getExtension(ideaProject, ProjectSettings.class); | ||||
| 			final ActionDelegationConfig delegateActions = getExtension(settings, ActionDelegationConfig.class); | ||||
| 			final TaskTriggersConfig taskTriggers = getExtension(settings, TaskTriggersConfig.class); | ||||
| 			final NamedDomainObjectContainer<RunConfiguration> runConfigurations = (NamedDomainObjectContainer<RunConfiguration>) ((ExtensionAware) settings).getExtensions().getByName("runConfigurations"); | ||||
| 
 | ||||
| 			// Run the sync task on import | ||||
| 			taskTriggers.afterSync(ideaSyncTask); | ||||
| 		}); | ||||
| 	} | ||||
| 
 | ||||
| 	private static <T> T getExtension(Object extensionAware, Class<T> type) { | ||||
| 		return Objects.requireNonNull(((ExtensionAware) extensionAware).getExtensions().getByType(type)); | ||||
| 		// Run the idea sync task, is this exposed via the api? | ||||
| 		final TaskExecutionGraphInternal taskGraph = (TaskExecutionGraphInternal) project.getGradle().getTaskGraph(); | ||||
| 		taskGraph.whenReady(taskExecutionGraph -> taskGraph.addEntryTasks(List.of(ideaSyncTask.get()))); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue