pub enum KnownType<'a> {
ELF(Elf<'a>),
EXE(EXE<'a>),
MachO(Macho<'a>),
FatMachO(FatMacho<'a>),
PEF(Pef<'a>),
Office95(Office95<'a>),
PDF(PDF<'a>),
RTF(Rtf<'a>),
Unknown(&'a [u8]),
}
Expand description
Types known to MalwareDB
Variants§
ELF(Elf<'a>)
Linux, *BSD, Haiku, Solaris, etc binaries
EXE(EXE<'a>)
Windows, DOS, OS/2 Executables. Anything ending with:
- .cpl
- .dll
- .exe
- .ocx
- .sys
MachO(Macho<'a>)
Single architecture macOS (and derivatives) binaries
FatMachO(FatMacho<'a>)
Multiple architecture macOS (and derivatives) binaries
PEF(Pef<'a>)
Classic Mac OS and Be OS
Office95(Office95<'a>)
Microsoft Office Compound Document Format
PDF(PDF<'a>)
Adobe PDF document
RTF(Rtf<'a>)
Rich Text File
Unknown(&'a [u8])
Files for which we don’t have an analytic or feature extractor, or are of an unknown type
Implementations§
Source§impl<'a> KnownType<'a>
impl<'a> KnownType<'a>
Sourcepub fn new(data: &'a [u8]) -> Result<Self>
pub fn new(data: &'a [u8]) -> Result<Self>
Known type from a sequence of bytes
§Errors
Returns an error if the parser fails to process the detect type.
Sourcepub fn exec(self) -> Option<Box<dyn ExecutableFile + Send + 'a>>
pub fn exec(self) -> Option<Box<dyn ExecutableFile + Send + 'a>>
Get the file’s inner executable type
Trait Implementations§
Auto Trait Implementations§
impl<'a> Freeze for KnownType<'a>
impl<'a> RefUnwindSafe for KnownType<'a>
impl<'a> Send for KnownType<'a>
impl<'a> Sync for KnownType<'a>
impl<'a> Unpin for KnownType<'a>
impl<'a> UnwindSafe for KnownType<'a>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more