Module

Struct Module 

Source
pub struct Module<'a> {
    pub functions: Vec<Function<'a>>,
    pub types: Vec<TypeDef<'a>>,
    pub data: Vec<DataDef<'a>>,
}
Expand description

A complete QBE IL module.

A module contains all the functions, data definitions, and type definitions that make up a QBE IL file. When converted to a string, it produces valid QBE IL code that can be compiled by QBE.

§Examples

use qbe::{Module, Function, DataDef, TypeDef, Linkage, Type, Value, Instr, DataItem};

// Create a new module
let mut module = Module::new();

// Add a string constant
let hello_str = DataDef::new(
    Linkage::private(),
    "hello",
    None,
    vec![
        (Type::Byte, DataItem::Str("Hello, World!\n".to_string())),
        (Type::Byte, DataItem::Const(0)), // Null terminator
    ],
);
module.add_data(hello_str);

// Add a main function that prints the string
let mut main = Function::new(
    Linkage::public(),
    "main",
    vec![],
    Some(Type::Word),
);

let mut start = main.add_block("start");

// Call printf with the string: %r = call $printf(l $hello)
start.assign_instr(
    Value::Temporary("r".to_string()),
    Type::Word,
    Instr::Call(
        "printf".to_string(),
        vec![(Type::Long, Value::Global("hello".to_string()))],
        None,
    ),
);

// Return 0
start.add_instr(Instr::Ret(Some(Value::Const(0))));

// Add the function to the module
module.add_function(main);

Fields§

§functions: Vec<Function<'a>>§types: Vec<TypeDef<'a>>§data: Vec<DataDef<'a>>

Implementations§

Source§

impl<'a> Module<'a>

Source

pub fn new() -> Module<'a>

Creates a new module

Examples found in repository?
examples/hello_world.rs (line 63)
62fn main() {
63    let mut module = Module::new();
64    generate_add_func(&mut module);
65    generate_main_func(&mut module);
66    generate_data(&mut module);
67    println!("{module}");
68}
Source

pub fn add_function(&mut self, func: Function<'a>) -> &mut Function<'a>

Adds a function to the module, returning a reference to it for later modification

Examples found in repository?
examples/hello_world.rs (line 24)
5fn generate_add_func(module: &mut Module) {
6    let mut func = Function::new(
7        Linkage::private(),
8        "add",
9        vec![
10            (Type::Word, Value::Temporary("a".into())),
11            (Type::Word, Value::Temporary("b".into())),
12        ],
13        Some(Type::Word),
14    );
15
16    func.add_block("start");
17    func.assign_instr(
18        Value::Temporary("c".into()),
19        Type::Word,
20        Instr::Add(Value::Temporary("a".into()), Value::Temporary("b".into())),
21    );
22    func.add_instr(Instr::Ret(Some(Value::Temporary("c".into()))));
23
24    module.add_function(func);
25}
26
27fn generate_main_func(module: &mut Module) {
28    let mut func = Function::new(Linkage::public(), "main", Vec::new(), Some(Type::Word));
29
30    func.add_block("start");
31    func.assign_instr(
32        Value::Temporary("r".into()),
33        Type::Word,
34        Instr::Call(
35            "add".into(),
36            vec![(Type::Word, Value::Const(1)), (Type::Word, Value::Const(1))],
37            None,
38        ),
39    );
40    func.add_instr(Instr::Call(
41        "printf".into(),
42        vec![
43            (Type::Long, Value::Global("fmt".into())),
44            (Type::Word, Value::Temporary("r".into())),
45        ],
46        Some(1),
47    ));
48    func.add_instr(Instr::Ret(Some(Value::Const(0))));
49
50    module.add_function(func);
51}
Source

pub fn add_type(&mut self, def: TypeDef<'a>) -> &mut TypeDef<'a>

Adds a type definition to the module, returning a reference to it for later modification

Source

pub fn add_data(&mut self, data: DataDef<'a>) -> &mut DataDef<'a>

Adds a data definition to the module

Examples found in repository?
examples/hello_world.rs (line 59)
53fn generate_data(module: &mut Module) {
54    let items = vec![
55        (Type::Byte, DataItem::Str("One and one make %d!\\n".into())),
56        (Type::Byte, DataItem::Const(0)),
57    ];
58    let data = DataDef::new(Linkage::private(), "fmt", None, items);
59    module.add_data(data);
60}

Trait Implementations§

Source§

impl<'a> Clone for Module<'a>

Source§

fn clone(&self) -> Module<'a>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for Module<'a>

Source§

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

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

impl<'a> Default for Module<'a>

Source§

fn default() -> Module<'a>

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

impl Display for Module<'_>

Source§

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

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

impl<'a> Hash for Module<'a>

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<'a> Ord for Module<'a>

Source§

fn cmp(&self, other: &Module<'a>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<'a> PartialEq for Module<'a>

Source§

fn eq(&self, other: &Module<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'a> PartialOrd for Module<'a>

Source§

fn partial_cmp(&self, other: &Module<'a>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<'a> Eq for Module<'a>

Source§

impl<'a> StructuralPartialEq for Module<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for Module<'a>

§

impl<'a> RefUnwindSafe for Module<'a>

§

impl<'a> Send for Module<'a>

§

impl<'a> Sync for Module<'a>

§

impl<'a> Unpin for Module<'a>

§

impl<'a> UnwindSafe for Module<'a>

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
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.