From 9917355bb08e268f8b7659eee5c5f2954e4d96f0 Mon Sep 17 00:00:00 2001 From: Jan Petykiewicz Date: Thu, 12 Dec 2024 23:47:19 -0800 Subject: [PATCH] speed up prune_empty() on large patterns --- masque/library.py | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/masque/library.py b/masque/library.py index 08a15b9..82277e1 100644 --- a/masque/library.py +++ b/masque/library.py @@ -1068,20 +1068,22 @@ class ILibrary(ILibraryView, MutableMapping[str, 'Pattern'], metaclass=ABCMeta): Returns: A set containing the names of all deleted patterns """ + parent_graph = self.parent_graph() + empty = {name for name, pat in self.items() if pat.is_empty()} trimmed = set() - while empty := {name for name, pat in self.items() if pat.is_empty()}: + while empty: + parents = set() for name in empty: del self[name] - - for pat in self.values(): - for name in empty: - # Second pass to skip looking at refs in empty patterns - if name in pat.refs: - del pat.refs[name] + for parent in parent_graph[name]: + del self[parent].refs[name] + parents |= parent_graph[name] trimmed |= empty if not repeat: break + + empty = {parent for parent in parents if self[parent].is_empty()} return trimmed def delete(