From ec840dded22d6640c66bd9d3aefbb4df848d7b66 Mon Sep 17 00:00:00 2001 From: "Robin.Mueller" <robin.mueller.m@gmail.com> Date: Wed, 19 Aug 2020 20:42:40 +0200 Subject: [PATCH] updated requirements --- requirements.txt | 2 +- .../wrapt-1.12.1-py3.8.egg-info/PKG-INFO | 167 + .../wrapt-1.12.1-py3.8.egg-info/SOURCES.txt | 11 + .../dependency_links.txt | 1 + .../installed-files.txt | 13 + .../wrapt-1.12.1-py3.8.egg-info/top_level.txt | 1 + venv/Lib/site-packages/wrapt/__init__.py | 16 + .../wrapt/_wrappers.cp38-win_amd64.pyd | Bin 0 -> 41984 bytes venv/Lib/site-packages/wrapt/decorators.py | 516 + venv/Lib/site-packages/wrapt/importer.py | 230 + venv/Lib/site-packages/wrapt/wrappers.py | 947 ++ .../yarl-1.5.1.dist-info/INSTALLER | 1 + .../yarl-1.5.1.dist-info/LICENSE | 201 + .../yarl-1.5.1.dist-info/METADATA | 701 + .../site-packages/yarl-1.5.1.dist-info/RECORD | 21 + .../yarl-1.5.1.dist-info/REQUESTED | 0 .../site-packages/yarl-1.5.1.dist-info/WHEEL | 5 + .../yarl-1.5.1.dist-info/top_level.txt | 1 + venv/Lib/site-packages/yarl/__init__.py | 5 + venv/Lib/site-packages/yarl/__init__.pyi | 110 + venv/Lib/site-packages/yarl/_quoting.py | 18 + venv/Lib/site-packages/yarl/_quoting_c.c | 12380 ++++++++++++++++ .../yarl/_quoting_c.cp38-win_amd64.pyd | Bin 0 -> 84480 bytes venv/Lib/site-packages/yarl/_quoting_c.pyi | 16 + venv/Lib/site-packages/yarl/_quoting_c.pyx | 394 + venv/Lib/site-packages/yarl/_quoting_py.py | 206 + venv/Lib/site-packages/yarl/_url.py | 1106 ++ venv/Lib/site-packages/yarl/py.typed | 1 + 28 files changed, 17069 insertions(+), 1 deletion(-) create mode 100644 venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/PKG-INFO create mode 100644 venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/SOURCES.txt create mode 100644 venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/dependency_links.txt create mode 100644 venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/installed-files.txt create mode 100644 venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/top_level.txt create mode 100644 venv/Lib/site-packages/wrapt/__init__.py create mode 100644 venv/Lib/site-packages/wrapt/_wrappers.cp38-win_amd64.pyd create mode 100644 venv/Lib/site-packages/wrapt/decorators.py create mode 100644 venv/Lib/site-packages/wrapt/importer.py create mode 100644 venv/Lib/site-packages/wrapt/wrappers.py create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/INSTALLER create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/LICENSE create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/METADATA create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/RECORD create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/REQUESTED create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/WHEEL create mode 100644 venv/Lib/site-packages/yarl-1.5.1.dist-info/top_level.txt create mode 100644 venv/Lib/site-packages/yarl/__init__.py create mode 100644 venv/Lib/site-packages/yarl/__init__.pyi create mode 100644 venv/Lib/site-packages/yarl/_quoting.py create mode 100644 venv/Lib/site-packages/yarl/_quoting_c.c create mode 100644 venv/Lib/site-packages/yarl/_quoting_c.cp38-win_amd64.pyd create mode 100644 venv/Lib/site-packages/yarl/_quoting_c.pyi create mode 100644 venv/Lib/site-packages/yarl/_quoting_c.pyx create mode 100644 venv/Lib/site-packages/yarl/_quoting_py.py create mode 100644 venv/Lib/site-packages/yarl/_url.py create mode 100644 venv/Lib/site-packages/yarl/py.typed diff --git a/requirements.txt b/requirements.txt index 5548b57..29f58b5 100644 --- a/requirements.txt +++ b/requirements.txt @@ -25,4 +25,4 @@ six==1.15.0 toml==0.10.1 typing-extensions==3.7.4.2 wrapt==1.11.2 -yarl==1.5.0 +yarl==1.5.1 diff --git a/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/PKG-INFO b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/PKG-INFO new file mode 100644 index 0000000..94a1534 --- /dev/null +++ b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/PKG-INFO @@ -0,0 +1,167 @@ +Metadata-Version: 1.1 +Name: wrapt +Version: 1.12.1 +Summary: Module for decorators, wrappers and monkey patching. +Home-page: https://github.com/GrahamDumpleton/wrapt +Author: Graham Dumpleton +Author-email: Graham.Dumpleton@gmail.com +License: BSD +Description: wrapt + ===== + + |Travis| |AppVeyor| |Coveralls| |PyPI| + + The aim of the **wrapt** module is to provide a transparent object proxy + for Python, which can be used as the basis for the construction of function + wrappers and decorator functions. + + The **wrapt** module focuses very much on correctness. It therefore goes + way beyond existing mechanisms such as ``functools.wraps()`` to ensure that + decorators preserve introspectability, signatures, type checking abilities + etc. The decorators that can be constructed using this module will work in + far more scenarios than typical decorators and provide more predictable and + consistent behaviour. + + To ensure that the overhead is as minimal as possible, a C extension module + is used for performance critical components. An automatic fallback to a + pure Python implementation is also provided where a target system does not + have a compiler to allow the C extension to be compiled. + + Documentation + ------------- + + For further information on the **wrapt** module see: + + * http://wrapt.readthedocs.org/ + + Quick Start + ----------- + + To implement your decorator you need to first define a wrapper function. + This will be called each time a decorated function is called. The wrapper + function needs to take four positional arguments: + + * ``wrapped`` - The wrapped function which in turns needs to be called by your wrapper function. + * ``instance`` - The object to which the wrapped function was bound when it was called. + * ``args`` - The list of positional arguments supplied when the decorated function was called. + * ``kwargs`` - The dictionary of keyword arguments supplied when the decorated function was called. + + The wrapper function would do whatever it needs to, but would usually in + turn call the wrapped function that is passed in via the ``wrapped`` + argument. + + The decorator ``@wrapt.decorator`` then needs to be applied to the wrapper + function to convert it into a decorator which can in turn be applied to + other functions. + + :: + + import wrapt + + @wrapt.decorator + def pass_through(wrapped, instance, args, kwargs): + return wrapped(*args, **kwargs) + + @pass_through + def function(): + pass + + If you wish to implement a decorator which accepts arguments, then wrap the + definition of the decorator in a function closure. Any arguments supplied + to the outer function when the decorator is applied, will be available to + the inner wrapper when the wrapped function is called. + + :: + + import wrapt + + def with_arguments(myarg1, myarg2): + @wrapt.decorator + def wrapper(wrapped, instance, args, kwargs): + return wrapped(*args, **kwargs) + return wrapper + + @with_arguments(1, 2) + def function(): + pass + + When applied to a normal function or static method, the wrapper function + when called will be passed ``None`` as the ``instance`` argument. + + When applied to an instance method, the wrapper function when called will + be passed the instance of the class the method is being called on as the + ``instance`` argument. This will be the case even when the instance method + was called explicitly via the class and the instance passed as the first + argument. That is, the instance will never be passed as part of ``args``. + + When applied to a class method, the wrapper function when called will be + passed the class type as the ``instance`` argument. + + When applied to a class, the wrapper function when called will be passed + ``None`` as the ``instance`` argument. The ``wrapped`` argument in this + case will be the class. + + The above rules can be summarised with the following example. + + :: + + import inspect + + @wrapt.decorator + def universal(wrapped, instance, args, kwargs): + if instance is None: + if inspect.isclass(wrapped): + # Decorator was applied to a class. + return wrapped(*args, **kwargs) + else: + # Decorator was applied to a function or staticmethod. + return wrapped(*args, **kwargs) + else: + if inspect.isclass(instance): + # Decorator was applied to a classmethod. + return wrapped(*args, **kwargs) + else: + # Decorator was applied to an instancemethod. + return wrapped(*args, **kwargs) + + Using these checks it is therefore possible to create a universal decorator + that can be applied in all situations. It is no longer necessary to create + different variants of decorators for normal functions and instance methods, + or use additional wrappers to convert a function decorator into one that + will work for instance methods. + + In all cases, the wrapped function passed to the wrapper function is called + in the same way, with ``args`` and ``kwargs`` being passed. The + ``instance`` argument doesn't need to be used in calling the wrapped + function. + + Repository + ---------- + + Full source code for the **wrapt** module, including documentation files + and unit tests, can be obtained from github. + + * https://github.com/GrahamDumpleton/wrapt + + .. |Travis| image:: https://travis-ci.org/GrahamDumpleton/wrapt.svg?branch=develop + :target: https://travis-ci.org/GrahamDumpleton/wrapt + .. |Appveyor| image:: https://ci.appveyor.com/api/projects/status/32r7s2skrgm9ubva?svg=true + :target: https://ci.appveyor.com/project/GrahamDumpleton/wrapt/branch/develop + .. |Coveralls| image:: https://img.shields.io/coveralls/GrahamDumpleton/wrapt/develop.svg + :target: https://coveralls.io/github/GrahamDumpleton/wrapt?branch=develop + .. |PyPI| image:: https://img.shields.io/pypi/v/wrapt.svg + :target: https://pypi.python.org/pypi/wrapt + +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: License :: OSI Approved :: BSD License +Classifier: Programming Language :: Python :: 2 +Classifier: Programming Language :: Python :: 2.7 +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.4 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy diff --git a/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/SOURCES.txt b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/SOURCES.txt new file mode 100644 index 0000000..09a17b5 --- /dev/null +++ b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/SOURCES.txt @@ -0,0 +1,11 @@ +README.rst +setup.py +src/wrapt/_wrappers.c +src/wrapt/__init__.py +src/wrapt/decorators.py +src/wrapt/importer.py +src/wrapt/wrappers.py +src/wrapt.egg-info/PKG-INFO +src/wrapt.egg-info/SOURCES.txt +src/wrapt.egg-info/dependency_links.txt +src/wrapt.egg-info/top_level.txt \ No newline at end of file diff --git a/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/dependency_links.txt b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/dependency_links.txt new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/dependency_links.txt @@ -0,0 +1 @@ + diff --git a/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/installed-files.txt b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/installed-files.txt new file mode 100644 index 0000000..d6dcfd9 --- /dev/null +++ b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/installed-files.txt @@ -0,0 +1,13 @@ +..\wrapt\__init__.py +..\wrapt\__pycache__\__init__.cpython-38.pyc +..\wrapt\__pycache__\decorators.cpython-38.pyc +..\wrapt\__pycache__\importer.cpython-38.pyc +..\wrapt\__pycache__\wrappers.cpython-38.pyc +..\wrapt\_wrappers.cp38-win_amd64.pyd +..\wrapt\decorators.py +..\wrapt\importer.py +..\wrapt\wrappers.py +PKG-INFO +SOURCES.txt +dependency_links.txt +top_level.txt diff --git a/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/top_level.txt b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/top_level.txt new file mode 100644 index 0000000..ba11553 --- /dev/null +++ b/venv/Lib/site-packages/wrapt-1.12.1-py3.8.egg-info/top_level.txt @@ -0,0 +1 @@ +wrapt diff --git a/venv/Lib/site-packages/wrapt/__init__.py b/venv/Lib/site-packages/wrapt/__init__.py new file mode 100644 index 0000000..7be739b --- /dev/null +++ b/venv/Lib/site-packages/wrapt/__init__.py @@ -0,0 +1,16 @@ +__version_info__ = ('1', '12', '1') +__version__ = '.'.join(__version_info__) + +from .wrappers import (ObjectProxy, CallableObjectProxy, FunctionWrapper, + BoundFunctionWrapper, WeakFunctionProxy, PartialCallableObjectProxy, + resolve_path, apply_patch, wrap_object, wrap_object_attribute, + function_wrapper, wrap_function_wrapper, patch_function_wrapper, + transient_function_wrapper) + +from .decorators import (adapter_factory, AdapterFactory, decorator, + synchronized) + +from .importer import (register_post_import_hook, when_imported, + notify_module_loaded, discover_post_import_hooks) + +from inspect import getcallargs diff --git a/venv/Lib/site-packages/wrapt/_wrappers.cp38-win_amd64.pyd b/venv/Lib/site-packages/wrapt/_wrappers.cp38-win_amd64.pyd new file mode 100644 index 0000000000000000000000000000000000000000..2c5cb91a68d34ade405ebe0bc1a249232d680fb0 GIT binary patch literal 41984 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 literal 0 HcmV?d00001 diff --git a/venv/Lib/site-packages/wrapt/decorators.py b/venv/Lib/site-packages/wrapt/decorators.py new file mode 100644 index 0000000..506303d --- /dev/null +++ b/venv/Lib/site-packages/wrapt/decorators.py @@ -0,0 +1,516 @@ +"""This module implements decorators for implementing other decorators +as well as some commonly used decorators. + +""" + +import sys + +PY2 = sys.version_info[0] == 2 + +if PY2: + string_types = basestring, + + def exec_(_code_, _globs_=None, _locs_=None): + """Execute code in a namespace.""" + if _globs_ is None: + frame = sys._getframe(1) + _globs_ = frame.f_globals + if _locs_ is None: + _locs_ = frame.f_locals + del frame + elif _locs_ is None: + _locs_ = _globs_ + exec("""exec _code_ in _globs_, _locs_""") + +else: + string_types = str, + + import builtins + + exec_ = getattr(builtins, "exec") + del builtins + +from functools import partial +from inspect import ismethod, isclass, formatargspec +from collections import namedtuple +from threading import Lock, RLock + +try: + from inspect import signature +except ImportError: + pass + +from .wrappers import (FunctionWrapper, BoundFunctionWrapper, ObjectProxy, + CallableObjectProxy) + +# Adapter wrapper for the wrapped function which will overlay certain +# properties from the adapter function onto the wrapped function so that +# functions such as inspect.getargspec(), inspect.getfullargspec(), +# inspect.signature() and inspect.getsource() return the correct results +# one would expect. + +class _AdapterFunctionCode(CallableObjectProxy): + + def __init__(self, wrapped_code, adapter_code): + super(_AdapterFunctionCode, self).__init__(wrapped_code) + self._self_adapter_code = adapter_code + + @property + def co_argcount(self): + return self._self_adapter_code.co_argcount + + @property + def co_code(self): + return self._self_adapter_code.co_code + + @property + def co_flags(self): + return self._self_adapter_code.co_flags + + @property + def co_kwonlyargcount(self): + return self._self_adapter_code.co_kwonlyargcount + + @property + def co_varnames(self): + return self._self_adapter_code.co_varnames + +class _AdapterFunctionSurrogate(CallableObjectProxy): + + def __init__(self, wrapped, adapter): + super(_AdapterFunctionSurrogate, self).__init__(wrapped) + self._self_adapter = adapter + + @property + def __code__(self): + return _AdapterFunctionCode(self.__wrapped__.__code__, + self._self_adapter.__code__) + + @property + def __defaults__(self): + return self._self_adapter.__defaults__ + + @property + def __kwdefaults__(self): + return self._self_adapter.__kwdefaults__ + + @property + def __signature__(self): + if 'signature' not in globals(): + return self._self_adapter.__signature__ + else: + return signature(self._self_adapter) + + if PY2: + func_code = __code__ + func_defaults = __defaults__ + +class _BoundAdapterWrapper(BoundFunctionWrapper): + + @property + def __func__(self): + return _AdapterFunctionSurrogate(self.__wrapped__.__func__, + self._self_parent._self_adapter) + + @property + def __signature__(self): + if 'signature' not in globals(): + return self.__wrapped__.__signature__ + else: + return signature(self._self_parent._self_adapter) + + if PY2: + im_func = __func__ + +class AdapterWrapper(FunctionWrapper): + + __bound_function_wrapper__ = _BoundAdapterWrapper + + def __init__(self, *args, **kwargs): + adapter = kwargs.pop('adapter') + super(AdapterWrapper, self).__init__(*args, **kwargs) + self._self_surrogate = _AdapterFunctionSurrogate( + self.__wrapped__, adapter) + self._self_adapter = adapter + + @property + def __code__(self): + return self._self_surrogate.__code__ + + @property + def __defaults__(self): + return self._self_surrogate.__defaults__ + + @property + def __kwdefaults__(self): + return self._self_surrogate.__kwdefaults__ + + if PY2: + func_code = __code__ + func_defaults = __defaults__ + + @property + def __signature__(self): + return self._self_surrogate.__signature__ + +class AdapterFactory(object): + def __call__(self, wrapped): + raise NotImplementedError() + +class DelegatedAdapterFactory(AdapterFactory): + def __init__(self, factory): + super(DelegatedAdapterFactory, self).__init__() + self.factory = factory + def __call__(self, wrapped): + return self.factory(wrapped) + +adapter_factory = DelegatedAdapterFactory + +# Decorator for creating other decorators. This decorator and the +# wrappers which they use are designed to properly preserve any name +# attributes, function signatures etc, in addition to the wrappers +# themselves acting like a transparent proxy for the original wrapped +# function so the wrapper is effectively indistinguishable from the +# original wrapped function. + +def decorator(wrapper=None, enabled=None, adapter=None): + # The decorator should be supplied with a single positional argument + # which is the wrapper function to be used to implement the + # decorator. This may be preceded by a step whereby the keyword + # arguments are supplied to customise the behaviour of the + # decorator. The 'adapter' argument is used to optionally denote a + # separate function which is notionally used by an adapter + # decorator. In that case parts of the function '__code__' and + # '__defaults__' attributes are used from the adapter function + # rather than those of the wrapped function. This allows for the + # argument specification from inspect.getargspec() and similar + # functions to be overridden with a prototype for a different + # function than what was wrapped. The 'enabled' argument provides a + # way to enable/disable the use of the decorator. If the type of + # 'enabled' is a boolean, then it is evaluated immediately and the + # wrapper not even applied if it is False. If not a boolean, it will + # be evaluated when the wrapper is called for an unbound wrapper, + # and when binding occurs for a bound wrapper. When being evaluated, + # if 'enabled' is callable it will be called to obtain the value to + # be checked. If False, the wrapper will not be called and instead + # the original wrapped function will be called directly instead. + + if wrapper is not None: + # Helper function for creating wrapper of the appropriate + # time when we need it down below. + + def _build(wrapped, wrapper, enabled=None, adapter=None): + if adapter: + if isinstance(adapter, AdapterFactory): + adapter = adapter(wrapped) + + if not callable(adapter): + ns = {} + if not isinstance(adapter, string_types): + adapter = formatargspec(*adapter) + exec_('def adapter{}: pass'.format(adapter), ns, ns) + adapter = ns['adapter'] + + return AdapterWrapper(wrapped=wrapped, wrapper=wrapper, + enabled=enabled, adapter=adapter) + + return FunctionWrapper(wrapped=wrapped, wrapper=wrapper, + enabled=enabled) + + # The wrapper has been provided so return the final decorator. + # The decorator is itself one of our function wrappers so we + # can determine when it is applied to functions, instance methods + # or class methods. This allows us to bind the instance or class + # method so the appropriate self or cls attribute is supplied + # when it is finally called. + + def _wrapper(wrapped, instance, args, kwargs): + # We first check for the case where the decorator was applied + # to a class type. + # + # @decorator + # class mydecoratorclass(object): + # def __init__(self, arg=None): + # self.arg = arg + # def __call__(self, wrapped, instance, args, kwargs): + # return wrapped(*args, **kwargs) + # + # @mydecoratorclass(arg=1) + # def function(): + # pass + # + # In this case an instance of the class is to be used as the + # decorator wrapper function. If args was empty at this point, + # then it means that there were optional keyword arguments + # supplied to be used when creating an instance of the class + # to be used as the wrapper function. + + if instance is None and isclass(wrapped) and not args: + # We still need to be passed the target function to be + # wrapped as yet, so we need to return a further function + # to be able to capture it. + + def _capture(target_wrapped): + # Now have the target function to be wrapped and need + # to create an instance of the class which is to act + # as the decorator wrapper function. Before we do that, + # we need to first check that use of the decorator + # hadn't been disabled by a simple boolean. If it was, + # the target function to be wrapped is returned instead. + + _enabled = enabled + if type(_enabled) is bool: + if not _enabled: + return target_wrapped + _enabled = None + + # Now create an instance of the class which is to act + # as the decorator wrapper function. Any arguments had + # to be supplied as keyword only arguments so that is + # all we pass when creating it. + + target_wrapper = wrapped(**kwargs) + + # Finally build the wrapper itself and return it. + + return _build(target_wrapped, target_wrapper, + _enabled, adapter) + + return _capture + + # We should always have the target function to be wrapped at + # this point as the first (and only) value in args. + + target_wrapped = args[0] + + # Need to now check that use of the decorator hadn't been + # disabled by a simple boolean. If it was, then target + # function to be wrapped is returned instead. + + _enabled = enabled + if type(_enabled) is bool: + if not _enabled: + return target_wrapped + _enabled = None + + # We now need to build the wrapper, but there are a couple of + # different cases we need to consider. + + if instance is None: + if isclass(wrapped): + # In this case the decorator was applied to a class + # type but optional keyword arguments were not supplied + # for initialising an instance of the class to be used + # as the decorator wrapper function. + # + # @decorator + # class mydecoratorclass(object): + # def __init__(self, arg=None): + # self.arg = arg + # def __call__(self, wrapped, instance, + # args, kwargs): + # return wrapped(*args, **kwargs) + # + # @mydecoratorclass + # def function(): + # pass + # + # We still need to create an instance of the class to + # be used as the decorator wrapper function, but no + # arguments are pass. + + target_wrapper = wrapped() + + else: + # In this case the decorator was applied to a normal + # function, or possibly a static method of a class. + # + # @decorator + # def mydecoratorfuntion(wrapped, instance, + # args, kwargs): + # return wrapped(*args, **kwargs) + # + # @mydecoratorfunction + # def function(): + # pass + # + # That normal function becomes the decorator wrapper + # function. + + target_wrapper = wrapper + + else: + if isclass(instance): + # In this case the decorator was applied to a class + # method. + # + # class myclass(object): + # @decorator + # @classmethod + # def decoratorclassmethod(cls, wrapped, + # instance, args, kwargs): + # return wrapped(*args, **kwargs) + # + # instance = myclass() + # + # @instance.decoratorclassmethod + # def function(): + # pass + # + # This one is a bit strange because binding was actually + # performed on the wrapper created by our decorator + # factory. We need to apply that binding to the decorator + # wrapper function which which the decorator factory + # was applied to. + + target_wrapper = wrapper.__get__(None, instance) + + else: + # In this case the decorator was applied to an instance + # method. + # + # class myclass(object): + # @decorator + # def decoratorclassmethod(self, wrapped, + # instance, args, kwargs): + # return wrapped(*args, **kwargs) + # + # instance = myclass() + # + # @instance.decoratorclassmethod + # def function(): + # pass + # + # This one is a bit strange because binding was actually + # performed on the wrapper created by our decorator + # factory. We need to apply that binding to the decorator + # wrapper function which which the decorator factory + # was applied to. + + target_wrapper = wrapper.__get__(instance, type(instance)) + + # Finally build the wrapper itself and return it. + + return _build(target_wrapped, target_wrapper, _enabled, adapter) + + # We first return our magic function wrapper here so we can + # determine in what context the decorator factory was used. In + # other words, it is itself a universal decorator. The decorator + # function is used as the adapter so that linters see a signature + # corresponding to the decorator and not the wrapper it is being + # applied to. + + return _build(wrapper, _wrapper, adapter=decorator) + + else: + # The wrapper still has not been provided, so we are just + # collecting the optional keyword arguments. Return the + # decorator again wrapped in a partial using the collected + # arguments. + + return partial(decorator, enabled=enabled, adapter=adapter) + +# Decorator for implementing thread synchronization. It can be used as a +# decorator, in which case the synchronization context is determined by +# what type of function is wrapped, or it can also be used as a context +# manager, where the user needs to supply the correct synchronization +# context. It is also possible to supply an object which appears to be a +# synchronization primitive of some sort, by virtue of having release() +# and acquire() methods. In that case that will be used directly as the +# synchronization primitive without creating a separate lock against the +# derived or supplied context. + +def synchronized(wrapped): + # Determine if being passed an object which is a synchronization + # primitive. We can't check by type for Lock, RLock, Semaphore etc, + # as the means of creating them isn't the type. Therefore use the + # existence of acquire() and release() methods. This is more + # extensible anyway as it allows custom synchronization mechanisms. + + if hasattr(wrapped, 'acquire') and hasattr(wrapped, 'release'): + # We remember what the original lock is and then return a new + # decorator which accesses and locks it. When returning the new + # decorator we wrap it with an object proxy so we can override + # the context manager methods in case it is being used to wrap + # synchronized statements with a 'with' statement. + + lock = wrapped + + @decorator + def _synchronized(wrapped, instance, args, kwargs): + # Execute the wrapped function while the original supplied + # lock is held. + + with lock: + return wrapped(*args, **kwargs) + + class _PartialDecorator(CallableObjectProxy): + + def __enter__(self): + lock.acquire() + return lock + + def __exit__(self, *args): + lock.release() + + return _PartialDecorator(wrapped=_synchronized) + + # Following only apply when the lock is being created automatically + # based on the context of what was supplied. In this case we supply + # a final decorator, but need to use FunctionWrapper directly as we + # want to derive from it to add context manager methods in case it is + # being used to wrap synchronized statements with a 'with' statement. + + def _synchronized_lock(context): + # Attempt to retrieve the lock for the specific context. + + lock = vars(context).get('_synchronized_lock', None) + + if lock is None: + # There is no existing lock defined for the context we + # are dealing with so we need to create one. This needs + # to be done in a way to guarantee there is only one + # created, even if multiple threads try and create it at + # the same time. We can't always use the setdefault() + # method on the __dict__ for the context. This is the + # case where the context is a class, as __dict__ is + # actually a dictproxy. What we therefore do is use a + # meta lock on this wrapper itself, to control the + # creation and assignment of the lock attribute against + # the context. + + with synchronized._synchronized_meta_lock: + # We need to check again for whether the lock we want + # exists in case two threads were trying to create it + # at the same time and were competing to create the + # meta lock. + + lock = vars(context).get('_synchronized_lock', None) + + if lock is None: + lock = RLock() + setattr(context, '_synchronized_lock', lock) + + return lock + + def _synchronized_wrapper(wrapped, instance, args, kwargs): + # Execute the wrapped function while the lock for the + # desired context is held. If instance is None then the + # wrapped function is used as the context. + + with _synchronized_lock(instance if instance is not None else wrapped): + return wrapped(*args, **kwargs) + + class _FinalDecorator(FunctionWrapper): + + def __enter__(self): + self._self_lock = _synchronized_lock(self.__wrapped__) + self._self_lock.acquire() + return self._self_lock + + def __exit__(self, *args): + self._self_lock.release() + + return _FinalDecorator(wrapped=wrapped, wrapper=_synchronized_wrapper) + +synchronized._synchronized_meta_lock = Lock() diff --git a/venv/Lib/site-packages/wrapt/importer.py b/venv/Lib/site-packages/wrapt/importer.py new file mode 100644 index 0000000..4665f38 --- /dev/null +++ b/venv/Lib/site-packages/wrapt/importer.py @@ -0,0 +1,230 @@ +"""This module implements a post import hook mechanism styled after what is +described in PEP-369. Note that it doesn't cope with modules being reloaded. + +""" + +import sys +import threading + +PY2 = sys.version_info[0] == 2 + +if PY2: + string_types = basestring, +else: + import importlib + string_types = str, + +from .decorators import synchronized + +# The dictionary registering any post import hooks to be triggered once +# the target module has been imported. Once a module has been imported +# and the hooks fired, the list of hooks recorded against the target +# module will be truncacted but the list left in the dictionary. This +# acts as a flag to indicate that the module had already been imported. + +_post_import_hooks = {} +_post_import_hooks_init = False +_post_import_hooks_lock = threading.RLock() + +# Register a new post import hook for the target module name. This +# differs from the PEP-369 implementation in that it also allows the +# hook function to be specified as a string consisting of the name of +# the callback in the form 'module:function'. This will result in a +# proxy callback being registered which will defer loading of the +# specified module containing the callback function until required. + +def _create_import_hook_from_string(name): + def import_hook(module): + module_name, function = name.split(':') + attrs = function.split('.') + __import__(module_name) + callback = sys.modules[module_name] + for attr in attrs: + callback = getattr(callback, attr) + return callback(module) + return import_hook + +@synchronized(_post_import_hooks_lock) +def register_post_import_hook(hook, name): + # Create a deferred import hook if hook is a string name rather than + # a callable function. + + if isinstance(hook, string_types): + hook = _create_import_hook_from_string(hook) + + # Automatically install the import hook finder if it has not already + # been installed. + + global _post_import_hooks_init + + if not _post_import_hooks_init: + _post_import_hooks_init = True + sys.meta_path.insert(0, ImportHookFinder()) + + # Determine if any prior registration of a post import hook for + # the target modules has occurred and act appropriately. + + hooks = _post_import_hooks.get(name, None) + + if hooks is None: + # No prior registration of post import hooks for the target + # module. We need to check whether the module has already been + # imported. If it has we fire the hook immediately and add an + # empty list to the registry to indicate that the module has + # already been imported and hooks have fired. Otherwise add + # the post import hook to the registry. + + module = sys.modules.get(name, None) + + if module is not None: + _post_import_hooks[name] = [] + hook(module) + + else: + _post_import_hooks[name] = [hook] + + elif hooks == []: + # A prior registration of port import hooks for the target + # module was done and the hooks already fired. Fire the hook + # immediately. + + module = sys.modules[name] + hook(module) + + else: + # A prior registration of port import hooks for the target + # module was done but the module has not yet been imported. + + _post_import_hooks[name].append(hook) + +# Register post import hooks defined as package entry points. + +def _create_import_hook_from_entrypoint(entrypoint): + def import_hook(module): + __import__(entrypoint.module_name) + callback = sys.modules[entrypoint.module_name] + for attr in entrypoint.attrs: + callback = getattr(callback, attr) + return callback(module) + return import_hook + +def discover_post_import_hooks(group): + try: + import pkg_resources + except ImportError: + return + + for entrypoint in pkg_resources.iter_entry_points(group=group): + callback = _create_import_hook_from_entrypoint(entrypoint) + register_post_import_hook(callback, entrypoint.name) + +# Indicate that a module has been loaded. Any post import hooks which +# were registered against the target module will be invoked. If an +# exception is raised in any of the post import hooks, that will cause +# the import of the target module to fail. + +@synchronized(_post_import_hooks_lock) +def notify_module_loaded(module): + name = getattr(module, '__name__', None) + hooks = _post_import_hooks.get(name, None) + + if hooks: + _post_import_hooks[name] = [] + + for hook in hooks: + hook(module) + +# A custom module import finder. This intercepts attempts to import +# modules and watches out for attempts to import target modules of +# interest. When a module of interest is imported, then any post import +# hooks which are registered will be invoked. + +class _ImportHookLoader: + + def load_module(self, fullname): + module = sys.modules[fullname] + notify_module_loaded(module) + + return module + +class _ImportHookChainedLoader: + + def __init__(self, loader): + self.loader = loader + + def load_module(self, fullname): + module = self.loader.load_module(fullname) + notify_module_loaded(module) + + return module + +class ImportHookFinder: + + def __init__(self): + self.in_progress = {} + + @synchronized(_post_import_hooks_lock) + def find_module(self, fullname, path=None): + # If the module being imported is not one we have registered + # post import hooks for, we can return immediately. We will + # take no further part in the importing of this module. + + if not fullname in _post_import_hooks: + return None + + # When we are interested in a specific module, we will call back + # into the import system a second time to defer to the import + # finder that is supposed to handle the importing of the module. + # We set an in progress flag for the target module so that on + # the second time through we don't trigger another call back + # into the import system and cause a infinite loop. + + if fullname in self.in_progress: + return None + + self.in_progress[fullname] = True + + # Now call back into the import system again. + + try: + if PY2: + # For Python 2 we don't have much choice but to + # call back in to __import__(). This will + # actually cause the module to be imported. If no + # module could be found then ImportError will be + # raised. Otherwise we return a loader which + # returns the already loaded module and invokes + # the post import hooks. + + __import__(fullname) + + return _ImportHookLoader() + + else: + # For Python 3 we need to use find_spec().loader + # from the importlib.util module. It doesn't actually + # import the target module and only finds the + # loader. If a loader is found, we need to return + # our own loader which will then in turn call the + # real loader to import the module and invoke the + # post import hooks. + try: + import importlib.util + loader = importlib.util.find_spec(fullname).loader + except (ImportError, AttributeError): + loader = importlib.find_loader(fullname, path) + if loader: + return _ImportHookChainedLoader(loader) + + + finally: + del self.in_progress[fullname] + +# Decorator for marking that a function should be called as a post +# import hook when the target module is imported. + +def when_imported(name): + def register(hook): + register_post_import_hook(hook, name) + return hook + return register diff --git a/venv/Lib/site-packages/wrapt/wrappers.py b/venv/Lib/site-packages/wrapt/wrappers.py new file mode 100644 index 0000000..18cf5e0 --- /dev/null +++ b/venv/Lib/site-packages/wrapt/wrappers.py @@ -0,0 +1,947 @@ +import os +import sys +import functools +import operator +import weakref +import inspect + +PY2 = sys.version_info[0] == 2 + +if PY2: + string_types = basestring, +else: + string_types = str, + +def with_metaclass(meta, *bases): + """Create a base class with a metaclass.""" + return meta("NewBase", bases, {}) + +class _ObjectProxyMethods(object): + + # We use properties to override the values of __module__ and + # __doc__. If we add these in ObjectProxy, the derived class + # __dict__ will still be setup to have string variants of these + # attributes and the rules of descriptors means that they appear to + # take precedence over the properties in the base class. To avoid + # that, we copy the properties into the derived class type itself + # via a meta class. In that way the properties will always take + # precedence. + + @property + def __module__(self): + return self.__wrapped__.__module__ + + @__module__.setter + def __module__(self, value): + self.__wrapped__.__module__ = value + + @property + def __doc__(self): + return self.__wrapped__.__doc__ + + @__doc__.setter + def __doc__(self, value): + self.__wrapped__.__doc__ = value + + # We similar use a property for __dict__. We need __dict__ to be + # explicit to ensure that vars() works as expected. + + @property + def __dict__(self): + return self.__wrapped__.__dict__ + + # Need to also propagate the special __weakref__ attribute for case + # where decorating classes which will define this. If do not define + # it and use a function like inspect.getmembers() on a decorator + # class it will fail. This can't be in the derived classes. + + @property + def __weakref__(self): + return self.__wrapped__.__weakref__ + +class _ObjectProxyMetaType(type): + def __new__(cls, name, bases, dictionary): + # Copy our special properties into the class so that they + # always take precedence over attributes of the same name added + # during construction of a derived class. This is to save + # duplicating the implementation for them in all derived classes. + + dictionary.update(vars(_ObjectProxyMethods)) + + return type.__new__(cls, name, bases, dictionary) + +class ObjectProxy(with_metaclass(_ObjectProxyMetaType)): + + __slots__ = '__wrapped__' + + def __init__(self, wrapped): + object.__setattr__(self, '__wrapped__', wrapped) + + # Python 3.2+ has the __qualname__ attribute, but it does not + # allow it to be overridden using a property and it must instead + # be an actual string object instead. + + try: + object.__setattr__(self, '__qualname__', wrapped.__qualname__) + except AttributeError: + pass + + @property + def __name__(self): + return self.__wrapped__.__name__ + + @__name__.setter + def __name__(self, value): + self.__wrapped__.__name__ = value + + @property + def __class__(self): + return self.__wrapped__.__class__ + + @__class__.setter + def __class__(self, value): + self.__wrapped__.__class__ = value + + @property + def __annotations__(self): + return self.__wrapped__.__annotations__ + + @__annotations__.setter + def __annotations__(self, value): + self.__wrapped__.__annotations__ = value + + def __dir__(self): + return dir(self.__wrapped__) + + def __str__(self): + return str(self.__wrapped__) + + if not PY2: + def __bytes__(self): + return bytes(self.__wrapped__) + + def __repr__(self): + return '<{} at 0x{:x} for {} at 0x{:x}>'.format( + type(self).__name__, id(self), + type(self.__wrapped__).__name__, + id(self.__wrapped__)) + + def __reversed__(self): + return reversed(self.__wrapped__) + + if not PY2: + def __round__(self): + return round(self.__wrapped__) + + if sys.hexversion >= 0x03070000: + def __mro_entries__(self, bases): + return (self.__wrapped__,) + + def __lt__(self, other): + return self.__wrapped__ < other + + def __le__(self, other): + return self.__wrapped__ <= other + + def __eq__(self, other): + return self.__wrapped__ == other + + def __ne__(self, other): + return self.__wrapped__ != other + + def __gt__(self, other): + return self.__wrapped__ > other + + def __ge__(self, other): + return self.__wrapped__ >= other + + def __hash__(self): + return hash(self.__wrapped__) + + def __nonzero__(self): + return bool(self.__wrapped__) + + def __bool__(self): + return bool(self.__wrapped__) + + def __setattr__(self, name, value): + if name.startswith('_self_'): + object.__setattr__(self, name, value) + + elif name == '__wrapped__': + object.__setattr__(self, name, value) + try: + object.__delattr__(self, '__qualname__') + except AttributeError: + pass + try: + object.__setattr__(self, '__qualname__', value.__qualname__) + except AttributeError: + pass + + elif name == '__qualname__': + setattr(self.__wrapped__, name, value) + object.__setattr__(self, name, value) + + elif hasattr(type(self), name): + object.__setattr__(self, name, value) + + else: + setattr(self.__wrapped__, name, value) + + def __getattr__(self, name): + # If we are being to lookup '__wrapped__' then the + # '__init__()' method cannot have been called. + + if name == '__wrapped__': + raise ValueError('wrapper has not been initialised') + + return getattr(self.__wrapped__, name) + + def __delattr__(self, name): + if name.startswith('_self_'): + object.__delattr__(self, name) + + elif name == '__wrapped__': + raise TypeError('__wrapped__ must be an object') + + elif name == '__qualname__': + object.__delattr__(self, name) + delattr(self.__wrapped__, name) + + elif hasattr(type(self), name): + object.__delattr__(self, name) + + else: + delattr(self.__wrapped__, name) + + def __add__(self, other): + return self.__wrapped__ + other + + def __sub__(self, other): + return self.__wrapped__ - other + + def __mul__(self, other): + return self.__wrapped__ * other + + def __div__(self, other): + return operator.div(self.__wrapped__, other) + + def __truediv__(self, other): + return operator.truediv(self.__wrapped__, other) + + def __floordiv__(self, other): + return self.__wrapped__ // other + + def __mod__(self, other): + return self.__wrapped__ % other + + def __divmod__(self, other): + return divmod(self.__wrapped__, other) + + def __pow__(self, other, *args): + return pow(self.__wrapped__, other, *args) + + def __lshift__(self, other): + return self.__wrapped__ << other + + def __rshift__(self, other): + return self.__wrapped__ >> other + + def __and__(self, other): + return self.__wrapped__ & other + + def __xor__(self, other): + return self.__wrapped__ ^ other + + def __or__(self, other): + return self.__wrapped__ | other + + def __radd__(self, other): + return other + self.__wrapped__ + + def __rsub__(self, other): + return other - self.__wrapped__ + + def __rmul__(self, other): + return other * self.__wrapped__ + + def __rdiv__(self, other): + return operator.div(other, self.__wrapped__) + + def __rtruediv__(self, other): + return operator.truediv(other, self.__wrapped__) + + def __rfloordiv__(self, other): + return other // self.__wrapped__ + + def __rmod__(self, other): + return other % self.__wrapped__ + + def __rdivmod__(self, other): + return divmod(other, self.__wrapped__) + + def __rpow__(self, other, *args): + return pow(other, self.__wrapped__, *args) + + def __rlshift__(self, other): + return other << self.__wrapped__ + + def __rrshift__(self, other): + return other >> self.__wrapped__ + + def __rand__(self, other): + return other & self.__wrapped__ + + def __rxor__(self, other): + return other ^ self.__wrapped__ + + def __ror__(self, other): + return other | self.__wrapped__ + + def __iadd__(self, other): + self.__wrapped__ += other + return self + + def __isub__(self, other): + self.__wrapped__ -= other + return self + + def __imul__(self, other): + self.__wrapped__ *= other + return self + + def __idiv__(self, other): + self.__wrapped__ = operator.idiv(self.__wrapped__, other) + return self + + def __itruediv__(self, other): + self.__wrapped__ = operator.itruediv(self.__wrapped__, other) + return self + + def __ifloordiv__(self, other): + self.__wrapped__ //= other + return self + + def __imod__(self, other): + self.__wrapped__ %= other + return self + + def __ipow__(self, other): + self.__wrapped__ **= other + return self + + def __ilshift__(self, other): + self.__wrapped__ <<= other + return self + + def __irshift__(self, other): + self.__wrapped__ >>= other + return self + + def __iand__(self, other): + self.__wrapped__ &= other + return self + + def __ixor__(self, other): + self.__wrapped__ ^= other + return self + + def __ior__(self, other): + self.__wrapped__ |= other + return self + + def __neg__(self): + return -self.__wrapped__ + + def __pos__(self): + return +self.__wrapped__ + + def __abs__(self): + return abs(self.__wrapped__) + + def __invert__(self): + return ~self.__wrapped__ + + def __int__(self): + return int(self.__wrapped__) + + def __long__(self): + return long(self.__wrapped__) + + def __float__(self): + return float(self.__wrapped__) + + def __complex__(self): + return complex(self.__wrapped__) + + def __oct__(self): + return oct(self.__wrapped__) + + def __hex__(self): + return hex(self.__wrapped__) + + def __index__(self): + return operator.index(self.__wrapped__) + + def __len__(self): + return len(self.__wrapped__) + + def __contains__(self, value): + return value in self.__wrapped__ + + def __getitem__(self, key): + return self.__wrapped__[key] + + def __setitem__(self, key, value): + self.__wrapped__[key] = value + + def __delitem__(self, key): + del self.__wrapped__[key] + + def __getslice__(self, i, j): + return self.__wrapped__[i:j] + + def __setslice__(self, i, j, value): + self.__wrapped__[i:j] = value + + def __delslice__(self, i, j): + del self.__wrapped__[i:j] + + def __enter__(self): + return self.__wrapped__.__enter__() + + def __exit__(self, *args, **kwargs): + return self.__wrapped__.__exit__(*args, **kwargs) + + def __iter__(self): + return iter(self.__wrapped__) + + def __copy__(self): + raise NotImplementedError('object proxy must define __copy__()') + + def __deepcopy__(self, memo): + raise NotImplementedError('object proxy must define __deepcopy__()') + + def __reduce__(self): + raise NotImplementedError( + 'object proxy must define __reduce_ex__()') + + def __reduce_ex__(self, protocol): + raise NotImplementedError( + 'object proxy must define __reduce_ex__()') + +class CallableObjectProxy(ObjectProxy): + + def __call__(self, *args, **kwargs): + return self.__wrapped__(*args, **kwargs) + +class PartialCallableObjectProxy(ObjectProxy): + + def __init__(self, *args, **kwargs): + if len(args) < 1: + raise TypeError('partial type takes at least one argument') + + wrapped, args = args[0], args[1:] + + if not callable(wrapped): + raise TypeError('the first argument must be callable') + + super(PartialCallableObjectProxy, self).__init__(wrapped) + + self._self_args = args + self._self_kwargs = kwargs + + def __call__(self, *args, **kwargs): + _args = self._self_args + args + + _kwargs = dict(self._self_kwargs) + _kwargs.update(kwargs) + + return self.__wrapped__(*_args, **_kwargs) + +class _FunctionWrapperBase(ObjectProxy): + + __slots__ = ('_self_instance', '_self_wrapper', '_self_enabled', + '_self_binding', '_self_parent') + + def __init__(self, wrapped, instance, wrapper, enabled=None, + binding='function', parent=None): + + super(_FunctionWrapperBase, self).__init__(wrapped) + + object.__setattr__(self, '_self_instance', instance) + object.__setattr__(self, '_self_wrapper', wrapper) + object.__setattr__(self, '_self_enabled', enabled) + object.__setattr__(self, '_self_binding', binding) + object.__setattr__(self, '_self_parent', parent) + + def __get__(self, instance, owner): + # This method is actually doing double duty for both unbound and + # bound derived wrapper classes. It should possibly be broken up + # and the distinct functionality moved into the derived classes. + # Can't do that straight away due to some legacy code which is + # relying on it being here in this base class. + # + # The distinguishing attribute which determines whether we are + # being called in an unbound or bound wrapper is the parent + # attribute. If binding has never occurred, then the parent will + # be None. + # + # First therefore, is if we are called in an unbound wrapper. In + # this case we perform the binding. + # + # We have one special case to worry about here. This is where we + # are decorating a nested class. In this case the wrapped class + # would not have a __get__() method to call. In that case we + # simply return self. + # + # Note that we otherwise still do binding even if instance is + # None and accessing an unbound instance method from a class. + # This is because we need to be able to later detect that + # specific case as we will need to extract the instance from the + # first argument of those passed in. + + if self._self_parent is None: + if not inspect.isclass(self.__wrapped__): + descriptor = self.__wrapped__.__get__(instance, owner) + + return self.__bound_function_wrapper__(descriptor, instance, + self._self_wrapper, self._self_enabled, + self._self_binding, self) + + return self + + # Now we have the case of binding occurring a second time on what + # was already a bound function. In this case we would usually + # return ourselves again. This mirrors what Python does. + # + # The special case this time is where we were originally bound + # with an instance of None and we were likely an instance + # method. In that case we rebind against the original wrapped + # function from the parent again. + + if self._self_instance is None and self._self_binding == 'function': + descriptor = self._self_parent.__wrapped__.__get__( + instance, owner) + + return self._self_parent.__bound_function_wrapper__( + descriptor, instance, self._self_wrapper, + self._self_enabled, self._self_binding, + self._self_parent) + + return self + + def __call__(self, *args, **kwargs): + # If enabled has been specified, then evaluate it at this point + # and if the wrapper is not to be executed, then simply return + # the bound function rather than a bound wrapper for the bound + # function. When evaluating enabled, if it is callable we call + # it, otherwise we evaluate it as a boolean. + + if self._self_enabled is not None: + if callable(self._self_enabled): + if not self._self_enabled(): + return self.__wrapped__(*args, **kwargs) + elif not self._self_enabled: + return self.__wrapped__(*args, **kwargs) + + # This can occur where initial function wrapper was applied to + # a function that was already bound to an instance. In that case + # we want to extract the instance from the function and use it. + + if self._self_binding == 'function': + if self._self_instance is None: + instance = getattr(self.__wrapped__, '__self__', None) + if instance is not None: + return self._self_wrapper(self.__wrapped__, instance, + args, kwargs) + + # This is generally invoked when the wrapped function is being + # called as a normal function and is not bound to a class as an + # instance method. This is also invoked in the case where the + # wrapped function was a method, but this wrapper was in turn + # wrapped using the staticmethod decorator. + + return self._self_wrapper(self.__wrapped__, self._self_instance, + args, kwargs) + +class BoundFunctionWrapper(_FunctionWrapperBase): + + def __call__(self, *args, **kwargs): + # If enabled has been specified, then evaluate it at this point + # and if the wrapper is not to be executed, then simply return + # the bound function rather than a bound wrapper for the bound + # function. When evaluating enabled, if it is callable we call + # it, otherwise we evaluate it as a boolean. + + if self._self_enabled is not None: + if callable(self._self_enabled): + if not self._self_enabled(): + return self.__wrapped__(*args, **kwargs) + elif not self._self_enabled: + return self.__wrapped__(*args, **kwargs) + + # We need to do things different depending on whether we are + # likely wrapping an instance method vs a static method or class + # method. + + if self._self_binding == 'function': + if self._self_instance is None: + # This situation can occur where someone is calling the + # instancemethod via the class type and passing the instance + # as the first argument. We need to shift the args before + # making the call to the wrapper and effectively bind the + # instance to the wrapped function using a partial so the + # wrapper doesn't see anything as being different. + + if not args: + raise TypeError('missing 1 required positional argument') + + instance, args = args[0], args[1:] + wrapped = PartialCallableObjectProxy(self.__wrapped__, instance) + return self._self_wrapper(wrapped, instance, args, kwargs) + + return self._self_wrapper(self.__wrapped__, self._self_instance, + args, kwargs) + + else: + # As in this case we would be dealing with a classmethod or + # staticmethod, then _self_instance will only tell us whether + # when calling the classmethod or staticmethod they did it via an + # instance of the class it is bound to and not the case where + # done by the class type itself. We thus ignore _self_instance + # and use the __self__ attribute of the bound function instead. + # For a classmethod, this means instance will be the class type + # and for a staticmethod it will be None. This is probably the + # more useful thing we can pass through even though we loose + # knowledge of whether they were called on the instance vs the + # class type, as it reflects what they have available in the + # decoratored function. + + instance = getattr(self.__wrapped__, '__self__', None) + + return self._self_wrapper(self.__wrapped__, instance, args, + kwargs) + +class FunctionWrapper(_FunctionWrapperBase): + + __bound_function_wrapper__ = BoundFunctionWrapper + + def __init__(self, wrapped, wrapper, enabled=None): + # What it is we are wrapping here could be anything. We need to + # try and detect specific cases though. In particular, we need + # to detect when we are given something that is a method of a + # class. Further, we need to know when it is likely an instance + # method, as opposed to a class or static method. This can + # become problematic though as there isn't strictly a fool proof + # method of knowing. + # + # The situations we could encounter when wrapping a method are: + # + # 1. The wrapper is being applied as part of a decorator which + # is a part of the class definition. In this case what we are + # given is the raw unbound function, classmethod or staticmethod + # wrapper objects. + # + # The problem here is that we will not know we are being applied + # in the context of the class being set up. This becomes + # important later for the case of an instance method, because in + # that case we just see it as a raw function and can't + # distinguish it from wrapping a normal function outside of + # a class context. + # + # 2. The wrapper is being applied when performing monkey + # patching of the class type afterwards and the method to be + # wrapped was retrieved direct from the __dict__ of the class + # type. This is effectively the same as (1) above. + # + # 3. The wrapper is being applied when performing monkey + # patching of the class type afterwards and the method to be + # wrapped was retrieved from the class type. In this case + # binding will have been performed where the instance against + # which the method is bound will be None at that point. + # + # This case is a problem because we can no longer tell if the + # method was a static method, plus if using Python3, we cannot + # tell if it was an instance method as the concept of an + # unnbound method no longer exists. + # + # 4. The wrapper is being applied when performing monkey + # patching of an instance of a class. In this case binding will + # have been perfomed where the instance was not None. + # + # This case is a problem because we can no longer tell if the + # method was a static method. + # + # Overall, the best we can do is look at the original type of the + # object which was wrapped prior to any binding being done and + # see if it is an instance of classmethod or staticmethod. In + # the case where other decorators are between us and them, if + # they do not propagate the __class__ attribute so that the + # isinstance() checks works, then likely this will do the wrong + # thing where classmethod and staticmethod are used. + # + # Since it is likely to be very rare that anyone even puts + # decorators around classmethod and staticmethod, likelihood of + # that being an issue is very small, so we accept it and suggest + # that those other decorators be fixed. It is also only an issue + # if a decorator wants to actually do things with the arguments. + # + # As to not being able to identify static methods properly, we + # just hope that that isn't something people are going to want + # to wrap, or if they do suggest they do it the correct way by + # ensuring that it is decorated in the class definition itself, + # or patch it in the __dict__ of the class type. + # + # So to get the best outcome we can, whenever we aren't sure what + # it is, we label it as a 'function'. If it was already bound and + # that is rebound later, we assume that it will be an instance + # method and try an cope with the possibility that the 'self' + # argument it being passed as an explicit argument and shuffle + # the arguments around to extract 'self' for use as the instance. + + if isinstance(wrapped, classmethod): + binding = 'classmethod' + + elif isinstance(wrapped, staticmethod): + binding = 'staticmethod' + + elif hasattr(wrapped, '__self__'): + if inspect.isclass(wrapped.__self__): + binding = 'classmethod' + else: + binding = 'function' + + else: + binding = 'function' + + super(FunctionWrapper, self).__init__(wrapped, None, wrapper, + enabled, binding) + +try: + if not os.environ.get('WRAPT_DISABLE_EXTENSIONS'): + from ._wrappers import (ObjectProxy, CallableObjectProxy, + PartialCallableObjectProxy, FunctionWrapper, + BoundFunctionWrapper, _FunctionWrapperBase) +except ImportError: + pass + +# Helper functions for applying wrappers to existing functions. + +def resolve_path(module, name): + if isinstance(module, string_types): + __import__(module) + module = sys.modules[module] + + parent = module + + path = name.split('.') + attribute = path[0] + + # We can't just always use getattr() because in doing + # that on a class it will cause binding to occur which + # will complicate things later and cause some things not + # to work. For the case of a class we therefore access + # the __dict__ directly. To cope though with the wrong + # class being given to us, or a method being moved into + # a base class, we need to walk the class hierarchy to + # work out exactly which __dict__ the method was defined + # in, as accessing it from __dict__ will fail if it was + # not actually on the class given. Fallback to using + # getattr() if we can't find it. If it truly doesn't + # exist, then that will fail. + + def lookup_attribute(parent, attribute): + if inspect.isclass(parent): + for cls in inspect.getmro(parent): + if attribute in vars(cls): + return vars(cls)[attribute] + else: + return getattr(parent, attribute) + else: + return getattr(parent, attribute) + + original = lookup_attribute(parent, attribute) + + for attribute in path[1:]: + parent = original + original = lookup_attribute(parent, attribute) + + return (parent, attribute, original) + +def apply_patch(parent, attribute, replacement): + setattr(parent, attribute, replacement) + +def wrap_object(module, name, factory, args=(), kwargs={}): + (parent, attribute, original) = resolve_path(module, name) + wrapper = factory(original, *args, **kwargs) + apply_patch(parent, attribute, wrapper) + return wrapper + +# Function for applying a proxy object to an attribute of a class +# instance. The wrapper works by defining an attribute of the same name +# on the class which is a descriptor and which intercepts access to the +# instance attribute. Note that this cannot be used on attributes which +# are themselves defined by a property object. + +class AttributeWrapper(object): + + def __init__(self, attribute, factory, args, kwargs): + self.attribute = attribute + self.factory = factory + self.args = args + self.kwargs = kwargs + + def __get__(self, instance, owner): + value = instance.__dict__[self.attribute] + return self.factory(value, *self.args, **self.kwargs) + + def __set__(self, instance, value): + instance.__dict__[self.attribute] = value + + def __delete__(self, instance): + del instance.__dict__[self.attribute] + +def wrap_object_attribute(module, name, factory, args=(), kwargs={}): + path, attribute = name.rsplit('.', 1) + parent = resolve_path(module, path)[2] + wrapper = AttributeWrapper(attribute, factory, args, kwargs) + apply_patch(parent, attribute, wrapper) + return wrapper + +# Functions for creating a simple decorator using a FunctionWrapper, +# plus short cut functions for applying wrappers to functions. These are +# for use when doing monkey patching. For a more featured way of +# creating decorators see the decorator decorator instead. + +def function_wrapper(wrapper): + def _wrapper(wrapped, instance, args, kwargs): + target_wrapped = args[0] + if instance is None: + target_wrapper = wrapper + elif inspect.isclass(instance): + target_wrapper = wrapper.__get__(None, instance) + else: + target_wrapper = wrapper.__get__(instance, type(instance)) + return FunctionWrapper(target_wrapped, target_wrapper) + return FunctionWrapper(wrapper, _wrapper) + +def wrap_function_wrapper(module, name, wrapper): + return wrap_object(module, name, FunctionWrapper, (wrapper,)) + +def patch_function_wrapper(module, name): + def _wrapper(wrapper): + return wrap_object(module, name, FunctionWrapper, (wrapper,)) + return _wrapper + +def transient_function_wrapper(module, name): + def _decorator(wrapper): + def _wrapper(wrapped, instance, args, kwargs): + target_wrapped = args[0] + if instance is None: + target_wrapper = wrapper + elif inspect.isclass(instance): + target_wrapper = wrapper.__get__(None, instance) + else: + target_wrapper = wrapper.__get__(instance, type(instance)) + def _execute(wrapped, instance, args, kwargs): + (parent, attribute, original) = resolve_path(module, name) + replacement = FunctionWrapper(original, target_wrapper) + setattr(parent, attribute, replacement) + try: + return wrapped(*args, **kwargs) + finally: + setattr(parent, attribute, original) + return FunctionWrapper(target_wrapped, _execute) + return FunctionWrapper(wrapper, _wrapper) + return _decorator + +# A weak function proxy. This will work on instance methods, class +# methods, static methods and regular functions. Special treatment is +# needed for the method types because the bound method is effectively a +# transient object and applying a weak reference to one will immediately +# result in it being destroyed and the weakref callback called. The weak +# reference is therefore applied to the instance the method is bound to +# and the original function. The function is then rebound at the point +# of a call via the weak function proxy. + +def _weak_function_proxy_callback(ref, proxy, callback): + if proxy._self_expired: + return + + proxy._self_expired = True + + # This could raise an exception. We let it propagate back and let + # the weakref.proxy() deal with it, at which point it generally + # prints out a short error message direct to stderr and keeps going. + + if callback is not None: + callback(proxy) + +class WeakFunctionProxy(ObjectProxy): + + __slots__ = ('_self_expired', '_self_instance') + + def __init__(self, wrapped, callback=None): + # We need to determine if the wrapped function is actually a + # bound method. In the case of a bound method, we need to keep a + # reference to the original unbound function and the instance. + # This is necessary because if we hold a reference to the bound + # function, it will be the only reference and given it is a + # temporary object, it will almost immediately expire and + # the weakref callback triggered. So what is done is that we + # hold a reference to the instance and unbound function and + # when called bind the function to the instance once again and + # then call it. Note that we avoid using a nested function for + # the callback here so as not to cause any odd reference cycles. + + _callback = callback and functools.partial( + _weak_function_proxy_callback, proxy=self, + callback=callback) + + self._self_expired = False + + if isinstance(wrapped, _FunctionWrapperBase): + self._self_instance = weakref.ref(wrapped._self_instance, + _callback) + + if wrapped._self_parent is not None: + super(WeakFunctionProxy, self).__init__( + weakref.proxy(wrapped._self_parent, _callback)) + + else: + super(WeakFunctionProxy, self).__init__( + weakref.proxy(wrapped, _callback)) + + return + + try: + self._self_instance = weakref.ref(wrapped.__self__, _callback) + + super(WeakFunctionProxy, self).__init__( + weakref.proxy(wrapped.__func__, _callback)) + + except AttributeError: + self._self_instance = None + + super(WeakFunctionProxy, self).__init__( + weakref.proxy(wrapped, _callback)) + + def __call__(self, *args, **kwargs): + # We perform a boolean check here on the instance and wrapped + # function as that will trigger the reference error prior to + # calling if the reference had expired. + + instance = self._self_instance and self._self_instance() + function = self.__wrapped__ and self.__wrapped__ + + # If the wrapped function was originally a bound function, for + # which we retained a reference to the instance and the unbound + # function we need to rebind the function and then call it. If + # not just called the wrapped function. + + if instance is None: + return self.__wrapped__(*args, **kwargs) + + return function.__get__(instance, type(instance))(*args, **kwargs) diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/INSTALLER b/venv/Lib/site-packages/yarl-1.5.1.dist-info/INSTALLER new file mode 100644 index 0000000..a1b589e --- /dev/null +++ b/venv/Lib/site-packages/yarl-1.5.1.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/LICENSE b/venv/Lib/site-packages/yarl-1.5.1.dist-info/LICENSE new file mode 100644 index 0000000..3e37e61 --- /dev/null +++ b/venv/Lib/site-packages/yarl-1.5.1.dist-info/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright 2016-2018, Andrew Svetlov and aio-libs team + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/METADATA b/venv/Lib/site-packages/yarl-1.5.1.dist-info/METADATA new file mode 100644 index 0000000..8e7f5cd --- /dev/null +++ b/venv/Lib/site-packages/yarl-1.5.1.dist-info/METADATA @@ -0,0 +1,701 @@ +Metadata-Version: 2.1 +Name: yarl +Version: 1.5.1 +Summary: Yet another URL library +Home-page: https://github.com/aio-libs/yarl/ +Author: Andrew Svetlov +Author-email: andrew.svetlov@gmail.com +License: Apache 2 +Platform: UNKNOWN +Classifier: License :: OSI Approved :: Apache Software License +Classifier: Intended Audience :: Developers +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Topic :: Internet :: WWW/HTTP +Requires-Python: >=3.5 +Description-Content-Type: text/x-rst +Requires-Dist: multidict (>=4.0) +Requires-Dist: idna (>=2.0) +Requires-Dist: typing-extensions (>=3.7.4) ; python_version < "3.8" + +yarl +==== + +.. image:: https://dev.azure.com/aio-libs/yarl/_apis/build/status/CI?branchName=master + :target: https://dev.azure.com/aio-libs/yarl/_build/latest?definitionId=7&branchName=master + :align: right + +.. image:: https://codecov.io/gh/aio-libs/yarl/branch/master/graph/badge.svg + :target: https://codecov.io/gh/aio-libs/yarl + +.. image:: https://badge.fury.io/py/yarl.svg + :target: https://badge.fury.io/py/yarl + + +.. image:: https://readthedocs.org/projects/yarl/badge/?version=latest + :target: https://yarl.readthedocs.io + + +.. image:: https://img.shields.io/pypi/pyversions/yarl.svg + :target: https://pypi.python.org/pypi/yarl + +.. image:: https://badges.gitter.im/Join%20Chat.svg + :target: https://gitter.im/aio-libs/Lobby + :alt: Chat on Gitter + +Introduction +------------ + +Url is constructed from ``str``: + +.. code-block:: pycon + + >>> from yarl import URL + >>> url = URL('https://www.python.org/~guido?arg=1#frag') + >>> url + URL('https://www.python.org/~guido?arg=1#frag') + +All url parts: *scheme*, *user*, *password*, *host*, *port*, *path*, +*query* and *fragment* are accessible by properties: + +.. code-block:: pycon + + >>> url.scheme + 'https' + >>> url.host + 'www.python.org' + >>> url.path + '/~guido' + >>> url.query_string + 'arg=1' + >>> url.query + <MultiDictProxy('arg': '1')> + >>> url.fragment + 'frag' + +All url manipulations produce a new url object: + +.. code-block:: pycon + + >>> url = URL('https://www.python.org') + >>> url / 'foo' / 'bar' + URL('https://www.python.org/foo/bar') + >>> url / 'foo' % {'bar': 'baz'} + URL('https://www.python.org/foo?bar=baz') + +Strings passed to constructor and modification methods are +automatically encoded giving canonical representation as result: + +.. code-block:: pycon + + >>> url = URL('https://www.python.org/путь') + >>> url + URL('https://www.python.org/%D0%BF%D1%83%D1%82%D1%8C') + +Regular properties are *percent-decoded*, use ``raw_`` versions for +getting *encoded* strings: + +.. code-block:: pycon + + >>> url.path + '/путь' + + >>> url.raw_path + '/%D0%BF%D1%83%D1%82%D1%8C' + +Human readable representation of URL is available as ``.human_repr()``: + +.. code-block:: pycon + + >>> url.human_repr() + 'https://www.python.org/путь' + +For full documentation please read https://yarl.readthedocs.org. + + +Installation +------------ + +:: + + $ pip install yarl + +The library is Python 3 only! + +PyPI contains binary wheels for Linux, Windows and MacOS. If you want to install +``yarl`` on another operating system (like *Alpine Linux*, which is not +manylinux-compliant because of the missing glibc and therefore, cannot be +used with our wheels) the the tarball will be used to compile the library from +the source code. It requires a C compiler and and Python headers installed. + +To skip the compilation you must explicitly opt-in by setting the `YARL_NO_EXTENSIONS` +environment variable to a non-empty value, e.g.: + +.. code-block:: bash + + $ YARL_NO_EXTENSIONS=1 pip install yarl + +Please note that the pure-Python (uncompiled) version is much slower. However, +PyPy always uses a pure-Python implementation, and, as such, it is unaffected +by this variable. + +Dependencies +------------ + +YARL requires multidict_ library. + + +API documentation +------------------ + +The documentation is located at https://yarl.readthedocs.org + + +Why isn't boolean supported by the URL query API? +------------------------------------------------- + +There is no standard for boolean representation of boolean values. + +Some systems prefer ``true``/``false``, others like ``yes``/``no``, ``on``/``off``, +``Y``/``N``, ``1``/``0``, etc. + +``yarl`` cannot make an unambiguous decision on how to serialize ``bool`` values because +it is specific to how the end-user's application is built and would be different for +different apps. The library doesn't accept booleans in the API; a user should convert +bools into strings using own preferred translation protocol. + + +Comparison with other URL libraries +------------------------------------ + +* furl (https://pypi.python.org/pypi/furl) + + The library has rich functionality but the ``furl`` object is mutable. + + I'm afraid to pass this object into foreign code: who knows if the + code will modify my url in a terrible way while I just want to send URL + with handy helpers for accessing URL properties. + + ``furl`` has other non-obvious tricky things but the main objection + is mutability. + +* URLObject (https://pypi.python.org/pypi/URLObject) + + URLObject is immutable, that's pretty good. + + Every URL change generates a new URL object. + + But the library doesn't do any decode/encode transformations leaving the + end user to cope with these gory details. + + +Source code +----------- + +The project is hosted on GitHub_ + +Please file an issue on the `bug tracker +<https://github.com/aio-libs/yarl/issues>`_ if you have found a bug +or have some suggestion in order to improve the library. + +The library uses `Azure Pipelines <https://dev.azure.com/aio-libs/yarl>`_ for +Continuous Integration. + +Discussion list +--------------- + +*aio-libs* google group: https://groups.google.com/forum/#!forum/aio-libs + +Feel free to post your questions and ideas here. + + +Authors and License +------------------- + +The ``yarl`` package is written by Andrew Svetlov. + +It's *Apache 2* licensed and freely available. + + +.. _GitHub: https://github.com/aio-libs/yarl + +.. _multidict: https://github.com/aio-libs/multidict + + +========= +Changelog +========= + +.. + You should *NOT* be adding new change log entries to this file, this + file is managed by towncrier. You *may* edit previous change logs to + fix problems like typo corrections or such. + To add a new change log entry, please see + https://pip.pypa.io/en/latest/development/#adding-a-news-entry + we named the news folder "changes". + + WARNING: Don't drop the next directive! + +.. towncrier release notes start + +1.5.0 (2020-07-26) +================== + +Features +-------- + +- Convert host to lowercase on URL building. + `#386 <https://github.com/aio-libs/yarl/issues/386>`_ +- Allow using ``mod`` operator (`%`) for updating query string (an alias for ``update_query()`` method). + `#435 <https://github.com/aio-libs/yarl/issues/435>`_ +- Allow use of sequences such as ``list`` and ``tuple`` in the values + of a mapping such as ``dict`` to represent that a key has many values:: + + url = URL("http://example.com") + assert url.with_query({"a": [1, 2]}) == URL("http://example.com/?a=1&a=2") + + `#443 <https://github.com/aio-libs/yarl/issues/443>`_ +- Support URL.build() with scheme and path (creates a relative URL). + `#464 <https://github.com/aio-libs/yarl/issues/464>`_ +- Cache slow IDNA encode/decode calls. + `#476 <https://github.com/aio-libs/yarl/issues/476>`_ +- Add ``@final`` / ``Final`` type hints + `#477 <https://github.com/aio-libs/yarl/issues/477>`_ +- Support URL authority/raw_authority properties and authority argument of ``URL.build()`` method. + `#478 <https://github.com/aio-libs/yarl/issues/478>`_ +- Hide the library implementation details, make the exposed public list very clean. + `#483 <https://github.com/aio-libs/yarl/issues/483>`_ + + +Bugfixes +-------- + +- Fix tests with newer Python (3.7.6, 3.8.1 and 3.9.0+). + `#409 <https://github.com/aio-libs/yarl/issues/409>`_ +- Fix a bug where query component, passed in a form of mapping or sequence, is unquoted in unexpected way. + `#426 <https://github.com/aio-libs/yarl/issues/426>`_ +- Hide `Query` and `QueryVariable` type aliases in `__init__.pyi`, now they are prefixed with underscore. + `#431 <https://github.com/aio-libs/yarl/issues/431>`_ +- Keep ipv6 brackets after updating port/user/password. + `#451 <https://github.com/aio-libs/yarl/issues/451>`_ + + +---- + + +1.4.2 (2019-12-05) +================== + +Features +-------- + +- Workaround for missing `str.isascii()` in Python 3.6 + `#389 <https://github.com/aio-libs/yarl/issues/389>`_ + + +---- + + +1.4.1 (2019-11-29) +================== + +* Fix regression, make the library work on Python 3.5 and 3.6 again. + +1.4.0 (2019-11-29) +================== + +* Distinguish an empty password in URL from a password not provided at all (#262) + +* Fixed annotations for optional parameters of ``URL.build`` (#309) + +* Use None as default value of ``user`` parameter of ``URL.build`` (#309) + +* Enforce building C Accelerated modules when installing from source tarball, use + ``YARL_NO_EXTENSIONS`` environment variable for falling back to (slower) Pure Python + implementation (#329) + +* Drop Python 3.5 support + +* Fix quoting of plus in path by pure python version (#339) + +* Don't create a new URL if fragment is unchanged (#292) + +* Included in error msg the path that produces starting slash forbidden error (#376) + +* Skip slow IDNA encoding for ASCII-only strings (#387) + + +1.3.0 (2018-12-11) +================== + +* Fix annotations for ``query`` parameter (#207) + +* An incoming query sequence can have int variables (the same as for + Mapping type) (#208) + +* Add ``URL.explicit_port`` property (#218) + +* Give a friendlier error when port cant be converted to int (#168) + +* ``bool(URL())`` now returns ``False`` (#272) + +1.2.6 (2018-06-14) +================== + +* Drop Python 3.4 trove classifier (#205) + +1.2.5 (2018-05-23) +================== + +* Fix annotations for ``build`` (#199) + +1.2.4 (2018-05-08) +================== + +* Fix annotations for ``cached_property`` (#195) + +1.2.3 (2018-05-03) +================== + +* Accept ``str`` subclasses in ``URL`` constructor (#190) + +1.2.2 (2018-05-01) +================== + +* Fix build + +1.2.1 (2018-04-30) +================== + +* Pin minimal required Python to 3.5.3 (#189) + +1.2.0 (2018-04-30) +================== + +* Forbid inheritance, replace ``__init__`` with ``__new__`` (#171) + +* Support PEP-561 (provide type hinting marker) (#182) + +1.1.1 (2018-02-17) +================== + +* Fix performance regression: don't encode enmpty netloc (#170) + +1.1.0 (2018-01-21) +================== + +* Make pure Python quoter consistent with Cython version (#162) + +1.0.0 (2018-01-15) +================== + +* Use fast path if quoted string does not need requoting (#154) + +* Speed up quoting/unquoting by ``_Quoter`` and ``_Unquoter`` classes (#155) + +* Drop ``yarl.quote`` and ``yarl.unquote`` public functions (#155) + +* Add custom string writer, reuse static buffer if available (#157) + Code is 50-80 times faster than Pure Python version (was 4-5 times faster) + +* Don't recode IP zone (#144) + +* Support ``encoded=True`` in ``yarl.URL.build()`` (#158) + +* Fix updating query with multiple keys (#160) + +0.18.0 (2018-01-10) +=================== + +* Fallback to IDNA 2003 if domain name is not IDNA 2008 compatible (#152) + +0.17.0 (2017-12-30) +=================== + +* Use IDNA 2008 for domain name processing (#149) + +0.16.0 (2017-12-07) +=================== + +* Fix raising ``TypeError`` by ``url.query_string()`` after + ``url.with_query({})`` (empty mapping) (#141) + +0.15.0 (2017-11-23) +=================== + +* Add ``raw_path_qs`` attribute (#137) + +0.14.2 (2017-11-14) +=================== + +* Restore ``strict`` parameter as no-op in ``quote`` / ``unquote`` + +0.14.1 (2017-11-13) +=================== + +* Restore ``strict`` parameter as no-op for sake of compatibility with + aiohttp 2.2 + +0.14.0 (2017-11-11) +=================== + +* Drop strict mode (#123) + +* Fix ``"ValueError: Unallowed PCT %"`` when there's a ``"%"`` in the url (#124) + +0.13.0 (2017-10-01) +=================== + +* Document ``encoded`` parameter (#102) + +* Support relative urls like ``'?key=value'`` (#100) + +* Unsafe encoding for QS fixed. Encode ``;`` char in value param (#104) + +* Process passwords without user names (#95) + +0.12.0 (2017-06-26) +=================== + +* Properly support paths without leading slash in ``URL.with_path()`` (#90) + +* Enable type annotation checks + +0.11.0 (2017-06-26) +=================== + +* Normalize path (#86) + +* Clear query and fragment parts in ``.with_path()`` (#85) + +0.10.3 (2017-06-13) +=================== + +* Prevent double URL args unquoting (#83) + +0.10.2 (2017-05-05) +=================== + +* Unexpected hash behaviour (#75) + + +0.10.1 (2017-05-03) +=================== + +* Unexpected compare behaviour (#73) + +* Do not quote or unquote + if not a query string. (#74) + + +0.10.0 (2017-03-14) +=================== + +* Added ``URL.build`` class method (#58) + +* Added ``path_qs`` attribute (#42) + + +0.9.8 (2017-02-16) +================== + +* Do not quote ``:`` in path + + +0.9.7 (2017-02-16) +================== + +* Load from pickle without _cache (#56) + +* Percent-encoded pluses in path variables become spaces (#59) + + +0.9.6 (2017-02-15) +================== + +* Revert backward incompatible change (BaseURL) + + +0.9.5 (2017-02-14) +================== + +* Fix BaseURL rich comparison support + + +0.9.4 (2017-02-14) +================== + +* Use BaseURL + + +0.9.3 (2017-02-14) +================== + +* Added BaseURL + + +0.9.2 (2017-02-08) +================== + +* Remove debug print + + +0.9.1 (2017-02-07) +================== + +* Do not lose tail chars (#45) + + +0.9.0 (2017-02-07) +================== + +* Allow to quote ``%`` in non strict mode (#21) + +* Incorrect parsing of query parameters with %3B (;) inside (#34) + +* Fix core dumps (#41) + +* tmpbuf - compiling error (#43) + +* Added ``URL.update_path()`` method + +* Added ``URL.update_query()`` method (#47) + + +0.8.1 (2016-12-03) +================== + +* Fix broken aiohttp: revert back ``quote`` / ``unquote``. + + +0.8.0 (2016-12-03) +================== + +* Support more verbose error messages in ``.with_query()`` (#24) + +* Don't percent-encode ``@`` and ``:`` in path (#32) + +* Don't expose ``yarl.quote`` and ``yarl.unquote``, these functions are + part of private API + +0.7.1 (2016-11-18) +================== + +* Accept not only ``str`` but all classes inherited from ``str`` also (#25) + +0.7.0 (2016-11-07) +================== + +* Accept ``int`` as value for ``.with_query()`` + +0.6.0 (2016-11-07) +================== + +* Explicitly use UTF8 encoding in setup.py (#20) +* Properly unquote non-UTF8 strings (#19) + +0.5.3 (2016-11-02) +================== + +* Don't use namedtuple fields but indexes on URL construction + +0.5.2 (2016-11-02) +================== + +* Inline ``_encode`` class method + +0.5.1 (2016-11-02) +================== + +* Make URL construction faster by removing extra classmethod calls + +0.5.0 (2016-11-02) +================== + +* Add cython optimization for quoting/unquoting +* Provide binary wheels + +0.4.3 (2016-09-29) +================== + +* Fix typing stubs + +0.4.2 (2016-09-29) +================== + +* Expose ``quote()`` and ``unquote()`` as public API + +0.4.1 (2016-09-28) +================== + +* Support empty values in query (``'/path?arg'``) + +0.4.0 (2016-09-27) +================== + +* Introduce ``relative()`` (#16) + +0.3.2 (2016-09-27) +================== + +* Typo fixes #15 + +0.3.1 (2016-09-26) +================== + +* Support sequence of pairs as ``with_query()`` parameter + +0.3.0 (2016-09-26) +================== + +* Introduce ``is_default_port()`` + +0.2.1 (2016-09-26) +================== + +* Raise ValueError for URLs like 'http://:8080/' + +0.2.0 (2016-09-18) +================== + +* Avoid doubling slashes when joining paths (#13) + +* Appending path starting from slash is forbidden (#12) + +0.1.4 (2016-09-09) +================== + +* Add kwargs support for ``with_query()`` (#10) + +0.1.3 (2016-09-07) +================== + +* Document ``with_query()``, ``with_fragment()`` and ``origin()`` + +* Allow ``None`` for ``with_query()`` and ``with_fragment()`` + +0.1.2 (2016-09-07) +================== + +* Fix links, tune docs theme. + +0.1.1 (2016-09-06) +================== + +* Update README, old version used obsolete API + +0.1.0 (2016-09-06) +================== + +* The library was deeply refactored, bytes are gone away but all + accepted strings are encoded if needed. + +0.0.1 (2016-08-30) +================== + +* The first release. + + diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/RECORD b/venv/Lib/site-packages/yarl-1.5.1.dist-info/RECORD new file mode 100644 index 0000000..248085f --- /dev/null +++ b/venv/Lib/site-packages/yarl-1.5.1.dist-info/RECORD @@ -0,0 +1,21 @@ +yarl-1.5.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +yarl-1.5.1.dist-info/LICENSE,sha256=PH_Yufnp1q9DnAmWxKDWyTg4DAS8rYibeIgZQf4sQTI,11569 +yarl-1.5.1.dist-info/METADATA,sha256=scBHPxkUE2QIWHYUg_JqOu0TWQeH2Peh6L--uiNtZOE,16528 +yarl-1.5.1.dist-info/RECORD,, +yarl-1.5.1.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +yarl-1.5.1.dist-info/WHEEL,sha256=-ODc2a2AO_YJ5T46NOquHfWjRM7bQvlt-f3zRaLBjL4,105 +yarl-1.5.1.dist-info/top_level.txt,sha256=vf3SJuQh-k7YtvsUrV_OPOrT9Kqn0COlk7IPYyhtGkQ,5 +yarl/__init__.py,sha256=VX110GkzGNcQDSMLi70ItkogVE1LxeegjQ2RPoTJ-Fo,159 +yarl/__init__.pyi,sha256=EEFiNABHYl0e0kTv041qvNdX7zkQ9MsI7Zs1PRk6cww,3746 +yarl/__pycache__/__init__.cpython-38.pyc,, +yarl/__pycache__/_quoting.cpython-38.pyc,, +yarl/__pycache__/_quoting_py.cpython-38.pyc,, +yarl/__pycache__/_url.cpython-38.pyc,, +yarl/_quoting.py,sha256=JSWI4rNhpLOLNxs2w_i0b0IE1N1CJaWnOs3eg4wJ7RU,537 +yarl/_quoting_c.c,sha256=z7EUzcVRjMjnOeu-XRWLn-Ym6uRHpPk606zH-FV1wC0,476397 +yarl/_quoting_c.cp38-win_amd64.pyd,sha256=q1ixeev2CPIFt4y9gYaA4AL7qff-XTmW8jIXeOEpPjc,84480 +yarl/_quoting_c.pyi,sha256=8QHtEuD1IwrQKNfZU8VAykdBOF9TqF6DFc6jmPbM6mo,463 +yarl/_quoting_c.pyx,sha256=bz2UOaux2MgU1wn0swfQNk6duiRxEpSGXBX8JFZuCVo,12206 +yarl/_quoting_py.py,sha256=AtHQUIqm2k7u_plHZykMl37sjOltTskYMCvdKbbKjLs,6722 +yarl/_url.py,sha256=TOxpp_NH-Sz78Y37ALyOsvjQ_yM_4TTzSkcBTySBC70,35695 +yarl/py.typed,sha256=Ml3HXnuYFoaiowlyfo6IQ_Dmv9gGV8uhQbqwZDzsNE8,13 diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/REQUESTED b/venv/Lib/site-packages/yarl-1.5.1.dist-info/REQUESTED new file mode 100644 index 0000000..e69de29 diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/WHEEL b/venv/Lib/site-packages/yarl-1.5.1.dist-info/WHEEL new file mode 100644 index 0000000..069f5d9 --- /dev/null +++ b/venv/Lib/site-packages/yarl-1.5.1.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.34.2) +Root-Is-Purelib: false +Tag: cp38-cp38-win_amd64 + diff --git a/venv/Lib/site-packages/yarl-1.5.1.dist-info/top_level.txt b/venv/Lib/site-packages/yarl-1.5.1.dist-info/top_level.txt new file mode 100644 index 0000000..e93e8bd --- /dev/null +++ b/venv/Lib/site-packages/yarl-1.5.1.dist-info/top_level.txt @@ -0,0 +1 @@ +yarl diff --git a/venv/Lib/site-packages/yarl/__init__.py b/venv/Lib/site-packages/yarl/__init__.py new file mode 100644 index 0000000..c031c49 --- /dev/null +++ b/venv/Lib/site-packages/yarl/__init__.py @@ -0,0 +1,5 @@ +from ._url import URL, cache_clear, cache_configure, cache_info + +__version__ = "1.5.1" + +__all__ = ("URL", "cache_clear", "cache_configure", "cache_info") diff --git a/venv/Lib/site-packages/yarl/__init__.pyi b/venv/Lib/site-packages/yarl/__init__.pyi new file mode 100644 index 0000000..c4cd87d --- /dev/null +++ b/venv/Lib/site-packages/yarl/__init__.pyi @@ -0,0 +1,110 @@ +from typing import overload, Any, Tuple, Optional, Mapping, Union, Sequence, Type +import multidict +from functools import _CacheInfo +import sys + +if sys.version_info >= (3, 8): + from typing import TypedDict, Final, final +else: + from typing_extensions import TypedDict, Final, final + +_QueryVariable = Union[str, int] +_Query = Union[ + None, str, Mapping[str, _QueryVariable], Sequence[Tuple[str, _QueryVariable]] +] +@final +class URL: + scheme: Final[str] + raw_user: Final[str] + user: Final[Optional[str]] + raw_password: Final[Optional[str]] + password: Final[Optional[str]] + raw_host: Final[Optional[str]] + host: Final[Optional[str]] + port: Final[Optional[int]] + raw_authority: Final[str] + authority: Final[str] + raw_path: Final[str] + path: Final[str] + raw_query_string: Final[str] + query_string: Final[str] + path_qs: Final[str] + raw_path_qs: Final[str] + raw_fragment: Final[str] + fragment: Final[str] + query: Final[multidict.MultiDict[str]] + raw_name: Final[str] + name: Final[str] + raw_parts: Final[Tuple[str, ...]] + parts: Final[Tuple[str, ...]] + parent: Final[URL] + def __init__( + self, val: Union[str, "URL"] = ..., *, encoded: bool = ... + ) -> None: ... + @classmethod + def build( + cls, + *, + scheme: str = ..., + authority: str = ..., + user: Optional[str] = ..., + password: Optional[str] = ..., + host: str = ..., + port: Optional[int] = ..., + path: str = ..., + query: Optional[_Query] = ..., + query_string: str = ..., + fragment: str = ..., + encoded: bool = ... + ) -> URL: ... + def __str__(self) -> str: ... + def __repr__(self) -> str: ... + def __eq__(self, other: Any) -> bool: ... + def __le__(self, other: Any) -> bool: ... + def __lt__(self, other: Any) -> bool: ... + def __ge__(self, other: Any) -> bool: ... + def __gt__(self, other: Any) -> bool: ... + def __hash__(self) -> int: ... + def __truediv__(self, name: str) -> URL: ... + def __mod__(self, query: _Query) -> URL: ... + def is_absolute(self) -> bool: ... + def is_default_port(self) -> bool: ... + def origin(self) -> URL: ... + def relative(self) -> URL: ... + def with_scheme(self, scheme: str) -> URL: ... + def with_user(self, user: Optional[str]) -> URL: ... + def with_password(self, password: Optional[str]) -> URL: ... + def with_host(self, host: str) -> URL: ... + def with_port(self, port: Optional[int]) -> URL: ... + def with_path(self, path: str, *, encoded: bool = ...) -> URL: ... + @overload + def with_query(self, query: _Query) -> URL: ... + @overload + def with_query(self, **kwargs: _QueryVariable) -> URL: ... + @overload + def update_query(self, query: _Query) -> URL: ... + @overload + def update_query(self, **kwargs: _QueryVariable) -> URL: ... + def with_fragment(self, fragment: Optional[str]) -> URL: ... + def with_name(self, name: str) -> URL: ... + def join(self, url: URL) -> URL: ... + def human_repr(self) -> str: ... + # private API + @classmethod + def _normalize_path(cls, path: str) -> str: ... + +@final +class cached_property: + def __init__(self, wrapped: Any) -> None: ... + def __get__(self, inst: URL, owner: Type[URL]) -> Any: ... + def __set__(self, inst: URL, value: Any) -> None: ... + +class CacheInfo(TypedDict): + idna_encode: _CacheInfo + idna_decode: _CacheInfo + +def cache_clear() -> None: ... +def cache_info() -> CacheInfo: ... +def cache_configure( + *, idna_encode_size: Optional[int] = ..., idna_decode_size: Optional[int] = ... +) -> None: ... diff --git a/venv/Lib/site-packages/yarl/_quoting.py b/venv/Lib/site-packages/yarl/_quoting.py new file mode 100644 index 0000000..4f8d392 --- /dev/null +++ b/venv/Lib/site-packages/yarl/_quoting.py @@ -0,0 +1,18 @@ +import os +import sys + +__all__ = ("_Quoter", "_Unquoter") + + +NO_EXTENSIONS = bool(os.environ.get("YARL_NO_EXTENSIONS")) # type: bool +if sys.implementation.name != "cpython": + NO_EXTENSIONS = True + + +if not NO_EXTENSIONS: # pragma: no branch + try: + from ._quoting_c import _Quoter, _Unquoter # type: ignore[misc] + except ImportError: # pragma: no cover + from ._quoting_py import _Quoter, _Unquoter # type: ignore[misc] +else: + from ._quoting_py import _Quoter, _Unquoter # type: ignore[misc] diff --git a/venv/Lib/site-packages/yarl/_quoting_c.c b/venv/Lib/site-packages/yarl/_quoting_c.c new file mode 100644 index 0000000..b12143c --- /dev/null +++ b/venv/Lib/site-packages/yarl/_quoting_c.c @@ -0,0 +1,12380 @@ +/* Generated by Cython 0.29.21 */ + +#define PY_SSIZE_T_CLEAN +#include "Python.h" +#ifndef Py_PYTHON_H + #error Python headers needed to compile C extensions, please install development version of Python. +#elif PY_VERSION_HEX < 0x02060000 || (0x03000000 <= PY_VERSION_HEX && PY_VERSION_HEX < 0x03030000) + #error Cython requires Python 2.6+ or Python 3.3+. +#else +#define CYTHON_ABI "0_29_21" +#define CYTHON_HEX_VERSION 0x001D15F0 +#define CYTHON_FUTURE_DIVISION 1 +#include <stddef.h> +#ifndef offsetof + #define offsetof(type, member) ( (size_t) & ((type*)0) -> member ) +#endif +#if !defined(WIN32) && !defined(MS_WINDOWS) + #ifndef __stdcall + #define __stdcall + #endif + #ifndef __cdecl + #define __cdecl + #endif + #ifndef __fastcall + #define __fastcall + #endif +#endif +#ifndef DL_IMPORT + #define DL_IMPORT(t) t +#endif +#ifndef DL_EXPORT + #define DL_EXPORT(t) t +#endif +#define __PYX_COMMA , +#ifndef HAVE_LONG_LONG + #if PY_VERSION_HEX >= 0x02070000 + #define HAVE_LONG_LONG + #endif +#endif +#ifndef PY_LONG_LONG + #define PY_LONG_LONG LONG_LONG +#endif +#ifndef Py_HUGE_VAL + #define Py_HUGE_VAL HUGE_VAL +#endif +#ifdef PYPY_VERSION + #define CYTHON_COMPILING_IN_PYPY 1 + #define CYTHON_COMPILING_IN_PYSTON 0 + #define CYTHON_COMPILING_IN_CPYTHON 0 + #undef CYTHON_USE_TYPE_SLOTS + #define CYTHON_USE_TYPE_SLOTS 0 + #undef CYTHON_USE_PYTYPE_LOOKUP + #define CYTHON_USE_PYTYPE_LOOKUP 0 + #if PY_VERSION_HEX < 0x03050000 + #undef CYTHON_USE_ASYNC_SLOTS + #define CYTHON_USE_ASYNC_SLOTS 0 + #elif !defined(CYTHON_USE_ASYNC_SLOTS) + #define CYTHON_USE_ASYNC_SLOTS 1 + #endif + #undef CYTHON_USE_PYLIST_INTERNALS + #define CYTHON_USE_PYLIST_INTERNALS 0 + #undef CYTHON_USE_UNICODE_INTERNALS + #define CYTHON_USE_UNICODE_INTERNALS 0 + #undef CYTHON_USE_UNICODE_WRITER + #define CYTHON_USE_UNICODE_WRITER 0 + #undef CYTHON_USE_PYLONG_INTERNALS + #define CYTHON_USE_PYLONG_INTERNALS 0 + #undef CYTHON_AVOID_BORROWED_REFS + #define CYTHON_AVOID_BORROWED_REFS 1 + #undef CYTHON_ASSUME_SAFE_MACROS + #define CYTHON_ASSUME_SAFE_MACROS 0 + #undef CYTHON_UNPACK_METHODS + #define CYTHON_UNPACK_METHODS 0 + #undef CYTHON_FAST_THREAD_STATE + #define CYTHON_FAST_THREAD_STATE 0 + #undef CYTHON_FAST_PYCALL + #define CYTHON_FAST_PYCALL 0 + #undef CYTHON_PEP489_MULTI_PHASE_INIT + #define CYTHON_PEP489_MULTI_PHASE_INIT 0 + #undef CYTHON_USE_TP_FINALIZE + #define CYTHON_USE_TP_FINALIZE 0 + #undef CYTHON_USE_DICT_VERSIONS + #define CYTHON_USE_DICT_VERSIONS 0 + #undef CYTHON_USE_EXC_INFO_STACK + #define CYTHON_USE_EXC_INFO_STACK 0 +#elif defined(PYSTON_VERSION) + #define CYTHON_COMPILING_IN_PYPY 0 + #define CYTHON_COMPILING_IN_PYSTON 1 + #define CYTHON_COMPILING_IN_CPYTHON 0 + #ifndef CYTHON_USE_TYPE_SLOTS + #define CYTHON_USE_TYPE_SLOTS 1 + #endif + #undef CYTHON_USE_PYTYPE_LOOKUP + #define CYTHON_USE_PYTYPE_LOOKUP 0 + #undef CYTHON_USE_ASYNC_SLOTS + #define CYTHON_USE_ASYNC_SLOTS 0 + #undef CYTHON_USE_PYLIST_INTERNALS + #define CYTHON_USE_PYLIST_INTERNALS 0 + #ifndef CYTHON_USE_UNICODE_INTERNALS + #define CYTHON_USE_UNICODE_INTERNALS 1 + #endif + #undef CYTHON_USE_UNICODE_WRITER + #define CYTHON_USE_UNICODE_WRITER 0 + #undef CYTHON_USE_PYLONG_INTERNALS + #define CYTHON_USE_PYLONG_INTERNALS 0 + #ifndef CYTHON_AVOID_BORROWED_REFS + #define CYTHON_AVOID_BORROWED_REFS 0 + #endif + #ifndef CYTHON_ASSUME_SAFE_MACROS + #define CYTHON_ASSUME_SAFE_MACROS 1 + #endif + #ifndef CYTHON_UNPACK_METHODS + #define CYTHON_UNPACK_METHODS 1 + #endif + #undef CYTHON_FAST_THREAD_STATE + #define CYTHON_FAST_THREAD_STATE 0 + #undef CYTHON_FAST_PYCALL + #define CYTHON_FAST_PYCALL 0 + #undef CYTHON_PEP489_MULTI_PHASE_INIT + #define CYTHON_PEP489_MULTI_PHASE_INIT 0 + #undef CYTHON_USE_TP_FINALIZE + #define CYTHON_USE_TP_FINALIZE 0 + #undef CYTHON_USE_DICT_VERSIONS + #define CYTHON_USE_DICT_VERSIONS 0 + #undef CYTHON_USE_EXC_INFO_STACK + #define CYTHON_USE_EXC_INFO_STACK 0 +#else + #define CYTHON_COMPILING_IN_PYPY 0 + #define CYTHON_COMPILING_IN_PYSTON 0 + #define CYTHON_COMPILING_IN_CPYTHON 1 + #ifndef CYTHON_USE_TYPE_SLOTS + #define CYTHON_USE_TYPE_SLOTS 1 + #endif + #if PY_VERSION_HEX < 0x02070000 + #undef CYTHON_USE_PYTYPE_LOOKUP + #define CYTHON_USE_PYTYPE_LOOKUP 0 + #elif !defined(CYTHON_USE_PYTYPE_LOOKUP) + #define CYTHON_USE_PYTYPE_LOOKUP 1 + #endif + #if PY_MAJOR_VERSION < 3 + #undef CYTHON_USE_ASYNC_SLOTS + #define CYTHON_USE_ASYNC_SLOTS 0 + #elif !defined(CYTHON_USE_ASYNC_SLOTS) + #define CYTHON_USE_ASYNC_SLOTS 1 + #endif + #if PY_VERSION_HEX < 0x02070000 + #undef CYTHON_USE_PYLONG_INTERNALS + #define CYTHON_USE_PYLONG_INTERNALS 0 + #elif !defined(CYTHON_USE_PYLONG_INTERNALS) + #define CYTHON_USE_PYLONG_INTERNALS 1 + #endif + #ifndef CYTHON_USE_PYLIST_INTERNALS + #define CYTHON_USE_PYLIST_INTERNALS 1 + #endif + #ifndef CYTHON_USE_UNICODE_INTERNALS + #define CYTHON_USE_UNICODE_INTERNALS 1 + #endif + #if PY_VERSION_HEX < 0x030300F0 + #undef CYTHON_USE_UNICODE_WRITER + #define CYTHON_USE_UNICODE_WRITER 0 + #elif !defined(CYTHON_USE_UNICODE_WRITER) + #define CYTHON_USE_UNICODE_WRITER 1 + #endif + #ifndef CYTHON_AVOID_BORROWED_REFS + #define CYTHON_AVOID_BORROWED_REFS 0 + #endif + #ifndef CYTHON_ASSUME_SAFE_MACROS + #define CYTHON_ASSUME_SAFE_MACROS 1 + #endif + #ifndef CYTHON_UNPACK_METHODS + #define CYTHON_UNPACK_METHODS 1 + #endif + #ifndef CYTHON_FAST_THREAD_STATE + #define CYTHON_FAST_THREAD_STATE 1 + #endif + #ifndef CYTHON_FAST_PYCALL + #define CYTHON_FAST_PYCALL 1 + #endif + #ifndef CYTHON_PEP489_MULTI_PHASE_INIT + #define CYTHON_PEP489_MULTI_PHASE_INIT (PY_VERSION_HEX >= 0x03050000) + #endif + #ifndef CYTHON_USE_TP_FINALIZE + #define CYTHON_USE_TP_FINALIZE (PY_VERSION_HEX >= 0x030400a1) + #endif + #ifndef CYTHON_USE_DICT_VERSIONS + #define CYTHON_USE_DICT_VERSIONS (PY_VERSION_HEX >= 0x030600B1) + #endif + #ifndef CYTHON_USE_EXC_INFO_STACK + #define CYTHON_USE_EXC_INFO_STACK (PY_VERSION_HEX >= 0x030700A3) + #endif +#endif +#if !defined(CYTHON_FAST_PYCCALL) +#define CYTHON_FAST_PYCCALL (CYTHON_FAST_PYCALL && PY_VERSION_HEX >= 0x030600B1) +#endif +#if CYTHON_USE_PYLONG_INTERNALS + #include "longintrepr.h" + #undef SHIFT + #undef BASE + #undef MASK + #ifdef SIZEOF_VOID_P + enum { __pyx_check_sizeof_voidp = 1 / (int)(SIZEOF_VOID_P == sizeof(void*)) }; + #endif +#endif +#ifndef __has_attribute + #define __has_attribute(x) 0 +#endif +#ifndef __has_cpp_attribute + #define __has_cpp_attribute(x) 0 +#endif +#ifndef CYTHON_RESTRICT + #if defined(__GNUC__) + #define CYTHON_RESTRICT __restrict__ + #elif defined(_MSC_VER) && _MSC_VER >= 1400 + #define CYTHON_RESTRICT __restrict + #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L + #define CYTHON_RESTRICT restrict + #else + #define CYTHON_RESTRICT + #endif +#endif +#ifndef CYTHON_UNUSED +# if defined(__GNUC__) +# if !(defined(__cplusplus)) || (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)) +# define CYTHON_UNUSED __attribute__ ((__unused__)) +# else +# define CYTHON_UNUSED +# endif +# elif defined(__ICC) || (defined(__INTEL_COMPILER) && !defined(_MSC_VER)) +# define CYTHON_UNUSED __attribute__ ((__unused__)) +# else +# define CYTHON_UNUSED +# endif +#endif +#ifndef CYTHON_MAYBE_UNUSED_VAR +# if defined(__cplusplus) + template<class T> void CYTHON_MAYBE_UNUSED_VAR( const T& ) { } +# else +# define CYTHON_MAYBE_UNUSED_VAR(x) (void)(x) +# endif +#endif +#ifndef CYTHON_NCP_UNUSED +# if CYTHON_COMPILING_IN_CPYTHON +# define CYTHON_NCP_UNUSED +# else +# define CYTHON_NCP_UNUSED CYTHON_UNUSED +# endif +#endif +#define __Pyx_void_to_None(void_result) ((void)(void_result), Py_INCREF(Py_None), Py_None) +#ifdef _MSC_VER + #ifndef _MSC_STDINT_H_ + #if _MSC_VER < 1300 + typedef unsigned char uint8_t; + typedef unsigned int uint32_t; + #else + typedef unsigned __int8 uint8_t; + typedef unsigned __int32 uint32_t; + #endif + #endif +#else + #include <stdint.h> +#endif +#ifndef CYTHON_FALLTHROUGH + #if defined(__cplusplus) && __cplusplus >= 201103L + #if __has_cpp_attribute(fallthrough) + #define CYTHON_FALLTHROUGH [[fallthrough]] + #elif __has_cpp_attribute(clang::fallthrough) + #define CYTHON_FALLTHROUGH [[clang::fallthrough]] + #elif __has_cpp_attribute(gnu::fallthrough) + #define CYTHON_FALLTHROUGH [[gnu::fallthrough]] + #endif + #endif + #ifndef CYTHON_FALLTHROUGH + #if __has_attribute(fallthrough) + #define CYTHON_FALLTHROUGH __attribute__((fallthrough)) + #else + #define CYTHON_FALLTHROUGH + #endif + #endif + #if defined(__clang__ ) && defined(__apple_build_version__) + #if __apple_build_version__ < 7000000 + #undef CYTHON_FALLTHROUGH + #define CYTHON_FALLTHROUGH + #endif + #endif +#endif + +#ifndef CYTHON_INLINE + #if defined(__clang__) + #define CYTHON_INLINE __inline__ __attribute__ ((__unused__)) + #elif defined(__GNUC__) + #define CYTHON_INLINE __inline__ + #elif defined(_MSC_VER) + #define CYTHON_INLINE __inline + #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L + #define CYTHON_INLINE inline + #else + #define CYTHON_INLINE + #endif +#endif + +#if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX < 0x02070600 && !defined(Py_OptimizeFlag) + #define Py_OptimizeFlag 0 +#endif +#define __PYX_BUILD_PY_SSIZE_T "n" +#define CYTHON_FORMAT_SSIZE_T "z" +#if PY_MAJOR_VERSION < 3 + #define __Pyx_BUILTIN_MODULE_NAME "__builtin__" + #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\ + PyCode_New(a+k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) + #define __Pyx_DefaultClassType PyClass_Type +#else + #define __Pyx_BUILTIN_MODULE_NAME "builtins" +#if PY_VERSION_HEX >= 0x030800A4 && PY_VERSION_HEX < 0x030800B2 + #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\ + PyCode_New(a, 0, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) +#else + #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\ + PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) +#endif + #define __Pyx_DefaultClassType PyType_Type +#endif +#ifndef Py_TPFLAGS_CHECKTYPES + #define Py_TPFLAGS_CHECKTYPES 0 +#endif +#ifndef Py_TPFLAGS_HAVE_INDEX + #define Py_TPFLAGS_HAVE_INDEX 0 +#endif +#ifndef Py_TPFLAGS_HAVE_NEWBUFFER + #define Py_TPFLAGS_HAVE_NEWBUFFER 0 +#endif +#ifndef Py_TPFLAGS_HAVE_FINALIZE + #define Py_TPFLAGS_HAVE_FINALIZE 0 +#endif +#ifndef METH_STACKLESS + #define METH_STACKLESS 0 +#endif +#if PY_VERSION_HEX <= 0x030700A3 || !defined(METH_FASTCALL) + #ifndef METH_FASTCALL + #define METH_FASTCALL 0x80 + #endif + typedef PyObject *(*__Pyx_PyCFunctionFast) (PyObject *self, PyObject *const *args, Py_ssize_t nargs); + typedef PyObject *(*__Pyx_PyCFunctionFastWithKeywords) (PyObject *self, PyObject *const *args, + Py_ssize_t nargs, PyObject *kwnames); +#else + #define __Pyx_PyCFunctionFast _PyCFunctionFast + #define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords +#endif +#if CYTHON_FAST_PYCCALL +#define __Pyx_PyFastCFunction_Check(func)\ + ((PyCFunction_Check(func) && (METH_FASTCALL == (PyCFunction_GET_FLAGS(func) & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_KEYWORDS | METH_STACKLESS))))) +#else +#define __Pyx_PyFastCFunction_Check(func) 0 +#endif +#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Malloc) + #define PyObject_Malloc(s) PyMem_Malloc(s) + #define PyObject_Free(p) PyMem_Free(p) + #define PyObject_Realloc(p) PyMem_Realloc(p) +#endif +#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030400A1 + #define PyMem_RawMalloc(n) PyMem_Malloc(n) + #define PyMem_RawRealloc(p, n) PyMem_Realloc(p, n) + #define PyMem_RawFree(p) PyMem_Free(p) +#endif +#if CYTHON_COMPILING_IN_PYSTON + #define __Pyx_PyCode_HasFreeVars(co) PyCode_HasFreeVars(co) + #define __Pyx_PyFrame_SetLineNumber(frame, lineno) PyFrame_SetLineNumber(frame, lineno) +#else + #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) + #define __Pyx_PyFrame_SetLineNumber(frame, lineno) (frame)->f_lineno = (lineno) +#endif +#if !CYTHON_FAST_THREAD_STATE || PY_VERSION_HEX < 0x02070000 + #define __Pyx_PyThreadState_Current PyThreadState_GET() +#elif PY_VERSION_HEX >= 0x03060000 + #define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet() +#elif PY_VERSION_HEX >= 0x03000000 + #define __Pyx_PyThreadState_Current PyThreadState_GET() +#else + #define __Pyx_PyThreadState_Current _PyThreadState_Current +#endif +#if PY_VERSION_HEX < 0x030700A2 && !defined(PyThread_tss_create) && !defined(Py_tss_NEEDS_INIT) +#include "pythread.h" +#define Py_tss_NEEDS_INIT 0 +typedef int Py_tss_t; +static CYTHON_INLINE int PyThread_tss_create(Py_tss_t *key) { + *key = PyThread_create_key(); + return 0; +} +static CYTHON_INLINE Py_tss_t * PyThread_tss_alloc(void) { + Py_tss_t *key = (Py_tss_t *)PyObject_Malloc(sizeof(Py_tss_t)); + *key = Py_tss_NEEDS_INIT; + return key; +} +static CYTHON_INLINE void PyThread_tss_free(Py_tss_t *key) { + PyObject_Free(key); +} +static CYTHON_INLINE int PyThread_tss_is_created(Py_tss_t *key) { + return *key != Py_tss_NEEDS_INIT; +} +static CYTHON_INLINE void PyThread_tss_delete(Py_tss_t *key) { + PyThread_delete_key(*key); + *key = Py_tss_NEEDS_INIT; +} +static CYTHON_INLINE int PyThread_tss_set(Py_tss_t *key, void *value) { + return PyThread_set_key_value(*key, value); +} +static CYTHON_INLINE void * PyThread_tss_get(Py_tss_t *key) { + return PyThread_get_key_value(*key); +} +#endif +#if CYTHON_COMPILING_IN_CPYTHON || defined(_PyDict_NewPresized) +#define __Pyx_PyDict_NewPresized(n) ((n <= 8) ? PyDict_New() : _PyDict_NewPresized(n)) +#else +#define __Pyx_PyDict_NewPresized(n) PyDict_New() +#endif +#if PY_MAJOR_VERSION >= 3 || CYTHON_FUTURE_DIVISION + #define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y) + #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y) +#else + #define __Pyx_PyNumber_Divide(x,y) PyNumber_Divide(x,y) + #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceDivide(x,y) +#endif +#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030500A1 && CYTHON_USE_UNICODE_INTERNALS +#define __Pyx_PyDict_GetItemStr(dict, name) _PyDict_GetItem_KnownHash(dict, name, ((PyASCIIObject *) name)->hash) +#else +#define __Pyx_PyDict_GetItemStr(dict, name) PyDict_GetItem(dict, name) +#endif +#if PY_VERSION_HEX > 0x03030000 && defined(PyUnicode_KIND) + #define CYTHON_PEP393_ENABLED 1 + #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ?\ + 0 : _PyUnicode_Ready((PyObject *)(op))) + #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_LENGTH(u) + #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i) + #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) PyUnicode_MAX_CHAR_VALUE(u) + #define __Pyx_PyUnicode_KIND(u) PyUnicode_KIND(u) + #define __Pyx_PyUnicode_DATA(u) PyUnicode_DATA(u) + #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i) + #define __Pyx_PyUnicode_WRITE(k, d, i, ch) PyUnicode_WRITE(k, d, i, ch) + #if defined(PyUnicode_IS_READY) && defined(PyUnicode_GET_SIZE) + #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u))) + #else + #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_LENGTH(u)) + #endif +#else + #define CYTHON_PEP393_ENABLED 0 + #define PyUnicode_1BYTE_KIND 1 + #define PyUnicode_2BYTE_KIND 2 + #define PyUnicode_4BYTE_KIND 4 + #define __Pyx_PyUnicode_READY(op) (0) + #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_SIZE(u) + #define __Pyx_PyUnicode_READ_CHAR(u, i) ((Py_UCS4)(PyUnicode_AS_UNICODE(u)[i])) + #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) ((sizeof(Py_UNICODE) == 2) ? 65535 : 1114111) + #define __Pyx_PyUnicode_KIND(u) (sizeof(Py_UNICODE)) + #define __Pyx_PyUnicode_DATA(u) ((void*)PyUnicode_AS_UNICODE(u)) + #define __Pyx_PyUnicode_READ(k, d, i) ((void)(k), (Py_UCS4)(((Py_UNICODE*)d)[i])) + #define __Pyx_PyUnicode_WRITE(k, d, i, ch) (((void)(k)), ((Py_UNICODE*)d)[i] = ch) + #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_SIZE(u)) +#endif +#if CYTHON_COMPILING_IN_PYPY + #define __Pyx_PyUnicode_Concat(a, b) PyNumber_Add(a, b) + #define __Pyx_PyUnicode_ConcatSafe(a, b) PyNumber_Add(a, b) +#else + #define __Pyx_PyUnicode_Concat(a, b) PyUnicode_Concat(a, b) + #define __Pyx_PyUnicode_ConcatSafe(a, b) ((unlikely((a) == Py_None) || unlikely((b) == Py_None)) ?\ + PyNumber_Add(a, b) : __Pyx_PyUnicode_Concat(a, b)) +#endif +#if CYTHON_COMPILING_IN_PYPY && !defined(PyUnicode_Contains) + #define PyUnicode_Contains(u, s) PySequence_Contains(u, s) +#endif +#if CYTHON_COMPILING_IN_PYPY && !defined(PyByteArray_Check) + #define PyByteArray_Check(obj) PyObject_TypeCheck(obj, &PyByteArray_Type) +#endif +#if CYTHON_COMPILING_IN_PYPY && !defined(PyObject_Format) + #define PyObject_Format(obj, fmt) PyObject_CallMethod(obj, "__format__", "O", fmt) +#endif +#define __Pyx_PyString_FormatSafe(a, b) ((unlikely((a) == Py_None || (PyString_Check(b) && !PyString_CheckExact(b)))) ? PyNumber_Remainder(a, b) : __Pyx_PyString_Format(a, b)) +#define __Pyx_PyUnicode_FormatSafe(a, b) ((unlikely((a) == Py_None || (PyUnicode_Check(b) && !PyUnicode_CheckExact(b)))) ? PyNumber_Remainder(a, b) : PyUnicode_Format(a, b)) +#if PY_MAJOR_VERSION >= 3 + #define __Pyx_PyString_Format(a, b) PyUnicode_Format(a, b) +#else + #define __Pyx_PyString_Format(a, b) PyString_Format(a, b) +#endif +#if PY_MAJOR_VERSION < 3 && !defined(PyObject_ASCII) + #define PyObject_ASCII(o) PyObject_Repr(o) +#endif +#if PY_MAJOR_VERSION >= 3 + #define PyBaseString_Type PyUnicode_Type + #define PyStringObject PyUnicodeObject + #define PyString_Type PyUnicode_Type + #define PyString_Check PyUnicode_Check + #define PyString_CheckExact PyUnicode_CheckExact +#ifndef PyObject_Unicode + #define PyObject_Unicode PyObject_Str +#endif +#endif +#if PY_MAJOR_VERSION >= 3 + #define __Pyx_PyBaseString_Check(obj) PyUnicode_Check(obj) + #define __Pyx_PyBaseString_CheckExact(obj) PyUnicode_CheckExact(obj) +#else + #define __Pyx_PyBaseString_Check(obj) (PyString_Check(obj) || PyUnicode_Check(obj)) + #define __Pyx_PyBaseString_CheckExact(obj) (PyString_CheckExact(obj) || PyUnicode_CheckExact(obj)) +#endif +#ifndef PySet_CheckExact + #define PySet_CheckExact(obj) (Py_TYPE(obj) == &PySet_Type) +#endif +#if PY_VERSION_HEX >= 0x030900A4 + #define __Pyx_SET_REFCNT(obj, refcnt) Py_SET_REFCNT(obj, refcnt) + #define __Pyx_SET_SIZE(obj, size) Py_SET_SIZE(obj, size) +#else + #define __Pyx_SET_REFCNT(obj, refcnt) Py_REFCNT(obj) = (refcnt) + #define __Pyx_SET_SIZE(obj, size) Py_SIZE(obj) = (size) +#endif +#if CYTHON_ASSUME_SAFE_MACROS + #define __Pyx_PySequence_SIZE(seq) Py_SIZE(seq) +#else + #define __Pyx_PySequence_SIZE(seq) PySequence_Size(seq) +#endif +#if PY_MAJOR_VERSION >= 3 + #define PyIntObject PyLongObject + #define PyInt_Type PyLong_Type + #define PyInt_Check(op) PyLong_Check(op) + #define PyInt_CheckExact(op) PyLong_CheckExact(op) + #define PyInt_FromString PyLong_FromString + #define PyInt_FromUnicode PyLong_FromUnicode + #define PyInt_FromLong PyLong_FromLong + #define PyInt_FromSize_t PyLong_FromSize_t + #define PyInt_FromSsize_t PyLong_FromSsize_t + #define PyInt_AsLong PyLong_AsLong + #define PyInt_AS_LONG PyLong_AS_LONG + #define PyInt_AsSsize_t PyLong_AsSsize_t + #define PyInt_AsUnsignedLongMask PyLong_AsUnsignedLongMask + #define PyInt_AsUnsignedLongLongMask PyLong_AsUnsignedLongLongMask + #define PyNumber_Int PyNumber_Long +#endif +#if PY_MAJOR_VERSION >= 3 + #define PyBoolObject PyLongObject +#endif +#if PY_MAJOR_VERSION >= 3 && CYTHON_COMPILING_IN_PYPY + #ifndef PyUnicode_InternFromString + #define PyUnicode_InternFromString(s) PyUnicode_FromString(s) + #endif +#endif +#if PY_VERSION_HEX < 0x030200A4 + typedef long Py_hash_t; + #define __Pyx_PyInt_FromHash_t PyInt_FromLong + #define __Pyx_PyInt_AsHash_t PyInt_AsLong +#else + #define __Pyx_PyInt_FromHash_t PyInt_FromSsize_t + #define __Pyx_PyInt_AsHash_t PyInt_AsSsize_t +#endif +#if PY_MAJOR_VERSION >= 3 + #define __Pyx_PyMethod_New(func, self, klass) ((self) ? ((void)(klass), PyMethod_New(func, self)) : __Pyx_NewRef(func)) +#else + #define __Pyx_PyMethod_New(func, self, klass) PyMethod_New(func, self, klass) +#endif +#if CYTHON_USE_ASYNC_SLOTS + #if PY_VERSION_HEX >= 0x030500B1 + #define __Pyx_PyAsyncMethodsStruct PyAsyncMethods + #define __Pyx_PyType_AsAsync(obj) (Py_TYPE(obj)->tp_as_async) + #else + #define __Pyx_PyType_AsAsync(obj) ((__Pyx_PyAsyncMethodsStruct*) (Py_TYPE(obj)->tp_reserved)) + #endif +#else + #define __Pyx_PyType_AsAsync(obj) NULL +#endif +#ifndef __Pyx_PyAsyncMethodsStruct + typedef struct { + unaryfunc am_await; + unaryfunc am_aiter; + unaryfunc am_anext; + } __Pyx_PyAsyncMethodsStruct; +#endif + +#if defined(WIN32) || defined(MS_WINDOWS) + #define _USE_MATH_DEFINES +#endif +#include <math.h> +#ifdef NAN +#define __PYX_NAN() ((float) NAN) +#else +static CYTHON_INLINE float __PYX_NAN() { + float value; + memset(&value, 0xFF, sizeof(value)); + return value; +} +#endif +#if defined(__CYGWIN__) && defined(_LDBL_EQ_DBL) +#define __Pyx_truncl trunc +#else +#define __Pyx_truncl truncl +#endif + +#define __PYX_MARK_ERR_POS(f_index, lineno) \ + { __pyx_filename = __pyx_f[f_index]; (void)__pyx_filename; __pyx_lineno = lineno; (void)__pyx_lineno; __pyx_clineno = __LINE__; (void)__pyx_clineno; } +#define __PYX_ERR(f_index, lineno, Ln_error) \ + { __PYX_MARK_ERR_POS(f_index, lineno) goto Ln_error; } + +#ifndef __PYX_EXTERN_C + #ifdef __cplusplus + #define __PYX_EXTERN_C extern "C" + #else + #define __PYX_EXTERN_C extern + #endif +#endif + +#define __PYX_HAVE__yarl___quoting_c +#define __PYX_HAVE_API__yarl___quoting_c +/* Early includes */ +#include <stdint.h> +#include <string.h> +#include <stdio.h> +#ifdef _OPENMP +#include <omp.h> +#endif /* _OPENMP */ + +#if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS) +#define CYTHON_WITHOUT_ASSERTIONS +#endif + +typedef struct {PyObject **p; const char *s; const Py_ssize_t n; const char* encoding; + const char is_unicode; const char is_str; const char intern; } __Pyx_StringTabEntry; + +#define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0 +#define __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 0 +#define __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT (PY_MAJOR_VERSION >= 3 && __PYX_DEFAULT_STRING_ENCODING_IS_UTF8) +#define __PYX_DEFAULT_STRING_ENCODING "" +#define __Pyx_PyObject_FromString __Pyx_PyBytes_FromString +#define __Pyx_PyObject_FromStringAndSize __Pyx_PyBytes_FromStringAndSize +#define __Pyx_uchar_cast(c) ((unsigned char)c) +#define __Pyx_long_cast(x) ((long)x) +#define __Pyx_fits_Py_ssize_t(v, type, is_signed) (\ + (sizeof(type) < sizeof(Py_ssize_t)) ||\ + (sizeof(type) > sizeof(Py_ssize_t) &&\ + likely(v < (type)PY_SSIZE_T_MAX ||\ + v == (type)PY_SSIZE_T_MAX) &&\ + (!is_signed || likely(v > (type)PY_SSIZE_T_MIN ||\ + v == (type)PY_SSIZE_T_MIN))) ||\ + (sizeof(type) == sizeof(Py_ssize_t) &&\ + (is_signed || likely(v < (type)PY_SSIZE_T_MAX ||\ + v == (type)PY_SSIZE_T_MAX))) ) +static CYTHON_INLINE int __Pyx_is_valid_index(Py_ssize_t i, Py_ssize_t limit) { + return (size_t) i < (size_t) limit; +} +#if defined (__cplusplus) && __cplusplus >= 201103L + #include <cstdlib> + #define __Pyx_sst_abs(value) std::abs(value) +#elif SIZEOF_INT >= SIZEOF_SIZE_T + #define __Pyx_sst_abs(value) abs(value) +#elif SIZEOF_LONG >= SIZEOF_SIZE_T + #define __Pyx_sst_abs(value) labs(value) +#elif defined (_MSC_VER) + #define __Pyx_sst_abs(value) ((Py_ssize_t)_abs64(value)) +#elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L + #define __Pyx_sst_abs(value) llabs(value) +#elif defined (__GNUC__) + #define __Pyx_sst_abs(value) __builtin_llabs(value) +#else + #define __Pyx_sst_abs(value) ((value<0) ? -value : value) +#endif +static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject*); +static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length); +#define __Pyx_PyByteArray_FromString(s) PyByteArray_FromStringAndSize((const char*)s, strlen((const char*)s)) +#define __Pyx_PyByteArray_FromStringAndSize(s, l) PyByteArray_FromStringAndSize((const char*)s, l) +#define __Pyx_PyBytes_FromString PyBytes_FromString +#define __Pyx_PyBytes_FromStringAndSize PyBytes_FromStringAndSize +static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char*); +#if PY_MAJOR_VERSION < 3 + #define __Pyx_PyStr_FromString __Pyx_PyBytes_FromString + #define __Pyx_PyStr_FromStringAndSize __Pyx_PyBytes_FromStringAndSize +#else + #define __Pyx_PyStr_FromString __Pyx_PyUnicode_FromString + #define __Pyx_PyStr_FromStringAndSize __Pyx_PyUnicode_FromStringAndSize +#endif +#define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AS_STRING(s)) +#define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AS_STRING(s)) +#define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AS_STRING(s)) +#define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AS_STRING(s)) +#define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AS_STRING(s)) +#define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AS_STRING(s)) +#define __Pyx_PyObject_AsWritableString(s) ((char*) __Pyx_PyObject_AsString(s)) +#define __Pyx_PyObject_AsWritableSString(s) ((signed char*) __Pyx_PyObject_AsString(s)) +#define __Pyx_PyObject_AsWritableUString(s) ((unsigned char*) __Pyx_PyObject_AsString(s)) +#define __Pyx_PyObject_AsSString(s) ((const signed char*) __Pyx_PyObject_AsString(s)) +#define __Pyx_PyObject_AsUString(s) ((const unsigned char*) __Pyx_PyObject_AsString(s)) +#define __Pyx_PyObject_FromCString(s) __Pyx_PyObject_FromString((const char*)s) +#define __Pyx_PyBytes_FromCString(s) __Pyx_PyBytes_FromString((const char*)s) +#define __Pyx_PyByteArray_FromCString(s) __Pyx_PyByteArray_FromString((const char*)s) +#define __Pyx_PyStr_FromCString(s) __Pyx_PyStr_FromString((const char*)s) +#define __Pyx_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s) +static CYTHON_INLINE size_t __Pyx_Py_UNICODE_strlen(const Py_UNICODE *u) { + const Py_UNICODE *u_end = u; + while (*u_end++) ; + return (size_t)(u_end - u - 1); +} +#define __Pyx_PyUnicode_FromUnicode(u) PyUnicode_FromUnicode(u, __Pyx_Py_UNICODE_strlen(u)) +#define __Pyx_PyUnicode_FromUnicodeAndLength PyUnicode_FromUnicode +#define __Pyx_PyUnicode_AsUnicode PyUnicode_AsUnicode +#define __Pyx_NewRef(obj) (Py_INCREF(obj), obj) +#define __Pyx_Owned_Py_None(b) __Pyx_NewRef(Py_None) +static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b); +static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*); +static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject*); +static CYTHON_INLINE PyObject* __Pyx_PyNumber_IntOrLong(PyObject* x); +#define __Pyx_PySequence_Tuple(obj)\ + (likely(PyTuple_CheckExact(obj)) ? __Pyx_NewRef(obj) : PySequence_Tuple(obj)) +static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*); +static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t); +#if CYTHON_ASSUME_SAFE_MACROS +#define __pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x)) +#else +#define __pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x) +#endif +#define __pyx_PyFloat_AsFloat(x) ((float) __pyx_PyFloat_AsDouble(x)) +#if PY_MAJOR_VERSION >= 3 +#define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x)) +#else +#define __Pyx_PyNumber_Int(x) (PyInt_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Int(x)) +#endif +#define __Pyx_PyNumber_Float(x) (PyFloat_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Float(x)) +#if PY_MAJOR_VERSION < 3 && __PYX_DEFAULT_STRING_ENCODING_IS_ASCII +static int __Pyx_sys_getdefaultencoding_not_ascii; +static int __Pyx_init_sys_getdefaultencoding_params(void) { + PyObject* sys; + PyObject* default_encoding = NULL; + PyObject* ascii_chars_u = NULL; + PyObject* ascii_chars_b = NULL; + const char* default_encoding_c; + sys = PyImport_ImportModule("sys"); + if (!sys) goto bad; + default_encoding = PyObject_CallMethod(sys, (char*) "getdefaultencoding", NULL); + Py_DECREF(sys); + if (!default_encoding) goto bad; + default_encoding_c = PyBytes_AsString(default_encoding); + if (!default_encoding_c) goto bad; + if (strcmp(default_encoding_c, "ascii") == 0) { + __Pyx_sys_getdefaultencoding_not_ascii = 0; + } else { + char ascii_chars[128]; + int c; + for (c = 0; c < 128; c++) { + ascii_chars[c] = c; + } + __Pyx_sys_getdefaultencoding_not_ascii = 1; + ascii_chars_u = PyUnicode_DecodeASCII(ascii_chars, 128, NULL); + if (!ascii_chars_u) goto bad; + ascii_chars_b = PyUnicode_AsEncodedString(ascii_chars_u, default_encoding_c, NULL); + if (!ascii_chars_b || !PyBytes_Check(ascii_chars_b) || memcmp(ascii_chars, PyBytes_AS_STRING(ascii_chars_b), 128) != 0) { + PyErr_Format( + PyExc_ValueError, + "This module compiled with c_string_encoding=ascii, but default encoding '%.200s' is not a superset of ascii.", + default_encoding_c); + goto bad; + } + Py_DECREF(ascii_chars_u); + Py_DECREF(ascii_chars_b); + } + Py_DECREF(default_encoding); + return 0; +bad: + Py_XDECREF(default_encoding); + Py_XDECREF(ascii_chars_u); + Py_XDECREF(ascii_chars_b); + return -1; +} +#endif +#if __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT && PY_MAJOR_VERSION >= 3 +#define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL) +#else +#define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL) +#if __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT +static char* __PYX_DEFAULT_STRING_ENCODING; +static int __Pyx_init_sys_getdefaultencoding_params(void) { + PyObject* sys; + PyObject* default_encoding = NULL; + char* default_encoding_c; + sys = PyImport_ImportModule("sys"); + if (!sys) goto bad; + default_encoding = PyObject_CallMethod(sys, (char*) (const char*) "getdefaultencoding", NULL); + Py_DECREF(sys); + if (!default_encoding) goto bad; + default_encoding_c = PyBytes_AsString(default_encoding); + if (!default_encoding_c) goto bad; + __PYX_DEFAULT_STRING_ENCODING = (char*) malloc(strlen(default_encoding_c) + 1); + if (!__PYX_DEFAULT_STRING_ENCODING) goto bad; + strcpy(__PYX_DEFAULT_STRING_ENCODING, default_encoding_c); + Py_DECREF(default_encoding); + return 0; +bad: + Py_XDECREF(default_encoding); + return -1; +} +#endif +#endif + + +/* Test for GCC > 2.95 */ +#if defined(__GNUC__) && (__GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))) + #define likely(x) __builtin_expect(!!(x), 1) + #define unlikely(x) __builtin_expect(!!(x), 0) +#else /* !__GNUC__ or GCC < 2.95 */ + #define likely(x) (x) + #define unlikely(x) (x) +#endif /* __GNUC__ */ +static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; } + +static PyObject *__pyx_m = NULL; +static PyObject *__pyx_d; +static PyObject *__pyx_b; +static PyObject *__pyx_cython_runtime = NULL; +static PyObject *__pyx_empty_tuple; +static PyObject *__pyx_empty_bytes; +static PyObject *__pyx_empty_unicode; +static int __pyx_lineno; +static int __pyx_clineno = 0; +static const char * __pyx_cfilenm= __FILE__; +static const char *__pyx_filename; + + +static const char *__pyx_f[] = { + "yarl\\_quoting_c.pyx", + "stringsource", + "type.pxd", +}; + +/*--- Type declarations ---*/ +struct __pyx_obj_4yarl_10_quoting_c__Quoter; +struct __pyx_obj_4yarl_10_quoting_c__Unquoter; +struct __pyx_t_4yarl_10_quoting_c_Writer; + +/* "yarl/_quoting_c.pyx":76 + * # ----------------- writer --------------------------- + * + * cdef struct Writer: # <<<<<<<<<<<<<< + * char *buf + * Py_ssize_t size + */ +struct __pyx_t_4yarl_10_quoting_c_Writer { + char *buf; + Py_ssize_t size; + Py_ssize_t pos; + int changed; +}; + +/* "yarl/_quoting_c.pyx":186 + * + * + * cdef class _Quoter: # <<<<<<<<<<<<<< + * cdef bint _qs + * cdef bint _requote + */ +struct __pyx_obj_4yarl_10_quoting_c__Quoter { + PyObject_HEAD + struct __pyx_vtabstruct_4yarl_10_quoting_c__Quoter *__pyx_vtab; + int _qs; + int _requote; + uint8_t _safe_table[16]; + uint8_t _protected_table[16]; +}; + + +/* "yarl/_quoting_c.pyx":305 + * + * + * cdef class _Unquoter: # <<<<<<<<<<<<<< + * cdef str _unsafe + * cdef bint _qs + */ +struct __pyx_obj_4yarl_10_quoting_c__Unquoter { + PyObject_HEAD + struct __pyx_vtabstruct_4yarl_10_quoting_c__Unquoter *__pyx_vtab; + PyObject *_unsafe; + int _qs; + struct __pyx_obj_4yarl_10_quoting_c__Quoter *_quoter; + struct __pyx_obj_4yarl_10_quoting_c__Quoter *_qs_quoter; +}; + + + +/* "yarl/_quoting_c.pyx":186 + * + * + * cdef class _Quoter: # <<<<<<<<<<<<<< + * cdef bint _qs + * cdef bint _requote + */ + +struct __pyx_vtabstruct_4yarl_10_quoting_c__Quoter { + PyObject *(*_do_quote)(struct __pyx_obj_4yarl_10_quoting_c__Quoter *, PyObject *, struct __pyx_t_4yarl_10_quoting_c_Writer *); + int (*_write)(struct __pyx_obj_4yarl_10_quoting_c__Quoter *, struct __pyx_t_4yarl_10_quoting_c_Writer *, Py_UCS4); +}; +static struct __pyx_vtabstruct_4yarl_10_quoting_c__Quoter *__pyx_vtabptr_4yarl_10_quoting_c__Quoter; +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c_7_Quoter__write(struct __pyx_obj_4yarl_10_quoting_c__Quoter *, struct __pyx_t_4yarl_10_quoting_c_Writer *, Py_UCS4); + + +/* "yarl/_quoting_c.pyx":305 + * + * + * cdef class _Unquoter: # <<<<<<<<<<<<<< + * cdef str _unsafe + * cdef bint _qs + */ + +struct __pyx_vtabstruct_4yarl_10_quoting_c__Unquoter { + PyObject *(*_do_unquote)(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *, PyObject *); +}; +static struct __pyx_vtabstruct_4yarl_10_quoting_c__Unquoter *__pyx_vtabptr_4yarl_10_quoting_c__Unquoter; + +/* --- Runtime support code (head) --- */ +/* Refnanny.proto */ +#ifndef CYTHON_REFNANNY + #define CYTHON_REFNANNY 0 +#endif +#if CYTHON_REFNANNY + typedef struct { + void (*INCREF)(void*, PyObject*, int); + void (*DECREF)(void*, PyObject*, int); + void (*GOTREF)(void*, PyObject*, int); + void (*GIVEREF)(void*, PyObject*, int); + void* (*SetupContext)(const char*, int, const char*); + void (*FinishContext)(void**); + } __Pyx_RefNannyAPIStruct; + static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL; + static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); + #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL; +#ifdef WITH_THREAD + #define __Pyx_RefNannySetupContext(name, acquire_gil)\ + if (acquire_gil) {\ + PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ + __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__);\ + PyGILState_Release(__pyx_gilstate_save);\ + } else {\ + __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__);\ + } +#else + #define __Pyx_RefNannySetupContext(name, acquire_gil)\ + __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__) +#endif + #define __Pyx_RefNannyFinishContext()\ + __Pyx_RefNanny->FinishContext(&__pyx_refnanny) + #define __Pyx_INCREF(r) __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), __LINE__) + #define __Pyx_DECREF(r) __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), __LINE__) + #define __Pyx_GOTREF(r) __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), __LINE__) + #define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), __LINE__) + #define __Pyx_XINCREF(r) do { if((r) != NULL) {__Pyx_INCREF(r); }} while(0) + #define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r); }} while(0) + #define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r); }} while(0) + #define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);}} while(0) +#else + #define __Pyx_RefNannyDeclarations + #define __Pyx_RefNannySetupContext(name, acquire_gil) + #define __Pyx_RefNannyFinishContext() + #define __Pyx_INCREF(r) Py_INCREF(r) + #define __Pyx_DECREF(r) Py_DECREF(r) + #define __Pyx_GOTREF(r) + #define __Pyx_GIVEREF(r) + #define __Pyx_XINCREF(r) Py_XINCREF(r) + #define __Pyx_XDECREF(r) Py_XDECREF(r) + #define __Pyx_XGOTREF(r) + #define __Pyx_XGIVEREF(r) +#endif +#define __Pyx_XDECREF_SET(r, v) do {\ + PyObject *tmp = (PyObject *) r;\ + r = v; __Pyx_XDECREF(tmp);\ + } while (0) +#define __Pyx_DECREF_SET(r, v) do {\ + PyObject *tmp = (PyObject *) r;\ + r = v; __Pyx_DECREF(tmp);\ + } while (0) +#define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0) +#define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0) + +/* PyObjectGetAttrStr.proto */ +#if CYTHON_USE_TYPE_SLOTS +static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name); +#else +#define __Pyx_PyObject_GetAttrStr(o,n) PyObject_GetAttr(o,n) +#endif + +/* GetBuiltinName.proto */ +static PyObject *__Pyx_GetBuiltinName(PyObject *name); + +/* PyThreadStateGet.proto */ +#if CYTHON_FAST_THREAD_STATE +#define __Pyx_PyThreadState_declare PyThreadState *__pyx_tstate; +#define __Pyx_PyThreadState_assign __pyx_tstate = __Pyx_PyThreadState_Current; +#define __Pyx_PyErr_Occurred() __pyx_tstate->curexc_type +#else +#define __Pyx_PyThreadState_declare +#define __Pyx_PyThreadState_assign +#define __Pyx_PyErr_Occurred() PyErr_Occurred() +#endif + +/* PyErrFetchRestore.proto */ +#if CYTHON_FAST_THREAD_STATE +#define __Pyx_PyErr_Clear() __Pyx_ErrRestore(NULL, NULL, NULL) +#define __Pyx_ErrRestoreWithState(type, value, tb) __Pyx_ErrRestoreInState(PyThreadState_GET(), type, value, tb) +#define __Pyx_ErrFetchWithState(type, value, tb) __Pyx_ErrFetchInState(PyThreadState_GET(), type, value, tb) +#define __Pyx_ErrRestore(type, value, tb) __Pyx_ErrRestoreInState(__pyx_tstate, type, value, tb) +#define __Pyx_ErrFetch(type, value, tb) __Pyx_ErrFetchInState(__pyx_tstate, type, value, tb) +static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb); +static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); +#if CYTHON_COMPILING_IN_CPYTHON +#define __Pyx_PyErr_SetNone(exc) (Py_INCREF(exc), __Pyx_ErrRestore((exc), NULL, NULL)) +#else +#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) +#endif +#else +#define __Pyx_PyErr_Clear() PyErr_Clear() +#define __Pyx_PyErr_SetNone(exc) PyErr_SetNone(exc) +#define __Pyx_ErrRestoreWithState(type, value, tb) PyErr_Restore(type, value, tb) +#define __Pyx_ErrFetchWithState(type, value, tb) PyErr_Fetch(type, value, tb) +#define __Pyx_ErrRestoreInState(tstate, type, value, tb) PyErr_Restore(type, value, tb) +#define __Pyx_ErrFetchInState(tstate, type, value, tb) PyErr_Fetch(type, value, tb) +#define __Pyx_ErrRestore(type, value, tb) PyErr_Restore(type, value, tb) +#define __Pyx_ErrFetch(type, value, tb) PyErr_Fetch(type, value, tb) +#endif + +/* WriteUnraisableException.proto */ +static void __Pyx_WriteUnraisable(const char *name, int clineno, + int lineno, const char *filename, + int full_traceback, int nogil); + +/* RaiseDoubleKeywords.proto */ +static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name); + +/* ParseKeywords.proto */ +static int __Pyx_ParseOptionalKeywords(PyObject *kwds, PyObject **argnames[],\ + PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args,\ + const char* function_name); + +/* RaiseArgTupleInvalid.proto */ +static void __Pyx_RaiseArgtupleInvalid(const char* func_name, int exact, + Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found); + +/* ArgTypeTest.proto */ +#define __Pyx_ArgTypeTest(obj, type, none_allowed, name, exact)\ + ((likely((Py_TYPE(obj) == type) | (none_allowed && (obj == Py_None)))) ? 1 :\ + __Pyx__ArgTypeTest(obj, type, name, exact)) +static int __Pyx__ArgTypeTest(PyObject *obj, PyTypeObject *type, const char *name, int exact); + +/* unicode_iter.proto */ +static CYTHON_INLINE int __Pyx_init_unicode_iteration( + PyObject* ustring, Py_ssize_t *length, void** data, int *kind); + +/* PyObjectCall.proto */ +#if CYTHON_COMPILING_IN_CPYTHON +static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw); +#else +#define __Pyx_PyObject_Call(func, arg, kw) PyObject_Call(func, arg, kw) +#endif + +/* RaiseException.proto */ +static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause); + +/* PyCFunctionFastCall.proto */ +#if CYTHON_FAST_PYCCALL +static CYTHON_INLINE PyObject *__Pyx_PyCFunction_FastCall(PyObject *func, PyObject **args, Py_ssize_t nargs); +#else +#define __Pyx_PyCFunction_FastCall(func, args, nargs) (assert(0), NULL) +#endif + +/* PyFunctionFastCall.proto */ +#if CYTHON_FAST_PYCALL +#define __Pyx_PyFunction_FastCall(func, args, nargs)\ + __Pyx_PyFunction_FastCallDict((func), (args), (nargs), NULL) +#if 1 || PY_VERSION_HEX < 0x030600B1 +static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject **args, Py_ssize_t nargs, PyObject *kwargs); +#else +#define __Pyx_PyFunction_FastCallDict(func, args, nargs, kwargs) _PyFunction_FastCallDict(func, args, nargs, kwargs) +#endif +#define __Pyx_BUILD_ASSERT_EXPR(cond)\ + (sizeof(char [1 - 2*!(cond)]) - 1) +#ifndef Py_MEMBER_SIZE +#define Py_MEMBER_SIZE(type, member) sizeof(((type *)0)->member) +#endif + static size_t __pyx_pyframe_localsplus_offset = 0; + #include "frameobject.h" + #define __Pxy_PyFrame_Initialize_Offsets()\ + ((void)__Pyx_BUILD_ASSERT_EXPR(sizeof(PyFrameObject) == offsetof(PyFrameObject, f_localsplus) + Py_MEMBER_SIZE(PyFrameObject, f_localsplus)),\ + (void)(__pyx_pyframe_localsplus_offset = ((size_t)PyFrame_Type.tp_basicsize) - Py_MEMBER_SIZE(PyFrameObject, f_localsplus))) + #define __Pyx_PyFrame_GetLocalsplus(frame)\ + (assert(__pyx_pyframe_localsplus_offset), (PyObject **)(((char *)(frame)) + __pyx_pyframe_localsplus_offset)) +#endif + +/* PyObjectCallMethO.proto */ +#if CYTHON_COMPILING_IN_CPYTHON +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg); +#endif + +/* PyObjectCallOneArg.proto */ +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg); + +/* GetException.proto */ +#if CYTHON_FAST_THREAD_STATE +#define __Pyx_GetException(type, value, tb) __Pyx__GetException(__pyx_tstate, type, value, tb) +static int __Pyx__GetException(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); +#else +static int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb); +#endif + +/* SwapException.proto */ +#if CYTHON_FAST_THREAD_STATE +#define __Pyx_ExceptionSwap(type, value, tb) __Pyx__ExceptionSwap(__pyx_tstate, type, value, tb) +static CYTHON_INLINE void __Pyx__ExceptionSwap(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); +#else +static CYTHON_INLINE void __Pyx_ExceptionSwap(PyObject **type, PyObject **value, PyObject **tb); +#endif + +/* GetTopmostException.proto */ +#if CYTHON_USE_EXC_INFO_STACK +static _PyErr_StackItem * __Pyx_PyErr_GetTopmostException(PyThreadState *tstate); +#endif + +/* SaveResetException.proto */ +#if CYTHON_FAST_THREAD_STATE +#define __Pyx_ExceptionSave(type, value, tb) __Pyx__ExceptionSave(__pyx_tstate, type, value, tb) +static CYTHON_INLINE void __Pyx__ExceptionSave(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb); +#define __Pyx_ExceptionReset(type, value, tb) __Pyx__ExceptionReset(__pyx_tstate, type, value, tb) +static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb); +#else +#define __Pyx_ExceptionSave(type, value, tb) PyErr_GetExcInfo(type, value, tb) +#define __Pyx_ExceptionReset(type, value, tb) PyErr_SetExcInfo(type, value, tb) +#endif + +/* ReRaiseException.proto */ +static CYTHON_INLINE void __Pyx_ReraiseException(void); + +/* PyErrExceptionMatches.proto */ +#if CYTHON_FAST_THREAD_STATE +#define __Pyx_PyErr_ExceptionMatches(err) __Pyx_PyErr_ExceptionMatchesInState(__pyx_tstate, err) +static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err); +#else +#define __Pyx_PyErr_ExceptionMatches(err) PyErr_ExceptionMatches(err) +#endif + +/* GetAttr.proto */ +static CYTHON_INLINE PyObject *__Pyx_GetAttr(PyObject *, PyObject *); + +/* GetAttr3.proto */ +static CYTHON_INLINE PyObject *__Pyx_GetAttr3(PyObject *, PyObject *, PyObject *); + +/* PyDictVersioning.proto */ +#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS +#define __PYX_DICT_VERSION_INIT ((PY_UINT64_T) -1) +#define __PYX_GET_DICT_VERSION(dict) (((PyDictObject*)(dict))->ma_version_tag) +#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var)\ + (version_var) = __PYX_GET_DICT_VERSION(dict);\ + (cache_var) = (value); +#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) {\ + static PY_UINT64_T __pyx_dict_version = 0;\ + static PyObject *__pyx_dict_cached_value = NULL;\ + if (likely(__PYX_GET_DICT_VERSION(DICT) == __pyx_dict_version)) {\ + (VAR) = __pyx_dict_cached_value;\ + } else {\ + (VAR) = __pyx_dict_cached_value = (LOOKUP);\ + __pyx_dict_version = __PYX_GET_DICT_VERSION(DICT);\ + }\ +} +static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj); +static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj); +static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version); +#else +#define __PYX_GET_DICT_VERSION(dict) (0) +#define __PYX_UPDATE_DICT_CACHE(dict, value, cache_var, version_var) +#define __PYX_PY_DICT_LOOKUP_IF_MODIFIED(VAR, DICT, LOOKUP) (VAR) = (LOOKUP); +#endif + +/* GetModuleGlobalName.proto */ +#if CYTHON_USE_DICT_VERSIONS +#define __Pyx_GetModuleGlobalName(var, name) {\ + static PY_UINT64_T __pyx_dict_version = 0;\ + static PyObject *__pyx_dict_cached_value = NULL;\ + (var) = (likely(__pyx_dict_version == __PYX_GET_DICT_VERSION(__pyx_d))) ?\ + (likely(__pyx_dict_cached_value) ? __Pyx_NewRef(__pyx_dict_cached_value) : __Pyx_GetBuiltinName(name)) :\ + __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ +} +#define __Pyx_GetModuleGlobalNameUncached(var, name) {\ + PY_UINT64_T __pyx_dict_version;\ + PyObject *__pyx_dict_cached_value;\ + (var) = __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ +} +static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value); +#else +#define __Pyx_GetModuleGlobalName(var, name) (var) = __Pyx__GetModuleGlobalName(name) +#define __Pyx_GetModuleGlobalNameUncached(var, name) (var) = __Pyx__GetModuleGlobalName(name) +static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name); +#endif + +/* PyObjectCallNoArg.proto */ +#if CYTHON_COMPILING_IN_CPYTHON +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func); +#else +#define __Pyx_PyObject_CallNoArg(func) __Pyx_PyObject_Call(func, __pyx_empty_tuple, NULL) +#endif + +/* PyObjectCall2Args.proto */ +static CYTHON_UNUSED PyObject* __Pyx_PyObject_Call2Args(PyObject* function, PyObject* arg1, PyObject* arg2); + +/* PyObjectGetMethod.proto */ +static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method); + +/* PyObjectCallMethod1.proto */ +static PyObject* __Pyx_PyObject_CallMethod1(PyObject* obj, PyObject* method_name, PyObject* arg); + +/* ByteArrayAppend.proto */ +static CYTHON_INLINE int __Pyx_PyByteArray_Append(PyObject* bytearray, int value); + +/* ByteArrayAppendObject.proto */ +static CYTHON_INLINE int __Pyx_PyByteArray_AppendObject(PyObject* bytearray, PyObject* value); + +/* PyUnicode_Substring.proto */ +static CYTHON_INLINE PyObject* __Pyx_PyUnicode_Substring( + PyObject* text, Py_ssize_t start, Py_ssize_t stop); + +/* decode_c_string_utf16.proto */ +static CYTHON_INLINE PyObject *__Pyx_PyUnicode_DecodeUTF16(const char *s, Py_ssize_t size, const char *errors) { + int byteorder = 0; + return PyUnicode_DecodeUTF16(s, size, errors, &byteorder); +} +static CYTHON_INLINE PyObject *__Pyx_PyUnicode_DecodeUTF16LE(const char *s, Py_ssize_t size, const char *errors) { + int byteorder = -1; + return PyUnicode_DecodeUTF16(s, size, errors, &byteorder); +} +static CYTHON_INLINE PyObject *__Pyx_PyUnicode_DecodeUTF16BE(const char *s, Py_ssize_t size, const char *errors) { + int byteorder = 1; + return PyUnicode_DecodeUTF16(s, size, errors, &byteorder); +} + +/* decode_c_bytes.proto */ +static CYTHON_INLINE PyObject* __Pyx_decode_c_bytes( + const char* cstring, Py_ssize_t length, Py_ssize_t start, Py_ssize_t stop, + const char* encoding, const char* errors, + PyObject* (*decode_func)(const char *s, Py_ssize_t size, const char *errors)); + +/* decode_bytearray.proto */ +static CYTHON_INLINE PyObject* __Pyx_decode_bytearray( + PyObject* string, Py_ssize_t start, Py_ssize_t stop, + const char* encoding, const char* errors, + PyObject* (*decode_func)(const char *s, Py_ssize_t size, const char *errors)) { + return __Pyx_decode_c_bytes( + PyByteArray_AS_STRING(string), PyByteArray_GET_SIZE(string), + start, stop, encoding, errors, decode_func); +} + +/* PyUnicodeContains.proto */ +static CYTHON_INLINE int __Pyx_PyUnicode_ContainsTF(PyObject* substring, PyObject* text, int eq) { + int result = PyUnicode_Contains(text, substring); + return unlikely(result < 0) ? result : (result == (eq == Py_EQ)); +} + +/* ListAppend.proto */ +#if CYTHON_USE_PYLIST_INTERNALS && CYTHON_ASSUME_SAFE_MACROS +static CYTHON_INLINE int __Pyx_PyList_Append(PyObject* list, PyObject* x) { + PyListObject* L = (PyListObject*) list; + Py_ssize_t len = Py_SIZE(list); + if (likely(L->allocated > len) & likely(len > (L->allocated >> 1))) { + Py_INCREF(x); + PyList_SET_ITEM(list, len, x); + __Pyx_SET_SIZE(list, len + 1); + return 0; + } + return PyList_Append(list, x); +} +#else +#define __Pyx_PyList_Append(L,x) PyList_Append(L,x) +#endif + +/* SliceObject.proto */ +#define __Pyx_PyObject_DelSlice(obj, cstart, cstop, py_start, py_stop, py_slice, has_cstart, has_cstop, wraparound)\ + __Pyx_PyObject_SetSlice(obj, (PyObject*)NULL, cstart, cstop, py_start, py_stop, py_slice, has_cstart, has_cstop, wraparound) +static CYTHON_INLINE int __Pyx_PyObject_SetSlice( + PyObject* obj, PyObject* value, Py_ssize_t cstart, Py_ssize_t cstop, + PyObject** py_start, PyObject** py_stop, PyObject** py_slice, + int has_cstart, int has_cstop, int wraparound); + +/* IncludeStringH.proto */ +#include <string.h> + +/* BytesEquals.proto */ +static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals); + +/* UnicodeEquals.proto */ +static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals); + +/* UnicodeAsUCS4.proto */ +static CYTHON_INLINE Py_UCS4 __Pyx_PyUnicode_AsPy_UCS4(PyObject*); + +/* object_ord.proto */ +#if PY_MAJOR_VERSION >= 3 +#define __Pyx_PyObject_Ord(c)\ + (likely(PyUnicode_Check(c)) ? (long)__Pyx_PyUnicode_AsPy_UCS4(c) : __Pyx__PyObject_Ord(c)) +#else +#define __Pyx_PyObject_Ord(c) __Pyx__PyObject_Ord(c) +#endif +static long __Pyx__PyObject_Ord(PyObject* c); + +/* SliceObject.proto */ +static CYTHON_INLINE PyObject* __Pyx_PyObject_GetSlice( + PyObject* obj, Py_ssize_t cstart, Py_ssize_t cstop, + PyObject** py_start, PyObject** py_stop, PyObject** py_slice, + int has_cstart, int has_cstop, int wraparound); + +/* Import.proto */ +static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level); + +/* ImportFrom.proto */ +static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name); + +/* GetItemInt.proto */ +#define __Pyx_GetItemInt(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck)\ + (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\ + __Pyx_GetItemInt_Fast(o, (Py_ssize_t)i, is_list, wraparound, boundscheck) :\ + (is_list ? (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL) :\ + __Pyx_GetItemInt_Generic(o, to_py_func(i)))) +#define __Pyx_GetItemInt_List(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck)\ + (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\ + __Pyx_GetItemInt_List_Fast(o, (Py_ssize_t)i, wraparound, boundscheck) :\ + (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL)) +static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i, + int wraparound, int boundscheck); +#define __Pyx_GetItemInt_Tuple(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck)\ + (__Pyx_fits_Py_ssize_t(i, type, is_signed) ?\ + __Pyx_GetItemInt_Tuple_Fast(o, (Py_ssize_t)i, wraparound, boundscheck) :\ + (PyErr_SetString(PyExc_IndexError, "tuple index out of range"), (PyObject*)NULL)) +static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i, + int wraparound, int boundscheck); +static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j); +static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i, + int is_list, int wraparound, int boundscheck); + +/* HasAttr.proto */ +static CYTHON_INLINE int __Pyx_HasAttr(PyObject *, PyObject *); + +/* ExtTypeTest.proto */ +static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type); + +/* PyObject_GenericGetAttrNoDict.proto */ +#if CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP && PY_VERSION_HEX < 0x03070000 +static CYTHON_INLINE PyObject* __Pyx_PyObject_GenericGetAttrNoDict(PyObject* obj, PyObject* attr_name); +#else +#define __Pyx_PyObject_GenericGetAttrNoDict PyObject_GenericGetAttr +#endif + +/* PyObject_GenericGetAttr.proto */ +#if CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP && PY_VERSION_HEX < 0x03070000 +static PyObject* __Pyx_PyObject_GenericGetAttr(PyObject* obj, PyObject* attr_name); +#else +#define __Pyx_PyObject_GenericGetAttr PyObject_GenericGetAttr +#endif + +/* SetVTable.proto */ +static int __Pyx_SetVtable(PyObject *dict, void *vtable); + +/* PyObjectGetAttrStrNoError.proto */ +static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name); + +/* SetupReduce.proto */ +static int __Pyx_setup_reduce(PyObject* type_obj); + +/* TypeImport.proto */ +#ifndef __PYX_HAVE_RT_ImportType_proto +#define __PYX_HAVE_RT_ImportType_proto +enum __Pyx_ImportType_CheckSize { + __Pyx_ImportType_CheckSize_Error = 0, + __Pyx_ImportType_CheckSize_Warn = 1, + __Pyx_ImportType_CheckSize_Ignore = 2 +}; +static PyTypeObject *__Pyx_ImportType(PyObject* module, const char *module_name, const char *class_name, size_t size, enum __Pyx_ImportType_CheckSize check_size); +#endif + +/* CLineInTraceback.proto */ +#ifdef CYTHON_CLINE_IN_TRACEBACK +#define __Pyx_CLineForTraceback(tstate, c_line) (((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0) +#else +static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line); +#endif + +/* CodeObjectCache.proto */ +typedef struct { + PyCodeObject* code_object; + int code_line; +} __Pyx_CodeObjectCacheEntry; +struct __Pyx_CodeObjectCache { + int count; + int max_count; + __Pyx_CodeObjectCacheEntry* entries; +}; +static struct __Pyx_CodeObjectCache __pyx_code_cache = {0,0,NULL}; +static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line); +static PyCodeObject *__pyx_find_code_object(int code_line); +static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object); + +/* AddTraceback.proto */ +static void __Pyx_AddTraceback(const char *funcname, int c_line, + int py_line, const char *filename); + +/* CIntToPy.proto */ +static CYTHON_INLINE PyObject* __Pyx_PyInt_From_long(long value); + +/* CIntFromPy.proto */ +static CYTHON_INLINE uint8_t __Pyx_PyInt_As_uint8_t(PyObject *); + +/* CIntFromPy.proto */ +static CYTHON_INLINE uint64_t __Pyx_PyInt_As_uint64_t(PyObject *); + +/* CIntFromPy.proto */ +static CYTHON_INLINE long __Pyx_PyInt_As_long(PyObject *); + +/* CIntFromPy.proto */ +static CYTHON_INLINE int __Pyx_PyInt_As_int(PyObject *); + +/* FastTypeChecks.proto */ +#if CYTHON_COMPILING_IN_CPYTHON +#define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type) +static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b); +static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject *type); +static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2); +#else +#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type) +#define __Pyx_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type) +#define __Pyx_PyErr_GivenExceptionMatches2(err, type1, type2) (PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2)) +#endif +#define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception) + +/* CheckBinaryVersion.proto */ +static int __Pyx_check_binary_version(void); + +/* InitStrings.proto */ +static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); + +static PyObject *__pyx_f_4yarl_10_quoting_c_7_Quoter__do_quote(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v_val, struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer); /* proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c_7_Quoter__write(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer, Py_UCS4 __pyx_v_ch); /* proto*/ +static PyObject *__pyx_f_4yarl_10_quoting_c_9_Unquoter__do_unquote(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v_val); /* proto*/ + +/* Module declarations from 'libc.stdint' */ + +/* Module declarations from 'libc.string' */ + +/* Module declarations from 'libc.stdio' */ + +/* Module declarations from '__builtin__' */ + +/* Module declarations from 'cpython.type' */ +static PyTypeObject *__pyx_ptype_7cpython_4type_type = 0; + +/* Module declarations from 'cpython' */ + +/* Module declarations from 'cpython.object' */ + +/* Module declarations from 'cpython.exc' */ + +/* Module declarations from 'cpython.mem' */ + +/* Module declarations from 'cpython.unicode' */ + +/* Module declarations from 'yarl._quoting_c' */ +static PyTypeObject *__pyx_ptype_4yarl_10_quoting_c__Quoter = 0; +static PyTypeObject *__pyx_ptype_4yarl_10_quoting_c__Unquoter = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_GEN_DELIMS = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_SUB_DELIMS_WITHOUT_QS = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_SUB_DELIMS = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_RESERVED = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_UNRESERVED = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_ALLOWED = 0; +static PyObject *__pyx_v_4yarl_10_quoting_c_QS = 0; +static char __pyx_v_4yarl_10_quoting_c_BUFFER[0x2000]; +static uint8_t __pyx_v_4yarl_10_quoting_c_ALLOWED_TABLE[16]; +static uint8_t __pyx_v_4yarl_10_quoting_c_ALLOWED_NOTQS_TABLE[16]; +static CYTHON_INLINE Py_UCS4 __pyx_f_4yarl_10_quoting_c__to_hex(uint8_t); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__from_hex(Py_UCS4); /*proto*/ +static CYTHON_INLINE Py_UCS4 __pyx_f_4yarl_10_quoting_c__restore_ch(Py_UCS4, Py_UCS4); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c_bit_at(uint8_t *, uint64_t); /*proto*/ +static CYTHON_INLINE void __pyx_f_4yarl_10_quoting_c_set_bit(uint8_t *, uint64_t); /*proto*/ +static CYTHON_INLINE void __pyx_f_4yarl_10_quoting_c__init_writer(struct __pyx_t_4yarl_10_quoting_c_Writer *); /*proto*/ +static CYTHON_INLINE void __pyx_f_4yarl_10_quoting_c__release_writer(struct __pyx_t_4yarl_10_quoting_c_Writer *); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_char(struct __pyx_t_4yarl_10_quoting_c_Writer *, Py_UCS4, int); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_pct(struct __pyx_t_4yarl_10_quoting_c_Writer *, uint8_t, int); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_percent(struct __pyx_t_4yarl_10_quoting_c_Writer *); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_pct_check(struct __pyx_t_4yarl_10_quoting_c_Writer *, Py_UCS4, Py_UCS4 *); /*proto*/ +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_utf8(struct __pyx_t_4yarl_10_quoting_c_Writer *, Py_UCS4); /*proto*/ +static PyObject *__pyx_f_4yarl_10_quoting_c___pyx_unpickle__Quoter__set_state(struct __pyx_obj_4yarl_10_quoting_c__Quoter *, PyObject *); /*proto*/ +static PyObject *__pyx_f_4yarl_10_quoting_c___pyx_unpickle__Unquoter__set_state(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *, PyObject *); /*proto*/ +static int __Pyx_carray_from_py_uint8_t(PyObject *, uint8_t *, Py_ssize_t); /*proto*/ +#define __Pyx_MODULE_NAME "yarl._quoting_c" +extern int __pyx_module_is_main_yarl___quoting_c; +int __pyx_module_is_main_yarl___quoting_c = 0; + +/* Implementation of 'yarl._quoting_c' */ +static PyObject *__pyx_builtin_range; +static PyObject *__pyx_builtin_chr; +static PyObject *__pyx_builtin_ValueError; +static PyObject *__pyx_builtin_TypeError; +static PyObject *__pyx_builtin_UnicodeDecodeError; +static PyObject *__pyx_builtin_hex; +static PyObject *__pyx_builtin_OverflowError; +static PyObject *__pyx_builtin_enumerate; +static PyObject *__pyx_builtin_IndexError; +static const char __pyx_k_[] = ""; +static const char __pyx_k_i[] = "i"; +static const char __pyx_k__4[] = "+=&;"; +static const char __pyx_k__5[] = "%"; +static const char __pyx_k__6[] = "+"; +static const char __pyx_k__7[] = " "; +static const char __pyx_k__9[] = ":/?#[]@"; +static const char __pyx_k_qs[] = "qs"; +static const char __pyx_k__10[] = "!$'()*,"; +static const char __pyx_k__11[] = "+?=;"; +static const char __pyx_k__12[] = "-._~"; +static const char __pyx_k__13[] = "+&=;"; +static const char __pyx_k_chr[] = "chr"; +static const char __pyx_k_hex[] = "hex"; +static const char __pyx_k_new[] = "__new__"; +static const char __pyx_k_val[] = "val"; +static const char __pyx_k_base[] = "base"; +static const char __pyx_k_dict[] = "__dict__"; +static const char __pyx_k_main[] = "__main__"; +static const char __pyx_k_name[] = "__name__"; +static const char __pyx_k_safe[] = "safe"; +static const char __pyx_k_test[] = "__test__"; +static const char __pyx_k_range[] = "range"; +static const char __pyx_k_upper[] = "upper"; +static const char __pyx_k_Quoter[] = "_Quoter"; +static const char __pyx_k_append[] = "append"; +static const char __pyx_k_digits[] = "digits"; +static const char __pyx_k_import[] = "__import__"; +static const char __pyx_k_pickle[] = "pickle"; +static const char __pyx_k_reduce[] = "__reduce__"; +static const char __pyx_k_string[] = "string"; +static const char __pyx_k_unsafe[] = "unsafe"; +static const char __pyx_k_update[] = "update"; +static const char __pyx_k_requote[] = "requote"; +static const char __pyx_k_Unquoter[] = "_Unquoter"; +static const char __pyx_k_getstate[] = "__getstate__"; +static const char __pyx_k_pyx_type[] = "__pyx_type"; +static const char __pyx_k_setstate[] = "__setstate__"; +static const char __pyx_k_TypeError[] = "TypeError"; +static const char __pyx_k_enumerate[] = "enumerate"; +static const char __pyx_k_protected[] = "protected"; +static const char __pyx_k_pyx_state[] = "__pyx_state"; +static const char __pyx_k_reduce_ex[] = "__reduce_ex__"; +static const char __pyx_k_IndexError[] = "IndexError"; +static const char __pyx_k_ValueError[] = "ValueError"; +static const char __pyx_k_pyx_result[] = "__pyx_result"; +static const char __pyx_k_pyx_vtable[] = "__pyx_vtable__"; +static const char __pyx_k_PickleError[] = "PickleError"; +static const char __pyx_k_pyx_checksum[] = "__pyx_checksum"; +static const char __pyx_k_stringsource[] = "stringsource"; +static const char __pyx_k_OverflowError[] = "OverflowError"; +static const char __pyx_k_ascii_letters[] = "ascii_letters"; +static const char __pyx_k_reduce_cython[] = "__reduce_cython__"; +static const char __pyx_k_pyx_PickleError[] = "__pyx_PickleError"; +static const char __pyx_k_setstate_cython[] = "__setstate_cython__"; +static const char __pyx_k_yarl__quoting_c[] = "yarl._quoting_c"; +static const char __pyx_k_UnicodeDecodeError[] = "UnicodeDecodeError"; +static const char __pyx_k_cline_in_traceback[] = "cline_in_traceback"; +static const char __pyx_k_pyx_unpickle__Quoter[] = "__pyx_unpickle__Quoter"; +static const char __pyx_k_Argument_should_be_str[] = "Argument should be str"; +static const char __pyx_k_pyx_unpickle__Unquoter[] = "__pyx_unpickle__Unquoter"; +static const char __pyx_k_Incompatible_checksums_s_vs_0x27[] = "Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))"; +static const char __pyx_k_Incompatible_checksums_s_vs_0xe9[] = "Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))"; +static const char __pyx_k_Only_safe_symbols_with_ORD_128_a[] = "Only safe symbols with ORD < 128 are allowed"; +static PyObject *__pyx_kp_u_; +static PyObject *__pyx_kp_u_Argument_should_be_str; +static PyObject *__pyx_kp_s_Incompatible_checksums_s_vs_0x27; +static PyObject *__pyx_kp_s_Incompatible_checksums_s_vs_0xe9; +static PyObject *__pyx_n_s_IndexError; +static PyObject *__pyx_kp_u_Only_safe_symbols_with_ORD_128_a; +static PyObject *__pyx_n_s_OverflowError; +static PyObject *__pyx_n_s_PickleError; +static PyObject *__pyx_n_s_Quoter; +static PyObject *__pyx_n_s_TypeError; +static PyObject *__pyx_n_s_UnicodeDecodeError; +static PyObject *__pyx_n_s_Unquoter; +static PyObject *__pyx_n_s_ValueError; +static PyObject *__pyx_kp_u__10; +static PyObject *__pyx_kp_u__11; +static PyObject *__pyx_kp_u__12; +static PyObject *__pyx_kp_u__13; +static PyObject *__pyx_kp_u__4; +static PyObject *__pyx_kp_u__5; +static PyObject *__pyx_kp_u__6; +static PyObject *__pyx_kp_u__7; +static PyObject *__pyx_kp_u__9; +static PyObject *__pyx_n_s_append; +static PyObject *__pyx_n_s_ascii_letters; +static PyObject *__pyx_n_s_base; +static PyObject *__pyx_n_s_chr; +static PyObject *__pyx_n_s_cline_in_traceback; +static PyObject *__pyx_n_s_dict; +static PyObject *__pyx_n_s_digits; +static PyObject *__pyx_n_s_enumerate; +static PyObject *__pyx_n_s_getstate; +static PyObject *__pyx_n_s_hex; +static PyObject *__pyx_n_s_i; +static PyObject *__pyx_n_s_import; +static PyObject *__pyx_n_s_main; +static PyObject *__pyx_n_s_name; +static PyObject *__pyx_n_s_new; +static PyObject *__pyx_n_s_pickle; +static PyObject *__pyx_n_s_protected; +static PyObject *__pyx_n_s_pyx_PickleError; +static PyObject *__pyx_n_s_pyx_checksum; +static PyObject *__pyx_n_s_pyx_result; +static PyObject *__pyx_n_s_pyx_state; +static PyObject *__pyx_n_s_pyx_type; +static PyObject *__pyx_n_s_pyx_unpickle__Quoter; +static PyObject *__pyx_n_s_pyx_unpickle__Unquoter; +static PyObject *__pyx_n_s_pyx_vtable; +static PyObject *__pyx_n_s_qs; +static PyObject *__pyx_n_s_range; +static PyObject *__pyx_n_s_reduce; +static PyObject *__pyx_n_s_reduce_cython; +static PyObject *__pyx_n_s_reduce_ex; +static PyObject *__pyx_n_s_requote; +static PyObject *__pyx_n_s_safe; +static PyObject *__pyx_n_s_setstate; +static PyObject *__pyx_n_s_setstate_cython; +static PyObject *__pyx_n_s_string; +static PyObject *__pyx_kp_s_stringsource; +static PyObject *__pyx_n_s_test; +static PyObject *__pyx_n_s_unsafe; +static PyObject *__pyx_n_s_update; +static PyObject *__pyx_n_s_upper; +static PyObject *__pyx_n_s_val; +static PyObject *__pyx_n_s_yarl__quoting_c; +static int __pyx_pf_4yarl_10_quoting_c_7_Quoter___init__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v_safe, PyObject *__pyx_v_protected, int __pyx_v_qs, int __pyx_v_requote); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_7_Quoter_2__call__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v_val); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_7_Quoter_4__reduce_cython__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_7_Quoter_6__setstate_cython__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v___pyx_state); /* proto */ +static int __pyx_pf_4yarl_10_quoting_c_9_Unquoter___init__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v_unsafe, PyObject *__pyx_v_qs); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_9_Unquoter_2__call__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v_val); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_9_Unquoter_4__reduce_cython__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_9_Unquoter_6__setstate_cython__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v___pyx_state); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c___pyx_unpickle__Quoter(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v___pyx_type, long __pyx_v___pyx_checksum, PyObject *__pyx_v___pyx_state); /* proto */ +static PyObject *__pyx_pf_4yarl_10_quoting_c_2__pyx_unpickle__Unquoter(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v___pyx_type, long __pyx_v___pyx_checksum, PyObject *__pyx_v___pyx_state); /* proto */ +static PyObject *__pyx_tp_new_4yarl_10_quoting_c__Quoter(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/ +static PyObject *__pyx_tp_new_4yarl_10_quoting_c__Unquoter(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/ +static PyObject *__pyx_int_2; +static PyObject *__pyx_int_16; +static PyObject *__pyx_int_41310077; +static PyObject *__pyx_int_244432181; +static PyObject *__pyx_slice__8; +static PyObject *__pyx_tuple__2; +static PyObject *__pyx_tuple__3; +static PyObject *__pyx_tuple__14; +static PyObject *__pyx_tuple__16; +static PyObject *__pyx_codeobj__15; +static PyObject *__pyx_codeobj__17; +/* Late includes */ + +/* "yarl/_quoting_c.pyx":24 + * + * + * cdef inline Py_UCS4 _to_hex(uint8_t v): # <<<<<<<<<<<<<< + * if v < 10: + * return <Py_UCS4>(v+0x30) # ord('0') == 0x30 + */ + +static CYTHON_INLINE Py_UCS4 __pyx_f_4yarl_10_quoting_c__to_hex(uint8_t __pyx_v_v) { + Py_UCS4 __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + __Pyx_RefNannySetupContext("_to_hex", 0); + + /* "yarl/_quoting_c.pyx":25 + * + * cdef inline Py_UCS4 _to_hex(uint8_t v): + * if v < 10: # <<<<<<<<<<<<<< + * return <Py_UCS4>(v+0x30) # ord('0') == 0x30 + * else: + */ + __pyx_t_1 = ((__pyx_v_v < 10) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":26 + * cdef inline Py_UCS4 _to_hex(uint8_t v): + * if v < 10: + * return <Py_UCS4>(v+0x30) # ord('0') == 0x30 # <<<<<<<<<<<<<< + * else: + * return <Py_UCS4>(v+0x41-10) # ord('A') == 0x41 + */ + __pyx_r = ((Py_UCS4)(__pyx_v_v + 0x30)); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":25 + * + * cdef inline Py_UCS4 _to_hex(uint8_t v): + * if v < 10: # <<<<<<<<<<<<<< + * return <Py_UCS4>(v+0x30) # ord('0') == 0x30 + * else: + */ + } + + /* "yarl/_quoting_c.pyx":28 + * return <Py_UCS4>(v+0x30) # ord('0') == 0x30 + * else: + * return <Py_UCS4>(v+0x41-10) # ord('A') == 0x41 # <<<<<<<<<<<<<< + * + * + */ + /*else*/ { + __pyx_r = ((Py_UCS4)((__pyx_v_v + 0x41) - 10)); + goto __pyx_L0; + } + + /* "yarl/_quoting_c.pyx":24 + * + * + * cdef inline Py_UCS4 _to_hex(uint8_t v): # <<<<<<<<<<<<<< + * if v < 10: + * return <Py_UCS4>(v+0x30) # ord('0') == 0x30 + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":31 + * + * + * cdef inline int _from_hex(Py_UCS4 v): # <<<<<<<<<<<<<< + * if '0' <= v <= '9': + * return <int>(v) - 0x30 # ord('0') == 0x30 + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__from_hex(Py_UCS4 __pyx_v_v) { + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + int __pyx_t_2; + __Pyx_RefNannySetupContext("_from_hex", 0); + + /* "yarl/_quoting_c.pyx":32 + * + * cdef inline int _from_hex(Py_UCS4 v): + * if '0' <= v <= '9': # <<<<<<<<<<<<<< + * return <int>(v) - 0x30 # ord('0') == 0x30 + * elif 'A' <= v <= 'F': + */ + __pyx_t_1 = (48 <= __pyx_v_v); + if (__pyx_t_1) { + __pyx_t_1 = (__pyx_v_v <= 57); + } + __pyx_t_2 = (__pyx_t_1 != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":33 + * cdef inline int _from_hex(Py_UCS4 v): + * if '0' <= v <= '9': + * return <int>(v) - 0x30 # ord('0') == 0x30 # <<<<<<<<<<<<<< + * elif 'A' <= v <= 'F': + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + */ + __pyx_r = (((int)__pyx_v_v) - 0x30); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":32 + * + * cdef inline int _from_hex(Py_UCS4 v): + * if '0' <= v <= '9': # <<<<<<<<<<<<<< + * return <int>(v) - 0x30 # ord('0') == 0x30 + * elif 'A' <= v <= 'F': + */ + } + + /* "yarl/_quoting_c.pyx":34 + * if '0' <= v <= '9': + * return <int>(v) - 0x30 # ord('0') == 0x30 + * elif 'A' <= v <= 'F': # <<<<<<<<<<<<<< + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + * elif 'a' <= v <= 'f': + */ + __pyx_t_2 = (65 <= __pyx_v_v); + if (__pyx_t_2) { + __pyx_t_2 = (__pyx_v_v <= 70); + } + __pyx_t_1 = (__pyx_t_2 != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":35 + * return <int>(v) - 0x30 # ord('0') == 0x30 + * elif 'A' <= v <= 'F': + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 # <<<<<<<<<<<<<< + * elif 'a' <= v <= 'f': + * return <int>(v) - 0x61 + 10 # ord('a') == 0x61 + */ + __pyx_r = ((((int)__pyx_v_v) - 0x41) + 10); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":34 + * if '0' <= v <= '9': + * return <int>(v) - 0x30 # ord('0') == 0x30 + * elif 'A' <= v <= 'F': # <<<<<<<<<<<<<< + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + * elif 'a' <= v <= 'f': + */ + } + + /* "yarl/_quoting_c.pyx":36 + * elif 'A' <= v <= 'F': + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + * elif 'a' <= v <= 'f': # <<<<<<<<<<<<<< + * return <int>(v) - 0x61 + 10 # ord('a') == 0x61 + * else: + */ + __pyx_t_1 = (97 <= __pyx_v_v); + if (__pyx_t_1) { + __pyx_t_1 = (__pyx_v_v <= 0x66); + } + __pyx_t_2 = (__pyx_t_1 != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":37 + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + * elif 'a' <= v <= 'f': + * return <int>(v) - 0x61 + 10 # ord('a') == 0x61 # <<<<<<<<<<<<<< + * else: + * return -1 + */ + __pyx_r = ((((int)__pyx_v_v) - 0x61) + 10); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":36 + * elif 'A' <= v <= 'F': + * return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + * elif 'a' <= v <= 'f': # <<<<<<<<<<<<<< + * return <int>(v) - 0x61 + 10 # ord('a') == 0x61 + * else: + */ + } + + /* "yarl/_quoting_c.pyx":39 + * return <int>(v) - 0x61 + 10 # ord('a') == 0x61 + * else: + * return -1 # <<<<<<<<<<<<<< + * + * + */ + /*else*/ { + __pyx_r = -1; + goto __pyx_L0; + } + + /* "yarl/_quoting_c.pyx":31 + * + * + * cdef inline int _from_hex(Py_UCS4 v): # <<<<<<<<<<<<<< + * if '0' <= v <= '9': + * return <int>(v) - 0x30 # ord('0') == 0x30 + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":42 + * + * + * cdef inline Py_UCS4 _restore_ch(Py_UCS4 d1, Py_UCS4 d2): # <<<<<<<<<<<<<< + * cdef int digit1 = _from_hex(d1) + * if digit1 < 0: + */ + +static CYTHON_INLINE Py_UCS4 __pyx_f_4yarl_10_quoting_c__restore_ch(Py_UCS4 __pyx_v_d1, Py_UCS4 __pyx_v_d2) { + int __pyx_v_digit1; + int __pyx_v_digit2; + Py_UCS4 __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + __Pyx_RefNannySetupContext("_restore_ch", 0); + + /* "yarl/_quoting_c.pyx":43 + * + * cdef inline Py_UCS4 _restore_ch(Py_UCS4 d1, Py_UCS4 d2): + * cdef int digit1 = _from_hex(d1) # <<<<<<<<<<<<<< + * if digit1 < 0: + * return <Py_UCS4>-1 + */ + __pyx_v_digit1 = __pyx_f_4yarl_10_quoting_c__from_hex(__pyx_v_d1); + + /* "yarl/_quoting_c.pyx":44 + * cdef inline Py_UCS4 _restore_ch(Py_UCS4 d1, Py_UCS4 d2): + * cdef int digit1 = _from_hex(d1) + * if digit1 < 0: # <<<<<<<<<<<<<< + * return <Py_UCS4>-1 + * cdef int digit2 = _from_hex(d2) + */ + __pyx_t_1 = ((__pyx_v_digit1 < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":45 + * cdef int digit1 = _from_hex(d1) + * if digit1 < 0: + * return <Py_UCS4>-1 # <<<<<<<<<<<<<< + * cdef int digit2 = _from_hex(d2) + * if digit2 < 0: + */ + __pyx_r = ((Py_UCS4)-1L); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":44 + * cdef inline Py_UCS4 _restore_ch(Py_UCS4 d1, Py_UCS4 d2): + * cdef int digit1 = _from_hex(d1) + * if digit1 < 0: # <<<<<<<<<<<<<< + * return <Py_UCS4>-1 + * cdef int digit2 = _from_hex(d2) + */ + } + + /* "yarl/_quoting_c.pyx":46 + * if digit1 < 0: + * return <Py_UCS4>-1 + * cdef int digit2 = _from_hex(d2) # <<<<<<<<<<<<<< + * if digit2 < 0: + * return <Py_UCS4>-1 + */ + __pyx_v_digit2 = __pyx_f_4yarl_10_quoting_c__from_hex(__pyx_v_d2); + + /* "yarl/_quoting_c.pyx":47 + * return <Py_UCS4>-1 + * cdef int digit2 = _from_hex(d2) + * if digit2 < 0: # <<<<<<<<<<<<<< + * return <Py_UCS4>-1 + * return <Py_UCS4>(digit1 << 4 | digit2) + */ + __pyx_t_1 = ((__pyx_v_digit2 < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":48 + * cdef int digit2 = _from_hex(d2) + * if digit2 < 0: + * return <Py_UCS4>-1 # <<<<<<<<<<<<<< + * return <Py_UCS4>(digit1 << 4 | digit2) + * + */ + __pyx_r = ((Py_UCS4)-1L); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":47 + * return <Py_UCS4>-1 + * cdef int digit2 = _from_hex(d2) + * if digit2 < 0: # <<<<<<<<<<<<<< + * return <Py_UCS4>-1 + * return <Py_UCS4>(digit1 << 4 | digit2) + */ + } + + /* "yarl/_quoting_c.pyx":49 + * if digit2 < 0: + * return <Py_UCS4>-1 + * return <Py_UCS4>(digit1 << 4 | digit2) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = ((Py_UCS4)((__pyx_v_digit1 << 4) | __pyx_v_digit2)); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":42 + * + * + * cdef inline Py_UCS4 _restore_ch(Py_UCS4 d1, Py_UCS4 d2): # <<<<<<<<<<<<<< + * cdef int digit1 = _from_hex(d1) + * if digit1 < 0: + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":56 + * + * + * cdef inline bint bit_at(uint8_t array[], uint64_t ch): # <<<<<<<<<<<<<< + * return array[ch >> 3] & (1 << (ch & 7)) + * + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c_bit_at(uint8_t *__pyx_v_array, uint64_t __pyx_v_ch) { + int __pyx_r; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("bit_at", 0); + + /* "yarl/_quoting_c.pyx":57 + * + * cdef inline bint bit_at(uint8_t array[], uint64_t ch): + * return array[ch >> 3] & (1 << (ch & 7)) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = ((__pyx_v_array[(__pyx_v_ch >> 3)]) & (1 << (__pyx_v_ch & 7))); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":56 + * + * + * cdef inline bint bit_at(uint8_t array[], uint64_t ch): # <<<<<<<<<<<<<< + * return array[ch >> 3] & (1 << (ch & 7)) + * + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":60 + * + * + * cdef inline void set_bit(uint8_t array[], uint64_t ch): # <<<<<<<<<<<<<< + * array[ch >> 3] |= (1 << (ch & 7)) + * + */ + +static CYTHON_INLINE void __pyx_f_4yarl_10_quoting_c_set_bit(uint8_t *__pyx_v_array, uint64_t __pyx_v_ch) { + __Pyx_RefNannyDeclarations + uint64_t __pyx_t_1; + __Pyx_RefNannySetupContext("set_bit", 0); + + /* "yarl/_quoting_c.pyx":61 + * + * cdef inline void set_bit(uint8_t array[], uint64_t ch): + * array[ch >> 3] |= (1 << (ch & 7)) # <<<<<<<<<<<<<< + * + * + */ + __pyx_t_1 = (__pyx_v_ch >> 3); + (__pyx_v_array[__pyx_t_1]) = ((__pyx_v_array[__pyx_t_1]) | (1 << (__pyx_v_ch & 7))); + + /* "yarl/_quoting_c.pyx":60 + * + * + * cdef inline void set_bit(uint8_t array[], uint64_t ch): # <<<<<<<<<<<<<< + * array[ch >> 3] |= (1 << (ch & 7)) + * + */ + + /* function exit code */ + __Pyx_RefNannyFinishContext(); +} + +/* "yarl/_quoting_c.pyx":83 + * + * + * cdef inline void _init_writer(Writer* writer): # <<<<<<<<<<<<<< + * writer.buf = &BUFFER[0] + * writer.size = BUF_SIZE + */ + +static CYTHON_INLINE void __pyx_f_4yarl_10_quoting_c__init_writer(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("_init_writer", 0); + + /* "yarl/_quoting_c.pyx":84 + * + * cdef inline void _init_writer(Writer* writer): + * writer.buf = &BUFFER[0] # <<<<<<<<<<<<<< + * writer.size = BUF_SIZE + * writer.pos = 0 + */ + __pyx_v_writer->buf = (&(__pyx_v_4yarl_10_quoting_c_BUFFER[0])); + + /* "yarl/_quoting_c.pyx":85 + * cdef inline void _init_writer(Writer* writer): + * writer.buf = &BUFFER[0] + * writer.size = BUF_SIZE # <<<<<<<<<<<<<< + * writer.pos = 0 + * writer.changed = 0 + */ + __pyx_v_writer->size = 0x2000; + + /* "yarl/_quoting_c.pyx":86 + * writer.buf = &BUFFER[0] + * writer.size = BUF_SIZE + * writer.pos = 0 # <<<<<<<<<<<<<< + * writer.changed = 0 + * + */ + __pyx_v_writer->pos = 0; + + /* "yarl/_quoting_c.pyx":87 + * writer.size = BUF_SIZE + * writer.pos = 0 + * writer.changed = 0 # <<<<<<<<<<<<<< + * + * + */ + __pyx_v_writer->changed = 0; + + /* "yarl/_quoting_c.pyx":83 + * + * + * cdef inline void _init_writer(Writer* writer): # <<<<<<<<<<<<<< + * writer.buf = &BUFFER[0] + * writer.size = BUF_SIZE + */ + + /* function exit code */ + __Pyx_RefNannyFinishContext(); +} + +/* "yarl/_quoting_c.pyx":90 + * + * + * cdef inline void _release_writer(Writer* writer): # <<<<<<<<<<<<<< + * if writer.buf != BUFFER: + * PyMem_Free(writer.buf) + */ + +static CYTHON_INLINE void __pyx_f_4yarl_10_quoting_c__release_writer(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer) { + __Pyx_RefNannyDeclarations + int __pyx_t_1; + __Pyx_RefNannySetupContext("_release_writer", 0); + + /* "yarl/_quoting_c.pyx":91 + * + * cdef inline void _release_writer(Writer* writer): + * if writer.buf != BUFFER: # <<<<<<<<<<<<<< + * PyMem_Free(writer.buf) + * + */ + __pyx_t_1 = ((__pyx_v_writer->buf != __pyx_v_4yarl_10_quoting_c_BUFFER) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":92 + * cdef inline void _release_writer(Writer* writer): + * if writer.buf != BUFFER: + * PyMem_Free(writer.buf) # <<<<<<<<<<<<<< + * + * + */ + PyMem_Free(__pyx_v_writer->buf); + + /* "yarl/_quoting_c.pyx":91 + * + * cdef inline void _release_writer(Writer* writer): + * if writer.buf != BUFFER: # <<<<<<<<<<<<<< + * PyMem_Free(writer.buf) + * + */ + } + + /* "yarl/_quoting_c.pyx":90 + * + * + * cdef inline void _release_writer(Writer* writer): # <<<<<<<<<<<<<< + * if writer.buf != BUFFER: + * PyMem_Free(writer.buf) + */ + + /* function exit code */ + __Pyx_RefNannyFinishContext(); +} + +/* "yarl/_quoting_c.pyx":95 + * + * + * cdef inline int _write_char(Writer* writer, Py_UCS4 ch, bint changed): # <<<<<<<<<<<<<< + * cdef char * buf + * cdef Py_ssize_t size + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_char(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer, Py_UCS4 __pyx_v_ch, int __pyx_v_changed) { + char *__pyx_v_buf; + Py_ssize_t __pyx_v_size; + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + PyObject *__pyx_t_2; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("_write_char", 0); + + /* "yarl/_quoting_c.pyx":99 + * cdef Py_ssize_t size + * + * if writer.pos == writer.size: # <<<<<<<<<<<<<< + * # reallocate + * size = writer.size + BUF_SIZE + */ + __pyx_t_1 = ((__pyx_v_writer->pos == __pyx_v_writer->size) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":101 + * if writer.pos == writer.size: + * # reallocate + * size = writer.size + BUF_SIZE # <<<<<<<<<<<<<< + * if writer.buf == BUFFER: + * buf = <char*>PyMem_Malloc(size) + */ + __pyx_v_size = (__pyx_v_writer->size + 0x2000); + + /* "yarl/_quoting_c.pyx":102 + * # reallocate + * size = writer.size + BUF_SIZE + * if writer.buf == BUFFER: # <<<<<<<<<<<<<< + * buf = <char*>PyMem_Malloc(size) + * if buf == NULL: + */ + __pyx_t_1 = ((__pyx_v_writer->buf == __pyx_v_4yarl_10_quoting_c_BUFFER) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":103 + * size = writer.size + BUF_SIZE + * if writer.buf == BUFFER: + * buf = <char*>PyMem_Malloc(size) # <<<<<<<<<<<<<< + * if buf == NULL: + * PyErr_NoMemory() + */ + __pyx_v_buf = ((char *)PyMem_Malloc(__pyx_v_size)); + + /* "yarl/_quoting_c.pyx":104 + * if writer.buf == BUFFER: + * buf = <char*>PyMem_Malloc(size) + * if buf == NULL: # <<<<<<<<<<<<<< + * PyErr_NoMemory() + * return -1 + */ + __pyx_t_1 = ((__pyx_v_buf == NULL) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":105 + * buf = <char*>PyMem_Malloc(size) + * if buf == NULL: + * PyErr_NoMemory() # <<<<<<<<<<<<<< + * return -1 + * memcpy(buf, writer.buf, writer.size) + */ + __pyx_t_2 = PyErr_NoMemory(); if (unlikely(__pyx_t_2 == ((PyObject *)NULL))) __PYX_ERR(0, 105, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":106 + * if buf == NULL: + * PyErr_NoMemory() + * return -1 # <<<<<<<<<<<<<< + * memcpy(buf, writer.buf, writer.size) + * else: + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":104 + * if writer.buf == BUFFER: + * buf = <char*>PyMem_Malloc(size) + * if buf == NULL: # <<<<<<<<<<<<<< + * PyErr_NoMemory() + * return -1 + */ + } + + /* "yarl/_quoting_c.pyx":107 + * PyErr_NoMemory() + * return -1 + * memcpy(buf, writer.buf, writer.size) # <<<<<<<<<<<<<< + * else: + * buf = <char*>PyMem_Realloc(writer.buf, size) + */ + (void)(memcpy(__pyx_v_buf, __pyx_v_writer->buf, __pyx_v_writer->size)); + + /* "yarl/_quoting_c.pyx":102 + * # reallocate + * size = writer.size + BUF_SIZE + * if writer.buf == BUFFER: # <<<<<<<<<<<<<< + * buf = <char*>PyMem_Malloc(size) + * if buf == NULL: + */ + goto __pyx_L4; + } + + /* "yarl/_quoting_c.pyx":109 + * memcpy(buf, writer.buf, writer.size) + * else: + * buf = <char*>PyMem_Realloc(writer.buf, size) # <<<<<<<<<<<<<< + * if buf == NULL: + * PyErr_NoMemory() + */ + /*else*/ { + __pyx_v_buf = ((char *)PyMem_Realloc(__pyx_v_writer->buf, __pyx_v_size)); + + /* "yarl/_quoting_c.pyx":110 + * else: + * buf = <char*>PyMem_Realloc(writer.buf, size) + * if buf == NULL: # <<<<<<<<<<<<<< + * PyErr_NoMemory() + * return -1 + */ + __pyx_t_1 = ((__pyx_v_buf == NULL) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":111 + * buf = <char*>PyMem_Realloc(writer.buf, size) + * if buf == NULL: + * PyErr_NoMemory() # <<<<<<<<<<<<<< + * return -1 + * writer.buf = buf + */ + __pyx_t_2 = PyErr_NoMemory(); if (unlikely(__pyx_t_2 == ((PyObject *)NULL))) __PYX_ERR(0, 111, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":112 + * if buf == NULL: + * PyErr_NoMemory() + * return -1 # <<<<<<<<<<<<<< + * writer.buf = buf + * writer.size = size + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":110 + * else: + * buf = <char*>PyMem_Realloc(writer.buf, size) + * if buf == NULL: # <<<<<<<<<<<<<< + * PyErr_NoMemory() + * return -1 + */ + } + } + __pyx_L4:; + + /* "yarl/_quoting_c.pyx":113 + * PyErr_NoMemory() + * return -1 + * writer.buf = buf # <<<<<<<<<<<<<< + * writer.size = size + * writer.buf[writer.pos] = <char>ch + */ + __pyx_v_writer->buf = __pyx_v_buf; + + /* "yarl/_quoting_c.pyx":114 + * return -1 + * writer.buf = buf + * writer.size = size # <<<<<<<<<<<<<< + * writer.buf[writer.pos] = <char>ch + * writer.pos += 1 + */ + __pyx_v_writer->size = __pyx_v_size; + + /* "yarl/_quoting_c.pyx":99 + * cdef Py_ssize_t size + * + * if writer.pos == writer.size: # <<<<<<<<<<<<<< + * # reallocate + * size = writer.size + BUF_SIZE + */ + } + + /* "yarl/_quoting_c.pyx":115 + * writer.buf = buf + * writer.size = size + * writer.buf[writer.pos] = <char>ch # <<<<<<<<<<<<<< + * writer.pos += 1 + * writer.changed |= changed + */ + (__pyx_v_writer->buf[__pyx_v_writer->pos]) = ((char)__pyx_v_ch); + + /* "yarl/_quoting_c.pyx":116 + * writer.size = size + * writer.buf[writer.pos] = <char>ch + * writer.pos += 1 # <<<<<<<<<<<<<< + * writer.changed |= changed + * return 0 + */ + __pyx_v_writer->pos = (__pyx_v_writer->pos + 1); + + /* "yarl/_quoting_c.pyx":117 + * writer.buf[writer.pos] = <char>ch + * writer.pos += 1 + * writer.changed |= changed # <<<<<<<<<<<<<< + * return 0 + * + */ + __pyx_v_writer->changed = (__pyx_v_writer->changed | __pyx_v_changed); + + /* "yarl/_quoting_c.pyx":118 + * writer.pos += 1 + * writer.changed |= changed + * return 0 # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = 0; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":95 + * + * + * cdef inline int _write_char(Writer* writer, Py_UCS4 ch, bint changed): # <<<<<<<<<<<<<< + * cdef char * buf + * cdef Py_ssize_t size + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_WriteUnraisable("yarl._quoting_c._write_char", __pyx_clineno, __pyx_lineno, __pyx_filename, 1, 0); + __pyx_r = 0; + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":121 + * + * + * cdef inline int _write_pct(Writer* writer, uint8_t ch, bint changed): # <<<<<<<<<<<<<< + * if _write_char(writer, '%', changed) < 0: + * return -1 + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_pct(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer, uint8_t __pyx_v_ch, int __pyx_v_changed) { + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + __Pyx_RefNannySetupContext("_write_pct", 0); + + /* "yarl/_quoting_c.pyx":122 + * + * cdef inline int _write_pct(Writer* writer, uint8_t ch, bint changed): + * if _write_char(writer, '%', changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, 37, __pyx_v_changed) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":123 + * cdef inline int _write_pct(Writer* writer, uint8_t ch, bint changed): + * if _write_char(writer, '%', changed) < 0: + * return -1 # <<<<<<<<<<<<<< + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: + * return -1 + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":122 + * + * cdef inline int _write_pct(Writer* writer, uint8_t ch, bint changed): + * if _write_char(writer, '%', changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: + */ + } + + /* "yarl/_quoting_c.pyx":124 + * if _write_char(writer, '%', changed) < 0: + * return -1 + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_char(writer, _to_hex(<uint8_t>ch & 0x0f), changed) + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, __pyx_f_4yarl_10_quoting_c__to_hex((((uint8_t)__pyx_v_ch) >> 4)), __pyx_v_changed) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":125 + * return -1 + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: + * return -1 # <<<<<<<<<<<<<< + * return _write_char(writer, _to_hex(<uint8_t>ch & 0x0f), changed) + * + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":124 + * if _write_char(writer, '%', changed) < 0: + * return -1 + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_char(writer, _to_hex(<uint8_t>ch & 0x0f), changed) + */ + } + + /* "yarl/_quoting_c.pyx":126 + * if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: + * return -1 + * return _write_char(writer, _to_hex(<uint8_t>ch & 0x0f), changed) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, __pyx_f_4yarl_10_quoting_c__to_hex((((uint8_t)__pyx_v_ch) & 0x0f)), __pyx_v_changed); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":121 + * + * + * cdef inline int _write_pct(Writer* writer, uint8_t ch, bint changed): # <<<<<<<<<<<<<< + * if _write_char(writer, '%', changed) < 0: + * return -1 + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":129 + * + * + * cdef inline int _write_percent(Writer* writer): # <<<<<<<<<<<<<< + * if _write_char(writer, '%', True) < 0: + * return -1 + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_percent(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer) { + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + __Pyx_RefNannySetupContext("_write_percent", 0); + + /* "yarl/_quoting_c.pyx":130 + * + * cdef inline int _write_percent(Writer* writer): + * if _write_char(writer, '%', True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_char(writer, '2', True) < 0: + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, 37, 1) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":131 + * cdef inline int _write_percent(Writer* writer): + * if _write_char(writer, '%', True) < 0: + * return -1 # <<<<<<<<<<<<<< + * if _write_char(writer, '2', True) < 0: + * return -1 + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":130 + * + * cdef inline int _write_percent(Writer* writer): + * if _write_char(writer, '%', True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_char(writer, '2', True) < 0: + */ + } + + /* "yarl/_quoting_c.pyx":132 + * if _write_char(writer, '%', True) < 0: + * return -1 + * if _write_char(writer, '2', True) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_char(writer, '5', True) + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, 50, 1) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":133 + * return -1 + * if _write_char(writer, '2', True) < 0: + * return -1 # <<<<<<<<<<<<<< + * return _write_char(writer, '5', True) + * + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":132 + * if _write_char(writer, '%', True) < 0: + * return -1 + * if _write_char(writer, '2', True) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_char(writer, '5', True) + */ + } + + /* "yarl/_quoting_c.pyx":134 + * if _write_char(writer, '2', True) < 0: + * return -1 + * return _write_char(writer, '5', True) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, 53, 1); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":129 + * + * + * cdef inline int _write_percent(Writer* writer): # <<<<<<<<<<<<<< + * if _write_char(writer, '%', True) < 0: + * return -1 + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":137 + * + * + * cdef inline int _write_pct_check(Writer* writer, Py_UCS4 ch, Py_UCS4 pct[]): # <<<<<<<<<<<<<< + * cdef Py_UCS4 pct1 = _to_hex(<uint8_t>ch >> 4) + * cdef Py_UCS4 pct2 = _to_hex(<uint8_t>ch & 0x0f) + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_pct_check(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer, Py_UCS4 __pyx_v_ch, Py_UCS4 *__pyx_v_pct) { + Py_UCS4 __pyx_v_pct1; + Py_UCS4 __pyx_v_pct2; + int __pyx_v_changed; + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + int __pyx_t_2; + __Pyx_RefNannySetupContext("_write_pct_check", 0); + + /* "yarl/_quoting_c.pyx":138 + * + * cdef inline int _write_pct_check(Writer* writer, Py_UCS4 ch, Py_UCS4 pct[]): + * cdef Py_UCS4 pct1 = _to_hex(<uint8_t>ch >> 4) # <<<<<<<<<<<<<< + * cdef Py_UCS4 pct2 = _to_hex(<uint8_t>ch & 0x0f) + * cdef bint changed = pct[0] != pct1 or pct[1] != pct2 + */ + __pyx_v_pct1 = __pyx_f_4yarl_10_quoting_c__to_hex((((uint8_t)__pyx_v_ch) >> 4)); + + /* "yarl/_quoting_c.pyx":139 + * cdef inline int _write_pct_check(Writer* writer, Py_UCS4 ch, Py_UCS4 pct[]): + * cdef Py_UCS4 pct1 = _to_hex(<uint8_t>ch >> 4) + * cdef Py_UCS4 pct2 = _to_hex(<uint8_t>ch & 0x0f) # <<<<<<<<<<<<<< + * cdef bint changed = pct[0] != pct1 or pct[1] != pct2 + * + */ + __pyx_v_pct2 = __pyx_f_4yarl_10_quoting_c__to_hex((((uint8_t)__pyx_v_ch) & 0x0f)); + + /* "yarl/_quoting_c.pyx":140 + * cdef Py_UCS4 pct1 = _to_hex(<uint8_t>ch >> 4) + * cdef Py_UCS4 pct2 = _to_hex(<uint8_t>ch & 0x0f) + * cdef bint changed = pct[0] != pct1 or pct[1] != pct2 # <<<<<<<<<<<<<< + * + * if _write_char(writer, '%', changed) < 0: + */ + __pyx_t_2 = (((__pyx_v_pct[0]) != __pyx_v_pct1) != 0); + if (!__pyx_t_2) { + } else { + __pyx_t_1 = __pyx_t_2; + goto __pyx_L3_bool_binop_done; + } + __pyx_t_2 = (((__pyx_v_pct[1]) != __pyx_v_pct2) != 0); + __pyx_t_1 = __pyx_t_2; + __pyx_L3_bool_binop_done:; + __pyx_v_changed = __pyx_t_1; + + /* "yarl/_quoting_c.pyx":142 + * cdef bint changed = pct[0] != pct1 or pct[1] != pct2 + * + * if _write_char(writer, '%', changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_char(writer, pct1, changed) < 0: + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, 37, __pyx_v_changed) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":143 + * + * if _write_char(writer, '%', changed) < 0: + * return -1 # <<<<<<<<<<<<<< + * if _write_char(writer, pct1, changed) < 0: + * return -1 + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":142 + * cdef bint changed = pct[0] != pct1 or pct[1] != pct2 + * + * if _write_char(writer, '%', changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_char(writer, pct1, changed) < 0: + */ + } + + /* "yarl/_quoting_c.pyx":144 + * if _write_char(writer, '%', changed) < 0: + * return -1 + * if _write_char(writer, pct1, changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_char(writer, pct2, changed) + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, __pyx_v_pct1, __pyx_v_changed) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":145 + * return -1 + * if _write_char(writer, pct1, changed) < 0: + * return -1 # <<<<<<<<<<<<<< + * return _write_char(writer, pct2, changed) + * + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":144 + * if _write_char(writer, '%', changed) < 0: + * return -1 + * if _write_char(writer, pct1, changed) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_char(writer, pct2, changed) + */ + } + + /* "yarl/_quoting_c.pyx":146 + * if _write_char(writer, pct1, changed) < 0: + * return -1 + * return _write_char(writer, pct2, changed) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, __pyx_v_pct2, __pyx_v_changed); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":137 + * + * + * cdef inline int _write_pct_check(Writer* writer, Py_UCS4 ch, Py_UCS4 pct[]): # <<<<<<<<<<<<<< + * cdef Py_UCS4 pct1 = _to_hex(<uint8_t>ch >> 4) + * cdef Py_UCS4 pct2 = _to_hex(<uint8_t>ch & 0x0f) + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":149 + * + * + * cdef inline int _write_utf8(Writer* writer, Py_UCS4 symbol): # <<<<<<<<<<<<<< + * cdef uint64_t utf = <uint64_t> symbol + * + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c__write_utf8(struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer, Py_UCS4 __pyx_v_symbol) { + uint64_t __pyx_v_utf; + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + int __pyx_t_2; + __Pyx_RefNannySetupContext("_write_utf8", 0); + + /* "yarl/_quoting_c.pyx":150 + * + * cdef inline int _write_utf8(Writer* writer, Py_UCS4 symbol): + * cdef uint64_t utf = <uint64_t> symbol # <<<<<<<<<<<<<< + * + * if utf < 0x80: + */ + __pyx_v_utf = ((uint64_t)__pyx_v_symbol); + + /* "yarl/_quoting_c.pyx":152 + * cdef uint64_t utf = <uint64_t> symbol + * + * if utf < 0x80: # <<<<<<<<<<<<<< + * return _write_pct(writer, <uint8_t>utf, True) + * elif utf < 0x800: + */ + __pyx_t_1 = ((__pyx_v_utf < 0x80) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":153 + * + * if utf < 0x80: + * return _write_pct(writer, <uint8_t>utf, True) # <<<<<<<<<<<<<< + * elif utf < 0x800: + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)__pyx_v_utf), 1); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":152 + * cdef uint64_t utf = <uint64_t> symbol + * + * if utf < 0x80: # <<<<<<<<<<<<<< + * return _write_pct(writer, <uint8_t>utf, True) + * elif utf < 0x800: + */ + } + + /* "yarl/_quoting_c.pyx":154 + * if utf < 0x80: + * return _write_pct(writer, <uint8_t>utf, True) + * elif utf < 0x800: # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: + * return -1 + */ + __pyx_t_1 = ((__pyx_v_utf < 0x800) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":155 + * return _write_pct(writer, <uint8_t>utf, True) + * elif utf < 0x800: + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + */ + __pyx_t_1 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0xc0 | (__pyx_v_utf >> 6))), 1) < 0) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":156 + * elif utf < 0x800: + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: + * return -1 # <<<<<<<<<<<<<< + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * elif 0xD800 <= utf <= 0xDFFF: + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":155 + * return _write_pct(writer, <uint8_t>utf, True) + * elif utf < 0x800: + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + */ + } + + /* "yarl/_quoting_c.pyx":157 + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) # <<<<<<<<<<<<<< + * elif 0xD800 <= utf <= 0xDFFF: + * # surogate pair, ignored + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0x80 | (__pyx_v_utf & 0x3f))), 1); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":154 + * if utf < 0x80: + * return _write_pct(writer, <uint8_t>utf, True) + * elif utf < 0x800: # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: + * return -1 + */ + } + + /* "yarl/_quoting_c.pyx":158 + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * elif 0xD800 <= utf <= 0xDFFF: # <<<<<<<<<<<<<< + * # surogate pair, ignored + * return 0 + */ + __pyx_t_1 = (0xD800 <= __pyx_v_utf); + if (__pyx_t_1) { + __pyx_t_1 = (__pyx_v_utf <= 0xDFFF); + } + __pyx_t_2 = (__pyx_t_1 != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":160 + * elif 0xD800 <= utf <= 0xDFFF: + * # surogate pair, ignored + * return 0 # <<<<<<<<<<<<<< + * elif utf < 0x10000: + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + */ + __pyx_r = 0; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":158 + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * elif 0xD800 <= utf <= 0xDFFF: # <<<<<<<<<<<<<< + * # surogate pair, ignored + * return 0 + */ + } + + /* "yarl/_quoting_c.pyx":161 + * # surogate pair, ignored + * return 0 + * elif utf < 0x10000: # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + * return -1 + */ + __pyx_t_2 = ((__pyx_v_utf < 0x10000) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":162 + * return 0 + * elif utf < 0x10000: + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + */ + __pyx_t_2 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0xe0 | (__pyx_v_utf >> 12))), 1) < 0) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":163 + * elif utf < 0x10000: + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + * return -1 # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + * True) < 0: + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":162 + * return 0 + * elif utf < 0x10000: + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + */ + } + + /* "yarl/_quoting_c.pyx":165 + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + * True) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + */ + __pyx_t_2 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0x80 | ((__pyx_v_utf >> 6) & 0x3f))), 1) < 0) != 0); + + /* "yarl/_quoting_c.pyx":164 + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), # <<<<<<<<<<<<<< + * True) < 0: + * return -1 + */ + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":166 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + * True) < 0: + * return -1 # <<<<<<<<<<<<<< + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * elif utf > 0x10FFFF: + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":164 + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), # <<<<<<<<<<<<<< + * True) < 0: + * return -1 + */ + } + + /* "yarl/_quoting_c.pyx":167 + * True) < 0: + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) # <<<<<<<<<<<<<< + * elif utf > 0x10FFFF: + * # symbol is too large + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0x80 | (__pyx_v_utf & 0x3f))), 1); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":161 + * # surogate pair, ignored + * return 0 + * elif utf < 0x10000: # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + * return -1 + */ + } + + /* "yarl/_quoting_c.pyx":168 + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * elif utf > 0x10FFFF: # <<<<<<<<<<<<<< + * # symbol is too large + * return 0 + */ + __pyx_t_2 = ((__pyx_v_utf > 0x10FFFF) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":170 + * elif utf > 0x10FFFF: + * # symbol is too large + * return 0 # <<<<<<<<<<<<<< + * else: + * if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: + */ + __pyx_r = 0; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":168 + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * elif utf > 0x10FFFF: # <<<<<<<<<<<<<< + * # symbol is too large + * return 0 + */ + } + + /* "yarl/_quoting_c.pyx":172 + * return 0 + * else: + * if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), + */ + /*else*/ { + __pyx_t_2 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0xf0 | (__pyx_v_utf >> 18))), 1) < 0) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":173 + * else: + * if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: + * return -1 # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), + * True) < 0: + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":172 + * return 0 + * else: + * if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), + */ + } + + /* "yarl/_quoting_c.pyx":175 + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), + * True) < 0: # <<<<<<<<<<<<<< + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + */ + __pyx_t_2 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0x80 | ((__pyx_v_utf >> 12) & 0x3f))), 1) < 0) != 0); + + /* "yarl/_quoting_c.pyx":174 + * if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), # <<<<<<<<<<<<<< + * True) < 0: + * return -1 + */ + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":176 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), + * True) < 0: + * return -1 # <<<<<<<<<<<<<< + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + * True) < 0: + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":174 + * if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), # <<<<<<<<<<<<<< + * True) < 0: + * return -1 + */ + } + + /* "yarl/_quoting_c.pyx":178 + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + * True) < 0: # <<<<<<<<<<<<<< + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + */ + __pyx_t_2 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0x80 | ((__pyx_v_utf >> 6) & 0x3f))), 1) < 0) != 0); + + /* "yarl/_quoting_c.pyx":177 + * True) < 0: + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), # <<<<<<<<<<<<<< + * True) < 0: + * return -1 + */ + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":179 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + * True) < 0: + * return -1 # <<<<<<<<<<<<<< + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + * + */ + __pyx_r = -1; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":177 + * True) < 0: + * return -1 + * if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), # <<<<<<<<<<<<<< + * True) < 0: + * return -1 + */ + } + + /* "yarl/_quoting_c.pyx":180 + * True) < 0: + * return -1 + * return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, ((uint8_t)(0x80 | (__pyx_v_utf & 0x3f))), 1); + goto __pyx_L0; + } + + /* "yarl/_quoting_c.pyx":149 + * + * + * cdef inline int _write_utf8(Writer* writer, Py_UCS4 symbol): # <<<<<<<<<<<<<< + * cdef uint64_t utf = <uint64_t> symbol + * + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":193 + * cdef uint8_t _protected_table[16] + * + * def __init__( # <<<<<<<<<<<<<< + * self, *, str safe='', str protected='', bint qs=False, bint requote=True, + * ): + */ + +/* Python wrapper */ +static int __pyx_pw_4yarl_10_quoting_c_7_Quoter_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ +static int __pyx_pw_4yarl_10_quoting_c_7_Quoter_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { + PyObject *__pyx_v_safe = 0; + PyObject *__pyx_v_protected = 0; + int __pyx_v_qs; + int __pyx_v_requote; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + int __pyx_r; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__init__ (wrapper)", 0); + { + static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_safe,&__pyx_n_s_protected,&__pyx_n_s_qs,&__pyx_n_s_requote,0}; + PyObject* values[4] = {0,0,0,0}; + values[0] = ((PyObject*)__pyx_kp_u_); + values[1] = ((PyObject*)__pyx_kp_u_); + if (unlikely(__pyx_kwds)) { + Py_ssize_t kw_args; + const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); + switch (pos_args) { + case 0: break; + default: goto __pyx_L5_argtuple_error; + } + kw_args = PyDict_Size(__pyx_kwds); + if (kw_args > 0 && likely(kw_args <= 4)) { + Py_ssize_t index; + for (index = 0; index < 4 && kw_args > 0; index++) { + PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, *__pyx_pyargnames[index]); + if (value) { values[index] = value; kw_args--; } + } + } + if (unlikely(kw_args > 0)) { + if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, 0, "__init__") < 0)) __PYX_ERR(0, 193, __pyx_L3_error) + } + } else if (PyTuple_GET_SIZE(__pyx_args) != 0) { + goto __pyx_L5_argtuple_error; + } else { + } + __pyx_v_safe = ((PyObject*)values[0]); + __pyx_v_protected = ((PyObject*)values[1]); + if (values[2]) { + __pyx_v_qs = __Pyx_PyObject_IsTrue(values[2]); if (unlikely((__pyx_v_qs == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 194, __pyx_L3_error) + } else { + + /* "yarl/_quoting_c.pyx":194 + * + * def __init__( + * self, *, str safe='', str protected='', bint qs=False, bint requote=True, # <<<<<<<<<<<<<< + * ): + * cdef Py_UCS4 ch + */ + __pyx_v_qs = ((int)0); + } + if (values[3]) { + __pyx_v_requote = __Pyx_PyObject_IsTrue(values[3]); if (unlikely((__pyx_v_requote == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 194, __pyx_L3_error) + } else { + __pyx_v_requote = ((int)1); + } + } + goto __pyx_L4_argument_unpacking_done; + __pyx_L5_argtuple_error:; + __Pyx_RaiseArgtupleInvalid("__init__", 1, 0, 0, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 193, __pyx_L3_error) + __pyx_L3_error:; + __Pyx_AddTraceback("yarl._quoting_c._Quoter.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __Pyx_RefNannyFinishContext(); + return -1; + __pyx_L4_argument_unpacking_done:; + if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_safe), (&PyUnicode_Type), 1, "safe", 1))) __PYX_ERR(0, 194, __pyx_L1_error) + if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_protected), (&PyUnicode_Type), 1, "protected", 1))) __PYX_ERR(0, 194, __pyx_L1_error) + __pyx_r = __pyx_pf_4yarl_10_quoting_c_7_Quoter___init__(((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_v_self), __pyx_v_safe, __pyx_v_protected, __pyx_v_qs, __pyx_v_requote); + + /* "yarl/_quoting_c.pyx":193 + * cdef uint8_t _protected_table[16] + * + * def __init__( # <<<<<<<<<<<<<< + * self, *, str safe='', str protected='', bint qs=False, bint requote=True, + * ): + */ + + /* function exit code */ + goto __pyx_L0; + __pyx_L1_error:; + __pyx_r = -1; + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static int __pyx_pf_4yarl_10_quoting_c_7_Quoter___init__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v_safe, PyObject *__pyx_v_protected, int __pyx_v_qs, int __pyx_v_requote) { + Py_UCS4 __pyx_v_ch; + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + PyObject *__pyx_t_2 = NULL; + Py_ssize_t __pyx_t_3; + Py_ssize_t __pyx_t_4; + void *__pyx_t_5; + int __pyx_t_6; + int __pyx_t_7; + Py_ssize_t __pyx_t_8; + PyObject *__pyx_t_9 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__init__", 0); + + /* "yarl/_quoting_c.pyx":198 + * cdef Py_UCS4 ch + * + * self._qs = qs # <<<<<<<<<<<<<< + * self._requote = requote + * + */ + __pyx_v_self->_qs = __pyx_v_qs; + + /* "yarl/_quoting_c.pyx":199 + * + * self._qs = qs + * self._requote = requote # <<<<<<<<<<<<<< + * + * if not self._qs: + */ + __pyx_v_self->_requote = __pyx_v_requote; + + /* "yarl/_quoting_c.pyx":201 + * self._requote = requote + * + * if not self._qs: # <<<<<<<<<<<<<< + * memcpy(self._safe_table, + * ALLOWED_NOTQS_TABLE, + */ + __pyx_t_1 = ((!(__pyx_v_self->_qs != 0)) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":202 + * + * if not self._qs: + * memcpy(self._safe_table, # <<<<<<<<<<<<<< + * ALLOWED_NOTQS_TABLE, + * sizeof(self._safe_table)) + */ + (void)(memcpy(__pyx_v_self->_safe_table, __pyx_v_4yarl_10_quoting_c_ALLOWED_NOTQS_TABLE, (sizeof(__pyx_v_self->_safe_table)))); + + /* "yarl/_quoting_c.pyx":201 + * self._requote = requote + * + * if not self._qs: # <<<<<<<<<<<<<< + * memcpy(self._safe_table, + * ALLOWED_NOTQS_TABLE, + */ + goto __pyx_L3; + } + + /* "yarl/_quoting_c.pyx":206 + * sizeof(self._safe_table)) + * else: + * memcpy(self._safe_table, # <<<<<<<<<<<<<< + * ALLOWED_TABLE, + * sizeof(self._safe_table)) + */ + /*else*/ { + + /* "yarl/_quoting_c.pyx":208 + * memcpy(self._safe_table, + * ALLOWED_TABLE, + * sizeof(self._safe_table)) # <<<<<<<<<<<<<< + * for ch in safe: + * if ord(ch) > 127: + */ + (void)(memcpy(__pyx_v_self->_safe_table, __pyx_v_4yarl_10_quoting_c_ALLOWED_TABLE, (sizeof(__pyx_v_self->_safe_table)))); + } + __pyx_L3:; + + /* "yarl/_quoting_c.pyx":209 + * ALLOWED_TABLE, + * sizeof(self._safe_table)) + * for ch in safe: # <<<<<<<<<<<<<< + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + */ + if (unlikely(__pyx_v_safe == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' is not iterable"); + __PYX_ERR(0, 209, __pyx_L1_error) + } + __Pyx_INCREF(__pyx_v_safe); + __pyx_t_2 = __pyx_v_safe; + __pyx_t_7 = __Pyx_init_unicode_iteration(__pyx_t_2, (&__pyx_t_4), (&__pyx_t_5), (&__pyx_t_6)); if (unlikely(__pyx_t_7 == ((int)-1))) __PYX_ERR(0, 209, __pyx_L1_error) + for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_4; __pyx_t_8++) { + __pyx_t_3 = __pyx_t_8; + __pyx_v_ch = __Pyx_PyUnicode_READ(__pyx_t_6, __pyx_t_5, __pyx_t_3); + + /* "yarl/_quoting_c.pyx":210 + * sizeof(self._safe_table)) + * for ch in safe: + * if ord(ch) > 127: # <<<<<<<<<<<<<< + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) + */ + __pyx_t_1 = ((((long)__pyx_v_ch) > 0x7F) != 0); + if (unlikely(__pyx_t_1)) { + + /* "yarl/_quoting_c.pyx":211 + * for ch in safe: + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") # <<<<<<<<<<<<<< + * set_bit(self._safe_table, ch) + * + */ + __pyx_t_9 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 211, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_9); + __Pyx_Raise(__pyx_t_9, 0, 0, 0); + __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; + __PYX_ERR(0, 211, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":210 + * sizeof(self._safe_table)) + * for ch in safe: + * if ord(ch) > 127: # <<<<<<<<<<<<<< + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) + */ + } + + /* "yarl/_quoting_c.pyx":212 + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) # <<<<<<<<<<<<<< + * + * memset(self._protected_table, 0, sizeof(self._protected_table)) + */ + __pyx_f_4yarl_10_quoting_c_set_bit(__pyx_v_self->_safe_table, __pyx_v_ch); + } + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + + /* "yarl/_quoting_c.pyx":214 + * set_bit(self._safe_table, ch) + * + * memset(self._protected_table, 0, sizeof(self._protected_table)) # <<<<<<<<<<<<<< + * for ch in protected: + * if ord(ch) > 127: + */ + (void)(memset(__pyx_v_self->_protected_table, 0, (sizeof(__pyx_v_self->_protected_table)))); + + /* "yarl/_quoting_c.pyx":215 + * + * memset(self._protected_table, 0, sizeof(self._protected_table)) + * for ch in protected: # <<<<<<<<<<<<<< + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + */ + if (unlikely(__pyx_v_protected == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' is not iterable"); + __PYX_ERR(0, 215, __pyx_L1_error) + } + __Pyx_INCREF(__pyx_v_protected); + __pyx_t_2 = __pyx_v_protected; + __pyx_t_7 = __Pyx_init_unicode_iteration(__pyx_t_2, (&__pyx_t_3), (&__pyx_t_5), (&__pyx_t_6)); if (unlikely(__pyx_t_7 == ((int)-1))) __PYX_ERR(0, 215, __pyx_L1_error) + for (__pyx_t_8 = 0; __pyx_t_8 < __pyx_t_3; __pyx_t_8++) { + __pyx_t_4 = __pyx_t_8; + __pyx_v_ch = __Pyx_PyUnicode_READ(__pyx_t_6, __pyx_t_5, __pyx_t_4); + + /* "yarl/_quoting_c.pyx":216 + * memset(self._protected_table, 0, sizeof(self._protected_table)) + * for ch in protected: + * if ord(ch) > 127: # <<<<<<<<<<<<<< + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) + */ + __pyx_t_1 = ((((long)__pyx_v_ch) > 0x7F) != 0); + if (unlikely(__pyx_t_1)) { + + /* "yarl/_quoting_c.pyx":217 + * for ch in protected: + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") # <<<<<<<<<<<<<< + * set_bit(self._safe_table, ch) + * set_bit(self._protected_table, ch) + */ + __pyx_t_9 = __Pyx_PyObject_Call(__pyx_builtin_ValueError, __pyx_tuple__2, NULL); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 217, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_9); + __Pyx_Raise(__pyx_t_9, 0, 0, 0); + __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; + __PYX_ERR(0, 217, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":216 + * memset(self._protected_table, 0, sizeof(self._protected_table)) + * for ch in protected: + * if ord(ch) > 127: # <<<<<<<<<<<<<< + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) + */ + } + + /* "yarl/_quoting_c.pyx":218 + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) # <<<<<<<<<<<<<< + * set_bit(self._protected_table, ch) + * + */ + __pyx_f_4yarl_10_quoting_c_set_bit(__pyx_v_self->_safe_table, __pyx_v_ch); + + /* "yarl/_quoting_c.pyx":219 + * raise ValueError("Only safe symbols with ORD < 128 are allowed") + * set_bit(self._safe_table, ch) + * set_bit(self._protected_table, ch) # <<<<<<<<<<<<<< + * + * def __call__(self, val): + */ + __pyx_f_4yarl_10_quoting_c_set_bit(__pyx_v_self->_protected_table, __pyx_v_ch); + } + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + + /* "yarl/_quoting_c.pyx":193 + * cdef uint8_t _protected_table[16] + * + * def __init__( # <<<<<<<<<<<<<< + * self, *, str safe='', str protected='', bint qs=False, bint requote=True, + * ): + */ + + /* function exit code */ + __pyx_r = 0; + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_2); + __Pyx_XDECREF(__pyx_t_9); + __Pyx_AddTraceback("yarl._quoting_c._Quoter.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = -1; + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":221 + * set_bit(self._protected_table, ch) + * + * def __call__(self, val): # <<<<<<<<<<<<<< + * cdef Writer writer + * if val is None: + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_7_Quoter_3__call__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ +static PyObject *__pyx_pw_4yarl_10_quoting_c_7_Quoter_3__call__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { + PyObject *__pyx_v_val = 0; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__call__ (wrapper)", 0); + { + static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_val,0}; + PyObject* values[1] = {0}; + if (unlikely(__pyx_kwds)) { + Py_ssize_t kw_args; + const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); + switch (pos_args) { + case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + CYTHON_FALLTHROUGH; + case 0: break; + default: goto __pyx_L5_argtuple_error; + } + kw_args = PyDict_Size(__pyx_kwds); + switch (pos_args) { + case 0: + if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_val)) != 0)) kw_args--; + else goto __pyx_L5_argtuple_error; + } + if (unlikely(kw_args > 0)) { + if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__call__") < 0)) __PYX_ERR(0, 221, __pyx_L3_error) + } + } else if (PyTuple_GET_SIZE(__pyx_args) != 1) { + goto __pyx_L5_argtuple_error; + } else { + values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + } + __pyx_v_val = values[0]; + } + goto __pyx_L4_argument_unpacking_done; + __pyx_L5_argtuple_error:; + __Pyx_RaiseArgtupleInvalid("__call__", 1, 1, 1, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 221, __pyx_L3_error) + __pyx_L3_error:; + __Pyx_AddTraceback("yarl._quoting_c._Quoter.__call__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __Pyx_RefNannyFinishContext(); + return NULL; + __pyx_L4_argument_unpacking_done:; + __pyx_r = __pyx_pf_4yarl_10_quoting_c_7_Quoter_2__call__(((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_v_self), __pyx_v_val); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_7_Quoter_2__call__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v_val) { + struct __pyx_t_4yarl_10_quoting_c_Writer __pyx_v_writer; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + int __pyx_t_2; + PyObject *__pyx_t_3 = NULL; + int __pyx_t_4; + int __pyx_t_5; + char const *__pyx_t_6; + PyObject *__pyx_t_7 = NULL; + PyObject *__pyx_t_8 = NULL; + PyObject *__pyx_t_9 = NULL; + PyObject *__pyx_t_10 = NULL; + PyObject *__pyx_t_11 = NULL; + PyObject *__pyx_t_12 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__call__", 0); + __Pyx_INCREF(__pyx_v_val); + + /* "yarl/_quoting_c.pyx":223 + * def __call__(self, val): + * cdef Writer writer + * if val is None: # <<<<<<<<<<<<<< + * return None + * if type(val) is not str: + */ + __pyx_t_1 = (__pyx_v_val == Py_None); + __pyx_t_2 = (__pyx_t_1 != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":224 + * cdef Writer writer + * if val is None: + * return None # <<<<<<<<<<<<<< + * if type(val) is not str: + * if isinstance(val, str): + */ + __Pyx_XDECREF(__pyx_r); + __pyx_r = Py_None; __Pyx_INCREF(Py_None); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":223 + * def __call__(self, val): + * cdef Writer writer + * if val is None: # <<<<<<<<<<<<<< + * return None + * if type(val) is not str: + */ + } + + /* "yarl/_quoting_c.pyx":225 + * if val is None: + * return None + * if type(val) is not str: # <<<<<<<<<<<<<< + * if isinstance(val, str): + * # derived from str + */ + __pyx_t_2 = (((PyObject *)Py_TYPE(__pyx_v_val)) != ((PyObject *)(&PyUnicode_Type))); + __pyx_t_1 = (__pyx_t_2 != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":226 + * return None + * if type(val) is not str: + * if isinstance(val, str): # <<<<<<<<<<<<<< + * # derived from str + * val = str(val) + */ + __pyx_t_1 = PyUnicode_Check(__pyx_v_val); + __pyx_t_2 = (__pyx_t_1 != 0); + if (likely(__pyx_t_2)) { + + /* "yarl/_quoting_c.pyx":228 + * if isinstance(val, str): + * # derived from str + * val = str(val) # <<<<<<<<<<<<<< + * else: + * raise TypeError("Argument should be str") + */ + __pyx_t_3 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyUnicode_Type)), __pyx_v_val); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 228, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF_SET(__pyx_v_val, __pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":226 + * return None + * if type(val) is not str: + * if isinstance(val, str): # <<<<<<<<<<<<<< + * # derived from str + * val = str(val) + */ + goto __pyx_L5; + } + + /* "yarl/_quoting_c.pyx":230 + * val = str(val) + * else: + * raise TypeError("Argument should be str") # <<<<<<<<<<<<<< + * _init_writer(&writer) + * try: + */ + /*else*/ { + __pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_TypeError, __pyx_tuple__3, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 230, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_Raise(__pyx_t_3, 0, 0, 0); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __PYX_ERR(0, 230, __pyx_L1_error) + } + __pyx_L5:; + + /* "yarl/_quoting_c.pyx":225 + * if val is None: + * return None + * if type(val) is not str: # <<<<<<<<<<<<<< + * if isinstance(val, str): + * # derived from str + */ + } + + /* "yarl/_quoting_c.pyx":231 + * else: + * raise TypeError("Argument should be str") + * _init_writer(&writer) # <<<<<<<<<<<<<< + * try: + * return self._do_quote(<str>val, &writer) + */ + __pyx_f_4yarl_10_quoting_c__init_writer((&__pyx_v_writer)); + + /* "yarl/_quoting_c.pyx":232 + * raise TypeError("Argument should be str") + * _init_writer(&writer) + * try: # <<<<<<<<<<<<<< + * return self._do_quote(<str>val, &writer) + * finally: + */ + /*try:*/ { + + /* "yarl/_quoting_c.pyx":233 + * _init_writer(&writer) + * try: + * return self._do_quote(<str>val, &writer) # <<<<<<<<<<<<<< + * finally: + * _release_writer(&writer) + */ + __Pyx_XDECREF(__pyx_r); + __pyx_t_3 = ((struct __pyx_vtabstruct_4yarl_10_quoting_c__Quoter *)__pyx_v_self->__pyx_vtab)->_do_quote(__pyx_v_self, ((PyObject*)__pyx_v_val), (&__pyx_v_writer)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 233, __pyx_L7_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_r = __pyx_t_3; + __pyx_t_3 = 0; + goto __pyx_L6_return; + } + + /* "yarl/_quoting_c.pyx":235 + * return self._do_quote(<str>val, &writer) + * finally: + * _release_writer(&writer) # <<<<<<<<<<<<<< + * + * cdef str _do_quote(self, str val, Writer *writer): + */ + /*finally:*/ { + __pyx_L7_error:; + /*exception exit:*/{ + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + __pyx_t_7 = 0; __pyx_t_8 = 0; __pyx_t_9 = 0; __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_t_12 = 0; + __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; + if (PY_MAJOR_VERSION >= 3) __Pyx_ExceptionSwap(&__pyx_t_10, &__pyx_t_11, &__pyx_t_12); + if ((PY_MAJOR_VERSION < 3) || unlikely(__Pyx_GetException(&__pyx_t_7, &__pyx_t_8, &__pyx_t_9) < 0)) __Pyx_ErrFetch(&__pyx_t_7, &__pyx_t_8, &__pyx_t_9); + __Pyx_XGOTREF(__pyx_t_7); + __Pyx_XGOTREF(__pyx_t_8); + __Pyx_XGOTREF(__pyx_t_9); + __Pyx_XGOTREF(__pyx_t_10); + __Pyx_XGOTREF(__pyx_t_11); + __Pyx_XGOTREF(__pyx_t_12); + __pyx_t_4 = __pyx_lineno; __pyx_t_5 = __pyx_clineno; __pyx_t_6 = __pyx_filename; + { + __pyx_f_4yarl_10_quoting_c__release_writer((&__pyx_v_writer)); + } + if (PY_MAJOR_VERSION >= 3) { + __Pyx_XGIVEREF(__pyx_t_10); + __Pyx_XGIVEREF(__pyx_t_11); + __Pyx_XGIVEREF(__pyx_t_12); + __Pyx_ExceptionReset(__pyx_t_10, __pyx_t_11, __pyx_t_12); + } + __Pyx_XGIVEREF(__pyx_t_7); + __Pyx_XGIVEREF(__pyx_t_8); + __Pyx_XGIVEREF(__pyx_t_9); + __Pyx_ErrRestore(__pyx_t_7, __pyx_t_8, __pyx_t_9); + __pyx_t_7 = 0; __pyx_t_8 = 0; __pyx_t_9 = 0; __pyx_t_10 = 0; __pyx_t_11 = 0; __pyx_t_12 = 0; + __pyx_lineno = __pyx_t_4; __pyx_clineno = __pyx_t_5; __pyx_filename = __pyx_t_6; + goto __pyx_L1_error; + } + __pyx_L6_return: { + __pyx_t_12 = __pyx_r; + __pyx_r = 0; + __pyx_f_4yarl_10_quoting_c__release_writer((&__pyx_v_writer)); + __pyx_r = __pyx_t_12; + __pyx_t_12 = 0; + goto __pyx_L0; + } + } + + /* "yarl/_quoting_c.pyx":221 + * set_bit(self._protected_table, ch) + * + * def __call__(self, val): # <<<<<<<<<<<<<< + * cdef Writer writer + * if val is None: + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_3); + __Pyx_AddTraceback("yarl._quoting_c._Quoter.__call__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v_val); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":237 + * _release_writer(&writer) + * + * cdef str _do_quote(self, str val, Writer *writer): # <<<<<<<<<<<<<< + * cdef Py_UCS4 ch + * cdef int has_pct = 0 + */ + +static PyObject *__pyx_f_4yarl_10_quoting_c_7_Quoter__do_quote(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v_val, struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer) { + Py_UCS4 __pyx_v_ch; + int __pyx_v_has_pct; + Py_UCS4 __pyx_v_pct[2]; + CYTHON_UNUSED int __pyx_v_idx; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + Py_ssize_t __pyx_t_2; + Py_ssize_t __pyx_t_3; + void *__pyx_t_4; + int __pyx_t_5; + int __pyx_t_6; + Py_ssize_t __pyx_t_7; + int __pyx_t_8; + int __pyx_t_9; + PyObject *__pyx_t_10 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("_do_quote", 0); + + /* "yarl/_quoting_c.pyx":239 + * cdef str _do_quote(self, str val, Writer *writer): + * cdef Py_UCS4 ch + * cdef int has_pct = 0 # <<<<<<<<<<<<<< + * cdef Py_UCS4 pct[2] + * cdef int idx = 0 + */ + __pyx_v_has_pct = 0; + + /* "yarl/_quoting_c.pyx":241 + * cdef int has_pct = 0 + * cdef Py_UCS4 pct[2] + * cdef int idx = 0 # <<<<<<<<<<<<<< + * + * for ch in val: + */ + __pyx_v_idx = 0; + + /* "yarl/_quoting_c.pyx":243 + * cdef int idx = 0 + * + * for ch in val: # <<<<<<<<<<<<<< + * if has_pct: + * pct[has_pct-1] = ch + */ + if (unlikely(__pyx_v_val == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' is not iterable"); + __PYX_ERR(0, 243, __pyx_L1_error) + } + __Pyx_INCREF(__pyx_v_val); + __pyx_t_1 = __pyx_v_val; + __pyx_t_6 = __Pyx_init_unicode_iteration(__pyx_t_1, (&__pyx_t_3), (&__pyx_t_4), (&__pyx_t_5)); if (unlikely(__pyx_t_6 == ((int)-1))) __PYX_ERR(0, 243, __pyx_L1_error) + for (__pyx_t_7 = 0; __pyx_t_7 < __pyx_t_3; __pyx_t_7++) { + __pyx_t_2 = __pyx_t_7; + __pyx_v_ch = __Pyx_PyUnicode_READ(__pyx_t_5, __pyx_t_4, __pyx_t_2); + + /* "yarl/_quoting_c.pyx":244 + * + * for ch in val: + * if has_pct: # <<<<<<<<<<<<<< + * pct[has_pct-1] = ch + * has_pct += 1 + */ + __pyx_t_8 = (__pyx_v_has_pct != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":245 + * for ch in val: + * if has_pct: + * pct[has_pct-1] = ch # <<<<<<<<<<<<<< + * has_pct += 1 + * if has_pct == 3: + */ + (__pyx_v_pct[(__pyx_v_has_pct - 1)]) = __pyx_v_ch; + + /* "yarl/_quoting_c.pyx":246 + * if has_pct: + * pct[has_pct-1] = ch + * has_pct += 1 # <<<<<<<<<<<<<< + * if has_pct == 3: + * ch = _restore_ch(pct[0], pct[1]) + */ + __pyx_v_has_pct = (__pyx_v_has_pct + 1); + + /* "yarl/_quoting_c.pyx":247 + * pct[has_pct-1] = ch + * has_pct += 1 + * if has_pct == 3: # <<<<<<<<<<<<<< + * ch = _restore_ch(pct[0], pct[1]) + * has_pct = 0 + */ + __pyx_t_8 = ((__pyx_v_has_pct == 3) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":248 + * has_pct += 1 + * if has_pct == 3: + * ch = _restore_ch(pct[0], pct[1]) # <<<<<<<<<<<<<< + * has_pct = 0 + * + */ + __pyx_v_ch = __pyx_f_4yarl_10_quoting_c__restore_ch((__pyx_v_pct[0]), (__pyx_v_pct[1])); + + /* "yarl/_quoting_c.pyx":249 + * if has_pct == 3: + * ch = _restore_ch(pct[0], pct[1]) + * has_pct = 0 # <<<<<<<<<<<<<< + * + * if ch == <Py_UCS4>-1: + */ + __pyx_v_has_pct = 0; + + /* "yarl/_quoting_c.pyx":251 + * has_pct = 0 + * + * if ch == <Py_UCS4>-1: # <<<<<<<<<<<<<< + * if _write_percent(writer) < 0: + * raise + */ + __pyx_t_8 = ((__pyx_v_ch == ((Py_UCS4)-1L)) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":252 + * + * if ch == <Py_UCS4>-1: + * if _write_percent(writer) < 0: # <<<<<<<<<<<<<< + * raise + * if self._write(writer, pct[0]) < 0: + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c__write_percent(__pyx_v_writer) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":253 + * if ch == <Py_UCS4>-1: + * if _write_percent(writer) < 0: + * raise # <<<<<<<<<<<<<< + * if self._write(writer, pct[0]) < 0: + * raise + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 253, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":252 + * + * if ch == <Py_UCS4>-1: + * if _write_percent(writer) < 0: # <<<<<<<<<<<<<< + * raise + * if self._write(writer, pct[0]) < 0: + */ + } + + /* "yarl/_quoting_c.pyx":254 + * if _write_percent(writer) < 0: + * raise + * if self._write(writer, pct[0]) < 0: # <<<<<<<<<<<<<< + * raise + * if self._write(writer, pct[1]) < 0: + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c_7_Quoter__write(__pyx_v_self, __pyx_v_writer, (__pyx_v_pct[0])) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":255 + * raise + * if self._write(writer, pct[0]) < 0: + * raise # <<<<<<<<<<<<<< + * if self._write(writer, pct[1]) < 0: + * raise + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 255, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":254 + * if _write_percent(writer) < 0: + * raise + * if self._write(writer, pct[0]) < 0: # <<<<<<<<<<<<<< + * raise + * if self._write(writer, pct[1]) < 0: + */ + } + + /* "yarl/_quoting_c.pyx":256 + * if self._write(writer, pct[0]) < 0: + * raise + * if self._write(writer, pct[1]) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c_7_Quoter__write(__pyx_v_self, __pyx_v_writer, (__pyx_v_pct[1])) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":257 + * raise + * if self._write(writer, pct[1]) < 0: + * raise # <<<<<<<<<<<<<< + * continue + * + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 257, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":256 + * if self._write(writer, pct[0]) < 0: + * raise + * if self._write(writer, pct[1]) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + } + + /* "yarl/_quoting_c.pyx":258 + * if self._write(writer, pct[1]) < 0: + * raise + * continue # <<<<<<<<<<<<<< + * + * if ch < 128: + */ + goto __pyx_L3_continue; + + /* "yarl/_quoting_c.pyx":251 + * has_pct = 0 + * + * if ch == <Py_UCS4>-1: # <<<<<<<<<<<<<< + * if _write_percent(writer) < 0: + * raise + */ + } + + /* "yarl/_quoting_c.pyx":260 + * continue + * + * if ch < 128: # <<<<<<<<<<<<<< + * if bit_at(self._protected_table, ch): + * if _write_pct(writer, ch, True) < 0: + */ + __pyx_t_8 = ((__pyx_v_ch < 0x80) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":261 + * + * if ch < 128: + * if bit_at(self._protected_table, ch): # <<<<<<<<<<<<<< + * if _write_pct(writer, ch, True) < 0: + * raise + */ + __pyx_t_8 = (__pyx_f_4yarl_10_quoting_c_bit_at(__pyx_v_self->_protected_table, __pyx_v_ch) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":262 + * if ch < 128: + * if bit_at(self._protected_table, ch): + * if _write_pct(writer, ch, True) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c__write_pct(__pyx_v_writer, __pyx_v_ch, 1) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":263 + * if bit_at(self._protected_table, ch): + * if _write_pct(writer, ch, True) < 0: + * raise # <<<<<<<<<<<<<< + * continue + * + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 263, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":262 + * if ch < 128: + * if bit_at(self._protected_table, ch): + * if _write_pct(writer, ch, True) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + } + + /* "yarl/_quoting_c.pyx":264 + * if _write_pct(writer, ch, True) < 0: + * raise + * continue # <<<<<<<<<<<<<< + * + * if bit_at(self._safe_table, ch): + */ + goto __pyx_L3_continue; + + /* "yarl/_quoting_c.pyx":261 + * + * if ch < 128: + * if bit_at(self._protected_table, ch): # <<<<<<<<<<<<<< + * if _write_pct(writer, ch, True) < 0: + * raise + */ + } + + /* "yarl/_quoting_c.pyx":266 + * continue + * + * if bit_at(self._safe_table, ch): # <<<<<<<<<<<<<< + * if _write_char(writer, ch, True) < 0: + * raise + */ + __pyx_t_8 = (__pyx_f_4yarl_10_quoting_c_bit_at(__pyx_v_self->_safe_table, __pyx_v_ch) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":267 + * + * if bit_at(self._safe_table, ch): + * if _write_char(writer, ch, True) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, __pyx_v_ch, 1) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":268 + * if bit_at(self._safe_table, ch): + * if _write_char(writer, ch, True) < 0: + * raise # <<<<<<<<<<<<<< + * continue + * + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 268, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":267 + * + * if bit_at(self._safe_table, ch): + * if _write_char(writer, ch, True) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + } + + /* "yarl/_quoting_c.pyx":269 + * if _write_char(writer, ch, True) < 0: + * raise + * continue # <<<<<<<<<<<<<< + * + * if _write_pct_check(writer, ch, pct) < 0: + */ + goto __pyx_L3_continue; + + /* "yarl/_quoting_c.pyx":266 + * continue + * + * if bit_at(self._safe_table, ch): # <<<<<<<<<<<<<< + * if _write_char(writer, ch, True) < 0: + * raise + */ + } + + /* "yarl/_quoting_c.pyx":260 + * continue + * + * if ch < 128: # <<<<<<<<<<<<<< + * if bit_at(self._protected_table, ch): + * if _write_pct(writer, ch, True) < 0: + */ + } + + /* "yarl/_quoting_c.pyx":271 + * continue + * + * if _write_pct_check(writer, ch, pct) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c__write_pct_check(__pyx_v_writer, __pyx_v_ch, __pyx_v_pct) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":272 + * + * if _write_pct_check(writer, ch, pct) < 0: + * raise # <<<<<<<<<<<<<< + * continue + * + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 272, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":271 + * continue + * + * if _write_pct_check(writer, ch, pct) < 0: # <<<<<<<<<<<<<< + * raise + * continue + */ + } + + /* "yarl/_quoting_c.pyx":247 + * pct[has_pct-1] = ch + * has_pct += 1 + * if has_pct == 3: # <<<<<<<<<<<<<< + * ch = _restore_ch(pct[0], pct[1]) + * has_pct = 0 + */ + } + + /* "yarl/_quoting_c.pyx":273 + * if _write_pct_check(writer, ch, pct) < 0: + * raise + * continue # <<<<<<<<<<<<<< + * + * elif ch == '%' and self._requote: + */ + goto __pyx_L3_continue; + + /* "yarl/_quoting_c.pyx":244 + * + * for ch in val: + * if has_pct: # <<<<<<<<<<<<<< + * pct[has_pct-1] = ch + * has_pct += 1 + */ + } + + /* "yarl/_quoting_c.pyx":275 + * continue + * + * elif ch == '%' and self._requote: # <<<<<<<<<<<<<< + * has_pct = 1 + * continue + */ + __pyx_t_9 = ((__pyx_v_ch == 37) != 0); + if (__pyx_t_9) { + } else { + __pyx_t_8 = __pyx_t_9; + goto __pyx_L17_bool_binop_done; + } + __pyx_t_9 = (__pyx_v_self->_requote != 0); + __pyx_t_8 = __pyx_t_9; + __pyx_L17_bool_binop_done:; + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":276 + * + * elif ch == '%' and self._requote: + * has_pct = 1 # <<<<<<<<<<<<<< + * continue + * + */ + __pyx_v_has_pct = 1; + + /* "yarl/_quoting_c.pyx":277 + * elif ch == '%' and self._requote: + * has_pct = 1 + * continue # <<<<<<<<<<<<<< + * + * if self._write(writer, ch) < 0: + */ + goto __pyx_L3_continue; + + /* "yarl/_quoting_c.pyx":275 + * continue + * + * elif ch == '%' and self._requote: # <<<<<<<<<<<<<< + * has_pct = 1 + * continue + */ + } + + /* "yarl/_quoting_c.pyx":279 + * continue + * + * if self._write(writer, ch) < 0: # <<<<<<<<<<<<<< + * raise + * + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c_7_Quoter__write(__pyx_v_self, __pyx_v_writer, __pyx_v_ch) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":280 + * + * if self._write(writer, ch) < 0: + * raise # <<<<<<<<<<<<<< + * + * if has_pct: + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 280, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":279 + * continue + * + * if self._write(writer, ch) < 0: # <<<<<<<<<<<<<< + * raise + * + */ + } + __pyx_L3_continue:; + } + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":282 + * raise + * + * if has_pct: # <<<<<<<<<<<<<< + * if _write_percent(writer) < 0: + * raise + */ + __pyx_t_8 = (__pyx_v_has_pct != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":283 + * + * if has_pct: + * if _write_percent(writer) < 0: # <<<<<<<<<<<<<< + * raise + * if has_pct > 1: # the value is 2 + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c__write_percent(__pyx_v_writer) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":284 + * if has_pct: + * if _write_percent(writer) < 0: + * raise # <<<<<<<<<<<<<< + * if has_pct > 1: # the value is 2 + * if self._write(writer, ch) < 0: + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 284, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":283 + * + * if has_pct: + * if _write_percent(writer) < 0: # <<<<<<<<<<<<<< + * raise + * if has_pct > 1: # the value is 2 + */ + } + + /* "yarl/_quoting_c.pyx":285 + * if _write_percent(writer) < 0: + * raise + * if has_pct > 1: # the value is 2 # <<<<<<<<<<<<<< + * if self._write(writer, ch) < 0: + * raise + */ + __pyx_t_8 = ((__pyx_v_has_pct > 1) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":286 + * raise + * if has_pct > 1: # the value is 2 + * if self._write(writer, ch) < 0: # <<<<<<<<<<<<<< + * raise + * + */ + __pyx_t_8 = ((__pyx_f_4yarl_10_quoting_c_7_Quoter__write(__pyx_v_self, __pyx_v_writer, __pyx_v_ch) < 0) != 0); + if (unlikely(__pyx_t_8)) { + + /* "yarl/_quoting_c.pyx":287 + * if has_pct > 1: # the value is 2 + * if self._write(writer, ch) < 0: + * raise # <<<<<<<<<<<<<< + * + * if not writer.changed: + */ + __Pyx_ReraiseException(); __PYX_ERR(0, 287, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":286 + * raise + * if has_pct > 1: # the value is 2 + * if self._write(writer, ch) < 0: # <<<<<<<<<<<<<< + * raise + * + */ + } + + /* "yarl/_quoting_c.pyx":285 + * if _write_percent(writer) < 0: + * raise + * if has_pct > 1: # the value is 2 # <<<<<<<<<<<<<< + * if self._write(writer, ch) < 0: + * raise + */ + } + + /* "yarl/_quoting_c.pyx":282 + * raise + * + * if has_pct: # <<<<<<<<<<<<<< + * if _write_percent(writer) < 0: + * raise + */ + } + + /* "yarl/_quoting_c.pyx":289 + * raise + * + * if not writer.changed: # <<<<<<<<<<<<<< + * return val + * else: + */ + __pyx_t_8 = ((!(__pyx_v_writer->changed != 0)) != 0); + if (__pyx_t_8) { + + /* "yarl/_quoting_c.pyx":290 + * + * if not writer.changed: + * return val # <<<<<<<<<<<<<< + * else: + * return PyUnicode_DecodeASCII(writer.buf, writer.pos, "strict") + */ + __Pyx_XDECREF(__pyx_r); + __Pyx_INCREF(__pyx_v_val); + __pyx_r = __pyx_v_val; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":289 + * raise + * + * if not writer.changed: # <<<<<<<<<<<<<< + * return val + * else: + */ + } + + /* "yarl/_quoting_c.pyx":292 + * return val + * else: + * return PyUnicode_DecodeASCII(writer.buf, writer.pos, "strict") # <<<<<<<<<<<<<< + * + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): + */ + /*else*/ { + __Pyx_XDECREF(__pyx_r); + __pyx_t_10 = PyUnicode_DecodeASCII(__pyx_v_writer->buf, __pyx_v_writer->pos, ((char *)"strict")); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 292, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_10); + __pyx_r = ((PyObject*)__pyx_t_10); + __pyx_t_10 = 0; + goto __pyx_L0; + } + + /* "yarl/_quoting_c.pyx":237 + * _release_writer(&writer) + * + * cdef str _do_quote(self, str val, Writer *writer): # <<<<<<<<<<<<<< + * cdef Py_UCS4 ch + * cdef int has_pct = 0 + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_10); + __Pyx_AddTraceback("yarl._quoting_c._Quoter._do_quote", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = 0; + __pyx_L0:; + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":294 + * return PyUnicode_DecodeASCII(writer.buf, writer.pos, "strict") + * + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): # <<<<<<<<<<<<<< + * if self._qs: + * if ch == ' ': + */ + +static CYTHON_INLINE int __pyx_f_4yarl_10_quoting_c_7_Quoter__write(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, struct __pyx_t_4yarl_10_quoting_c_Writer *__pyx_v_writer, Py_UCS4 __pyx_v_ch) { + int __pyx_r; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + int __pyx_t_2; + __Pyx_RefNannySetupContext("_write", 0); + + /* "yarl/_quoting_c.pyx":295 + * + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): + * if self._qs: # <<<<<<<<<<<<<< + * if ch == ' ': + * return _write_char(writer, '+', True) + */ + __pyx_t_1 = (__pyx_v_self->_qs != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":296 + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): + * if self._qs: + * if ch == ' ': # <<<<<<<<<<<<<< + * return _write_char(writer, '+', True) + * + */ + __pyx_t_1 = ((__pyx_v_ch == 32) != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":297 + * if self._qs: + * if ch == ' ': + * return _write_char(writer, '+', True) # <<<<<<<<<<<<<< + * + * if ch < 128 and bit_at(self._safe_table, ch): + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, 43, 1); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":296 + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): + * if self._qs: + * if ch == ' ': # <<<<<<<<<<<<<< + * return _write_char(writer, '+', True) + * + */ + } + + /* "yarl/_quoting_c.pyx":295 + * + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): + * if self._qs: # <<<<<<<<<<<<<< + * if ch == ' ': + * return _write_char(writer, '+', True) + */ + } + + /* "yarl/_quoting_c.pyx":299 + * return _write_char(writer, '+', True) + * + * if ch < 128 and bit_at(self._safe_table, ch): # <<<<<<<<<<<<<< + * return _write_char(writer, ch, False) + * + */ + __pyx_t_2 = ((__pyx_v_ch < 0x80) != 0); + if (__pyx_t_2) { + } else { + __pyx_t_1 = __pyx_t_2; + goto __pyx_L6_bool_binop_done; + } + __pyx_t_2 = (__pyx_f_4yarl_10_quoting_c_bit_at(__pyx_v_self->_safe_table, __pyx_v_ch) != 0); + __pyx_t_1 = __pyx_t_2; + __pyx_L6_bool_binop_done:; + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":300 + * + * if ch < 128 and bit_at(self._safe_table, ch): + * return _write_char(writer, ch, False) # <<<<<<<<<<<<<< + * + * return _write_utf8(writer, ch) + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_char(__pyx_v_writer, __pyx_v_ch, 0); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":299 + * return _write_char(writer, '+', True) + * + * if ch < 128 and bit_at(self._safe_table, ch): # <<<<<<<<<<<<<< + * return _write_char(writer, ch, False) + * + */ + } + + /* "yarl/_quoting_c.pyx":302 + * return _write_char(writer, ch, False) + * + * return _write_utf8(writer, ch) # <<<<<<<<<<<<<< + * + * + */ + __pyx_r = __pyx_f_4yarl_10_quoting_c__write_utf8(__pyx_v_writer, __pyx_v_ch); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":294 + * return PyUnicode_DecodeASCII(writer.buf, writer.pos, "strict") + * + * cdef inline int _write(self, Writer *writer, Py_UCS4 ch): # <<<<<<<<<<<<<< + * if self._qs: + * if ch == ' ': + */ + + /* function exit code */ + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":1 + * def __reduce_cython__(self): # <<<<<<<<<<<<<< + * cdef tuple state + * cdef object _dict + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_7_Quoter_5__reduce_cython__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ +static PyObject *__pyx_pw_4yarl_10_quoting_c_7_Quoter_5__reduce_cython__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__reduce_cython__ (wrapper)", 0); + __pyx_r = __pyx_pf_4yarl_10_quoting_c_7_Quoter_4__reduce_cython__(((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_v_self)); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_7_Quoter_4__reduce_cython__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self) { + PyObject *__pyx_v_state = 0; + PyObject *__pyx_v__dict = 0; + int __pyx_v_use_setstate; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + PyObject *__pyx_t_2 = NULL; + PyObject *__pyx_t_3 = NULL; + PyObject *__pyx_t_4 = NULL; + PyObject *__pyx_t_5 = NULL; + int __pyx_t_6; + int __pyx_t_7; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__reduce_cython__", 0); + + /* "(tree fragment)":5 + * cdef object _dict + * cdef bint use_setstate + * state = (self._protected_table, self._qs, self._requote, self._safe_table) # <<<<<<<<<<<<<< + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: + */ + __pyx_t_1 = __Pyx_PyObject_FromCString(__pyx_v_self->_protected_table); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_2 = __Pyx_PyBool_FromLong(__pyx_v_self->_qs); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __pyx_t_3 = __Pyx_PyBool_FromLong(__pyx_v_self->_requote); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_4 = __Pyx_PyObject_FromCString(__pyx_v_self->_safe_table); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_4); + __pyx_t_5 = PyTuple_New(4); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_5); + __Pyx_GIVEREF(__pyx_t_1); + PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_t_1); + __Pyx_GIVEREF(__pyx_t_2); + PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_t_2); + __Pyx_GIVEREF(__pyx_t_3); + PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_t_3); + __Pyx_GIVEREF(__pyx_t_4); + PyTuple_SET_ITEM(__pyx_t_5, 3, __pyx_t_4); + __pyx_t_1 = 0; + __pyx_t_2 = 0; + __pyx_t_3 = 0; + __pyx_t_4 = 0; + __pyx_v_state = ((PyObject*)__pyx_t_5); + __pyx_t_5 = 0; + + /* "(tree fragment)":6 + * cdef bint use_setstate + * state = (self._protected_table, self._qs, self._requote, self._safe_table) + * _dict = getattr(self, '__dict__', None) # <<<<<<<<<<<<<< + * if _dict is not None: + * state += (_dict,) + */ + __pyx_t_5 = __Pyx_GetAttr3(((PyObject *)__pyx_v_self), __pyx_n_s_dict, Py_None); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_5); + __pyx_v__dict = __pyx_t_5; + __pyx_t_5 = 0; + + /* "(tree fragment)":7 + * state = (self._protected_table, self._qs, self._requote, self._safe_table) + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: # <<<<<<<<<<<<<< + * state += (_dict,) + * use_setstate = True + */ + __pyx_t_6 = (__pyx_v__dict != Py_None); + __pyx_t_7 = (__pyx_t_6 != 0); + if (__pyx_t_7) { + + /* "(tree fragment)":8 + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: + * state += (_dict,) # <<<<<<<<<<<<<< + * use_setstate = True + * else: + */ + __pyx_t_5 = PyTuple_New(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 8, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_5); + __Pyx_INCREF(__pyx_v__dict); + __Pyx_GIVEREF(__pyx_v__dict); + PyTuple_SET_ITEM(__pyx_t_5, 0, __pyx_v__dict); + __pyx_t_4 = PyNumber_InPlaceAdd(__pyx_v_state, __pyx_t_5); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 8, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_4); + __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; + __Pyx_DECREF_SET(__pyx_v_state, ((PyObject*)__pyx_t_4)); + __pyx_t_4 = 0; + + /* "(tree fragment)":9 + * if _dict is not None: + * state += (_dict,) + * use_setstate = True # <<<<<<<<<<<<<< + * else: + * use_setstate = False + */ + __pyx_v_use_setstate = 1; + + /* "(tree fragment)":7 + * state = (self._protected_table, self._qs, self._requote, self._safe_table) + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: # <<<<<<<<<<<<<< + * state += (_dict,) + * use_setstate = True + */ + goto __pyx_L3; + } + + /* "(tree fragment)":11 + * use_setstate = True + * else: + * use_setstate = False # <<<<<<<<<<<<<< + * if use_setstate: + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, None), state + */ + /*else*/ { + __pyx_v_use_setstate = 0; + } + __pyx_L3:; + + /* "(tree fragment)":12 + * else: + * use_setstate = False + * if use_setstate: # <<<<<<<<<<<<<< + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, None), state + * else: + */ + __pyx_t_7 = (__pyx_v_use_setstate != 0); + if (__pyx_t_7) { + + /* "(tree fragment)":13 + * use_setstate = False + * if use_setstate: + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, None), state # <<<<<<<<<<<<<< + * else: + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, state) + */ + __Pyx_XDECREF(__pyx_r); + __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_n_s_pyx_unpickle__Quoter); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 13, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_4); + __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 13, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_5); + __Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_GIVEREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + PyTuple_SET_ITEM(__pyx_t_5, 0, ((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_INCREF(__pyx_int_244432181); + __Pyx_GIVEREF(__pyx_int_244432181); + PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_int_244432181); + __Pyx_INCREF(Py_None); + __Pyx_GIVEREF(Py_None); + PyTuple_SET_ITEM(__pyx_t_5, 2, Py_None); + __pyx_t_3 = PyTuple_New(3); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 13, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_GIVEREF(__pyx_t_4); + PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_4); + __Pyx_GIVEREF(__pyx_t_5); + PyTuple_SET_ITEM(__pyx_t_3, 1, __pyx_t_5); + __Pyx_INCREF(__pyx_v_state); + __Pyx_GIVEREF(__pyx_v_state); + PyTuple_SET_ITEM(__pyx_t_3, 2, __pyx_v_state); + __pyx_t_4 = 0; + __pyx_t_5 = 0; + __pyx_r = __pyx_t_3; + __pyx_t_3 = 0; + goto __pyx_L0; + + /* "(tree fragment)":12 + * else: + * use_setstate = False + * if use_setstate: # <<<<<<<<<<<<<< + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, None), state + * else: + */ + } + + /* "(tree fragment)":15 + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, None), state + * else: + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, state) # <<<<<<<<<<<<<< + * def __setstate_cython__(self, __pyx_state): + * __pyx_unpickle__Quoter__set_state(self, __pyx_state) + */ + /*else*/ { + __Pyx_XDECREF(__pyx_r); + __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_pyx_unpickle__Quoter); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_5 = PyTuple_New(3); if (unlikely(!__pyx_t_5)) __PYX_ERR(1, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_5); + __Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_GIVEREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + PyTuple_SET_ITEM(__pyx_t_5, 0, ((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_INCREF(__pyx_int_244432181); + __Pyx_GIVEREF(__pyx_int_244432181); + PyTuple_SET_ITEM(__pyx_t_5, 1, __pyx_int_244432181); + __Pyx_INCREF(__pyx_v_state); + __Pyx_GIVEREF(__pyx_v_state); + PyTuple_SET_ITEM(__pyx_t_5, 2, __pyx_v_state); + __pyx_t_4 = PyTuple_New(2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_4); + __Pyx_GIVEREF(__pyx_t_3); + PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3); + __Pyx_GIVEREF(__pyx_t_5); + PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_t_5); + __pyx_t_3 = 0; + __pyx_t_5 = 0; + __pyx_r = __pyx_t_4; + __pyx_t_4 = 0; + goto __pyx_L0; + } + + /* "(tree fragment)":1 + * def __reduce_cython__(self): # <<<<<<<<<<<<<< + * cdef tuple state + * cdef object _dict + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_2); + __Pyx_XDECREF(__pyx_t_3); + __Pyx_XDECREF(__pyx_t_4); + __Pyx_XDECREF(__pyx_t_5); + __Pyx_AddTraceback("yarl._quoting_c._Quoter.__reduce_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v_state); + __Pyx_XDECREF(__pyx_v__dict); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":16 + * else: + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, state) + * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< + * __pyx_unpickle__Quoter__set_state(self, __pyx_state) + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_7_Quoter_7__setstate_cython__(PyObject *__pyx_v_self, PyObject *__pyx_v___pyx_state); /*proto*/ +static PyObject *__pyx_pw_4yarl_10_quoting_c_7_Quoter_7__setstate_cython__(PyObject *__pyx_v_self, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__setstate_cython__ (wrapper)", 0); + __pyx_r = __pyx_pf_4yarl_10_quoting_c_7_Quoter_6__setstate_cython__(((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_v_self), ((PyObject *)__pyx_v___pyx_state)); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_7_Quoter_6__setstate_cython__(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v_self, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__setstate_cython__", 0); + + /* "(tree fragment)":17 + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, state) + * def __setstate_cython__(self, __pyx_state): + * __pyx_unpickle__Quoter__set_state(self, __pyx_state) # <<<<<<<<<<<<<< + */ + if (!(likely(PyTuple_CheckExact(__pyx_v___pyx_state))||((__pyx_v___pyx_state) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_v___pyx_state)->tp_name), 0))) __PYX_ERR(1, 17, __pyx_L1_error) + __pyx_t_1 = __pyx_f_4yarl_10_quoting_c___pyx_unpickle__Quoter__set_state(__pyx_v_self, ((PyObject*)__pyx_v___pyx_state)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 17, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "(tree fragment)":16 + * else: + * return __pyx_unpickle__Quoter, (type(self), 0xe91bd35, state) + * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< + * __pyx_unpickle__Quoter__set_state(self, __pyx_state) + */ + + /* function exit code */ + __pyx_r = Py_None; __Pyx_INCREF(Py_None); + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_AddTraceback("yarl._quoting_c._Quoter.__setstate_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":311 + * cdef _Quoter _qs_quoter + * + * def __init__(self, *, unsafe='', qs=False): # <<<<<<<<<<<<<< + * self._unsafe = unsafe + * self._qs = qs + */ + +/* Python wrapper */ +static int __pyx_pw_4yarl_10_quoting_c_9_Unquoter_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ +static int __pyx_pw_4yarl_10_quoting_c_9_Unquoter_1__init__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { + PyObject *__pyx_v_unsafe = 0; + PyObject *__pyx_v_qs = 0; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + int __pyx_r; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__init__ (wrapper)", 0); + { + static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_unsafe,&__pyx_n_s_qs,0}; + PyObject* values[2] = {0,0}; + values[0] = ((PyObject *)__pyx_kp_u_); + values[1] = ((PyObject *)Py_False); + if (unlikely(__pyx_kwds)) { + Py_ssize_t kw_args; + const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); + switch (pos_args) { + case 0: break; + default: goto __pyx_L5_argtuple_error; + } + kw_args = PyDict_Size(__pyx_kwds); + if (kw_args > 0 && likely(kw_args <= 2)) { + Py_ssize_t index; + for (index = 0; index < 2 && kw_args > 0; index++) { + PyObject* value = __Pyx_PyDict_GetItemStr(__pyx_kwds, *__pyx_pyargnames[index]); + if (value) { values[index] = value; kw_args--; } + } + } + if (unlikely(kw_args > 0)) { + if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, 0, "__init__") < 0)) __PYX_ERR(0, 311, __pyx_L3_error) + } + } else if (PyTuple_GET_SIZE(__pyx_args) != 0) { + goto __pyx_L5_argtuple_error; + } else { + } + __pyx_v_unsafe = values[0]; + __pyx_v_qs = values[1]; + } + goto __pyx_L4_argument_unpacking_done; + __pyx_L5_argtuple_error:; + __Pyx_RaiseArgtupleInvalid("__init__", 1, 0, 0, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 311, __pyx_L3_error) + __pyx_L3_error:; + __Pyx_AddTraceback("yarl._quoting_c._Unquoter.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __Pyx_RefNannyFinishContext(); + return -1; + __pyx_L4_argument_unpacking_done:; + __pyx_r = __pyx_pf_4yarl_10_quoting_c_9_Unquoter___init__(((struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)__pyx_v_self), __pyx_v_unsafe, __pyx_v_qs); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static int __pyx_pf_4yarl_10_quoting_c_9_Unquoter___init__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v_unsafe, PyObject *__pyx_v_qs) { + int __pyx_r; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + int __pyx_t_2; + PyObject *__pyx_t_3 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__init__", 0); + + /* "yarl/_quoting_c.pyx":312 + * + * def __init__(self, *, unsafe='', qs=False): + * self._unsafe = unsafe # <<<<<<<<<<<<<< + * self._qs = qs + * self._quoter = _Quoter() + */ + if (!(likely(PyUnicode_CheckExact(__pyx_v_unsafe))||((__pyx_v_unsafe) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "unicode", Py_TYPE(__pyx_v_unsafe)->tp_name), 0))) __PYX_ERR(0, 312, __pyx_L1_error) + __pyx_t_1 = __pyx_v_unsafe; + __Pyx_INCREF(__pyx_t_1); + __Pyx_GIVEREF(__pyx_t_1); + __Pyx_GOTREF(__pyx_v_self->_unsafe); + __Pyx_DECREF(__pyx_v_self->_unsafe); + __pyx_v_self->_unsafe = ((PyObject*)__pyx_t_1); + __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":313 + * def __init__(self, *, unsafe='', qs=False): + * self._unsafe = unsafe + * self._qs = qs # <<<<<<<<<<<<<< + * self._quoter = _Quoter() + * self._qs_quoter = _Quoter(qs=True) + */ + __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_v_qs); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 313, __pyx_L1_error) + __pyx_v_self->_qs = __pyx_t_2; + + /* "yarl/_quoting_c.pyx":314 + * self._unsafe = unsafe + * self._qs = qs + * self._quoter = _Quoter() # <<<<<<<<<<<<<< + * self._qs_quoter = _Quoter(qs=True) + * + */ + __pyx_t_1 = __Pyx_PyObject_CallNoArg(((PyObject *)__pyx_ptype_4yarl_10_quoting_c__Quoter)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 314, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_GIVEREF(__pyx_t_1); + __Pyx_GOTREF(__pyx_v_self->_quoter); + __Pyx_DECREF(((PyObject *)__pyx_v_self->_quoter)); + __pyx_v_self->_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_t_1); + __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":315 + * self._qs = qs + * self._quoter = _Quoter() + * self._qs_quoter = _Quoter(qs=True) # <<<<<<<<<<<<<< + * + * def __call__(self, val): + */ + __pyx_t_1 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 315, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_t_1, __pyx_n_s_qs, Py_True) < 0) __PYX_ERR(0, 315, __pyx_L1_error) + __pyx_t_3 = __Pyx_PyObject_Call(((PyObject *)__pyx_ptype_4yarl_10_quoting_c__Quoter), __pyx_empty_tuple, __pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 315, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __Pyx_GIVEREF(__pyx_t_3); + __Pyx_GOTREF(__pyx_v_self->_qs_quoter); + __Pyx_DECREF(((PyObject *)__pyx_v_self->_qs_quoter)); + __pyx_v_self->_qs_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":311 + * cdef _Quoter _qs_quoter + * + * def __init__(self, *, unsafe='', qs=False): # <<<<<<<<<<<<<< + * self._unsafe = unsafe + * self._qs = qs + */ + + /* function exit code */ + __pyx_r = 0; + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_3); + __Pyx_AddTraceback("yarl._quoting_c._Unquoter.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = -1; + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":317 + * self._qs_quoter = _Quoter(qs=True) + * + * def __call__(self, val): # <<<<<<<<<<<<<< + * if val is None: + * return None + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_9_Unquoter_3__call__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ +static PyObject *__pyx_pw_4yarl_10_quoting_c_9_Unquoter_3__call__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { + PyObject *__pyx_v_val = 0; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__call__ (wrapper)", 0); + { + static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_val,0}; + PyObject* values[1] = {0}; + if (unlikely(__pyx_kwds)) { + Py_ssize_t kw_args; + const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); + switch (pos_args) { + case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + CYTHON_FALLTHROUGH; + case 0: break; + default: goto __pyx_L5_argtuple_error; + } + kw_args = PyDict_Size(__pyx_kwds); + switch (pos_args) { + case 0: + if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_val)) != 0)) kw_args--; + else goto __pyx_L5_argtuple_error; + } + if (unlikely(kw_args > 0)) { + if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__call__") < 0)) __PYX_ERR(0, 317, __pyx_L3_error) + } + } else if (PyTuple_GET_SIZE(__pyx_args) != 1) { + goto __pyx_L5_argtuple_error; + } else { + values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + } + __pyx_v_val = values[0]; + } + goto __pyx_L4_argument_unpacking_done; + __pyx_L5_argtuple_error:; + __Pyx_RaiseArgtupleInvalid("__call__", 1, 1, 1, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(0, 317, __pyx_L3_error) + __pyx_L3_error:; + __Pyx_AddTraceback("yarl._quoting_c._Unquoter.__call__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __Pyx_RefNannyFinishContext(); + return NULL; + __pyx_L4_argument_unpacking_done:; + __pyx_r = __pyx_pf_4yarl_10_quoting_c_9_Unquoter_2__call__(((struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)__pyx_v_self), __pyx_v_val); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_9_Unquoter_2__call__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v_val) { + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + int __pyx_t_2; + PyObject *__pyx_t_3 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__call__", 0); + __Pyx_INCREF(__pyx_v_val); + + /* "yarl/_quoting_c.pyx":318 + * + * def __call__(self, val): + * if val is None: # <<<<<<<<<<<<<< + * return None + * if type(val) is not str: + */ + __pyx_t_1 = (__pyx_v_val == Py_None); + __pyx_t_2 = (__pyx_t_1 != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":319 + * def __call__(self, val): + * if val is None: + * return None # <<<<<<<<<<<<<< + * if type(val) is not str: + * if isinstance(val, str): + */ + __Pyx_XDECREF(__pyx_r); + __pyx_r = Py_None; __Pyx_INCREF(Py_None); + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":318 + * + * def __call__(self, val): + * if val is None: # <<<<<<<<<<<<<< + * return None + * if type(val) is not str: + */ + } + + /* "yarl/_quoting_c.pyx":320 + * if val is None: + * return None + * if type(val) is not str: # <<<<<<<<<<<<<< + * if isinstance(val, str): + * # derived from str + */ + __pyx_t_2 = (((PyObject *)Py_TYPE(__pyx_v_val)) != ((PyObject *)(&PyUnicode_Type))); + __pyx_t_1 = (__pyx_t_2 != 0); + if (__pyx_t_1) { + + /* "yarl/_quoting_c.pyx":321 + * return None + * if type(val) is not str: + * if isinstance(val, str): # <<<<<<<<<<<<<< + * # derived from str + * val = str(val) + */ + __pyx_t_1 = PyUnicode_Check(__pyx_v_val); + __pyx_t_2 = (__pyx_t_1 != 0); + if (likely(__pyx_t_2)) { + + /* "yarl/_quoting_c.pyx":323 + * if isinstance(val, str): + * # derived from str + * val = str(val) # <<<<<<<<<<<<<< + * else: + * raise TypeError("Argument should be str") + */ + __pyx_t_3 = __Pyx_PyObject_CallOneArg(((PyObject *)(&PyUnicode_Type)), __pyx_v_val); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 323, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF_SET(__pyx_v_val, __pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":321 + * return None + * if type(val) is not str: + * if isinstance(val, str): # <<<<<<<<<<<<<< + * # derived from str + * val = str(val) + */ + goto __pyx_L5; + } + + /* "yarl/_quoting_c.pyx":325 + * val = str(val) + * else: + * raise TypeError("Argument should be str") # <<<<<<<<<<<<<< + * return self._do_unquote(<str>val) + * + */ + /*else*/ { + __pyx_t_3 = __Pyx_PyObject_Call(__pyx_builtin_TypeError, __pyx_tuple__3, NULL); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 325, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_Raise(__pyx_t_3, 0, 0, 0); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __PYX_ERR(0, 325, __pyx_L1_error) + } + __pyx_L5:; + + /* "yarl/_quoting_c.pyx":320 + * if val is None: + * return None + * if type(val) is not str: # <<<<<<<<<<<<<< + * if isinstance(val, str): + * # derived from str + */ + } + + /* "yarl/_quoting_c.pyx":326 + * else: + * raise TypeError("Argument should be str") + * return self._do_unquote(<str>val) # <<<<<<<<<<<<<< + * + * cdef str _do_unquote(self, str val): + */ + __Pyx_XDECREF(__pyx_r); + __pyx_t_3 = ((struct __pyx_vtabstruct_4yarl_10_quoting_c__Unquoter *)__pyx_v_self->__pyx_vtab)->_do_unquote(__pyx_v_self, ((PyObject*)__pyx_v_val)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 326, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_r = __pyx_t_3; + __pyx_t_3 = 0; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":317 + * self._qs_quoter = _Quoter(qs=True) + * + * def __call__(self, val): # <<<<<<<<<<<<<< + * if val is None: + * return None + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_3); + __Pyx_AddTraceback("yarl._quoting_c._Unquoter.__call__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v_val); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "yarl/_quoting_c.pyx":328 + * return self._do_unquote(<str>val) + * + * cdef str _do_unquote(self, str val): # <<<<<<<<<<<<<< + * if len(val) == 0: + * return val + */ + +static PyObject *__pyx_f_4yarl_10_quoting_c_9_Unquoter__do_unquote(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v_val) { + PyObject *__pyx_v_pct = 0; + PyObject *__pyx_v_last_pct = 0; + PyObject *__pyx_v_pcts = 0; + PyObject *__pyx_v_ret = 0; + PyObject *__pyx_v_unquoted = 0; + PyObject *__pyx_v_ch = NULL; + PyObject *__pyx_v_h = NULL; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + Py_ssize_t __pyx_t_1; + int __pyx_t_2; + PyObject *__pyx_t_3 = NULL; + PyObject *__pyx_t_4 = NULL; + Py_ssize_t __pyx_t_5; + void *__pyx_t_6; + int __pyx_t_7; + int __pyx_t_8; + Py_ssize_t __pyx_t_9; + Py_ssize_t __pyx_t_10; + PyObject *__pyx_t_11 = NULL; + PyObject *__pyx_t_12 = NULL; + int __pyx_t_13; + PyObject *__pyx_t_14 = NULL; + PyObject *__pyx_t_15 = NULL; + PyObject *__pyx_t_16 = NULL; + int __pyx_t_17; + int __pyx_t_18; + long __pyx_t_19; + PyObject *(*__pyx_t_20)(PyObject *); + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("_do_unquote", 0); + + /* "yarl/_quoting_c.pyx":329 + * + * cdef str _do_unquote(self, str val): + * if len(val) == 0: # <<<<<<<<<<<<<< + * return val + * cdef str pct = '' + */ + if (unlikely(__pyx_v_val == Py_None)) { + PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); + __PYX_ERR(0, 329, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_PyUnicode_GET_LENGTH(__pyx_v_val); if (unlikely(__pyx_t_1 == ((Py_ssize_t)-1))) __PYX_ERR(0, 329, __pyx_L1_error) + __pyx_t_2 = ((__pyx_t_1 == 0) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":330 + * cdef str _do_unquote(self, str val): + * if len(val) == 0: + * return val # <<<<<<<<<<<<<< + * cdef str pct = '' + * cdef str last_pct = '' + */ + __Pyx_XDECREF(__pyx_r); + __Pyx_INCREF(__pyx_v_val); + __pyx_r = __pyx_v_val; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":329 + * + * cdef str _do_unquote(self, str val): + * if len(val) == 0: # <<<<<<<<<<<<<< + * return val + * cdef str pct = '' + */ + } + + /* "yarl/_quoting_c.pyx":331 + * if len(val) == 0: + * return val + * cdef str pct = '' # <<<<<<<<<<<<<< + * cdef str last_pct = '' + * cdef bytearray pcts = bytearray() + */ + __Pyx_INCREF(__pyx_kp_u_); + __pyx_v_pct = __pyx_kp_u_; + + /* "yarl/_quoting_c.pyx":332 + * return val + * cdef str pct = '' + * cdef str last_pct = '' # <<<<<<<<<<<<<< + * cdef bytearray pcts = bytearray() + * cdef list ret = [] + */ + __Pyx_INCREF(__pyx_kp_u_); + __pyx_v_last_pct = __pyx_kp_u_; + + /* "yarl/_quoting_c.pyx":333 + * cdef str pct = '' + * cdef str last_pct = '' + * cdef bytearray pcts = bytearray() # <<<<<<<<<<<<<< + * cdef list ret = [] + * cdef str unquoted + */ + __pyx_t_3 = __Pyx_PyObject_CallNoArg(((PyObject *)(&PyByteArray_Type))); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 333, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_v_pcts = ((PyObject*)__pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":334 + * cdef str last_pct = '' + * cdef bytearray pcts = bytearray() + * cdef list ret = [] # <<<<<<<<<<<<<< + * cdef str unquoted + * for ch in val: + */ + __pyx_t_3 = PyList_New(0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 334, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_v_ret = ((PyObject*)__pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":336 + * cdef list ret = [] + * cdef str unquoted + * for ch in val: # <<<<<<<<<<<<<< + * if pct: + * pct += ch + */ + if (unlikely(__pyx_v_val == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' is not iterable"); + __PYX_ERR(0, 336, __pyx_L1_error) + } + __Pyx_INCREF(__pyx_v_val); + __pyx_t_4 = __pyx_v_val; + __pyx_t_8 = __Pyx_init_unicode_iteration(__pyx_t_4, (&__pyx_t_5), (&__pyx_t_6), (&__pyx_t_7)); if (unlikely(__pyx_t_8 == ((int)-1))) __PYX_ERR(0, 336, __pyx_L1_error) + for (__pyx_t_9 = 0; __pyx_t_9 < __pyx_t_5; __pyx_t_9++) { + __pyx_t_1 = __pyx_t_9; + __pyx_t_3 = PyUnicode_FromOrdinal(__Pyx_PyUnicode_READ(__pyx_t_7, __pyx_t_6, __pyx_t_1)); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 336, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_XDECREF_SET(__pyx_v_ch, __pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":337 + * cdef str unquoted + * for ch in val: + * if pct: # <<<<<<<<<<<<<< + * pct += ch + * if len(pct) == 3: # pragma: no branch # peephole optimizer + */ + __pyx_t_2 = (__pyx_v_pct != Py_None)&&(__Pyx_PyUnicode_IS_TRUE(__pyx_v_pct) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":338 + * for ch in val: + * if pct: + * pct += ch # <<<<<<<<<<<<<< + * if len(pct) == 3: # pragma: no branch # peephole optimizer + * pcts.append(int(pct[1:], base=16)) + */ + __pyx_t_3 = PyNumber_InPlaceAdd(__pyx_v_pct, __pyx_v_ch); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 338, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + if (!(likely(PyUnicode_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "unicode", Py_TYPE(__pyx_t_3)->tp_name), 0))) __PYX_ERR(0, 338, __pyx_L1_error) + __Pyx_DECREF_SET(__pyx_v_pct, ((PyObject*)__pyx_t_3)); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":339 + * if pct: + * pct += ch + * if len(pct) == 3: # pragma: no branch # peephole optimizer # <<<<<<<<<<<<<< + * pcts.append(int(pct[1:], base=16)) + * last_pct = pct + */ + if (unlikely(__pyx_v_pct == Py_None)) { + PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); + __PYX_ERR(0, 339, __pyx_L1_error) + } + __pyx_t_10 = __Pyx_PyUnicode_GET_LENGTH(__pyx_v_pct); if (unlikely(__pyx_t_10 == ((Py_ssize_t)-1))) __PYX_ERR(0, 339, __pyx_L1_error) + __pyx_t_2 = ((__pyx_t_10 == 3) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":340 + * pct += ch + * if len(pct) == 3: # pragma: no branch # peephole optimizer + * pcts.append(int(pct[1:], base=16)) # <<<<<<<<<<<<<< + * last_pct = pct + * pct = '' + */ + if (unlikely(__pyx_v_pct == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(0, 340, __pyx_L1_error) + } + __pyx_t_3 = __Pyx_PyUnicode_Substring(__pyx_v_pct, 1, PY_SSIZE_T_MAX); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 340, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_11 = PyTuple_New(1); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 340, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_11); + __Pyx_GIVEREF(__pyx_t_3); + PyTuple_SET_ITEM(__pyx_t_11, 0, __pyx_t_3); + __pyx_t_3 = 0; + __pyx_t_3 = __Pyx_PyDict_NewPresized(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 340, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + if (PyDict_SetItem(__pyx_t_3, __pyx_n_s_base, __pyx_int_16) < 0) __PYX_ERR(0, 340, __pyx_L1_error) + __pyx_t_12 = __Pyx_PyObject_Call(((PyObject *)(&PyInt_Type)), __pyx_t_11, __pyx_t_3); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 340, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_12); + __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_t_13 = __Pyx_PyByteArray_AppendObject(__pyx_v_pcts, __pyx_t_12); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 340, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; + + /* "yarl/_quoting_c.pyx":341 + * if len(pct) == 3: # pragma: no branch # peephole optimizer + * pcts.append(int(pct[1:], base=16)) + * last_pct = pct # <<<<<<<<<<<<<< + * pct = '' + * continue + */ + __Pyx_INCREF(__pyx_v_pct); + __Pyx_DECREF_SET(__pyx_v_last_pct, __pyx_v_pct); + + /* "yarl/_quoting_c.pyx":342 + * pcts.append(int(pct[1:], base=16)) + * last_pct = pct + * pct = '' # <<<<<<<<<<<<<< + * continue + * if pcts: + */ + __Pyx_INCREF(__pyx_kp_u_); + __Pyx_DECREF_SET(__pyx_v_pct, __pyx_kp_u_); + + /* "yarl/_quoting_c.pyx":339 + * if pct: + * pct += ch + * if len(pct) == 3: # pragma: no branch # peephole optimizer # <<<<<<<<<<<<<< + * pcts.append(int(pct[1:], base=16)) + * last_pct = pct + */ + } + + /* "yarl/_quoting_c.pyx":343 + * last_pct = pct + * pct = '' + * continue # <<<<<<<<<<<<<< + * if pcts: + * try: + */ + goto __pyx_L4_continue; + + /* "yarl/_quoting_c.pyx":337 + * cdef str unquoted + * for ch in val: + * if pct: # <<<<<<<<<<<<<< + * pct += ch + * if len(pct) == 3: # pragma: no branch # peephole optimizer + */ + } + + /* "yarl/_quoting_c.pyx":344 + * pct = '' + * continue + * if pcts: # <<<<<<<<<<<<<< + * try: + * unquoted = pcts.decode('utf8') + */ + __pyx_t_2 = (PyByteArray_GET_SIZE(__pyx_v_pcts) != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":345 + * continue + * if pcts: + * try: # <<<<<<<<<<<<<< + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + */ + { + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + __Pyx_ExceptionSave(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16); + __Pyx_XGOTREF(__pyx_t_14); + __Pyx_XGOTREF(__pyx_t_15); + __Pyx_XGOTREF(__pyx_t_16); + /*try:*/ { + + /* "yarl/_quoting_c.pyx":346 + * if pcts: + * try: + * unquoted = pcts.decode('utf8') # <<<<<<<<<<<<<< + * except UnicodeDecodeError: + * pass + */ + __pyx_t_12 = __Pyx_decode_bytearray(__pyx_v_pcts, 0, PY_SSIZE_T_MAX, NULL, NULL, PyUnicode_DecodeUTF8); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 346, __pyx_L9_error) + __Pyx_GOTREF(__pyx_t_12); + __Pyx_XDECREF_SET(__pyx_v_unquoted, ((PyObject*)__pyx_t_12)); + __pyx_t_12 = 0; + + /* "yarl/_quoting_c.pyx":345 + * continue + * if pcts: + * try: # <<<<<<<<<<<<<< + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + */ + } + + /* "yarl/_quoting_c.pyx":350 + * pass + * else: + * if self._qs and unquoted in '+=&;': # <<<<<<<<<<<<<< + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: + */ + /*else:*/ { + __pyx_t_17 = (__pyx_v_self->_qs != 0); + if (__pyx_t_17) { + } else { + __pyx_t_2 = __pyx_t_17; + goto __pyx_L18_bool_binop_done; + } + __pyx_t_17 = (__Pyx_PyUnicode_ContainsTF(__pyx_v_unquoted, __pyx_kp_u__4, Py_EQ)); if (unlikely(__pyx_t_17 < 0)) __PYX_ERR(0, 350, __pyx_L11_except_error) + __pyx_t_18 = (__pyx_t_17 != 0); + __pyx_t_2 = __pyx_t_18; + __pyx_L18_bool_binop_done:; + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":351 + * else: + * if self._qs and unquoted in '+=&;': + * ret.append(self._qs_quoter(unquoted)) # <<<<<<<<<<<<<< + * elif unquoted in self._unsafe: + * ret.append(self._quoter(unquoted)) + */ + __Pyx_INCREF(((PyObject *)__pyx_v_self->_qs_quoter)); + __pyx_t_3 = ((PyObject *)__pyx_v_self->_qs_quoter); __pyx_t_11 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { + __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_3); + if (likely(__pyx_t_11)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); + __Pyx_INCREF(__pyx_t_11); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_3, function); + } + } + __pyx_t_12 = (__pyx_t_11) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_11, __pyx_v_unquoted) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_unquoted); + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 351, __pyx_L11_except_error) + __Pyx_GOTREF(__pyx_t_12); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_t_12); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 351, __pyx_L11_except_error) + __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; + + /* "yarl/_quoting_c.pyx":350 + * pass + * else: + * if self._qs and unquoted in '+=&;': # <<<<<<<<<<<<<< + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: + */ + goto __pyx_L17; + } + + /* "yarl/_quoting_c.pyx":352 + * if self._qs and unquoted in '+=&;': + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: # <<<<<<<<<<<<<< + * ret.append(self._quoter(unquoted)) + * else: + */ + if (unlikely(__pyx_v_self->_unsafe == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); + __PYX_ERR(0, 352, __pyx_L11_except_error) + } + __pyx_t_2 = (__Pyx_PyUnicode_ContainsTF(__pyx_v_unquoted, __pyx_v_self->_unsafe, Py_EQ)); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 352, __pyx_L11_except_error) + __pyx_t_18 = (__pyx_t_2 != 0); + if (__pyx_t_18) { + + /* "yarl/_quoting_c.pyx":353 + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: + * ret.append(self._quoter(unquoted)) # <<<<<<<<<<<<<< + * else: + * ret.append(unquoted) + */ + __Pyx_INCREF(((PyObject *)__pyx_v_self->_quoter)); + __pyx_t_3 = ((PyObject *)__pyx_v_self->_quoter); __pyx_t_11 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { + __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_3); + if (likely(__pyx_t_11)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); + __Pyx_INCREF(__pyx_t_11); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_3, function); + } + } + __pyx_t_12 = (__pyx_t_11) ? __Pyx_PyObject_Call2Args(__pyx_t_3, __pyx_t_11, __pyx_v_unquoted) : __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_v_unquoted); + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 353, __pyx_L11_except_error) + __Pyx_GOTREF(__pyx_t_12); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_t_12); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 353, __pyx_L11_except_error) + __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; + + /* "yarl/_quoting_c.pyx":352 + * if self._qs and unquoted in '+=&;': + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: # <<<<<<<<<<<<<< + * ret.append(self._quoter(unquoted)) + * else: + */ + goto __pyx_L17; + } + + /* "yarl/_quoting_c.pyx":355 + * ret.append(self._quoter(unquoted)) + * else: + * ret.append(unquoted) # <<<<<<<<<<<<<< + * del pcts[:] + * + */ + /*else*/ { + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_v_unquoted); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 355, __pyx_L11_except_error) + } + __pyx_L17:; + + /* "yarl/_quoting_c.pyx":356 + * else: + * ret.append(unquoted) + * del pcts[:] # <<<<<<<<<<<<<< + * + * if ch == '%': + */ + if (__Pyx_PyObject_DelSlice(__pyx_v_pcts, 0, 0, NULL, NULL, NULL, 0, 0, 1) < 0) __PYX_ERR(0, 356, __pyx_L11_except_error) + } + __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; + __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; + __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0; + goto __pyx_L16_try_end; + __pyx_L9_error:; + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; + __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":347 + * try: + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: # <<<<<<<<<<<<<< + * pass + * else: + */ + __pyx_t_8 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_UnicodeDecodeError); + if (__pyx_t_8) { + __Pyx_ErrRestore(0,0,0); + goto __pyx_L10_exception_handled; + } + goto __pyx_L11_except_error; + __pyx_L11_except_error:; + + /* "yarl/_quoting_c.pyx":345 + * continue + * if pcts: + * try: # <<<<<<<<<<<<<< + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + */ + __Pyx_XGIVEREF(__pyx_t_14); + __Pyx_XGIVEREF(__pyx_t_15); + __Pyx_XGIVEREF(__pyx_t_16); + __Pyx_ExceptionReset(__pyx_t_14, __pyx_t_15, __pyx_t_16); + goto __pyx_L1_error; + __pyx_L10_exception_handled:; + __Pyx_XGIVEREF(__pyx_t_14); + __Pyx_XGIVEREF(__pyx_t_15); + __Pyx_XGIVEREF(__pyx_t_16); + __Pyx_ExceptionReset(__pyx_t_14, __pyx_t_15, __pyx_t_16); + __pyx_L16_try_end:; + } + + /* "yarl/_quoting_c.pyx":344 + * pct = '' + * continue + * if pcts: # <<<<<<<<<<<<<< + * try: + * unquoted = pcts.decode('utf8') + */ + } + + /* "yarl/_quoting_c.pyx":358 + * del pcts[:] + * + * if ch == '%': # <<<<<<<<<<<<<< + * pct = ch + * continue + */ + __pyx_t_18 = (__Pyx_PyUnicode_Equals(__pyx_v_ch, __pyx_kp_u__5, Py_EQ)); if (unlikely(__pyx_t_18 < 0)) __PYX_ERR(0, 358, __pyx_L1_error) + if (__pyx_t_18) { + + /* "yarl/_quoting_c.pyx":359 + * + * if ch == '%': + * pct = ch # <<<<<<<<<<<<<< + * continue + * + */ + if (!(likely(PyUnicode_CheckExact(__pyx_v_ch))||((__pyx_v_ch) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "unicode", Py_TYPE(__pyx_v_ch)->tp_name), 0))) __PYX_ERR(0, 359, __pyx_L1_error) + __pyx_t_12 = __pyx_v_ch; + __Pyx_INCREF(__pyx_t_12); + __Pyx_DECREF_SET(__pyx_v_pct, ((PyObject*)__pyx_t_12)); + __pyx_t_12 = 0; + + /* "yarl/_quoting_c.pyx":360 + * if ch == '%': + * pct = ch + * continue # <<<<<<<<<<<<<< + * + * if pcts: + */ + goto __pyx_L4_continue; + + /* "yarl/_quoting_c.pyx":358 + * del pcts[:] + * + * if ch == '%': # <<<<<<<<<<<<<< + * pct = ch + * continue + */ + } + + /* "yarl/_quoting_c.pyx":362 + * continue + * + * if pcts: # <<<<<<<<<<<<<< + * ret.append(last_pct) # %F8ab + * last_pct = '' + */ + __pyx_t_18 = (PyByteArray_GET_SIZE(__pyx_v_pcts) != 0); + if (__pyx_t_18) { + + /* "yarl/_quoting_c.pyx":363 + * + * if pcts: + * ret.append(last_pct) # %F8ab # <<<<<<<<<<<<<< + * last_pct = '' + * + */ + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_v_last_pct); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 363, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":364 + * if pcts: + * ret.append(last_pct) # %F8ab + * last_pct = '' # <<<<<<<<<<<<<< + * + * if ch == '+': + */ + __Pyx_INCREF(__pyx_kp_u_); + __Pyx_DECREF_SET(__pyx_v_last_pct, __pyx_kp_u_); + + /* "yarl/_quoting_c.pyx":362 + * continue + * + * if pcts: # <<<<<<<<<<<<<< + * ret.append(last_pct) # %F8ab + * last_pct = '' + */ + } + + /* "yarl/_quoting_c.pyx":366 + * last_pct = '' + * + * if ch == '+': # <<<<<<<<<<<<<< + * if not self._qs or ch in self._unsafe: + * ret.append('+') + */ + __pyx_t_18 = (__Pyx_PyUnicode_Equals(__pyx_v_ch, __pyx_kp_u__6, Py_EQ)); if (unlikely(__pyx_t_18 < 0)) __PYX_ERR(0, 366, __pyx_L1_error) + if (__pyx_t_18) { + + /* "yarl/_quoting_c.pyx":367 + * + * if ch == '+': + * if not self._qs or ch in self._unsafe: # <<<<<<<<<<<<<< + * ret.append('+') + * else: + */ + __pyx_t_2 = ((!(__pyx_v_self->_qs != 0)) != 0); + if (!__pyx_t_2) { + } else { + __pyx_t_18 = __pyx_t_2; + goto __pyx_L24_bool_binop_done; + } + if (unlikely(__pyx_v_self->_unsafe == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); + __PYX_ERR(0, 367, __pyx_L1_error) + } + __pyx_t_2 = (__Pyx_PyUnicode_ContainsTF(__pyx_v_ch, __pyx_v_self->_unsafe, Py_EQ)); if (unlikely(__pyx_t_2 < 0)) __PYX_ERR(0, 367, __pyx_L1_error) + __pyx_t_17 = (__pyx_t_2 != 0); + __pyx_t_18 = __pyx_t_17; + __pyx_L24_bool_binop_done:; + if (__pyx_t_18) { + + /* "yarl/_quoting_c.pyx":368 + * if ch == '+': + * if not self._qs or ch in self._unsafe: + * ret.append('+') # <<<<<<<<<<<<<< + * else: + * ret.append(' ') + */ + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_kp_u__6); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 368, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":367 + * + * if ch == '+': + * if not self._qs or ch in self._unsafe: # <<<<<<<<<<<<<< + * ret.append('+') + * else: + */ + goto __pyx_L23; + } + + /* "yarl/_quoting_c.pyx":370 + * ret.append('+') + * else: + * ret.append(' ') # <<<<<<<<<<<<<< + * continue + * + */ + /*else*/ { + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_kp_u__7); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 370, __pyx_L1_error) + } + __pyx_L23:; + + /* "yarl/_quoting_c.pyx":371 + * else: + * ret.append(' ') + * continue # <<<<<<<<<<<<<< + * + * if ch in self._unsafe: + */ + goto __pyx_L4_continue; + + /* "yarl/_quoting_c.pyx":366 + * last_pct = '' + * + * if ch == '+': # <<<<<<<<<<<<<< + * if not self._qs or ch in self._unsafe: + * ret.append('+') + */ + } + + /* "yarl/_quoting_c.pyx":373 + * continue + * + * if ch in self._unsafe: # <<<<<<<<<<<<<< + * ret.append('%') + * h = hex(ord(ch)).upper()[2:] + */ + if (unlikely(__pyx_v_self->_unsafe == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); + __PYX_ERR(0, 373, __pyx_L1_error) + } + __pyx_t_18 = (__Pyx_PyUnicode_ContainsTF(__pyx_v_ch, __pyx_v_self->_unsafe, Py_EQ)); if (unlikely(__pyx_t_18 < 0)) __PYX_ERR(0, 373, __pyx_L1_error) + __pyx_t_17 = (__pyx_t_18 != 0); + if (__pyx_t_17) { + + /* "yarl/_quoting_c.pyx":374 + * + * if ch in self._unsafe: + * ret.append('%') # <<<<<<<<<<<<<< + * h = hex(ord(ch)).upper()[2:] + * for ch in h: + */ + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_kp_u__5); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 374, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":375 + * if ch in self._unsafe: + * ret.append('%') + * h = hex(ord(ch)).upper()[2:] # <<<<<<<<<<<<<< + * for ch in h: + * ret.append(ch) + */ + __pyx_t_19 = __Pyx_PyObject_Ord(__pyx_v_ch); if (unlikely(__pyx_t_19 == ((long)(long)(Py_UCS4)-1))) __PYX_ERR(0, 375, __pyx_L1_error) + __pyx_t_3 = __Pyx_PyInt_From_long(__pyx_t_19); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 375, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_11 = __Pyx_PyObject_CallOneArg(__pyx_builtin_hex, __pyx_t_3); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 375, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_11); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_11, __pyx_n_s_upper); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 375, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_11); __pyx_t_11 = 0; + __pyx_t_11 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_3))) { + __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_3); + if (likely(__pyx_t_11)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_3); + __Pyx_INCREF(__pyx_t_11); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_3, function); + } + } + __pyx_t_12 = (__pyx_t_11) ? __Pyx_PyObject_CallOneArg(__pyx_t_3, __pyx_t_11) : __Pyx_PyObject_CallNoArg(__pyx_t_3); + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 375, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_12); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_t_3 = __Pyx_PyObject_GetSlice(__pyx_t_12, 2, 0, NULL, NULL, &__pyx_slice__8, 1, 0, 1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 375, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; + __Pyx_XDECREF_SET(__pyx_v_h, __pyx_t_3); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":376 + * ret.append('%') + * h = hex(ord(ch)).upper()[2:] + * for ch in h: # <<<<<<<<<<<<<< + * ret.append(ch) + * continue + */ + if (likely(PyList_CheckExact(__pyx_v_h)) || PyTuple_CheckExact(__pyx_v_h)) { + __pyx_t_3 = __pyx_v_h; __Pyx_INCREF(__pyx_t_3); __pyx_t_10 = 0; + __pyx_t_20 = NULL; + } else { + __pyx_t_10 = -1; __pyx_t_3 = PyObject_GetIter(__pyx_v_h); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 376, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_20 = Py_TYPE(__pyx_t_3)->tp_iternext; if (unlikely(!__pyx_t_20)) __PYX_ERR(0, 376, __pyx_L1_error) + } + for (;;) { + if (likely(!__pyx_t_20)) { + if (likely(PyList_CheckExact(__pyx_t_3))) { + if (__pyx_t_10 >= PyList_GET_SIZE(__pyx_t_3)) break; + #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS + __pyx_t_12 = PyList_GET_ITEM(__pyx_t_3, __pyx_t_10); __Pyx_INCREF(__pyx_t_12); __pyx_t_10++; if (unlikely(0 < 0)) __PYX_ERR(0, 376, __pyx_L1_error) + #else + __pyx_t_12 = PySequence_ITEM(__pyx_t_3, __pyx_t_10); __pyx_t_10++; if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 376, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_12); + #endif + } else { + if (__pyx_t_10 >= PyTuple_GET_SIZE(__pyx_t_3)) break; + #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS + __pyx_t_12 = PyTuple_GET_ITEM(__pyx_t_3, __pyx_t_10); __Pyx_INCREF(__pyx_t_12); __pyx_t_10++; if (unlikely(0 < 0)) __PYX_ERR(0, 376, __pyx_L1_error) + #else + __pyx_t_12 = PySequence_ITEM(__pyx_t_3, __pyx_t_10); __pyx_t_10++; if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 376, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_12); + #endif + } + } else { + __pyx_t_12 = __pyx_t_20(__pyx_t_3); + if (unlikely(!__pyx_t_12)) { + PyObject* exc_type = PyErr_Occurred(); + if (exc_type) { + if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); + else __PYX_ERR(0, 376, __pyx_L1_error) + } + break; + } + __Pyx_GOTREF(__pyx_t_12); + } + __Pyx_DECREF_SET(__pyx_v_ch, __pyx_t_12); + __pyx_t_12 = 0; + + /* "yarl/_quoting_c.pyx":377 + * h = hex(ord(ch)).upper()[2:] + * for ch in h: + * ret.append(ch) # <<<<<<<<<<<<<< + * continue + * + */ + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_v_ch); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 377, __pyx_L1_error) + + /* "yarl/_quoting_c.pyx":376 + * ret.append('%') + * h = hex(ord(ch)).upper()[2:] + * for ch in h: # <<<<<<<<<<<<<< + * ret.append(ch) + * continue + */ + } + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":378 + * for ch in h: + * ret.append(ch) + * continue # <<<<<<<<<<<<<< + * + * ret.append(ch) + */ + goto __pyx_L4_continue; + + /* "yarl/_quoting_c.pyx":373 + * continue + * + * if ch in self._unsafe: # <<<<<<<<<<<<<< + * ret.append('%') + * h = hex(ord(ch)).upper()[2:] + */ + } + + /* "yarl/_quoting_c.pyx":380 + * continue + * + * ret.append(ch) # <<<<<<<<<<<<<< + * + * if pcts: + */ + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_v_ch); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 380, __pyx_L1_error) + __pyx_L4_continue:; + } + __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; + + /* "yarl/_quoting_c.pyx":382 + * ret.append(ch) + * + * if pcts: # <<<<<<<<<<<<<< + * try: + * unquoted = pcts.decode('utf8') + */ + __pyx_t_17 = (PyByteArray_GET_SIZE(__pyx_v_pcts) != 0); + if (__pyx_t_17) { + + /* "yarl/_quoting_c.pyx":383 + * + * if pcts: + * try: # <<<<<<<<<<<<<< + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + */ + { + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + __Pyx_ExceptionSave(&__pyx_t_16, &__pyx_t_15, &__pyx_t_14); + __Pyx_XGOTREF(__pyx_t_16); + __Pyx_XGOTREF(__pyx_t_15); + __Pyx_XGOTREF(__pyx_t_14); + /*try:*/ { + + /* "yarl/_quoting_c.pyx":384 + * if pcts: + * try: + * unquoted = pcts.decode('utf8') # <<<<<<<<<<<<<< + * except UnicodeDecodeError: + * ret.append(last_pct) # %F8 + */ + __pyx_t_3 = __Pyx_decode_bytearray(__pyx_v_pcts, 0, PY_SSIZE_T_MAX, NULL, NULL, PyUnicode_DecodeUTF8); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 384, __pyx_L30_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_XDECREF_SET(__pyx_v_unquoted, ((PyObject*)__pyx_t_3)); + __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":383 + * + * if pcts: + * try: # <<<<<<<<<<<<<< + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + */ + } + + /* "yarl/_quoting_c.pyx":388 + * ret.append(last_pct) # %F8 + * else: + * if self._qs and unquoted in '+=&;': # <<<<<<<<<<<<<< + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: + */ + /*else:*/ { + __pyx_t_18 = (__pyx_v_self->_qs != 0); + if (__pyx_t_18) { + } else { + __pyx_t_17 = __pyx_t_18; + goto __pyx_L37_bool_binop_done; + } + __pyx_t_18 = (__Pyx_PyUnicode_ContainsTF(__pyx_v_unquoted, __pyx_kp_u__4, Py_EQ)); if (unlikely(__pyx_t_18 < 0)) __PYX_ERR(0, 388, __pyx_L32_except_error) + __pyx_t_2 = (__pyx_t_18 != 0); + __pyx_t_17 = __pyx_t_2; + __pyx_L37_bool_binop_done:; + if (__pyx_t_17) { + + /* "yarl/_quoting_c.pyx":389 + * else: + * if self._qs and unquoted in '+=&;': + * ret.append(self._qs_quoter(unquoted)) # <<<<<<<<<<<<<< + * elif unquoted in self._unsafe: + * ret.append(self._quoter(unquoted)) + */ + __Pyx_INCREF(((PyObject *)__pyx_v_self->_qs_quoter)); + __pyx_t_12 = ((PyObject *)__pyx_v_self->_qs_quoter); __pyx_t_11 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_12))) { + __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_12); + if (likely(__pyx_t_11)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_12); + __Pyx_INCREF(__pyx_t_11); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_12, function); + } + } + __pyx_t_3 = (__pyx_t_11) ? __Pyx_PyObject_Call2Args(__pyx_t_12, __pyx_t_11, __pyx_v_unquoted) : __Pyx_PyObject_CallOneArg(__pyx_t_12, __pyx_v_unquoted); + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 389, __pyx_L32_except_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_t_3); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 389, __pyx_L32_except_error) + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":388 + * ret.append(last_pct) # %F8 + * else: + * if self._qs and unquoted in '+=&;': # <<<<<<<<<<<<<< + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: + */ + goto __pyx_L36; + } + + /* "yarl/_quoting_c.pyx":390 + * if self._qs and unquoted in '+=&;': + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: # <<<<<<<<<<<<<< + * ret.append(self._quoter(unquoted)) + * else: + */ + if (unlikely(__pyx_v_self->_unsafe == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); + __PYX_ERR(0, 390, __pyx_L32_except_error) + } + __pyx_t_17 = (__Pyx_PyUnicode_ContainsTF(__pyx_v_unquoted, __pyx_v_self->_unsafe, Py_EQ)); if (unlikely(__pyx_t_17 < 0)) __PYX_ERR(0, 390, __pyx_L32_except_error) + __pyx_t_2 = (__pyx_t_17 != 0); + if (__pyx_t_2) { + + /* "yarl/_quoting_c.pyx":391 + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: + * ret.append(self._quoter(unquoted)) # <<<<<<<<<<<<<< + * else: + * ret.append(unquoted) + */ + __Pyx_INCREF(((PyObject *)__pyx_v_self->_quoter)); + __pyx_t_12 = ((PyObject *)__pyx_v_self->_quoter); __pyx_t_11 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_12))) { + __pyx_t_11 = PyMethod_GET_SELF(__pyx_t_12); + if (likely(__pyx_t_11)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_12); + __Pyx_INCREF(__pyx_t_11); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_12, function); + } + } + __pyx_t_3 = (__pyx_t_11) ? __Pyx_PyObject_Call2Args(__pyx_t_12, __pyx_t_11, __pyx_v_unquoted) : __Pyx_PyObject_CallOneArg(__pyx_t_12, __pyx_v_unquoted); + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 391, __pyx_L32_except_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_t_3); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 391, __pyx_L32_except_error) + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "yarl/_quoting_c.pyx":390 + * if self._qs and unquoted in '+=&;': + * ret.append(self._qs_quoter(unquoted)) + * elif unquoted in self._unsafe: # <<<<<<<<<<<<<< + * ret.append(self._quoter(unquoted)) + * else: + */ + goto __pyx_L36; + } + + /* "yarl/_quoting_c.pyx":393 + * ret.append(self._quoter(unquoted)) + * else: + * ret.append(unquoted) # <<<<<<<<<<<<<< + * return ''.join(ret) + */ + /*else*/ { + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_v_unquoted); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 393, __pyx_L32_except_error) + } + __pyx_L36:; + } + __Pyx_XDECREF(__pyx_t_16); __pyx_t_16 = 0; + __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; + __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; + goto __pyx_L35_try_end; + __pyx_L30_error:; + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; + __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; + __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; + + /* "yarl/_quoting_c.pyx":385 + * try: + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: # <<<<<<<<<<<<<< + * ret.append(last_pct) # %F8 + * else: + */ + __pyx_t_7 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_UnicodeDecodeError); + if (__pyx_t_7) { + __Pyx_AddTraceback("yarl._quoting_c._Unquoter._do_unquote", __pyx_clineno, __pyx_lineno, __pyx_filename); + if (__Pyx_GetException(&__pyx_t_3, &__pyx_t_12, &__pyx_t_11) < 0) __PYX_ERR(0, 385, __pyx_L32_except_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_GOTREF(__pyx_t_12); + __Pyx_GOTREF(__pyx_t_11); + + /* "yarl/_quoting_c.pyx":386 + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + * ret.append(last_pct) # %F8 # <<<<<<<<<<<<<< + * else: + * if self._qs and unquoted in '+=&;': + */ + __pyx_t_13 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_v_last_pct); if (unlikely(__pyx_t_13 == ((int)-1))) __PYX_ERR(0, 386, __pyx_L32_except_error) + __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; + __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; + __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; + goto __pyx_L31_exception_handled; + } + goto __pyx_L32_except_error; + __pyx_L32_except_error:; + + /* "yarl/_quoting_c.pyx":383 + * + * if pcts: + * try: # <<<<<<<<<<<<<< + * unquoted = pcts.decode('utf8') + * except UnicodeDecodeError: + */ + __Pyx_XGIVEREF(__pyx_t_16); + __Pyx_XGIVEREF(__pyx_t_15); + __Pyx_XGIVEREF(__pyx_t_14); + __Pyx_ExceptionReset(__pyx_t_16, __pyx_t_15, __pyx_t_14); + goto __pyx_L1_error; + __pyx_L31_exception_handled:; + __Pyx_XGIVEREF(__pyx_t_16); + __Pyx_XGIVEREF(__pyx_t_15); + __Pyx_XGIVEREF(__pyx_t_14); + __Pyx_ExceptionReset(__pyx_t_16, __pyx_t_15, __pyx_t_14); + __pyx_L35_try_end:; + } + + /* "yarl/_quoting_c.pyx":382 + * ret.append(ch) + * + * if pcts: # <<<<<<<<<<<<<< + * try: + * unquoted = pcts.decode('utf8') + */ + } + + /* "yarl/_quoting_c.pyx":394 + * else: + * ret.append(unquoted) + * return ''.join(ret) # <<<<<<<<<<<<<< + */ + __Pyx_XDECREF(__pyx_r); + __pyx_t_11 = PyUnicode_Join(__pyx_kp_u_, __pyx_v_ret); if (unlikely(!__pyx_t_11)) __PYX_ERR(0, 394, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_11); + __pyx_r = ((PyObject*)__pyx_t_11); + __pyx_t_11 = 0; + goto __pyx_L0; + + /* "yarl/_quoting_c.pyx":328 + * return self._do_unquote(<str>val) + * + * cdef str _do_unquote(self, str val): # <<<<<<<<<<<<<< + * if len(val) == 0: + * return val + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_3); + __Pyx_XDECREF(__pyx_t_4); + __Pyx_XDECREF(__pyx_t_11); + __Pyx_XDECREF(__pyx_t_12); + __Pyx_AddTraceback("yarl._quoting_c._Unquoter._do_unquote", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = 0; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v_pct); + __Pyx_XDECREF(__pyx_v_last_pct); + __Pyx_XDECREF(__pyx_v_pcts); + __Pyx_XDECREF(__pyx_v_ret); + __Pyx_XDECREF(__pyx_v_unquoted); + __Pyx_XDECREF(__pyx_v_ch); + __Pyx_XDECREF(__pyx_v_h); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":1 + * def __reduce_cython__(self): # <<<<<<<<<<<<<< + * cdef tuple state + * cdef object _dict + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_9_Unquoter_5__reduce_cython__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ +static PyObject *__pyx_pw_4yarl_10_quoting_c_9_Unquoter_5__reduce_cython__(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__reduce_cython__ (wrapper)", 0); + __pyx_r = __pyx_pf_4yarl_10_quoting_c_9_Unquoter_4__reduce_cython__(((struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)__pyx_v_self)); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_9_Unquoter_4__reduce_cython__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self) { + PyObject *__pyx_v_state = 0; + PyObject *__pyx_v__dict = 0; + int __pyx_v_use_setstate; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + PyObject *__pyx_t_2 = NULL; + int __pyx_t_3; + int __pyx_t_4; + int __pyx_t_5; + PyObject *__pyx_t_6 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__reduce_cython__", 0); + + /* "(tree fragment)":5 + * cdef object _dict + * cdef bint use_setstate + * state = (self._qs, self._qs_quoter, self._quoter, self._unsafe) # <<<<<<<<<<<<<< + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: + */ + __pyx_t_1 = __Pyx_PyBool_FromLong(__pyx_v_self->_qs); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_2 = PyTuple_New(4); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_GIVEREF(__pyx_t_1); + PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1); + __Pyx_INCREF(((PyObject *)__pyx_v_self->_qs_quoter)); + __Pyx_GIVEREF(((PyObject *)__pyx_v_self->_qs_quoter)); + PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_v_self->_qs_quoter)); + __Pyx_INCREF(((PyObject *)__pyx_v_self->_quoter)); + __Pyx_GIVEREF(((PyObject *)__pyx_v_self->_quoter)); + PyTuple_SET_ITEM(__pyx_t_2, 2, ((PyObject *)__pyx_v_self->_quoter)); + __Pyx_INCREF(__pyx_v_self->_unsafe); + __Pyx_GIVEREF(__pyx_v_self->_unsafe); + PyTuple_SET_ITEM(__pyx_t_2, 3, __pyx_v_self->_unsafe); + __pyx_t_1 = 0; + __pyx_v_state = ((PyObject*)__pyx_t_2); + __pyx_t_2 = 0; + + /* "(tree fragment)":6 + * cdef bint use_setstate + * state = (self._qs, self._qs_quoter, self._quoter, self._unsafe) + * _dict = getattr(self, '__dict__', None) # <<<<<<<<<<<<<< + * if _dict is not None: + * state += (_dict,) + */ + __pyx_t_2 = __Pyx_GetAttr3(((PyObject *)__pyx_v_self), __pyx_n_s_dict, Py_None); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __pyx_v__dict = __pyx_t_2; + __pyx_t_2 = 0; + + /* "(tree fragment)":7 + * state = (self._qs, self._qs_quoter, self._quoter, self._unsafe) + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: # <<<<<<<<<<<<<< + * state += (_dict,) + * use_setstate = True + */ + __pyx_t_3 = (__pyx_v__dict != Py_None); + __pyx_t_4 = (__pyx_t_3 != 0); + if (__pyx_t_4) { + + /* "(tree fragment)":8 + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: + * state += (_dict,) # <<<<<<<<<<<<<< + * use_setstate = True + * else: + */ + __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 8, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(__pyx_v__dict); + __Pyx_GIVEREF(__pyx_v__dict); + PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v__dict); + __pyx_t_1 = PyNumber_InPlaceAdd(__pyx_v_state, __pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 8, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_DECREF_SET(__pyx_v_state, ((PyObject*)__pyx_t_1)); + __pyx_t_1 = 0; + + /* "(tree fragment)":9 + * if _dict is not None: + * state += (_dict,) + * use_setstate = True # <<<<<<<<<<<<<< + * else: + * use_setstate = self._qs_quoter is not None or self._quoter is not None or self._unsafe is not None + */ + __pyx_v_use_setstate = 1; + + /* "(tree fragment)":7 + * state = (self._qs, self._qs_quoter, self._quoter, self._unsafe) + * _dict = getattr(self, '__dict__', None) + * if _dict is not None: # <<<<<<<<<<<<<< + * state += (_dict,) + * use_setstate = True + */ + goto __pyx_L3; + } + + /* "(tree fragment)":11 + * use_setstate = True + * else: + * use_setstate = self._qs_quoter is not None or self._quoter is not None or self._unsafe is not None # <<<<<<<<<<<<<< + * if use_setstate: + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, None), state + */ + /*else*/ { + __pyx_t_3 = (((PyObject *)__pyx_v_self->_qs_quoter) != Py_None); + __pyx_t_5 = (__pyx_t_3 != 0); + if (!__pyx_t_5) { + } else { + __pyx_t_4 = __pyx_t_5; + goto __pyx_L4_bool_binop_done; + } + __pyx_t_5 = (((PyObject *)__pyx_v_self->_quoter) != Py_None); + __pyx_t_3 = (__pyx_t_5 != 0); + if (!__pyx_t_3) { + } else { + __pyx_t_4 = __pyx_t_3; + goto __pyx_L4_bool_binop_done; + } + __pyx_t_3 = (__pyx_v_self->_unsafe != ((PyObject*)Py_None)); + __pyx_t_5 = (__pyx_t_3 != 0); + __pyx_t_4 = __pyx_t_5; + __pyx_L4_bool_binop_done:; + __pyx_v_use_setstate = __pyx_t_4; + } + __pyx_L3:; + + /* "(tree fragment)":12 + * else: + * use_setstate = self._qs_quoter is not None or self._quoter is not None or self._unsafe is not None + * if use_setstate: # <<<<<<<<<<<<<< + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, None), state + * else: + */ + __pyx_t_4 = (__pyx_v_use_setstate != 0); + if (__pyx_t_4) { + + /* "(tree fragment)":13 + * use_setstate = self._qs_quoter is not None or self._quoter is not None or self._unsafe is not None + * if use_setstate: + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, None), state # <<<<<<<<<<<<<< + * else: + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, state) + */ + __Pyx_XDECREF(__pyx_r); + __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_pyx_unpickle__Unquoter); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 13, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_2 = PyTuple_New(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 13, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_GIVEREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + PyTuple_SET_ITEM(__pyx_t_2, 0, ((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_INCREF(__pyx_int_41310077); + __Pyx_GIVEREF(__pyx_int_41310077); + PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_int_41310077); + __Pyx_INCREF(Py_None); + __Pyx_GIVEREF(Py_None); + PyTuple_SET_ITEM(__pyx_t_2, 2, Py_None); + __pyx_t_6 = PyTuple_New(3); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 13, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_6); + __Pyx_GIVEREF(__pyx_t_1); + PyTuple_SET_ITEM(__pyx_t_6, 0, __pyx_t_1); + __Pyx_GIVEREF(__pyx_t_2); + PyTuple_SET_ITEM(__pyx_t_6, 1, __pyx_t_2); + __Pyx_INCREF(__pyx_v_state); + __Pyx_GIVEREF(__pyx_v_state); + PyTuple_SET_ITEM(__pyx_t_6, 2, __pyx_v_state); + __pyx_t_1 = 0; + __pyx_t_2 = 0; + __pyx_r = __pyx_t_6; + __pyx_t_6 = 0; + goto __pyx_L0; + + /* "(tree fragment)":12 + * else: + * use_setstate = self._qs_quoter is not None or self._quoter is not None or self._unsafe is not None + * if use_setstate: # <<<<<<<<<<<<<< + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, None), state + * else: + */ + } + + /* "(tree fragment)":15 + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, None), state + * else: + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, state) # <<<<<<<<<<<<<< + * def __setstate_cython__(self, __pyx_state): + * __pyx_unpickle__Unquoter__set_state(self, __pyx_state) + */ + /*else*/ { + __Pyx_XDECREF(__pyx_r); + __Pyx_GetModuleGlobalName(__pyx_t_6, __pyx_n_s_pyx_unpickle__Unquoter); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_6); + __pyx_t_2 = PyTuple_New(3); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_GIVEREF(((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + PyTuple_SET_ITEM(__pyx_t_2, 0, ((PyObject *)Py_TYPE(((PyObject *)__pyx_v_self)))); + __Pyx_INCREF(__pyx_int_41310077); + __Pyx_GIVEREF(__pyx_int_41310077); + PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_int_41310077); + __Pyx_INCREF(__pyx_v_state); + __Pyx_GIVEREF(__pyx_v_state); + PyTuple_SET_ITEM(__pyx_t_2, 2, __pyx_v_state); + __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_GIVEREF(__pyx_t_6); + PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_6); + __Pyx_GIVEREF(__pyx_t_2); + PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_t_2); + __pyx_t_6 = 0; + __pyx_t_2 = 0; + __pyx_r = __pyx_t_1; + __pyx_t_1 = 0; + goto __pyx_L0; + } + + /* "(tree fragment)":1 + * def __reduce_cython__(self): # <<<<<<<<<<<<<< + * cdef tuple state + * cdef object _dict + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_2); + __Pyx_XDECREF(__pyx_t_6); + __Pyx_AddTraceback("yarl._quoting_c._Unquoter.__reduce_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v_state); + __Pyx_XDECREF(__pyx_v__dict); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":16 + * else: + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, state) + * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< + * __pyx_unpickle__Unquoter__set_state(self, __pyx_state) + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_9_Unquoter_7__setstate_cython__(PyObject *__pyx_v_self, PyObject *__pyx_v___pyx_state); /*proto*/ +static PyObject *__pyx_pw_4yarl_10_quoting_c_9_Unquoter_7__setstate_cython__(PyObject *__pyx_v_self, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__setstate_cython__ (wrapper)", 0); + __pyx_r = __pyx_pf_4yarl_10_quoting_c_9_Unquoter_6__setstate_cython__(((struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)__pyx_v_self), ((PyObject *)__pyx_v___pyx_state)); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_9_Unquoter_6__setstate_cython__(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v_self, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__setstate_cython__", 0); + + /* "(tree fragment)":17 + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, state) + * def __setstate_cython__(self, __pyx_state): + * __pyx_unpickle__Unquoter__set_state(self, __pyx_state) # <<<<<<<<<<<<<< + */ + if (!(likely(PyTuple_CheckExact(__pyx_v___pyx_state))||((__pyx_v___pyx_state) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_v___pyx_state)->tp_name), 0))) __PYX_ERR(1, 17, __pyx_L1_error) + __pyx_t_1 = __pyx_f_4yarl_10_quoting_c___pyx_unpickle__Unquoter__set_state(__pyx_v_self, ((PyObject*)__pyx_v___pyx_state)); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 17, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "(tree fragment)":16 + * else: + * return __pyx_unpickle__Unquoter, (type(self), 0x276577d, state) + * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< + * __pyx_unpickle__Unquoter__set_state(self, __pyx_state) + */ + + /* function exit code */ + __pyx_r = Py_None; __Pyx_INCREF(Py_None); + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_AddTraceback("yarl._quoting_c._Unquoter.__setstate_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":1 + * def __pyx_unpickle__Quoter(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<< + * cdef object __pyx_PickleError + * cdef object __pyx_result + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_1__pyx_unpickle__Quoter(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ +static PyMethodDef __pyx_mdef_4yarl_10_quoting_c_1__pyx_unpickle__Quoter = {"__pyx_unpickle__Quoter", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_4yarl_10_quoting_c_1__pyx_unpickle__Quoter, METH_VARARGS|METH_KEYWORDS, 0}; +static PyObject *__pyx_pw_4yarl_10_quoting_c_1__pyx_unpickle__Quoter(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { + PyObject *__pyx_v___pyx_type = 0; + long __pyx_v___pyx_checksum; + PyObject *__pyx_v___pyx_state = 0; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__pyx_unpickle__Quoter (wrapper)", 0); + { + static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_pyx_type,&__pyx_n_s_pyx_checksum,&__pyx_n_s_pyx_state,0}; + PyObject* values[3] = {0,0,0}; + if (unlikely(__pyx_kwds)) { + Py_ssize_t kw_args; + const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); + switch (pos_args) { + case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); + CYTHON_FALLTHROUGH; + case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); + CYTHON_FALLTHROUGH; + case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + CYTHON_FALLTHROUGH; + case 0: break; + default: goto __pyx_L5_argtuple_error; + } + kw_args = PyDict_Size(__pyx_kwds); + switch (pos_args) { + case 0: + if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pyx_type)) != 0)) kw_args--; + else goto __pyx_L5_argtuple_error; + CYTHON_FALLTHROUGH; + case 1: + if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pyx_checksum)) != 0)) kw_args--; + else { + __Pyx_RaiseArgtupleInvalid("__pyx_unpickle__Quoter", 1, 3, 3, 1); __PYX_ERR(1, 1, __pyx_L3_error) + } + CYTHON_FALLTHROUGH; + case 2: + if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pyx_state)) != 0)) kw_args--; + else { + __Pyx_RaiseArgtupleInvalid("__pyx_unpickle__Quoter", 1, 3, 3, 2); __PYX_ERR(1, 1, __pyx_L3_error) + } + } + if (unlikely(kw_args > 0)) { + if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__pyx_unpickle__Quoter") < 0)) __PYX_ERR(1, 1, __pyx_L3_error) + } + } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { + goto __pyx_L5_argtuple_error; + } else { + values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + values[1] = PyTuple_GET_ITEM(__pyx_args, 1); + values[2] = PyTuple_GET_ITEM(__pyx_args, 2); + } + __pyx_v___pyx_type = values[0]; + __pyx_v___pyx_checksum = __Pyx_PyInt_As_long(values[1]); if (unlikely((__pyx_v___pyx_checksum == (long)-1) && PyErr_Occurred())) __PYX_ERR(1, 1, __pyx_L3_error) + __pyx_v___pyx_state = values[2]; + } + goto __pyx_L4_argument_unpacking_done; + __pyx_L5_argtuple_error:; + __Pyx_RaiseArgtupleInvalid("__pyx_unpickle__Quoter", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1, __pyx_L3_error) + __pyx_L3_error:; + __Pyx_AddTraceback("yarl._quoting_c.__pyx_unpickle__Quoter", __pyx_clineno, __pyx_lineno, __pyx_filename); + __Pyx_RefNannyFinishContext(); + return NULL; + __pyx_L4_argument_unpacking_done:; + __pyx_r = __pyx_pf_4yarl_10_quoting_c___pyx_unpickle__Quoter(__pyx_self, __pyx_v___pyx_type, __pyx_v___pyx_checksum, __pyx_v___pyx_state); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c___pyx_unpickle__Quoter(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v___pyx_type, long __pyx_v___pyx_checksum, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_v___pyx_PickleError = 0; + PyObject *__pyx_v___pyx_result = 0; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + PyObject *__pyx_t_2 = NULL; + PyObject *__pyx_t_3 = NULL; + PyObject *__pyx_t_4 = NULL; + PyObject *__pyx_t_5 = NULL; + int __pyx_t_6; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__pyx_unpickle__Quoter", 0); + + /* "(tree fragment)":4 + * cdef object __pyx_PickleError + * cdef object __pyx_result + * if __pyx_checksum != 0xe91bd35: # <<<<<<<<<<<<<< + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) + */ + __pyx_t_1 = ((__pyx_v___pyx_checksum != 0xe91bd35) != 0); + if (__pyx_t_1) { + + /* "(tree fragment)":5 + * cdef object __pyx_result + * if __pyx_checksum != 0xe91bd35: + * from pickle import PickleError as __pyx_PickleError # <<<<<<<<<<<<<< + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) + * __pyx_result = _Quoter.__new__(__pyx_type) + */ + __pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(__pyx_n_s_PickleError); + __Pyx_GIVEREF(__pyx_n_s_PickleError); + PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_PickleError); + __pyx_t_3 = __Pyx_Import(__pyx_n_s_pickle, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_PickleError); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(__pyx_t_2); + __pyx_v___pyx_PickleError = __pyx_t_2; + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "(tree fragment)":6 + * if __pyx_checksum != 0xe91bd35: + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) # <<<<<<<<<<<<<< + * __pyx_result = _Quoter.__new__(__pyx_type) + * if __pyx_state is not None: + */ + __pyx_t_2 = __Pyx_PyInt_From_long(__pyx_v___pyx_checksum); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __pyx_t_4 = __Pyx_PyString_Format(__pyx_kp_s_Incompatible_checksums_s_vs_0xe9, __pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_4); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_INCREF(__pyx_v___pyx_PickleError); + __pyx_t_2 = __pyx_v___pyx_PickleError; __pyx_t_5 = NULL; + if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) { + __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2); + if (likely(__pyx_t_5)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); + __Pyx_INCREF(__pyx_t_5); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_2, function); + } + } + __pyx_t_3 = (__pyx_t_5) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_5, __pyx_t_4) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_4); + __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; + __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; + if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_Raise(__pyx_t_3, 0, 0, 0); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __PYX_ERR(1, 6, __pyx_L1_error) + + /* "(tree fragment)":4 + * cdef object __pyx_PickleError + * cdef object __pyx_result + * if __pyx_checksum != 0xe91bd35: # <<<<<<<<<<<<<< + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) + */ + } + + /* "(tree fragment)":7 + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) + * __pyx_result = _Quoter.__new__(__pyx_type) # <<<<<<<<<<<<<< + * if __pyx_state is not None: + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + */ + __pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_ptype_4yarl_10_quoting_c__Quoter), __pyx_n_s_new); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __pyx_t_4 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { + __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2); + if (likely(__pyx_t_4)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); + __Pyx_INCREF(__pyx_t_4); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_2, function); + } + } + __pyx_t_3 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_v___pyx_type) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v___pyx_type); + __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; + if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __pyx_v___pyx_result = __pyx_t_3; + __pyx_t_3 = 0; + + /* "(tree fragment)":8 + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) + * __pyx_result = _Quoter.__new__(__pyx_type) + * if __pyx_state is not None: # <<<<<<<<<<<<<< + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + * return __pyx_result + */ + __pyx_t_1 = (__pyx_v___pyx_state != Py_None); + __pyx_t_6 = (__pyx_t_1 != 0); + if (__pyx_t_6) { + + /* "(tree fragment)":9 + * __pyx_result = _Quoter.__new__(__pyx_type) + * if __pyx_state is not None: + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) # <<<<<<<<<<<<<< + * return __pyx_result + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): + */ + if (!(likely(PyTuple_CheckExact(__pyx_v___pyx_state))||((__pyx_v___pyx_state) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_v___pyx_state)->tp_name), 0))) __PYX_ERR(1, 9, __pyx_L1_error) + __pyx_t_3 = __pyx_f_4yarl_10_quoting_c___pyx_unpickle__Quoter__set_state(((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_v___pyx_result), ((PyObject*)__pyx_v___pyx_state)); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 9, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "(tree fragment)":8 + * raise __pyx_PickleError("Incompatible checksums (%s vs 0xe91bd35 = (_protected_table, _qs, _requote, _safe_table))" % __pyx_checksum) + * __pyx_result = _Quoter.__new__(__pyx_type) + * if __pyx_state is not None: # <<<<<<<<<<<<<< + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + * return __pyx_result + */ + } + + /* "(tree fragment)":10 + * if __pyx_state is not None: + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + * return __pyx_result # <<<<<<<<<<<<<< + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + */ + __Pyx_XDECREF(__pyx_r); + __Pyx_INCREF(__pyx_v___pyx_result); + __pyx_r = __pyx_v___pyx_result; + goto __pyx_L0; + + /* "(tree fragment)":1 + * def __pyx_unpickle__Quoter(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<< + * cdef object __pyx_PickleError + * cdef object __pyx_result + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_2); + __Pyx_XDECREF(__pyx_t_3); + __Pyx_XDECREF(__pyx_t_4); + __Pyx_XDECREF(__pyx_t_5); + __Pyx_AddTraceback("yarl._quoting_c.__pyx_unpickle__Quoter", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v___pyx_PickleError); + __Pyx_XDECREF(__pyx_v___pyx_result); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":11 + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + * return __pyx_result + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<< + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + */ + +static PyObject *__pyx_f_4yarl_10_quoting_c___pyx_unpickle__Quoter__set_state(struct __pyx_obj_4yarl_10_quoting_c__Quoter *__pyx_v___pyx_result, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + uint8_t __pyx_t_2[16]; + int __pyx_t_3; + Py_ssize_t __pyx_t_4; + int __pyx_t_5; + int __pyx_t_6; + PyObject *__pyx_t_7 = NULL; + PyObject *__pyx_t_8 = NULL; + PyObject *__pyx_t_9 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__pyx_unpickle__Quoter__set_state", 0); + + /* "(tree fragment)":12 + * return __pyx_result + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] # <<<<<<<<<<<<<< + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + * __pyx_result.__dict__.update(__pyx_state[4]) + */ + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (unlikely(__Pyx_carray_from_py_uint8_t(__pyx_t_1, __pyx_t_2, 16) < 0)) __PYX_ERR(1, 12, __pyx_L1_error) + memcpy(&(__pyx_v___pyx_result->_protected_table[0]), __pyx_t_2, sizeof(__pyx_v___pyx_result->_protected_table[0]) * (16)); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 1, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_3 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_v___pyx_result->_qs = __pyx_t_3; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 2, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_3 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_v___pyx_result->_requote = __pyx_t_3; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 3, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (unlikely(__Pyx_carray_from_py_uint8_t(__pyx_t_1, __pyx_t_2, 16) < 0)) __PYX_ERR(1, 12, __pyx_L1_error) + memcpy(&(__pyx_v___pyx_result->_safe_table[0]), __pyx_t_2, sizeof(__pyx_v___pyx_result->_safe_table[0]) * (16)); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "(tree fragment)":13 + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): # <<<<<<<<<<<<<< + * __pyx_result.__dict__.update(__pyx_state[4]) + */ + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); + __PYX_ERR(1, 13, __pyx_L1_error) + } + __pyx_t_4 = PyTuple_GET_SIZE(__pyx_v___pyx_state); if (unlikely(__pyx_t_4 == ((Py_ssize_t)-1))) __PYX_ERR(1, 13, __pyx_L1_error) + __pyx_t_5 = ((__pyx_t_4 > 4) != 0); + if (__pyx_t_5) { + } else { + __pyx_t_3 = __pyx_t_5; + goto __pyx_L4_bool_binop_done; + } + __pyx_t_5 = __Pyx_HasAttr(((PyObject *)__pyx_v___pyx_result), __pyx_n_s_dict); if (unlikely(__pyx_t_5 == ((int)-1))) __PYX_ERR(1, 13, __pyx_L1_error) + __pyx_t_6 = (__pyx_t_5 != 0); + __pyx_t_3 = __pyx_t_6; + __pyx_L4_bool_binop_done:; + if (__pyx_t_3) { + + /* "(tree fragment)":14 + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + * __pyx_result.__dict__.update(__pyx_state[4]) # <<<<<<<<<<<<<< + */ + __pyx_t_7 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v___pyx_result), __pyx_n_s_dict); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_7); + __pyx_t_8 = __Pyx_PyObject_GetAttrStr(__pyx_t_7, __pyx_n_s_update); if (unlikely(!__pyx_t_8)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_8); + __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 14, __pyx_L1_error) + } + __pyx_t_7 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 4, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_7); + __pyx_t_9 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_8))) { + __pyx_t_9 = PyMethod_GET_SELF(__pyx_t_8); + if (likely(__pyx_t_9)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_8); + __Pyx_INCREF(__pyx_t_9); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_8, function); + } + } + __pyx_t_1 = (__pyx_t_9) ? __Pyx_PyObject_Call2Args(__pyx_t_8, __pyx_t_9, __pyx_t_7) : __Pyx_PyObject_CallOneArg(__pyx_t_8, __pyx_t_7); + __Pyx_XDECREF(__pyx_t_9); __pyx_t_9 = 0; + __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; + if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "(tree fragment)":13 + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): # <<<<<<<<<<<<<< + * __pyx_result.__dict__.update(__pyx_state[4]) + */ + } + + /* "(tree fragment)":11 + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + * return __pyx_result + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<< + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + */ + + /* function exit code */ + __pyx_r = Py_None; __Pyx_INCREF(Py_None); + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_7); + __Pyx_XDECREF(__pyx_t_8); + __Pyx_XDECREF(__pyx_t_9); + __Pyx_AddTraceback("yarl._quoting_c.__pyx_unpickle__Quoter__set_state", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = 0; + __pyx_L0:; + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":1 + * def __pyx_unpickle__Unquoter(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<< + * cdef object __pyx_PickleError + * cdef object __pyx_result + */ + +/* Python wrapper */ +static PyObject *__pyx_pw_4yarl_10_quoting_c_3__pyx_unpickle__Unquoter(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ +static PyMethodDef __pyx_mdef_4yarl_10_quoting_c_3__pyx_unpickle__Unquoter = {"__pyx_unpickle__Unquoter", (PyCFunction)(void*)(PyCFunctionWithKeywords)__pyx_pw_4yarl_10_quoting_c_3__pyx_unpickle__Unquoter, METH_VARARGS|METH_KEYWORDS, 0}; +static PyObject *__pyx_pw_4yarl_10_quoting_c_3__pyx_unpickle__Unquoter(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { + PyObject *__pyx_v___pyx_type = 0; + long __pyx_v___pyx_checksum; + PyObject *__pyx_v___pyx_state = 0; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + PyObject *__pyx_r = 0; + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__pyx_unpickle__Unquoter (wrapper)", 0); + { + static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_pyx_type,&__pyx_n_s_pyx_checksum,&__pyx_n_s_pyx_state,0}; + PyObject* values[3] = {0,0,0}; + if (unlikely(__pyx_kwds)) { + Py_ssize_t kw_args; + const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); + switch (pos_args) { + case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); + CYTHON_FALLTHROUGH; + case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); + CYTHON_FALLTHROUGH; + case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + CYTHON_FALLTHROUGH; + case 0: break; + default: goto __pyx_L5_argtuple_error; + } + kw_args = PyDict_Size(__pyx_kwds); + switch (pos_args) { + case 0: + if (likely((values[0] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pyx_type)) != 0)) kw_args--; + else goto __pyx_L5_argtuple_error; + CYTHON_FALLTHROUGH; + case 1: + if (likely((values[1] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pyx_checksum)) != 0)) kw_args--; + else { + __Pyx_RaiseArgtupleInvalid("__pyx_unpickle__Unquoter", 1, 3, 3, 1); __PYX_ERR(1, 1, __pyx_L3_error) + } + CYTHON_FALLTHROUGH; + case 2: + if (likely((values[2] = __Pyx_PyDict_GetItemStr(__pyx_kwds, __pyx_n_s_pyx_state)) != 0)) kw_args--; + else { + __Pyx_RaiseArgtupleInvalid("__pyx_unpickle__Unquoter", 1, 3, 3, 2); __PYX_ERR(1, 1, __pyx_L3_error) + } + } + if (unlikely(kw_args > 0)) { + if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__pyx_unpickle__Unquoter") < 0)) __PYX_ERR(1, 1, __pyx_L3_error) + } + } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { + goto __pyx_L5_argtuple_error; + } else { + values[0] = PyTuple_GET_ITEM(__pyx_args, 0); + values[1] = PyTuple_GET_ITEM(__pyx_args, 1); + values[2] = PyTuple_GET_ITEM(__pyx_args, 2); + } + __pyx_v___pyx_type = values[0]; + __pyx_v___pyx_checksum = __Pyx_PyInt_As_long(values[1]); if (unlikely((__pyx_v___pyx_checksum == (long)-1) && PyErr_Occurred())) __PYX_ERR(1, 1, __pyx_L3_error) + __pyx_v___pyx_state = values[2]; + } + goto __pyx_L4_argument_unpacking_done; + __pyx_L5_argtuple_error:; + __Pyx_RaiseArgtupleInvalid("__pyx_unpickle__Unquoter", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); __PYX_ERR(1, 1, __pyx_L3_error) + __pyx_L3_error:; + __Pyx_AddTraceback("yarl._quoting_c.__pyx_unpickle__Unquoter", __pyx_clineno, __pyx_lineno, __pyx_filename); + __Pyx_RefNannyFinishContext(); + return NULL; + __pyx_L4_argument_unpacking_done:; + __pyx_r = __pyx_pf_4yarl_10_quoting_c_2__pyx_unpickle__Unquoter(__pyx_self, __pyx_v___pyx_type, __pyx_v___pyx_checksum, __pyx_v___pyx_state); + + /* function exit code */ + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +static PyObject *__pyx_pf_4yarl_10_quoting_c_2__pyx_unpickle__Unquoter(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v___pyx_type, long __pyx_v___pyx_checksum, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_v___pyx_PickleError = 0; + PyObject *__pyx_v___pyx_result = 0; + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + int __pyx_t_1; + PyObject *__pyx_t_2 = NULL; + PyObject *__pyx_t_3 = NULL; + PyObject *__pyx_t_4 = NULL; + PyObject *__pyx_t_5 = NULL; + int __pyx_t_6; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__pyx_unpickle__Unquoter", 0); + + /* "(tree fragment)":4 + * cdef object __pyx_PickleError + * cdef object __pyx_result + * if __pyx_checksum != 0x276577d: # <<<<<<<<<<<<<< + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) + */ + __pyx_t_1 = ((__pyx_v___pyx_checksum != 0x276577d) != 0); + if (__pyx_t_1) { + + /* "(tree fragment)":5 + * cdef object __pyx_result + * if __pyx_checksum != 0x276577d: + * from pickle import PickleError as __pyx_PickleError # <<<<<<<<<<<<<< + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) + * __pyx_result = _Unquoter.__new__(__pyx_type) + */ + __pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(__pyx_n_s_PickleError); + __Pyx_GIVEREF(__pyx_n_s_PickleError); + PyList_SET_ITEM(__pyx_t_2, 0, __pyx_n_s_PickleError); + __pyx_t_3 = __Pyx_Import(__pyx_n_s_pickle, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __pyx_t_2 = __Pyx_ImportFrom(__pyx_t_3, __pyx_n_s_PickleError); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 5, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_INCREF(__pyx_t_2); + __pyx_v___pyx_PickleError = __pyx_t_2; + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "(tree fragment)":6 + * if __pyx_checksum != 0x276577d: + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) # <<<<<<<<<<<<<< + * __pyx_result = _Unquoter.__new__(__pyx_type) + * if __pyx_state is not None: + */ + __pyx_t_2 = __Pyx_PyInt_From_long(__pyx_v___pyx_checksum); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __pyx_t_4 = __Pyx_PyString_Format(__pyx_kp_s_Incompatible_checksums_s_vs_0x27, __pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_4); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_INCREF(__pyx_v___pyx_PickleError); + __pyx_t_2 = __pyx_v___pyx_PickleError; __pyx_t_5 = NULL; + if (CYTHON_UNPACK_METHODS && unlikely(PyMethod_Check(__pyx_t_2))) { + __pyx_t_5 = PyMethod_GET_SELF(__pyx_t_2); + if (likely(__pyx_t_5)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); + __Pyx_INCREF(__pyx_t_5); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_2, function); + } + } + __pyx_t_3 = (__pyx_t_5) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_5, __pyx_t_4) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_t_4); + __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; + __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; + if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 6, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_Raise(__pyx_t_3, 0, 0, 0); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __PYX_ERR(1, 6, __pyx_L1_error) + + /* "(tree fragment)":4 + * cdef object __pyx_PickleError + * cdef object __pyx_result + * if __pyx_checksum != 0x276577d: # <<<<<<<<<<<<<< + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) + */ + } + + /* "(tree fragment)":7 + * from pickle import PickleError as __pyx_PickleError + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) + * __pyx_result = _Unquoter.__new__(__pyx_type) # <<<<<<<<<<<<<< + * if __pyx_state is not None: + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) + */ + __pyx_t_2 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_ptype_4yarl_10_quoting_c__Unquoter), __pyx_n_s_new); if (unlikely(!__pyx_t_2)) __PYX_ERR(1, 7, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __pyx_t_4 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_2))) { + __pyx_t_4 = PyMethod_GET_SELF(__pyx_t_2); + if (likely(__pyx_t_4)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_2); + __Pyx_INCREF(__pyx_t_4); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_2, function); + } + } + __pyx_t_3 = (__pyx_t_4) ? __Pyx_PyObject_Call2Args(__pyx_t_2, __pyx_t_4, __pyx_v___pyx_type) : __Pyx_PyObject_CallOneArg(__pyx_t_2, __pyx_v___pyx_type); + __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; + if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 7, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __pyx_v___pyx_result = __pyx_t_3; + __pyx_t_3 = 0; + + /* "(tree fragment)":8 + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) + * __pyx_result = _Unquoter.__new__(__pyx_type) + * if __pyx_state is not None: # <<<<<<<<<<<<<< + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) + * return __pyx_result + */ + __pyx_t_1 = (__pyx_v___pyx_state != Py_None); + __pyx_t_6 = (__pyx_t_1 != 0); + if (__pyx_t_6) { + + /* "(tree fragment)":9 + * __pyx_result = _Unquoter.__new__(__pyx_type) + * if __pyx_state is not None: + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) # <<<<<<<<<<<<<< + * return __pyx_result + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): + */ + if (!(likely(PyTuple_CheckExact(__pyx_v___pyx_state))||((__pyx_v___pyx_state) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "tuple", Py_TYPE(__pyx_v___pyx_state)->tp_name), 0))) __PYX_ERR(1, 9, __pyx_L1_error) + __pyx_t_3 = __pyx_f_4yarl_10_quoting_c___pyx_unpickle__Unquoter__set_state(((struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)__pyx_v___pyx_result), ((PyObject*)__pyx_v___pyx_state)); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 9, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + + /* "(tree fragment)":8 + * raise __pyx_PickleError("Incompatible checksums (%s vs 0x276577d = (_qs, _qs_quoter, _quoter, _unsafe))" % __pyx_checksum) + * __pyx_result = _Unquoter.__new__(__pyx_type) + * if __pyx_state is not None: # <<<<<<<<<<<<<< + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) + * return __pyx_result + */ + } + + /* "(tree fragment)":10 + * if __pyx_state is not None: + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) + * return __pyx_result # <<<<<<<<<<<<<< + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] + */ + __Pyx_XDECREF(__pyx_r); + __Pyx_INCREF(__pyx_v___pyx_result); + __pyx_r = __pyx_v___pyx_result; + goto __pyx_L0; + + /* "(tree fragment)":1 + * def __pyx_unpickle__Unquoter(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<< + * cdef object __pyx_PickleError + * cdef object __pyx_result + */ + + /* function exit code */ + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_2); + __Pyx_XDECREF(__pyx_t_3); + __Pyx_XDECREF(__pyx_t_4); + __Pyx_XDECREF(__pyx_t_5); + __Pyx_AddTraceback("yarl._quoting_c.__pyx_unpickle__Unquoter", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = NULL; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v___pyx_PickleError); + __Pyx_XDECREF(__pyx_v___pyx_result); + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "(tree fragment)":11 + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) + * return __pyx_result + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<< + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + */ + +static PyObject *__pyx_f_4yarl_10_quoting_c___pyx_unpickle__Unquoter__set_state(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *__pyx_v___pyx_result, PyObject *__pyx_v___pyx_state) { + PyObject *__pyx_r = NULL; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + int __pyx_t_2; + Py_ssize_t __pyx_t_3; + int __pyx_t_4; + int __pyx_t_5; + PyObject *__pyx_t_6 = NULL; + PyObject *__pyx_t_7 = NULL; + PyObject *__pyx_t_8 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__pyx_unpickle__Unquoter__set_state", 0); + + /* "(tree fragment)":12 + * return __pyx_result + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] # <<<<<<<<<<<<<< + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + * __pyx_result.__dict__.update(__pyx_state[4]) + */ + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely((__pyx_t_2 == (int)-1) && PyErr_Occurred())) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_v___pyx_result->_qs = __pyx_t_2; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 1, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_4yarl_10_quoting_c__Quoter))))) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GIVEREF(__pyx_t_1); + __Pyx_GOTREF(__pyx_v___pyx_result->_qs_quoter); + __Pyx_DECREF(((PyObject *)__pyx_v___pyx_result->_qs_quoter)); + __pyx_v___pyx_result->_qs_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_t_1); + __pyx_t_1 = 0; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 2, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_4yarl_10_quoting_c__Quoter))))) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GIVEREF(__pyx_t_1); + __Pyx_GOTREF(__pyx_v___pyx_result->_quoter); + __Pyx_DECREF(((PyObject *)__pyx_v___pyx_result->_quoter)); + __pyx_v___pyx_result->_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)__pyx_t_1); + __pyx_t_1 = 0; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 12, __pyx_L1_error) + } + __pyx_t_1 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 3, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (!(likely(PyUnicode_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "unicode", Py_TYPE(__pyx_t_1)->tp_name), 0))) __PYX_ERR(1, 12, __pyx_L1_error) + __Pyx_GIVEREF(__pyx_t_1); + __Pyx_GOTREF(__pyx_v___pyx_result->_unsafe); + __Pyx_DECREF(__pyx_v___pyx_result->_unsafe); + __pyx_v___pyx_result->_unsafe = ((PyObject*)__pyx_t_1); + __pyx_t_1 = 0; + + /* "(tree fragment)":13 + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): # <<<<<<<<<<<<<< + * __pyx_result.__dict__.update(__pyx_state[4]) + */ + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "object of type 'NoneType' has no len()"); + __PYX_ERR(1, 13, __pyx_L1_error) + } + __pyx_t_3 = PyTuple_GET_SIZE(__pyx_v___pyx_state); if (unlikely(__pyx_t_3 == ((Py_ssize_t)-1))) __PYX_ERR(1, 13, __pyx_L1_error) + __pyx_t_4 = ((__pyx_t_3 > 4) != 0); + if (__pyx_t_4) { + } else { + __pyx_t_2 = __pyx_t_4; + goto __pyx_L4_bool_binop_done; + } + __pyx_t_4 = __Pyx_HasAttr(((PyObject *)__pyx_v___pyx_result), __pyx_n_s_dict); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(1, 13, __pyx_L1_error) + __pyx_t_5 = (__pyx_t_4 != 0); + __pyx_t_2 = __pyx_t_5; + __pyx_L4_bool_binop_done:; + if (__pyx_t_2) { + + /* "(tree fragment)":14 + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + * __pyx_result.__dict__.update(__pyx_state[4]) # <<<<<<<<<<<<<< + */ + __pyx_t_6 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v___pyx_result), __pyx_n_s_dict); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_6); + __pyx_t_7 = __Pyx_PyObject_GetAttrStr(__pyx_t_6, __pyx_n_s_update); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_7); + __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; + if (unlikely(__pyx_v___pyx_state == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not subscriptable"); + __PYX_ERR(1, 14, __pyx_L1_error) + } + __pyx_t_6 = __Pyx_GetItemInt_Tuple(__pyx_v___pyx_state, 4, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_6); + __pyx_t_8 = NULL; + if (CYTHON_UNPACK_METHODS && likely(PyMethod_Check(__pyx_t_7))) { + __pyx_t_8 = PyMethod_GET_SELF(__pyx_t_7); + if (likely(__pyx_t_8)) { + PyObject* function = PyMethod_GET_FUNCTION(__pyx_t_7); + __Pyx_INCREF(__pyx_t_8); + __Pyx_INCREF(function); + __Pyx_DECREF_SET(__pyx_t_7, function); + } + } + __pyx_t_1 = (__pyx_t_8) ? __Pyx_PyObject_Call2Args(__pyx_t_7, __pyx_t_8, __pyx_t_6) : __Pyx_PyObject_CallOneArg(__pyx_t_7, __pyx_t_6); + __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; + __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; + if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "(tree fragment)":13 + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): # <<<<<<<<<<<<<< + * __pyx_result.__dict__.update(__pyx_state[4]) + */ + } + + /* "(tree fragment)":11 + * __pyx_unpickle__Unquoter__set_state(<_Unquoter> __pyx_result, __pyx_state) + * return __pyx_result + * cdef __pyx_unpickle__Unquoter__set_state(_Unquoter __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<< + * __pyx_result._qs = __pyx_state[0]; __pyx_result._qs_quoter = __pyx_state[1]; __pyx_result._quoter = __pyx_state[2]; __pyx_result._unsafe = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + */ + + /* function exit code */ + __pyx_r = Py_None; __Pyx_INCREF(Py_None); + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_6); + __Pyx_XDECREF(__pyx_t_7); + __Pyx_XDECREF(__pyx_t_8); + __Pyx_AddTraceback("yarl._quoting_c.__pyx_unpickle__Unquoter__set_state", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = 0; + __pyx_L0:; + __Pyx_XGIVEREF(__pyx_r); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} + +/* "carray.from_py":77 + * + * @cname("__Pyx_carray_from_py_uint8_t") + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: # <<<<<<<<<<<<<< + * cdef Py_ssize_t i = length + * try: + */ + +static int __Pyx_carray_from_py_uint8_t(PyObject *__pyx_v_o, uint8_t *__pyx_v_v, Py_ssize_t __pyx_v_length) { + Py_ssize_t __pyx_v_i; + PyObject *__pyx_v_item = NULL; + int __pyx_r; + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + PyObject *__pyx_t_2 = NULL; + PyObject *__pyx_t_3 = NULL; + Py_ssize_t __pyx_t_4; + int __pyx_t_5; + int __pyx_t_6; + PyObject *__pyx_t_7 = NULL; + Py_ssize_t __pyx_t_8; + PyObject *(*__pyx_t_9)(PyObject *); + PyObject *__pyx_t_10 = NULL; + uint8_t __pyx_t_11; + char const *__pyx_t_12; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__Pyx_carray_from_py_uint8_t", 0); + + /* "carray.from_py":78 + * @cname("__Pyx_carray_from_py_uint8_t") + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: + * cdef Py_ssize_t i = length # <<<<<<<<<<<<<< + * try: + * i = len(o) + */ + __pyx_v_i = __pyx_v_length; + + /* "carray.from_py":79 + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: + * cdef Py_ssize_t i = length + * try: # <<<<<<<<<<<<<< + * i = len(o) + * except (TypeError, OverflowError): + */ + { + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + __Pyx_ExceptionSave(&__pyx_t_1, &__pyx_t_2, &__pyx_t_3); + __Pyx_XGOTREF(__pyx_t_1); + __Pyx_XGOTREF(__pyx_t_2); + __Pyx_XGOTREF(__pyx_t_3); + /*try:*/ { + + /* "carray.from_py":80 + * cdef Py_ssize_t i = length + * try: + * i = len(o) # <<<<<<<<<<<<<< + * except (TypeError, OverflowError): + * pass + */ + __pyx_t_4 = PyObject_Length(__pyx_v_o); if (unlikely(__pyx_t_4 == ((Py_ssize_t)-1))) __PYX_ERR(1, 80, __pyx_L3_error) + __pyx_v_i = __pyx_t_4; + + /* "carray.from_py":79 + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: + * cdef Py_ssize_t i = length + * try: # <<<<<<<<<<<<<< + * i = len(o) + * except (TypeError, OverflowError): + */ + } + __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; + __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; + goto __pyx_L8_try_end; + __pyx_L3_error:; + + /* "carray.from_py":81 + * try: + * i = len(o) + * except (TypeError, OverflowError): # <<<<<<<<<<<<<< + * pass + * if i == length: + */ + __pyx_t_5 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_TypeError) || __Pyx_PyErr_ExceptionMatches(__pyx_builtin_OverflowError); + if (__pyx_t_5) { + __Pyx_ErrRestore(0,0,0); + goto __pyx_L4_exception_handled; + } + goto __pyx_L5_except_error; + __pyx_L5_except_error:; + + /* "carray.from_py":79 + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: + * cdef Py_ssize_t i = length + * try: # <<<<<<<<<<<<<< + * i = len(o) + * except (TypeError, OverflowError): + */ + __Pyx_XGIVEREF(__pyx_t_1); + __Pyx_XGIVEREF(__pyx_t_2); + __Pyx_XGIVEREF(__pyx_t_3); + __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); + goto __pyx_L1_error; + __pyx_L4_exception_handled:; + __Pyx_XGIVEREF(__pyx_t_1); + __Pyx_XGIVEREF(__pyx_t_2); + __Pyx_XGIVEREF(__pyx_t_3); + __Pyx_ExceptionReset(__pyx_t_1, __pyx_t_2, __pyx_t_3); + __pyx_L8_try_end:; + } + + /* "carray.from_py":83 + * except (TypeError, OverflowError): + * pass + * if i == length: # <<<<<<<<<<<<<< + * for i, item in enumerate(o): + * if i >= length: + */ + __pyx_t_6 = ((__pyx_v_i == __pyx_v_length) != 0); + if (__pyx_t_6) { + + /* "carray.from_py":84 + * pass + * if i == length: + * for i, item in enumerate(o): # <<<<<<<<<<<<<< + * if i >= length: + * break + */ + __pyx_t_4 = 0; + if (likely(PyList_CheckExact(__pyx_v_o)) || PyTuple_CheckExact(__pyx_v_o)) { + __pyx_t_7 = __pyx_v_o; __Pyx_INCREF(__pyx_t_7); __pyx_t_8 = 0; + __pyx_t_9 = NULL; + } else { + __pyx_t_8 = -1; __pyx_t_7 = PyObject_GetIter(__pyx_v_o); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 84, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_7); + __pyx_t_9 = Py_TYPE(__pyx_t_7)->tp_iternext; if (unlikely(!__pyx_t_9)) __PYX_ERR(1, 84, __pyx_L1_error) + } + for (;;) { + if (likely(!__pyx_t_9)) { + if (likely(PyList_CheckExact(__pyx_t_7))) { + if (__pyx_t_8 >= PyList_GET_SIZE(__pyx_t_7)) break; + #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS + __pyx_t_10 = PyList_GET_ITEM(__pyx_t_7, __pyx_t_8); __Pyx_INCREF(__pyx_t_10); __pyx_t_8++; if (unlikely(0 < 0)) __PYX_ERR(1, 84, __pyx_L1_error) + #else + __pyx_t_10 = PySequence_ITEM(__pyx_t_7, __pyx_t_8); __pyx_t_8++; if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 84, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_10); + #endif + } else { + if (__pyx_t_8 >= PyTuple_GET_SIZE(__pyx_t_7)) break; + #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS + __pyx_t_10 = PyTuple_GET_ITEM(__pyx_t_7, __pyx_t_8); __Pyx_INCREF(__pyx_t_10); __pyx_t_8++; if (unlikely(0 < 0)) __PYX_ERR(1, 84, __pyx_L1_error) + #else + __pyx_t_10 = PySequence_ITEM(__pyx_t_7, __pyx_t_8); __pyx_t_8++; if (unlikely(!__pyx_t_10)) __PYX_ERR(1, 84, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_10); + #endif + } + } else { + __pyx_t_10 = __pyx_t_9(__pyx_t_7); + if (unlikely(!__pyx_t_10)) { + PyObject* exc_type = PyErr_Occurred(); + if (exc_type) { + if (likely(__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear(); + else __PYX_ERR(1, 84, __pyx_L1_error) + } + break; + } + __Pyx_GOTREF(__pyx_t_10); + } + __Pyx_XDECREF_SET(__pyx_v_item, __pyx_t_10); + __pyx_t_10 = 0; + __pyx_v_i = __pyx_t_4; + __pyx_t_4 = (__pyx_t_4 + 1); + + /* "carray.from_py":85 + * if i == length: + * for i, item in enumerate(o): + * if i >= length: # <<<<<<<<<<<<<< + * break + * v[i] = item + */ + __pyx_t_6 = ((__pyx_v_i >= __pyx_v_length) != 0); + if (__pyx_t_6) { + + /* "carray.from_py":86 + * for i, item in enumerate(o): + * if i >= length: + * break # <<<<<<<<<<<<<< + * v[i] = item + * else: + */ + goto __pyx_L11_break; + + /* "carray.from_py":85 + * if i == length: + * for i, item in enumerate(o): + * if i >= length: # <<<<<<<<<<<<<< + * break + * v[i] = item + */ + } + + /* "carray.from_py":87 + * if i >= length: + * break + * v[i] = item # <<<<<<<<<<<<<< + * else: + * i += 1 # convert index to length + */ + __pyx_t_11 = __Pyx_PyInt_As_uint8_t(__pyx_v_item); if (unlikely((__pyx_t_11 == ((uint8_t)-1)) && PyErr_Occurred())) __PYX_ERR(1, 87, __pyx_L1_error) + (__pyx_v_v[__pyx_v_i]) = __pyx_t_11; + + /* "carray.from_py":84 + * pass + * if i == length: + * for i, item in enumerate(o): # <<<<<<<<<<<<<< + * if i >= length: + * break + */ + } + /*else*/ { + + /* "carray.from_py":89 + * v[i] = item + * else: + * i += 1 # convert index to length # <<<<<<<<<<<<<< + * if i == length: + * return 0 + */ + __pyx_v_i = (__pyx_v_i + 1); + + /* "carray.from_py":90 + * else: + * i += 1 # convert index to length + * if i == length: # <<<<<<<<<<<<<< + * return 0 + * + */ + __pyx_t_6 = ((__pyx_v_i == __pyx_v_length) != 0); + if (__pyx_t_6) { + + /* "carray.from_py":91 + * i += 1 # convert index to length + * if i == length: + * return 0 # <<<<<<<<<<<<<< + * + * PyErr_Format( + */ + __pyx_r = 0; + __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; + goto __pyx_L0; + + /* "carray.from_py":90 + * else: + * i += 1 # convert index to length + * if i == length: # <<<<<<<<<<<<<< + * return 0 + * + */ + } + } + + /* "carray.from_py":84 + * pass + * if i == length: + * for i, item in enumerate(o): # <<<<<<<<<<<<<< + * if i >= length: + * break + */ + __pyx_L11_break:; + __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; + + /* "carray.from_py":83 + * except (TypeError, OverflowError): + * pass + * if i == length: # <<<<<<<<<<<<<< + * for i, item in enumerate(o): + * if i >= length: + */ + } + + /* "carray.from_py":96 + * IndexError, + * ("too many values found during array assignment, expected %zd" + * if i >= length else # <<<<<<<<<<<<<< + * "not enough values found during array assignment, expected %zd, got %zd"), + * length, i) + */ + if (((__pyx_v_i >= __pyx_v_length) != 0)) { + __pyx_t_12 = ((char const *)"too many values found during array assignment, expected %zd"); + } else { + __pyx_t_12 = ((char const *)"not enough values found during array assignment, expected %zd, got %zd"); + } + + /* "carray.from_py":93 + * return 0 + * + * PyErr_Format( # <<<<<<<<<<<<<< + * IndexError, + * ("too many values found during array assignment, expected %zd" + */ + __pyx_t_7 = PyErr_Format(__pyx_builtin_IndexError, __pyx_t_12, __pyx_v_length, __pyx_v_i); if (unlikely(!__pyx_t_7)) __PYX_ERR(1, 93, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_7); + __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; + + /* "carray.from_py":77 + * + * @cname("__Pyx_carray_from_py_uint8_t") + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: # <<<<<<<<<<<<<< + * cdef Py_ssize_t i = length + * try: + */ + + /* function exit code */ + __pyx_r = 0; + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_7); + __Pyx_XDECREF(__pyx_t_10); + __Pyx_AddTraceback("carray.from_py.__Pyx_carray_from_py_uint8_t", __pyx_clineno, __pyx_lineno, __pyx_filename); + __pyx_r = -1; + __pyx_L0:; + __Pyx_XDECREF(__pyx_v_item); + __Pyx_RefNannyFinishContext(); + return __pyx_r; +} +static struct __pyx_vtabstruct_4yarl_10_quoting_c__Quoter __pyx_vtable_4yarl_10_quoting_c__Quoter; + +static PyObject *__pyx_tp_new_4yarl_10_quoting_c__Quoter(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) { + struct __pyx_obj_4yarl_10_quoting_c__Quoter *p; + PyObject *o; + if (likely((t->tp_flags & Py_TPFLAGS_IS_ABSTRACT) == 0)) { + o = (*t->tp_alloc)(t, 0); + } else { + o = (PyObject *) PyBaseObject_Type.tp_new(t, __pyx_empty_tuple, 0); + } + if (unlikely(!o)) return 0; + p = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)o); + p->__pyx_vtab = __pyx_vtabptr_4yarl_10_quoting_c__Quoter; + return o; +} + +static void __pyx_tp_dealloc_4yarl_10_quoting_c__Quoter(PyObject *o) { + #if CYTHON_USE_TP_FINALIZE + if (unlikely(PyType_HasFeature(Py_TYPE(o), Py_TPFLAGS_HAVE_FINALIZE) && Py_TYPE(o)->tp_finalize) && (!PyType_IS_GC(Py_TYPE(o)) || !_PyGC_FINALIZED(o))) { + if (PyObject_CallFinalizerFromDealloc(o)) return; + } + #endif + (*Py_TYPE(o)->tp_free)(o); +} + +static PyMethodDef __pyx_methods_4yarl_10_quoting_c__Quoter[] = { + {"__reduce_cython__", (PyCFunction)__pyx_pw_4yarl_10_quoting_c_7_Quoter_5__reduce_cython__, METH_NOARGS, 0}, + {"__setstate_cython__", (PyCFunction)__pyx_pw_4yarl_10_quoting_c_7_Quoter_7__setstate_cython__, METH_O, 0}, + {0, 0, 0, 0} +}; + +static PyTypeObject __pyx_type_4yarl_10_quoting_c__Quoter = { + PyVarObject_HEAD_INIT(0, 0) + "yarl._quoting_c._Quoter", /*tp_name*/ + sizeof(struct __pyx_obj_4yarl_10_quoting_c__Quoter), /*tp_basicsize*/ + 0, /*tp_itemsize*/ + __pyx_tp_dealloc_4yarl_10_quoting_c__Quoter, /*tp_dealloc*/ + #if PY_VERSION_HEX < 0x030800b4 + 0, /*tp_print*/ + #endif + #if PY_VERSION_HEX >= 0x030800b4 + 0, /*tp_vectorcall_offset*/ + #endif + 0, /*tp_getattr*/ + 0, /*tp_setattr*/ + #if PY_MAJOR_VERSION < 3 + 0, /*tp_compare*/ + #endif + #if PY_MAJOR_VERSION >= 3 + 0, /*tp_as_async*/ + #endif + 0, /*tp_repr*/ + 0, /*tp_as_number*/ + 0, /*tp_as_sequence*/ + 0, /*tp_as_mapping*/ + 0, /*tp_hash*/ + __pyx_pw_4yarl_10_quoting_c_7_Quoter_3__call__, /*tp_call*/ + 0, /*tp_str*/ + 0, /*tp_getattro*/ + 0, /*tp_setattro*/ + 0, /*tp_as_buffer*/ + Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE, /*tp_flags*/ + 0, /*tp_doc*/ + 0, /*tp_traverse*/ + 0, /*tp_clear*/ + 0, /*tp_richcompare*/ + 0, /*tp_weaklistoffset*/ + 0, /*tp_iter*/ + 0, /*tp_iternext*/ + __pyx_methods_4yarl_10_quoting_c__Quoter, /*tp_methods*/ + 0, /*tp_members*/ + 0, /*tp_getset*/ + 0, /*tp_base*/ + 0, /*tp_dict*/ + 0, /*tp_descr_get*/ + 0, /*tp_descr_set*/ + 0, /*tp_dictoffset*/ + __pyx_pw_4yarl_10_quoting_c_7_Quoter_1__init__, /*tp_init*/ + 0, /*tp_alloc*/ + __pyx_tp_new_4yarl_10_quoting_c__Quoter, /*tp_new*/ + 0, /*tp_free*/ + 0, /*tp_is_gc*/ + 0, /*tp_bases*/ + 0, /*tp_mro*/ + 0, /*tp_cache*/ + 0, /*tp_subclasses*/ + 0, /*tp_weaklist*/ + 0, /*tp_del*/ + 0, /*tp_version_tag*/ + #if PY_VERSION_HEX >= 0x030400a1 + 0, /*tp_finalize*/ + #endif + #if PY_VERSION_HEX >= 0x030800b1 + 0, /*tp_vectorcall*/ + #endif + #if PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x03090000 + 0, /*tp_print*/ + #endif +}; +static struct __pyx_vtabstruct_4yarl_10_quoting_c__Unquoter __pyx_vtable_4yarl_10_quoting_c__Unquoter; + +static PyObject *__pyx_tp_new_4yarl_10_quoting_c__Unquoter(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) { + struct __pyx_obj_4yarl_10_quoting_c__Unquoter *p; + PyObject *o; + if (likely((t->tp_flags & Py_TPFLAGS_IS_ABSTRACT) == 0)) { + o = (*t->tp_alloc)(t, 0); + } else { + o = (PyObject *) PyBaseObject_Type.tp_new(t, __pyx_empty_tuple, 0); + } + if (unlikely(!o)) return 0; + p = ((struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)o); + p->__pyx_vtab = __pyx_vtabptr_4yarl_10_quoting_c__Unquoter; + p->_unsafe = ((PyObject*)Py_None); Py_INCREF(Py_None); + p->_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)Py_None); Py_INCREF(Py_None); + p->_qs_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)Py_None); Py_INCREF(Py_None); + return o; +} + +static void __pyx_tp_dealloc_4yarl_10_quoting_c__Unquoter(PyObject *o) { + struct __pyx_obj_4yarl_10_quoting_c__Unquoter *p = (struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)o; + #if CYTHON_USE_TP_FINALIZE + if (unlikely(PyType_HasFeature(Py_TYPE(o), Py_TPFLAGS_HAVE_FINALIZE) && Py_TYPE(o)->tp_finalize) && !_PyGC_FINALIZED(o)) { + if (PyObject_CallFinalizerFromDealloc(o)) return; + } + #endif + PyObject_GC_UnTrack(o); + Py_CLEAR(p->_unsafe); + Py_CLEAR(p->_quoter); + Py_CLEAR(p->_qs_quoter); + (*Py_TYPE(o)->tp_free)(o); +} + +static int __pyx_tp_traverse_4yarl_10_quoting_c__Unquoter(PyObject *o, visitproc v, void *a) { + int e; + struct __pyx_obj_4yarl_10_quoting_c__Unquoter *p = (struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)o; + if (p->_quoter) { + e = (*v)(((PyObject *)p->_quoter), a); if (e) return e; + } + if (p->_qs_quoter) { + e = (*v)(((PyObject *)p->_qs_quoter), a); if (e) return e; + } + return 0; +} + +static int __pyx_tp_clear_4yarl_10_quoting_c__Unquoter(PyObject *o) { + PyObject* tmp; + struct __pyx_obj_4yarl_10_quoting_c__Unquoter *p = (struct __pyx_obj_4yarl_10_quoting_c__Unquoter *)o; + tmp = ((PyObject*)p->_quoter); + p->_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)Py_None); Py_INCREF(Py_None); + Py_XDECREF(tmp); + tmp = ((PyObject*)p->_qs_quoter); + p->_qs_quoter = ((struct __pyx_obj_4yarl_10_quoting_c__Quoter *)Py_None); Py_INCREF(Py_None); + Py_XDECREF(tmp); + return 0; +} + +static PyMethodDef __pyx_methods_4yarl_10_quoting_c__Unquoter[] = { + {"__reduce_cython__", (PyCFunction)__pyx_pw_4yarl_10_quoting_c_9_Unquoter_5__reduce_cython__, METH_NOARGS, 0}, + {"__setstate_cython__", (PyCFunction)__pyx_pw_4yarl_10_quoting_c_9_Unquoter_7__setstate_cython__, METH_O, 0}, + {0, 0, 0, 0} +}; + +static PyTypeObject __pyx_type_4yarl_10_quoting_c__Unquoter = { + PyVarObject_HEAD_INIT(0, 0) + "yarl._quoting_c._Unquoter", /*tp_name*/ + sizeof(struct __pyx_obj_4yarl_10_quoting_c__Unquoter), /*tp_basicsize*/ + 0, /*tp_itemsize*/ + __pyx_tp_dealloc_4yarl_10_quoting_c__Unquoter, /*tp_dealloc*/ + #if PY_VERSION_HEX < 0x030800b4 + 0, /*tp_print*/ + #endif + #if PY_VERSION_HEX >= 0x030800b4 + 0, /*tp_vectorcall_offset*/ + #endif + 0, /*tp_getattr*/ + 0, /*tp_setattr*/ + #if PY_MAJOR_VERSION < 3 + 0, /*tp_compare*/ + #endif + #if PY_MAJOR_VERSION >= 3 + 0, /*tp_as_async*/ + #endif + 0, /*tp_repr*/ + 0, /*tp_as_number*/ + 0, /*tp_as_sequence*/ + 0, /*tp_as_mapping*/ + 0, /*tp_hash*/ + __pyx_pw_4yarl_10_quoting_c_9_Unquoter_3__call__, /*tp_call*/ + 0, /*tp_str*/ + 0, /*tp_getattro*/ + 0, /*tp_setattro*/ + 0, /*tp_as_buffer*/ + Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/ + 0, /*tp_doc*/ + __pyx_tp_traverse_4yarl_10_quoting_c__Unquoter, /*tp_traverse*/ + __pyx_tp_clear_4yarl_10_quoting_c__Unquoter, /*tp_clear*/ + 0, /*tp_richcompare*/ + 0, /*tp_weaklistoffset*/ + 0, /*tp_iter*/ + 0, /*tp_iternext*/ + __pyx_methods_4yarl_10_quoting_c__Unquoter, /*tp_methods*/ + 0, /*tp_members*/ + 0, /*tp_getset*/ + 0, /*tp_base*/ + 0, /*tp_dict*/ + 0, /*tp_descr_get*/ + 0, /*tp_descr_set*/ + 0, /*tp_dictoffset*/ + __pyx_pw_4yarl_10_quoting_c_9_Unquoter_1__init__, /*tp_init*/ + 0, /*tp_alloc*/ + __pyx_tp_new_4yarl_10_quoting_c__Unquoter, /*tp_new*/ + 0, /*tp_free*/ + 0, /*tp_is_gc*/ + 0, /*tp_bases*/ + 0, /*tp_mro*/ + 0, /*tp_cache*/ + 0, /*tp_subclasses*/ + 0, /*tp_weaklist*/ + 0, /*tp_del*/ + 0, /*tp_version_tag*/ + #if PY_VERSION_HEX >= 0x030400a1 + 0, /*tp_finalize*/ + #endif + #if PY_VERSION_HEX >= 0x030800b1 + 0, /*tp_vectorcall*/ + #endif + #if PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x03090000 + 0, /*tp_print*/ + #endif +}; + +static PyMethodDef __pyx_methods[] = { + {0, 0, 0, 0} +}; + +#if PY_MAJOR_VERSION >= 3 +#if CYTHON_PEP489_MULTI_PHASE_INIT +static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/ +static int __pyx_pymod_exec__quoting_c(PyObject* module); /*proto*/ +static PyModuleDef_Slot __pyx_moduledef_slots[] = { + {Py_mod_create, (void*)__pyx_pymod_create}, + {Py_mod_exec, (void*)__pyx_pymod_exec__quoting_c}, + {0, NULL} +}; +#endif + +static struct PyModuleDef __pyx_moduledef = { + PyModuleDef_HEAD_INIT, + "_quoting_c", + 0, /* m_doc */ + #if CYTHON_PEP489_MULTI_PHASE_INIT + 0, /* m_size */ + #else + -1, /* m_size */ + #endif + __pyx_methods /* m_methods */, + #if CYTHON_PEP489_MULTI_PHASE_INIT + __pyx_moduledef_slots, /* m_slots */ + #else + NULL, /* m_reload */ + #endif + NULL, /* m_traverse */ + NULL, /* m_clear */ + NULL /* m_free */ +}; +#endif +#ifndef CYTHON_SMALL_CODE +#if defined(__clang__) + #define CYTHON_SMALL_CODE +#elif defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)) + #define CYTHON_SMALL_CODE __attribute__((cold)) +#else + #define CYTHON_SMALL_CODE +#endif +#endif + +static __Pyx_StringTabEntry __pyx_string_tab[] = { + {&__pyx_kp_u_, __pyx_k_, sizeof(__pyx_k_), 0, 1, 0, 0}, + {&__pyx_kp_u_Argument_should_be_str, __pyx_k_Argument_should_be_str, sizeof(__pyx_k_Argument_should_be_str), 0, 1, 0, 0}, + {&__pyx_kp_s_Incompatible_checksums_s_vs_0x27, __pyx_k_Incompatible_checksums_s_vs_0x27, sizeof(__pyx_k_Incompatible_checksums_s_vs_0x27), 0, 0, 1, 0}, + {&__pyx_kp_s_Incompatible_checksums_s_vs_0xe9, __pyx_k_Incompatible_checksums_s_vs_0xe9, sizeof(__pyx_k_Incompatible_checksums_s_vs_0xe9), 0, 0, 1, 0}, + {&__pyx_n_s_IndexError, __pyx_k_IndexError, sizeof(__pyx_k_IndexError), 0, 0, 1, 1}, + {&__pyx_kp_u_Only_safe_symbols_with_ORD_128_a, __pyx_k_Only_safe_symbols_with_ORD_128_a, sizeof(__pyx_k_Only_safe_symbols_with_ORD_128_a), 0, 1, 0, 0}, + {&__pyx_n_s_OverflowError, __pyx_k_OverflowError, sizeof(__pyx_k_OverflowError), 0, 0, 1, 1}, + {&__pyx_n_s_PickleError, __pyx_k_PickleError, sizeof(__pyx_k_PickleError), 0, 0, 1, 1}, + {&__pyx_n_s_Quoter, __pyx_k_Quoter, sizeof(__pyx_k_Quoter), 0, 0, 1, 1}, + {&__pyx_n_s_TypeError, __pyx_k_TypeError, sizeof(__pyx_k_TypeError), 0, 0, 1, 1}, + {&__pyx_n_s_UnicodeDecodeError, __pyx_k_UnicodeDecodeError, sizeof(__pyx_k_UnicodeDecodeError), 0, 0, 1, 1}, + {&__pyx_n_s_Unquoter, __pyx_k_Unquoter, sizeof(__pyx_k_Unquoter), 0, 0, 1, 1}, + {&__pyx_n_s_ValueError, __pyx_k_ValueError, sizeof(__pyx_k_ValueError), 0, 0, 1, 1}, + {&__pyx_kp_u__10, __pyx_k__10, sizeof(__pyx_k__10), 0, 1, 0, 0}, + {&__pyx_kp_u__11, __pyx_k__11, sizeof(__pyx_k__11), 0, 1, 0, 0}, + {&__pyx_kp_u__12, __pyx_k__12, sizeof(__pyx_k__12), 0, 1, 0, 0}, + {&__pyx_kp_u__13, __pyx_k__13, sizeof(__pyx_k__13), 0, 1, 0, 0}, + {&__pyx_kp_u__4, __pyx_k__4, sizeof(__pyx_k__4), 0, 1, 0, 0}, + {&__pyx_kp_u__5, __pyx_k__5, sizeof(__pyx_k__5), 0, 1, 0, 0}, + {&__pyx_kp_u__6, __pyx_k__6, sizeof(__pyx_k__6), 0, 1, 0, 0}, + {&__pyx_kp_u__7, __pyx_k__7, sizeof(__pyx_k__7), 0, 1, 0, 0}, + {&__pyx_kp_u__9, __pyx_k__9, sizeof(__pyx_k__9), 0, 1, 0, 0}, + {&__pyx_n_s_append, __pyx_k_append, sizeof(__pyx_k_append), 0, 0, 1, 1}, + {&__pyx_n_s_ascii_letters, __pyx_k_ascii_letters, sizeof(__pyx_k_ascii_letters), 0, 0, 1, 1}, + {&__pyx_n_s_base, __pyx_k_base, sizeof(__pyx_k_base), 0, 0, 1, 1}, + {&__pyx_n_s_chr, __pyx_k_chr, sizeof(__pyx_k_chr), 0, 0, 1, 1}, + {&__pyx_n_s_cline_in_traceback, __pyx_k_cline_in_traceback, sizeof(__pyx_k_cline_in_traceback), 0, 0, 1, 1}, + {&__pyx_n_s_dict, __pyx_k_dict, sizeof(__pyx_k_dict), 0, 0, 1, 1}, + {&__pyx_n_s_digits, __pyx_k_digits, sizeof(__pyx_k_digits), 0, 0, 1, 1}, + {&__pyx_n_s_enumerate, __pyx_k_enumerate, sizeof(__pyx_k_enumerate), 0, 0, 1, 1}, + {&__pyx_n_s_getstate, __pyx_k_getstate, sizeof(__pyx_k_getstate), 0, 0, 1, 1}, + {&__pyx_n_s_hex, __pyx_k_hex, sizeof(__pyx_k_hex), 0, 0, 1, 1}, + {&__pyx_n_s_i, __pyx_k_i, sizeof(__pyx_k_i), 0, 0, 1, 1}, + {&__pyx_n_s_import, __pyx_k_import, sizeof(__pyx_k_import), 0, 0, 1, 1}, + {&__pyx_n_s_main, __pyx_k_main, sizeof(__pyx_k_main), 0, 0, 1, 1}, + {&__pyx_n_s_name, __pyx_k_name, sizeof(__pyx_k_name), 0, 0, 1, 1}, + {&__pyx_n_s_new, __pyx_k_new, sizeof(__pyx_k_new), 0, 0, 1, 1}, + {&__pyx_n_s_pickle, __pyx_k_pickle, sizeof(__pyx_k_pickle), 0, 0, 1, 1}, + {&__pyx_n_s_protected, __pyx_k_protected, sizeof(__pyx_k_protected), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_PickleError, __pyx_k_pyx_PickleError, sizeof(__pyx_k_pyx_PickleError), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_checksum, __pyx_k_pyx_checksum, sizeof(__pyx_k_pyx_checksum), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_result, __pyx_k_pyx_result, sizeof(__pyx_k_pyx_result), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_state, __pyx_k_pyx_state, sizeof(__pyx_k_pyx_state), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_type, __pyx_k_pyx_type, sizeof(__pyx_k_pyx_type), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_unpickle__Quoter, __pyx_k_pyx_unpickle__Quoter, sizeof(__pyx_k_pyx_unpickle__Quoter), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_unpickle__Unquoter, __pyx_k_pyx_unpickle__Unquoter, sizeof(__pyx_k_pyx_unpickle__Unquoter), 0, 0, 1, 1}, + {&__pyx_n_s_pyx_vtable, __pyx_k_pyx_vtable, sizeof(__pyx_k_pyx_vtable), 0, 0, 1, 1}, + {&__pyx_n_s_qs, __pyx_k_qs, sizeof(__pyx_k_qs), 0, 0, 1, 1}, + {&__pyx_n_s_range, __pyx_k_range, sizeof(__pyx_k_range), 0, 0, 1, 1}, + {&__pyx_n_s_reduce, __pyx_k_reduce, sizeof(__pyx_k_reduce), 0, 0, 1, 1}, + {&__pyx_n_s_reduce_cython, __pyx_k_reduce_cython, sizeof(__pyx_k_reduce_cython), 0, 0, 1, 1}, + {&__pyx_n_s_reduce_ex, __pyx_k_reduce_ex, sizeof(__pyx_k_reduce_ex), 0, 0, 1, 1}, + {&__pyx_n_s_requote, __pyx_k_requote, sizeof(__pyx_k_requote), 0, 0, 1, 1}, + {&__pyx_n_s_safe, __pyx_k_safe, sizeof(__pyx_k_safe), 0, 0, 1, 1}, + {&__pyx_n_s_setstate, __pyx_k_setstate, sizeof(__pyx_k_setstate), 0, 0, 1, 1}, + {&__pyx_n_s_setstate_cython, __pyx_k_setstate_cython, sizeof(__pyx_k_setstate_cython), 0, 0, 1, 1}, + {&__pyx_n_s_string, __pyx_k_string, sizeof(__pyx_k_string), 0, 0, 1, 1}, + {&__pyx_kp_s_stringsource, __pyx_k_stringsource, sizeof(__pyx_k_stringsource), 0, 0, 1, 0}, + {&__pyx_n_s_test, __pyx_k_test, sizeof(__pyx_k_test), 0, 0, 1, 1}, + {&__pyx_n_s_unsafe, __pyx_k_unsafe, sizeof(__pyx_k_unsafe), 0, 0, 1, 1}, + {&__pyx_n_s_update, __pyx_k_update, sizeof(__pyx_k_update), 0, 0, 1, 1}, + {&__pyx_n_s_upper, __pyx_k_upper, sizeof(__pyx_k_upper), 0, 0, 1, 1}, + {&__pyx_n_s_val, __pyx_k_val, sizeof(__pyx_k_val), 0, 0, 1, 1}, + {&__pyx_n_s_yarl__quoting_c, __pyx_k_yarl__quoting_c, sizeof(__pyx_k_yarl__quoting_c), 0, 0, 1, 1}, + {0, 0, 0, 0, 0, 0, 0} +}; +static CYTHON_SMALL_CODE int __Pyx_InitCachedBuiltins(void) { + __pyx_builtin_range = __Pyx_GetBuiltinName(__pyx_n_s_range); if (!__pyx_builtin_range) __PYX_ERR(0, 67, __pyx_L1_error) + __pyx_builtin_chr = __Pyx_GetBuiltinName(__pyx_n_s_chr); if (!__pyx_builtin_chr) __PYX_ERR(0, 68, __pyx_L1_error) + __pyx_builtin_ValueError = __Pyx_GetBuiltinName(__pyx_n_s_ValueError); if (!__pyx_builtin_ValueError) __PYX_ERR(0, 211, __pyx_L1_error) + __pyx_builtin_TypeError = __Pyx_GetBuiltinName(__pyx_n_s_TypeError); if (!__pyx_builtin_TypeError) __PYX_ERR(0, 230, __pyx_L1_error) + __pyx_builtin_UnicodeDecodeError = __Pyx_GetBuiltinName(__pyx_n_s_UnicodeDecodeError); if (!__pyx_builtin_UnicodeDecodeError) __PYX_ERR(0, 347, __pyx_L1_error) + __pyx_builtin_hex = __Pyx_GetBuiltinName(__pyx_n_s_hex); if (!__pyx_builtin_hex) __PYX_ERR(0, 375, __pyx_L1_error) + __pyx_builtin_OverflowError = __Pyx_GetBuiltinName(__pyx_n_s_OverflowError); if (!__pyx_builtin_OverflowError) __PYX_ERR(1, 81, __pyx_L1_error) + __pyx_builtin_enumerate = __Pyx_GetBuiltinName(__pyx_n_s_enumerate); if (!__pyx_builtin_enumerate) __PYX_ERR(1, 84, __pyx_L1_error) + __pyx_builtin_IndexError = __Pyx_GetBuiltinName(__pyx_n_s_IndexError); if (!__pyx_builtin_IndexError) __PYX_ERR(1, 94, __pyx_L1_error) + return 0; + __pyx_L1_error:; + return -1; +} + +static CYTHON_SMALL_CODE int __Pyx_InitCachedConstants(void) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0); + + /* "yarl/_quoting_c.pyx":211 + * for ch in safe: + * if ord(ch) > 127: + * raise ValueError("Only safe symbols with ORD < 128 are allowed") # <<<<<<<<<<<<<< + * set_bit(self._safe_table, ch) + * + */ + __pyx_tuple__2 = PyTuple_Pack(1, __pyx_kp_u_Only_safe_symbols_with_ORD_128_a); if (unlikely(!__pyx_tuple__2)) __PYX_ERR(0, 211, __pyx_L1_error) + __Pyx_GOTREF(__pyx_tuple__2); + __Pyx_GIVEREF(__pyx_tuple__2); + + /* "yarl/_quoting_c.pyx":230 + * val = str(val) + * else: + * raise TypeError("Argument should be str") # <<<<<<<<<<<<<< + * _init_writer(&writer) + * try: + */ + __pyx_tuple__3 = PyTuple_Pack(1, __pyx_kp_u_Argument_should_be_str); if (unlikely(!__pyx_tuple__3)) __PYX_ERR(0, 230, __pyx_L1_error) + __Pyx_GOTREF(__pyx_tuple__3); + __Pyx_GIVEREF(__pyx_tuple__3); + + /* "yarl/_quoting_c.pyx":375 + * if ch in self._unsafe: + * ret.append('%') + * h = hex(ord(ch)).upper()[2:] # <<<<<<<<<<<<<< + * for ch in h: + * ret.append(ch) + */ + __pyx_slice__8 = PySlice_New(__pyx_int_2, Py_None, Py_None); if (unlikely(!__pyx_slice__8)) __PYX_ERR(0, 375, __pyx_L1_error) + __Pyx_GOTREF(__pyx_slice__8); + __Pyx_GIVEREF(__pyx_slice__8); + + /* "(tree fragment)":1 + * def __pyx_unpickle__Quoter(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<< + * cdef object __pyx_PickleError + * cdef object __pyx_result + */ + __pyx_tuple__14 = PyTuple_Pack(5, __pyx_n_s_pyx_type, __pyx_n_s_pyx_checksum, __pyx_n_s_pyx_state, __pyx_n_s_pyx_PickleError, __pyx_n_s_pyx_result); if (unlikely(!__pyx_tuple__14)) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_GOTREF(__pyx_tuple__14); + __Pyx_GIVEREF(__pyx_tuple__14); + __pyx_codeobj__15 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__14, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_stringsource, __pyx_n_s_pyx_unpickle__Quoter, 1, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__15)) __PYX_ERR(1, 1, __pyx_L1_error) + __pyx_tuple__16 = PyTuple_Pack(5, __pyx_n_s_pyx_type, __pyx_n_s_pyx_checksum, __pyx_n_s_pyx_state, __pyx_n_s_pyx_PickleError, __pyx_n_s_pyx_result); if (unlikely(!__pyx_tuple__16)) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_GOTREF(__pyx_tuple__16); + __Pyx_GIVEREF(__pyx_tuple__16); + __pyx_codeobj__17 = (PyObject*)__Pyx_PyCode_New(3, 0, 5, 0, CO_OPTIMIZED|CO_NEWLOCALS, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_tuple__16, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_stringsource, __pyx_n_s_pyx_unpickle__Unquoter, 1, __pyx_empty_bytes); if (unlikely(!__pyx_codeobj__17)) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_RefNannyFinishContext(); + return 0; + __pyx_L1_error:; + __Pyx_RefNannyFinishContext(); + return -1; +} + +static CYTHON_SMALL_CODE int __Pyx_InitGlobals(void) { + if (__Pyx_InitStrings(__pyx_string_tab) < 0) __PYX_ERR(0, 1, __pyx_L1_error); + __pyx_int_2 = PyInt_FromLong(2); if (unlikely(!__pyx_int_2)) __PYX_ERR(0, 1, __pyx_L1_error) + __pyx_int_16 = PyInt_FromLong(16); if (unlikely(!__pyx_int_16)) __PYX_ERR(0, 1, __pyx_L1_error) + __pyx_int_41310077 = PyInt_FromLong(41310077L); if (unlikely(!__pyx_int_41310077)) __PYX_ERR(0, 1, __pyx_L1_error) + __pyx_int_244432181 = PyInt_FromLong(244432181L); if (unlikely(!__pyx_int_244432181)) __PYX_ERR(0, 1, __pyx_L1_error) + return 0; + __pyx_L1_error:; + return -1; +} + +static CYTHON_SMALL_CODE int __Pyx_modinit_global_init_code(void); /*proto*/ +static CYTHON_SMALL_CODE int __Pyx_modinit_variable_export_code(void); /*proto*/ +static CYTHON_SMALL_CODE int __Pyx_modinit_function_export_code(void); /*proto*/ +static CYTHON_SMALL_CODE int __Pyx_modinit_type_init_code(void); /*proto*/ +static CYTHON_SMALL_CODE int __Pyx_modinit_type_import_code(void); /*proto*/ +static CYTHON_SMALL_CODE int __Pyx_modinit_variable_import_code(void); /*proto*/ +static CYTHON_SMALL_CODE int __Pyx_modinit_function_import_code(void); /*proto*/ + +static int __Pyx_modinit_global_init_code(void) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__Pyx_modinit_global_init_code", 0); + /*--- Global init code ---*/ + __pyx_v_4yarl_10_quoting_c_GEN_DELIMS = ((PyObject*)Py_None); Py_INCREF(Py_None); + __pyx_v_4yarl_10_quoting_c_SUB_DELIMS_WITHOUT_QS = ((PyObject*)Py_None); Py_INCREF(Py_None); + __pyx_v_4yarl_10_quoting_c_SUB_DELIMS = ((PyObject*)Py_None); Py_INCREF(Py_None); + __pyx_v_4yarl_10_quoting_c_RESERVED = ((PyObject*)Py_None); Py_INCREF(Py_None); + __pyx_v_4yarl_10_quoting_c_UNRESERVED = ((PyObject*)Py_None); Py_INCREF(Py_None); + __pyx_v_4yarl_10_quoting_c_ALLOWED = ((PyObject*)Py_None); Py_INCREF(Py_None); + __pyx_v_4yarl_10_quoting_c_QS = ((PyObject*)Py_None); Py_INCREF(Py_None); + __Pyx_RefNannyFinishContext(); + return 0; +} + +static int __Pyx_modinit_variable_export_code(void) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__Pyx_modinit_variable_export_code", 0); + /*--- Variable export code ---*/ + __Pyx_RefNannyFinishContext(); + return 0; +} + +static int __Pyx_modinit_function_export_code(void) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__Pyx_modinit_function_export_code", 0); + /*--- Function export code ---*/ + __Pyx_RefNannyFinishContext(); + return 0; +} + +static int __Pyx_modinit_type_init_code(void) { + __Pyx_RefNannyDeclarations + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__Pyx_modinit_type_init_code", 0); + /*--- Type init code ---*/ + __pyx_vtabptr_4yarl_10_quoting_c__Quoter = &__pyx_vtable_4yarl_10_quoting_c__Quoter; + __pyx_vtable_4yarl_10_quoting_c__Quoter._do_quote = (PyObject *(*)(struct __pyx_obj_4yarl_10_quoting_c__Quoter *, PyObject *, struct __pyx_t_4yarl_10_quoting_c_Writer *))__pyx_f_4yarl_10_quoting_c_7_Quoter__do_quote; + __pyx_vtable_4yarl_10_quoting_c__Quoter._write = (int (*)(struct __pyx_obj_4yarl_10_quoting_c__Quoter *, struct __pyx_t_4yarl_10_quoting_c_Writer *, Py_UCS4))__pyx_f_4yarl_10_quoting_c_7_Quoter__write; + if (PyType_Ready(&__pyx_type_4yarl_10_quoting_c__Quoter) < 0) __PYX_ERR(0, 186, __pyx_L1_error) + #if PY_VERSION_HEX < 0x030800B1 + __pyx_type_4yarl_10_quoting_c__Quoter.tp_print = 0; + #endif + if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_type_4yarl_10_quoting_c__Quoter.tp_dictoffset && __pyx_type_4yarl_10_quoting_c__Quoter.tp_getattro == PyObject_GenericGetAttr)) { + __pyx_type_4yarl_10_quoting_c__Quoter.tp_getattro = __Pyx_PyObject_GenericGetAttr; + } + if (__Pyx_SetVtable(__pyx_type_4yarl_10_quoting_c__Quoter.tp_dict, __pyx_vtabptr_4yarl_10_quoting_c__Quoter) < 0) __PYX_ERR(0, 186, __pyx_L1_error) + if (PyObject_SetAttr(__pyx_m, __pyx_n_s_Quoter, (PyObject *)&__pyx_type_4yarl_10_quoting_c__Quoter) < 0) __PYX_ERR(0, 186, __pyx_L1_error) + if (__Pyx_setup_reduce((PyObject*)&__pyx_type_4yarl_10_quoting_c__Quoter) < 0) __PYX_ERR(0, 186, __pyx_L1_error) + __pyx_ptype_4yarl_10_quoting_c__Quoter = &__pyx_type_4yarl_10_quoting_c__Quoter; + __pyx_vtabptr_4yarl_10_quoting_c__Unquoter = &__pyx_vtable_4yarl_10_quoting_c__Unquoter; + __pyx_vtable_4yarl_10_quoting_c__Unquoter._do_unquote = (PyObject *(*)(struct __pyx_obj_4yarl_10_quoting_c__Unquoter *, PyObject *))__pyx_f_4yarl_10_quoting_c_9_Unquoter__do_unquote; + if (PyType_Ready(&__pyx_type_4yarl_10_quoting_c__Unquoter) < 0) __PYX_ERR(0, 305, __pyx_L1_error) + #if PY_VERSION_HEX < 0x030800B1 + __pyx_type_4yarl_10_quoting_c__Unquoter.tp_print = 0; + #endif + if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_type_4yarl_10_quoting_c__Unquoter.tp_dictoffset && __pyx_type_4yarl_10_quoting_c__Unquoter.tp_getattro == PyObject_GenericGetAttr)) { + __pyx_type_4yarl_10_quoting_c__Unquoter.tp_getattro = __Pyx_PyObject_GenericGetAttr; + } + if (__Pyx_SetVtable(__pyx_type_4yarl_10_quoting_c__Unquoter.tp_dict, __pyx_vtabptr_4yarl_10_quoting_c__Unquoter) < 0) __PYX_ERR(0, 305, __pyx_L1_error) + if (PyObject_SetAttr(__pyx_m, __pyx_n_s_Unquoter, (PyObject *)&__pyx_type_4yarl_10_quoting_c__Unquoter) < 0) __PYX_ERR(0, 305, __pyx_L1_error) + if (__Pyx_setup_reduce((PyObject*)&__pyx_type_4yarl_10_quoting_c__Unquoter) < 0) __PYX_ERR(0, 305, __pyx_L1_error) + __pyx_ptype_4yarl_10_quoting_c__Unquoter = &__pyx_type_4yarl_10_quoting_c__Unquoter; + __Pyx_RefNannyFinishContext(); + return 0; + __pyx_L1_error:; + __Pyx_RefNannyFinishContext(); + return -1; +} + +static int __Pyx_modinit_type_import_code(void) { + __Pyx_RefNannyDeclarations + PyObject *__pyx_t_1 = NULL; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannySetupContext("__Pyx_modinit_type_import_code", 0); + /*--- Type import code ---*/ + __pyx_t_1 = PyImport_ImportModule(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_t_1)) __PYX_ERR(2, 9, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_ptype_7cpython_4type_type = __Pyx_ImportType(__pyx_t_1, __Pyx_BUILTIN_MODULE_NAME, "type", + #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000 + sizeof(PyTypeObject), + #else + sizeof(PyHeapTypeObject), + #endif + __Pyx_ImportType_CheckSize_Warn); + if (!__pyx_ptype_7cpython_4type_type) __PYX_ERR(2, 9, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __Pyx_RefNannyFinishContext(); + return 0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_RefNannyFinishContext(); + return -1; +} + +static int __Pyx_modinit_variable_import_code(void) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__Pyx_modinit_variable_import_code", 0); + /*--- Variable import code ---*/ + __Pyx_RefNannyFinishContext(); + return 0; +} + +static int __Pyx_modinit_function_import_code(void) { + __Pyx_RefNannyDeclarations + __Pyx_RefNannySetupContext("__Pyx_modinit_function_import_code", 0); + /*--- Function import code ---*/ + __Pyx_RefNannyFinishContext(); + return 0; +} + + +#ifndef CYTHON_NO_PYINIT_EXPORT +#define __Pyx_PyMODINIT_FUNC PyMODINIT_FUNC +#elif PY_MAJOR_VERSION < 3 +#ifdef __cplusplus +#define __Pyx_PyMODINIT_FUNC extern "C" void +#else +#define __Pyx_PyMODINIT_FUNC void +#endif +#else +#ifdef __cplusplus +#define __Pyx_PyMODINIT_FUNC extern "C" PyObject * +#else +#define __Pyx_PyMODINIT_FUNC PyObject * +#endif +#endif + + +#if PY_MAJOR_VERSION < 3 +__Pyx_PyMODINIT_FUNC init_quoting_c(void) CYTHON_SMALL_CODE; /*proto*/ +__Pyx_PyMODINIT_FUNC init_quoting_c(void) +#else +__Pyx_PyMODINIT_FUNC PyInit__quoting_c(void) CYTHON_SMALL_CODE; /*proto*/ +__Pyx_PyMODINIT_FUNC PyInit__quoting_c(void) +#if CYTHON_PEP489_MULTI_PHASE_INIT +{ + return PyModuleDef_Init(&__pyx_moduledef); +} +static CYTHON_SMALL_CODE int __Pyx_check_single_interpreter(void) { + #if PY_VERSION_HEX >= 0x030700A1 + static PY_INT64_T main_interpreter_id = -1; + PY_INT64_T current_id = PyInterpreterState_GetID(PyThreadState_Get()->interp); + if (main_interpreter_id == -1) { + main_interpreter_id = current_id; + return (unlikely(current_id == -1)) ? -1 : 0; + } else if (unlikely(main_interpreter_id != current_id)) + #else + static PyInterpreterState *main_interpreter = NULL; + PyInterpreterState *current_interpreter = PyThreadState_Get()->interp; + if (!main_interpreter) { + main_interpreter = current_interpreter; + } else if (unlikely(main_interpreter != current_interpreter)) + #endif + { + PyErr_SetString( + PyExc_ImportError, + "Interpreter change detected - this module can only be loaded into one interpreter per process."); + return -1; + } + return 0; +} +static CYTHON_SMALL_CODE int __Pyx_copy_spec_to_module(PyObject *spec, PyObject *moddict, const char* from_name, const char* to_name, int allow_none) { + PyObject *value = PyObject_GetAttrString(spec, from_name); + int result = 0; + if (likely(value)) { + if (allow_none || value != Py_None) { + result = PyDict_SetItemString(moddict, to_name, value); + } + Py_DECREF(value); + } else if (PyErr_ExceptionMatches(PyExc_AttributeError)) { + PyErr_Clear(); + } else { + result = -1; + } + return result; +} +static CYTHON_SMALL_CODE PyObject* __pyx_pymod_create(PyObject *spec, CYTHON_UNUSED PyModuleDef *def) { + PyObject *module = NULL, *moddict, *modname; + if (__Pyx_check_single_interpreter()) + return NULL; + if (__pyx_m) + return __Pyx_NewRef(__pyx_m); + modname = PyObject_GetAttrString(spec, "name"); + if (unlikely(!modname)) goto bad; + module = PyModule_NewObject(modname); + Py_DECREF(modname); + if (unlikely(!module)) goto bad; + moddict = PyModule_GetDict(module); + if (unlikely(!moddict)) goto bad; + if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "loader", "__loader__", 1) < 0)) goto bad; + if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "origin", "__file__", 1) < 0)) goto bad; + if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "parent", "__package__", 1) < 0)) goto bad; + if (unlikely(__Pyx_copy_spec_to_module(spec, moddict, "submodule_search_locations", "__path__", 0) < 0)) goto bad; + return module; +bad: + Py_XDECREF(module); + return NULL; +} + + +static CYTHON_SMALL_CODE int __pyx_pymod_exec__quoting_c(PyObject *__pyx_pyinit_module) +#endif +#endif +{ + PyObject *__pyx_t_1 = NULL; + PyObject *__pyx_t_2 = NULL; + PyObject *__pyx_t_3 = NULL; + long __pyx_t_4; + int __pyx_t_5; + int __pyx_t_6; + uint64_t __pyx_t_7; + int __pyx_lineno = 0; + const char *__pyx_filename = NULL; + int __pyx_clineno = 0; + __Pyx_RefNannyDeclarations + #if CYTHON_PEP489_MULTI_PHASE_INIT + if (__pyx_m) { + if (__pyx_m == __pyx_pyinit_module) return 0; + PyErr_SetString(PyExc_RuntimeError, "Module '_quoting_c' has already been imported. Re-initialisation is not supported."); + return -1; + } + #elif PY_MAJOR_VERSION >= 3 + if (__pyx_m) return __Pyx_NewRef(__pyx_m); + #endif + #if CYTHON_REFNANNY +__Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny"); +if (!__Pyx_RefNanny) { + PyErr_Clear(); + __Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny"); + if (!__Pyx_RefNanny) + Py_FatalError("failed to import 'refnanny' module"); +} +#endif + __Pyx_RefNannySetupContext("__Pyx_PyMODINIT_FUNC PyInit__quoting_c(void)", 0); + if (__Pyx_check_binary_version() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #ifdef __Pxy_PyFrame_Initialize_Offsets + __Pxy_PyFrame_Initialize_Offsets(); + #endif + __pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error) + __pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error) + __pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error) + #ifdef __Pyx_CyFunction_USED + if (__pyx_CyFunction_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + #ifdef __Pyx_FusedFunction_USED + if (__pyx_FusedFunction_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + #ifdef __Pyx_Coroutine_USED + if (__pyx_Coroutine_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + #ifdef __Pyx_Generator_USED + if (__pyx_Generator_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + #ifdef __Pyx_AsyncGen_USED + if (__pyx_AsyncGen_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + #ifdef __Pyx_StopAsyncIteration_USED + if (__pyx_StopAsyncIteration_init() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + /*--- Library function declarations ---*/ + /*--- Threads initialization code ---*/ + #if defined(__PYX_FORCE_INIT_THREADS) && __PYX_FORCE_INIT_THREADS + #ifdef WITH_THREAD /* Python build with threading support? */ + PyEval_InitThreads(); + #endif + #endif + /*--- Module creation code ---*/ + #if CYTHON_PEP489_MULTI_PHASE_INIT + __pyx_m = __pyx_pyinit_module; + Py_INCREF(__pyx_m); + #else + #if PY_MAJOR_VERSION < 3 + __pyx_m = Py_InitModule4("_quoting_c", __pyx_methods, 0, 0, PYTHON_API_VERSION); Py_XINCREF(__pyx_m); + #else + __pyx_m = PyModule_Create(&__pyx_moduledef); + #endif + if (unlikely(!__pyx_m)) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + __pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error) + Py_INCREF(__pyx_d); + __pyx_b = PyImport_AddModule(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error) + Py_INCREF(__pyx_b); + __pyx_cython_runtime = PyImport_AddModule((char *) "cython_runtime"); if (unlikely(!__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error) + Py_INCREF(__pyx_cython_runtime); + if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error); + /*--- Initialize various global constants etc. ---*/ + if (__Pyx_InitGlobals() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #if PY_MAJOR_VERSION < 3 && (__PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT) + if (__Pyx_init_sys_getdefaultencoding_params() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + if (__pyx_module_is_main_yarl___quoting_c) { + if (PyObject_SetAttr(__pyx_m, __pyx_n_s_name, __pyx_n_s_main) < 0) __PYX_ERR(0, 1, __pyx_L1_error) + } + #if PY_MAJOR_VERSION >= 3 + { + PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error) + if (!PyDict_GetItemString(modules, "yarl._quoting_c")) { + if (unlikely(PyDict_SetItemString(modules, "yarl._quoting_c", __pyx_m) < 0)) __PYX_ERR(0, 1, __pyx_L1_error) + } + } + #endif + /*--- Builtin init code ---*/ + if (__Pyx_InitCachedBuiltins() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + /*--- Constants init code ---*/ + if (__Pyx_InitCachedConstants() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + /*--- Global type/function init code ---*/ + (void)__Pyx_modinit_global_init_code(); + (void)__Pyx_modinit_variable_export_code(); + (void)__Pyx_modinit_function_export_code(); + if (unlikely(__Pyx_modinit_type_init_code() < 0)) __PYX_ERR(0, 1, __pyx_L1_error) + if (unlikely(__Pyx_modinit_type_import_code() < 0)) __PYX_ERR(0, 1, __pyx_L1_error) + (void)__Pyx_modinit_variable_import_code(); + (void)__Pyx_modinit_function_import_code(); + /*--- Execution code ---*/ + #if defined(__Pyx_Generator_USED) || defined(__Pyx_Coroutine_USED) + if (__Pyx_patch_abc() < 0) __PYX_ERR(0, 1, __pyx_L1_error) + #endif + + /* "yarl/_quoting_c.pyx":10 + * from cpython.unicode cimport PyUnicode_DecodeASCII + * + * from string import ascii_letters, digits # <<<<<<<<<<<<<< + * + * cdef str GEN_DELIMS = ":/?#[]@" + */ + __pyx_t_1 = PyList_New(2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 10, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_INCREF(__pyx_n_s_ascii_letters); + __Pyx_GIVEREF(__pyx_n_s_ascii_letters); + PyList_SET_ITEM(__pyx_t_1, 0, __pyx_n_s_ascii_letters); + __Pyx_INCREF(__pyx_n_s_digits); + __Pyx_GIVEREF(__pyx_n_s_digits); + PyList_SET_ITEM(__pyx_t_1, 1, __pyx_n_s_digits); + __pyx_t_2 = __Pyx_Import(__pyx_n_s_string, __pyx_t_1, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 10, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_ascii_letters); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 10, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_d, __pyx_n_s_ascii_letters, __pyx_t_1) < 0) __PYX_ERR(0, 10, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_t_1 = __Pyx_ImportFrom(__pyx_t_2, __pyx_n_s_digits); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 10, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_d, __pyx_n_s_digits, __pyx_t_1) < 0) __PYX_ERR(0, 10, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + + /* "yarl/_quoting_c.pyx":12 + * from string import ascii_letters, digits + * + * cdef str GEN_DELIMS = ":/?#[]@" # <<<<<<<<<<<<<< + * cdef str SUB_DELIMS_WITHOUT_QS = "!$'()*," + * cdef str SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + '+?=;' + */ + __Pyx_INCREF(__pyx_kp_u__9); + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_GEN_DELIMS); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_GEN_DELIMS, __pyx_kp_u__9); + __Pyx_GIVEREF(__pyx_kp_u__9); + + /* "yarl/_quoting_c.pyx":13 + * + * cdef str GEN_DELIMS = ":/?#[]@" + * cdef str SUB_DELIMS_WITHOUT_QS = "!$'()*," # <<<<<<<<<<<<<< + * cdef str SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + '+?=;' + * cdef str RESERVED = GEN_DELIMS + SUB_DELIMS + */ + __Pyx_INCREF(__pyx_kp_u__10); + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_SUB_DELIMS_WITHOUT_QS); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_SUB_DELIMS_WITHOUT_QS, __pyx_kp_u__10); + __Pyx_GIVEREF(__pyx_kp_u__10); + + /* "yarl/_quoting_c.pyx":14 + * cdef str GEN_DELIMS = ":/?#[]@" + * cdef str SUB_DELIMS_WITHOUT_QS = "!$'()*," + * cdef str SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + '+?=;' # <<<<<<<<<<<<<< + * cdef str RESERVED = GEN_DELIMS + SUB_DELIMS + * cdef str UNRESERVED = ascii_letters + digits + '-._~' + */ + __pyx_t_2 = __Pyx_PyUnicode_ConcatSafe(__pyx_v_4yarl_10_quoting_c_SUB_DELIMS_WITHOUT_QS, __pyx_kp_u__11); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 14, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_SUB_DELIMS); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_SUB_DELIMS, ((PyObject*)__pyx_t_2)); + __Pyx_GIVEREF(__pyx_t_2); + __pyx_t_2 = 0; + + /* "yarl/_quoting_c.pyx":15 + * cdef str SUB_DELIMS_WITHOUT_QS = "!$'()*," + * cdef str SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + '+?=;' + * cdef str RESERVED = GEN_DELIMS + SUB_DELIMS # <<<<<<<<<<<<<< + * cdef str UNRESERVED = ascii_letters + digits + '-._~' + * cdef str ALLOWED = UNRESERVED + SUB_DELIMS_WITHOUT_QS + */ + __pyx_t_2 = __Pyx_PyUnicode_ConcatSafe(__pyx_v_4yarl_10_quoting_c_GEN_DELIMS, __pyx_v_4yarl_10_quoting_c_SUB_DELIMS); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 15, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_RESERVED); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_RESERVED, ((PyObject*)__pyx_t_2)); + __Pyx_GIVEREF(__pyx_t_2); + __pyx_t_2 = 0; + + /* "yarl/_quoting_c.pyx":16 + * cdef str SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + '+?=;' + * cdef str RESERVED = GEN_DELIMS + SUB_DELIMS + * cdef str UNRESERVED = ascii_letters + digits + '-._~' # <<<<<<<<<<<<<< + * cdef str ALLOWED = UNRESERVED + SUB_DELIMS_WITHOUT_QS + * cdef str QS = '+&=;' + */ + __Pyx_GetModuleGlobalName(__pyx_t_2, __pyx_n_s_ascii_letters); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 16, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_2); + __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_digits); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 16, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_3 = PyNumber_Add(__pyx_t_2, __pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 16, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_t_1 = PyNumber_Add(__pyx_t_3, __pyx_kp_u__12); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 16, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + if (!(likely(PyUnicode_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected %.16s, got %.200s", "unicode", Py_TYPE(__pyx_t_1)->tp_name), 0))) __PYX_ERR(0, 16, __pyx_L1_error) + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_UNRESERVED); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_UNRESERVED, ((PyObject*)__pyx_t_1)); + __Pyx_GIVEREF(__pyx_t_1); + __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":17 + * cdef str RESERVED = GEN_DELIMS + SUB_DELIMS + * cdef str UNRESERVED = ascii_letters + digits + '-._~' + * cdef str ALLOWED = UNRESERVED + SUB_DELIMS_WITHOUT_QS # <<<<<<<<<<<<<< + * cdef str QS = '+&=;' + * + */ + __pyx_t_1 = __Pyx_PyUnicode_ConcatSafe(__pyx_v_4yarl_10_quoting_c_UNRESERVED, __pyx_v_4yarl_10_quoting_c_SUB_DELIMS_WITHOUT_QS); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 17, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_ALLOWED); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_ALLOWED, ((PyObject*)__pyx_t_1)); + __Pyx_GIVEREF(__pyx_t_1); + __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":18 + * cdef str UNRESERVED = ascii_letters + digits + '-._~' + * cdef str ALLOWED = UNRESERVED + SUB_DELIMS_WITHOUT_QS + * cdef str QS = '+&=;' # <<<<<<<<<<<<<< + * + * DEF BUF_SIZE = 8 * 1024 # 8KiB + */ + __Pyx_INCREF(__pyx_kp_u__13); + __Pyx_XGOTREF(__pyx_v_4yarl_10_quoting_c_QS); + __Pyx_DECREF_SET(__pyx_v_4yarl_10_quoting_c_QS, __pyx_kp_u__13); + __Pyx_GIVEREF(__pyx_kp_u__13); + + /* "yarl/_quoting_c.pyx":64 + * + * + * memset(ALLOWED_TABLE, 0, sizeof(ALLOWED_TABLE)) # <<<<<<<<<<<<<< + * memset(ALLOWED_NOTQS_TABLE, 0, sizeof(ALLOWED_NOTQS_TABLE)) + * + */ + (void)(memset(__pyx_v_4yarl_10_quoting_c_ALLOWED_TABLE, 0, (sizeof(__pyx_v_4yarl_10_quoting_c_ALLOWED_TABLE)))); + + /* "yarl/_quoting_c.pyx":65 + * + * memset(ALLOWED_TABLE, 0, sizeof(ALLOWED_TABLE)) + * memset(ALLOWED_NOTQS_TABLE, 0, sizeof(ALLOWED_NOTQS_TABLE)) # <<<<<<<<<<<<<< + * + * for i in range(128): + */ + (void)(memset(__pyx_v_4yarl_10_quoting_c_ALLOWED_NOTQS_TABLE, 0, (sizeof(__pyx_v_4yarl_10_quoting_c_ALLOWED_NOTQS_TABLE)))); + + /* "yarl/_quoting_c.pyx":67 + * memset(ALLOWED_NOTQS_TABLE, 0, sizeof(ALLOWED_NOTQS_TABLE)) + * + * for i in range(128): # <<<<<<<<<<<<<< + * if chr(i) in ALLOWED: + * set_bit(ALLOWED_TABLE, i) + */ + for (__pyx_t_4 = 0; __pyx_t_4 < 0x80; __pyx_t_4+=1) { + __pyx_t_1 = __Pyx_PyInt_From_long(__pyx_t_4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 67, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_d, __pyx_n_s_i, __pyx_t_1) < 0) __PYX_ERR(0, 67, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":68 + * + * for i in range(128): + * if chr(i) in ALLOWED: # <<<<<<<<<<<<<< + * set_bit(ALLOWED_TABLE, i) + * set_bit(ALLOWED_NOTQS_TABLE, i) + */ + __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_i); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 68, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_3 = __Pyx_PyObject_CallOneArg(__pyx_builtin_chr, __pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 68, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + if (unlikely(__pyx_v_4yarl_10_quoting_c_ALLOWED == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); + __PYX_ERR(0, 68, __pyx_L1_error) + } + __pyx_t_5 = (__Pyx_PyUnicode_ContainsTF(__pyx_t_3, __pyx_v_4yarl_10_quoting_c_ALLOWED, Py_EQ)); if (unlikely(__pyx_t_5 < 0)) __PYX_ERR(0, 68, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_t_6 = (__pyx_t_5 != 0); + if (__pyx_t_6) { + + /* "yarl/_quoting_c.pyx":69 + * for i in range(128): + * if chr(i) in ALLOWED: + * set_bit(ALLOWED_TABLE, i) # <<<<<<<<<<<<<< + * set_bit(ALLOWED_NOTQS_TABLE, i) + * if chr(i) in QS: + */ + __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_i); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 69, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_7 = __Pyx_PyInt_As_uint64_t(__pyx_t_3); if (unlikely((__pyx_t_7 == ((uint64_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 69, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_f_4yarl_10_quoting_c_set_bit(__pyx_v_4yarl_10_quoting_c_ALLOWED_TABLE, __pyx_t_7); + + /* "yarl/_quoting_c.pyx":70 + * if chr(i) in ALLOWED: + * set_bit(ALLOWED_TABLE, i) + * set_bit(ALLOWED_NOTQS_TABLE, i) # <<<<<<<<<<<<<< + * if chr(i) in QS: + * set_bit(ALLOWED_NOTQS_TABLE, i) + */ + __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_i); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 70, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_7 = __Pyx_PyInt_As_uint64_t(__pyx_t_3); if (unlikely((__pyx_t_7 == ((uint64_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 70, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + __pyx_f_4yarl_10_quoting_c_set_bit(__pyx_v_4yarl_10_quoting_c_ALLOWED_NOTQS_TABLE, __pyx_t_7); + + /* "yarl/_quoting_c.pyx":68 + * + * for i in range(128): + * if chr(i) in ALLOWED: # <<<<<<<<<<<<<< + * set_bit(ALLOWED_TABLE, i) + * set_bit(ALLOWED_NOTQS_TABLE, i) + */ + } + + /* "yarl/_quoting_c.pyx":71 + * set_bit(ALLOWED_TABLE, i) + * set_bit(ALLOWED_NOTQS_TABLE, i) + * if chr(i) in QS: # <<<<<<<<<<<<<< + * set_bit(ALLOWED_NOTQS_TABLE, i) + * + */ + __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_n_s_i); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 71, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_3); + __pyx_t_1 = __Pyx_PyObject_CallOneArg(__pyx_builtin_chr, __pyx_t_3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 71, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; + if (unlikely(__pyx_v_4yarl_10_quoting_c_QS == Py_None)) { + PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); + __PYX_ERR(0, 71, __pyx_L1_error) + } + __pyx_t_6 = (__Pyx_PyUnicode_ContainsTF(__pyx_t_1, __pyx_v_4yarl_10_quoting_c_QS, Py_EQ)); if (unlikely(__pyx_t_6 < 0)) __PYX_ERR(0, 71, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_t_5 = (__pyx_t_6 != 0); + if (__pyx_t_5) { + + /* "yarl/_quoting_c.pyx":72 + * set_bit(ALLOWED_NOTQS_TABLE, i) + * if chr(i) in QS: + * set_bit(ALLOWED_NOTQS_TABLE, i) # <<<<<<<<<<<<<< + * + * # ----------------- writer --------------------------- + */ + __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_n_s_i); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 72, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + __pyx_t_7 = __Pyx_PyInt_As_uint64_t(__pyx_t_1); if (unlikely((__pyx_t_7 == ((uint64_t)-1)) && PyErr_Occurred())) __PYX_ERR(0, 72, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + __pyx_f_4yarl_10_quoting_c_set_bit(__pyx_v_4yarl_10_quoting_c_ALLOWED_NOTQS_TABLE, __pyx_t_7); + + /* "yarl/_quoting_c.pyx":71 + * set_bit(ALLOWED_TABLE, i) + * set_bit(ALLOWED_NOTQS_TABLE, i) + * if chr(i) in QS: # <<<<<<<<<<<<<< + * set_bit(ALLOWED_NOTQS_TABLE, i) + * + */ + } + } + + /* "(tree fragment)":1 + * def __pyx_unpickle__Quoter(__pyx_type, long __pyx_checksum, __pyx_state): # <<<<<<<<<<<<<< + * cdef object __pyx_PickleError + * cdef object __pyx_result + */ + __pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4yarl_10_quoting_c_1__pyx_unpickle__Quoter, NULL, __pyx_n_s_yarl__quoting_c); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_d, __pyx_n_s_pyx_unpickle__Quoter, __pyx_t_1) < 0) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "(tree fragment)":11 + * __pyx_unpickle__Quoter__set_state(<_Quoter> __pyx_result, __pyx_state) + * return __pyx_result + * cdef __pyx_unpickle__Quoter__set_state(_Quoter __pyx_result, tuple __pyx_state): # <<<<<<<<<<<<<< + * __pyx_result._protected_table = __pyx_state[0]; __pyx_result._qs = __pyx_state[1]; __pyx_result._requote = __pyx_state[2]; __pyx_result._safe_table = __pyx_state[3] + * if len(__pyx_state) > 4 and hasattr(__pyx_result, '__dict__'): + */ + __pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_4yarl_10_quoting_c_3__pyx_unpickle__Unquoter, NULL, __pyx_n_s_yarl__quoting_c); if (unlikely(!__pyx_t_1)) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_d, __pyx_n_s_pyx_unpickle__Unquoter, __pyx_t_1) < 0) __PYX_ERR(1, 1, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "yarl/_quoting_c.pyx":1 + * # cython: language_level=3 # <<<<<<<<<<<<<< + * + * from libc.stdint cimport uint8_t, uint64_t + */ + __pyx_t_1 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error) + __Pyx_GOTREF(__pyx_t_1); + if (PyDict_SetItem(__pyx_d, __pyx_n_s_test, __pyx_t_1) < 0) __PYX_ERR(0, 1, __pyx_L1_error) + __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; + + /* "carray.from_py":77 + * + * @cname("__Pyx_carray_from_py_uint8_t") + * cdef int __Pyx_carray_from_py_uint8_t(object o, base_type *v, Py_ssize_t length) except -1: # <<<<<<<<<<<<<< + * cdef Py_ssize_t i = length + * try: + */ + + /*--- Wrapped vars code ---*/ + + goto __pyx_L0; + __pyx_L1_error:; + __Pyx_XDECREF(__pyx_t_1); + __Pyx_XDECREF(__pyx_t_2); + __Pyx_XDECREF(__pyx_t_3); + if (__pyx_m) { + if (__pyx_d) { + __Pyx_AddTraceback("init yarl._quoting_c", __pyx_clineno, __pyx_lineno, __pyx_filename); + } + Py_CLEAR(__pyx_m); + } else if (!PyErr_Occurred()) { + PyErr_SetString(PyExc_ImportError, "init yarl._quoting_c"); + } + __pyx_L0:; + __Pyx_RefNannyFinishContext(); + #if CYTHON_PEP489_MULTI_PHASE_INIT + return (__pyx_m != NULL) ? 0 : -1; + #elif PY_MAJOR_VERSION >= 3 + return __pyx_m; + #else + return; + #endif +} + +/* --- Runtime support code --- */ +/* Refnanny */ +#if CYTHON_REFNANNY +static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) { + PyObject *m = NULL, *p = NULL; + void *r = NULL; + m = PyImport_ImportModule(modname); + if (!m) goto end; + p = PyObject_GetAttrString(m, "RefNannyAPI"); + if (!p) goto end; + r = PyLong_AsVoidPtr(p); +end: + Py_XDECREF(p); + Py_XDECREF(m); + return (__Pyx_RefNannyAPIStruct *)r; +} +#endif + +/* PyObjectGetAttrStr */ +#if CYTHON_USE_TYPE_SLOTS +static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStr(PyObject* obj, PyObject* attr_name) { + PyTypeObject* tp = Py_TYPE(obj); + if (likely(tp->tp_getattro)) + return tp->tp_getattro(obj, attr_name); +#if PY_MAJOR_VERSION < 3 + if (likely(tp->tp_getattr)) + return tp->tp_getattr(obj, PyString_AS_STRING(attr_name)); +#endif + return PyObject_GetAttr(obj, attr_name); +} +#endif + +/* GetBuiltinName */ +static PyObject *__Pyx_GetBuiltinName(PyObject *name) { + PyObject* result = __Pyx_PyObject_GetAttrStr(__pyx_b, name); + if (unlikely(!result)) { + PyErr_Format(PyExc_NameError, +#if PY_MAJOR_VERSION >= 3 + "name '%U' is not defined", name); +#else + "name '%.200s' is not defined", PyString_AS_STRING(name)); +#endif + } + return result; +} + +/* PyErrFetchRestore */ +#if CYTHON_FAST_THREAD_STATE +static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { + PyObject *tmp_type, *tmp_value, *tmp_tb; + tmp_type = tstate->curexc_type; + tmp_value = tstate->curexc_value; + tmp_tb = tstate->curexc_traceback; + tstate->curexc_type = type; + tstate->curexc_value = value; + tstate->curexc_traceback = tb; + Py_XDECREF(tmp_type); + Py_XDECREF(tmp_value); + Py_XDECREF(tmp_tb); +} +static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { + *type = tstate->curexc_type; + *value = tstate->curexc_value; + *tb = tstate->curexc_traceback; + tstate->curexc_type = 0; + tstate->curexc_value = 0; + tstate->curexc_traceback = 0; +} +#endif + +/* WriteUnraisableException */ +static void __Pyx_WriteUnraisable(const char *name, CYTHON_UNUSED int clineno, + CYTHON_UNUSED int lineno, CYTHON_UNUSED const char *filename, + int full_traceback, CYTHON_UNUSED int nogil) { + PyObject *old_exc, *old_val, *old_tb; + PyObject *ctx; + __Pyx_PyThreadState_declare +#ifdef WITH_THREAD + PyGILState_STATE state; + if (nogil) + state = PyGILState_Ensure(); +#ifdef _MSC_VER + else state = (PyGILState_STATE)-1; +#endif +#endif + __Pyx_PyThreadState_assign + __Pyx_ErrFetch(&old_exc, &old_val, &old_tb); + if (full_traceback) { + Py_XINCREF(old_exc); + Py_XINCREF(old_val); + Py_XINCREF(old_tb); + __Pyx_ErrRestore(old_exc, old_val, old_tb); + PyErr_PrintEx(1); + } + #if PY_MAJOR_VERSION < 3 + ctx = PyString_FromString(name); + #else + ctx = PyUnicode_FromString(name); + #endif + __Pyx_ErrRestore(old_exc, old_val, old_tb); + if (!ctx) { + PyErr_WriteUnraisable(Py_None); + } else { + PyErr_WriteUnraisable(ctx); + Py_DECREF(ctx); + } +#ifdef WITH_THREAD + if (nogil) + PyGILState_Release(state); +#endif +} + +/* RaiseDoubleKeywords */ +static void __Pyx_RaiseDoubleKeywordsError( + const char* func_name, + PyObject* kw_name) +{ + PyErr_Format(PyExc_TypeError, + #if PY_MAJOR_VERSION >= 3 + "%s() got multiple values for keyword argument '%U'", func_name, kw_name); + #else + "%s() got multiple values for keyword argument '%s'", func_name, + PyString_AsString(kw_name)); + #endif +} + +/* ParseKeywords */ +static int __Pyx_ParseOptionalKeywords( + PyObject *kwds, + PyObject **argnames[], + PyObject *kwds2, + PyObject *values[], + Py_ssize_t num_pos_args, + const char* function_name) +{ + PyObject *key = 0, *value = 0; + Py_ssize_t pos = 0; + PyObject*** name; + PyObject*** first_kw_arg = argnames + num_pos_args; + while (PyDict_Next(kwds, &pos, &key, &value)) { + name = first_kw_arg; + while (*name && (**name != key)) name++; + if (*name) { + values[name-argnames] = value; + continue; + } + name = first_kw_arg; + #if PY_MAJOR_VERSION < 3 + if (likely(PyString_Check(key))) { + while (*name) { + if ((CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**name) == PyString_GET_SIZE(key)) + && _PyString_Eq(**name, key)) { + values[name-argnames] = value; + break; + } + name++; + } + if (*name) continue; + else { + PyObject*** argname = argnames; + while (argname != first_kw_arg) { + if ((**argname == key) || ( + (CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**argname) == PyString_GET_SIZE(key)) + && _PyString_Eq(**argname, key))) { + goto arg_passed_twice; + } + argname++; + } + } + } else + #endif + if (likely(PyUnicode_Check(key))) { + while (*name) { + int cmp = (**name == key) ? 0 : + #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3 + (__Pyx_PyUnicode_GET_LENGTH(**name) != __Pyx_PyUnicode_GET_LENGTH(key)) ? 1 : + #endif + PyUnicode_Compare(**name, key); + if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; + if (cmp == 0) { + values[name-argnames] = value; + break; + } + name++; + } + if (*name) continue; + else { + PyObject*** argname = argnames; + while (argname != first_kw_arg) { + int cmp = (**argname == key) ? 0 : + #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3 + (__Pyx_PyUnicode_GET_LENGTH(**argname) != __Pyx_PyUnicode_GET_LENGTH(key)) ? 1 : + #endif + PyUnicode_Compare(**argname, key); + if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; + if (cmp == 0) goto arg_passed_twice; + argname++; + } + } + } else + goto invalid_keyword_type; + if (kwds2) { + if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad; + } else { + goto invalid_keyword; + } + } + return 0; +arg_passed_twice: + __Pyx_RaiseDoubleKeywordsError(function_name, key); + goto bad; +invalid_keyword_type: + PyErr_Format(PyExc_TypeError, + "%.200s() keywords must be strings", function_name); + goto bad; +invalid_keyword: + PyErr_Format(PyExc_TypeError, + #if PY_MAJOR_VERSION < 3 + "%.200s() got an unexpected keyword argument '%.200s'", + function_name, PyString_AsString(key)); + #else + "%s() got an unexpected keyword argument '%U'", + function_name, key); + #endif +bad: + return -1; +} + +/* RaiseArgTupleInvalid */ +static void __Pyx_RaiseArgtupleInvalid( + const char* func_name, + int exact, + Py_ssize_t num_min, + Py_ssize_t num_max, + Py_ssize_t num_found) +{ + Py_ssize_t num_expected; + const char *more_or_less; + if (num_found < num_min) { + num_expected = num_min; + more_or_less = "at least"; + } else { + num_expected = num_max; + more_or_less = "at most"; + } + if (exact) { + more_or_less = "exactly"; + } + PyErr_Format(PyExc_TypeError, + "%.200s() takes %.8s %" CYTHON_FORMAT_SSIZE_T "d positional argument%.1s (%" CYTHON_FORMAT_SSIZE_T "d given)", + func_name, more_or_less, num_expected, + (num_expected == 1) ? "" : "s", num_found); +} + +/* ArgTypeTest */ +static int __Pyx__ArgTypeTest(PyObject *obj, PyTypeObject *type, const char *name, int exact) +{ + if (unlikely(!type)) { + PyErr_SetString(PyExc_SystemError, "Missing type object"); + return 0; + } + else if (exact) { + #if PY_MAJOR_VERSION == 2 + if ((type == &PyBaseString_Type) && likely(__Pyx_PyBaseString_CheckExact(obj))) return 1; + #endif + } + else { + if (likely(__Pyx_TypeCheck(obj, type))) return 1; + } + PyErr_Format(PyExc_TypeError, + "Argument '%.200s' has incorrect type (expected %.200s, got %.200s)", + name, type->tp_name, Py_TYPE(obj)->tp_name); + return 0; +} + +/* unicode_iter */ +static CYTHON_INLINE int __Pyx_init_unicode_iteration( + PyObject* ustring, Py_ssize_t *length, void** data, int *kind) { +#if CYTHON_PEP393_ENABLED + if (unlikely(__Pyx_PyUnicode_READY(ustring) < 0)) return -1; + *kind = PyUnicode_KIND(ustring); + *length = PyUnicode_GET_LENGTH(ustring); + *data = PyUnicode_DATA(ustring); +#else + *kind = 0; + *length = PyUnicode_GET_SIZE(ustring); + *data = (void*)PyUnicode_AS_UNICODE(ustring); +#endif + return 0; +} + +/* PyObjectCall */ +#if CYTHON_COMPILING_IN_CPYTHON +static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) { + PyObject *result; + ternaryfunc call = func->ob_type->tp_call; + if (unlikely(!call)) + return PyObject_Call(func, arg, kw); + if (unlikely(Py_EnterRecursiveCall((char*)" while calling a Python object"))) + return NULL; + result = (*call)(func, arg, kw); + Py_LeaveRecursiveCall(); + if (unlikely(!result) && unlikely(!PyErr_Occurred())) { + PyErr_SetString( + PyExc_SystemError, + "NULL result without error in PyObject_Call"); + } + return result; +} +#endif + +/* RaiseException */ +#if PY_MAJOR_VERSION < 3 +static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, + CYTHON_UNUSED PyObject *cause) { + __Pyx_PyThreadState_declare + Py_XINCREF(type); + if (!value || value == Py_None) + value = NULL; + else + Py_INCREF(value); + if (!tb || tb == Py_None) + tb = NULL; + else { + Py_INCREF(tb); + if (!PyTraceBack_Check(tb)) { + PyErr_SetString(PyExc_TypeError, + "raise: arg 3 must be a traceback or None"); + goto raise_error; + } + } + if (PyType_Check(type)) { +#if CYTHON_COMPILING_IN_PYPY + if (!value) { + Py_INCREF(Py_None); + value = Py_None; + } +#endif + PyErr_NormalizeException(&type, &value, &tb); + } else { + if (value) { + PyErr_SetString(PyExc_TypeError, + "instance exception may not have a separate value"); + goto raise_error; + } + value = type; + type = (PyObject*) Py_TYPE(type); + Py_INCREF(type); + if (!PyType_IsSubtype((PyTypeObject *)type, (PyTypeObject *)PyExc_BaseException)) { + PyErr_SetString(PyExc_TypeError, + "raise: exception class must be a subclass of BaseException"); + goto raise_error; + } + } + __Pyx_PyThreadState_assign + __Pyx_ErrRestore(type, value, tb); + return; +raise_error: + Py_XDECREF(value); + Py_XDECREF(type); + Py_XDECREF(tb); + return; +} +#else +static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause) { + PyObject* owned_instance = NULL; + if (tb == Py_None) { + tb = 0; + } else if (tb && !PyTraceBack_Check(tb)) { + PyErr_SetString(PyExc_TypeError, + "raise: arg 3 must be a traceback or None"); + goto bad; + } + if (value == Py_None) + value = 0; + if (PyExceptionInstance_Check(type)) { + if (value) { + PyErr_SetString(PyExc_TypeError, + "instance exception may not have a separate value"); + goto bad; + } + value = type; + type = (PyObject*) Py_TYPE(value); + } else if (PyExceptionClass_Check(type)) { + PyObject *instance_class = NULL; + if (value && PyExceptionInstance_Check(value)) { + instance_class = (PyObject*) Py_TYPE(value); + if (instance_class != type) { + int is_subclass = PyObject_IsSubclass(instance_class, type); + if (!is_subclass) { + instance_class = NULL; + } else if (unlikely(is_subclass == -1)) { + goto bad; + } else { + type = instance_class; + } + } + } + if (!instance_class) { + PyObject *args; + if (!value) + args = PyTuple_New(0); + else if (PyTuple_Check(value)) { + Py_INCREF(value); + args = value; + } else + args = PyTuple_Pack(1, value); + if (!args) + goto bad; + owned_instance = PyObject_Call(type, args, NULL); + Py_DECREF(args); + if (!owned_instance) + goto bad; + value = owned_instance; + if (!PyExceptionInstance_Check(value)) { + PyErr_Format(PyExc_TypeError, + "calling %R should have returned an instance of " + "BaseException, not %R", + type, Py_TYPE(value)); + goto bad; + } + } + } else { + PyErr_SetString(PyExc_TypeError, + "raise: exception class must be a subclass of BaseException"); + goto bad; + } + if (cause) { + PyObject *fixed_cause; + if (cause == Py_None) { + fixed_cause = NULL; + } else if (PyExceptionClass_Check(cause)) { + fixed_cause = PyObject_CallObject(cause, NULL); + if (fixed_cause == NULL) + goto bad; + } else if (PyExceptionInstance_Check(cause)) { + fixed_cause = cause; + Py_INCREF(fixed_cause); + } else { + PyErr_SetString(PyExc_TypeError, + "exception causes must derive from " + "BaseException"); + goto bad; + } + PyException_SetCause(value, fixed_cause); + } + PyErr_SetObject(type, value); + if (tb) { +#if CYTHON_COMPILING_IN_PYPY + PyObject *tmp_type, *tmp_value, *tmp_tb; + PyErr_Fetch(&tmp_type, &tmp_value, &tmp_tb); + Py_INCREF(tb); + PyErr_Restore(tmp_type, tmp_value, tb); + Py_XDECREF(tmp_tb); +#else + PyThreadState *tstate = __Pyx_PyThreadState_Current; + PyObject* tmp_tb = tstate->curexc_traceback; + if (tb != tmp_tb) { + Py_INCREF(tb); + tstate->curexc_traceback = tb; + Py_XDECREF(tmp_tb); + } +#endif + } +bad: + Py_XDECREF(owned_instance); + return; +} +#endif + +/* PyCFunctionFastCall */ +#if CYTHON_FAST_PYCCALL +static CYTHON_INLINE PyObject * __Pyx_PyCFunction_FastCall(PyObject *func_obj, PyObject **args, Py_ssize_t nargs) { + PyCFunctionObject *func = (PyCFunctionObject*)func_obj; + PyCFunction meth = PyCFunction_GET_FUNCTION(func); + PyObject *self = PyCFunction_GET_SELF(func); + int flags = PyCFunction_GET_FLAGS(func); + assert(PyCFunction_Check(func)); + assert(METH_FASTCALL == (flags & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_KEYWORDS | METH_STACKLESS))); + assert(nargs >= 0); + assert(nargs == 0 || args != NULL); + /* _PyCFunction_FastCallDict() must not be called with an exception set, + because it may clear it (directly or indirectly) and so the + caller loses its exception */ + assert(!PyErr_Occurred()); + if ((PY_VERSION_HEX < 0x030700A0) || unlikely(flags & METH_KEYWORDS)) { + return (*((__Pyx_PyCFunctionFastWithKeywords)(void*)meth)) (self, args, nargs, NULL); + } else { + return (*((__Pyx_PyCFunctionFast)(void*)meth)) (self, args, nargs); + } +} +#endif + +/* PyFunctionFastCall */ +#if CYTHON_FAST_PYCALL +static PyObject* __Pyx_PyFunction_FastCallNoKw(PyCodeObject *co, PyObject **args, Py_ssize_t na, + PyObject *globals) { + PyFrameObject *f; + PyThreadState *tstate = __Pyx_PyThreadState_Current; + PyObject **fastlocals; + Py_ssize_t i; + PyObject *result; + assert(globals != NULL); + /* XXX Perhaps we should create a specialized + PyFrame_New() that doesn't take locals, but does + take builtins without sanity checking them. + */ + assert(tstate != NULL); + f = PyFrame_New(tstate, co, globals, NULL); + if (f == NULL) { + return NULL; + } + fastlocals = __Pyx_PyFrame_GetLocalsplus(f); + for (i = 0; i < na; i++) { + Py_INCREF(*args); + fastlocals[i] = *args++; + } + result = PyEval_EvalFrameEx(f,0); + ++tstate->recursion_depth; + Py_DECREF(f); + --tstate->recursion_depth; + return result; +} +#if 1 || PY_VERSION_HEX < 0x030600B1 +static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject **args, Py_ssize_t nargs, PyObject *kwargs) { + PyCodeObject *co = (PyCodeObject *)PyFunction_GET_CODE(func); + PyObject *globals = PyFunction_GET_GLOBALS(func); + PyObject *argdefs = PyFunction_GET_DEFAULTS(func); + PyObject *closure; +#if PY_MAJOR_VERSION >= 3 + PyObject *kwdefs; +#endif + PyObject *kwtuple, **k; + PyObject **d; + Py_ssize_t nd; + Py_ssize_t nk; + PyObject *result; + assert(kwargs == NULL || PyDict_Check(kwargs)); + nk = kwargs ? PyDict_Size(kwargs) : 0; + if (Py_EnterRecursiveCall((char*)" while calling a Python object")) { + return NULL; + } + if ( +#if PY_MAJOR_VERSION >= 3 + co->co_kwonlyargcount == 0 && +#endif + likely(kwargs == NULL || nk == 0) && + co->co_flags == (CO_OPTIMIZED | CO_NEWLOCALS | CO_NOFREE)) { + if (argdefs == NULL && co->co_argcount == nargs) { + result = __Pyx_PyFunction_FastCallNoKw(co, args, nargs, globals); + goto done; + } + else if (nargs == 0 && argdefs != NULL + && co->co_argcount == Py_SIZE(argdefs)) { + /* function called with no arguments, but all parameters have + a default value: use default values as arguments .*/ + args = &PyTuple_GET_ITEM(argdefs, 0); + result =__Pyx_PyFunction_FastCallNoKw(co, args, Py_SIZE(argdefs), globals); + goto done; + } + } + if (kwargs != NULL) { + Py_ssize_t pos, i; + kwtuple = PyTuple_New(2 * nk); + if (kwtuple == NULL) { + result = NULL; + goto done; + } + k = &PyTuple_GET_ITEM(kwtuple, 0); + pos = i = 0; + while (PyDict_Next(kwargs, &pos, &k[i], &k[i+1])) { + Py_INCREF(k[i]); + Py_INCREF(k[i+1]); + i += 2; + } + nk = i / 2; + } + else { + kwtuple = NULL; + k = NULL; + } + closure = PyFunction_GET_CLOSURE(func); +#if PY_MAJOR_VERSION >= 3 + kwdefs = PyFunction_GET_KW_DEFAULTS(func); +#endif + if (argdefs != NULL) { + d = &PyTuple_GET_ITEM(argdefs, 0); + nd = Py_SIZE(argdefs); + } + else { + d = NULL; + nd = 0; + } +#if PY_MAJOR_VERSION >= 3 + result = PyEval_EvalCodeEx((PyObject*)co, globals, (PyObject *)NULL, + args, (int)nargs, + k, (int)nk, + d, (int)nd, kwdefs, closure); +#else + result = PyEval_EvalCodeEx(co, globals, (PyObject *)NULL, + args, (int)nargs, + k, (int)nk, + d, (int)nd, closure); +#endif + Py_XDECREF(kwtuple); +done: + Py_LeaveRecursiveCall(); + return result; +} +#endif +#endif + +/* PyObjectCallMethO */ +#if CYTHON_COMPILING_IN_CPYTHON +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg) { + PyObject *self, *result; + PyCFunction cfunc; + cfunc = PyCFunction_GET_FUNCTION(func); + self = PyCFunction_GET_SELF(func); + if (unlikely(Py_EnterRecursiveCall((char*)" while calling a Python object"))) + return NULL; + result = cfunc(self, arg); + Py_LeaveRecursiveCall(); + if (unlikely(!result) && unlikely(!PyErr_Occurred())) { + PyErr_SetString( + PyExc_SystemError, + "NULL result without error in PyObject_Call"); + } + return result; +} +#endif + +/* PyObjectCallOneArg */ +#if CYTHON_COMPILING_IN_CPYTHON +static PyObject* __Pyx__PyObject_CallOneArg(PyObject *func, PyObject *arg) { + PyObject *result; + PyObject *args = PyTuple_New(1); + if (unlikely(!args)) return NULL; + Py_INCREF(arg); + PyTuple_SET_ITEM(args, 0, arg); + result = __Pyx_PyObject_Call(func, args, NULL); + Py_DECREF(args); + return result; +} +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) { +#if CYTHON_FAST_PYCALL + if (PyFunction_Check(func)) { + return __Pyx_PyFunction_FastCall(func, &arg, 1); + } +#endif + if (likely(PyCFunction_Check(func))) { + if (likely(PyCFunction_GET_FLAGS(func) & METH_O)) { + return __Pyx_PyObject_CallMethO(func, arg); +#if CYTHON_FAST_PYCCALL + } else if (PyCFunction_GET_FLAGS(func) & METH_FASTCALL) { + return __Pyx_PyCFunction_FastCall(func, &arg, 1); +#endif + } + } + return __Pyx__PyObject_CallOneArg(func, arg); +} +#else +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) { + PyObject *result; + PyObject *args = PyTuple_Pack(1, arg); + if (unlikely(!args)) return NULL; + result = __Pyx_PyObject_Call(func, args, NULL); + Py_DECREF(args); + return result; +} +#endif + +/* GetException */ +#if CYTHON_FAST_THREAD_STATE +static int __Pyx__GetException(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) +#else +static int __Pyx_GetException(PyObject **type, PyObject **value, PyObject **tb) +#endif +{ + PyObject *local_type, *local_value, *local_tb; +#if CYTHON_FAST_THREAD_STATE + PyObject *tmp_type, *tmp_value, *tmp_tb; + local_type = tstate->curexc_type; + local_value = tstate->curexc_value; + local_tb = tstate->curexc_traceback; + tstate->curexc_type = 0; + tstate->curexc_value = 0; + tstate->curexc_traceback = 0; +#else + PyErr_Fetch(&local_type, &local_value, &local_tb); +#endif + PyErr_NormalizeException(&local_type, &local_value, &local_tb); +#if CYTHON_FAST_THREAD_STATE + if (unlikely(tstate->curexc_type)) +#else + if (unlikely(PyErr_Occurred())) +#endif + goto bad; + #if PY_MAJOR_VERSION >= 3 + if (local_tb) { + if (unlikely(PyException_SetTraceback(local_value, local_tb) < 0)) + goto bad; + } + #endif + Py_XINCREF(local_tb); + Py_XINCREF(local_type); + Py_XINCREF(local_value); + *type = local_type; + *value = local_value; + *tb = local_tb; +#if CYTHON_FAST_THREAD_STATE + #if CYTHON_USE_EXC_INFO_STACK + { + _PyErr_StackItem *exc_info = tstate->exc_info; + tmp_type = exc_info->exc_type; + tmp_value = exc_info->exc_value; + tmp_tb = exc_info->exc_traceback; + exc_info->exc_type = local_type; + exc_info->exc_value = local_value; + exc_info->exc_traceback = local_tb; + } + #else + tmp_type = tstate->exc_type; + tmp_value = tstate->exc_value; + tmp_tb = tstate->exc_traceback; + tstate->exc_type = local_type; + tstate->exc_value = local_value; + tstate->exc_traceback = local_tb; + #endif + Py_XDECREF(tmp_type); + Py_XDECREF(tmp_value); + Py_XDECREF(tmp_tb); +#else + PyErr_SetExcInfo(local_type, local_value, local_tb); +#endif + return 0; +bad: + *type = 0; + *value = 0; + *tb = 0; + Py_XDECREF(local_type); + Py_XDECREF(local_value); + Py_XDECREF(local_tb); + return -1; +} + +/* SwapException */ +#if CYTHON_FAST_THREAD_STATE +static CYTHON_INLINE void __Pyx__ExceptionSwap(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { + PyObject *tmp_type, *tmp_value, *tmp_tb; + #if CYTHON_USE_EXC_INFO_STACK + _PyErr_StackItem *exc_info = tstate->exc_info; + tmp_type = exc_info->exc_type; + tmp_value = exc_info->exc_value; + tmp_tb = exc_info->exc_traceback; + exc_info->exc_type = *type; + exc_info->exc_value = *value; + exc_info->exc_traceback = *tb; + #else + tmp_type = tstate->exc_type; + tmp_value = tstate->exc_value; + tmp_tb = tstate->exc_traceback; + tstate->exc_type = *type; + tstate->exc_value = *value; + tstate->exc_traceback = *tb; + #endif + *type = tmp_type; + *value = tmp_value; + *tb = tmp_tb; +} +#else +static CYTHON_INLINE void __Pyx_ExceptionSwap(PyObject **type, PyObject **value, PyObject **tb) { + PyObject *tmp_type, *tmp_value, *tmp_tb; + PyErr_GetExcInfo(&tmp_type, &tmp_value, &tmp_tb); + PyErr_SetExcInfo(*type, *value, *tb); + *type = tmp_type; + *value = tmp_value; + *tb = tmp_tb; +} +#endif + +/* GetTopmostException */ +#if CYTHON_USE_EXC_INFO_STACK +static _PyErr_StackItem * +__Pyx_PyErr_GetTopmostException(PyThreadState *tstate) +{ + _PyErr_StackItem *exc_info = tstate->exc_info; + while ((exc_info->exc_type == NULL || exc_info->exc_type == Py_None) && + exc_info->previous_item != NULL) + { + exc_info = exc_info->previous_item; + } + return exc_info; +} +#endif + +/* SaveResetException */ +#if CYTHON_FAST_THREAD_STATE +static CYTHON_INLINE void __Pyx__ExceptionSave(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { + #if CYTHON_USE_EXC_INFO_STACK + _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate); + *type = exc_info->exc_type; + *value = exc_info->exc_value; + *tb = exc_info->exc_traceback; + #else + *type = tstate->exc_type; + *value = tstate->exc_value; + *tb = tstate->exc_traceback; + #endif + Py_XINCREF(*type); + Py_XINCREF(*value); + Py_XINCREF(*tb); +} +static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { + PyObject *tmp_type, *tmp_value, *tmp_tb; + #if CYTHON_USE_EXC_INFO_STACK + _PyErr_StackItem *exc_info = tstate->exc_info; + tmp_type = exc_info->exc_type; + tmp_value = exc_info->exc_value; + tmp_tb = exc_info->exc_traceback; + exc_info->exc_type = type; + exc_info->exc_value = value; + exc_info->exc_traceback = tb; + #else + tmp_type = tstate->exc_type; + tmp_value = tstate->exc_value; + tmp_tb = tstate->exc_traceback; + tstate->exc_type = type; + tstate->exc_value = value; + tstate->exc_traceback = tb; + #endif + Py_XDECREF(tmp_type); + Py_XDECREF(tmp_value); + Py_XDECREF(tmp_tb); +} +#endif + +/* ReRaiseException */ +static CYTHON_INLINE void __Pyx_ReraiseException(void) { + PyObject *type = NULL, *value = NULL, *tb = NULL; +#if CYTHON_FAST_THREAD_STATE + PyThreadState *tstate = PyThreadState_GET(); + #if CYTHON_USE_EXC_INFO_STACK + _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate); + type = exc_info->exc_type; + value = exc_info->exc_value; + tb = exc_info->exc_traceback; + #else + type = tstate->exc_type; + value = tstate->exc_value; + tb = tstate->exc_traceback; + #endif +#else + PyErr_GetExcInfo(&type, &value, &tb); +#endif + if (!type || type == Py_None) { +#if !CYTHON_FAST_THREAD_STATE + Py_XDECREF(type); + Py_XDECREF(value); + Py_XDECREF(tb); +#endif + PyErr_SetString(PyExc_RuntimeError, + "No active exception to reraise"); + } else { +#if CYTHON_FAST_THREAD_STATE + Py_INCREF(type); + Py_XINCREF(value); + Py_XINCREF(tb); +#endif + PyErr_Restore(type, value, tb); + } +} + +/* PyErrExceptionMatches */ +#if CYTHON_FAST_THREAD_STATE +static int __Pyx_PyErr_ExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { + Py_ssize_t i, n; + n = PyTuple_GET_SIZE(tuple); +#if PY_MAJOR_VERSION >= 3 + for (i=0; i<n; i++) { + if (exc_type == PyTuple_GET_ITEM(tuple, i)) return 1; + } +#endif + for (i=0; i<n; i++) { + if (__Pyx_PyErr_GivenExceptionMatches(exc_type, PyTuple_GET_ITEM(tuple, i))) return 1; + } + return 0; +} +static CYTHON_INLINE int __Pyx_PyErr_ExceptionMatchesInState(PyThreadState* tstate, PyObject* err) { + PyObject *exc_type = tstate->curexc_type; + if (exc_type == err) return 1; + if (unlikely(!exc_type)) return 0; + if (unlikely(PyTuple_Check(err))) + return __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err); + return __Pyx_PyErr_GivenExceptionMatches(exc_type, err); +} +#endif + +/* GetAttr */ +static CYTHON_INLINE PyObject *__Pyx_GetAttr(PyObject *o, PyObject *n) { +#if CYTHON_USE_TYPE_SLOTS +#if PY_MAJOR_VERSION >= 3 + if (likely(PyUnicode_Check(n))) +#else + if (likely(PyString_Check(n))) +#endif + return __Pyx_PyObject_GetAttrStr(o, n); +#endif + return PyObject_GetAttr(o, n); +} + +/* GetAttr3 */ +static PyObject *__Pyx_GetAttr3Default(PyObject *d) { + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + if (unlikely(!__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError))) + return NULL; + __Pyx_PyErr_Clear(); + Py_INCREF(d); + return d; +} +static CYTHON_INLINE PyObject *__Pyx_GetAttr3(PyObject *o, PyObject *n, PyObject *d) { + PyObject *r = __Pyx_GetAttr(o, n); + return (likely(r)) ? r : __Pyx_GetAttr3Default(d); +} + +/* PyDictVersioning */ +#if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_TYPE_SLOTS +static CYTHON_INLINE PY_UINT64_T __Pyx_get_tp_dict_version(PyObject *obj) { + PyObject *dict = Py_TYPE(obj)->tp_dict; + return likely(dict) ? __PYX_GET_DICT_VERSION(dict) : 0; +} +static CYTHON_INLINE PY_UINT64_T __Pyx_get_object_dict_version(PyObject *obj) { + PyObject **dictptr = NULL; + Py_ssize_t offset = Py_TYPE(obj)->tp_dictoffset; + if (offset) { +#if CYTHON_COMPILING_IN_CPYTHON + dictptr = (likely(offset > 0)) ? (PyObject **) ((char *)obj + offset) : _PyObject_GetDictPtr(obj); +#else + dictptr = _PyObject_GetDictPtr(obj); +#endif + } + return (dictptr && *dictptr) ? __PYX_GET_DICT_VERSION(*dictptr) : 0; +} +static CYTHON_INLINE int __Pyx_object_dict_version_matches(PyObject* obj, PY_UINT64_T tp_dict_version, PY_UINT64_T obj_dict_version) { + PyObject *dict = Py_TYPE(obj)->tp_dict; + if (unlikely(!dict) || unlikely(tp_dict_version != __PYX_GET_DICT_VERSION(dict))) + return 0; + return obj_dict_version == __Pyx_get_object_dict_version(obj); +} +#endif + +/* GetModuleGlobalName */ +#if CYTHON_USE_DICT_VERSIONS +static PyObject *__Pyx__GetModuleGlobalName(PyObject *name, PY_UINT64_T *dict_version, PyObject **dict_cached_value) +#else +static CYTHON_INLINE PyObject *__Pyx__GetModuleGlobalName(PyObject *name) +#endif +{ + PyObject *result; +#if !CYTHON_AVOID_BORROWED_REFS +#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030500A1 + result = _PyDict_GetItem_KnownHash(__pyx_d, name, ((PyASCIIObject *) name)->hash); + __PYX_UPDATE_DICT_CACHE(__pyx_d, result, *dict_cached_value, *dict_version) + if (likely(result)) { + return __Pyx_NewRef(result); + } else if (unlikely(PyErr_Occurred())) { + return NULL; + } +#else + result = PyDict_GetItem(__pyx_d, name); + __PYX_UPDATE_DICT_CACHE(__pyx_d, result, *dict_cached_value, *dict_version) + if (likely(result)) { + return __Pyx_NewRef(result); + } +#endif +#else + result = PyObject_GetItem(__pyx_d, name); + __PYX_UPDATE_DICT_CACHE(__pyx_d, result, *dict_cached_value, *dict_version) + if (likely(result)) { + return __Pyx_NewRef(result); + } + PyErr_Clear(); +#endif + return __Pyx_GetBuiltinName(name); +} + +/* PyObjectCallNoArg */ +#if CYTHON_COMPILING_IN_CPYTHON +static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func) { +#if CYTHON_FAST_PYCALL + if (PyFunction_Check(func)) { + return __Pyx_PyFunction_FastCall(func, NULL, 0); + } +#endif +#ifdef __Pyx_CyFunction_USED + if (likely(PyCFunction_Check(func) || __Pyx_CyFunction_Check(func))) +#else + if (likely(PyCFunction_Check(func))) +#endif + { + if (likely(PyCFunction_GET_FLAGS(func) & METH_NOARGS)) { + return __Pyx_PyObject_CallMethO(func, NULL); + } + } + return __Pyx_PyObject_Call(func, __pyx_empty_tuple, NULL); +} +#endif + +/* PyObjectCall2Args */ +static CYTHON_UNUSED PyObject* __Pyx_PyObject_Call2Args(PyObject* function, PyObject* arg1, PyObject* arg2) { + PyObject *args, *result = NULL; + #if CYTHON_FAST_PYCALL + if (PyFunction_Check(function)) { + PyObject *args[2] = {arg1, arg2}; + return __Pyx_PyFunction_FastCall(function, args, 2); + } + #endif + #if CYTHON_FAST_PYCCALL + if (__Pyx_PyFastCFunction_Check(function)) { + PyObject *args[2] = {arg1, arg2}; + return __Pyx_PyCFunction_FastCall(function, args, 2); + } + #endif + args = PyTuple_New(2); + if (unlikely(!args)) goto done; + Py_INCREF(arg1); + PyTuple_SET_ITEM(args, 0, arg1); + Py_INCREF(arg2); + PyTuple_SET_ITEM(args, 1, arg2); + Py_INCREF(function); + result = __Pyx_PyObject_Call(function, args, NULL); + Py_DECREF(args); + Py_DECREF(function); +done: + return result; +} + +/* PyObjectGetMethod */ +static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method) { + PyObject *attr; +#if CYTHON_UNPACK_METHODS && CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_PYTYPE_LOOKUP + PyTypeObject *tp = Py_TYPE(obj); + PyObject *descr; + descrgetfunc f = NULL; + PyObject **dictptr, *dict; + int meth_found = 0; + assert (*method == NULL); + if (unlikely(tp->tp_getattro != PyObject_GenericGetAttr)) { + attr = __Pyx_PyObject_GetAttrStr(obj, name); + goto try_unpack; + } + if (unlikely(tp->tp_dict == NULL) && unlikely(PyType_Ready(tp) < 0)) { + return 0; + } + descr = _PyType_Lookup(tp, name); + if (likely(descr != NULL)) { + Py_INCREF(descr); +#if PY_MAJOR_VERSION >= 3 + #ifdef __Pyx_CyFunction_USED + if (likely(PyFunction_Check(descr) || (Py_TYPE(descr) == &PyMethodDescr_Type) || __Pyx_CyFunction_Check(descr))) + #else + if (likely(PyFunction_Check(descr) || (Py_TYPE(descr) == &PyMethodDescr_Type))) + #endif +#else + #ifdef __Pyx_CyFunction_USED + if (likely(PyFunction_Check(descr) || __Pyx_CyFunction_Check(descr))) + #else + if (likely(PyFunction_Check(descr))) + #endif +#endif + { + meth_found = 1; + } else { + f = Py_TYPE(descr)->tp_descr_get; + if (f != NULL && PyDescr_IsData(descr)) { + attr = f(descr, obj, (PyObject *)Py_TYPE(obj)); + Py_DECREF(descr); + goto try_unpack; + } + } + } + dictptr = _PyObject_GetDictPtr(obj); + if (dictptr != NULL && (dict = *dictptr) != NULL) { + Py_INCREF(dict); + attr = __Pyx_PyDict_GetItemStr(dict, name); + if (attr != NULL) { + Py_INCREF(attr); + Py_DECREF(dict); + Py_XDECREF(descr); + goto try_unpack; + } + Py_DECREF(dict); + } + if (meth_found) { + *method = descr; + return 1; + } + if (f != NULL) { + attr = f(descr, obj, (PyObject *)Py_TYPE(obj)); + Py_DECREF(descr); + goto try_unpack; + } + if (descr != NULL) { + *method = descr; + return 0; + } + PyErr_Format(PyExc_AttributeError, +#if PY_MAJOR_VERSION >= 3 + "'%.50s' object has no attribute '%U'", + tp->tp_name, name); +#else + "'%.50s' object has no attribute '%.400s'", + tp->tp_name, PyString_AS_STRING(name)); +#endif + return 0; +#else + attr = __Pyx_PyObject_GetAttrStr(obj, name); + goto try_unpack; +#endif +try_unpack: +#if CYTHON_UNPACK_METHODS + if (likely(attr) && PyMethod_Check(attr) && likely(PyMethod_GET_SELF(attr) == obj)) { + PyObject *function = PyMethod_GET_FUNCTION(attr); + Py_INCREF(function); + Py_DECREF(attr); + *method = function; + return 1; + } +#endif + *method = attr; + return 0; +} + +/* PyObjectCallMethod1 */ +static PyObject* __Pyx__PyObject_CallMethod1(PyObject* method, PyObject* arg) { + PyObject *result = __Pyx_PyObject_CallOneArg(method, arg); + Py_DECREF(method); + return result; +} +static PyObject* __Pyx_PyObject_CallMethod1(PyObject* obj, PyObject* method_name, PyObject* arg) { + PyObject *method = NULL, *result; + int is_method = __Pyx_PyObject_GetMethod(obj, method_name, &method); + if (likely(is_method)) { + result = __Pyx_PyObject_Call2Args(method, obj, arg); + Py_DECREF(method); + return result; + } + if (unlikely(!method)) return NULL; + return __Pyx__PyObject_CallMethod1(method, arg); +} + +/* ByteArrayAppend */ +static CYTHON_INLINE int __Pyx_PyByteArray_Append(PyObject* bytearray, int value) { + PyObject *pyval, *retval; +#if CYTHON_COMPILING_IN_CPYTHON + if (likely(__Pyx_is_valid_index(value, 256))) { + Py_ssize_t n = Py_SIZE(bytearray); + if (likely(n != PY_SSIZE_T_MAX)) { + if (unlikely(PyByteArray_Resize(bytearray, n + 1) < 0)) + return -1; + PyByteArray_AS_STRING(bytearray)[n] = value; + return 0; + } + } else { + PyErr_SetString(PyExc_ValueError, "byte must be in range(0, 256)"); + return -1; + } +#endif + pyval = PyInt_FromLong(value); + if (unlikely(!pyval)) + return -1; + retval = __Pyx_PyObject_CallMethod1(bytearray, __pyx_n_s_append, pyval); + Py_DECREF(pyval); + if (unlikely(!retval)) + return -1; + Py_DECREF(retval); + return 0; +} + +/* ByteArrayAppendObject */ +static CYTHON_INLINE int __Pyx_PyByteArray_AppendObject(PyObject* bytearray, PyObject* value) { + Py_ssize_t ival; +#if PY_MAJOR_VERSION < 3 + if (unlikely(PyString_Check(value))) { + if (unlikely(PyString_GET_SIZE(value) != 1)) { + PyErr_SetString(PyExc_ValueError, "string must be of size 1"); + return -1; + } + ival = (unsigned char) (PyString_AS_STRING(value)[0]); + } else +#endif +#if CYTHON_USE_PYLONG_INTERNALS + if (likely(PyLong_CheckExact(value)) && likely(Py_SIZE(value) == 1 || Py_SIZE(value) == 0)) { + if (Py_SIZE(value) == 0) { + ival = 0; + } else { + ival = ((PyLongObject*)value)->ob_digit[0]; + if (unlikely(ival > 255)) goto bad_range; + } + } else +#endif + { + ival = __Pyx_PyIndex_AsSsize_t(value); + if (unlikely(!__Pyx_is_valid_index(ival, 256))) { + if (ival == -1 && PyErr_Occurred()) + return -1; + goto bad_range; + } + } + return __Pyx_PyByteArray_Append(bytearray, ival); +bad_range: + PyErr_SetString(PyExc_ValueError, "byte must be in range(0, 256)"); + return -1; +} + +/* PyUnicode_Substring */ +static CYTHON_INLINE PyObject* __Pyx_PyUnicode_Substring( + PyObject* text, Py_ssize_t start, Py_ssize_t stop) { + Py_ssize_t length; + if (unlikely(__Pyx_PyUnicode_READY(text) == -1)) return NULL; + length = __Pyx_PyUnicode_GET_LENGTH(text); + if (start < 0) { + start += length; + if (start < 0) + start = 0; + } + if (stop < 0) + stop += length; + else if (stop > length) + stop = length; + if (stop <= start) + return __Pyx_NewRef(__pyx_empty_unicode); +#if CYTHON_PEP393_ENABLED + return PyUnicode_FromKindAndData(PyUnicode_KIND(text), + PyUnicode_1BYTE_DATA(text) + start*PyUnicode_KIND(text), stop-start); +#else + return PyUnicode_FromUnicode(PyUnicode_AS_UNICODE(text)+start, stop-start); +#endif +} + +/* decode_c_bytes */ +static CYTHON_INLINE PyObject* __Pyx_decode_c_bytes( + const char* cstring, Py_ssize_t length, Py_ssize_t start, Py_ssize_t stop, + const char* encoding, const char* errors, + PyObject* (*decode_func)(const char *s, Py_ssize_t size, const char *errors)) { + if (unlikely((start < 0) | (stop < 0))) { + if (start < 0) { + start += length; + if (start < 0) + start = 0; + } + if (stop < 0) + stop += length; + } + if (stop > length) + stop = length; + if (unlikely(stop <= start)) + return __Pyx_NewRef(__pyx_empty_unicode); + length = stop - start; + cstring += start; + if (decode_func) { + return decode_func(cstring, length, errors); + } else { + return PyUnicode_Decode(cstring, length, encoding, errors); + } +} + +/* SliceObject */ +static CYTHON_INLINE int __Pyx_PyObject_SetSlice(PyObject* obj, PyObject* value, + Py_ssize_t cstart, Py_ssize_t cstop, + PyObject** _py_start, PyObject** _py_stop, PyObject** _py_slice, + int has_cstart, int has_cstop, CYTHON_UNUSED int wraparound) { +#if CYTHON_USE_TYPE_SLOTS + PyMappingMethods* mp; +#if PY_MAJOR_VERSION < 3 + PySequenceMethods* ms = Py_TYPE(obj)->tp_as_sequence; + if (likely(ms && ms->sq_ass_slice)) { + if (!has_cstart) { + if (_py_start && (*_py_start != Py_None)) { + cstart = __Pyx_PyIndex_AsSsize_t(*_py_start); + if ((cstart == (Py_ssize_t)-1) && PyErr_Occurred()) goto bad; + } else + cstart = 0; + } + if (!has_cstop) { + if (_py_stop && (*_py_stop != Py_None)) { + cstop = __Pyx_PyIndex_AsSsize_t(*_py_stop); + if ((cstop == (Py_ssize_t)-1) && PyErr_Occurred()) goto bad; + } else + cstop = PY_SSIZE_T_MAX; + } + if (wraparound && unlikely((cstart < 0) | (cstop < 0)) && likely(ms->sq_length)) { + Py_ssize_t l = ms->sq_length(obj); + if (likely(l >= 0)) { + if (cstop < 0) { + cstop += l; + if (cstop < 0) cstop = 0; + } + if (cstart < 0) { + cstart += l; + if (cstart < 0) cstart = 0; + } + } else { + if (!PyErr_ExceptionMatches(PyExc_OverflowError)) + goto bad; + PyErr_Clear(); + } + } + return ms->sq_ass_slice(obj, cstart, cstop, value); + } +#endif + mp = Py_TYPE(obj)->tp_as_mapping; + if (likely(mp && mp->mp_ass_subscript)) +#endif + { + int result; + PyObject *py_slice, *py_start, *py_stop; + if (_py_slice) { + py_slice = *_py_slice; + } else { + PyObject* owned_start = NULL; + PyObject* owned_stop = NULL; + if (_py_start) { + py_start = *_py_start; + } else { + if (has_cstart) { + owned_start = py_start = PyInt_FromSsize_t(cstart); + if (unlikely(!py_start)) goto bad; + } else + py_start = Py_None; + } + if (_py_stop) { + py_stop = *_py_stop; + } else { + if (has_cstop) { + owned_stop = py_stop = PyInt_FromSsize_t(cstop); + if (unlikely(!py_stop)) { + Py_XDECREF(owned_start); + goto bad; + } + } else + py_stop = Py_None; + } + py_slice = PySlice_New(py_start, py_stop, Py_None); + Py_XDECREF(owned_start); + Py_XDECREF(owned_stop); + if (unlikely(!py_slice)) goto bad; + } +#if CYTHON_USE_TYPE_SLOTS + result = mp->mp_ass_subscript(obj, py_slice, value); +#else + result = value ? PyObject_SetItem(obj, py_slice, value) : PyObject_DelItem(obj, py_slice); +#endif + if (!_py_slice) { + Py_DECREF(py_slice); + } + return result; + } + PyErr_Format(PyExc_TypeError, + "'%.200s' object does not support slice %.10s", + Py_TYPE(obj)->tp_name, value ? "assignment" : "deletion"); +bad: + return -1; +} + +/* BytesEquals */ +static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals) { +#if CYTHON_COMPILING_IN_PYPY + return PyObject_RichCompareBool(s1, s2, equals); +#else + if (s1 == s2) { + return (equals == Py_EQ); + } else if (PyBytes_CheckExact(s1) & PyBytes_CheckExact(s2)) { + const char *ps1, *ps2; + Py_ssize_t length = PyBytes_GET_SIZE(s1); + if (length != PyBytes_GET_SIZE(s2)) + return (equals == Py_NE); + ps1 = PyBytes_AS_STRING(s1); + ps2 = PyBytes_AS_STRING(s2); + if (ps1[0] != ps2[0]) { + return (equals == Py_NE); + } else if (length == 1) { + return (equals == Py_EQ); + } else { + int result; +#if CYTHON_USE_UNICODE_INTERNALS + Py_hash_t hash1, hash2; + hash1 = ((PyBytesObject*)s1)->ob_shash; + hash2 = ((PyBytesObject*)s2)->ob_shash; + if (hash1 != hash2 && hash1 != -1 && hash2 != -1) { + return (equals == Py_NE); + } +#endif + result = memcmp(ps1, ps2, (size_t)length); + return (equals == Py_EQ) ? (result == 0) : (result != 0); + } + } else if ((s1 == Py_None) & PyBytes_CheckExact(s2)) { + return (equals == Py_NE); + } else if ((s2 == Py_None) & PyBytes_CheckExact(s1)) { + return (equals == Py_NE); + } else { + int result; + PyObject* py_result = PyObject_RichCompare(s1, s2, equals); + if (!py_result) + return -1; + result = __Pyx_PyObject_IsTrue(py_result); + Py_DECREF(py_result); + return result; + } +#endif +} + +/* UnicodeEquals */ +static CYTHON_INLINE int __Pyx_PyUnicode_Equals(PyObject* s1, PyObject* s2, int equals) { +#if CYTHON_COMPILING_IN_PYPY + return PyObject_RichCompareBool(s1, s2, equals); +#else +#if PY_MAJOR_VERSION < 3 + PyObject* owned_ref = NULL; +#endif + int s1_is_unicode, s2_is_unicode; + if (s1 == s2) { + goto return_eq; + } + s1_is_unicode = PyUnicode_CheckExact(s1); + s2_is_unicode = PyUnicode_CheckExact(s2); +#if PY_MAJOR_VERSION < 3 + if ((s1_is_unicode & (!s2_is_unicode)) && PyString_CheckExact(s2)) { + owned_ref = PyUnicode_FromObject(s2); + if (unlikely(!owned_ref)) + return -1; + s2 = owned_ref; + s2_is_unicode = 1; + } else if ((s2_is_unicode & (!s1_is_unicode)) && PyString_CheckExact(s1)) { + owned_ref = PyUnicode_FromObject(s1); + if (unlikely(!owned_ref)) + return -1; + s1 = owned_ref; + s1_is_unicode = 1; + } else if (((!s2_is_unicode) & (!s1_is_unicode))) { + return __Pyx_PyBytes_Equals(s1, s2, equals); + } +#endif + if (s1_is_unicode & s2_is_unicode) { + Py_ssize_t length; + int kind; + void *data1, *data2; + if (unlikely(__Pyx_PyUnicode_READY(s1) < 0) || unlikely(__Pyx_PyUnicode_READY(s2) < 0)) + return -1; + length = __Pyx_PyUnicode_GET_LENGTH(s1); + if (length != __Pyx_PyUnicode_GET_LENGTH(s2)) { + goto return_ne; + } +#if CYTHON_USE_UNICODE_INTERNALS + { + Py_hash_t hash1, hash2; + #if CYTHON_PEP393_ENABLED + hash1 = ((PyASCIIObject*)s1)->hash; + hash2 = ((PyASCIIObject*)s2)->hash; + #else + hash1 = ((PyUnicodeObject*)s1)->hash; + hash2 = ((PyUnicodeObject*)s2)->hash; + #endif + if (hash1 != hash2 && hash1 != -1 && hash2 != -1) { + goto return_ne; + } + } +#endif + kind = __Pyx_PyUnicode_KIND(s1); + if (kind != __Pyx_PyUnicode_KIND(s2)) { + goto return_ne; + } + data1 = __Pyx_PyUnicode_DATA(s1); + data2 = __Pyx_PyUnicode_DATA(s2); + if (__Pyx_PyUnicode_READ(kind, data1, 0) != __Pyx_PyUnicode_READ(kind, data2, 0)) { + goto return_ne; + } else if (length == 1) { + goto return_eq; + } else { + int result = memcmp(data1, data2, (size_t)(length * kind)); + #if PY_MAJOR_VERSION < 3 + Py_XDECREF(owned_ref); + #endif + return (equals == Py_EQ) ? (result == 0) : (result != 0); + } + } else if ((s1 == Py_None) & s2_is_unicode) { + goto return_ne; + } else if ((s2 == Py_None) & s1_is_unicode) { + goto return_ne; + } else { + int result; + PyObject* py_result = PyObject_RichCompare(s1, s2, equals); + #if PY_MAJOR_VERSION < 3 + Py_XDECREF(owned_ref); + #endif + if (!py_result) + return -1; + result = __Pyx_PyObject_IsTrue(py_result); + Py_DECREF(py_result); + return result; + } +return_eq: + #if PY_MAJOR_VERSION < 3 + Py_XDECREF(owned_ref); + #endif + return (equals == Py_EQ); +return_ne: + #if PY_MAJOR_VERSION < 3 + Py_XDECREF(owned_ref); + #endif + return (equals == Py_NE); +#endif +} + +/* UnicodeAsUCS4 */ +static CYTHON_INLINE Py_UCS4 __Pyx_PyUnicode_AsPy_UCS4(PyObject* x) { + Py_ssize_t length; + #if CYTHON_PEP393_ENABLED + length = PyUnicode_GET_LENGTH(x); + if (likely(length == 1)) { + return PyUnicode_READ_CHAR(x, 0); + } + #else + length = PyUnicode_GET_SIZE(x); + if (likely(length == 1)) { + return PyUnicode_AS_UNICODE(x)[0]; + } + #if Py_UNICODE_SIZE == 2 + else if (PyUnicode_GET_SIZE(x) == 2) { + Py_UCS4 high_val = PyUnicode_AS_UNICODE(x)[0]; + if (high_val >= 0xD800 && high_val <= 0xDBFF) { + Py_UCS4 low_val = PyUnicode_AS_UNICODE(x)[1]; + if (low_val >= 0xDC00 && low_val <= 0xDFFF) { + return 0x10000 + (((high_val & ((1<<10)-1)) << 10) | (low_val & ((1<<10)-1))); + } + } + } + #endif + #endif + PyErr_Format(PyExc_ValueError, + "only single character unicode strings can be converted to Py_UCS4, " + "got length %" CYTHON_FORMAT_SSIZE_T "d", length); + return (Py_UCS4)-1; +} + +/* object_ord */ +static long __Pyx__PyObject_Ord(PyObject* c) { + Py_ssize_t size; + if (PyBytes_Check(c)) { + size = PyBytes_GET_SIZE(c); + if (likely(size == 1)) { + return (unsigned char) PyBytes_AS_STRING(c)[0]; + } +#if PY_MAJOR_VERSION < 3 + } else if (PyUnicode_Check(c)) { + return (long)__Pyx_PyUnicode_AsPy_UCS4(c); +#endif +#if (!CYTHON_COMPILING_IN_PYPY) || (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE)) + } else if (PyByteArray_Check(c)) { + size = PyByteArray_GET_SIZE(c); + if (likely(size == 1)) { + return (unsigned char) PyByteArray_AS_STRING(c)[0]; + } +#endif + } else { + PyErr_Format(PyExc_TypeError, + "ord() expected string of length 1, but %.200s found", c->ob_type->tp_name); + return (long)(Py_UCS4)-1; + } + PyErr_Format(PyExc_TypeError, + "ord() expected a character, but string of length %zd found", size); + return (long)(Py_UCS4)-1; +} + +/* SliceObject */ +static CYTHON_INLINE PyObject* __Pyx_PyObject_GetSlice(PyObject* obj, + Py_ssize_t cstart, Py_ssize_t cstop, + PyObject** _py_start, PyObject** _py_stop, PyObject** _py_slice, + int has_cstart, int has_cstop, CYTHON_UNUSED int wraparound) { +#if CYTHON_USE_TYPE_SLOTS + PyMappingMethods* mp; +#if PY_MAJOR_VERSION < 3 + PySequenceMethods* ms = Py_TYPE(obj)->tp_as_sequence; + if (likely(ms && ms->sq_slice)) { + if (!has_cstart) { + if (_py_start && (*_py_start != Py_None)) { + cstart = __Pyx_PyIndex_AsSsize_t(*_py_start); + if ((cstart == (Py_ssize_t)-1) && PyErr_Occurred()) goto bad; + } else + cstart = 0; + } + if (!has_cstop) { + if (_py_stop && (*_py_stop != Py_None)) { + cstop = __Pyx_PyIndex_AsSsize_t(*_py_stop); + if ((cstop == (Py_ssize_t)-1) && PyErr_Occurred()) goto bad; + } else + cstop = PY_SSIZE_T_MAX; + } + if (wraparound && unlikely((cstart < 0) | (cstop < 0)) && likely(ms->sq_length)) { + Py_ssize_t l = ms->sq_length(obj); + if (likely(l >= 0)) { + if (cstop < 0) { + cstop += l; + if (cstop < 0) cstop = 0; + } + if (cstart < 0) { + cstart += l; + if (cstart < 0) cstart = 0; + } + } else { + if (!PyErr_ExceptionMatches(PyExc_OverflowError)) + goto bad; + PyErr_Clear(); + } + } + return ms->sq_slice(obj, cstart, cstop); + } +#endif + mp = Py_TYPE(obj)->tp_as_mapping; + if (likely(mp && mp->mp_subscript)) +#endif + { + PyObject* result; + PyObject *py_slice, *py_start, *py_stop; + if (_py_slice) { + py_slice = *_py_slice; + } else { + PyObject* owned_start = NULL; + PyObject* owned_stop = NULL; + if (_py_start) { + py_start = *_py_start; + } else { + if (has_cstart) { + owned_start = py_start = PyInt_FromSsize_t(cstart); + if (unlikely(!py_start)) goto bad; + } else + py_start = Py_None; + } + if (_py_stop) { + py_stop = *_py_stop; + } else { + if (has_cstop) { + owned_stop = py_stop = PyInt_FromSsize_t(cstop); + if (unlikely(!py_stop)) { + Py_XDECREF(owned_start); + goto bad; + } + } else + py_stop = Py_None; + } + py_slice = PySlice_New(py_start, py_stop, Py_None); + Py_XDECREF(owned_start); + Py_XDECREF(owned_stop); + if (unlikely(!py_slice)) goto bad; + } +#if CYTHON_USE_TYPE_SLOTS + result = mp->mp_subscript(obj, py_slice); +#else + result = PyObject_GetItem(obj, py_slice); +#endif + if (!_py_slice) { + Py_DECREF(py_slice); + } + return result; + } + PyErr_Format(PyExc_TypeError, + "'%.200s' object is unsliceable", Py_TYPE(obj)->tp_name); +bad: + return NULL; +} + +/* Import */ +static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level) { + PyObject *empty_list = 0; + PyObject *module = 0; + PyObject *global_dict = 0; + PyObject *empty_dict = 0; + PyObject *list; + #if PY_MAJOR_VERSION < 3 + PyObject *py_import; + py_import = __Pyx_PyObject_GetAttrStr(__pyx_b, __pyx_n_s_import); + if (!py_import) + goto bad; + #endif + if (from_list) + list = from_list; + else { + empty_list = PyList_New(0); + if (!empty_list) + goto bad; + list = empty_list; + } + global_dict = PyModule_GetDict(__pyx_m); + if (!global_dict) + goto bad; + empty_dict = PyDict_New(); + if (!empty_dict) + goto bad; + { + #if PY_MAJOR_VERSION >= 3 + if (level == -1) { + if ((1) && (strchr(__Pyx_MODULE_NAME, '.'))) { + module = PyImport_ImportModuleLevelObject( + name, global_dict, empty_dict, list, 1); + if (!module) { + if (!PyErr_ExceptionMatches(PyExc_ImportError)) + goto bad; + PyErr_Clear(); + } + } + level = 0; + } + #endif + if (!module) { + #if PY_MAJOR_VERSION < 3 + PyObject *py_level = PyInt_FromLong(level); + if (!py_level) + goto bad; + module = PyObject_CallFunctionObjArgs(py_import, + name, global_dict, empty_dict, list, py_level, (PyObject *)NULL); + Py_DECREF(py_level); + #else + module = PyImport_ImportModuleLevelObject( + name, global_dict, empty_dict, list, level); + #endif + } + } +bad: + #if PY_MAJOR_VERSION < 3 + Py_XDECREF(py_import); + #endif + Py_XDECREF(empty_list); + Py_XDECREF(empty_dict); + return module; +} + +/* ImportFrom */ +static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name) { + PyObject* value = __Pyx_PyObject_GetAttrStr(module, name); + if (unlikely(!value) && PyErr_ExceptionMatches(PyExc_AttributeError)) { + PyErr_Format(PyExc_ImportError, + #if PY_MAJOR_VERSION < 3 + "cannot import name %.230s", PyString_AS_STRING(name)); + #else + "cannot import name %S", name); + #endif + } + return value; +} + +/* GetItemInt */ +static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) { + PyObject *r; + if (!j) return NULL; + r = PyObject_GetItem(o, j); + Py_DECREF(j); + return r; +} +static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i, + CYTHON_NCP_UNUSED int wraparound, + CYTHON_NCP_UNUSED int boundscheck) { +#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS + Py_ssize_t wrapped_i = i; + if (wraparound & unlikely(i < 0)) { + wrapped_i += PyList_GET_SIZE(o); + } + if ((!boundscheck) || likely(__Pyx_is_valid_index(wrapped_i, PyList_GET_SIZE(o)))) { + PyObject *r = PyList_GET_ITEM(o, wrapped_i); + Py_INCREF(r); + return r; + } + return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i)); +#else + return PySequence_GetItem(o, i); +#endif +} +static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i, + CYTHON_NCP_UNUSED int wraparound, + CYTHON_NCP_UNUSED int boundscheck) { +#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS + Py_ssize_t wrapped_i = i; + if (wraparound & unlikely(i < 0)) { + wrapped_i += PyTuple_GET_SIZE(o); + } + if ((!boundscheck) || likely(__Pyx_is_valid_index(wrapped_i, PyTuple_GET_SIZE(o)))) { + PyObject *r = PyTuple_GET_ITEM(o, wrapped_i); + Py_INCREF(r); + return r; + } + return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i)); +#else + return PySequence_GetItem(o, i); +#endif +} +static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i, int is_list, + CYTHON_NCP_UNUSED int wraparound, + CYTHON_NCP_UNUSED int boundscheck) { +#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS && CYTHON_USE_TYPE_SLOTS + if (is_list || PyList_CheckExact(o)) { + Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyList_GET_SIZE(o); + if ((!boundscheck) || (likely(__Pyx_is_valid_index(n, PyList_GET_SIZE(o))))) { + PyObject *r = PyList_GET_ITEM(o, n); + Py_INCREF(r); + return r; + } + } + else if (PyTuple_CheckExact(o)) { + Py_ssize_t n = ((!wraparound) | likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o); + if ((!boundscheck) || likely(__Pyx_is_valid_index(n, PyTuple_GET_SIZE(o)))) { + PyObject *r = PyTuple_GET_ITEM(o, n); + Py_INCREF(r); + return r; + } + } else { + PySequenceMethods *m = Py_TYPE(o)->tp_as_sequence; + if (likely(m && m->sq_item)) { + if (wraparound && unlikely(i < 0) && likely(m->sq_length)) { + Py_ssize_t l = m->sq_length(o); + if (likely(l >= 0)) { + i += l; + } else { + if (!PyErr_ExceptionMatches(PyExc_OverflowError)) + return NULL; + PyErr_Clear(); + } + } + return m->sq_item(o, i); + } + } +#else + if (is_list || PySequence_Check(o)) { + return PySequence_GetItem(o, i); + } +#endif + return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i)); +} + +/* HasAttr */ +static CYTHON_INLINE int __Pyx_HasAttr(PyObject *o, PyObject *n) { + PyObject *r; + if (unlikely(!__Pyx_PyBaseString_Check(n))) { + PyErr_SetString(PyExc_TypeError, + "hasattr(): attribute name must be string"); + return -1; + } + r = __Pyx_GetAttr(o, n); + if (unlikely(!r)) { + PyErr_Clear(); + return 0; + } else { + Py_DECREF(r); + return 1; + } +} + +/* ExtTypeTest */ +static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type) { + if (unlikely(!type)) { + PyErr_SetString(PyExc_SystemError, "Missing type object"); + return 0; + } + if (likely(__Pyx_TypeCheck(obj, type))) + return 1; + PyErr_Format(PyExc_TypeError, "Cannot convert %.200s to %.200s", + Py_TYPE(obj)->tp_name, type->tp_name); + return 0; +} + +/* PyObject_GenericGetAttrNoDict */ +#if CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP && PY_VERSION_HEX < 0x03070000 +static PyObject *__Pyx_RaiseGenericGetAttributeError(PyTypeObject *tp, PyObject *attr_name) { + PyErr_Format(PyExc_AttributeError, +#if PY_MAJOR_VERSION >= 3 + "'%.50s' object has no attribute '%U'", + tp->tp_name, attr_name); +#else + "'%.50s' object has no attribute '%.400s'", + tp->tp_name, PyString_AS_STRING(attr_name)); +#endif + return NULL; +} +static CYTHON_INLINE PyObject* __Pyx_PyObject_GenericGetAttrNoDict(PyObject* obj, PyObject* attr_name) { + PyObject *descr; + PyTypeObject *tp = Py_TYPE(obj); + if (unlikely(!PyString_Check(attr_name))) { + return PyObject_GenericGetAttr(obj, attr_name); + } + assert(!tp->tp_dictoffset); + descr = _PyType_Lookup(tp, attr_name); + if (unlikely(!descr)) { + return __Pyx_RaiseGenericGetAttributeError(tp, attr_name); + } + Py_INCREF(descr); + #if PY_MAJOR_VERSION < 3 + if (likely(PyType_HasFeature(Py_TYPE(descr), Py_TPFLAGS_HAVE_CLASS))) + #endif + { + descrgetfunc f = Py_TYPE(descr)->tp_descr_get; + if (unlikely(f)) { + PyObject *res = f(descr, obj, (PyObject *)tp); + Py_DECREF(descr); + return res; + } + } + return descr; +} +#endif + +/* PyObject_GenericGetAttr */ +#if CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP && PY_VERSION_HEX < 0x03070000 +static PyObject* __Pyx_PyObject_GenericGetAttr(PyObject* obj, PyObject* attr_name) { + if (unlikely(Py_TYPE(obj)->tp_dictoffset)) { + return PyObject_GenericGetAttr(obj, attr_name); + } + return __Pyx_PyObject_GenericGetAttrNoDict(obj, attr_name); +} +#endif + +/* SetVTable */ +static int __Pyx_SetVtable(PyObject *dict, void *vtable) { +#if PY_VERSION_HEX >= 0x02070000 + PyObject *ob = PyCapsule_New(vtable, 0, 0); +#else + PyObject *ob = PyCObject_FromVoidPtr(vtable, 0); +#endif + if (!ob) + goto bad; + if (PyDict_SetItem(dict, __pyx_n_s_pyx_vtable, ob) < 0) + goto bad; + Py_DECREF(ob); + return 0; +bad: + Py_XDECREF(ob); + return -1; +} + +/* PyObjectGetAttrStrNoError */ +static void __Pyx_PyObject_GetAttrStr_ClearAttributeError(void) { + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + if (likely(__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError))) + __Pyx_PyErr_Clear(); +} +static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name) { + PyObject *result; +#if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_TYPE_SLOTS && PY_VERSION_HEX >= 0x030700B1 + PyTypeObject* tp = Py_TYPE(obj); + if (likely(tp->tp_getattro == PyObject_GenericGetAttr)) { + return _PyObject_GenericGetAttrWithDict(obj, attr_name, NULL, 1); + } +#endif + result = __Pyx_PyObject_GetAttrStr(obj, attr_name); + if (unlikely(!result)) { + __Pyx_PyObject_GetAttrStr_ClearAttributeError(); + } + return result; +} + +/* SetupReduce */ +static int __Pyx_setup_reduce_is_named(PyObject* meth, PyObject* name) { + int ret; + PyObject *name_attr; + name_attr = __Pyx_PyObject_GetAttrStr(meth, __pyx_n_s_name); + if (likely(name_attr)) { + ret = PyObject_RichCompareBool(name_attr, name, Py_EQ); + } else { + ret = -1; + } + if (unlikely(ret < 0)) { + PyErr_Clear(); + ret = 0; + } + Py_XDECREF(name_attr); + return ret; +} +static int __Pyx_setup_reduce(PyObject* type_obj) { + int ret = 0; + PyObject *object_reduce = NULL; + PyObject *object_reduce_ex = NULL; + PyObject *reduce = NULL; + PyObject *reduce_ex = NULL; + PyObject *reduce_cython = NULL; + PyObject *setstate = NULL; + PyObject *setstate_cython = NULL; +#if CYTHON_USE_PYTYPE_LOOKUP + if (_PyType_Lookup((PyTypeObject*)type_obj, __pyx_n_s_getstate)) goto __PYX_GOOD; +#else + if (PyObject_HasAttr(type_obj, __pyx_n_s_getstate)) goto __PYX_GOOD; +#endif +#if CYTHON_USE_PYTYPE_LOOKUP + object_reduce_ex = _PyType_Lookup(&PyBaseObject_Type, __pyx_n_s_reduce_ex); if (!object_reduce_ex) goto __PYX_BAD; +#else + object_reduce_ex = __Pyx_PyObject_GetAttrStr((PyObject*)&PyBaseObject_Type, __pyx_n_s_reduce_ex); if (!object_reduce_ex) goto __PYX_BAD; +#endif + reduce_ex = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_reduce_ex); if (unlikely(!reduce_ex)) goto __PYX_BAD; + if (reduce_ex == object_reduce_ex) { +#if CYTHON_USE_PYTYPE_LOOKUP + object_reduce = _PyType_Lookup(&PyBaseObject_Type, __pyx_n_s_reduce); if (!object_reduce) goto __PYX_BAD; +#else + object_reduce = __Pyx_PyObject_GetAttrStr((PyObject*)&PyBaseObject_Type, __pyx_n_s_reduce); if (!object_reduce) goto __PYX_BAD; +#endif + reduce = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_reduce); if (unlikely(!reduce)) goto __PYX_BAD; + if (reduce == object_reduce || __Pyx_setup_reduce_is_named(reduce, __pyx_n_s_reduce_cython)) { + reduce_cython = __Pyx_PyObject_GetAttrStrNoError(type_obj, __pyx_n_s_reduce_cython); + if (likely(reduce_cython)) { + ret = PyDict_SetItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_reduce, reduce_cython); if (unlikely(ret < 0)) goto __PYX_BAD; + ret = PyDict_DelItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_reduce_cython); if (unlikely(ret < 0)) goto __PYX_BAD; + } else if (reduce == object_reduce || PyErr_Occurred()) { + goto __PYX_BAD; + } + setstate = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_n_s_setstate); + if (!setstate) PyErr_Clear(); + if (!setstate || __Pyx_setup_reduce_is_named(setstate, __pyx_n_s_setstate_cython)) { + setstate_cython = __Pyx_PyObject_GetAttrStrNoError(type_obj, __pyx_n_s_setstate_cython); + if (likely(setstate_cython)) { + ret = PyDict_SetItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_setstate, setstate_cython); if (unlikely(ret < 0)) goto __PYX_BAD; + ret = PyDict_DelItem(((PyTypeObject*)type_obj)->tp_dict, __pyx_n_s_setstate_cython); if (unlikely(ret < 0)) goto __PYX_BAD; + } else if (!setstate || PyErr_Occurred()) { + goto __PYX_BAD; + } + } + PyType_Modified((PyTypeObject*)type_obj); + } + } + goto __PYX_GOOD; +__PYX_BAD: + if (!PyErr_Occurred()) + PyErr_Format(PyExc_RuntimeError, "Unable to initialize pickling for %s", ((PyTypeObject*)type_obj)->tp_name); + ret = -1; +__PYX_GOOD: +#if !CYTHON_USE_PYTYPE_LOOKUP + Py_XDECREF(object_reduce); + Py_XDECREF(object_reduce_ex); +#endif + Py_XDECREF(reduce); + Py_XDECREF(reduce_ex); + Py_XDECREF(reduce_cython); + Py_XDECREF(setstate); + Py_XDECREF(setstate_cython); + return ret; +} + +/* TypeImport */ +#ifndef __PYX_HAVE_RT_ImportType +#define __PYX_HAVE_RT_ImportType +static PyTypeObject *__Pyx_ImportType(PyObject *module, const char *module_name, const char *class_name, + size_t size, enum __Pyx_ImportType_CheckSize check_size) +{ + PyObject *result = 0; + char warning[200]; + Py_ssize_t basicsize; +#ifdef Py_LIMITED_API + PyObject *py_basicsize; +#endif + result = PyObject_GetAttrString(module, class_name); + if (!result) + goto bad; + if (!PyType_Check(result)) { + PyErr_Format(PyExc_TypeError, + "%.200s.%.200s is not a type object", + module_name, class_name); + goto bad; + } +#ifndef Py_LIMITED_API + basicsize = ((PyTypeObject *)result)->tp_basicsize; +#else + py_basicsize = PyObject_GetAttrString(result, "__basicsize__"); + if (!py_basicsize) + goto bad; + basicsize = PyLong_AsSsize_t(py_basicsize); + Py_DECREF(py_basicsize); + py_basicsize = 0; + if (basicsize == (Py_ssize_t)-1 && PyErr_Occurred()) + goto bad; +#endif + if ((size_t)basicsize < size) { + PyErr_Format(PyExc_ValueError, + "%.200s.%.200s size changed, may indicate binary incompatibility. " + "Expected %zd from C header, got %zd from PyObject", + module_name, class_name, size, basicsize); + goto bad; + } + if (check_size == __Pyx_ImportType_CheckSize_Error && (size_t)basicsize != size) { + PyErr_Format(PyExc_ValueError, + "%.200s.%.200s size changed, may indicate binary incompatibility. " + "Expected %zd from C header, got %zd from PyObject", + module_name, class_name, size, basicsize); + goto bad; + } + else if (check_size == __Pyx_ImportType_CheckSize_Warn && (size_t)basicsize > size) { + PyOS_snprintf(warning, sizeof(warning), + "%s.%s size changed, may indicate binary incompatibility. " + "Expected %zd from C header, got %zd from PyObject", + module_name, class_name, size, basicsize); + if (PyErr_WarnEx(NULL, warning, 0) < 0) goto bad; + } + return (PyTypeObject *)result; +bad: + Py_XDECREF(result); + return NULL; +} +#endif + +/* CLineInTraceback */ +#ifndef CYTHON_CLINE_IN_TRACEBACK +static int __Pyx_CLineForTraceback(CYTHON_NCP_UNUSED PyThreadState *tstate, int c_line) { + PyObject *use_cline; + PyObject *ptype, *pvalue, *ptraceback; +#if CYTHON_COMPILING_IN_CPYTHON + PyObject **cython_runtime_dict; +#endif + if (unlikely(!__pyx_cython_runtime)) { + return c_line; + } + __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); +#if CYTHON_COMPILING_IN_CPYTHON + cython_runtime_dict = _PyObject_GetDictPtr(__pyx_cython_runtime); + if (likely(cython_runtime_dict)) { + __PYX_PY_DICT_LOOKUP_IF_MODIFIED( + use_cline, *cython_runtime_dict, + __Pyx_PyDict_GetItemStr(*cython_runtime_dict, __pyx_n_s_cline_in_traceback)) + } else +#endif + { + PyObject *use_cline_obj = __Pyx_PyObject_GetAttrStr(__pyx_cython_runtime, __pyx_n_s_cline_in_traceback); + if (use_cline_obj) { + use_cline = PyObject_Not(use_cline_obj) ? Py_False : Py_True; + Py_DECREF(use_cline_obj); + } else { + PyErr_Clear(); + use_cline = NULL; + } + } + if (!use_cline) { + c_line = 0; + PyObject_SetAttr(__pyx_cython_runtime, __pyx_n_s_cline_in_traceback, Py_False); + } + else if (use_cline == Py_False || (use_cline != Py_True && PyObject_Not(use_cline) != 0)) { + c_line = 0; + } + __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); + return c_line; +} +#endif + +/* CodeObjectCache */ +static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) { + int start = 0, mid = 0, end = count - 1; + if (end >= 0 && code_line > entries[end].code_line) { + return count; + } + while (start < end) { + mid = start + (end - start) / 2; + if (code_line < entries[mid].code_line) { + end = mid; + } else if (code_line > entries[mid].code_line) { + start = mid + 1; + } else { + return mid; + } + } + if (code_line <= entries[mid].code_line) { + return mid; + } else { + return mid + 1; + } +} +static PyCodeObject *__pyx_find_code_object(int code_line) { + PyCodeObject* code_object; + int pos; + if (unlikely(!code_line) || unlikely(!__pyx_code_cache.entries)) { + return NULL; + } + pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line); + if (unlikely(pos >= __pyx_code_cache.count) || unlikely(__pyx_code_cache.entries[pos].code_line != code_line)) { + return NULL; + } + code_object = __pyx_code_cache.entries[pos].code_object; + Py_INCREF(code_object); + return code_object; +} +static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object) { + int pos, i; + __Pyx_CodeObjectCacheEntry* entries = __pyx_code_cache.entries; + if (unlikely(!code_line)) { + return; + } + if (unlikely(!entries)) { + entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry)); + if (likely(entries)) { + __pyx_code_cache.entries = entries; + __pyx_code_cache.max_count = 64; + __pyx_code_cache.count = 1; + entries[0].code_line = code_line; + entries[0].code_object = code_object; + Py_INCREF(code_object); + } + return; + } + pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line); + if ((pos < __pyx_code_cache.count) && unlikely(__pyx_code_cache.entries[pos].code_line == code_line)) { + PyCodeObject* tmp = entries[pos].code_object; + entries[pos].code_object = code_object; + Py_DECREF(tmp); + return; + } + if (__pyx_code_cache.count == __pyx_code_cache.max_count) { + int new_max = __pyx_code_cache.max_count + 64; + entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc( + __pyx_code_cache.entries, ((size_t)new_max) * sizeof(__Pyx_CodeObjectCacheEntry)); + if (unlikely(!entries)) { + return; + } + __pyx_code_cache.entries = entries; + __pyx_code_cache.max_count = new_max; + } + for (i=__pyx_code_cache.count; i>pos; i--) { + entries[i] = entries[i-1]; + } + entries[pos].code_line = code_line; + entries[pos].code_object = code_object; + __pyx_code_cache.count++; + Py_INCREF(code_object); +} + +/* AddTraceback */ +#include "compile.h" +#include "frameobject.h" +#include "traceback.h" +static PyCodeObject* __Pyx_CreateCodeObjectForTraceback( + const char *funcname, int c_line, + int py_line, const char *filename) { + PyCodeObject *py_code = 0; + PyObject *py_srcfile = 0; + PyObject *py_funcname = 0; + #if PY_MAJOR_VERSION < 3 + py_srcfile = PyString_FromString(filename); + #else + py_srcfile = PyUnicode_FromString(filename); + #endif + if (!py_srcfile) goto bad; + if (c_line) { + #if PY_MAJOR_VERSION < 3 + py_funcname = PyString_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); + #else + py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); + #endif + } + else { + #if PY_MAJOR_VERSION < 3 + py_funcname = PyString_FromString(funcname); + #else + py_funcname = PyUnicode_FromString(funcname); + #endif + } + if (!py_funcname) goto bad; + py_code = __Pyx_PyCode_New( + 0, + 0, + 0, + 0, + 0, + __pyx_empty_bytes, /*PyObject *code,*/ + __pyx_empty_tuple, /*PyObject *consts,*/ + __pyx_empty_tuple, /*PyObject *names,*/ + __pyx_empty_tuple, /*PyObject *varnames,*/ + __pyx_empty_tuple, /*PyObject *freevars,*/ + __pyx_empty_tuple, /*PyObject *cellvars,*/ + py_srcfile, /*PyObject *filename,*/ + py_funcname, /*PyObject *name,*/ + py_line, + __pyx_empty_bytes /*PyObject *lnotab*/ + ); + Py_DECREF(py_srcfile); + Py_DECREF(py_funcname); + return py_code; +bad: + Py_XDECREF(py_srcfile); + Py_XDECREF(py_funcname); + return NULL; +} +static void __Pyx_AddTraceback(const char *funcname, int c_line, + int py_line, const char *filename) { + PyCodeObject *py_code = 0; + PyFrameObject *py_frame = 0; + PyThreadState *tstate = __Pyx_PyThreadState_Current; + if (c_line) { + c_line = __Pyx_CLineForTraceback(tstate, c_line); + } + py_code = __pyx_find_code_object(c_line ? -c_line : py_line); + if (!py_code) { + py_code = __Pyx_CreateCodeObjectForTraceback( + funcname, c_line, py_line, filename); + if (!py_code) goto bad; + __pyx_insert_code_object(c_line ? -c_line : py_line, py_code); + } + py_frame = PyFrame_New( + tstate, /*PyThreadState *tstate,*/ + py_code, /*PyCodeObject *code,*/ + __pyx_d, /*PyObject *globals,*/ + 0 /*PyObject *locals*/ + ); + if (!py_frame) goto bad; + __Pyx_PyFrame_SetLineNumber(py_frame, py_line); + PyTraceBack_Here(py_frame); +bad: + Py_XDECREF(py_code); + Py_XDECREF(py_frame); +} + +/* CIntFromPyVerify */ +#define __PYX_VERIFY_RETURN_INT(target_type, func_type, func_value)\ + __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 0) +#define __PYX_VERIFY_RETURN_INT_EXC(target_type, func_type, func_value)\ + __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, 1) +#define __PYX__VERIFY_RETURN_INT(target_type, func_type, func_value, exc)\ + {\ + func_type value = func_value;\ + if (sizeof(target_type) < sizeof(func_type)) {\ + if (unlikely(value != (func_type) (target_type) value)) {\ + func_type zero = 0;\ + if (exc && unlikely(value == (func_type)-1 && PyErr_Occurred()))\ + return (target_type) -1;\ + if (is_unsigned && unlikely(value < zero))\ + goto raise_neg_overflow;\ + else\ + goto raise_overflow;\ + }\ + }\ + return (target_type) value;\ + } + +/* CIntToPy */ +static CYTHON_INLINE PyObject* __Pyx_PyInt_From_long(long value) { + const long neg_one = (long) ((long) 0 - (long) 1), const_zero = (long) 0; + const int is_unsigned = neg_one > const_zero; + if (is_unsigned) { + if (sizeof(long) < sizeof(long)) { + return PyInt_FromLong((long) value); + } else if (sizeof(long) <= sizeof(unsigned long)) { + return PyLong_FromUnsignedLong((unsigned long) value); +#ifdef HAVE_LONG_LONG + } else if (sizeof(long) <= sizeof(unsigned PY_LONG_LONG)) { + return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value); +#endif + } + } else { + if (sizeof(long) <= sizeof(long)) { + return PyInt_FromLong((long) value); +#ifdef HAVE_LONG_LONG + } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) { + return PyLong_FromLongLong((PY_LONG_LONG) value); +#endif + } + } + { + int one = 1; int little = (int)*(unsigned char *)&one; + unsigned char *bytes = (unsigned char *)&value; + return _PyLong_FromByteArray(bytes, sizeof(long), + little, !is_unsigned); + } +} + +/* CIntFromPy */ +static CYTHON_INLINE uint8_t __Pyx_PyInt_As_uint8_t(PyObject *x) { + const uint8_t neg_one = (uint8_t) ((uint8_t) 0 - (uint8_t) 1), const_zero = (uint8_t) 0; + const int is_unsigned = neg_one > const_zero; +#if PY_MAJOR_VERSION < 3 + if (likely(PyInt_Check(x))) { + if (sizeof(uint8_t) < sizeof(long)) { + __PYX_VERIFY_RETURN_INT(uint8_t, long, PyInt_AS_LONG(x)) + } else { + long val = PyInt_AS_LONG(x); + if (is_unsigned && unlikely(val < 0)) { + goto raise_neg_overflow; + } + return (uint8_t) val; + } + } else +#endif + if (likely(PyLong_Check(x))) { + if (is_unsigned) { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (uint8_t) 0; + case 1: __PYX_VERIFY_RETURN_INT(uint8_t, digit, digits[0]) + case 2: + if (8 * sizeof(uint8_t) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) >= 2 * PyLong_SHIFT) { + return (uint8_t) (((((uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0])); + } + } + break; + case 3: + if (8 * sizeof(uint8_t) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) >= 3 * PyLong_SHIFT) { + return (uint8_t) (((((((uint8_t)digits[2]) << PyLong_SHIFT) | (uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0])); + } + } + break; + case 4: + if (8 * sizeof(uint8_t) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) >= 4 * PyLong_SHIFT) { + return (uint8_t) (((((((((uint8_t)digits[3]) << PyLong_SHIFT) | (uint8_t)digits[2]) << PyLong_SHIFT) | (uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0])); + } + } + break; + } +#endif +#if CYTHON_COMPILING_IN_CPYTHON + if (unlikely(Py_SIZE(x) < 0)) { + goto raise_neg_overflow; + } +#else + { + int result = PyObject_RichCompareBool(x, Py_False, Py_LT); + if (unlikely(result < 0)) + return (uint8_t) -1; + if (unlikely(result == 1)) + goto raise_neg_overflow; + } +#endif + if (sizeof(uint8_t) <= sizeof(unsigned long)) { + __PYX_VERIFY_RETURN_INT_EXC(uint8_t, unsigned long, PyLong_AsUnsignedLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(uint8_t) <= sizeof(unsigned PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(uint8_t, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) +#endif + } + } else { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (uint8_t) 0; + case -1: __PYX_VERIFY_RETURN_INT(uint8_t, sdigit, (sdigit) (-(sdigit)digits[0])) + case 1: __PYX_VERIFY_RETURN_INT(uint8_t, digit, +digits[0]) + case -2: + if (8 * sizeof(uint8_t) - 1 > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) - 1 > 2 * PyLong_SHIFT) { + return (uint8_t) (((uint8_t)-1)*(((((uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0]))); + } + } + break; + case 2: + if (8 * sizeof(uint8_t) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) - 1 > 2 * PyLong_SHIFT) { + return (uint8_t) ((((((uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0]))); + } + } + break; + case -3: + if (8 * sizeof(uint8_t) - 1 > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) - 1 > 3 * PyLong_SHIFT) { + return (uint8_t) (((uint8_t)-1)*(((((((uint8_t)digits[2]) << PyLong_SHIFT) | (uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0]))); + } + } + break; + case 3: + if (8 * sizeof(uint8_t) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) - 1 > 3 * PyLong_SHIFT) { + return (uint8_t) ((((((((uint8_t)digits[2]) << PyLong_SHIFT) | (uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0]))); + } + } + break; + case -4: + if (8 * sizeof(uint8_t) - 1 > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) - 1 > 4 * PyLong_SHIFT) { + return (uint8_t) (((uint8_t)-1)*(((((((((uint8_t)digits[3]) << PyLong_SHIFT) | (uint8_t)digits[2]) << PyLong_SHIFT) | (uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0]))); + } + } + break; + case 4: + if (8 * sizeof(uint8_t) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint8_t, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint8_t) - 1 > 4 * PyLong_SHIFT) { + return (uint8_t) ((((((((((uint8_t)digits[3]) << PyLong_SHIFT) | (uint8_t)digits[2]) << PyLong_SHIFT) | (uint8_t)digits[1]) << PyLong_SHIFT) | (uint8_t)digits[0]))); + } + } + break; + } +#endif + if (sizeof(uint8_t) <= sizeof(long)) { + __PYX_VERIFY_RETURN_INT_EXC(uint8_t, long, PyLong_AsLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(uint8_t) <= sizeof(PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(uint8_t, PY_LONG_LONG, PyLong_AsLongLong(x)) +#endif + } + } + { +#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) + PyErr_SetString(PyExc_RuntimeError, + "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); +#else + uint8_t val; + PyObject *v = __Pyx_PyNumber_IntOrLong(x); + #if PY_MAJOR_VERSION < 3 + if (likely(v) && !PyLong_Check(v)) { + PyObject *tmp = v; + v = PyNumber_Long(tmp); + Py_DECREF(tmp); + } + #endif + if (likely(v)) { + int one = 1; int is_little = (int)*(unsigned char *)&one; + unsigned char *bytes = (unsigned char *)&val; + int ret = _PyLong_AsByteArray((PyLongObject *)v, + bytes, sizeof(val), + is_little, !is_unsigned); + Py_DECREF(v); + if (likely(!ret)) + return val; + } +#endif + return (uint8_t) -1; + } + } else { + uint8_t val; + PyObject *tmp = __Pyx_PyNumber_IntOrLong(x); + if (!tmp) return (uint8_t) -1; + val = __Pyx_PyInt_As_uint8_t(tmp); + Py_DECREF(tmp); + return val; + } +raise_overflow: + PyErr_SetString(PyExc_OverflowError, + "value too large to convert to uint8_t"); + return (uint8_t) -1; +raise_neg_overflow: + PyErr_SetString(PyExc_OverflowError, + "can't convert negative value to uint8_t"); + return (uint8_t) -1; +} + +/* CIntFromPy */ +static CYTHON_INLINE uint64_t __Pyx_PyInt_As_uint64_t(PyObject *x) { + const uint64_t neg_one = (uint64_t) ((uint64_t) 0 - (uint64_t) 1), const_zero = (uint64_t) 0; + const int is_unsigned = neg_one > const_zero; +#if PY_MAJOR_VERSION < 3 + if (likely(PyInt_Check(x))) { + if (sizeof(uint64_t) < sizeof(long)) { + __PYX_VERIFY_RETURN_INT(uint64_t, long, PyInt_AS_LONG(x)) + } else { + long val = PyInt_AS_LONG(x); + if (is_unsigned && unlikely(val < 0)) { + goto raise_neg_overflow; + } + return (uint64_t) val; + } + } else +#endif + if (likely(PyLong_Check(x))) { + if (is_unsigned) { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (uint64_t) 0; + case 1: __PYX_VERIFY_RETURN_INT(uint64_t, digit, digits[0]) + case 2: + if (8 * sizeof(uint64_t) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) >= 2 * PyLong_SHIFT) { + return (uint64_t) (((((uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0])); + } + } + break; + case 3: + if (8 * sizeof(uint64_t) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) >= 3 * PyLong_SHIFT) { + return (uint64_t) (((((((uint64_t)digits[2]) << PyLong_SHIFT) | (uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0])); + } + } + break; + case 4: + if (8 * sizeof(uint64_t) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) >= 4 * PyLong_SHIFT) { + return (uint64_t) (((((((((uint64_t)digits[3]) << PyLong_SHIFT) | (uint64_t)digits[2]) << PyLong_SHIFT) | (uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0])); + } + } + break; + } +#endif +#if CYTHON_COMPILING_IN_CPYTHON + if (unlikely(Py_SIZE(x) < 0)) { + goto raise_neg_overflow; + } +#else + { + int result = PyObject_RichCompareBool(x, Py_False, Py_LT); + if (unlikely(result < 0)) + return (uint64_t) -1; + if (unlikely(result == 1)) + goto raise_neg_overflow; + } +#endif + if (sizeof(uint64_t) <= sizeof(unsigned long)) { + __PYX_VERIFY_RETURN_INT_EXC(uint64_t, unsigned long, PyLong_AsUnsignedLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(uint64_t) <= sizeof(unsigned PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(uint64_t, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) +#endif + } + } else { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (uint64_t) 0; + case -1: __PYX_VERIFY_RETURN_INT(uint64_t, sdigit, (sdigit) (-(sdigit)digits[0])) + case 1: __PYX_VERIFY_RETURN_INT(uint64_t, digit, +digits[0]) + case -2: + if (8 * sizeof(uint64_t) - 1 > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) - 1 > 2 * PyLong_SHIFT) { + return (uint64_t) (((uint64_t)-1)*(((((uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0]))); + } + } + break; + case 2: + if (8 * sizeof(uint64_t) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) - 1 > 2 * PyLong_SHIFT) { + return (uint64_t) ((((((uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0]))); + } + } + break; + case -3: + if (8 * sizeof(uint64_t) - 1 > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) - 1 > 3 * PyLong_SHIFT) { + return (uint64_t) (((uint64_t)-1)*(((((((uint64_t)digits[2]) << PyLong_SHIFT) | (uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0]))); + } + } + break; + case 3: + if (8 * sizeof(uint64_t) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) - 1 > 3 * PyLong_SHIFT) { + return (uint64_t) ((((((((uint64_t)digits[2]) << PyLong_SHIFT) | (uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0]))); + } + } + break; + case -4: + if (8 * sizeof(uint64_t) - 1 > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) - 1 > 4 * PyLong_SHIFT) { + return (uint64_t) (((uint64_t)-1)*(((((((((uint64_t)digits[3]) << PyLong_SHIFT) | (uint64_t)digits[2]) << PyLong_SHIFT) | (uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0]))); + } + } + break; + case 4: + if (8 * sizeof(uint64_t) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(uint64_t, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(uint64_t) - 1 > 4 * PyLong_SHIFT) { + return (uint64_t) ((((((((((uint64_t)digits[3]) << PyLong_SHIFT) | (uint64_t)digits[2]) << PyLong_SHIFT) | (uint64_t)digits[1]) << PyLong_SHIFT) | (uint64_t)digits[0]))); + } + } + break; + } +#endif + if (sizeof(uint64_t) <= sizeof(long)) { + __PYX_VERIFY_RETURN_INT_EXC(uint64_t, long, PyLong_AsLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(uint64_t) <= sizeof(PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(uint64_t, PY_LONG_LONG, PyLong_AsLongLong(x)) +#endif + } + } + { +#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) + PyErr_SetString(PyExc_RuntimeError, + "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); +#else + uint64_t val; + PyObject *v = __Pyx_PyNumber_IntOrLong(x); + #if PY_MAJOR_VERSION < 3 + if (likely(v) && !PyLong_Check(v)) { + PyObject *tmp = v; + v = PyNumber_Long(tmp); + Py_DECREF(tmp); + } + #endif + if (likely(v)) { + int one = 1; int is_little = (int)*(unsigned char *)&one; + unsigned char *bytes = (unsigned char *)&val; + int ret = _PyLong_AsByteArray((PyLongObject *)v, + bytes, sizeof(val), + is_little, !is_unsigned); + Py_DECREF(v); + if (likely(!ret)) + return val; + } +#endif + return (uint64_t) -1; + } + } else { + uint64_t val; + PyObject *tmp = __Pyx_PyNumber_IntOrLong(x); + if (!tmp) return (uint64_t) -1; + val = __Pyx_PyInt_As_uint64_t(tmp); + Py_DECREF(tmp); + return val; + } +raise_overflow: + PyErr_SetString(PyExc_OverflowError, + "value too large to convert to uint64_t"); + return (uint64_t) -1; +raise_neg_overflow: + PyErr_SetString(PyExc_OverflowError, + "can't convert negative value to uint64_t"); + return (uint64_t) -1; +} + +/* CIntFromPy */ +static CYTHON_INLINE long __Pyx_PyInt_As_long(PyObject *x) { + const long neg_one = (long) ((long) 0 - (long) 1), const_zero = (long) 0; + const int is_unsigned = neg_one > const_zero; +#if PY_MAJOR_VERSION < 3 + if (likely(PyInt_Check(x))) { + if (sizeof(long) < sizeof(long)) { + __PYX_VERIFY_RETURN_INT(long, long, PyInt_AS_LONG(x)) + } else { + long val = PyInt_AS_LONG(x); + if (is_unsigned && unlikely(val < 0)) { + goto raise_neg_overflow; + } + return (long) val; + } + } else +#endif + if (likely(PyLong_Check(x))) { + if (is_unsigned) { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (long) 0; + case 1: __PYX_VERIFY_RETURN_INT(long, digit, digits[0]) + case 2: + if (8 * sizeof(long) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) >= 2 * PyLong_SHIFT) { + return (long) (((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); + } + } + break; + case 3: + if (8 * sizeof(long) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) >= 3 * PyLong_SHIFT) { + return (long) (((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); + } + } + break; + case 4: + if (8 * sizeof(long) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) >= 4 * PyLong_SHIFT) { + return (long) (((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0])); + } + } + break; + } +#endif +#if CYTHON_COMPILING_IN_CPYTHON + if (unlikely(Py_SIZE(x) < 0)) { + goto raise_neg_overflow; + } +#else + { + int result = PyObject_RichCompareBool(x, Py_False, Py_LT); + if (unlikely(result < 0)) + return (long) -1; + if (unlikely(result == 1)) + goto raise_neg_overflow; + } +#endif + if (sizeof(long) <= sizeof(unsigned long)) { + __PYX_VERIFY_RETURN_INT_EXC(long, unsigned long, PyLong_AsUnsignedLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(long) <= sizeof(unsigned PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(long, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) +#endif + } + } else { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (long) 0; + case -1: __PYX_VERIFY_RETURN_INT(long, sdigit, (sdigit) (-(sdigit)digits[0])) + case 1: __PYX_VERIFY_RETURN_INT(long, digit, +digits[0]) + case -2: + if (8 * sizeof(long) - 1 > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { + return (long) (((long)-1)*(((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); + } + } + break; + case 2: + if (8 * sizeof(long) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { + return (long) ((((((long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); + } + } + break; + case -3: + if (8 * sizeof(long) - 1 > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { + return (long) (((long)-1)*(((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); + } + } + break; + case 3: + if (8 * sizeof(long) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { + return (long) ((((((((long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); + } + } + break; + case -4: + if (8 * sizeof(long) - 1 > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) { + return (long) (((long)-1)*(((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); + } + } + break; + case 4: + if (8 * sizeof(long) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(long, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(long) - 1 > 4 * PyLong_SHIFT) { + return (long) ((((((((((long)digits[3]) << PyLong_SHIFT) | (long)digits[2]) << PyLong_SHIFT) | (long)digits[1]) << PyLong_SHIFT) | (long)digits[0]))); + } + } + break; + } +#endif + if (sizeof(long) <= sizeof(long)) { + __PYX_VERIFY_RETURN_INT_EXC(long, long, PyLong_AsLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(long, PY_LONG_LONG, PyLong_AsLongLong(x)) +#endif + } + } + { +#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) + PyErr_SetString(PyExc_RuntimeError, + "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); +#else + long val; + PyObject *v = __Pyx_PyNumber_IntOrLong(x); + #if PY_MAJOR_VERSION < 3 + if (likely(v) && !PyLong_Check(v)) { + PyObject *tmp = v; + v = PyNumber_Long(tmp); + Py_DECREF(tmp); + } + #endif + if (likely(v)) { + int one = 1; int is_little = (int)*(unsigned char *)&one; + unsigned char *bytes = (unsigned char *)&val; + int ret = _PyLong_AsByteArray((PyLongObject *)v, + bytes, sizeof(val), + is_little, !is_unsigned); + Py_DECREF(v); + if (likely(!ret)) + return val; + } +#endif + return (long) -1; + } + } else { + long val; + PyObject *tmp = __Pyx_PyNumber_IntOrLong(x); + if (!tmp) return (long) -1; + val = __Pyx_PyInt_As_long(tmp); + Py_DECREF(tmp); + return val; + } +raise_overflow: + PyErr_SetString(PyExc_OverflowError, + "value too large to convert to long"); + return (long) -1; +raise_neg_overflow: + PyErr_SetString(PyExc_OverflowError, + "can't convert negative value to long"); + return (long) -1; +} + +/* CIntFromPy */ +static CYTHON_INLINE int __Pyx_PyInt_As_int(PyObject *x) { + const int neg_one = (int) ((int) 0 - (int) 1), const_zero = (int) 0; + const int is_unsigned = neg_one > const_zero; +#if PY_MAJOR_VERSION < 3 + if (likely(PyInt_Check(x))) { + if (sizeof(int) < sizeof(long)) { + __PYX_VERIFY_RETURN_INT(int, long, PyInt_AS_LONG(x)) + } else { + long val = PyInt_AS_LONG(x); + if (is_unsigned && unlikely(val < 0)) { + goto raise_neg_overflow; + } + return (int) val; + } + } else +#endif + if (likely(PyLong_Check(x))) { + if (is_unsigned) { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (int) 0; + case 1: __PYX_VERIFY_RETURN_INT(int, digit, digits[0]) + case 2: + if (8 * sizeof(int) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) >= 2 * PyLong_SHIFT) { + return (int) (((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); + } + } + break; + case 3: + if (8 * sizeof(int) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) >= 3 * PyLong_SHIFT) { + return (int) (((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); + } + } + break; + case 4: + if (8 * sizeof(int) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) >= 4 * PyLong_SHIFT) { + return (int) (((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0])); + } + } + break; + } +#endif +#if CYTHON_COMPILING_IN_CPYTHON + if (unlikely(Py_SIZE(x) < 0)) { + goto raise_neg_overflow; + } +#else + { + int result = PyObject_RichCompareBool(x, Py_False, Py_LT); + if (unlikely(result < 0)) + return (int) -1; + if (unlikely(result == 1)) + goto raise_neg_overflow; + } +#endif + if (sizeof(int) <= sizeof(unsigned long)) { + __PYX_VERIFY_RETURN_INT_EXC(int, unsigned long, PyLong_AsUnsignedLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(int) <= sizeof(unsigned PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(int, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) +#endif + } + } else { +#if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)x)->ob_digit; + switch (Py_SIZE(x)) { + case 0: return (int) 0; + case -1: __PYX_VERIFY_RETURN_INT(int, sdigit, (sdigit) (-(sdigit)digits[0])) + case 1: __PYX_VERIFY_RETURN_INT(int, digit, +digits[0]) + case -2: + if (8 * sizeof(int) - 1 > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) - 1 > 2 * PyLong_SHIFT) { + return (int) (((int)-1)*(((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); + } + } + break; + case 2: + if (8 * sizeof(int) > 1 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 2 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) - 1 > 2 * PyLong_SHIFT) { + return (int) ((((((int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); + } + } + break; + case -3: + if (8 * sizeof(int) - 1 > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) - 1 > 3 * PyLong_SHIFT) { + return (int) (((int)-1)*(((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); + } + } + break; + case 3: + if (8 * sizeof(int) > 2 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 3 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) - 1 > 3 * PyLong_SHIFT) { + return (int) ((((((((int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); + } + } + break; + case -4: + if (8 * sizeof(int) - 1 > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, long, -(long) (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) - 1 > 4 * PyLong_SHIFT) { + return (int) (((int)-1)*(((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); + } + } + break; + case 4: + if (8 * sizeof(int) > 3 * PyLong_SHIFT) { + if (8 * sizeof(unsigned long) > 4 * PyLong_SHIFT) { + __PYX_VERIFY_RETURN_INT(int, unsigned long, (((((((((unsigned long)digits[3]) << PyLong_SHIFT) | (unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) + } else if (8 * sizeof(int) - 1 > 4 * PyLong_SHIFT) { + return (int) ((((((((((int)digits[3]) << PyLong_SHIFT) | (int)digits[2]) << PyLong_SHIFT) | (int)digits[1]) << PyLong_SHIFT) | (int)digits[0]))); + } + } + break; + } +#endif + if (sizeof(int) <= sizeof(long)) { + __PYX_VERIFY_RETURN_INT_EXC(int, long, PyLong_AsLong(x)) +#ifdef HAVE_LONG_LONG + } else if (sizeof(int) <= sizeof(PY_LONG_LONG)) { + __PYX_VERIFY_RETURN_INT_EXC(int, PY_LONG_LONG, PyLong_AsLongLong(x)) +#endif + } + } + { +#if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) + PyErr_SetString(PyExc_RuntimeError, + "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); +#else + int val; + PyObject *v = __Pyx_PyNumber_IntOrLong(x); + #if PY_MAJOR_VERSION < 3 + if (likely(v) && !PyLong_Check(v)) { + PyObject *tmp = v; + v = PyNumber_Long(tmp); + Py_DECREF(tmp); + } + #endif + if (likely(v)) { + int one = 1; int is_little = (int)*(unsigned char *)&one; + unsigned char *bytes = (unsigned char *)&val; + int ret = _PyLong_AsByteArray((PyLongObject *)v, + bytes, sizeof(val), + is_little, !is_unsigned); + Py_DECREF(v); + if (likely(!ret)) + return val; + } +#endif + return (int) -1; + } + } else { + int val; + PyObject *tmp = __Pyx_PyNumber_IntOrLong(x); + if (!tmp) return (int) -1; + val = __Pyx_PyInt_As_int(tmp); + Py_DECREF(tmp); + return val; + } +raise_overflow: + PyErr_SetString(PyExc_OverflowError, + "value too large to convert to int"); + return (int) -1; +raise_neg_overflow: + PyErr_SetString(PyExc_OverflowError, + "can't convert negative value to int"); + return (int) -1; +} + +/* FastTypeChecks */ +#if CYTHON_COMPILING_IN_CPYTHON +static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) { + while (a) { + a = a->tp_base; + if (a == b) + return 1; + } + return b == &PyBaseObject_Type; +} +static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b) { + PyObject *mro; + if (a == b) return 1; + mro = a->tp_mro; + if (likely(mro)) { + Py_ssize_t i, n; + n = PyTuple_GET_SIZE(mro); + for (i = 0; i < n; i++) { + if (PyTuple_GET_ITEM(mro, i) == (PyObject *)b) + return 1; + } + return 0; + } + return __Pyx_InBases(a, b); +} +#if PY_MAJOR_VERSION == 2 +static int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject* exc_type2) { + PyObject *exception, *value, *tb; + int res; + __Pyx_PyThreadState_declare + __Pyx_PyThreadState_assign + __Pyx_ErrFetch(&exception, &value, &tb); + res = exc_type1 ? PyObject_IsSubclass(err, exc_type1) : 0; + if (unlikely(res == -1)) { + PyErr_WriteUnraisable(err); + res = 0; + } + if (!res) { + res = PyObject_IsSubclass(err, exc_type2); + if (unlikely(res == -1)) { + PyErr_WriteUnraisable(err); + res = 0; + } + } + __Pyx_ErrRestore(exception, value, tb); + return res; +} +#else +static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) { + int res = exc_type1 ? __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type1) : 0; + if (!res) { + res = __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2); + } + return res; +} +#endif +static int __Pyx_PyErr_GivenExceptionMatchesTuple(PyObject *exc_type, PyObject *tuple) { + Py_ssize_t i, n; + assert(PyExceptionClass_Check(exc_type)); + n = PyTuple_GET_SIZE(tuple); +#if PY_MAJOR_VERSION >= 3 + for (i=0; i<n; i++) { + if (exc_type == PyTuple_GET_ITEM(tuple, i)) return 1; + } +#endif + for (i=0; i<n; i++) { + PyObject *t = PyTuple_GET_ITEM(tuple, i); + #if PY_MAJOR_VERSION < 3 + if (likely(exc_type == t)) return 1; + #endif + if (likely(PyExceptionClass_Check(t))) { + if (__Pyx_inner_PyErr_GivenExceptionMatches2(exc_type, NULL, t)) return 1; + } else { + } + } + return 0; +} +static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches(PyObject *err, PyObject* exc_type) { + if (likely(err == exc_type)) return 1; + if (likely(PyExceptionClass_Check(err))) { + if (likely(PyExceptionClass_Check(exc_type))) { + return __Pyx_inner_PyErr_GivenExceptionMatches2(err, NULL, exc_type); + } else if (likely(PyTuple_Check(exc_type))) { + return __Pyx_PyErr_GivenExceptionMatchesTuple(err, exc_type); + } else { + } + } + return PyErr_GivenExceptionMatches(err, exc_type); +} +static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *exc_type1, PyObject *exc_type2) { + assert(PyExceptionClass_Check(exc_type1)); + assert(PyExceptionClass_Check(exc_type2)); + if (likely(err == exc_type1 || err == exc_type2)) return 1; + if (likely(PyExceptionClass_Check(err))) { + return __Pyx_inner_PyErr_GivenExceptionMatches2(err, exc_type1, exc_type2); + } + return (PyErr_GivenExceptionMatches(err, exc_type1) || PyErr_GivenExceptionMatches(err, exc_type2)); +} +#endif + +/* CheckBinaryVersion */ +static int __Pyx_check_binary_version(void) { + char ctversion[4], rtversion[4]; + PyOS_snprintf(ctversion, 4, "%d.%d", PY_MAJOR_VERSION, PY_MINOR_VERSION); + PyOS_snprintf(rtversion, 4, "%s", Py_GetVersion()); + if (ctversion[0] != rtversion[0] || ctversion[2] != rtversion[2]) { + char message[200]; + PyOS_snprintf(message, sizeof(message), + "compiletime version %s of module '%.100s' " + "does not match runtime version %s", + ctversion, __Pyx_MODULE_NAME, rtversion); + return PyErr_WarnEx(NULL, message, 1); + } + return 0; +} + +/* InitStrings */ +static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) { + while (t->p) { + #if PY_MAJOR_VERSION < 3 + if (t->is_unicode) { + *t->p = PyUnicode_DecodeUTF8(t->s, t->n - 1, NULL); + } else if (t->intern) { + *t->p = PyString_InternFromString(t->s); + } else { + *t->p = PyString_FromStringAndSize(t->s, t->n - 1); + } + #else + if (t->is_unicode | t->is_str) { + if (t->intern) { + *t->p = PyUnicode_InternFromString(t->s); + } else if (t->encoding) { + *t->p = PyUnicode_Decode(t->s, t->n - 1, t->encoding, NULL); + } else { + *t->p = PyUnicode_FromStringAndSize(t->s, t->n - 1); + } + } else { + *t->p = PyBytes_FromStringAndSize(t->s, t->n - 1); + } + #endif + if (!*t->p) + return -1; + if (PyObject_Hash(*t->p) == -1) + return -1; + ++t; + } + return 0; +} + +static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) { + return __Pyx_PyUnicode_FromStringAndSize(c_str, (Py_ssize_t)strlen(c_str)); +} +static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject* o) { + Py_ssize_t ignore; + return __Pyx_PyObject_AsStringAndSize(o, &ignore); +} +#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT +#if !CYTHON_PEP393_ENABLED +static const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) { + char* defenc_c; + PyObject* defenc = _PyUnicode_AsDefaultEncodedString(o, NULL); + if (!defenc) return NULL; + defenc_c = PyBytes_AS_STRING(defenc); +#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII + { + char* end = defenc_c + PyBytes_GET_SIZE(defenc); + char* c; + for (c = defenc_c; c < end; c++) { + if ((unsigned char) (*c) >= 128) { + PyUnicode_AsASCIIString(o); + return NULL; + } + } + } +#endif + *length = PyBytes_GET_SIZE(defenc); + return defenc_c; +} +#else +static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) { + if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL; +#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII + if (likely(PyUnicode_IS_ASCII(o))) { + *length = PyUnicode_GET_LENGTH(o); + return PyUnicode_AsUTF8(o); + } else { + PyUnicode_AsASCIIString(o); + return NULL; + } +#else + return PyUnicode_AsUTF8AndSize(o, length); +#endif +} +#endif +#endif +static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject* o, Py_ssize_t *length) { +#if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII || __PYX_DEFAULT_STRING_ENCODING_IS_DEFAULT + if ( +#if PY_MAJOR_VERSION < 3 && __PYX_DEFAULT_STRING_ENCODING_IS_ASCII + __Pyx_sys_getdefaultencoding_not_ascii && +#endif + PyUnicode_Check(o)) { + return __Pyx_PyUnicode_AsStringAndSize(o, length); + } else +#endif +#if (!CYTHON_COMPILING_IN_PYPY) || (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE)) + if (PyByteArray_Check(o)) { + *length = PyByteArray_GET_SIZE(o); + return PyByteArray_AS_STRING(o); + } else +#endif + { + char* result; + int r = PyBytes_AsStringAndSize(o, &result, length); + if (unlikely(r < 0)) { + return NULL; + } else { + return result; + } + } +} +static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject* x) { + int is_true = x == Py_True; + if (is_true | (x == Py_False) | (x == Py_None)) return is_true; + else return PyObject_IsTrue(x); +} +static CYTHON_INLINE int __Pyx_PyObject_IsTrueAndDecref(PyObject* x) { + int retval; + if (unlikely(!x)) return -1; + retval = __Pyx_PyObject_IsTrue(x); + Py_DECREF(x); + return retval; +} +static PyObject* __Pyx_PyNumber_IntOrLongWrongResultType(PyObject* result, const char* type_name) { +#if PY_MAJOR_VERSION >= 3 + if (PyLong_Check(result)) { + if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1, + "__int__ returned non-int (type %.200s). " + "The ability to return an instance of a strict subclass of int " + "is deprecated, and may be removed in a future version of Python.", + Py_TYPE(result)->tp_name)) { + Py_DECREF(result); + return NULL; + } + return result; + } +#endif + PyErr_Format(PyExc_TypeError, + "__%.4s__ returned non-%.4s (type %.200s)", + type_name, type_name, Py_TYPE(result)->tp_name); + Py_DECREF(result); + return NULL; +} +static CYTHON_INLINE PyObject* __Pyx_PyNumber_IntOrLong(PyObject* x) { +#if CYTHON_USE_TYPE_SLOTS + PyNumberMethods *m; +#endif + const char *name = NULL; + PyObject *res = NULL; +#if PY_MAJOR_VERSION < 3 + if (likely(PyInt_Check(x) || PyLong_Check(x))) +#else + if (likely(PyLong_Check(x))) +#endif + return __Pyx_NewRef(x); +#if CYTHON_USE_TYPE_SLOTS + m = Py_TYPE(x)->tp_as_number; + #if PY_MAJOR_VERSION < 3 + if (m && m->nb_int) { + name = "int"; + res = m->nb_int(x); + } + else if (m && m->nb_long) { + name = "long"; + res = m->nb_long(x); + } + #else + if (likely(m && m->nb_int)) { + name = "int"; + res = m->nb_int(x); + } + #endif +#else + if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) { + res = PyNumber_Int(x); + } +#endif + if (likely(res)) { +#if PY_MAJOR_VERSION < 3 + if (unlikely(!PyInt_Check(res) && !PyLong_Check(res))) { +#else + if (unlikely(!PyLong_CheckExact(res))) { +#endif + return __Pyx_PyNumber_IntOrLongWrongResultType(res, name); + } + } + else if (!PyErr_Occurred()) { + PyErr_SetString(PyExc_TypeError, + "an integer is required"); + } + return res; +} +static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject* b) { + Py_ssize_t ival; + PyObject *x; +#if PY_MAJOR_VERSION < 3 + if (likely(PyInt_CheckExact(b))) { + if (sizeof(Py_ssize_t) >= sizeof(long)) + return PyInt_AS_LONG(b); + else + return PyInt_AsSsize_t(b); + } +#endif + if (likely(PyLong_CheckExact(b))) { + #if CYTHON_USE_PYLONG_INTERNALS + const digit* digits = ((PyLongObject*)b)->ob_digit; + const Py_ssize_t size = Py_SIZE(b); + if (likely(__Pyx_sst_abs(size) <= 1)) { + ival = likely(size) ? digits[0] : 0; + if (size == -1) ival = -ival; + return ival; + } else { + switch (size) { + case 2: + if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { + return (Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); + } + break; + case -2: + if (8 * sizeof(Py_ssize_t) > 2 * PyLong_SHIFT) { + return -(Py_ssize_t) (((((size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); + } + break; + case 3: + if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { + return (Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); + } + break; + case -3: + if (8 * sizeof(Py_ssize_t) > 3 * PyLong_SHIFT) { + return -(Py_ssize_t) (((((((size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); + } + break; + case 4: + if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { + return (Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); + } + break; + case -4: + if (8 * sizeof(Py_ssize_t) > 4 * PyLong_SHIFT) { + return -(Py_ssize_t) (((((((((size_t)digits[3]) << PyLong_SHIFT) | (size_t)digits[2]) << PyLong_SHIFT) | (size_t)digits[1]) << PyLong_SHIFT) | (size_t)digits[0])); + } + break; + } + } + #endif + return PyLong_AsSsize_t(b); + } + x = PyNumber_Index(b); + if (!x) return -1; + ival = PyInt_AsSsize_t(x); + Py_DECREF(x); + return ival; +} +static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b) { + return b ? __Pyx_NewRef(Py_True) : __Pyx_NewRef(Py_False); +} +static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t ival) { + return PyInt_FromSize_t(ival); +} + + +#endif /* Py_PYTHON_H */ diff --git a/venv/Lib/site-packages/yarl/_quoting_c.cp38-win_amd64.pyd b/venv/Lib/site-packages/yarl/_quoting_c.cp38-win_amd64.pyd new file mode 100644 index 0000000000000000000000000000000000000000..01cea3ac8073f5c7aeb0a3ebb168724ce259ac60 GIT binary patch literal 84480 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 BA5s7S literal 0 HcmV?d00001 diff --git a/venv/Lib/site-packages/yarl/_quoting_c.pyi b/venv/Lib/site-packages/yarl/_quoting_c.pyi new file mode 100644 index 0000000..4e6a35d --- /dev/null +++ b/venv/Lib/site-packages/yarl/_quoting_c.pyi @@ -0,0 +1,16 @@ +from typing import Optional + +class _Quoter: + def __init__( + self, + *, + safe: str = ..., + protected: str = ..., + qs: bool = ..., + requote: bool = ... + ) -> None: ... + def __call__(self, val: Optional[str] = ...) -> Optional[str]: ... + +class _Unquoter: + def __init__(self, *, unsafe: str = ..., qs: bool = ...) -> None: ... + def __call__(self, val: Optional[str] = ...) -> Optional[str]: ... diff --git a/venv/Lib/site-packages/yarl/_quoting_c.pyx b/venv/Lib/site-packages/yarl/_quoting_c.pyx new file mode 100644 index 0000000..2f12b8e --- /dev/null +++ b/venv/Lib/site-packages/yarl/_quoting_c.pyx @@ -0,0 +1,394 @@ +# cython: language_level=3 + +from libc.stdint cimport uint8_t, uint64_t +from libc.string cimport memcpy, memset + +from cpython.exc cimport PyErr_NoMemory +from cpython.mem cimport PyMem_Malloc, PyMem_Realloc, PyMem_Free +from cpython.unicode cimport PyUnicode_DecodeASCII + +from string import ascii_letters, digits + +cdef str GEN_DELIMS = ":/?#[]@" +cdef str SUB_DELIMS_WITHOUT_QS = "!$'()*," +cdef str SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + '+?=;' +cdef str RESERVED = GEN_DELIMS + SUB_DELIMS +cdef str UNRESERVED = ascii_letters + digits + '-._~' +cdef str ALLOWED = UNRESERVED + SUB_DELIMS_WITHOUT_QS +cdef str QS = '+&=;' + +DEF BUF_SIZE = 8 * 1024 # 8KiB +cdef char BUFFER[BUF_SIZE] + + +cdef inline Py_UCS4 _to_hex(uint8_t v): + if v < 10: + return <Py_UCS4>(v+0x30) # ord('0') == 0x30 + else: + return <Py_UCS4>(v+0x41-10) # ord('A') == 0x41 + + +cdef inline int _from_hex(Py_UCS4 v): + if '0' <= v <= '9': + return <int>(v) - 0x30 # ord('0') == 0x30 + elif 'A' <= v <= 'F': + return <int>(v) - 0x41 + 10 # ord('A') == 0x41 + elif 'a' <= v <= 'f': + return <int>(v) - 0x61 + 10 # ord('a') == 0x61 + else: + return -1 + + +cdef inline Py_UCS4 _restore_ch(Py_UCS4 d1, Py_UCS4 d2): + cdef int digit1 = _from_hex(d1) + if digit1 < 0: + return <Py_UCS4>-1 + cdef int digit2 = _from_hex(d2) + if digit2 < 0: + return <Py_UCS4>-1 + return <Py_UCS4>(digit1 << 4 | digit2) + + +cdef uint8_t ALLOWED_TABLE[16] +cdef uint8_t ALLOWED_NOTQS_TABLE[16] + + +cdef inline bint bit_at(uint8_t array[], uint64_t ch): + return array[ch >> 3] & (1 << (ch & 7)) + + +cdef inline void set_bit(uint8_t array[], uint64_t ch): + array[ch >> 3] |= (1 << (ch & 7)) + + +memset(ALLOWED_TABLE, 0, sizeof(ALLOWED_TABLE)) +memset(ALLOWED_NOTQS_TABLE, 0, sizeof(ALLOWED_NOTQS_TABLE)) + +for i in range(128): + if chr(i) in ALLOWED: + set_bit(ALLOWED_TABLE, i) + set_bit(ALLOWED_NOTQS_TABLE, i) + if chr(i) in QS: + set_bit(ALLOWED_NOTQS_TABLE, i) + +# ----------------- writer --------------------------- + +cdef struct Writer: + char *buf + Py_ssize_t size + Py_ssize_t pos + bint changed + + +cdef inline void _init_writer(Writer* writer): + writer.buf = &BUFFER[0] + writer.size = BUF_SIZE + writer.pos = 0 + writer.changed = 0 + + +cdef inline void _release_writer(Writer* writer): + if writer.buf != BUFFER: + PyMem_Free(writer.buf) + + +cdef inline int _write_char(Writer* writer, Py_UCS4 ch, bint changed): + cdef char * buf + cdef Py_ssize_t size + + if writer.pos == writer.size: + # reallocate + size = writer.size + BUF_SIZE + if writer.buf == BUFFER: + buf = <char*>PyMem_Malloc(size) + if buf == NULL: + PyErr_NoMemory() + return -1 + memcpy(buf, writer.buf, writer.size) + else: + buf = <char*>PyMem_Realloc(writer.buf, size) + if buf == NULL: + PyErr_NoMemory() + return -1 + writer.buf = buf + writer.size = size + writer.buf[writer.pos] = <char>ch + writer.pos += 1 + writer.changed |= changed + return 0 + + +cdef inline int _write_pct(Writer* writer, uint8_t ch, bint changed): + if _write_char(writer, '%', changed) < 0: + return -1 + if _write_char(writer, _to_hex(<uint8_t>ch >> 4), changed) < 0: + return -1 + return _write_char(writer, _to_hex(<uint8_t>ch & 0x0f), changed) + + +cdef inline int _write_percent(Writer* writer): + if _write_char(writer, '%', True) < 0: + return -1 + if _write_char(writer, '2', True) < 0: + return -1 + return _write_char(writer, '5', True) + + +cdef inline int _write_pct_check(Writer* writer, Py_UCS4 ch, Py_UCS4 pct[]): + cdef Py_UCS4 pct1 = _to_hex(<uint8_t>ch >> 4) + cdef Py_UCS4 pct2 = _to_hex(<uint8_t>ch & 0x0f) + cdef bint changed = pct[0] != pct1 or pct[1] != pct2 + + if _write_char(writer, '%', changed) < 0: + return -1 + if _write_char(writer, pct1, changed) < 0: + return -1 + return _write_char(writer, pct2, changed) + + +cdef inline int _write_utf8(Writer* writer, Py_UCS4 symbol): + cdef uint64_t utf = <uint64_t> symbol + + if utf < 0x80: + return _write_pct(writer, <uint8_t>utf, True) + elif utf < 0x800: + if _write_pct(writer, <uint8_t>(0xc0 | (utf >> 6)), True) < 0: + return -1 + return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + elif 0xD800 <= utf <= 0xDFFF: + # surogate pair, ignored + return 0 + elif utf < 0x10000: + if _write_pct(writer, <uint8_t>(0xe0 | (utf >> 12)), True) < 0: + return -1 + if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + True) < 0: + return -1 + return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + elif utf > 0x10FFFF: + # symbol is too large + return 0 + else: + if _write_pct(writer, <uint8_t>(0xf0 | (utf >> 18)), True) < 0: + return -1 + if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 12) & 0x3f)), + True) < 0: + return -1 + if _write_pct(writer, <uint8_t>(0x80 | ((utf >> 6) & 0x3f)), + True) < 0: + return -1 + return _write_pct(writer, <uint8_t>(0x80 | (utf & 0x3f)), True) + + +# --------------------- end writer -------------------------- + + +cdef class _Quoter: + cdef bint _qs + cdef bint _requote + + cdef uint8_t _safe_table[16] + cdef uint8_t _protected_table[16] + + def __init__( + self, *, str safe='', str protected='', bint qs=False, bint requote=True, + ): + cdef Py_UCS4 ch + + self._qs = qs + self._requote = requote + + if not self._qs: + memcpy(self._safe_table, + ALLOWED_NOTQS_TABLE, + sizeof(self._safe_table)) + else: + memcpy(self._safe_table, + ALLOWED_TABLE, + sizeof(self._safe_table)) + for ch in safe: + if ord(ch) > 127: + raise ValueError("Only safe symbols with ORD < 128 are allowed") + set_bit(self._safe_table, ch) + + memset(self._protected_table, 0, sizeof(self._protected_table)) + for ch in protected: + if ord(ch) > 127: + raise ValueError("Only safe symbols with ORD < 128 are allowed") + set_bit(self._safe_table, ch) + set_bit(self._protected_table, ch) + + def __call__(self, val): + cdef Writer writer + if val is None: + return None + if type(val) is not str: + if isinstance(val, str): + # derived from str + val = str(val) + else: + raise TypeError("Argument should be str") + _init_writer(&writer) + try: + return self._do_quote(<str>val, &writer) + finally: + _release_writer(&writer) + + cdef str _do_quote(self, str val, Writer *writer): + cdef Py_UCS4 ch + cdef int has_pct = 0 + cdef Py_UCS4 pct[2] + cdef int idx = 0 + + for ch in val: + if has_pct: + pct[has_pct-1] = ch + has_pct += 1 + if has_pct == 3: + ch = _restore_ch(pct[0], pct[1]) + has_pct = 0 + + if ch == <Py_UCS4>-1: + if _write_percent(writer) < 0: + raise + if self._write(writer, pct[0]) < 0: + raise + if self._write(writer, pct[1]) < 0: + raise + continue + + if ch < 128: + if bit_at(self._protected_table, ch): + if _write_pct(writer, ch, True) < 0: + raise + continue + + if bit_at(self._safe_table, ch): + if _write_char(writer, ch, True) < 0: + raise + continue + + if _write_pct_check(writer, ch, pct) < 0: + raise + continue + + elif ch == '%' and self._requote: + has_pct = 1 + continue + + if self._write(writer, ch) < 0: + raise + + if has_pct: + if _write_percent(writer) < 0: + raise + if has_pct > 1: # the value is 2 + if self._write(writer, ch) < 0: + raise + + if not writer.changed: + return val + else: + return PyUnicode_DecodeASCII(writer.buf, writer.pos, "strict") + + cdef inline int _write(self, Writer *writer, Py_UCS4 ch): + if self._qs: + if ch == ' ': + return _write_char(writer, '+', True) + + if ch < 128 and bit_at(self._safe_table, ch): + return _write_char(writer, ch, False) + + return _write_utf8(writer, ch) + + +cdef class _Unquoter: + cdef str _unsafe + cdef bint _qs + cdef _Quoter _quoter + cdef _Quoter _qs_quoter + + def __init__(self, *, unsafe='', qs=False): + self._unsafe = unsafe + self._qs = qs + self._quoter = _Quoter() + self._qs_quoter = _Quoter(qs=True) + + def __call__(self, val): + if val is None: + return None + if type(val) is not str: + if isinstance(val, str): + # derived from str + val = str(val) + else: + raise TypeError("Argument should be str") + return self._do_unquote(<str>val) + + cdef str _do_unquote(self, str val): + if len(val) == 0: + return val + cdef str pct = '' + cdef str last_pct = '' + cdef bytearray pcts = bytearray() + cdef list ret = [] + cdef str unquoted + for ch in val: + if pct: + pct += ch + if len(pct) == 3: # pragma: no branch # peephole optimizer + pcts.append(int(pct[1:], base=16)) + last_pct = pct + pct = '' + continue + if pcts: + try: + unquoted = pcts.decode('utf8') + except UnicodeDecodeError: + pass + else: + if self._qs and unquoted in '+=&;': + ret.append(self._qs_quoter(unquoted)) + elif unquoted in self._unsafe: + ret.append(self._quoter(unquoted)) + else: + ret.append(unquoted) + del pcts[:] + + if ch == '%': + pct = ch + continue + + if pcts: + ret.append(last_pct) # %F8ab + last_pct = '' + + if ch == '+': + if not self._qs or ch in self._unsafe: + ret.append('+') + else: + ret.append(' ') + continue + + if ch in self._unsafe: + ret.append('%') + h = hex(ord(ch)).upper()[2:] + for ch in h: + ret.append(ch) + continue + + ret.append(ch) + + if pcts: + try: + unquoted = pcts.decode('utf8') + except UnicodeDecodeError: + ret.append(last_pct) # %F8 + else: + if self._qs and unquoted in '+=&;': + ret.append(self._qs_quoter(unquoted)) + elif unquoted in self._unsafe: + ret.append(self._quoter(unquoted)) + else: + ret.append(unquoted) + return ''.join(ret) diff --git a/venv/Lib/site-packages/yarl/_quoting_py.py b/venv/Lib/site-packages/yarl/_quoting_py.py new file mode 100644 index 0000000..be68b78 --- /dev/null +++ b/venv/Lib/site-packages/yarl/_quoting_py.py @@ -0,0 +1,206 @@ +import re +from string import ascii_letters, ascii_lowercase, digits +from typing import Optional, cast + + +BASCII_LOWERCASE = ascii_lowercase.encode("ascii") +BPCT_ALLOWED = {"%{:02X}".format(i).encode("ascii") for i in range(256)} +GEN_DELIMS = ":/?#[]@" +SUB_DELIMS_WITHOUT_QS = "!$'()*," +SUB_DELIMS = SUB_DELIMS_WITHOUT_QS + "+&=;" +RESERVED = GEN_DELIMS + SUB_DELIMS +UNRESERVED = ascii_letters + digits + "-._~" +ALLOWED = UNRESERVED + SUB_DELIMS_WITHOUT_QS + + +_IS_HEX = re.compile(b"[A-Z0-9][A-Z0-9]") + + +class _Quoter: + def __init__( + self, + *, + safe: str = "", + protected: str = "", + qs: bool = False, + requote: bool = True + ) -> None: + self._safe = safe + self._protected = protected + self._qs = qs + self._requote = requote + + def __call__(self, val: Optional[str]) -> Optional[str]: + if val is None: + return None + if not isinstance(val, str): + raise TypeError("Argument should be str") + if not val: + return "" + bval = cast(str, val).encode("utf8", errors="ignore") + ret = bytearray() + pct = bytearray() + safe = self._safe + safe += ALLOWED + if not self._qs: + safe += "+&=;" + safe += self._protected + bsafe = safe.encode("ascii") + idx = 0 + while idx < len(bval): + ch = bval[idx] + idx += 1 + + if pct: + if ch in BASCII_LOWERCASE: + ch = ch - 32 # convert to uppercase + pct.append(ch) + if len(pct) == 3: # pragma: no branch # peephole optimizer + buf = pct[1:] + if not _IS_HEX.match(buf): + ret.extend(b"%25") + pct.clear() + idx -= 2 + continue + try: + unquoted = chr(int(pct[1:].decode("ascii"), base=16)) + except ValueError: + ret.extend(b"%25") + pct.clear() + idx -= 2 + continue + + if unquoted in self._protected: + ret.extend(pct) + elif unquoted in safe: + ret.append(ord(unquoted)) + else: + ret.extend(pct) + pct.clear() + + # special case, if we have only one char after "%" + elif len(pct) == 2 and idx == len(bval): + ret.extend(b"%25") + pct.clear() + idx -= 1 + + continue + + elif ch == ord("%") and self._requote: + pct.clear() + pct.append(ch) + + # special case if "%" is last char + if idx == len(bval): + ret.extend(b"%25") + + continue + + if self._qs: + if ch == ord(" "): + ret.append(ord("+")) + continue + if ch in bsafe: + ret.append(ch) + continue + + ret.extend(("%{:02X}".format(ch)).encode("ascii")) + + ret2 = ret.decode("ascii") + if ret2 == val: + return val + return ret2 + + +class _Unquoter: + def __init__(self, *, unsafe: str = "", qs: bool = False) -> None: + self._unsafe = unsafe + self._qs = qs + self._quoter = _Quoter() + self._qs_quoter = _Quoter(qs=True) + + def __call__(self, val: Optional[str]) -> Optional[str]: + if val is None: + return None + if not isinstance(val, str): + raise TypeError("Argument should be str") + if not val: + return "" + pct = "" + last_pct = "" + pcts = bytearray() + ret = [] + for ch in val: + if pct: + pct += ch + if len(pct) == 3: # pragma: no branch # peephole optimizer + pcts.append(int(pct[1:], base=16)) + last_pct = pct + pct = "" + continue + if pcts: + try: + unquoted = pcts.decode("utf8") + except UnicodeDecodeError: + pass + else: + if self._qs and unquoted in "+=&;": + to_add = self._qs_quoter(unquoted) + if to_add is None: # pragma: no cover + raise RuntimeError("Cannot quote None") + ret.append(to_add) + elif unquoted in self._unsafe: + to_add = self._quoter(unquoted) + if to_add is None: # pragma: no cover + raise RuntimeError("Cannot quote None") + ret.append(to_add) + else: + ret.append(unquoted) + del pcts[:] + + if ch == "%": + pct = ch + continue + + if pcts: + ret.append(last_pct) # %F8ab + last_pct = "" + + if ch == "+": + if not self._qs or ch in self._unsafe: + ret.append("+") + else: + ret.append(" ") + continue + + if ch in self._unsafe: + ret.append("%") + h = hex(ord(ch)).upper()[2:] + for ch in h: + ret.append(ch) + continue + + ret.append(ch) + + if pcts: + try: + unquoted = pcts.decode("utf8") + except UnicodeDecodeError: + ret.append(last_pct) # %F8 + else: + if self._qs and unquoted in "+=&;": + to_add = self._qs_quoter(unquoted) + if to_add is None: # pragma: no cover + raise RuntimeError("Cannot quote None") + ret.append(to_add) + elif unquoted in self._unsafe: + to_add = self._qs_quoter(unquoted) + if to_add is None: # pragma: no cover + raise RuntimeError("Cannot quote None") + ret.append(to_add) + else: + ret.append(unquoted) + ret2 = "".join(ret) + if ret2 == val: + return val + return ret2 diff --git a/venv/Lib/site-packages/yarl/_url.py b/venv/Lib/site-packages/yarl/_url.py new file mode 100644 index 0000000..61688ce --- /dev/null +++ b/venv/Lib/site-packages/yarl/_url.py @@ -0,0 +1,1106 @@ +import functools +import sys +import warnings +from collections.abc import Mapping, Sequence +from ipaddress import ip_address +from urllib.parse import SplitResult, parse_qsl, urljoin, urlsplit, urlunsplit + +from multidict import MultiDict, MultiDictProxy +import idna + + +from ._quoting import _Quoter, _Unquoter + + +DEFAULT_PORTS = {"http": 80, "https": 443, "ws": 80, "wss": 443} + +sentinel = object() + + +def rewrite_module(obj: object) -> object: + obj.__module__ = "yarl" + return obj + + +class cached_property: + """Use as a class method decorator. It operates almost exactly like + the Python `@property` decorator, but it puts the result of the + method it decorates into the instance dict after the first call, + effectively replacing the function it decorates with an instance + variable. It is, in Python parlance, a data descriptor. + + """ + + def __init__(self, wrapped): + self.wrapped = wrapped + try: + self.__doc__ = wrapped.__doc__ + except AttributeError: # pragma: no cover + self.__doc__ = "" + self.name = wrapped.__name__ + + def __get__(self, inst, owner, _sentinel=sentinel): + if inst is None: + return self + val = inst._cache.get(self.name, _sentinel) + if val is not _sentinel: + return val + val = self.wrapped(inst) + inst._cache[self.name] = val + return val + + def __set__(self, inst, value): + raise AttributeError("cached property is read-only") + + +@rewrite_module +class URL: + # Don't derive from str + # follow pathlib.Path design + # probably URL will not suffer from pathlib problems: + # it's intended for libraries like aiohttp, + # not to be passed into standard library functions like os.open etc. + + # URL grammar (RFC 3986) + # pct-encoded = "%" HEXDIG HEXDIG + # reserved = gen-delims / sub-delims + # gen-delims = ":" / "/" / "?" / "#" / "[" / "]" / "@" + # sub-delims = "!" / "$" / "&" / "'" / "(" / ")" + # / "*" / "+" / "," / ";" / "=" + # unreserved = ALPHA / DIGIT / "-" / "." / "_" / "~" + # URI = scheme ":" hier-part [ "?" query ] [ "#" fragment ] + # hier-part = "//" authority path-abempty + # / path-absolute + # / path-rootless + # / path-empty + # scheme = ALPHA *( ALPHA / DIGIT / "+" / "-" / "." ) + # authority = [ userinfo "@" ] host [ ":" port ] + # userinfo = *( unreserved / pct-encoded / sub-delims / ":" ) + # host = IP-literal / IPv4address / reg-name + # IP-literal = "[" ( IPv6address / IPvFuture ) "]" + # IPvFuture = "v" 1*HEXDIG "." 1*( unreserved / sub-delims / ":" ) + # IPv6address = 6( h16 ":" ) ls32 + # / "::" 5( h16 ":" ) ls32 + # / [ h16 ] "::" 4( h16 ":" ) ls32 + # / [ *1( h16 ":" ) h16 ] "::" 3( h16 ":" ) ls32 + # / [ *2( h16 ":" ) h16 ] "::" 2( h16 ":" ) ls32 + # / [ *3( h16 ":" ) h16 ] "::" h16 ":" ls32 + # / [ *4( h16 ":" ) h16 ] "::" ls32 + # / [ *5( h16 ":" ) h16 ] "::" h16 + # / [ *6( h16 ":" ) h16 ] "::" + # ls32 = ( h16 ":" h16 ) / IPv4address + # ; least-significant 32 bits of address + # h16 = 1*4HEXDIG + # ; 16 bits of address represented in hexadecimal + # IPv4address = dec-octet "." dec-octet "." dec-octet "." dec-octet + # dec-octet = DIGIT ; 0-9 + # / %x31-39 DIGIT ; 10-99 + # / "1" 2DIGIT ; 100-199 + # / "2" %x30-34 DIGIT ; 200-249 + # / "25" %x30-35 ; 250-255 + # reg-name = *( unreserved / pct-encoded / sub-delims ) + # port = *DIGIT + # path = path-abempty ; begins with "/" or is empty + # / path-absolute ; begins with "/" but not "//" + # / path-noscheme ; begins with a non-colon segment + # / path-rootless ; begins with a segment + # / path-empty ; zero characters + # path-abempty = *( "/" segment ) + # path-absolute = "/" [ segment-nz *( "/" segment ) ] + # path-noscheme = segment-nz-nc *( "/" segment ) + # path-rootless = segment-nz *( "/" segment ) + # path-empty = 0<pchar> + # segment = *pchar + # segment-nz = 1*pchar + # segment-nz-nc = 1*( unreserved / pct-encoded / sub-delims / "@" ) + # ; non-zero-length segment without any colon ":" + # pchar = unreserved / pct-encoded / sub-delims / ":" / "@" + # query = *( pchar / "/" / "?" ) + # fragment = *( pchar / "/" / "?" ) + # URI-reference = URI / relative-ref + # relative-ref = relative-part [ "?" query ] [ "#" fragment ] + # relative-part = "//" authority path-abempty + # / path-absolute + # / path-noscheme + # / path-empty + # absolute-URI = scheme ":" hier-part [ "?" query ] + __slots__ = ("_cache", "_val") + + _QUOTER = _Quoter() + _PATH_QUOTER = _Quoter(safe="@:", protected="/+") + _QUERY_QUOTER = _Quoter(safe="?/:@", protected="=+&;", qs=True) + _QUERY_PART_QUOTER = _Quoter(safe="?/:@", qs=True, requote=False) + _FRAGMENT_QUOTER = _Quoter(safe="?/:@") + + _UNQUOTER = _Unquoter() + _PATH_UNQUOTER = _Unquoter(unsafe="+") + _QS_UNQUOTER = _Unquoter(qs=True) + + def __new__(cls, val="", *, encoded=False, strict=None): + if strict is not None: # pragma: no cover + warnings.warn("strict parameter is ignored") + if type(val) is cls: + return val + if type(val) is str: + val = urlsplit(val) + elif type(val) is SplitResult: + if not encoded: + raise ValueError("Cannot apply decoding to SplitResult") + elif isinstance(val, str): + val = urlsplit(str(val)) + else: + raise TypeError("Constructor parameter should be str") + + if not encoded: + if not val[1]: # netloc + netloc = "" + host = "" + else: + host = val.hostname + if host is None: + raise ValueError("Invalid URL: host is required for absolute urls") + + try: + port = val.port + except ValueError as e: + raise ValueError( + "Invalid URL: port can't be converted to integer" + ) from e + + netloc = cls._make_netloc( + val.username, val.password, host, port, encode=True + ) + path = cls._PATH_QUOTER(val[2]) + if netloc: + path = cls._normalize_path(path) + + cls._validate_authority_uri_abs_path(host=host, path=path) + query = cls._QUERY_QUOTER(val[3]) + fragment = cls._FRAGMENT_QUOTER(val[4]) + val = SplitResult(val[0], netloc, path, query, fragment) + + self = object.__new__(cls) + self._val = val + self._cache = {} + return self + + @classmethod + def build( + cls, + *, + scheme="", + authority="", + user=None, + password=None, + host="", + port=None, + path="", + query=None, + query_string="", + fragment="", + encoded=False + ): + """Creates and returns a new URL""" + + if authority and (user or password or host or port): + raise ValueError( + 'Can\'t mix "authority" with "user", "password", "host" or "port".' + ) + if port and not host: + raise ValueError('Can\'t build URL with "port" but without "host".') + if query and query_string: + raise ValueError('Only one of "query" or "query_string" should be passed') + if ( + scheme is None + or authority is None + or path is None + or query_string is None + or fragment is None + ): + raise TypeError( + 'NoneType is illegal for "scheme", "authority", "path", ' + '"query_string", and "fragment" args, use empty string instead.' + ) + + if authority: + if encoded: + netloc = authority + else: + tmp = SplitResult("", authority, "", "", "") + netloc = cls._make_netloc( + tmp.username, tmp.password, tmp.hostname, tmp.port, encode=True + ) + elif not user and not password and not host and not port: + netloc = "" + else: + netloc = cls._make_netloc(user, password, host, port, encode=not encoded) + if not encoded: + path = cls._PATH_QUOTER(path) + if netloc: + path = cls._normalize_path(path) + + cls._validate_authority_uri_abs_path(host=host, path=path) + query_string = cls._QUERY_QUOTER(query_string) + fragment = cls._FRAGMENT_QUOTER(fragment) + + url = cls( + SplitResult(scheme, netloc, path, query_string, fragment), encoded=True + ) + + if query: + return url.with_query(query) + else: + return url + + def __init_subclass__(cls): + raise TypeError("Inheritance a class {!r} from URL is forbidden".format(cls)) + + def __str__(self): + val = self._val + if not val.path and self.is_absolute() and (val.query or val.fragment): + val = val._replace(path="/") + return urlunsplit(val) + + def __repr__(self): + return "{}('{}')".format(self.__class__.__name__, str(self)) + + def __eq__(self, other): + if not type(other) is URL: + return NotImplemented + + val1 = self._val + if not val1.path and self.is_absolute(): + val1 = val1._replace(path="/") + + val2 = other._val + if not val2.path and other.is_absolute(): + val2 = val2._replace(path="/") + + return val1 == val2 + + def __hash__(self): + ret = self._cache.get("hash") + if ret is None: + val = self._val + if not val.path and self.is_absolute(): + val = val._replace(path="/") + ret = self._cache["hash"] = hash(val) + return ret + + def __le__(self, other): + if not type(other) is URL: + return NotImplemented + return self._val <= other._val + + def __lt__(self, other): + if not type(other) is URL: + return NotImplemented + return self._val < other._val + + def __ge__(self, other): + if not type(other) is URL: + return NotImplemented + return self._val >= other._val + + def __gt__(self, other): + if not type(other) is URL: + return NotImplemented + return self._val > other._val + + def __truediv__(self, name): + name = self._PATH_QUOTER(name) + if name.startswith("/"): + raise ValueError( + "Appending path {!r} starting from slash is forbidden".format(name) + ) + path = self._val.path + if path == "/": + new_path = "/" + name + elif not path and not self.is_absolute(): + new_path = name + else: + parts = path.rstrip("/").split("/") + parts.append(name) + new_path = "/".join(parts) + if self.is_absolute(): + new_path = self._normalize_path(new_path) + return URL( + self._val._replace(path=new_path, query="", fragment=""), encoded=True + ) + + def __mod__(self, query): + return self.update_query(query) + + def __bool__(self) -> bool: + return bool( + self._val.netloc or self._val.path or self._val.query or self._val.fragment + ) + + def __getstate__(self): + return (self._val,) + + def __setstate__(self, state): + if state[0] is None and isinstance(state[1], dict): + # default style pickle + self._val = state[1]["_val"] + else: + self._val, *unused = state + self._cache = {} + + def is_absolute(self): + """A check for absolute URLs. + + Return True for absolute ones (having scheme or starting + with //), False otherwise. + + """ + return self.raw_host is not None + + def is_default_port(self): + """A check for default port. + + Return True if port is default for specified scheme, + e.g. 'http://python.org' or 'http://python.org:80', False + otherwise. + + """ + if self.port is None: + return False + default = DEFAULT_PORTS.get(self.scheme) + if default is None: + return False + return self.port == default + + def origin(self): + """Return an URL with scheme, host and port parts only. + + user, password, path, query and fragment are removed. + + """ + # TODO: add a keyword-only option for keeping user/pass maybe? + if not self.is_absolute(): + raise ValueError("URL should be absolute") + if not self._val.scheme: + raise ValueError("URL should have scheme") + v = self._val + netloc = self._make_netloc(None, None, v.hostname, v.port, encode=False) + val = v._replace(netloc=netloc, path="", query="", fragment="") + return URL(val, encoded=True) + + def relative(self): + """Return a relative part of the URL. + + scheme, user, password, host and port are removed. + + """ + if not self.is_absolute(): + raise ValueError("URL should be absolute") + val = self._val._replace(scheme="", netloc="") + return URL(val, encoded=True) + + @property + def scheme(self): + """Scheme for absolute URLs. + + Empty string for relative URLs or URLs starting with // + + """ + return self._val.scheme + + @property + def raw_authority(self): + """Encoded authority part of URL. + + Empty string for relative URLs. + + """ + return self._val.netloc + + @cached_property + def authority(self): + """Decoded authority part of URL. + + Empty string for relative URLs. + + """ + return self._make_netloc( + self.user, self.password, self.host, self.port, encode=False + ) + + @property + def raw_user(self): + """Encoded user part of URL. + + None if user is missing. + + """ + # not .username + ret = self._val.username + if not ret: + return None + return ret + + @cached_property + def user(self): + """Decoded user part of URL. + + None if user is missing. + + """ + return self._UNQUOTER(self.raw_user) + + @property + def raw_password(self): + """Encoded password part of URL. + + None if password is missing. + + """ + return self._val.password + + @cached_property + def password(self): + """Decoded password part of URL. + + None if password is missing. + + """ + return self._UNQUOTER(self.raw_password) + + @property + def raw_host(self): + """Encoded host part of URL. + + None for relative URLs. + + """ + # Use host instead of hostname for sake of shortness + # May add .hostname prop later + return self._val.hostname + + @cached_property + def host(self): + """Decoded host part of URL. + + None for relative URLs. + + """ + raw = self.raw_host + if raw is None: + return None + if "%" in raw: + # Hack for scoped IPv6 addresses like + # fe80::2%Проверка + # presence of '%' sign means only IPv6 address, so idna is useless. + return raw + return _idna_decode(raw) + + @property + def port(self): + """Port part of URL, with scheme-based fallback. + + None for relative URLs or URLs without explicit port and + scheme without default port substitution. + + """ + return self._val.port or DEFAULT_PORTS.get(self._val.scheme) + + @property + def explicit_port(self): + """Port part of URL, without scheme-based fallback. + + None for relative URLs or URLs without explicit port. + + """ + return self._val.port + + @property + def raw_path(self): + """Encoded path of URL. + + / for absolute URLs without path part. + + """ + ret = self._val.path + if not ret and self.is_absolute(): + ret = "/" + return ret + + @cached_property + def path(self): + """Decoded path of URL. + + / for absolute URLs without path part. + + """ + return self._PATH_UNQUOTER(self.raw_path) + + @cached_property + def query(self): + """A MultiDictProxy representing parsed query parameters in decoded + representation. + + Empty value if URL has no query part. + + """ + ret = MultiDict(parse_qsl(self.raw_query_string, keep_blank_values=True)) + return MultiDictProxy(ret) + + @property + def raw_query_string(self): + """Encoded query part of URL. + + Empty string if query is missing. + + """ + return self._val.query + + @cached_property + def query_string(self): + """Decoded query part of URL. + + Empty string if query is missing. + + """ + return self._QS_UNQUOTER(self.raw_query_string) + + @cached_property + def path_qs(self): + """Decoded path of URL with query.""" + if not self.query_string: + return self.path + return "{}?{}".format(self.path, self.query_string) + + @cached_property + def raw_path_qs(self): + """Encoded path of URL with query.""" + if not self.raw_query_string: + return self.raw_path + return "{}?{}".format(self.raw_path, self.raw_query_string) + + @property + def raw_fragment(self): + """Encoded fragment part of URL. + + Empty string if fragment is missing. + + """ + return self._val.fragment + + @cached_property + def fragment(self): + """Decoded fragment part of URL. + + Empty string if fragment is missing. + + """ + return self._UNQUOTER(self.raw_fragment) + + @cached_property + def raw_parts(self): + """A tuple containing encoded *path* parts. + + ('/',) for absolute URLs if *path* is missing. + + """ + path = self._val.path + if self.is_absolute(): + if not path: + parts = ["/"] + else: + parts = ["/"] + path[1:].split("/") + else: + if path.startswith("/"): + parts = ["/"] + path[1:].split("/") + else: + parts = path.split("/") + return tuple(parts) + + @cached_property + def parts(self): + """A tuple containing decoded *path* parts. + + ('/',) for absolute URLs if *path* is missing. + + """ + return tuple(self._UNQUOTER(part) for part in self.raw_parts) + + @cached_property + def parent(self): + """A new URL with last part of path removed and cleaned up query and + fragment. + + """ + path = self.raw_path + if not path or path == "/": + if self.raw_fragment or self.raw_query_string: + return URL(self._val._replace(query="", fragment=""), encoded=True) + return self + parts = path.split("/") + val = self._val._replace(path="/".join(parts[:-1]), query="", fragment="") + return URL(val, encoded=True) + + @cached_property + def raw_name(self): + """The last part of raw_parts.""" + parts = self.raw_parts + if self.is_absolute(): + parts = parts[1:] + if not parts: + return "" + else: + return parts[-1] + else: + return parts[-1] + + @cached_property + def name(self): + """The last part of parts.""" + return self._UNQUOTER(self.raw_name) + + @staticmethod + def _validate_authority_uri_abs_path(host, path): + """Ensure that path in URL with authority starts with a leading slash. + + Raise ValueError if not. + """ + if len(host) > 0 and len(path) > 0 and not path.startswith("/"): + raise ValueError( + "Path in a URL with authority should start with a slash ('/') if set" + ) + + @classmethod + def _normalize_path(cls, path): + # Drop '.' and '..' from path + + segments = path.split("/") + resolved_path = [] + + for seg in segments: + if seg == "..": + try: + resolved_path.pop() + except IndexError: + # ignore any .. segments that would otherwise cause an + # IndexError when popped from resolved_path if + # resolving for rfc3986 + pass + elif seg == ".": + continue + else: + resolved_path.append(seg) + + if segments[-1] in (".", ".."): + # do some post-processing here. + # if the last segment was a relative dir, + # then we need to append the trailing '/' + resolved_path.append("") + + return "/".join(resolved_path) + + if sys.version_info >= (3, 7): + + @classmethod + def _encode_host(cls, host): + try: + ip, sep, zone = host.partition("%") + ip = ip_address(ip) + except ValueError: + host = host.lower() + # IDNA encoding is slow, + # skip it for ASCII-only strings + # Don't move the check into _idna_encode() helper + # to reduce the cache size + if host.isascii(): + return host + host = _idna_encode(host) + else: + host = ip.compressed + if sep: + host += "%" + zone + if ip.version == 6: + host = "[" + host + "]" + return host + + else: + # work around for missing str.isascii() in Python <= 3.6 + @classmethod + def _encode_host(cls, host): + try: + ip, sep, zone = host.partition("%") + ip = ip_address(ip) + except ValueError: + host = host.lower() + + for char in host: + if char > "\x7f": + break + else: + return host + host = _idna_encode(host) + else: + host = ip.compressed + if sep: + host += "%" + zone + if ip.version == 6: + host = "[" + host + "]" + return host + + @classmethod + def _make_netloc(cls, user, password, host, port, encode): + if encode: + ret = cls._encode_host(host) + else: + ret = host + if port: + ret = ret + ":" + str(port) + if password is not None: + if not user: + user = "" + else: + if encode: + user = cls._QUOTER(user) + if encode: + password = cls._QUOTER(password) + user = user + ":" + password + elif user and encode: + user = cls._QUOTER(user) + if user: + ret = user + "@" + ret + return ret + + def with_scheme(self, scheme): + """Return a new URL with scheme replaced.""" + # N.B. doesn't cleanup query/fragment + if not isinstance(scheme, str): + raise TypeError("Invalid scheme type") + if not self.is_absolute(): + raise ValueError("scheme replacement is not allowed for relative URLs") + return URL(self._val._replace(scheme=scheme.lower()), encoded=True) + + def with_user(self, user): + """Return a new URL with user replaced. + + Autoencode user if needed. + + Clear user/password if user is None. + + """ + # N.B. doesn't cleanup query/fragment + val = self._val + if user is None: + password = None + elif isinstance(user, str): + user = self._QUOTER(user) + password = val.password + else: + raise TypeError("Invalid user type") + if not self.is_absolute(): + raise ValueError("user replacement is not allowed for relative URLs") + return URL( + self._val._replace( + netloc=self._make_netloc( + user, password, val.hostname, val.port, encode=True + ) + ), + encoded=True, + ) + + def with_password(self, password): + """Return a new URL with password replaced. + + Autoencode password if needed. + + Clear password if argument is None. + + """ + # N.B. doesn't cleanup query/fragment + if password is None: + pass + elif isinstance(password, str): + password = self._QUOTER(password) + else: + raise TypeError("Invalid password type") + if not self.is_absolute(): + raise ValueError("password replacement is not allowed for relative URLs") + val = self._val + return URL( + self._val._replace( + netloc=self._make_netloc( + val.username, password, val.hostname, val.port, encode=True + ) + ), + encoded=True, + ) + + def with_host(self, host): + """Return a new URL with host replaced. + + Autoencode host if needed. + + Changing host for relative URLs is not allowed, use .join() + instead. + + """ + # N.B. doesn't cleanup query/fragment + if not isinstance(host, str): + raise TypeError("Invalid host type") + if not self.is_absolute(): + raise ValueError("host replacement is not allowed for relative URLs") + if not host: + raise ValueError("host removing is not allowed") + host = self._encode_host(host) + val = self._val + return URL( + self._val._replace( + netloc=self._make_netloc( + val.username, val.password, host, val.port, encode=False + ) + ), + encoded=True, + ) + + def with_port(self, port): + """Return a new URL with port replaced. + + Clear port to default if None is passed. + + """ + # N.B. doesn't cleanup query/fragment + if port is not None and not isinstance(port, int): + raise TypeError("port should be int or None, got {}".format(type(port))) + if not self.is_absolute(): + raise ValueError("port replacement is not allowed for relative URLs") + val = self._val + return URL( + self._val._replace( + netloc=self._make_netloc( + val.username, val.password, val.hostname, port, encode=True + ) + ), + encoded=True, + ) + + def with_path(self, path, *, encoded=False): + """Return a new URL with path replaced.""" + if not encoded: + path = self._PATH_QUOTER(path) + if self.is_absolute(): + path = self._normalize_path(path) + if len(path) > 0 and path[0] != "/": + path = "/" + path + return URL(self._val._replace(path=path, query="", fragment=""), encoded=True) + + @classmethod + def _query_seq_pairs(cls, quoter, pairs): + for key, val in pairs: + if isinstance(val, (list, tuple)): + for v in val: + yield quoter(key) + "=" + quoter(cls._query_var(v)) + else: + yield quoter(key) + "=" + quoter(cls._query_var(val)) + + @staticmethod + def _query_var(v): + if isinstance(v, str): + return v + if type(v) is int: # no subclasses like bool + return str(v) + raise TypeError( + "Invalid variable type: value " + "should be str or int, got {!r} " + "of type {}".format(v, type(v)) + ) + + def _get_str_query(self, *args, **kwargs): + if kwargs: + if len(args) > 0: + raise ValueError( + "Either kwargs or single query parameter must be present" + ) + query = kwargs + elif len(args) == 1: + query = args[0] + else: + raise ValueError("Either kwargs or single query parameter must be present") + + if query is None: + query = "" + elif isinstance(query, Mapping): + quoter = self._QUERY_PART_QUOTER + query = "&".join(self._query_seq_pairs(quoter, query.items())) + elif isinstance(query, str): + query = self._QUERY_QUOTER(query) + elif isinstance(query, (bytes, bytearray, memoryview)): + raise TypeError( + "Invalid query type: bytes, bytearray and memoryview are forbidden" + ) + elif isinstance(query, Sequence): + quoter = self._QUERY_PART_QUOTER + # We don't expect sequence values if we're given a list of pairs + # already; only mappings like builtin `dict` which can't have the + # same key pointing to multiple values are allowed to use + # `_query_seq_pairs`. + query = "&".join( + quoter(k) + "=" + quoter(self._query_var(v)) for k, v in query + ) + else: + raise TypeError( + "Invalid query type: only str, mapping or " + "sequence of (key, value) pairs is allowed" + ) + + return query + + def with_query(self, *args, **kwargs): + """Return a new URL with query part replaced. + + Accepts any Mapping (e.g. dict, multidict.MultiDict instances) + or str, autoencode the argument if needed. + + A sequence of (key, value) pairs is supported as well. + + It also can take an arbitrary number of keyword arguments. + + Clear query if None is passed. + + """ + # N.B. doesn't cleanup query/fragment + + new_query = self._get_str_query(*args, **kwargs) + return URL( + self._val._replace(path=self._val.path, query=new_query), encoded=True + ) + + def update_query(self, *args, **kwargs): + """Return a new URL with query part updated.""" + s = self._get_str_query(*args, **kwargs) + new_query = MultiDict(parse_qsl(s, keep_blank_values=True)) + query = MultiDict(self.query) + query.update(new_query) + + return URL(self._val._replace(query=self._get_str_query(query)), encoded=True) + + def with_fragment(self, fragment): + """Return a new URL with fragment replaced. + + Autoencode fragment if needed. + + Clear fragment to default if None is passed. + + """ + # N.B. doesn't cleanup query/fragment + if fragment is None: + raw_fragment = "" + elif not isinstance(fragment, str): + raise TypeError("Invalid fragment type") + else: + raw_fragment = self._FRAGMENT_QUOTER(fragment) + if self.raw_fragment == raw_fragment: + return self + return URL(self._val._replace(fragment=raw_fragment), encoded=True) + + def with_name(self, name): + """Return a new URL with name (last part of path) replaced. + + Query and fragment parts are cleaned up. + + Name is encoded if needed. + + """ + # N.B. DOES cleanup query/fragment + if not isinstance(name, str): + raise TypeError("Invalid name type") + if "/" in name: + raise ValueError("Slash in name is not allowed") + name = self._PATH_QUOTER(name) + if name in (".", ".."): + raise ValueError(". and .. values are forbidden") + parts = list(self.raw_parts) + if self.is_absolute(): + if len(parts) == 1: + parts.append(name) + else: + parts[-1] = name + parts[0] = "" # replace leading '/' + else: + parts[-1] = name + if parts[0] == "/": + parts[0] = "" # replace leading '/' + return URL( + self._val._replace(path="/".join(parts), query="", fragment=""), + encoded=True, + ) + + def join(self, url): + """Join URLs + + Construct a full (“absoluteâ€) URL by combining a “base URL†+ (self) with another URL (url). + + Informally, this uses components of the base URL, in + particular the addressing scheme, the network location and + (part of) the path, to provide missing components in the + relative URL. + + """ + # See docs for urllib.parse.urljoin + if not isinstance(url, URL): + raise TypeError("url should be URL") + return URL(urljoin(str(self), str(url)), encoded=True) + + def human_repr(self): + """Return decoded human readable string for URL representation.""" + + return urlunsplit( + SplitResult( + self.scheme, + self._make_netloc( + self.user, self.password, self.host, self._val.port, encode=False + ), + self.path, + self.query_string, + self.fragment, + ) + ) + + +_MAXCACHE = 256 + + +@functools.lru_cache(_MAXCACHE) +def _idna_decode(raw): + try: + return idna.decode(raw.encode("ascii")) + except UnicodeError: # e.g. '::1' + return raw.encode("ascii").decode("idna") + + +@functools.lru_cache(_MAXCACHE) +def _idna_encode(host): + try: + return idna.encode(host, uts46=True).decode("ascii") + except UnicodeError: + return host.encode("idna").decode("ascii") + + +@rewrite_module +def cache_clear(): + _idna_decode.cache_clear() + _idna_encode.cache_clear() + + +@rewrite_module +def cache_info(): + return { + "idna_encode": _idna_encode.cache_info(), + "idna_decode": _idna_decode.cache_info(), + } + + +@rewrite_module +def cache_configure(*, idna_encode_size=_MAXCACHE, idna_decode_size=_MAXCACHE): + global _idna_decode, _idna_encode + + _idna_encode = functools.lru_cache(idna_encode_size)(_idna_encode.__wrapped__) + _idna_decode = functools.lru_cache(idna_decode_size)(_idna_decode.__wrapped__) diff --git a/venv/Lib/site-packages/yarl/py.typed b/venv/Lib/site-packages/yarl/py.typed new file mode 100644 index 0000000..867e2c8 --- /dev/null +++ b/venv/Lib/site-packages/yarl/py.typed @@ -0,0 +1 @@ +# Placeholder \ No newline at end of file -- GitLab