Why decompiling a delphi exe, is so easy, compared to others executables built with other programming languages/compilers?
Why decompiling a delphi exe, is so easy, compared to others executables built with
Share
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
There are a few things that help with reversing delphi programs:
publishedvisibility have metadata used with RTTIclasses. And for any instance of a class you happen to see in the debugger you can get its VMT and thus its class name.Delphi uses textfiles describing the content of your form and hooks up event handlers by name. This approach obviously needs enough metadata to deserialize that textual representation of a from and hook up the eventhandlers by name.
An alternative some other GUI toolkits use is auto-generating code that initializes the form and hooks up the event handler with code. Since this code directly uses pointers to the eventhandlers and directly assigns to properties/calls setters it doesn’t need any metadata. Which has the side-effect that reversing becomes a bit harder.
It shouldn’t be too hard to create a program that transforms a dfm file into a series of hardcoded instructions that creates the form instead. So a tool like DeDe won’t work that well anymore. But that doesn’t gain you much in practice.
But figuring out which evenhandler corresponds to which control/event is still rather easy. Especially since stuff like FLIRT identifies most library functions. So you just need to breakpoint the one you’re interested in and then step into the user code.