Skip to main content

DdminInput

Struct DdminInput 

Source
pub struct DdminInput<C> { /* private fields */ }
Expand description

Input for one DDMin reduction run.

Implementations§

Source§

impl<C> DdminInput<C>

Source

pub const fn new(candidates: Vec<C>, options: DdminOptions) -> Self

Create a DDMin input from ordered candidates and execution options.

Examples found in repository?
examples/basic.rs (line 4)
3fn main() {
4    let input = DdminInput::new(vec![1_u8, 2, 3, 4], DdminOptions::default());
5    let mut oracle = |remaining: &[u8]| {
6        if remaining.contains(&2) && remaining.contains(&4) {
7            OracleOutcome::Interesting
8        } else {
9            OracleOutcome::NotInteresting
10        }
11    };
12
13    let output = ddmin(input, &mut oracle);
14    assert_eq!(output.remaining(), &[2, 4], "DDMin should keep the required values");
15    assert_eq!(output.removed(), &[1, 3], "DDMin should remove the irrelevant values");
16}
More examples
Hide additional examples
examples/budgeted.rs (line 9)
7fn main() {
8    let options = DdminOptions::new(NonZeroUsize::MIN, Some(1));
9    let input = DdminInput::new(vec![1_u8, 2, 3, 4], options);
10    let mut oracle = |remaining: &[u8]| {
11        if remaining.contains(&2) {
12            OracleOutcome::Interesting
13        } else {
14            OracleOutcome::NotInteresting
15        }
16    };
17
18    let output = ddmin(input, &mut oracle);
19    assert_eq!(
20        output.guarantee(),
21        DdminGuarantee::Incomplete(DdminStopReason::MaxOracleCallsReached),
22        "DDMin should report an incomplete guarantee when the oracle-call budget is exhausted"
23    );
24    assert_eq!(output.stats().oracle_calls(), 1, "DDMin should stop at the configured budget");
25}
examples/unresolved.rs (line 4)
3fn main() {
4    let input = DdminInput::new(vec!["core", "flaky", "noise"], DdminOptions::default());
5    let mut oracle = |remaining: &[&str]| {
6        if remaining.contains(&"flaky") && remaining.len() == 1 {
7            OracleOutcome::Unresolved(UnresolvedReason::NonDeterministic)
8        } else if remaining.contains(&"core") {
9            OracleOutcome::Interesting
10        } else {
11            OracleOutcome::NotInteresting
12        }
13    };
14
15    let output = ddmin(input, &mut oracle);
16    assert_eq!(output.remaining(), &["core"], "DDMin should keep the stable interesting value");
17    assert_eq!(
18        output.stats().unresolved_trials(),
19        1,
20        "DDMin should count unresolved oracle outcomes"
21    );
22}
examples/file_candidates.rs (lines 12-19)
11fn main() -> ExitCode {
12    let input = DdminInput::new(
13        vec![
14            FileCandidate { path: "fixture/src/lib.rs", required: true },
15            FileCandidate { path: "fixture/README.md", required: false },
16            FileCandidate { path: "fixture/noise.log", required: false },
17        ],
18        DdminOptions::default(),
19    );
20    let mut oracle = |remaining: &[FileCandidate]| {
21        if remaining.iter().any(|candidate| candidate.required) {
22            OracleOutcome::Interesting
23        } else {
24            OracleOutcome::NotInteresting
25        }
26    };
27
28    let output = ddmin(input, &mut oracle);
29    let [remaining] = output.remaining() else {
30        return ExitCode::from(1);
31    };
32    if remaining.path == "fixture/src/lib.rs" { ExitCode::SUCCESS } else { ExitCode::from(1) }
33}

Trait Implementations§

Source§

impl<C: Clone> Clone for DdminInput<C>

Source§

fn clone(&self) -> DdminInput<C>

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<C: Debug> Debug for DdminInput<C>

Source§

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

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

impl<C: PartialEq> PartialEq for DdminInput<C>

Source§

fn eq(&self, other: &DdminInput<C>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<C: Eq> Eq for DdminInput<C>

Source§

impl<C> StructuralPartialEq for DdminInput<C>

Auto Trait Implementations§

§

impl<C> Freeze for DdminInput<C>

§

impl<C> RefUnwindSafe for DdminInput<C>
where C: RefUnwindSafe,

§

impl<C> Send for DdminInput<C>
where C: Send,

§

impl<C> Sync for DdminInput<C>
where C: Sync,

§

impl<C> Unpin for DdminInput<C>
where C: Unpin,

§

impl<C> UnsafeUnpin for DdminInput<C>

§

impl<C> UnwindSafe for DdminInput<C>
where C: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.