-
Notifications
You must be signed in to change notification settings - Fork 475
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
"Goto definition" in decompiler mode may not match bytecode reference due to name shadowing #389
Comments
Looks like the JavaParser resolve logic is failing in this case. I'll have to look and see why its resolving that way. Can you provide a sample? |
Yeah, validated my prior assumption. Because the context is based on the decompiled code and not the underlying bytecode it sees that we're in I'd have to incorporate some double layer (source + bytecode) context system to address this since the information needed to resolve this simply cannot be represented in decompiled code. There's no good way to resolve bytecode instruction correlation to decompiled source code in any of the decompilers AFAIK, so it'd be some work to figure that out and put an implementation of that in Recaf. |
There might be, but for now you may can prevent this bug by simply checking the bytecode instructions if there is another class exist with the same Simple Name. (Compare what Recaf tries to redirect and what bytecode includes) I'm going to explain here what I'm trying to say. (cuz my english is bad) (Goto Definition option might become strikethrough text and might show a text box while hovering over that says something like "Destination may not be true, check the bytecode in order to be sure") |
That's the double layer approach, but warning instead of resolving. |
While I was working on an obfuscated jar, I found a bug that causes you to find yourself in a random class that is not even relevant to what you would expect. Let me introduce a few images to explain.
I was on a pretty clean class and I though there was no problem to use "Goto definiton" option.
data:image/s3,"s3://crabby-images/fcdbe/fcdbe1b05f044ed16719a6a9565382424203b5f8" alt="image"
I used it and... I was here...
data:image/s3,"s3://crabby-images/945dd/945ddc960b961f512bff4f87833347237c63aab3" alt="image"
I was expecting a Packet class but I found a Predicate, my mind just blowed first time I faced this bug
Fortunately, I found a way to find the actual class after I let go of my persistent thoughts about a "clean class". I just opened it in the assembler.
data:image/s3,"s3://crabby-images/eba2b/eba2bd6382f47a5e1e0620d21765a4af265c39fd" alt="image"
It was the actual class. But it was in the default package. This is where the problem starts...
As Java do not allow importing classes in default package from a non-default package class and the other way around (since Java 1.5), we can't import like that. So, CFR couldn't put the import statement of that class. But Recaf somehow recognizes this class as a same-package class I guess (because there is no import statement for that) and redirects me to the same-packaged class. (Both Predicate class named j1 and it's initializer class are in the
net.minecraft
package)The text was updated successfully, but these errors were encountered: