From 94485f36aeefb2b2ba81fe7445c9915594f14d22 Mon Sep 17 00:00:00 2001 From: Damien Elmes Date: Wed, 25 Dec 2019 13:01:19 +1000 Subject: [PATCH] fix handling of typing cards --- rs/ankirs/src/template.rs | 17 ++++++++++++----- tests/test_models.py | 6 ++++++ 2 files changed, 18 insertions(+), 5 deletions(-) diff --git a/rs/ankirs/src/template.rs b/rs/ankirs/src/template.rs index 89f7589e3..ab1758f74 100644 --- a/rs/ankirs/src/template.rs +++ b/rs/ankirs/src/template.rs @@ -177,7 +177,12 @@ fn template_is_empty<'a>(nonempty_fields: &HashSet<&str>, nodes: &[ParsedNode<'a match node { // ignore normal text Text(_) => (), - Replacement { key, .. } => { + Replacement { key, filters } => { + // Anki doesn't consider a type: reference as a required field + if filters.contains(&"type") { + continue; + } + if nonempty_fields.contains(*key) { // a single replacement is enough return false; @@ -307,7 +312,7 @@ mod test { let mut tmpl = PT::from_text("{{2}}{{1}}").unwrap(); assert_eq!(tmpl.renders_with_fields(&fields), true); tmpl = PT::from_text("{{2}}{{type:cloze:1}}").unwrap(); - assert_eq!(tmpl.renders_with_fields(&fields), true); + assert_eq!(tmpl.renders_with_fields(&fields), false); tmpl = PT::from_text("{{2}}{{4}}").unwrap(); assert_eq!(tmpl.renders_with_fields(&fields), false); tmpl = PT::from_text("{{#3}}{{^2}}{{1}}{{/2}}{{/3}}").unwrap(); @@ -346,8 +351,10 @@ mod test { FieldRequirements::All(HashSet::from_iter(vec![0, 1].into_iter())) ); - // fixme: handling of type in answer card reqs doesn't match desktop, - // which only requires first field - // + tmpl = PT::from_text("{{a}}{{type:b}}").unwrap(); + assert_eq!( + tmpl.requirements(&field_map), + FieldRequirements::Any(HashSet::from_iter(vec![0].into_iter())) + ); } } diff --git a/tests/test_models.py b/tests/test_models.py index 78581aa67..823be124e 100644 --- a/tests/test_models.py +++ b/tests/test_models.py @@ -371,6 +371,12 @@ def test_req(): mm.save(opt, templates=True) assert opt['req'][1] == [1, 'none', []] + opt = mm.byName("Basic (type in the answer)") + reqSize(opt) + r = opt['req'][0] + assert r[1] in ("any", "all") + assert r[2] == [0] + # def test_updatereqs_performance(): # import time # d = getEmptyCol()