# HG changeset patch # User Sylvain Thénault # Date 1286780474 -7200 # Node ID dc4398d094beaf3aac00c591556526fa66e0e955 # Parent 72669e7950c1a068f106373149b095e400ae090c [breadcrumb] infinite loop safety belt, bw compatible by hi-jacking 'recurs' argument diff -r 72669e7950c1 -r dc4398d094be web/views/ibreadcrumbs.py --- a/web/views/ibreadcrumbs.py Sat Oct 09 00:38:07 2010 +0200 +++ b/web/views/ibreadcrumbs.py Mon Oct 11 09:01:14 2010 +0200 @@ -62,7 +62,7 @@ return itree.parent() return None - def breadcrumbs(self, view=None, recurs=False): + def breadcrumbs(self, view=None, recurs=None): """return a list containing some: * tuple (url, label) @@ -71,14 +71,26 @@ defining path from a root to the current view - the main view is given as argument so breadcrumbs may vary according - to displayed view (may be None). When recursing on a parent entity, - the `recurs` argument should be set to True. + the main view is given as argument so breadcrumbs may vary according to + displayed view (may be None). When recursing on a parent entity, the + `recurs` argument should be a set of already traversed nodes (infinite + loop safety belt). """ parent = self.parent_entity() if parent is not None: + if recurs: + _recurs = recurs + else: + if reculs is False: + warn('[3.10] recurs argument should be a set() or None', + DeprecationWarning, stacklevel=2) + _recurs = set() + if _recurs and parent.eid in _recurs: + self.error('cycle in breadcrumbs for entity %s' % self.entity) + return [] + _recurs.add(parent.eid) adapter = ibreadcrumb_adapter(parent) - path = adapter.breadcrumbs(view, True) + [self.entity] + path = adapter.breadcrumbs(view, _recurs) + [self.entity] else: path = [self.entity] if not recurs: