File: mangled_methods.rst

package info (click to toggle)
python-atom 0.12.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,616 kB
  • sloc: cpp: 9,040; python: 6,249; makefile: 123
file content (150 lines) | stat: -rw-r--r-- 3,979 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
.. _basis-mangled-methods:

Customimizing members: specially named methods
==============================================

.. include:: ../substitutions.sub

Atom offers multiple ways to customize the inner working of members. The
easiest one is to use specially named methods on your class definition. Since
this covers most of the use cases, it is the only one that is covered here
more details and advanced methods can be found in
:ref:`advanced-customization`.

The customization method should use the name of the member to customize with
one of the following prefixes depending on the operation to customize:

- ``_default_``: to define default values.
- ``_observe_``: to define a static observer.
- ``_validate_``: to define a custom validation algorithm.
- ``_post_getattr_``: to customize the post-getattr step.
- ``_post_setattr_``: to customize the post-setattr step.
- ``_post_validate_``: to customize the post-setattr step.
- ``_getstate_``: to determine if a member should be pickled

Default values
--------------

A default value handler should take no argument and return the default value
for the member.

.. code-block:: python

    class MyAtom(Atom):

        v = Value()

        def _default_v(self):
            return [{}, 1, 'a']

Static observers
----------------

A static observer is basically an observer so it should take the change
dictionary as argument (save for |Signal|).

.. code-block:: python

    class MyAtom(Atom):

        v = Value()

        def _observe_v(self, change):
            print(change)


Validation
----------

A validation handler should accept both the old value of the member and the
new value to validate. It should return a valid value.

.. code-block:: python

    class MyAtom(Atom):

        v = Value()

        def _validate_v(self, old, new):
            if old and not isinstance(new, type(old)):
                raise TypeError()
            return new


Post-operation methods
----------------------

Post-gettatr should take a single argument, ie the value that was retrieve
during the *get* step, and return whatever value it decides to.

.. code-block:: python

    class MyAtom(Atom):

        v = Value()

        def _post_getattr_v(self, value):
            print('v was accessed')
            return value

Post-setattr and post-validate both take the old and the new value of the
member as input, and post-validate should return a valid value.

.. code-block:: python

    class MyAtom(Atom):

        v = Value()

        def _post_setattr_v(self, old, new):
            print('v was set')
            return value

    class MyAtom(Atom):

        v = Value()

        def _post_validate_v(self, old, new):
            print('v was validated')
            return value

Pickle
------

Getstate method should take as single argument the name of the member they apply
to and return a bool indicating whether or not the member value should be included
in the object pickle.

.. code-block:: python

    class MyAtom(Atom):

        v = Value()

        def _getstate_v(self, name):
            print('do not pickle v')
            return False

.. note::

    Contrary to other operations, answering to the question whether a member
    should be pickled or not can be done for a given Atom class and has little
    to do with the current state of the class instance. For such cases, it
    is possible to directly set the member getstate mode as follows:

    .. code:: python

        from atom.api import GetState

        class A(Atom):

            # This member will never be pickled.
            unpickeable = Value()
            unpickeable.set_getstate_mode(GetState.Exclude, None)

    Useful variants from the |GetState| enum are:

    - Include: also include the member value in the pickle
    - Exclude: never include the member value in the pickle
    - IncludeNonDefault: include the member value only if it already exists (i.e.
      we won't need to invoke default to get a value).