Struct Function
pub struct Function {
pub name: Option<String>,
pub arguments: Vec<FunctionArgument>,
pub result: Option<FunctionResult>,
pub local_variables: Arena<LocalVariable>,
pub expressions: Arena<Expression>,
pub named_expressions: IndexMap<Handle<Expression>, String, BuildHasherDefault<FxHasher>>,
pub body: Block,
pub diagnostic_filter_leaf: Option<Handle<DiagnosticFilterNode>>,
}unstable-wgpu-27 only.Expand description
A function defined in the module.
Fields§
§name: Option<String>Name of the function, if any.
arguments: Vec<FunctionArgument>Information about function argument.
result: Option<FunctionResult>The result of this function, if any.
local_variables: Arena<LocalVariable>Local variables defined and used in the function.
expressions: Arena<Expression>Expressions used inside this function.
Unless explicitly stated otherwise, if an Expression is in this
arena, then its subexpressions are in this arena too. In other words,
every Handle<Expression> in this arena refers to an Expression in
this arena too.
The main ways this arena refers to Module::global_expressions are:
-
Constant,Override, andGlobalVariableexpressions hold handles for their respective types, whose initializer expressions are inModule::global_expressions. -
Various expressions hold
Typehandles, andTypes may refer to global expressions, for things like array lengths.
An Expression must occur before all other Expressions that use
its value.
named_expressions: IndexMap<Handle<Expression>, String, BuildHasherDefault<FxHasher>>Map of expressions that have associated variable names
body: BlockBlock of instructions comprising the body of the function.
diagnostic_filter_leaf: Option<Handle<DiagnosticFilterNode>>The leaf of all diagnostic filter rules tree (stored in Module::diagnostic_filters)
parsed on this function.
In WGSL, this corresponds to @diagnostic(…) attributes.
See DiagnosticFilterNode for details on how the tree is represented and used in
validation.
Implementations§
§impl Function
impl Function
pub fn originating_global(
&self,
pointer: Handle<Expression>,
) -> Option<Handle<GlobalVariable>>
pub fn originating_global( &self, pointer: Handle<Expression>, ) -> Option<Handle<GlobalVariable>>
Return the global variable being accessed by the expression pointer.
Assuming that pointer is a series of Access and AccessIndex
expressions that ultimately access some part of a GlobalVariable,
return a handle for that global.
If the expression does not ultimately access a global variable, return
None.
Trait Implementations§
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,
§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>
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.§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.§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.§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.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 more§impl<T> NoneValue for Twhere
T: Default,
impl<T> NoneValue for Twhere
T: Default,
type NoneType = T
§fn null_value() -> T
fn null_value() -> T
§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
Source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
ReadEndian::read_from_little_endian().§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.