Fixed #23473 -- Documented that @deconstructible classes need __eq__.

This commit is contained in:
Markus Holtermann 2014-09-24 19:07:56 +02:00 committed by Tim Graham
parent 450a616004
commit 066e672d79
1 changed files with 12 additions and 2 deletions

View File

@ -601,9 +601,14 @@ of three things ``(path, args, kwargs)``:
Django will write out the value as an instantiation of your class with the Django will write out the value as an instantiation of your class with the
given arguments, similar to the way it writes out references to Django fields. given arguments, similar to the way it writes out references to Django fields.
To prevent a new migration from being created each time
:djadmin:`makemigrations` is run, you should also add a ``__eq__()`` method to
the decorated class. This function will be called by Django's migration
framework to detect changes between states.
As long as all of the arguments to your class' constructor are themselves As long as all of the arguments to your class' constructor are themselves
serializable, you can just use the ``@deconstructible`` class decorator serializable, you can use the ``@deconstructible`` class decorator from
from ``django.utils.deconstruct`` to add the method:: ``django.utils.deconstruct`` to add the ``deconstruct()`` method::
from django.utils.deconstruct import deconstructible from django.utils.deconstruct import deconstructible
@ -611,8 +616,13 @@ from ``django.utils.deconstruct`` to add the method::
class MyCustomClass(object): class MyCustomClass(object):
def __init__(self, foo=1): def __init__(self, foo=1):
self.foo = foo
... ...
def __eq__(self, other):
return self.foo == other.foo
The decorator adds logic to capture and preserve the arguments on their The decorator adds logic to capture and preserve the arguments on their
way into your constructor, and then returns those arguments exactly when way into your constructor, and then returns those arguments exactly when
deconstruct() is called. deconstruct() is called.