mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +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:
		| @@ -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 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user