Main Page | Modules | Namespace List | Class Hierarchy | Class List | Directories | File List | Namespace Members | Class Members | File Members

Jdb_disasm Class Reference

#include <jdb_disasm_i.h>

Inheritance diagram for Jdb_disasm:

Jdb_module List of all members.

Public Member Functions

Jdb_module::Action_code action (int cmd, void *&args, char const *&fmt, int &next_char)
 The actual handler of the module.
Jdb_module::Cmd const *const cmds () const
 The commands this module provides.
int const num_cmds () const
 The number of commands this modules provides.
 Jdb_disasm ()

Static Public Member Functions

static bool show_disasm_line (int len, Address &addr, int show_symbols, Task_num task)
static Jdb_module::Action_code show (Address virt, Task_num task, int level)

Static Private Member Functions

static bool disasm_line (char *buffer, int buflen, Address &addr, int show_symbols, Task_num task)
static int at_symbol (Address addr, Task_num task)
static int at_line (Address addr, Task_num task)
static Address disasm_offset (Address &start, int offset, Task_num task)

Static Private Attributes

static char show_intel_syntax
static char show_lines = 2

Constructor & Destructor Documentation

Jdb_disasm::Jdb_disasm  ) 
 


Member Function Documentation

Jdb_module::Action_code Jdb_disasm::action int  cmd,
void *&  args,
char const *&  fmt,
int &  next_char
[virtual]
 

The actual handler of the module.

Parameters:
cmd the command ID (see Cmd::id) of the executed command.
args a reference to the argument buffer pointer.
fmt a reference to the format string pointer.
This method is pure virtual and must be provided by the specific derivate of the Jdb_module. action() is called if one of the module's commands was issued and the input according to the format string is read.

The args and fmt arguments are references because they may be modified by the action() method and extra input may be requested by returning Action_code::EXTRA_INPUT. In the case where Action_code::EXTRA_INPUT is returned the Jdb_core reads again the values according to the given format (fmt) and enters action(). With this mechanism it is possible to request further input depending on the already given input.

Implements Jdb_module.

int Jdb_disasm::at_line Address  addr,
Task_num  task
[static, private]
 

int Jdb_disasm::at_symbol Address  addr,
Task_num  task
[static, private]
 

Jdb_module::Cmd const *const Jdb_disasm::cmds  )  const [virtual]
 

The commands this module provides.

An array of Cmd structures must be returned, where each entry describes a single command. The command IDs (see Cmd::id) should be unique within the module, so that action() can distinguish between the different commands.

See also:
num_cmds()

Cmd

action()

Implements Jdb_module.

bool Jdb_disasm::disasm_line char *  buffer,
int  buflen,
Address &  addr,
int  show_symbols,
Task_num  task
[static, private]
 

Address Jdb_disasm::disasm_offset Address &  start,
int  offset,
Task_num  task
[static, private]
 

int const Jdb_disasm::num_cmds  )  const [virtual]
 

The number of commands this modules provides.

This method must return how many Cmd structures can be found in the array returned by cmds().

See also:
cmds()

Implements Jdb_module.

Jdb_module::Action_code Jdb_disasm::show Address  virt,
Task_num  task,
int  level
[static]
 

bool Jdb_disasm::show_disasm_line int  len,
Address &  addr,
int  show_symbols,
Task_num  task
[static]
 


Member Data Documentation

char Jdb_disasm::show_intel_syntax [static, private]
 

char Jdb_disasm::show_lines = 2 [static, private]
 


The documentation for this class was generated from the following files:
Generated on Mon Sep 26 14:20:15 2005 for Fiasco by  doxygen 1.4.2