Skip to content

_compat

ReadOnlyDict

Bases: IterableUserDict

Best-effort read-only dict wrapper.

Source code in client/ayon_fusion/vendor/attr/_compat.py
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
class ReadOnlyDict(IterableUserDict):
    """
    Best-effort read-only dict wrapper.
    """

    def __setitem__(self, key, val):
        # We gently pretend we're a Python 3 mappingproxy.
        raise TypeError(
            "'mappingproxy' object does not support item assignment"
        )

    def update(self, _):
        # We gently pretend we're a Python 3 mappingproxy.
        raise AttributeError(
            "'mappingproxy' object has no attribute 'update'"
        )

    def __delitem__(self, _):
        # We gently pretend we're a Python 3 mappingproxy.
        raise TypeError(
            "'mappingproxy' object does not support item deletion"
        )

    def clear(self):
        # We gently pretend we're a Python 3 mappingproxy.
        raise AttributeError(
            "'mappingproxy' object has no attribute 'clear'"
        )

    def pop(self, key, default=None):
        # We gently pretend we're a Python 3 mappingproxy.
        raise AttributeError(
            "'mappingproxy' object has no attribute 'pop'"
        )

    def popitem(self):
        # We gently pretend we're a Python 3 mappingproxy.
        raise AttributeError(
            "'mappingproxy' object has no attribute 'popitem'"
        )

    def setdefault(self, key, default=None):
        # We gently pretend we're a Python 3 mappingproxy.
        raise AttributeError(
            "'mappingproxy' object has no attribute 'setdefault'"
        )

    def __repr__(self):
        # Override to be identical to the Python 3 version.
        return "mappingproxy(" + repr(self.data) + ")"

just_warn(*args, **kw)

We only warn on Python 3 because we are not aware of any concrete consequences of not setting the cell on Python 2.

Source code in client/ayon_fusion/vendor/attr/_compat.py
113
114
115
116
117
118
119
120
121
122
123
124
def just_warn(*args, **kw):
    """
    We only warn on Python 3 because we are not aware of any concrete
    consequences of not setting the cell on Python 2.
    """
    warnings.warn(
        "Running interpreter doesn't sufficiently support code object "
        "introspection.  Some features like bare super() or accessing "
        "__class__ will not work with slotted classes.",
        RuntimeWarning,
        stacklevel=2,
    )

make_set_closure_cell()

Return a function of two arguments (cell, value) which sets the value stored in the closure cell cell to value.

Source code in client/ayon_fusion/vendor/attr/_compat.py
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
def make_set_closure_cell():
    """Return a function of two arguments (cell, value) which sets
    the value stored in the closure cell `cell` to `value`.
    """
    # pypy makes this easy. (It also supports the logic below, but
    # why not do the easy/fast thing?)
    if PYPY:

        def set_closure_cell(cell, value):
            cell.__setstate__((value,))

        return set_closure_cell

    # Otherwise gotta do it the hard way.

    # Create a function that will set its first cellvar to `value`.
    def set_first_cellvar_to(value):
        x = value
        return

        # This function will be eliminated as dead code, but
        # not before its reference to `x` forces `x` to be
        # represented as a closure cell rather than a local.
        def force_x_to_be_a_cell():  # pragma: no cover
            return x

    try:
        # Extract the code object and make sure our assumptions about
        # the closure behavior are correct.
        if PY2:
            co = set_first_cellvar_to.func_code
        else:
            co = set_first_cellvar_to.__code__
        if co.co_cellvars != ("x",) or co.co_freevars != ():
            raise AssertionError  # pragma: no cover

        # Convert this code object to a code object that sets the
        # function's first _freevar_ (not cellvar) to the argument.
        if sys.version_info >= (3, 8):
            # CPython 3.8+ has an incompatible CodeType signature
            # (added a posonlyargcount argument) but also added
            # CodeType.replace() to do this without counting parameters.
            set_first_freevar_code = co.replace(
                co_cellvars=co.co_freevars, co_freevars=co.co_cellvars
            )
        else:
            args = [co.co_argcount]
            if not PY2:
                args.append(co.co_kwonlyargcount)
            args.extend(
                [
                    co.co_nlocals,
                    co.co_stacksize,
                    co.co_flags,
                    co.co_code,
                    co.co_consts,
                    co.co_names,
                    co.co_varnames,
                    co.co_filename,
                    co.co_name,
                    co.co_firstlineno,
                    co.co_lnotab,
                    # These two arguments are reversed:
                    co.co_cellvars,
                    co.co_freevars,
                ]
            )
            set_first_freevar_code = types.CodeType(*args)

        def set_closure_cell(cell, value):
            # Create a function using the set_first_freevar_code,
            # whose first closure cell is `cell`. Calling it will
            # change the value of that cell.
            setter = types.FunctionType(
                set_first_freevar_code, {}, "setter", (), (cell,)
            )
            # And call it to set the cell.
            setter(value)

        # Make sure it works on this interpreter:
        def make_func_with_cell():
            x = None

            def func():
                return x  # pragma: no cover

            return func

        if PY2:
            cell = make_func_with_cell().func_closure[0]
        else:
            cell = make_func_with_cell().__closure__[0]
        set_closure_cell(cell, 100)
        if cell.cell_contents != 100:
            raise AssertionError  # pragma: no cover

    except Exception:
        return just_warn
    else:
        return set_closure_cell

new_class(name, bases, kwds, exec_body)

A minimal stub of types.new_class that we need for make_class.

Source code in client/ayon_fusion/vendor/attr/_compat.py
31
32
33
34
35
36
37
38
def new_class(name, bases, kwds, exec_body):
    """
    A minimal stub of types.new_class that we need for make_class.
    """
    ns = {}
    exec_body(ns)

    return type(name, bases, ns)