diff options
| author | David Beitey <david@davidjb.com> | 2019-03-11 03:14:01 +0000 |
|---|---|---|
| committer | Tim Graham <timograham@gmail.com> | 2019-03-12 10:12:33 -0400 |
| commit | 9fd90c4088833855b1ae973e4a66cab09a26f3e6 (patch) | |
| tree | cdf5ad490926826f11379a6d73bce17038d71f60 /docs/howto/custom-model-fields.txt | |
| parent | 45dfb3641aa4d9828a7c5448d11aa67c7cbd7966 (diff) | |
Clarified deconstruct() in Custom Model Field docs.
Diffstat (limited to 'docs/howto/custom-model-fields.txt')
| -rw-r--r-- | docs/howto/custom-model-fields.txt | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/docs/howto/custom-model-fields.txt b/docs/howto/custom-model-fields.txt index 0a9aab4706..4bb81611cd 100644 --- a/docs/howto/custom-model-fields.txt +++ b/docs/howto/custom-model-fields.txt @@ -231,9 +231,10 @@ Field deconstruction -------------------- The counterpoint to writing your ``__init__()`` method is writing the -``deconstruct()`` method. This method tells Django how to take an instance -of your new field and reduce it to a serialized form - in particular, what -arguments to pass to ``__init__()`` to re-create it. +:meth:`~.Field.deconstruct` method. It's used during :doc:`model migrations +</topics/migrations>` to tell Django how to take an instance of your new field +and reduce it to a serialized form - in particular, what arguments to pass to +``__init__()`` to re-create it. If you haven't added any extra options on top of the field you inherited from, then there's no need to write a new ``deconstruct()`` method. If, however, @@ -269,8 +270,10 @@ we can drop it from the keyword arguments for readability:: del kwargs["max_length"] return name, path, args, kwargs -If you add a new keyword argument, you need to write code to put its value -into ``kwargs`` yourself:: +If you add a new keyword argument, you need to write code in ``deconstruct()`` +that puts its value into ``kwargs`` yourself. You should also omit the value +from ``kwargs`` when it isn't necessary to reconstruct the state of the field, +such as when the default value is being used:: from django.db import models |
