Skip to content
/ ljd Public
forked from wenlong66/ljd

LuaJIT raw-bytecode decompiler

License

Notifications You must be signed in to change notification settings

sacwtv/ljd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

92 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LuaJIT raw-bytecode decompiler (LJD)

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.

SECOND WARNING! And, BTW, this all is a one huge prototype. Because the "release" version should be written into lua itself. Because it's cool to decompile the decompiler - a great test too!

How to use it

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

TODO

There is a lot of work to do, in the order of priority

  1. AST Optimizations - currently the resulting code is not even compilable.

    1. 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

    2. Logical expressions recomposition - logical expressions are not broken into dozen small if's. This should be fixed for code readability

    3. Use the line information (or common sense if there is no line information) to squash similar expressions into a single expression.

    4. Function names as function name () instead of name = function()

  2. Formatting improvements

    1. Use operator priority information for arithmetic expressions to omit redundant parentheses.

    2. 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

    3. Use method-style calls and definitions for tables.

  3. Features not supported:

    1. GOTO statement (from lua 5.2). All the required functionality is now in place, but that's rather a low-priority task right now

    2. 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.
    
    P.S. After a bit more research - it could be hard after all and
    I don't see much profit.,, An ultra-low priority
    

About

LuaJIT raw-bytecode decompiler

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 85.3%
  • Lua 14.7%