libbpf_cargo

Struct SkeletonBuilder

Source
pub struct SkeletonBuilder { /* private fields */ }
Expand description

SkeletonBuilder builds and generates a single skeleton.

This interface is meant to be used in build scripts.

§Examples

use libbpf_cargo::SkeletonBuilder;

SkeletonBuilder::new()
    .source("myobject.bpf.c")
    .debug(true)
    .clang("/opt/clang/clang")
    .build_and_generate("/output/path")
    .unwrap();

Implementations§

Source§

impl SkeletonBuilder

Source

pub fn new() -> Self

Source

pub fn source<P: AsRef<Path>>(&mut self, source: P) -> &mut SkeletonBuilder

Point the SkeletonBuilder to a source file for compilation

Default is None

Source

pub fn obj<P: AsRef<Path>>(&mut self, obj: P) -> &mut SkeletonBuilder

Point the SkeletonBuilder to an object file for generation

Default is None

Source

pub fn debug(&mut self, debug: bool) -> &mut SkeletonBuilder

Turn debug output on or off

Default is off

Source

pub fn clang<P: AsRef<Path>>(&mut self, clang: P) -> &mut SkeletonBuilder

Specify which clang binary to use

Default searches $PATH for clang

Source

pub fn clang_args<A, S>(&mut self, args: A) -> &mut SkeletonBuilder
where A: IntoIterator<Item = S>, S: AsRef<OsStr>,

Pass additional arguments to clang when building BPF object file

§Examples
use libbpf_cargo::SkeletonBuilder;

SkeletonBuilder::new()
    .source("myobject.bpf.c")
    .clang_args([
        "-DMACRO=value",
        "-I/some/include/dir",
    ])
    .build_and_generate("/output/path")
    .unwrap();
Source

pub fn skip_clang_version_check(&mut self, skip: bool) -> &mut SkeletonBuilder

Specify whether or not to skip clang version check

Default is false

Source

pub fn rustfmt<P: AsRef<Path>>(&mut self, rustfmt: P) -> &mut SkeletonBuilder

Specify which rustfmt binary to use

Default searches $PATH for rustfmt

Source

pub fn build_and_generate<P: AsRef<Path>>(&mut self, output: P) -> Result<()>

Build BPF programs and generate the skeleton at path output

Source

pub fn build(&mut self) -> Result<()>

Source

pub fn generate<P: AsRef<Path>>(&mut self, output: P) -> Result<()>

Trait Implementations§

Source§

impl Default for SkeletonBuilder

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

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.