pub struct StackLayoutBuilder<'a> { /* private fields */ }
Expand description
Builder to create a stack layout as described by the StackLayoutRef
type.
Implementations§
Source§impl<'a> StackLayoutBuilder<'a>
impl<'a> StackLayoutBuilder<'a>
Sourcepub const fn new() -> Self
pub const fn new() -> Self
Creates a mew bioöder-
Examples found in repository?
examples/minimal_builder.rs (line 28)
27fn main() {
28 let builder = StackLayoutBuilder::new()
29 // can contain terminating zero; not mandatory in the builder
30 .add_argv("foo")
31 .add_argv("hello")
32 .add_envv("PATH=/bin")
33 .add_auxv(AuxVar::ExecFn("/usr/bin/foo".into()));
34
35 let layout = builder.build(None /* we create the layout in our address space */);
36 let layout = StackLayoutRef::new(layout.as_ref(), None);
37
38 // SAFETY: This is safe as all pointers point into our address space.
39 for (i, arg) in unsafe { layout.argv_iter() }.enumerate() {
40 println!(" [{i}] {}", arg.to_str().unwrap());
41 }
42}
Sourcepub fn add_argv(self, arg: impl Into<String>) -> Self
pub fn add_argv(self, arg: impl Into<String>) -> Self
Adds an argument to the builder.
Adding a terminating NUL byte is not necessary. Interim NUL bytes are prohibited.
Examples found in repository?
examples/minimal_builder.rs (line 30)
27fn main() {
28 let builder = StackLayoutBuilder::new()
29 // can contain terminating zero; not mandatory in the builder
30 .add_argv("foo")
31 .add_argv("hello")
32 .add_envv("PATH=/bin")
33 .add_auxv(AuxVar::ExecFn("/usr/bin/foo".into()));
34
35 let layout = builder.build(None /* we create the layout in our address space */);
36 let layout = StackLayoutRef::new(layout.as_ref(), None);
37
38 // SAFETY: This is safe as all pointers point into our address space.
39 for (i, arg) in unsafe { layout.argv_iter() }.enumerate() {
40 println!(" [{i}] {}", arg.to_str().unwrap());
41 }
42}
Sourcepub fn add_envv(self, env: impl Into<String>) -> Self
pub fn add_envv(self, env: impl Into<String>) -> Self
Adds an environment-variable to the builder.
Adding a terminating NUL byte is not necessary. Interim NUL bytes are prohibited.
The value must follow the key=value
syntax, where value
may be
empty.
Examples found in repository?
examples/minimal_builder.rs (line 32)
27fn main() {
28 let builder = StackLayoutBuilder::new()
29 // can contain terminating zero; not mandatory in the builder
30 .add_argv("foo")
31 .add_argv("hello")
32 .add_envv("PATH=/bin")
33 .add_auxv(AuxVar::ExecFn("/usr/bin/foo".into()));
34
35 let layout = builder.build(None /* we create the layout in our address space */);
36 let layout = StackLayoutRef::new(layout.as_ref(), None);
37
38 // SAFETY: This is safe as all pointers point into our address space.
39 for (i, arg) in unsafe { layout.argv_iter() }.enumerate() {
40 println!(" [{i}] {}", arg.to_str().unwrap());
41 }
42}
Sourcepub fn add_auxv(self, aux: AuxVar<'a>) -> Self
pub fn add_auxv(self, aux: AuxVar<'a>) -> Self
Adds an AuxVar
to the builder.
Examples found in repository?
examples/minimal_builder.rs (line 33)
27fn main() {
28 let builder = StackLayoutBuilder::new()
29 // can contain terminating zero; not mandatory in the builder
30 .add_argv("foo")
31 .add_argv("hello")
32 .add_envv("PATH=/bin")
33 .add_auxv(AuxVar::ExecFn("/usr/bin/foo".into()));
34
35 let layout = builder.build(None /* we create the layout in our address space */);
36 let layout = StackLayoutRef::new(layout.as_ref(), None);
37
38 // SAFETY: This is safe as all pointers point into our address space.
39 for (i, arg) in unsafe { layout.argv_iter() }.enumerate() {
40 println!(" [{i}] {}", arg.to_str().unwrap());
41 }
42}
Sourcepub fn build(self, target_addr: Option<usize>) -> ABox<[u8]>
pub fn build(self, target_addr: Option<usize>) -> ABox<[u8]>
Builds the layout with heap-allocated memory.
§Arguments
target_addr
: The address the stack layout in the target address space. This may be a user-space address of another process. If this isNone
then the address of the buffer will be used.
Examples found in repository?
examples/minimal_builder.rs (line 35)
27fn main() {
28 let builder = StackLayoutBuilder::new()
29 // can contain terminating zero; not mandatory in the builder
30 .add_argv("foo")
31 .add_argv("hello")
32 .add_envv("PATH=/bin")
33 .add_auxv(AuxVar::ExecFn("/usr/bin/foo".into()));
34
35 let layout = builder.build(None /* we create the layout in our address space */);
36 let layout = StackLayoutRef::new(layout.as_ref(), None);
37
38 // SAFETY: This is safe as all pointers point into our address space.
39 for (i, arg) in unsafe { layout.argv_iter() }.enumerate() {
40 println!(" [{i}] {}", arg.to_str().unwrap());
41 }
42}
Trait Implementations§
Source§impl<'a> Clone for StackLayoutBuilder<'a>
impl<'a> Clone for StackLayoutBuilder<'a>
Source§fn clone(&self) -> StackLayoutBuilder<'a>
fn clone(&self) -> StackLayoutBuilder<'a>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<'a> Debug for StackLayoutBuilder<'a>
impl<'a> Debug for StackLayoutBuilder<'a>
Source§impl<'a> Default for StackLayoutBuilder<'a>
impl<'a> Default for StackLayoutBuilder<'a>
Source§fn default() -> StackLayoutBuilder<'a>
fn default() -> StackLayoutBuilder<'a>
Returns the “default value” for a type. Read more
Source§impl<'a> PartialEq for StackLayoutBuilder<'a>
impl<'a> PartialEq for StackLayoutBuilder<'a>
impl<'a> Eq for StackLayoutBuilder<'a>
impl<'a> StructuralPartialEq for StackLayoutBuilder<'a>
Auto Trait Implementations§
impl<'a> Freeze for StackLayoutBuilder<'a>
impl<'a> RefUnwindSafe for StackLayoutBuilder<'a>
impl<'a> !Send for StackLayoutBuilder<'a>
impl<'a> !Sync for StackLayoutBuilder<'a>
impl<'a> Unpin for StackLayoutBuilder<'a>
impl<'a> UnwindSafe for StackLayoutBuilder<'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