pub struct ExtractValueOp { /* private fields */ }Expand description
Equivalent to LLVM’s ExtractValue opcode.
§Operands
| operand | description |
|---|---|
aggregate | LLVM aggregate type |
§Result(s):
| result | description |
|---|---|
res | LLVM type |
§Attribute(s):
Note: Only attributes defined directly as part of this operation are listed here. There may be others, not listed here, defined by interface implementations.
| Name | Static Name Identifier | Type |
|---|---|---|
extract_value_indices | ATTR_KEY_EXTRACT_VALUE_INDICES | InsertExtractValueIndicesAttr |
Implementations§
Source§impl ExtractValueOp
impl ExtractValueOp
Sourcepub fn get_attr_extract_value_indices<'a>(
&self,
ctx: &'a Context,
) -> Option<Ref<'a, InsertExtractValueIndicesAttr>>
pub fn get_attr_extract_value_indices<'a>( &self, ctx: &'a Context, ) -> Option<Ref<'a, InsertExtractValueIndicesAttr>>
Get a Ref to the value of the attribute named extract_value_indices.
The Ref is a borrow of the containing Operation object.
Sourcepub fn set_attr_extract_value_indices(
&self,
ctx: &Context,
value: InsertExtractValueIndicesAttr,
)
pub fn set_attr_extract_value_indices( &self, ctx: &Context, value: InsertExtractValueIndicesAttr, )
Set the value of the attribute named extract_value_indices.
Source§impl ExtractValueOp
impl ExtractValueOp
Sourcepub fn new(
ctx: &mut Context,
aggregate: Value,
indices: Vec<u32>,
) -> Result<Self>
pub fn new( ctx: &mut Context, aggregate: Value, indices: Vec<u32>, ) -> Result<Self>
Create a new ExtractValueOp.
aggregate is the aggregate type and indices is the list of indices to extract the value from.
The indices must be valid for the given aggregate type.
The result type of the operation is the type of the value at the given indices.
Trait Implementations§
Source§impl Clone for ExtractValueOp
impl Clone for ExtractValueOp
Source§fn clone(&self) -> ExtractValueOp
fn clone(&self) -> ExtractValueOp
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 Hash for ExtractValueOp
impl Hash for ExtractValueOp
Source§impl OneOpdInterface for ExtractValueOp
impl OneOpdInterface for ExtractValueOp
Source§impl OneResultInterface for ExtractValueOp
impl OneResultInterface for ExtractValueOp
Source§impl Op for ExtractValueOp
impl Op for ExtractValueOp
Source§fn get_operation(&self) -> Ptr<Operation>
fn get_operation(&self) -> Ptr<Operation>
Get the underlying IR Operation
Source§fn get_opid_static() -> OpId
fn get_opid_static() -> OpId
Get this Op’s OpId, without self reference.
Source§fn get_concrete_op_info() -> (fn(Ptr<Operation>) -> OpBox, TypeId)where
Self: Sized,
fn get_concrete_op_info() -> (fn(Ptr<Operation>) -> OpBox, TypeId)where
Self: Sized,
Get details about the concrete Op type.
Source§impl Parsable for ExtractValueOp
impl Parsable for ExtractValueOp
Source§type Arg = Vec<(Identifier, Location)>
type Arg = Vec<(Identifier, Location)>
Type of the argument that must be passed to the parser.
Source§fn parse<'__pliron_parse>(
state_stream: &mut StateStream<'__pliron_parse>,
arg: Self::Arg,
) -> ParseResult<'__pliron_parse, Self::Parsed>
fn parse<'__pliron_parse>( state_stream: &mut StateStream<'__pliron_parse>, arg: Self::Arg, ) -> ParseResult<'__pliron_parse, Self::Parsed>
Define a parser using existing combinators and call
into on [Parser::parse_stream] to get the final ParseResult.
Use state_stream.state as necessary.Source§fn parser<'a>(
arg: Self::Arg,
) -> Box<dyn Parser<Stream<Stream<Stream<Stream<IteratorStream<CharIterator<'a>>, SourcePosition>>>, State<'a>>, PartialState = (), Output = Self::Parsed> + 'a>
fn parser<'a>( arg: Self::Arg, ) -> Box<dyn Parser<Stream<Stream<Stream<Stream<IteratorStream<CharIterator<'a>>, SourcePosition>>>, State<'a>>, PartialState = (), Output = Self::Parsed> + 'a>
Get a parser combinator that can work on StateStream as its input.
Source§impl PartialEq for ExtractValueOp
impl PartialEq for ExtractValueOp
Source§impl Printable for ExtractValueOp
impl Printable for ExtractValueOp
Source§impl SideEffects for ExtractValueOp
impl SideEffects for ExtractValueOp
Source§fn has_side_effects(&self, _ctx: &Context) -> bool
fn has_side_effects(&self, _ctx: &Context) -> bool
Returns
true if the operation has side effects, and false otherwise.impl Copy for ExtractValueOp
impl Eq for ExtractValueOp
impl NOpdsInterface<1> for ExtractValueOp
impl NResultsInterface<1> for ExtractValueOp
impl StructuralPartialEq for ExtractValueOp
Auto Trait Implementations§
impl Freeze for ExtractValueOp
impl !RefUnwindSafe for ExtractValueOp
impl Send for ExtractValueOp
impl Sync for ExtractValueOp
impl Unpin for ExtractValueOp
impl UnsafeUnpin for ExtractValueOp
impl !UnwindSafe for ExtractValueOp
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.