ROSE  0.9.9.149
Classes | Public Member Functions | Public Attributes | List of all members
Rose::BinaryAnalysis::AsmUnparser::StaticDataDisassembler Class Reference

Description

Disassembles static data as if it were code.

This callback only does something if it is first initialized with a disassembler. It can also be initialized with an unparser, but that is optional (the default unparser will be the same as a default-constructed AsmUnparser except that a pre-instruction callback is added to print the string "(data)" in front of every instruction as a reminder that the instruction came from what ROSE considered to be static data.

Definition at line 596 of file AsmUnparser.h.

#include <AsmUnparser.h>

Inheritance diagram for Rose::BinaryAnalysis::AsmUnparser::StaticDataDisassembler:
Inheritance graph
[legend]
Collaboration diagram for Rose::BinaryAnalysis::AsmUnparser::StaticDataDisassembler:
Collaboration graph
[legend]

Classes

class  DataNote
 

Public Member Functions

virtual void reset ()
 
virtual void init (Disassembler *disassembler, AsmUnparser *unparser=NULL)
 
virtual bool operator() (bool enabled, const StaticDataArgs &args)
 Default callbacks. More...
 
- Public Member Functions inherited from Rose::BinaryAnalysis::AsmUnparser::UnparserCallback
virtual bool operator() (bool enabled, const InsnArgs &)
 Default callbacks. More...
 
virtual bool operator() (bool enabled, const BasicBlockArgs &)
 Default callbacks. More...
 
virtual bool operator() (bool enabled, const DataBlockArgs &)
 Default callbacks. More...
 
virtual bool operator() (bool enabled, const FunctionArgs &)
 Default callbacks. More...
 
virtual bool operator() (bool enabled, const InterpretationArgs &)
 Default callbacks. More...
 

Public Attributes

DataNote data_note
 
Disassemblerdisassembler
 
AsmUnparserunparser
 
bool unparser_allocated_here
 

Member Function Documentation

virtual bool Rose::BinaryAnalysis::AsmUnparser::StaticDataDisassembler::operator() ( bool  enabled,
const StaticDataArgs  
)
virtual

Default callbacks.

The default is to abort, because if these are called it means one of three things:

  1. The arguments are wrong in the subclass and the subclass therefore isn't providing an implementation when it thinks it is.
  2. The wrong type was used for the second argument. Instruction callbacks use InsnArgs, basic block callbacks use BasicBlockArgs, etc.
  3. The functor was added to the wrong callback list. For instance, an instruction functor was accidently added to one of the function callback lists.

Reimplemented from Rose::BinaryAnalysis::AsmUnparser::UnparserCallback.


The documentation for this class was generated from the following file: