The original name was ljwthgnd as in LuaJIT 'What The Hell is Going On' Decompiler named under the LuaJIT C sources variable naming convention.
WARNING! This code is nor finished, nor tested yet! There is no even slightest warranty that resulting code is even near to the original. Use it at your own risk of the wasted time.
There is not argument parsing right now, so comment out things in the main.py
script and launch it as in main.py path/to/file.luac
There is a lot of work to do, in the order of priority
-
AST Optimizations - currently the resulting code is not even compilable.
-
Slots elimination - in case of debug information present it should be possible to eliminate all the slots in the resulting code, drastically reducing it's size and improving readability.
(and after that this will be really decompiler and not a just and improved disassembler).
In case of debug information NOT present (which is not supported right now) some slots for local variables may remain.
-
MULTRES elimination - pretty much straightforward after the slots elimination. The last thing to be done before the resulting code will be compilable.
-
If statements recomposition
if something then ... elseif something_else then ... end
is now translated into
if something then ... else if something_else then ... end end
This should be fixed for code readability
-
Logical expressions recomposition - logical expressions are not broken into dozen small if's. This should be fixed for code readability
-
Use the line information (or common sense if there is no line information) to squash similar expressions into a single expression.
-
Function names as function name () instead of name = function()
-
-
Formatting improvements
-
Use operator priority information for arithmetic expressions to omit redundant parentheses.
-
Use the line information (or common sense) to preserve empty lines and break long statements like in the original code. this should be done for code readability
-
Use method-style calls and definitions for tables.
-
-
Features not supported:
-
GOTO statement (from lua 5.2) - it isn't hard to add the goto statement support into the AST builder, but this will require random look-aheads to distinguish between GOTO and loop statements. And that's not cool, so I guess I'll wait until 5.2 will be released and fully supported by LuaJIT.
-
Local sub-blocks:
do ... end
These subblocks are not reflected anyhow directly in the bytecode. The only way to guess them is to watch local variable scopes, which is simple enough in case of non-stripped bytecode and a bit harder otherwise.
-