fix #48
This commit is contained in:
		
							parent
							
								
									0b38f3ecc5
								
							
						
					
					
						commit
						d4ae5e9b72
					
				
					 3 changed files with 143 additions and 97 deletions
				
			
		|  | @ -29,63 +29,15 @@ import net.fabricmc.loom.providers.MappingsProvider; | ||||||
| import net.fabricmc.loom.util.Constants; | import net.fabricmc.loom.util.Constants; | ||||||
| import net.fabricmc.loom.util.MinecraftVersionInfo; | import net.fabricmc.loom.util.MinecraftVersionInfo; | ||||||
| import net.fabricmc.loom.util.OperatingSystem; | import net.fabricmc.loom.util.OperatingSystem; | ||||||
|  | import net.fabricmc.loom.util.RunConfig; | ||||||
| import org.gradle.api.tasks.JavaExec; | import org.gradle.api.tasks.JavaExec; | ||||||
| 
 | 
 | ||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| public class RunClientTask extends JavaExec { | public class RunClientTask extends RunTaskBase { | ||||||
| 	public RunClientTask() { | 	public RunClientTask() { | ||||||
| 		setGroup("fabric"); | 		super(RunConfig::clientRunConfig); | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public void exec() { |  | ||||||
| 		LoomGradleExtension extension = this.getProject().getExtensions().getByType(LoomGradleExtension.class); |  | ||||||
| 		MinecraftVersionInfo minecraftVersionInfo = extension.getMinecraftProvider().versionInfo; |  | ||||||
| 		MappingsProvider mappingsProvider = extension.getMappingsProvider(); |  | ||||||
| 
 |  | ||||||
| 		List<String> libs = new ArrayList<>(); |  | ||||||
| 		for (File file : getProject().getConfigurations().getByName("compile").getFiles()) { |  | ||||||
| 			libs.add(file.getAbsolutePath()); |  | ||||||
| 		} |  | ||||||
| 		for (File file : extension.getUnmappedMods()) { |  | ||||||
| 			if (file.isFile()) { |  | ||||||
| 				libs.add(file.getAbsolutePath()); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		classpath(libs); |  | ||||||
| 		args("--tweakClass", Constants.DEFAULT_FABRIC_CLIENT_TWEAKER, "--assetIndex", minecraftVersionInfo.assetIndex.getFabricId(extension.getMinecraftProvider().minecraftVersion), "--assetsDir", new File(extension.getUserCache(), "assets").getAbsolutePath()); |  | ||||||
| 
 |  | ||||||
| 		setWorkingDir(new File(getProject().getRootDir(), "run")); |  | ||||||
| 
 |  | ||||||
| 		super.exec(); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public void setWorkingDir(File dir) { |  | ||||||
| 		if(!dir.exists()){ |  | ||||||
| 			dir.mkdirs(); |  | ||||||
| 		} |  | ||||||
| 		super.setWorkingDir(dir); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public String getMain() { |  | ||||||
| 		return "net.minecraft.launchwrapper.Launch"; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public List<String> getJvmArgs() { |  | ||||||
| 		LoomGradleExtension extension = this.getProject().getExtensions().getByType(LoomGradleExtension.class); |  | ||||||
| 		List<String> args = new ArrayList<>(super.getJvmArgs()); |  | ||||||
| 		args.add("-Dfabric.development=true"); |  | ||||||
| 		if(OperatingSystem.getOS().equalsIgnoreCase("osx")){ |  | ||||||
| 			args.add("-XstartOnFirstThread"); |  | ||||||
| 		} |  | ||||||
| 		return args; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -26,58 +26,15 @@ package net.fabricmc.loom.task; | ||||||
| 
 | 
 | ||||||
| import net.fabricmc.loom.LoomGradleExtension; | import net.fabricmc.loom.LoomGradleExtension; | ||||||
| import net.fabricmc.loom.util.Constants; | import net.fabricmc.loom.util.Constants; | ||||||
|  | import net.fabricmc.loom.util.RunConfig; | ||||||
| import org.gradle.api.tasks.JavaExec; | import org.gradle.api.tasks.JavaExec; | ||||||
| 
 | 
 | ||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| public class RunServerTask extends JavaExec { | public class RunServerTask extends RunTaskBase { | ||||||
| 	public RunServerTask() { | 	public RunServerTask() { | ||||||
| 		setGroup("fabric"); | 		super(RunConfig::serverRunConfig); | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public void exec() { |  | ||||||
| 		LoomGradleExtension extension = this.getProject().getExtensions().getByType(LoomGradleExtension.class); |  | ||||||
| 
 |  | ||||||
| 		List<String> libs = new ArrayList<>(); |  | ||||||
| 		for (File file : getProject().getConfigurations().getByName("compile").getFiles()) { |  | ||||||
| 			libs.add(file.getAbsolutePath()); |  | ||||||
| 		} |  | ||||||
| 		for (File file : extension.getUnmappedMods()) { |  | ||||||
| 			if (file.isFile()) { |  | ||||||
| 				libs.add(file.getAbsolutePath()); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		classpath(libs); |  | ||||||
| 
 |  | ||||||
| 		args("--tweakClass", Constants.DEFAULT_FABRIC_SERVER_TWEAKER); |  | ||||||
| 
 |  | ||||||
| 		setWorkingDir(new File(getProject().getRootDir(), "run")); |  | ||||||
| 
 |  | ||||||
| 		super.exec(); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public String getMain() { |  | ||||||
| 		return "net.minecraft.launchwrapper.Launch"; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public void setWorkingDir(File dir) { |  | ||||||
| 		if(!dir.exists()){ |  | ||||||
| 			dir.mkdirs(); |  | ||||||
| 		} |  | ||||||
| 		super.setWorkingDir(dir); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	@Override |  | ||||||
| 	public List<String> getJvmArgs() { |  | ||||||
| 		LoomGradleExtension extension = this.getProject().getExtensions().getByType(LoomGradleExtension.class); |  | ||||||
| 		List<String> args = new ArrayList<>(super.getJvmArgs()); |  | ||||||
| 		args.add("-Dfabric.development=true"); |  | ||||||
| 		return args; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										137
									
								
								src/main/java/net/fabricmc/loom/task/RunTaskBase.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								src/main/java/net/fabricmc/loom/task/RunTaskBase.java
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,137 @@ | ||||||
|  | /* | ||||||
|  |  * This file is part of fabric-loom, licensed under the MIT License (MIT). | ||||||
|  |  * | ||||||
|  |  * Copyright (c) 2016, 2017, 2018 FabricMC | ||||||
|  |  * | ||||||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  |  * of this software and associated documentation files (the "Software"), to deal | ||||||
|  |  * in the Software without restriction, including without limitation the rights | ||||||
|  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  |  * copies of the Software, and to permit persons to whom the Software is | ||||||
|  |  * furnished to do so, subject to the following conditions: | ||||||
|  |  * | ||||||
|  |  * The above copyright notice and this permission notice shall be included in all | ||||||
|  |  * copies or substantial portions of the Software. | ||||||
|  |  * | ||||||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  |  * SOFTWARE. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | package net.fabricmc.loom.task; | ||||||
|  | 
 | ||||||
|  | import net.fabricmc.loom.LoomGradleExtension; | ||||||
|  | import net.fabricmc.loom.providers.MappingsProvider; | ||||||
|  | import net.fabricmc.loom.util.MinecraftVersionInfo; | ||||||
|  | import net.fabricmc.loom.util.OperatingSystem; | ||||||
|  | import net.fabricmc.loom.util.RunConfig; | ||||||
|  | import org.gradle.api.Project; | ||||||
|  | import org.gradle.api.tasks.JavaExec; | ||||||
|  | 
 | ||||||
|  | import java.io.File; | ||||||
|  | import java.util.ArrayList; | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Collections; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.function.Function; | ||||||
|  | 
 | ||||||
|  | public abstract class RunTaskBase extends JavaExec { | ||||||
|  |     private final Function<Project, RunConfig> configProvider; | ||||||
|  |     private RunConfig config; | ||||||
|  | 
 | ||||||
|  |     public RunTaskBase(Function<Project, RunConfig> config) { | ||||||
|  |         super(); | ||||||
|  |         setGroup("fabric"); | ||||||
|  |         this.configProvider = config; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void exec() { | ||||||
|  |         if (config == null) { | ||||||
|  |             config = configProvider.apply(getProject()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         LoomGradleExtension extension = this.getProject().getExtensions().getByType(LoomGradleExtension.class); | ||||||
|  |         MinecraftVersionInfo minecraftVersionInfo = extension.getMinecraftProvider().versionInfo; | ||||||
|  |         MappingsProvider mappingsProvider = extension.getMappingsProvider(); | ||||||
|  | 
 | ||||||
|  |         List<String> libs = new ArrayList<>(); | ||||||
|  |         for (File file : getProject().getConfigurations().getByName("compile").getFiles()) { | ||||||
|  |             libs.add(file.getAbsolutePath()); | ||||||
|  |         } | ||||||
|  |         for (File file : extension.getUnmappedMods()) { | ||||||
|  |             if (file.isFile()) { | ||||||
|  |                 libs.add(file.getAbsolutePath()); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         classpath(libs); | ||||||
|  |         List<String> argsSplit = new ArrayList<>(); | ||||||
|  |         String[] args = config.programArgs.split(" "); | ||||||
|  |         int partPos = -1; | ||||||
|  |         for (int i = 0; i < args.length; i++) { | ||||||
|  |             if (partPos < 0) { | ||||||
|  |                 if (args[i].startsWith("\"")) { | ||||||
|  |                     if (args[i].endsWith("\"")) { | ||||||
|  |                         argsSplit.add(args[i].substring(1, args[i].length() - 1)); | ||||||
|  |                     } else { | ||||||
|  |                         partPos = i; | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     argsSplit.add(args[i]); | ||||||
|  |                 } | ||||||
|  |             } else if (args[i].endsWith("\"")) { | ||||||
|  |                 StringBuilder builder = new StringBuilder(args[partPos].substring(1)); | ||||||
|  |                 for (int j = partPos + 1; j < i; j++) { | ||||||
|  |                     builder.append(" ").append(args[j]); | ||||||
|  |                 } | ||||||
|  |                 builder.append(" ").append(args[i], 0, args[i].length() - 1); | ||||||
|  |                 argsSplit.add(builder.toString()); | ||||||
|  |                 partPos = -1; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         args(argsSplit); | ||||||
|  |         setWorkingDir(new File(config.runDir)); | ||||||
|  | 
 | ||||||
|  |         super.exec(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void setWorkingDir(File dir) { | ||||||
|  |         if (config == null) { | ||||||
|  |             config = configProvider.apply(getProject()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if(!dir.exists()){ | ||||||
|  |             dir.mkdirs(); | ||||||
|  |         } | ||||||
|  |         super.setWorkingDir(dir); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public String getMain() { | ||||||
|  |         if (config == null) { | ||||||
|  |             config = configProvider.apply(getProject()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return config.mainClass; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public List<String> getJvmArgs() { | ||||||
|  |         if (config == null) { | ||||||
|  |             config = configProvider.apply(getProject()); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         LoomGradleExtension extension = this.getProject().getExtensions().getByType(LoomGradleExtension.class); | ||||||
|  |         List<String> superArgs = super.getJvmArgs(); | ||||||
|  |         List<String> args = new ArrayList<>(superArgs != null ? superArgs : Collections.emptyList()); | ||||||
|  |         args.addAll(Arrays.asList(config.vmArgs.split(" "))); | ||||||
|  |         return args; | ||||||
|  |     } | ||||||
|  | } | ||||||
		Loading…
	
		Reference in a new issue