Struct CLIConfig

Source
pub struct CLIConfig {
Show 17 fields pub file_path: PathBuf, pub disassemble: bool, pub disassemble_symbol: Option<String>, pub file_headers: bool, pub argument_section: bool, pub line_numbers: bool, pub section_headers: bool, pub data: bool, pub full_contents: bool, pub stabs: bool, pub syms: bool, pub reloc: bool, pub all_headers: bool, pub info: bool, pub demangle: bool, pub show_no_raw_instr: bool, pub show_no_labels: bool,
}
Expand description

This structure controls all the settings that make this program perform differently These represent command line arguments read in by clap

Fields§

§file_path: PathBuf

The input file path, which is required

§disassemble: bool

Whether we should disassemble the file’s code sections Conflicts with disassemble_symbol and full-contents

§disassemble_symbol: Option<String>

Whether we should disassemble the file’s code sections, starting at a particular symbol Conflicts with disassemble and full-contents

§file_headers: bool

Whether we should dump the file headers KO only

§argument_section: bool

Whether we should dump the argument section contents KSM only

§line_numbers: bool

Whether we should display line numbers in disassembled code KSM only

§section_headers: bool

Whether we should dump the section header table KO only

§data: bool

Whether we should dump the data section of the file KO only

§full_contents: bool

Whether we should display the contents of every section in the object file

§stabs: bool

Whether we should dump the string tables of the file KO only

§syms: bool

Whether we should dump the symbol tables of the file KO only

§reloc: bool

Whether we should dump the relocation data section of the file KO only

§all_headers: bool

Whether we should display all of the section headers of the file KO only

§info: bool

Displays all available meta info of the object file including compiler comments and version information

§demangle: bool

Whether we should attempt to demangle symbol names

§show_no_raw_instr: bool

A flag for if we should NOT display raw instruction bytes in the disassembly KSM only

§show_no_labels: bool

A flag for if we should NOT display instruction labels in the disassembly KSM only

Trait Implementations§

Source§

impl Args for CLIConfig

Source§

fn group_id() -> Option<Id>

Report the ArgGroup::id for this set of arguments
Source§

fn augment_args<'b>(__clap_app: Command) -> Command

Append to Command so it can instantiate Self via FromArgMatches::from_arg_matches_mut Read more
Source§

fn augment_args_for_update<'b>(__clap_app: Command) -> Command

Append to Command so it can instantiate self via FromArgMatches::update_from_arg_matches_mut Read more
Source§

impl CommandFactory for CLIConfig

Source§

fn command<'b>() -> Command

Build a Command that can instantiate Self. Read more
Source§

fn command_for_update<'b>() -> Command

Build a Command that can update self. Read more
Source§

impl Debug for CLIConfig

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl FromArgMatches for CLIConfig

Source§

fn from_arg_matches(__clap_arg_matches: &ArgMatches) -> Result<Self, Error>

Instantiate Self from ArgMatches, parsing the arguments as needed. Read more
Source§

fn from_arg_matches_mut( __clap_arg_matches: &mut ArgMatches, ) -> Result<Self, Error>

Instantiate Self from ArgMatches, parsing the arguments as needed. Read more
Source§

fn update_from_arg_matches( &mut self, __clap_arg_matches: &ArgMatches, ) -> Result<(), Error>

Assign values from ArgMatches to self.
Source§

fn update_from_arg_matches_mut( &mut self, __clap_arg_matches: &mut ArgMatches, ) -> Result<(), Error>

Assign values from ArgMatches to self.
Source§

impl Parser for CLIConfig

Source§

fn parse() -> Self

Parse from std::env::args_os(), exit on error.
Source§

fn try_parse() -> Result<Self, Error>

Parse from std::env::args_os(), return Err on error.
Source§

fn parse_from<I, T>(itr: I) -> Self
where I: IntoIterator<Item = T>, T: Into<OsString> + Clone,

Parse from iterator, exit on error.
Source§

fn try_parse_from<I, T>(itr: I) -> Result<Self, Error>
where I: IntoIterator<Item = T>, T: Into<OsString> + Clone,

Parse from iterator, return Err on error.
Source§

fn update_from<I, T>(&mut self, itr: I)
where I: IntoIterator<Item = T>, T: Into<OsString> + Clone,

Update from iterator, exit on error. Read more
Source§

fn try_update_from<I, T>(&mut self, itr: I) -> Result<(), Error>
where I: IntoIterator<Item = T>, T: Into<OsString> + Clone,

Update from iterator, return Err on error.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.