Adds pretty_output

This commit is contained in:
2019-02-01 13:53:50 +01:00
parent 1d091bd419
commit 66514eb192
3 changed files with 21 additions and 41 deletions

View File

@@ -12,6 +12,7 @@ use self::planner::solver::{Variables, Domain, Problem, Constraint};
/// Lunch => RecipeCategory::MainCourse
/// Dinner => RecipeCategory::MainCourse
type Day = String;
const DAYS: &[&str] = &["Lundi", "Mardi", "Mercredi"];
enum Meals {
Breakfast(Day),
@@ -36,7 +37,7 @@ enum RecipeCategory {
/// It may also contains an initial value for each variable
fn generate_variables<V>(domain: &Domain<V>) -> Vec<(String, &Domain<V>, Option<&V>)> {
let mut vars = Vec::new();
for day in &["Lundi", "Mardi", "Mercredi"] {
for day in DAYS {
vars.push((Meals::Lunch(day.to_string()).into(), domain, None));
vars.push((Meals::Dinner(day.to_string()).into(), domain, None));
}
@@ -48,6 +49,19 @@ fn ingredients_contains<'a>(assign: &Variables<'a,Recipe>) -> bool {
&& !assign.get("Mardi_Lunch").unwrap().unwrap().ingredients.contains("Patates")
}
fn pretty_output(res: &Variables<Recipe>) -> String {
let mut repr = String::new();
for (var,value) in res {
let value = match value {
Some(rec) => &rec.title,
None => "---",
};
repr.push_str(&format!("{} => {}\n", var, value));
}
repr
}
fn get_planning_all_results() -> String {
let conn = establish_connection();
let possible_values = recipes::load_all(&conn);
@@ -56,10 +70,13 @@ fn get_planning_all_results() -> String {
for (var, dom, ini) in generate_variables(&domain) {
problem = problem.add_variable(var, dom, ini);
}
let mut problem = problem.add_constraint(ingredients_contains)
.finish();
let mut problem = problem
.add_constraint(
ingredients_contains
)
.finish();
let results = problem.solve_all();
format!("{:#?}\nTotal = {}", &results.first(), results.len())
format!("{}\nTotal = {}", pretty_output(&results.first().unwrap()), results.len())
}
fn main() {