1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
use super::Dimension;
use std::error::Error;
use std::fmt;
#[derive(Clone)]
pub struct ShapeError {
repr: ErrorKind,
}
impl ShapeError {
#[inline]
pub fn kind(&self) -> ErrorKind {
self.repr
}
pub fn from_kind(error: ErrorKind) -> Self {
from_kind(error)
}
}
#[non_exhaustive]
#[derive(Copy, Clone, Debug)]
pub enum ErrorKind {
IncompatibleShape = 1,
IncompatibleLayout,
RangeLimited,
OutOfBounds,
Unsupported,
Overflow,
}
#[inline(always)]
pub fn from_kind(k: ErrorKind) -> ShapeError {
ShapeError { repr: k }
}
impl PartialEq for ErrorKind {
#[inline(always)]
fn eq(&self, rhs: &Self) -> bool {
*self as u8 == *rhs as u8
}
}
impl PartialEq for ShapeError {
#[inline(always)]
fn eq(&self, rhs: &Self) -> bool {
self.repr == rhs.repr
}
}
impl Error for ShapeError {}
impl fmt::Display for ShapeError {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
let description = match self.kind() {
ErrorKind::IncompatibleShape => "incompatible shapes",
ErrorKind::IncompatibleLayout => "incompatible memory layout",
ErrorKind::RangeLimited => "the shape does not fit in type limits",
ErrorKind::OutOfBounds => "out of bounds indexing",
ErrorKind::Unsupported => "unsupported operation",
ErrorKind::Overflow => "arithmetic overflow",
};
write!(f, "ShapeError/{:?}: {}", self.kind(), description)
}
}
impl fmt::Debug for ShapeError {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{}", self)
}
}
pub fn incompatible_shapes<D, E>(_a: &D, _b: &E) -> ShapeError
where
D: Dimension,
E: Dimension,
{
from_kind(ErrorKind::IncompatibleShape)
}