diff options
| author | Étienne Loks <etienne.loks@iggdrasil.net> | 2016-12-23 17:01:35 +0100 | 
|---|---|---|
| committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2016-12-23 17:02:21 +0100 | 
| commit | 58b51b2539cdf695ac3be29fd20ea114ad1bbfd9 (patch) | |
| tree | 4cf16ab6ede4175e6b0c2fdf34bf3217bd28972e /ishtar_common/utils.py | |
| parent | bac3c069fe13e94d454a0a6f2d483e9df8fae548 (diff) | |
| download | Ishtar-58b51b2539cdf695ac3be29fd20ea114ad1bbfd9.tar.bz2 Ishtar-58b51b2539cdf695ac3be29fd20ea114ad1bbfd9.zip | |
Add index to containers (refs #3391) - manage multiple cached labels
Diffstat (limited to 'ishtar_common/utils.py')
| -rw-r--r-- | ishtar_common/utils.py | 13 | 
1 files changed, 10 insertions, 3 deletions
| diff --git a/ishtar_common/utils.py b/ishtar_common/utils.py index 44112bca3..9b3c85694 100644 --- a/ishtar_common/utils.py +++ b/ishtar_common/utils.py @@ -60,11 +60,18 @@ def cached_label_changed(sender, **kwargs):              and instance._cached_label_checked:          return      instance._cached_label_checked = True -    lbl = instance._generate_cached_label() -    if lbl != instance.cached_label: +    cached_labels = ['cached_label'] +    if hasattr(sender, 'CACHED_LABELS'): +        cached_labels = sender.CACHED_LABELS +    changed = False +    for cached_label in cached_labels: +        lbl = getattr(instance, '_generate_' + cached_label)() +        if lbl != getattr(instance, cached_label): +            setattr(instance, cached_label, lbl) +            changed = True +    if changed:          if hasattr(instance, '_cascade_change') and instance._cascade_change:              instance.skip_history_when_saving = True -        instance.cached_label = lbl          instance.save()      if hasattr(instance, '_get_associated_cached_labels'):          for item in instance._get_associated_cached_labels(): | 
