-
Notifications
You must be signed in to change notification settings - Fork 21
/
decompile_simple.py
44 lines (33 loc) · 1.48 KB
/
decompile_simple.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#!/usr/bin/env python2
# -*- coding:utf-8 -*-
"""
Python Script used to communicate with Ghidra's API.
It will decompile all the functions of a defined binary and
save results into decompiled_output.c
The code is pretty straightforward, it includes comments and it is easy to understand.
This will help people that is starting with Automated Malware Analysis
using Headless scripts with Ghidra.
"""
import sys
from ghidra.app.decompiler import DecompInterface
from ghidra.util.task import ConsoleTaskMonitor
# Communicates with Decompiler Interface
decompinterface = DecompInterface()
# Open Current Program
decompinterface.openProgram(currentProgram);
# Get Binary Functions
functions = currentProgram.getFunctionManager().getFunctions(True)
# Prints Current Python version (2.7)
print "Current Python version: " + str(sys.version.decode())
# Iterates through all functions in the binary and decompiles them
# Then prints the Pseudo C Code
with open("decompiled_output.c", "w") as output_file:
for function in list(functions):
# Add a comment with the name of the function
# print "// Function: " + str(function)
output_file.write("// Function: " + str(function))
# Decompile each function
decompiled_function = decompinterface.decompileFunction(function, 0, ConsoleTaskMonitor())
# Print Decompiled Code
# print decompiled_function.getDecompiledFunction().getC()
output_file.write(decompiled_function.getDecompiledFunction().getC())