-
Notifications
You must be signed in to change notification settings - Fork 102
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Added checks for child_index out of bounds * slightly better descriptions * updated RELEASES.md * Changed TaffyError back to Error * split error type into two * fixed error in git merge * updated RELEASES.md file * cargo fmt * moved errors into error module, and gave them better names * Split InvalidChild::InvalidNode into two * updated RELEASES.md * cargo fmt * more changes to RELEASES.md Co-authored-by: Alice Cecile <alice.i.cecile@gmail.com>
- Loading branch information
1 parent
3bd95d6
commit ab22fd7
Showing
7 changed files
with
112 additions
and
60 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
//! The Error types produced by Taffy. | ||
#[cfg(feature = "std")] | ||
use core::fmt::{Display, Formatter, Result}; | ||
|
||
use crate::node::Node; | ||
|
||
/// The [`Node`] was not found in the [`Taffy`](crate::Taffy) instance | ||
#[derive(Debug)] | ||
pub struct InvalidNode(pub Node); | ||
|
||
#[cfg(feature = "std")] | ||
impl Display for InvalidNode { | ||
fn fmt(&self, f: &mut Formatter) -> Result { | ||
write!(f, "Node {:?} is not in the Taffy instance", self.0) | ||
} | ||
} | ||
|
||
#[cfg(feature = "std")] | ||
impl std::error::Error for InvalidNode {} | ||
|
||
/// An error that occurs while trying to access or modify a [`Node`]'s children by index. | ||
#[derive(Debug)] | ||
pub enum InvalidChild { | ||
/// The parent [`Node`] does not have a child at `child_index`. It only has `child_count` children | ||
ChildIndexOutOfBounds { | ||
/// The parent node whose child was being looked up | ||
parent: Node, | ||
/// The index that was looked up | ||
child_index: usize, | ||
/// The total number of children the parent has | ||
child_count: usize, | ||
}, | ||
/// The parent [`Node`] was not found in the [`Taffy`](crate::Taffy) instance. | ||
InvalidParentNode(Node), | ||
/// The child [`Node`] was not found in the [`Taffy`](crate::Taffy) instance. | ||
InvalidChildNode(Node), | ||
} | ||
|
||
#[cfg(feature = "std")] | ||
impl Display for InvalidChild { | ||
fn fmt(&self, f: &mut Formatter) -> Result { | ||
match self { | ||
InvalidChild::ChildIndexOutOfBounds { parent, child_index, child_count } => write!( | ||
f, | ||
"Index (is {}) should be < child_count ({}) for parent node {:?}", | ||
child_index, child_count, parent | ||
), | ||
InvalidChild::InvalidParentNode(parent) => { | ||
write!(f, "Parent Node {:?} is not in the Taffy instance", parent) | ||
} | ||
InvalidChild::InvalidChildNode(child) => write!(f, "Child Node {:?} is not in the Taffy instance", child), | ||
} | ||
} | ||
} | ||
|
||
#[cfg(feature = "std")] | ||
impl std::error::Error for InvalidChild {} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters