Decompile Vb6 Exe To Source Code

  1. How To Decompile Exe File
  2. Vb6 Exe Decompiler To Source Code Free
  3. Decompile A Program
  4. Decompile Vb6 Exe To Source Code Online
  5. Decompile Vb6 Exe To Source Code


This is the home page of (yet another) open source

It is the exe decompiler for Visual Basic applications & disassembler for Visual Studio.NET apps. VB Decompiler can recover the lost source code of your Visual Basic applications. Rumi book in urdu. It supports disassembling and analyzing the IL code of Visual Basic.NET, C#, etc. Visit for more content! Including Blogs, Forums and Downloads. Use my G2A Referral link and help me out!:

Decompiling vb6.exe project to source code Can you guide me how to de-compile a visual basic 6.0 exe file to source code file. This thread is locked. You can follow the question or vote as helpful, but you cannot reply to this thread. I have the same question (0). VB Decompiler is an advanced tool that can decompile programs (EXE, DLL, or OCX) written in Visual Basic 5.0/6.0 and disassemble programs based on.NET technology. As you know, programs written in Visual Basic can be compiled to interpreted p-code or to native code, and a.NET assembly is always compiled to Microsoft intermediate language.

machine code decompiler

How To Decompile Exe File

project. The goal of a machine code decompiler is to analyze executable files (like .EXE or .DLL files in Windows or ELF files in Unix-like environments) and attempt to create a high level representation of the machine code in the executable file:the decompiler tries to reconstruct the source code from which the executable was compiled in the first place.

Vb6 Exe Decompiler To Source Code Free

To download the Decompiler, go to the project page:

Since compilation is a non-reversible process (information such as comments and variable data types is irretrievably lost), decompilation can never completely recover the source code of a machine code executable. However, with some oracular (read 'human') assistance, it can go a long waytowards this goal. An oracle can provide function parameter types, the locations of otherwise unreachable code, and user-specified comments.

The decompiler is designed to be processor- and platform-agnostic. The intent is that you should be able to useit to decompile executables for any processor architecture and not be tied to a particular instruction set. Although currently only a x86 front end is implemented, there is nothing preventing you from implementing a 68K, Sparc, or VAX front end if you need one.

The decompiler can be run as a command-line tool, in which case it can be fed either with a simple executable file, or a decompiler project file, which not only specifies the executable file to decompile but also any oracular information that assists its work. The decompiler also has a graphical front end, which lets an operator specify oracular information while examining the decompiled executable.

Decompile Vb6 Exe To Source Code

The outputs of the decompiler are a C source code file containing all the disassembled code and a header file in which type-reconstructed data types can be found.


Decompile A Program

The decompiler consists of several phases.
  • The loading phase loads the executable into memory and determines what kind of executable is being decompiled. The executable format usually defines the processor format and the expected operating system environment. For older formats, such as plain MS-DOS .EXE files, the processor (x86 real mode) and operating system environent (MS-DOS) are implicit. Once the format is determined, the binary is loaded into memory (uncompressing it if necessary) and pointer or segment relocations are carried out. These relocations are also helpfulin later stages of the decompiler, as each relocated pointer valuecan be given a preliminary type pointer-to(<unknown>) andeach relocated segment selector the type segment-selector.
  • The scanning phase follows the loading phase. The executablewill usually have one or more entry points, addresses pointing to executable code. The code at the the entry points is disassembled and traced, looking in particular for branch, call, and return statements. Successively, individual procedures are discovered, and call graph is built up, whose edges represent calls between procedures.
  • The rewriting phase rewrites all machine-specific instructions into low-level machine-independent instructions. Idiomatic instruction sequences are rewritten to expressions. From this point on, the decompilation process is processor independent.
  • The analysis phase first does a interprocedural reaching definitions analysis. This is done to determine, for each procedure proc of the program, which processor registersare preserved and which processor registers are modified after a call to proc. A subsequent interprocedural liveness analysis, combined with the results of the reaching definitions analysis, determins which processor registers are used as parameters and return value registers for each procedure. Note that this analysis avoids depending on a specific processor/platform ABI or calling convention. Once the two interprocedural analyses are complete, the procedures can be rewritten with their explicit arguments. Subsequent analyses are then performed on a procedure-by-procedure basis. Procedures are converted into SSA Form, condition code flags are eliminated and expressions are simplified. Finally the procedures are converted out of SSA Form.
  • The interprocedural type analysis phase attempts to recover the data types used in the program by analyzing the way in which values are used by the program code, incorporating clues obtained from the relocation data as well as any 'oracular' information provided by the user. Memory access expressions are converted into their C equivalents: pointer dereferences (*foo), member access expressions (foo->bar), and array references (foo[bar]).
  • Finally, a structure analysis rewrites the control structures from unstructured goto-sphaghetti code to C-language if, while- / do-loops, and switch-statements.


The decompiler is written in C# and currently targets CLR version 2.0.It's currently developed with Visual Studio 2005, but the planis to have a working MonoDevelop project soon (wanna pitch in?)

The project implements the Test Driven Development methodology, with heavy emphasis on unit testing.No new code is allowed into the project unless it has one or more associated tests written for it. Developing a decompiler is notoriously tricky work with lots of special cases. Not having unit tests would make development an eternal bug hunt as fixes for one bug introduce other bugs. Unit tests are developed using NUnit v2.2.

SourceVisual studio decompile exe

Subversion is used for source control.

Decompile Vb6 Exe To Source Code Online


The decompiler project is in a pre-alpha stage. As it stands, it is able to load MS-DOS and PE binary files,disassemble their contents, rewrite the disassembled instructions into intermediate code, and perform the analysis phasementioned above. Currently work is focussed on type analysis, while code structuring is on the back-burner as it's considerablyless complex than type recovery.If you'd like to chip in, feel free to contact us!

Decompile Vb6 Exe To Source Code