1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2025-01-23 07:26:58 +00:00

Replace mixin with access transformers

Hadn't realised I could use these to touch final modifiers! More
importantly, Mixin doesn't work with FG 5.0, so we needed an alternative
:).
This commit is contained in:
Jonathan Coates 2021-06-19 12:52:07 +01:00
parent 0bfe960cbd
commit 2d3e88ef59
No known key found for this signature in database
GPG Key ID: B9E431FF07C98D06
4 changed files with 19 additions and 53 deletions

View File

@ -5,16 +5,10 @@ buildscript {
name = "forge" name = "forge"
url = "https://maven.minecraftforge.net" url = "https://maven.minecraftforge.net"
} }
maven {
name = "Sponge (Mixin)"
url = "https://repo.spongepowered.org/repository/maven-public/"
content { includeGroup "org.spongepowered" }
}
} }
dependencies { dependencies {
classpath 'com.google.code.gson:gson:2.8.1' classpath 'com.google.code.gson:gson:2.8.1'
classpath 'net.minecraftforge.gradle:ForgeGradle:5.0.12' classpath 'net.minecraftforge.gradle:ForgeGradle:5.0.12'
classpath 'org.spongepowered:mixingradle:0.7-SNAPSHOT'
} }
} }
@ -30,7 +24,6 @@ plugins {
} }
apply plugin: 'net.minecraftforge.gradle' apply plugin: 'net.minecraftforge.gradle'
apply plugin: 'org.spongepowered.mixin'
version = mod_version version = mod_version
@ -68,9 +61,6 @@ minecraft {
property 'forge.logging.markers', 'REGISTRIES' property 'forge.logging.markers', 'REGISTRIES'
property 'forge.logging.console.level', 'debug' property 'forge.logging.console.level', 'debug'
property 'mixin.env.remapRefMap', 'true'
property 'mixin.env.refMapRemappingFile', "${buildDir}/createSrgToMcp/output.srg"
mods { mods {
computercraft { computercraft {
source sourceSets.main source sourceSets.main
@ -107,9 +97,6 @@ minecraft {
testServer { testServer {
workingDirectory project.file('test-files/server') workingDirectory project.file('test-files/server')
parent runs.server parent runs.server
properties 'mixin.env.disableRefMap': 'true'
arg "-mixin.config=cctest.mixin.json"
arg "--nogui" arg "--nogui"
mods { mods {
@ -123,10 +110,7 @@ minecraft {
mappings channel: 'official', version: mc_version mappings channel: 'official', version: mc_version
accessTransformer file('src/main/resources/META-INF/accesstransformer.cfg') accessTransformer file('src/main/resources/META-INF/accesstransformer.cfg')
} accessTransformer file('src/test/resources/META-INF/accesstransformer.cfg')
mixin {
add sourceSets.test, "cctest.refmap.json"
} }
sourceSets { sourceSets {
@ -169,7 +153,6 @@ dependencies {
testImplementation 'org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.72' testImplementation 'org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.72'
testImplementation 'org.jetbrains.kotlin:kotlin-reflect:1.3.72' testImplementation 'org.jetbrains.kotlin:kotlin-reflect:1.3.72'
testImplementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.8' testImplementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.8'
testAnnotationProcessor 'org.spongepowered:mixin:0.8.2:processor'
cctJavadoc 'cc.tweaked:cct-javadoc:1.4.0' cctJavadoc 'cc.tweaked:cct-javadoc:1.4.0'
} }

View File

@ -17,7 +17,6 @@ import net.minecraftforge.fml.unsafe.UnsafeHacks;
import net.minecraftforge.forgespi.language.ModFileScanData; import net.minecraftforge.forgespi.language.ModFileScanData;
import org.objectweb.asm.Type; import org.objectweb.asm.Type;
import java.lang.reflect.Field;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
@ -86,30 +85,16 @@ class TestLoader
int maxTicks, int maxTicks,
long setupTicks long setupTicks
) )
{
try
{ {
TestFunctionInfo func = UnsafeHacks.newInstance( TestFunctionInfo.class ); TestFunctionInfo func = UnsafeHacks.newInstance( TestFunctionInfo.class );
setFinalField( func, "batchName", batchName ); func.batchName = batchName;
setFinalField( func, "testName", testName ); func.testName = testName;
setFinalField( func, "structureName", structureName ); func.structureName = structureName;
setFinalField( func, "required", required ); func.required = required;
setFinalField( func, "function", function ); func.function = function;
setFinalField( func, "maxTicks", maxTicks ); func.maxTicks = maxTicks;
setFinalField( func, "setupTicks", setupTicks ); func.setupTicks = setupTicks;
setFinalField( func, "rotation", Rotation.NONE ); func.rotation = Rotation.NONE;
return func; return func;
} }
catch( ReflectiveOperationException e )
{
throw new RuntimeException( e );
}
}
private static void setFinalField( TestFunctionInfo func, String name, Object value ) throws ReflectiveOperationException
{
Field field = TestFunctionInfo.class.getDeclaredField( name );
field.setAccessible( true );
field.set( func, value );
}
} }

View File

@ -0,0 +1,8 @@
public-f net.minecraft.test.TestFunctionInfo field_229650_a_
public-f net.minecraft.test.TestFunctionInfo field_229651_b_
public-f net.minecraft.test.TestFunctionInfo field_229652_c_
public-f net.minecraft.test.TestFunctionInfo field_229653_d_
public-f net.minecraft.test.TestFunctionInfo field_229654_e_
public-f net.minecraft.test.TestFunctionInfo field_229655_f_
public-f net.minecraft.test.TestFunctionInfo field_229656_g_
public-f net.minecraft.test.TestFunctionInfo field_240589_h_

View File

@ -1,10 +0,0 @@
{
"required": true,
"package": "dan200.computercraft.ingame.mixin",
"compatibilityLevel": "JAVA_8",
"refmap": "cctest.refmap.json",
"mixins": [
"MixinTestFunctionInfo"
],
"minVersion": "0.8"
}