Enum brane_ast::errors::TypeError

source ·
pub enum TypeError {
Show 18 variants ProjOnNonClassError { got: DataType, range: TextRange, }, UnexpectedMethod { class_name: String, name: String, range: TextRange, }, UnknownField { class_name: String, name: String, range: TextRange, }, IncorrectType { got: DataType, expected: DataType, range: TextRange, }, IllegalDataReturnError { name: String, range: TextRange, }, IncompatibleReturns { got: DataType, expected: DataType, got_range: TextRange, expected_range: TextRange, }, ParallelNoReturn { block: usize, range: TextRange, }, ParallelUnexpectedReturn { block: usize, got: DataType, range: TextRange, }, ParallelIncompleteReturn { block: usize, expected: DataType, range: TextRange, }, ParallelIllegalType { merge: MergeStrategy, got: DataType, expected: Vec<DataType>, range: TextRange, reason: TextRange, }, ParallelNoStrategy { range: TextRange, }, NonFunctionCall { got: DataType, range: TextRange, defined_range: TextRange, }, UndefinedFunctionCall { name: String, range: TextRange, }, FunctionArityError { name: String, got: usize, expected: usize, got_range: TextRange, expected_range: TextRange, }, InconsistentArrayError { got: DataType, expected: DataType, got_range: TextRange, expected_range: TextRange, }, NonArrayIndexError { got: DataType, range: TextRange, }, DataNameNotAStringError { name: String, got: Expr, range: TextRange, }, DataNoNamePropertyError { name: String, range: TextRange, },
}
Expand description

Defines errors that occur during type checking.

Variants§

§

ProjOnNonClassError

The projection operator was used on a non-class variable.

Fields

§

UnexpectedMethod

A method was used as if it was a field.

Fields

§class_name: String
§name: String
§

UnknownField

The given field is not known in the given class.

Fields

§class_name: String
§name: String
§

IncorrectType

A type cannot be (implicitly) casted to another.

Fields

§expected: DataType
§

IllegalDataReturnError

An imported function returned a Data, while it cannot do that anymore.

Fields

§name: String
§

IncompatibleReturns

The return statements of a function did not all return the same type.

Fields

§expected: DataType
§got_range: TextRange
§expected_range: TextRange
§

ParallelNoReturn

A block in a parallel statement did not return while it should have.

Fields

§block: usize
§

ParallelUnexpectedReturn

A block in a parallel statement did return while it should not have.

Fields

§block: usize
§

ParallelIncompleteReturn

Not all blocks in a parallel statement return a non-void value.

Fields

§block: usize
§expected: DataType
§

ParallelIllegalType

The parallel returned the wrong value for the merge strategy

Fields

§expected: Vec<DataType>
§reason: TextRange
§

ParallelNoStrategy

The parallel returns a value but the merge is None

Fields

§

NonFunctionCall

A function call has been attempted on a non-function.

Fields

§defined_range: TextRange
§

UndefinedFunctionCall

The function identifier was not known.

Fields

§name: String
§

FunctionArityError

A function was given an incorrect number of parameters.

Fields

§name: String
§got: usize
§expected: usize
§got_range: TextRange
§expected_range: TextRange
§

InconsistentArrayError

An Array had confusing types

Fields

§expected: DataType
§got_range: TextRange
§expected_range: TextRange
§

NonArrayIndexError

An Array Index was used on a non-array.

Fields

§

DataNameNotAStringError

The user specified something else as a Data than a literal string.

Fields

§name: String
§got: Expr
§

DataNoNamePropertyError

The user did not specify a name field in a Data or IntermediateResult field.

Fields

§name: String

Implementations§

source§

impl TypeError

source

pub fn prettyprint(&self, file: impl AsRef<str>, source: impl AsRef<str>)

Prints the warning in a pretty way to stderr.

§Arguments
  • file: The ‘path’ of the file (or some other identifier) where the source text originates from.
  • source: The source text to read the debug range from.
source

pub fn prettywrite( &self, writer: impl Write, file: impl AsRef<str>, source: impl AsRef<str>, ) -> Result<(), Error>

Prints the warning in a pretty way to the given Writer.

§Arguments:
  • writer: The Write-enabled object to write to.
  • file: The ‘path’ of the file (or some other identifier) where the source text originates from.
  • source: The source text to read the debug range from.
§Errors

This function may error if we failed to write to the given writer.

Trait Implementations§

source§

impl Debug for TypeError

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Display for TypeError

source§

fn fmt(&self, f: &mut Formatter<'_>) -> FResult

Formats the value using the given formatter. Read more
source§

impl Error for TypeError

1.30.0 · source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
source§

impl From<TypeError> for AstError

source§

fn from(err: TypeError) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> ErasedDestructor for T
where T: 'static,

source§

impl<T> MaybeSendSync for T