From 05da9515ea48229550895e022a6021915bada2eb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jos=C3=A9=20Manuel=20Dom=C3=ADnguez?= Date: Tue, 6 Dec 2022 09:54:21 +0100 Subject: [PATCH] Workaround for issue #820 (caching mechanism incompatible with DFS). --- simphony_osp/tools/search.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/simphony_osp/tools/search.py b/simphony_osp/tools/search.py index a99b4cf4..6d5e0e3d 100644 --- a/simphony_osp/tools/search.py +++ b/simphony_osp/tools/search.py @@ -114,10 +114,14 @@ def _iter( yield root if current_depth < max_depth: - for sub in chain( + # Originally, this function was using DFS (no `list`), but it is + # incompatible with the caching mechanism. See issue #820. + # TODO: Fix + # [issue #820](https://github.com/simphony/simphony-osp/issues/820). + for sub in list(chain( *(root.iter(rel=r) for r in rel), *(root.annotations_iter(rel=r) for r in annotation) - ): + )): if sub.uid not in visited: yield from _iter( criterion=criterion,