Comments (4)
This is (partially) handled in InstanceConstants
However, while it's a 'nice' thing, it tends to lead to completely confusing code in all but the most obvious cases; it's been a while so I may be mis remembering, but GUI code in particular uses a lot of magic constants , so the code to do this is very pessimistic. ( while a false negative is annoying, a false positive is downright confusing ).
from cfr.
The name of the constant is not stored in the constant pool in the bytecode. The disassembled code looks like this:
419: aload_0
420: dload 23
422: ldc2_w #117 // double 1.6777216E7d
425: dmul
426: invokestatic #66 // Method org/bukkit/util/NumberConversions.floor:(D)I
429: putfield #119 // Field secondError:I
So it's just fetching the value stored at index 117
in the constant pool and pushing it onto the stack. There's no name associated with that value.
So the best CFR would be able to do is guess that it's the same as the gridSize
constant. Is that what you're proposing?
from cfr.
The name of the constant is not stored in the constant pool in the bytecode. The disassembled code looks like this:
419: aload_0 420: dload 23 422: ldc2_w #117 // double 1.6777216E7d 425: dmul 426: invokestatic #66 // Method org/bukkit/util/NumberConversions.floor:(D)I 429: putfield #119 // Field secondError:I
So it's just fetching the value stored at index
117
in the constant pool and pushing it onto the stack. There's no name associated with that value.So the best CFR would be able to do is guess that it's the same as the
gridSize
constant. Is that what you're proposing?
Yes, that's what I'm proposing. Thank you for clarifying that!
from cfr.
This is (partially) handled in InstanceConstants
However, while it's a 'nice' thing, it tends to lead to completely confusing code in all but the most obvious cases; it's been a while so I may be mis remembering, but GUI code in particular uses a lot of magic constants , so the code to do this is very pessimistic. ( while a false negative is annoying, a false positive is downright confusing ).
Thank you for your explanation.
from cfr.
Related Issues (20)
- CFR generates incorrect code for type arguments
- CFR may perform incorrect modifications to the type of generic class variables
- CFR generates duplicate variable names inside and outside lambda expressions
- Type argument of null reference generic class variables is converted to Object
- Casting of primitive types may be decompiled as casting of corresponding wrapper classes under certain circumstances
- Type Conversion Expression Lost in Constructor
- Question: Is there any switch to specify a single class to be decompiled? HOT 1
- How can I show the class packages?
- Option to remove the file headers HOT 1
- Question: decompiling multiple files from terminal HOT 1
- How do I decompile using CFR's CFRDriver?
- Decompiling class files from Java bytecode source HOT 2
- Ternary Expression Causing Decompilation Type Error
- Incorrect Comparable Expression Produced by Ternary Expression
- CFR can't handle recent Oracle JDBC jars HOT 1
- CFR omits parentheses in expressions with mixed operators HOT 1
- CFR omits optional braces after if statements HOT 1
- Extractable last case doesn't follow previous, and can't clone.
- Decompiler HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
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.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from cfr.