Python idaapi.init_hexrays_plugin() Examples
The following are 6
code examples of idaapi.init_hexrays_plugin().
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example.
You may also want to check out all available functions/classes of the module
idaapi
, or try the search function
.
Example #1
Source File: ida_painter.py From lighthouse with MIT License | 6 votes |
def _notify_status_changed(self, status): # enable / disable hook based on the painter being enabled or disabled if status: self._idp_hooks.hook() if idaapi.init_hexrays_plugin(): idaapi.install_hexrays_callback(self._hxe_callback) else: self._idp_hooks.unhook() if idaapi.init_hexrays_plugin(): idaapi.remove_hexrays_callback(self._hxe_callback) # send the status changed signal... super(IDAPainter, self)._notify_status_changed(status) #------------------------------------------------------------------------------ # Paint Actions #------------------------------------------------------------------------------
Example #2
Source File: ida_batch_decompile.py From ida-batch_decompile with GNU General Public License v3.0 | 6 votes |
def __init__(self): self.is_windows = sys.platform.startswith('win') self.is_ida64 = GetIdbPath().endswith(".i64") # hackhackhack - check if we're ida64 or ida32 logger.debug("[+] is_windows: %r" % self.is_windows) logger.debug("[+] is_ida64: %r" % self.is_ida64) self.my_path = os.path.abspath(__file__) self.temp_path = None self._init_target() # settings (form) # todo: load from configfile if available. self.output_path = None self.chk_annotate_stackvar_size = False self.chk_annotate_xrefs = False self.chk_decompile_imports = False self.chk_decompile_imports_recursive = False self.chk_decompile_alternative = False # self.ida_home = idaapi.idadir(".") self.ida_home = GetIdaDirectory() # wait for ida analysis to finish self.wait_for_analysis_to_finish() if not idaapi.init_hexrays_plugin(): logger.warning("forcing hexrays to load...") self.load_plugin_decompiler() if not idaapi.init_hexrays_plugin(): raise Exception("hexrays decompiler is not available :(")
Example #3
Source File: ida_prefix.py From prefix with MIT License | 5 votes |
def _init_hexrays_hooks(self): """ Install Hex-Rrays hooks (when available). NOTE: This is called when the ui_ready_to_run event fires. """ if idaapi.init_hexrays_plugin(): idaapi.install_hexrays_callback(self._hooks.hxe_callback) #-------------------------------------------------------------------------- # IDA Actions #--------------------------------------------------------------------------
Example #4
Source File: hexrays.py From bap-ida-python with MIT License | 5 votes |
def init(self): """ Ensure plugin's line modification function is called whenever needed. If Hex-Rays is not installed, or is not initialized yet, then plugin will not load. To ensure that the plugin loads after Hex-Rays, please name your plugin's .py file with a name that starts lexicographically after "hexx86f" """ try: if idaapi.init_hexrays_plugin(): def hexrays_event_callback(event, *args): if event == idaapi.hxe_refresh_pseudocode: # We use this event instead of hxe_text_ready because # MacOSX doesn't seem to work well with it # TODO: Look into this vu, = args self.visit_func(vu.cfunc) return 0 idaapi.install_hexrays_callback(hexrays_event_callback) else: return idaapi.PLUGIN_SKIP except AttributeError: idc.Warning('''init_hexrays_plugin() not found. Skipping Hex-Rays plugin.''') return idaapi.PLUGIN_KEEP
Example #5
Source File: find_get_proc_address.py From flare-ida with Apache License 2.0 | 5 votes |
def main(): if not idaapi.init_hexrays_plugin(): return False print "Hex-rays version %s has been detected" % idaapi.get_hexrays_version() idaapi.install_hexrays_callback(event_callback)
Example #6
Source File: __init__.py From hrdev with MIT License | 4 votes |
def run(self): '''Start the plugin.''' if not idaapi.init_hexrays_plugin(): print "HRDEV Error: Failed to initialise Hex-Rays plugin." return function_name = idaapi.get_func_name(idaapi.get_screen_ea()) demangled_name = self.tools.demangle_name(function_name) src = idaapi.decompile(idaapi.get_screen_ea()) file_name = '{}.cpp'.format(self.tools.to_file_name(demangled_name)) cache_path = os.path.sep.join([tempfile.gettempdir(), 'hrdev_cache', self._bin_name]) # Create required directories if they dont exist tmp_dir_path = os.path.sep.join([tempfile.gettempdir(), 'hrdev_cache']) if not os.path.isdir(tmp_dir_path): os.mkdir(tmp_dir_path) if not os.path.isdir(cache_path): os.mkdir(cache_path) complete_path = os.path.sep.join([cache_path, file_name]) idaapi.msg("HRDEV cache path: {}\n".format(complete_path)) # Check if file is already in cache if not os.path.isfile(complete_path) or \ self.config_main.getboolean('etc', 'disable_cache'): self.tools.save_file(complete_path, str(src)) self.tools.set_file_path(complete_path) lvars = {} for v in src.lvars: _type = idaapi.print_tinfo('', 0, 0, idaapi.PRTYPE_1LINE, v.tif, '', '') lvars[str(v.name)] = "{} {} {}".\ format(_type, str(v.name), str(v.cmt)) max_title = self.config_main.getint('etc', 'max_title') self.gui = hrdev_plugin.include.gui.Canvas(self.config_main, self.config_theme, self.tools, lvars, demangled_name[:max_title]) self.gui.Show('HRDEV') self.parser = hrdev_plugin.include.syntax.Parser(self, lvars) self.parser.run(complete_path) return