1
0
mirror of https://github.com/django/django.git synced 2025-01-26 02:00:08 +00:00

[1.7.x] Fixed #22507 -- Clarified nature of the sender argument of signals

Backport of d1f93e9c1e from master.
This commit is contained in:
Claude Paroz 2014-04-25 23:13:58 +02:00
parent 6b38e48ba1
commit abd68b5aff

View File

@ -235,7 +235,8 @@ For example:
This declares a ``pizza_done`` signal that will provide receivers with This declares a ``pizza_done`` signal that will provide receivers with
``toppings`` and ``size`` arguments. ``toppings`` and ``size`` arguments.
Remember that you're allowed to change this list of arguments at any time, so getting the API right on the first try isn't necessary. Remember that you're allowed to change this list of arguments at any time, so
getting the API right on the first try isn't necessary.
Sending signals Sending signals
--------------- ---------------
@ -246,8 +247,8 @@ There are two ways to send signals in Django.
.. method:: Signal.send_robust(sender, **kwargs) .. method:: Signal.send_robust(sender, **kwargs)
To send a signal, call either :meth:`Signal.send` or :meth:`Signal.send_robust`. To send a signal, call either :meth:`Signal.send` or :meth:`Signal.send_robust`.
You must provide the ``sender`` argument, and may provide as many other keyword You must provide the ``sender`` argument (which is a class most of the time),
arguments as you like. and may provide as many other keyword arguments as you like.
For example, here's how sending our ``pizza_done`` signal might look: For example, here's how sending our ``pizza_done`` signal might look:
@ -257,7 +258,7 @@ For example, here's how sending our ``pizza_done`` signal might look:
... ...
def send_pizza(self, toppings, size): def send_pizza(self, toppings, size):
pizza_done.send(sender=self, toppings=toppings, size=size) pizza_done.send(sender=self.__class__, toppings=toppings, size=size)
... ...
Both ``send()`` and ``send_robust()`` return a list of tuple pairs Both ``send()`` and ``send_robust()`` return a list of tuple pairs