Giter Site home page Giter Site logo

Comments (5)

LexManos avatar LexManos commented on June 1, 2024 1

To make this clear, it has nothing to do with things being synthetic or not. This is a bug in FML, or at least a misunderstanding of design.
The SRG names are meant to be unique and treated as a lookup in a single dictionary
Having them split by FML means that record names do not get the field names as they are intended.

The fix would be to update FML's Naming Service, but it can also be fixed on our end by duplicating the data into both csv files. So feel free to PR FG to add "f_" to the list of methods so it's retroactive.

from forgegradle.

cpw avatar cpw commented on June 1, 2024

The record field accessor methods are likely marked as synthetic by the compiler, which likely means they should not even be in the decompile.

Are you trying to reflect them at runtime and hitting an error, or is it a "they seem to be missing"? Because I would generally expect them to be missing. Note that at runtime deobf, they probably deobf to their field name because they're synthetic.

from forgegradle.

Su5eD avatar Su5eD commented on June 1, 2024

Runtime deobf doesn't work at all because the default modlauncher naming service loads its method mappings from methods.csv. And since record method names are filtered out from that file due to this bug, remap calls will always fall back to the obfuscated name.

All the required method names are already present in the SRG input of OfficialChannelProvider, they just get filtered out because they begin with the field name prefix f_.

from forgegradle.

cpw avatar cpw commented on June 1, 2024

Fixing name service is quite doable. We'd need to identify the special case where the method is a field name somehow..

from forgegradle.

LexManos avatar LexManos commented on June 1, 2024

The point is they shouldn't be special cased. It'd just need to load both the methods and fields csv into a single dictionary.

from forgegradle.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.