Bump version to 0.2
Allow protecting fields
This commit is contained in:
parent
142b809c63
commit
b30187dc16
2 changed files with 9 additions and 3 deletions
|
@ -133,6 +133,8 @@ class FilterSignal(Signal):
|
||||||
if not self.receivers or self.sender_receivers_cache.get(sender) is NO_RECEIVERS:
|
if not self.receivers or self.sender_receivers_cache.get(sender) is NO_RECEIVERS:
|
||||||
return named
|
return named
|
||||||
|
|
||||||
|
named["_protected"] = named["_protected"] if "_protected" in named.keys() else []
|
||||||
|
|
||||||
responses = named
|
responses = named
|
||||||
|
|
||||||
receivers = self._live_receivers(sender)
|
receivers = self._live_receivers(sender)
|
||||||
|
@ -141,6 +143,7 @@ class FilterSignal(Signal):
|
||||||
for receiver, _ in receivers:
|
for receiver, _ in receivers:
|
||||||
response = receiver(signal=self, sender=sender, **responses)
|
response = receiver(signal=self, sender=sender, **responses)
|
||||||
for key, value in response.items():
|
for key, value in response.items():
|
||||||
|
if not key in responses["_protected"]:
|
||||||
responses[key] = value
|
responses[key] = value
|
||||||
|
|
||||||
return responses
|
return responses
|
||||||
|
@ -172,6 +175,8 @@ class FilterSignal(Signal):
|
||||||
if not self.receivers or self.sender_receivers_cache.get(sender) is NO_RECEIVERS:
|
if not self.receivers or self.sender_receivers_cache.get(sender) is NO_RECEIVERS:
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
named["_protected"] = named["_protected"] if "_protected" in named.keys() else []
|
||||||
|
|
||||||
# Call each receiver with whatever arguments it can accept.
|
# Call each receiver with whatever arguments it can accept.
|
||||||
# Return the updated dict
|
# Return the updated dict
|
||||||
responses = named
|
responses = named
|
||||||
|
@ -184,6 +189,7 @@ class FilterSignal(Signal):
|
||||||
try:
|
try:
|
||||||
response = receiver(signal=self, sender=sender, **responses)
|
response = receiver(signal=self, sender=sender, **responses)
|
||||||
for key, value in response.items():
|
for key, value in response.items():
|
||||||
|
if not key in responses["_protected"]:
|
||||||
responses[key] = value
|
responses[key] = value
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
responses["_errors"].append((receiver, err))
|
responses["_errors"].append((receiver, err))
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
[metadata]
|
[metadata]
|
||||||
name = django-filtersignals
|
name = django-filtersignals
|
||||||
version = 0.1.1
|
version = 0.2
|
||||||
description = Prioritized signals for Django projects
|
description = Prioritized signals for Django projects
|
||||||
long_description = file: README.md
|
long_description = file: README.md
|
||||||
url = https://kumig.it/kumisystems/django-filtersignals
|
url = https://kumig.it/kumisystems/django-filtersignals
|
||||||
|
|
Loading…
Reference in a new issue