Skip to main content
Log in

Mojo struct

StaticTuple

@register_passable(trivial) struct StaticTuple[element_type: AnyTrivialRegType, size: Int]

A statically sized tuple type which contains elements of homogeneous types.

Parameters

  • element_type (AnyTrivialRegType): The type of the elements in the tuple.
  • size (Int): The size of the tuple.

Aliases

  • type = array<#lit.struct.extract<:@stdlib::@builtin::@int::@Int size, "value">, element_type>:

Fields

  • array (array<#lit.struct.extract<:@stdlib::@builtin::@int::@Int size, "value">, element_type>): The underlying storage for the static tuple.

Implemented traits

AnyType, Copyable, ExplicitlyCopyable, Movable, Sized, UnknownDestructibility

Methods

__init__

__init__() -> Self

Constructs an empty (undefined) tuple.

@implicit __init__(array: array<#lit.struct.extract<:_stdlib::_builtin::_int::_Int size, "value">, element_type>) -> Self

Constructs from an array type.

Args:

  • array (array<#lit.struct.extract<:_stdlib::_builtin::_int::_Int size, "value">, element_type>): Underlying MLIR array type.

@implicit __init__(*elems: element_type) -> Self

Constructs a static tuple given a set of arguments.

Args:

  • *elems (element_type): The element types.

@implicit __init__(values: VariadicList[element_type]) -> Self

Creates a tuple constant using the specified values.

Args:

  • values (VariadicList[element_type]): The list of values.

__init__(*, other: Self) -> Self

Explicitly copy the provided StaticTuple.

Args:

  • other (Self): The StaticTuple to copy.

__getitem__

__getitem__[index: Int](self) -> element_type

Returns the value of the tuple at the given index.

Parameters:

  • index (Int): The index into the tuple.

Returns:

The value at the specified position.

__getitem__[I: Indexer, //](self, idx: I) -> element_type

Returns the value of the tuple at the given dynamic index.

Parameters:

  • I (Indexer): A type that can be used as an index.

Args:

  • idx (I): The index into the tuple.

Returns:

The value at the specified position.

__setitem__

__setitem__[I: Indexer, //](mut self, idx: I, val: element_type)

Stores a single value into the tuple at the specified dynamic index.

Parameters:

  • I (Indexer): A type that can be used as an index.

Args:

  • idx (I): The index into the tuple.
  • val (element_type): The value to store.

__setitem__[idx: Int](mut self, val: element_type)

Stores a single value into the tuple at the specified index.

Parameters:

  • idx (Int): The index into the tuple.

Args:

  • val (element_type): The value to store.

__len__

__len__(self) -> Int

Returns the length of the array. This is a known constant value.

Returns:

The size of the list.