Function canrun::goals::either[][src]

pub fn either<'a, D>(a: Goal<'a, D>, b: Goal<'a, D>) -> Goal<'a, D> where
    D: Domain<'a>, 
Expand description

Create a goal that succeeds if either sub-goal succeed.

This is essentially an “OR” operation, and will eventually lead to zero, one or two resolved states, depending on the success or failure of the sub-goals.

Examples

Two successful goals will yield up two different results:

use canrun::value::var;
use canrun::goals::{Goal, either, unify};
use canrun::example::I32;

let x = var();
let goal: Goal<I32> = either(unify(x, 1), unify(x, 2));
let result: Vec<_> = goal.query(x).collect();
assert_eq!(result, vec![1, 2])

One failing goal will not cause the other to fail:

let goal: Goal<I32> = either(unify(1, 2), unify(x, 3));
let result: Vec<_> = goal.query(x).collect();
assert_eq!(result, vec![3])

Both goals can fail, leading to no results:

let goal: Goal<I32> = either(unify(6, 5), unify(1, 2));
let result: Vec<_> = goal.query(x).collect();
assert_eq!(result, vec![]) // Empty result