Commit 9eca984c72ff9a0182c100b37da282df784203fc
1 parent
ebb3c2be
Update build.gradle for Mixins
Showing
1 changed file
with
91 additions
and
18 deletions
build.gradle
| 1 | buildscript { | 1 | buildscript { |
| 2 | repositories { | 2 | repositories { |
| 3 | + jcenter() | ||
| 3 | mavenLocal() | 4 | mavenLocal() |
| 4 | mavenCentral() | 5 | mavenCentral() |
| 5 | maven { | 6 | maven { |
| @@ -13,38 +14,59 @@ buildscript { | @@ -13,38 +14,59 @@ buildscript { | ||
| 13 | } | 14 | } |
| 14 | dependencies { | 15 | dependencies { |
| 15 | classpath 'net.minecraftforge.gradle:ForgeGradle:2.0-SNAPSHOT' | 16 | classpath 'net.minecraftforge.gradle:ForgeGradle:2.0-SNAPSHOT' |
| 17 | + classpath 'com.github.jengelman.gradle.plugins:shadow:1.2.0' | ||
| 16 | } | 18 | } |
| 17 | } | 19 | } |
| 18 | 20 | ||
| 19 | apply plugin: 'net.minecraftforge.gradle.tweaker-client' | 21 | apply plugin: 'net.minecraftforge.gradle.tweaker-client' |
| 20 | apply plugin: 'checkstyle' | 22 | apply plugin: 'checkstyle' |
| 21 | apply plugin: 'maven' | 23 | apply plugin: 'maven' |
| 24 | +apply plugin: 'com.github.johnrengelman.shadow' | ||
| 22 | 25 | ||
| 23 | -// Artefact details | ||
| 24 | -ext.buildNumber = project.hasProperty("buildNumber") ? buildNumber : '0' | ||
| 25 | -ext.ciSystem = project.hasProperty("ciSystem") ? ciSystem : 'unknown' | ||
| 26 | -ext.commit = project.hasProperty("commit") ? commit : 'unknown' | ||
| 27 | -ext.classifier = project.hasProperty("buildType") ? buildType : 'SNAPSHOT' | ||
| 28 | -ext.isReleaseBuild = "RELEASE".equals(project.classifier.toUpperCase()) | ||
| 29 | -ext.mavenRepo = project.isReleaseBuild ? "mavenUrl" : "mavenSnapshotUrl" | 26 | +ext { |
| 27 | + // Artefact details | ||
| 28 | + buildNumber = project.hasProperty("buildNumber") ? buildNumber : '0' | ||
| 29 | + ciSystem = project.hasProperty("ciSystem") ? ciSystem : 'unknown' | ||
| 30 | + commit = project.hasProperty("commit") ? commit : 'unknown' | ||
| 31 | + classifier = project.hasProperty("buildType") ? buildType : 'SNAPSHOT' | ||
| 32 | + isReleaseBuild = "RELEASE".equals(project.classifier.toUpperCase()) | ||
| 33 | + mavenRepo = project.isReleaseBuild ? "mavenUrl" : "mavenSnapshotUrl" | ||
| 34 | + | ||
| 35 | + // Extended project information | ||
| 36 | + projectName = 'LiteLoader' | ||
| 37 | + inceptionYear = '2012' | ||
| 38 | + packaging = 'jar' | ||
| 39 | + | ||
| 40 | + startClass = 'com.mumfrey.liteloader.debug.Start' | ||
| 41 | + tweakClass = 'com.mumfrey.liteloader.launch.LiteLoaderTweaker' | ||
| 42 | + | ||
| 43 | + mixinSrg = new File(project.buildDir, 'tmp/mixins.liteloader/mixins.srg') | ||
| 44 | + mixinRefMap = new File(project.buildDir, "tmp/mixins.liteloader/mixins.liteloader.refmap.json") | ||
| 45 | +} | ||
| 30 | 46 | ||
| 31 | // Basic project information | 47 | // Basic project information |
| 32 | group = "com.mumfrey" | 48 | group = "com.mumfrey" |
| 33 | archivesBaseName = "liteloader" | 49 | archivesBaseName = "liteloader" |
| 34 | version = buildVersion + (project.isReleaseBuild ? '' : '-' + project.classifier) | 50 | version = buildVersion + (project.isReleaseBuild ? '' : '-' + project.classifier) |
| 35 | 51 | ||
| 36 | -// Extended project information | ||
| 37 | -ext.projectName = 'LiteLoader' | ||
| 38 | -ext.inceptionYear = '2012' | ||
| 39 | -ext.packaging = 'jar' | ||
| 40 | - | ||
| 41 | -ext.startClass = 'com.mumfrey.liteloader.debug.Start' | ||
| 42 | -ext.tweakClass = 'com.mumfrey.liteloader.launch.LiteLoaderTweaker' | ||
| 43 | - | ||
| 44 | // Minimum version of Java required | 52 | // Minimum version of Java required |
| 45 | sourceCompatibility = '1.6' | 53 | sourceCompatibility = '1.6' |
| 46 | targetCompatibility = '1.6' | 54 | targetCompatibility = '1.6' |
| 47 | 55 | ||
| 56 | +repositories { | ||
| 57 | + maven { | ||
| 58 | + name = 'sponge' | ||
| 59 | + url = 'https://repo.spongepowered.org/maven/' | ||
| 60 | + } | ||
| 61 | +} | ||
| 62 | + | ||
| 63 | +dependencies { | ||
| 64 | + compile('org.spongepowered:mixin:0.4.7-SNAPSHOT') { | ||
| 65 | + exclude module: 'launchwrapper' | ||
| 66 | + exclude module: 'guava' | ||
| 67 | + } | ||
| 68 | +} | ||
| 69 | + | ||
| 48 | minecraft { | 70 | minecraft { |
| 49 | version = project.mcVersion | 71 | version = project.mcVersion |
| 50 | mappings = project.mcMappings | 72 | mappings = project.mcMappings |
| @@ -104,7 +126,29 @@ jar { | @@ -104,7 +126,29 @@ jar { | ||
| 104 | task releaseJar(type: Jar) { | 126 | task releaseJar(type: Jar) { |
| 105 | from sourceSets.main.output | 127 | from sourceSets.main.output |
| 106 | from sourceSets.client.output | 128 | from sourceSets.client.output |
| 129 | + from project.mixinRefMap | ||
| 130 | + | ||
| 131 | + manifest jarManifest | ||
| 132 | + classifier = 'staging' | ||
| 133 | +} | ||
| 134 | + | ||
| 135 | +shadowJar { | ||
| 107 | manifest jarManifest | 136 | manifest jarManifest |
| 137 | + dependsOn 'reobfReleaseJar' | ||
| 138 | + | ||
| 139 | + from sourceSets.main.output | ||
| 140 | + from sourceSets.client.output | ||
| 141 | + from project.mixinRefMap | ||
| 142 | + | ||
| 143 | + exclude 'META-INF/*.DSA' | ||
| 144 | + exclude 'META-INF/*.RSA' | ||
| 145 | + exclude 'dummyThing' | ||
| 146 | + exclude 'LICENSE.txt' | ||
| 147 | + | ||
| 148 | + dependencies { | ||
| 149 | + include(dependency('org.spongepowered:mixin')) | ||
| 150 | + } | ||
| 151 | + | ||
| 108 | classifier = 'release' | 152 | classifier = 'release' |
| 109 | } | 153 | } |
| 110 | 154 | ||
| @@ -122,7 +166,15 @@ task runClient(type: JavaExec, overwrite: true) { | @@ -122,7 +166,15 @@ task runClient(type: JavaExec, overwrite: true) { | ||
| 122 | } | 166 | } |
| 123 | 167 | ||
| 124 | tasks.withType(JavaCompile) { | 168 | tasks.withType(JavaCompile) { |
| 125 | - options.compilerArgs += ['-Xlint:all', '-Xlint:-path', '-Xlint:-rawtypes'] | 169 | + options.compilerArgs += [ |
| 170 | + '-Xlint:all', | ||
| 171 | + '-Xlint:-path', | ||
| 172 | + '-Xlint:-rawtypes', | ||
| 173 | + '-Xlint:-processing', | ||
| 174 | + "-AoutSrgFile=${project.mixinSrg.canonicalPath}", | ||
| 175 | + "-AoutRefMapFile=${project.mixinRefMap.canonicalPath}", | ||
| 176 | + "-AreobfSrgFile=${genSrgs.mcpToNotch.canonicalPath}" | ||
| 177 | + ] | ||
| 126 | options.deprecation = true | 178 | options.deprecation = true |
| 127 | options.encoding = 'utf8' | 179 | options.encoding = 'utf8' |
| 128 | } | 180 | } |
| @@ -141,6 +193,16 @@ reobf { | @@ -141,6 +193,16 @@ reobf { | ||
| 141 | releaseJar { | 193 | releaseJar { |
| 142 | useNotchSrg() | 194 | useNotchSrg() |
| 143 | classpath = sourceSets.main.compileClasspath | 195 | classpath = sourceSets.main.compileClasspath |
| 196 | + extraFiles([ | ||
| 197 | + project.mixinSrg | ||
| 198 | + ]) | ||
| 199 | + } | ||
| 200 | + shadowJar { | ||
| 201 | + useNotchSrg() | ||
| 202 | + classpath = sourceSets.main.compileClasspath | ||
| 203 | + extraFiles([ | ||
| 204 | + project.mixinSrg | ||
| 205 | + ]) | ||
| 144 | } | 206 | } |
| 145 | } | 207 | } |
| 146 | 208 | ||
| @@ -150,17 +212,28 @@ compileJava.doFirst { | @@ -150,17 +212,28 @@ compileJava.doFirst { | ||
| 150 | println '------------------------------------------------------------' | 212 | println '------------------------------------------------------------' |
| 151 | } | 213 | } |
| 152 | 214 | ||
| 153 | -build.dependsOn "reobfReleaseJar" | 215 | +build.dependsOn {[ |
| 216 | + 'reobfReleaseJar', | ||
| 217 | + 'reobfShadowJar' | ||
| 218 | + ] | ||
| 219 | +} | ||
| 154 | 220 | ||
| 155 | artifacts { | 221 | artifacts { |
| 156 | if (project.isReleaseBuild) { | 222 | if (project.isReleaseBuild) { |
| 157 | archives jar | 223 | archives jar |
| 158 | } | 224 | } |
| 159 | - archives releaseJar | 225 | + archives shadowJar |
| 160 | archives sourceJar | 226 | archives sourceJar |
| 161 | archives javadocJar | 227 | archives javadocJar |
| 162 | } | 228 | } |
| 163 | 229 | ||
| 230 | +task deploy(type: Copy, dependsOn: build) { | ||
| 231 | + def libraryDir = new File(new File(System.env.APPDATA), ".minecraft/libraries") | ||
| 232 | + from shadowJar.outputs.files[0] | ||
| 233 | + into new File(libraryDir, sprintf('%1$s%4$s%2$s%4$s%3$s', project.group.replace('.', File.separator), archivesBaseName, buildVersion, File.separatorChar)) | ||
| 234 | + rename shadowJar.outputs.files[0].name, sprintf("%s-%s.jar", archivesBaseName, buildVersion) | ||
| 235 | +} | ||
| 236 | + | ||
| 164 | uploadArchives { | 237 | uploadArchives { |
| 165 | repositories { | 238 | repositories { |
| 166 | mavenDeployer { | 239 | mavenDeployer { |