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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
//! Error types for fallible [`ArrayList`](crate::ArrayList) operations.
//!
//! The single public type in this module is [`ListError`], returned by methods that
//! accept an index or mutate the list's capacity.
//!
//! # When Each Variant Is Returned
//!
//! | Situation | Variant |
//! |-----------|---------|
//! | `idx >= len` and `len == 0` | [`ListError::EmptyList`] |
//! | `idx >= len` and `len > 0` | [`ListError::OutOfBounds`] |
//! | doubling capacity would overflow `usize` | [`ListError::CapacityOverflow`] |
//!
//! # Example
//!
//! ```rust
//! use arrlist::{
//! ArrayList,
//! error::ListError,
//! };
//!
//! let mut list: ArrayList<i32> = ArrayList::new();
//!
//! // Empty list — EmptyList is returned regardless of which index is used.
//! assert!(matches!(list.remove(0), Err(ListError::EmptyList)));
//!
//! list.push(10);
//! list.push(20);
//!
//! // Non-empty list, but index 5 is out of range.
//! assert!(matches!(
//! list.remove(5),
//! Err(ListError::OutOfBounds {
//! idx: 5,
//! limits: (0, 1)
//! })
//! ));
//! ```
use Error;
/// Errors that can occur during [`ArrayList`](crate::ArrayList) operations.
///
/// This enum covers three failure modes: accessing an out-of-range index, operating on
/// an empty list, and exhausting the addressable capacity of the allocator.