feat: add keep_lowest method to Outcome
This commit is contained in:
@@ -5,3 +5,4 @@ pub mod outcome_keep_highest;
|
|||||||
pub mod outcome_max;
|
pub mod outcome_max;
|
||||||
pub mod outcome_min;
|
pub mod outcome_min;
|
||||||
pub mod outcome_sum;
|
pub mod outcome_sum;
|
||||||
|
pub mod outcome_keep_lowest;
|
||||||
|
|||||||
21
01.workspace/oxidice_lib/src/imp/outcome_keep_lowest.rs
Normal file
21
01.workspace/oxidice_lib/src/imp/outcome_keep_lowest.rs
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
use crate::*;
|
||||||
|
|
||||||
|
impl Outcome {
|
||||||
|
pub fn keep_lowest(self, dice_num: u16) -> Result<Outcome, FailedTo> {
|
||||||
|
if dice_num == 0 {
|
||||||
|
return Err(FailedTo::ProcessInput);
|
||||||
|
}
|
||||||
|
match self {
|
||||||
|
Outcome::Scalar(value) => Ok(Outcome::List(vec![value])),
|
||||||
|
Outcome::List(mut values) => {
|
||||||
|
values.sort();
|
||||||
|
Ok(Outcome::List(
|
||||||
|
values.into_iter().take(dice_num as usize).collect(),
|
||||||
|
))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// #[cfg(test)]
|
||||||
|
// mod unit_tests { use super::*; }
|
||||||
Reference in New Issue
Block a user