Struct wasmparser::BinaryReader
source · [−]pub struct BinaryReader<'a> { /* private fields */ }
Expand description
A binary reader of the WebAssembly structures and types.
Implementations
sourceimpl<'a> BinaryReader<'a>
impl<'a> BinaryReader<'a>
sourcepub fn new(data: &[u8]) -> BinaryReader<'_>
pub fn new(data: &[u8]) -> BinaryReader<'_>
Constructs BinaryReader
type.
Examples
let fn_body = &vec![0x41, 0x00, 0x10, 0x00, 0x0B];
let mut reader = wasmparser::BinaryReader::new(fn_body);
while !reader.eof() {
let op = reader.read_operator();
println!("{:?}", op)
}
sourcepub fn new_with_offset(data: &[u8], original_offset: usize) -> BinaryReader<'_>
pub fn new_with_offset(data: &[u8], original_offset: usize) -> BinaryReader<'_>
Constructs a BinaryReader
with an explicit starting offset.
pub fn original_position(&self) -> usize
sourcepub fn range(&self) -> Range
pub fn range(&self) -> Range
Returns a range from the starting offset to the end of the buffer.
pub fn read_type(&mut self) -> Result<Type>
sourcepub fn current_position(&self) -> usize
pub fn current_position(&self) -> usize
Returns the BinaryReader
’s current position.
sourcepub fn bytes_remaining(&self) -> usize
pub fn bytes_remaining(&self) -> usize
Returns the number of bytes remaining in the BinaryReader
.
sourcepub fn read_bytes(&mut self, size: usize) -> Result<&'a [u8]>
pub fn read_bytes(&mut self, size: usize) -> Result<&'a [u8]>
Advances the BinaryReader
size
bytes, and returns a slice from the
current position of size
length.
Errors
If size
exceeds the remaining length in BinaryReader
.
sourcepub fn read_u32(&mut self) -> Result<u32>
pub fn read_u32(&mut self) -> Result<u32>
Advances the BinaryReader
four bytes and returns a u32
.
Errors
If BinaryReader
has less than four bytes remaining.
sourcepub fn read_u64(&mut self) -> Result<u64>
pub fn read_u64(&mut self) -> Result<u64>
Advances the BinaryReader
eight bytes and returns a u64
.
Errors
If BinaryReader
has less than eight bytes remaining.
sourcepub fn read_u8(&mut self) -> Result<u32>
pub fn read_u8(&mut self) -> Result<u32>
Advances the BinaryReader
a single byte, and returns the data as
a u32
.
Errors
If BinaryReader
has no bytes remaining.
sourcepub fn read_var_u8(&mut self) -> Result<u32>
pub fn read_var_u8(&mut self) -> Result<u32>
Advances the BinaryReader
up to two bytes to parse a variable
length integer as a u8
.
Errors
If BinaryReader
has less than one or two bytes remaining, or the
integer is larger than eight bits.
sourcepub fn read_var_u32(&mut self) -> Result<u32>
pub fn read_var_u32(&mut self) -> Result<u32>
Advances the BinaryReader
up to four bytes to parse a variable
length integer as a u32
.
Errors
If BinaryReader
has less than one or up to four bytes remaining, or
the integer is larger than 32 bits.
sourcepub fn read_var_u64(&mut self) -> Result<u64>
pub fn read_var_u64(&mut self) -> Result<u64>
Advances the BinaryReader
up to four bytes to parse a variable
length integer as a u64
.
Errors
If BinaryReader
has less than one or up to eight bytes remaining, or
the integer is larger than 64 bits.
sourcepub fn skip_var_32(&mut self) -> Result<()>
pub fn skip_var_32(&mut self) -> Result<()>
Advances the BinaryReader
up to four bytes over a variable length 32
bit integer, discarding the result.
Errors
If BinaryReader
has less than one or up to four bytes remaining, or
the integer is larger than 32 bits.
sourcepub fn skip_bytes(&mut self, len: usize) -> Result<()>
pub fn skip_bytes(&mut self, len: usize) -> Result<()>
Advances the BinaryReader
len
bytes, skipping the result.
Errors
If BinaryReader
has less than len
bytes remaining.
sourcepub fn skip_string(&mut self) -> Result<()>
pub fn skip_string(&mut self) -> Result<()>
Advances the BinaryReader
past a WebAssembly string. This method does
not perform any utf-8 validation.
Errors
If BinaryReader
has less than four bytes, the string’s length exceeds
the remaining bytes, or the string length
exceeds limits::MAX_WASM_STRING_SIZE
.
sourcepub fn read_var_i32(&mut self) -> Result<i32>
pub fn read_var_i32(&mut self) -> Result<i32>
Advances the BinaryReader
up to four bytes to parse a variable
length integer as a i32
.
Errors
If BinaryReader
has less than one or up to four bytes remaining, or
the integer is larger than 32 bits.
sourcepub fn read_var_s33(&mut self) -> Result<i64>
pub fn read_var_s33(&mut self) -> Result<i64>
Advances the BinaryReader
up to four bytes to parse a variable
length integer as a signed 33 bit integer, returned as a i64
.
Errors
If BinaryReader
has less than one or up to five bytes remaining, or
the integer is larger than 33 bits.
sourcepub fn read_var_i64(&mut self) -> Result<i64>
pub fn read_var_i64(&mut self) -> Result<i64>
Advances the BinaryReader
up to eight bytes to parse a variable
length integer as a 64 bit integer, returned as a i64
.
Errors
If BinaryReader
has less than one or up to eight bytes remaining, or
the integer is larger than 64 bits.
sourcepub fn read_f32(&mut self) -> Result<Ieee32>
pub fn read_f32(&mut self) -> Result<Ieee32>
Advances the BinaryReader
up to four bytes to parse a variable
length integer as a 32 bit floating point integer, returned as Ieee32
.
Errors
If BinaryReader
has less than one or up to four bytes remaining, or
the integer is larger than 32 bits.
sourcepub fn read_f64(&mut self) -> Result<Ieee64>
pub fn read_f64(&mut self) -> Result<Ieee64>
Advances the BinaryReader
up to four bytes to parse a variable
length integer as a 32 bit floating point integer, returned as Ieee32
.
Errors
If BinaryReader
has less than one or up to four bytes remaining, or
the integer is larger than 32 bits.
sourcepub fn read_string(&mut self) -> Result<&'a str>
pub fn read_string(&mut self) -> Result<&'a str>
Reads a WebAssembly string from the module.
Errors
If BinaryReader
has less than up to four bytes remaining, the string’s
length exceeds the remaining bytes, the string’s length exceeds
limits::MAX_WASM_STRING_SIZE
, or the string contains invalid utf-8.
sourcepub fn read_operator(&mut self) -> Result<Operator<'a>>
pub fn read_operator(&mut self) -> Result<Operator<'a>>
Reads the next available Operator
.
Errors
If BinaryReader
has less bytes remaining than required to parse
the Operator
.
Trait Implementations
sourceimpl<'a> Clone for BinaryReader<'a>
impl<'a> Clone for BinaryReader<'a>
sourcefn clone(&self) -> BinaryReader<'a>
fn clone(&self) -> BinaryReader<'a>
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl<'a> Debug for BinaryReader<'a>
impl<'a> Debug for BinaryReader<'a>
Auto Trait Implementations
impl<'a> RefUnwindSafe for BinaryReader<'a>
impl<'a> Send for BinaryReader<'a>
impl<'a> Sync for BinaryReader<'a>
impl<'a> Unpin for BinaryReader<'a>
impl<'a> UnwindSafe for BinaryReader<'a>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more