pub struct Function(pub DefaultKey);
Tuple Fields§
§0: DefaultKey
Implementations§
Source§impl Function
impl Function
Sourcepub fn new(
context: &mut Context<'_>,
module: Module,
name: String,
args: Vec<(String, Type, Option<MetadataIndex>)>,
return_type: Type,
selector: Option<[u8; 4]>,
is_public: bool,
is_entry: bool,
is_original_entry: bool,
is_fallback: bool,
metadata: Option<MetadataIndex>,
) -> Function
pub fn new( context: &mut Context<'_>, module: Module, name: String, args: Vec<(String, Type, Option<MetadataIndex>)>, return_type: Type, selector: Option<[u8; 4]>, is_public: bool, is_entry: bool, is_original_entry: bool, is_fallback: bool, metadata: Option<MetadataIndex>, ) -> Function
Sourcepub fn create_block(
&self,
context: &mut Context<'_>,
label: Option<Label>,
) -> Block
pub fn create_block( &self, context: &mut Context<'_>, label: Option<Label>, ) -> Block
Create and append a new Block
to this function.
Sourcepub fn create_block_before(
&self,
context: &mut Context<'_>,
other: &Block,
label: Option<Label>,
) -> Result<Block, IrError>
pub fn create_block_before( &self, context: &mut Context<'_>, other: &Block, label: Option<Label>, ) -> Result<Block, IrError>
Create and insert a new Block
into this function.
The new block is inserted before other
.
Sourcepub fn create_block_after(
&self,
context: &mut Context<'_>,
other: &Block,
label: Option<Label>,
) -> Result<Block, IrError>
pub fn create_block_after( &self, context: &mut Context<'_>, other: &Block, label: Option<Label>, ) -> Result<Block, IrError>
Create and insert a new Block
into this function.
The new block is inserted after other
.
Sourcepub fn remove_block(
&self,
context: &mut Context<'_>,
block: &Block,
) -> Result<(), IrError>
pub fn remove_block( &self, context: &mut Context<'_>, block: &Block, ) -> Result<(), IrError>
Remove a Block
from this function.
Care must be taken to ensure the block has no predecessors otherwise the function will be made invalid.
Sourcepub fn get_unique_label(
&self,
context: &mut Context<'_>,
hint: Option<String>,
) -> String
pub fn get_unique_label( &self, context: &mut Context<'_>, hint: Option<String>, ) -> String
Get a new unique block label.
If hint
is None
then the label will be in the form "blockN"
where N is an
incrementing decimal.
Otherwise if the hint is already unique to this function it will be returned. If not already unique it will have N appended to it until it is unique.
Sourcepub fn num_blocks(&self, context: &Context<'_>) -> usize
pub fn num_blocks(&self, context: &Context<'_>) -> usize
Return the number of blocks in this function.
Sourcepub fn num_instructions(&self, context: &Context<'_>) -> usize
pub fn num_instructions(&self, context: &Context<'_>) -> usize
Return the number of instructions in this function.
The crate::InstOp::AsmBlock is counted as a single instruction, regardless of the number of crate::asm::AsmInstructions in the ASM block. E.g., even if the ASM block is empty and contains no instructions, it will still be counted as a single instruction.
If you want to count every ASM instruction as an instruction, use
num_instructions_incl_asm_instructions
instead.
Sourcepub fn num_instructions_incl_asm_instructions(
&self,
context: &Context<'_>,
) -> usize
pub fn num_instructions_incl_asm_instructions( &self, context: &Context<'_>, ) -> usize
Return the number of instructions in this function, including the crate::asm::AsmInstructions found in crate::InstOp::AsmBlocks.
Every crate::asm::AsmInstruction encountered in any of the ASM blocks will be counted as an instruction. The crate::InstOp::AsmBlock itself is not counted but rather replaced with the number of ASM instructions found in the block. In other words, empty ASM blocks do not count as instructions.
If you want to count crate::InstOp::AsmBlocks as single instructions, use
num_instructions
instead.
Sourcepub fn get_module(&self, context: &Context<'_>) -> Module
pub fn get_module(&self, context: &Context<'_>) -> Module
Return the module that this function belongs to.
Sourcepub fn get_entry_block(&self, context: &Context<'_>) -> Block
pub fn get_entry_block(&self, context: &Context<'_>) -> Block
Return the function entry (i.e., the first) block.
Sourcepub fn get_metadata(&self, context: &Context<'_>) -> Option<MetadataIndex>
pub fn get_metadata(&self, context: &Context<'_>) -> Option<MetadataIndex>
Return the attached metadata.
Sourcepub fn has_selector(&self, context: &Context<'_>) -> bool
pub fn has_selector(&self, context: &Context<'_>) -> bool
Whether this function has a valid selector.
Sourcepub fn get_selector(&self, context: &Context<'_>) -> Option<[u8; 4]>
pub fn get_selector(&self, context: &Context<'_>) -> Option<[u8; 4]>
Return the function selector, if it has one.
Sourcepub fn is_entry(&self, context: &Context<'_>) -> bool
pub fn is_entry(&self, context: &Context<'_>) -> bool
Whether or not the function is a program entry point, i.e. main
, #[test]
fns or abi
methods.
Sourcepub fn is_original_entry(&self, context: &Context<'_>) -> bool
pub fn is_original_entry(&self, context: &Context<'_>) -> bool
Whether or not the function was a program entry point, i.e. main
, #[test]
fns or abi
methods, before it got wrapped within the __entry
function.
Sourcepub fn is_fallback(&self, context: &Context<'_>) -> bool
pub fn is_fallback(&self, context: &Context<'_>) -> bool
Whether or not this function is a contract fallback function
pub fn get_return_type(&self, context: &Context<'_>) -> Type
pub fn set_return_type(&self, context: &mut Context<'_>, new_ret_type: Type)
Sourcepub fn get_arg(&self, context: &Context<'_>, name: &str) -> Option<Value>
pub fn get_arg(&self, context: &Context<'_>, name: &str) -> Option<Value>
Get an arg value by name, if found.
Sourcepub fn add_arg<S: Into<String>>(
&self,
context: &mut Context<'_>,
name: S,
arg: Value,
)
pub fn add_arg<S: Into<String>>( &self, context: &mut Context<'_>, name: S, arg: Value, )
Append an extra argument to the function signature.
NOTE: arg
must be a BlockArgument
value with the correct index otherwise add_arg
will
panic.
Sourcepub fn lookup_arg_name<'a>(
&self,
context: &'a Context<'_>,
value: &Value,
) -> Option<&'a String>
pub fn lookup_arg_name<'a>( &self, context: &'a Context<'_>, value: &Value, ) -> Option<&'a String>
Find the name of an arg by value.
Sourcepub fn args_iter<'a>(
&self,
context: &'a Context<'_>,
) -> impl Iterator<Item = &'a (String, Value)>
pub fn args_iter<'a>( &self, context: &'a Context<'_>, ) -> impl Iterator<Item = &'a (String, Value)>
Return an iterator for each of the function arguments.
Sourcepub fn get_local_var(
&self,
context: &Context<'_>,
name: &str,
) -> Option<LocalVar>
pub fn get_local_var( &self, context: &Context<'_>, name: &str, ) -> Option<LocalVar>
Get a pointer to a local value by name, if found.
Sourcepub fn lookup_local_name<'a>(
&self,
context: &'a Context<'_>,
var: &LocalVar,
) -> Option<&'a String>
pub fn lookup_local_name<'a>( &self, context: &'a Context<'_>, var: &LocalVar, ) -> Option<&'a String>
Find the name of a local value by pointer.
Sourcepub fn new_local_var(
&self,
context: &mut Context<'_>,
name: String,
local_type: Type,
initializer: Option<Constant>,
mutable: bool,
) -> Result<LocalVar, IrError>
pub fn new_local_var( &self, context: &mut Context<'_>, name: String, local_type: Type, initializer: Option<Constant>, mutable: bool, ) -> Result<LocalVar, IrError>
Add a value to the function local storage.
The name must be unique to this function else an error is returned.
Sourcepub fn new_unique_local_var(
&self,
context: &mut Context<'_>,
name: String,
local_type: Type,
initializer: Option<Constant>,
mutable: bool,
) -> LocalVar
pub fn new_unique_local_var( &self, context: &mut Context<'_>, name: String, local_type: Type, initializer: Option<Constant>, mutable: bool, ) -> LocalVar
Add a value to the function local storage, by forcing the name to be unique if needed.
Will use the provided name as a hint and rename to guarantee insertion.
Sourcepub fn locals_iter<'a>(
&self,
context: &'a Context<'_>,
) -> impl Iterator<Item = (&'a String, &'a LocalVar)>
pub fn locals_iter<'a>( &self, context: &'a Context<'_>, ) -> impl Iterator<Item = (&'a String, &'a LocalVar)>
Return an iterator to all of the values in this function’s local storage.
Sourcepub fn remove_locals(&self, context: &mut Context<'_>, removals: &Vec<String>)
pub fn remove_locals(&self, context: &mut Context<'_>, removals: &Vec<String>)
Remove given list of locals
Sourcepub fn merge_locals_from(
&self,
context: &mut Context<'_>,
other: Function,
) -> HashMap<LocalVar, LocalVar>
pub fn merge_locals_from( &self, context: &mut Context<'_>, other: Function, ) -> HashMap<LocalVar, LocalVar>
Merge values from another Function
into this one.
The names of the merged values are guaranteed to be unique via the use of
Function::new_unique_local_var
.
Returns a map from the original pointers to the newly merged pointers.
Sourcepub fn block_iter(&self, context: &Context<'_>) -> BlockIterator ⓘ
pub fn block_iter(&self, context: &Context<'_>) -> BlockIterator ⓘ
Return an iterator to each block in this function.
Sourcepub fn instruction_iter<'a>(
&self,
context: &'a Context<'_>,
) -> impl Iterator<Item = (Block, Value)> + 'a
pub fn instruction_iter<'a>( &self, context: &'a Context<'_>, ) -> impl Iterator<Item = (Block, Value)> + 'a
Return an iterator to each instruction in each block in this function.
This is a convenience method for when all instructions in a function need to be inspected. The instruction value is returned from the iterator along with the block it belongs to.
Sourcepub fn replace_values(
&self,
context: &mut Context<'_>,
replace_map: &FxHashMap<Value, Value>,
starting_block: Option<Block>,
)
pub fn replace_values( &self, context: &mut Context<'_>, replace_map: &FxHashMap<Value, Value>, starting_block: Option<Block>, )
Replace a value with another within this function.
This is a convenience method which iterates over this function’s blocks and calls
Block::replace_values
in turn.
starting_block
is an optimisation for when the first possible reference to old_val
is
known.
pub fn replace_value( &self, context: &mut Context<'_>, old_val: Value, new_val: Value, starting_block: Option<Block>, )
Trait Implementations§
Source§impl PassScope for Function
impl PassScope for Function
fn get_arena_idx(&self) -> DefaultKey
impl Copy for Function
impl Eq for Function
impl StructuralPartialEq for Function
Auto Trait Implementations§
impl Freeze for Function
impl RefUnwindSafe for Function
impl Send for Function
impl Sync for Function
impl Unpin for Function
impl UnwindSafe for Function
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.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>
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>
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 moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> StorageAsMut for T
impl<T> StorageAsMut for T
fn storage<Type>(&mut self) -> StorageMut<'_, Self, Type>where
Type: Mappable,
fn storage_as_mut<Type>(&mut self) -> StorageMut<'_, Self, Type>where
Type: Mappable,
Source§impl<T> StorageAsRef for T
impl<T> StorageAsRef for T
fn storage<Type>(&self) -> StorageRef<'_, Self, Type>where
Type: Mappable,
fn storage_as_ref<Type>(&self) -> StorageRef<'_, Self, Type>where
Type: Mappable,
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.