Skip to main content
Log in

Mojo struct

Error

@register_passable struct Error

This type represents an Error.

Fields

  • data (UnsafePointer[SIMD[uint8, 1]]): A pointer to the beginning of the string data being referenced.
  • loaded_length (Int): The length of the string being referenced. Error instances conditionally own their error message. To reduce the size of the error instance we use the sign bit of the length field to store the ownership value. When loaded_length is negative it indicates ownership and a free is executed in the destructor.

Implemented traits

AnyType, Boolable, CollectionElement, CollectionElementNew, Copyable, ExplicitlyCopyable, Movable, Representable, Stringable, UnknownDestructibility, Writable, _CurlyEntryFormattable

Methods

__init__

__init__() -> Self

Default constructor.

@implicit __init__(value: StringLiteral) -> Self

Construct an Error object with a given string literal.

Args:

  • value (StringLiteral): The error message.

@implicit __init__(src: String) -> Self

Construct an Error object with a given string.

Args:

  • src (String): The error message.

@implicit __init__(src: StringRef) -> Self

Construct an Error object with a given string ref.

Args:

  • src (StringRef): The error message.

__init__[*Ts: Writable](*args: *Ts, *, sep: StringLiteral = "", end: StringLiteral = "") -> Self

Construct an Error by concatenating a sequence of Writable arguments.

Parameters:

  • *Ts (Writable): The types of the arguments to format. Each type must be satisfy Writable.

Args:

  • *args (*Ts): A sequence of Writable arguments.
  • sep (StringLiteral): The separator used between elements.
  • end (StringLiteral): The String to write after printing the elements.

__copyinit__

__copyinit__(existing: Self) -> Self

Creates a deep copy of an existing error.

Args:

  • existing (Self): The error to copy from.

__del__

__del__(owned self)

Releases memory if allocated.

__bool__

__bool__(self) -> Bool

Returns True if the error is set and false otherwise.

Returns:

True if the error object contains a value and False otherwise.

copy

copy(self) -> Self

Copy the object.

Returns:

A copy of the value.

__str__

__str__(self) -> String

Converts the Error to string representation.

Returns:

A String of the error message.

write_to

write_to[W: Writer](self, mut writer: W)

Formats this error to the provided Writer.

Parameters:

  • W (Writer): A type conforming to the Writable trait.

Args:

  • writer (W): The object to write to.

__repr__

__repr__(self) -> String

Converts the Error to printable representation.

Returns:

A printable representation of the error message.

unsafe_cstr_ptr

unsafe_cstr_ptr(self) -> UnsafePointer[SIMD[int8, 1]]

Retrieves a C-string-compatible pointer to the underlying memory.

The returned pointer is guaranteed to be NUL terminated, and not null.

Returns:

The pointer to the underlying memory.