Jump to content

Recommended Posts

Posted

Through a lot of determination and code sleuthing, I've managed to get a grasp on setting up a core mod and using it to employ class transformers.

 

Just as a preliminary test, I made a transformer that would add

|| var8 == Block.arbitraryBlock.blockId

to BlockFarmland in its isCropsNearby method to expand what it considered a crop.

 

The transformer works well enough, but it got me thinking about the best ways to go about transforming classes. It seems like injecting code at arbitrary points would be fragile in that slight modification to the class by other transformers would mess up the bytecode "heuristics" I used to do it. Furthermore, just adding code to an arbitrary location in the class seems not much better than actually editing the class.

 

So, my question is: What kind of programming practices do you consider to be effective or proper when dealing with arbitrary code insertion? I've seen patterns where you just insert a redirect at the beginning of the method and go from there, and I've also seen stuff on the internet about the proxy class design pattern (though I don't understand it too well right now). Is there another pattern that would be effective?

 

I'm looking for advice/opinions on this mostly, how the modders on these boards do/would do it, rather than some concrete answer.

 

P.S. After learning some ASM and going through a LOT of the code, I started to realize just how complex and powerful Forge is, so bravo cpw and LexManos, this project is definitely an achievement.

 

EDIT: I just found out that the latest build of Forge actually has a new interface related to what I was sort of accomplishing here, but my question still stands!

Posted

In general you want to minimize your footprint so as to not step on other mods trying to do the same thing.  Pick a good point, like a call and cancel hook at the start or something, rather than just mass editing the code.

Posted

Thanks for the advice, Overmind! I had kind of given up on this topic. I leaning in the direction of what you said.

 

I was mostly worried about screwing up the variable indexes and possibly labels further on in a method's bytecode if I inserted sufficiently complex logic. I think that if other people are smart though, they will use simple heuristics like I did to get around that problem.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • I also just tried with iron's spellbooks removed, since that seemed related, but i am still having the same problem, even in newly created worlds. https://mclo.gs/AtrAfaj 
    • My Gradle Project for my Minecraft mod isn't building. Terminal: * Where: Settings file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\settings.gradle' line: 2 * What went wrong: Could not compile settings file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\settings.gradle'. > startup failed:   settings file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\settings.gradle': 2: The pluginManagement {} block must appear before any other statements in the script.   For more information on the pluginManagement {} block, please refer to https://docs.gradle.org/9.0.0/userguide/plugins.html#sec:plugin_management in the Gradle documentation.    @ line 2, column 1.      pluginManagement {      ^   1 error * Try: > Run with --stacktrace option to get the stack trace. > Run with --info or --debug option to get more log output. > Run with --scan to generate a Build Scan (Powered by Develocity). > Get more help at https://help.gradle.org.   Setting.Gradle File:   rootProject.name = 'fusion-lucky-block' pluginManagement {     repositories {         gradlePluginPortal()         maven { url "https://maven.minecraftforge.net/" }         mavenCentral()     } }
    • no change still. here's a new log  https://mclo.gs/RXwiZmn 
    • Whenever I go to build my it says "Build failed in " how many seconds   Here is what is said in my terminal * Where: Build file 'C:\Users\csonn\OneDrive\Desktop\fusionlucky\build.gradle' line: 3 * What went wrong: Plugin [id: 'net.minecraftforge.gradle', version: '6.1.51'] was not found in any of the following sources: - Gradle Core Plugins (plugin is not in 'org.gradle' namespace) - Included Builds (No included builds contain this plugin) - Plugin Repositories (could not resolve plugin artifact 'net.minecraftforge.gradle:net.minecraftforge.gradle.gradle.plugin:6.1.51')   Searched in the following repositories:     Gradle Central Plugin Repository     MinecraftForge(https://maven.minecraftforge.net/) * Try: > Run with --stacktrace option to get the stack trace. > Run with --info or --debug option to get more log output. > Get more help at https://help.gradle.org.   Here is what is in my build.gradle file plugins {     id 'java'     id 'net.minecraftforge.gradle' version '6.1+' }   group = 'io.github.csonnic03.fusionlucky' version = '1.0.0' archivesBaseName = 'fusionlucky'   java {     toolchain {         languageVersion = JavaLanguageVersion.of(17)     } }   repositories {     mavenCentral()     maven {         name "forgeMaven"         url "https://maven.minecraftforge.net/<repository>" } }   dependencies {     minecraft 'net.minecraftforge:forge:1.20.1-47.1.0' }   minecraft {     mappings channel: 'official', version: '1.20.1'     runs {         client {             workingDirectory project.file('run')         }         server {             workingDirectory project.file('run')         }     } }   tasks.withType(JavaCompile) {     options.encoding = 'UTF-8' }   jar {     manifest {         attributes(             "Specification-Title": "Fusion Lucky Block",             "Specification-Vendor": "example",             "Implementation-Title": project.name,             "Implementation-Version": project.version,             "Implementation-Vendor": "example",             "ModLauncher-TargetFMLVersion": "[47,)"         )     } }  
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.