pax_global_header00006660000000000000000000000064151741747530014530gustar00rootroot0000000000000052 comment=6be6a733932ebda4b5c1d1b0b2e4776eeb32c297 inveniosoftware-contrib-intbitset-91de683/000077500000000000000000000000001517417475300207605ustar00rootroot00000000000000inveniosoftware-contrib-intbitset-91de683/.github/000077500000000000000000000000001517417475300223205ustar00rootroot00000000000000inveniosoftware-contrib-intbitset-91de683/.github/workflows/000077500000000000000000000000001517417475300243555ustar00rootroot00000000000000inveniosoftware-contrib-intbitset-91de683/.github/workflows/pypi-release.yml000066400000000000000000000132001517417475300274730ustar00rootroot00000000000000 # Derived in part from https://github.com/google/brotli-wheels # # Copyright (c) 2009, 2010, 2013-2016 by the Brotli Authors. # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal # in the Software without restriction, including without limitation the rights # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN # THE SOFTWARE. name: Create library release archives, create a GH release and publish PyPI wheel and sdist on tag push on: workflow_dispatch: push: tags: - "v*.*.*" permissions: {} jobs: build-wheels: name: Build unicode wheels ${{ matrix.type }} ${{ matrix.arch }} on ${{ matrix.os }} runs-on: ${{ matrix.os }} defaults: run: shell: bash strategy: fail-fast: false matrix: os: [macos-latest, windows-latest] arch: [auto64] build: ["cp{310,311,312,313,314}-*"] include: - os: ubuntu-latest arch: auto64 type: manylinux2014 build: "cp{310,311,312,313,314}-*" CIBW_MANYLINUX_X86_64_IMAGE: manylinux2014 - os: ubuntu-24.04-arm arch: aarch64 build: "cp{310,311,312,313,314}-*" CIBW_MANYLINUX_AARCH64_IMAGE: manylinux2014 - os: macos-latest arch: universal2 build: "cp{310,311,312,313,314}-*" - os: windows-latest arch: auto64 build: "cp{310,311,312,313,314}-*" steps: - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd with: persist-credentials: false - name: Build wheels and run tests uses: pypa/cibuildwheel@8d2b08b68458a16aeb24b64e68a09ab1c8e82084 env: CIBW_BUILD: ${{ matrix.build }} CIBW_MANYLINUX_X86_64_IMAGE: ${{ matrix.CIBW_MANYLINUX_X86_64_IMAGE }} CIBW_MANYLINUX_AARCH64_IMAGE: ${{ matrix.CIBW_MANYLINUX_AARCH64_IMAGE }} CIBW_ARCHS: ${{ matrix.arch }} - name: Collect built wheels uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f with: name: intbitset-wheels-${{ matrix.os }}-${{ strategy.job-index }} path: ./wheelhouse/*.whl build-sdist: name: Build source distribution runs-on: ubuntu-24.04 steps: - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd with: persist-credentials: false - name: Checkout and install reqs run: | pip install --upgrade --user build twine pkginfo packaging pip setuptools cython - name: Build sdist run: | python setup.py sdist twine check dist/* - name: Collect built sdist uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f with: name: intbitset-sdist path: dist/*.tar.gz merge: runs-on: ubuntu-latest needs: [build-sdist, build-wheels] steps: - name: Merge created wheels and sdist in a single zip uses: actions/upload-artifact/merge@b7c566a772e6b6bfb58ed0dc250532a479d7789f with: name: intbitset-build pattern: intbitset-* check-dist: name: Check distributions are PyPi-correct needs: merge runs-on: ubuntu-24.04 steps: - uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 with: path: intbitset-build - run: find . -ls - run: pipx run twine check --strict intbitset-build/*/* create-gh-release: name: Create GH release needs: - check-dist runs-on: ubuntu-24.04 permissions: contents: write steps: - name: Download builds uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 with: name: intbitset-build path: intbitset-build - name: Create GH release uses: softprops/action-gh-release@b4309332981a82ec1c5618f44dd2e27cc8bfbfda with: draft: true files: intbitset-build/* create-pypi-release: name: Create PyPI release needs: - create-gh-release runs-on: ubuntu-24.04 environment: pypi-publish permissions: id-token: write steps: - name: Download builds uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 with: name: intbitset-build path: dist/ - name: Mock PyPI upload run: | ls -al dist - name: Publish to PyPI if: startsWith(github.ref, 'refs/tags') uses: pypa/gh-action-pypi-publish@cef221092ed1bacb1cc03d23a2d87d1d172e277b inveniosoftware-contrib-intbitset-91de683/.github/workflows/test-and-build.yml000066400000000000000000000132611517417475300277170ustar00rootroot00000000000000 # Derived in part from https://github.com/google/brotli-wheels # # Copyright (c) 2009, 2010, 2013-2016 by the Brotli Authors. # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal # in the Software without restriction, including without limitation the rights # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN # THE SOFTWARE. name: Run tests and build wheel and sdist on all supported OS and Python on: [push, pull_request, workflow_dispatch] permissions: {} jobs: build_wheels: name: Build wheels ${{ matrix.type }} ${{ matrix.arch }} on ${{ matrix.os }} runs-on: ${{ matrix.os }} defaults: run: shell: bash strategy: fail-fast: false matrix: os: [macos-latest, windows-latest] arch: [auto64] build: ["cp{310,311,312,313,314}-*"] include: - os: ubuntu-latest arch: auto64 type: manylinux2014 build: "cp{310,311,cp312,313,314}-*" CIBW_MANYLINUX_X86_64_IMAGE: manylinux2014 - os: ubuntu-24.04-arm arch: aarch64 build: "cp{310,311,312,313,314}-*" CIBW_MANYLINUX_AARCH64_IMAGE: manylinux2014 - os: macos-latest arch: universal2 build: "cp{310,311,312,313,314}-*" - os: windows-latest arch: auto64 build: "cp{310,311,312,313,314}-*" steps: - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd with: persist-credentials: false - name: Build wheels and run tests uses: pypa/cibuildwheel@8d2b08b68458a16aeb24b64e68a09ab1c8e82084 env: CIBW_BUILD: ${{ matrix.build }} CIBW_MANYLINUX_X86_64_IMAGE: ${{ matrix.CIBW_MANYLINUX_X86_64_IMAGE }} CIBW_MANYLINUX_AARCH64_IMAGE: ${{ matrix.CIBW_MANYLINUX_AARCH64_IMAGE }} CIBW_ARCHS: ${{ matrix.arch }} CIBW_TEST_REQUIRES: pytest pytest-xdist CIBW_TEST_COMMAND: pytest {package}/tests -n4 - name: Collect built wheels uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f with: name: intbitset-wheels-${{ matrix.os }}-${{ matrix.arch }}-${{ matrix.type }} path: wheelhouse/*.whl build_sdist: name: Build source distribution runs-on: ubuntu-24.04 steps: - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd with: persist-credentials: false - name: Checkout and install reqs run: | pip install --upgrade --user build twine pip setuptools packaging - name: Build sdist run: | python setup.py sdist twine check dist/* - name: Collect built sdist uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f with: name: intbitset-sdist path: dist/*.tar.gz merge: runs-on: ubuntu-24.04 needs: [build_sdist, build_wheels] steps: - name: Merge created wheels and sdist in a single zip uses: actions/upload-artifact/merge@b7c566a772e6b6bfb58ed0dc250532a479d7789f with: name: intbitset-build pattern: intbitset-* check_dist: name: Check distributions are PyPi-correct needs: merge runs-on: ubuntu-24.04 steps: - uses: actions/download-artifact@37930b1c2abaa49bbe596cd826c3c89aef350131 with: path: intbitset-build - run: find . -ls - run: pipx run twine check --strict intbitset-build/*/* test_on_many_oses: name: Run tests ${{ matrix.python }} on ${{ matrix.os }} runs-on: ${{ matrix.os }} defaults: run: shell: bash strategy: fail-fast: false matrix: os: [ubuntu-22.04, ubuntu-24.04, ubuntu-22.04-arm, ubuntu-24.04-arm, macos-14, macos-15, macos-15-intel, windows-2022, windows-2025] python: ["3.10", "3.11", "3.12", "3.13", "3.14"] steps: - name: Set up Python uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 with: python-version: "${{ matrix.python }}" - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd with: persist-credentials: false - name: Install run: pip install -e .[tests] - name: Run tests run: pytest -vs tests -n4 inveniosoftware-contrib-intbitset-91de683/.gitignore000066400000000000000000000001741517417475300227520ustar00rootroot00000000000000.coverage *.pyc *.egg-info dist/ build/ docs/_build/ *.so .tox *.egg *.egg-info.kdev4 *.kdev4 /.python-version /tmp/ /venv/ inveniosoftware-contrib-intbitset-91de683/AUTHORS.rst000066400000000000000000000020241517417475300226350ustar00rootroot00000000000000Authors ------- IntbitSet was originally developed for use in `Invenio `_ digital library software and is now used by several other projects as a library that need a fast integer set. Contact the current maintainer at `Philippe Ombredanne `_ Contact Invenio at `info@inveniosoftware.org `_ Contributors ^^^^^^^^^^^^ * Alessio Deiana @Osso * Andrew Mundy @mundya * Ayan Sinha Mahapatra @AyanSinhaMahapatra * Jiri Kuncar @jirikuncar * Konrad Weihmann @priv-kweihmann * Lars Holm Nielsen @lnielsen * Marco Neumann @crepererum * Maximiliano Curia @maxyz * Maximilian Teegen @max-te * Nikola Yolov @NikolaYolov * Philippe Ombredanne @pombredanne * Pierre Tardy @tardyp * Samuele Kaplun @kaplun * Steven Esser @steven-esser * Tibor Simko @tiborsimko inveniosoftware-contrib-intbitset-91de683/CHANGELOG.rst000066400000000000000000000076771517417475300230220ustar00rootroot00000000000000Changes ======= Here you can see the list of key changes between each intbitset release. Version 4.1.2 ------------------ - Fix pypi release using environments/trusted publishing Version 4.1.1 ------------------ - Also release linux arm wheels Version 4.1.0 ------------------ - Support Python 3.14 and regenerate C code accordingly - Drop support for Python 3.9 Version 4.0.0 ------------------ - Support Python 3.13 thanks to @eclipseo - Regenerate C code accordingly - Drop support for Python 3.8 Version 3.1.0 ------------------ - Support Python 3.12, macOS 12, 13 and 14 - Regenerate C code accordingly - Drop support for Python 3.7 Version 3.0.2 ------------------ - Support Python 3.11 - Regenerate C code accordingly - Drop support for Python 3.6 Thank you ~~~~~~~~~ * Ayan Sinha Mahapatra @AyanSinhaMahapatra * Konrad Weihmann @priv-kweihmann Version 3.0.1 (released 2022-03-05) ----------------------------------- - Build wheels for older Linux platforms and correct Windows and macOS versions. Version 3.0.0 (released 2022-02-23) ----------------------------------- Bug fixes and updates ~~~~~~~~~~~~~~~~~~~~~ - Allow empty generator - Behave like a set when doing comparison with other types - Regenerate C code with Cython 0.29.28 - Drop nose in favor of pytest - Drop support for Python 2.7 - Add support for Python 3.9 and 3.10 - Remove outdated Docker files - Streamline documentation - Let the compiler decide optimization and support non-X86 builds. Thank you ~~~~~~~~~ - Pierre Tardy @tardyp Version 2.4.1 (released 2020-09-23) ----------------------------------- Bug fixes and updates ~~~~~~~~~~~~~~~~~~~~~ - Allow empty generator - Regenerate C code with Cython 0.29.21 Thank you ~~~~~~~~~ - Yoan Blanc - Steven Esser Version 2.4.0 (released 2019-12-19) ----------------------------------- Thank you ~~~~~~~~~ - Maximiliano Curia - Jiri Kuncar - Andrew Murdy - Philippe Ombredanne - Tibo Simko - Max Teegen Bug fixes and updates ~~~~~~~~~~~~~~~~~~~~~ - Add support Python 3.5, 3.6, 3.7 and 3.8 and run the tests on these versions - Fix and improve isdisjoint logic and resource usage - Regenerate C code with Cython 0.29.14 Version 2.3.0 (released 2016-06-21) ----------------------------------- Bug fixes ~~~~~~~~~ - Fixes implementation of `del x[123]` operator which was wrongly defined as `__del__` rather than `__delitem__`. (#40) - Amends license reST reference from gpl to lgpl to avoid detection as GPL when scanning the docs for licensing information. Version 2.2.1 (released 2015-09-16) ----------------------------------- Bug fixes ~~~~~~~~~ - Reorganizes MANIFEST.in and adds missing files. (#28) (#29) Version 2.2.0 ------------- * Removes coverage because it is not really supported for Cython modules. * Automatically generates intbitset documentation by using Sphinx automodule functionality. * Overall, amends documentation to be compatible with reStructuredText. * Amends .update() and corresponding methods to accept also non-intbitset objects, such as lists or sets of integers respecting the set interface. * Raises TypeError rather than terminating current process with a segmentation fault when None is used on the left side of an operation with an intbitset. * Initial release of Docker configuration suitable for local developments. * No longer returns self in fastload(). * Stops using `-march=native` for compilation, because it makes the compiler to optimize the code for only the currently used processor. Version 2.1.1 ------------- * PyBytes_FromStringAndSize() fix in Python 2 Version 2.1 ----------- * Adds type checking for &, \|, etc. operators. The type of "self" was not checked. * Adds support for new union() and isdisjoint() set methods. * Updates intbitset interface to look like set built-in in Python 2.6. * Supports initialization of an intbitset from a set. * No crash when intbitset is on rhs. * Complete Python 3.x support. Version 2.0 ----------- * Packaged into a standalone git repository. inveniosoftware-contrib-intbitset-91de683/LICENSE000066400000000000000000000167431517417475300220000ustar00rootroot00000000000000 GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. 0. Additional Definitions. As used herein, "this License" refers to version 3 of the GNU Lesser General Public License, and the "GNU GPL" refers to version 3 of the GNU General Public License. "The Library" refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. An "Application" is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. A "Combined Work" is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the "Linked Version". The "Minimal Corresponding Source" for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. The "Corresponding Application Code" for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. 1. Exception to Section 3 of the GNU GPL. You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. 2. Conveying Modified Versions. If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. 3. Object Code Incorporating Material from Library Header Files. The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the object code with a copy of the GNU GPL and this license document. 4. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the Combined Work with a copy of the GNU GPL and this license document. c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. d) Do one of the following: 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) 5. Combined Libraries. You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 6. Revised Versions of the GNU Lesser General Public License. The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. inveniosoftware-contrib-intbitset-91de683/MANIFEST.in000066400000000000000000000030231517417475300225140ustar00rootroot00000000000000# -*- coding: utf-8 -*- # # This file is part of intbitset # Copyright (C) 2013, 2015, 2016 CERN. # # SPDX-License-Identifier: LGPL-3.0-or-later # # intbitset is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # intbitset is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with intbitset; if not, write to the Free Software Foundation, # Inc., 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. # # In applying this licence, CERN does not waive the privileges and immunities # granted to it by virtue of its status as an Intergovernmental Organization # or submit itself to any jurisdiction. include *.rst include *.sh include *.yml include docs/requirements.txt include LICENSE include tox.ini recursive-include docs *.py recursive-include docs *.rst recursive-include docs Makefile recursive-include docs/_themes *.css *.css_t *.conf *.html COPYING README recursive-include docs/_templates *.html recursive-include intbitset *.c recursive-include intbitset *.h recursive-include intbitset *.py recursive-include intbitset *.pyx recursive-include tests *.int recursive-include tests *.py inveniosoftware-contrib-intbitset-91de683/README.rst000066400000000000000000000070661517417475300224600ustar00rootroot00000000000000=========== intbitset =========== .. image:: https://img.shields.io/github/tag/inveniosoftware/intbitset.svg :target: https://github.com/inveniosoftware-contrib/intbitset/releases .. image:: https://img.shields.io/pypi/dm/intbitset.svg :target: https://pypi.python.org/pypi/intbitset .. image:: https://img.shields.io/github/license/inveniosoftware/intbitset.svg :target: https://github.com/inveniosoftware-contrib/intbitset/blob/master/LICENSE Installation ============ intbitset is on PyPI :: pip install intbitset We provide pre-built wheels for the most common operating systems and common 64 bits CPU architectures. Otherwise, you will need a C compiler if you build from sources. Documentation ============= The ``intbitset`` library provides a set implementation to store sorted unsigned integers either 32-bits integers (between ``0`` and ``2**31 - 1`` or ``intbitset.__maxelem__``) or an infinite range with fast set operations implemented via bit vectors in a *Python C extension* for speed and reduced memory usage. The ``inbitset`` class emulates the Python built-in set class interface with some additional specific methods such as its own fast dump and load marshalling functions. :: >>> from intbitset import intbitset >>> x = intbitset([1,2,3]) >>> y = intbitset([3,4,5]) >>> x & y intbitset([3]) >>> x | y intbitset([1, 2, 3, 4, 5]) Additionally, ``intbitset`` supports: - The `pickle protocol `_, - The `iterator protocol `_ - ``intbitset`` can behave like a ``sequence`` that can be sliced. - Natural min and max. Because the integers are always stored sorted, the fist element of a non-empty set `[0]` is also the `min()` integer and the last element `[-1]` is also the `max()` integer in the set. When compared to the standard library ``set`` class, ``intbitset`` set operations and the intersection, union and difference of ``intbitset``can be up to 5000 faster for dense integer sets than the standard library ``set``. Complete documentation is available at or can be built using Sphinx: :: pip install sphinx python setup.py build_sphinx Testing ======= Running the tests are as simple as: :: pip install -e .[tests] pytest Running the tests on multiple Python versions: :: pip install tox tox Development =========== To regenerate the C code with Cython: :: pip install cython cython intbitset/intbitset.pyx Then commit the regenrated C source and update the CHANGELOG.rst License ======= Copyright (C) CERN and others SPDX-License-Identifier: LGPL-3.0-or-later intbitset is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. intbitset is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with intbitset; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA. In applying this licence, CERN does not waive the privileges and immunities granted to it by virtue of its status as an Intergovernmental Organization or submit itself to any jurisdiction. inveniosoftware-contrib-intbitset-91de683/docs/000077500000000000000000000000001517417475300217105ustar00rootroot00000000000000inveniosoftware-contrib-intbitset-91de683/docs/Makefile000066400000000000000000000127101517417475300233510ustar00rootroot00000000000000# Makefile for Sphinx documentation # # You can set these variables from the command line. SPHINXOPTS = SPHINXBUILD = sphinx-build PAPER = BUILDDIR = _build # Internal variables. PAPEROPT_a4 = -D latex_paper_size=a4 PAPEROPT_letter = -D latex_paper_size=letter ALLSPHINXOPTS = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . # the i18n builder cannot share the environment and doctrees with the others I18NSPHINXOPTS = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . .PHONY: help clean html dirhtml singlehtml pickle json htmlhelp qthelp devhelp epub latex latexpdf text man changes linkcheck doctest gettext help: @echo "Please use \`make ' where is one of" @echo " html to make standalone HTML files" @echo " dirhtml to make HTML files named index.html in directories" @echo " singlehtml to make a single large HTML file" @echo " pickle to make pickle files" @echo " json to make JSON files" @echo " htmlhelp to make HTML files and a HTML help project" @echo " qthelp to make HTML files and a qthelp project" @echo " devhelp to make HTML files and a Devhelp project" @echo " epub to make an epub" @echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter" @echo " latexpdf to make LaTeX files and run them through pdflatex" @echo " text to make text files" @echo " man to make manual pages" @echo " texinfo to make Texinfo files" @echo " info to make Texinfo files and run them through makeinfo" @echo " gettext to make PO message catalogs" @echo " changes to make an overview of all changed/added/deprecated items" @echo " linkcheck to check all external links for integrity" @echo " doctest to run all doctests embedded in the documentation (if enabled)" clean: -rm -rf $(BUILDDIR)/* html: $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html @echo @echo "Build finished. The HTML pages are in $(BUILDDIR)/html." dirhtml: $(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml @echo @echo "Build finished. The HTML pages are in $(BUILDDIR)/dirhtml." singlehtml: $(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml @echo @echo "Build finished. The HTML page is in $(BUILDDIR)/singlehtml." pickle: $(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle @echo @echo "Build finished; now you can process the pickle files." json: $(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json @echo @echo "Build finished; now you can process the JSON files." htmlhelp: $(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp @echo @echo "Build finished; now you can run HTML Help Workshop with the" \ ".hhp project file in $(BUILDDIR)/htmlhelp." qthelp: $(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp @echo @echo "Build finished; now you can run "qcollectiongenerator" with the" \ ".qhcp project file in $(BUILDDIR)/qthelp, like this:" @echo "# qcollectiongenerator $(BUILDDIR)/qthelp/intbitset.qhcp" @echo "To view the help file:" @echo "# assistant -collectionFile $(BUILDDIR)/qthelp/intbitset.qhc" devhelp: $(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp @echo @echo "Build finished." @echo "To view the help file:" @echo "# mkdir -p $$HOME/.local/share/devhelp/intbitset" @echo "# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/intbitset" @echo "# devhelp" epub: $(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub @echo @echo "Build finished. The epub file is in $(BUILDDIR)/epub." latex: $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex @echo @echo "Build finished; the LaTeX files are in $(BUILDDIR)/latex." @echo "Run \`make' in that directory to run these through (pdf)latex" \ "(use \`make latexpdf' here to do that automatically)." latexpdf: $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex @echo "Running LaTeX files through pdflatex..." $(MAKE) -C $(BUILDDIR)/latex all-pdf @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex." text: $(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text @echo @echo "Build finished. The text files are in $(BUILDDIR)/text." man: $(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man @echo @echo "Build finished. The manual pages are in $(BUILDDIR)/man." texinfo: $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo @echo @echo "Build finished. The Texinfo files are in $(BUILDDIR)/texinfo." @echo "Run \`make' in that directory to run these through makeinfo" \ "(use \`make info' here to do that automatically)." info: $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo @echo "Running Texinfo files through makeinfo..." make -C $(BUILDDIR)/texinfo info @echo "makeinfo finished; the Info files are in $(BUILDDIR)/texinfo." gettext: $(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale @echo @echo "Build finished. The message catalogs are in $(BUILDDIR)/locale." changes: $(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes @echo @echo "The overview file is in $(BUILDDIR)/changes." linkcheck: $(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck @echo @echo "Link check complete; look for any errors in the above output " \ "or in $(BUILDDIR)/linkcheck/output.txt." doctest: $(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest @echo "Testing of doctests in the sources finished, look at the " \ "results in $(BUILDDIR)/doctest/output.txt." inveniosoftware-contrib-intbitset-91de683/docs/changelog.rst000066400000000000000000000000541517417475300243700ustar00rootroot00000000000000.. _changes: .. include:: ../CHANGELOG.rst inveniosoftware-contrib-intbitset-91de683/docs/conf.py000066400000000000000000000176211517417475300232160ustar00rootroot00000000000000# -*- coding: utf-8 -*- # # intbitset documentation build configuration file, created by # sphinx-quickstart on Fri Dec 6 06:12:33 2013. # # This file is execfile()d with the current directory set to its containing dir. # # Note that not all possible configuration values are present in this # autogenerated file. # # All configuration values have a default; values that are commented out # serve to show the default. import sys import os import re # If extensions (or modules to document with autodoc) are in another directory, # add these directories to sys.path here. If the directory is relative to the # documentation root, use os.path.abspath to make it absolute, like shown here. #sys.path.insert(0, os.path.abspath('.')) sys.path.insert(0, os.path.abspath('../src')) # -- General configuration ----------------------------------------------------- # If your documentation needs a minimal Sphinx version, state it here. #needs_sphinx = '1.0' # Add any Sphinx extension module names here, as strings. They can be extensions # coming with Sphinx (named 'sphinx.ext.*') or your custom ones. extensions = ['sphinx.ext.autodoc', 'sphinx.ext.doctest'] # Add any paths that contain templates here, relative to this directory. templates_path = ['_templates'] # The suffix of source filenames. source_suffix = '.rst' # The encoding of source files. #source_encoding = 'utf-8-sig' # The master toctree document. master_doc = 'index' # General information about the project. project = u'intbitset' copyright = u'2013, 2014, 2015 CERN' # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the # built documents. # # The short X.Y version. # Get the version string. Cannot be done with import! with open(os.path.join('..', 'intbitset', 'intbitset_version.py'), 'rt') as f: version = re.search( '__version__\s*=\s*"(?P.*)"\n', f.read() ).group('version') # The full version, including alpha/beta/rc tags. release = version # The language for content autogenerated by Sphinx. Refer to documentation # for a list of supported languages. #language = None # There are two options for replacing |today|: either, you set today to some # non-false value, then it is used: #today = '' # Else, today_fmt is used as the format for a strftime call. #today_fmt = '%B %d, %Y' # List of patterns, relative to source directory, that match files and # directories to ignore when looking for source files. exclude_patterns = ['_build'] # The reST default role (used for this markup: `text`) to use for all documents. #default_role = None # If true, '()' will be appended to :func: etc. cross-reference text. #add_function_parentheses = True # If true, the current module name will be prepended to all description # unit titles (such as .. function::). #add_module_names = True # If true, sectionauthor and moduleauthor directives will be shown in the # output. They are ignored by default. #show_authors = False # The name of the Pygments (syntax highlighting) style to use. pygments_style = 'sphinx' # A list of ignored prefixes for module index sorting. #modindex_common_prefix = [] # -- Options for HTML output --------------------------------------------------- # The theme to use for HTML and HTML Help pages. See the documentation for # a list of builtin themes. html_theme = 'default' # Theme options are theme-specific and customize the look and feel of a theme # further. For a list of options available for each theme, see the # documentation. #html_theme_options = {} # Add any paths that contain custom themes here, relative to this directory. #html_theme_path = [] # The name for this set of Sphinx documents. If None, it defaults to # " v documentation". #html_title = None # A shorter title for the navigation bar. Default is the same as html_title. #html_short_title = None # The name of an image file (relative to this directory) to place at the top # of the sidebar. #html_logo = None # The name of an image file (within the static path) to use as favicon of the # docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32 # pixels large. #html_favicon = None # Add any paths that contain custom static files (such as style sheets) here, # relative to this directory. They are copied after the builtin static files, # so a file named "default.css" will overwrite the builtin "default.css". html_static_path = ['_static'] # If not '', a 'Last updated on:' timestamp is inserted at every page bottom, # using the given strftime format. #html_last_updated_fmt = '%b %d, %Y' # If true, SmartyPants will be used to convert quotes and dashes to # typographically correct entities. #html_use_smartypants = True # Custom sidebar templates, maps document names to template names. #html_sidebars = {} # Additional templates that should be rendered to pages, maps page names to # template names. #html_additional_pages = {} # If false, no module index is generated. #html_domain_indices = True # If false, no index is generated. #html_use_index = True # If true, the index is split into individual pages for each letter. #html_split_index = False # If true, links to the reST sources are added to the pages. #html_show_sourcelink = True # If true, "Created using Sphinx" is shown in the HTML footer. Default is True. #html_show_sphinx = True # If true, "(C) Copyright ..." is shown in the HTML footer. Default is True. #html_show_copyright = True # If true, an OpenSearch description file will be output, and all pages will # contain a tag referring to it. The value of this option must be the # base URL from which the finished HTML is served. #html_use_opensearch = '' # This is the file name suffix for HTML files (e.g. ".xhtml"). #html_file_suffix = None # Output file base name for HTML help builder. htmlhelp_basename = 'intbitsetdoc' # -- Options for LaTeX output -------------------------------------------------- latex_elements = { # The paper size ('letterpaper' or 'a4paper'). #'papersize': 'letterpaper', # The font size ('10pt', '11pt' or '12pt'). #'pointsize': '10pt', # Additional stuff for the LaTeX preamble. #'preamble': '', } # Grouping the document tree into LaTeX files. List of tuples # (source start file, target name, title, author, documentclass [howto/manual]). latex_documents = [ ('index', 'intbitset.tex', u'intbitset Documentation', u'CERN', 'manual'), ] # The name of an image file (relative to this directory) to place at the top of # the title page. #latex_logo = None # For "manual" documents, if this is true, then toplevel headings are parts, # not chapters. #latex_use_parts = False # If true, show page references after internal links. #latex_show_pagerefs = False # If true, show URL addresses after external links. #latex_show_urls = False # Documents to append as an appendix to all manuals. #latex_appendices = [] # If false, no module index is generated. #latex_domain_indices = True # -- Options for manual page output -------------------------------------------- # One entry per manual page. List of tuples # (source start file, name, description, authors, manual section). man_pages = [ ('index', 'intbitset', u'intbitset Documentation', [u'CERN'], 1) ] # If true, show URL addresses after external links. #man_show_urls = False # -- Options for Texinfo output ------------------------------------------------ # Grouping the document tree into Texinfo files. List of tuples # (source start file, target name, title, author, # dir menu entry, description, category) texinfo_documents = [ ('index', 'intbitset', u'intbitset Documentation', u'CERN', 'intbitset', 'C-based extension implementing fast integer bit sets', 'Miscellaneous'), ] # Documents to append as an appendix to all manuals. #texinfo_appendices = [] # If false, no module index is generated. #texinfo_domain_indices = True # How to display URL addresses: 'footnote', 'no', or 'inline'. #texinfo_show_urls = 'footnote' inveniosoftware-contrib-intbitset-91de683/docs/contributing.rst000066400000000000000000000001431517417475300251470ustar00rootroot00000000000000Contributing ============ See for now. inveniosoftware-contrib-intbitset-91de683/docs/index.rst000066400000000000000000000153141517417475300235550ustar00rootroot00000000000000######### intbitset ######### ***** About ***** Provides an ``intbitset`` data object holding unordered sets of unsigned integers with ultra fast set operations, implemented via bit vectors and *Python C extension* to optimize speed and memory usage. Emulates the Python built-in set class interface with some additional specific methods such as its own fast dump and load marshalling functions. ``intbitset`` additionally support the `pickle protocol `_, the `iterator protocol `_ and can behave like a ``sequence`` type. Usage ===== Example: :: >>> from intbitset import intbitset >>> x = intbitset([1,2,3]) >>> y = intbitset([3,4,5]) >>> x & y intbitset([3]) >>> x | y intbitset([1, 2, 3, 4, 5]) Notes ===== - Uses real bits to optimize memory usage, so may have issues with *endianness* if you transport serialized bitsets between various machine architectures. - Please note that no bigger than ``__maxelem__`` elements can be added to an ``intbitset``. - On modern CPUs, *vectorial instruction sets* (such as MMX/SSE) are exploited to further optimize speed. *********** Performance *********** Here is an example of performance gain with respect to traditional ``set`` of positive integers (example of *ipython* session): :: >>> ## preparation >>> from intbitset import intbitset >>> from random import sample >>> sparse_population1 = sample(range(1000000), 10000) >>> sparse_population2 = sample(range(1000000), 10000) >>> dense_population1 = sample(range(1000000), 900000) >>> dense_population2 = sample(range(1000000), 900000) >>> sparse_set1 = set(sparse_population1) >>> sparse_set2 = set(sparse_population2) >>> sparse_intbitset1 = intbitset(sparse_population1) >>> sparse_intbitset2 = intbitset(sparse_population2) >>> dense_set1 = set(dense_population1) >>> dense_set2 = set(dense_population2) >>> dense_intbitset1 = intbitset(dense_population1) >>> dense_intbitset2 = intbitset(dense_population2) >>> sorted(sparse_population1)[5000:5002] [500095, 500124] >>> in_sparse = 500095 >>> not_in_sparse = 500096 >>> sorted(dense_population1)[500000:500002] [555705, 555707] >>> in_dense = 555705 >>> not_in_dense = 555706 For sparse sets, ``intbitset`` operations are typically **50 times faster** than set operations. >>> ## Sparse sets operations >>> %timeit sparse_set1 & sparse_set2 1000 loops, best of 3: 263 µs per loop >>> %timeit sparse_intbitset1 & sparse_intbitset2 ## more than 20 times faster 100000 loops, best of 3: 11.6 µs per loop >>> %timeit sparse_set1 | sparse_set2 1000 loops, best of 3: 891 µs per loop >>> %timeit sparse_intbitset1 | sparse_intbitset2 ## almost 70 times faster 100000 loops, best of 3: 12.8 µs per loop >>> %timeit sparse_set1 ^ sparse_set2 1000 loops, best of 3: 1.09 ms per loop >>> %timeit sparse_intbitset1 ^ sparse_intbitset2 ## more than 80 times faster 100000 loops, best of 3: 12.9 µs per loop >>> %timeit sparse_set1 - sparse_set2 1000 loops, best of 3: 739 µs per loop >>> %timeit sparse_intbitset1 - sparse_intbitset2 ## almost 60 times faster 100000 loops, best of 3: 12.5 µs per loop For dense sets, ``intbitset`` operations are typically **5000 times faster** than set operations: :: >>> ## Dense sets operations >>> %timeit dense_set1 & dense_set2 10 loops, best of 3: 62.1 ms per loop >>> %timeit dense_intbitset1 & dense_intbitset2 ## more than 5000 times faster 100000 loops, best of 3: 12.3 µs per loop >>> %timeit dense_set1 | dense_set2 10 loops, best of 3: 84.1 ms per loop >>> %timeit dense_intbitset1 | dense_intbitset2 ## more than 6000 times faster 100000 loops, best of 3: 12.5 µs per loop >>> %timeit dense_set1 ^ dense_set2 10 loops, best of 3: 64.2 ms per loop >>> %timeit dense_intbitset1 ^ dense_intbitset2 ## more than 5000 times faster 100000 loops, best of 3: 12.6 µs per loop >>> %timeit dense_set1 - dense_set2 10 loops, best of 3: 38.6 ms per loop >>> timeit dense_intbitset1 - dense_intbitset2 ## more than 3000 times faster 100000 loops, best of 3: 12.8 µs per loop Membership operations in ``intbitset`` behave in a comparable way than ``set`` objects, albeit with slightly better performance: :: >>> ## Membership tests >>> %timeit in_sparse in sparse_set1 10000000 loops, best of 3: 66.8 ns per loop >>> %timeit in_sparse in sparse_intbitset1 ## 1.5 times faster 10000000 loops, best of 3: 42.8 ns per loop >>> %timeit not_in_sparse in sparse_set1 10000000 loops, best of 3: 71.3 ns per loop >>> %timeit not_in_sparse in sparse_intbitset1 ## 1.6 times faster 10000000 loops, best of 3: 44.7 ns per loop >>> %timeit in_dense in dense_set1 10000000 loops, best of 3: 61.8 ns per loop >>> %timeit in_dense in dense_intbitset1 ## 1.3 times faster 10000000 loops, best of 3: 45.3 ns per loop >>> %timeit not_in_dense in dense_set1 10000000 loops, best of 3: 45.5 ns per loop >>> %timeit not_in_dense in dense_intbitset1 ## similar speed 10000000 loops, best of 3: 41.4 ns per loop Serialising can be up to **30 times faster**: :: >>> ## serialization speed >>> ## note: internally intbitset compress using zlib so we are >>> ## going to also compress the equivalent set >>> from zlib import compress, decompress >>> from marshal import dumps, loads >>> %timeit loads(decompress(compress(dumps(sparse_set1)))) 100 loops, best of 3: 6.55 ms per loop >>> %timeit intbitset(sparse_intbitset1.fastdump()) ## 15% faster 100 loops, best of 3: 5.63 ms per loop >>> %timeit loads(decompress(compress(dumps(dense_set1)))) 1 loops, best of 3: 565 ms per loop >>> %timeit intbitset(dense_intbitset1.fastdump()) ## almost 30 times faster for dense sets 10 loops, best of 3: 20.9 ms per loop Serialising can lead to **20 times smaller footprint**: :: >>> len(compress(dumps(sparse_set1))) 29349 >>> len(sparse_intbitset1.fastdump()) ## almost half the space 16166 >>> len(compress(dumps(dense_set1))) 1363026 >>> len(dense_intbitset1.fastdump()) ## 5% of the space for dense set 70332 ********* Reference ********* .. automodule:: intbitset :members: :undoc-members: :special-members: ****************** Indices and tables ****************** * :ref:`genindex` * :ref:`modindex` * :ref:`search` **************** Additional Notes **************** Notes on how to contribute, legal information and changelog are here for the interested. .. toctree:: :maxdepth: 2 contributing changelog license inveniosoftware-contrib-intbitset-91de683/docs/license.rst000066400000000000000000000024051517417475300240650ustar00rootroot00000000000000License ======= .. code-block:: text Copyright (C) 2013, 2014, 2015, 2016 CERN and others SPDX-License-Identifier: LGPL-3.0-or-later intbitset is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. intbitset is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with intbitset; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA. In applying this licence, CERN does not waive the privileges and immunities granted to it by virtue of its status as an Intergovernmental Organization or submit itself to any jurisdiction. The full license text can be found below (:ref:`lgpl`). .. _authors: .. include:: ../AUTHORS.rst .. _lgpl: GNU Lesser General Public License --------------------------------- .. include:: ../LICENSE inveniosoftware-contrib-intbitset-91de683/docs/requirements.txt000066400000000000000000000000211517417475300251650ustar00rootroot00000000000000-e .[docs,tests] inveniosoftware-contrib-intbitset-91de683/intbitset/000077500000000000000000000000001517417475300227655ustar00rootroot00000000000000inveniosoftware-contrib-intbitset-91de683/intbitset/intbitset.c000066400000000000000000043717041517417475300251560ustar00rootroot00000000000000/* Generated by Cython 3.1.6 */ #ifndef PY_SSIZE_T_CLEAN #define PY_SSIZE_T_CLEAN #endif /* PY_SSIZE_T_CLEAN */ /* InitLimitedAPI */ #if defined(Py_LIMITED_API) #if !defined(CYTHON_LIMITED_API) #define CYTHON_LIMITED_API 1 #endif #elif defined(CYTHON_LIMITED_API) #ifdef _MSC_VER #pragma message ("Limited API usage is enabled with 'CYTHON_LIMITED_API' but 'Py_LIMITED_API' does not define a Python target version. Consider setting 'Py_LIMITED_API' instead.") #else #warning Limited API usage is enabled with 'CYTHON_LIMITED_API' but 'Py_LIMITED_API' does not define a Python target version. Consider setting 'Py_LIMITED_API' instead. #endif #endif #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 < 0x03080000 #error Cython requires Python 3.8+. #else #define __PYX_ABI_VERSION "3_1_6" #define CYTHON_HEX_VERSION 0x030106F0 #define CYTHON_FUTURE_DIVISION 0 /* CModulePreamble */ #include #ifndef offsetof #define offsetof(type, member) ( (size_t) & ((type*)0) -> member ) #endif #if !defined(_WIN32) && !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 #define HAVE_LONG_LONG #endif #ifndef PY_LONG_LONG #define PY_LONG_LONG LONG_LONG #endif #ifndef Py_HUGE_VAL #define Py_HUGE_VAL HUGE_VAL #endif #define __PYX_LIMITED_VERSION_HEX PY_VERSION_HEX #if defined(GRAALVM_PYTHON) /* For very preliminary testing purposes. Most variables are set the same as PyPy. The existence of this section does not imply that anything works or is even tested */ #define CYTHON_COMPILING_IN_PYPY 0 #define CYTHON_COMPILING_IN_CPYTHON 0 #define CYTHON_COMPILING_IN_LIMITED_API 0 #define CYTHON_COMPILING_IN_GRAAL 1 #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 #undef CYTHON_USE_TYPE_SLOTS #define CYTHON_USE_TYPE_SLOTS 0 #undef CYTHON_USE_TYPE_SPECS #define CYTHON_USE_TYPE_SPECS 0 #undef CYTHON_USE_PYTYPE_LOOKUP #define CYTHON_USE_PYTYPE_LOOKUP 0 #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_AVOID_THREAD_UNSAFE_BORROWED_REFS #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 #undef CYTHON_ASSUME_SAFE_MACROS #define CYTHON_ASSUME_SAFE_MACROS 0 #undef CYTHON_ASSUME_SAFE_SIZE #define CYTHON_ASSUME_SAFE_SIZE 0 #undef CYTHON_UNPACK_METHODS #define CYTHON_UNPACK_METHODS 0 #undef CYTHON_FAST_THREAD_STATE #define CYTHON_FAST_THREAD_STATE 0 #undef CYTHON_FAST_GIL #define CYTHON_FAST_GIL 0 #undef CYTHON_METH_FASTCALL #define CYTHON_METH_FASTCALL 0 #undef CYTHON_FAST_PYCALL #define CYTHON_FAST_PYCALL 0 #ifndef CYTHON_PEP487_INIT_SUBCLASS #define CYTHON_PEP487_INIT_SUBCLASS 1 #endif #undef CYTHON_PEP489_MULTI_PHASE_INIT #define CYTHON_PEP489_MULTI_PHASE_INIT 1 #undef CYTHON_USE_MODULE_STATE #define CYTHON_USE_MODULE_STATE 0 #undef CYTHON_USE_SYS_MONITORING #define CYTHON_USE_SYS_MONITORING 0 #undef CYTHON_USE_TP_FINALIZE #define CYTHON_USE_TP_FINALIZE 0 #undef CYTHON_USE_AM_SEND #define CYTHON_USE_AM_SEND 0 #undef CYTHON_USE_DICT_VERSIONS #define CYTHON_USE_DICT_VERSIONS 0 #undef CYTHON_USE_EXC_INFO_STACK #define CYTHON_USE_EXC_INFO_STACK 1 #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 #endif #undef CYTHON_USE_FREELISTS #define CYTHON_USE_FREELISTS 0 #elif defined(PYPY_VERSION) #define CYTHON_COMPILING_IN_PYPY 1 #define CYTHON_COMPILING_IN_CPYTHON 0 #define CYTHON_COMPILING_IN_LIMITED_API 0 #define CYTHON_COMPILING_IN_GRAAL 0 #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 #undef CYTHON_USE_TYPE_SLOTS #define CYTHON_USE_TYPE_SLOTS 1 #ifndef CYTHON_USE_TYPE_SPECS #define CYTHON_USE_TYPE_SPECS 0 #endif #undef CYTHON_USE_PYTYPE_LOOKUP #define CYTHON_USE_PYTYPE_LOOKUP 0 #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_AVOID_THREAD_UNSAFE_BORROWED_REFS #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 #undef CYTHON_ASSUME_SAFE_MACROS #define CYTHON_ASSUME_SAFE_MACROS 0 #ifndef CYTHON_ASSUME_SAFE_SIZE #define CYTHON_ASSUME_SAFE_SIZE 1 #endif #undef CYTHON_UNPACK_METHODS #define CYTHON_UNPACK_METHODS 0 #undef CYTHON_FAST_THREAD_STATE #define CYTHON_FAST_THREAD_STATE 0 #undef CYTHON_FAST_GIL #define CYTHON_FAST_GIL 0 #undef CYTHON_METH_FASTCALL #define CYTHON_METH_FASTCALL 0 #undef CYTHON_FAST_PYCALL #define CYTHON_FAST_PYCALL 0 #ifndef CYTHON_PEP487_INIT_SUBCLASS #define CYTHON_PEP487_INIT_SUBCLASS 1 #endif #if PY_VERSION_HEX < 0x03090000 #undef CYTHON_PEP489_MULTI_PHASE_INIT #define CYTHON_PEP489_MULTI_PHASE_INIT 0 #elif !defined(CYTHON_PEP489_MULTI_PHASE_INIT) #define CYTHON_PEP489_MULTI_PHASE_INIT 1 #endif #undef CYTHON_USE_MODULE_STATE #define CYTHON_USE_MODULE_STATE 0 #undef CYTHON_USE_SYS_MONITORING #define CYTHON_USE_SYS_MONITORING 0 #ifndef CYTHON_USE_TP_FINALIZE #define CYTHON_USE_TP_FINALIZE (PYPY_VERSION_NUM >= 0x07030C00) #endif #undef CYTHON_USE_AM_SEND #define CYTHON_USE_AM_SEND 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 #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC #define CYTHON_UPDATE_DESCRIPTOR_DOC (PYPY_VERSION_NUM >= 0x07031100) #endif #undef CYTHON_USE_FREELISTS #define CYTHON_USE_FREELISTS 0 #elif defined(CYTHON_LIMITED_API) #ifdef Py_LIMITED_API #undef __PYX_LIMITED_VERSION_HEX #define __PYX_LIMITED_VERSION_HEX Py_LIMITED_API #endif #define CYTHON_COMPILING_IN_PYPY 0 #define CYTHON_COMPILING_IN_CPYTHON 0 #define CYTHON_COMPILING_IN_LIMITED_API 1 #define CYTHON_COMPILING_IN_GRAAL 0 #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 #undef CYTHON_CLINE_IN_TRACEBACK #define CYTHON_CLINE_IN_TRACEBACK 0 #undef CYTHON_USE_TYPE_SLOTS #define CYTHON_USE_TYPE_SLOTS 0 #undef CYTHON_USE_TYPE_SPECS #define CYTHON_USE_TYPE_SPECS 1 #undef CYTHON_USE_PYTYPE_LOOKUP #define CYTHON_USE_PYTYPE_LOOKUP 0 #undef CYTHON_USE_PYLIST_INTERNALS #define CYTHON_USE_PYLIST_INTERNALS 0 #undef CYTHON_USE_UNICODE_INTERNALS #define CYTHON_USE_UNICODE_INTERNALS 0 #ifndef CYTHON_USE_UNICODE_WRITER #define CYTHON_USE_UNICODE_WRITER 0 #endif #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_AVOID_THREAD_UNSAFE_BORROWED_REFS #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 #endif #undef CYTHON_ASSUME_SAFE_MACROS #define CYTHON_ASSUME_SAFE_MACROS 0 #undef CYTHON_ASSUME_SAFE_SIZE #define CYTHON_ASSUME_SAFE_SIZE 0 #undef CYTHON_UNPACK_METHODS #define CYTHON_UNPACK_METHODS 0 #undef CYTHON_FAST_THREAD_STATE #define CYTHON_FAST_THREAD_STATE 0 #undef CYTHON_FAST_GIL #define CYTHON_FAST_GIL 0 #undef CYTHON_METH_FASTCALL #define CYTHON_METH_FASTCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) #undef CYTHON_FAST_PYCALL #define CYTHON_FAST_PYCALL 0 #ifndef CYTHON_PEP487_INIT_SUBCLASS #define CYTHON_PEP487_INIT_SUBCLASS 1 #endif #ifndef CYTHON_PEP489_MULTI_PHASE_INIT #define CYTHON_PEP489_MULTI_PHASE_INIT 1 #endif #ifndef CYTHON_USE_MODULE_STATE #define CYTHON_USE_MODULE_STATE 0 #endif #undef CYTHON_USE_SYS_MONITORING #define CYTHON_USE_SYS_MONITORING 0 #ifndef CYTHON_USE_TP_FINALIZE #define CYTHON_USE_TP_FINALIZE 0 #endif #ifndef CYTHON_USE_AM_SEND #define CYTHON_USE_AM_SEND (__PYX_LIMITED_VERSION_HEX >= 0x030A0000) #endif #undef CYTHON_USE_DICT_VERSIONS #define CYTHON_USE_DICT_VERSIONS 0 #undef CYTHON_USE_EXC_INFO_STACK #define CYTHON_USE_EXC_INFO_STACK 0 #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC #define CYTHON_UPDATE_DESCRIPTOR_DOC 0 #endif #undef CYTHON_USE_FREELISTS #define CYTHON_USE_FREELISTS 0 #else #define CYTHON_COMPILING_IN_PYPY 0 #define CYTHON_COMPILING_IN_CPYTHON 1 #define CYTHON_COMPILING_IN_LIMITED_API 0 #define CYTHON_COMPILING_IN_GRAAL 0 #ifdef Py_GIL_DISABLED #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 1 #else #define CYTHON_COMPILING_IN_CPYTHON_FREETHREADING 0 #endif #if PY_VERSION_HEX < 0x030A0000 #undef CYTHON_USE_TYPE_SLOTS #define CYTHON_USE_TYPE_SLOTS 1 #elif !defined(CYTHON_USE_TYPE_SLOTS) #define CYTHON_USE_TYPE_SLOTS 1 #endif #ifndef CYTHON_USE_TYPE_SPECS #define CYTHON_USE_TYPE_SPECS 0 #endif #ifndef CYTHON_USE_PYTYPE_LOOKUP #define CYTHON_USE_PYTYPE_LOOKUP 1 #endif #ifndef CYTHON_USE_PYLONG_INTERNALS #define CYTHON_USE_PYLONG_INTERNALS 1 #endif #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING #undef CYTHON_USE_PYLIST_INTERNALS #define CYTHON_USE_PYLIST_INTERNALS 0 #elif !defined(CYTHON_USE_PYLIST_INTERNALS) #define CYTHON_USE_PYLIST_INTERNALS 1 #endif #ifndef CYTHON_USE_UNICODE_INTERNALS #define CYTHON_USE_UNICODE_INTERNALS 1 #endif #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING || PY_VERSION_HEX >= 0x030B00A2 #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 #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING #undef CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 1 #elif !defined(CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS) #define CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS 0 #endif #ifndef CYTHON_ASSUME_SAFE_MACROS #define CYTHON_ASSUME_SAFE_MACROS 1 #endif #ifndef CYTHON_ASSUME_SAFE_SIZE #define CYTHON_ASSUME_SAFE_SIZE 1 #endif #ifndef CYTHON_UNPACK_METHODS #define CYTHON_UNPACK_METHODS 1 #endif #ifndef CYTHON_FAST_THREAD_STATE #define CYTHON_FAST_THREAD_STATE 1 #endif #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING #undef CYTHON_FAST_GIL #define CYTHON_FAST_GIL 0 #elif !defined(CYTHON_FAST_GIL) #define CYTHON_FAST_GIL (PY_VERSION_HEX < 0x030C00A6) #endif #ifndef CYTHON_METH_FASTCALL #define CYTHON_METH_FASTCALL 1 #endif #ifndef CYTHON_FAST_PYCALL #define CYTHON_FAST_PYCALL 1 #endif #ifndef CYTHON_PEP487_INIT_SUBCLASS #define CYTHON_PEP487_INIT_SUBCLASS 1 #endif #ifndef CYTHON_PEP489_MULTI_PHASE_INIT #define CYTHON_PEP489_MULTI_PHASE_INIT 1 #endif #ifndef CYTHON_USE_MODULE_STATE #define CYTHON_USE_MODULE_STATE 0 #endif #ifndef CYTHON_USE_SYS_MONITORING #define CYTHON_USE_SYS_MONITORING (PY_VERSION_HEX >= 0x030d00B1) #endif #ifndef CYTHON_USE_TP_FINALIZE #define CYTHON_USE_TP_FINALIZE 1 #endif #ifndef CYTHON_USE_AM_SEND #define CYTHON_USE_AM_SEND 1 #endif #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING #undef CYTHON_USE_DICT_VERSIONS #define CYTHON_USE_DICT_VERSIONS 0 #elif !defined(CYTHON_USE_DICT_VERSIONS) #define CYTHON_USE_DICT_VERSIONS (PY_VERSION_HEX < 0x030C00A5 && !CYTHON_USE_MODULE_STATE) #endif #ifndef CYTHON_USE_EXC_INFO_STACK #define CYTHON_USE_EXC_INFO_STACK 1 #endif #ifndef CYTHON_UPDATE_DESCRIPTOR_DOC #define CYTHON_UPDATE_DESCRIPTOR_DOC 1 #endif #ifndef CYTHON_USE_FREELISTS #define CYTHON_USE_FREELISTS (!CYTHON_COMPILING_IN_CPYTHON_FREETHREADING) #endif #endif #ifndef CYTHON_FAST_PYCCALL #define CYTHON_FAST_PYCCALL CYTHON_FAST_PYCALL #endif #ifndef CYTHON_VECTORCALL #if CYTHON_COMPILING_IN_LIMITED_API #define CYTHON_VECTORCALL (__PYX_LIMITED_VERSION_HEX >= 0x030C0000) #else #define CYTHON_VECTORCALL (CYTHON_FAST_PYCCALL && PY_VERSION_HEX >= 0x030800B1) #endif #endif #define CYTHON_BACKPORT_VECTORCALL (CYTHON_METH_FASTCALL && PY_VERSION_HEX < 0x030800B1) #if CYTHON_USE_PYLONG_INTERNALS #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 CYTHON_LOCK_AND_GIL_DEADLOCK_AVOIDANCE_TIME #define CYTHON_LOCK_AND_GIL_DEADLOCK_AVOIDANCE_TIME 100 #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(__cplusplus) /* for clang __has_cpp_attribute(maybe_unused) is true even before C++17 * but leads to warnings with -pedantic, since it is a C++17 feature */ #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) #if __has_cpp_attribute(maybe_unused) #define CYTHON_UNUSED [[maybe_unused]] #endif #endif #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_UNUSED_VAR # if defined(__cplusplus) template void CYTHON_UNUSED_VAR( const T& ) { } # else # define CYTHON_UNUSED_VAR(x) (void)(x) # endif #endif #ifndef CYTHON_MAYBE_UNUSED_VAR #define CYTHON_MAYBE_UNUSED_VAR(x) CYTHON_UNUSED_VAR(x) #endif #ifndef CYTHON_NCP_UNUSED # if CYTHON_COMPILING_IN_CPYTHON && !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING # define CYTHON_NCP_UNUSED # else # define CYTHON_NCP_UNUSED CYTHON_UNUSED # endif #endif #ifndef CYTHON_USE_CPP_STD_MOVE #if defined(__cplusplus) && (\ __cplusplus >= 201103L || (defined(_MSC_VER) && _MSC_VER >= 1600)) #define CYTHON_USE_CPP_STD_MOVE 1 #else #define CYTHON_USE_CPP_STD_MOVE 0 #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 short uint16_t; typedef unsigned int uint32_t; #else typedef unsigned __int8 uint8_t; typedef unsigned __int16 uint16_t; typedef unsigned __int32 uint32_t; #endif #endif #if _MSC_VER < 1300 #ifdef _WIN64 typedef unsigned long long __pyx_uintptr_t; #else typedef unsigned int __pyx_uintptr_t; #endif #else #ifdef _WIN64 typedef unsigned __int64 __pyx_uintptr_t; #else typedef unsigned __int32 __pyx_uintptr_t; #endif #endif #else #include typedef uintptr_t __pyx_uintptr_t; #endif #ifndef CYTHON_FALLTHROUGH #if defined(__cplusplus) /* for clang __has_cpp_attribute(fallthrough) is true even before C++17 * but leads to warnings with -pedantic, since it is a C++17 feature */ #if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L) #if __has_cpp_attribute(fallthrough) #define CYTHON_FALLTHROUGH [[fallthrough]] #endif #endif #ifndef CYTHON_FALLTHROUGH #if __has_cpp_attribute(clang::fallthrough) #define CYTHON_FALLTHROUGH [[clang::fallthrough]] #elif __has_cpp_attribute(gnu::fallthrough) #define CYTHON_FALLTHROUGH [[gnu::fallthrough]] #endif #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 Py_UNREACHABLE #define Py_UNREACHABLE() assert(0); abort() #endif #ifdef __cplusplus template struct __PYX_IS_UNSIGNED_IMPL {static const bool value = T(0) < T(-1);}; #define __PYX_IS_UNSIGNED(type) (__PYX_IS_UNSIGNED_IMPL::value) #else #define __PYX_IS_UNSIGNED(type) (((type)-1) > 0) #endif #if CYTHON_COMPILING_IN_PYPY == 1 #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x030A0000) #else #define __PYX_NEED_TP_PRINT_SLOT (PY_VERSION_HEX >= 0x030800b4 && PY_VERSION_HEX < 0x03090000) #endif #define __PYX_REINTERPRET_FUNCION(func_pointer, other_pointer) ((func_pointer)(void(*)(void))(other_pointer)) /* CInitCode */ #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 /* PythonCompatibility */ #define __PYX_BUILD_PY_SSIZE_T "n" #define CYTHON_FORMAT_SSIZE_T "z" #define __Pyx_BUILTIN_MODULE_NAME "builtins" #define __Pyx_DefaultClassType PyType_Type #if CYTHON_COMPILING_IN_LIMITED_API #ifndef CO_OPTIMIZED static int CO_OPTIMIZED; #endif #ifndef CO_NEWLOCALS static int CO_NEWLOCALS; #endif #ifndef CO_VARARGS static int CO_VARARGS; #endif #ifndef CO_VARKEYWORDS static int CO_VARKEYWORDS; #endif #ifndef CO_ASYNC_GENERATOR static int CO_ASYNC_GENERATOR; #endif #ifndef CO_GENERATOR static int CO_GENERATOR; #endif #ifndef CO_COROUTINE static int CO_COROUTINE; #endif #else #ifndef CO_COROUTINE #define CO_COROUTINE 0x80 #endif #ifndef CO_ASYNC_GENERATOR #define CO_ASYNC_GENERATOR 0x200 #endif #endif static int __Pyx_init_co_variables(void); #if PY_VERSION_HEX >= 0x030900A4 || defined(Py_IS_TYPE) #define __Pyx_IS_TYPE(ob, type) Py_IS_TYPE(ob, type) #else #define __Pyx_IS_TYPE(ob, type) (((const PyObject*)ob)->ob_type == (type)) #endif #if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_Is) #define __Pyx_Py_Is(x, y) Py_Is(x, y) #else #define __Pyx_Py_Is(x, y) ((x) == (y)) #endif #if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsNone) #define __Pyx_Py_IsNone(ob) Py_IsNone(ob) #else #define __Pyx_Py_IsNone(ob) __Pyx_Py_Is((ob), Py_None) #endif #if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsTrue) #define __Pyx_Py_IsTrue(ob) Py_IsTrue(ob) #else #define __Pyx_Py_IsTrue(ob) __Pyx_Py_Is((ob), Py_True) #endif #if PY_VERSION_HEX >= 0x030A00B1 || defined(Py_IsFalse) #define __Pyx_Py_IsFalse(ob) Py_IsFalse(ob) #else #define __Pyx_Py_IsFalse(ob) __Pyx_Py_Is((ob), Py_False) #endif #define __Pyx_NoneAsNull(obj) (__Pyx_Py_IsNone(obj) ? NULL : (obj)) #if PY_VERSION_HEX >= 0x030900F0 && !CYTHON_COMPILING_IN_PYPY #define __Pyx_PyObject_GC_IsFinalized(o) PyObject_GC_IsFinalized(o) #else #define __Pyx_PyObject_GC_IsFinalized(o) _PyGC_FINALIZED(o) #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 Py_TPFLAGS_SEQUENCE #define Py_TPFLAGS_SEQUENCE 0 #endif #ifndef Py_TPFLAGS_MAPPING #define Py_TPFLAGS_MAPPING 0 #endif #ifndef METH_STACKLESS #define METH_STACKLESS 0 #endif #ifndef 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 #if PY_VERSION_HEX >= 0x030d00A4 # define __Pyx_PyCFunctionFast PyCFunctionFast # define __Pyx_PyCFunctionFastWithKeywords PyCFunctionFastWithKeywords #else # define __Pyx_PyCFunctionFast _PyCFunctionFast # define __Pyx_PyCFunctionFastWithKeywords _PyCFunctionFastWithKeywords #endif #endif #if CYTHON_METH_FASTCALL #define __Pyx_METH_FASTCALL METH_FASTCALL #define __Pyx_PyCFunction_FastCall __Pyx_PyCFunctionFast #define __Pyx_PyCFunction_FastCallWithKeywords __Pyx_PyCFunctionFastWithKeywords #else #define __Pyx_METH_FASTCALL METH_VARARGS #define __Pyx_PyCFunction_FastCall PyCFunction #define __Pyx_PyCFunction_FastCallWithKeywords PyCFunctionWithKeywords #endif #if CYTHON_VECTORCALL #define __pyx_vectorcallfunc vectorcallfunc #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET PY_VECTORCALL_ARGUMENTS_OFFSET #define __Pyx_PyVectorcall_NARGS(n) PyVectorcall_NARGS((size_t)(n)) #elif CYTHON_BACKPORT_VECTORCALL typedef PyObject *(*__pyx_vectorcallfunc)(PyObject *callable, PyObject *const *args, size_t nargsf, PyObject *kwnames); #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET ((size_t)1 << (8 * sizeof(size_t) - 1)) #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(((size_t)(n)) & ~__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)) #else #define __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET 0 #define __Pyx_PyVectorcall_NARGS(n) ((Py_ssize_t)(n)) #endif #if PY_VERSION_HEX >= 0x030900B1 #define __Pyx_PyCFunction_CheckExact(func) PyCFunction_CheckExact(func) #else #define __Pyx_PyCFunction_CheckExact(func) PyCFunction_Check(func) #endif #define __Pyx_CyOrPyCFunction_Check(func) PyCFunction_Check(func) #if CYTHON_COMPILING_IN_CPYTHON #define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) (((PyCFunctionObject*)(func))->m_ml->ml_meth) #elif !CYTHON_COMPILING_IN_LIMITED_API #define __Pyx_CyOrPyCFunction_GET_FUNCTION(func) PyCFunction_GET_FUNCTION(func) #endif #if CYTHON_COMPILING_IN_CPYTHON #define __Pyx_CyOrPyCFunction_GET_FLAGS(func) (((PyCFunctionObject*)(func))->m_ml->ml_flags) static CYTHON_INLINE PyObject* __Pyx_CyOrPyCFunction_GET_SELF(PyObject *func) { return (__Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_STATIC) ? NULL : ((PyCFunctionObject*)func)->m_self; } #endif static CYTHON_INLINE int __Pyx__IsSameCFunction(PyObject *func, void (*cfunc)(void)) { #if CYTHON_COMPILING_IN_LIMITED_API return PyCFunction_Check(func) && PyCFunction_GetFunction(func) == (PyCFunction) cfunc; #else return PyCFunction_Check(func) && PyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc; #endif } #define __Pyx_IsSameCFunction(func, cfunc) __Pyx__IsSameCFunction(func, cfunc) #if __PYX_LIMITED_VERSION_HEX < 0x03090000 #define __Pyx_PyType_FromModuleAndSpec(m, s, b) ((void)m, PyType_FromSpecWithBases(s, b)) typedef PyObject *(*__Pyx_PyCMethod)(PyObject *, PyTypeObject *, PyObject *const *, size_t, PyObject *); #else #define __Pyx_PyType_FromModuleAndSpec(m, s, b) PyType_FromModuleAndSpec(m, s, b) #define __Pyx_PyCMethod PyCMethod #endif #ifndef METH_METHOD #define METH_METHOD 0x200 #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_LIMITED_API #define __Pyx_PyFrame_SetLineNumber(frame, lineno) #elif CYTHON_COMPILING_IN_GRAAL #define __Pyx_PyCode_HasFreeVars(co) (PyCode_GetNumFree(co) > 0) #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_COMPILING_IN_LIMITED_API #define __Pyx_PyThreadState_Current PyThreadState_Get() #elif !CYTHON_FAST_THREAD_STATE #define __Pyx_PyThreadState_Current PyThreadState_GET() #elif PY_VERSION_HEX >= 0x030d00A1 #define __Pyx_PyThreadState_Current PyThreadState_GetUnchecked() #else #define __Pyx_PyThreadState_Current _PyThreadState_UncheckedGet() #endif #if CYTHON_USE_MODULE_STATE static CYTHON_INLINE void *__Pyx__PyModule_GetState(PyObject *op) { void *result; result = PyModule_GetState(op); if (!result) Py_FatalError("Couldn't find the module state"); return result; } #define __Pyx_PyModule_GetState(o) (__pyx_mstatetype *)__Pyx__PyModule_GetState(o) #else #define __Pyx_PyModule_GetState(op) ((void)op,__pyx_mstate_global) #endif #define __Pyx_PyObject_GetSlot(obj, name, func_ctype) __Pyx_PyType_GetSlot(Py_TYPE((PyObject *) obj), name, func_ctype) #define __Pyx_PyObject_TryGetSlot(obj, name, func_ctype) __Pyx_PyType_TryGetSlot(Py_TYPE(obj), name, func_ctype) #define __Pyx_PyObject_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(Py_TYPE(obj), sub, name, func_ctype) #define __Pyx_PyObject_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSubSlot(Py_TYPE(obj), sub, name, func_ctype) #if CYTHON_USE_TYPE_SLOTS #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((type)->name) #define __Pyx_PyType_TryGetSlot(type, name, func_ctype) __Pyx_PyType_GetSlot(type, name, func_ctype) #define __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) (((type)->sub) ? ((type)->sub->name) : NULL) #define __Pyx_PyType_TryGetSubSlot(type, sub, name, func_ctype) __Pyx_PyType_GetSubSlot(type, sub, name, func_ctype) #else #define __Pyx_PyType_GetSlot(type, name, func_ctype) ((func_ctype) PyType_GetSlot((type), Py_##name)) #define __Pyx_PyType_TryGetSlot(type, name, func_ctype)\ ((__PYX_LIMITED_VERSION_HEX >= 0x030A0000 ||\ (PyType_GetFlags(type) & Py_TPFLAGS_HEAPTYPE) || __Pyx_get_runtime_version() >= 0x030A0000) ?\ __Pyx_PyType_GetSlot(type, name, func_ctype) : NULL) #define __Pyx_PyType_GetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_GetSlot(obj, name, func_ctype) #define __Pyx_PyType_TryGetSubSlot(obj, sub, name, func_ctype) __Pyx_PyType_TryGetSlot(obj, name, func_ctype) #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 #define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y) #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y) #if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_UNICODE_INTERNALS #define __Pyx_PyDict_GetItemStrWithError(dict, name) _PyDict_GetItem_KnownHash(dict, name, ((PyASCIIObject *) name)->hash) static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStr(PyObject *dict, PyObject *name) { PyObject *res = __Pyx_PyDict_GetItemStrWithError(dict, name); if (res == NULL) PyErr_Clear(); return res; } #elif !CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07020000 #define __Pyx_PyDict_GetItemStrWithError PyDict_GetItemWithError #define __Pyx_PyDict_GetItemStr PyDict_GetItem #else static CYTHON_INLINE PyObject * __Pyx_PyDict_GetItemStrWithError(PyObject *dict, PyObject *name) { #if CYTHON_COMPILING_IN_PYPY return PyDict_GetItem(dict, name); #else PyDictEntry *ep; PyDictObject *mp = (PyDictObject*) dict; long hash = ((PyStringObject *) name)->ob_shash; assert(hash != -1); ep = (mp->ma_lookup)(mp, name, hash); if (ep == NULL) { return NULL; } return ep->me_value; #endif } #define __Pyx_PyDict_GetItemStr PyDict_GetItem #endif #if CYTHON_USE_TYPE_SLOTS #define __Pyx_PyType_GetFlags(tp) (((PyTypeObject *)tp)->tp_flags) #define __Pyx_PyType_HasFeature(type, feature) ((__Pyx_PyType_GetFlags(type) & (feature)) != 0) #else #define __Pyx_PyType_GetFlags(tp) (PyType_GetFlags((PyTypeObject *)tp)) #define __Pyx_PyType_HasFeature(type, feature) PyType_HasFeature(type, feature) #endif #define __Pyx_PyObject_GetIterNextFunc(iterator) __Pyx_PyObject_GetSlot(iterator, tp_iternext, iternextfunc) #if CYTHON_USE_TYPE_SPECS && PY_VERSION_HEX >= 0x03080000 #define __Pyx_PyHeapTypeObject_GC_Del(obj) {\ PyTypeObject *type = Py_TYPE((PyObject*)obj);\ assert(__Pyx_PyType_HasFeature(type, Py_TPFLAGS_HEAPTYPE));\ PyObject_GC_Del(obj);\ Py_DECREF(type);\ } #else #define __Pyx_PyHeapTypeObject_GC_Del(obj) PyObject_GC_Del(obj) #endif #if CYTHON_COMPILING_IN_LIMITED_API #define __Pyx_PyUnicode_READY(op) (0) #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_ReadChar(u, i) #define __Pyx_PyUnicode_MAX_CHAR_VALUE(u) ((void)u, 1114111U) #define __Pyx_PyUnicode_KIND(u) ((void)u, (0)) #define __Pyx_PyUnicode_DATA(u) ((void*)u) #define __Pyx_PyUnicode_READ(k, d, i) ((void)k, PyUnicode_ReadChar((PyObject*)(d), i)) #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GetLength(u)) #else #if PY_VERSION_HEX >= 0x030C0000 #define __Pyx_PyUnicode_READY(op) (0) #else #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ?\ 0 : _PyUnicode_Ready((PyObject *)(op))) #endif #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) ((int)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, (Py_UCS4) ch) #if PY_VERSION_HEX >= 0x030C0000 #define __Pyx_PyUnicode_IS_TRUE(u) (0 != PyUnicode_GET_LENGTH(u)) #else #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x03090000 #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : ((PyCompactUnicodeObject *)(u))->wstr_length)) #else #define __Pyx_PyUnicode_IS_TRUE(u) (0 != (likely(PyUnicode_IS_READY(u)) ? PyUnicode_GET_LENGTH(u) : PyUnicode_GET_SIZE(u))) #endif #endif #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 #if !defined(PyUnicode_DecodeUnicodeEscape) #define PyUnicode_DecodeUnicodeEscape(s, size, errors) PyUnicode_Decode(s, size, "unicode_escape", errors) #endif #if !defined(PyUnicode_Contains) #define PyUnicode_Contains(u, s) PySequence_Contains(u, s) #endif #if !defined(PyByteArray_Check) #define PyByteArray_Check(obj) PyObject_TypeCheck(obj, &PyByteArray_Type) #endif #if !defined(PyObject_Format) #define PyObject_Format(obj, fmt) PyObject_CallMethod(obj, "__format__", "O", fmt) #endif #endif #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 CYTHON_COMPILING_IN_CPYTHON #define __Pyx_PySequence_ListKeepNew(obj)\ (likely(PyList_CheckExact(obj) && Py_REFCNT(obj) == 1) ? __Pyx_NewRef(obj) : PySequence_List(obj)) #else #define __Pyx_PySequence_ListKeepNew(obj) PySequence_List(obj) #endif #ifndef PySet_CheckExact #define PySet_CheckExact(obj) __Pyx_IS_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_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i) #elif CYTHON_COMPILING_IN_LIMITED_API || !CYTHON_ASSUME_SAFE_MACROS #define __Pyx_PyList_GetItemRef(o, i) (likely((i) >= 0) ? PySequence_GetItem(o, i) : (PyErr_SetString(PyExc_IndexError, "list index out of range"), (PyObject*)NULL)) #else #define __Pyx_PyList_GetItemRef(o, i) PySequence_ITEM(o, i) #endif #elif CYTHON_COMPILING_IN_LIMITED_API || !CYTHON_ASSUME_SAFE_MACROS #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 #define __Pyx_PyList_GetItemRef(o, i) PyList_GetItemRef(o, i) #else #define __Pyx_PyList_GetItemRef(o, i) __Pyx_XNewRef(PyList_GetItem(o, i)) #endif #else #define __Pyx_PyList_GetItemRef(o, i) __Pyx_NewRef(PyList_GET_ITEM(o, i)) #endif #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 #define __Pyx_PyDict_GetItemRef(dict, key, result) PyDict_GetItemRef(dict, key, result) #elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { *result = PyObject_GetItem(dict, key); if (*result == NULL) { if (PyErr_ExceptionMatches(PyExc_KeyError)) { PyErr_Clear(); return 0; } return -1; } return 1; } #else static CYTHON_INLINE int __Pyx_PyDict_GetItemRef(PyObject *dict, PyObject *key, PyObject **result) { *result = PyDict_GetItemWithError(dict, key); if (*result == NULL) { return PyErr_Occurred() ? -1 : 0; } Py_INCREF(*result); return 1; } #endif #if defined(CYTHON_DEBUG_VISIT_CONST) && CYTHON_DEBUG_VISIT_CONST #define __Pyx_VISIT_CONST(obj) Py_VISIT(obj) #else #define __Pyx_VISIT_CONST(obj) #endif #if CYTHON_ASSUME_SAFE_MACROS #define __Pyx_PySequence_ITEM(o, i) PySequence_ITEM(o, i) #define __Pyx_PySequence_SIZE(seq) Py_SIZE(seq) #define __Pyx_PyTuple_SET_ITEM(o, i, v) (PyTuple_SET_ITEM(o, i, v), (0)) #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GET_ITEM(o, i) #define __Pyx_PyList_SET_ITEM(o, i, v) (PyList_SET_ITEM(o, i, v), (0)) #define __Pyx_PyList_GET_ITEM(o, i) PyList_GET_ITEM(o, i) #else #define __Pyx_PySequence_ITEM(o, i) PySequence_GetItem(o, i) #define __Pyx_PySequence_SIZE(seq) PySequence_Size(seq) #define __Pyx_PyTuple_SET_ITEM(o, i, v) PyTuple_SetItem(o, i, v) #define __Pyx_PyTuple_GET_ITEM(o, i) PyTuple_GetItem(o, i) #define __Pyx_PyList_SET_ITEM(o, i, v) PyList_SetItem(o, i, v) #define __Pyx_PyList_GET_ITEM(o, i) PyList_GetItem(o, i) #endif #if CYTHON_ASSUME_SAFE_SIZE #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_GET_SIZE(o) #define __Pyx_PyList_GET_SIZE(o) PyList_GET_SIZE(o) #define __Pyx_PySet_GET_SIZE(o) PySet_GET_SIZE(o) #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_GET_SIZE(o) #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_GET_SIZE(o) #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GET_LENGTH(o) #else #define __Pyx_PyTuple_GET_SIZE(o) PyTuple_Size(o) #define __Pyx_PyList_GET_SIZE(o) PyList_Size(o) #define __Pyx_PySet_GET_SIZE(o) PySet_Size(o) #define __Pyx_PyBytes_GET_SIZE(o) PyBytes_Size(o) #define __Pyx_PyByteArray_GET_SIZE(o) PyByteArray_Size(o) #define __Pyx_PyUnicode_GET_LENGTH(o) PyUnicode_GetLength(o) #endif #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 #define __Pyx_PyImport_AddModuleRef(name) PyImport_AddModuleRef(name) #else static CYTHON_INLINE PyObject *__Pyx_PyImport_AddModuleRef(const char *name) { PyObject *module = PyImport_AddModule(name); Py_XINCREF(module); return module; } #endif #if CYTHON_COMPILING_IN_PYPY && !defined(PyUnicode_InternFromString) #define PyUnicode_InternFromString(s) PyUnicode_FromString(s) #endif #define __Pyx_PyLong_FromHash_t PyLong_FromSsize_t #define __Pyx_PyLong_AsHash_t __Pyx_PyIndex_AsSsize_t #if __PYX_LIMITED_VERSION_HEX >= 0x030A0000 #define __Pyx_PySendResult PySendResult #else typedef enum { PYGEN_RETURN = 0, PYGEN_ERROR = -1, PYGEN_NEXT = 1, } __Pyx_PySendResult; #endif #if CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX < 0x030A00A3 typedef __Pyx_PySendResult (*__Pyx_pyiter_sendfunc)(PyObject *iter, PyObject *value, PyObject **result); #else #define __Pyx_pyiter_sendfunc sendfunc #endif #if !CYTHON_USE_AM_SEND #define __PYX_HAS_PY_AM_SEND 0 #elif __PYX_LIMITED_VERSION_HEX >= 0x030A0000 #define __PYX_HAS_PY_AM_SEND 1 #else #define __PYX_HAS_PY_AM_SEND 2 // our own backported implementation #endif #if __PYX_HAS_PY_AM_SEND < 2 #define __Pyx_PyAsyncMethodsStruct PyAsyncMethods #else typedef struct { unaryfunc am_await; unaryfunc am_aiter; unaryfunc am_anext; __Pyx_pyiter_sendfunc am_send; } __Pyx_PyAsyncMethodsStruct; #define __Pyx_SlotTpAsAsync(s) ((PyAsyncMethods*)(s)) #endif #if CYTHON_USE_AM_SEND && PY_VERSION_HEX < 0x030A00F0 #define __Pyx_TPFLAGS_HAVE_AM_SEND (1UL << 21) #else #define __Pyx_TPFLAGS_HAVE_AM_SEND (0) #endif #if PY_VERSION_HEX >= 0x03090000 #define __Pyx_PyInterpreterState_Get() PyInterpreterState_Get() #else #define __Pyx_PyInterpreterState_Get() PyThreadState_Get()->interp #endif #if CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030A0000 #ifdef __cplusplus extern "C" #endif PyAPI_FUNC(void *) PyMem_Calloc(size_t nelem, size_t elsize); #endif #if CYTHON_COMPILING_IN_LIMITED_API static int __Pyx_init_co_variable(PyObject *inspect, const char* name, int *write_to) { int value; PyObject *py_value = PyObject_GetAttrString(inspect, name); if (!py_value) return 0; value = (int) PyLong_AsLong(py_value); Py_DECREF(py_value); *write_to = value; return value != -1 || !PyErr_Occurred(); } static int __Pyx_init_co_variables(void) { PyObject *inspect; int result; inspect = PyImport_ImportModule("inspect"); result = #if !defined(CO_OPTIMIZED) __Pyx_init_co_variable(inspect, "CO_OPTIMIZED", &CO_OPTIMIZED) && #endif #if !defined(CO_NEWLOCALS) __Pyx_init_co_variable(inspect, "CO_NEWLOCALS", &CO_NEWLOCALS) && #endif #if !defined(CO_VARARGS) __Pyx_init_co_variable(inspect, "CO_VARARGS", &CO_VARARGS) && #endif #if !defined(CO_VARKEYWORDS) __Pyx_init_co_variable(inspect, "CO_VARKEYWORDS", &CO_VARKEYWORDS) && #endif #if !defined(CO_ASYNC_GENERATOR) __Pyx_init_co_variable(inspect, "CO_ASYNC_GENERATOR", &CO_ASYNC_GENERATOR) && #endif #if !defined(CO_GENERATOR) __Pyx_init_co_variable(inspect, "CO_GENERATOR", &CO_GENERATOR) && #endif #if !defined(CO_COROUTINE) __Pyx_init_co_variable(inspect, "CO_COROUTINE", &CO_COROUTINE) && #endif 1; Py_DECREF(inspect); return result ? 0 : -1; } #else static int __Pyx_init_co_variables(void) { return 0; // It's a limited API-only feature } #endif /* MathInitCode */ #if defined(_WIN32) || defined(WIN32) || defined(MS_WINDOWS) #ifndef _USE_MATH_DEFINES #define _USE_MATH_DEFINES #endif #endif #include #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 #ifndef CYTHON_CLINE_IN_TRACEBACK_RUNTIME #define CYTHON_CLINE_IN_TRACEBACK_RUNTIME 0 #endif #ifndef CYTHON_CLINE_IN_TRACEBACK #define CYTHON_CLINE_IN_TRACEBACK CYTHON_CLINE_IN_TRACEBACK_RUNTIME #endif #if CYTHON_CLINE_IN_TRACEBACK #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; } #else #define __PYX_MARK_ERR_POS(f_index, lineno) { __pyx_filename = __pyx_f[f_index]; (void) __pyx_filename; __pyx_lineno = lineno; (void) __pyx_lineno; (void) __pyx_clineno; } #endif #define __PYX_ERR(f_index, lineno, Ln_error) \ { __PYX_MARK_ERR_POS(f_index, lineno) goto Ln_error; } #ifdef CYTHON_EXTERN_C #undef __PYX_EXTERN_C #define __PYX_EXTERN_C CYTHON_EXTERN_C #elif defined(__PYX_EXTERN_C) #ifdef _MSC_VER #pragma message ("Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead.") #else #warning Please do not define the '__PYX_EXTERN_C' macro externally. Use 'CYTHON_EXTERN_C' instead. #endif #else #ifdef __cplusplus #define __PYX_EXTERN_C extern "C" #else #define __PYX_EXTERN_C extern #endif #endif #define __PYX_HAVE__intbitset #define __PYX_HAVE_API__intbitset /* Early includes */ #include #include #include "intbitset.h" #ifdef _OPENMP #include #endif /* _OPENMP */ #if defined(PYREX_WITHOUT_ASSERTIONS) && !defined(CYTHON_WITHOUT_ASSERTIONS) #define CYTHON_WITHOUT_ASSERTIONS #endif #define __PYX_DEFAULT_STRING_ENCODING_IS_ASCII 0 #define __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 0 #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 #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 Py_ssize_t __Pyx_ssize_strlen(const char *s); static CYTHON_INLINE const char* __Pyx_PyObject_AsString(PyObject*); static CYTHON_INLINE const char* __Pyx_PyObject_AsStringAndSize(PyObject*, Py_ssize_t* length); static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char*); #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 CYTHON_ASSUME_SAFE_MACROS #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_PyByteArray_AsString(s) PyByteArray_AS_STRING(s) #else #define __Pyx_PyBytes_AsWritableString(s) ((char*) PyBytes_AsString(s)) #define __Pyx_PyBytes_AsWritableSString(s) ((signed char*) PyBytes_AsString(s)) #define __Pyx_PyBytes_AsWritableUString(s) ((unsigned char*) PyBytes_AsString(s)) #define __Pyx_PyBytes_AsString(s) ((const char*) PyBytes_AsString(s)) #define __Pyx_PyBytes_AsSString(s) ((const signed char*) PyBytes_AsString(s)) #define __Pyx_PyBytes_AsUString(s) ((const unsigned char*) PyBytes_AsString(s)) #define __Pyx_PyByteArray_AsString(s) PyByteArray_AsString(s) #endif #define __Pyx_PyObject_AsWritableString(s) ((char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) #define __Pyx_PyObject_AsWritableSString(s) ((signed char*)(__pyx_uintptr_t) __Pyx_PyObject_AsString(s)) #define __Pyx_PyObject_AsWritableUString(s) ((unsigned char*)(__pyx_uintptr_t) __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_PyUnicode_FromCString(s) __Pyx_PyUnicode_FromString((const char*)s) #define __Pyx_PyUnicode_FromOrdinal(o) PyUnicode_FromOrdinal((int)o) #define __Pyx_PyUnicode_AsUnicode PyUnicode_AsUnicode static CYTHON_INLINE PyObject *__Pyx_NewRef(PyObject *obj) { #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_NewRef) return Py_NewRef(obj); #else Py_INCREF(obj); return obj; #endif } static CYTHON_INLINE PyObject *__Pyx_XNewRef(PyObject *obj) { #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030a0000 || defined(Py_XNewRef) return Py_XNewRef(obj); #else Py_XINCREF(obj); return obj; #endif } static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b); 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_Long(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_PyLong_FromSize_t(size_t); static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject*); #if CYTHON_ASSUME_SAFE_MACROS #define __Pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x)) #define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AS_DOUBLE(x) #else #define __Pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x) #define __Pyx_PyFloat_AS_DOUBLE(x) PyFloat_AsDouble(x) #endif #define __Pyx_PyFloat_AsFloat(x) ((float) __Pyx_PyFloat_AsDouble(x)) #define __Pyx_PyNumber_Int(x) (PyLong_CheckExact(x) ? __Pyx_NewRef(x) : PyNumber_Long(x)) #if CYTHON_USE_PYLONG_INTERNALS #if PY_VERSION_HEX >= 0x030C00A7 #ifndef _PyLong_SIGN_MASK #define _PyLong_SIGN_MASK 3 #endif #ifndef _PyLong_NON_SIZE_BITS #define _PyLong_NON_SIZE_BITS 3 #endif #define __Pyx_PyLong_Sign(x) (((PyLongObject*)x)->long_value.lv_tag & _PyLong_SIGN_MASK) #define __Pyx_PyLong_IsNeg(x) ((__Pyx_PyLong_Sign(x) & 2) != 0) #define __Pyx_PyLong_IsNonNeg(x) (!__Pyx_PyLong_IsNeg(x)) #define __Pyx_PyLong_IsZero(x) (__Pyx_PyLong_Sign(x) & 1) #define __Pyx_PyLong_IsPos(x) (__Pyx_PyLong_Sign(x) == 0) #define __Pyx_PyLong_CompactValueUnsigned(x) (__Pyx_PyLong_Digits(x)[0]) #define __Pyx_PyLong_DigitCount(x) ((Py_ssize_t) (((PyLongObject*)x)->long_value.lv_tag >> _PyLong_NON_SIZE_BITS)) #define __Pyx_PyLong_SignedDigitCount(x)\ ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * __Pyx_PyLong_DigitCount(x)) #if defined(PyUnstable_Long_IsCompact) && defined(PyUnstable_Long_CompactValue) #define __Pyx_PyLong_IsCompact(x) PyUnstable_Long_IsCompact((PyLongObject*) x) #define __Pyx_PyLong_CompactValue(x) PyUnstable_Long_CompactValue((PyLongObject*) x) #else #define __Pyx_PyLong_IsCompact(x) (((PyLongObject*)x)->long_value.lv_tag < (2 << _PyLong_NON_SIZE_BITS)) #define __Pyx_PyLong_CompactValue(x) ((1 - (Py_ssize_t) __Pyx_PyLong_Sign(x)) * (Py_ssize_t) __Pyx_PyLong_Digits(x)[0]) #endif typedef Py_ssize_t __Pyx_compact_pylong; typedef size_t __Pyx_compact_upylong; #else #define __Pyx_PyLong_IsNeg(x) (Py_SIZE(x) < 0) #define __Pyx_PyLong_IsNonNeg(x) (Py_SIZE(x) >= 0) #define __Pyx_PyLong_IsZero(x) (Py_SIZE(x) == 0) #define __Pyx_PyLong_IsPos(x) (Py_SIZE(x) > 0) #define __Pyx_PyLong_CompactValueUnsigned(x) ((Py_SIZE(x) == 0) ? 0 : __Pyx_PyLong_Digits(x)[0]) #define __Pyx_PyLong_DigitCount(x) __Pyx_sst_abs(Py_SIZE(x)) #define __Pyx_PyLong_SignedDigitCount(x) Py_SIZE(x) #define __Pyx_PyLong_IsCompact(x) (Py_SIZE(x) == 0 || Py_SIZE(x) == 1 || Py_SIZE(x) == -1) #define __Pyx_PyLong_CompactValue(x)\ ((Py_SIZE(x) == 0) ? (sdigit) 0 : ((Py_SIZE(x) < 0) ? -(sdigit)__Pyx_PyLong_Digits(x)[0] : (sdigit)__Pyx_PyLong_Digits(x)[0])) typedef sdigit __Pyx_compact_pylong; typedef digit __Pyx_compact_upylong; #endif static CYTHON_INLINE int __Pyx_PyLong_CompactAsLong(PyObject *x, long *return_value); #if PY_VERSION_HEX >= 0x030C00A5 #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->long_value.ob_digit) #else #define __Pyx_PyLong_Digits(x) (((PyLongObject*)x)->ob_digit) #endif #endif #if __PYX_DEFAULT_STRING_ENCODING_IS_UTF8 #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeUTF8(c_str, size, NULL) #elif __PYX_DEFAULT_STRING_ENCODING_IS_ASCII #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_DecodeASCII(c_str, size, NULL) #else #define __Pyx_PyUnicode_FromStringAndSize(c_str, size) PyUnicode_Decode(c_str, size, __PYX_DEFAULT_STRING_ENCODING, NULL) #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__ */ /* PretendToInitialize */ #ifdef __cplusplus #if __cplusplus > 201103L #include #endif template static void __Pyx_pretend_to_initialize(T* ptr) { #if __cplusplus > 201103L if ((std::is_trivially_default_constructible::value)) #endif *ptr = T(); (void)ptr; } #else static CYTHON_INLINE void __Pyx_pretend_to_initialize(void* ptr) { (void)ptr; } #endif #if !CYTHON_USE_MODULE_STATE static PyObject *__pyx_m = NULL; #endif static int __pyx_lineno; static int __pyx_clineno = 0; static const char * const __pyx_cfilenm = __FILE__; static const char *__pyx_filename; /* #### Code section: filename_table ### */ static const char* const __pyx_f[] = { "intbitset/intbitset.pyx", "", "cpython/type.pxd", }; /* #### Code section: utility_code_proto_before_types ### */ /* Atomics.proto */ #include #ifndef CYTHON_ATOMICS #define CYTHON_ATOMICS 1 #endif #define __PYX_CYTHON_ATOMICS_ENABLED() CYTHON_ATOMICS #define __PYX_GET_CYTHON_COMPILING_IN_CPYTHON_FREETHREADING() CYTHON_COMPILING_IN_CPYTHON_FREETHREADING #define __pyx_atomic_int_type int #define __pyx_nonatomic_int_type int #if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ (__STDC_VERSION__ >= 201112L) &&\ !defined(__STDC_NO_ATOMICS__)) #include #elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ (__cplusplus >= 201103L) ||\ (defined(_MSC_VER) && _MSC_VER >= 1700))) #include #endif #if CYTHON_ATOMICS && (defined(__STDC_VERSION__) &&\ (__STDC_VERSION__ >= 201112L) &&\ !defined(__STDC_NO_ATOMICS__) &&\ ATOMIC_INT_LOCK_FREE == 2) #undef __pyx_atomic_int_type #define __pyx_atomic_int_type atomic_int #define __pyx_atomic_ptr_type atomic_uintptr_t #define __pyx_nonatomic_ptr_type uintptr_t #define __pyx_atomic_incr_relaxed(value) atomic_fetch_add_explicit(value, 1, memory_order_relaxed) #define __pyx_atomic_incr_acq_rel(value) atomic_fetch_add_explicit(value, 1, memory_order_acq_rel) #define __pyx_atomic_decr_acq_rel(value) atomic_fetch_sub_explicit(value, 1, memory_order_acq_rel) #define __pyx_atomic_sub(value, arg) atomic_fetch_sub(value, arg) #define __pyx_atomic_int_cmp_exchange(value, expected, desired) atomic_compare_exchange_strong(value, expected, desired) #define __pyx_atomic_load(value) atomic_load(value) #define __pyx_atomic_store(value, new_value) atomic_store(value, new_value) #define __pyx_atomic_pointer_load_relaxed(value) atomic_load_explicit(value, memory_order_relaxed) #define __pyx_atomic_pointer_load_acquire(value) atomic_load_explicit(value, memory_order_acquire) #define __pyx_atomic_pointer_exchange(value, new_value) atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) #pragma message ("Using standard C atomics") #elif defined(__PYX_DEBUG_ATOMICS) #warning "Using standard C atomics" #endif #elif CYTHON_ATOMICS && (defined(__cplusplus) && (\ (__cplusplus >= 201103L) ||\ \ (defined(_MSC_VER) && _MSC_VER >= 1700)) &&\ ATOMIC_INT_LOCK_FREE == 2) #undef __pyx_atomic_int_type #define __pyx_atomic_int_type std::atomic_int #define __pyx_atomic_ptr_type std::atomic_uintptr_t #define __pyx_nonatomic_ptr_type uintptr_t #define __pyx_atomic_incr_relaxed(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_relaxed) #define __pyx_atomic_incr_acq_rel(value) std::atomic_fetch_add_explicit(value, 1, std::memory_order_acq_rel) #define __pyx_atomic_decr_acq_rel(value) std::atomic_fetch_sub_explicit(value, 1, std::memory_order_acq_rel) #define __pyx_atomic_sub(value, arg) std::atomic_fetch_sub(value, arg) #define __pyx_atomic_int_cmp_exchange(value, expected, desired) std::atomic_compare_exchange_strong(value, expected, desired) #define __pyx_atomic_load(value) std::atomic_load(value) #define __pyx_atomic_store(value, new_value) std::atomic_store(value, new_value) #define __pyx_atomic_pointer_load_relaxed(value) std::atomic_load_explicit(value, std::memory_order_relaxed) #define __pyx_atomic_pointer_load_acquire(value) std::atomic_load_explicit(value, std::memory_order_acquire) #define __pyx_atomic_pointer_exchange(value, new_value) std::atomic_exchange(value, (__pyx_nonatomic_ptr_type)new_value) #if defined(__PYX_DEBUG_ATOMICS) && defined(_MSC_VER) #pragma message ("Using standard C++ atomics") #elif defined(__PYX_DEBUG_ATOMICS) #warning "Using standard C++ atomics" #endif #elif CYTHON_ATOMICS && (__GNUC__ >= 5 || (__GNUC__ == 4 &&\ (__GNUC_MINOR__ > 1 ||\ (__GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ >= 2)))) #define __pyx_atomic_ptr_type void* #define __pyx_atomic_incr_relaxed(value) __sync_fetch_and_add(value, 1) #define __pyx_atomic_incr_acq_rel(value) __sync_fetch_and_add(value, 1) #define __pyx_atomic_decr_acq_rel(value) __sync_fetch_and_sub(value, 1) #define __pyx_atomic_sub(value, arg) __sync_fetch_and_sub(value, arg) static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { __pyx_nonatomic_int_type old = __sync_val_compare_and_swap(value, *expected, desired); int result = old == *expected; *expected = old; return result; } #define __pyx_atomic_load(value) __sync_fetch_and_add(value, 0) #define __pyx_atomic_store(value, new_value) __sync_lock_test_and_set(value, new_value) #define __pyx_atomic_pointer_load_relaxed(value) __sync_fetch_and_add(value, 0) #define __pyx_atomic_pointer_load_acquire(value) __sync_fetch_and_add(value, 0) #define __pyx_atomic_pointer_exchange(value, new_value) __sync_lock_test_and_set(value, (__pyx_atomic_ptr_type)new_value) #ifdef __PYX_DEBUG_ATOMICS #warning "Using GNU atomics" #endif #elif CYTHON_ATOMICS && defined(_MSC_VER) #include #undef __pyx_atomic_int_type #define __pyx_atomic_int_type long #define __pyx_atomic_ptr_type void* #undef __pyx_nonatomic_int_type #define __pyx_nonatomic_int_type long #pragma intrinsic (_InterlockedExchangeAdd, _InterlockedExchange, _InterlockedCompareExchange, _InterlockedCompareExchangePointer, _InterlockedExchangePointer) #define __pyx_atomic_incr_relaxed(value) _InterlockedExchangeAdd(value, 1) #define __pyx_atomic_incr_acq_rel(value) _InterlockedExchangeAdd(value, 1) #define __pyx_atomic_decr_acq_rel(value) _InterlockedExchangeAdd(value, -1) #define __pyx_atomic_sub(value, arg) _InterlockedExchangeAdd(value, -arg) static CYTHON_INLINE int __pyx_atomic_int_cmp_exchange(__pyx_atomic_int_type* value, __pyx_nonatomic_int_type* expected, __pyx_nonatomic_int_type desired) { __pyx_nonatomic_int_type old = _InterlockedCompareExchange(value, desired, *expected); int result = old == *expected; *expected = old; return result; } #define __pyx_atomic_load(value) _InterlockedExchangeAdd(value, 0) #define __pyx_atomic_store(value, new_value) _InterlockedExchange(value, new_value) #define __pyx_atomic_pointer_load_relaxed(value) *(void * volatile *)value #define __pyx_atomic_pointer_load_acquire(value) _InterlockedCompareExchangePointer(value, 0, 0) #define __pyx_atomic_pointer_exchange(value, new_value) _InterlockedExchangePointer(value, (__pyx_atomic_ptr_type)new_value) #ifdef __PYX_DEBUG_ATOMICS #pragma message ("Using MSVC atomics") #endif #else #undef CYTHON_ATOMICS #define CYTHON_ATOMICS 0 #ifdef __PYX_DEBUG_ATOMICS #warning "Not using atomics" #endif #endif #if CYTHON_ATOMICS #define __pyx_add_acquisition_count(memview)\ __pyx_atomic_incr_relaxed(__pyx_get_slice_count_pointer(memview)) #define __pyx_sub_acquisition_count(memview)\ __pyx_atomic_decr_acq_rel(__pyx_get_slice_count_pointer(memview)) #else #define __pyx_add_acquisition_count(memview)\ __pyx_add_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) #define __pyx_sub_acquisition_count(memview)\ __pyx_sub_acquisition_count_locked(__pyx_get_slice_count_pointer(memview), memview->lock) #endif /* IncludeStructmemberH.proto */ #include /* CriticalSections.proto */ #if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING #define __Pyx_PyCriticalSection void* #define __Pyx_PyCriticalSection2 void* #define __Pyx_PyCriticalSection_Begin1(cs, arg) (void)cs #define __Pyx_PyCriticalSection_Begin2(cs, arg1, arg2) (void)cs #define __Pyx_PyCriticalSection_End1(cs) #define __Pyx_PyCriticalSection_End2(cs) #else #define __Pyx_PyCriticalSection PyCriticalSection #define __Pyx_PyCriticalSection2 PyCriticalSection2 #define __Pyx_PyCriticalSection_Begin1 PyCriticalSection_Begin #define __Pyx_PyCriticalSection_Begin2 PyCriticalSection2_Begin #define __Pyx_PyCriticalSection_End1 PyCriticalSection_End #define __Pyx_PyCriticalSection_End2 PyCriticalSection2_End #endif #if PY_VERSION_HEX < 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API #define __Pyx_BEGIN_CRITICAL_SECTION(o) { #define __Pyx_END_CRITICAL_SECTION() } #else #define __Pyx_BEGIN_CRITICAL_SECTION Py_BEGIN_CRITICAL_SECTION #define __Pyx_END_CRITICAL_SECTION Py_END_CRITICAL_SECTION #endif /* #### Code section: numeric_typedefs ### */ /* #### Code section: complex_type_declarations ### */ /* #### Code section: type_declarations ### */ /*--- Type declarations ---*/ struct __pyx_obj_9intbitset_intbitset; struct __pyx_obj_9intbitset_intbitset_iterator; struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list; /* "intbitset.pyx":750 * return self.bitset.trailing_bits != 0 * * cpdef extract_finite_list(intbitset self, int up_to=-1): # <<<<<<<<<<<<<< * """Return a finite list of elements sufficient to be passed to intbitset * constructor toghether with the proper value of trailing_bits in order */ struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list { int __pyx_n; int up_to; }; /* "intbitset.pyx":108 * __maxelem__ = maxelem * * cdef class intbitset: # <<<<<<<<<<<<<< * """ * Defines an intbitset data object to hold unordered sets of */ struct __pyx_obj_9intbitset_intbitset { PyObject_HEAD struct __pyx_vtabstruct_9intbitset_intbitset *__pyx_vtab; IntBitSet *bitset; int sanity_checks; PyObject *__weakref__; }; /* "intbitset.pyx":786 * cdef object __weakref__ * * cdef class intbitset_iterator: # <<<<<<<<<<<<<< * cdef int last * cdef IntBitSet *bitset */ struct __pyx_obj_9intbitset_intbitset_iterator { PyObject_HEAD int last; IntBitSet *bitset; int sanity_checks; PyObject *__weakref__; }; /* "intbitset.pyx":108 * __maxelem__ = maxelem * * cdef class intbitset: # <<<<<<<<<<<<<< * """ * Defines an intbitset data object to hold unordered sets of */ struct __pyx_vtabstruct_9intbitset_intbitset { PyObject *(*add)(struct __pyx_obj_9intbitset_intbitset *, int, int __pyx_skip_dispatch); PyObject *(*clear)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*discard)(struct __pyx_obj_9intbitset_intbitset *, int, int __pyx_skip_dispatch); PyObject *(*issubset)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch); PyObject *(*issuperset)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch); PyObject *(*fastdump)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*fastload)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch); PyObject *(*copy)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*pop)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*remove)(struct __pyx_obj_9intbitset_intbitset *, int, int __pyx_skip_dispatch); PyObject *(*strbits)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*update_with_signs)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch); PyObject *(*get_size)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*get_allocated)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*is_infinite)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*extract_finite_list)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch, struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list *__pyx_optional_args); PyObject *(*get_wordbitsize)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*get_wordbytsize)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); PyObject *(*tolist)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch); }; static struct __pyx_vtabstruct_9intbitset_intbitset *__pyx_vtabptr_9intbitset_intbitset; /* #### Code section: utility_code_proto ### */ /* --- Runtime support code (head) --- */ /* Refnanny.proto */ #ifndef CYTHON_REFNANNY #define CYTHON_REFNANNY 0 #endif #if CYTHON_REFNANNY typedef struct { void (*INCREF)(void*, PyObject*, Py_ssize_t); void (*DECREF)(void*, PyObject*, Py_ssize_t); void (*GOTREF)(void*, PyObject*, Py_ssize_t); void (*GIVEREF)(void*, PyObject*, Py_ssize_t); void* (*SetupContext)(const char*, Py_ssize_t, 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; #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__));\ } #define __Pyx_RefNannyFinishContextNogil() {\ PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ __Pyx_RefNannyFinishContext();\ PyGILState_Release(__pyx_gilstate_save);\ } #define __Pyx_RefNannyFinishContextNogil() {\ PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure();\ __Pyx_RefNannyFinishContext();\ PyGILState_Release(__pyx_gilstate_save);\ } #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); else {__Pyx_INCREF(r); }} while(0) #define __Pyx_XDECREF(r) do { if((r) == NULL); else {__Pyx_DECREF(r); }} while(0) #define __Pyx_XGOTREF(r) do { if((r) == NULL); else {__Pyx_GOTREF(r); }} while(0) #define __Pyx_XGIVEREF(r) do { if((r) == NULL); else {__Pyx_GIVEREF(r);}} while(0) #else #define __Pyx_RefNannyDeclarations #define __Pyx_RefNannySetupContext(name, acquire_gil) #define __Pyx_RefNannyFinishContextNogil() #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_Py_XDECREF_SET(r, v) do {\ PyObject *tmp = (PyObject *) r;\ r = v; Py_XDECREF(tmp);\ } while (0) #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) /* 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 /* PyThreadStateGet.proto */ #if CYTHON_FAST_THREAD_STATE #define __Pyx_PyThreadState_declare PyThreadState *__pyx_tstate; #define __Pyx_PyThreadState_assign __pyx_tstate = __Pyx_PyThreadState_Current; #if PY_VERSION_HEX >= 0x030C00A6 #define __Pyx_PyErr_Occurred() (__pyx_tstate->current_exception != NULL) #define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->current_exception ? (PyObject*) Py_TYPE(__pyx_tstate->current_exception) : (PyObject*) NULL) #else #define __Pyx_PyErr_Occurred() (__pyx_tstate->curexc_type != NULL) #define __Pyx_PyErr_CurrentExceptionType() (__pyx_tstate->curexc_type) #endif #else #define __Pyx_PyThreadState_declare #define __Pyx_PyThreadState_assign #define __Pyx_PyErr_Occurred() (PyErr_Occurred() != NULL) #define __Pyx_PyErr_CurrentExceptionType() 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 && PY_VERSION_HEX < 0x030C00A6 #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 /* 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 /* PyObjectGetAttrStrNoError.proto */ static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name); /* GetBuiltinName.proto */ static PyObject *__Pyx_GetBuiltinName(PyObject *name); /* TupleAndListFromArray.proto */ #if CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE PyObject* __Pyx_PyList_FromArray(PyObject *const *src, Py_ssize_t n); #endif #if CYTHON_COMPILING_IN_CPYTHON || CYTHON_METH_FASTCALL static CYTHON_INLINE PyObject* __Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n); #endif /* IncludeStringH.proto */ #include /* 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); /* fastcall.proto */ #if CYTHON_AVOID_BORROWED_REFS #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_PySequence_ITEM(args, i) #elif CYTHON_ASSUME_SAFE_MACROS #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_NewRef(__Pyx_PyTuple_GET_ITEM(args, i)) #else #define __Pyx_ArgRef_VARARGS(args, i) __Pyx_XNewRef(PyTuple_GetItem(args, i)) #endif #define __Pyx_NumKwargs_VARARGS(kwds) PyDict_Size(kwds) #define __Pyx_KwValues_VARARGS(args, nargs) NULL #define __Pyx_GetKwValue_VARARGS(kw, kwvalues, s) __Pyx_PyDict_GetItemStrWithError(kw, s) #define __Pyx_KwargsAsDict_VARARGS(kw, kwvalues) PyDict_Copy(kw) #if CYTHON_METH_FASTCALL #define __Pyx_ArgRef_FASTCALL(args, i) __Pyx_NewRef(args[i]) #define __Pyx_NumKwargs_FASTCALL(kwds) __Pyx_PyTuple_GET_SIZE(kwds) #define __Pyx_KwValues_FASTCALL(args, nargs) ((args) + (nargs)) static CYTHON_INLINE PyObject * __Pyx_GetKwValue_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues, PyObject *s); #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API CYTHON_UNUSED static PyObject *__Pyx_KwargsAsDict_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues); #else #define __Pyx_KwargsAsDict_FASTCALL(kw, kwvalues) _PyStack_AsDict(kwvalues, kw) #endif #else #define __Pyx_ArgRef_FASTCALL __Pyx_ArgRef_VARARGS #define __Pyx_NumKwargs_FASTCALL __Pyx_NumKwargs_VARARGS #define __Pyx_KwValues_FASTCALL __Pyx_KwValues_VARARGS #define __Pyx_GetKwValue_FASTCALL __Pyx_GetKwValue_VARARGS #define __Pyx_KwargsAsDict_FASTCALL __Pyx_KwargsAsDict_VARARGS #endif #define __Pyx_ArgsSlice_VARARGS(args, start, stop) PyTuple_GetSlice(args, start, stop) #if CYTHON_METH_FASTCALL || (CYTHON_COMPILING_IN_CPYTHON && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS) #define __Pyx_ArgsSlice_FASTCALL(args, start, stop) __Pyx_PyTuple_FromArray(args + start, stop - start) #else #define __Pyx_ArgsSlice_FASTCALL(args, start, stop) PyTuple_GetSlice(args, start, stop) #endif /* RaiseDoubleKeywords.proto */ static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name); /* ParseKeywords.proto */ static CYTHON_INLINE int __Pyx_ParseKeywords( PyObject *kwds, PyObject *const *kwvalues, PyObject ** const argnames[], PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, Py_ssize_t num_kwargs, const char* function_name, int ignore_unknown_kwargs ); /* CallCFunction.proto */ #define __Pyx_CallCFunction(cfunc, self, args)\ ((PyCFunction)(void(*)(void))(cfunc)->func)(self, args) #define __Pyx_CallCFunctionWithKeywords(cfunc, self, args, kwargs)\ ((PyCFunctionWithKeywords)(void(*)(void))(cfunc)->func)(self, args, kwargs) #define __Pyx_CallCFunctionFast(cfunc, self, args, nargs)\ ((__Pyx_PyCFunctionFast)(void(*)(void))(PyCFunction)(cfunc)->func)(self, args, nargs) #define __Pyx_CallCFunctionFastWithKeywords(cfunc, self, args, nargs, kwnames)\ ((__Pyx_PyCFunctionFastWithKeywords)(void(*)(void))(PyCFunction)(cfunc)->func)(self, args, nargs, kwnames) /* PyFunctionFastCall.proto */ #if CYTHON_FAST_PYCALL #if !CYTHON_VECTORCALL #define __Pyx_PyFunction_FastCall(func, args, nargs)\ __Pyx_PyFunction_FastCallDict((func), (args), (nargs), NULL) static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *args, Py_ssize_t nargs, PyObject *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 #if !CYTHON_VECTORCALL #if PY_VERSION_HEX >= 0x03080000 #include "frameobject.h" #define __Pxy_PyFrame_Initialize_Offsets() #define __Pyx_PyFrame_GetLocalsplus(frame) ((frame)->f_localsplus) #else 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 #endif #endif /* 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 /* PyObjectCallMethO.proto */ #if CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg); #endif /* PyObjectFastCall.proto */ #define __Pyx_PyObject_FastCall(func, args, nargs) __Pyx_PyObject_FastCallDict(func, args, (size_t)(nargs), NULL) static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs); /* UnpackUnboundCMethod.proto */ typedef struct { PyObject *type; PyObject **method_name; #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && CYTHON_ATOMICS __pyx_atomic_int_type initialized; #endif PyCFunction func; PyObject *method; int flag; } __Pyx_CachedCFunction; #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING static CYTHON_INLINE int __Pyx_CachedCFunction_GetAndSetInitializing(__Pyx_CachedCFunction *cfunc) { #if !CYTHON_ATOMICS return 1; #else __pyx_nonatomic_int_type expected = 0; if (__pyx_atomic_int_cmp_exchange(&cfunc->initialized, &expected, 1)) { return 0; } return expected; #endif } static CYTHON_INLINE void __Pyx_CachedCFunction_SetFinishedInitializing(__Pyx_CachedCFunction *cfunc) { #if CYTHON_ATOMICS __pyx_atomic_store(&cfunc->initialized, 2); #endif } #else #define __Pyx_CachedCFunction_GetAndSetInitializing(cfunc) 2 #define __Pyx_CachedCFunction_SetFinishedInitializing(cfunc) #endif /* CallUnboundCMethod2.proto */ CYTHON_UNUSED static PyObject* __Pyx__CallUnboundCMethod2(__Pyx_CachedCFunction* cfunc, PyObject* self, PyObject* arg1, PyObject* arg2); #if CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE PyObject *__Pyx_CallUnboundCMethod2(__Pyx_CachedCFunction *cfunc, PyObject *self, PyObject *arg1, PyObject *arg2); #else #define __Pyx_CallUnboundCMethod2(cfunc, self, arg1, arg2) __Pyx__CallUnboundCMethod2(cfunc, self, arg1, arg2) #endif /* 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); /* RaiseException.proto */ static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause); /* 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) do {\ 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_mstate_global->__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);\ } while(0) #define __Pyx_GetModuleGlobalNameUncached(var, name) do {\ PY_UINT64_T __pyx_dict_version;\ PyObject *__pyx_dict_cached_value;\ (var) = __Pyx__GetModuleGlobalName(name, &__pyx_dict_version, &__pyx_dict_cached_value);\ } while(0) 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 /* PyObjectFastCallMethod.proto */ #if CYTHON_VECTORCALL && PY_VERSION_HEX >= 0x03090000 #define __Pyx_PyObject_FastCallMethod(name, args, nargsf) PyObject_VectorcallMethod(name, args, nargsf, NULL) #else static PyObject *__Pyx_PyObject_FastCallMethod(PyObject *name, PyObject *const *args, size_t nargsf); #endif /* ModInt[Py_ssize_t].proto */ static CYTHON_INLINE Py_ssize_t __Pyx_mod_Py_ssize_t(Py_ssize_t, Py_ssize_t, int b_is_constant); /* 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 && CYTHON_FAST_THREAD_STATE 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 /* PyObject_Unicode.proto */ #define __Pyx_PyObject_Unicode(obj)\ (likely(PyUnicode_CheckExact(obj)) ? __Pyx_NewRef(obj) : PyObject_Str(obj)) /* HasAttr.proto */ #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 #define __Pyx_HasAttr(o, n) PyObject_HasAttrWithError(o, n) #else static CYTHON_INLINE int __Pyx_HasAttr(PyObject *, PyObject *); #endif /* GetItemInt.proto */ #define __Pyx_GetItemInt(o, i, type, is_signed, to_py_func, is_list, wraparound, boundscheck, has_gil)\ (__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, has_gil)\ (__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, has_gil)\ (__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); /* ArgTypeTest.proto */ #define __Pyx_ArgTypeTest(obj, type, none_allowed, name, exact)\ ((likely(__Pyx_IS_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); /* DivInt[int].proto */ static CYTHON_INLINE int __Pyx_div_int(int, int, int b_is_constant); /* UnaryNegOverflows.proto */ #define __Pyx_UNARY_NEG_WOULD_OVERFLOW(x)\ (((x) < 0) & ((unsigned long)(x) == 0-(unsigned long)(x))) /* PyObjectVectorCallKwBuilder.proto */ CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); #if CYTHON_VECTORCALL #if PY_VERSION_HEX >= 0x03090000 #define __Pyx_Object_Vectorcall_CallFromBuilder PyObject_Vectorcall #else #define __Pyx_Object_Vectorcall_CallFromBuilder _PyObject_Vectorcall #endif #define __Pyx_MakeVectorcallBuilderKwds(n) PyTuple_New(n) static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n); static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n); #else #define __Pyx_Object_Vectorcall_CallFromBuilder __Pyx_PyObject_FastCallDict #define __Pyx_MakeVectorcallBuilderKwds(n) __Pyx_PyDict_NewPresized(n) #define __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n) PyDict_SetItem(builder, key, value) #define __Pyx_VectorcallBuilder_AddArgStr(key, value, builder, args, n) PyDict_SetItemString(builder, key, value) #endif /* 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); /* UnicodeConcatInPlace.proto */ # if CYTHON_COMPILING_IN_CPYTHON #if CYTHON_REFNANNY #define __Pyx_PyUnicode_ConcatInPlace(left, right) __Pyx_PyUnicode_ConcatInPlaceImpl(&left, right, __pyx_refnanny) #else #define __Pyx_PyUnicode_ConcatInPlace(left, right) __Pyx_PyUnicode_ConcatInPlaceImpl(&left, right) #endif static CYTHON_INLINE PyObject *__Pyx_PyUnicode_ConcatInPlaceImpl(PyObject **p_left, PyObject *right #if CYTHON_REFNANNY , void* __pyx_refnanny #endif ); #else #define __Pyx_PyUnicode_ConcatInPlace __Pyx_PyUnicode_Concat #endif #define __Pyx_PyUnicode_ConcatInPlaceSafe(left, right) ((unlikely((left) == Py_None) || unlikely((right) == Py_None)) ?\ PyNumber_InPlaceAdd(left, right) : __Pyx_PyUnicode_ConcatInPlace(left, right)) /* PyUnicode_Substring.proto */ static CYTHON_INLINE PyObject* __Pyx_PyUnicode_Substring( PyObject* text, Py_ssize_t start, Py_ssize_t stop); /* RaiseTooManyValuesToUnpack.proto */ static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected); /* RaiseNeedMoreValuesToUnpack.proto */ static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index); /* IterFinish.proto */ static CYTHON_INLINE int __Pyx_IterFinish(void); /* UnpackItemEndCheck.proto */ static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected); /* RejectKeywords.proto */ static void __Pyx_RejectKeywords(const char* function_name, PyObject *kwds); /* 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); #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 L->ob_item[len] = x; #else PyList_SET_ITEM(list, len, x); #endif __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 /* PySequenceMultiply.proto */ #define __Pyx_PySequence_Multiply_Left(mul, seq) __Pyx_PySequence_Multiply(seq, mul) static CYTHON_INLINE PyObject* __Pyx_PySequence_Multiply(PyObject *seq, Py_ssize_t mul); /* ExtTypeTest.proto */ static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type); /* PyObjectCallNoArg.proto */ static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func); /* PyObjectCallOneArg.proto */ static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg); /* PyObjectGetMethod.proto */ static int __Pyx_PyObject_GetMethod(PyObject *obj, PyObject *name, PyObject **method); /* PyObjectCallMethod0.proto */ static PyObject* __Pyx_PyObject_CallMethod0(PyObject* obj, PyObject* method_name); /* RaiseNoneIterError.proto */ static CYTHON_INLINE void __Pyx_RaiseNoneNotIterableError(void); /* UnpackTupleError.proto */ static void __Pyx_UnpackTupleError(PyObject *, Py_ssize_t index); /* UnpackTuple2.proto */ static CYTHON_INLINE int __Pyx_unpack_tuple2( PyObject* tuple, PyObject** value1, PyObject** value2, int is_tuple, int has_known_size, int decref_tuple); static CYTHON_INLINE int __Pyx_unpack_tuple2_exact( PyObject* tuple, PyObject** value1, PyObject** value2, int decref_tuple); static int __Pyx_unpack_tuple2_generic( PyObject* tuple, PyObject** value1, PyObject** value2, int has_known_size, int decref_tuple); /* dict_iter.proto */ static CYTHON_INLINE PyObject* __Pyx_dict_iterator(PyObject* dict, int is_dict, PyObject* method_name, Py_ssize_t* p_orig_length, int* p_is_dict); static CYTHON_INLINE int __Pyx_dict_iter_next(PyObject* dict_or_iter, Py_ssize_t orig_length, Py_ssize_t* ppos, PyObject** pkey, PyObject** pvalue, PyObject** pitem, int is_dict); /* BuildPyUnicode.proto */ static PyObject* __Pyx_PyUnicode_BuildFromAscii(Py_ssize_t ulength, const char* chars, int clength, int prepend_sign, char padding_char); /* COrdinalToPyUnicode.proto */ static CYTHON_INLINE int __Pyx_CheckUnicodeValue(int value); static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromOrdinal_Padded(int value, Py_ssize_t width, char padding_char); /* GCCDiagnostics.proto */ #if !defined(__INTEL_COMPILER) && defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6)) #define __Pyx_HAS_GCC_DIAGNOSTIC #endif /* IncludeStdlibH.proto */ #include /* CIntToPyUnicode.proto */ static CYTHON_INLINE PyObject* __Pyx_PyUnicode_From_int(int value, Py_ssize_t width, char padding_char, char format_char); /* JoinPyUnicode.proto */ static PyObject* __Pyx_PyUnicode_Join(PyObject** values, Py_ssize_t value_count, Py_ssize_t result_ulength, Py_UCS4 max_char); /* LimitedApiGetTypeDict.proto */ #if CYTHON_COMPILING_IN_LIMITED_API static PyObject *__Pyx_GetTypeDict(PyTypeObject *tp); #endif /* SetItemOnTypeDict.proto */ static int __Pyx__SetItemOnTypeDict(PyTypeObject *tp, PyObject *k, PyObject *v); #define __Pyx_SetItemOnTypeDict(tp, k, v) __Pyx__SetItemOnTypeDict((PyTypeObject*)tp, k, v) /* FixUpExtensionType.proto */ static CYTHON_INLINE int __Pyx_fix_up_extension_type_from_spec(PyType_Spec *spec, PyTypeObject *type); /* ValidateBasesTuple.proto */ #if CYTHON_COMPILING_IN_CPYTHON || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_USE_TYPE_SPECS static int __Pyx_validate_bases_tuple(const char *type_name, Py_ssize_t dictoffset, PyObject *bases); #endif /* PyType_Ready.proto */ CYTHON_UNUSED static int __Pyx_PyType_Ready(PyTypeObject *t); /* SetVTable.proto */ static int __Pyx_SetVtable(PyTypeObject* typeptr , void* vtable); /* GetVTable.proto */ static void* __Pyx_GetVtable(PyTypeObject *type); /* MergeVTables.proto */ static int __Pyx_MergeVtables(PyTypeObject *type); /* DelItemOnTypeDict.proto */ static int __Pyx__DelItemOnTypeDict(PyTypeObject *tp, PyObject *k); #define __Pyx_DelItemOnTypeDict(tp, k) __Pyx__DelItemOnTypeDict((PyTypeObject*)tp, k) /* SetupReduce.proto */ static int __Pyx_setup_reduce(PyObject* type_obj); /* TypeImport.proto */ #ifndef __PYX_HAVE_RT_ImportType_proto_3_1_6 #define __PYX_HAVE_RT_ImportType_proto_3_1_6 #if defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112L #include #endif #if (defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112L) || __cplusplus >= 201103L #define __PYX_GET_STRUCT_ALIGNMENT_3_1_6(s) alignof(s) #else #define __PYX_GET_STRUCT_ALIGNMENT_3_1_6(s) sizeof(void*) #endif enum __Pyx_ImportType_CheckSize_3_1_6 { __Pyx_ImportType_CheckSize_Error_3_1_6 = 0, __Pyx_ImportType_CheckSize_Warn_3_1_6 = 1, __Pyx_ImportType_CheckSize_Ignore_3_1_6 = 2 }; static PyTypeObject *__Pyx_ImportType_3_1_6(PyObject* module, const char *module_name, const char *class_name, size_t size, size_t alignment, enum __Pyx_ImportType_CheckSize_3_1_6 check_size); #endif /* Import.proto */ static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level); /* ImportDottedModule.proto */ static PyObject *__Pyx_ImportDottedModule(PyObject *name, PyObject *parts_tuple); static PyObject *__Pyx_ImportDottedModule_WalkParts(PyObject *module, PyObject *name, PyObject *parts_tuple); /* ListPack.proto */ static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...); /* ImportFrom.proto */ static PyObject* __Pyx_ImportFrom(PyObject* module, PyObject* name); /* FetchSharedCythonModule.proto */ static PyObject *__Pyx_FetchSharedCythonABIModule(void); /* dict_setdefault.proto */ static CYTHON_INLINE PyObject *__Pyx_PyDict_SetDefault(PyObject *d, PyObject *key, PyObject *default_value, int is_safe_type); /* FetchCommonType.proto */ static PyTypeObject* __Pyx_FetchCommonTypeFromSpec(PyTypeObject *metaclass, PyObject *module, PyType_Spec *spec, PyObject *bases); /* CommonTypesMetaclass.proto */ static int __pyx_CommonTypesMetaclass_init(PyObject *module); #define __Pyx_CommonTypesMetaclass_USED /* CallTypeTraverse.proto */ #if !CYTHON_USE_TYPE_SPECS || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x03090000) #define __Pyx_call_type_traverse(o, always_call, visit, arg) 0 #else static int __Pyx_call_type_traverse(PyObject *o, int always_call, visitproc visit, void *arg); #endif /* PyMethodNew.proto */ static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ); /* PyVectorcallFastCallDict.proto */ #if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) static CYTHON_INLINE PyObject *__Pyx_PyVectorcall_FastCallDict(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw); #endif /* CythonFunctionShared.proto */ #define __Pyx_CyFunction_USED #define __Pyx_CYFUNCTION_STATICMETHOD 0x01 #define __Pyx_CYFUNCTION_CLASSMETHOD 0x02 #define __Pyx_CYFUNCTION_CCLASS 0x04 #define __Pyx_CYFUNCTION_COROUTINE 0x08 #define __Pyx_CyFunction_GetClosure(f)\ (((__pyx_CyFunctionObject *) (f))->func_closure) #if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API #define __Pyx_CyFunction_GetClassObj(f)\ (((__pyx_CyFunctionObject *) (f))->func_classobj) #else #define __Pyx_CyFunction_GetClassObj(f)\ ((PyObject*) ((PyCMethodObject *) (f))->mm_class) #endif #define __Pyx_CyFunction_SetClassObj(f, classobj)\ __Pyx__CyFunction_SetClassObj((__pyx_CyFunctionObject *) (f), (classobj)) #define __Pyx_CyFunction_Defaults(type, f)\ ((type *)(((__pyx_CyFunctionObject *) (f))->defaults)) #define __Pyx_CyFunction_SetDefaultsGetter(f, g)\ ((__pyx_CyFunctionObject *) (f))->defaults_getter = (g) typedef struct { #if CYTHON_COMPILING_IN_LIMITED_API PyObject_HEAD PyObject *func; #elif PY_VERSION_HEX < 0x030900B1 PyCFunctionObject func; #else PyCMethodObject func; #endif #if CYTHON_BACKPORT_VECTORCALL ||\ (CYTHON_COMPILING_IN_LIMITED_API && CYTHON_METH_FASTCALL) __pyx_vectorcallfunc func_vectorcall; #endif #if CYTHON_COMPILING_IN_LIMITED_API PyObject *func_weakreflist; #endif PyObject *func_dict; PyObject *func_name; PyObject *func_qualname; PyObject *func_doc; PyObject *func_globals; PyObject *func_code; PyObject *func_closure; #if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API PyObject *func_classobj; #endif PyObject *defaults; int flags; PyObject *defaults_tuple; PyObject *defaults_kwdict; PyObject *(*defaults_getter)(PyObject *); PyObject *func_annotations; PyObject *func_is_coroutine; } __pyx_CyFunctionObject; #undef __Pyx_CyOrPyCFunction_Check #define __Pyx_CyFunction_Check(obj) __Pyx_TypeCheck(obj, __pyx_mstate_global->__pyx_CyFunctionType) #define __Pyx_CyOrPyCFunction_Check(obj) __Pyx_TypeCheck2(obj, __pyx_mstate_global->__pyx_CyFunctionType, &PyCFunction_Type) #define __Pyx_CyFunction_CheckExact(obj) __Pyx_IS_TYPE(obj, __pyx_mstate_global->__pyx_CyFunctionType) static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)); #undef __Pyx_IsSameCFunction #define __Pyx_IsSameCFunction(func, cfunc) __Pyx__IsSameCyOrCFunction(func, cfunc) static PyObject *__Pyx_CyFunction_Init(__pyx_CyFunctionObject* op, PyMethodDef *ml, int flags, PyObject* qualname, PyObject *closure, PyObject *module, PyObject *globals, PyObject* code); static CYTHON_INLINE void __Pyx__CyFunction_SetClassObj(__pyx_CyFunctionObject* f, PyObject* classobj); static CYTHON_INLINE PyObject *__Pyx_CyFunction_InitDefaults(PyObject *func, PyTypeObject *defaults_type); static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *m, PyObject *tuple); static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsKwDict(PyObject *m, PyObject *dict); static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *m, PyObject *dict); static int __pyx_CyFunction_init(PyObject *module); #if CYTHON_METH_FASTCALL static PyObject * __Pyx_CyFunction_Vectorcall_NOARGS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); static PyObject * __Pyx_CyFunction_Vectorcall_O(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames); #if CYTHON_BACKPORT_VECTORCALL || CYTHON_COMPILING_IN_LIMITED_API #define __Pyx_CyFunction_func_vectorcall(f) (((__pyx_CyFunctionObject*)f)->func_vectorcall) #else #define __Pyx_CyFunction_func_vectorcall(f) (((PyCFunctionObject*)f)->vectorcall) #endif #endif /* CythonFunction.proto */ static PyObject *__Pyx_CyFunction_New(PyMethodDef *ml, int flags, PyObject* qualname, PyObject *closure, PyObject *module, PyObject *globals, PyObject* code); /* GetNameInClass.proto */ #define __Pyx_GetNameInClass(var, nmspace, name) (var) = __Pyx__GetNameInClass(nmspace, name) static PyObject *__Pyx__GetNameInClass(PyObject *nmspace, PyObject *name); /* CLineInTraceback.proto */ #if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line); #else #define __Pyx_CLineForTraceback(tstate, c_line) (((CYTHON_CLINE_IN_TRACEBACK)) ? c_line : 0) #endif /* CodeObjectCache.proto */ #if CYTHON_COMPILING_IN_LIMITED_API typedef PyObject __Pyx_CachedCodeObjectType; #else typedef PyCodeObject __Pyx_CachedCodeObjectType; #endif typedef struct { __Pyx_CachedCodeObjectType* code_object; int code_line; } __Pyx_CodeObjectCacheEntry; struct __Pyx_CodeObjectCache { int count; int max_count; __Pyx_CodeObjectCacheEntry* entries; #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING __pyx_atomic_int_type accessor_count; #endif }; static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line); static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line); static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* 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_PyLong_From_int(int value); /* CIntFromPy.proto */ static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *); /* CIntToPy.proto */ static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value); /* CIntFromPy.proto */ static CYTHON_INLINE unsigned int __Pyx_PyLong_As_unsigned_int(PyObject *); /* CIntToPy.proto */ static CYTHON_INLINE PyObject* __Pyx_PyLong_From_word_t(word_t value); /* FormatTypeName.proto */ #if CYTHON_COMPILING_IN_LIMITED_API typedef PyObject *__Pyx_TypeName; #define __Pyx_FMT_TYPENAME "%U" #define __Pyx_DECREF_TypeName(obj) Py_XDECREF(obj) #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 #define __Pyx_PyType_GetFullyQualifiedName PyType_GetFullyQualifiedName #else static __Pyx_TypeName __Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp); #endif #else // !LIMITED_API typedef const char *__Pyx_TypeName; #define __Pyx_FMT_TYPENAME "%.200s" #define __Pyx_PyType_GetFullyQualifiedName(tp) ((tp)->tp_name) #define __Pyx_DECREF_TypeName(obj) #endif /* CIntFromPy.proto */ static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *); /* FastTypeChecks.proto */ #if CYTHON_COMPILING_IN_CPYTHON #define __Pyx_TypeCheck(obj, type) __Pyx_IsSubtype(Py_TYPE(obj), (PyTypeObject *)type) #define __Pyx_TypeCheck2(obj, type1, type2) __Pyx_IsAnySubtype2(Py_TYPE(obj), (PyTypeObject *)type1, (PyTypeObject *)type2) static CYTHON_INLINE int __Pyx_IsSubtype(PyTypeObject *a, PyTypeObject *b); static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, 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_TypeCheck2(obj, type1, type2) (PyObject_TypeCheck(obj, (PyTypeObject *)type1) || PyObject_TypeCheck(obj, (PyTypeObject *)type2)) #define __Pyx_PyErr_GivenExceptionMatches(err, type) PyErr_GivenExceptionMatches(err, type) static CYTHON_INLINE int __Pyx_PyErr_GivenExceptionMatches2(PyObject *err, PyObject *type1, PyObject *type2) { return PyErr_GivenExceptionMatches(err, type1) || PyErr_GivenExceptionMatches(err, type2); } #endif #define __Pyx_PyErr_ExceptionMatches2(err1, err2) __Pyx_PyErr_GivenExceptionMatches2(__Pyx_PyErr_CurrentExceptionType(), err1, err2) #define __Pyx_PyException_Check(obj) __Pyx_TypeCheck(obj, PyExc_Exception) #ifdef PyExceptionInstance_Check #define __Pyx_PyBaseException_Check(obj) PyExceptionInstance_Check(obj) #else #define __Pyx_PyBaseException_Check(obj) __Pyx_TypeCheck(obj, PyExc_BaseException) #endif /* GetRuntimeVersion.proto */ static unsigned long __Pyx_get_runtime_version(void); /* CheckBinaryVersion.proto */ static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer); /* MultiPhaseInitModuleState.proto */ #if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE static PyObject *__Pyx_State_FindModule(void*); static int __Pyx_State_AddModule(PyObject* module, void*); static int __Pyx_State_RemoveModule(void*); #elif CYTHON_USE_MODULE_STATE #define __Pyx_State_FindModule PyState_FindModule #define __Pyx_State_AddModule PyState_AddModule #define __Pyx_State_RemoveModule PyState_RemoveModule #endif /* #### Code section: module_declarations ### */ /* CythonABIVersion.proto */ #if CYTHON_COMPILING_IN_LIMITED_API #if CYTHON_METH_FASTCALL #define __PYX_FASTCALL_ABI_SUFFIX "_fastcall" #else #define __PYX_FASTCALL_ABI_SUFFIX #endif #define __PYX_LIMITED_ABI_SUFFIX "limited" __PYX_FASTCALL_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX #else #define __PYX_LIMITED_ABI_SUFFIX #endif #if __PYX_HAS_PY_AM_SEND == 1 #define __PYX_AM_SEND_ABI_SUFFIX #elif __PYX_HAS_PY_AM_SEND == 2 #define __PYX_AM_SEND_ABI_SUFFIX "amsendbackport" #else #define __PYX_AM_SEND_ABI_SUFFIX "noamsend" #endif #ifndef __PYX_MONITORING_ABI_SUFFIX #define __PYX_MONITORING_ABI_SUFFIX #endif #if CYTHON_USE_TP_FINALIZE #define __PYX_TP_FINALIZE_ABI_SUFFIX #else #define __PYX_TP_FINALIZE_ABI_SUFFIX "nofinalize" #endif #if CYTHON_USE_FREELISTS || !defined(__Pyx_AsyncGen_USED) #define __PYX_FREELISTS_ABI_SUFFIX #else #define __PYX_FREELISTS_ABI_SUFFIX "nofreelists" #endif #define CYTHON_ABI __PYX_ABI_VERSION __PYX_LIMITED_ABI_SUFFIX __PYX_MONITORING_ABI_SUFFIX __PYX_TP_FINALIZE_ABI_SUFFIX __PYX_FREELISTS_ABI_SUFFIX __PYX_AM_SEND_ABI_SUFFIX #define __PYX_ABI_MODULE_NAME "_cython_" CYTHON_ABI #define __PYX_TYPE_MODULE_PREFIX __PYX_ABI_MODULE_NAME "." static PyObject *__pyx_f_9intbitset_9intbitset_add(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_clear(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_discard(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_issubset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_issuperset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_fastdump(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_fastload(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_strdump, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_copy(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_pop(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_remove(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_strbits(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_update_with_signs(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_size(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_allocated(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_is_infinite(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_extract_finite_list(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch, struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list *__pyx_optional_args); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_wordbitsize(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_wordbytsize(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_tolist(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch); /* proto*/ /* Module declarations from "cpython.buffer" */ /* Module declarations from "libc.string" */ /* Module declarations from "libc.stdio" */ /* Module declarations from "__builtin__" */ /* Module declarations from "cpython.type" */ /* Module declarations from "cpython" */ /* Module declarations from "cpython.object" */ /* Module declarations from "cpython.ref" */ /* Module declarations from "intbitset" */ /* #### Code section: typeinfo ### */ /* #### Code section: before_global_var ### */ #define __Pyx_MODULE_NAME "intbitset" extern int __pyx_module_is_main_intbitset; int __pyx_module_is_main_intbitset = 0; /* Implementation of "intbitset" */ /* #### Code section: global_var ### */ static PyObject *__pyx_builtin_ValueError; static PyObject *__pyx_builtin_max; static PyObject *__pyx_builtin_OverflowError; static PyObject *__pyx_builtin_TypeError; static PyObject *__pyx_builtin_IndexError; static PyObject *__pyx_builtin_range; static PyObject *__pyx_builtin_KeyError; static PyObject *__pyx_builtin_AttributeError; static PyObject *__pyx_builtin_StopIteration; static PyObject *__pyx_builtin_MemoryError; /* #### Code section: string_decls ### */ static const char __pyx_k_0[] = "0"; static const char __pyx_k_1[] = "1"; static const char __pyx_k_Q[] = "\200\001\330\004\n\210+\220Q"; static const char __pyx_k_i[] = "%i, "; static const char __pyx_k__2[] = "..., "; static const char __pyx_k__3[] = "])"; 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_gc[] = "gc"; static const char __pyx_k_ge[] = "__ge__"; static const char __pyx_k_le[] = "__le__"; static const char __pyx_k_A_q[] = "\200A\330\010\017\210q"; static const char __pyx_k_A_y[] = "\200A\330\010\017\210y\230\001\230\021"; static const char __pyx_k_add[] = "add"; static const char __pyx_k_all[] = "__all__"; static const char __pyx_k_arg[] = "arg"; static const char __pyx_k_cmp[] = "__cmp__"; static const char __pyx_k_max[] = "max"; static const char __pyx_k_pop[] = "pop"; static const char __pyx_k_ret[] = "ret"; static const char __pyx_k_rhs[] = "rhs"; static const char __pyx_k_sys[] = "sys"; static const char __pyx_k_xor[] = "__xor__"; static const char __pyx_k_A_AT[] = "\200A\330\010\017\320\017$\240A\240T\250\021"; static const char __pyx_k_A_iq[] = "\200A\330\010\016\210i\220q\230\001"; static const char __pyx_k_args[] = "args"; static const char __pyx_k_copy[] = "copy"; static const char __pyx_k_dict[] = "__dict__"; static const char __pyx_k_elem[] = "elem"; static const char __pyx_k_func[] = "__func__"; static const char __pyx_k_iarg[] = "iarg"; static const char __pyx_k_iter[] = "__iter__"; static const char __pyx_k_ixor[] = "__ixor__"; static const char __pyx_k_main[] = "__main__"; static const char __pyx_k_memo[] = "memo"; static const char __pyx_k_name[] = "__name__"; static const char __pyx_k_repr[] = "__repr__"; static const char __pyx_k_self[] = "self"; static const char __pyx_k_size[] = ", size: "; static const char __pyx_k_spec[] = "__spec__"; static const char __pyx_k_stop[] = "stop"; static const char __pyx_k_test[] = "__test__"; static const char __pyx_k_zlib[] = "zlib"; static const char __pyx_k_A_at1[] = "\200A\330\010\026\220a\220t\2301"; static const char __pyx_k_A_q_A[] = "\200A\330\010\017\320\017\037\230q\240\004\240A"; static const char __pyx_k_A_t4y[] = "\200A\330\010\017\210t\2204\220y\240\001"; static const char __pyx_k_A_y_2[] = "\200A\340\010\017\210y\230\001\230\021"; static const char __pyx_k_Error[] = "Error"; static const char __pyx_k_array[] = "array"; static const char __pyx_k_clear[] = "clear"; static const char __pyx_k_range[] = "range"; static const char __pyx_k_start[] = "start"; static const char __pyx_k_union[] = "union"; static const char __pyx_k_up_to[] = "up_to"; static const char __pyx_k_A_4y_1[] = "\200A\340\010\017\320\017\"\240!\2404\240y\260\003\2601"; static const char __pyx_k_A_t7_1[] = "\200A\340\010\017\210t\2207\230!\2301"; static const char __pyx_k_A_t7_A[] = "\200A\360\006\000\t\020\210t\2207\230/\250\023\250A"; static const char __pyx_k_bitset[] = "bitset"; static const char __pyx_k_enable[] = "enable"; static const char __pyx_k_module[] = "__module__"; static const char __pyx_k_reduce[] = "__reduce__"; static const char __pyx_k_remove[] = "remove"; static const char __pyx_k_tolist[] = "tolist"; static const char __pyx_k_update[] = "update"; static const char __pyx_k_disable[] = "disable"; static const char __pyx_k_discard[] = "discard"; static const char __pyx_k_getitem[] = "__getitem__"; static const char __pyx_k_indices[] = "indices"; static const char __pyx_k_maxelem[] = "__maxelem__"; static const char __pyx_k_strbits[] = "strbits"; static const char __pyx_k_strdump[] = "strdump"; static const char __pyx_k_tobytes[] = "tobytes"; static const char __pyx_k_version[] = "__version__"; static const char __pyx_k_KeyError[] = "KeyError"; static const char __pyx_k_add_note[] = "add_note"; static const char __pyx_k_compress[] = "compress"; static const char __pyx_k_deepcopy[] = "__deepcopy__"; static const char __pyx_k_fastdump[] = "fastdump"; static const char __pyx_k_fastload[] = "fastload"; static const char __pyx_k_get_size[] = "get_size"; static const char __pyx_k_getstate[] = "__getstate__"; static const char __pyx_k_issubset[] = "issubset"; static const char __pyx_k_qualname[] = "__qualname__"; static const char __pyx_k_set_name[] = "__set_name__"; static const char __pyx_k_setstate[] = "__setstate__"; static const char __pyx_k_tostring[] = "tostring"; static const char __pyx_k_TypeError[] = "TypeError"; static const char __pyx_k_intbitset[] = "intbitset(["; static const char __pyx_k_isenabled[] = "isenabled"; static const char __pyx_k_iteritems[] = "iteritems"; 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_decompress[] = "decompress"; static const char __pyx_k_difference[] = "difference"; static const char __pyx_k_isdisjoint[] = "isdisjoint"; static const char __pyx_k_issuperset[] = "issuperset"; static const char __pyx_k_pyx_vtable[] = "__pyx_vtable__"; static const char __pyx_k_A_4wa_q_t_q[] = "\200A\360\010\000\t\014\2104\210w\220a\330\014\022\220-\230q\240\001\330\010\017\210t\320\023'\240q"; static const char __pyx_k_MemoryError[] = "MemoryError"; static const char __pyx_k_intbitset_2[] = "intbitset"; static const char __pyx_k_intbitset_s[] = "intbitset(%s)"; static const char __pyx_k_is_infinite[] = "is_infinite"; static const char __pyx_k_no_allocate[] = "no_allocate"; static const char __pyx_k_preallocate[] = "preallocate"; static const char __pyx_k_initializing[] = "_initializing"; static const char __pyx_k_intersection[] = "intersection"; static const char __pyx_k_is_coroutine[] = "_is_coroutine"; static const char __pyx_k_stringsource[] = ""; static const char __pyx_k_union_update[] = "union_update"; static const char __pyx_k_A_G1_7_iq_it1[] = "\200A\360\006\000\t\r\210G\2201\330\014\023\2207\230'\240\021\240%\240\177\260i\270q\300\001\330\014\031\230\021\230$\230i\240t\2501"; static const char __pyx_k_OverflowError[] = "OverflowError"; static const char __pyx_k_StopIteration[] = "StopIteration"; static const char __pyx_k_get_allocated[] = "get_allocated"; static const char __pyx_k_intbitset_add[] = "intbitset.add"; static const char __pyx_k_intbitset_pop[] = "intbitset.pop"; static const char __pyx_k_reduce_cython[] = "__reduce_cython__"; static const char __pyx_k_rhs_must_be_s[] = "rhs must be <= %s"; static const char __pyx_k_sanity_checks[] = "sanity_checks"; static const char __pyx_k_trailing_bits[] = "trailing_bits"; static const char __pyx_k_A_G1_7_iq_1D_Q[] = "\200A\360\006\000\t\r\210G\2201\330\014\023\2207\230'\240\021\240%\240\177\260i\270q\300\001\330\014\033\2301\230D\240\t\250\024\250Q"; static const char __pyx_k_A_G1_7_iq_4y_A[] = "\200A\360\006\000\t\r\210G\2201\330\014\023\2207\230'\240\021\240%\240\177\260i\270q\300\001\330\014\"\240!\2404\240y\260\004\260A"; static const char __pyx_k_AttributeError[] = "AttributeError"; static const char __pyx_k_intbitset_copy[] = "intbitset.copy"; static const char __pyx_k_A_at1_4r_1_Ya_q[] = "\200A\360\016\000\t\017\320\016\036\230a\230t\2401\330\010\013\2104\210r\220\021\330\014\022\220(\230!\2301\330\010\030\230\001\230\024\230Y\240a\330\010\017\210q"; static const char __pyx_k_Elements_must_s[] = "Elements must <= %s"; static const char __pyx_k_get_wordbitsize[] = "get_wordbitsize"; static const char __pyx_k_get_wordbytsize[] = "get_wordbytsize"; static const char __pyx_k_intbitset___cmp[] = "intbitset.__cmp__"; static const char __pyx_k_intbitset_clear[] = "intbitset.clear"; static const char __pyx_k_intbitset_union[] = "intbitset.union"; static const char __pyx_k_setstate_cython[] = "__setstate_cython__"; static const char __pyx_k_up_to_must_be_s[] = "up_to must be <= %s"; static const char __pyx_k_intbitset_helper[] = "intbitset_helper"; static const char __pyx_k_intbitset_remove[] = "intbitset.remove"; static const char __pyx_k_intbitset_tolist[] = "intbitset.tolist"; static const char __pyx_k_intbitset_update[] = "intbitset.update"; static const char __pyx_k_Element_must_be_s[] = "Element must be <= %s"; static const char __pyx_k_difference_update[] = "difference_update"; static const char __pyx_k_intbitset_discard[] = "intbitset.discard"; static const char __pyx_k_intbitset_strbits[] = "intbitset.strbits"; static const char __pyx_k_intbitset_version[] = "intbitset_version"; static const char __pyx_k_update_with_signs[] = "update_with_signs"; static const char __pyx_k_A_Yaq_G1_7_iq_Yd_q[] = "\200A\340\010\035\230Y\240a\240q\340\010\014\210G\2201\330\014\023\2207\230'\240\021\240%\240\177\260i\270q\300\001\330\014\031\230\021\230#\230Y\240d\250!\330\010\017\210q"; static const char __pyx_k_Elements_must_be_s[] = "Elements must be <= %s"; static const char __pyx_k_asyncio_coroutines[] = "asyncio.coroutines"; static const char __pyx_k_cline_in_traceback[] = "cline_in_traceback"; static const char __pyx_k_intbitset___reduce[] = "intbitset.__reduce__"; static const char __pyx_k_intbitset_fastdump[] = "intbitset.fastdump"; static const char __pyx_k_intbitset_fastload[] = "intbitset.fastload"; static const char __pyx_k_intbitset_get_size[] = "intbitset.get_size"; static const char __pyx_k_intbitset_issubset[] = "intbitset.issubset"; static const char __pyx_k_intbitset_iterator[] = "intbitset_iterator"; static const char __pyx_k_rhs_is_corrupted_s[] = "rhs is corrupted: %s"; static const char __pyx_k_extract_finite_list[] = "extract_finite_list"; static const char __pyx_k_intersection_update[] = "intersection_update"; static const char __pyx_k_safe_for_unpickling[] = "__safe_for_unpickling__"; static const char __pyx_k_A_Yaq_G1_7_iq_3it1_q[] = "\200A\340\010\035\230Y\240a\240q\340\010\014\210G\2201\330\014\023\2207\230'\240\021\240%\240\177\260i\270q\300\001\330\014\"\240!\2403\240i\250t\2601\330\010\017\210q"; static const char __pyx_k_Unable_to_get_buffer[] = "Unable to get buffer"; static const char __pyx_k_intbitset___deepcopy[] = "intbitset.__deepcopy__"; static const char __pyx_k_intbitset_difference[] = "intbitset.difference"; static const char __pyx_k_intbitset_isdisjoint[] = "intbitset.isdisjoint"; static const char __pyx_k_intbitset_issuperset[] = "intbitset.issuperset"; static const char __pyx_k_strdump_is_corrupted[] = "strdump is corrupted"; static const char __pyx_k_symmetric_difference[] = "symmetric_difference"; static const char __pyx_k_A_4q_uBa_j_b_m1_Ba_Ya[] = "\200A\360\006\000\t\014\2104\210q\330\014\017\210u\220B\220a\330\020\026\220j\240\001\240\021\330\021\026\220b\230\001\330\020\026\220m\2401\320$<\270B\270a\330\010\030\230\001\230\024\230Y\240a"; static const char __pyx_k_A_Yaq_G1_7_iq_1Cy_A_q[] = "\200A\340\010\035\230Y\240a\240q\340\010\014\210G\2201\330\014\023\2207\230'\240\021\240%\240\177\260i\270q\300\001\330\014\033\2301\230C\230y\250\004\250A\330\010\017\210q"; static const char __pyx_k_intbitset_is_infinite[] = "intbitset.is_infinite"; static const char __pyx_k_rhs_can_t_be_negative[] = "rhs can't be negative"; static const char __pyx_k_A_r_U_q_G_e2SPRRS_t9AQ[] = "\200A\360\010\000\t\020\320\017\037\230r\240\034\250U\260!\330\010\016\320\016'\240q\250\010\260\004\260G\270;\300e\3102\310S\320PR\320RS\330\010\017\210t\2209\230A\230Q"; static const char __pyx_k_intbitset_intersection[] = "intbitset.intersection"; static const char __pyx_k_intbitset_get_allocated[] = "intbitset.get_allocated"; static const char __pyx_k_intbitset_intbitset_pyx[] = "intbitset/intbitset.pyx"; static const char __pyx_k_rhs_is_of_unknown_type_s[] = "rhs is of unknown type %s"; static const char __pyx_k_intbitset_get_wordbitsize[] = "intbitset.get_wordbitsize"; static const char __pyx_k_intbitset_get_wordbytsize[] = "intbitset.get_wordbytsize"; static const char __pyx_k_A_4q_uBa_j_b_m1_Rq_AT_AT_1[] = "\200A\360\010\000\t\014\2104\210q\330\014\017\210u\220B\220a\330\020\026\220j\240\001\240\021\330\021\026\220b\230\001\330\020\026\220m\2401\320$=\270R\270q\330\010\013\320\013\034\230A\230T\240\031\250!\330\014\034\230A\230T\240\031\250!\340\014\022\220(\230!\2301"; static const char __pyx_k_intbitset_difference_update[] = "intbitset.difference_update"; static const char __pyx_k_intbitset_update_with_signs[] = "intbitset.update_with_signs"; static const char __pyx_k_symmetric_difference_update[] = "symmetric_difference_update"; static const char __pyx_k_Negative_numbers_not_allowed[] = "Negative numbers, not allowed"; static const char __pyx_k_intbitset_index_out_of_range[] = "intbitset index out of range"; static const char __pyx_k_intbitset_trailing_bits_True[] = "intbitset([...], trailing_bits=True)"; static const char __pyx_k_intbitset_corrupted_allocated[] = "intbitset corrupted: allocated: "; static const char __pyx_k_intbitset_extract_finite_list[] = "intbitset.extract_finite_list"; static const char __pyx_k_intbitset_intersection_update[] = "intbitset.intersection_update"; static const char __pyx_k_9_4_d_q_6b_a_1_j_e2Q_1D_uD_waq[] = "\320\0049\270\021\360\020\000\t\014\2104\210\177\230d\240&\250\002\250!\330\014\022\220-\230q\320 6\260b\270\001\330\010\016\210a\330\010\030\230\001\230\030\320!1\260\021\260$\260j\300\002\300!\330\010\020\220\001\330\010\016\210e\2202\220Q\330\014\023\320\023#\2401\240D\250\t\260\021\330\014\017\210u\220D\230\001\330\020\021\330\014\017\210w\220a\220q\330\010\017\210q"; static const char __pyx_k_intbitset_s_trailing_bits_True[] = "intbitset(%s, trailing_bits=True)"; static const char __pyx_k_A_a_q_t1IS_k_q_nCq_j_d_t1_E_1_1[] = "\200A\360\020\000\t\017\210a\330\010\017\210q\330\010\t\330\014\017\210t\2201\220I\230S\240\001\330\020\032\230'\240\031\250!\340\014\022\220$\220k\240\021\240!\340\014\017\320\017!\240\021\240%\240q\250\006\250n\270C\270q\330\020\026\220j\240\001\240\021\340\014\r\330\020\026\320\026&\240d\250!\330\020\027\220t\2301\340\020\024\220E\230\022\2301\340\024\032\230)\2401\340\020(\250\002\250,\260e\2709\300E\310\021\340\020 \240\001\240\021\240!\360\006\000\r\023\220*\230A\230Q"; static const char __pyx_k_A_t1_G83j_vRq_j_r_m1_B_A_uBa_Ya[] = "\200A\360\010\000\t\n\330\014\017\210t\2201\330\020\024\220G\2308\2403\240j\260\001\330\024\027\220v\230R\230q\330\030\036\230j\250\001\250\021\330\031\037\230r\240\021\330\030\036\230m\2501\320,B\300\"\300A\330\024\027\220u\230B\230a\330\030(\250\001\250\024\250Y\260a\340\030(\250\001\250\024\250Y\260a\340\020\024\220G\2308\2403\240j\260\001\330\024\027\220u\230B\230a\330\030(\250\001\250\024\250Y\260a\340\030(\250\001\250\024\250Y\260a\330\017\020\330\014\022\220)\2301\230A"; static const char __pyx_k_Defines_an_intbitset_data_objec[] = "\nDefines an intbitset data object to hold unordered sets of unsigned\nintegers with ultra fast set operations, implemented via bit vectors\nand Python C extension to optimize speed and memory usage.\n\nEmulates the Python built-in set class interface with some additional\nspecific methods such as its own fast dump and load marshalling\nfunctions. Uses real bits to optimize memory usage, so may have\nissues with endianness if you transport serialized bitsets between\nvarious machine architectures.\n\nPlease note that no bigger than __maxelem__ elements can be added to\nan intbitset and, if CFG_INTBITSET_ENABLE_SANITY_CHECKS is disabled,\nyou will receive unpredictable results.\n\nNote to developers: If you make modification to this file you\nhave to manually regenerate intbitset.c by running:\n $ cython intbitset.pyx\nand then commit generated intbitset.c.\n"; static const char __pyx_k_It_s_impossible_to_iterate_over[] = "It's impossible to iterate over an infinite set."; static const char __pyx_k_retrieving_integers_from_rhs_is[] = "retrieving integers from rhs is impossible: %s"; static const char __pyx_k_A_L_WA_q_q_a_E_was_AQe1A_1AQ_r_a[] = "\200A\360\014\000\t\r\210L\230\005\230W\240A\330\014\022\220-\230q\240\001\330\010\017\210q\330\010\016\210a\330\010\014\210E\220\021\330\014\017\210w\220a\220s\230\"\230A\230Q\230e\2401\240A\330\014\023\2201\220A\220Q\330\010\017\210r\220\025\220a\220q"; static const char __pyx_k_CFG_INTBITSET_ENABLE_SANITY_CHEC[] = "CFG_INTBITSET_ENABLE_SANITY_CHECKS"; static const char __pyx_k_Can_t_store_integers_bigger_than[] = "Can't store integers bigger than %s"; static const char __pyx_k_It_s_impossible_to_print_an_infi[] = "It's impossible to print an infinite set."; static const char __pyx_k_It_s_impossible_to_retrieve_a_li[] = "It's impossible to retrieve a list of an infinite set"; static const char __pyx_k_Note_that_Cython_is_deliberately[] = "Note that Cython is deliberately stricter than PEP-484 and rejects subclasses of builtin types. If you need to pass subclasses then set the 'annotation_typing' directive to False."; static const char __pyx_k_cannot_compare_intbitset_using_c[] = "cannot compare intbitset using cmp()"; static const char __pyx_k_intbitset_iterator___reduce_cyth[] = "intbitset_iterator.__reduce_cython__"; static const char __pyx_k_intbitset_iterator___setstate_cy[] = "intbitset_iterator.__setstate_cython__"; static const char __pyx_k_negative_indexes_are_not_allowed[] = "negative indexes are not allowed on infinite intbitset"; static const char __pyx_k_negative_steps_are_not_yet_suppo[] = "negative steps are not yet supported"; static const char __pyx_k_no_default___reduce___due_to_non[] = "no default __reduce__ due to non-trivial __cinit__"; static const char __pyx_k_pop_from_an_empty_or_infinite_in[] = "pop from an empty or infinite intbitset"; static const char __pyx_k_rhs_should_be_a_valid_dictionary[] = "rhs should be a valid dictionary with integers keys and integer values"; /* #### Code section: decls ### */ static int __pyx_pf_9intbitset_9intbitset___cinit__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_v_preallocate, int __pyx_v_trailing_bits, int __pyx_v_sanity_checks, int __pyx_v_no_allocate); /* proto */ static void __pyx_pf_9intbitset_9intbitset_2__dealloc__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static int __pyx_pf_9intbitset_9intbitset_4__contains__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_6__cmp__(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_8__richcmp__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_v_op); /* proto */ static Py_ssize_t __pyx_pf_9intbitset_9intbitset_10__len__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static Py_hash_t __pyx_pf_9intbitset_9intbitset_12__hash__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static int __pyx_pf_9intbitset_9intbitset_14__nonzero__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_16__deepcopy__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v_memo); /* proto */ static int __pyx_pf_9intbitset_9intbitset_18__delitem__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_20__iadd__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_22__isub__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_24__sub__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_26__and__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_28__iand__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_30__or__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_32__ior__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_34__xor__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_36__ixor__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_38__repr__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_40__str__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_42__getitem__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_key); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_44__reduce__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_46__iter__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_48add(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_50clear(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_52discard(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_54issubset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_56issuperset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_58fastdump(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_60fastload(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_strdump); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_62copy(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_64pop(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_66remove(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_68strbits(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_70update(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_72intersection_update(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_74difference_update(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_76union(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_78intersection(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_80difference(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_82isdisjoint(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_84update_with_signs(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_86get_size(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_88get_allocated(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_90is_infinite(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_92extract_finite_list(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_up_to); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_94get_wordbitsize(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_96get_wordbytsize(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_9intbitset_98tolist(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self); /* proto */ static int __pyx_pf_9intbitset_18intbitset_iterator___cinit__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_bitset); /* proto */ static void __pyx_pf_9intbitset_18intbitset_iterator_2__dealloc__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_4__next__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_6__iter__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_8__reduce_cython__(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_10__setstate_cython__(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v___pyx_state); /* proto */ static PyObject *__pyx_tp_new_9intbitset_intbitset(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/ static PyObject *__pyx_tp_new_9intbitset_intbitset_iterator(PyTypeObject *t, PyObject *a, PyObject *k); /*proto*/ /* #### Code section: late_includes ### */ /* #### Code section: module_state ### */ /* SmallCodeConfig */ #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 typedef struct { PyObject *__pyx_d; PyObject *__pyx_b; PyObject *__pyx_cython_runtime; PyObject *__pyx_empty_tuple; PyObject *__pyx_empty_bytes; PyObject *__pyx_empty_unicode; #ifdef __Pyx_CyFunction_USED PyTypeObject *__pyx_CyFunctionType; #endif #ifdef __Pyx_FusedFunction_USED PyTypeObject *__pyx_FusedFunctionType; #endif #ifdef __Pyx_Generator_USED PyTypeObject *__pyx_GeneratorType; #endif #ifdef __Pyx_IterableCoroutine_USED PyTypeObject *__pyx_IterableCoroutineType; #endif #ifdef __Pyx_Coroutine_USED PyTypeObject *__pyx_CoroutineAwaitType; #endif #ifdef __Pyx_Coroutine_USED PyTypeObject *__pyx_CoroutineType; #endif PyTypeObject *__pyx_ptype_7cpython_4type_type; PyObject *__pyx_type_9intbitset_intbitset; PyObject *__pyx_type_9intbitset_intbitset_iterator; PyTypeObject *__pyx_ptype_9intbitset_intbitset; PyTypeObject *__pyx_ptype_9intbitset_intbitset_iterator; __Pyx_CachedCFunction __pyx_umethod_PyDict_Type_pop; int __pyx_k_; PyObject *__pyx_slice[1]; PyObject *__pyx_tuple[1]; PyObject *__pyx_codeobj_tab[31]; PyObject *__pyx_string_tab[182]; PyObject *__pyx_int_0; PyObject *__pyx_int_1; PyObject *__pyx_int_5; PyObject *__pyx_int_neg_1; /* #### Code section: module_state_contents ### */ /* CommonTypesMetaclass.module_state_decls */ PyTypeObject *__pyx_CommonTypesMetaclassType; /* CachedMethodType.module_state_decls */ #if CYTHON_COMPILING_IN_LIMITED_API PyObject *__Pyx_CachedMethodType; #endif /* CodeObjectCache.module_state_decls */ struct __Pyx_CodeObjectCache __pyx_code_cache; /* #### Code section: module_state_end ### */ } __pyx_mstatetype; #if CYTHON_USE_MODULE_STATE #ifdef __cplusplus namespace { extern struct PyModuleDef __pyx_moduledef; } /* anonymous namespace */ #else static struct PyModuleDef __pyx_moduledef; #endif #define __pyx_mstate_global (__Pyx_PyModule_GetState(__Pyx_State_FindModule(&__pyx_moduledef))) #define __pyx_m (__Pyx_State_FindModule(&__pyx_moduledef)) #else static __pyx_mstatetype __pyx_mstate_global_static = #ifdef __cplusplus {}; #else {0}; #endif static __pyx_mstatetype * const __pyx_mstate_global = &__pyx_mstate_global_static; #endif /* #### Code section: constant_name_defines ### */ #define __pyx_kp_u_0 __pyx_string_tab[0] #define __pyx_kp_u_1 __pyx_string_tab[1] #define __pyx_n_u_AttributeError __pyx_string_tab[2] #define __pyx_n_u_CFG_INTBITSET_ENABLE_SANITY_CHEC __pyx_string_tab[3] #define __pyx_kp_u_Can_t_store_integers_bigger_than __pyx_string_tab[4] #define __pyx_kp_u_Element_must_be_s __pyx_string_tab[5] #define __pyx_kp_u_Elements_must_be_s __pyx_string_tab[6] #define __pyx_kp_u_Elements_must_s __pyx_string_tab[7] #define __pyx_n_u_Error __pyx_string_tab[8] #define __pyx_n_u_IndexError __pyx_string_tab[9] #define __pyx_kp_u_It_s_impossible_to_iterate_over __pyx_string_tab[10] #define __pyx_kp_u_It_s_impossible_to_print_an_infi __pyx_string_tab[11] #define __pyx_kp_u_It_s_impossible_to_retrieve_a_li __pyx_string_tab[12] #define __pyx_n_u_KeyError __pyx_string_tab[13] #define __pyx_n_u_MemoryError __pyx_string_tab[14] #define __pyx_kp_u_Negative_numbers_not_allowed __pyx_string_tab[15] #define __pyx_kp_u_Note_that_Cython_is_deliberately __pyx_string_tab[16] #define __pyx_n_u_OverflowError __pyx_string_tab[17] #define __pyx_n_u_StopIteration __pyx_string_tab[18] #define __pyx_n_u_TypeError __pyx_string_tab[19] #define __pyx_kp_u_Unable_to_get_buffer __pyx_string_tab[20] #define __pyx_n_u_ValueError __pyx_string_tab[21] #define __pyx_kp_u__2 __pyx_string_tab[22] #define __pyx_kp_u__3 __pyx_string_tab[23] #define __pyx_n_u__4 __pyx_string_tab[24] #define __pyx_kp_u__5 __pyx_string_tab[25] #define __pyx_kp_u__6 __pyx_string_tab[26] #define __pyx_kp_u__7 __pyx_string_tab[27] #define __pyx_n_u_add __pyx_string_tab[28] #define __pyx_kp_u_add_note __pyx_string_tab[29] #define __pyx_n_u_all __pyx_string_tab[30] #define __pyx_n_u_arg __pyx_string_tab[31] #define __pyx_n_u_args __pyx_string_tab[32] #define __pyx_n_u_array __pyx_string_tab[33] #define __pyx_n_u_asyncio_coroutines __pyx_string_tab[34] #define __pyx_n_u_bitset __pyx_string_tab[35] #define __pyx_kp_u_cannot_compare_intbitset_using_c __pyx_string_tab[36] #define __pyx_n_u_clear __pyx_string_tab[37] #define __pyx_n_u_cline_in_traceback __pyx_string_tab[38] #define __pyx_n_u_cmp __pyx_string_tab[39] #define __pyx_n_u_compress __pyx_string_tab[40] #define __pyx_n_u_copy __pyx_string_tab[41] #define __pyx_n_u_decompress __pyx_string_tab[42] #define __pyx_n_u_deepcopy __pyx_string_tab[43] #define __pyx_n_u_dict __pyx_string_tab[44] #define __pyx_n_u_difference __pyx_string_tab[45] #define __pyx_n_u_difference_update __pyx_string_tab[46] #define __pyx_kp_u_disable __pyx_string_tab[47] #define __pyx_n_u_discard __pyx_string_tab[48] #define __pyx_n_u_elem __pyx_string_tab[49] #define __pyx_kp_u_enable __pyx_string_tab[50] #define __pyx_n_u_extract_finite_list __pyx_string_tab[51] #define __pyx_n_u_fastdump __pyx_string_tab[52] #define __pyx_n_u_fastload __pyx_string_tab[53] #define __pyx_n_u_func __pyx_string_tab[54] #define __pyx_kp_u_gc __pyx_string_tab[55] #define __pyx_n_u_ge __pyx_string_tab[56] #define __pyx_n_u_get_allocated __pyx_string_tab[57] #define __pyx_n_u_get_size __pyx_string_tab[58] #define __pyx_n_u_get_wordbitsize __pyx_string_tab[59] #define __pyx_n_u_get_wordbytsize __pyx_string_tab[60] #define __pyx_n_u_getitem __pyx_string_tab[61] #define __pyx_n_u_getstate __pyx_string_tab[62] #define __pyx_kp_u_i __pyx_string_tab[63] #define __pyx_n_u_iarg __pyx_string_tab[64] #define __pyx_n_u_indices __pyx_string_tab[65] #define __pyx_n_u_initializing __pyx_string_tab[66] #define __pyx_kp_u_intbitset __pyx_string_tab[67] #define __pyx_n_u_intbitset_2 __pyx_string_tab[68] #define __pyx_n_u_intbitset___cmp __pyx_string_tab[69] #define __pyx_n_u_intbitset___deepcopy __pyx_string_tab[70] #define __pyx_n_u_intbitset___reduce __pyx_string_tab[71] #define __pyx_n_u_intbitset_add __pyx_string_tab[72] #define __pyx_n_u_intbitset_clear __pyx_string_tab[73] #define __pyx_n_u_intbitset_copy __pyx_string_tab[74] #define __pyx_kp_u_intbitset_corrupted_allocated __pyx_string_tab[75] #define __pyx_n_u_intbitset_difference __pyx_string_tab[76] #define __pyx_n_u_intbitset_difference_update __pyx_string_tab[77] #define __pyx_n_u_intbitset_discard __pyx_string_tab[78] #define __pyx_n_u_intbitset_extract_finite_list __pyx_string_tab[79] #define __pyx_n_u_intbitset_fastdump __pyx_string_tab[80] #define __pyx_n_u_intbitset_fastload __pyx_string_tab[81] #define __pyx_n_u_intbitset_get_allocated __pyx_string_tab[82] #define __pyx_n_u_intbitset_get_size __pyx_string_tab[83] #define __pyx_n_u_intbitset_get_wordbitsize __pyx_string_tab[84] #define __pyx_n_u_intbitset_get_wordbytsize __pyx_string_tab[85] #define __pyx_n_u_intbitset_helper __pyx_string_tab[86] #define __pyx_kp_u_intbitset_index_out_of_range __pyx_string_tab[87] #define __pyx_kp_u_intbitset_intbitset_pyx __pyx_string_tab[88] #define __pyx_n_u_intbitset_intersection __pyx_string_tab[89] #define __pyx_n_u_intbitset_intersection_update __pyx_string_tab[90] #define __pyx_n_u_intbitset_is_infinite __pyx_string_tab[91] #define __pyx_n_u_intbitset_isdisjoint __pyx_string_tab[92] #define __pyx_n_u_intbitset_issubset __pyx_string_tab[93] #define __pyx_n_u_intbitset_issuperset __pyx_string_tab[94] #define __pyx_n_u_intbitset_iterator __pyx_string_tab[95] #define __pyx_n_u_intbitset_iterator___reduce_cyth __pyx_string_tab[96] #define __pyx_n_u_intbitset_iterator___setstate_cy __pyx_string_tab[97] #define __pyx_n_u_intbitset_pop __pyx_string_tab[98] #define __pyx_n_u_intbitset_remove __pyx_string_tab[99] #define __pyx_kp_u_intbitset_s __pyx_string_tab[100] #define __pyx_kp_u_intbitset_s_trailing_bits_True __pyx_string_tab[101] #define __pyx_n_u_intbitset_strbits __pyx_string_tab[102] #define __pyx_n_u_intbitset_tolist __pyx_string_tab[103] #define __pyx_kp_u_intbitset_trailing_bits_True __pyx_string_tab[104] #define __pyx_n_u_intbitset_union __pyx_string_tab[105] #define __pyx_n_u_intbitset_update __pyx_string_tab[106] #define __pyx_n_u_intbitset_update_with_signs __pyx_string_tab[107] #define __pyx_n_u_intbitset_version __pyx_string_tab[108] #define __pyx_n_u_intersection __pyx_string_tab[109] #define __pyx_n_u_intersection_update __pyx_string_tab[110] #define __pyx_n_u_is_coroutine __pyx_string_tab[111] #define __pyx_n_u_is_infinite __pyx_string_tab[112] #define __pyx_n_u_isdisjoint __pyx_string_tab[113] #define __pyx_kp_u_isenabled __pyx_string_tab[114] #define __pyx_n_u_issubset __pyx_string_tab[115] #define __pyx_n_u_issuperset __pyx_string_tab[116] #define __pyx_n_u_iter __pyx_string_tab[117] #define __pyx_n_u_iteritems __pyx_string_tab[118] #define __pyx_n_u_ixor __pyx_string_tab[119] #define __pyx_n_u_le __pyx_string_tab[120] #define __pyx_n_u_main __pyx_string_tab[121] #define __pyx_n_u_max __pyx_string_tab[122] #define __pyx_n_u_maxelem __pyx_string_tab[123] #define __pyx_n_u_memo __pyx_string_tab[124] #define __pyx_n_u_module __pyx_string_tab[125] #define __pyx_n_u_name __pyx_string_tab[126] #define __pyx_kp_u_negative_indexes_are_not_allowed __pyx_string_tab[127] #define __pyx_kp_u_negative_steps_are_not_yet_suppo __pyx_string_tab[128] #define __pyx_n_u_no_allocate __pyx_string_tab[129] #define __pyx_kp_u_no_default___reduce___due_to_non __pyx_string_tab[130] #define __pyx_n_u_pop __pyx_string_tab[131] #define __pyx_kp_u_pop_from_an_empty_or_infinite_in __pyx_string_tab[132] #define __pyx_n_u_preallocate __pyx_string_tab[133] #define __pyx_n_u_pyx_state __pyx_string_tab[134] #define __pyx_n_u_pyx_vtable __pyx_string_tab[135] #define __pyx_n_u_qualname __pyx_string_tab[136] #define __pyx_n_u_range __pyx_string_tab[137] #define __pyx_n_u_reduce __pyx_string_tab[138] #define __pyx_n_u_reduce_cython __pyx_string_tab[139] #define __pyx_n_u_reduce_ex __pyx_string_tab[140] #define __pyx_n_u_remove __pyx_string_tab[141] #define __pyx_n_u_repr __pyx_string_tab[142] #define __pyx_n_u_ret __pyx_string_tab[143] #define __pyx_kp_u_retrieving_integers_from_rhs_is __pyx_string_tab[144] #define __pyx_n_u_rhs __pyx_string_tab[145] #define __pyx_kp_u_rhs_can_t_be_negative __pyx_string_tab[146] #define __pyx_kp_u_rhs_is_corrupted_s __pyx_string_tab[147] #define __pyx_kp_u_rhs_is_of_unknown_type_s __pyx_string_tab[148] #define __pyx_kp_u_rhs_must_be_s __pyx_string_tab[149] #define __pyx_kp_u_rhs_should_be_a_valid_dictionary __pyx_string_tab[150] #define __pyx_n_u_safe_for_unpickling __pyx_string_tab[151] #define __pyx_n_u_sanity_checks __pyx_string_tab[152] #define __pyx_n_u_self __pyx_string_tab[153] #define __pyx_n_u_set_name __pyx_string_tab[154] #define __pyx_n_u_setstate __pyx_string_tab[155] #define __pyx_n_u_setstate_cython __pyx_string_tab[156] #define __pyx_kp_u_size __pyx_string_tab[157] #define __pyx_n_u_spec __pyx_string_tab[158] #define __pyx_n_u_start __pyx_string_tab[159] #define __pyx_n_u_stop __pyx_string_tab[160] #define __pyx_n_u_strbits __pyx_string_tab[161] #define __pyx_n_u_strdump __pyx_string_tab[162] #define __pyx_kp_u_strdump_is_corrupted __pyx_string_tab[163] #define __pyx_kp_u_stringsource __pyx_string_tab[164] #define __pyx_n_u_symmetric_difference __pyx_string_tab[165] #define __pyx_n_u_symmetric_difference_update __pyx_string_tab[166] #define __pyx_n_u_sys __pyx_string_tab[167] #define __pyx_n_u_test __pyx_string_tab[168] #define __pyx_n_u_tobytes __pyx_string_tab[169] #define __pyx_n_u_tolist __pyx_string_tab[170] #define __pyx_n_u_tostring __pyx_string_tab[171] #define __pyx_n_u_trailing_bits __pyx_string_tab[172] #define __pyx_n_u_union __pyx_string_tab[173] #define __pyx_n_u_union_update __pyx_string_tab[174] #define __pyx_n_u_up_to __pyx_string_tab[175] #define __pyx_kp_u_up_to_must_be_s __pyx_string_tab[176] #define __pyx_n_u_update __pyx_string_tab[177] #define __pyx_n_u_update_with_signs __pyx_string_tab[178] #define __pyx_n_u_version __pyx_string_tab[179] #define __pyx_n_u_xor __pyx_string_tab[180] #define __pyx_n_u_zlib __pyx_string_tab[181] /* #### Code section: module_state_clear ### */ #if CYTHON_USE_MODULE_STATE static CYTHON_SMALL_CODE int __pyx_m_clear(PyObject *m) { __pyx_mstatetype *clear_module_state = __Pyx_PyModule_GetState(m); if (!clear_module_state) return 0; Py_CLEAR(clear_module_state->__pyx_d); Py_CLEAR(clear_module_state->__pyx_b); Py_CLEAR(clear_module_state->__pyx_cython_runtime); Py_CLEAR(clear_module_state->__pyx_empty_tuple); Py_CLEAR(clear_module_state->__pyx_empty_bytes); Py_CLEAR(clear_module_state->__pyx_empty_unicode); #ifdef __Pyx_CyFunction_USED Py_CLEAR(clear_module_state->__pyx_CyFunctionType); #endif #ifdef __Pyx_FusedFunction_USED Py_CLEAR(clear_module_state->__pyx_FusedFunctionType); #endif #if CYTHON_PEP489_MULTI_PHASE_INIT __Pyx_State_RemoveModule(NULL); #endif Py_CLEAR(clear_module_state->__pyx_ptype_7cpython_4type_type); Py_CLEAR(clear_module_state->__pyx_ptype_9intbitset_intbitset); Py_CLEAR(clear_module_state->__pyx_type_9intbitset_intbitset); Py_CLEAR(clear_module_state->__pyx_ptype_9intbitset_intbitset_iterator); Py_CLEAR(clear_module_state->__pyx_type_9intbitset_intbitset_iterator); for (int i=0; i<1; ++i) { Py_CLEAR(clear_module_state->__pyx_slice[i]); } for (int i=0; i<1; ++i) { Py_CLEAR(clear_module_state->__pyx_tuple[i]); } for (int i=0; i<31; ++i) { Py_CLEAR(clear_module_state->__pyx_codeobj_tab[i]); } for (int i=0; i<182; ++i) { Py_CLEAR(clear_module_state->__pyx_string_tab[i]); } Py_CLEAR(clear_module_state->__pyx_int_0); Py_CLEAR(clear_module_state->__pyx_int_1); Py_CLEAR(clear_module_state->__pyx_int_5); Py_CLEAR(clear_module_state->__pyx_int_neg_1); return 0; } #endif /* #### Code section: module_state_traverse ### */ #if CYTHON_USE_MODULE_STATE static CYTHON_SMALL_CODE int __pyx_m_traverse(PyObject *m, visitproc visit, void *arg) { __pyx_mstatetype *traverse_module_state = __Pyx_PyModule_GetState(m); if (!traverse_module_state) return 0; Py_VISIT(traverse_module_state->__pyx_d); Py_VISIT(traverse_module_state->__pyx_b); Py_VISIT(traverse_module_state->__pyx_cython_runtime); __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_tuple); __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_bytes); __Pyx_VISIT_CONST(traverse_module_state->__pyx_empty_unicode); #ifdef __Pyx_CyFunction_USED Py_VISIT(traverse_module_state->__pyx_CyFunctionType); #endif #ifdef __Pyx_FusedFunction_USED Py_VISIT(traverse_module_state->__pyx_FusedFunctionType); #endif Py_VISIT(traverse_module_state->__pyx_ptype_7cpython_4type_type); Py_VISIT(traverse_module_state->__pyx_ptype_9intbitset_intbitset); Py_VISIT(traverse_module_state->__pyx_type_9intbitset_intbitset); Py_VISIT(traverse_module_state->__pyx_ptype_9intbitset_intbitset_iterator); Py_VISIT(traverse_module_state->__pyx_type_9intbitset_intbitset_iterator); for (int i=0; i<1; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_slice[i]); } for (int i=0; i<1; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_tuple[i]); } for (int i=0; i<31; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_codeobj_tab[i]); } for (int i=0; i<182; ++i) { __Pyx_VISIT_CONST(traverse_module_state->__pyx_string_tab[i]); } __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_0); __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_1); __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_5); __Pyx_VISIT_CONST(traverse_module_state->__pyx_int_neg_1); return 0; } #endif /* #### Code section: module_code ### */ /* "intbitset.pyx":160 * cdef bint sanity_checks * * def __cinit__( # <<<<<<<<<<<<<< * self not None, * rhs=0, */ /* Python wrapper */ static int __pyx_pw_9intbitset_9intbitset_1__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static int __pyx_pw_9intbitset_9intbitset_1__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_rhs = 0; int __pyx_v_preallocate; int __pyx_v_trailing_bits; int __pyx_v_sanity_checks; int __pyx_v_no_allocate; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[5] = {0,0,0,0,0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__ (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_rhs,&__pyx_mstate_global->__pyx_n_u_preallocate,&__pyx_mstate_global->__pyx_n_u_trailing_bits,&__pyx_mstate_global->__pyx_n_u_sanity_checks,&__pyx_mstate_global->__pyx_n_u_no_allocate,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 160, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 5: values[4] = __Pyx_ArgRef_VARARGS(__pyx_args, 4); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 4: values[3] = __Pyx_ArgRef_VARARGS(__pyx_args, 3); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 3: values[2] = __Pyx_ArgRef_VARARGS(__pyx_args, 2); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 2: values[1] = __Pyx_ArgRef_VARARGS(__pyx_args, 1); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 1: values[0] = __Pyx_ArgRef_VARARGS(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__cinit__", 0) < (0)) __PYX_ERR(0, 160, __pyx_L3_error) if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_int_0)); } else { switch (__pyx_nargs) { case 5: values[4] = __Pyx_ArgRef_VARARGS(__pyx_args, 4); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[4])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 4: values[3] = __Pyx_ArgRef_VARARGS(__pyx_args, 3); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[3])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 3: values[2] = __Pyx_ArgRef_VARARGS(__pyx_args, 2); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[2])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 2: values[1] = __Pyx_ArgRef_VARARGS(__pyx_args, 1); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[1])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 1: values[0] = __Pyx_ArgRef_VARARGS(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 160, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } if (!values[0]) values[0] = __Pyx_NewRef(((PyObject *)__pyx_mstate_global->__pyx_int_0)); } __pyx_v_rhs = values[0]; if (values[1]) { __pyx_v_preallocate = __Pyx_PyLong_As_int(values[1]); if (unlikely((__pyx_v_preallocate == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 163, __pyx_L3_error) } else { __pyx_v_preallocate = ((int)-1); } if (values[2]) { __pyx_v_trailing_bits = __Pyx_PyLong_As_int(values[2]); if (unlikely((__pyx_v_trailing_bits == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 164, __pyx_L3_error) } else { __pyx_v_trailing_bits = ((int)0); } if (values[3]) { __pyx_v_sanity_checks = __Pyx_PyObject_IsTrue(values[3]); if (unlikely((__pyx_v_sanity_checks == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 165, __pyx_L3_error) } else { __pyx_v_sanity_checks = __pyx_mstate_global->__pyx_k_; } if (values[4]) { __pyx_v_no_allocate = __Pyx_PyLong_As_int(values[4]); if (unlikely((__pyx_v_no_allocate == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 166, __pyx_L3_error) } else { __pyx_v_no_allocate = ((int)0); } } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__cinit__", 0, 0, 5, __pyx_nargs); __PYX_ERR(0, 160, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return -1; __pyx_L4_argument_unpacking_done:; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 161, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset___cinit__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_rhs, __pyx_v_preallocate, __pyx_v_trailing_bits, __pyx_v_sanity_checks, __pyx_v_no_allocate); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } goto __pyx_L7_cleaned_up; __pyx_L0:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __pyx_L7_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_9intbitset_9intbitset___cinit__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_v_preallocate, int __pyx_v_trailing_bits, int __pyx_v_sanity_checks, int __pyx_v_no_allocate) { Py_ssize_t __pyx_v_size; const void* __pyx_v_buf; int __pyx_v_elem; int __pyx_v_last; int __pyx_v_remelem; int __pyx_v_tuple_of_tuples; Py_buffer __pyx_v_view; CYTHON_UNUSED PyObject *__pyx_v_msg = NULL; PyObject *__pyx_v_tmp = NULL; PyObject *__pyx_v_e = NULL; PyObject *__pyx_v_tmp_tuple = NULL; int __pyx_r; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_t_4; PyObject *__pyx_t_5 = NULL; PyObject *__pyx_t_6 = NULL; int __pyx_t_7; PyObject *__pyx_t_8 = NULL; size_t __pyx_t_9; int __pyx_t_10; PyObject *__pyx_t_11 = NULL; PyObject *__pyx_t_12 = NULL; PyObject *__pyx_t_13 = NULL; PyObject *__pyx_t_14 = NULL; Py_ssize_t __pyx_t_15; int __pyx_t_16; char const *__pyx_t_17; PyObject *__pyx_t_18 = NULL; PyObject *__pyx_t_19 = NULL; PyObject *__pyx_t_20 = NULL; PyObject *__pyx_t_21 = NULL; PyObject *__pyx_t_22 = NULL; PyObject *__pyx_t_23 = NULL; PyObject *__pyx_t_24 = NULL; PyObject *__pyx_t_25 = NULL; PyObject *__pyx_t_26 = NULL; PyObject *__pyx_t_27 = NULL; int __pyx_t_28; PyObject *(*__pyx_t_29)(PyObject *); int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__cinit__", 0); __Pyx_INCREF(__pyx_v_rhs); /* "intbitset.pyx":168 * int no_allocate=0, * ): * cdef Py_ssize_t size = 0 # <<<<<<<<<<<<<< * cdef const_void_ptr buf = NULL * cdef int elem */ __pyx_v_size = 0; /* "intbitset.pyx":169 * ): * cdef Py_ssize_t size = 0 * cdef const_void_ptr buf = NULL # <<<<<<<<<<<<<< * cdef int elem * cdef int last */ __pyx_v_buf = NULL; /* "intbitset.pyx":176 * cdef Py_buffer view * * self.sanity_checks = sanity_checks # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset.__cinit__ is called" * msg = "Error" */ __pyx_v_self->sanity_checks = __pyx_v_sanity_checks; /* "intbitset.pyx":178 * self.sanity_checks = sanity_checks * #print >> sys.stderr, "intbitset.__cinit__ is called" * msg = "Error" # <<<<<<<<<<<<<< * self.bitset = NULL * try: */ __Pyx_INCREF(__pyx_mstate_global->__pyx_n_u_Error); __pyx_v_msg = __pyx_mstate_global->__pyx_n_u_Error; /* "intbitset.pyx":179 * #print >> sys.stderr, "intbitset.__cinit__ is called" * msg = "Error" * self.bitset = NULL # <<<<<<<<<<<<<< * try: * if no_allocate: */ __pyx_v_self->bitset = NULL; /* "intbitset.pyx":180 * msg = "Error" * self.bitset = NULL * try: # <<<<<<<<<<<<<< * if no_allocate: * return */ { __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:*/ { /* "intbitset.pyx":181 * self.bitset = NULL * try: * if no_allocate: # <<<<<<<<<<<<<< * return * if type(rhs) in (int, long): */ __pyx_t_4 = (__pyx_v_no_allocate != 0); if (__pyx_t_4) { /* "intbitset.pyx":182 * try: * if no_allocate: * return # <<<<<<<<<<<<<< * if type(rhs) in (int, long): * if rhs < 0: */ __pyx_r = 0; goto __pyx_L7_try_return; /* "intbitset.pyx":181 * self.bitset = NULL * try: * if no_allocate: # <<<<<<<<<<<<<< * return * if type(rhs) in (int, long): */ } /* "intbitset.pyx":183 * if no_allocate: * return * if type(rhs) in (int, long): # <<<<<<<<<<<<<< * if rhs < 0: * raise ValueError("rhs can't be negative") */ __Pyx_INCREF(((PyObject *)Py_TYPE(__pyx_v_rhs))); __pyx_t_5 = ((PyObject *)Py_TYPE(__pyx_v_rhs)); __pyx_t_6 = PyObject_RichCompare(((PyObject *)__pyx_t_5), ((PyObject *)(&PyLong_Type)), Py_EQ); __Pyx_XGOTREF(__pyx_t_6); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 183, __pyx_L3_error) __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 183, __pyx_L3_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (!__pyx_t_7) { } else { __pyx_t_4 = __pyx_t_7; goto __pyx_L11_bool_binop_done; } __pyx_t_6 = PyObject_RichCompare(((PyObject *)__pyx_t_5), ((PyObject *)(&PyLong_Type)), Py_EQ); __Pyx_XGOTREF(__pyx_t_6); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 183, __pyx_L3_error) __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 183, __pyx_L3_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_4 = __pyx_t_7; __pyx_L11_bool_binop_done:; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __pyx_t_4; if (__pyx_t_7) { /* "intbitset.pyx":184 * return * if type(rhs) in (int, long): * if rhs < 0: # <<<<<<<<<<<<<< * raise ValueError("rhs can't be negative") * self.bitset = intBitSetCreate(rhs, trailing_bits) */ __pyx_t_5 = PyObject_RichCompare(__pyx_v_rhs, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 184, __pyx_L3_error) __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 184, __pyx_L3_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":185 * if type(rhs) in (int, long): * if rhs < 0: * raise ValueError("rhs can't be negative") # <<<<<<<<<<<<<< * self.bitset = intBitSetCreate(rhs, trailing_bits) * elif type(rhs) is intbitset: */ __pyx_t_6 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_8 = __pyx_builtin_ValueError; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_mstate_global->__pyx_kp_u_rhs_can_t_be_negative}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 185, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_5); } __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __PYX_ERR(0, 185, __pyx_L3_error) /* "intbitset.pyx":184 * return * if type(rhs) in (int, long): * if rhs < 0: # <<<<<<<<<<<<<< * raise ValueError("rhs can't be negative") * self.bitset = intBitSetCreate(rhs, trailing_bits) */ } /* "intbitset.pyx":186 * if rhs < 0: * raise ValueError("rhs can't be negative") * self.bitset = intBitSetCreate(rhs, trailing_bits) # <<<<<<<<<<<<<< * elif type(rhs) is intbitset: * self.bitset = intBitSetClone((rhs).bitset) */ __pyx_t_10 = __Pyx_PyLong_As_int(__pyx_v_rhs); if (unlikely((__pyx_t_10 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 186, __pyx_L3_error) __pyx_v_self->bitset = intBitSetCreate(__pyx_t_10, __pyx_v_trailing_bits); /* "intbitset.pyx":183 * if no_allocate: * return * if type(rhs) in (int, long): # <<<<<<<<<<<<<< * if rhs < 0: * raise ValueError("rhs can't be negative") */ goto __pyx_L10; } /* "intbitset.pyx":187 * raise ValueError("rhs can't be negative") * self.bitset = intBitSetCreate(rhs, trailing_bits) * elif type(rhs) is intbitset: # <<<<<<<<<<<<<< * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): */ __pyx_t_7 = (((PyObject *)Py_TYPE(__pyx_v_rhs)) == ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset)); if (__pyx_t_7) { /* "intbitset.pyx":188 * self.bitset = intBitSetCreate(rhs, trailing_bits) * elif type(rhs) is intbitset: * self.bitset = intBitSetClone((rhs).bitset) # <<<<<<<<<<<<<< * elif type(rhs) in (bytes, array): * try: */ __pyx_v_self->bitset = intBitSetClone(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)->bitset); /* "intbitset.pyx":187 * raise ValueError("rhs can't be negative") * self.bitset = intBitSetCreate(rhs, trailing_bits) * elif type(rhs) is intbitset: # <<<<<<<<<<<<<< * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): */ goto __pyx_L10; } /* "intbitset.pyx":189 * elif type(rhs) is intbitset: * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): # <<<<<<<<<<<<<< * try: * if type(rhs) is array: */ __Pyx_INCREF(((PyObject *)Py_TYPE(__pyx_v_rhs))); __pyx_t_5 = ((PyObject *)Py_TYPE(__pyx_v_rhs)); __pyx_t_8 = PyObject_RichCompare(((PyObject *)__pyx_t_5), ((PyObject *)(&PyBytes_Type)), Py_EQ); __Pyx_XGOTREF(__pyx_t_8); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 189, __pyx_L3_error) __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_8); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 189, __pyx_L3_error) __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (!__pyx_t_4) { } else { __pyx_t_7 = __pyx_t_4; goto __pyx_L14_bool_binop_done; } __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 189, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_6 = PyObject_RichCompare(((PyObject *)__pyx_t_5), __pyx_t_8, Py_EQ); __Pyx_XGOTREF(__pyx_t_6); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 189, __pyx_L3_error) __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_6); if (unlikely((__pyx_t_4 < 0))) __PYX_ERR(0, 189, __pyx_L3_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_7 = __pyx_t_4; __pyx_L14_bool_binop_done:; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_4 = __pyx_t_7; if (__pyx_t_4) { /* "intbitset.pyx":190 * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): * try: # <<<<<<<<<<<<<< * if type(rhs) is array: * rhs = rhs.tobytes() */ { __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __Pyx_ExceptionSave(&__pyx_t_11, &__pyx_t_12, &__pyx_t_13); __Pyx_XGOTREF(__pyx_t_11); __Pyx_XGOTREF(__pyx_t_12); __Pyx_XGOTREF(__pyx_t_13); /*try:*/ { /* "intbitset.pyx":191 * elif type(rhs) in (bytes, array): * try: * if type(rhs) is array: # <<<<<<<<<<<<<< * rhs = rhs.tobytes() * tmp = zlib.decompress(rhs) */ __Pyx_GetModuleGlobalName(__pyx_t_5, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 191, __pyx_L16_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_4 = (((PyObject *)Py_TYPE(__pyx_v_rhs)) == __pyx_t_5); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_4) { /* "intbitset.pyx":192 * try: * if type(rhs) is array: * rhs = rhs.tobytes() # <<<<<<<<<<<<<< * tmp = zlib.decompress(rhs) * */ __pyx_t_6 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_6); __pyx_t_9 = 0; { PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL}; __pyx_t_5 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_tobytes, __pyx_callargs+__pyx_t_9, (1-__pyx_t_9) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 192, __pyx_L16_error) __Pyx_GOTREF(__pyx_t_5); } __Pyx_DECREF_SET(__pyx_v_rhs, __pyx_t_5); __pyx_t_5 = 0; /* "intbitset.pyx":191 * elif type(rhs) in (bytes, array): * try: * if type(rhs) is array: # <<<<<<<<<<<<<< * rhs = rhs.tobytes() * tmp = zlib.decompress(rhs) */ } /* "intbitset.pyx":193 * if type(rhs) is array: * rhs = rhs.tobytes() * tmp = zlib.decompress(rhs) # <<<<<<<<<<<<<< * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: */ __pyx_t_6 = NULL; __Pyx_GetModuleGlobalName(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_zlib); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 193, __pyx_L16_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_14 = __Pyx_PyObject_GetAttrStr(__pyx_t_8, __pyx_mstate_global->__pyx_n_u_decompress); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 193, __pyx_L16_error) __Pyx_GOTREF(__pyx_t_14); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_14))) { __pyx_t_6 = PyMethod_GET_SELF(__pyx_t_14); assert(__pyx_t_6); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_14); __Pyx_INCREF(__pyx_t_6); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_14, __pyx__function); __pyx_t_9 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_rhs}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 193, __pyx_L16_error) __Pyx_GOTREF(__pyx_t_5); } __pyx_v_tmp = __pyx_t_5; __pyx_t_5 = 0; /* "intbitset.pyx":195 * tmp = zlib.decompress(rhs) * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: # <<<<<<<<<<<<<< * raise ValueError("Unable to get buffer") * */ __pyx_t_10 = PyObject_GetBuffer(__pyx_v_tmp, (&__pyx_v_view), PyBUF_SIMPLE); if (unlikely(__pyx_t_10 == ((int)-1))) __PYX_ERR(0, 195, __pyx_L16_error) __pyx_t_4 = (__pyx_t_10 != 0); if (unlikely(__pyx_t_4)) { /* "intbitset.pyx":196 * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: * raise ValueError("Unable to get buffer") # <<<<<<<<<<<<<< * * try: */ __pyx_t_14 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_6 = __pyx_builtin_ValueError; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_mstate_global->__pyx_kp_u_Unable_to_get_buffer}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 196, __pyx_L16_error) __Pyx_GOTREF(__pyx_t_5); } __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __PYX_ERR(0, 196, __pyx_L16_error) /* "intbitset.pyx":195 * tmp = zlib.decompress(rhs) * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: # <<<<<<<<<<<<<< * raise ValueError("Unable to get buffer") * */ } /* "intbitset.pyx":198 * raise ValueError("Unable to get buffer") * * try: # <<<<<<<<<<<<<< * buf = view.buf * size = view.len */ /*try:*/ { /* "intbitset.pyx":199 * * try: * buf = view.buf # <<<<<<<<<<<<<< * size = view.len * */ __pyx_v_buf = ((const void*)__pyx_v_view.buf); /* "intbitset.pyx":200 * try: * buf = view.buf * size = view.len # <<<<<<<<<<<<<< * * if (size % wordbytesize): */ __pyx_t_15 = __pyx_v_view.len; __pyx_v_size = __pyx_t_15; /* "intbitset.pyx":202 * size = view.len * * if (size % wordbytesize): # <<<<<<<<<<<<<< * ## Wrong size! * raise Exception() */ if (unlikely(wordbytesize == 0)) { PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero"); __PYX_ERR(0, 202, __pyx_L25_error) } __pyx_t_4 = (__Pyx_mod_Py_ssize_t(__pyx_v_size, wordbytesize, 0) != 0); if (unlikely(__pyx_t_4)) { /* "intbitset.pyx":204 * if (size % wordbytesize): * ## Wrong size! * raise Exception() # <<<<<<<<<<<<<< * * self.bitset = intBitSetCreateFromBuffer(buf, size) */ __pyx_t_6 = NULL; __Pyx_INCREF((PyObject *)(((PyTypeObject*)PyExc_Exception))); __pyx_t_14 = ((PyObject *)(((PyTypeObject*)PyExc_Exception))); __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_6, NULL}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_9, (1-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 204, __pyx_L25_error) __Pyx_GOTREF(__pyx_t_5); } __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __PYX_ERR(0, 204, __pyx_L25_error) /* "intbitset.pyx":202 * size = view.len * * if (size % wordbytesize): # <<<<<<<<<<<<<< * ## Wrong size! * raise Exception() */ } /* "intbitset.pyx":206 * raise Exception() * * self.bitset = intBitSetCreateFromBuffer(buf, size) # <<<<<<<<<<<<<< * finally: * PyBuffer_Release(&view) */ __pyx_v_self->bitset = intBitSetCreateFromBuffer(__pyx_v_buf, __pyx_v_size); } /* "intbitset.pyx":208 * self.bitset = intBitSetCreateFromBuffer(buf, size) * finally: * PyBuffer_Release(&view) # <<<<<<<<<<<<<< * * except Exception as e: */ /*finally:*/ { /*normal exit:*/{ PyBuffer_Release((&__pyx_v_view)); goto __pyx_L26; } __pyx_L25_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_18 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __pyx_t_22 = 0; __pyx_t_23 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_ExceptionSwap(&__pyx_t_21, &__pyx_t_22, &__pyx_t_23); if ( unlikely(__Pyx_GetException(&__pyx_t_18, &__pyx_t_19, &__pyx_t_20) < 0)) __Pyx_ErrFetch(&__pyx_t_18, &__pyx_t_19, &__pyx_t_20); __Pyx_XGOTREF(__pyx_t_18); __Pyx_XGOTREF(__pyx_t_19); __Pyx_XGOTREF(__pyx_t_20); __Pyx_XGOTREF(__pyx_t_21); __Pyx_XGOTREF(__pyx_t_22); __Pyx_XGOTREF(__pyx_t_23); __pyx_t_10 = __pyx_lineno; __pyx_t_16 = __pyx_clineno; __pyx_t_17 = __pyx_filename; { PyBuffer_Release((&__pyx_v_view)); } __Pyx_XGIVEREF(__pyx_t_21); __Pyx_XGIVEREF(__pyx_t_22); __Pyx_XGIVEREF(__pyx_t_23); __Pyx_ExceptionReset(__pyx_t_21, __pyx_t_22, __pyx_t_23); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_XGIVEREF(__pyx_t_19); __Pyx_XGIVEREF(__pyx_t_20); __Pyx_ErrRestore(__pyx_t_18, __pyx_t_19, __pyx_t_20); __pyx_t_18 = 0; __pyx_t_19 = 0; __pyx_t_20 = 0; __pyx_t_21 = 0; __pyx_t_22 = 0; __pyx_t_23 = 0; __pyx_lineno = __pyx_t_10; __pyx_clineno = __pyx_t_16; __pyx_filename = __pyx_t_17; goto __pyx_L16_error; } __pyx_L26:; } /* "intbitset.pyx":190 * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): * try: # <<<<<<<<<<<<<< * if type(rhs) is array: * rhs = rhs.tobytes() */ } __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; goto __pyx_L21_try_end; __pyx_L16_error:; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; /* "intbitset.pyx":210 * PyBuffer_Release(&view) * * except Exception as e: # <<<<<<<<<<<<<< * raise ValueError("rhs is corrupted: %s" % str(e)) * elif hasattr(rhs, '__iter__'): */ __pyx_t_16 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_Exception)))); if (__pyx_t_16) { __Pyx_AddTraceback("intbitset.intbitset.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_5, &__pyx_t_14, &__pyx_t_6) < 0) __PYX_ERR(0, 210, __pyx_L18_except_error) __Pyx_XGOTREF(__pyx_t_5); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_6); __Pyx_INCREF(__pyx_t_14); __pyx_v_e = __pyx_t_14; /* "intbitset.pyx":211 * * except Exception as e: * raise ValueError("rhs is corrupted: %s" % str(e)) # <<<<<<<<<<<<<< * elif hasattr(rhs, '__iter__'): * tuple_of_tuples = ( */ __pyx_t_24 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_25 = __pyx_builtin_ValueError; __pyx_t_26 = __Pyx_PyObject_Unicode(__pyx_v_e); if (unlikely(!__pyx_t_26)) __PYX_ERR(0, 211, __pyx_L18_except_error) __Pyx_GOTREF(__pyx_t_26); __pyx_t_27 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_rhs_is_corrupted_s, __pyx_t_26); if (unlikely(!__pyx_t_27)) __PYX_ERR(0, 211, __pyx_L18_except_error) __Pyx_GOTREF(__pyx_t_27); __Pyx_DECREF(__pyx_t_26); __pyx_t_26 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_24, __pyx_t_27}; __pyx_t_8 = __Pyx_PyObject_FastCall(__pyx_t_25, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0; __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 211, __pyx_L18_except_error) __Pyx_GOTREF(__pyx_t_8); } __Pyx_Raise(__pyx_t_8, 0, 0, 0); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __PYX_ERR(0, 211, __pyx_L18_except_error) } goto __pyx_L18_except_error; /* "intbitset.pyx":190 * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): * try: # <<<<<<<<<<<<<< * if type(rhs) is array: * rhs = rhs.tobytes() */ __pyx_L18_except_error:; __Pyx_XGIVEREF(__pyx_t_11); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_XGIVEREF(__pyx_t_13); __Pyx_ExceptionReset(__pyx_t_11, __pyx_t_12, __pyx_t_13); goto __pyx_L3_error; __pyx_L21_try_end:; } /* "intbitset.pyx":189 * elif type(rhs) is intbitset: * self.bitset = intBitSetClone((rhs).bitset) * elif type(rhs) in (bytes, array): # <<<<<<<<<<<<<< * try: * if type(rhs) is array: */ goto __pyx_L10; } /* "intbitset.pyx":212 * except Exception as e: * raise ValueError("rhs is corrupted: %s" % str(e)) * elif hasattr(rhs, '__iter__'): # <<<<<<<<<<<<<< * tuple_of_tuples = ( * rhs */ __pyx_t_4 = __Pyx_HasAttr(__pyx_v_rhs, __pyx_mstate_global->__pyx_n_u_iter); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(0, 212, __pyx_L3_error) if (likely(__pyx_t_4)) { /* "intbitset.pyx":214 * elif hasattr(rhs, '__iter__'): * tuple_of_tuples = ( * rhs # <<<<<<<<<<<<<< * and hasattr(rhs, '__getitem__') * and hasattr(rhs[0], '__getitem__') */ __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_rhs); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 214, __pyx_L3_error) if (__pyx_t_7) { } else { __pyx_t_4 = __pyx_t_7; goto __pyx_L32_bool_binop_done; } /* "intbitset.pyx":215 * tuple_of_tuples = ( * rhs * and hasattr(rhs, '__getitem__') # <<<<<<<<<<<<<< * and hasattr(rhs[0], '__getitem__') * ) */ __pyx_t_7 = __Pyx_HasAttr(__pyx_v_rhs, __pyx_mstate_global->__pyx_n_u_getitem); if (unlikely(__pyx_t_7 == ((int)-1))) __PYX_ERR(0, 215, __pyx_L3_error) if (__pyx_t_7) { } else { __pyx_t_4 = __pyx_t_7; goto __pyx_L32_bool_binop_done; } /* "intbitset.pyx":216 * rhs * and hasattr(rhs, '__getitem__') * and hasattr(rhs[0], '__getitem__') # <<<<<<<<<<<<<< * ) * try: */ __pyx_t_6 = __Pyx_GetItemInt(__pyx_v_rhs, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 216, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = __Pyx_HasAttr(__pyx_t_6, __pyx_mstate_global->__pyx_n_u_getitem); if (unlikely(__pyx_t_7 == ((int)-1))) __PYX_ERR(0, 216, __pyx_L3_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_4 = __pyx_t_7; __pyx_L32_bool_binop_done:; __pyx_v_tuple_of_tuples = __pyx_t_4; /* "intbitset.pyx":218 * and hasattr(rhs[0], '__getitem__') * ) * try: # <<<<<<<<<<<<<< * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): */ { __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __Pyx_ExceptionSave(&__pyx_t_13, &__pyx_t_12, &__pyx_t_11); __Pyx_XGOTREF(__pyx_t_13); __Pyx_XGOTREF(__pyx_t_12); __Pyx_XGOTREF(__pyx_t_11); /*try:*/ { /* "intbitset.pyx":219 * ) * try: * if preallocate < 0: # <<<<<<<<<<<<<< * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): * try: */ __pyx_t_4 = (__pyx_v_preallocate < 0); if (__pyx_t_4) { /* "intbitset.pyx":220 * try: * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): # <<<<<<<<<<<<<< * try: * preallocate = max(rhs) */ __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_v_rhs); if (unlikely((__pyx_t_7 < 0))) __PYX_ERR(0, 220, __pyx_L35_error) if (__pyx_t_7) { } else { __pyx_t_4 = __pyx_t_7; goto __pyx_L43_bool_binop_done; } __pyx_t_7 = __Pyx_HasAttr(__pyx_v_rhs, __pyx_mstate_global->__pyx_n_u_getitem); if (unlikely(__pyx_t_7 == ((int)-1))) __PYX_ERR(0, 220, __pyx_L35_error) __pyx_t_28 = (!__pyx_t_7); if (!__pyx_t_28) { } else { __pyx_t_4 = __pyx_t_28; goto __pyx_L43_bool_binop_done; } __pyx_t_6 = __Pyx_GetItemInt(__pyx_v_rhs, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 220, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_28 = (((PyObject *)Py_TYPE(__pyx_t_6)) == ((PyObject *)(&PyLong_Type))); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_4 = __pyx_t_28; __pyx_L43_bool_binop_done:; if (__pyx_t_4) { /* "intbitset.pyx":221 * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): * try: # <<<<<<<<<<<<<< * preallocate = max(rhs) * except ValueError: */ { __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __Pyx_ExceptionSave(&__pyx_t_23, &__pyx_t_22, &__pyx_t_21); __Pyx_XGOTREF(__pyx_t_23); __Pyx_XGOTREF(__pyx_t_22); __Pyx_XGOTREF(__pyx_t_21); /*try:*/ { /* "intbitset.pyx":222 * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): * try: * preallocate = max(rhs) # <<<<<<<<<<<<<< * except ValueError: * preallocate = 0 */ __pyx_t_14 = NULL; __Pyx_INCREF(__pyx_builtin_max); __pyx_t_5 = __pyx_builtin_max; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_14, __pyx_v_rhs}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 222, __pyx_L46_error) __Pyx_GOTREF(__pyx_t_6); } __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 222, __pyx_L46_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_preallocate = __pyx_t_16; /* "intbitset.pyx":221 * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): * try: # <<<<<<<<<<<<<< * preallocate = max(rhs) * except ValueError: */ } __Pyx_XDECREF(__pyx_t_23); __pyx_t_23 = 0; __Pyx_XDECREF(__pyx_t_22); __pyx_t_22 = 0; __Pyx_XDECREF(__pyx_t_21); __pyx_t_21 = 0; goto __pyx_L51_try_end; __pyx_L46_error:; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0; __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_XDECREF(__pyx_t_26); __pyx_t_26 = 0; __Pyx_XDECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; /* "intbitset.pyx":223 * try: * preallocate = max(rhs) * except ValueError: # <<<<<<<<<<<<<< * preallocate = 0 * else: */ __pyx_t_16 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_ValueError); if (__pyx_t_16) { __Pyx_AddTraceback("intbitset.intbitset.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_6, &__pyx_t_5, &__pyx_t_14) < 0) __PYX_ERR(0, 223, __pyx_L48_except_error) __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_5); __Pyx_XGOTREF(__pyx_t_14); /* "intbitset.pyx":224 * preallocate = max(rhs) * except ValueError: * preallocate = 0 # <<<<<<<<<<<<<< * else: * preallocate = 0 */ __pyx_v_preallocate = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; goto __pyx_L47_exception_handled; } goto __pyx_L48_except_error; /* "intbitset.pyx":221 * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): * try: # <<<<<<<<<<<<<< * preallocate = max(rhs) * except ValueError: */ __pyx_L48_except_error:; __Pyx_XGIVEREF(__pyx_t_23); __Pyx_XGIVEREF(__pyx_t_22); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ExceptionReset(__pyx_t_23, __pyx_t_22, __pyx_t_21); goto __pyx_L35_error; __pyx_L47_exception_handled:; __Pyx_XGIVEREF(__pyx_t_23); __Pyx_XGIVEREF(__pyx_t_22); __Pyx_XGIVEREF(__pyx_t_21); __Pyx_ExceptionReset(__pyx_t_23, __pyx_t_22, __pyx_t_21); __pyx_L51_try_end:; } /* "intbitset.pyx":220 * try: * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): # <<<<<<<<<<<<<< * try: * preallocate = max(rhs) */ goto __pyx_L42; } /* "intbitset.pyx":226 * preallocate = 0 * else: * preallocate = 0 # <<<<<<<<<<<<<< * if self.sanity_checks: * if not (0 <= preallocate < maxelem): */ /*else*/ { __pyx_v_preallocate = 0; } __pyx_L42:; /* "intbitset.pyx":219 * ) * try: * if preallocate < 0: # <<<<<<<<<<<<<< * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): * try: */ } /* "intbitset.pyx":227 * else: * preallocate = 0 * if self.sanity_checks: # <<<<<<<<<<<<<< * if not (0 <= preallocate < maxelem): * raise OverflowError("Can't store integers bigger than %s" % maxelem) */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":228 * preallocate = 0 * if self.sanity_checks: * if not (0 <= preallocate < maxelem): # <<<<<<<<<<<<<< * raise OverflowError("Can't store integers bigger than %s" % maxelem) * self.bitset = intBitSetCreate(preallocate, trailing_bits) */ __pyx_t_4 = (0 <= __pyx_v_preallocate); if (__pyx_t_4) { __pyx_t_4 = (__pyx_v_preallocate < maxelem); } __pyx_t_28 = (!__pyx_t_4); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":229 * if self.sanity_checks: * if not (0 <= preallocate < maxelem): * raise OverflowError("Can't store integers bigger than %s" % maxelem) # <<<<<<<<<<<<<< * self.bitset = intBitSetCreate(preallocate, trailing_bits) * if trailing_bits: */ __pyx_t_5 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_6 = __pyx_builtin_OverflowError; __pyx_t_8 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 229, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_25 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Can_t_store_integers_bigger_than, __pyx_t_8); if (unlikely(!__pyx_t_25)) __PYX_ERR(0, 229, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_25); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_25}; __pyx_t_14 = __Pyx_PyObject_FastCall(__pyx_t_6, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 229, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); } __Pyx_Raise(__pyx_t_14, 0, 0, 0); __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; __PYX_ERR(0, 229, __pyx_L35_error) /* "intbitset.pyx":228 * preallocate = 0 * if self.sanity_checks: * if not (0 <= preallocate < maxelem): # <<<<<<<<<<<<<< * raise OverflowError("Can't store integers bigger than %s" % maxelem) * self.bitset = intBitSetCreate(preallocate, trailing_bits) */ } /* "intbitset.pyx":227 * else: * preallocate = 0 * if self.sanity_checks: # <<<<<<<<<<<<<< * if not (0 <= preallocate < maxelem): * raise OverflowError("Can't store integers bigger than %s" % maxelem) */ } /* "intbitset.pyx":230 * if not (0 <= preallocate < maxelem): * raise OverflowError("Can't store integers bigger than %s" % maxelem) * self.bitset = intBitSetCreate(preallocate, trailing_bits) # <<<<<<<<<<<<<< * if trailing_bits: * last = 0 */ __pyx_v_self->bitset = intBitSetCreate(__pyx_v_preallocate, __pyx_v_trailing_bits); /* "intbitset.pyx":231 * raise OverflowError("Can't store integers bigger than %s" % maxelem) * self.bitset = intBitSetCreate(preallocate, trailing_bits) * if trailing_bits: # <<<<<<<<<<<<<< * last = 0 * if self.sanity_checks: */ __pyx_t_28 = (__pyx_v_trailing_bits != 0); if (__pyx_t_28) { /* "intbitset.pyx":232 * self.bitset = intBitSetCreate(preallocate, trailing_bits) * if trailing_bits: * last = 0 # <<<<<<<<<<<<<< * if self.sanity_checks: * if tuple_of_tuples: */ __pyx_v_last = 0; /* "intbitset.pyx":233 * if trailing_bits: * last = 0 * if self.sanity_checks: # <<<<<<<<<<<<<< * if tuple_of_tuples: * for tmp_tuple in rhs: */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":234 * last = 0 * if self.sanity_checks: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ if (__pyx_v_tuple_of_tuples) { /* "intbitset.pyx":235 * if self.sanity_checks: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * if elem < 0: */ if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 235, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 235, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 235, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 235, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 235, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 235, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __Pyx_XDECREF_SET(__pyx_v_tmp_tuple, __pyx_t_6); __pyx_t_6 = 0; /* "intbitset.pyx":236 * if tuple_of_tuples: * for tmp_tuple in rhs: * elem = tmp_tuple[0] # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ __pyx_t_6 = __Pyx_GetItemInt(__pyx_v_tmp_tuple, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 236, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 236, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":237 * for tmp_tuple in rhs: * elem = tmp_tuple[0] * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_28 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":238 * elem = tmp_tuple[0] * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_25 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_5 = __pyx_builtin_ValueError; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_25, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 238, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 238, __pyx_L35_error) /* "intbitset.pyx":237 * for tmp_tuple in rhs: * elem = tmp_tuple[0] * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":239 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: */ __pyx_t_28 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":240 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) */ __pyx_t_5 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_25 = __pyx_builtin_OverflowError; __pyx_t_8 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 240, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_27 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_8); if (unlikely(!__pyx_t_27)) __PYX_ERR(0, 240, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_27); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_27}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_25, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 240, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 240, __pyx_L35_error) /* "intbitset.pyx":239 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: */ } /* "intbitset.pyx":241 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 */ __pyx_t_16 = __pyx_v_elem; for (__pyx_v_remelem = __pyx_v_last; __pyx_v_remelem < __pyx_t_16; __pyx_v_remelem++) { /* "intbitset.pyx":242 * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) # <<<<<<<<<<<<<< * last = elem + 1 * else: */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_remelem); } /* "intbitset.pyx":243 * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 # <<<<<<<<<<<<<< * else: * for elem in rhs: */ __pyx_v_last = (__pyx_v_elem + 1); /* "intbitset.pyx":235 * if self.sanity_checks: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * if elem < 0: */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; /* "intbitset.pyx":234 * last = 0 * if self.sanity_checks: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ goto __pyx_L58; } /* "intbitset.pyx":245 * last = elem + 1 * else: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ /*else*/ { if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 245, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 245, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 245, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 245, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 245, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 245, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 245, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":246 * else: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_28 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":247 * for elem in rhs: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_25 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_27 = __pyx_builtin_ValueError; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_25, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_27, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 247, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 247, __pyx_L35_error) /* "intbitset.pyx":246 * else: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":248 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: */ __pyx_t_28 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":249 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) */ __pyx_t_27 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_25 = __pyx_builtin_OverflowError; __pyx_t_5 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 249, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_8 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_5); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 249, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_27, __pyx_t_8}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_25, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 249, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 249, __pyx_L35_error) /* "intbitset.pyx":248 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: */ } /* "intbitset.pyx":250 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 */ __pyx_t_16 = __pyx_v_elem; for (__pyx_v_remelem = __pyx_v_last; __pyx_v_remelem < __pyx_t_16; __pyx_v_remelem++) { /* "intbitset.pyx":251 * raise OverflowError("Elements must be <= %s" % maxelem) * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) # <<<<<<<<<<<<<< * last = elem + 1 * else: */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_remelem); } /* "intbitset.pyx":252 * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 # <<<<<<<<<<<<<< * else: * if tuple_of_tuples: */ __pyx_v_last = (__pyx_v_elem + 1); /* "intbitset.pyx":245 * last = elem + 1 * else: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; } __pyx_L58:; /* "intbitset.pyx":233 * if trailing_bits: * last = 0 * if self.sanity_checks: # <<<<<<<<<<<<<< * if tuple_of_tuples: * for tmp_tuple in rhs: */ goto __pyx_L57; } /* "intbitset.pyx":254 * last = elem + 1 * else: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ /*else*/ { if (__pyx_v_tuple_of_tuples) { /* "intbitset.pyx":255 * else: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * for remelem from last <= remelem < elem: */ if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 255, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 255, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 255, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 255, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 255, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 255, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __Pyx_XDECREF_SET(__pyx_v_tmp_tuple, __pyx_t_6); __pyx_t_6 = 0; /* "intbitset.pyx":256 * if tuple_of_tuples: * for tmp_tuple in rhs: * elem = tmp_tuple[0] # <<<<<<<<<<<<<< * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) */ __pyx_t_6 = __Pyx_GetItemInt(__pyx_v_tmp_tuple, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 256, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 256, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":257 * for tmp_tuple in rhs: * elem = tmp_tuple[0] * for remelem from last <= remelem < elem: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 */ __pyx_t_16 = __pyx_v_elem; for (__pyx_v_remelem = __pyx_v_last; __pyx_v_remelem < __pyx_t_16; __pyx_v_remelem++) { /* "intbitset.pyx":258 * elem = tmp_tuple[0] * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) # <<<<<<<<<<<<<< * last = elem + 1 * else: */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_remelem); } /* "intbitset.pyx":259 * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 # <<<<<<<<<<<<<< * else: * for elem in rhs: */ __pyx_v_last = (__pyx_v_elem + 1); /* "intbitset.pyx":255 * else: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * for remelem from last <= remelem < elem: */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; /* "intbitset.pyx":254 * last = elem + 1 * else: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ goto __pyx_L71; } /* "intbitset.pyx":261 * last = elem + 1 * else: * for elem in rhs: # <<<<<<<<<<<<<< * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) */ /*else*/ { if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 261, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 261, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 261, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 261, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 261, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 261, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 261, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":262 * else: * for elem in rhs: * for remelem from last <= remelem < elem: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 */ __pyx_t_16 = __pyx_v_elem; for (__pyx_v_remelem = __pyx_v_last; __pyx_v_remelem < __pyx_t_16; __pyx_v_remelem++) { /* "intbitset.pyx":263 * for elem in rhs: * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) # <<<<<<<<<<<<<< * last = elem + 1 * */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_remelem); } /* "intbitset.pyx":264 * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) * last = elem + 1 # <<<<<<<<<<<<<< * * else: */ __pyx_v_last = (__pyx_v_elem + 1); /* "intbitset.pyx":261 * last = elem + 1 * else: * for elem in rhs: # <<<<<<<<<<<<<< * for remelem from last <= remelem < elem: * intBitSetDelElem(self.bitset, remelem) */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; } __pyx_L71:; } __pyx_L57:; /* "intbitset.pyx":231 * raise OverflowError("Can't store integers bigger than %s" % maxelem) * self.bitset = intBitSetCreate(preallocate, trailing_bits) * if trailing_bits: # <<<<<<<<<<<<<< * last = 0 * if self.sanity_checks: */ goto __pyx_L56; } /* "intbitset.pyx":267 * * else: * if self.sanity_checks: # <<<<<<<<<<<<<< * if tuple_of_tuples: * for tmp_tuple in rhs: */ /*else*/ { if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":268 * else: * if self.sanity_checks: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ if (__pyx_v_tuple_of_tuples) { /* "intbitset.pyx":269 * if self.sanity_checks: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * if elem < 0: */ if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 269, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 269, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 269, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 269, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 269, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 269, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __Pyx_XDECREF_SET(__pyx_v_tmp_tuple, __pyx_t_6); __pyx_t_6 = 0; /* "intbitset.pyx":270 * if tuple_of_tuples: * for tmp_tuple in rhs: * elem = tmp_tuple[0] # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ __pyx_t_6 = __Pyx_GetItemInt(__pyx_v_tmp_tuple, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 270, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 270, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":271 * for tmp_tuple in rhs: * elem = tmp_tuple[0] * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_28 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":272 * elem = tmp_tuple[0] * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_25 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_8 = __pyx_builtin_ValueError; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_25, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 272, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 272, __pyx_L35_error) /* "intbitset.pyx":271 * for tmp_tuple in rhs: * elem = tmp_tuple[0] * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":273 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ __pyx_t_28 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":274 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * else: */ __pyx_t_8 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_25 = __pyx_builtin_OverflowError; __pyx_t_27 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_27)) __PYX_ERR(0, 274, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_27); __pyx_t_5 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_27); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 274, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_8, __pyx_t_5}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_25, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 274, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 274, __pyx_L35_error) /* "intbitset.pyx":273 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ } /* "intbitset.pyx":275 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * else: * for elem in rhs: */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":269 * if self.sanity_checks: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * if elem < 0: */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; /* "intbitset.pyx":268 * else: * if self.sanity_checks: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ goto __pyx_L83; } /* "intbitset.pyx":277 * intBitSetAddElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ /*else*/ { if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 277, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 277, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 277, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 277, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 277, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 277, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 277, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":278 * else: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_28 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":279 * for elem in rhs: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_25 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_5 = __pyx_builtin_ValueError; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_25, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 279, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 279, __pyx_L35_error) /* "intbitset.pyx":278 * else: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":280 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ __pyx_t_28 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_28)) { /* "intbitset.pyx":281 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * else: */ __pyx_t_5 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_25 = __pyx_builtin_OverflowError; __pyx_t_8 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 281, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_8); __pyx_t_27 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_8); if (unlikely(!__pyx_t_27)) __PYX_ERR(0, 281, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_27); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_27}; __pyx_t_6 = __Pyx_PyObject_FastCall(__pyx_t_25, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 281, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); } __Pyx_Raise(__pyx_t_6, 0, 0, 0); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __PYX_ERR(0, 281, __pyx_L35_error) /* "intbitset.pyx":280 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ } /* "intbitset.pyx":282 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * else: * if tuple_of_tuples: */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":277 * intBitSetAddElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; } __pyx_L83:; /* "intbitset.pyx":267 * * else: * if self.sanity_checks: # <<<<<<<<<<<<<< * if tuple_of_tuples: * for tmp_tuple in rhs: */ goto __pyx_L82; } /* "intbitset.pyx":284 * intBitSetAddElem(self.bitset, elem) * else: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ /*else*/ { if (__pyx_v_tuple_of_tuples) { /* "intbitset.pyx":285 * else: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * intBitSetAddElem(self.bitset, elem) */ if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 285, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 285, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 285, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 285, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 285, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 285, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __Pyx_XDECREF_SET(__pyx_v_tmp_tuple, __pyx_t_6); __pyx_t_6 = 0; /* "intbitset.pyx":286 * if tuple_of_tuples: * for tmp_tuple in rhs: * elem = tmp_tuple[0] # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * else: */ __pyx_t_6 = __Pyx_GetItemInt(__pyx_v_tmp_tuple, 0, long, 1, __Pyx_PyLong_From_long, 0, 0, 1, 1); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 286, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 286, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":287 * for tmp_tuple in rhs: * elem = tmp_tuple[0] * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * else: * for elem in rhs: */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":285 * else: * if tuple_of_tuples: * for tmp_tuple in rhs: # <<<<<<<<<<<<<< * elem = tmp_tuple[0] * intBitSetAddElem(self.bitset, elem) */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; /* "intbitset.pyx":284 * intBitSetAddElem(self.bitset, elem) * else: * if tuple_of_tuples: # <<<<<<<<<<<<<< * for tmp_tuple in rhs: * elem = tmp_tuple[0] */ goto __pyx_L92; } /* "intbitset.pyx":289 * intBitSetAddElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * except Exception as e: */ /*else*/ { if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_14 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_14); __pyx_t_15 = 0; __pyx_t_29 = NULL; } else { __pyx_t_15 = -1; __pyx_t_14 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 289, __pyx_L35_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_29 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_14); if (unlikely(!__pyx_t_29)) __PYX_ERR(0, 289, __pyx_L35_error) } for (;;) { if (likely(!__pyx_t_29)) { if (likely(PyList_CheckExact(__pyx_t_14))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 289, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_14, __pyx_t_15); ++__pyx_t_15; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_14); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 289, __pyx_L35_error) #endif if (__pyx_t_15 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_14, __pyx_t_15)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_14, __pyx_t_15); #endif ++__pyx_t_15; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 289, __pyx_L35_error) } else { __pyx_t_6 = __pyx_t_29(__pyx_t_14); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 289, __pyx_L35_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __pyx_t_16 = __Pyx_PyLong_As_int(__pyx_t_6); if (unlikely((__pyx_t_16 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 289, __pyx_L35_error) __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_v_elem = __pyx_t_16; /* "intbitset.pyx":290 * else: * for elem in rhs: * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * except Exception as e: * raise ValueError("retrieving integers from rhs is impossible: %s" % str(e)) */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":289 * intBitSetAddElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * except Exception as e: */ } __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; } __pyx_L92:; } __pyx_L82:; } __pyx_L56:; /* "intbitset.pyx":218 * and hasattr(rhs[0], '__getitem__') * ) * try: # <<<<<<<<<<<<<< * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): */ } __Pyx_XDECREF(__pyx_t_13); __pyx_t_13 = 0; __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_XDECREF(__pyx_t_11); __pyx_t_11 = 0; goto __pyx_L40_try_end; __pyx_L35_error:; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0; __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_XDECREF(__pyx_t_26); __pyx_t_26 = 0; __Pyx_XDECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; /* "intbitset.pyx":291 * for elem in rhs: * intBitSetAddElem(self.bitset, elem) * except Exception as e: # <<<<<<<<<<<<<< * raise ValueError("retrieving integers from rhs is impossible: %s" % str(e)) * else: */ __pyx_t_16 = __Pyx_PyErr_ExceptionMatches(((PyObject *)(((PyTypeObject*)PyExc_Exception)))); if (__pyx_t_16) { __Pyx_AddTraceback("intbitset.intbitset.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_14, &__pyx_t_6, &__pyx_t_25) < 0) __PYX_ERR(0, 291, __pyx_L37_except_error) __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_25); __Pyx_INCREF(__pyx_t_6); __pyx_v_e = __pyx_t_6; /* "intbitset.pyx":292 * intBitSetAddElem(self.bitset, elem) * except Exception as e: * raise ValueError("retrieving integers from rhs is impossible: %s" % str(e)) # <<<<<<<<<<<<<< * else: * raise TypeError("rhs is of unknown type %s" % type(rhs)) */ __pyx_t_5 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_8 = __pyx_builtin_ValueError; __pyx_t_24 = __Pyx_PyObject_Unicode(__pyx_v_e); if (unlikely(!__pyx_t_24)) __PYX_ERR(0, 292, __pyx_L37_except_error) __Pyx_GOTREF(__pyx_t_24); __pyx_t_26 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_retrieving_integers_from_rhs_is, __pyx_t_24); if (unlikely(!__pyx_t_26)) __PYX_ERR(0, 292, __pyx_L37_except_error) __Pyx_GOTREF(__pyx_t_26); __Pyx_DECREF(__pyx_t_24); __pyx_t_24 = 0; __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_5, __pyx_t_26}; __pyx_t_27 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_26); __pyx_t_26 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(!__pyx_t_27)) __PYX_ERR(0, 292, __pyx_L37_except_error) __Pyx_GOTREF(__pyx_t_27); } __Pyx_Raise(__pyx_t_27, 0, 0, 0); __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; __PYX_ERR(0, 292, __pyx_L37_except_error) } goto __pyx_L37_except_error; /* "intbitset.pyx":218 * and hasattr(rhs[0], '__getitem__') * ) * try: # <<<<<<<<<<<<<< * if preallocate < 0: * if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): */ __pyx_L37_except_error:; __Pyx_XGIVEREF(__pyx_t_13); __Pyx_XGIVEREF(__pyx_t_12); __Pyx_XGIVEREF(__pyx_t_11); __Pyx_ExceptionReset(__pyx_t_13, __pyx_t_12, __pyx_t_11); goto __pyx_L3_error; __pyx_L40_try_end:; } /* "intbitset.pyx":212 * except Exception as e: * raise ValueError("rhs is corrupted: %s" % str(e)) * elif hasattr(rhs, '__iter__'): # <<<<<<<<<<<<<< * tuple_of_tuples = ( * rhs */ goto __pyx_L10; } /* "intbitset.pyx":294 * raise ValueError("retrieving integers from rhs is impossible: %s" % str(e)) * else: * raise TypeError("rhs is of unknown type %s" % type(rhs)) # <<<<<<<<<<<<<< * except: * intBitSetDestroy(self.bitset) */ /*else*/ { __pyx_t_6 = NULL; __Pyx_INCREF(__pyx_builtin_TypeError); __pyx_t_14 = __pyx_builtin_TypeError; __pyx_t_27 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_rhs_is_of_unknown_type_s, ((PyObject *)Py_TYPE(__pyx_v_rhs))); if (unlikely(!__pyx_t_27)) __PYX_ERR(0, 294, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_27); __pyx_t_9 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_t_27}; __pyx_t_25 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_9, (2-__pyx_t_9) | (__pyx_t_9*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (unlikely(!__pyx_t_25)) __PYX_ERR(0, 294, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_25); } __Pyx_Raise(__pyx_t_25, 0, 0, 0); __Pyx_DECREF(__pyx_t_25); __pyx_t_25 = 0; __PYX_ERR(0, 294, __pyx_L3_error) } __pyx_L10:; /* "intbitset.pyx":180 * msg = "Error" * self.bitset = NULL * try: # <<<<<<<<<<<<<< * if no_allocate: * return */ } __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:; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_24); __pyx_t_24 = 0; __Pyx_XDECREF(__pyx_t_25); __pyx_t_25 = 0; __Pyx_XDECREF(__pyx_t_26); __pyx_t_26 = 0; __Pyx_XDECREF(__pyx_t_27); __pyx_t_27 = 0; __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; /* "intbitset.pyx":295 * else: * raise TypeError("rhs is of unknown type %s" % type(rhs)) * except: # <<<<<<<<<<<<<< * intBitSetDestroy(self.bitset) * raise */ /*except:*/ { __Pyx_AddTraceback("intbitset.intbitset.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_25, &__pyx_t_14, &__pyx_t_27) < 0) __PYX_ERR(0, 295, __pyx_L5_except_error) __Pyx_XGOTREF(__pyx_t_25); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_27); /* "intbitset.pyx":296 * raise TypeError("rhs is of unknown type %s" % type(rhs)) * except: * intBitSetDestroy(self.bitset) # <<<<<<<<<<<<<< * raise * */ intBitSetDestroy(__pyx_v_self->bitset); /* "intbitset.pyx":297 * except: * intBitSetDestroy(self.bitset) * raise # <<<<<<<<<<<<<< * * def __dealloc__(self not None): */ __Pyx_GIVEREF(__pyx_t_25); __Pyx_GIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_27); __Pyx_ErrRestoreWithState(__pyx_t_25, __pyx_t_14, __pyx_t_27); __pyx_t_25 = 0; __pyx_t_14 = 0; __pyx_t_27 = 0; __PYX_ERR(0, 297, __pyx_L5_except_error) } /* "intbitset.pyx":180 * msg = "Error" * self.bitset = NULL * try: # <<<<<<<<<<<<<< * if no_allocate: * return */ __pyx_L5_except_error:; __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_L7_try_return:; __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_L0; __pyx_L8_try_end:; } /* "intbitset.pyx":160 * cdef bint sanity_checks * * def __cinit__( # <<<<<<<<<<<<<< * self not None, * rhs=0, */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_8); __Pyx_XDECREF(__pyx_t_14); __Pyx_XDECREF(__pyx_t_24); __Pyx_XDECREF(__pyx_t_25); __Pyx_XDECREF(__pyx_t_26); __Pyx_XDECREF(__pyx_t_27); __Pyx_AddTraceback("intbitset.intbitset.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_XDECREF(__pyx_v_msg); __Pyx_XDECREF(__pyx_v_tmp); __Pyx_XDECREF(__pyx_v_e); __Pyx_XDECREF(__pyx_v_tmp_tuple); __Pyx_XDECREF(__pyx_v_rhs); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":299 * raise * * def __dealloc__(self not None): # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset.__dealloc__ is called" * intBitSetDestroy(self.bitset) */ /* Python wrapper */ static void __pyx_pw_9intbitset_9intbitset_3__dealloc__(PyObject *__pyx_v_self); /*proto*/ static void __pyx_pw_9intbitset_9intbitset_3__dealloc__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__dealloc__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 299, __pyx_L1_error) } __pyx_pf_9intbitset_9intbitset_2__dealloc__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); } static void __pyx_pf_9intbitset_9intbitset_2__dealloc__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { /* "intbitset.pyx":301 * def __dealloc__(self not None): * #print >> sys.stderr, "intbitset.__dealloc__ is called" * intBitSetDestroy(self.bitset) # <<<<<<<<<<<<<< * * def __contains__(self not None, int elem): */ intBitSetDestroy(__pyx_v_self->bitset); /* "intbitset.pyx":299 * raise * * def __dealloc__(self not None): # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset.__dealloc__ is called" * intBitSetDestroy(self.bitset) */ /* function exit code */ } /* "intbitset.pyx":303 * intBitSetDestroy(self.bitset) * * def __contains__(self not None, int elem): # <<<<<<<<<<<<<< * if self.sanity_checks: * if elem < 0: */ /* Python wrapper */ static int __pyx_pw_9intbitset_9intbitset_5__contains__(PyObject *__pyx_v_self, PyObject *__pyx_arg_elem); /*proto*/ static int __pyx_pw_9intbitset_9intbitset_5__contains__(PyObject *__pyx_v_self, PyObject *__pyx_arg_elem) { int __pyx_v_elem; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__contains__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); assert(__pyx_arg_elem); { __pyx_v_elem = __Pyx_PyLong_As_int(__pyx_arg_elem); if (unlikely((__pyx_v_elem == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 303, __pyx_L3_error) } goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; __Pyx_AddTraceback("intbitset.intbitset.__contains__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return -1; __pyx_L4_argument_unpacking_done:; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 303, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_4__contains__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((int)__pyx_v_elem)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_9intbitset_9intbitset_4__contains__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem) { int __pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; PyObject *__pyx_t_4 = NULL; size_t __pyx_t_5; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__contains__", 0); /* "intbitset.pyx":304 * * def __contains__(self not None, int elem): * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":305 * def __contains__(self not None, int elem): * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_1 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":306 * if self.sanity_checks: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 306, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 306, __pyx_L1_error) /* "intbitset.pyx":305 * def __contains__(self not None, int elem): * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":307 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * return intBitSetIsInElem(self.bitset, elem) != 0 */ __pyx_t_1 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":308 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) # <<<<<<<<<<<<<< * return intBitSetIsInElem(self.bitset, elem) != 0 * */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_3 = __pyx_builtin_OverflowError; __pyx_t_6 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 308, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Element_must_be_s, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 308, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_7}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 308, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 308, __pyx_L1_error) /* "intbitset.pyx":307 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * return intBitSetIsInElem(self.bitset, elem) != 0 */ } /* "intbitset.pyx":304 * * def __contains__(self not None, int elem): * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":309 * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) * return intBitSetIsInElem(self.bitset, elem) != 0 # <<<<<<<<<<<<<< * * def __cmp__(self not None, intbitset rhs not None): */ __pyx_r = (intBitSetIsInElem(__pyx_v_self->bitset, __pyx_v_elem) != 0); goto __pyx_L0; /* "intbitset.pyx":303 * intBitSetDestroy(self.bitset) * * def __contains__(self not None, int elem): # <<<<<<<<<<<<<< * if self.sanity_checks: * if elem < 0: */ /* 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_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("intbitset.intbitset.__contains__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":311 * return intBitSetIsInElem(self.bitset, elem) != 0 * * def __cmp__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * raise TypeError("cannot compare intbitset using cmp()") * */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_7__cmp__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_7__cmp__ = {"__cmp__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_7__cmp__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_7__cmp__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cmp__ (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_rhs,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 311, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 311, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__cmp__", 0) < (0)) __PYX_ERR(0, 311, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__cmp__", 1, 1, 1, i); __PYX_ERR(0, 311, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 311, __pyx_L3_error) } __pyx_v_rhs = ((struct __pyx_obj_9intbitset_intbitset *)values[0]); } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__cmp__", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 311, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.__cmp__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 311, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 311, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_6__cmp__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_rhs); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } goto __pyx_L7_cleaned_up; __pyx_L0:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __pyx_L7_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_6__cmp__(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__cmp__", 0); /* "intbitset.pyx":312 * * def __cmp__(self not None, intbitset rhs not None): * raise TypeError("cannot compare intbitset using cmp()") # <<<<<<<<<<<<<< * * def __richcmp__(self not None, rhs, int op): */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_TypeError); __pyx_t_3 = __pyx_builtin_TypeError; __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_cannot_compare_intbitset_using_c}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 312, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 312, __pyx_L1_error) /* "intbitset.pyx":311 * return intBitSetIsInElem(self.bitset, elem) != 0 * * def __cmp__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * raise TypeError("cannot compare intbitset using cmp()") * */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("intbitset.intbitset.__cmp__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":314 * raise TypeError("cannot compare intbitset using cmp()") * * def __richcmp__(self not None, rhs, int op): # <<<<<<<<<<<<<< * if not isinstance(self, intbitset) or not isinstance(rhs, intbitset): * return False */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_9__richcmp__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_v_op); /*proto*/ static PyObject *__pyx_pw_9intbitset_9intbitset_9__richcmp__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_v_op) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__richcmp__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 314, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_8__richcmp__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((PyObject *)__pyx_v_rhs), ((int)__pyx_v_op)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_8__richcmp__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_v_op) { unsigned short __pyx_v_tmp; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; int __pyx_t_2; int __pyx_t_3; PyObject *__pyx_t_4 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__richcmp__", 0); /* "intbitset.pyx":315 * * def __richcmp__(self not None, rhs, int op): * if not isinstance(self, intbitset) or not isinstance(rhs, intbitset): # <<<<<<<<<<<<<< * return False * cdef short unsigned int tmp */ __pyx_t_2 = __Pyx_TypeCheck(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = (!__pyx_t_2); if (!__pyx_t_3) { } else { __pyx_t_1 = __pyx_t_3; goto __pyx_L4_bool_binop_done; } __pyx_t_3 = __Pyx_TypeCheck(__pyx_v_rhs, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_2 = (!__pyx_t_3); __pyx_t_1 = __pyx_t_2; __pyx_L4_bool_binop_done:; if (__pyx_t_1) { /* "intbitset.pyx":316 * def __richcmp__(self not None, rhs, int op): * if not isinstance(self, intbitset) or not isinstance(rhs, intbitset): * return False # <<<<<<<<<<<<<< * cdef short unsigned int tmp * tmp = intBitSetCmp((self).bitset, (rhs).bitset) */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(Py_False); __pyx_r = Py_False; goto __pyx_L0; /* "intbitset.pyx":315 * * def __richcmp__(self not None, rhs, int op): * if not isinstance(self, intbitset) or not isinstance(rhs, intbitset): # <<<<<<<<<<<<<< * return False * cdef short unsigned int tmp */ } /* "intbitset.pyx":318 * return False * cdef short unsigned int tmp * tmp = intBitSetCmp((self).bitset, (rhs).bitset) # <<<<<<<<<<<<<< * if op == 0: # < * return tmp == 1 */ __pyx_v_tmp = intBitSetCmp(__pyx_v_self->bitset, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)->bitset); /* "intbitset.pyx":319 * cdef short unsigned int tmp * tmp = intBitSetCmp((self).bitset, (rhs).bitset) * if op == 0: # < # <<<<<<<<<<<<<< * return tmp == 1 * if op == 1: # <= */ __pyx_t_1 = (__pyx_v_op == 0); if (__pyx_t_1) { /* "intbitset.pyx":320 * tmp = intBitSetCmp((self).bitset, (rhs).bitset) * if op == 0: # < * return tmp == 1 # <<<<<<<<<<<<<< * if op == 1: # <= * return tmp <= 1 */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyBool_FromLong((__pyx_v_tmp == 1)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 320, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; /* "intbitset.pyx":319 * cdef short unsigned int tmp * tmp = intBitSetCmp((self).bitset, (rhs).bitset) * if op == 0: # < # <<<<<<<<<<<<<< * return tmp == 1 * if op == 1: # <= */ } /* "intbitset.pyx":321 * if op == 0: # < * return tmp == 1 * if op == 1: # <= # <<<<<<<<<<<<<< * return tmp <= 1 * if op == 2: # == */ __pyx_t_1 = (__pyx_v_op == 1); if (__pyx_t_1) { /* "intbitset.pyx":322 * return tmp == 1 * if op == 1: # <= * return tmp <= 1 # <<<<<<<<<<<<<< * if op == 2: # == * return tmp == 0 */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyBool_FromLong((__pyx_v_tmp <= 1)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 322, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; /* "intbitset.pyx":321 * if op == 0: # < * return tmp == 1 * if op == 1: # <= # <<<<<<<<<<<<<< * return tmp <= 1 * if op == 2: # == */ } /* "intbitset.pyx":323 * if op == 1: # <= * return tmp <= 1 * if op == 2: # == # <<<<<<<<<<<<<< * return tmp == 0 * if op == 3: # != */ __pyx_t_1 = (__pyx_v_op == 2); if (__pyx_t_1) { /* "intbitset.pyx":324 * return tmp <= 1 * if op == 2: # == * return tmp == 0 # <<<<<<<<<<<<<< * if op == 3: # != * return tmp > 0 */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyBool_FromLong((__pyx_v_tmp == 0)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 324, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; /* "intbitset.pyx":323 * if op == 1: # <= * return tmp <= 1 * if op == 2: # == # <<<<<<<<<<<<<< * return tmp == 0 * if op == 3: # != */ } /* "intbitset.pyx":325 * if op == 2: # == * return tmp == 0 * if op == 3: # != # <<<<<<<<<<<<<< * return tmp > 0 * if op == 4: # > */ __pyx_t_1 = (__pyx_v_op == 3); if (__pyx_t_1) { /* "intbitset.pyx":326 * return tmp == 0 * if op == 3: # != * return tmp > 0 # <<<<<<<<<<<<<< * if op == 4: # > * return tmp == 2 */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyBool_FromLong((__pyx_v_tmp > 0)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 326, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; /* "intbitset.pyx":325 * if op == 2: # == * return tmp == 0 * if op == 3: # != # <<<<<<<<<<<<<< * return tmp > 0 * if op == 4: # > */ } /* "intbitset.pyx":327 * if op == 3: # != * return tmp > 0 * if op == 4: # > # <<<<<<<<<<<<<< * return tmp == 2 * if op == 5: # >= */ __pyx_t_1 = (__pyx_v_op == 4); if (__pyx_t_1) { /* "intbitset.pyx":328 * return tmp > 0 * if op == 4: # > * return tmp == 2 # <<<<<<<<<<<<<< * if op == 5: # >= * return tmp in (0, 2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PyBool_FromLong((__pyx_v_tmp == 2)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 328, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; /* "intbitset.pyx":327 * if op == 3: # != * return tmp > 0 * if op == 4: # > # <<<<<<<<<<<<<< * return tmp == 2 * if op == 5: # >= */ } /* "intbitset.pyx":329 * if op == 4: # > * return tmp == 2 * if op == 5: # >= # <<<<<<<<<<<<<< * return tmp in (0, 2) * */ __pyx_t_1 = (__pyx_v_op == 5); if (__pyx_t_1) { /* "intbitset.pyx":330 * return tmp == 2 * if op == 5: # >= * return tmp in (0, 2) # <<<<<<<<<<<<<< * * def __len__(self not None): */ __Pyx_XDECREF(__pyx_r); switch (__pyx_v_tmp) { case 0: case 2: __pyx_t_1 = 1; break; default: __pyx_t_1 = 0; break; } __pyx_t_4 = __Pyx_PyBool_FromLong(__pyx_t_1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 330, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; /* "intbitset.pyx":329 * if op == 4: # > * return tmp == 2 * if op == 5: # >= # <<<<<<<<<<<<<< * return tmp in (0, 2) * */ } /* "intbitset.pyx":314 * raise TypeError("cannot compare intbitset using cmp()") * * def __richcmp__(self not None, rhs, int op): # <<<<<<<<<<<<<< * if not isinstance(self, intbitset) or not isinstance(rhs, intbitset): * return False */ /* function exit code */ __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("intbitset.intbitset.__richcmp__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":332 * return tmp in (0, 2) * * def __len__(self not None): # <<<<<<<<<<<<<< * return intBitSetGetTot(self.bitset) * */ /* Python wrapper */ static Py_ssize_t __pyx_pw_9intbitset_9intbitset_11__len__(PyObject *__pyx_v_self); /*proto*/ static Py_ssize_t __pyx_pw_9intbitset_9intbitset_11__len__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; Py_ssize_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__len__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 332, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_10__len__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static Py_ssize_t __pyx_pf_9intbitset_9intbitset_10__len__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { Py_ssize_t __pyx_r; /* "intbitset.pyx":333 * * def __len__(self not None): * return intBitSetGetTot(self.bitset) # <<<<<<<<<<<<<< * * def __hash__(self not None): */ __pyx_r = intBitSetGetTot(__pyx_v_self->bitset); goto __pyx_L0; /* "intbitset.pyx":332 * return tmp in (0, 2) * * def __len__(self not None): # <<<<<<<<<<<<<< * return intBitSetGetTot(self.bitset) * */ /* function exit code */ __pyx_L0:; return __pyx_r; } /* "intbitset.pyx":335 * return intBitSetGetTot(self.bitset) * * def __hash__(self not None): # <<<<<<<<<<<<<< * return hash( * PyBytes_FromStringAndSize( */ /* Python wrapper */ static Py_hash_t __pyx_pw_9intbitset_9intbitset_13__hash__(PyObject *__pyx_v_self); /*proto*/ static Py_hash_t __pyx_pw_9intbitset_9intbitset_13__hash__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; Py_hash_t __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__hash__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 335, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_12__hash__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static Py_hash_t __pyx_pf_9intbitset_9intbitset_12__hash__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { Py_hash_t __pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; Py_hash_t __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__hash__", 0); /* "intbitset.pyx":339 * PyBytes_FromStringAndSize( * self.bitset.bitset, * wordbytesize * (intBitSetGetTot(self.bitset) / wordbitsize + 1) # <<<<<<<<<<<<<< * ) * ) */ __pyx_t_1 = intBitSetGetTot(__pyx_v_self->bitset); if (unlikely(wordbitsize == 0)) { PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero"); __PYX_ERR(0, 339, __pyx_L1_error) } else if (sizeof(int) == sizeof(long) && (!(((int)-1) > 0)) && unlikely(wordbitsize == (int)-1) && unlikely(__Pyx_UNARY_NEG_WOULD_OVERFLOW(__pyx_t_1))) { PyErr_SetString(PyExc_OverflowError, "value too large to perform division"); __PYX_ERR(0, 339, __pyx_L1_error) } /* "intbitset.pyx":337 * def __hash__(self not None): * return hash( * PyBytes_FromStringAndSize( # <<<<<<<<<<<<<< * self.bitset.bitset, * wordbytesize * (intBitSetGetTot(self.bitset) / wordbitsize + 1) */ __pyx_t_2 = PyBytes_FromStringAndSize(((char *)__pyx_v_self->bitset->bitset), (wordbytesize * (__Pyx_div_int(__pyx_t_1, wordbitsize, 0) + 1))); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 337, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); /* "intbitset.pyx":336 * * def __hash__(self not None): * return hash( # <<<<<<<<<<<<<< * PyBytes_FromStringAndSize( * self.bitset.bitset, */ __pyx_t_3 = PyObject_Hash(__pyx_t_2); if (unlikely(__pyx_t_3 == ((Py_hash_t)-1))) __PYX_ERR(0, 336, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_r = __pyx_t_3; goto __pyx_L0; /* "intbitset.pyx":335 * return intBitSetGetTot(self.bitset) * * def __hash__(self not None): # <<<<<<<<<<<<<< * return hash( * PyBytes_FromStringAndSize( */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("intbitset.intbitset.__hash__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; if (unlikely(__pyx_r == -1) && !PyErr_Occurred()) __pyx_r = -2; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":343 * ) * * def __nonzero__(self not None): # <<<<<<<<<<<<<< * return not intBitSetEmpty(self.bitset) * */ /* Python wrapper */ static int __pyx_pw_9intbitset_9intbitset_15__nonzero__(PyObject *__pyx_v_self); /*proto*/ static int __pyx_pw_9intbitset_9intbitset_15__nonzero__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__nonzero__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 343, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_14__nonzero__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_9intbitset_9intbitset_14__nonzero__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { int __pyx_r; /* "intbitset.pyx":344 * * def __nonzero__(self not None): * return not intBitSetEmpty(self.bitset) # <<<<<<<<<<<<<< * * def __deepcopy__(self not None, memo): */ __pyx_r = (!intBitSetEmpty(__pyx_v_self->bitset)); goto __pyx_L0; /* "intbitset.pyx":343 * ) * * def __nonzero__(self not None): # <<<<<<<<<<<<<< * return not intBitSetEmpty(self.bitset) * */ /* function exit code */ __pyx_L0:; return __pyx_r; } /* "intbitset.pyx":346 * return not intBitSetEmpty(self.bitset) * * def __deepcopy__(self not None, memo): # <<<<<<<<<<<<<< * return intbitset(self) * */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_17__deepcopy__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_17__deepcopy__ = {"__deepcopy__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_17__deepcopy__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_17__deepcopy__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { CYTHON_UNUSED PyObject *__pyx_v_memo = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__deepcopy__ (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_memo,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 346, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 346, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__deepcopy__", 0) < (0)) __PYX_ERR(0, 346, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__deepcopy__", 1, 1, 1, i); __PYX_ERR(0, 346, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 346, __pyx_L3_error) } __pyx_v_memo = values[0]; } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__deepcopy__", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 346, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.__deepcopy__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 346, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_16__deepcopy__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_memo); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } goto __pyx_L7_cleaned_up; __pyx_L0:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __pyx_L7_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_16__deepcopy__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v_memo) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__deepcopy__", 0); /* "intbitset.pyx":347 * * def __deepcopy__(self not None, memo): * return intbitset(self) # <<<<<<<<<<<<<< * * def __delitem__(self not None, int elem): */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, ((PyObject *)__pyx_v_self)}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 347, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_r = ((PyObject *)__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":346 * return not intBitSetEmpty(self.bitset) * * def __deepcopy__(self not None, memo): # <<<<<<<<<<<<<< * return intbitset(self) * */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("intbitset.intbitset.__deepcopy__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":349 * return intbitset(self) * * def __delitem__(self not None, int elem): # <<<<<<<<<<<<<< * if self.sanity_checks: * if elem < 0: */ /* Python wrapper */ static int __pyx_pw_9intbitset_9intbitset_19__delitem__(PyObject *__pyx_v_self, PyObject *__pyx_arg_elem); /*proto*/ static int __pyx_pw_9intbitset_9intbitset_19__delitem__(PyObject *__pyx_v_self, PyObject *__pyx_arg_elem) { int __pyx_v_elem; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__delitem__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); assert(__pyx_arg_elem); { __pyx_v_elem = __Pyx_PyLong_As_int(__pyx_arg_elem); if (unlikely((__pyx_v_elem == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 349, __pyx_L3_error) } goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; __Pyx_AddTraceback("intbitset.intbitset.__delitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return -1; __pyx_L4_argument_unpacking_done:; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 349, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_18__delitem__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((int)__pyx_v_elem)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_9intbitset_9intbitset_18__delitem__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem) { int __pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; PyObject *__pyx_t_4 = NULL; size_t __pyx_t_5; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__delitem__", 0); /* "intbitset.pyx":350 * * def __delitem__(self not None, int elem): * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":351 * def __delitem__(self not None, int elem): * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_1 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":352 * if self.sanity_checks: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 352, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 352, __pyx_L1_error) /* "intbitset.pyx":351 * def __delitem__(self not None, int elem): * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":353 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) */ __pyx_t_1 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":354 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_3 = __pyx_builtin_OverflowError; __pyx_t_6 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 354, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Element_must_be_s, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 354, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_7}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 354, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 354, __pyx_L1_error) /* "intbitset.pyx":353 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) */ } /* "intbitset.pyx":350 * * def __delitem__(self not None, int elem): * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":355 * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) # <<<<<<<<<<<<<< * * def __iadd__(self not None, rhs): */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":349 * return intbitset(self) * * def __delitem__(self not None, int elem): # <<<<<<<<<<<<<< * if self.sanity_checks: * if elem < 0: */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("intbitset.intbitset.__delitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":357 * intBitSetDelElem(self.bitset, elem) * * def __iadd__(self not None, rhs): # <<<<<<<<<<<<<< * cdef int elem * if isinstance(rhs, (int, long)): */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_21__iadd__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ static PyObject *__pyx_pw_9intbitset_9intbitset_21__iadd__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iadd__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 357, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_20__iadd__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((PyObject *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_20__iadd__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs) { int __pyx_v_elem; 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; size_t __pyx_t_5; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; unsigned int __pyx_t_8; Py_ssize_t __pyx_t_9; PyObject *(*__pyx_t_10)(PyObject *); int __pyx_t_11; PyObject *__pyx_t_12 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__iadd__", 0); /* "intbitset.pyx":359 * def __iadd__(self not None, rhs): * cdef int elem * if isinstance(rhs, (int, long)): # <<<<<<<<<<<<<< * if self.sanity_checks: * if rhs < 0: */ __pyx_t_1 = PyLong_Check(__pyx_v_rhs); if (__pyx_t_1) { /* "intbitset.pyx":360 * cdef int elem * if isinstance(rhs, (int, long)): * if self.sanity_checks: # <<<<<<<<<<<<<< * if rhs < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":361 * if isinstance(rhs, (int, long)): * if self.sanity_checks: * if rhs < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: */ __pyx_t_2 = PyObject_RichCompare(__pyx_v_rhs, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 361, __pyx_L1_error) __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 361, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":362 * if self.sanity_checks: * if rhs < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif rhs > maxelem: * raise OverflowError("rhs must be <= %s" % maxelem) */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 362, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 362, __pyx_L1_error) /* "intbitset.pyx":361 * if isinstance(rhs, (int, long)): * if self.sanity_checks: * if rhs < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: */ } /* "intbitset.pyx":363 * if rhs < 0: * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, rhs) */ __pyx_t_2 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 363, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = PyObject_RichCompare(__pyx_v_rhs, __pyx_t_2, Py_GT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 363, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 363, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":364 * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: * raise OverflowError("rhs must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_3 = __pyx_builtin_OverflowError; __pyx_t_6 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 364, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_rhs_must_be_s, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 364, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_7}; __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 364, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); } __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 364, __pyx_L1_error) /* "intbitset.pyx":363 * if rhs < 0: * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, rhs) */ } /* "intbitset.pyx":360 * cdef int elem * if isinstance(rhs, (int, long)): * if self.sanity_checks: # <<<<<<<<<<<<<< * if rhs < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":365 * elif rhs > maxelem: * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, rhs) # <<<<<<<<<<<<<< * elif isinstance(rhs, intbitset): * intBitSetIUnion(self.bitset, ( rhs).bitset) */ __pyx_t_8 = __Pyx_PyLong_As_unsigned_int(__pyx_v_rhs); if (unlikely((__pyx_t_8 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 365, __pyx_L1_error) intBitSetAddElem(__pyx_v_self->bitset, __pyx_t_8); /* "intbitset.pyx":359 * def __iadd__(self not None, rhs): * cdef int elem * if isinstance(rhs, (int, long)): # <<<<<<<<<<<<<< * if self.sanity_checks: * if rhs < 0: */ goto __pyx_L3; } /* "intbitset.pyx":366 * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): # <<<<<<<<<<<<<< * intBitSetIUnion(self.bitset, ( rhs).bitset) * else: */ __pyx_t_1 = __Pyx_TypeCheck(__pyx_v_rhs, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (__pyx_t_1) { /* "intbitset.pyx":367 * intBitSetAddElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): * intBitSetIUnion(self.bitset, ( rhs).bitset) # <<<<<<<<<<<<<< * else: * if self.sanity_checks: */ (void)(intBitSetIUnion(__pyx_v_self->bitset, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)->bitset)); /* "intbitset.pyx":366 * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): # <<<<<<<<<<<<<< * intBitSetIUnion(self.bitset, ( rhs).bitset) * else: */ goto __pyx_L3; } /* "intbitset.pyx":369 * intBitSetIUnion(self.bitset, ( rhs).bitset) * else: * if self.sanity_checks: # <<<<<<<<<<<<<< * for elem in rhs: * if elem < 0: */ /*else*/ { if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":370 * else: * if self.sanity_checks: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_4 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_4); __pyx_t_9 = 0; __pyx_t_10 = NULL; } else { __pyx_t_9 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 370, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_10 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 370, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_10)) { if (likely(PyList_CheckExact(__pyx_t_4))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 370, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } __pyx_t_3 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_9); ++__pyx_t_9; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 370, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_9)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_9); #endif ++__pyx_t_9; } if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 370, __pyx_L1_error) } else { __pyx_t_3 = __pyx_t_10(__pyx_t_4); if (unlikely(!__pyx_t_3)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 370, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_3); __pyx_t_11 = __Pyx_PyLong_As_int(__pyx_t_3); if (unlikely((__pyx_t_11 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 370, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_elem = __pyx_t_11; /* "intbitset.pyx":371 * if self.sanity_checks: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_1 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":372 * for elem in rhs: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_7 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_2 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 372, __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, 372, __pyx_L1_error) /* "intbitset.pyx":371 * if self.sanity_checks: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":373 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ __pyx_t_1 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":374 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * else: */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_7 = __pyx_builtin_OverflowError; __pyx_t_6 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 374, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_12 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_6); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 374, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_12}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 374, __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, 374, __pyx_L1_error) /* "intbitset.pyx":373 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ } /* "intbitset.pyx":375 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * else: * for elem in rhs: */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":370 * else: * if self.sanity_checks: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; /* "intbitset.pyx":369 * intBitSetIUnion(self.bitset, ( rhs).bitset) * else: * if self.sanity_checks: # <<<<<<<<<<<<<< * for elem in rhs: * if elem < 0: */ goto __pyx_L6; } /* "intbitset.pyx":377 * intBitSetAddElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ /*else*/ { if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_4 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_4); __pyx_t_9 = 0; __pyx_t_10 = NULL; } else { __pyx_t_9 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 377, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_10 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 377, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_10)) { if (likely(PyList_CheckExact(__pyx_t_4))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 377, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } __pyx_t_3 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_9); ++__pyx_t_9; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 377, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_9)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_9); #endif ++__pyx_t_9; } if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 377, __pyx_L1_error) } else { __pyx_t_3 = __pyx_t_10(__pyx_t_4); if (unlikely(!__pyx_t_3)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 377, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_3); __pyx_t_11 = __Pyx_PyLong_As_int(__pyx_t_3); if (unlikely((__pyx_t_11 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 377, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_elem = __pyx_t_11; /* "intbitset.pyx":378 * else: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_1 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":379 * for elem in rhs: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_7 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_12 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_12, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 379, __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, 379, __pyx_L1_error) /* "intbitset.pyx":378 * else: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":380 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ __pyx_t_1 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":381 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * return self */ __pyx_t_12 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_7 = __pyx_builtin_OverflowError; __pyx_t_2 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 381, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_6 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_2); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 381, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_12, __pyx_t_6}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 381, __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, 381, __pyx_L1_error) /* "intbitset.pyx":380 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ } /* "intbitset.pyx":382 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * return self * */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":377 * intBitSetAddElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; } __pyx_L6:; } __pyx_L3:; /* "intbitset.pyx":383 * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) * return self # <<<<<<<<<<<<<< * * def __isub__(self not None, rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_self); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0; /* "intbitset.pyx":357 * intBitSetDelElem(self.bitset, elem) * * def __iadd__(self not None, rhs): # <<<<<<<<<<<<<< * cdef int elem * if isinstance(rhs, (int, long)): */ /* 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_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("intbitset.intbitset.__iadd__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":385 * return self * * def __isub__(self not None, rhs not None): # <<<<<<<<<<<<<< * """Remove all elements of another set from this set.""" * cdef int elem */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_23__isub__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_22__isub__, "Remove all elements of another set from this set."); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_22__isub__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_23__isub__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__isub__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 385, __pyx_L1_error) } if (unlikely(((PyObject *)__pyx_v_rhs) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "rhs"); __PYX_ERR(0, 385, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_22__isub__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((PyObject *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_22__isub__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs) { int __pyx_v_elem; 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; size_t __pyx_t_5; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; unsigned int __pyx_t_8; Py_ssize_t __pyx_t_9; PyObject *(*__pyx_t_10)(PyObject *); int __pyx_t_11; PyObject *__pyx_t_12 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__isub__", 0); /* "intbitset.pyx":388 * """Remove all elements of another set from this set.""" * cdef int elem * if isinstance(rhs, (int, long)): # <<<<<<<<<<<<<< * if self.sanity_checks: * if rhs < 0: */ __pyx_t_1 = PyLong_Check(__pyx_v_rhs); if (__pyx_t_1) { /* "intbitset.pyx":389 * cdef int elem * if isinstance(rhs, (int, long)): * if self.sanity_checks: # <<<<<<<<<<<<<< * if rhs < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":390 * if isinstance(rhs, (int, long)): * if self.sanity_checks: * if rhs < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: */ __pyx_t_2 = PyObject_RichCompare(__pyx_v_rhs, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 390, __pyx_L1_error) __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 390, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":391 * if self.sanity_checks: * if rhs < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif rhs > maxelem: * raise OverflowError("rhs must be <= %s" % maxelem) */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 391, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 391, __pyx_L1_error) /* "intbitset.pyx":390 * if isinstance(rhs, (int, long)): * if self.sanity_checks: * if rhs < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: */ } /* "intbitset.pyx":392 * if rhs < 0: * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, rhs) */ __pyx_t_2 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 392, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = PyObject_RichCompare(__pyx_v_rhs, __pyx_t_2, Py_GT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 392, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_1 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_1 < 0))) __PYX_ERR(0, 392, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":393 * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: * raise OverflowError("rhs must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_3 = __pyx_builtin_OverflowError; __pyx_t_6 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 393, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_rhs_must_be_s, __pyx_t_6); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 393, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_7}; __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 393, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); } __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 393, __pyx_L1_error) /* "intbitset.pyx":392 * if rhs < 0: * raise ValueError("Negative numbers, not allowed") * elif rhs > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, rhs) */ } /* "intbitset.pyx":389 * cdef int elem * if isinstance(rhs, (int, long)): * if self.sanity_checks: # <<<<<<<<<<<<<< * if rhs < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":394 * elif rhs > maxelem: * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, rhs) # <<<<<<<<<<<<<< * elif isinstance(rhs, intbitset): * intBitSetISub(self.bitset, ( rhs).bitset) */ __pyx_t_8 = __Pyx_PyLong_As_unsigned_int(__pyx_v_rhs); if (unlikely((__pyx_t_8 == (unsigned int)-1) && PyErr_Occurred())) __PYX_ERR(0, 394, __pyx_L1_error) intBitSetDelElem(__pyx_v_self->bitset, __pyx_t_8); /* "intbitset.pyx":388 * """Remove all elements of another set from this set.""" * cdef int elem * if isinstance(rhs, (int, long)): # <<<<<<<<<<<<<< * if self.sanity_checks: * if rhs < 0: */ goto __pyx_L3; } /* "intbitset.pyx":395 * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): # <<<<<<<<<<<<<< * intBitSetISub(self.bitset, ( rhs).bitset) * else: */ __pyx_t_1 = __Pyx_TypeCheck(__pyx_v_rhs, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (__pyx_t_1) { /* "intbitset.pyx":396 * intBitSetDelElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): * intBitSetISub(self.bitset, ( rhs).bitset) # <<<<<<<<<<<<<< * else: * if self.sanity_checks: */ (void)(intBitSetISub(__pyx_v_self->bitset, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)->bitset)); /* "intbitset.pyx":395 * raise OverflowError("rhs must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, rhs) * elif isinstance(rhs, intbitset): # <<<<<<<<<<<<<< * intBitSetISub(self.bitset, ( rhs).bitset) * else: */ goto __pyx_L3; } /* "intbitset.pyx":398 * intBitSetISub(self.bitset, ( rhs).bitset) * else: * if self.sanity_checks: # <<<<<<<<<<<<<< * for elem in rhs: * if elem < 0: */ /*else*/ { if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":399 * else: * if self.sanity_checks: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_4 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_4); __pyx_t_9 = 0; __pyx_t_10 = NULL; } else { __pyx_t_9 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 399, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_10 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 399, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_10)) { if (likely(PyList_CheckExact(__pyx_t_4))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 399, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } __pyx_t_3 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_9); ++__pyx_t_9; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 399, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_9)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_9); #endif ++__pyx_t_9; } if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 399, __pyx_L1_error) } else { __pyx_t_3 = __pyx_t_10(__pyx_t_4); if (unlikely(!__pyx_t_3)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 399, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_3); __pyx_t_11 = __Pyx_PyLong_As_int(__pyx_t_3); if (unlikely((__pyx_t_11 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 399, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_elem = __pyx_t_11; /* "intbitset.pyx":400 * if self.sanity_checks: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_1 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":401 * for elem in rhs: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_7 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_2 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 401, __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, 401, __pyx_L1_error) /* "intbitset.pyx":400 * if self.sanity_checks: * for elem in rhs: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":402 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) */ __pyx_t_1 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":403 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * else: */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_7 = __pyx_builtin_OverflowError; __pyx_t_6 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 403, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_12 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_6); if (unlikely(!__pyx_t_12)) __PYX_ERR(0, 403, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_12); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_12}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 403, __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, 403, __pyx_L1_error) /* "intbitset.pyx":402 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) */ } /* "intbitset.pyx":404 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) # <<<<<<<<<<<<<< * else: * for elem in rhs: */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":399 * else: * if self.sanity_checks: * for elem in rhs: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; /* "intbitset.pyx":398 * intBitSetISub(self.bitset, ( rhs).bitset) * else: * if self.sanity_checks: # <<<<<<<<<<<<<< * for elem in rhs: * if elem < 0: */ goto __pyx_L6; } /* "intbitset.pyx":406 * intBitSetDelElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * return self */ /*else*/ { if (likely(PyList_CheckExact(__pyx_v_rhs)) || PyTuple_CheckExact(__pyx_v_rhs)) { __pyx_t_4 = __pyx_v_rhs; __Pyx_INCREF(__pyx_t_4); __pyx_t_9 = 0; __pyx_t_10 = NULL; } else { __pyx_t_9 = -1; __pyx_t_4 = PyObject_GetIter(__pyx_v_rhs); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 406, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_10 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_4); if (unlikely(!__pyx_t_10)) __PYX_ERR(0, 406, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_10)) { if (likely(PyList_CheckExact(__pyx_t_4))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 406, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } __pyx_t_3 = __Pyx_PyList_GetItemRef(__pyx_t_4, __pyx_t_9); ++__pyx_t_9; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_4); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 406, __pyx_L1_error) #endif if (__pyx_t_9 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_4, __pyx_t_9)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_4, __pyx_t_9); #endif ++__pyx_t_9; } if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 406, __pyx_L1_error) } else { __pyx_t_3 = __pyx_t_10(__pyx_t_4); if (unlikely(!__pyx_t_3)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 406, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_3); __pyx_t_11 = __Pyx_PyLong_As_int(__pyx_t_3); if (unlikely((__pyx_t_11 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 406, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_v_elem = __pyx_t_11; /* "intbitset.pyx":407 * else: * for elem in rhs: * intBitSetDelElem(self.bitset, elem) # <<<<<<<<<<<<<< * return self * */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":406 * intBitSetDelElem(self.bitset, elem) * else: * for elem in rhs: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * return self */ } __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; } __pyx_L6:; } __pyx_L3:; /* "intbitset.pyx":408 * for elem in rhs: * intBitSetDelElem(self.bitset, elem) * return self # <<<<<<<<<<<<<< * * def __sub__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_self); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0; /* "intbitset.pyx":385 * return self * * def __isub__(self not None, rhs not None): # <<<<<<<<<<<<<< * """Remove all elements of another set from this set.""" * cdef int elem */ /* 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_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_12); __Pyx_AddTraceback("intbitset.intbitset.__isub__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":410 * return self * * def __sub__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the difference of two intbitsets as a new set. * (i.e. all elements that are in this intbitset but not the other.) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_25__sub__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_24__sub__, "Return the difference of two intbitsets as a new set.\n (i.e. all elements that are in this intbitset but not the other.)\n "); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_24__sub__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_25__sub__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__sub__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 410, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 410, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_24__sub__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_24__sub__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; PyObject *__pyx_t_5 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__sub__", 0); /* "intbitset.pyx":414 * (i.e. all elements that are in this intbitset but not the other.) * """ * cdef intbitset ret = intbitset(no_allocate=1) # <<<<<<<<<<<<<< * (ret).bitset = intBitSetSub(( self).bitset, rhs.bitset) * return ret */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, NULL}; __pyx_t_5 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 414, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_no_allocate, __pyx_mstate_global->__pyx_int_1, __pyx_t_5, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 414, __pyx_L1_error) __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder(__pyx_t_3, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_5); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 414, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":415 * """ * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetSub(( self).bitset, rhs.bitset) # <<<<<<<<<<<<<< * return ret * */ __pyx_v_ret->bitset = intBitSetSub(__pyx_v_self->bitset, __pyx_v_rhs->bitset); /* "intbitset.pyx":416 * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetSub(( self).bitset, rhs.bitset) * return ret # <<<<<<<<<<<<<< * * def __and__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":410 * return self * * def __sub__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the difference of two intbitsets as a new set. * (i.e. all elements that are in this intbitset but not the other.) */ /* 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_5); __Pyx_AddTraceback("intbitset.intbitset.__sub__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":418 * return ret * * def __and__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the intersection of two intbitsets as a new set. * (i.e. all elements that are in both intbitsets.) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_27__and__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_26__and__, "Return the intersection of two intbitsets as a new set.\n (i.e. all elements that are in both intbitsets.)\n "); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_26__and__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_27__and__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__and__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 418, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 418, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_26__and__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_26__and__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; PyObject *__pyx_t_5 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__and__", 0); /* "intbitset.pyx":422 * (i.e. all elements that are in both intbitsets.) * """ * cdef intbitset ret = intbitset(no_allocate=1) # <<<<<<<<<<<<<< * (ret).bitset = intBitSetIntersection(( self).bitset, rhs.bitset) * return ret */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, NULL}; __pyx_t_5 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 422, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_no_allocate, __pyx_mstate_global->__pyx_int_1, __pyx_t_5, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 422, __pyx_L1_error) __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder(__pyx_t_3, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_5); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 422, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":423 * """ * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetIntersection(( self).bitset, rhs.bitset) # <<<<<<<<<<<<<< * return ret * */ __pyx_v_ret->bitset = intBitSetIntersection(__pyx_v_self->bitset, __pyx_v_rhs->bitset); /* "intbitset.pyx":424 * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetIntersection(( self).bitset, rhs.bitset) * return ret # <<<<<<<<<<<<<< * * def __iand__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":418 * return ret * * def __and__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the intersection of two intbitsets as a new set. * (i.e. all elements that are in both intbitsets.) */ /* 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_5); __Pyx_AddTraceback("intbitset.intbitset.__and__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":426 * return ret * * def __iand__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Update a intbitset with the intersection of itself and another.""" * intBitSetIIntersection(self.bitset, rhs.bitset) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_29__iand__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_28__iand__, "Update a intbitset with the intersection of itself and another."); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_28__iand__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_29__iand__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iand__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 426, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 426, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_28__iand__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_28__iand__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iand__", 0); /* "intbitset.pyx":428 * def __iand__(self not None, intbitset rhs not None): * """Update a intbitset with the intersection of itself and another.""" * intBitSetIIntersection(self.bitset, rhs.bitset) # <<<<<<<<<<<<<< * return self * */ (void)(intBitSetIIntersection(__pyx_v_self->bitset, __pyx_v_rhs->bitset)); /* "intbitset.pyx":429 * """Update a intbitset with the intersection of itself and another.""" * intBitSetIIntersection(self.bitset, rhs.bitset) * return self # <<<<<<<<<<<<<< * * def __or__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_self); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0; /* "intbitset.pyx":426 * return ret * * def __iand__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Update a intbitset with the intersection of itself and another.""" * intBitSetIIntersection(self.bitset, rhs.bitset) */ /* function exit code */ __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":431 * return self * * def __or__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the union of two intbitsets as a new set. * (i.e. all elements that are in either intbitsets.) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_31__or__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_30__or__, "Return the union of two intbitsets as a new set.\n (i.e. all elements that are in either intbitsets.)\n "); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_30__or__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_31__or__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__or__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 431, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 431, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_30__or__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_30__or__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; PyObject *__pyx_t_5 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__or__", 0); /* "intbitset.pyx":435 * (i.e. all elements that are in either intbitsets.) * """ * cdef intbitset ret = intbitset(no_allocate=1) # <<<<<<<<<<<<<< * (ret).bitset = intBitSetUnion(( self).bitset, rhs.bitset) * return ret */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, NULL}; __pyx_t_5 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 435, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_no_allocate, __pyx_mstate_global->__pyx_int_1, __pyx_t_5, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 435, __pyx_L1_error) __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder(__pyx_t_3, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_5); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 435, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":436 * """ * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetUnion(( self).bitset, rhs.bitset) # <<<<<<<<<<<<<< * return ret * */ __pyx_v_ret->bitset = intBitSetUnion(__pyx_v_self->bitset, __pyx_v_rhs->bitset); /* "intbitset.pyx":437 * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetUnion(( self).bitset, rhs.bitset) * return ret # <<<<<<<<<<<<<< * * def __ior__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":431 * return self * * def __or__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the union of two intbitsets as a new set. * (i.e. all elements that are in either intbitsets.) */ /* 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_5); __Pyx_AddTraceback("intbitset.intbitset.__or__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":439 * return ret * * def __ior__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Update a intbitset with the union of itself and another.""" * intBitSetIUnion(self.bitset, rhs.bitset) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_33__ior__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_32__ior__, "Update a intbitset with the union of itself and another."); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_32__ior__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_33__ior__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__ior__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 439, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 439, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_32__ior__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_32__ior__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__ior__", 0); /* "intbitset.pyx":441 * def __ior__(self not None, intbitset rhs not None): * """Update a intbitset with the union of itself and another.""" * intBitSetIUnion(self.bitset, rhs.bitset) # <<<<<<<<<<<<<< * return self * */ (void)(intBitSetIUnion(__pyx_v_self->bitset, __pyx_v_rhs->bitset)); /* "intbitset.pyx":442 * """Update a intbitset with the union of itself and another.""" * intBitSetIUnion(self.bitset, rhs.bitset) * return self # <<<<<<<<<<<<<< * * def __xor__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_self); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0; /* "intbitset.pyx":439 * return ret * * def __ior__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Update a intbitset with the union of itself and another.""" * intBitSetIUnion(self.bitset, rhs.bitset) */ /* function exit code */ __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":444 * return self * * def __xor__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the symmetric difference of two sets as a new set. * (i.e. all elements that are in exactly one of the sets.) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_35__xor__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_34__xor__, "Return the symmetric difference of two sets as a new set.\n (i.e. all elements that are in exactly one of the sets.)\n "); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_34__xor__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_35__xor__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__xor__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 444, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 444, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_34__xor__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_34__xor__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; PyObject *__pyx_t_5 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__xor__", 0); /* "intbitset.pyx":448 * (i.e. all elements that are in exactly one of the sets.) * """ * cdef intbitset ret = intbitset(no_allocate=1) # <<<<<<<<<<<<<< * (ret).bitset = intBitSetXor(( self).bitset, rhs.bitset) * return ret */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2 + ((CYTHON_VECTORCALL) ? 1 : 0)] = {__pyx_t_2, NULL}; __pyx_t_5 = __Pyx_MakeVectorcallBuilderKwds(1); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 448, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); if (__Pyx_VectorcallBuilder_AddArg(__pyx_mstate_global->__pyx_n_u_no_allocate, __pyx_mstate_global->__pyx_int_1, __pyx_t_5, __pyx_callargs+1, 0) < (0)) __PYX_ERR(0, 448, __pyx_L1_error) __pyx_t_1 = __Pyx_Object_Vectorcall_CallFromBuilder(__pyx_t_3, __pyx_callargs+__pyx_t_4, (1-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET), __pyx_t_5); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 448, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":449 * """ * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetXor(( self).bitset, rhs.bitset) # <<<<<<<<<<<<<< * return ret * */ __pyx_v_ret->bitset = intBitSetXor(__pyx_v_self->bitset, __pyx_v_rhs->bitset); /* "intbitset.pyx":450 * cdef intbitset ret = intbitset(no_allocate=1) * (ret).bitset = intBitSetXor(( self).bitset, rhs.bitset) * return ret # <<<<<<<<<<<<<< * * def __ixor__(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":444 * return self * * def __xor__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return the symmetric difference of two sets as a new set. * (i.e. all elements that are in exactly one of the sets.) */ /* 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_5); __Pyx_AddTraceback("intbitset.intbitset.__xor__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":452 * return ret * * def __ixor__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Update an intbitset with the symmetric difference of itself and another. * """ */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_37__ixor__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_36__ixor__, "Update an intbitset with the symmetric difference of itself and another.\n "); #if CYTHON_UPDATE_DESCRIPTOR_DOC struct wrapperbase __pyx_wrapperbase_9intbitset_9intbitset_36__ixor__; #endif static PyObject *__pyx_pw_9intbitset_9intbitset_37__ixor__(PyObject *__pyx_v_self, PyObject *__pyx_v_rhs) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__ixor__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 452, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 452, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_36__ixor__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_rhs)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_36__ixor__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__ixor__", 0); /* "intbitset.pyx":455 * """Update an intbitset with the symmetric difference of itself and another. * """ * intBitSetIXor(self.bitset, rhs.bitset) # <<<<<<<<<<<<<< * return self * */ (void)(intBitSetIXor(__pyx_v_self->bitset, __pyx_v_rhs->bitset)); /* "intbitset.pyx":456 * """ * intBitSetIXor(self.bitset, rhs.bitset) * return self # <<<<<<<<<<<<<< * * def __repr__(self not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_self); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0; /* "intbitset.pyx":452 * return ret * * def __ixor__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Update an intbitset with the symmetric difference of itself and another. * """ */ /* function exit code */ __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":458 * return self * * def __repr__(self not None): # <<<<<<<<<<<<<< * finite_list = self.extract_finite_list() * if self.bitset.trailing_bits: */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_39__repr__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_9intbitset_9intbitset_39__repr__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__repr__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 458, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_38__repr__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_38__repr__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { PyObject *__pyx_v_finite_list = NULL; PyObject *__pyx_r = NULL; __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("__repr__", 0); /* "intbitset.pyx":459 * * def __repr__(self not None): * finite_list = self.extract_finite_list() # <<<<<<<<<<<<<< * if self.bitset.trailing_bits: * return "intbitset(%s, trailing_bits=True)" % repr(finite_list) */ __pyx_t_1 = ((struct __pyx_vtabstruct_9intbitset_intbitset *)__pyx_v_self->__pyx_vtab)->extract_finite_list(__pyx_v_self, 0, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 459, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_finite_list = __pyx_t_1; __pyx_t_1 = 0; /* "intbitset.pyx":460 * def __repr__(self not None): * finite_list = self.extract_finite_list() * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * return "intbitset(%s, trailing_bits=True)" % repr(finite_list) * else: */ __pyx_t_2 = (__pyx_v_self->bitset->trailing_bits != 0); if (__pyx_t_2) { /* "intbitset.pyx":461 * finite_list = self.extract_finite_list() * if self.bitset.trailing_bits: * return "intbitset(%s, trailing_bits=True)" % repr(finite_list) # <<<<<<<<<<<<<< * else: * return "intbitset(%s)" % repr(finite_list) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyObject_Repr(__pyx_v_finite_list); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 461, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_3 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_intbitset_s_trailing_bits_True, __pyx_t_1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 461, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; /* "intbitset.pyx":460 * def __repr__(self not None): * finite_list = self.extract_finite_list() * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * return "intbitset(%s, trailing_bits=True)" % repr(finite_list) * else: */ } /* "intbitset.pyx":463 * return "intbitset(%s, trailing_bits=True)" % repr(finite_list) * else: * return "intbitset(%s)" % repr(finite_list) # <<<<<<<<<<<<<< * * def __str__(self not None): */ /*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = PyObject_Repr(__pyx_v_finite_list); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 463, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_intbitset_s, __pyx_t_3); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 463, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; } /* "intbitset.pyx":458 * return self * * def __repr__(self not None): # <<<<<<<<<<<<<< * finite_list = self.extract_finite_list() * if self.bitset.trailing_bits: */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("intbitset.intbitset.__repr__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_finite_list); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":465 * return "intbitset(%s)" % repr(finite_list) * * def __str__(self not None): # <<<<<<<<<<<<<< * cdef int tot * tot = intBitSetGetTot(self.bitset) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_41__str__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_9intbitset_9intbitset_41__str__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__str__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 465, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_40__str__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_40__str__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { int __pyx_v_tot; PyObject *__pyx_v_begin_list = NULL; PyObject *__pyx_v_end_list = NULL; PyObject *__pyx_v_ret = NULL; PyObject *__pyx_v_n = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; Py_ssize_t __pyx_t_3; PyObject *(*__pyx_t_4)(PyObject *); PyObject *__pyx_t_5 = NULL; PyObject *__pyx_t_6 = NULL; size_t __pyx_t_7; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__str__", 0); /* "intbitset.pyx":467 * def __str__(self not None): * cdef int tot * tot = intBitSetGetTot(self.bitset) # <<<<<<<<<<<<<< * if tot < 0: * return "intbitset([...], trailing_bits=True)" */ __pyx_v_tot = intBitSetGetTot(__pyx_v_self->bitset); /* "intbitset.pyx":468 * cdef int tot * tot = intBitSetGetTot(self.bitset) * if tot < 0: # <<<<<<<<<<<<<< * return "intbitset([...], trailing_bits=True)" * elif tot > 10: */ __pyx_t_1 = (__pyx_v_tot < 0); if (__pyx_t_1) { /* "intbitset.pyx":469 * tot = intBitSetGetTot(self.bitset) * if tot < 0: * return "intbitset([...], trailing_bits=True)" # <<<<<<<<<<<<<< * elif tot > 10: * begin_list = self[0:5] */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_intbitset_trailing_bits_True); __pyx_r = __pyx_mstate_global->__pyx_kp_u_intbitset_trailing_bits_True; goto __pyx_L0; /* "intbitset.pyx":468 * cdef int tot * tot = intBitSetGetTot(self.bitset) * if tot < 0: # <<<<<<<<<<<<<< * return "intbitset([...], trailing_bits=True)" * elif tot > 10: */ } /* "intbitset.pyx":470 * if tot < 0: * return "intbitset([...], trailing_bits=True)" * elif tot > 10: # <<<<<<<<<<<<<< * begin_list = self[0:5] * end_list = self[tot - 5:tot] */ __pyx_t_1 = (__pyx_v_tot > 10); if (__pyx_t_1) { /* "intbitset.pyx":471 * return "intbitset([...], trailing_bits=True)" * elif tot > 10: * begin_list = self[0:5] # <<<<<<<<<<<<<< * end_list = self[tot - 5:tot] * ret = "intbitset([" */ __pyx_t_2 = __Pyx_PyObject_GetSlice(((PyObject *)__pyx_v_self), 0, 5, NULL, NULL, &__pyx_mstate_global->__pyx_slice[0], 1, 1, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 471, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_begin_list = __pyx_t_2; __pyx_t_2 = 0; /* "intbitset.pyx":472 * elif tot > 10: * begin_list = self[0:5] * end_list = self[tot - 5:tot] # <<<<<<<<<<<<<< * ret = "intbitset([" * for n in begin_list: */ __pyx_t_2 = __Pyx_PyObject_GetSlice(((PyObject *)__pyx_v_self), (__pyx_v_tot - 5), __pyx_v_tot, NULL, NULL, NULL, 1, 1, 1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 472, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_v_end_list = __pyx_t_2; __pyx_t_2 = 0; /* "intbitset.pyx":473 * begin_list = self[0:5] * end_list = self[tot - 5:tot] * ret = "intbitset([" # <<<<<<<<<<<<<< * for n in begin_list: * ret += '%i, ' % n */ __Pyx_INCREF(__pyx_mstate_global->__pyx_kp_u_intbitset); __pyx_v_ret = __pyx_mstate_global->__pyx_kp_u_intbitset; /* "intbitset.pyx":474 * end_list = self[tot - 5:tot] * ret = "intbitset([" * for n in begin_list: # <<<<<<<<<<<<<< * ret += '%i, ' % n * ret += "..., " */ if (likely(PyList_CheckExact(__pyx_v_begin_list)) || PyTuple_CheckExact(__pyx_v_begin_list)) { __pyx_t_2 = __pyx_v_begin_list; __Pyx_INCREF(__pyx_t_2); __pyx_t_3 = 0; __pyx_t_4 = NULL; } else { __pyx_t_3 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_v_begin_list); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 474, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 474, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_4)) { if (likely(PyList_CheckExact(__pyx_t_2))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_2); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 474, __pyx_L1_error) #endif if (__pyx_t_3 >= __pyx_temp) break; } __pyx_t_5 = __Pyx_PyList_GetItemRef(__pyx_t_2, __pyx_t_3); ++__pyx_t_3; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_2); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 474, __pyx_L1_error) #endif if (__pyx_t_3 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_5 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_3)); #else __pyx_t_5 = __Pyx_PySequence_ITEM(__pyx_t_2, __pyx_t_3); #endif ++__pyx_t_3; } if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 474, __pyx_L1_error) } else { __pyx_t_5 = __pyx_t_4(__pyx_t_2); if (unlikely(!__pyx_t_5)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 474, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_5); __Pyx_XDECREF_SET(__pyx_v_n, __pyx_t_5); __pyx_t_5 = 0; /* "intbitset.pyx":475 * ret = "intbitset([" * for n in begin_list: * ret += '%i, ' % n # <<<<<<<<<<<<<< * ret += "..., " * for n in end_list: */ __pyx_t_5 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_i, __pyx_v_n); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 475, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = __Pyx_PyUnicode_ConcatInPlace(__pyx_v_ret, __pyx_t_5); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 475, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF_SET(__pyx_v_ret, ((PyObject*)__pyx_t_6)); __pyx_t_6 = 0; /* "intbitset.pyx":474 * end_list = self[tot - 5:tot] * ret = "intbitset([" * for n in begin_list: # <<<<<<<<<<<<<< * ret += '%i, ' % n * ret += "..., " */ } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":476 * for n in begin_list: * ret += '%i, ' % n * ret += "..., " # <<<<<<<<<<<<<< * for n in end_list: * ret += '%i, ' % n */ __pyx_t_2 = __Pyx_PyUnicode_ConcatInPlace(__pyx_v_ret, __pyx_mstate_global->__pyx_kp_u__2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 476, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF_SET(__pyx_v_ret, ((PyObject*)__pyx_t_2)); __pyx_t_2 = 0; /* "intbitset.pyx":477 * ret += '%i, ' % n * ret += "..., " * for n in end_list: # <<<<<<<<<<<<<< * ret += '%i, ' % n * ret = ret[:-2] */ if (likely(PyList_CheckExact(__pyx_v_end_list)) || PyTuple_CheckExact(__pyx_v_end_list)) { __pyx_t_2 = __pyx_v_end_list; __Pyx_INCREF(__pyx_t_2); __pyx_t_3 = 0; __pyx_t_4 = NULL; } else { __pyx_t_3 = -1; __pyx_t_2 = PyObject_GetIter(__pyx_v_end_list); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 477, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_2); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 477, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_4)) { if (likely(PyList_CheckExact(__pyx_t_2))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_2); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 477, __pyx_L1_error) #endif if (__pyx_t_3 >= __pyx_temp) break; } __pyx_t_6 = __Pyx_PyList_GetItemRef(__pyx_t_2, __pyx_t_3); ++__pyx_t_3; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_2); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 477, __pyx_L1_error) #endif if (__pyx_t_3 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_6 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_2, __pyx_t_3)); #else __pyx_t_6 = __Pyx_PySequence_ITEM(__pyx_t_2, __pyx_t_3); #endif ++__pyx_t_3; } if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 477, __pyx_L1_error) } else { __pyx_t_6 = __pyx_t_4(__pyx_t_2); if (unlikely(!__pyx_t_6)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 477, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_6); __Pyx_XDECREF_SET(__pyx_v_n, __pyx_t_6); __pyx_t_6 = 0; /* "intbitset.pyx":478 * ret += "..., " * for n in end_list: * ret += '%i, ' % n # <<<<<<<<<<<<<< * ret = ret[:-2] * ret += '])' */ __pyx_t_6 = __Pyx_PyUnicode_FormatSafe(__pyx_mstate_global->__pyx_kp_u_i, __pyx_v_n); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 478, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_5 = __Pyx_PyUnicode_ConcatInPlace(__pyx_v_ret, __pyx_t_6); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 478, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF_SET(__pyx_v_ret, ((PyObject*)__pyx_t_5)); __pyx_t_5 = 0; /* "intbitset.pyx":477 * ret += '%i, ' % n * ret += "..., " * for n in end_list: # <<<<<<<<<<<<<< * ret += '%i, ' % n * ret = ret[:-2] */ } __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":479 * for n in end_list: * ret += '%i, ' % n * ret = ret[:-2] # <<<<<<<<<<<<<< * ret += '])' * return ret */ __pyx_t_2 = __Pyx_PyUnicode_Substring(__pyx_v_ret, 0, -2L); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 479, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF_SET(__pyx_v_ret, ((PyObject*)__pyx_t_2)); __pyx_t_2 = 0; /* "intbitset.pyx":480 * ret += '%i, ' % n * ret = ret[:-2] * ret += '])' # <<<<<<<<<<<<<< * return ret * else: */ __pyx_t_2 = __Pyx_PyUnicode_ConcatInPlace(__pyx_v_ret, __pyx_mstate_global->__pyx_kp_u__3); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 480, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF_SET(__pyx_v_ret, ((PyObject*)__pyx_t_2)); __pyx_t_2 = 0; /* "intbitset.pyx":481 * ret = ret[:-2] * ret += '])' * return ret # <<<<<<<<<<<<<< * else: * return self.__repr__() */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_ret); __pyx_r = __pyx_v_ret; goto __pyx_L0; /* "intbitset.pyx":470 * if tot < 0: * return "intbitset([...], trailing_bits=True)" * elif tot > 10: # <<<<<<<<<<<<<< * begin_list = self[0:5] * end_list = self[tot - 5:tot] */ } /* "intbitset.pyx":483 * return ret * else: * return self.__repr__() # <<<<<<<<<<<<<< * * def __getitem__(self not None, object key): */ /*else*/ { __Pyx_XDECREF(__pyx_r); __pyx_t_5 = ((PyObject *)__pyx_v_self); __Pyx_INCREF(__pyx_t_5); __pyx_t_7 = 0; { PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_repr, __pyx_callargs+__pyx_t_7, (1-__pyx_t_7) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 483, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; } /* "intbitset.pyx":465 * return "intbitset(%s)" % repr(finite_list) * * def __str__(self not None): # <<<<<<<<<<<<<< * cdef int tot * tot = intBitSetGetTot(self.bitset) */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_AddTraceback("intbitset.intbitset.__str__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF(__pyx_v_begin_list); __Pyx_XDECREF(__pyx_v_end_list); __Pyx_XDECREF(__pyx_v_ret); __Pyx_XDECREF(__pyx_v_n); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":485 * return self.__repr__() * * def __getitem__(self not None, object key): # <<<<<<<<<<<<<< * cdef Py_ssize_t i * cdef int elem = -1 */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_43__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key); /*proto*/ static PyObject *__pyx_pw_9intbitset_9intbitset_43__getitem__(PyObject *__pyx_v_self, PyObject *__pyx_v_key) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getitem__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 485, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_42__getitem__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), ((PyObject *)__pyx_v_key)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_42__getitem__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_key) { Py_ssize_t __pyx_v_i; int __pyx_v_elem; int __pyx_v_start; int __pyx_v_end; int __pyx_v_step; struct __pyx_obj_9intbitset_intbitset *__pyx_v_retset = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; int __pyx_t_2; PyObject *__pyx_t_3 = NULL; PyObject *__pyx_t_4 = NULL; PyObject *__pyx_t_5 = NULL; size_t __pyx_t_6; PyObject *__pyx_t_7 = NULL; PyObject *__pyx_t_8 = NULL; PyObject *(*__pyx_t_9)(PyObject *); int __pyx_t_10; int __pyx_t_11; int __pyx_t_12; Py_ssize_t __pyx_t_13; long __pyx_t_14; long __pyx_t_15; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__getitem__", 0); /* "intbitset.pyx":487 * def __getitem__(self not None, object key): * cdef Py_ssize_t i * cdef int elem = -1 # <<<<<<<<<<<<<< * cdef int start * cdef int end */ __pyx_v_elem = -1; /* "intbitset.pyx":491 * cdef int end * cdef int step * if hasattr(key, 'indices'): # <<<<<<<<<<<<<< * ## This is a slice object! * if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): */ __pyx_t_1 = __Pyx_HasAttr(__pyx_v_key, __pyx_mstate_global->__pyx_n_u_indices); if (unlikely(__pyx_t_1 == ((int)-1))) __PYX_ERR(0, 491, __pyx_L1_error) if (__pyx_t_1) { /* "intbitset.pyx":493 * if hasattr(key, 'indices'): * ## This is a slice object! * if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): # <<<<<<<<<<<<<< * raise IndexError("negative indexes are not allowed on infinite intbitset") * retset = intbitset() */ __pyx_t_2 = (__pyx_v_self->bitset->trailing_bits != 0); if (__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; } __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_v_key, __pyx_mstate_global->__pyx_n_u_start); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 493, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = PyObject_RichCompare(__pyx_t_3, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 493, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 493, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (!__pyx_t_2) { } else { __pyx_t_1 = __pyx_t_2; goto __pyx_L5_bool_binop_done; } __pyx_t_4 = __Pyx_PyObject_GetAttrStr(__pyx_v_key, __pyx_mstate_global->__pyx_n_u_stop); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 493, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = PyObject_RichCompare(__pyx_t_4, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 493, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_2 < 0))) __PYX_ERR(0, 493, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_1 = __pyx_t_2; __pyx_L5_bool_binop_done:; if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":494 * ## This is a slice object! * if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): * raise IndexError("negative indexes are not allowed on infinite intbitset") # <<<<<<<<<<<<<< * retset = intbitset() * start, end, step = key.indices(intBitSetGetTot(self.bitset)) */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_IndexError); __pyx_t_5 = __pyx_builtin_IndexError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_negative_indexes_are_not_allowed}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 494, __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, 494, __pyx_L1_error) /* "intbitset.pyx":493 * if hasattr(key, 'indices'): * ## This is a slice object! * if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): # <<<<<<<<<<<<<< * raise IndexError("negative indexes are not allowed on infinite intbitset") * retset = intbitset() */ } /* "intbitset.pyx":495 * if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): * raise IndexError("negative indexes are not allowed on infinite intbitset") * retset = intbitset() # <<<<<<<<<<<<<< * start, end, step = key.indices(intBitSetGetTot(self.bitset)) * if step < 0: */ __pyx_t_5 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_5, NULL}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (1-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __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(0, 495, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_3); } __pyx_v_retset = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":496 * raise IndexError("negative indexes are not allowed on infinite intbitset") * retset = intbitset() * start, end, step = key.indices(intBitSetGetTot(self.bitset)) # <<<<<<<<<<<<<< * if step < 0: * raise ValueError("negative steps are not yet supported") */ __pyx_t_4 = __pyx_v_key; __Pyx_INCREF(__pyx_t_4); __pyx_t_5 = __Pyx_PyLong_From_int(intBitSetGetTot(__pyx_v_self->bitset)); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = 0; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_5}; __pyx_t_3 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_indices, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); } if ((likely(PyTuple_CheckExact(__pyx_t_3))) || (PyList_CheckExact(__pyx_t_3))) { PyObject* sequence = __pyx_t_3; Py_ssize_t size = __Pyx_PySequence_SIZE(sequence); if (unlikely(size != 3)) { if (size > 3) __Pyx_RaiseTooManyValuesError(3); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); __PYX_ERR(0, 496, __pyx_L1_error) } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS if (likely(PyTuple_CheckExact(sequence))) { __pyx_t_5 = PyTuple_GET_ITEM(sequence, 0); __Pyx_INCREF(__pyx_t_5); __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1); __Pyx_INCREF(__pyx_t_4); __pyx_t_7 = PyTuple_GET_ITEM(sequence, 2); __Pyx_INCREF(__pyx_t_7); } else { __pyx_t_5 = __Pyx_PyList_GetItemRef(sequence, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_XGOTREF(__pyx_t_5); __pyx_t_4 = __Pyx_PyList_GetItemRef(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_XGOTREF(__pyx_t_4); __pyx_t_7 = __Pyx_PyList_GetItemRef(sequence, 2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_XGOTREF(__pyx_t_7); } #else __pyx_t_5 = __Pyx_PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_4 = __Pyx_PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_7 = __Pyx_PySequence_ITEM(sequence, 2); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); #endif __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; } else { Py_ssize_t index = -1; __pyx_t_8 = PyObject_GetIter(__pyx_t_3); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_9 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_8); index = 0; __pyx_t_5 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_5)) goto __pyx_L8_unpacking_failed; __Pyx_GOTREF(__pyx_t_5); index = 1; __pyx_t_4 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_4)) goto __pyx_L8_unpacking_failed; __Pyx_GOTREF(__pyx_t_4); index = 2; __pyx_t_7 = __pyx_t_9(__pyx_t_8); if (unlikely(!__pyx_t_7)) goto __pyx_L8_unpacking_failed; __Pyx_GOTREF(__pyx_t_7); if (__Pyx_IternextUnpackEndCheck(__pyx_t_9(__pyx_t_8), 3) < (0)) __PYX_ERR(0, 496, __pyx_L1_error) __pyx_t_9 = NULL; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L9_unpacking_done; __pyx_L8_unpacking_failed:; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __pyx_t_9 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); __PYX_ERR(0, 496, __pyx_L1_error) __pyx_L9_unpacking_done:; } __pyx_t_10 = __Pyx_PyLong_As_int(__pyx_t_5); if (unlikely((__pyx_t_10 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_11 = __Pyx_PyLong_As_int(__pyx_t_4); if (unlikely((__pyx_t_11 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_12 = __Pyx_PyLong_As_int(__pyx_t_7); if (unlikely((__pyx_t_12 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 496, __pyx_L1_error) __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_v_start = __pyx_t_10; __pyx_v_end = __pyx_t_11; __pyx_v_step = __pyx_t_12; /* "intbitset.pyx":497 * retset = intbitset() * start, end, step = key.indices(intBitSetGetTot(self.bitset)) * if step < 0: # <<<<<<<<<<<<<< * raise ValueError("negative steps are not yet supported") * for i in range(start): */ __pyx_t_1 = (__pyx_v_step < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":498 * start, end, step = key.indices(intBitSetGetTot(self.bitset)) * if step < 0: * raise ValueError("negative steps are not yet supported") # <<<<<<<<<<<<<< * for i in range(start): * elem = intBitSetGetNext(self.bitset, elem) */ __pyx_t_7 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_negative_steps_are_not_yet_suppo}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 498, __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, 498, __pyx_L1_error) /* "intbitset.pyx":497 * retset = intbitset() * start, end, step = key.indices(intBitSetGetTot(self.bitset)) * if step < 0: # <<<<<<<<<<<<<< * raise ValueError("negative steps are not yet supported") * for i in range(start): */ } /* "intbitset.pyx":499 * if step < 0: * raise ValueError("negative steps are not yet supported") * for i in range(start): # <<<<<<<<<<<<<< * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: */ __pyx_t_12 = __pyx_v_start; __pyx_t_11 = __pyx_t_12; for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_11; __pyx_t_13+=1) { __pyx_v_i = __pyx_t_13; /* "intbitset.pyx":500 * raise ValueError("negative steps are not yet supported") * for i in range(start): * elem = intBitSetGetNext(self.bitset, elem) # <<<<<<<<<<<<<< * if elem < 0: * return retset */ __pyx_v_elem = intBitSetGetNext(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":501 * for i in range(start): * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: # <<<<<<<<<<<<<< * return retset * for i in range(end - start): */ __pyx_t_1 = (__pyx_v_elem < 0); if (__pyx_t_1) { /* "intbitset.pyx":502 * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: * return retset # <<<<<<<<<<<<<< * for i in range(end - start): * elem = intBitSetGetNext(self.bitset, elem) */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_retset); __pyx_r = ((PyObject *)__pyx_v_retset); goto __pyx_L0; /* "intbitset.pyx":501 * for i in range(start): * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: # <<<<<<<<<<<<<< * return retset * for i in range(end - start): */ } } /* "intbitset.pyx":503 * if elem < 0: * return retset * for i in range(end - start): # <<<<<<<<<<<<<< * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: */ __pyx_t_12 = (__pyx_v_end - __pyx_v_start); __pyx_t_11 = __pyx_t_12; for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_11; __pyx_t_13+=1) { __pyx_v_i = __pyx_t_13; /* "intbitset.pyx":504 * return retset * for i in range(end - start): * elem = intBitSetGetNext(self.bitset, elem) # <<<<<<<<<<<<<< * if elem < 0: * return retset */ __pyx_v_elem = intBitSetGetNext(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":505 * for i in range(end - start): * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: # <<<<<<<<<<<<<< * return retset * if i % step == 0: */ __pyx_t_1 = (__pyx_v_elem < 0); if (__pyx_t_1) { /* "intbitset.pyx":506 * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: * return retset # <<<<<<<<<<<<<< * if i % step == 0: * retset.add(elem) */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_retset); __pyx_r = ((PyObject *)__pyx_v_retset); goto __pyx_L0; /* "intbitset.pyx":505 * for i in range(end - start): * elem = intBitSetGetNext(self.bitset, elem) * if elem < 0: # <<<<<<<<<<<<<< * return retset * if i % step == 0: */ } /* "intbitset.pyx":507 * if elem < 0: * return retset * if i % step == 0: # <<<<<<<<<<<<<< * retset.add(elem) * return retset */ if (unlikely(__pyx_v_step == 0)) { PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero"); __PYX_ERR(0, 507, __pyx_L1_error) } __pyx_t_1 = (__Pyx_mod_Py_ssize_t(__pyx_v_i, __pyx_v_step, 0) == 0); if (__pyx_t_1) { /* "intbitset.pyx":508 * return retset * if i % step == 0: * retset.add(elem) # <<<<<<<<<<<<<< * return retset * else: */ __pyx_t_3 = ((struct __pyx_vtabstruct_9intbitset_intbitset *)__pyx_v_retset->__pyx_vtab)->add(__pyx_v_retset, __pyx_v_elem, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 508, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":507 * if elem < 0: * return retset * if i % step == 0: # <<<<<<<<<<<<<< * retset.add(elem) * return retset */ } } /* "intbitset.pyx":509 * if i % step == 0: * retset.add(elem) * return retset # <<<<<<<<<<<<<< * else: * end = key */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_retset); __pyx_r = ((PyObject *)__pyx_v_retset); goto __pyx_L0; /* "intbitset.pyx":491 * cdef int end * cdef int step * if hasattr(key, 'indices'): # <<<<<<<<<<<<<< * ## This is a slice object! * if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): */ } /* "intbitset.pyx":511 * return retset * else: * end = key # <<<<<<<<<<<<<< * if end < 0: * if self.bitset.trailing_bits: */ /*else*/ { __pyx_t_12 = __Pyx_PyLong_As_int(__pyx_v_key); if (unlikely((__pyx_t_12 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 511, __pyx_L1_error) __pyx_v_end = __pyx_t_12; /* "intbitset.pyx":512 * else: * end = key * if end < 0: # <<<<<<<<<<<<<< * if self.bitset.trailing_bits: * raise IndexError("negative indexes are not allowed on infinite intbitset") */ __pyx_t_1 = (__pyx_v_end < 0); if (__pyx_t_1) { /* "intbitset.pyx":513 * end = key * if end < 0: * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * raise IndexError("negative indexes are not allowed on infinite intbitset") * end += intBitSetGetTot(self.bitset) */ __pyx_t_1 = (__pyx_v_self->bitset->trailing_bits != 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":514 * if end < 0: * if self.bitset.trailing_bits: * raise IndexError("negative indexes are not allowed on infinite intbitset") # <<<<<<<<<<<<<< * end += intBitSetGetTot(self.bitset) * if end < 0: */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_IndexError); __pyx_t_7 = __pyx_builtin_IndexError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_negative_indexes_are_not_allowed}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 514, __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, 514, __pyx_L1_error) /* "intbitset.pyx":513 * end = key * if end < 0: * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * raise IndexError("negative indexes are not allowed on infinite intbitset") * end += intBitSetGetTot(self.bitset) */ } /* "intbitset.pyx":515 * if self.bitset.trailing_bits: * raise IndexError("negative indexes are not allowed on infinite intbitset") * end += intBitSetGetTot(self.bitset) # <<<<<<<<<<<<<< * if end < 0: * raise IndexError("intbitset index out of range") */ __pyx_v_end = (__pyx_v_end + intBitSetGetTot(__pyx_v_self->bitset)); /* "intbitset.pyx":516 * raise IndexError("negative indexes are not allowed on infinite intbitset") * end += intBitSetGetTot(self.bitset) * if end < 0: # <<<<<<<<<<<<<< * raise IndexError("intbitset index out of range") * if end >= intBitSetGetTot(self.bitset): */ __pyx_t_1 = (__pyx_v_end < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":517 * end += intBitSetGetTot(self.bitset) * if end < 0: * raise IndexError("intbitset index out of range") # <<<<<<<<<<<<<< * if end >= intBitSetGetTot(self.bitset): * raise IndexError("intbitset index out of range") */ __pyx_t_7 = NULL; __Pyx_INCREF(__pyx_builtin_IndexError); __pyx_t_4 = __pyx_builtin_IndexError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_mstate_global->__pyx_kp_u_intbitset_index_out_of_range}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 517, __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, 517, __pyx_L1_error) /* "intbitset.pyx":516 * raise IndexError("negative indexes are not allowed on infinite intbitset") * end += intBitSetGetTot(self.bitset) * if end < 0: # <<<<<<<<<<<<<< * raise IndexError("intbitset index out of range") * if end >= intBitSetGetTot(self.bitset): */ } /* "intbitset.pyx":512 * else: * end = key * if end < 0: # <<<<<<<<<<<<<< * if self.bitset.trailing_bits: * raise IndexError("negative indexes are not allowed on infinite intbitset") */ } /* "intbitset.pyx":518 * if end < 0: * raise IndexError("intbitset index out of range") * if end >= intBitSetGetTot(self.bitset): # <<<<<<<<<<<<<< * raise IndexError("intbitset index out of range") * for i in range(end + 1): */ __pyx_t_1 = (__pyx_v_end >= intBitSetGetTot(__pyx_v_self->bitset)); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":519 * raise IndexError("intbitset index out of range") * if end >= intBitSetGetTot(self.bitset): * raise IndexError("intbitset index out of range") # <<<<<<<<<<<<<< * for i in range(end + 1): * elem = intBitSetGetNext(self.bitset, elem) */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_IndexError); __pyx_t_7 = __pyx_builtin_IndexError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_intbitset_index_out_of_range}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 519, __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, 519, __pyx_L1_error) /* "intbitset.pyx":518 * if end < 0: * raise IndexError("intbitset index out of range") * if end >= intBitSetGetTot(self.bitset): # <<<<<<<<<<<<<< * raise IndexError("intbitset index out of range") * for i in range(end + 1): */ } /* "intbitset.pyx":520 * if end >= intBitSetGetTot(self.bitset): * raise IndexError("intbitset index out of range") * for i in range(end + 1): # <<<<<<<<<<<<<< * elem = intBitSetGetNext(self.bitset, elem) * return elem */ __pyx_t_14 = (__pyx_v_end + 1); __pyx_t_15 = __pyx_t_14; for (__pyx_t_13 = 0; __pyx_t_13 < __pyx_t_15; __pyx_t_13+=1) { __pyx_v_i = __pyx_t_13; /* "intbitset.pyx":521 * raise IndexError("intbitset index out of range") * for i in range(end + 1): * elem = intBitSetGetNext(self.bitset, elem) # <<<<<<<<<<<<<< * return elem * */ __pyx_v_elem = intBitSetGetNext(__pyx_v_self->bitset, __pyx_v_elem); } /* "intbitset.pyx":522 * for i in range(end + 1): * elem = intBitSetGetNext(self.bitset, elem) * return elem # <<<<<<<<<<<<<< * * # pickle interface */ __Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_elem); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 522, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; } /* "intbitset.pyx":485 * return self.__repr__() * * def __getitem__(self not None, object key): # <<<<<<<<<<<<<< * cdef Py_ssize_t i * cdef int elem = -1 */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("intbitset.intbitset.__getitem__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_retset); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":525 * * # pickle interface * def __reduce__(self not None): # <<<<<<<<<<<<<< * return _, (self.fastdump(),) * */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_45__reduce__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_45__reduce__ = {"__reduce__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_45__reduce__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_45__reduce__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__reduce__ (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("__reduce__", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("__reduce__", __pyx_kwds); return NULL;} if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 525, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_44__reduce__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_44__reduce__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__reduce__", 0); /* "intbitset.pyx":526 * # pickle interface * def __reduce__(self not None): * return _, (self.fastdump(),) # <<<<<<<<<<<<<< * * __safe_for_unpickling__ = True */ __Pyx_XDECREF(__pyx_r); __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u__4); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 526, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = ((struct __pyx_vtabstruct_9intbitset_intbitset *)__pyx_v_self->__pyx_vtab)->fastdump(__pyx_v_self, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 526, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 526, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_GIVEREF(__pyx_t_2); if (__Pyx_PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2) != (0)) __PYX_ERR(0, 526, __pyx_L1_error); __pyx_t_2 = 0; __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 526, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GIVEREF(__pyx_t_1); if (__Pyx_PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1) != (0)) __PYX_ERR(0, 526, __pyx_L1_error); __Pyx_GIVEREF(__pyx_t_3); if (__Pyx_PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_3) != (0)) __PYX_ERR(0, 526, __pyx_L1_error); __pyx_t_1 = 0; __pyx_t_3 = 0; __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; /* "intbitset.pyx":525 * * # pickle interface * def __reduce__(self not None): # <<<<<<<<<<<<<< * return _, (self.fastdump(),) * */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("intbitset.intbitset.__reduce__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":531 * * # Iterator interface * def __iter__(self not None): # <<<<<<<<<<<<<< * if self.bitset.trailing_bits: * raise OverflowError("It's impossible to iterate over an infinite set.") */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_47__iter__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_9intbitset_9intbitset_47__iter__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iter__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 531, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_46__iter__(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_46__iter__(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__iter__", 0); /* "intbitset.pyx":532 * # Iterator interface * def __iter__(self not None): * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * raise OverflowError("It's impossible to iterate over an infinite set.") * return intbitset_iterator(self) */ __pyx_t_1 = (__pyx_v_self->bitset->trailing_bits != 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":533 * def __iter__(self not None): * if self.bitset.trailing_bits: * raise OverflowError("It's impossible to iterate over an infinite set.") # <<<<<<<<<<<<<< * return intbitset_iterator(self) * */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_4 = __pyx_builtin_OverflowError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_It_s_impossible_to_iterate_over}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 533, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __Pyx_Raise(__pyx_t_2, 0, 0, 0); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __PYX_ERR(0, 533, __pyx_L1_error) /* "intbitset.pyx":532 * # Iterator interface * def __iter__(self not None): * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * raise OverflowError("It's impossible to iterate over an infinite set.") * return intbitset_iterator(self) */ } /* "intbitset.pyx":534 * if self.bitset.trailing_bits: * raise OverflowError("It's impossible to iterate over an infinite set.") * return intbitset_iterator(self) # <<<<<<<<<<<<<< * * # Customized interface */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset_iterator); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset_iterator); __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, ((PyObject *)__pyx_v_self)}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 534, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_2); } __pyx_r = ((PyObject *)__pyx_t_2); __pyx_t_2 = 0; goto __pyx_L0; /* "intbitset.pyx":531 * * # Iterator interface * def __iter__(self not None): # <<<<<<<<<<<<<< * if self.bitset.trailing_bits: * raise OverflowError("It's impossible to iterate over an infinite set.") */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("intbitset.intbitset.__iter__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":537 * * # Customized interface * cpdef add(intbitset self, int elem): # <<<<<<<<<<<<<< * """Add an element to a set. * This has no effect if the element is already present.""" */ static PyObject *__pyx_pw_9intbitset_9intbitset_49add(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_add(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem, int __pyx_skip_dispatch) { 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; size_t __pyx_t_6; int __pyx_t_7; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("add", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_add); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 537, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_49add)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_elem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 537, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_6 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_5}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 537, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":540 * """Add an element to a set. * This has no effect if the element is already present.""" * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":541 * This has no effect if the element is already present.""" * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_7 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":542 * if self.sanity_checks: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 542, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 542, __pyx_L1_error) /* "intbitset.pyx":541 * This has no effect if the element is already present.""" * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":543 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ __pyx_t_7 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":544 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetAddElem(self.bitset, elem) * */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_2 = __pyx_builtin_OverflowError; __pyx_t_5 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 544, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Element_must_be_s, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 544, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 544, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 544, __pyx_L1_error) /* "intbitset.pyx":543 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) */ } /* "intbitset.pyx":540 * """Add an element to a set. * This has no effect if the element is already present.""" * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":545 * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetAddElem(self.bitset, elem) # <<<<<<<<<<<<<< * * cpdef clear(intbitset self): */ intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":537 * * # Customized interface * cpdef add(intbitset self, int elem): # <<<<<<<<<<<<<< * """Add an element to a set. * This has no effect if the element is already present.""" */ /* 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_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("intbitset.intbitset.add", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_49add(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_48add, "Add an element to a set.\n This has no effect if the element is already present."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_49add = {"add", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_49add, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_48add}; static PyObject *__pyx_pw_9intbitset_9intbitset_49add(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { int __pyx_v_elem; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("add (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_elem,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 537, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 537, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "add", 0) < (0)) __PYX_ERR(0, 537, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("add", 1, 1, 1, i); __PYX_ERR(0, 537, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 537, __pyx_L3_error) } __pyx_v_elem = __Pyx_PyLong_As_int(values[0]); if (unlikely((__pyx_v_elem == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 537, __pyx_L3_error) } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("add", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 537, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.add", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_48add(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_elem); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_48add(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem) { 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("add", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_add(__pyx_v_self, __pyx_v_elem, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 537, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.add", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":547 * intBitSetAddElem(self.bitset, elem) * * cpdef clear(intbitset self): # <<<<<<<<<<<<<< * intBitSetReset(self.bitset) * */ static PyObject *__pyx_pw_9intbitset_9intbitset_51clear(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_clear(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("clear", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_clear); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 547, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_51clear)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 547, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":548 * * cpdef clear(intbitset self): * intBitSetReset(self.bitset) # <<<<<<<<<<<<<< * * */ (void)(intBitSetReset(__pyx_v_self->bitset)); /* "intbitset.pyx":547 * intBitSetAddElem(self.bitset, elem) * * cpdef clear(intbitset self): # <<<<<<<<<<<<<< * intBitSetReset(self.bitset) * */ /* 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_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("intbitset.intbitset.clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_51clear(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_51clear = {"clear", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_51clear, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_51clear(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("clear (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("clear", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("clear", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_50clear(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_50clear(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("clear", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_clear(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 547, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.clear", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":551 * * * cpdef discard(intbitset self, int elem): # <<<<<<<<<<<<<< * """Remove an element from a intbitset if it is a member. * If the element is not a member, do nothing.""" */ static PyObject *__pyx_pw_9intbitset_9intbitset_53discard(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_discard(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem, int __pyx_skip_dispatch) { 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; size_t __pyx_t_6; int __pyx_t_7; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("discard", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_discard); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 551, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_53discard)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_elem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 551, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_6 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_5}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 551, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":554 * """Remove an element from a intbitset if it is a member. * If the element is not a member, do nothing.""" * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":555 * If the element is not a member, do nothing.""" * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_7 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":556 * if self.sanity_checks: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 556, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 556, __pyx_L1_error) /* "intbitset.pyx":555 * If the element is not a member, do nothing.""" * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":557 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) */ __pyx_t_7 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":558 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_2 = __pyx_builtin_OverflowError; __pyx_t_5 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 558, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Element_must_be_s, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 558, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 558, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 558, __pyx_L1_error) /* "intbitset.pyx":557 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) */ } /* "intbitset.pyx":554 * """Remove an element from a intbitset if it is a member. * If the element is not a member, do nothing.""" * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":559 * elif elem > maxelem: * raise OverflowError("Element must be <= %s" % maxelem) * intBitSetDelElem(self.bitset, elem) # <<<<<<<<<<<<<< * * symmetric_difference = __xor__ */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":551 * * * cpdef discard(intbitset self, int elem): # <<<<<<<<<<<<<< * """Remove an element from a intbitset if it is a member. * If the element is not a member, do nothing.""" */ /* 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_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("intbitset.intbitset.discard", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_53discard(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_52discard, "Remove an element from a intbitset if it is a member.\n If the element is not a member, do nothing."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_53discard = {"discard", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_53discard, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_52discard}; static PyObject *__pyx_pw_9intbitset_9intbitset_53discard(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { int __pyx_v_elem; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("discard (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_elem,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 551, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 551, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "discard", 0) < (0)) __PYX_ERR(0, 551, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("discard", 1, 1, 1, i); __PYX_ERR(0, 551, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 551, __pyx_L3_error) } __pyx_v_elem = __Pyx_PyLong_As_int(values[0]); if (unlikely((__pyx_v_elem == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 551, __pyx_L3_error) } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("discard", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 551, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.discard", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_52discard(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_elem); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_52discard(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem) { 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("discard", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_discard(__pyx_v_self, __pyx_v_elem, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 551, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.discard", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":564 * symmetric_difference_update = __ixor__ * * cpdef issubset(intbitset self, rhs): # <<<<<<<<<<<<<< * """Report whether another set contains this set.""" * return self.__le__(rhs) */ static PyObject *__pyx_pw_9intbitset_9intbitset_55issubset(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_issubset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("issubset", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_issubset); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 564, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_55issubset)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_rhs}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 564, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":566 * cpdef issubset(intbitset self, rhs): * """Report whether another set contains this set.""" * return self.__le__(rhs) # <<<<<<<<<<<<<< * * cpdef issuperset(intbitset self, rhs): */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = ((PyObject *)__pyx_v_self); __Pyx_INCREF(__pyx_t_2); __pyx_t_5 = 0; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_rhs}; __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_le, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 566, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":564 * symmetric_difference_update = __ixor__ * * cpdef issubset(intbitset self, rhs): # <<<<<<<<<<<<<< * """Report whether another set contains this set.""" * return self.__le__(rhs) */ /* 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_AddTraceback("intbitset.intbitset.issubset", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_55issubset(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_54issubset, "Report whether another set contains this set."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_55issubset = {"issubset", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_55issubset, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_54issubset}; static PyObject *__pyx_pw_9intbitset_9intbitset_55issubset(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { PyObject *__pyx_v_rhs = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("issubset (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_rhs,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 564, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 564, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "issubset", 0) < (0)) __PYX_ERR(0, 564, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("issubset", 1, 1, 1, i); __PYX_ERR(0, 564, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 564, __pyx_L3_error) } __pyx_v_rhs = values[0]; } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("issubset", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 564, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.issubset", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_54issubset(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_rhs); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_54issubset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs) { 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("issubset", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_issubset(__pyx_v_self, __pyx_v_rhs, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 564, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.issubset", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":568 * return self.__le__(rhs) * * cpdef issuperset(intbitset self, rhs): # <<<<<<<<<<<<<< * """Report whether this set contains another set.""" * return self.__ge__(rhs) */ static PyObject *__pyx_pw_9intbitset_9intbitset_57issuperset(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_issuperset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("issuperset", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_issuperset); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 568, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_57issuperset)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_rhs}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 568, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":570 * cpdef issuperset(intbitset self, rhs): * """Report whether this set contains another set.""" * return self.__ge__(rhs) # <<<<<<<<<<<<<< * * # Dumping & Loading */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = ((PyObject *)__pyx_v_self); __Pyx_INCREF(__pyx_t_2); __pyx_t_5 = 0; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_rhs}; __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_ge, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 570, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":568 * return self.__le__(rhs) * * cpdef issuperset(intbitset self, rhs): # <<<<<<<<<<<<<< * """Report whether this set contains another set.""" * return self.__ge__(rhs) */ /* 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_AddTraceback("intbitset.intbitset.issuperset", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_57issuperset(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_56issuperset, "Report whether this set contains another set."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_57issuperset = {"issuperset", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_57issuperset, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_56issuperset}; static PyObject *__pyx_pw_9intbitset_9intbitset_57issuperset(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { PyObject *__pyx_v_rhs = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("issuperset (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_rhs,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 568, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 568, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "issuperset", 0) < (0)) __PYX_ERR(0, 568, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("issuperset", 1, 1, 1, i); __PYX_ERR(0, 568, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 568, __pyx_L3_error) } __pyx_v_rhs = values[0]; } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("issuperset", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 568, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.issuperset", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_56issuperset(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_rhs); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_56issuperset(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs) { 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("issuperset", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_issuperset(__pyx_v_self, __pyx_v_rhs, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 568, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.issuperset", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":573 * * # Dumping & Loading * cpdef fastdump(intbitset self): # <<<<<<<<<<<<<< * """Return a compressed string representation suitable to be saved * somewhere.""" */ static PyObject *__pyx_pw_9intbitset_9intbitset_59fastdump(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_fastdump(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { Py_ssize_t __pyx_v_size; PyObject *__pyx_v_tmp = NULL; 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("fastdump", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_fastdump); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 573, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_59fastdump)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 573, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":577 * somewhere.""" * cdef Py_ssize_t size * size = intBitSetGetSize(( self).bitset) # <<<<<<<<<<<<<< * tmp = PyBytes_FromStringAndSize(self.bitset.bitset, ( size + 1) * wordbytesize) * return zlib.compress(tmp) */ __pyx_v_size = intBitSetGetSize(__pyx_v_self->bitset); /* "intbitset.pyx":578 * cdef Py_ssize_t size * size = intBitSetGetSize(( self).bitset) * tmp = PyBytes_FromStringAndSize(self.bitset.bitset, ( size + 1) * wordbytesize) # <<<<<<<<<<<<<< * return zlib.compress(tmp) * */ __pyx_t_1 = PyBytes_FromStringAndSize(((char *)__pyx_v_self->bitset->bitset), ((__pyx_v_size + 1) * wordbytesize)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 578, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_tmp = __pyx_t_1; __pyx_t_1 = 0; /* "intbitset.pyx":579 * size = intBitSetGetSize(( self).bitset) * tmp = PyBytes_FromStringAndSize(self.bitset.bitset, ( size + 1) * wordbytesize) * return zlib.compress(tmp) # <<<<<<<<<<<<<< * * cpdef fastload(intbitset self, strdump): */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = NULL; __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_zlib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 579, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_compress); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 579, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_3))) { __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); assert(__pyx_t_2); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_2); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_tmp}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 579, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":573 * * # Dumping & Loading * cpdef fastdump(intbitset self): # <<<<<<<<<<<<<< * """Return a compressed string representation suitable to be saved * somewhere.""" */ /* 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_AddTraceback("intbitset.intbitset.fastdump", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_tmp); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_59fastdump(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_58fastdump, "Return a compressed string representation suitable to be saved\n somewhere."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_59fastdump = {"fastdump", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_59fastdump, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_58fastdump}; static PyObject *__pyx_pw_9intbitset_9intbitset_59fastdump(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fastdump (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("fastdump", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("fastdump", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_58fastdump(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_58fastdump(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("fastdump", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_fastdump(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 573, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.fastdump", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":581 * return zlib.compress(tmp) * * cpdef fastload(intbitset self, strdump): # <<<<<<<<<<<<<< * """Load a compressed string representation produced by a previous call * to the fastdump method into the current intbitset. The previous content */ static PyObject *__pyx_pw_9intbitset_9intbitset_61fastload(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_fastload(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_strdump, int __pyx_skip_dispatch) { Py_ssize_t __pyx_v_size; const void* __pyx_v_buf; Py_buffer __pyx_v_view; PyObject *__pyx_v_tmp = NULL; 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; size_t __pyx_t_5; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; PyObject *__pyx_t_8 = NULL; int __pyx_t_9; int __pyx_t_10; Py_ssize_t __pyx_t_11; int __pyx_t_12; char const *__pyx_t_13; PyObject *__pyx_t_14 = NULL; PyObject *__pyx_t_15 = NULL; PyObject *__pyx_t_16 = NULL; PyObject *__pyx_t_17 = NULL; PyObject *__pyx_t_18 = NULL; PyObject *__pyx_t_19 = NULL; PyObject *__pyx_t_20 = NULL; PyObject *__pyx_t_21 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("fastload", 0); __Pyx_INCREF(__pyx_v_strdump); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_fastload); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 581, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_61fastload)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_strdump}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 581, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":589 * cdef Py_buffer view * * buf = NULL # <<<<<<<<<<<<<< * size = 0 * try: */ __pyx_v_buf = NULL; /* "intbitset.pyx":590 * * buf = NULL * size = 0 # <<<<<<<<<<<<<< * try: * if type(strdump) is array: */ __pyx_v_size = 0; /* "intbitset.pyx":591 * buf = NULL * size = 0 * try: # <<<<<<<<<<<<<< * if type(strdump) is array: * strdump = strdump.tostring() */ { __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __Pyx_ExceptionSave(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8); __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_7); __Pyx_XGOTREF(__pyx_t_8); /*try:*/ { /* "intbitset.pyx":592 * size = 0 * try: * if type(strdump) is array: # <<<<<<<<<<<<<< * strdump = strdump.tostring() * # tmp needed to not be garbage collected */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 592, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_9 = (((PyObject *)Py_TYPE(__pyx_v_strdump)) == __pyx_t_1); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_9) { /* "intbitset.pyx":593 * try: * if type(strdump) is array: * strdump = strdump.tostring() # <<<<<<<<<<<<<< * # tmp needed to not be garbage collected * tmp = zlib.decompress(strdump) */ __pyx_t_2 = __pyx_v_strdump; __Pyx_INCREF(__pyx_t_2); __pyx_t_5 = 0; { PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; __pyx_t_1 = __Pyx_PyObject_FastCallMethod(__pyx_mstate_global->__pyx_n_u_tostring, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (1*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 593, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_DECREF_SET(__pyx_v_strdump, __pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":592 * size = 0 * try: * if type(strdump) is array: # <<<<<<<<<<<<<< * strdump = strdump.tostring() * # tmp needed to not be garbage collected */ } /* "intbitset.pyx":595 * strdump = strdump.tostring() * # tmp needed to not be garbage collected * tmp = zlib.decompress(strdump) # <<<<<<<<<<<<<< * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: */ __pyx_t_2 = NULL; __Pyx_GetModuleGlobalName(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_zlib); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 595, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = __Pyx_PyObject_GetAttrStr(__pyx_t_4, __pyx_mstate_global->__pyx_n_u_decompress); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 595, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_3))) { __pyx_t_2 = PyMethod_GET_SELF(__pyx_t_3); assert(__pyx_t_2); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_3); __Pyx_INCREF(__pyx_t_2); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_3, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_v_strdump}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 595, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_1); } __pyx_v_tmp = __pyx_t_1; __pyx_t_1 = 0; /* "intbitset.pyx":597 * tmp = zlib.decompress(strdump) * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: # <<<<<<<<<<<<<< * raise ValueError("Unable to get buffer") * */ __pyx_t_10 = PyObject_GetBuffer(__pyx_v_tmp, (&__pyx_v_view), PyBUF_SIMPLE); if (unlikely(__pyx_t_10 == ((int)-1))) __PYX_ERR(0, 597, __pyx_L3_error) __pyx_t_9 = (__pyx_t_10 != 0); if (unlikely(__pyx_t_9)) { /* "intbitset.pyx":598 * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: * raise ValueError("Unable to get buffer") # <<<<<<<<<<<<<< * * try: */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_2 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_Unable_to_get_buffer}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 598, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 598, __pyx_L3_error) /* "intbitset.pyx":597 * tmp = zlib.decompress(strdump) * * if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: # <<<<<<<<<<<<<< * raise ValueError("Unable to get buffer") * */ } /* "intbitset.pyx":600 * raise ValueError("Unable to get buffer") * * try: # <<<<<<<<<<<<<< * buf = view.buf * size = view.len */ /*try:*/ { /* "intbitset.pyx":601 * * try: * buf = view.buf # <<<<<<<<<<<<<< * size = view.len * */ __pyx_v_buf = ((const void*)__pyx_v_view.buf); /* "intbitset.pyx":602 * try: * buf = view.buf * size = view.len # <<<<<<<<<<<<<< * * if (size % wordbytesize): */ __pyx_t_11 = __pyx_v_view.len; __pyx_v_size = __pyx_t_11; /* "intbitset.pyx":604 * size = view.len * * if (size % wordbytesize): # <<<<<<<<<<<<<< * ## Wrong size! * raise Exception() */ if (unlikely(wordbytesize == 0)) { PyErr_SetString(PyExc_ZeroDivisionError, "integer division or modulo by zero"); __PYX_ERR(0, 604, __pyx_L12_error) } __pyx_t_9 = (__Pyx_mod_Py_ssize_t(__pyx_v_size, wordbytesize, 0) != 0); if (unlikely(__pyx_t_9)) { /* "intbitset.pyx":606 * if (size % wordbytesize): * ## Wrong size! * raise Exception() # <<<<<<<<<<<<<< * * intBitSetResetFromBuffer(( self).bitset, buf, size) */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)(((PyTypeObject*)PyExc_Exception))); __pyx_t_3 = ((PyObject *)(((PyTypeObject*)PyExc_Exception))); __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, NULL}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 606, __pyx_L12_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 606, __pyx_L12_error) /* "intbitset.pyx":604 * size = view.len * * if (size % wordbytesize): # <<<<<<<<<<<<<< * ## Wrong size! * raise Exception() */ } /* "intbitset.pyx":608 * raise Exception() * * intBitSetResetFromBuffer(( self).bitset, buf, size) # <<<<<<<<<<<<<< * finally: * PyBuffer_Release(&view) */ (void)(intBitSetResetFromBuffer(__pyx_v_self->bitset, __pyx_v_buf, __pyx_v_size)); } /* "intbitset.pyx":610 * intBitSetResetFromBuffer(( self).bitset, buf, size) * finally: * PyBuffer_Release(&view) # <<<<<<<<<<<<<< * * except: */ /*finally:*/ { /*normal exit:*/{ PyBuffer_Release((&__pyx_v_view)); goto __pyx_L13; } __pyx_L12_error:; /*exception exit:*/{ __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; __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; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_ExceptionSwap(&__pyx_t_17, &__pyx_t_18, &__pyx_t_19); if ( unlikely(__Pyx_GetException(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16) < 0)) __Pyx_ErrFetch(&__pyx_t_14, &__pyx_t_15, &__pyx_t_16); __Pyx_XGOTREF(__pyx_t_14); __Pyx_XGOTREF(__pyx_t_15); __Pyx_XGOTREF(__pyx_t_16); __Pyx_XGOTREF(__pyx_t_17); __Pyx_XGOTREF(__pyx_t_18); __Pyx_XGOTREF(__pyx_t_19); __pyx_t_10 = __pyx_lineno; __pyx_t_12 = __pyx_clineno; __pyx_t_13 = __pyx_filename; { PyBuffer_Release((&__pyx_v_view)); } __Pyx_XGIVEREF(__pyx_t_17); __Pyx_XGIVEREF(__pyx_t_18); __Pyx_XGIVEREF(__pyx_t_19); __Pyx_ExceptionReset(__pyx_t_17, __pyx_t_18, __pyx_t_19); __Pyx_XGIVEREF(__pyx_t_14); __Pyx_XGIVEREF(__pyx_t_15); __Pyx_XGIVEREF(__pyx_t_16); __Pyx_ErrRestore(__pyx_t_14, __pyx_t_15, __pyx_t_16); __pyx_t_14 = 0; __pyx_t_15 = 0; __pyx_t_16 = 0; __pyx_t_17 = 0; __pyx_t_18 = 0; __pyx_t_19 = 0; __pyx_lineno = __pyx_t_10; __pyx_clineno = __pyx_t_12; __pyx_filename = __pyx_t_13; goto __pyx_L3_error; } __pyx_L13:; } /* "intbitset.pyx":591 * buf = NULL * size = 0 * try: # <<<<<<<<<<<<<< * if type(strdump) is array: * strdump = strdump.tostring() */ } __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L8_try_end; __pyx_L3_error:; __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; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; /* "intbitset.pyx":612 * PyBuffer_Release(&view) * * except: # <<<<<<<<<<<<<< * raise ValueError("strdump is corrupted") * */ /*except:*/ { __Pyx_AddTraceback("intbitset.intbitset.fastload", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_1, &__pyx_t_3, &__pyx_t_2) < 0) __PYX_ERR(0, 612, __pyx_L5_except_error) __Pyx_XGOTREF(__pyx_t_1); __Pyx_XGOTREF(__pyx_t_3); __Pyx_XGOTREF(__pyx_t_2); /* "intbitset.pyx":613 * * except: * raise ValueError("strdump is corrupted") # <<<<<<<<<<<<<< * * cpdef copy(intbitset self): */ __pyx_t_20 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_21 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_20, __pyx_mstate_global->__pyx_kp_u_strdump_is_corrupted}; __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_21, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_20); __pyx_t_20 = 0; __Pyx_DECREF(__pyx_t_21); __pyx_t_21 = 0; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 613, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_4); } __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 613, __pyx_L5_except_error) } /* "intbitset.pyx":591 * buf = NULL * size = 0 * try: # <<<<<<<<<<<<<< * if type(strdump) is array: * strdump = strdump.tostring() */ __pyx_L5_except_error:; __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); goto __pyx_L1_error; __pyx_L8_try_end:; } /* "intbitset.pyx":581 * return zlib.compress(tmp) * * cpdef fastload(intbitset self, strdump): # <<<<<<<<<<<<<< * """Load a compressed string representation produced by a previous call * to the fastdump method into the current intbitset. The previous content */ /* 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_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_20); __Pyx_XDECREF(__pyx_t_21); __Pyx_AddTraceback("intbitset.intbitset.fastload", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_tmp); __Pyx_XDECREF(__pyx_v_strdump); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_61fastload(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_60fastload, "Load a compressed string representation produced by a previous call\n to the fastdump method into the current intbitset. The previous content\n will be replaced."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_61fastload = {"fastload", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_61fastload, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_60fastload}; static PyObject *__pyx_pw_9intbitset_9intbitset_61fastload(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { PyObject *__pyx_v_strdump = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("fastload (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_strdump,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 581, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 581, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "fastload", 0) < (0)) __PYX_ERR(0, 581, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("fastload", 1, 1, 1, i); __PYX_ERR(0, 581, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 581, __pyx_L3_error) } __pyx_v_strdump = values[0]; } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("fastload", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 581, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.fastload", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_60fastload(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_strdump); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_60fastload(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_strdump) { 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("fastload", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_fastload(__pyx_v_self, __pyx_v_strdump, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 581, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.fastload", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":615 * raise ValueError("strdump is corrupted") * * cpdef copy(intbitset self): # <<<<<<<<<<<<<< * """Return a shallow copy of a set.""" * return intbitset(self) */ static PyObject *__pyx_pw_9intbitset_9intbitset_63copy(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_copy(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("copy", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_copy); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 615, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_63copy)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 615, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":617 * cpdef copy(intbitset self): * """Return a shallow copy of a set.""" * return intbitset(self) # <<<<<<<<<<<<<< * * cpdef pop(intbitset self): */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, ((PyObject *)__pyx_v_self)}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 617, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_r = ((PyObject *)__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":615 * raise ValueError("strdump is corrupted") * * cpdef copy(intbitset self): # <<<<<<<<<<<<<< * """Return a shallow copy of a set.""" * return intbitset(self) */ /* 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_AddTraceback("intbitset.intbitset.copy", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_63copy(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_62copy, "Return a shallow copy of a set."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_63copy = {"copy", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_63copy, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_62copy}; static PyObject *__pyx_pw_9intbitset_9intbitset_63copy(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("copy (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("copy", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("copy", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_62copy(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_62copy(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("copy", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_copy(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 615, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.copy", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":619 * return intbitset(self) * * cpdef pop(intbitset self): # <<<<<<<<<<<<<< * """Remove and return an arbitrary set element. * */ static PyObject *__pyx_pw_9intbitset_9intbitset_65pop(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_pop(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { int __pyx_v_ret; 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; size_t __pyx_t_5; int __pyx_t_6; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("pop", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_pop); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 619, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_65pop)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 619, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":626 * """ * cdef int ret * ret = intBitSetGetLast(self.bitset) # <<<<<<<<<<<<<< * if ret < 0: * raise KeyError("pop from an empty or infinite intbitset") */ __pyx_v_ret = intBitSetGetLast(__pyx_v_self->bitset); /* "intbitset.pyx":627 * cdef int ret * ret = intBitSetGetLast(self.bitset) * if ret < 0: # <<<<<<<<<<<<<< * raise KeyError("pop from an empty or infinite intbitset") * intBitSetDelElem(self.bitset, ret) */ __pyx_t_6 = (__pyx_v_ret < 0); if (unlikely(__pyx_t_6)) { /* "intbitset.pyx":628 * ret = intBitSetGetLast(self.bitset) * if ret < 0: * raise KeyError("pop from an empty or infinite intbitset") # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, ret) * return ret */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_KeyError); __pyx_t_4 = __pyx_builtin_KeyError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_pop_from_an_empty_or_infinite_in}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 628, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 628, __pyx_L1_error) /* "intbitset.pyx":627 * cdef int ret * ret = intBitSetGetLast(self.bitset) * if ret < 0: # <<<<<<<<<<<<<< * raise KeyError("pop from an empty or infinite intbitset") * intBitSetDelElem(self.bitset, ret) */ } /* "intbitset.pyx":629 * if ret < 0: * raise KeyError("pop from an empty or infinite intbitset") * intBitSetDelElem(self.bitset, ret) # <<<<<<<<<<<<<< * return ret * */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_ret); /* "intbitset.pyx":630 * raise KeyError("pop from an empty or infinite intbitset") * intBitSetDelElem(self.bitset, ret) * return ret # <<<<<<<<<<<<<< * * cpdef remove(intbitset self, int elem): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_ret); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 630, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":619 * return intbitset(self) * * cpdef pop(intbitset self): # <<<<<<<<<<<<<< * """Remove and return an arbitrary set element. * */ /* 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_AddTraceback("intbitset.intbitset.pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_65pop(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_64pop, "Remove and return an arbitrary set element.\n\n Note: intbitset implementation of .pop() differs from the native ``set``\n implementation by guaranteeing returning always the largest element.\n "); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_65pop = {"pop", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_65pop, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_64pop}; static PyObject *__pyx_pw_9intbitset_9intbitset_65pop(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("pop (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("pop", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("pop", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_64pop(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_64pop(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("pop", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_pop(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 619, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.pop", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":632 * return ret * * cpdef remove(intbitset self, int elem): # <<<<<<<<<<<<<< * """Remove an element from a set; it must be a member. * If the element is not a member, raise a KeyError. */ static PyObject *__pyx_pw_9intbitset_9intbitset_67remove(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_remove(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem, int __pyx_skip_dispatch) { 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; size_t __pyx_t_6; int __pyx_t_7; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("remove", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_remove); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_67remove)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_elem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_6 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_5}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":636 * If the element is not a member, raise a KeyError. * """ * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":637 * """ * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ __pyx_t_7 = (__pyx_v_elem < 0); if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":638 * if self.sanity_checks: * if elem < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_4 = __pyx_builtin_ValueError; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 638, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 638, __pyx_L1_error) /* "intbitset.pyx":637 * """ * if self.sanity_checks: * if elem < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: */ } /* "intbitset.pyx":639 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * if intBitSetIsInElem(self.bitset, elem): */ __pyx_t_7 = (__pyx_v_elem > maxelem); if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":640 * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) # <<<<<<<<<<<<<< * if intBitSetIsInElem(self.bitset, elem): * intBitSetDelElem(self.bitset, elem) */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_2 = __pyx_builtin_OverflowError; __pyx_t_5 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 640, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_be_s, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 640, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_3}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 640, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 640, __pyx_L1_error) /* "intbitset.pyx":639 * if elem < 0: * raise ValueError("Negative numbers, not allowed") * elif elem > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must be <= %s" % maxelem) * if intBitSetIsInElem(self.bitset, elem): */ } /* "intbitset.pyx":636 * If the element is not a member, raise a KeyError. * """ * if self.sanity_checks: # <<<<<<<<<<<<<< * if elem < 0: * raise ValueError("Negative numbers, not allowed") */ } /* "intbitset.pyx":641 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * if intBitSetIsInElem(self.bitset, elem): # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * else: */ __pyx_t_7 = intBitSetIsInElem(__pyx_v_self->bitset, __pyx_v_elem); if (likely(__pyx_t_7)) { /* "intbitset.pyx":642 * raise OverflowError("Elements must be <= %s" % maxelem) * if intBitSetIsInElem(self.bitset, elem): * intBitSetDelElem(self.bitset, elem) # <<<<<<<<<<<<<< * else: * raise KeyError(elem) */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_elem); /* "intbitset.pyx":641 * elif elem > maxelem: * raise OverflowError("Elements must be <= %s" % maxelem) * if intBitSetIsInElem(self.bitset, elem): # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, elem) * else: */ goto __pyx_L5; } /* "intbitset.pyx":644 * intBitSetDelElem(self.bitset, elem) * else: * raise KeyError(elem) # <<<<<<<<<<<<<< * * cpdef strbits(intbitset self): */ /*else*/ { __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_KeyError); __pyx_t_3 = __pyx_builtin_KeyError; __pyx_t_4 = __Pyx_PyLong_From_int(__pyx_v_elem); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 644, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_4}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 644, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 644, __pyx_L1_error) } __pyx_L5:; /* "intbitset.pyx":632 * return ret * * cpdef remove(intbitset self, int elem): # <<<<<<<<<<<<<< * """Remove an element from a set; it must be a member. * If the element is not a member, raise a KeyError. */ /* 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_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("intbitset.intbitset.remove", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_67remove(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_66remove, "Remove an element from a set; it must be a member.\n If the element is not a member, raise a KeyError.\n "); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_67remove = {"remove", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_67remove, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_66remove}; static PyObject *__pyx_pw_9intbitset_9intbitset_67remove(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { int __pyx_v_elem; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("remove (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_elem,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 632, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 632, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "remove", 0) < (0)) __PYX_ERR(0, 632, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("remove", 1, 1, 1, i); __PYX_ERR(0, 632, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 632, __pyx_L3_error) } __pyx_v_elem = __Pyx_PyLong_As_int(values[0]); if (unlikely((__pyx_v_elem == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 632, __pyx_L3_error) } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("remove", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 632, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.remove", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_66remove(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_elem); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_66remove(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_elem) { 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("remove", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_remove(__pyx_v_self, __pyx_v_elem, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.remove", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":646 * raise KeyError(elem) * * cpdef strbits(intbitset self): # <<<<<<<<<<<<<< * """Return a string of 0s and 1s representing the content in memory * of the intbitset. */ static PyObject *__pyx_pw_9intbitset_9intbitset_69strbits(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_strbits(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { int __pyx_v_i; int __pyx_v_last; PyObject *__pyx_v_ret = NULL; 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; size_t __pyx_t_5; int __pyx_t_6; Py_ssize_t __pyx_t_7; PyObject *(*__pyx_t_8)(PyObject *); int __pyx_t_9; int __pyx_t_10; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("strbits", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_strbits); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 646, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_69strbits)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 646, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":652 * cdef int i * cdef int last * if ( self).bitset.trailing_bits: # <<<<<<<<<<<<<< * raise OverflowError("It's impossible to print an infinite set.") * last = 0 */ __pyx_t_6 = (__pyx_v_self->bitset->trailing_bits != 0); if (unlikely(__pyx_t_6)) { /* "intbitset.pyx":653 * cdef int last * if ( self).bitset.trailing_bits: * raise OverflowError("It's impossible to print an infinite set.") # <<<<<<<<<<<<<< * last = 0 * ret = [] */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_4 = __pyx_builtin_OverflowError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_It_s_impossible_to_print_an_infi}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 653, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 653, __pyx_L1_error) /* "intbitset.pyx":652 * cdef int i * cdef int last * if ( self).bitset.trailing_bits: # <<<<<<<<<<<<<< * raise OverflowError("It's impossible to print an infinite set.") * last = 0 */ } /* "intbitset.pyx":654 * if ( self).bitset.trailing_bits: * raise OverflowError("It's impossible to print an infinite set.") * last = 0 # <<<<<<<<<<<<<< * ret = [] * for i in self: */ __pyx_v_last = 0; /* "intbitset.pyx":655 * raise OverflowError("It's impossible to print an infinite set.") * last = 0 * ret = [] # <<<<<<<<<<<<<< * for i in self: * ret.append('0'*(i-last)+'1') */ __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 655, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_ret = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":656 * last = 0 * ret = [] * for i in self: # <<<<<<<<<<<<<< * ret.append('0'*(i-last)+'1') * last = i+1 */ if (likely(PyList_CheckExact(((PyObject *)__pyx_v_self))) || PyTuple_CheckExact(((PyObject *)__pyx_v_self))) { __pyx_t_1 = ((PyObject *)__pyx_v_self); __Pyx_INCREF(__pyx_t_1); __pyx_t_7 = 0; __pyx_t_8 = NULL; } else { __pyx_t_7 = -1; __pyx_t_1 = PyObject_GetIter(((PyObject *)__pyx_v_self)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 656, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_8 = (CYTHON_COMPILING_IN_LIMITED_API) ? PyIter_Next : __Pyx_PyObject_GetIterNextFunc(__pyx_t_1); if (unlikely(!__pyx_t_8)) __PYX_ERR(0, 656, __pyx_L1_error) } for (;;) { if (likely(!__pyx_t_8)) { if (likely(PyList_CheckExact(__pyx_t_1))) { { Py_ssize_t __pyx_temp = __Pyx_PyList_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 656, __pyx_L1_error) #endif if (__pyx_t_7 >= __pyx_temp) break; } __pyx_t_4 = __Pyx_PyList_GetItemRef(__pyx_t_1, __pyx_t_7); ++__pyx_t_7; } else { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 656, __pyx_L1_error) #endif if (__pyx_t_7 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_4 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_7)); #else __pyx_t_4 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_7); #endif ++__pyx_t_7; } if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 656, __pyx_L1_error) } else { __pyx_t_4 = __pyx_t_8(__pyx_t_1); if (unlikely(!__pyx_t_4)) { PyObject* exc_type = PyErr_Occurred(); if (exc_type) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) __PYX_ERR(0, 656, __pyx_L1_error) PyErr_Clear(); } break; } } __Pyx_GOTREF(__pyx_t_4); __pyx_t_9 = __Pyx_PyLong_As_int(__pyx_t_4); if (unlikely((__pyx_t_9 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 656, __pyx_L1_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_v_i = __pyx_t_9; /* "intbitset.pyx":657 * ret = [] * for i in self: * ret.append('0'*(i-last)+'1') # <<<<<<<<<<<<<< * last = i+1 * return ''.join(ret) */ __pyx_t_4 = __Pyx_PySequence_Multiply(__pyx_mstate_global->__pyx_kp_u_0, (__pyx_v_i - __pyx_v_last)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 657, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_4); __pyx_t_2 = __Pyx_PyUnicode_ConcatInPlace(__pyx_t_4, __pyx_mstate_global->__pyx_kp_u_1); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 657, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_10 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_t_2); if (unlikely(__pyx_t_10 == ((int)-1))) __PYX_ERR(0, 657, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":658 * for i in self: * ret.append('0'*(i-last)+'1') * last = i+1 # <<<<<<<<<<<<<< * return ''.join(ret) * */ __pyx_v_last = (__pyx_v_i + 1); /* "intbitset.pyx":656 * last = 0 * ret = [] * for i in self: # <<<<<<<<<<<<<< * ret.append('0'*(i-last)+'1') * last = i+1 */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":659 * ret.append('0'*(i-last)+'1') * last = i+1 * return ''.join(ret) # <<<<<<<<<<<<<< * * def update(self not None, *args): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyUnicode_Join(__pyx_mstate_global->__pyx_kp_u__5, __pyx_v_ret); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 659, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":646 * raise KeyError(elem) * * cpdef strbits(intbitset self): # <<<<<<<<<<<<<< * """Return a string of 0s and 1s representing the content in memory * of the intbitset. */ /* 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_AddTraceback("intbitset.intbitset.strbits", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_ret); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_69strbits(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_68strbits, "Return a string of 0s and 1s representing the content in memory\n of the intbitset.\n "); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_69strbits = {"strbits", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_69strbits, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_68strbits}; static PyObject *__pyx_pw_9intbitset_9intbitset_69strbits(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("strbits (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("strbits", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("strbits", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_68strbits(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_68strbits(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("strbits", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_strbits(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 646, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.strbits", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":661 * return ''.join(ret) * * def update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, adding elements from all others.""" * cdef intbitset iarg */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_71update(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_70update, "Update the intbitset, adding elements from all others."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_71update = {"update", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_71update, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_70update}; static PyObject *__pyx_pw_9intbitset_9intbitset_71update(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_args = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("update (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("update", __pyx_kwds); return NULL;} __Pyx_INCREF(__pyx_args); __pyx_v_args = __pyx_args; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 661, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_70update(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_args); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_DECREF(__pyx_v_args); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_70update(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_iarg = 0; PyObject *__pyx_v_arg = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; Py_ssize_t __pyx_t_2; PyObject *__pyx_t_3 = NULL; int __pyx_t_4; PyObject *__pyx_t_5 = NULL; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; size_t __pyx_t_8; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("update", 0); /* "intbitset.pyx":664 * """Update the intbitset, adding elements from all others.""" * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(self.bitset, iarg.bitset) */ __pyx_t_1 = __pyx_v_args; __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = 0; for (;;) { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 664, __pyx_L1_error) #endif if (__pyx_t_2 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_2)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_2); #endif ++__pyx_t_2; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 664, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF_SET(__pyx_v_arg, __pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":665 * cdef intbitset iarg * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) # <<<<<<<<<<<<<< * intBitSetIUnion(self.bitset, iarg.bitset) * */ __pyx_t_4 = __Pyx_HasAttr(__pyx_v_arg, __pyx_mstate_global->__pyx_n_u_bitset); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(0, 665, __pyx_L1_error) if (__pyx_t_4) { if (!(likely(((__pyx_v_arg) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_arg, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset))))) __PYX_ERR(0, 665, __pyx_L1_error) __Pyx_INCREF(__pyx_v_arg); __pyx_t_3 = __pyx_v_arg; } else { __pyx_t_6 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_7 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_8 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_arg}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 665, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_5); } __pyx_t_3 = ((PyObject *)__pyx_t_5); __pyx_t_5 = 0; } __Pyx_XDECREF_SET(__pyx_v_iarg, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3)); __pyx_t_3 = 0; /* "intbitset.pyx":666 * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(self.bitset, iarg.bitset) # <<<<<<<<<<<<<< * * union_update = update */ (void)(intBitSetIUnion(__pyx_v_self->bitset, __pyx_v_iarg->bitset)); /* "intbitset.pyx":664 * """Update the intbitset, adding elements from all others.""" * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(self.bitset, iarg.bitset) */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":661 * return ''.join(ret) * * def update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, adding elements from all others.""" * cdef intbitset iarg */ /* 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_3); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("intbitset.intbitset.update", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_iarg); __Pyx_XDECREF(__pyx_v_arg); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":670 * union_update = update * * def intersection_update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, keeping only elements found in it and all others.""" * cdef intbitset iarg */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_73intersection_update(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_72intersection_update, "Update the intbitset, keeping only elements found in it and all others."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_73intersection_update = {"intersection_update", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_73intersection_update, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_72intersection_update}; static PyObject *__pyx_pw_9intbitset_9intbitset_73intersection_update(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_args = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("intersection_update (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("intersection_update", __pyx_kwds); return NULL;} __Pyx_INCREF(__pyx_args); __pyx_v_args = __pyx_args; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 670, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_72intersection_update(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_args); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_DECREF(__pyx_v_args); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_72intersection_update(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_iarg = 0; PyObject *__pyx_v_arg = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; Py_ssize_t __pyx_t_2; PyObject *__pyx_t_3 = NULL; int __pyx_t_4; PyObject *__pyx_t_5 = NULL; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; size_t __pyx_t_8; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("intersection_update", 0); /* "intbitset.pyx":673 * """Update the intbitset, keeping only elements found in it and all others.""" * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(self.bitset, iarg.bitset) */ __pyx_t_1 = __pyx_v_args; __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = 0; for (;;) { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 673, __pyx_L1_error) #endif if (__pyx_t_2 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_2)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_2); #endif ++__pyx_t_2; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 673, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF_SET(__pyx_v_arg, __pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":674 * cdef intbitset iarg * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) # <<<<<<<<<<<<<< * intBitSetIIntersection(self.bitset, iarg.bitset) * */ __pyx_t_4 = __Pyx_HasAttr(__pyx_v_arg, __pyx_mstate_global->__pyx_n_u_bitset); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(0, 674, __pyx_L1_error) if (__pyx_t_4) { if (!(likely(((__pyx_v_arg) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_arg, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset))))) __PYX_ERR(0, 674, __pyx_L1_error) __Pyx_INCREF(__pyx_v_arg); __pyx_t_3 = __pyx_v_arg; } else { __pyx_t_6 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_7 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_8 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_arg}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 674, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_5); } __pyx_t_3 = ((PyObject *)__pyx_t_5); __pyx_t_5 = 0; } __Pyx_XDECREF_SET(__pyx_v_iarg, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3)); __pyx_t_3 = 0; /* "intbitset.pyx":675 * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(self.bitset, iarg.bitset) # <<<<<<<<<<<<<< * * def difference_update(self not None, *args): */ (void)(intBitSetIIntersection(__pyx_v_self->bitset, __pyx_v_iarg->bitset)); /* "intbitset.pyx":673 * """Update the intbitset, keeping only elements found in it and all others.""" * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(self.bitset, iarg.bitset) */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":670 * union_update = update * * def intersection_update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, keeping only elements found in it and all others.""" * cdef intbitset iarg */ /* 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_3); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("intbitset.intbitset.intersection_update", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_iarg); __Pyx_XDECREF(__pyx_v_arg); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":677 * intBitSetIIntersection(self.bitset, iarg.bitset) * * def difference_update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, removing elements found in others.""" * cdef intbitset iarg */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_75difference_update(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_74difference_update, "Update the intbitset, removing elements found in others."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_75difference_update = {"difference_update", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_75difference_update, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_74difference_update}; static PyObject *__pyx_pw_9intbitset_9intbitset_75difference_update(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_args = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("difference_update (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("difference_update", __pyx_kwds); return NULL;} __Pyx_INCREF(__pyx_args); __pyx_v_args = __pyx_args; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 677, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_74difference_update(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_args); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_DECREF(__pyx_v_args); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_74difference_update(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_iarg = 0; PyObject *__pyx_v_arg = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; Py_ssize_t __pyx_t_2; PyObject *__pyx_t_3 = NULL; int __pyx_t_4; PyObject *__pyx_t_5 = NULL; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; size_t __pyx_t_8; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("difference_update", 0); /* "intbitset.pyx":680 * """Update the intbitset, removing elements found in others.""" * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(self.bitset, iarg.bitset) */ __pyx_t_1 = __pyx_v_args; __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = 0; for (;;) { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 680, __pyx_L1_error) #endif if (__pyx_t_2 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_2)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_2); #endif ++__pyx_t_2; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 680, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF_SET(__pyx_v_arg, __pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":681 * cdef intbitset iarg * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) # <<<<<<<<<<<<<< * intBitSetISub(self.bitset, iarg.bitset) * */ __pyx_t_4 = __Pyx_HasAttr(__pyx_v_arg, __pyx_mstate_global->__pyx_n_u_bitset); if (unlikely(__pyx_t_4 == ((int)-1))) __PYX_ERR(0, 681, __pyx_L1_error) if (__pyx_t_4) { if (!(likely(((__pyx_v_arg) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_arg, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset))))) __PYX_ERR(0, 681, __pyx_L1_error) __Pyx_INCREF(__pyx_v_arg); __pyx_t_3 = __pyx_v_arg; } else { __pyx_t_6 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_7 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_8 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_6, __pyx_v_arg}; __pyx_t_5 = __Pyx_PyObject_FastCall(__pyx_t_7, __pyx_callargs+__pyx_t_8, (2-__pyx_t_8) | (__pyx_t_8*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 681, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_5); } __pyx_t_3 = ((PyObject *)__pyx_t_5); __pyx_t_5 = 0; } __Pyx_XDECREF_SET(__pyx_v_iarg, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3)); __pyx_t_3 = 0; /* "intbitset.pyx":682 * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(self.bitset, iarg.bitset) # <<<<<<<<<<<<<< * * def union(self not None, *args): */ (void)(intBitSetISub(__pyx_v_self->bitset, __pyx_v_iarg->bitset)); /* "intbitset.pyx":680 * """Update the intbitset, removing elements found in others.""" * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(self.bitset, iarg.bitset) */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":677 * intBitSetIIntersection(self.bitset, iarg.bitset) * * def difference_update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, removing elements found in others.""" * cdef intbitset iarg */ /* 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_3); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_AddTraceback("intbitset.intbitset.difference_update", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_iarg); __Pyx_XDECREF(__pyx_v_arg); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":684 * intBitSetISub(self.bitset, iarg.bitset) * * def union(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements from the intbitset and all others.""" * cdef intbitset ret = intbitset(self) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_77union(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_76union, "Return a new intbitset with elements from the intbitset and all others."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_77union = {"union", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_77union, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_76union}; static PyObject *__pyx_pw_9intbitset_9intbitset_77union(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_args = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("union (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("union", __pyx_kwds); return NULL;} __Pyx_INCREF(__pyx_args); __pyx_v_args = __pyx_args; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 684, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_76union(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_args); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_DECREF(__pyx_v_args); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_76union(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; struct __pyx_obj_9intbitset_intbitset *__pyx_v_iarg = 0; PyObject *__pyx_v_arg = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; Py_ssize_t __pyx_t_5; int __pyx_t_6; 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("union", 0); /* "intbitset.pyx":686 * def union(self not None, *args): * """Return a new intbitset with elements from the intbitset and all others.""" * cdef intbitset ret = intbitset(self) # <<<<<<<<<<<<<< * cdef intbitset iarg * for arg in args: */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, ((PyObject *)__pyx_v_self)}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 686, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":688 * cdef intbitset ret = intbitset(self) * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(ret.bitset, iarg.bitset) */ __pyx_t_1 = __pyx_v_args; __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; for (;;) { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 688, __pyx_L1_error) #endif if (__pyx_t_5 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_5)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_5); #endif ++__pyx_t_5; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 688, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF_SET(__pyx_v_arg, __pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":689 * cdef intbitset iarg * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) # <<<<<<<<<<<<<< * intBitSetIUnion(ret.bitset, iarg.bitset) * return ret */ __pyx_t_6 = __Pyx_HasAttr(__pyx_v_arg, __pyx_mstate_global->__pyx_n_u_bitset); if (unlikely(__pyx_t_6 == ((int)-1))) __PYX_ERR(0, 689, __pyx_L1_error) if (__pyx_t_6) { if (!(likely(((__pyx_v_arg) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_arg, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset))))) __PYX_ERR(0, 689, __pyx_L1_error) __Pyx_INCREF(__pyx_v_arg); __pyx_t_3 = __pyx_v_arg; } else { __pyx_t_7 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_8 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_arg}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 689, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_2); } __pyx_t_3 = ((PyObject *)__pyx_t_2); __pyx_t_2 = 0; } __Pyx_XDECREF_SET(__pyx_v_iarg, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3)); __pyx_t_3 = 0; /* "intbitset.pyx":690 * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(ret.bitset, iarg.bitset) # <<<<<<<<<<<<<< * return ret * */ (void)(intBitSetIUnion(__pyx_v_ret->bitset, __pyx_v_iarg->bitset)); /* "intbitset.pyx":688 * cdef intbitset ret = intbitset(self) * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(ret.bitset, iarg.bitset) */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":691 * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIUnion(ret.bitset, iarg.bitset) * return ret # <<<<<<<<<<<<<< * * def intersection(self not None, *args): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":684 * intBitSetISub(self.bitset, iarg.bitset) * * def union(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements from the intbitset and all others.""" * cdef intbitset ret = intbitset(self) */ /* 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_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("intbitset.intbitset.union", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XDECREF((PyObject *)__pyx_v_iarg); __Pyx_XDECREF(__pyx_v_arg); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":693 * return ret * * def intersection(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements common to the intbitset and all others.""" * cdef intbitset ret = intbitset(self) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_79intersection(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_78intersection, "Return a new intbitset with elements common to the intbitset and all others."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_79intersection = {"intersection", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_79intersection, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_78intersection}; static PyObject *__pyx_pw_9intbitset_9intbitset_79intersection(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_args = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("intersection (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("intersection", __pyx_kwds); return NULL;} __Pyx_INCREF(__pyx_args); __pyx_v_args = __pyx_args; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 693, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_78intersection(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_args); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_DECREF(__pyx_v_args); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_78intersection(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; struct __pyx_obj_9intbitset_intbitset *__pyx_v_iarg = 0; PyObject *__pyx_v_arg = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; Py_ssize_t __pyx_t_5; int __pyx_t_6; 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("intersection", 0); /* "intbitset.pyx":695 * def intersection(self not None, *args): * """Return a new intbitset with elements common to the intbitset and all others.""" * cdef intbitset ret = intbitset(self) # <<<<<<<<<<<<<< * cdef intbitset iarg * for arg in args: */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, ((PyObject *)__pyx_v_self)}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 695, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":697 * cdef intbitset ret = intbitset(self) * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(ret.bitset, iarg.bitset) */ __pyx_t_1 = __pyx_v_args; __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; for (;;) { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 697, __pyx_L1_error) #endif if (__pyx_t_5 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_5)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_5); #endif ++__pyx_t_5; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 697, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF_SET(__pyx_v_arg, __pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":698 * cdef intbitset iarg * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) # <<<<<<<<<<<<<< * intBitSetIIntersection(ret.bitset, iarg.bitset) * return ret */ __pyx_t_6 = __Pyx_HasAttr(__pyx_v_arg, __pyx_mstate_global->__pyx_n_u_bitset); if (unlikely(__pyx_t_6 == ((int)-1))) __PYX_ERR(0, 698, __pyx_L1_error) if (__pyx_t_6) { if (!(likely(((__pyx_v_arg) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_arg, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset))))) __PYX_ERR(0, 698, __pyx_L1_error) __Pyx_INCREF(__pyx_v_arg); __pyx_t_3 = __pyx_v_arg; } else { __pyx_t_7 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_8 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_arg}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 698, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_2); } __pyx_t_3 = ((PyObject *)__pyx_t_2); __pyx_t_2 = 0; } __Pyx_XDECREF_SET(__pyx_v_iarg, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3)); __pyx_t_3 = 0; /* "intbitset.pyx":699 * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(ret.bitset, iarg.bitset) # <<<<<<<<<<<<<< * return ret * */ (void)(intBitSetIIntersection(__pyx_v_ret->bitset, __pyx_v_iarg->bitset)); /* "intbitset.pyx":697 * cdef intbitset ret = intbitset(self) * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(ret.bitset, iarg.bitset) */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":700 * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetIIntersection(ret.bitset, iarg.bitset) * return ret # <<<<<<<<<<<<<< * * def difference(self not None, *args): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":693 * return ret * * def intersection(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements common to the intbitset and all others.""" * cdef intbitset ret = intbitset(self) */ /* 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_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("intbitset.intbitset.intersection", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XDECREF((PyObject *)__pyx_v_iarg); __Pyx_XDECREF(__pyx_v_arg); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":702 * return ret * * def difference(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements from the intbitset that are not in the others.""" * cdef intbitset ret = intbitset(self) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_81difference(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_80difference, "Return a new intbitset with elements from the intbitset that are not in the others."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_81difference = {"difference", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_81difference, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_80difference}; static PyObject *__pyx_pw_9intbitset_9intbitset_81difference(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_args = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("difference (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("difference", __pyx_kwds); return NULL;} __Pyx_INCREF(__pyx_args); __pyx_v_args = __pyx_args; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 702, __pyx_L1_error) } __pyx_r = __pyx_pf_9intbitset_9intbitset_80difference(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_args); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; goto __pyx_L5_cleaned_up; __pyx_L0:; __pyx_L5_cleaned_up:; __Pyx_DECREF(__pyx_v_args); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_80difference(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_args) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_ret = 0; struct __pyx_obj_9intbitset_intbitset *__pyx_v_iarg = 0; PyObject *__pyx_v_arg = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; size_t __pyx_t_4; Py_ssize_t __pyx_t_5; int __pyx_t_6; 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("difference", 0); /* "intbitset.pyx":704 * def difference(self not None, *args): * """Return a new intbitset with elements from the intbitset that are not in the others.""" * cdef intbitset ret = intbitset(self) # <<<<<<<<<<<<<< * cdef intbitset iarg * for arg in args: */ __pyx_t_2 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_3 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, ((PyObject *)__pyx_v_self)}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 704, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_1); } __pyx_v_ret = ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":706 * cdef intbitset ret = intbitset(self) * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(ret.bitset, iarg.bitset) */ __pyx_t_1 = __pyx_v_args; __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0; for (;;) { { Py_ssize_t __pyx_temp = __Pyx_PyTuple_GET_SIZE(__pyx_t_1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely((__pyx_temp < 0))) __PYX_ERR(0, 706, __pyx_L1_error) #endif if (__pyx_t_5 >= __pyx_temp) break; } #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS __pyx_t_3 = __Pyx_NewRef(PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_5)); #else __pyx_t_3 = __Pyx_PySequence_ITEM(__pyx_t_1, __pyx_t_5); #endif ++__pyx_t_5; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 706, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF_SET(__pyx_v_arg, __pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":707 * cdef intbitset iarg * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) # <<<<<<<<<<<<<< * intBitSetISub(ret.bitset, iarg.bitset) * return ret */ __pyx_t_6 = __Pyx_HasAttr(__pyx_v_arg, __pyx_mstate_global->__pyx_n_u_bitset); if (unlikely(__pyx_t_6 == ((int)-1))) __PYX_ERR(0, 707, __pyx_L1_error) if (__pyx_t_6) { if (!(likely(((__pyx_v_arg) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_arg, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset))))) __PYX_ERR(0, 707, __pyx_L1_error) __Pyx_INCREF(__pyx_v_arg); __pyx_t_3 = __pyx_v_arg; } else { __pyx_t_7 = NULL; __Pyx_INCREF((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_8 = ((PyObject *)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); __pyx_t_4 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_7, __pyx_v_arg}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_8, __pyx_callargs+__pyx_t_4, (2-__pyx_t_4) | (__pyx_t_4*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 707, __pyx_L1_error) __Pyx_GOTREF((PyObject *)__pyx_t_2); } __pyx_t_3 = ((PyObject *)__pyx_t_2); __pyx_t_2 = 0; } __Pyx_XDECREF_SET(__pyx_v_iarg, ((struct __pyx_obj_9intbitset_intbitset *)__pyx_t_3)); __pyx_t_3 = 0; /* "intbitset.pyx":708 * for arg in args: * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(ret.bitset, iarg.bitset) # <<<<<<<<<<<<<< * return ret * */ (void)(intBitSetISub(__pyx_v_ret->bitset, __pyx_v_iarg->bitset)); /* "intbitset.pyx":706 * cdef intbitset ret = intbitset(self) * cdef intbitset iarg * for arg in args: # <<<<<<<<<<<<<< * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(ret.bitset, iarg.bitset) */ } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":709 * iarg = arg if hasattr(arg, "bitset") else intbitset(arg) * intBitSetISub(ret.bitset, iarg.bitset) * return ret # <<<<<<<<<<<<<< * * def isdisjoint(self not None, intbitset rhs not None): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_ret); __pyx_r = ((PyObject *)__pyx_v_ret); goto __pyx_L0; /* "intbitset.pyx":702 * return ret * * def difference(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements from the intbitset that are not in the others.""" * cdef intbitset ret = intbitset(self) */ /* 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_7); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("intbitset.intbitset.difference", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_ret); __Pyx_XDECREF((PyObject *)__pyx_v_iarg); __Pyx_XDECREF(__pyx_v_arg); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":711 * return ret * * def isdisjoint(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return True if two intbitsets have a null intersection.""" * return intBitSetIsDisjoint(self.bitset, rhs.bitset) */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_83isdisjoint(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_82isdisjoint, "Return True if two intbitsets have a null intersection."); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_83isdisjoint = {"isdisjoint", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_83isdisjoint, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_82isdisjoint}; static PyObject *__pyx_pw_9intbitset_9intbitset_83isdisjoint(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("isdisjoint (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_rhs,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 711, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 711, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "isdisjoint", 0) < (0)) __PYX_ERR(0, 711, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("isdisjoint", 1, 1, 1, i); __PYX_ERR(0, 711, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 711, __pyx_L3_error) } __pyx_v_rhs = ((struct __pyx_obj_9intbitset_intbitset *)values[0]); } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("isdisjoint", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 711, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.isdisjoint", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(((PyObject *)__pyx_v_self) == Py_None)) { PyErr_Format(PyExc_TypeError, "Argument '%.200s' must not be None", "self"); __PYX_ERR(0, 711, __pyx_L1_error) } if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rhs), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "rhs", 0))) __PYX_ERR(0, 711, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_9intbitset_82isdisjoint(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_rhs); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } goto __pyx_L7_cleaned_up; __pyx_L0:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __pyx_L7_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_82isdisjoint(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_rhs) { 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("isdisjoint", 0); /* "intbitset.pyx":713 * def isdisjoint(self not None, intbitset rhs not None): * """Return True if two intbitsets have a null intersection.""" * return intBitSetIsDisjoint(self.bitset, rhs.bitset) # <<<<<<<<<<<<<< * * cpdef update_with_signs(intbitset self, rhs): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyBool_FromLong(intBitSetIsDisjoint(__pyx_v_self->bitset, __pyx_v_rhs->bitset)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 713, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":711 * return ret * * def isdisjoint(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return True if two intbitsets have a null intersection.""" * return intBitSetIsDisjoint(self.bitset, rhs.bitset) */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.isdisjoint", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":715 * return intBitSetIsDisjoint(self.bitset, rhs.bitset) * * cpdef update_with_signs(intbitset self, rhs): # <<<<<<<<<<<<<< * """Given a dictionary rhs whose keys are integers, remove all the integers * whose value are less than 0 and add every integer whose value is 0 or more""" */ static PyObject *__pyx_pw_9intbitset_9intbitset_85update_with_signs(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_update_with_signs(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs, int __pyx_skip_dispatch) { int __pyx_v_value; PyObject *__pyx_v_sign = NULL; 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; size_t __pyx_t_5; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; PyObject *__pyx_t_8 = NULL; Py_ssize_t __pyx_t_9; Py_ssize_t __pyx_t_10; int __pyx_t_11; int __pyx_t_12; int __pyx_t_13; PyObject *__pyx_t_14 = NULL; PyObject *__pyx_t_15 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("update_with_signs", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_update_with_signs); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 715, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_85update_with_signs)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_v_rhs}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 715, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":719 * whose value are less than 0 and add every integer whose value is 0 or more""" * cdef int value * try: # <<<<<<<<<<<<<< * if self.sanity_checks: * for value, sign in rhs.iteritems(): */ { __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign __Pyx_ExceptionSave(&__pyx_t_6, &__pyx_t_7, &__pyx_t_8); __Pyx_XGOTREF(__pyx_t_6); __Pyx_XGOTREF(__pyx_t_7); __Pyx_XGOTREF(__pyx_t_8); /*try:*/ { /* "intbitset.pyx":720 * cdef int value * try: * if self.sanity_checks: # <<<<<<<<<<<<<< * for value, sign in rhs.iteritems(): * if value < 0: */ if (__pyx_v_self->sanity_checks) { /* "intbitset.pyx":721 * try: * if self.sanity_checks: * for value, sign in rhs.iteritems(): # <<<<<<<<<<<<<< * if value < 0: * raise ValueError("Negative numbers, not allowed") */ __pyx_t_9 = 0; if (unlikely(__pyx_v_rhs == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%.30s'", "iteritems"); __PYX_ERR(0, 721, __pyx_L3_error) } __pyx_t_2 = __Pyx_dict_iterator(__pyx_v_rhs, 0, __pyx_mstate_global->__pyx_n_u_iteritems, (&__pyx_t_10), (&__pyx_t_11)); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 721, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = __pyx_t_2; __pyx_t_2 = 0; while (1) { __pyx_t_12 = __Pyx_dict_iter_next(__pyx_t_1, __pyx_t_10, &__pyx_t_9, &__pyx_t_2, &__pyx_t_4, NULL, __pyx_t_11); if (unlikely(__pyx_t_12 == 0)) break; if (unlikely(__pyx_t_12 == -1)) __PYX_ERR(0, 721, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_GOTREF(__pyx_t_4); __pyx_t_12 = __Pyx_PyLong_As_int(__pyx_t_2); if (unlikely((__pyx_t_12 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 721, __pyx_L3_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_value = __pyx_t_12; __Pyx_XDECREF_SET(__pyx_v_sign, __pyx_t_4); __pyx_t_4 = 0; /* "intbitset.pyx":722 * if self.sanity_checks: * for value, sign in rhs.iteritems(): * if value < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif value > maxelem: */ __pyx_t_13 = (__pyx_v_value < 0); if (unlikely(__pyx_t_13)) { /* "intbitset.pyx":723 * for value, sign in rhs.iteritems(): * if value < 0: * raise ValueError("Negative numbers, not allowed") # <<<<<<<<<<<<<< * elif value > maxelem: * raise OverflowError("Elements must <= %s" % maxelem) */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_ValueError); __pyx_t_3 = __pyx_builtin_ValueError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_Negative_numbers_not_allowed}; __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_3, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 723, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_4); } __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 723, __pyx_L3_error) /* "intbitset.pyx":722 * if self.sanity_checks: * for value, sign in rhs.iteritems(): * if value < 0: # <<<<<<<<<<<<<< * raise ValueError("Negative numbers, not allowed") * elif value > maxelem: */ } /* "intbitset.pyx":724 * if value < 0: * raise ValueError("Negative numbers, not allowed") * elif value > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must <= %s" % maxelem) * if sign < 0: */ __pyx_t_13 = (__pyx_v_value > maxelem); if (unlikely(__pyx_t_13)) { /* "intbitset.pyx":725 * raise ValueError("Negative numbers, not allowed") * elif value > maxelem: * raise OverflowError("Elements must <= %s" % maxelem) # <<<<<<<<<<<<<< * if sign < 0: * intBitSetDelElem(self.bitset, value) */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_2 = __pyx_builtin_OverflowError; __pyx_t_14 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_14)) __PYX_ERR(0, 725, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_14); __pyx_t_15 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_Elements_must_s, __pyx_t_14); if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 725, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_15); __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_15}; __pyx_t_4 = __Pyx_PyObject_FastCall(__pyx_t_2, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 725, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_4); } __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __PYX_ERR(0, 725, __pyx_L3_error) /* "intbitset.pyx":724 * if value < 0: * raise ValueError("Negative numbers, not allowed") * elif value > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("Elements must <= %s" % maxelem) * if sign < 0: */ } /* "intbitset.pyx":726 * elif value > maxelem: * raise OverflowError("Elements must <= %s" % maxelem) * if sign < 0: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, value) * else: */ __pyx_t_4 = PyObject_RichCompare(__pyx_v_sign, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 726, __pyx_L3_error) __pyx_t_13 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 726, __pyx_L3_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_13) { /* "intbitset.pyx":727 * raise OverflowError("Elements must <= %s" % maxelem) * if sign < 0: * intBitSetDelElem(self.bitset, value) # <<<<<<<<<<<<<< * else: * intBitSetAddElem(self.bitset, value) */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_value); /* "intbitset.pyx":726 * elif value > maxelem: * raise OverflowError("Elements must <= %s" % maxelem) * if sign < 0: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, value) * else: */ goto __pyx_L13; } /* "intbitset.pyx":729 * intBitSetDelElem(self.bitset, value) * else: * intBitSetAddElem(self.bitset, value) # <<<<<<<<<<<<<< * else: * for value, sign in rhs.iteritems(): */ /*else*/ { intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_value); } __pyx_L13:; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":720 * cdef int value * try: * if self.sanity_checks: # <<<<<<<<<<<<<< * for value, sign in rhs.iteritems(): * if value < 0: */ goto __pyx_L9; } /* "intbitset.pyx":731 * intBitSetAddElem(self.bitset, value) * else: * for value, sign in rhs.iteritems(): # <<<<<<<<<<<<<< * if sign < 0: * intBitSetDelElem(self.bitset, value) */ /*else*/ { __pyx_t_10 = 0; if (unlikely(__pyx_v_rhs == Py_None)) { PyErr_Format(PyExc_AttributeError, "'NoneType' object has no attribute '%.30s'", "iteritems"); __PYX_ERR(0, 731, __pyx_L3_error) } __pyx_t_4 = __Pyx_dict_iterator(__pyx_v_rhs, 0, __pyx_mstate_global->__pyx_n_u_iteritems, (&__pyx_t_9), (&__pyx_t_11)); if (unlikely(!__pyx_t_4)) __PYX_ERR(0, 731, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = __pyx_t_4; __pyx_t_4 = 0; while (1) { __pyx_t_12 = __Pyx_dict_iter_next(__pyx_t_1, __pyx_t_9, &__pyx_t_10, &__pyx_t_4, &__pyx_t_2, NULL, __pyx_t_11); if (unlikely(__pyx_t_12 == 0)) break; if (unlikely(__pyx_t_12 == -1)) __PYX_ERR(0, 731, __pyx_L3_error) __Pyx_GOTREF(__pyx_t_4); __Pyx_GOTREF(__pyx_t_2); __pyx_t_12 = __Pyx_PyLong_As_int(__pyx_t_4); if (unlikely((__pyx_t_12 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 731, __pyx_L3_error) __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_v_value = __pyx_t_12; __Pyx_XDECREF_SET(__pyx_v_sign, __pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":732 * else: * for value, sign in rhs.iteritems(): * if sign < 0: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, value) * else: */ __pyx_t_2 = PyObject_RichCompare(__pyx_v_sign, __pyx_mstate_global->__pyx_int_0, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 732, __pyx_L3_error) __pyx_t_13 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely((__pyx_t_13 < 0))) __PYX_ERR(0, 732, __pyx_L3_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_13) { /* "intbitset.pyx":733 * for value, sign in rhs.iteritems(): * if sign < 0: * intBitSetDelElem(self.bitset, value) # <<<<<<<<<<<<<< * else: * intBitSetAddElem(self.bitset, value) */ intBitSetDelElem(__pyx_v_self->bitset, __pyx_v_value); /* "intbitset.pyx":732 * else: * for value, sign in rhs.iteritems(): * if sign < 0: # <<<<<<<<<<<<<< * intBitSetDelElem(self.bitset, value) * else: */ goto __pyx_L16; } /* "intbitset.pyx":735 * intBitSetDelElem(self.bitset, value) * else: * intBitSetAddElem(self.bitset, value) # <<<<<<<<<<<<<< * except AttributeError: * raise TypeError("rhs should be a valid dictionary with integers keys and integer values") */ /*else*/ { intBitSetAddElem(__pyx_v_self->bitset, __pyx_v_value); } __pyx_L16:; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; } __pyx_L9:; /* "intbitset.pyx":719 * whose value are less than 0 and add every integer whose value is 0 or more""" * cdef int value * try: # <<<<<<<<<<<<<< * if self.sanity_checks: * for value, sign in rhs.iteritems(): */ } __Pyx_XDECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_XDECREF(__pyx_t_7); __pyx_t_7 = 0; __Pyx_XDECREF(__pyx_t_8); __pyx_t_8 = 0; goto __pyx_L8_try_end; __pyx_L3_error:; __Pyx_XDECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_XDECREF(__pyx_t_14); __pyx_t_14 = 0; __Pyx_XDECREF(__pyx_t_15); __pyx_t_15 = 0; __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; /* "intbitset.pyx":736 * else: * intBitSetAddElem(self.bitset, value) * except AttributeError: # <<<<<<<<<<<<<< * raise TypeError("rhs should be a valid dictionary with integers keys and integer values") * */ __pyx_t_11 = __Pyx_PyErr_ExceptionMatches(__pyx_builtin_AttributeError); if (__pyx_t_11) { __Pyx_AddTraceback("intbitset.intbitset.update_with_signs", __pyx_clineno, __pyx_lineno, __pyx_filename); if (__Pyx_GetException(&__pyx_t_1, &__pyx_t_2, &__pyx_t_4) < 0) __PYX_ERR(0, 736, __pyx_L5_except_error) __Pyx_XGOTREF(__pyx_t_1); __Pyx_XGOTREF(__pyx_t_2); __Pyx_XGOTREF(__pyx_t_4); /* "intbitset.pyx":737 * intBitSetAddElem(self.bitset, value) * except AttributeError: * raise TypeError("rhs should be a valid dictionary with integers keys and integer values") # <<<<<<<<<<<<<< * * cpdef get_size(intbitset self): */ __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_builtin_TypeError); __pyx_t_14 = __pyx_builtin_TypeError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_mstate_global->__pyx_kp_u_rhs_should_be_a_valid_dictionary}; __pyx_t_15 = __Pyx_PyObject_FastCall(__pyx_t_14, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_14); __pyx_t_14 = 0; if (unlikely(!__pyx_t_15)) __PYX_ERR(0, 737, __pyx_L5_except_error) __Pyx_GOTREF(__pyx_t_15); } __Pyx_Raise(__pyx_t_15, 0, 0, 0); __Pyx_DECREF(__pyx_t_15); __pyx_t_15 = 0; __PYX_ERR(0, 737, __pyx_L5_except_error) } goto __pyx_L5_except_error; /* "intbitset.pyx":719 * whose value are less than 0 and add every integer whose value is 0 or more""" * cdef int value * try: # <<<<<<<<<<<<<< * if self.sanity_checks: * for value, sign in rhs.iteritems(): */ __pyx_L5_except_error:; __Pyx_XGIVEREF(__pyx_t_6); __Pyx_XGIVEREF(__pyx_t_7); __Pyx_XGIVEREF(__pyx_t_8); __Pyx_ExceptionReset(__pyx_t_6, __pyx_t_7, __pyx_t_8); goto __pyx_L1_error; __pyx_L8_try_end:; } /* "intbitset.pyx":715 * return intBitSetIsDisjoint(self.bitset, rhs.bitset) * * cpdef update_with_signs(intbitset self, rhs): # <<<<<<<<<<<<<< * """Given a dictionary rhs whose keys are integers, remove all the integers * whose value are less than 0 and add every integer whose value is 0 or more""" */ /* 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_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_14); __Pyx_XDECREF(__pyx_t_15); __Pyx_AddTraceback("intbitset.intbitset.update_with_signs", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_sign); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_85update_with_signs(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_84update_with_signs, "Given a dictionary rhs whose keys are integers, remove all the integers\n whose value are less than 0 and add every integer whose value is 0 or more"); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_85update_with_signs = {"update_with_signs", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_85update_with_signs, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_84update_with_signs}; static PyObject *__pyx_pw_9intbitset_9intbitset_85update_with_signs(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { PyObject *__pyx_v_rhs = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("update_with_signs (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_rhs,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 715, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 715, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "update_with_signs", 0) < (0)) __PYX_ERR(0, 715, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("update_with_signs", 1, 1, 1, i); __PYX_ERR(0, 715, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 715, __pyx_L3_error) } __pyx_v_rhs = values[0]; } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("update_with_signs", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 715, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.update_with_signs", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_84update_with_signs(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_rhs); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_84update_with_signs(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, PyObject *__pyx_v_rhs) { 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("update_with_signs", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_update_with_signs(__pyx_v_self, __pyx_v_rhs, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 715, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.update_with_signs", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":739 * raise TypeError("rhs should be a valid dictionary with integers keys and integer values") * * cpdef get_size(intbitset self): # <<<<<<<<<<<<<< * return intBitSetGetSize(self.bitset) * */ static PyObject *__pyx_pw_9intbitset_9intbitset_87get_size(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_size(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("get_size", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_get_size); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 739, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_87get_size)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 739, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":740 * * cpdef get_size(intbitset self): * return intBitSetGetSize(self.bitset) # <<<<<<<<<<<<<< * * cpdef get_allocated(intbitset self): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyLong_From_int(intBitSetGetSize(__pyx_v_self->bitset)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 740, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":739 * raise TypeError("rhs should be a valid dictionary with integers keys and integer values") * * cpdef get_size(intbitset self): # <<<<<<<<<<<<<< * return intBitSetGetSize(self.bitset) * */ /* 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_AddTraceback("intbitset.intbitset.get_size", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_87get_size(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_87get_size = {"get_size", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_87get_size, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_87get_size(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("get_size (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("get_size", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("get_size", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_86get_size(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_86get_size(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("get_size", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_get_size(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 739, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.get_size", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":742 * return intBitSetGetSize(self.bitset) * * cpdef get_allocated(intbitset self): # <<<<<<<<<<<<<< * return intBitSetGetAllocated(self.bitset) * */ static PyObject *__pyx_pw_9intbitset_9intbitset_89get_allocated(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_allocated(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("get_allocated", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_get_allocated); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 742, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_89get_allocated)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 742, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":743 * * cpdef get_allocated(intbitset self): * return intBitSetGetAllocated(self.bitset) # <<<<<<<<<<<<<< * * cpdef is_infinite(intbitset self): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyLong_From_int(intBitSetGetAllocated(__pyx_v_self->bitset)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 743, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":742 * return intBitSetGetSize(self.bitset) * * cpdef get_allocated(intbitset self): # <<<<<<<<<<<<<< * return intBitSetGetAllocated(self.bitset) * */ /* 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_AddTraceback("intbitset.intbitset.get_allocated", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_89get_allocated(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_89get_allocated = {"get_allocated", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_89get_allocated, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_89get_allocated(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("get_allocated (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("get_allocated", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("get_allocated", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_88get_allocated(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_88get_allocated(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("get_allocated", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_get_allocated(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 742, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.get_allocated", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":745 * return intBitSetGetAllocated(self.bitset) * * cpdef is_infinite(intbitset self): # <<<<<<<<<<<<<< * """Return True if the intbitset is infinite. (i.e. trailing_bits=True * was used in the constructor.)""" */ static PyObject *__pyx_pw_9intbitset_9intbitset_91is_infinite(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_is_infinite(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("is_infinite", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_is_infinite); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 745, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_91is_infinite)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 745, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":748 * """Return True if the intbitset is infinite. (i.e. trailing_bits=True * was used in the constructor.)""" * return self.bitset.trailing_bits != 0 # <<<<<<<<<<<<<< * * cpdef extract_finite_list(intbitset self, int up_to=-1): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyBool_FromLong((__pyx_v_self->bitset->trailing_bits != 0)); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 748, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":745 * return intBitSetGetAllocated(self.bitset) * * cpdef is_infinite(intbitset self): # <<<<<<<<<<<<<< * """Return True if the intbitset is infinite. (i.e. trailing_bits=True * was used in the constructor.)""" */ /* 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_AddTraceback("intbitset.intbitset.is_infinite", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_91is_infinite(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_90is_infinite, "Return True if the intbitset is infinite. (i.e. trailing_bits=True\n was used in the constructor.)"); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_91is_infinite = {"is_infinite", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_91is_infinite, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_90is_infinite}; static PyObject *__pyx_pw_9intbitset_9intbitset_91is_infinite(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("is_infinite (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("is_infinite", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("is_infinite", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_90is_infinite(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_90is_infinite(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("is_infinite", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_is_infinite(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 745, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.is_infinite", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":750 * return self.bitset.trailing_bits != 0 * * cpdef extract_finite_list(intbitset self, int up_to=-1): # <<<<<<<<<<<<<< * """Return a finite list of elements sufficient to be passed to intbitset * constructor toghether with the proper value of trailing_bits in order */ static PyObject *__pyx_pw_9intbitset_9intbitset_93extract_finite_list(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_extract_finite_list(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch, struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list *__pyx_optional_args) { int __pyx_v_up_to = ((int)-1); int __pyx_v_true_up_to; int __pyx_v_last; PyObject *__pyx_v_ret = NULL; 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; size_t __pyx_t_6; int __pyx_t_7; int __pyx_t_8; int __pyx_t_9; int __pyx_t_10; int __pyx_t_11; int __pyx_t_12; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("extract_finite_list", 0); if (__pyx_optional_args) { if (__pyx_optional_args->__pyx_n > 0) { __pyx_v_up_to = __pyx_optional_args->up_to; } } /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_extract_finite_list); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_93extract_finite_list)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = __Pyx_PyLong_From_int(__pyx_v_up_to); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_6 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, __pyx_t_5}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":758 * cdef int true_up_to * cdef int last * if self.sanity_checks and up_to > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("up_to must be <= %s" % maxelem) * ret = [] */ if (__pyx_v_self->sanity_checks) { } else { __pyx_t_7 = __pyx_v_self->sanity_checks; goto __pyx_L4_bool_binop_done; } __pyx_t_8 = (__pyx_v_up_to > maxelem); __pyx_t_7 = __pyx_t_8; __pyx_L4_bool_binop_done:; if (unlikely(__pyx_t_7)) { /* "intbitset.pyx":759 * cdef int last * if self.sanity_checks and up_to > maxelem: * raise OverflowError("up_to must be <= %s" % maxelem) # <<<<<<<<<<<<<< * ret = [] * true_up_to = max(up_to, (intBitSetGetSize(self.bitset)) * wordbitsize) */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_4 = __pyx_builtin_OverflowError; __pyx_t_5 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_5)) __PYX_ERR(0, 759, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyUnicode_Format(__pyx_mstate_global->__pyx_kp_u_up_to_must_be_s, __pyx_t_5); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 759, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_6 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_t_3}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_6, (2-__pyx_t_6) | (__pyx_t_6*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 759, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 759, __pyx_L1_error) /* "intbitset.pyx":758 * cdef int true_up_to * cdef int last * if self.sanity_checks and up_to > maxelem: # <<<<<<<<<<<<<< * raise OverflowError("up_to must be <= %s" % maxelem) * ret = [] */ } /* "intbitset.pyx":760 * if self.sanity_checks and up_to > maxelem: * raise OverflowError("up_to must be <= %s" % maxelem) * ret = [] # <<<<<<<<<<<<<< * true_up_to = max(up_to, (intBitSetGetSize(self.bitset)) * wordbitsize) * last = -1 */ __pyx_t_1 = PyList_New(0); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 760, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_v_ret = ((PyObject*)__pyx_t_1); __pyx_t_1 = 0; /* "intbitset.pyx":761 * raise OverflowError("up_to must be <= %s" % maxelem) * ret = [] * true_up_to = max(up_to, (intBitSetGetSize(self.bitset)) * wordbitsize) # <<<<<<<<<<<<<< * last = -1 * while last < true_up_to: */ __pyx_t_9 = (intBitSetGetSize(__pyx_v_self->bitset) * wordbitsize); __pyx_t_10 = __pyx_v_up_to; __pyx_t_7 = (__pyx_t_9 > __pyx_t_10); if (__pyx_t_7) { __pyx_t_11 = __pyx_t_9; } else { __pyx_t_11 = __pyx_t_10; } __pyx_v_true_up_to = __pyx_t_11; /* "intbitset.pyx":762 * ret = [] * true_up_to = max(up_to, (intBitSetGetSize(self.bitset)) * wordbitsize) * last = -1 # <<<<<<<<<<<<<< * while last < true_up_to: * last = intBitSetGetNext(self.bitset, last) */ __pyx_v_last = -1; /* "intbitset.pyx":763 * true_up_to = max(up_to, (intBitSetGetSize(self.bitset)) * wordbitsize) * last = -1 * while last < true_up_to: # <<<<<<<<<<<<<< * last = intBitSetGetNext(self.bitset, last) * if last == -2: */ while (1) { __pyx_t_7 = (__pyx_v_last < __pyx_v_true_up_to); if (!__pyx_t_7) break; /* "intbitset.pyx":764 * last = -1 * while last < true_up_to: * last = intBitSetGetNext(self.bitset, last) # <<<<<<<<<<<<<< * if last == -2: * break */ __pyx_v_last = intBitSetGetNext(__pyx_v_self->bitset, __pyx_v_last); /* "intbitset.pyx":765 * while last < true_up_to: * last = intBitSetGetNext(self.bitset, last) * if last == -2: # <<<<<<<<<<<<<< * break * ret.append(last) */ __pyx_t_7 = (__pyx_v_last == -2L); if (__pyx_t_7) { /* "intbitset.pyx":766 * last = intBitSetGetNext(self.bitset, last) * if last == -2: * break # <<<<<<<<<<<<<< * ret.append(last) * return ret */ goto __pyx_L7_break; /* "intbitset.pyx":765 * while last < true_up_to: * last = intBitSetGetNext(self.bitset, last) * if last == -2: # <<<<<<<<<<<<<< * break * ret.append(last) */ } /* "intbitset.pyx":767 * if last == -2: * break * ret.append(last) # <<<<<<<<<<<<<< * return ret * */ __pyx_t_1 = __Pyx_PyLong_From_int(__pyx_v_last); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 767, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_t_12 = __Pyx_PyList_Append(__pyx_v_ret, __pyx_t_1); if (unlikely(__pyx_t_12 == ((int)-1))) __PYX_ERR(0, 767, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; } __pyx_L7_break:; /* "intbitset.pyx":768 * break * ret.append(last) * return ret # <<<<<<<<<<<<<< * * cpdef get_wordbitsize(intbitset self): */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_v_ret); __pyx_r = __pyx_v_ret; goto __pyx_L0; /* "intbitset.pyx":750 * return self.bitset.trailing_bits != 0 * * cpdef extract_finite_list(intbitset self, int up_to=-1): # <<<<<<<<<<<<<< * """Return a finite list of elements sufficient to be passed to intbitset * constructor toghether with the proper value of trailing_bits in order */ /* 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("intbitset.intbitset.extract_finite_list", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XDECREF(__pyx_v_ret); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_93extract_finite_list(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_92extract_finite_list, "Return a finite list of elements sufficient to be passed to intbitset\n constructor toghether with the proper value of trailing_bits in order\n to reproduce this intbitset. At least up_to integer are looked for when\n they are inside the intbitset but not necessarily needed to build the\n intbitset"); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_93extract_finite_list = {"extract_finite_list", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_93extract_finite_list, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_92extract_finite_list}; static PyObject *__pyx_pw_9intbitset_9intbitset_93extract_finite_list(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { int __pyx_v_up_to; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("extract_finite_list (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_up_to,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 750, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 750, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "extract_finite_list", 0) < (0)) __PYX_ERR(0, 750, __pyx_L3_error) } else { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 750, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } } if (values[0]) { __pyx_v_up_to = __Pyx_PyLong_As_int(values[0]); if (unlikely((__pyx_v_up_to == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 750, __pyx_L3_error) } else { __pyx_v_up_to = ((int)-1); } } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("extract_finite_list", 0, 0, 1, __pyx_nargs); __PYX_ERR(0, 750, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset.extract_finite_list", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_9intbitset_92extract_finite_list(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self), __pyx_v_up_to); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_92extract_finite_list(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_v_up_to) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list __pyx_t_2; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("extract_finite_list", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_2.__pyx_n = 1; __pyx_t_2.up_to = __pyx_v_up_to; __pyx_t_1 = __pyx_vtabptr_9intbitset_intbitset->extract_finite_list(__pyx_v_self, 1, &__pyx_t_2); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.extract_finite_list", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":770 * return ret * * cpdef get_wordbitsize(intbitset self): # <<<<<<<<<<<<<< * return wordbitsize * */ static PyObject *__pyx_pw_9intbitset_9intbitset_95get_wordbitsize(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_wordbitsize(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("get_wordbitsize", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_get_wordbitsize); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 770, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_95get_wordbitsize)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 770, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":771 * * cpdef get_wordbitsize(intbitset self): * return wordbitsize # <<<<<<<<<<<<<< * * cpdef get_wordbytsize(intbitset self): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyLong_From_int(wordbitsize); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 771, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":770 * return ret * * cpdef get_wordbitsize(intbitset self): # <<<<<<<<<<<<<< * return wordbitsize * */ /* 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_AddTraceback("intbitset.intbitset.get_wordbitsize", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_95get_wordbitsize(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_95get_wordbitsize = {"get_wordbitsize", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_95get_wordbitsize, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_95get_wordbitsize(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("get_wordbitsize (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("get_wordbitsize", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("get_wordbitsize", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_94get_wordbitsize(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_94get_wordbitsize(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("get_wordbitsize", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_get_wordbitsize(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 770, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.get_wordbitsize", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":773 * return wordbitsize * * cpdef get_wordbytsize(intbitset self): # <<<<<<<<<<<<<< * return wordbytesize * */ static PyObject *__pyx_pw_9intbitset_9intbitset_97get_wordbytsize(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_get_wordbytsize(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("get_wordbytsize", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_get_wordbytsize); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 773, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_97get_wordbytsize)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 773, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":774 * * cpdef get_wordbytsize(intbitset self): * return wordbytesize # <<<<<<<<<<<<<< * * cpdef tolist(intbitset self): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __Pyx_PyLong_From_int(wordbytesize); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 774, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":773 * return wordbitsize * * cpdef get_wordbytsize(intbitset self): # <<<<<<<<<<<<<< * return wordbytesize * */ /* 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_AddTraceback("intbitset.intbitset.get_wordbytsize", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_97get_wordbytsize(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_9intbitset_97get_wordbytsize = {"get_wordbytsize", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_97get_wordbytsize, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_9intbitset_97get_wordbytsize(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("get_wordbytsize (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("get_wordbytsize", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("get_wordbytsize", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_96get_wordbytsize(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_96get_wordbytsize(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("get_wordbytsize", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_get_wordbytsize(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 773, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.get_wordbytsize", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":776 * return wordbytesize * * cpdef tolist(intbitset self): # <<<<<<<<<<<<<< * """Legacy method to retrieve a list of all the elements inside an * intbitset. */ static PyObject *__pyx_pw_9intbitset_9intbitset_99tolist(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyObject *__pyx_f_9intbitset_9intbitset_tolist(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self, int __pyx_skip_dispatch) { 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; size_t __pyx_t_5; int __pyx_t_6; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("tolist", 0); /* Check if called by wrapper */ if (unlikely(__pyx_skip_dispatch)) ; /* Check if overridden in Python */ else if ( #if !CYTHON_USE_TYPE_SLOTS unlikely(Py_TYPE(((PyObject *)__pyx_v_self)) != __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset && __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), Py_TPFLAGS_HAVE_GC)) #else unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0 || __Pyx_PyType_HasFeature(Py_TYPE(((PyObject *)__pyx_v_self)), (Py_TPFLAGS_IS_ABSTRACT | Py_TPFLAGS_HEAPTYPE))) #endif ) { #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS static PY_UINT64_T __pyx_tp_dict_version = __PYX_DICT_VERSION_INIT, __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; if (unlikely(!__Pyx_object_dict_version_matches(((PyObject *)__pyx_v_self), __pyx_tp_dict_version, __pyx_obj_dict_version))) { PY_UINT64_T __pyx_typedict_guard = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); #endif __pyx_t_1 = __Pyx_PyObject_GetAttrStr(((PyObject *)__pyx_v_self), __pyx_mstate_global->__pyx_n_u_tolist); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 776, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); if (!__Pyx_IsSameCFunction(__pyx_t_1, (void(*)(void)) __pyx_pw_9intbitset_9intbitset_99tolist)) { __Pyx_XDECREF(__pyx_r); __pyx_t_3 = NULL; __Pyx_INCREF(__pyx_t_1); __pyx_t_4 = __pyx_t_1; __pyx_t_5 = 1; #if CYTHON_UNPACK_METHODS if (unlikely(PyMethod_Check(__pyx_t_4))) { __pyx_t_3 = PyMethod_GET_SELF(__pyx_t_4); assert(__pyx_t_3); PyObject* __pyx__function = PyMethod_GET_FUNCTION(__pyx_t_4); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx__function); __Pyx_DECREF_SET(__pyx_t_4, __pyx__function); __pyx_t_5 = 0; } #endif { PyObject *__pyx_callargs[2] = {__pyx_t_3, NULL}; __pyx_t_2 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (1-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 776, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); } __pyx_r = __pyx_t_2; __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L0; } #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS __pyx_tp_dict_version = __Pyx_get_tp_dict_version(((PyObject *)__pyx_v_self)); __pyx_obj_dict_version = __Pyx_get_object_dict_version(((PyObject *)__pyx_v_self)); if (unlikely(__pyx_typedict_guard != __pyx_tp_dict_version)) { __pyx_tp_dict_version = __pyx_obj_dict_version = __PYX_DICT_VERSION_INIT; } #endif __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; #if CYTHON_USE_DICT_VERSIONS && CYTHON_USE_PYTYPE_LOOKUP && CYTHON_USE_TYPE_SLOTS } #endif } /* "intbitset.pyx":780 * intbitset. * """ * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * raise OverflowError("It's impossible to retrieve a list of an infinite set") * return self.extract_finite_list() */ __pyx_t_6 = (__pyx_v_self->bitset->trailing_bits != 0); if (unlikely(__pyx_t_6)) { /* "intbitset.pyx":781 * """ * if self.bitset.trailing_bits: * raise OverflowError("It's impossible to retrieve a list of an infinite set") # <<<<<<<<<<<<<< * return self.extract_finite_list() * */ __pyx_t_2 = NULL; __Pyx_INCREF(__pyx_builtin_OverflowError); __pyx_t_4 = __pyx_builtin_OverflowError; __pyx_t_5 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_2, __pyx_mstate_global->__pyx_kp_u_It_s_impossible_to_retrieve_a_li}; __pyx_t_1 = __Pyx_PyObject_FastCall(__pyx_t_4, __pyx_callargs+__pyx_t_5, (2-__pyx_t_5) | (__pyx_t_5*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 781, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); } __Pyx_Raise(__pyx_t_1, 0, 0, 0); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __PYX_ERR(0, 781, __pyx_L1_error) /* "intbitset.pyx":780 * intbitset. * """ * if self.bitset.trailing_bits: # <<<<<<<<<<<<<< * raise OverflowError("It's impossible to retrieve a list of an infinite set") * return self.extract_finite_list() */ } /* "intbitset.pyx":782 * if self.bitset.trailing_bits: * raise OverflowError("It's impossible to retrieve a list of an infinite set") * return self.extract_finite_list() # <<<<<<<<<<<<<< * * cdef object __weakref__ */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = ((struct __pyx_vtabstruct_9intbitset_intbitset *)__pyx_v_self->__pyx_vtab)->extract_finite_list(__pyx_v_self, 0, NULL); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 782, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* "intbitset.pyx":776 * return wordbytesize * * cpdef tolist(intbitset self): # <<<<<<<<<<<<<< * """Legacy method to retrieve a list of all the elements inside an * intbitset. */ /* 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_AddTraceback("intbitset.intbitset.tolist", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_9intbitset_99tolist(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ PyDoc_STRVAR(__pyx_doc_9intbitset_9intbitset_98tolist, "Legacy method to retrieve a list of all the elements inside an\n intbitset.\n "); static PyMethodDef __pyx_mdef_9intbitset_9intbitset_99tolist = {"tolist", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_99tolist, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_98tolist}; static PyObject *__pyx_pw_9intbitset_9intbitset_99tolist(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("tolist (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("tolist", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("tolist", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_9intbitset_98tolist(((struct __pyx_obj_9intbitset_intbitset *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_9intbitset_98tolist(struct __pyx_obj_9intbitset_intbitset *__pyx_v_self) { 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("tolist", 0); __Pyx_XDECREF(__pyx_r); __pyx_t_1 = __pyx_f_9intbitset_9intbitset_tolist(__pyx_v_self, 1); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 776, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset.tolist", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":791 * cdef bint sanity_checks * * def __cinit__(intbitset_iterator self, intbitset bitset not None): # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset_iterator.__cinit__ is called" * self.last = -1 */ /* Python wrapper */ static int __pyx_pw_9intbitset_18intbitset_iterator_1__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static int __pyx_pw_9intbitset_18intbitset_iterator_1__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { struct __pyx_obj_9intbitset_intbitset *__pyx_v_bitset = 0; CYTHON_UNUSED Py_ssize_t __pyx_nargs; CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__cinit__ (wrapper)", 0); #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return -1; #endif __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_bitset,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_VARARGS(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(0, 791, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_VARARGS(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 791, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__cinit__", 0) < (0)) __PYX_ERR(0, 791, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__cinit__", 1, 1, 1, i); __PYX_ERR(0, 791, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_VARARGS(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(0, 791, __pyx_L3_error) } __pyx_v_bitset = ((struct __pyx_obj_9intbitset_intbitset *)values[0]); } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__cinit__", 1, 1, 1, __pyx_nargs); __PYX_ERR(0, 791, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset_iterator.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return -1; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_bitset), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, 0, "bitset", 0))) __PYX_ERR(0, 791, __pyx_L1_error) __pyx_r = __pyx_pf_9intbitset_18intbitset_iterator___cinit__(((struct __pyx_obj_9intbitset_intbitset_iterator *)__pyx_v_self), __pyx_v_bitset); /* function exit code */ goto __pyx_L0; __pyx_L1_error:; __pyx_r = -1; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } goto __pyx_L7_cleaned_up; __pyx_L0:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __pyx_L7_cleaned_up:; __Pyx_RefNannyFinishContext(); return __pyx_r; } static int __pyx_pf_9intbitset_18intbitset_iterator___cinit__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self, struct __pyx_obj_9intbitset_intbitset *__pyx_v_bitset) { int __pyx_r; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; int __pyx_t_2; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__cinit__", 0); /* "intbitset.pyx":793 * def __cinit__(intbitset_iterator self, intbitset bitset not None): * #print >> sys.stderr, "intbitset_iterator.__cinit__ is called" * self.last = -1 # <<<<<<<<<<<<<< * ## A copy should be performed, in case the original bitset disappears * ## as in "for x in intbitset([1,2,3])"! */ __pyx_v_self->last = -1; /* "intbitset.pyx":796 * ## A copy should be performed, in case the original bitset disappears * ## as in "for x in intbitset([1,2,3])"! * self.bitset = intBitSetClone(bitset.bitset) # <<<<<<<<<<<<<< * self.sanity_checks = CFG_INTBITSET_ENABLE_SANITY_CHECKS * */ __pyx_v_self->bitset = intBitSetClone(__pyx_v_bitset->bitset); /* "intbitset.pyx":797 * ## as in "for x in intbitset([1,2,3])"! * self.bitset = intBitSetClone(bitset.bitset) * self.sanity_checks = CFG_INTBITSET_ENABLE_SANITY_CHECKS # <<<<<<<<<<<<<< * * def __dealloc__(intbitset_iterator self): */ __Pyx_GetModuleGlobalName(__pyx_t_1, __pyx_mstate_global->__pyx_n_u_CFG_INTBITSET_ENABLE_SANITY_CHEC); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 797, __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(0, 797, __pyx_L1_error) __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_self->sanity_checks = __pyx_t_2; /* "intbitset.pyx":791 * cdef bint sanity_checks * * def __cinit__(intbitset_iterator self, intbitset bitset not None): # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset_iterator.__cinit__ is called" * self.last = -1 */ /* function exit code */ __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("intbitset.intbitset_iterator.__cinit__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":799 * self.sanity_checks = CFG_INTBITSET_ENABLE_SANITY_CHECKS * * def __dealloc__(intbitset_iterator self): # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset_iterator.__dealloc__ is called" * intBitSetDestroy(self.bitset) */ /* Python wrapper */ static void __pyx_pw_9intbitset_18intbitset_iterator_3__dealloc__(PyObject *__pyx_v_self); /*proto*/ static void __pyx_pw_9intbitset_18intbitset_iterator_3__dealloc__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__dealloc__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); __pyx_pf_9intbitset_18intbitset_iterator_2__dealloc__(((struct __pyx_obj_9intbitset_intbitset_iterator *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); } static void __pyx_pf_9intbitset_18intbitset_iterator_2__dealloc__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self) { /* "intbitset.pyx":801 * def __dealloc__(intbitset_iterator self): * #print >> sys.stderr, "intbitset_iterator.__dealloc__ is called" * intBitSetDestroy(self.bitset) # <<<<<<<<<<<<<< * * def __next__(intbitset_iterator self): */ intBitSetDestroy(__pyx_v_self->bitset); /* "intbitset.pyx":799 * self.sanity_checks = CFG_INTBITSET_ENABLE_SANITY_CHECKS * * def __dealloc__(intbitset_iterator self): # <<<<<<<<<<<<<< * #print >> sys.stderr, "intbitset_iterator.__dealloc__ is called" * intBitSetDestroy(self.bitset) */ /* function exit code */ } /* "intbitset.pyx":803 * intBitSetDestroy(self.bitset) * * def __next__(intbitset_iterator self): # <<<<<<<<<<<<<< * if self.last == -2: * raise StopIteration() */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_5__next__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_5__next__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__next__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); __pyx_r = __pyx_pf_9intbitset_18intbitset_iterator_4__next__(((struct __pyx_obj_9intbitset_intbitset_iterator *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_4__next__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_error_without_exception = 0; /* StopIteration */ int __pyx_t_1; int __pyx_t_2; PyObject *__pyx_t_3 = NULL; PyObject *__pyx_t_4 = NULL; PyObject *__pyx_t_5 = NULL; PyObject *__pyx_t_6 = NULL; PyObject *__pyx_t_7 = NULL; PyObject *__pyx_t_8[4]; PyObject *__pyx_t_9 = NULL; size_t __pyx_t_10; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__next__", 0); /* "intbitset.pyx":804 * * def __next__(intbitset_iterator self): * if self.last == -2: # <<<<<<<<<<<<<< * raise StopIteration() * self.last = intBitSetGetNext(self.bitset, self.last) */ __pyx_t_1 = (__pyx_v_self->last == -2L); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":805 * def __next__(intbitset_iterator self): * if self.last == -2: * raise StopIteration() # <<<<<<<<<<<<<< * self.last = intBitSetGetNext(self.bitset, self.last) * if self.sanity_checks and (self.bitset.allocated < self.bitset.size): */ __pyx_error_without_exception = 1; goto __pyx_L1_error;; /* "intbitset.pyx":804 * * def __next__(intbitset_iterator self): * if self.last == -2: # <<<<<<<<<<<<<< * raise StopIteration() * self.last = intBitSetGetNext(self.bitset, self.last) */ } /* "intbitset.pyx":806 * if self.last == -2: * raise StopIteration() * self.last = intBitSetGetNext(self.bitset, self.last) # <<<<<<<<<<<<<< * if self.sanity_checks and (self.bitset.allocated < self.bitset.size): * raise MemoryError( */ __pyx_v_self->last = intBitSetGetNext(__pyx_v_self->bitset, __pyx_v_self->last); /* "intbitset.pyx":807 * raise StopIteration() * self.last = intBitSetGetNext(self.bitset, self.last) * if self.sanity_checks and (self.bitset.allocated < self.bitset.size): # <<<<<<<<<<<<<< * raise MemoryError( * "intbitset corrupted: allocated: %s, size: %s" */ if (__pyx_v_self->sanity_checks) { } else { __pyx_t_1 = __pyx_v_self->sanity_checks; goto __pyx_L5_bool_binop_done; } __pyx_t_2 = (__pyx_v_self->bitset->allocated < __pyx_v_self->bitset->size); __pyx_t_1 = __pyx_t_2; __pyx_L5_bool_binop_done:; if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":808 * self.last = intBitSetGetNext(self.bitset, self.last) * if self.sanity_checks and (self.bitset.allocated < self.bitset.size): * raise MemoryError( # <<<<<<<<<<<<<< * "intbitset corrupted: allocated: %s, size: %s" * % (self.bitset.allocated, self.bitset.size) */ __pyx_t_4 = NULL; __Pyx_INCREF(__pyx_builtin_MemoryError); __pyx_t_5 = __pyx_builtin_MemoryError; /* "intbitset.pyx":810 * raise MemoryError( * "intbitset corrupted: allocated: %s, size: %s" * % (self.bitset.allocated, self.bitset.size) # <<<<<<<<<<<<<< * ) * if self.last < 0: */ __pyx_t_6 = __Pyx_PyUnicode_From_int(__pyx_v_self->bitset->allocated, 0, ' ', 'd'); if (unlikely(!__pyx_t_6)) __PYX_ERR(0, 810, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_6); __pyx_t_7 = __Pyx_PyUnicode_From_int(__pyx_v_self->bitset->size, 0, ' ', 'd'); if (unlikely(!__pyx_t_7)) __PYX_ERR(0, 810, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_7); __pyx_t_8[0] = __pyx_mstate_global->__pyx_kp_u_intbitset_corrupted_allocated; __pyx_t_8[1] = __pyx_t_6; __pyx_t_8[2] = __pyx_mstate_global->__pyx_kp_u_size; __pyx_t_8[3] = __pyx_t_7; /* "intbitset.pyx":809 * if self.sanity_checks and (self.bitset.allocated < self.bitset.size): * raise MemoryError( * "intbitset corrupted: allocated: %s, size: %s" # <<<<<<<<<<<<<< * % (self.bitset.allocated, self.bitset.size) * ) */ __pyx_t_9 = __Pyx_PyUnicode_Join(__pyx_t_8, 4, 32 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_6) + 8 + __Pyx_PyUnicode_GET_LENGTH(__pyx_t_7), 127); if (unlikely(!__pyx_t_9)) __PYX_ERR(0, 809, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_9); __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0; __Pyx_DECREF(__pyx_t_7); __pyx_t_7 = 0; __pyx_t_10 = 1; { PyObject *__pyx_callargs[2] = {__pyx_t_4, __pyx_t_9}; __pyx_t_3 = __Pyx_PyObject_FastCall(__pyx_t_5, __pyx_callargs+__pyx_t_10, (2-__pyx_t_10) | (__pyx_t_10*__Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET)); __Pyx_XDECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 808, __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, 808, __pyx_L1_error) /* "intbitset.pyx":807 * raise StopIteration() * self.last = intBitSetGetNext(self.bitset, self.last) * if self.sanity_checks and (self.bitset.allocated < self.bitset.size): # <<<<<<<<<<<<<< * raise MemoryError( * "intbitset corrupted: allocated: %s, size: %s" */ } /* "intbitset.pyx":812 * % (self.bitset.allocated, self.bitset.size) * ) * if self.last < 0: # <<<<<<<<<<<<<< * self.last = -2 * raise StopIteration() */ __pyx_t_1 = (__pyx_v_self->last < 0); if (unlikely(__pyx_t_1)) { /* "intbitset.pyx":813 * ) * if self.last < 0: * self.last = -2 # <<<<<<<<<<<<<< * raise StopIteration() * return self.last */ __pyx_v_self->last = -2; /* "intbitset.pyx":814 * if self.last < 0: * self.last = -2 * raise StopIteration() # <<<<<<<<<<<<<< * return self.last * */ __pyx_error_without_exception = 1; goto __pyx_L1_error;; /* "intbitset.pyx":812 * % (self.bitset.allocated, self.bitset.size) * ) * if self.last < 0: # <<<<<<<<<<<<<< * self.last = -2 * raise StopIteration() */ } /* "intbitset.pyx":815 * self.last = -2 * raise StopIteration() * return self.last # <<<<<<<<<<<<<< * * def __iter__(intbitset_iterator self): */ __Pyx_XDECREF(__pyx_r); __pyx_t_3 = __Pyx_PyLong_From_int(__pyx_v_self->last); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 815, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_r = __pyx_t_3; __pyx_t_3 = 0; goto __pyx_L0; /* "intbitset.pyx":803 * intBitSetDestroy(self.bitset) * * def __next__(intbitset_iterator self): # <<<<<<<<<<<<<< * if self.last == -2: * raise StopIteration() */ /* function exit code */ __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_XDECREF(__pyx_t_6); __Pyx_XDECREF(__pyx_t_7); __Pyx_XDECREF(__pyx_t_9); if (!__pyx_error_without_exception) { __Pyx_AddTraceback("intbitset.intbitset_iterator.__next__", __pyx_clineno, __pyx_lineno, __pyx_filename); } __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "intbitset.pyx":817 * return self.last * * def __iter__(intbitset_iterator self): # <<<<<<<<<<<<<< * return self * */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_7__iter__(PyObject *__pyx_v_self); /*proto*/ static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_7__iter__(PyObject *__pyx_v_self) { CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iter__ (wrapper)", 0); __pyx_kwvalues = __Pyx_KwValues_VARARGS(__pyx_args, __pyx_nargs); __pyx_r = __pyx_pf_9intbitset_18intbitset_iterator_6__iter__(((struct __pyx_obj_9intbitset_intbitset_iterator *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_6__iter__(struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__iter__", 0); /* "intbitset.pyx":818 * * def __iter__(intbitset_iterator self): * return self # <<<<<<<<<<<<<< * * cdef object __weakref__ */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF((PyObject *)__pyx_v_self); __pyx_r = ((PyObject *)__pyx_v_self); goto __pyx_L0; /* "intbitset.pyx":817 * return self.last * * def __iter__(intbitset_iterator self): # <<<<<<<<<<<<<< * return self * */ /* function exit code */ __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "(tree fragment)":1 * def __reduce_cython__(self): # <<<<<<<<<<<<<< * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_9__reduce_cython__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_18intbitset_iterator_9__reduce_cython__ = {"__reduce_cython__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_18intbitset_iterator_9__reduce_cython__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_9__reduce_cython__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__reduce_cython__ (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); if (unlikely(__pyx_nargs > 0)) { __Pyx_RaiseArgtupleInvalid("__reduce_cython__", 1, 0, 0, __pyx_nargs); return NULL; } const Py_ssize_t __pyx_kwds_len = unlikely(__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len < 0)) return NULL; if (unlikely(__pyx_kwds_len > 0)) {__Pyx_RejectKeywords("__reduce_cython__", __pyx_kwds); return NULL;} __pyx_r = __pyx_pf_9intbitset_18intbitset_iterator_8__reduce_cython__(((struct __pyx_obj_9intbitset_intbitset_iterator *)__pyx_v_self)); /* function exit code */ __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_8__reduce_cython__(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__reduce_cython__", 0); /* "(tree fragment)":2 * def __reduce_cython__(self): * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" # <<<<<<<<<<<<<< * def __setstate_cython__(self, __pyx_state): * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" */ __Pyx_Raise(__pyx_builtin_TypeError, __pyx_mstate_global->__pyx_kp_u_no_default___reduce___due_to_non, 0, 0); __PYX_ERR(1, 2, __pyx_L1_error) /* "(tree fragment)":1 * def __reduce_cython__(self): # <<<<<<<<<<<<<< * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("intbitset.intbitset_iterator.__reduce_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "(tree fragment)":3 * def __reduce_cython__(self): * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" */ /* Python wrapper */ static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_11__setstate_cython__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ); /*proto*/ static PyMethodDef __pyx_mdef_9intbitset_18intbitset_iterator_11__setstate_cython__ = {"__setstate_cython__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_18intbitset_iterator_11__setstate_cython__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}; static PyObject *__pyx_pw_9intbitset_18intbitset_iterator_11__setstate_cython__(PyObject *__pyx_v_self, #if CYTHON_METH_FASTCALL PyObject *const *__pyx_args, Py_ssize_t __pyx_nargs, PyObject *__pyx_kwds #else PyObject *__pyx_args, PyObject *__pyx_kwds #endif ) { CYTHON_UNUSED PyObject *__pyx_v___pyx_state = 0; #if !CYTHON_METH_FASTCALL CYTHON_UNUSED Py_ssize_t __pyx_nargs; #endif CYTHON_UNUSED PyObject *const *__pyx_kwvalues; PyObject* values[1] = {0}; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__setstate_cython__ (wrapper)", 0); #if !CYTHON_METH_FASTCALL #if CYTHON_ASSUME_SAFE_SIZE __pyx_nargs = PyTuple_GET_SIZE(__pyx_args); #else __pyx_nargs = PyTuple_Size(__pyx_args); if (unlikely(__pyx_nargs < 0)) return NULL; #endif #endif __pyx_kwvalues = __Pyx_KwValues_FASTCALL(__pyx_args, __pyx_nargs); { PyObject ** const __pyx_pyargnames[] = {&__pyx_mstate_global->__pyx_n_u_pyx_state,0}; const Py_ssize_t __pyx_kwds_len = (__pyx_kwds) ? __Pyx_NumKwargs_FASTCALL(__pyx_kwds) : 0; if (unlikely(__pyx_kwds_len) < 0) __PYX_ERR(1, 3, __pyx_L3_error) if (__pyx_kwds_len > 0) { switch (__pyx_nargs) { case 1: values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(1, 3, __pyx_L3_error) CYTHON_FALLTHROUGH; case 0: break; default: goto __pyx_L5_argtuple_error; } const Py_ssize_t kwd_pos_args = __pyx_nargs; if (__Pyx_ParseKeywords(__pyx_kwds, __pyx_kwvalues, __pyx_pyargnames, 0, values, kwd_pos_args, __pyx_kwds_len, "__setstate_cython__", 0) < (0)) __PYX_ERR(1, 3, __pyx_L3_error) for (Py_ssize_t i = __pyx_nargs; i < 1; i++) { if (unlikely(!values[i])) { __Pyx_RaiseArgtupleInvalid("__setstate_cython__", 1, 1, 1, i); __PYX_ERR(1, 3, __pyx_L3_error) } } } else if (unlikely(__pyx_nargs != 1)) { goto __pyx_L5_argtuple_error; } else { values[0] = __Pyx_ArgRef_FASTCALL(__pyx_args, 0); if (!CYTHON_ASSUME_SAFE_MACROS && unlikely(!values[0])) __PYX_ERR(1, 3, __pyx_L3_error) } __pyx_v___pyx_state = values[0]; } goto __pyx_L6_skip; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("__setstate_cython__", 1, 1, 1, __pyx_nargs); __PYX_ERR(1, 3, __pyx_L3_error) __pyx_L6_skip:; goto __pyx_L4_argument_unpacking_done; __pyx_L3_error:; for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_AddTraceback("intbitset.intbitset_iterator.__setstate_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_9intbitset_18intbitset_iterator_10__setstate_cython__(((struct __pyx_obj_9intbitset_intbitset_iterator *)__pyx_v_self), __pyx_v___pyx_state); /* function exit code */ for (Py_ssize_t __pyx_temp=0; __pyx_temp < (Py_ssize_t)(sizeof(values)/sizeof(values[0])); ++__pyx_temp) { Py_XDECREF(values[__pyx_temp]); } __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_pf_9intbitset_18intbitset_iterator_10__setstate_cython__(CYTHON_UNUSED struct __pyx_obj_9intbitset_intbitset_iterator *__pyx_v_self, CYTHON_UNUSED PyObject *__pyx_v___pyx_state) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__setstate_cython__", 0); /* "(tree fragment)":4 * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" # <<<<<<<<<<<<<< */ __Pyx_Raise(__pyx_builtin_TypeError, __pyx_mstate_global->__pyx_kp_u_no_default___reduce___due_to_non, 0, 0); __PYX_ERR(1, 4, __pyx_L1_error) /* "(tree fragment)":3 * def __reduce_cython__(self): * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" */ /* function exit code */ __pyx_L1_error:; __Pyx_AddTraceback("intbitset.intbitset_iterator.__setstate_cython__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* #### Code section: module_exttypes ### */ static struct __pyx_vtabstruct_9intbitset_intbitset __pyx_vtable_9intbitset_intbitset; static PyObject *__pyx_tp_new_9intbitset_intbitset(PyTypeObject *t, PyObject *a, PyObject *k) { struct __pyx_obj_9intbitset_intbitset *p; PyObject *o; #if CYTHON_COMPILING_IN_LIMITED_API allocfunc alloc_func = (allocfunc)PyType_GetSlot(t, Py_tp_alloc); o = alloc_func(t, 0); #else if (likely(!__Pyx_PyType_HasFeature(t, Py_TPFLAGS_IS_ABSTRACT))) { o = (*t->tp_alloc)(t, 0); } else { o = (PyObject *) PyBaseObject_Type.tp_new(t, __pyx_mstate_global->__pyx_empty_tuple, 0); } if (unlikely(!o)) return 0; #endif p = ((struct __pyx_obj_9intbitset_intbitset *)o); p->__pyx_vtab = __pyx_vtabptr_9intbitset_intbitset; if (unlikely(__pyx_pw_9intbitset_9intbitset_1__cinit__(o, a, k) < 0)) goto bad; return o; bad: Py_DECREF(o); o = 0; return NULL; } static void __pyx_tp_dealloc_9intbitset_intbitset(PyObject *o) { struct __pyx_obj_9intbitset_intbitset *p = (struct __pyx_obj_9intbitset_intbitset *)o; #if CYTHON_USE_TP_FINALIZE if (unlikely((PY_VERSION_HEX >= 0x03080000 || __Pyx_PyType_HasFeature(Py_TYPE(o), Py_TPFLAGS_HAVE_FINALIZE)) && __Pyx_PyObject_GetSlot(o, tp_finalize, destructor)) && (!PyType_IS_GC(Py_TYPE(o)) || !__Pyx_PyObject_GC_IsFinalized(o))) { if (__Pyx_PyObject_GetSlot(o, tp_dealloc, destructor) == __pyx_tp_dealloc_9intbitset_intbitset) { if (PyObject_CallFinalizerFromDealloc(o)) return; } } #endif if (p->__weakref__) PyObject_ClearWeakRefs(o); { PyObject *etype, *eval, *etb; PyErr_Fetch(&etype, &eval, &etb); __Pyx_SET_REFCNT(o, Py_REFCNT(o) + 1); __pyx_pw_9intbitset_9intbitset_3__dealloc__(o); __Pyx_SET_REFCNT(o, Py_REFCNT(o) - 1); PyErr_Restore(etype, eval, etb); } #if CYTHON_USE_TYPE_SLOTS (*Py_TYPE(o)->tp_free)(o); #else { freefunc tp_free = (freefunc)PyType_GetSlot(Py_TYPE(o), Py_tp_free); if (tp_free) tp_free(o); } #endif } static PyObject *__pyx_sq_item_9intbitset_intbitset(PyObject *o, Py_ssize_t i) { PyObject *r; PyObject *x = PyLong_FromSsize_t(i); if(!x) return 0; #if CYTHON_USE_TYPE_SLOTS || (!CYTHON_USE_TYPE_SPECS && __PYX_LIMITED_VERSION_HEX < 0x030A0000) r = Py_TYPE(o)->tp_as_mapping->mp_subscript(o, x); #else r = ((binaryfunc)PyType_GetSlot(Py_TYPE(o), Py_mp_subscript))(o, x); #endif Py_DECREF(x); return r; } static int __pyx_mp_ass_subscript_9intbitset_intbitset(PyObject *o, PyObject *i, PyObject *v) { if (v) { __Pyx_TypeName o_type_name; o_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(o)); PyErr_Format(PyExc_NotImplementedError, "Subscript assignment not supported by " __Pyx_FMT_TYPENAME, o_type_name); __Pyx_DECREF_TypeName(o_type_name); return -1; } else { return __pyx_pw_9intbitset_9intbitset_19__delitem__(o, i); } } static CYTHON_INLINE PyObject *__pyx_nb_subtract_9intbitset_intbitset_maybe_call_slot(PyTypeObject* type, PyObject *left, PyObject *right ) { binaryfunc slot; #if CYTHON_USE_TYPE_SLOTS slot = type->tp_as_number ? type->tp_as_number->nb_subtract : NULL; #else slot = (binaryfunc) PyType_GetSlot(type, Py_nb_subtract); #endif return slot ? slot(left, right ) : __Pyx_NewRef(Py_NotImplemented); } static PyObject *__pyx_nb_subtract_9intbitset_intbitset(PyObject *left, PyObject *right ) { int maybe_self_is_left, maybe_self_is_right = 0; maybe_self_is_left = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(left)->tp_as_number && Py_TYPE(left)->tp_as_number->nb_subtract == &__pyx_nb_subtract_9intbitset_intbitset) #endif || __Pyx_TypeCheck(left, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_left) { PyObject *res; res = __pyx_pw_9intbitset_9intbitset_25__sub__(left, right); if (res != Py_NotImplemented) return res; Py_DECREF(res); } maybe_self_is_right = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(right)->tp_as_number && Py_TYPE(right)->tp_as_number->nb_subtract == &__pyx_nb_subtract_9intbitset_intbitset) #endif || PyType_IsSubtype(Py_TYPE(right), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_right) { return __pyx_nb_subtract_9intbitset_intbitset_maybe_call_slot(__Pyx_PyType_GetSlot(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, tp_base, PyTypeObject*), left, right ); } return __Pyx_NewRef(Py_NotImplemented); } static CYTHON_INLINE PyObject *__pyx_nb_and_9intbitset_intbitset_maybe_call_slot(PyTypeObject* type, PyObject *left, PyObject *right ) { binaryfunc slot; #if CYTHON_USE_TYPE_SLOTS slot = type->tp_as_number ? type->tp_as_number->nb_and : NULL; #else slot = (binaryfunc) PyType_GetSlot(type, Py_nb_and); #endif return slot ? slot(left, right ) : __Pyx_NewRef(Py_NotImplemented); } static PyObject *__pyx_nb_and_9intbitset_intbitset(PyObject *left, PyObject *right ) { int maybe_self_is_left, maybe_self_is_right = 0; maybe_self_is_left = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(left)->tp_as_number && Py_TYPE(left)->tp_as_number->nb_and == &__pyx_nb_and_9intbitset_intbitset) #endif || __Pyx_TypeCheck(left, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_left) { PyObject *res; res = __pyx_pw_9intbitset_9intbitset_27__and__(left, right); if (res != Py_NotImplemented) return res; Py_DECREF(res); } maybe_self_is_right = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(right)->tp_as_number && Py_TYPE(right)->tp_as_number->nb_and == &__pyx_nb_and_9intbitset_intbitset) #endif || PyType_IsSubtype(Py_TYPE(right), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_right) { return __pyx_nb_and_9intbitset_intbitset_maybe_call_slot(__Pyx_PyType_GetSlot(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, tp_base, PyTypeObject*), left, right ); } return __Pyx_NewRef(Py_NotImplemented); } static CYTHON_INLINE PyObject *__pyx_nb_xor_9intbitset_intbitset_maybe_call_slot(PyTypeObject* type, PyObject *left, PyObject *right ) { binaryfunc slot; #if CYTHON_USE_TYPE_SLOTS slot = type->tp_as_number ? type->tp_as_number->nb_xor : NULL; #else slot = (binaryfunc) PyType_GetSlot(type, Py_nb_xor); #endif return slot ? slot(left, right ) : __Pyx_NewRef(Py_NotImplemented); } static PyObject *__pyx_nb_xor_9intbitset_intbitset(PyObject *left, PyObject *right ) { int maybe_self_is_left, maybe_self_is_right = 0; maybe_self_is_left = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(left)->tp_as_number && Py_TYPE(left)->tp_as_number->nb_xor == &__pyx_nb_xor_9intbitset_intbitset) #endif || __Pyx_TypeCheck(left, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_left) { PyObject *res; res = __pyx_pw_9intbitset_9intbitset_35__xor__(left, right); if (res != Py_NotImplemented) return res; Py_DECREF(res); } maybe_self_is_right = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(right)->tp_as_number && Py_TYPE(right)->tp_as_number->nb_xor == &__pyx_nb_xor_9intbitset_intbitset) #endif || PyType_IsSubtype(Py_TYPE(right), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_right) { return __pyx_nb_xor_9intbitset_intbitset_maybe_call_slot(__Pyx_PyType_GetSlot(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, tp_base, PyTypeObject*), left, right ); } return __Pyx_NewRef(Py_NotImplemented); } static CYTHON_INLINE PyObject *__pyx_nb_or_9intbitset_intbitset_maybe_call_slot(PyTypeObject* type, PyObject *left, PyObject *right ) { binaryfunc slot; #if CYTHON_USE_TYPE_SLOTS slot = type->tp_as_number ? type->tp_as_number->nb_or : NULL; #else slot = (binaryfunc) PyType_GetSlot(type, Py_nb_or); #endif return slot ? slot(left, right ) : __Pyx_NewRef(Py_NotImplemented); } static PyObject *__pyx_nb_or_9intbitset_intbitset(PyObject *left, PyObject *right ) { int maybe_self_is_left, maybe_self_is_right = 0; maybe_self_is_left = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(left)->tp_as_number && Py_TYPE(left)->tp_as_number->nb_or == &__pyx_nb_or_9intbitset_intbitset) #endif || __Pyx_TypeCheck(left, __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_left) { PyObject *res; res = __pyx_pw_9intbitset_9intbitset_31__or__(left, right); if (res != Py_NotImplemented) return res; Py_DECREF(res); } maybe_self_is_right = Py_TYPE(left) == Py_TYPE(right) #if CYTHON_USE_TYPE_SLOTS || (Py_TYPE(right)->tp_as_number && Py_TYPE(right)->tp_as_number->nb_or == &__pyx_nb_or_9intbitset_intbitset) #endif || PyType_IsSubtype(Py_TYPE(right), __pyx_mstate_global->__pyx_ptype_9intbitset_intbitset); if (maybe_self_is_right) { return __pyx_nb_or_9intbitset_intbitset_maybe_call_slot(__Pyx_PyType_GetSlot(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, tp_base, PyTypeObject*), left, right ); } return __Pyx_NewRef(Py_NotImplemented); } static PyMethodDef __pyx_methods_9intbitset_intbitset[] = { {"__cmp__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_7__cmp__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}, {"__deepcopy__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_17__deepcopy__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}, {"__sub__", (PyCFunction)__pyx_pw_9intbitset_9intbitset_25__sub__, METH_O|METH_COEXIST, __pyx_doc_9intbitset_9intbitset_24__sub__}, {"__and__", (PyCFunction)__pyx_pw_9intbitset_9intbitset_27__and__, METH_O|METH_COEXIST, __pyx_doc_9intbitset_9intbitset_26__and__}, {"__or__", (PyCFunction)__pyx_pw_9intbitset_9intbitset_31__or__, METH_O|METH_COEXIST, __pyx_doc_9intbitset_9intbitset_30__or__}, {"__xor__", (PyCFunction)__pyx_pw_9intbitset_9intbitset_35__xor__, METH_O|METH_COEXIST, __pyx_doc_9intbitset_9intbitset_34__xor__}, {"__reduce__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_45__reduce__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}, {"update", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_71update, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_70update}, {"intersection_update", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_73intersection_update, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_72intersection_update}, {"difference_update", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_75difference_update, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_74difference_update}, {"union", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_77union, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_76union}, {"intersection", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_79intersection, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_78intersection}, {"difference", (PyCFunction)(void(*)(void))(PyCFunctionWithKeywords)__pyx_pw_9intbitset_9intbitset_81difference, METH_VARARGS|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_80difference}, {"isdisjoint", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_9intbitset_83isdisjoint, __Pyx_METH_FASTCALL|METH_KEYWORDS, __pyx_doc_9intbitset_9intbitset_82isdisjoint}, {0, 0, 0, 0} }; #if CYTHON_USE_TYPE_SPECS static PyMemberDef __pyx_type_9intbitset_intbitset_members[] = { #if !CYTHON_USE_TYPE_SLOTS {"__weaklistoffset__", T_PYSSIZET, offsetof(struct __pyx_obj_9intbitset_intbitset, __weakref__), READONLY, 0}, #endif {0, 0, 0, 0, 0} }; #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 #if defined(__GNUC__) || defined(__clang__) #warning "intbitset/intbitset.pyx:784:16: : __weakref__ is unsupported in the Limited API when running on Python <3.9." #elif defined(_MSC_VER) #pragma message("intbitset/intbitset.pyx:784:16: : __weakref__ is unsupported in the Limited API when running on Python <3.9.") #endif #endif static PyType_Slot __pyx_type_9intbitset_intbitset_slots[] = { {Py_tp_dealloc, (void *)__pyx_tp_dealloc_9intbitset_intbitset}, {Py_tp_repr, (void *)__pyx_pw_9intbitset_9intbitset_39__repr__}, {Py_nb_subtract, (void *)__pyx_nb_subtract_9intbitset_intbitset}, {Py_nb_bool, (void *)__pyx_pw_9intbitset_9intbitset_15__nonzero__}, {Py_nb_and, (void *)__pyx_nb_and_9intbitset_intbitset}, {Py_nb_xor, (void *)__pyx_nb_xor_9intbitset_intbitset}, {Py_nb_or, (void *)__pyx_nb_or_9intbitset_intbitset}, {Py_nb_inplace_add, (void *)__pyx_pw_9intbitset_9intbitset_21__iadd__}, {Py_nb_inplace_subtract, (void *)__pyx_pw_9intbitset_9intbitset_23__isub__}, {Py_nb_inplace_and, (void *)__pyx_pw_9intbitset_9intbitset_29__iand__}, {Py_nb_inplace_xor, (void *)__pyx_pw_9intbitset_9intbitset_37__ixor__}, {Py_nb_inplace_or, (void *)__pyx_pw_9intbitset_9intbitset_33__ior__}, {Py_sq_length, (void *)__pyx_pw_9intbitset_9intbitset_11__len__}, {Py_sq_item, (void *)__pyx_sq_item_9intbitset_intbitset}, {Py_sq_contains, (void *)__pyx_pw_9intbitset_9intbitset_5__contains__}, {Py_mp_length, (void *)__pyx_pw_9intbitset_9intbitset_11__len__}, {Py_mp_subscript, (void *)__pyx_pw_9intbitset_9intbitset_43__getitem__}, {Py_mp_ass_subscript, (void *)__pyx_mp_ass_subscript_9intbitset_intbitset}, {Py_tp_hash, (void *)__pyx_pw_9intbitset_9intbitset_13__hash__}, {Py_tp_str, (void *)__pyx_pw_9intbitset_9intbitset_41__str__}, {Py_tp_doc, (void *)PyDoc_STR("\n Defines an intbitset data object to hold unordered sets of\n unsigned integers with ultra fast set operations, implemented via\n bit vectors and Python C extension to optimize speed and memory\n usage.\n\n Emulates the Python built-in set class interface with some\n additional specific methods such as its own fast dump and load\n marshalling functions. Uses real bits to optimize memory usage,\n so may have issues with endianness if you transport serialized\n bitsets between various machine architectures.\n\n The constructor accept the following parameters:\n rhs=0, \n int preallocate=-1, \n int trailing_bits=0,\n bint sanity_checks=CFG_INTBITSET_ENABLE_SANITY_CHECKS,\n int no_allocate=0:\n\n where rhs can be:\n\n * ``int/long`` for creating allocating empty intbitset that will hold at\n least rhs elements, before being resized\n\n * ``intbitset`` for cloning\n\n * ``bytes`` for retrieving an intbitset that was dumped into a byte string\n\n * ``array`` for retrieving an intbitset that was dumped into a string stored\n in an array\n\n * sequence made of integers for copying all the elements from the sequence. \n If minsize is specified than it is initially allocated enough space to\n hold up to minsize integers, otherwise the biggest element of the sequence\n will be used.\n\n * sequence made of tuples: then the first element of each tuple is\n considered as an integer (as in the sequence made of integers).\n\n The other arguments are:\n\n * ``preallocate`` is a suggested initial upper bound on the numbers that\n will be stored, by looking at rhs a sequence of number.\n\n * ``trailing_bits`` is 1, then the set will contain \"all\" the positive integers\n\n * ``no_allocate`` and ``sanity_checks`` are used internally and should never be set.\n ")}, {Py_tp_richcompare, (void *)__pyx_pw_9intbitset_9intbitset_9__richcmp__}, {Py_tp_iter, (void *)__pyx_pw_9intbitset_9intbitset_47__iter__}, {Py_tp_methods, (void *)__pyx_methods_9intbitset_intbitset}, {Py_tp_new, (void *)__pyx_tp_new_9intbitset_intbitset}, {Py_tp_members, (void*)__pyx_type_9intbitset_intbitset_members}, {0, 0}, }; static PyType_Spec __pyx_type_9intbitset_intbitset_spec = { "intbitset.intbitset", sizeof(struct __pyx_obj_9intbitset_intbitset), 0, Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE, __pyx_type_9intbitset_intbitset_slots, }; #else static PyNumberMethods __pyx_tp_as_number_intbitset = { 0, /*nb_add*/ __pyx_nb_subtract_9intbitset_intbitset, /*nb_subtract*/ 0, /*nb_multiply*/ 0, /*nb_remainder*/ 0, /*nb_divmod*/ 0, /*nb_power*/ 0, /*nb_negative*/ 0, /*nb_positive*/ 0, /*nb_absolute*/ __pyx_pw_9intbitset_9intbitset_15__nonzero__, /*nb_bool*/ 0, /*nb_invert*/ 0, /*nb_lshift*/ 0, /*nb_rshift*/ __pyx_nb_and_9intbitset_intbitset, /*nb_and*/ __pyx_nb_xor_9intbitset_intbitset, /*nb_xor*/ __pyx_nb_or_9intbitset_intbitset, /*nb_or*/ 0, /*nb_int*/ 0, /*nb_long (reserved)*/ 0, /*nb_float*/ __pyx_pw_9intbitset_9intbitset_21__iadd__, /*nb_inplace_add*/ __pyx_pw_9intbitset_9intbitset_23__isub__, /*nb_inplace_subtract*/ 0, /*nb_inplace_multiply*/ 0, /*nb_inplace_remainder*/ 0, /*nb_inplace_power*/ 0, /*nb_inplace_lshift*/ 0, /*nb_inplace_rshift*/ __pyx_pw_9intbitset_9intbitset_29__iand__, /*nb_inplace_and*/ __pyx_pw_9intbitset_9intbitset_37__ixor__, /*nb_inplace_xor*/ __pyx_pw_9intbitset_9intbitset_33__ior__, /*nb_inplace_or*/ 0, /*nb_floor_divide*/ 0, /*nb_true_divide*/ 0, /*nb_inplace_floor_divide*/ 0, /*nb_inplace_true_divide*/ 0, /*nb_index*/ 0, /*nb_matrix_multiply*/ 0, /*nb_inplace_matrix_multiply*/ }; static PySequenceMethods __pyx_tp_as_sequence_intbitset = { __pyx_pw_9intbitset_9intbitset_11__len__, /*sq_length*/ 0, /*sq_concat*/ 0, /*sq_repeat*/ __pyx_sq_item_9intbitset_intbitset, /*sq_item*/ 0, /*sq_slice*/ 0, /*sq_ass_item*/ 0, /*sq_ass_slice*/ __pyx_pw_9intbitset_9intbitset_5__contains__, /*sq_contains*/ 0, /*sq_inplace_concat*/ 0, /*sq_inplace_repeat*/ }; static PyMappingMethods __pyx_tp_as_mapping_intbitset = { __pyx_pw_9intbitset_9intbitset_11__len__, /*mp_length*/ __pyx_pw_9intbitset_9intbitset_43__getitem__, /*mp_subscript*/ __pyx_mp_ass_subscript_9intbitset_intbitset, /*mp_ass_subscript*/ }; static PyTypeObject __pyx_type_9intbitset_intbitset = { PyVarObject_HEAD_INIT(0, 0) "intbitset.""intbitset", /*tp_name*/ sizeof(struct __pyx_obj_9intbitset_intbitset), /*tp_basicsize*/ 0, /*tp_itemsize*/ __pyx_tp_dealloc_9intbitset_intbitset, /*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*/ 0, /*tp_as_async*/ __pyx_pw_9intbitset_9intbitset_39__repr__, /*tp_repr*/ &__pyx_tp_as_number_intbitset, /*tp_as_number*/ &__pyx_tp_as_sequence_intbitset, /*tp_as_sequence*/ &__pyx_tp_as_mapping_intbitset, /*tp_as_mapping*/ __pyx_pw_9intbitset_9intbitset_13__hash__, /*tp_hash*/ 0, /*tp_call*/ __pyx_pw_9intbitset_9intbitset_41__str__, /*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*/ PyDoc_STR("\n Defines an intbitset data object to hold unordered sets of\n unsigned integers with ultra fast set operations, implemented via\n bit vectors and Python C extension to optimize speed and memory\n usage.\n\n Emulates the Python built-in set class interface with some\n additional specific methods such as its own fast dump and load\n marshalling functions. Uses real bits to optimize memory usage,\n so may have issues with endianness if you transport serialized\n bitsets between various machine architectures.\n\n The constructor accept the following parameters:\n rhs=0, \n int preallocate=-1, \n int trailing_bits=0,\n bint sanity_checks=CFG_INTBITSET_ENABLE_SANITY_CHECKS,\n int no_allocate=0:\n\n where rhs can be:\n\n * ``int/long`` for creating allocating empty intbitset that will hold at\n least rhs elements, before being resized\n\n * ``intbitset`` for cloning\n\n * ``bytes`` for retrieving an intbitset that was dumped into a byte string\n\n * ``array`` for retrieving an intbitset that was dumped into a string stored\n in an array\n\n * sequence made of integers for copying all the elements from the sequence. \n If minsize is specified than it is initially allocated enough space to\n hold up to minsize integers, otherwise the biggest element of the sequence\n will be used.\n\n * sequence made of tuples: then the first element of each tuple is\n considered as an integer (as in the sequence made of integers).\n\n The other arguments are:\n\n * ``preallocate`` is a suggested initial upper bound on the numbers that\n will be stored, by looking at rhs a sequence of number.\n\n * ``trailing_bits`` is 1, then the set will contain \"all\" the positive integers\n\n * ``no_allocate`` and ``sanity_checks`` are used internally and should never be set.\n "), /*tp_doc*/ 0, /*tp_traverse*/ 0, /*tp_clear*/ __pyx_pw_9intbitset_9intbitset_9__richcmp__, /*tp_richcompare*/ 0, /*tp_weaklistoffset*/ __pyx_pw_9intbitset_9intbitset_47__iter__, /*tp_iter*/ 0, /*tp_iternext*/ __pyx_methods_9intbitset_intbitset, /*tp_methods*/ 0, /*tp_members*/ 0, /*tp_getset*/ 0, /*tp_base*/ 0, /*tp_dict*/ 0, /*tp_descr_get*/ 0, /*tp_descr_set*/ #if !CYTHON_USE_TYPE_SPECS 0, /*tp_dictoffset*/ #endif 0, /*tp_init*/ 0, /*tp_alloc*/ __pyx_tp_new_9intbitset_intbitset, /*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 CYTHON_USE_TP_FINALIZE 0, /*tp_finalize*/ #else NULL, /*tp_finalize*/ #endif #if PY_VERSION_HEX >= 0x030800b1 && (!CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800) 0, /*tp_vectorcall*/ #endif #if __PYX_NEED_TP_PRINT_SLOT == 1 0, /*tp_print*/ #endif #if PY_VERSION_HEX >= 0x030C0000 0, /*tp_watched*/ #endif #if PY_VERSION_HEX >= 0x030d00A4 0, /*tp_versions_used*/ #endif #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000 0, /*tp_pypy_flags*/ #endif }; #endif static PyObject *__pyx_tp_new_9intbitset_intbitset_iterator(PyTypeObject *t, PyObject *a, PyObject *k) { PyObject *o; #if CYTHON_COMPILING_IN_LIMITED_API allocfunc alloc_func = (allocfunc)PyType_GetSlot(t, Py_tp_alloc); o = alloc_func(t, 0); #else if (likely(!__Pyx_PyType_HasFeature(t, Py_TPFLAGS_IS_ABSTRACT))) { o = (*t->tp_alloc)(t, 0); } else { o = (PyObject *) PyBaseObject_Type.tp_new(t, __pyx_mstate_global->__pyx_empty_tuple, 0); } if (unlikely(!o)) return 0; #endif if (unlikely(__pyx_pw_9intbitset_18intbitset_iterator_1__cinit__(o, a, k) < 0)) goto bad; return o; bad: Py_DECREF(o); o = 0; return NULL; } static void __pyx_tp_dealloc_9intbitset_intbitset_iterator(PyObject *o) { struct __pyx_obj_9intbitset_intbitset_iterator *p = (struct __pyx_obj_9intbitset_intbitset_iterator *)o; #if CYTHON_USE_TP_FINALIZE if (unlikely((PY_VERSION_HEX >= 0x03080000 || __Pyx_PyType_HasFeature(Py_TYPE(o), Py_TPFLAGS_HAVE_FINALIZE)) && __Pyx_PyObject_GetSlot(o, tp_finalize, destructor)) && (!PyType_IS_GC(Py_TYPE(o)) || !__Pyx_PyObject_GC_IsFinalized(o))) { if (__Pyx_PyObject_GetSlot(o, tp_dealloc, destructor) == __pyx_tp_dealloc_9intbitset_intbitset_iterator) { if (PyObject_CallFinalizerFromDealloc(o)) return; } } #endif if (p->__weakref__) PyObject_ClearWeakRefs(o); { PyObject *etype, *eval, *etb; PyErr_Fetch(&etype, &eval, &etb); __Pyx_SET_REFCNT(o, Py_REFCNT(o) + 1); __pyx_pw_9intbitset_18intbitset_iterator_3__dealloc__(o); __Pyx_SET_REFCNT(o, Py_REFCNT(o) - 1); PyErr_Restore(etype, eval, etb); } #if CYTHON_USE_TYPE_SLOTS (*Py_TYPE(o)->tp_free)(o); #else { freefunc tp_free = (freefunc)PyType_GetSlot(Py_TYPE(o), Py_tp_free); if (tp_free) tp_free(o); } #endif } static PyObject *__pyx_specialmethod___pyx_pw_9intbitset_18intbitset_iterator_5__next__(PyObject *self, CYTHON_UNUSED PyObject *arg) { PyObject *res = __pyx_pw_9intbitset_18intbitset_iterator_5__next__(self); if (!res && !PyErr_Occurred()) { PyErr_SetNone(PyExc_StopIteration); } return res; } static PyMethodDef __pyx_methods_9intbitset_intbitset_iterator[] = { {"__next__", (PyCFunction)__pyx_specialmethod___pyx_pw_9intbitset_18intbitset_iterator_5__next__, METH_NOARGS|METH_COEXIST, 0}, {"__reduce_cython__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_18intbitset_iterator_9__reduce_cython__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}, {"__setstate_cython__", (PyCFunction)(void(*)(void))(__Pyx_PyCFunction_FastCallWithKeywords)__pyx_pw_9intbitset_18intbitset_iterator_11__setstate_cython__, __Pyx_METH_FASTCALL|METH_KEYWORDS, 0}, {0, 0, 0, 0} }; #if CYTHON_USE_TYPE_SPECS static PyMemberDef __pyx_type_9intbitset_intbitset_iterator_members[] = { #if !CYTHON_USE_TYPE_SLOTS {"__weaklistoffset__", T_PYSSIZET, offsetof(struct __pyx_obj_9intbitset_intbitset_iterator, __weakref__), READONLY, 0}, #endif {0, 0, 0, 0, 0} }; #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 #if defined(__GNUC__) || defined(__clang__) #warning "intbitset/intbitset.pyx:820:16: : __weakref__ is unsupported in the Limited API when running on Python <3.9." #elif defined(_MSC_VER) #pragma message("intbitset/intbitset.pyx:820:16: : __weakref__ is unsupported in the Limited API when running on Python <3.9.") #endif #endif static PyType_Slot __pyx_type_9intbitset_intbitset_iterator_slots[] = { {Py_tp_dealloc, (void *)__pyx_tp_dealloc_9intbitset_intbitset_iterator}, {Py_tp_iter, (void *)__pyx_pw_9intbitset_18intbitset_iterator_7__iter__}, {Py_tp_iternext, (void *)__pyx_pw_9intbitset_18intbitset_iterator_5__next__}, {Py_tp_methods, (void *)__pyx_methods_9intbitset_intbitset_iterator}, {Py_tp_new, (void *)__pyx_tp_new_9intbitset_intbitset_iterator}, {Py_tp_members, (void*)__pyx_type_9intbitset_intbitset_iterator_members}, {0, 0}, }; static PyType_Spec __pyx_type_9intbitset_intbitset_iterator_spec = { "intbitset.intbitset_iterator", sizeof(struct __pyx_obj_9intbitset_intbitset_iterator), 0, Py_TPFLAGS_DEFAULT|Py_TPFLAGS_HAVE_VERSION_TAG|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE, __pyx_type_9intbitset_intbitset_iterator_slots, }; #else static PyTypeObject __pyx_type_9intbitset_intbitset_iterator = { PyVarObject_HEAD_INIT(0, 0) "intbitset.""intbitset_iterator", /*tp_name*/ sizeof(struct __pyx_obj_9intbitset_intbitset_iterator), /*tp_basicsize*/ 0, /*tp_itemsize*/ __pyx_tp_dealloc_9intbitset_intbitset_iterator, /*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*/ 0, /*tp_as_async*/ 0, /*tp_repr*/ 0, /*tp_as_number*/ 0, /*tp_as_sequence*/ 0, /*tp_as_mapping*/ 0, /*tp_hash*/ 0, /*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*/ __pyx_pw_9intbitset_18intbitset_iterator_7__iter__, /*tp_iter*/ __pyx_pw_9intbitset_18intbitset_iterator_5__next__, /*tp_iternext*/ __pyx_methods_9intbitset_intbitset_iterator, /*tp_methods*/ 0, /*tp_members*/ 0, /*tp_getset*/ 0, /*tp_base*/ 0, /*tp_dict*/ 0, /*tp_descr_get*/ 0, /*tp_descr_set*/ #if !CYTHON_USE_TYPE_SPECS 0, /*tp_dictoffset*/ #endif 0, /*tp_init*/ 0, /*tp_alloc*/ __pyx_tp_new_9intbitset_intbitset_iterator, /*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 CYTHON_USE_TP_FINALIZE 0, /*tp_finalize*/ #else NULL, /*tp_finalize*/ #endif #if PY_VERSION_HEX >= 0x030800b1 && (!CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM >= 0x07030800) 0, /*tp_vectorcall*/ #endif #if __PYX_NEED_TP_PRINT_SLOT == 1 0, /*tp_print*/ #endif #if PY_VERSION_HEX >= 0x030C0000 0, /*tp_watched*/ #endif #if PY_VERSION_HEX >= 0x030d00A4 0, /*tp_versions_used*/ #endif #if CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX >= 0x03090000 && PY_VERSION_HEX < 0x030a0000 0, /*tp_pypy_flags*/ #endif }; #endif static PyMethodDef __pyx_methods[] = { {0, 0, 0, 0} }; /* #### Code section: initfunc_declarations ### */ static CYTHON_SMALL_CODE int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_InitGlobals(void); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_variable_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate); /*proto*/ static CYTHON_SMALL_CODE int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate); /*proto*/ /* #### Code section: init_module ### */ static int __Pyx_modinit_global_init_code(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); __Pyx_RefNannySetupContext("__Pyx_modinit_global_init_code", 0); /*--- Global init code ---*/ __Pyx_RefNannyFinishContext(); return 0; } static int __Pyx_modinit_variable_export_code(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); __Pyx_RefNannySetupContext("__Pyx_modinit_variable_export_code", 0); /*--- Variable export code ---*/ __Pyx_RefNannyFinishContext(); return 0; } static int __Pyx_modinit_function_export_code(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); __Pyx_RefNannySetupContext("__Pyx_modinit_function_export_code", 0); /*--- Function export code ---*/ __Pyx_RefNannyFinishContext(); return 0; } static int __Pyx_modinit_type_init_code(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); 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_9intbitset_intbitset = &__pyx_vtable_9intbitset_intbitset; __pyx_vtable_9intbitset_intbitset.add = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_add; __pyx_vtable_9intbitset_intbitset.clear = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_clear; __pyx_vtable_9intbitset_intbitset.discard = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_discard; __pyx_vtable_9intbitset_intbitset.issubset = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_issubset; __pyx_vtable_9intbitset_intbitset.issuperset = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_issuperset; __pyx_vtable_9intbitset_intbitset.fastdump = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_fastdump; __pyx_vtable_9intbitset_intbitset.fastload = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_fastload; __pyx_vtable_9intbitset_intbitset.copy = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_copy; __pyx_vtable_9intbitset_intbitset.pop = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_pop; __pyx_vtable_9intbitset_intbitset.remove = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_remove; __pyx_vtable_9intbitset_intbitset.strbits = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_strbits; __pyx_vtable_9intbitset_intbitset.update_with_signs = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, PyObject *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_update_with_signs; __pyx_vtable_9intbitset_intbitset.get_size = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_get_size; __pyx_vtable_9intbitset_intbitset.get_allocated = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_get_allocated; __pyx_vtable_9intbitset_intbitset.is_infinite = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_is_infinite; __pyx_vtable_9intbitset_intbitset.extract_finite_list = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch, struct __pyx_opt_args_9intbitset_9intbitset_extract_finite_list *__pyx_optional_args))__pyx_f_9intbitset_9intbitset_extract_finite_list; __pyx_vtable_9intbitset_intbitset.get_wordbitsize = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_get_wordbitsize; __pyx_vtable_9intbitset_intbitset.get_wordbytsize = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_get_wordbytsize; __pyx_vtable_9intbitset_intbitset.tolist = (PyObject *(*)(struct __pyx_obj_9intbitset_intbitset *, int __pyx_skip_dispatch))__pyx_f_9intbitset_9intbitset_tolist; #if CYTHON_USE_TYPE_SPECS __pyx_mstate->__pyx_ptype_9intbitset_intbitset = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_9intbitset_intbitset_spec, NULL); if (unlikely(!__pyx_mstate->__pyx_ptype_9intbitset_intbitset)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_9intbitset_intbitset_spec, __pyx_mstate->__pyx_ptype_9intbitset_intbitset) < (0)) __PYX_ERR(0, 108, __pyx_L1_error) #else __pyx_mstate->__pyx_ptype_9intbitset_intbitset = &__pyx_type_9intbitset_intbitset; #endif #if !CYTHON_COMPILING_IN_LIMITED_API #endif #if !CYTHON_USE_TYPE_SPECS if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_9intbitset_intbitset) < (0)) __PYX_ERR(0, 108, __pyx_L1_error) #endif #if !CYTHON_COMPILING_IN_LIMITED_API if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_9intbitset_intbitset->tp_dictoffset && __pyx_mstate->__pyx_ptype_9intbitset_intbitset->tp_getattro == PyObject_GenericGetAttr)) { __pyx_mstate->__pyx_ptype_9intbitset_intbitset->tp_getattro = PyObject_GenericGetAttr; } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__isub__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_22__isub__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_22__isub__.doc = __pyx_doc_9intbitset_9intbitset_22__isub__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_22__isub__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__sub__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_24__sub__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_24__sub__.doc = __pyx_doc_9intbitset_9intbitset_24__sub__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_24__sub__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__and__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_26__and__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_26__and__.doc = __pyx_doc_9intbitset_9intbitset_26__and__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_26__and__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__iand__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_28__iand__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_28__iand__.doc = __pyx_doc_9intbitset_9intbitset_28__iand__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_28__iand__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__or__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_30__or__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_30__or__.doc = __pyx_doc_9intbitset_9intbitset_30__or__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_30__or__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__ior__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_32__ior__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_32__ior__.doc = __pyx_doc_9intbitset_9intbitset_32__ior__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_32__ior__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__xor__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_34__xor__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_34__xor__.doc = __pyx_doc_9intbitset_9intbitset_34__xor__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_34__xor__; } } #endif #if CYTHON_UPDATE_DESCRIPTOR_DOC { PyObject *wrapper = PyObject_GetAttrString((PyObject *)__pyx_mstate->__pyx_ptype_9intbitset_intbitset, "__ixor__"); if (unlikely(!wrapper)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_IS_TYPE(wrapper, &PyWrapperDescr_Type)) { __pyx_wrapperbase_9intbitset_9intbitset_36__ixor__ = *((PyWrapperDescrObject *)wrapper)->d_base; __pyx_wrapperbase_9intbitset_9intbitset_36__ixor__.doc = __pyx_doc_9intbitset_9intbitset_36__ixor__; ((PyWrapperDescrObject *)wrapper)->d_base = &__pyx_wrapperbase_9intbitset_9intbitset_36__ixor__; } } #endif if (__Pyx_SetVtable(__pyx_mstate->__pyx_ptype_9intbitset_intbitset, __pyx_vtabptr_9intbitset_intbitset) < (0)) __PYX_ERR(0, 108, __pyx_L1_error) if (__Pyx_MergeVtables(__pyx_mstate->__pyx_ptype_9intbitset_intbitset) < (0)) __PYX_ERR(0, 108, __pyx_L1_error) if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_intbitset_2, (PyObject *) __pyx_mstate->__pyx_ptype_9intbitset_intbitset) < (0)) __PYX_ERR(0, 108, __pyx_L1_error) #if CYTHON_USE_TYPE_SLOTS if (__pyx_mstate->__pyx_ptype_9intbitset_intbitset->tp_weaklistoffset == 0) __pyx_mstate->__pyx_ptype_9intbitset_intbitset->tp_weaklistoffset = offsetof(struct __pyx_obj_9intbitset_intbitset, __weakref__); #endif #if CYTHON_USE_TYPE_SPECS __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator = (PyTypeObject *) __Pyx_PyType_FromModuleAndSpec(__pyx_m, &__pyx_type_9intbitset_intbitset_iterator_spec, NULL); if (unlikely(!__pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator)) __PYX_ERR(0, 786, __pyx_L1_error) if (__Pyx_fix_up_extension_type_from_spec(&__pyx_type_9intbitset_intbitset_iterator_spec, __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator) < (0)) __PYX_ERR(0, 786, __pyx_L1_error) #else __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator = &__pyx_type_9intbitset_intbitset_iterator; #endif #if !CYTHON_COMPILING_IN_LIMITED_API #endif #if !CYTHON_USE_TYPE_SPECS if (__Pyx_PyType_Ready(__pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator) < (0)) __PYX_ERR(0, 786, __pyx_L1_error) #endif #if !CYTHON_COMPILING_IN_LIMITED_API if ((CYTHON_USE_TYPE_SLOTS && CYTHON_USE_PYTYPE_LOOKUP) && likely(!__pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator->tp_dictoffset && __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator->tp_getattro == PyObject_GenericGetAttr)) { __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator->tp_getattro = PyObject_GenericGetAttr; } #endif if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_intbitset_iterator, (PyObject *) __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator) < (0)) __PYX_ERR(0, 786, __pyx_L1_error) #if CYTHON_USE_TYPE_SLOTS if (__pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator->tp_weaklistoffset == 0) __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator->tp_weaklistoffset = offsetof(struct __pyx_obj_9intbitset_intbitset_iterator, __weakref__); #endif if (__Pyx_setup_reduce((PyObject *) __pyx_mstate->__pyx_ptype_9intbitset_intbitset_iterator) < (0)) __PYX_ERR(0, 786, __pyx_L1_error) __Pyx_RefNannyFinishContext(); return 0; __pyx_L1_error:; __Pyx_RefNannyFinishContext(); return -1; } static int __Pyx_modinit_type_import_code(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); 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_mstate->__pyx_ptype_7cpython_4type_type = __Pyx_ImportType_3_1_6(__pyx_t_1, __Pyx_BUILTIN_MODULE_NAME, "type", #if defined(PYPY_VERSION_NUM) && PYPY_VERSION_NUM < 0x050B0000 sizeof(PyTypeObject), __PYX_GET_STRUCT_ALIGNMENT_3_1_6(PyTypeObject), #elif CYTHON_COMPILING_IN_LIMITED_API 0, 0, #else sizeof(PyHeapTypeObject), __PYX_GET_STRUCT_ALIGNMENT_3_1_6(PyHeapTypeObject), #endif __Pyx_ImportType_CheckSize_Warn_3_1_6); if (!__pyx_mstate->__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(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); __Pyx_RefNannySetupContext("__Pyx_modinit_variable_import_code", 0); /*--- Variable import code ---*/ __Pyx_RefNannyFinishContext(); return 0; } static int __Pyx_modinit_function_import_code(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); __Pyx_RefNannySetupContext("__Pyx_modinit_function_import_code", 0); /*--- Function import code ---*/ __Pyx_RefNannyFinishContext(); return 0; } #if CYTHON_PEP489_MULTI_PHASE_INIT static PyObject* __pyx_pymod_create(PyObject *spec, PyModuleDef *def); /*proto*/ static int __pyx_pymod_exec_intbitset(PyObject* module); /*proto*/ static PyModuleDef_Slot __pyx_moduledef_slots[] = { {Py_mod_create, (void*)__pyx_pymod_create}, {Py_mod_exec, (void*)__pyx_pymod_exec_intbitset}, #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING {Py_mod_gil, Py_MOD_GIL_USED}, #endif #if PY_VERSION_HEX >= 0x030C0000 && CYTHON_USE_MODULE_STATE {Py_mod_multiple_interpreters, Py_MOD_MULTIPLE_INTERPRETERS_NOT_SUPPORTED}, #endif {0, NULL} }; #endif #ifdef __cplusplus namespace { struct PyModuleDef __pyx_moduledef = #else static struct PyModuleDef __pyx_moduledef = #endif { PyModuleDef_HEAD_INIT, "intbitset", __pyx_k_Defines_an_intbitset_data_objec, /* m_doc */ #if CYTHON_USE_MODULE_STATE sizeof(__pyx_mstatetype), /* m_size */ #else (CYTHON_PEP489_MULTI_PHASE_INIT) ? 0 : -1, /* m_size */ #endif __pyx_methods /* m_methods */, #if CYTHON_PEP489_MULTI_PHASE_INIT __pyx_moduledef_slots, /* m_slots */ #else NULL, /* m_reload */ #endif #if CYTHON_USE_MODULE_STATE __pyx_m_traverse, /* m_traverse */ __pyx_m_clear, /* m_clear */ NULL /* m_free */ #else NULL, /* m_traverse */ NULL, /* m_clear */ NULL /* m_free */ #endif }; #ifdef __cplusplus } /* anonymous namespace */ #endif /* PyModInitFuncType */ #ifndef CYTHON_NO_PYINIT_EXPORT #define __Pyx_PyMODINIT_FUNC PyMODINIT_FUNC #else #ifdef __cplusplus #define __Pyx_PyMODINIT_FUNC extern "C" PyObject * #else #define __Pyx_PyMODINIT_FUNC PyObject * #endif #endif __Pyx_PyMODINIT_FUNC PyInit_intbitset(void) CYTHON_SMALL_CODE; /*proto*/ __Pyx_PyMODINIT_FUNC PyInit_intbitset(void) #if CYTHON_PEP489_MULTI_PHASE_INIT { return PyModuleDef_Init(&__pyx_moduledef); } /* ModuleCreationPEP489 */ #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 static PY_INT64_T __Pyx_GetCurrentInterpreterId(void) { { PyObject *module = PyImport_ImportModule("_interpreters"); // 3.13+ I think if (!module) { PyErr_Clear(); // just try the 3.8-3.12 version module = PyImport_ImportModule("_xxsubinterpreters"); if (!module) goto bad; } PyObject *current = PyObject_CallMethod(module, "get_current", NULL); Py_DECREF(module); if (!current) goto bad; if (PyTuple_Check(current)) { PyObject *new_current = PySequence_GetItem(current, 0); Py_DECREF(current); current = new_current; if (!new_current) goto bad; } long long as_c_int = PyLong_AsLongLong(current); Py_DECREF(current); return as_c_int; } bad: PySys_WriteStderr("__Pyx_GetCurrentInterpreterId failed. Try setting the C define CYTHON_PEP489_MULTI_PHASE_INIT=0\n"); return -1; } #endif #if !CYTHON_USE_MODULE_STATE static CYTHON_SMALL_CODE int __Pyx_check_single_interpreter(void) { static PY_INT64_T main_interpreter_id = -1; #if CYTHON_COMPILING_IN_GRAAL PY_INT64_T current_id = PyInterpreterState_GetIDFromThreadState(PyThreadState_Get()); #elif CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX >= 0x03090000 PY_INT64_T current_id = PyInterpreterState_GetID(PyInterpreterState_Get()); #elif CYTHON_COMPILING_IN_LIMITED_API PY_INT64_T current_id = __Pyx_GetCurrentInterpreterId(); #else PY_INT64_T current_id = PyInterpreterState_GetID(PyThreadState_Get()->interp); #endif if (unlikely(current_id == -1)) { return -1; } if (main_interpreter_id == -1) { main_interpreter_id = current_id; return 0; } else if (unlikely(main_interpreter_id != current_id)) { PyErr_SetString( PyExc_ImportError, "Interpreter change detected - this module can only be loaded into one interpreter per process."); return -1; } return 0; } #endif 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, PyModuleDef *def) { PyObject *module = NULL, *moddict, *modname; CYTHON_UNUSED_VAR(def); #if !CYTHON_USE_MODULE_STATE if (__Pyx_check_single_interpreter()) return NULL; #endif 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_intbitset(PyObject *__pyx_pyinit_module) #endif { int stringtab_initialized = 0; #if CYTHON_USE_MODULE_STATE int pystate_addmodule_run = 0; #endif __pyx_mstatetype *__pyx_mstate = NULL; PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_t_4; 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 'intbitset' has already been imported. Re-initialisation is not supported."); return -1; } #else if (__pyx_m) return __Pyx_NewRef(__pyx_m); #endif /*--- Module creation code ---*/ #if CYTHON_PEP489_MULTI_PHASE_INIT __pyx_t_1 = __pyx_pyinit_module; Py_INCREF(__pyx_t_1); #else __pyx_t_1 = PyModule_Create(&__pyx_moduledef); if (unlikely(!__pyx_t_1)) __PYX_ERR(0, 1, __pyx_L1_error) #endif #if CYTHON_USE_MODULE_STATE { int add_module_result = __Pyx_State_AddModule(__pyx_t_1, &__pyx_moduledef); __pyx_t_1 = 0; /* transfer ownership from __pyx_t_1 to "intbitset" pseudovariable */ if (unlikely((add_module_result < 0))) __PYX_ERR(0, 1, __pyx_L1_error) pystate_addmodule_run = 1; } #else __pyx_m = __pyx_t_1; #endif #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING PyUnstable_Module_SetGIL(__pyx_m, Py_MOD_GIL_USED); #endif __pyx_mstate = __pyx_mstate_global; CYTHON_UNUSED_VAR(__pyx_t_1); __pyx_mstate->__pyx_d = PyModule_GetDict(__pyx_m); if (unlikely(!__pyx_mstate->__pyx_d)) __PYX_ERR(0, 1, __pyx_L1_error) Py_INCREF(__pyx_mstate->__pyx_d); __pyx_mstate->__pyx_b = __Pyx_PyImport_AddModuleRef(__Pyx_BUILTIN_MODULE_NAME); if (unlikely(!__pyx_mstate->__pyx_b)) __PYX_ERR(0, 1, __pyx_L1_error) __pyx_mstate->__pyx_cython_runtime = __Pyx_PyImport_AddModuleRef("cython_runtime"); if (unlikely(!__pyx_mstate->__pyx_cython_runtime)) __PYX_ERR(0, 1, __pyx_L1_error) if (PyObject_SetAttrString(__pyx_m, "__builtins__", __pyx_mstate->__pyx_b) < 0) __PYX_ERR(0, 1, __pyx_L1_error) /* ImportRefnannyAPI */ #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("PyInit_intbitset", 0); if (__Pyx_check_binary_version(__PYX_LIMITED_VERSION_HEX, __Pyx_get_runtime_version(), CYTHON_COMPILING_IN_LIMITED_API) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #ifdef __Pxy_PyFrame_Initialize_Offsets __Pxy_PyFrame_Initialize_Offsets(); #endif __pyx_mstate->__pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_mstate->__pyx_empty_tuple)) __PYX_ERR(0, 1, __pyx_L1_error) __pyx_mstate->__pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_bytes)) __PYX_ERR(0, 1, __pyx_L1_error) __pyx_mstate->__pyx_empty_unicode = PyUnicode_FromStringAndSize("", 0); if (unlikely(!__pyx_mstate->__pyx_empty_unicode)) __PYX_ERR(0, 1, __pyx_L1_error) /*--- Initialize various global constants etc. ---*/ if (__Pyx_InitConstants(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) stringtab_initialized = 1; if (__Pyx_InitGlobals() < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #if 0 || defined(__Pyx_CyFunction_USED) || defined(__Pyx_FusedFunction_USED) || defined(__Pyx_Coroutine_USED) || defined(__Pyx_Generator_USED) || defined(__Pyx_AsyncGen_USED) if (__pyx_CommonTypesMetaclass_init(__pyx_m) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #endif #ifdef __Pyx_CyFunction_USED if (__pyx_CyFunction_init(__pyx_m) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #endif #ifdef __Pyx_FusedFunction_USED if (__pyx_FusedFunction_init(__pyx_m) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #endif #ifdef __Pyx_Coroutine_USED if (__pyx_Coroutine_init(__pyx_m) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #endif #ifdef __Pyx_Generator_USED if (__pyx_Generator_init(__pyx_m) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #endif #ifdef __Pyx_AsyncGen_USED if (__pyx_AsyncGen_init(__pyx_m) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) #endif /*--- Library function declarations ---*/ if (__pyx_module_is_main_intbitset) { if (PyObject_SetAttr(__pyx_m, __pyx_mstate_global->__pyx_n_u_name, __pyx_mstate_global->__pyx_n_u_main) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) } { PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) __PYX_ERR(0, 1, __pyx_L1_error) if (!PyDict_GetItemString(modules, "intbitset")) { if (unlikely((PyDict_SetItemString(modules, "intbitset", __pyx_m) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) } } /*--- Builtin init code ---*/ if (__Pyx_InitCachedBuiltins(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) /*--- Constants init code ---*/ if (__Pyx_InitCachedConstants(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) if (__Pyx_CreateCodeObjects(__pyx_mstate) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) /*--- Global type/function init code ---*/ (void)__Pyx_modinit_global_init_code(__pyx_mstate); (void)__Pyx_modinit_variable_export_code(__pyx_mstate); (void)__Pyx_modinit_function_export_code(__pyx_mstate); if (unlikely((__Pyx_modinit_type_init_code(__pyx_mstate) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) if (unlikely((__Pyx_modinit_type_import_code(__pyx_mstate) < 0))) __PYX_ERR(0, 1, __pyx_L1_error) (void)__Pyx_modinit_variable_import_code(__pyx_mstate); (void)__Pyx_modinit_function_import_code(__pyx_mstate); /*--- Execution code ---*/ /* "intbitset.pyx":46 * #cython: infer_types=True * * import sys # <<<<<<<<<<<<<< * import zlib * from array import array */ __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_sys, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 46, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_sys, __pyx_t_2) < (0)) __PYX_ERR(0, 46, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":47 * * import sys * import zlib # <<<<<<<<<<<<<< * from array import array * from cpython.buffer cimport PyBUF_SIMPLE, Py_buffer, PyObject_GetBuffer, PyBuffer_Release */ __pyx_t_2 = __Pyx_ImportDottedModule(__pyx_mstate_global->__pyx_n_u_zlib, NULL); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 47, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_zlib, __pyx_t_2) < (0)) __PYX_ERR(0, 47, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":48 * import sys * import zlib * from array import array # <<<<<<<<<<<<<< * from cpython.buffer cimport PyBUF_SIMPLE, Py_buffer, PyObject_GetBuffer, PyBuffer_Release * from cpython.ref cimport PyObject */ __pyx_t_2 = __Pyx_PyList_Pack(1, __pyx_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_array, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 48, __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_mstate_global->__pyx_n_u_array); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_array, __pyx_t_2) < (0)) __PYX_ERR(0, 48, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":52 * from cpython.ref cimport PyObject * * CFG_INTBITSET_ENABLE_SANITY_CHECKS = False # <<<<<<<<<<<<<< * from intbitset_helper import _ * from intbitset_version import __version__ */ if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_CFG_INTBITSET_ENABLE_SANITY_CHEC, Py_False) < (0)) __PYX_ERR(0, 52, __pyx_L1_error) /* "intbitset.pyx":53 * * CFG_INTBITSET_ENABLE_SANITY_CHECKS = False * from intbitset_helper import _ # <<<<<<<<<<<<<< * from intbitset_version import __version__ * */ __pyx_t_3 = __Pyx_PyList_Pack(1, __pyx_mstate_global->__pyx_n_u__4); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_2 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_intbitset_helper, __pyx_t_3, 0); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = __Pyx_ImportFrom(__pyx_t_2, __pyx_mstate_global->__pyx_n_u__4); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u__4, __pyx_t_3) < (0)) __PYX_ERR(0, 53, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "intbitset.pyx":54 * CFG_INTBITSET_ENABLE_SANITY_CHECKS = False * from intbitset_helper import _ * from intbitset_version import __version__ # <<<<<<<<<<<<<< * * __all__ = ['intbitset', '__version__'] */ __pyx_t_2 = __Pyx_PyList_Pack(1, __pyx_mstate_global->__pyx_n_u_version); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_Import(__pyx_mstate_global->__pyx_n_u_intbitset_version, __pyx_t_2, 0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 54, __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_mstate_global->__pyx_n_u_version); if (unlikely(!__pyx_t_2)) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_2); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_version, __pyx_t_2) < (0)) __PYX_ERR(0, 54, __pyx_L1_error) __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":56 * from intbitset_version import __version__ * * __all__ = ['intbitset', '__version__'] # <<<<<<<<<<<<<< * * cdef extern from *: */ __pyx_t_3 = __Pyx_PyList_Pack(2, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_n_u_version); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 56, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_all, __pyx_t_3) < (0)) __PYX_ERR(0, 56, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":106 * unsigned char intBitSetCmp(IntBitSet *x, IntBitSet *y) * * __maxelem__ = maxelem # <<<<<<<<<<<<<< * * cdef class intbitset: */ __pyx_t_3 = __Pyx_PyLong_From_int(maxelem); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 106, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_maxelem, __pyx_t_3) < (0)) __PYX_ERR(0, 106, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":165 * int preallocate=-1, * int trailing_bits=0, * bint sanity_checks=CFG_INTBITSET_ENABLE_SANITY_CHECKS, # <<<<<<<<<<<<<< * int no_allocate=0, * ): */ __Pyx_GetModuleGlobalName(__pyx_t_3, __pyx_mstate_global->__pyx_n_u_CFG_INTBITSET_ENABLE_SANITY_CHEC); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 165, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely((__pyx_t_4 == (int)-1) && PyErr_Occurred())) __PYX_ERR(0, 165, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_mstate_global->__pyx_k_ = __pyx_t_4; /* "intbitset.pyx":311 * return intBitSetIsInElem(self.bitset, elem) != 0 * * def __cmp__(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * raise TypeError("cannot compare intbitset using cmp()") * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_7__cmp__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset___cmp, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[0])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 311, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_cmp, __pyx_t_3) < (0)) __PYX_ERR(0, 311, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":346 * return not intBitSetEmpty(self.bitset) * * def __deepcopy__(self not None, memo): # <<<<<<<<<<<<<< * return intbitset(self) * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_17__deepcopy__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset___deepcopy, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[1])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 346, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_deepcopy, __pyx_t_3) < (0)) __PYX_ERR(0, 346, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":525 * * # pickle interface * def __reduce__(self not None): # <<<<<<<<<<<<<< * return _, (self.fastdump(),) * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_45__reduce__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset___reduce, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[2])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 525, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_reduce, __pyx_t_3) < (0)) __PYX_ERR(0, 525, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":528 * return _, (self.fastdump(),) * * __safe_for_unpickling__ = True # <<<<<<<<<<<<<< * * # Iterator interface */ if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_safe_for_unpickling, Py_True) < (0)) __PYX_ERR(0, 528, __pyx_L1_error) /* "intbitset.pyx":537 * * # Customized interface * cpdef add(intbitset self, int elem): # <<<<<<<<<<<<<< * """Add an element to a set. * This has no effect if the element is already present.""" */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_49add, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_add, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[3])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 537, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_add, __pyx_t_3) < (0)) __PYX_ERR(0, 537, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":547 * intBitSetAddElem(self.bitset, elem) * * cpdef clear(intbitset self): # <<<<<<<<<<<<<< * intBitSetReset(self.bitset) * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_51clear, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_clear, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[4])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 547, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_clear, __pyx_t_3) < (0)) __PYX_ERR(0, 547, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":551 * * * cpdef discard(intbitset self, int elem): # <<<<<<<<<<<<<< * """Remove an element from a intbitset if it is a member. * If the element is not a member, do nothing.""" */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_53discard, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_discard, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[5])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 551, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_discard, __pyx_t_3) < (0)) __PYX_ERR(0, 551, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":561 * intBitSetDelElem(self.bitset, elem) * * symmetric_difference = __xor__ # <<<<<<<<<<<<<< * symmetric_difference_update = __ixor__ * */ __Pyx_GetNameInClass(__pyx_t_3, (PyObject*)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_xor); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 561, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_symmetric_difference, __pyx_t_3) < (0)) __PYX_ERR(0, 561, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":562 * * symmetric_difference = __xor__ * symmetric_difference_update = __ixor__ # <<<<<<<<<<<<<< * * cpdef issubset(intbitset self, rhs): */ __Pyx_GetNameInClass(__pyx_t_3, (PyObject*)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_ixor); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 562, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_symmetric_difference_update, __pyx_t_3) < (0)) __PYX_ERR(0, 562, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":564 * symmetric_difference_update = __ixor__ * * cpdef issubset(intbitset self, rhs): # <<<<<<<<<<<<<< * """Report whether another set contains this set.""" * return self.__le__(rhs) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_55issubset, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_issubset, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[6])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 564, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_issubset, __pyx_t_3) < (0)) __PYX_ERR(0, 564, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":568 * return self.__le__(rhs) * * cpdef issuperset(intbitset self, rhs): # <<<<<<<<<<<<<< * """Report whether this set contains another set.""" * return self.__ge__(rhs) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_57issuperset, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_issuperset, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[7])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 568, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_issuperset, __pyx_t_3) < (0)) __PYX_ERR(0, 568, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":573 * * # Dumping & Loading * cpdef fastdump(intbitset self): # <<<<<<<<<<<<<< * """Return a compressed string representation suitable to be saved * somewhere.""" */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_59fastdump, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_fastdump, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[8])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 573, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_fastdump, __pyx_t_3) < (0)) __PYX_ERR(0, 573, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":581 * return zlib.compress(tmp) * * cpdef fastload(intbitset self, strdump): # <<<<<<<<<<<<<< * """Load a compressed string representation produced by a previous call * to the fastdump method into the current intbitset. The previous content */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_61fastload, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_fastload, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[9])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 581, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_fastload, __pyx_t_3) < (0)) __PYX_ERR(0, 581, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":615 * raise ValueError("strdump is corrupted") * * cpdef copy(intbitset self): # <<<<<<<<<<<<<< * """Return a shallow copy of a set.""" * return intbitset(self) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_63copy, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_copy, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[10])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 615, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_copy, __pyx_t_3) < (0)) __PYX_ERR(0, 615, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":619 * return intbitset(self) * * cpdef pop(intbitset self): # <<<<<<<<<<<<<< * """Remove and return an arbitrary set element. * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_65pop, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_pop, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[11])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 619, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_pop, __pyx_t_3) < (0)) __PYX_ERR(0, 619, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":632 * return ret * * cpdef remove(intbitset self, int elem): # <<<<<<<<<<<<<< * """Remove an element from a set; it must be a member. * If the element is not a member, raise a KeyError. */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_67remove, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_remove, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[12])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 632, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_remove, __pyx_t_3) < (0)) __PYX_ERR(0, 632, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":646 * raise KeyError(elem) * * cpdef strbits(intbitset self): # <<<<<<<<<<<<<< * """Return a string of 0s and 1s representing the content in memory * of the intbitset. */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_69strbits, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_strbits, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[13])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 646, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_strbits, __pyx_t_3) < (0)) __PYX_ERR(0, 646, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":661 * return ''.join(ret) * * def update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, adding elements from all others.""" * cdef intbitset iarg */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_71update, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_update, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[14])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 661, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_update, __pyx_t_3) < (0)) __PYX_ERR(0, 661, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":668 * intBitSetIUnion(self.bitset, iarg.bitset) * * union_update = update # <<<<<<<<<<<<<< * * def intersection_update(self not None, *args): */ __Pyx_GetNameInClass(__pyx_t_3, (PyObject*)__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_update); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 668, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_union_update, __pyx_t_3) < (0)) __PYX_ERR(0, 668, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":670 * union_update = update * * def intersection_update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, keeping only elements found in it and all others.""" * cdef intbitset iarg */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_73intersection_update, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_intersection_update, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[15])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 670, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_intersection_update, __pyx_t_3) < (0)) __PYX_ERR(0, 670, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":677 * intBitSetIIntersection(self.bitset, iarg.bitset) * * def difference_update(self not None, *args): # <<<<<<<<<<<<<< * """Update the intbitset, removing elements found in others.""" * cdef intbitset iarg */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_75difference_update, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_difference_update, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[16])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 677, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_difference_update, __pyx_t_3) < (0)) __PYX_ERR(0, 677, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":684 * intBitSetISub(self.bitset, iarg.bitset) * * def union(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements from the intbitset and all others.""" * cdef intbitset ret = intbitset(self) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_77union, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_union, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[17])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 684, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_union, __pyx_t_3) < (0)) __PYX_ERR(0, 684, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":693 * return ret * * def intersection(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements common to the intbitset and all others.""" * cdef intbitset ret = intbitset(self) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_79intersection, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_intersection, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[18])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 693, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_intersection, __pyx_t_3) < (0)) __PYX_ERR(0, 693, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":702 * return ret * * def difference(self not None, *args): # <<<<<<<<<<<<<< * """Return a new intbitset with elements from the intbitset that are not in the others.""" * cdef intbitset ret = intbitset(self) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_81difference, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_difference, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[19])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 702, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_difference, __pyx_t_3) < (0)) __PYX_ERR(0, 702, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":711 * return ret * * def isdisjoint(self not None, intbitset rhs not None): # <<<<<<<<<<<<<< * """Return True if two intbitsets have a null intersection.""" * return intBitSetIsDisjoint(self.bitset, rhs.bitset) */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_83isdisjoint, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_isdisjoint, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[20])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 711, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_isdisjoint, __pyx_t_3) < (0)) __PYX_ERR(0, 711, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":715 * return intBitSetIsDisjoint(self.bitset, rhs.bitset) * * cpdef update_with_signs(intbitset self, rhs): # <<<<<<<<<<<<<< * """Given a dictionary rhs whose keys are integers, remove all the integers * whose value are less than 0 and add every integer whose value is 0 or more""" */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_85update_with_signs, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_update_with_signs, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[21])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 715, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_update_with_signs, __pyx_t_3) < (0)) __PYX_ERR(0, 715, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":739 * raise TypeError("rhs should be a valid dictionary with integers keys and integer values") * * cpdef get_size(intbitset self): # <<<<<<<<<<<<<< * return intBitSetGetSize(self.bitset) * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_87get_size, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_get_size, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[22])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 739, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_get_size, __pyx_t_3) < (0)) __PYX_ERR(0, 739, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":742 * return intBitSetGetSize(self.bitset) * * cpdef get_allocated(intbitset self): # <<<<<<<<<<<<<< * return intBitSetGetAllocated(self.bitset) * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_89get_allocated, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_get_allocated, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[23])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 742, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_get_allocated, __pyx_t_3) < (0)) __PYX_ERR(0, 742, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":745 * return intBitSetGetAllocated(self.bitset) * * cpdef is_infinite(intbitset self): # <<<<<<<<<<<<<< * """Return True if the intbitset is infinite. (i.e. trailing_bits=True * was used in the constructor.)""" */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_91is_infinite, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_is_infinite, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[24])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 745, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_is_infinite, __pyx_t_3) < (0)) __PYX_ERR(0, 745, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":750 * return self.bitset.trailing_bits != 0 * * cpdef extract_finite_list(intbitset self, int up_to=-1): # <<<<<<<<<<<<<< * """Return a finite list of elements sufficient to be passed to intbitset * constructor toghether with the proper value of trailing_bits in order */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_93extract_finite_list, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_extract_finite_list, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[25])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); __Pyx_CyFunction_SetDefaultsTuple(__pyx_t_3, __pyx_mstate_global->__pyx_tuple[0]); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_extract_finite_list, __pyx_t_3) < (0)) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":770 * return ret * * cpdef get_wordbitsize(intbitset self): # <<<<<<<<<<<<<< * return wordbitsize * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_95get_wordbitsize, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_get_wordbitsize, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[26])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 770, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_get_wordbitsize, __pyx_t_3) < (0)) __PYX_ERR(0, 770, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":773 * return wordbitsize * * cpdef get_wordbytsize(intbitset self): # <<<<<<<<<<<<<< * return wordbytesize * */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_97get_wordbytsize, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_get_wordbytsize, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[27])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 773, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_get_wordbytsize, __pyx_t_3) < (0)) __PYX_ERR(0, 773, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":776 * return wordbytesize * * cpdef tolist(intbitset self): # <<<<<<<<<<<<<< * """Legacy method to retrieve a list of all the elements inside an * intbitset. */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_9intbitset_99tolist, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_tolist, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[28])); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 776, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (__Pyx_SetItemOnTypeDict(__pyx_mstate_global->__pyx_ptype_9intbitset_intbitset, __pyx_mstate_global->__pyx_n_u_tolist, __pyx_t_3) < (0)) __PYX_ERR(0, 776, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "(tree fragment)":1 * def __reduce_cython__(self): # <<<<<<<<<<<<<< * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_18intbitset_iterator_9__reduce_cython__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_iterator___reduce_cyth, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[29])); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 1, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_reduce_cython, __pyx_t_3) < (0)) __PYX_ERR(1, 1, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "(tree fragment)":3 * def __reduce_cython__(self): * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" * def __setstate_cython__(self, __pyx_state): # <<<<<<<<<<<<<< * raise TypeError, "no default __reduce__ due to non-trivial __cinit__" */ __pyx_t_3 = __Pyx_CyFunction_New(&__pyx_mdef_9intbitset_18intbitset_iterator_11__setstate_cython__, __Pyx_CYFUNCTION_CCLASS, __pyx_mstate_global->__pyx_n_u_intbitset_iterator___setstate_cy, NULL, __pyx_mstate_global->__pyx_n_u_intbitset_2, __pyx_mstate_global->__pyx_d, ((PyObject *)__pyx_mstate_global->__pyx_codeobj_tab[30])); if (unlikely(!__pyx_t_3)) __PYX_ERR(1, 3, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_setstate_cython, __pyx_t_3) < (0)) __PYX_ERR(1, 3, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /* "intbitset.pyx":1 * # This file is part of Invenio. # <<<<<<<<<<<<<< * # Copyright (C) 2007, 2008, 2009, 2010, 2011, 2013, 2014, 2015, 2016 CERN. * # */ __pyx_t_3 = __Pyx_PyDict_NewPresized(0); if (unlikely(!__pyx_t_3)) __PYX_ERR(0, 1, __pyx_L1_error) __Pyx_GOTREF(__pyx_t_3); if (PyDict_SetItem(__pyx_mstate_global->__pyx_d, __pyx_mstate_global->__pyx_n_u_test, __pyx_t_3) < (0)) __PYX_ERR(0, 1, __pyx_L1_error) __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; /*--- Wrapped vars code ---*/ goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); if (__pyx_m) { if (__pyx_mstate->__pyx_d && stringtab_initialized) { __Pyx_AddTraceback("init intbitset", __pyx_clineno, __pyx_lineno, __pyx_filename); } #if !CYTHON_USE_MODULE_STATE Py_CLEAR(__pyx_m); #else Py_DECREF(__pyx_m); if (pystate_addmodule_run) { PyObject *tp, *value, *tb; PyErr_Fetch(&tp, &value, &tb); PyState_RemoveModule(&__pyx_moduledef); PyErr_Restore(tp, value, tb); } #endif } else if (!PyErr_Occurred()) { PyErr_SetString(PyExc_ImportError, "init intbitset"); } __pyx_L0:; __Pyx_RefNannyFinishContext(); #if CYTHON_PEP489_MULTI_PHASE_INIT return (__pyx_m != NULL) ? 0 : -1; #else return __pyx_m; #endif } /* #### Code section: pystring_table ### */ typedef struct { const char *s; #if 179 <= 65535 const unsigned short n; #elif 179 / 2 < INT_MAX const unsigned int n; #elif 179 / 2 < LONG_MAX const unsigned long n; #else const Py_ssize_t n; #endif #if 1 <= 31 const unsigned int encoding : 5; #elif 1 <= 255 const unsigned char encoding; #elif 1 <= 65535 const unsigned short encoding; #else const Py_ssize_t encoding; #endif const unsigned int is_unicode : 1; const unsigned int intern : 1; } __Pyx_StringTabEntry; static const char * const __pyx_string_tab_encodings[] = { 0 }; static const __Pyx_StringTabEntry __pyx_string_tab[] = { {__pyx_k_0, sizeof(__pyx_k_0), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_0 */ {__pyx_k_1, sizeof(__pyx_k_1), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_1 */ {__pyx_k_AttributeError, sizeof(__pyx_k_AttributeError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_AttributeError */ {__pyx_k_CFG_INTBITSET_ENABLE_SANITY_CHEC, sizeof(__pyx_k_CFG_INTBITSET_ENABLE_SANITY_CHEC), 0, 1, 1}, /* PyObject cname: __pyx_n_u_CFG_INTBITSET_ENABLE_SANITY_CHEC */ {__pyx_k_Can_t_store_integers_bigger_than, sizeof(__pyx_k_Can_t_store_integers_bigger_than), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Can_t_store_integers_bigger_than */ {__pyx_k_Element_must_be_s, sizeof(__pyx_k_Element_must_be_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Element_must_be_s */ {__pyx_k_Elements_must_be_s, sizeof(__pyx_k_Elements_must_be_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Elements_must_be_s */ {__pyx_k_Elements_must_s, sizeof(__pyx_k_Elements_must_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Elements_must_s */ {__pyx_k_Error, sizeof(__pyx_k_Error), 0, 1, 1}, /* PyObject cname: __pyx_n_u_Error */ {__pyx_k_IndexError, sizeof(__pyx_k_IndexError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_IndexError */ {__pyx_k_It_s_impossible_to_iterate_over, sizeof(__pyx_k_It_s_impossible_to_iterate_over), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_It_s_impossible_to_iterate_over */ {__pyx_k_It_s_impossible_to_print_an_infi, sizeof(__pyx_k_It_s_impossible_to_print_an_infi), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_It_s_impossible_to_print_an_infi */ {__pyx_k_It_s_impossible_to_retrieve_a_li, sizeof(__pyx_k_It_s_impossible_to_retrieve_a_li), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_It_s_impossible_to_retrieve_a_li */ {__pyx_k_KeyError, sizeof(__pyx_k_KeyError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_KeyError */ {__pyx_k_MemoryError, sizeof(__pyx_k_MemoryError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_MemoryError */ {__pyx_k_Negative_numbers_not_allowed, sizeof(__pyx_k_Negative_numbers_not_allowed), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Negative_numbers_not_allowed */ {__pyx_k_Note_that_Cython_is_deliberately, sizeof(__pyx_k_Note_that_Cython_is_deliberately), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Note_that_Cython_is_deliberately */ {__pyx_k_OverflowError, sizeof(__pyx_k_OverflowError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_OverflowError */ {__pyx_k_StopIteration, sizeof(__pyx_k_StopIteration), 0, 1, 1}, /* PyObject cname: __pyx_n_u_StopIteration */ {__pyx_k_TypeError, sizeof(__pyx_k_TypeError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_TypeError */ {__pyx_k_Unable_to_get_buffer, sizeof(__pyx_k_Unable_to_get_buffer), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_Unable_to_get_buffer */ {__pyx_k_ValueError, sizeof(__pyx_k_ValueError), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ValueError */ {__pyx_k__2, sizeof(__pyx_k__2), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__2 */ {__pyx_k__3, sizeof(__pyx_k__3), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__3 */ {__pyx_k__4, sizeof(__pyx_k__4), 0, 1, 1}, /* PyObject cname: __pyx_n_u__4 */ {__pyx_k__5, sizeof(__pyx_k__5), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__5 */ {__pyx_k__6, sizeof(__pyx_k__6), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__6 */ {__pyx_k__7, sizeof(__pyx_k__7), 0, 1, 0}, /* PyObject cname: __pyx_kp_u__7 */ {__pyx_k_add, sizeof(__pyx_k_add), 0, 1, 1}, /* PyObject cname: __pyx_n_u_add */ {__pyx_k_add_note, sizeof(__pyx_k_add_note), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_add_note */ {__pyx_k_all, sizeof(__pyx_k_all), 0, 1, 1}, /* PyObject cname: __pyx_n_u_all */ {__pyx_k_arg, sizeof(__pyx_k_arg), 0, 1, 1}, /* PyObject cname: __pyx_n_u_arg */ {__pyx_k_args, sizeof(__pyx_k_args), 0, 1, 1}, /* PyObject cname: __pyx_n_u_args */ {__pyx_k_array, sizeof(__pyx_k_array), 0, 1, 1}, /* PyObject cname: __pyx_n_u_array */ {__pyx_k_asyncio_coroutines, sizeof(__pyx_k_asyncio_coroutines), 0, 1, 1}, /* PyObject cname: __pyx_n_u_asyncio_coroutines */ {__pyx_k_bitset, sizeof(__pyx_k_bitset), 0, 1, 1}, /* PyObject cname: __pyx_n_u_bitset */ {__pyx_k_cannot_compare_intbitset_using_c, sizeof(__pyx_k_cannot_compare_intbitset_using_c), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_cannot_compare_intbitset_using_c */ {__pyx_k_clear, sizeof(__pyx_k_clear), 0, 1, 1}, /* PyObject cname: __pyx_n_u_clear */ {__pyx_k_cline_in_traceback, sizeof(__pyx_k_cline_in_traceback), 0, 1, 1}, /* PyObject cname: __pyx_n_u_cline_in_traceback */ {__pyx_k_cmp, sizeof(__pyx_k_cmp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_cmp */ {__pyx_k_compress, sizeof(__pyx_k_compress), 0, 1, 1}, /* PyObject cname: __pyx_n_u_compress */ {__pyx_k_copy, sizeof(__pyx_k_copy), 0, 1, 1}, /* PyObject cname: __pyx_n_u_copy */ {__pyx_k_decompress, sizeof(__pyx_k_decompress), 0, 1, 1}, /* PyObject cname: __pyx_n_u_decompress */ {__pyx_k_deepcopy, sizeof(__pyx_k_deepcopy), 0, 1, 1}, /* PyObject cname: __pyx_n_u_deepcopy */ {__pyx_k_dict, sizeof(__pyx_k_dict), 0, 1, 1}, /* PyObject cname: __pyx_n_u_dict */ {__pyx_k_difference, sizeof(__pyx_k_difference), 0, 1, 1}, /* PyObject cname: __pyx_n_u_difference */ {__pyx_k_difference_update, sizeof(__pyx_k_difference_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_difference_update */ {__pyx_k_disable, sizeof(__pyx_k_disable), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_disable */ {__pyx_k_discard, sizeof(__pyx_k_discard), 0, 1, 1}, /* PyObject cname: __pyx_n_u_discard */ {__pyx_k_elem, sizeof(__pyx_k_elem), 0, 1, 1}, /* PyObject cname: __pyx_n_u_elem */ {__pyx_k_enable, sizeof(__pyx_k_enable), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_enable */ {__pyx_k_extract_finite_list, sizeof(__pyx_k_extract_finite_list), 0, 1, 1}, /* PyObject cname: __pyx_n_u_extract_finite_list */ {__pyx_k_fastdump, sizeof(__pyx_k_fastdump), 0, 1, 1}, /* PyObject cname: __pyx_n_u_fastdump */ {__pyx_k_fastload, sizeof(__pyx_k_fastload), 0, 1, 1}, /* PyObject cname: __pyx_n_u_fastload */ {__pyx_k_func, sizeof(__pyx_k_func), 0, 1, 1}, /* PyObject cname: __pyx_n_u_func */ {__pyx_k_gc, sizeof(__pyx_k_gc), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_gc */ {__pyx_k_ge, sizeof(__pyx_k_ge), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ge */ {__pyx_k_get_allocated, sizeof(__pyx_k_get_allocated), 0, 1, 1}, /* PyObject cname: __pyx_n_u_get_allocated */ {__pyx_k_get_size, sizeof(__pyx_k_get_size), 0, 1, 1}, /* PyObject cname: __pyx_n_u_get_size */ {__pyx_k_get_wordbitsize, sizeof(__pyx_k_get_wordbitsize), 0, 1, 1}, /* PyObject cname: __pyx_n_u_get_wordbitsize */ {__pyx_k_get_wordbytsize, sizeof(__pyx_k_get_wordbytsize), 0, 1, 1}, /* PyObject cname: __pyx_n_u_get_wordbytsize */ {__pyx_k_getitem, sizeof(__pyx_k_getitem), 0, 1, 1}, /* PyObject cname: __pyx_n_u_getitem */ {__pyx_k_getstate, sizeof(__pyx_k_getstate), 0, 1, 1}, /* PyObject cname: __pyx_n_u_getstate */ {__pyx_k_i, sizeof(__pyx_k_i), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_i */ {__pyx_k_iarg, sizeof(__pyx_k_iarg), 0, 1, 1}, /* PyObject cname: __pyx_n_u_iarg */ {__pyx_k_indices, sizeof(__pyx_k_indices), 0, 1, 1}, /* PyObject cname: __pyx_n_u_indices */ {__pyx_k_initializing, sizeof(__pyx_k_initializing), 0, 1, 1}, /* PyObject cname: __pyx_n_u_initializing */ {__pyx_k_intbitset, sizeof(__pyx_k_intbitset), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset */ {__pyx_k_intbitset_2, sizeof(__pyx_k_intbitset_2), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_2 */ {__pyx_k_intbitset___cmp, sizeof(__pyx_k_intbitset___cmp), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset___cmp */ {__pyx_k_intbitset___deepcopy, sizeof(__pyx_k_intbitset___deepcopy), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset___deepcopy */ {__pyx_k_intbitset___reduce, sizeof(__pyx_k_intbitset___reduce), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset___reduce */ {__pyx_k_intbitset_add, sizeof(__pyx_k_intbitset_add), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_add */ {__pyx_k_intbitset_clear, sizeof(__pyx_k_intbitset_clear), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_clear */ {__pyx_k_intbitset_copy, sizeof(__pyx_k_intbitset_copy), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_copy */ {__pyx_k_intbitset_corrupted_allocated, sizeof(__pyx_k_intbitset_corrupted_allocated), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset_corrupted_allocated */ {__pyx_k_intbitset_difference, sizeof(__pyx_k_intbitset_difference), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_difference */ {__pyx_k_intbitset_difference_update, sizeof(__pyx_k_intbitset_difference_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_difference_update */ {__pyx_k_intbitset_discard, sizeof(__pyx_k_intbitset_discard), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_discard */ {__pyx_k_intbitset_extract_finite_list, sizeof(__pyx_k_intbitset_extract_finite_list), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_extract_finite_list */ {__pyx_k_intbitset_fastdump, sizeof(__pyx_k_intbitset_fastdump), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_fastdump */ {__pyx_k_intbitset_fastload, sizeof(__pyx_k_intbitset_fastload), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_fastload */ {__pyx_k_intbitset_get_allocated, sizeof(__pyx_k_intbitset_get_allocated), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_get_allocated */ {__pyx_k_intbitset_get_size, sizeof(__pyx_k_intbitset_get_size), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_get_size */ {__pyx_k_intbitset_get_wordbitsize, sizeof(__pyx_k_intbitset_get_wordbitsize), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_get_wordbitsize */ {__pyx_k_intbitset_get_wordbytsize, sizeof(__pyx_k_intbitset_get_wordbytsize), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_get_wordbytsize */ {__pyx_k_intbitset_helper, sizeof(__pyx_k_intbitset_helper), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_helper */ {__pyx_k_intbitset_index_out_of_range, sizeof(__pyx_k_intbitset_index_out_of_range), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset_index_out_of_range */ {__pyx_k_intbitset_intbitset_pyx, sizeof(__pyx_k_intbitset_intbitset_pyx), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset_intbitset_pyx */ {__pyx_k_intbitset_intersection, sizeof(__pyx_k_intbitset_intersection), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_intersection */ {__pyx_k_intbitset_intersection_update, sizeof(__pyx_k_intbitset_intersection_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_intersection_update */ {__pyx_k_intbitset_is_infinite, sizeof(__pyx_k_intbitset_is_infinite), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_is_infinite */ {__pyx_k_intbitset_isdisjoint, sizeof(__pyx_k_intbitset_isdisjoint), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_isdisjoint */ {__pyx_k_intbitset_issubset, sizeof(__pyx_k_intbitset_issubset), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_issubset */ {__pyx_k_intbitset_issuperset, sizeof(__pyx_k_intbitset_issuperset), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_issuperset */ {__pyx_k_intbitset_iterator, sizeof(__pyx_k_intbitset_iterator), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_iterator */ {__pyx_k_intbitset_iterator___reduce_cyth, sizeof(__pyx_k_intbitset_iterator___reduce_cyth), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_iterator___reduce_cyth */ {__pyx_k_intbitset_iterator___setstate_cy, sizeof(__pyx_k_intbitset_iterator___setstate_cy), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_iterator___setstate_cy */ {__pyx_k_intbitset_pop, sizeof(__pyx_k_intbitset_pop), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_pop */ {__pyx_k_intbitset_remove, sizeof(__pyx_k_intbitset_remove), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_remove */ {__pyx_k_intbitset_s, sizeof(__pyx_k_intbitset_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset_s */ {__pyx_k_intbitset_s_trailing_bits_True, sizeof(__pyx_k_intbitset_s_trailing_bits_True), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset_s_trailing_bits_True */ {__pyx_k_intbitset_strbits, sizeof(__pyx_k_intbitset_strbits), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_strbits */ {__pyx_k_intbitset_tolist, sizeof(__pyx_k_intbitset_tolist), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_tolist */ {__pyx_k_intbitset_trailing_bits_True, sizeof(__pyx_k_intbitset_trailing_bits_True), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_intbitset_trailing_bits_True */ {__pyx_k_intbitset_union, sizeof(__pyx_k_intbitset_union), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_union */ {__pyx_k_intbitset_update, sizeof(__pyx_k_intbitset_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_update */ {__pyx_k_intbitset_update_with_signs, sizeof(__pyx_k_intbitset_update_with_signs), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_update_with_signs */ {__pyx_k_intbitset_version, sizeof(__pyx_k_intbitset_version), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intbitset_version */ {__pyx_k_intersection, sizeof(__pyx_k_intersection), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intersection */ {__pyx_k_intersection_update, sizeof(__pyx_k_intersection_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_intersection_update */ {__pyx_k_is_coroutine, sizeof(__pyx_k_is_coroutine), 0, 1, 1}, /* PyObject cname: __pyx_n_u_is_coroutine */ {__pyx_k_is_infinite, sizeof(__pyx_k_is_infinite), 0, 1, 1}, /* PyObject cname: __pyx_n_u_is_infinite */ {__pyx_k_isdisjoint, sizeof(__pyx_k_isdisjoint), 0, 1, 1}, /* PyObject cname: __pyx_n_u_isdisjoint */ {__pyx_k_isenabled, sizeof(__pyx_k_isenabled), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_isenabled */ {__pyx_k_issubset, sizeof(__pyx_k_issubset), 0, 1, 1}, /* PyObject cname: __pyx_n_u_issubset */ {__pyx_k_issuperset, sizeof(__pyx_k_issuperset), 0, 1, 1}, /* PyObject cname: __pyx_n_u_issuperset */ {__pyx_k_iter, sizeof(__pyx_k_iter), 0, 1, 1}, /* PyObject cname: __pyx_n_u_iter */ {__pyx_k_iteritems, sizeof(__pyx_k_iteritems), 0, 1, 1}, /* PyObject cname: __pyx_n_u_iteritems */ {__pyx_k_ixor, sizeof(__pyx_k_ixor), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ixor */ {__pyx_k_le, sizeof(__pyx_k_le), 0, 1, 1}, /* PyObject cname: __pyx_n_u_le */ {__pyx_k_main, sizeof(__pyx_k_main), 0, 1, 1}, /* PyObject cname: __pyx_n_u_main */ {__pyx_k_max, sizeof(__pyx_k_max), 0, 1, 1}, /* PyObject cname: __pyx_n_u_max */ {__pyx_k_maxelem, sizeof(__pyx_k_maxelem), 0, 1, 1}, /* PyObject cname: __pyx_n_u_maxelem */ {__pyx_k_memo, sizeof(__pyx_k_memo), 0, 1, 1}, /* PyObject cname: __pyx_n_u_memo */ {__pyx_k_module, sizeof(__pyx_k_module), 0, 1, 1}, /* PyObject cname: __pyx_n_u_module */ {__pyx_k_name, sizeof(__pyx_k_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_name */ {__pyx_k_negative_indexes_are_not_allowed, sizeof(__pyx_k_negative_indexes_are_not_allowed), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_negative_indexes_are_not_allowed */ {__pyx_k_negative_steps_are_not_yet_suppo, sizeof(__pyx_k_negative_steps_are_not_yet_suppo), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_negative_steps_are_not_yet_suppo */ {__pyx_k_no_allocate, sizeof(__pyx_k_no_allocate), 0, 1, 1}, /* PyObject cname: __pyx_n_u_no_allocate */ {__pyx_k_no_default___reduce___due_to_non, sizeof(__pyx_k_no_default___reduce___due_to_non), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_no_default___reduce___due_to_non */ {__pyx_k_pop, sizeof(__pyx_k_pop), 0, 1, 1}, /* PyObject cname: __pyx_n_u_pop */ {__pyx_k_pop_from_an_empty_or_infinite_in, sizeof(__pyx_k_pop_from_an_empty_or_infinite_in), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_pop_from_an_empty_or_infinite_in */ {__pyx_k_preallocate, sizeof(__pyx_k_preallocate), 0, 1, 1}, /* PyObject cname: __pyx_n_u_preallocate */ {__pyx_k_pyx_state, sizeof(__pyx_k_pyx_state), 0, 1, 1}, /* PyObject cname: __pyx_n_u_pyx_state */ {__pyx_k_pyx_vtable, sizeof(__pyx_k_pyx_vtable), 0, 1, 1}, /* PyObject cname: __pyx_n_u_pyx_vtable */ {__pyx_k_qualname, sizeof(__pyx_k_qualname), 0, 1, 1}, /* PyObject cname: __pyx_n_u_qualname */ {__pyx_k_range, sizeof(__pyx_k_range), 0, 1, 1}, /* PyObject cname: __pyx_n_u_range */ {__pyx_k_reduce, sizeof(__pyx_k_reduce), 0, 1, 1}, /* PyObject cname: __pyx_n_u_reduce */ {__pyx_k_reduce_cython, sizeof(__pyx_k_reduce_cython), 0, 1, 1}, /* PyObject cname: __pyx_n_u_reduce_cython */ {__pyx_k_reduce_ex, sizeof(__pyx_k_reduce_ex), 0, 1, 1}, /* PyObject cname: __pyx_n_u_reduce_ex */ {__pyx_k_remove, sizeof(__pyx_k_remove), 0, 1, 1}, /* PyObject cname: __pyx_n_u_remove */ {__pyx_k_repr, sizeof(__pyx_k_repr), 0, 1, 1}, /* PyObject cname: __pyx_n_u_repr */ {__pyx_k_ret, sizeof(__pyx_k_ret), 0, 1, 1}, /* PyObject cname: __pyx_n_u_ret */ {__pyx_k_retrieving_integers_from_rhs_is, sizeof(__pyx_k_retrieving_integers_from_rhs_is), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_retrieving_integers_from_rhs_is */ {__pyx_k_rhs, sizeof(__pyx_k_rhs), 0, 1, 1}, /* PyObject cname: __pyx_n_u_rhs */ {__pyx_k_rhs_can_t_be_negative, sizeof(__pyx_k_rhs_can_t_be_negative), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_rhs_can_t_be_negative */ {__pyx_k_rhs_is_corrupted_s, sizeof(__pyx_k_rhs_is_corrupted_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_rhs_is_corrupted_s */ {__pyx_k_rhs_is_of_unknown_type_s, sizeof(__pyx_k_rhs_is_of_unknown_type_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_rhs_is_of_unknown_type_s */ {__pyx_k_rhs_must_be_s, sizeof(__pyx_k_rhs_must_be_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_rhs_must_be_s */ {__pyx_k_rhs_should_be_a_valid_dictionary, sizeof(__pyx_k_rhs_should_be_a_valid_dictionary), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_rhs_should_be_a_valid_dictionary */ {__pyx_k_safe_for_unpickling, sizeof(__pyx_k_safe_for_unpickling), 0, 1, 1}, /* PyObject cname: __pyx_n_u_safe_for_unpickling */ {__pyx_k_sanity_checks, sizeof(__pyx_k_sanity_checks), 0, 1, 1}, /* PyObject cname: __pyx_n_u_sanity_checks */ {__pyx_k_self, sizeof(__pyx_k_self), 0, 1, 1}, /* PyObject cname: __pyx_n_u_self */ {__pyx_k_set_name, sizeof(__pyx_k_set_name), 0, 1, 1}, /* PyObject cname: __pyx_n_u_set_name */ {__pyx_k_setstate, sizeof(__pyx_k_setstate), 0, 1, 1}, /* PyObject cname: __pyx_n_u_setstate */ {__pyx_k_setstate_cython, sizeof(__pyx_k_setstate_cython), 0, 1, 1}, /* PyObject cname: __pyx_n_u_setstate_cython */ {__pyx_k_size, sizeof(__pyx_k_size), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_size */ {__pyx_k_spec, sizeof(__pyx_k_spec), 0, 1, 1}, /* PyObject cname: __pyx_n_u_spec */ {__pyx_k_start, sizeof(__pyx_k_start), 0, 1, 1}, /* PyObject cname: __pyx_n_u_start */ {__pyx_k_stop, sizeof(__pyx_k_stop), 0, 1, 1}, /* PyObject cname: __pyx_n_u_stop */ {__pyx_k_strbits, sizeof(__pyx_k_strbits), 0, 1, 1}, /* PyObject cname: __pyx_n_u_strbits */ {__pyx_k_strdump, sizeof(__pyx_k_strdump), 0, 1, 1}, /* PyObject cname: __pyx_n_u_strdump */ {__pyx_k_strdump_is_corrupted, sizeof(__pyx_k_strdump_is_corrupted), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_strdump_is_corrupted */ {__pyx_k_stringsource, sizeof(__pyx_k_stringsource), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_stringsource */ {__pyx_k_symmetric_difference, sizeof(__pyx_k_symmetric_difference), 0, 1, 1}, /* PyObject cname: __pyx_n_u_symmetric_difference */ {__pyx_k_symmetric_difference_update, sizeof(__pyx_k_symmetric_difference_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_symmetric_difference_update */ {__pyx_k_sys, sizeof(__pyx_k_sys), 0, 1, 1}, /* PyObject cname: __pyx_n_u_sys */ {__pyx_k_test, sizeof(__pyx_k_test), 0, 1, 1}, /* PyObject cname: __pyx_n_u_test */ {__pyx_k_tobytes, sizeof(__pyx_k_tobytes), 0, 1, 1}, /* PyObject cname: __pyx_n_u_tobytes */ {__pyx_k_tolist, sizeof(__pyx_k_tolist), 0, 1, 1}, /* PyObject cname: __pyx_n_u_tolist */ {__pyx_k_tostring, sizeof(__pyx_k_tostring), 0, 1, 1}, /* PyObject cname: __pyx_n_u_tostring */ {__pyx_k_trailing_bits, sizeof(__pyx_k_trailing_bits), 0, 1, 1}, /* PyObject cname: __pyx_n_u_trailing_bits */ {__pyx_k_union, sizeof(__pyx_k_union), 0, 1, 1}, /* PyObject cname: __pyx_n_u_union */ {__pyx_k_union_update, sizeof(__pyx_k_union_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_union_update */ {__pyx_k_up_to, sizeof(__pyx_k_up_to), 0, 1, 1}, /* PyObject cname: __pyx_n_u_up_to */ {__pyx_k_up_to_must_be_s, sizeof(__pyx_k_up_to_must_be_s), 0, 1, 0}, /* PyObject cname: __pyx_kp_u_up_to_must_be_s */ {__pyx_k_update, sizeof(__pyx_k_update), 0, 1, 1}, /* PyObject cname: __pyx_n_u_update */ {__pyx_k_update_with_signs, sizeof(__pyx_k_update_with_signs), 0, 1, 1}, /* PyObject cname: __pyx_n_u_update_with_signs */ {__pyx_k_version, sizeof(__pyx_k_version), 0, 1, 1}, /* PyObject cname: __pyx_n_u_version */ {__pyx_k_xor, sizeof(__pyx_k_xor), 0, 1, 1}, /* PyObject cname: __pyx_n_u_xor */ {__pyx_k_zlib, sizeof(__pyx_k_zlib), 0, 1, 1}, /* PyObject cname: __pyx_n_u_zlib */ {0, 0, 0, 0, 0} }; /* InitStrings.proto */ static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names); /* #### Code section: cached_builtins ### */ static int __Pyx_InitCachedBuiltins(__pyx_mstatetype *__pyx_mstate) { CYTHON_UNUSED_VAR(__pyx_mstate); __pyx_builtin_ValueError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_ValueError); if (!__pyx_builtin_ValueError) __PYX_ERR(0, 185, __pyx_L1_error) __pyx_builtin_max = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_max); if (!__pyx_builtin_max) __PYX_ERR(0, 222, __pyx_L1_error) __pyx_builtin_OverflowError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_OverflowError); if (!__pyx_builtin_OverflowError) __PYX_ERR(0, 229, __pyx_L1_error) __pyx_builtin_TypeError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_TypeError); if (!__pyx_builtin_TypeError) __PYX_ERR(0, 294, __pyx_L1_error) __pyx_builtin_IndexError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_IndexError); if (!__pyx_builtin_IndexError) __PYX_ERR(0, 494, __pyx_L1_error) __pyx_builtin_range = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_range); if (!__pyx_builtin_range) __PYX_ERR(0, 499, __pyx_L1_error) __pyx_builtin_KeyError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_KeyError); if (!__pyx_builtin_KeyError) __PYX_ERR(0, 628, __pyx_L1_error) __pyx_builtin_AttributeError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_AttributeError); if (!__pyx_builtin_AttributeError) __PYX_ERR(0, 736, __pyx_L1_error) __pyx_builtin_StopIteration = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_StopIteration); if (!__pyx_builtin_StopIteration) __PYX_ERR(0, 805, __pyx_L1_error) __pyx_builtin_MemoryError = __Pyx_GetBuiltinName(__pyx_mstate->__pyx_n_u_MemoryError); if (!__pyx_builtin_MemoryError) __PYX_ERR(0, 808, __pyx_L1_error) return 0; __pyx_L1_error:; return -1; } /* #### Code section: cached_constants ### */ static int __Pyx_InitCachedConstants(__pyx_mstatetype *__pyx_mstate) { __Pyx_RefNannyDeclarations CYTHON_UNUSED_VAR(__pyx_mstate); __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0); /* "intbitset.pyx":471 * return "intbitset([...], trailing_bits=True)" * elif tot > 10: * begin_list = self[0:5] # <<<<<<<<<<<<<< * end_list = self[tot - 5:tot] * ret = "intbitset([" */ __pyx_mstate_global->__pyx_slice[0] = PySlice_New(__pyx_mstate_global->__pyx_int_0, __pyx_mstate_global->__pyx_int_5, Py_None); if (unlikely(!__pyx_mstate_global->__pyx_slice[0])) __PYX_ERR(0, 471, __pyx_L1_error) __Pyx_GOTREF(__pyx_mstate_global->__pyx_slice[0]); __Pyx_GIVEREF(__pyx_mstate_global->__pyx_slice[0]); /* "intbitset.pyx":750 * return self.bitset.trailing_bits != 0 * * cpdef extract_finite_list(intbitset self, int up_to=-1): # <<<<<<<<<<<<<< * """Return a finite list of elements sufficient to be passed to intbitset * constructor toghether with the proper value of trailing_bits in order */ __pyx_mstate_global->__pyx_tuple[0] = PyTuple_Pack(1, __pyx_mstate_global->__pyx_int_neg_1); if (unlikely(!__pyx_mstate_global->__pyx_tuple[0])) __PYX_ERR(0, 750, __pyx_L1_error) __Pyx_GOTREF(__pyx_mstate_global->__pyx_tuple[0]); __Pyx_GIVEREF(__pyx_mstate_global->__pyx_tuple[0]); __Pyx_RefNannyFinishContext(); return 0; __pyx_L1_error:; __Pyx_RefNannyFinishContext(); return -1; } /* #### Code section: init_constants ### */ static int __Pyx_InitConstants(__pyx_mstatetype *__pyx_mstate) { CYTHON_UNUSED_VAR(__pyx_mstate); __pyx_mstate->__pyx_umethod_PyDict_Type_pop.type = (PyObject*)&PyDict_Type; __pyx_mstate->__pyx_umethod_PyDict_Type_pop.method_name = &__pyx_mstate->__pyx_n_u_pop; if (__Pyx_InitStrings(__pyx_string_tab, __pyx_mstate->__pyx_string_tab, __pyx_string_tab_encodings) < 0) __PYX_ERR(0, 1, __pyx_L1_error); __pyx_mstate->__pyx_int_0 = PyLong_FromLong(0); if (unlikely(!__pyx_mstate->__pyx_int_0)) __PYX_ERR(0, 1, __pyx_L1_error) __pyx_mstate->__pyx_int_1 = PyLong_FromLong(1); if (unlikely(!__pyx_mstate->__pyx_int_1)) __PYX_ERR(0, 1, __pyx_L1_error) __pyx_mstate->__pyx_int_5 = PyLong_FromLong(5); if (unlikely(!__pyx_mstate->__pyx_int_5)) __PYX_ERR(0, 1, __pyx_L1_error) __pyx_mstate->__pyx_int_neg_1 = PyLong_FromLong(-1); if (unlikely(!__pyx_mstate->__pyx_int_neg_1)) __PYX_ERR(0, 1, __pyx_L1_error) return 0; __pyx_L1_error:; return -1; } /* #### Code section: init_codeobjects ### */ \ typedef struct { unsigned int argcount : 2; unsigned int num_posonly_args : 1; unsigned int num_kwonly_args : 1; unsigned int nlocals : 3; unsigned int flags : 10; unsigned int first_line : 10; unsigned int line_table_length : 12; } __Pyx_PyCode_New_function_description; /* NewCodeObj.proto */ static PyObject* __Pyx_PyCode_New( const __Pyx_PyCode_New_function_description descr, PyObject * const *varnames, PyObject *filename, PyObject *funcname, const char *line_table, PyObject *tuple_dedup_map ); static int __Pyx_CreateCodeObjects(__pyx_mstatetype *__pyx_mstate) { PyObject* tuple_dedup_map = PyDict_New(); if (unlikely(!tuple_dedup_map)) return -1; { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 311, 11}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_rhs}; __pyx_mstate_global->__pyx_codeobj_tab[0] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_cmp, __pyx_k_A_iq, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[0])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 346, 11}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_memo}; __pyx_mstate_global->__pyx_codeobj_tab[1] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_deepcopy, __pyx_k_A_y, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[1])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 525, 13}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[2] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_reduce, __pyx_k_A_t4y, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[2])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 537, 61}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_elem}; __pyx_mstate_global->__pyx_codeobj_tab[3] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_add, __pyx_k_A_4q_uBa_j_b_m1_Ba_Ya, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[3])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 547, 11}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[4] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_clear, __pyx_k_A_at1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[4])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 551, 61}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_elem}; __pyx_mstate_global->__pyx_codeobj_tab[5] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_discard, __pyx_k_A_4q_uBa_j_b_m1_Ba_Ya, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[5])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 564, 13}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_rhs}; __pyx_mstate_global->__pyx_codeobj_tab[6] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_issubset, __pyx_k_A_t7_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[6])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 568, 13}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_rhs}; __pyx_mstate_global->__pyx_codeobj_tab[7] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_issuperset, __pyx_k_A_t7_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[7])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 573, 57}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[8] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_fastdump, __pyx_k_A_r_U_q_G_e2SPRRS_t9AQ, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[8])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 581, 150}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_strdump}; __pyx_mstate_global->__pyx_codeobj_tab[9] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_fastload, __pyx_k_A_a_q_t1IS_k_q_nCq_j_d_t1_E_1_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[9])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 615, 11}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[10] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_copy, __pyx_k_A_y_2, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[10])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 619, 50}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[11] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_pop, __pyx_k_A_at1_4r_1_Ya_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[11])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 632, 84}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_elem}; __pyx_mstate_global->__pyx_codeobj_tab[12] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_remove, __pyx_k_A_4q_uBa_j_b_m1_Rq_AT_AT_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[12])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 646, 82}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[13] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_strbits, __pyx_k_A_L_WA_q_q_a_E_was_AQe1A_1AQ_r_a, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[13])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARARGS), 661, 43}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_iarg, __pyx_mstate->__pyx_n_u_arg}; __pyx_mstate_global->__pyx_codeobj_tab[14] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_update, __pyx_k_A_G1_7_iq_1D_Q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[14])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARARGS), 670, 43}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_iarg, __pyx_mstate->__pyx_n_u_arg}; __pyx_mstate_global->__pyx_codeobj_tab[15] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_intersection_update, __pyx_k_A_G1_7_iq_4y_A, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[15])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 4, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARARGS), 677, 43}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_iarg, __pyx_mstate->__pyx_n_u_arg}; __pyx_mstate_global->__pyx_codeobj_tab[16] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_difference_update, __pyx_k_A_G1_7_iq_it1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[16])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARARGS), 684, 55}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_ret, __pyx_mstate->__pyx_n_u_iarg, __pyx_mstate->__pyx_n_u_arg}; __pyx_mstate_global->__pyx_codeobj_tab[17] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_union, __pyx_k_A_Yaq_G1_7_iq_1Cy_A_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[17])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARARGS), 693, 55}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_ret, __pyx_mstate->__pyx_n_u_iarg, __pyx_mstate->__pyx_n_u_arg}; __pyx_mstate_global->__pyx_codeobj_tab[18] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_intersection, __pyx_k_A_Yaq_G1_7_iq_3it1_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[18])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 5, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS|CO_VARARGS), 702, 55}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_args, __pyx_mstate->__pyx_n_u_ret, __pyx_mstate->__pyx_n_u_iarg, __pyx_mstate->__pyx_n_u_arg}; __pyx_mstate_global->__pyx_codeobj_tab[19] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_difference, __pyx_k_A_Yaq_G1_7_iq_Yd_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[19])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 711, 18}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_rhs}; __pyx_mstate_global->__pyx_codeobj_tab[20] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_isdisjoint, __pyx_k_A_4y_1, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[20])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 715, 153}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_rhs}; __pyx_mstate_global->__pyx_codeobj_tab[21] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_update_with_signs, __pyx_k_A_t1_G83j_vRq_j_r_m1_B_A_uBa_Ya, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[21])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 739, 14}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[22] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_get_size, __pyx_k_A_q_A, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[22])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 742, 14}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[23] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_get_allocated, __pyx_k_A_AT, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[23])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 745, 17}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[24] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_is_infinite, __pyx_k_A_t7_A, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[24])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 750, 115}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_up_to}; __pyx_mstate_global->__pyx_codeobj_tab[25] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_extract_finite_list, __pyx_k_9_4_d_q_6b_a_1_j_e2Q_1D_uD_waq, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[25])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 770, 7}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[26] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_get_wordbitsize, __pyx_k_A_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[26])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 773, 7}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[27] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_get_wordbytsize, __pyx_k_A_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[27])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 776, 32}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[28] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_intbitset_intbitset_pyx, __pyx_mstate->__pyx_n_u_tolist, __pyx_k_A_4wa_q_t_q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[28])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {1, 0, 0, 1, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 1, 9}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self}; __pyx_mstate_global->__pyx_codeobj_tab[29] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_stringsource, __pyx_mstate->__pyx_n_u_reduce_cython, __pyx_k_Q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[29])) goto bad; } { const __Pyx_PyCode_New_function_description descr = {2, 0, 0, 2, (unsigned int)(CO_OPTIMIZED|CO_NEWLOCALS), 3, 9}; PyObject* const varnames[] = {__pyx_mstate->__pyx_n_u_self, __pyx_mstate->__pyx_n_u_pyx_state}; __pyx_mstate_global->__pyx_codeobj_tab[30] = __Pyx_PyCode_New(descr, varnames, __pyx_mstate->__pyx_kp_u_stringsource, __pyx_mstate->__pyx_n_u_setstate_cython, __pyx_k_Q, tuple_dedup_map); if (unlikely(!__pyx_mstate_global->__pyx_codeobj_tab[30])) goto bad; } Py_DECREF(tuple_dedup_map); return 0; bad: Py_DECREF(tuple_dedup_map); return -1; } /* #### Code section: init_globals ### */ static int __Pyx_InitGlobals(void) { /* PythonCompatibility.init */ if (likely(__Pyx_init_co_variables() == 0)); else if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) /* CachedMethodType.init */ #if CYTHON_COMPILING_IN_LIMITED_API { PyObject *typesModule=NULL; typesModule = PyImport_ImportModule("types"); if (typesModule) { __pyx_mstate_global->__Pyx_CachedMethodType = PyObject_GetAttrString(typesModule, "MethodType"); Py_DECREF(typesModule); } } // error handling follows #endif if (unlikely(PyErr_Occurred())) __PYX_ERR(0, 1, __pyx_L1_error) return 0; __pyx_L1_error:; return -1; } /* #### Code section: cleanup_globals ### */ /* #### Code section: cleanup_module ### */ /* #### Code section: main_method ### */ /* #### Code section: utility_code_pragmas ### */ #ifdef _MSC_VER #pragma warning( push ) /* Warning 4127: conditional expression is constant * Cython uses constant conditional expressions to allow in inline functions to be optimized at * compile-time, so this warning is not useful */ #pragma warning( disable : 4127 ) #endif /* #### Code section: utility_code_def ### */ /* --- 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 /* 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); for (i=0; i= 0x030C00A6 PyObject *current_exception = tstate->current_exception; if (unlikely(!current_exception)) return 0; exc_type = (PyObject*) Py_TYPE(current_exception); if (exc_type == err) return 1; #else exc_type = tstate->curexc_type; if (exc_type == err) return 1; if (unlikely(!exc_type)) return 0; #endif #if CYTHON_AVOID_BORROWED_REFS Py_INCREF(exc_type); #endif if (unlikely(PyTuple_Check(err))) { result = __Pyx_PyErr_ExceptionMatchesTuple(exc_type, err); } else { result = __Pyx_PyErr_GivenExceptionMatches(exc_type, err); } #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(exc_type); #endif return result; } #endif /* PyErrFetchRestore */ #if CYTHON_FAST_THREAD_STATE static CYTHON_INLINE void __Pyx_ErrRestoreInState(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { #if PY_VERSION_HEX >= 0x030C00A6 PyObject *tmp_value; assert(type == NULL || (value != NULL && type == (PyObject*) Py_TYPE(value))); if (value) { #if CYTHON_COMPILING_IN_CPYTHON if (unlikely(((PyBaseExceptionObject*) value)->traceback != tb)) #endif PyException_SetTraceback(value, tb); } tmp_value = tstate->current_exception; tstate->current_exception = value; Py_XDECREF(tmp_value); Py_XDECREF(type); Py_XDECREF(tb); #else 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); #endif } static CYTHON_INLINE void __Pyx_ErrFetchInState(PyThreadState *tstate, PyObject **type, PyObject **value, PyObject **tb) { #if PY_VERSION_HEX >= 0x030C00A6 PyObject* exc_value; exc_value = tstate->current_exception; tstate->current_exception = 0; *value = exc_value; *type = NULL; *tb = NULL; if (exc_value) { *type = (PyObject*) Py_TYPE(exc_value); Py_INCREF(*type); #if CYTHON_COMPILING_IN_CPYTHON *tb = ((PyBaseExceptionObject*) exc_value)->traceback; Py_XINCREF(*tb); #else *tb = PyException_GetTraceback(exc_value); #endif } #else *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 } #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); return PyObject_GetAttr(obj, attr_name); } #endif /* PyObjectGetAttrStrNoError */ #if __PYX_LIMITED_VERSION_HEX < 0x030d0000 static void __Pyx_PyObject_GetAttrStr_ClearAttributeError(void) { __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign if (likely(__Pyx_PyErr_ExceptionMatches(PyExc_AttributeError))) __Pyx_PyErr_Clear(); } #endif static CYTHON_INLINE PyObject* __Pyx_PyObject_GetAttrStrNoError(PyObject* obj, PyObject* attr_name) { PyObject *result; #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 (void) PyObject_GetOptionalAttr(obj, attr_name, &result); return result; #else #if CYTHON_COMPILING_IN_CPYTHON && CYTHON_USE_TYPE_SLOTS 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; #endif } /* GetBuiltinName */ static PyObject *__Pyx_GetBuiltinName(PyObject *name) { PyObject* result = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_b, name); if (unlikely(!result) && !PyErr_Occurred()) { PyErr_Format(PyExc_NameError, "name '%U' is not defined", name); } return result; } /* TupleAndListFromArray */ #if !CYTHON_COMPILING_IN_CPYTHON && CYTHON_METH_FASTCALL static CYTHON_INLINE PyObject * __Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n) { PyObject *res; Py_ssize_t i; if (n <= 0) { return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_tuple); } res = PyTuple_New(n); if (unlikely(res == NULL)) return NULL; for (i = 0; i < n; i++) { if (unlikely(__Pyx_PyTuple_SET_ITEM(res, i, src[i]) < (0))) { Py_DECREF(res); return NULL; } Py_INCREF(src[i]); } return res; } #elif CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE void __Pyx_copy_object_array(PyObject *const *CYTHON_RESTRICT src, PyObject** CYTHON_RESTRICT dest, Py_ssize_t length) { PyObject *v; Py_ssize_t i; for (i = 0; i < length; i++) { v = dest[i] = src[i]; Py_INCREF(v); } } static CYTHON_INLINE PyObject * __Pyx_PyTuple_FromArray(PyObject *const *src, Py_ssize_t n) { PyObject *res; if (n <= 0) { return __Pyx_NewRef(__pyx_mstate_global->__pyx_empty_tuple); } res = PyTuple_New(n); if (unlikely(res == NULL)) return NULL; __Pyx_copy_object_array(src, ((PyTupleObject*)res)->ob_item, n); return res; } static CYTHON_INLINE PyObject * __Pyx_PyList_FromArray(PyObject *const *src, Py_ssize_t n) { PyObject *res; if (n <= 0) { return PyList_New(0); } res = PyList_New(n); if (unlikely(res == NULL)) return NULL; __Pyx_copy_object_array(src, ((PyListObject*)res)->ob_item, n); return res; } #endif /* BytesEquals */ static CYTHON_INLINE int __Pyx_PyBytes_Equals(PyObject* s1, PyObject* s2, int equals) { #if CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL ||\ !(CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) 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_VERSION_HEX < 0x030B0000) 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 || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_GRAAL return PyObject_RichCompareBool(s1, s2, equals); #else 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 (s1_is_unicode & s2_is_unicode) { Py_ssize_t length, length2; int kind; void *data1, *data2; #if !CYTHON_COMPILING_IN_LIMITED_API if (unlikely(__Pyx_PyUnicode_READY(s1) < 0) || unlikely(__Pyx_PyUnicode_READY(s2) < 0)) return -1; #endif length = __Pyx_PyUnicode_GET_LENGTH(s1); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(length < 0)) return -1; #endif length2 = __Pyx_PyUnicode_GET_LENGTH(s2); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(length2 < 0)) return -1; #endif if (length != length2) { goto return_ne; } #if CYTHON_USE_UNICODE_INTERNALS { Py_hash_t hash1, hash2; hash1 = ((PyASCIIObject*)s1)->hash; hash2 = ((PyASCIIObject*)s2)->hash; 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)); 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_result) return -1; result = __Pyx_PyObject_IsTrue(py_result); Py_DECREF(py_result); return result; } return_eq: return (equals == Py_EQ); return_ne: return (equals == Py_NE); #endif } /* fastcall */ #if CYTHON_METH_FASTCALL static CYTHON_INLINE PyObject * __Pyx_GetKwValue_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues, PyObject *s) { Py_ssize_t i, n = __Pyx_PyTuple_GET_SIZE(kwnames); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(n == -1)) return NULL; #endif for (i = 0; i < n; i++) { PyObject *namei = __Pyx_PyTuple_GET_ITEM(kwnames, i); #if !CYTHON_ASSUME_SAFE_MACROS if (unlikely(!namei)) return NULL; #endif if (s == namei) return kwvalues[i]; } for (i = 0; i < n; i++) { PyObject *namei = __Pyx_PyTuple_GET_ITEM(kwnames, i); #if !CYTHON_ASSUME_SAFE_MACROS if (unlikely(!namei)) return NULL; #endif int eq = __Pyx_PyUnicode_Equals(s, namei, Py_EQ); if (unlikely(eq != 0)) { if (unlikely(eq < 0)) return NULL; return kwvalues[i]; } } return NULL; } #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030d0000 || CYTHON_COMPILING_IN_LIMITED_API CYTHON_UNUSED static PyObject *__Pyx_KwargsAsDict_FASTCALL(PyObject *kwnames, PyObject *const *kwvalues) { Py_ssize_t i, nkwargs; PyObject *dict; #if !CYTHON_ASSUME_SAFE_SIZE nkwargs = PyTuple_Size(kwnames); if (unlikely(nkwargs < 0)) return NULL; #else nkwargs = PyTuple_GET_SIZE(kwnames); #endif dict = PyDict_New(); if (unlikely(!dict)) return NULL; for (i=0; irecursion_depth; Py_DECREF(f); --tstate->recursion_depth; return result; } static PyObject *__Pyx_PyFunction_FastCallDict(PyObject *func, PyObject *const *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; PyObject *kwdefs; 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 (unlikely(Py_EnterRecursiveCall(" while calling a Python object"))) { return NULL; } if ( co->co_kwonlyargcount == 0 && 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); kwdefs = PyFunction_GET_KW_DEFAULTS(func); if (argdefs != NULL) { d = &PyTuple_GET_ITEM(argdefs, 0); nd = Py_SIZE(argdefs); } else { d = NULL; nd = 0; } result = PyEval_EvalCodeEx((PyObject*)co, globals, (PyObject *)NULL, args, (int)nargs, k, (int)nk, d, (int)nd, kwdefs, closure); Py_XDECREF(kwtuple); done: Py_LeaveRecursiveCall(); return result; } #endif /* PyObjectCall */ #if CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE PyObject* __Pyx_PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw) { PyObject *result; ternaryfunc call = Py_TYPE(func)->tp_call; if (unlikely(!call)) return PyObject_Call(func, arg, kw); if (unlikely(Py_EnterRecursiveCall(" 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 /* PyObjectCallMethO */ #if CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE PyObject* __Pyx_PyObject_CallMethO(PyObject *func, PyObject *arg) { PyObject *self, *result; PyCFunction cfunc; cfunc = __Pyx_CyOrPyCFunction_GET_FUNCTION(func); self = __Pyx_CyOrPyCFunction_GET_SELF(func); if (unlikely(Py_EnterRecursiveCall(" 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 /* PyObjectFastCall */ #if PY_VERSION_HEX < 0x03090000 || CYTHON_COMPILING_IN_LIMITED_API static PyObject* __Pyx_PyObject_FastCall_fallback(PyObject *func, PyObject * const*args, size_t nargs, PyObject *kwargs) { PyObject *argstuple; PyObject *result = 0; size_t i; argstuple = PyTuple_New((Py_ssize_t)nargs); if (unlikely(!argstuple)) return NULL; for (i = 0; i < nargs; i++) { Py_INCREF(args[i]); if (__Pyx_PyTuple_SET_ITEM(argstuple, (Py_ssize_t)i, args[i]) != (0)) goto bad; } result = __Pyx_PyObject_Call(func, argstuple, kwargs); bad: Py_DECREF(argstuple); return result; } #endif #if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API #if PY_VERSION_HEX < 0x03090000 #define __Pyx_PyVectorcall_Function(callable) _PyVectorcall_Function(callable) #elif CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE vectorcallfunc __Pyx_PyVectorcall_Function(PyObject *callable) { PyTypeObject *tp = Py_TYPE(callable); #if defined(__Pyx_CyFunction_USED) if (__Pyx_CyFunction_CheckExact(callable)) { return __Pyx_CyFunction_func_vectorcall(callable); } #endif if (!PyType_HasFeature(tp, Py_TPFLAGS_HAVE_VECTORCALL)) { return NULL; } assert(PyCallable_Check(callable)); Py_ssize_t offset = tp->tp_vectorcall_offset; assert(offset > 0); vectorcallfunc ptr; memcpy(&ptr, (char *) callable + offset, sizeof(ptr)); return ptr; } #else #define __Pyx_PyVectorcall_Function(callable) PyVectorcall_Function(callable) #endif #endif static CYTHON_INLINE PyObject* __Pyx_PyObject_FastCallDict(PyObject *func, PyObject *const *args, size_t _nargs, PyObject *kwargs) { Py_ssize_t nargs = __Pyx_PyVectorcall_NARGS(_nargs); #if CYTHON_COMPILING_IN_CPYTHON if (nargs == 0 && kwargs == NULL) { if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_NOARGS)) return __Pyx_PyObject_CallMethO(func, NULL); } else if (nargs == 1 && kwargs == NULL) { if (__Pyx_CyOrPyCFunction_Check(func) && likely( __Pyx_CyOrPyCFunction_GET_FLAGS(func) & METH_O)) return __Pyx_PyObject_CallMethO(func, args[0]); } #endif #if PY_VERSION_HEX < 0x030800B1 #if CYTHON_FAST_PYCCALL if (PyCFunction_Check(func)) { if (kwargs) { return _PyCFunction_FastCallDict(func, args, nargs, kwargs); } else { return _PyCFunction_FastCallKeywords(func, args, nargs, NULL); } } if (!kwargs && __Pyx_IS_TYPE(func, &PyMethodDescr_Type)) { return _PyMethodDescr_FastCallKeywords(func, args, nargs, NULL); } #endif #if CYTHON_FAST_PYCALL if (PyFunction_Check(func)) { return __Pyx_PyFunction_FastCallDict(func, args, nargs, kwargs); } #endif #endif if (kwargs == NULL) { #if CYTHON_VECTORCALL && !CYTHON_COMPILING_IN_LIMITED_API vectorcallfunc f = __Pyx_PyVectorcall_Function(func); if (f) { return f(func, args, _nargs, NULL); } #elif defined(__Pyx_CyFunction_USED) && CYTHON_BACKPORT_VECTORCALL if (__Pyx_CyFunction_CheckExact(func)) { __pyx_vectorcallfunc f = __Pyx_CyFunction_func_vectorcall(func); if (f) return f(func, args, _nargs, NULL); } #elif CYTHON_COMPILING_IN_LIMITED_API && CYTHON_VECTORCALL return PyObject_Vectorcall(func, args, _nargs, NULL); #endif } if (nargs == 0) { return __Pyx_PyObject_Call(func, __pyx_mstate_global->__pyx_empty_tuple, kwargs); } #if PY_VERSION_HEX >= 0x03090000 && !CYTHON_COMPILING_IN_LIMITED_API return PyObject_VectorcallDict(func, args, (size_t)nargs, kwargs); #else return __Pyx_PyObject_FastCall_fallback(func, args, (size_t)nargs, kwargs); #endif } /* UnpackUnboundCMethod */ #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030C0000 static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject *args, PyObject *kwargs) { PyObject *result; PyObject *selfless_args = PyTuple_GetSlice(args, 1, PyTuple_Size(args)); if (unlikely(!selfless_args)) return NULL; result = PyObject_Call(method, selfless_args, kwargs); Py_DECREF(selfless_args); return result; } #elif CYTHON_COMPILING_IN_PYPY && PY_VERSION_HEX < 0x03090000 static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject **args, Py_ssize_t nargs, PyObject *kwnames) { return _PyObject_Vectorcall (method, args ? args+1 : NULL, nargs ? nargs-1 : 0, kwnames); } #else static PyObject *__Pyx_SelflessCall(PyObject *method, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) { return #if PY_VERSION_HEX < 0x03090000 _PyObject_Vectorcall #else PyObject_Vectorcall #endif (method, args ? args+1 : NULL, nargs ? (size_t) nargs-1 : 0, kwnames); } #endif static PyMethodDef __Pyx_UnboundCMethod_Def = { "CythonUnboundCMethod", __PYX_REINTERPRET_FUNCION(PyCFunction, __Pyx_SelflessCall), #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030C0000 METH_VARARGS | METH_KEYWORDS, #else METH_FASTCALL | METH_KEYWORDS, #endif NULL }; static int __Pyx_TryUnpackUnboundCMethod(__Pyx_CachedCFunction* target) { PyObject *method, *result=NULL; method = __Pyx_PyObject_GetAttrStr(target->type, *target->method_name); if (unlikely(!method)) return -1; result = method; #if CYTHON_COMPILING_IN_CPYTHON if (likely(__Pyx_TypeCheck(method, &PyMethodDescr_Type))) { PyMethodDescrObject *descr = (PyMethodDescrObject*) method; target->func = descr->d_method->ml_meth; target->flag = descr->d_method->ml_flags & ~(METH_CLASS | METH_STATIC | METH_COEXIST | METH_STACKLESS); } else #endif #if CYTHON_COMPILING_IN_PYPY #else if (PyCFunction_Check(method)) #endif { PyObject *self; int self_found; #if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY self = PyObject_GetAttrString(method, "__self__"); if (!self) { PyErr_Clear(); } #else self = PyCFunction_GET_SELF(method); #endif self_found = (self && self != Py_None); #if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_COMPILING_IN_PYPY Py_XDECREF(self); #endif if (self_found) { PyObject *unbound_method = PyCFunction_New(&__Pyx_UnboundCMethod_Def, method); if (unlikely(!unbound_method)) return -1; Py_DECREF(method); result = unbound_method; } } #if !CYTHON_COMPILING_IN_CPYTHON_FREETHREADING if (unlikely(target->method)) { Py_DECREF(result); } else #endif target->method = result; return 0; } /* CallUnboundCMethod2 */ #if CYTHON_COMPILING_IN_CPYTHON static CYTHON_INLINE PyObject *__Pyx_CallUnboundCMethod2(__Pyx_CachedCFunction *cfunc, PyObject *self, PyObject *arg1, PyObject *arg2) { int was_initialized = __Pyx_CachedCFunction_GetAndSetInitializing(cfunc); if (likely(was_initialized == 2 && cfunc->func)) { PyObject *args[2] = {arg1, arg2}; if (cfunc->flag == METH_FASTCALL) { return __Pyx_CallCFunctionFast(cfunc, self, args, 2); } if (cfunc->flag == (METH_FASTCALL | METH_KEYWORDS)) return __Pyx_CallCFunctionFastWithKeywords(cfunc, self, args, 2, NULL); } #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING else if (unlikely(was_initialized == 1)) { __Pyx_CachedCFunction tmp_cfunc = { #ifndef __cplusplus 0 #endif }; tmp_cfunc.type = cfunc->type; tmp_cfunc.method_name = cfunc->method_name; return __Pyx__CallUnboundCMethod2(&tmp_cfunc, self, arg1, arg2); } #endif PyObject *result = __Pyx__CallUnboundCMethod2(cfunc, self, arg1, arg2); __Pyx_CachedCFunction_SetFinishedInitializing(cfunc); return result; } #endif static PyObject* __Pyx__CallUnboundCMethod2(__Pyx_CachedCFunction* cfunc, PyObject* self, PyObject* arg1, PyObject* arg2){ if (unlikely(!cfunc->func && !cfunc->method) && unlikely(__Pyx_TryUnpackUnboundCMethod(cfunc) < 0)) return NULL; #if CYTHON_COMPILING_IN_CPYTHON if (cfunc->func && (cfunc->flag & METH_VARARGS)) { PyObject *result = NULL; PyObject *args = PyTuple_New(2); if (unlikely(!args)) return NULL; Py_INCREF(arg1); PyTuple_SET_ITEM(args, 0, arg1); Py_INCREF(arg2); PyTuple_SET_ITEM(args, 1, arg2); if (cfunc->flag & METH_KEYWORDS) result = __Pyx_CallCFunctionWithKeywords(cfunc, self, args, NULL); else result = __Pyx_CallCFunction(cfunc, self, args); Py_DECREF(args); return result; } #endif { PyObject *args[4] = {NULL, self, arg1, arg2}; return __Pyx_PyObject_FastCall(cfunc->method, args+1, 3 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); } } /* ParseKeywords */ static int __Pyx_ValidateDuplicatePosArgs( PyObject *kwds, PyObject ** const argnames[], PyObject ** const *first_kw_arg, const char* function_name) { PyObject ** const *name = argnames; while (name != first_kw_arg) { PyObject *key = **name; int found = PyDict_Contains(kwds, key); if (unlikely(found)) { if (found == 1) __Pyx_RaiseDoubleKeywordsError(function_name, key); goto bad; } name++; } return 0; bad: return -1; } #if CYTHON_USE_UNICODE_INTERNALS static CYTHON_INLINE int __Pyx_UnicodeKeywordsEqual(PyObject *s1, PyObject *s2) { int kind; Py_ssize_t len = PyUnicode_GET_LENGTH(s1); if (len != PyUnicode_GET_LENGTH(s2)) return 0; kind = PyUnicode_KIND(s1); if (kind != PyUnicode_KIND(s2)) return 0; const void *data1 = PyUnicode_DATA(s1); const void *data2 = PyUnicode_DATA(s2); return (memcmp(data1, data2, (size_t) len * (size_t) kind) == 0); } #endif static int __Pyx_MatchKeywordArg_str( PyObject *key, PyObject ** const argnames[], PyObject ** const *first_kw_arg, size_t *index_found, const char *function_name) { PyObject ** const *name; #if CYTHON_USE_UNICODE_INTERNALS Py_hash_t key_hash = ((PyASCIIObject*)key)->hash; if (unlikely(key_hash == -1)) { key_hash = PyObject_Hash(key); if (unlikely(key_hash == -1)) goto bad; } #endif name = first_kw_arg; while (*name) { PyObject *name_str = **name; #if CYTHON_USE_UNICODE_INTERNALS if (key_hash == ((PyASCIIObject*)name_str)->hash && __Pyx_UnicodeKeywordsEqual(name_str, key)) { *index_found = (size_t) (name - argnames); return 1; } #else #if CYTHON_ASSUME_SAFE_SIZE if (PyUnicode_GET_LENGTH(name_str) == PyUnicode_GET_LENGTH(key)) #endif { int cmp = PyUnicode_Compare(name_str, key); if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; if (cmp == 0) { *index_found = (size_t) (name - argnames); return 1; } } #endif name++; } name = argnames; while (name != first_kw_arg) { PyObject *name_str = **name; #if CYTHON_USE_UNICODE_INTERNALS if (unlikely(key_hash == ((PyASCIIObject*)name_str)->hash)) { if (__Pyx_UnicodeKeywordsEqual(name_str, key)) goto arg_passed_twice; } #else #if CYTHON_ASSUME_SAFE_SIZE if (PyUnicode_GET_LENGTH(name_str) == PyUnicode_GET_LENGTH(key)) #endif { if (unlikely(name_str == key)) goto arg_passed_twice; int cmp = PyUnicode_Compare(name_str, key); if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; if (cmp == 0) goto arg_passed_twice; } #endif name++; } return 0; arg_passed_twice: __Pyx_RaiseDoubleKeywordsError(function_name, key); goto bad; bad: return -1; } static int __Pyx_MatchKeywordArg_nostr( PyObject *key, PyObject ** const argnames[], PyObject ** const *first_kw_arg, size_t *index_found, const char *function_name) { PyObject ** const *name; if (unlikely(!PyUnicode_Check(key))) goto invalid_keyword_type; name = first_kw_arg; while (*name) { int cmp = PyObject_RichCompareBool(**name, key, Py_EQ); if (cmp == 1) { *index_found = (size_t) (name - argnames); return 1; } if (unlikely(cmp == -1)) goto bad; name++; } name = argnames; while (name != first_kw_arg) { int cmp = PyObject_RichCompareBool(**name, key, Py_EQ); if (unlikely(cmp != 0)) { if (cmp == 1) goto arg_passed_twice; else goto bad; } name++; } 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; bad: return -1; } static CYTHON_INLINE int __Pyx_MatchKeywordArg( PyObject *key, PyObject ** const argnames[], PyObject ** const *first_kw_arg, size_t *index_found, const char *function_name) { return likely(PyUnicode_CheckExact(key)) ? __Pyx_MatchKeywordArg_str(key, argnames, first_kw_arg, index_found, function_name) : __Pyx_MatchKeywordArg_nostr(key, argnames, first_kw_arg, index_found, function_name); } static void __Pyx_RejectUnknownKeyword( PyObject *kwds, PyObject ** const argnames[], PyObject ** const *first_kw_arg, const char *function_name) { Py_ssize_t pos = 0; PyObject *key = NULL; __Pyx_BEGIN_CRITICAL_SECTION(kwds); while (PyDict_Next(kwds, &pos, &key, NULL)) { PyObject** const *name = first_kw_arg; while (*name && (**name != key)) name++; if (!*name) { #if CYTHON_AVOID_BORROWED_REFS Py_INCREF(key); #endif size_t index_found = 0; int cmp = __Pyx_MatchKeywordArg(key, argnames, first_kw_arg, &index_found, function_name); if (cmp != 1) { if (cmp == 0) { PyErr_Format(PyExc_TypeError, "%s() got an unexpected keyword argument '%U'", function_name, key); } #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(key); #endif break; } #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(key); #endif } } __Pyx_END_CRITICAL_SECTION(); assert(PyErr_Occurred()); } static int __Pyx_ParseKeywordDict( PyObject *kwds, PyObject ** const argnames[], PyObject *values[], Py_ssize_t num_pos_args, Py_ssize_t num_kwargs, const char* function_name, int ignore_unknown_kwargs) { PyObject** const *name; PyObject** const *first_kw_arg = argnames + num_pos_args; Py_ssize_t extracted = 0; #if !CYTHON_COMPILING_IN_PYPY || defined(PyArg_ValidateKeywordArguments) if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return -1; #endif name = first_kw_arg; while (*name && num_kwargs > extracted) { PyObject * key = **name; PyObject *value; int found = 0; #if __PYX_LIMITED_VERSION_HEX >= 0x030d0000 found = PyDict_GetItemRef(kwds, key, &value); #else value = PyDict_GetItemWithError(kwds, key); if (value) { Py_INCREF(value); found = 1; } else { if (unlikely(PyErr_Occurred())) goto bad; } #endif if (found) { if (unlikely(found < 0)) goto bad; values[name-argnames] = value; extracted++; } name++; } if (num_kwargs > extracted) { if (ignore_unknown_kwargs) { if (unlikely(__Pyx_ValidateDuplicatePosArgs(kwds, argnames, first_kw_arg, function_name) == -1)) goto bad; } else { __Pyx_RejectUnknownKeyword(kwds, argnames, first_kw_arg, function_name); goto bad; } } return 0; bad: return -1; } static int __Pyx_ParseKeywordDictToDict( PyObject *kwds, PyObject ** const argnames[], PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, const char* function_name) { PyObject** const *name; PyObject** const *first_kw_arg = argnames + num_pos_args; Py_ssize_t len; #if !CYTHON_COMPILING_IN_PYPY || defined(PyArg_ValidateKeywordArguments) if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return -1; #endif if (PyDict_Update(kwds2, kwds) < 0) goto bad; name = first_kw_arg; while (*name) { PyObject *key = **name; PyObject *value; #if !CYTHON_COMPILING_IN_LIMITED_API && (PY_VERSION_HEX >= 0x030d00A2 || defined(PyDict_Pop)) int found = PyDict_Pop(kwds2, key, &value); if (found) { if (unlikely(found < 0)) goto bad; values[name-argnames] = value; } #elif __PYX_LIMITED_VERSION_HEX >= 0x030d0000 int found = PyDict_GetItemRef(kwds2, key, &value); if (found) { if (unlikely(found < 0)) goto bad; values[name-argnames] = value; if (unlikely(PyDict_DelItem(kwds2, key) < 0)) goto bad; } #else #if CYTHON_COMPILING_IN_CPYTHON value = _PyDict_Pop(kwds2, key, kwds2); #else value = __Pyx_CallUnboundCMethod2(&__pyx_mstate_global->__pyx_umethod_PyDict_Type_pop, kwds2, key, kwds2); #endif if (value == kwds2) { Py_DECREF(value); } else { if (unlikely(!value)) goto bad; values[name-argnames] = value; } #endif name++; } len = PyDict_Size(kwds2); if (len > 0) { return __Pyx_ValidateDuplicatePosArgs(kwds, argnames, first_kw_arg, function_name); } else if (unlikely(len == -1)) { goto bad; } return 0; bad: return -1; } static int __Pyx_ParseKeywordsTuple( PyObject *kwds, PyObject * const *kwvalues, PyObject ** const argnames[], PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, Py_ssize_t num_kwargs, const char* function_name, int ignore_unknown_kwargs) { PyObject *key = NULL; PyObject** const * name; PyObject** const *first_kw_arg = argnames + num_pos_args; for (Py_ssize_t pos = 0; pos < num_kwargs; pos++) { #if CYTHON_AVOID_BORROWED_REFS key = __Pyx_PySequence_ITEM(kwds, pos); #else key = __Pyx_PyTuple_GET_ITEM(kwds, pos); #endif #if !CYTHON_ASSUME_SAFE_MACROS if (unlikely(!key)) goto bad; #endif name = first_kw_arg; while (*name && (**name != key)) name++; if (*name) { PyObject *value = kwvalues[pos]; values[name-argnames] = __Pyx_NewRef(value); } else { size_t index_found = 0; int cmp = __Pyx_MatchKeywordArg(key, argnames, first_kw_arg, &index_found, function_name); if (cmp == 1) { PyObject *value = kwvalues[pos]; values[index_found] = __Pyx_NewRef(value); } else { if (unlikely(cmp == -1)) goto bad; if (kwds2) { PyObject *value = kwvalues[pos]; if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad; } else if (!ignore_unknown_kwargs) { goto invalid_keyword; } } } #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(key); key = NULL; #endif } return 0; invalid_keyword: PyErr_Format(PyExc_TypeError, "%s() got an unexpected keyword argument '%U'", function_name, key); goto bad; bad: #if CYTHON_AVOID_BORROWED_REFS Py_XDECREF(key); #endif return -1; } static int __Pyx_ParseKeywords( PyObject *kwds, PyObject * const *kwvalues, PyObject ** const argnames[], PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, Py_ssize_t num_kwargs, const char* function_name, int ignore_unknown_kwargs) { if (CYTHON_METH_FASTCALL && likely(PyTuple_Check(kwds))) return __Pyx_ParseKeywordsTuple(kwds, kwvalues, argnames, kwds2, values, num_pos_args, num_kwargs, function_name, ignore_unknown_kwargs); else if (kwds2) return __Pyx_ParseKeywordDictToDict(kwds, argnames, kwds2, values, num_pos_args, function_name); else return __Pyx_ParseKeywordDict(kwds, argnames, values, num_pos_args, num_kwargs, function_name, ignore_unknown_kwargs); } /* 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); } /* RaiseException */ 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 PY_VERSION_HEX >= 0x030C00A6 PyException_SetTraceback(value, tb); #elif CYTHON_FAST_THREAD_STATE 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); } #else 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); #endif } bad: Py_XDECREF(owned_instance); return; } /* 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_COMPILING_IN_LIMITED_API if (unlikely(!__pyx_m)) { if (!PyErr_Occurred()) PyErr_SetNone(PyExc_NameError); return NULL; } result = PyObject_GetAttr(__pyx_m, name); if (likely(result)) { return result; } PyErr_Clear(); #elif CYTHON_AVOID_BORROWED_REFS || CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS if (unlikely(__Pyx_PyDict_GetItemRef(__pyx_mstate_global->__pyx_d, name, &result) == -1)) PyErr_Clear(); __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version) if (likely(result)) { return result; } #else result = _PyDict_GetItem_KnownHash(__pyx_mstate_global->__pyx_d, name, ((PyASCIIObject *) name)->hash); __PYX_UPDATE_DICT_CACHE(__pyx_mstate_global->__pyx_d, result, *dict_cached_value, *dict_version) if (likely(result)) { return __Pyx_NewRef(result); } PyErr_Clear(); #endif return __Pyx_GetBuiltinName(name); } /* PyObjectFastCallMethod */ #if !CYTHON_VECTORCALL || PY_VERSION_HEX < 0x03090000 static PyObject *__Pyx_PyObject_FastCallMethod(PyObject *name, PyObject *const *args, size_t nargsf) { PyObject *result; PyObject *attr = PyObject_GetAttr(args[0], name); if (unlikely(!attr)) return NULL; result = __Pyx_PyObject_FastCall(attr, args+1, nargsf - 1); Py_DECREF(attr); return result; } #endif /* ModInt[Py_ssize_t] */ static CYTHON_INLINE Py_ssize_t __Pyx_mod_Py_ssize_t(Py_ssize_t a, Py_ssize_t b, int b_is_constant) { Py_ssize_t r = a % b; Py_ssize_t adapt_python = (b_is_constant ? ((r != 0) & ((r < 0) ^ (b < 0))) : ((r != 0) & ((r ^ b) < 0)) ); return r + adapt_python * b; } /* 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 = NULL, *local_value, *local_tb = NULL; #if CYTHON_FAST_THREAD_STATE PyObject *tmp_type, *tmp_value, *tmp_tb; #if PY_VERSION_HEX >= 0x030C0000 local_value = tstate->current_exception; tstate->current_exception = 0; #else 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; #endif #elif __PYX_LIMITED_VERSION_HEX > 0x030C0000 local_value = PyErr_GetRaisedException(); #else PyErr_Fetch(&local_type, &local_value, &local_tb); #endif #if __PYX_LIMITED_VERSION_HEX > 0x030C0000 if (likely(local_value)) { local_type = (PyObject*) Py_TYPE(local_value); Py_INCREF(local_type); local_tb = PyException_GetTraceback(local_value); } #else 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 (local_tb) { if (unlikely(PyException_SetTraceback(local_value, local_tb) < 0)) goto bad; } #endif // __PYX_LIMITED_VERSION_HEX > 0x030C0000 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; #if PY_VERSION_HEX >= 0x030B00a4 tmp_value = exc_info->exc_value; exc_info->exc_value = local_value; tmp_type = NULL; tmp_tb = NULL; Py_XDECREF(local_type); Py_XDECREF(local_tb); #else 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; #endif } #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); #elif __PYX_LIMITED_VERSION_HEX >= 0x030b0000 PyErr_SetHandledException(local_value); Py_XDECREF(local_value); Py_XDECREF(local_type); Py_XDECREF(local_tb); #else PyErr_SetExcInfo(local_type, local_value, local_tb); #endif return 0; #if __PYX_LIMITED_VERSION_HEX <= 0x030C0000 bad: *type = 0; *value = 0; *tb = 0; Py_XDECREF(local_type); Py_XDECREF(local_value); Py_XDECREF(local_tb); return -1; #endif } /* 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 && PY_VERSION_HEX >= 0x030B00a4 _PyErr_StackItem *exc_info = tstate->exc_info; tmp_value = exc_info->exc_value; exc_info->exc_value = *value; if (tmp_value == NULL || tmp_value == Py_None) { Py_XDECREF(tmp_value); tmp_value = NULL; tmp_type = NULL; tmp_tb = NULL; } else { tmp_type = (PyObject*) Py_TYPE(tmp_value); Py_INCREF(tmp_type); #if CYTHON_COMPILING_IN_CPYTHON tmp_tb = ((PyBaseExceptionObject*) tmp_value)->traceback; Py_XINCREF(tmp_tb); #else tmp_tb = PyException_GetTraceback(tmp_value); #endif } #elif 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 && CYTHON_FAST_THREAD_STATE static _PyErr_StackItem * __Pyx_PyErr_GetTopmostException(PyThreadState *tstate) { _PyErr_StackItem *exc_info = tstate->exc_info; while ((exc_info->exc_value == NULL || exc_info->exc_value == 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 && PY_VERSION_HEX >= 0x030B00a4 _PyErr_StackItem *exc_info = __Pyx_PyErr_GetTopmostException(tstate); PyObject *exc_value = exc_info->exc_value; if (exc_value == NULL || exc_value == Py_None) { *value = NULL; *type = NULL; *tb = NULL; } else { *value = exc_value; Py_INCREF(*value); *type = (PyObject*) Py_TYPE(exc_value); Py_INCREF(*type); *tb = PyException_GetTraceback(exc_value); } #elif 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; Py_XINCREF(*type); Py_XINCREF(*value); Py_XINCREF(*tb); #else *type = tstate->exc_type; *value = tstate->exc_value; *tb = tstate->exc_traceback; Py_XINCREF(*type); Py_XINCREF(*value); Py_XINCREF(*tb); #endif } static CYTHON_INLINE void __Pyx__ExceptionReset(PyThreadState *tstate, PyObject *type, PyObject *value, PyObject *tb) { #if CYTHON_USE_EXC_INFO_STACK && PY_VERSION_HEX >= 0x030B00a4 _PyErr_StackItem *exc_info = tstate->exc_info; PyObject *tmp_value = exc_info->exc_value; exc_info->exc_value = value; Py_XDECREF(tmp_value); Py_XDECREF(type); Py_XDECREF(tb); #else 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 } #endif /* HasAttr */ #if __PYX_LIMITED_VERSION_HEX < 0x030d0000 static CYTHON_INLINE int __Pyx_HasAttr(PyObject *o, PyObject *n) { PyObject *r; if (unlikely(!PyUnicode_Check(n))) { PyErr_SetString(PyExc_TypeError, "hasattr(): attribute name must be string"); return -1; } r = __Pyx_PyObject_GetAttrStrNoError(o, n); if (!r) { return (unlikely(PyErr_Occurred())) ? -1 : 0; } else { Py_DECREF(r); return 1; } } #endif /* GetItemInt */ static PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) { PyObject *r; if (unlikely(!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_ASSUME_SAFE_SIZE && !CYTHON_AVOID_BORROWED_REFS && !CYTHON_AVOID_THREAD_UNSAFE_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, PyLong_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_ASSUME_SAFE_SIZE && !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, PyLong_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_ASSUME_SAFE_SIZE && !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))))) { return __Pyx_PyList_GetItemRef(o, n); } } 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 { PyMappingMethods *mm = Py_TYPE(o)->tp_as_mapping; PySequenceMethods *sm = Py_TYPE(o)->tp_as_sequence; if (mm && mm->mp_subscript) { PyObject *r, *key = PyLong_FromSsize_t(i); if (unlikely(!key)) return NULL; r = mm->mp_subscript(o, key); Py_DECREF(key); return r; } if (likely(sm && sm->sq_item)) { if (wraparound && unlikely(i < 0) && likely(sm->sq_length)) { Py_ssize_t l = sm->sq_length(o); if (likely(l >= 0)) { i += l; } else { if (!PyErr_ExceptionMatches(PyExc_OverflowError)) return NULL; PyErr_Clear(); } } return sm->sq_item(o, i); } } #else if (is_list || !PyMapping_Check(o)) { return PySequence_GetItem(o, i); } #endif return __Pyx_GetItemInt_Generic(o, PyLong_FromSsize_t(i)); } /* ArgTypeTest */ static int __Pyx__ArgTypeTest(PyObject *obj, PyTypeObject *type, const char *name, int exact) { __Pyx_TypeName type_name; __Pyx_TypeName obj_type_name; PyObject *extra_info = __pyx_mstate_global->__pyx_empty_unicode; int from_annotation_subclass = 0; if (unlikely(!type)) { PyErr_SetString(PyExc_SystemError, "Missing type object"); return 0; } else if (!exact) { if (likely(__Pyx_TypeCheck(obj, type))) return 1; } else if (exact == 2) { if (__Pyx_TypeCheck(obj, type)) { from_annotation_subclass = 1; extra_info = __pyx_mstate_global->__pyx_kp_u_Note_that_Cython_is_deliberately; } } type_name = __Pyx_PyType_GetFullyQualifiedName(type); obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj)); PyErr_Format(PyExc_TypeError, "Argument '%.200s' has incorrect type (expected " __Pyx_FMT_TYPENAME ", got " __Pyx_FMT_TYPENAME ")" #if __PYX_LIMITED_VERSION_HEX < 0x030C0000 "%s%U" #endif , name, type_name, obj_type_name #if __PYX_LIMITED_VERSION_HEX < 0x030C0000 , (from_annotation_subclass ? ". " : ""), extra_info #endif ); #if __PYX_LIMITED_VERSION_HEX >= 0x030C0000 if (exact == 2 && from_annotation_subclass) { PyObject *res; PyObject *vargs[2]; vargs[0] = PyErr_GetRaisedException(); vargs[1] = extra_info; res = PyObject_VectorcallMethod(__pyx_mstate_global->__pyx_kp_u_add_note, vargs, 2, NULL); Py_XDECREF(res); PyErr_SetRaisedException(vargs[0]); } #endif __Pyx_DECREF_TypeName(type_name); __Pyx_DECREF_TypeName(obj_type_name); return 0; } /* DivInt[int] */ static CYTHON_INLINE int __Pyx_div_int(int a, int b, int b_is_constant) { int q = a / b; int r = a - q*b; int adapt_python = (b_is_constant ? ((r != 0) & ((r < 0) ^ (b < 0))) : ((r != 0) & ((r ^ b) < 0)) ); return q - adapt_python; } /* PyObjectVectorCallKwBuilder */ #if CYTHON_VECTORCALL static int __Pyx_VectorcallBuilder_AddArg(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { (void)__Pyx_PyObject_FastCallDict; if (__Pyx_PyTuple_SET_ITEM(builder, n, key) != (0)) return -1; Py_INCREF(key); args[n] = value; return 0; } CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, PyObject **args, int n) { (void)__Pyx_VectorcallBuilder_AddArgStr; if (unlikely(!PyUnicode_Check(key))) { PyErr_SetString(PyExc_TypeError, "keywords must be strings"); return -1; } return __Pyx_VectorcallBuilder_AddArg(key, value, builder, args, n); } static int __Pyx_VectorcallBuilder_AddArgStr(const char *key, PyObject *value, PyObject *builder, PyObject **args, int n) { PyObject *pyKey = PyUnicode_FromString(key); if (!pyKey) return -1; return __Pyx_VectorcallBuilder_AddArg(pyKey, value, builder, args, n); } #else // CYTHON_VECTORCALL CYTHON_UNUSED static int __Pyx_VectorcallBuilder_AddArg_Check(PyObject *key, PyObject *value, PyObject *builder, CYTHON_UNUSED PyObject **args, CYTHON_UNUSED int n) { if (unlikely(!PyUnicode_Check(key))) { PyErr_SetString(PyExc_TypeError, "keywords must be strings"); return -1; } return PyDict_SetItem(builder, key, value); } #endif /* 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) { __Pyx_TypeName obj_type_name; #if CYTHON_USE_TYPE_SLOTS PyMappingMethods* 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 = PyLong_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 = PyLong_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; } obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj)); PyErr_Format(PyExc_TypeError, "'" __Pyx_FMT_TYPENAME "' object is unsliceable", obj_type_name); __Pyx_DECREF_TypeName(obj_type_name); bad: return NULL; } /* UnicodeConcatInPlace */ # if CYTHON_COMPILING_IN_CPYTHON static int __Pyx_unicode_modifiable(PyObject *unicode) { if (Py_REFCNT(unicode) != 1) return 0; if (!PyUnicode_CheckExact(unicode)) return 0; if (PyUnicode_CHECK_INTERNED(unicode)) return 0; return 1; } static CYTHON_INLINE PyObject *__Pyx_PyUnicode_ConcatInPlaceImpl(PyObject **p_left, PyObject *right #if CYTHON_REFNANNY , void* __pyx_refnanny #endif ) { PyObject *left = *p_left; Py_ssize_t left_len, right_len, new_len; if (unlikely(__Pyx_PyUnicode_READY(left) == -1)) return NULL; if (unlikely(__Pyx_PyUnicode_READY(right) == -1)) return NULL; left_len = PyUnicode_GET_LENGTH(left); if (left_len == 0) { Py_INCREF(right); return right; } right_len = PyUnicode_GET_LENGTH(right); if (right_len == 0) { Py_INCREF(left); return left; } if (unlikely(left_len > PY_SSIZE_T_MAX - right_len)) { PyErr_SetString(PyExc_OverflowError, "strings are too large to concat"); return NULL; } new_len = left_len + right_len; if (__Pyx_unicode_modifiable(left) && PyUnicode_CheckExact(right) && PyUnicode_KIND(right) <= PyUnicode_KIND(left) && !(PyUnicode_IS_ASCII(left) && !PyUnicode_IS_ASCII(right))) { int ret; __Pyx_GIVEREF(*p_left); ret = PyUnicode_Resize(p_left, new_len); __Pyx_GOTREF(*p_left); if (unlikely(ret != 0)) return NULL; #if PY_VERSION_HEX >= 0x030d0000 if (unlikely(PyUnicode_CopyCharacters(*p_left, left_len, right, 0, right_len) < 0)) return NULL; #else _PyUnicode_FastCopyCharacters(*p_left, left_len, right, 0, right_len); #endif __Pyx_INCREF(*p_left); __Pyx_GIVEREF(*p_left); return *p_left; } else { return __Pyx_PyUnicode_Concat(left, right); } } #endif /* PyUnicode_Substring */ static CYTHON_INLINE PyObject* __Pyx_PyUnicode_Substring( PyObject* text, Py_ssize_t start, Py_ssize_t stop) { Py_ssize_t length; #if !CYTHON_COMPILING_IN_LIMITED_API if (unlikely(__Pyx_PyUnicode_READY(text) == -1)) return NULL; #endif length = __Pyx_PyUnicode_GET_LENGTH(text); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(length < 0)) return NULL; #endif 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_mstate_global->__pyx_empty_unicode); if (start == 0 && stop == length) return __Pyx_NewRef(text); #if CYTHON_COMPILING_IN_LIMITED_API return PyUnicode_Substring(text, start, stop); #else return PyUnicode_FromKindAndData(PyUnicode_KIND(text), PyUnicode_1BYTE_DATA(text) + start*PyUnicode_KIND(text), stop-start); #endif } /* RaiseTooManyValuesToUnpack */ static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected) { PyErr_Format(PyExc_ValueError, "too many values to unpack (expected %" CYTHON_FORMAT_SSIZE_T "d)", expected); } /* RaiseNeedMoreValuesToUnpack */ static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index) { PyErr_Format(PyExc_ValueError, "need more than %" CYTHON_FORMAT_SSIZE_T "d value%.1s to unpack", index, (index == 1) ? "" : "s"); } /* IterFinish */ static CYTHON_INLINE int __Pyx_IterFinish(void) { PyObject* exc_type; __Pyx_PyThreadState_declare __Pyx_PyThreadState_assign exc_type = __Pyx_PyErr_CurrentExceptionType(); if (unlikely(exc_type)) { if (unlikely(!__Pyx_PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) return -1; __Pyx_PyErr_Clear(); return 0; } return 0; } /* UnpackItemEndCheck */ static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected) { if (unlikely(retval)) { Py_DECREF(retval); __Pyx_RaiseTooManyValuesError(expected); return -1; } return __Pyx_IterFinish(); } /* RejectKeywords */ static void __Pyx_RejectKeywords(const char* function_name, PyObject *kwds) { PyObject *key = NULL; if (CYTHON_METH_FASTCALL && likely(PyTuple_Check(kwds))) { key = __Pyx_PySequence_ITEM(kwds, 0); } else { Py_ssize_t pos = 0; #if !CYTHON_COMPILING_IN_PYPY || defined(PyArg_ValidateKeywordArguments) if (unlikely(!PyArg_ValidateKeywordArguments(kwds))) return; #endif PyDict_Next(kwds, &pos, &key, NULL); Py_INCREF(key); } if (likely(key)) { PyErr_Format(PyExc_TypeError, "%s() got an unexpected keyword argument '%U'", function_name, key); Py_DECREF(key); } } /* PySequenceMultiply */ static PyObject* __Pyx_PySequence_Multiply_Generic(PyObject *seq, Py_ssize_t mul) { PyObject *result, *pymul = PyLong_FromSsize_t(mul); if (unlikely(!pymul)) return NULL; result = PyNumber_Multiply(seq, pymul); Py_DECREF(pymul); return result; } static CYTHON_INLINE PyObject* __Pyx_PySequence_Multiply(PyObject *seq, Py_ssize_t mul) { #if CYTHON_USE_TYPE_SLOTS PyTypeObject *type = Py_TYPE(seq); if (likely(type->tp_as_sequence && type->tp_as_sequence->sq_repeat)) { return type->tp_as_sequence->sq_repeat(seq, mul); } else #endif { return __Pyx_PySequence_Multiply_Generic(seq, mul); } } /* ExtTypeTest */ static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type) { __Pyx_TypeName obj_type_name; __Pyx_TypeName type_name; if (unlikely(!type)) { PyErr_SetString(PyExc_SystemError, "Missing type object"); return 0; } if (likely(__Pyx_TypeCheck(obj, type))) return 1; obj_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(obj)); type_name = __Pyx_PyType_GetFullyQualifiedName(type); PyErr_Format(PyExc_TypeError, "Cannot convert " __Pyx_FMT_TYPENAME " to " __Pyx_FMT_TYPENAME, obj_type_name, type_name); __Pyx_DECREF_TypeName(obj_type_name); __Pyx_DECREF_TypeName(type_name); return 0; } /* PyObjectCallNoArg */ static CYTHON_INLINE PyObject* __Pyx_PyObject_CallNoArg(PyObject *func) { PyObject *arg[2] = {NULL, NULL}; return __Pyx_PyObject_FastCall(func, arg + 1, 0 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); } /* PyObjectCallOneArg */ static CYTHON_INLINE PyObject* __Pyx_PyObject_CallOneArg(PyObject *func, PyObject *arg) { PyObject *args[2] = {NULL, arg}; return __Pyx_PyObject_FastCall(func, args+1, 1 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET); } /* 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 __Pyx_TypeName type_name; 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 defined(Py_TPFLAGS_METHOD_DESCRIPTOR) && Py_TPFLAGS_METHOD_DESCRIPTOR if (__Pyx_PyType_HasFeature(Py_TYPE(descr), Py_TPFLAGS_METHOD_DESCRIPTOR)) #else #ifdef __Pyx_CyFunction_USED if (likely(PyFunction_Check(descr) || __Pyx_IS_TYPE(descr, &PyMethodDescr_Type) || __Pyx_CyFunction_Check(descr))) #else if (likely(PyFunction_Check(descr) || __Pyx_IS_TYPE(descr, &PyMethodDescr_Type))) #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 (likely(descr != NULL)) { *method = descr; return 0; } type_name = __Pyx_PyType_GetFullyQualifiedName(tp); PyErr_Format(PyExc_AttributeError, "'" __Pyx_FMT_TYPENAME "' object has no attribute '%U'", type_name, name); __Pyx_DECREF_TypeName(type_name); 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; } /* PyObjectCallMethod0 */ static PyObject* __Pyx_PyObject_CallMethod0(PyObject* obj, PyObject* method_name) { #if CYTHON_VECTORCALL && (__PYX_LIMITED_VERSION_HEX >= 0x030C0000 || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x03090000)) PyObject *args[1] = {obj}; (void) __Pyx_PyObject_GetMethod; (void) __Pyx_PyObject_CallOneArg; (void) __Pyx_PyObject_CallNoArg; return PyObject_VectorcallMethod(method_name, args, 1 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL); #else PyObject *method = NULL, *result = NULL; int is_method = __Pyx_PyObject_GetMethod(obj, method_name, &method); if (likely(is_method)) { result = __Pyx_PyObject_CallOneArg(method, obj); Py_DECREF(method); return result; } if (unlikely(!method)) goto bad; result = __Pyx_PyObject_CallNoArg(method); Py_DECREF(method); bad: return result; #endif } /* RaiseNoneIterError */ static CYTHON_INLINE void __Pyx_RaiseNoneNotIterableError(void) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); } /* UnpackTupleError */ static void __Pyx_UnpackTupleError(PyObject *t, Py_ssize_t index) { if (t == Py_None) { __Pyx_RaiseNoneNotIterableError(); } else { Py_ssize_t size = __Pyx_PyTuple_GET_SIZE(t); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(size < 0)) return; #endif if (size < index) { __Pyx_RaiseNeedMoreValuesError(size); } else { __Pyx_RaiseTooManyValuesError(index); } } } /* UnpackTuple2 */ static CYTHON_INLINE int __Pyx_unpack_tuple2( PyObject* tuple, PyObject** value1, PyObject** value2, int is_tuple, int has_known_size, int decref_tuple) { if (likely(is_tuple || PyTuple_Check(tuple))) { Py_ssize_t size; if (has_known_size) { return __Pyx_unpack_tuple2_exact(tuple, value1, value2, decref_tuple); } size = __Pyx_PyTuple_GET_SIZE(tuple); if (likely(size == 2)) { return __Pyx_unpack_tuple2_exact(tuple, value1, value2, decref_tuple); } if (size >= 0) { __Pyx_UnpackTupleError(tuple, 2); } return -1; } else { return __Pyx_unpack_tuple2_generic(tuple, value1, value2, has_known_size, decref_tuple); } } static CYTHON_INLINE int __Pyx_unpack_tuple2_exact( PyObject* tuple, PyObject** pvalue1, PyObject** pvalue2, int decref_tuple) { PyObject *value1 = NULL, *value2 = NULL; #if CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS value1 = __Pyx_PySequence_ITEM(tuple, 0); if (unlikely(!value1)) goto bad; value2 = __Pyx_PySequence_ITEM(tuple, 1); if (unlikely(!value2)) goto bad; #else value1 = PyTuple_GET_ITEM(tuple, 0); Py_INCREF(value1); value2 = PyTuple_GET_ITEM(tuple, 1); Py_INCREF(value2); #endif if (decref_tuple) { Py_DECREF(tuple); } *pvalue1 = value1; *pvalue2 = value2; return 0; #if CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS bad: Py_XDECREF(value1); Py_XDECREF(value2); if (decref_tuple) { Py_XDECREF(tuple); } return -1; #endif } static int __Pyx_unpack_tuple2_generic(PyObject* tuple, PyObject** pvalue1, PyObject** pvalue2, int has_known_size, int decref_tuple) { Py_ssize_t index; PyObject *value1 = NULL, *value2 = NULL, *iter = NULL; iternextfunc iternext; iter = PyObject_GetIter(tuple); if (unlikely(!iter)) goto bad; if (decref_tuple) { Py_DECREF(tuple); tuple = NULL; } iternext = __Pyx_PyObject_GetIterNextFunc(iter); value1 = iternext(iter); if (unlikely(!value1)) { index = 0; goto unpacking_failed; } value2 = iternext(iter); if (unlikely(!value2)) { index = 1; goto unpacking_failed; } if (!has_known_size && unlikely(__Pyx_IternextUnpackEndCheck(iternext(iter), 2))) goto bad; Py_DECREF(iter); *pvalue1 = value1; *pvalue2 = value2; return 0; unpacking_failed: if (!has_known_size && __Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); bad: Py_XDECREF(iter); Py_XDECREF(value1); Py_XDECREF(value2); if (decref_tuple) { Py_XDECREF(tuple); } return -1; } /* dict_iter */ #if CYTHON_COMPILING_IN_PYPY #include #endif static CYTHON_INLINE PyObject* __Pyx_dict_iterator(PyObject* iterable, int is_dict, PyObject* method_name, Py_ssize_t* p_orig_length, int* p_source_is_dict) { is_dict = is_dict || likely(PyDict_CheckExact(iterable)); *p_source_is_dict = is_dict; if (is_dict) { #if !CYTHON_COMPILING_IN_PYPY *p_orig_length = PyDict_Size(iterable); Py_INCREF(iterable); return iterable; #else static PyObject *py_items = NULL, *py_keys = NULL, *py_values = NULL; PyObject **pp = NULL; if (method_name) { const char *name = PyUnicode_AsUTF8(method_name); if (strcmp(name, "iteritems") == 0) pp = &py_items; else if (strcmp(name, "iterkeys") == 0) pp = &py_keys; else if (strcmp(name, "itervalues") == 0) pp = &py_values; if (pp) { if (!*pp) { *pp = PyUnicode_FromString(name + 4); if (!*pp) return NULL; } method_name = *pp; } } #endif } *p_orig_length = 0; if (method_name) { PyObject* iter; iterable = __Pyx_PyObject_CallMethod0(iterable, method_name); if (!iterable) return NULL; #if !CYTHON_COMPILING_IN_PYPY if (PyTuple_CheckExact(iterable) || PyList_CheckExact(iterable)) return iterable; #endif iter = PyObject_GetIter(iterable); Py_DECREF(iterable); return iter; } return PyObject_GetIter(iterable); } #if !CYTHON_COMPILING_IN_PYPY static CYTHON_INLINE int __Pyx_dict_iter_next_source_is_dict( PyObject* iter_obj, CYTHON_NCP_UNUSED Py_ssize_t orig_length, CYTHON_NCP_UNUSED Py_ssize_t* ppos, PyObject** pkey, PyObject** pvalue, PyObject** pitem) { PyObject *key, *value; if (unlikely(orig_length != PyDict_Size(iter_obj))) { PyErr_SetString(PyExc_RuntimeError, "dictionary changed size during iteration"); return -1; } if (unlikely(!PyDict_Next(iter_obj, ppos, &key, &value))) { return 0; } if (pitem) { PyObject* tuple = PyTuple_New(2); if (unlikely(!tuple)) { return -1; } Py_INCREF(key); Py_INCREF(value); #if CYTHON_ASSUME_SAFE_MACROS PyTuple_SET_ITEM(tuple, 0, key); PyTuple_SET_ITEM(tuple, 1, value); #else if (unlikely(PyTuple_SetItem(tuple, 0, key) < 0)) { Py_DECREF(value); Py_DECREF(tuple); return -1; } if (unlikely(PyTuple_SetItem(tuple, 1, value) < 0)) { Py_DECREF(tuple); return -1; } #endif *pitem = tuple; } else { if (pkey) { Py_INCREF(key); *pkey = key; } if (pvalue) { Py_INCREF(value); *pvalue = value; } } return 1; } #endif static CYTHON_INLINE int __Pyx_dict_iter_next( PyObject* iter_obj, CYTHON_NCP_UNUSED Py_ssize_t orig_length, CYTHON_NCP_UNUSED Py_ssize_t* ppos, PyObject** pkey, PyObject** pvalue, PyObject** pitem, int source_is_dict) { PyObject* next_item; #if !CYTHON_COMPILING_IN_PYPY if (source_is_dict) { int result; #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API Py_BEGIN_CRITICAL_SECTION(iter_obj); #endif result = __Pyx_dict_iter_next_source_is_dict(iter_obj, orig_length, ppos, pkey, pvalue, pitem); #if PY_VERSION_HEX >= 0x030d0000 && !CYTHON_COMPILING_IN_LIMITED_API Py_END_CRITICAL_SECTION(); #endif return result; } else if (PyTuple_CheckExact(iter_obj)) { Py_ssize_t pos = *ppos; Py_ssize_t tuple_size = __Pyx_PyTuple_GET_SIZE(iter_obj); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(tuple_size < 0)) return -1; #endif if (unlikely(pos >= tuple_size)) return 0; *ppos = pos + 1; #if CYTHON_ASSUME_SAFE_MACROS next_item = PyTuple_GET_ITEM(iter_obj, pos); #else next_item = PyTuple_GetItem(iter_obj, pos); if (unlikely(!next_item)) return -1; #endif Py_INCREF(next_item); } else if (PyList_CheckExact(iter_obj)) { Py_ssize_t pos = *ppos; Py_ssize_t list_size = __Pyx_PyList_GET_SIZE(iter_obj); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(list_size < 0)) return -1; #endif if (unlikely(pos >= list_size)) return 0; *ppos = pos + 1; #if CYTHON_AVOID_THREAD_UNSAFE_BORROWED_REFS next_item = PyList_GetItemRef(iter_obj, pos); if (unlikely(!next_item)) return -1; #elif CYTHON_ASSUME_SAFE_MACROS next_item = PyList_GET_ITEM(iter_obj, pos); Py_INCREF(next_item); #else next_item = PyList_GetItem(iter_obj, pos); if (unlikely(!next_item)) return -1; Py_INCREF(next_item); #endif } else #endif { next_item = PyIter_Next(iter_obj); if (unlikely(!next_item)) { return __Pyx_IterFinish(); } } if (pitem) { *pitem = next_item; } else if (pkey && pvalue) { if (__Pyx_unpack_tuple2(next_item, pkey, pvalue, source_is_dict, source_is_dict, 1)) return -1; } else if (pkey) { *pkey = next_item; } else { *pvalue = next_item; } return 1; } /* CIntToDigits */ static const char DIGIT_PAIRS_10[2*10*10+1] = { "00010203040506070809" "10111213141516171819" "20212223242526272829" "30313233343536373839" "40414243444546474849" "50515253545556575859" "60616263646566676869" "70717273747576777879" "80818283848586878889" "90919293949596979899" }; static const char DIGIT_PAIRS_8[2*8*8+1] = { "0001020304050607" "1011121314151617" "2021222324252627" "3031323334353637" "4041424344454647" "5051525354555657" "6061626364656667" "7071727374757677" }; static const char DIGITS_HEX[2*16+1] = { "0123456789abcdef" "0123456789ABCDEF" }; /* BuildPyUnicode */ static PyObject* __Pyx_PyUnicode_BuildFromAscii(Py_ssize_t ulength, const char* chars, int clength, int prepend_sign, char padding_char) { PyObject *uval; Py_ssize_t uoffset = ulength - clength; #if CYTHON_USE_UNICODE_INTERNALS Py_ssize_t i; void *udata; uval = PyUnicode_New(ulength, 127); if (unlikely(!uval)) return NULL; udata = PyUnicode_DATA(uval); if (uoffset > 0) { i = 0; if (prepend_sign) { __Pyx_PyUnicode_WRITE(PyUnicode_1BYTE_KIND, udata, 0, '-'); i++; } for (; i < uoffset; i++) { __Pyx_PyUnicode_WRITE(PyUnicode_1BYTE_KIND, udata, i, padding_char); } } for (i=0; i < clength; i++) { __Pyx_PyUnicode_WRITE(PyUnicode_1BYTE_KIND, udata, uoffset+i, chars[i]); } #else { PyObject *sign = NULL, *padding = NULL; uval = NULL; if (uoffset > 0) { prepend_sign = !!prepend_sign; if (uoffset > prepend_sign) { padding = PyUnicode_FromOrdinal(padding_char); if (likely(padding) && uoffset > prepend_sign + 1) { PyObject *tmp = PySequence_Repeat(padding, uoffset - prepend_sign); Py_DECREF(padding); padding = tmp; } if (unlikely(!padding)) goto done_or_error; } if (prepend_sign) { sign = PyUnicode_FromOrdinal('-'); if (unlikely(!sign)) goto done_or_error; } } uval = PyUnicode_DecodeASCII(chars, clength, NULL); if (likely(uval) && padding) { PyObject *tmp = PyUnicode_Concat(padding, uval); Py_DECREF(uval); uval = tmp; } if (likely(uval) && sign) { PyObject *tmp = PyUnicode_Concat(sign, uval); Py_DECREF(uval); uval = tmp; } done_or_error: Py_XDECREF(padding); Py_XDECREF(sign); } #endif return uval; } /* COrdinalToPyUnicode */ static CYTHON_INLINE int __Pyx_CheckUnicodeValue(int value) { return value <= 1114111; } static PyObject* __Pyx_PyUnicode_FromOrdinal_Padded(int value, Py_ssize_t ulength, char padding_char) { if (likely(ulength <= 250)) { char chars[256]; if (value <= 255) { memset(chars, padding_char, (size_t) (ulength - 1)); chars[ulength-1] = (char) value; return PyUnicode_DecodeLatin1(chars, ulength, NULL); } char *cpos = chars + sizeof(chars); if (value < 0x800) { *--cpos = (char) (0x80 | (value & 0x3f)); value >>= 6; *--cpos = (char) (0xc0 | (value & 0x1f)); } else if (value < 0x10000) { *--cpos = (char) (0x80 | (value & 0x3f)); value >>= 6; *--cpos = (char) (0x80 | (value & 0x3f)); value >>= 6; *--cpos = (char) (0xe0 | (value & 0x0f)); } else { *--cpos = (char) (0x80 | (value & 0x3f)); value >>= 6; *--cpos = (char) (0x80 | (value & 0x3f)); value >>= 6; *--cpos = (char) (0x80 | (value & 0x3f)); value >>= 6; *--cpos = (char) (0xf0 | (value & 0x07)); } cpos -= ulength; memset(cpos, padding_char, (size_t) (ulength - 1)); return PyUnicode_DecodeUTF8(cpos, chars + sizeof(chars) - cpos, NULL); } if (value <= 127 && CYTHON_USE_UNICODE_INTERNALS) { const char chars[1] = {(char) value}; return __Pyx_PyUnicode_BuildFromAscii(ulength, chars, 1, 0, padding_char); } { PyObject *uchar, *padding_uchar, *padding, *result; padding_uchar = PyUnicode_FromOrdinal(padding_char); if (unlikely(!padding_uchar)) return NULL; padding = PySequence_Repeat(padding_uchar, ulength - 1); Py_DECREF(padding_uchar); if (unlikely(!padding)) return NULL; uchar = PyUnicode_FromOrdinal(value); if (unlikely(!uchar)) { Py_DECREF(padding); return NULL; } result = PyUnicode_Concat(padding, uchar); Py_DECREF(padding); Py_DECREF(uchar); return result; } } /* CIntToPyUnicode */ static CYTHON_INLINE PyObject* __Pyx_PyUnicode_From_int(int value, Py_ssize_t width, char padding_char, char format_char) { char digits[sizeof(int)*3+2]; char *dpos, *end = digits + sizeof(int)*3+2; const char *hex_digits = DIGITS_HEX; Py_ssize_t length, ulength; int prepend_sign, last_one_off; int remaining; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const int neg_one = (int) -1, const_zero = (int) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (format_char == 'c') { if (unlikely(!(is_unsigned || value == 0 || value > 0) || !(sizeof(value) <= 2 || value & ~ (int) 0x01fffff || __Pyx_CheckUnicodeValue((int) value)))) { PyErr_SetString(PyExc_OverflowError, "%c arg not in range(0x110000)"); return NULL; } if (width <= 1) { return PyUnicode_FromOrdinal((int) value); } return __Pyx_PyUnicode_FromOrdinal_Padded((int) value, width, padding_char); } if (format_char == 'X') { hex_digits += 16; format_char = 'x'; } remaining = value; last_one_off = 0; dpos = end; do { int digit_pos; switch (format_char) { case 'o': digit_pos = abs((int)(remaining % (8*8))); remaining = (int) (remaining / (8*8)); dpos -= 2; memcpy(dpos, DIGIT_PAIRS_8 + digit_pos * 2, 2); last_one_off = (digit_pos < 8); break; case 'd': digit_pos = abs((int)(remaining % (10*10))); remaining = (int) (remaining / (10*10)); dpos -= 2; memcpy(dpos, DIGIT_PAIRS_10 + digit_pos * 2, 2); last_one_off = (digit_pos < 10); break; case 'x': *(--dpos) = hex_digits[abs((int)(remaining % 16))]; remaining = (int) (remaining / 16); break; default: assert(0); break; } } while (unlikely(remaining != 0)); assert(!last_one_off || *dpos == '0'); dpos += last_one_off; length = end - dpos; ulength = length; prepend_sign = 0; if (!is_unsigned && value <= neg_one) { if (padding_char == ' ' || width <= length + 1) { *(--dpos) = '-'; ++length; } else { prepend_sign = 1; } ++ulength; } if (width > ulength) { ulength = width; } if (ulength == 1) { return PyUnicode_FromOrdinal(*dpos); } return __Pyx_PyUnicode_BuildFromAscii(ulength, dpos, (int) length, prepend_sign, padding_char); } /* JoinPyUnicode */ static PyObject* __Pyx_PyUnicode_Join(PyObject** values, Py_ssize_t value_count, Py_ssize_t result_ulength, Py_UCS4 max_char) { #if CYTHON_USE_UNICODE_INTERNALS && CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS PyObject *result_uval; int result_ukind, kind_shift; Py_ssize_t i, char_pos; void *result_udata; if (max_char > 1114111) max_char = 1114111; result_uval = PyUnicode_New(result_ulength, max_char); if (unlikely(!result_uval)) return NULL; result_ukind = (max_char <= 255) ? PyUnicode_1BYTE_KIND : (max_char <= 65535) ? PyUnicode_2BYTE_KIND : PyUnicode_4BYTE_KIND; kind_shift = (result_ukind == PyUnicode_4BYTE_KIND) ? 2 : result_ukind - 1; result_udata = PyUnicode_DATA(result_uval); assert(kind_shift == 2 || kind_shift == 1 || kind_shift == 0); if (unlikely((PY_SSIZE_T_MAX >> kind_shift) - result_ulength < 0)) goto overflow; char_pos = 0; for (i=0; i < value_count; i++) { int ukind; Py_ssize_t ulength; void *udata; PyObject *uval = values[i]; #if !CYTHON_COMPILING_IN_LIMITED_API if (__Pyx_PyUnicode_READY(uval) == (-1)) goto bad; #endif ulength = __Pyx_PyUnicode_GET_LENGTH(uval); #if !CYTHON_ASSUME_SAFE_SIZE if (unlikely(ulength < 0)) goto bad; #endif if (unlikely(!ulength)) continue; if (unlikely((PY_SSIZE_T_MAX >> kind_shift) - ulength < char_pos)) goto overflow; ukind = __Pyx_PyUnicode_KIND(uval); udata = __Pyx_PyUnicode_DATA(uval); if (ukind == result_ukind) { memcpy((char *)result_udata + (char_pos << kind_shift), udata, (size_t) (ulength << kind_shift)); } else { #if PY_VERSION_HEX >= 0x030d0000 if (unlikely(PyUnicode_CopyCharacters(result_uval, char_pos, uval, 0, ulength) < 0)) goto bad; #elif CYTHON_COMPILING_IN_CPYTHON || defined(_PyUnicode_FastCopyCharacters) _PyUnicode_FastCopyCharacters(result_uval, char_pos, uval, 0, ulength); #else Py_ssize_t j; for (j=0; j < ulength; j++) { Py_UCS4 uchar = __Pyx_PyUnicode_READ(ukind, udata, j); __Pyx_PyUnicode_WRITE(result_ukind, result_udata, char_pos+j, uchar); } #endif } char_pos += ulength; } return result_uval; overflow: PyErr_SetString(PyExc_OverflowError, "join() result is too long for a Python string"); bad: Py_DECREF(result_uval); return NULL; #else Py_ssize_t i; PyObject *result = NULL; PyObject *value_tuple = PyTuple_New(value_count); if (unlikely(!value_tuple)) return NULL; CYTHON_UNUSED_VAR(max_char); CYTHON_UNUSED_VAR(result_ulength); for (i=0; i__pyx_empty_unicode, value_tuple); bad: Py_DECREF(value_tuple); return result; #endif } /* LimitedApiGetTypeDict */ #if CYTHON_COMPILING_IN_LIMITED_API static Py_ssize_t __Pyx_GetTypeDictOffset(void) { PyObject *tp_dictoffset_o; Py_ssize_t tp_dictoffset; tp_dictoffset_o = PyObject_GetAttrString((PyObject*)(&PyType_Type), "__dictoffset__"); if (unlikely(!tp_dictoffset_o)) return -1; tp_dictoffset = PyLong_AsSsize_t(tp_dictoffset_o); Py_DECREF(tp_dictoffset_o); if (unlikely(tp_dictoffset == 0)) { PyErr_SetString( PyExc_TypeError, "'type' doesn't have a dictoffset"); return -1; } else if (unlikely(tp_dictoffset < 0)) { PyErr_SetString( PyExc_TypeError, "'type' has an unexpected negative dictoffset. " "Please report this as Cython bug"); return -1; } return tp_dictoffset; } static PyObject *__Pyx_GetTypeDict(PyTypeObject *tp) { static Py_ssize_t tp_dictoffset = 0; if (unlikely(tp_dictoffset == 0)) { tp_dictoffset = __Pyx_GetTypeDictOffset(); if (unlikely(tp_dictoffset == -1 && PyErr_Occurred())) { tp_dictoffset = 0; // try again next time? return NULL; } } return *(PyObject**)((char*)tp + tp_dictoffset); } #endif /* SetItemOnTypeDict */ static int __Pyx__SetItemOnTypeDict(PyTypeObject *tp, PyObject *k, PyObject *v) { int result; PyObject *tp_dict; #if CYTHON_COMPILING_IN_LIMITED_API tp_dict = __Pyx_GetTypeDict(tp); if (unlikely(!tp_dict)) return -1; #else tp_dict = tp->tp_dict; #endif result = PyDict_SetItem(tp_dict, k, v); if (likely(!result)) { PyType_Modified(tp); if (unlikely(PyObject_HasAttr(v, __pyx_mstate_global->__pyx_n_u_set_name))) { PyObject *setNameResult = PyObject_CallMethodObjArgs(v, __pyx_mstate_global->__pyx_n_u_set_name, (PyObject *) tp, k, NULL); if (!setNameResult) return -1; Py_DECREF(setNameResult); } } return result; } /* FixUpExtensionType */ static int __Pyx_fix_up_extension_type_from_spec(PyType_Spec *spec, PyTypeObject *type) { #if __PYX_LIMITED_VERSION_HEX > 0x030900B1 CYTHON_UNUSED_VAR(spec); CYTHON_UNUSED_VAR(type); CYTHON_UNUSED_VAR(__Pyx__SetItemOnTypeDict); #else const PyType_Slot *slot = spec->slots; int changed = 0; #if !CYTHON_COMPILING_IN_LIMITED_API while (slot && slot->slot && slot->slot != Py_tp_members) slot++; if (slot && slot->slot == Py_tp_members) { #if !CYTHON_COMPILING_IN_CPYTHON const #endif // !CYTHON_COMPILING_IN_CPYTHON) PyMemberDef *memb = (PyMemberDef*) slot->pfunc; while (memb && memb->name) { if (memb->name[0] == '_' && memb->name[1] == '_') { if (strcmp(memb->name, "__weaklistoffset__") == 0) { assert(memb->type == T_PYSSIZET); assert(memb->flags == READONLY); type->tp_weaklistoffset = memb->offset; changed = 1; } else if (strcmp(memb->name, "__dictoffset__") == 0) { assert(memb->type == T_PYSSIZET); assert(memb->flags == READONLY); type->tp_dictoffset = memb->offset; changed = 1; } #if CYTHON_METH_FASTCALL else if (strcmp(memb->name, "__vectorcalloffset__") == 0) { assert(memb->type == T_PYSSIZET); assert(memb->flags == READONLY); #if PY_VERSION_HEX >= 0x030800b4 type->tp_vectorcall_offset = memb->offset; #else type->tp_print = (printfunc) memb->offset; #endif changed = 1; } #endif // CYTHON_METH_FASTCALL #if !CYTHON_COMPILING_IN_PYPY else if (strcmp(memb->name, "__module__") == 0) { PyObject *descr; assert(memb->type == T_OBJECT); assert(memb->flags == 0 || memb->flags == READONLY); descr = PyDescr_NewMember(type, memb); if (unlikely(!descr)) return -1; int set_item_result = PyDict_SetItem(type->tp_dict, PyDescr_NAME(descr), descr); Py_DECREF(descr); if (unlikely(set_item_result < 0)) { return -1; } changed = 1; } #endif // !CYTHON_COMPILING_IN_PYPY } memb++; } } #endif // !CYTHON_COMPILING_IN_LIMITED_API #if !CYTHON_COMPILING_IN_PYPY slot = spec->slots; while (slot && slot->slot && slot->slot != Py_tp_getset) slot++; if (slot && slot->slot == Py_tp_getset) { PyGetSetDef *getset = (PyGetSetDef*) slot->pfunc; while (getset && getset->name) { if (getset->name[0] == '_' && getset->name[1] == '_' && strcmp(getset->name, "__module__") == 0) { PyObject *descr = PyDescr_NewGetSet(type, getset); if (unlikely(!descr)) return -1; #if CYTHON_COMPILING_IN_LIMITED_API PyObject *pyname = PyUnicode_FromString(getset->name); if (unlikely(!pyname)) { Py_DECREF(descr); return -1; } int set_item_result = __Pyx_SetItemOnTypeDict(type, pyname, descr); Py_DECREF(pyname); #else CYTHON_UNUSED_VAR(__Pyx__SetItemOnTypeDict); int set_item_result = PyDict_SetItem(type->tp_dict, PyDescr_NAME(descr), descr); #endif Py_DECREF(descr); if (unlikely(set_item_result < 0)) { return -1; } changed = 1; } ++getset; } } #endif // !CYTHON_COMPILING_IN_PYPY if (changed) PyType_Modified(type); #endif // PY_VERSION_HEX > 0x030900B1 return 0; } /* ValidateBasesTuple */ #if CYTHON_COMPILING_IN_CPYTHON || CYTHON_COMPILING_IN_LIMITED_API || CYTHON_USE_TYPE_SPECS static int __Pyx_validate_bases_tuple(const char *type_name, Py_ssize_t dictoffset, PyObject *bases) { Py_ssize_t i, n; #if CYTHON_ASSUME_SAFE_SIZE n = PyTuple_GET_SIZE(bases); #else n = PyTuple_Size(bases); if (unlikely(n < 0)) return -1; #endif for (i = 1; i < n; i++) { PyTypeObject *b; #if CYTHON_AVOID_BORROWED_REFS PyObject *b0 = PySequence_GetItem(bases, i); if (!b0) return -1; #elif CYTHON_ASSUME_SAFE_MACROS PyObject *b0 = PyTuple_GET_ITEM(bases, i); #else PyObject *b0 = PyTuple_GetItem(bases, i); if (!b0) return -1; #endif b = (PyTypeObject*) b0; if (!__Pyx_PyType_HasFeature(b, Py_TPFLAGS_HEAPTYPE)) { __Pyx_TypeName b_name = __Pyx_PyType_GetFullyQualifiedName(b); PyErr_Format(PyExc_TypeError, "base class '" __Pyx_FMT_TYPENAME "' is not a heap type", b_name); __Pyx_DECREF_TypeName(b_name); #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(b0); #endif return -1; } if (dictoffset == 0) { Py_ssize_t b_dictoffset = 0; #if CYTHON_USE_TYPE_SLOTS b_dictoffset = b->tp_dictoffset; #else PyObject *py_b_dictoffset = PyObject_GetAttrString((PyObject*)b, "__dictoffset__"); if (!py_b_dictoffset) goto dictoffset_return; b_dictoffset = PyLong_AsSsize_t(py_b_dictoffset); Py_DECREF(py_b_dictoffset); if (b_dictoffset == -1 && PyErr_Occurred()) goto dictoffset_return; #endif if (b_dictoffset) { { __Pyx_TypeName b_name = __Pyx_PyType_GetFullyQualifiedName(b); PyErr_Format(PyExc_TypeError, "extension type '%.200s' has no __dict__ slot, " "but base type '" __Pyx_FMT_TYPENAME "' has: " "either add 'cdef dict __dict__' to the extension type " "or add '__slots__ = [...]' to the base type", type_name, b_name); __Pyx_DECREF_TypeName(b_name); } #if !CYTHON_USE_TYPE_SLOTS dictoffset_return: #endif #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(b0); #endif return -1; } } #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(b0); #endif } return 0; } #endif /* PyType_Ready */ CYTHON_UNUSED static int __Pyx_PyType_HasMultipleInheritance(PyTypeObject *t) { while (t) { PyObject *bases = __Pyx_PyType_GetSlot(t, tp_bases, PyObject*); if (bases) { return 1; } t = __Pyx_PyType_GetSlot(t, tp_base, PyTypeObject*); } return 0; } static int __Pyx_PyType_Ready(PyTypeObject *t) { #if CYTHON_USE_TYPE_SPECS || !CYTHON_COMPILING_IN_CPYTHON || defined(PYSTON_MAJOR_VERSION) (void)__Pyx_PyObject_CallMethod0; #if CYTHON_USE_TYPE_SPECS (void)__Pyx_validate_bases_tuple; #endif return PyType_Ready(t); #else int r; if (!__Pyx_PyType_HasMultipleInheritance(t)) { return PyType_Ready(t); } PyObject *bases = __Pyx_PyType_GetSlot(t, tp_bases, PyObject*); if (bases && unlikely(__Pyx_validate_bases_tuple(t->tp_name, t->tp_dictoffset, bases) == -1)) return -1; #if !defined(PYSTON_MAJOR_VERSION) { int gc_was_enabled; #if PY_VERSION_HEX >= 0x030A00b1 gc_was_enabled = PyGC_Disable(); (void)__Pyx_PyObject_CallMethod0; #else PyObject *ret, *py_status; PyObject *gc = NULL; #if (!CYTHON_COMPILING_IN_PYPY || PYPY_VERSION_NUM+0 >= 0x07030400) &&\ !CYTHON_COMPILING_IN_GRAAL gc = PyImport_GetModule(__pyx_mstate_global->__pyx_kp_u_gc); #endif if (unlikely(!gc)) gc = PyImport_Import(__pyx_mstate_global->__pyx_kp_u_gc); if (unlikely(!gc)) return -1; py_status = __Pyx_PyObject_CallMethod0(gc, __pyx_mstate_global->__pyx_kp_u_isenabled); if (unlikely(!py_status)) { Py_DECREF(gc); return -1; } gc_was_enabled = __Pyx_PyObject_IsTrue(py_status); Py_DECREF(py_status); if (gc_was_enabled > 0) { ret = __Pyx_PyObject_CallMethod0(gc, __pyx_mstate_global->__pyx_kp_u_disable); if (unlikely(!ret)) { Py_DECREF(gc); return -1; } Py_DECREF(ret); } else if (unlikely(gc_was_enabled == -1)) { Py_DECREF(gc); return -1; } #endif t->tp_flags |= Py_TPFLAGS_HEAPTYPE; #if PY_VERSION_HEX >= 0x030A0000 t->tp_flags |= Py_TPFLAGS_IMMUTABLETYPE; #endif #else (void)__Pyx_PyObject_CallMethod0; #endif r = PyType_Ready(t); #if !defined(PYSTON_MAJOR_VERSION) t->tp_flags &= ~Py_TPFLAGS_HEAPTYPE; #if PY_VERSION_HEX >= 0x030A00b1 if (gc_was_enabled) PyGC_Enable(); #else if (gc_was_enabled) { PyObject *tp, *v, *tb; PyErr_Fetch(&tp, &v, &tb); ret = __Pyx_PyObject_CallMethod0(gc, __pyx_mstate_global->__pyx_kp_u_enable); if (likely(ret || r == -1)) { Py_XDECREF(ret); PyErr_Restore(tp, v, tb); } else { Py_XDECREF(tp); Py_XDECREF(v); Py_XDECREF(tb); r = -1; } } Py_DECREF(gc); #endif } #endif return r; #endif } /* SetVTable */ static int __Pyx_SetVtable(PyTypeObject *type, void *vtable) { PyObject *ob = PyCapsule_New(vtable, 0, 0); if (unlikely(!ob)) goto bad; #if CYTHON_COMPILING_IN_LIMITED_API if (unlikely(PyObject_SetAttr((PyObject *) type, __pyx_mstate_global->__pyx_n_u_pyx_vtable, ob) < 0)) #else if (unlikely(PyDict_SetItem(type->tp_dict, __pyx_mstate_global->__pyx_n_u_pyx_vtable, ob) < 0)) #endif goto bad; Py_DECREF(ob); return 0; bad: Py_XDECREF(ob); return -1; } /* GetVTable */ static void* __Pyx_GetVtable(PyTypeObject *type) { void* ptr; #if CYTHON_COMPILING_IN_LIMITED_API PyObject *ob = PyObject_GetAttr((PyObject *)type, __pyx_mstate_global->__pyx_n_u_pyx_vtable); #else PyObject *ob = PyObject_GetItem(type->tp_dict, __pyx_mstate_global->__pyx_n_u_pyx_vtable); #endif if (!ob) goto bad; ptr = PyCapsule_GetPointer(ob, 0); if (!ptr && !PyErr_Occurred()) PyErr_SetString(PyExc_RuntimeError, "invalid vtable found for imported type"); Py_DECREF(ob); return ptr; bad: Py_XDECREF(ob); return NULL; } /* MergeVTables */ static int __Pyx_MergeVtables(PyTypeObject *type) { int i=0; Py_ssize_t size; void** base_vtables; __Pyx_TypeName tp_base_name = NULL; __Pyx_TypeName base_name = NULL; void* unknown = (void*)-1; PyObject* bases = __Pyx_PyType_GetSlot(type, tp_bases, PyObject*); int base_depth = 0; { PyTypeObject* base = __Pyx_PyType_GetSlot(type, tp_base, PyTypeObject*); while (base) { base_depth += 1; base = __Pyx_PyType_GetSlot(base, tp_base, PyTypeObject*); } } base_vtables = (void**) PyMem_Malloc(sizeof(void*) * (size_t)(base_depth + 1)); base_vtables[0] = unknown; #if CYTHON_COMPILING_IN_LIMITED_API size = PyTuple_Size(bases); if (size < 0) goto other_failure; #else size = PyTuple_GET_SIZE(bases); #endif for (i = 1; i < size; i++) { PyObject *basei; void* base_vtable; #if CYTHON_AVOID_BORROWED_REFS basei = PySequence_GetItem(bases, i); if (unlikely(!basei)) goto other_failure; #elif !CYTHON_ASSUME_SAFE_MACROS basei = PyTuple_GetItem(bases, i); if (unlikely(!basei)) goto other_failure; #else basei = PyTuple_GET_ITEM(bases, i); #endif base_vtable = __Pyx_GetVtable((PyTypeObject*)basei); #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(basei); #endif if (base_vtable != NULL) { int j; PyTypeObject* base = __Pyx_PyType_GetSlot(type, tp_base, PyTypeObject*); for (j = 0; j < base_depth; j++) { if (base_vtables[j] == unknown) { base_vtables[j] = __Pyx_GetVtable(base); base_vtables[j + 1] = unknown; } if (base_vtables[j] == base_vtable) { break; } else if (base_vtables[j] == NULL) { goto bad; } base = __Pyx_PyType_GetSlot(base, tp_base, PyTypeObject*); } } } PyErr_Clear(); PyMem_Free(base_vtables); return 0; bad: { PyTypeObject* basei = NULL; PyTypeObject* tp_base = __Pyx_PyType_GetSlot(type, tp_base, PyTypeObject*); tp_base_name = __Pyx_PyType_GetFullyQualifiedName(tp_base); #if CYTHON_AVOID_BORROWED_REFS basei = (PyTypeObject*)PySequence_GetItem(bases, i); if (unlikely(!basei)) goto really_bad; #elif !CYTHON_ASSUME_SAFE_MACROS basei = (PyTypeObject*)PyTuple_GetItem(bases, i); if (unlikely(!basei)) goto really_bad; #else basei = (PyTypeObject*)PyTuple_GET_ITEM(bases, i); #endif base_name = __Pyx_PyType_GetFullyQualifiedName(basei); #if CYTHON_AVOID_BORROWED_REFS Py_DECREF(basei); #endif } PyErr_Format(PyExc_TypeError, "multiple bases have vtable conflict: '" __Pyx_FMT_TYPENAME "' and '" __Pyx_FMT_TYPENAME "'", tp_base_name, base_name); #if CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS really_bad: // bad has failed! #endif __Pyx_DECREF_TypeName(tp_base_name); __Pyx_DECREF_TypeName(base_name); #if CYTHON_COMPILING_IN_LIMITED_API || CYTHON_AVOID_BORROWED_REFS || !CYTHON_ASSUME_SAFE_MACROS other_failure: #endif PyMem_Free(base_vtables); return -1; } /* DelItemOnTypeDict */ static int __Pyx__DelItemOnTypeDict(PyTypeObject *tp, PyObject *k) { int result; PyObject *tp_dict; #if CYTHON_COMPILING_IN_LIMITED_API tp_dict = __Pyx_GetTypeDict(tp); if (unlikely(!tp_dict)) return -1; #else tp_dict = tp->tp_dict; #endif result = PyDict_DelItem(tp_dict, k); if (likely(!result)) PyType_Modified(tp); return result; } /* SetupReduce */ static int __Pyx_setup_reduce_is_named(PyObject* meth, PyObject* name) { int ret; PyObject *name_attr; name_attr = __Pyx_PyObject_GetAttrStrNoError(meth, __pyx_mstate_global->__pyx_n_u_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_getstate = NULL; PyObject *object_reduce_ex = NULL; PyObject *reduce = NULL; PyObject *reduce_ex = NULL; PyObject *reduce_cython = NULL; PyObject *setstate = NULL; PyObject *setstate_cython = NULL; PyObject *getstate = NULL; #if CYTHON_USE_PYTYPE_LOOKUP getstate = _PyType_Lookup((PyTypeObject*)type_obj, __pyx_mstate_global->__pyx_n_u_getstate); #else getstate = __Pyx_PyObject_GetAttrStrNoError(type_obj, __pyx_mstate_global->__pyx_n_u_getstate); if (!getstate && PyErr_Occurred()) { goto __PYX_BAD; } #endif if (getstate) { #if CYTHON_USE_PYTYPE_LOOKUP object_getstate = _PyType_Lookup(&PyBaseObject_Type, __pyx_mstate_global->__pyx_n_u_getstate); #else object_getstate = __Pyx_PyObject_GetAttrStrNoError((PyObject*)&PyBaseObject_Type, __pyx_mstate_global->__pyx_n_u_getstate); if (!object_getstate && PyErr_Occurred()) { goto __PYX_BAD; } #endif if (object_getstate != getstate) { goto __PYX_GOOD; } } #if CYTHON_USE_PYTYPE_LOOKUP object_reduce_ex = _PyType_Lookup(&PyBaseObject_Type, __pyx_mstate_global->__pyx_n_u_reduce_ex); if (!object_reduce_ex) goto __PYX_BAD; #else object_reduce_ex = __Pyx_PyObject_GetAttrStr((PyObject*)&PyBaseObject_Type, __pyx_mstate_global->__pyx_n_u_reduce_ex); if (!object_reduce_ex) goto __PYX_BAD; #endif reduce_ex = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_mstate_global->__pyx_n_u_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_mstate_global->__pyx_n_u_reduce); if (!object_reduce) goto __PYX_BAD; #else object_reduce = __Pyx_PyObject_GetAttrStr((PyObject*)&PyBaseObject_Type, __pyx_mstate_global->__pyx_n_u_reduce); if (!object_reduce) goto __PYX_BAD; #endif reduce = __Pyx_PyObject_GetAttrStr(type_obj, __pyx_mstate_global->__pyx_n_u_reduce); if (unlikely(!reduce)) goto __PYX_BAD; if (reduce == object_reduce || __Pyx_setup_reduce_is_named(reduce, __pyx_mstate_global->__pyx_n_u_reduce_cython)) { reduce_cython = __Pyx_PyObject_GetAttrStrNoError(type_obj, __pyx_mstate_global->__pyx_n_u_reduce_cython); if (likely(reduce_cython)) { ret = __Pyx_SetItemOnTypeDict((PyTypeObject*)type_obj, __pyx_mstate_global->__pyx_n_u_reduce, reduce_cython); if (unlikely(ret < 0)) goto __PYX_BAD; ret = __Pyx_DelItemOnTypeDict((PyTypeObject*)type_obj, __pyx_mstate_global->__pyx_n_u_reduce_cython); if (unlikely(ret < 0)) goto __PYX_BAD; } else if (reduce == object_reduce || PyErr_Occurred()) { goto __PYX_BAD; } setstate = __Pyx_PyObject_GetAttrStrNoError(type_obj, __pyx_mstate_global->__pyx_n_u_setstate); if (!setstate) PyErr_Clear(); if (!setstate || __Pyx_setup_reduce_is_named(setstate, __pyx_mstate_global->__pyx_n_u_setstate_cython)) { setstate_cython = __Pyx_PyObject_GetAttrStrNoError(type_obj, __pyx_mstate_global->__pyx_n_u_setstate_cython); if (likely(setstate_cython)) { ret = __Pyx_SetItemOnTypeDict((PyTypeObject*)type_obj, __pyx_mstate_global->__pyx_n_u_setstate, setstate_cython); if (unlikely(ret < 0)) goto __PYX_BAD; ret = __Pyx_DelItemOnTypeDict((PyTypeObject*)type_obj, __pyx_mstate_global->__pyx_n_u_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()) { __Pyx_TypeName type_obj_name = __Pyx_PyType_GetFullyQualifiedName((PyTypeObject*)type_obj); PyErr_Format(PyExc_RuntimeError, "Unable to initialize pickling for " __Pyx_FMT_TYPENAME, type_obj_name); __Pyx_DECREF_TypeName(type_obj_name); } ret = -1; __PYX_GOOD: #if !CYTHON_USE_PYTYPE_LOOKUP Py_XDECREF(object_reduce); Py_XDECREF(object_reduce_ex); Py_XDECREF(object_getstate); Py_XDECREF(getstate); #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_3_1_6 #define __PYX_HAVE_RT_ImportType_3_1_6 static PyTypeObject *__Pyx_ImportType_3_1_6(PyObject *module, const char *module_name, const char *class_name, size_t size, size_t alignment, enum __Pyx_ImportType_CheckSize_3_1_6 check_size) { PyObject *result = 0; Py_ssize_t basicsize; Py_ssize_t itemsize; #if defined(Py_LIMITED_API) || (defined(CYTHON_COMPILING_IN_LIMITED_API) && CYTHON_COMPILING_IN_LIMITED_API) PyObject *py_basicsize; PyObject *py_itemsize; #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; } #if !( defined(Py_LIMITED_API) || (defined(CYTHON_COMPILING_IN_LIMITED_API) && CYTHON_COMPILING_IN_LIMITED_API) ) basicsize = ((PyTypeObject *)result)->tp_basicsize; itemsize = ((PyTypeObject *)result)->tp_itemsize; #else if (size == 0) { return (PyTypeObject *)result; } 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; py_itemsize = PyObject_GetAttrString(result, "__itemsize__"); if (!py_itemsize) goto bad; itemsize = PyLong_AsSsize_t(py_itemsize); Py_DECREF(py_itemsize); py_itemsize = 0; if (itemsize == (Py_ssize_t)-1 && PyErr_Occurred()) goto bad; #endif if (itemsize) { if (size % alignment) { alignment = size % alignment; } if (itemsize < (Py_ssize_t)alignment) itemsize = (Py_ssize_t)alignment; } if ((size_t)(basicsize + itemsize) < 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+itemsize); goto bad; } if (check_size == __Pyx_ImportType_CheckSize_Error_3_1_6 && ((size_t)basicsize > size || (size_t)(basicsize + itemsize) < size)) { PyErr_Format(PyExc_ValueError, "%.200s.%.200s size changed, may indicate binary incompatibility. " "Expected %zd from C header, got %zd-%zd from PyObject", module_name, class_name, size, basicsize, basicsize+itemsize); goto bad; } else if (check_size == __Pyx_ImportType_CheckSize_Warn_3_1_6 && (size_t)basicsize > size) { if (PyErr_WarnFormat(NULL, 0, "%.200s.%.200s size changed, may indicate binary incompatibility. " "Expected %zd from C header, got %zd from PyObject", module_name, class_name, size, basicsize) < 0) { goto bad; } } return (PyTypeObject *)result; bad: Py_XDECREF(result); return NULL; } #endif /* Import */ static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, int level) { PyObject *module = 0; PyObject *empty_dict = 0; PyObject *empty_list = 0; empty_dict = PyDict_New(); if (unlikely(!empty_dict)) goto bad; if (level == -1) { const char* package_sep = strchr(__Pyx_MODULE_NAME, '.'); if (package_sep != (0)) { module = PyImport_ImportModuleLevelObject( name, __pyx_mstate_global->__pyx_d, empty_dict, from_list, 1); if (unlikely(!module)) { if (unlikely(!PyErr_ExceptionMatches(PyExc_ImportError))) goto bad; PyErr_Clear(); } } level = 0; } if (!module) { module = PyImport_ImportModuleLevelObject( name, __pyx_mstate_global->__pyx_d, empty_dict, from_list, level); } bad: Py_XDECREF(empty_dict); Py_XDECREF(empty_list); return module; } /* ImportDottedModule */ static PyObject *__Pyx__ImportDottedModule_Error(PyObject *name, PyObject *parts_tuple, Py_ssize_t count) { PyObject *partial_name = NULL, *slice = NULL, *sep = NULL; Py_ssize_t size; if (unlikely(PyErr_Occurred())) { PyErr_Clear(); } #if CYTHON_ASSUME_SAFE_SIZE size = PyTuple_GET_SIZE(parts_tuple); #else size = PyTuple_Size(parts_tuple); if (size < 0) goto bad; #endif if (likely(size == count)) { partial_name = name; } else { slice = PySequence_GetSlice(parts_tuple, 0, count); if (unlikely(!slice)) goto bad; sep = PyUnicode_FromStringAndSize(".", 1); if (unlikely(!sep)) goto bad; partial_name = PyUnicode_Join(sep, slice); } PyErr_Format( PyExc_ModuleNotFoundError, "No module named '%U'", partial_name); bad: Py_XDECREF(sep); Py_XDECREF(slice); Py_XDECREF(partial_name); return NULL; } static PyObject *__Pyx__ImportDottedModule_Lookup(PyObject *name) { PyObject *imported_module; #if (CYTHON_COMPILING_IN_PYPY && PYPY_VERSION_NUM < 0x07030400) ||\ CYTHON_COMPILING_IN_GRAAL PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) return NULL; imported_module = __Pyx_PyDict_GetItemStr(modules, name); Py_XINCREF(imported_module); #else imported_module = PyImport_GetModule(name); #endif return imported_module; } static PyObject *__Pyx_ImportDottedModule_WalkParts(PyObject *module, PyObject *name, PyObject *parts_tuple) { Py_ssize_t i, nparts; #if CYTHON_ASSUME_SAFE_SIZE nparts = PyTuple_GET_SIZE(parts_tuple); #else nparts = PyTuple_Size(parts_tuple); if (nparts < 0) return NULL; #endif for (i=1; i < nparts && module; i++) { PyObject *part, *submodule; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS part = PyTuple_GET_ITEM(parts_tuple, i); #else part = __Pyx_PySequence_ITEM(parts_tuple, i); if (!part) return NULL; #endif submodule = __Pyx_PyObject_GetAttrStrNoError(module, part); #if !(CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS) Py_DECREF(part); #endif Py_DECREF(module); module = submodule; } if (unlikely(!module)) { return __Pyx__ImportDottedModule_Error(name, parts_tuple, i); } return module; } static PyObject *__Pyx__ImportDottedModule(PyObject *name, PyObject *parts_tuple) { PyObject *imported_module; PyObject *module = __Pyx_Import(name, NULL, 0); if (!parts_tuple || unlikely(!module)) return module; imported_module = __Pyx__ImportDottedModule_Lookup(name); if (likely(imported_module)) { Py_DECREF(module); return imported_module; } PyErr_Clear(); return __Pyx_ImportDottedModule_WalkParts(module, name, parts_tuple); } static PyObject *__Pyx_ImportDottedModule(PyObject *name, PyObject *parts_tuple) { #if CYTHON_COMPILING_IN_CPYTHON PyObject *module = __Pyx__ImportDottedModule_Lookup(name); if (likely(module)) { PyObject *spec = __Pyx_PyObject_GetAttrStrNoError(module, __pyx_mstate_global->__pyx_n_u_spec); if (likely(spec)) { PyObject *unsafe = __Pyx_PyObject_GetAttrStrNoError(spec, __pyx_mstate_global->__pyx_n_u_initializing); if (likely(!unsafe || !__Pyx_PyObject_IsTrue(unsafe))) { Py_DECREF(spec); spec = NULL; } Py_XDECREF(unsafe); } if (likely(!spec)) { PyErr_Clear(); return module; } Py_DECREF(spec); Py_DECREF(module); } else if (PyErr_Occurred()) { PyErr_Clear(); } #endif return __Pyx__ImportDottedModule(name, parts_tuple); } /* ListPack */ static PyObject *__Pyx_PyList_Pack(Py_ssize_t n, ...) { va_list va; PyObject *l = PyList_New(n); va_start(va, n); if (unlikely(!l)) goto end; for (Py_ssize_t i=0; i__pyx_kp_u__6); if (unlikely(!module_dot)) { goto modbad; } full_name = PyUnicode_Concat(module_dot, name); if (unlikely(!full_name)) { goto modbad; } #if (CYTHON_COMPILING_IN_PYPY && PYPY_VERSION_NUM < 0x07030400) ||\ CYTHON_COMPILING_IN_GRAAL { PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) goto modbad; value = PyObject_GetItem(modules, full_name); } #else value = PyImport_GetModule(full_name); #endif modbad: Py_XDECREF(full_name); Py_XDECREF(module_dot); Py_XDECREF(module_name); } if (unlikely(!value)) { PyErr_Format(PyExc_ImportError, "cannot import name %S", name); } return value; } /* FetchSharedCythonModule */ static PyObject *__Pyx_FetchSharedCythonABIModule(void) { return __Pyx_PyImport_AddModuleRef(__PYX_ABI_MODULE_NAME); } /* dict_setdefault */ static CYTHON_INLINE PyObject *__Pyx_PyDict_SetDefault(PyObject *d, PyObject *key, PyObject *default_value, int is_safe_type) { PyObject* value; CYTHON_MAYBE_UNUSED_VAR(is_safe_type); #if CYTHON_COMPILING_IN_LIMITED_API value = PyObject_CallMethod(d, "setdefault", "OO", key, default_value); #elif PY_VERSION_HEX >= 0x030d0000 PyDict_SetDefaultRef(d, key, default_value, &value); #else value = PyDict_SetDefault(d, key, default_value); if (unlikely(!value)) return NULL; Py_INCREF(value); #endif return value; } /* FetchCommonType */ #if __PYX_LIMITED_VERSION_HEX < 0x030C0000 static PyObject* __Pyx_PyType_FromMetaclass(PyTypeObject *metaclass, PyObject *module, PyType_Spec *spec, PyObject *bases) { PyObject *result = __Pyx_PyType_FromModuleAndSpec(module, spec, bases); if (result && metaclass) { PyObject *old_tp = (PyObject*)Py_TYPE(result); Py_INCREF((PyObject*)metaclass); #if __PYX_LIMITED_VERSION_HEX >= 0x03090000 Py_SET_TYPE(result, metaclass); #else result->ob_type = metaclass; #endif Py_DECREF(old_tp); } return result; } #else #define __Pyx_PyType_FromMetaclass(me, mo, s, b) PyType_FromMetaclass(me, mo, s, b) #endif static int __Pyx_VerifyCachedType(PyObject *cached_type, const char *name, Py_ssize_t expected_basicsize) { Py_ssize_t basicsize; if (!PyType_Check(cached_type)) { PyErr_Format(PyExc_TypeError, "Shared Cython type %.200s is not a type object", name); return -1; } if (expected_basicsize == 0) { return 0; // size is inherited, nothing useful to check } #if CYTHON_COMPILING_IN_LIMITED_API PyObject *py_basicsize; py_basicsize = PyObject_GetAttrString(cached_type, "__basicsize__"); if (unlikely(!py_basicsize)) return -1; basicsize = PyLong_AsSsize_t(py_basicsize); Py_DECREF(py_basicsize); py_basicsize = NULL; if (unlikely(basicsize == (Py_ssize_t)-1) && PyErr_Occurred()) return -1; #else basicsize = ((PyTypeObject*) cached_type)->tp_basicsize; #endif if (basicsize != expected_basicsize) { PyErr_Format(PyExc_TypeError, "Shared Cython type %.200s has the wrong size, try recompiling", name); return -1; } return 0; } static PyTypeObject *__Pyx_FetchCommonTypeFromSpec(PyTypeObject *metaclass, PyObject *module, PyType_Spec *spec, PyObject *bases) { PyObject *abi_module = NULL, *cached_type = NULL, *abi_module_dict, *new_cached_type, *py_object_name; int get_item_ref_result; const char* object_name = strrchr(spec->name, '.'); object_name = object_name ? object_name+1 : spec->name; py_object_name = PyUnicode_FromString(object_name); if (!py_object_name) return NULL; abi_module = __Pyx_FetchSharedCythonABIModule(); if (!abi_module) goto done; abi_module_dict = PyModule_GetDict(abi_module); if (!abi_module_dict) goto done; get_item_ref_result = __Pyx_PyDict_GetItemRef(abi_module_dict, py_object_name, &cached_type); if (get_item_ref_result == 1) { if (__Pyx_VerifyCachedType( cached_type, object_name, spec->basicsize) < 0) { goto bad; } goto done; } else if (unlikely(get_item_ref_result == -1)) { goto bad; } CYTHON_UNUSED_VAR(module); cached_type = __Pyx_PyType_FromMetaclass(metaclass, abi_module, spec, bases); if (unlikely(!cached_type)) goto bad; if (unlikely(__Pyx_fix_up_extension_type_from_spec(spec, (PyTypeObject *) cached_type) < 0)) goto bad; new_cached_type = __Pyx_PyDict_SetDefault(abi_module_dict, py_object_name, cached_type, 1); if (unlikely(new_cached_type != cached_type)) { if (unlikely(!new_cached_type)) goto bad; Py_DECREF(cached_type); cached_type = new_cached_type; if (__Pyx_VerifyCachedType( cached_type, object_name, spec->basicsize) < 0) { goto bad; } goto done; } else { Py_DECREF(new_cached_type); } done: Py_XDECREF(abi_module); Py_DECREF(py_object_name); assert(cached_type == NULL || PyType_Check(cached_type)); return (PyTypeObject *) cached_type; bad: Py_XDECREF(cached_type); cached_type = NULL; goto done; } /* CommonTypesMetaclass */ static PyObject* __pyx_CommonTypesMetaclass_get_module(CYTHON_UNUSED PyObject *self, CYTHON_UNUSED void* context) { return PyUnicode_FromString(__PYX_ABI_MODULE_NAME); } static PyGetSetDef __pyx_CommonTypesMetaclass_getset[] = { {"__module__", __pyx_CommonTypesMetaclass_get_module, NULL, NULL, NULL}, {0, 0, 0, 0, 0} }; static PyType_Slot __pyx_CommonTypesMetaclass_slots[] = { {Py_tp_getset, (void *)__pyx_CommonTypesMetaclass_getset}, {0, 0} }; static PyType_Spec __pyx_CommonTypesMetaclass_spec = { __PYX_TYPE_MODULE_PREFIX "_common_types_metatype", 0, 0, #if PY_VERSION_HEX >= 0x030A0000 Py_TPFLAGS_IMMUTABLETYPE | Py_TPFLAGS_DISALLOW_INSTANTIATION | #endif Py_TPFLAGS_DEFAULT, __pyx_CommonTypesMetaclass_slots }; static int __pyx_CommonTypesMetaclass_init(PyObject *module) { __pyx_mstatetype *mstate = __Pyx_PyModule_GetState(module); PyObject *bases = PyTuple_Pack(1, &PyType_Type); if (unlikely(!bases)) { return -1; } mstate->__pyx_CommonTypesMetaclassType = __Pyx_FetchCommonTypeFromSpec(NULL, module, &__pyx_CommonTypesMetaclass_spec, bases); Py_DECREF(bases); if (unlikely(mstate->__pyx_CommonTypesMetaclassType == NULL)) { return -1; } return 0; } /* CallTypeTraverse */ #if !CYTHON_USE_TYPE_SPECS || (!CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x03090000) #else static int __Pyx_call_type_traverse(PyObject *o, int always_call, visitproc visit, void *arg) { #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x03090000 if (__Pyx_get_runtime_version() < 0x03090000) return 0; #endif if (!always_call) { PyTypeObject *base = __Pyx_PyObject_GetSlot(o, tp_base, PyTypeObject*); unsigned long flags = PyType_GetFlags(base); if (flags & Py_TPFLAGS_HEAPTYPE) { return 0; } } Py_VISIT((PyObject*)Py_TYPE(o)); return 0; } #endif /* PyMethodNew */ #if CYTHON_COMPILING_IN_LIMITED_API static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ) { PyObject *result; CYTHON_UNUSED_VAR(typ); if (!self) return __Pyx_NewRef(func); #if __PYX_LIMITED_VERSION_HEX >= 0x030C0000 { PyObject *args[] = {func, self}; result = PyObject_Vectorcall(__pyx_mstate_global->__Pyx_CachedMethodType, args, 2, NULL); } #else result = PyObject_CallFunctionObjArgs(__pyx_mstate_global->__Pyx_CachedMethodType, func, self, NULL); #endif return result; } #else static PyObject *__Pyx_PyMethod_New(PyObject *func, PyObject *self, PyObject *typ) { CYTHON_UNUSED_VAR(typ); if (!self) return __Pyx_NewRef(func); return PyMethod_New(func, self); } #endif /* PyVectorcallFastCallDict */ #if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) static PyObject *__Pyx_PyVectorcall_FastCallDict_kw(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw) { PyObject *res = NULL; PyObject *kwnames; PyObject **newargs; PyObject **kwvalues; Py_ssize_t i, pos; size_t j; PyObject *key, *value; unsigned long keys_are_strings; #if !CYTHON_ASSUME_SAFE_SIZE Py_ssize_t nkw = PyDict_Size(kw); if (unlikely(nkw == -1)) return NULL; #else Py_ssize_t nkw = PyDict_GET_SIZE(kw); #endif newargs = (PyObject **)PyMem_Malloc((nargs + (size_t)nkw) * sizeof(args[0])); if (unlikely(newargs == NULL)) { PyErr_NoMemory(); return NULL; } for (j = 0; j < nargs; j++) newargs[j] = args[j]; kwnames = PyTuple_New(nkw); if (unlikely(kwnames == NULL)) { PyMem_Free(newargs); return NULL; } kwvalues = newargs + nargs; pos = i = 0; keys_are_strings = Py_TPFLAGS_UNICODE_SUBCLASS; while (PyDict_Next(kw, &pos, &key, &value)) { keys_are_strings &= #if CYTHON_COMPILING_IN_LIMITED_API PyType_GetFlags(Py_TYPE(key)); #else Py_TYPE(key)->tp_flags; #endif Py_INCREF(key); Py_INCREF(value); #if !CYTHON_ASSUME_SAFE_MACROS if (unlikely(PyTuple_SetItem(kwnames, i, key) < 0)) goto cleanup; #else PyTuple_SET_ITEM(kwnames, i, key); #endif kwvalues[i] = value; i++; } if (unlikely(!keys_are_strings)) { PyErr_SetString(PyExc_TypeError, "keywords must be strings"); goto cleanup; } res = vc(func, newargs, nargs, kwnames); cleanup: Py_DECREF(kwnames); for (i = 0; i < nkw; i++) Py_DECREF(kwvalues[i]); PyMem_Free(newargs); return res; } static CYTHON_INLINE PyObject *__Pyx_PyVectorcall_FastCallDict(PyObject *func, __pyx_vectorcallfunc vc, PyObject *const *args, size_t nargs, PyObject *kw) { Py_ssize_t kw_size = likely(kw == NULL) ? 0 : #if !CYTHON_ASSUME_SAFE_SIZE PyDict_Size(kw); #else PyDict_GET_SIZE(kw); #endif if (kw_size == 0) { return vc(func, args, nargs, NULL); } #if !CYTHON_ASSUME_SAFE_SIZE else if (unlikely(kw_size == -1)) { return NULL; } #endif return __Pyx_PyVectorcall_FastCallDict_kw(func, vc, args, nargs, kw); } #endif /* CythonFunctionShared */ #if CYTHON_COMPILING_IN_LIMITED_API static CYTHON_INLINE int __Pyx__IsSameCyOrCFunctionNoMethod(PyObject *func, void (*cfunc)(void)) { if (__Pyx_CyFunction_Check(func)) { return PyCFunction_GetFunction(((__pyx_CyFunctionObject*)func)->func) == (PyCFunction) cfunc; } else if (PyCFunction_Check(func)) { return PyCFunction_GetFunction(func) == (PyCFunction) cfunc; } return 0; } static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)) { if ((PyObject*)Py_TYPE(func) == __pyx_mstate_global->__Pyx_CachedMethodType) { int result; PyObject *newFunc = PyObject_GetAttr(func, __pyx_mstate_global->__pyx_n_u_func); if (unlikely(!newFunc)) { PyErr_Clear(); // It's only an optimization, so don't throw an error return 0; } result = __Pyx__IsSameCyOrCFunctionNoMethod(newFunc, cfunc); Py_DECREF(newFunc); return result; } return __Pyx__IsSameCyOrCFunctionNoMethod(func, cfunc); } #else static CYTHON_INLINE int __Pyx__IsSameCyOrCFunction(PyObject *func, void (*cfunc)(void)) { if (PyMethod_Check(func)) { func = PyMethod_GET_FUNCTION(func); } return __Pyx_CyOrPyCFunction_Check(func) && __Pyx_CyOrPyCFunction_GET_FUNCTION(func) == (PyCFunction) cfunc; } #endif static CYTHON_INLINE void __Pyx__CyFunction_SetClassObj(__pyx_CyFunctionObject* f, PyObject* classobj) { #if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API __Pyx_Py_XDECREF_SET( __Pyx_CyFunction_GetClassObj(f), ((classobj) ? __Pyx_NewRef(classobj) : NULL)); #else __Pyx_Py_XDECREF_SET( ((PyCMethodObject *) (f))->mm_class, (PyTypeObject*)((classobj) ? __Pyx_NewRef(classobj) : NULL)); #endif } static PyObject * __Pyx_CyFunction_get_doc_locked(__pyx_CyFunctionObject *op) { if (unlikely(op->func_doc == NULL)) { #if CYTHON_COMPILING_IN_LIMITED_API op->func_doc = PyObject_GetAttrString(op->func, "__doc__"); if (unlikely(!op->func_doc)) return NULL; #else if (((PyCFunctionObject*)op)->m_ml->ml_doc) { op->func_doc = PyUnicode_FromString(((PyCFunctionObject*)op)->m_ml->ml_doc); if (unlikely(op->func_doc == NULL)) return NULL; } else { Py_INCREF(Py_None); return Py_None; } #endif } Py_INCREF(op->func_doc); return op->func_doc; } static PyObject * __Pyx_CyFunction_get_doc(__pyx_CyFunctionObject *op, void *closure) { PyObject *result; CYTHON_UNUSED_VAR(closure); __Pyx_BEGIN_CRITICAL_SECTION(op); result = __Pyx_CyFunction_get_doc_locked(op); __Pyx_END_CRITICAL_SECTION(); return result; } static int __Pyx_CyFunction_set_doc(__pyx_CyFunctionObject *op, PyObject *value, void *context) { CYTHON_UNUSED_VAR(context); if (value == NULL) { value = Py_None; } Py_INCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->func_doc, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_name_locked(__pyx_CyFunctionObject *op) { if (unlikely(op->func_name == NULL)) { #if CYTHON_COMPILING_IN_LIMITED_API op->func_name = PyObject_GetAttrString(op->func, "__name__"); #else op->func_name = PyUnicode_InternFromString(((PyCFunctionObject*)op)->m_ml->ml_name); #endif if (unlikely(op->func_name == NULL)) return NULL; } Py_INCREF(op->func_name); return op->func_name; } static PyObject * __Pyx_CyFunction_get_name(__pyx_CyFunctionObject *op, void *context) { PyObject *result = NULL; CYTHON_UNUSED_VAR(context); __Pyx_BEGIN_CRITICAL_SECTION(op); result = __Pyx_CyFunction_get_name_locked(op); __Pyx_END_CRITICAL_SECTION(); return result; } static int __Pyx_CyFunction_set_name(__pyx_CyFunctionObject *op, PyObject *value, void *context) { CYTHON_UNUSED_VAR(context); if (unlikely(value == NULL || !PyUnicode_Check(value))) { PyErr_SetString(PyExc_TypeError, "__name__ must be set to a string object"); return -1; } Py_INCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->func_name, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_qualname(__pyx_CyFunctionObject *op, void *context) { CYTHON_UNUSED_VAR(context); PyObject *result; __Pyx_BEGIN_CRITICAL_SECTION(op); Py_INCREF(op->func_qualname); result = op->func_qualname; __Pyx_END_CRITICAL_SECTION(); return result; } static int __Pyx_CyFunction_set_qualname(__pyx_CyFunctionObject *op, PyObject *value, void *context) { CYTHON_UNUSED_VAR(context); if (unlikely(value == NULL || !PyUnicode_Check(value))) { PyErr_SetString(PyExc_TypeError, "__qualname__ must be set to a string object"); return -1; } Py_INCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->func_qualname, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_dict_locked(__pyx_CyFunctionObject *op) { if (unlikely(op->func_dict == NULL)) { op->func_dict = PyDict_New(); if (unlikely(op->func_dict == NULL)) return NULL; } Py_INCREF(op->func_dict); return op->func_dict; } static PyObject * __Pyx_CyFunction_get_dict(__pyx_CyFunctionObject *op, void *context) { CYTHON_UNUSED_VAR(context); PyObject *result; __Pyx_BEGIN_CRITICAL_SECTION(op); result = __Pyx_CyFunction_get_dict_locked(op); __Pyx_END_CRITICAL_SECTION(); return result; } static int __Pyx_CyFunction_set_dict(__pyx_CyFunctionObject *op, PyObject *value, void *context) { CYTHON_UNUSED_VAR(context); if (unlikely(value == NULL)) { PyErr_SetString(PyExc_TypeError, "function's dictionary may not be deleted"); return -1; } if (unlikely(!PyDict_Check(value))) { PyErr_SetString(PyExc_TypeError, "setting function's dictionary to a non-dict"); return -1; } Py_INCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->func_dict, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_globals(__pyx_CyFunctionObject *op, void *context) { CYTHON_UNUSED_VAR(context); Py_INCREF(op->func_globals); return op->func_globals; } static PyObject * __Pyx_CyFunction_get_closure(__pyx_CyFunctionObject *op, void *context) { CYTHON_UNUSED_VAR(op); CYTHON_UNUSED_VAR(context); Py_INCREF(Py_None); return Py_None; } static PyObject * __Pyx_CyFunction_get_code(__pyx_CyFunctionObject *op, void *context) { PyObject* result = (op->func_code) ? op->func_code : Py_None; CYTHON_UNUSED_VAR(context); Py_INCREF(result); return result; } static int __Pyx_CyFunction_init_defaults(__pyx_CyFunctionObject *op) { int result = 0; PyObject *res = op->defaults_getter((PyObject *) op); if (unlikely(!res)) return -1; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS op->defaults_tuple = PyTuple_GET_ITEM(res, 0); Py_INCREF(op->defaults_tuple); op->defaults_kwdict = PyTuple_GET_ITEM(res, 1); Py_INCREF(op->defaults_kwdict); #else op->defaults_tuple = __Pyx_PySequence_ITEM(res, 0); if (unlikely(!op->defaults_tuple)) result = -1; else { op->defaults_kwdict = __Pyx_PySequence_ITEM(res, 1); if (unlikely(!op->defaults_kwdict)) result = -1; } #endif Py_DECREF(res); return result; } static int __Pyx_CyFunction_set_defaults(__pyx_CyFunctionObject *op, PyObject* value, void *context) { CYTHON_UNUSED_VAR(context); if (!value) { value = Py_None; } else if (unlikely(value != Py_None && !PyTuple_Check(value))) { PyErr_SetString(PyExc_TypeError, "__defaults__ must be set to a tuple object"); return -1; } PyErr_WarnEx(PyExc_RuntimeWarning, "changes to cyfunction.__defaults__ will not " "currently affect the values used in function calls", 1); Py_INCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->defaults_tuple, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_defaults_locked(__pyx_CyFunctionObject *op) { PyObject* result = op->defaults_tuple; if (unlikely(!result)) { if (op->defaults_getter) { if (unlikely(__Pyx_CyFunction_init_defaults(op) < 0)) return NULL; result = op->defaults_tuple; } else { result = Py_None; } } Py_INCREF(result); return result; } static PyObject * __Pyx_CyFunction_get_defaults(__pyx_CyFunctionObject *op, void *context) { PyObject* result = NULL; CYTHON_UNUSED_VAR(context); __Pyx_BEGIN_CRITICAL_SECTION(op); result = __Pyx_CyFunction_get_defaults_locked(op); __Pyx_END_CRITICAL_SECTION(); return result; } static int __Pyx_CyFunction_set_kwdefaults(__pyx_CyFunctionObject *op, PyObject* value, void *context) { CYTHON_UNUSED_VAR(context); if (!value) { value = Py_None; } else if (unlikely(value != Py_None && !PyDict_Check(value))) { PyErr_SetString(PyExc_TypeError, "__kwdefaults__ must be set to a dict object"); return -1; } PyErr_WarnEx(PyExc_RuntimeWarning, "changes to cyfunction.__kwdefaults__ will not " "currently affect the values used in function calls", 1); Py_INCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->defaults_kwdict, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_kwdefaults_locked(__pyx_CyFunctionObject *op) { PyObject* result = op->defaults_kwdict; if (unlikely(!result)) { if (op->defaults_getter) { if (unlikely(__Pyx_CyFunction_init_defaults(op) < 0)) return NULL; result = op->defaults_kwdict; } else { result = Py_None; } } Py_INCREF(result); return result; } static PyObject * __Pyx_CyFunction_get_kwdefaults(__pyx_CyFunctionObject *op, void *context) { PyObject* result; CYTHON_UNUSED_VAR(context); __Pyx_BEGIN_CRITICAL_SECTION(op); result = __Pyx_CyFunction_get_kwdefaults_locked(op); __Pyx_END_CRITICAL_SECTION(); return result; } static int __Pyx_CyFunction_set_annotations(__pyx_CyFunctionObject *op, PyObject* value, void *context) { CYTHON_UNUSED_VAR(context); if (!value || value == Py_None) { value = NULL; } else if (unlikely(!PyDict_Check(value))) { PyErr_SetString(PyExc_TypeError, "__annotations__ must be set to a dict object"); return -1; } Py_XINCREF(value); __Pyx_BEGIN_CRITICAL_SECTION(op); __Pyx_Py_XDECREF_SET(op->func_annotations, value); __Pyx_END_CRITICAL_SECTION(); return 0; } static PyObject * __Pyx_CyFunction_get_annotations_locked(__pyx_CyFunctionObject *op) { PyObject* result = op->func_annotations; if (unlikely(!result)) { result = PyDict_New(); if (unlikely(!result)) return NULL; op->func_annotations = result; } Py_INCREF(result); return result; } static PyObject * __Pyx_CyFunction_get_annotations(__pyx_CyFunctionObject *op, void *context) { PyObject *result; CYTHON_UNUSED_VAR(context); __Pyx_BEGIN_CRITICAL_SECTION(op); result = __Pyx_CyFunction_get_annotations_locked(op); __Pyx_END_CRITICAL_SECTION(); return result; } static PyObject * __Pyx_CyFunction_get_is_coroutine_value(__pyx_CyFunctionObject *op) { int is_coroutine = op->flags & __Pyx_CYFUNCTION_COROUTINE; if (is_coroutine) { PyObject *is_coroutine_value, *module, *fromlist, *marker = __pyx_mstate_global->__pyx_n_u_is_coroutine; fromlist = PyList_New(1); if (unlikely(!fromlist)) return NULL; Py_INCREF(marker); #if CYTHON_ASSUME_SAFE_MACROS PyList_SET_ITEM(fromlist, 0, marker); #else if (unlikely(PyList_SetItem(fromlist, 0, marker) < 0)) { Py_DECREF(marker); Py_DECREF(fromlist); return NULL; } #endif module = PyImport_ImportModuleLevelObject(__pyx_mstate_global->__pyx_n_u_asyncio_coroutines, NULL, NULL, fromlist, 0); Py_DECREF(fromlist); if (unlikely(!module)) goto ignore; is_coroutine_value = __Pyx_PyObject_GetAttrStr(module, marker); Py_DECREF(module); if (likely(is_coroutine_value)) { return is_coroutine_value; } ignore: PyErr_Clear(); } return __Pyx_PyBool_FromLong(is_coroutine); } static PyObject * __Pyx_CyFunction_get_is_coroutine(__pyx_CyFunctionObject *op, void *context) { PyObject *result; CYTHON_UNUSED_VAR(context); if (op->func_is_coroutine) { return __Pyx_NewRef(op->func_is_coroutine); } result = __Pyx_CyFunction_get_is_coroutine_value(op); if (unlikely(!result)) return NULL; __Pyx_BEGIN_CRITICAL_SECTION(op); if (op->func_is_coroutine) { Py_DECREF(result); result = __Pyx_NewRef(op->func_is_coroutine); } else { op->func_is_coroutine = __Pyx_NewRef(result); } __Pyx_END_CRITICAL_SECTION(); return result; } static void __Pyx_CyFunction_raise_argument_count_error(__pyx_CyFunctionObject *func, const char* message, Py_ssize_t size) { #if CYTHON_COMPILING_IN_LIMITED_API PyObject *py_name = __Pyx_CyFunction_get_name(func, NULL); if (!py_name) return; PyErr_Format(PyExc_TypeError, "%.200S() %s (%" CYTHON_FORMAT_SSIZE_T "d given)", py_name, message, size); Py_DECREF(py_name); #else const char* name = ((PyCFunctionObject*)func)->m_ml->ml_name; PyErr_Format(PyExc_TypeError, "%.200s() %s (%" CYTHON_FORMAT_SSIZE_T "d given)", name, message, size); #endif } static void __Pyx_CyFunction_raise_type_error(__pyx_CyFunctionObject *func, const char* message) { #if CYTHON_COMPILING_IN_LIMITED_API PyObject *py_name = __Pyx_CyFunction_get_name(func, NULL); if (!py_name) return; PyErr_Format(PyExc_TypeError, "%.200S() %s", py_name, message); Py_DECREF(py_name); #else const char* name = ((PyCFunctionObject*)func)->m_ml->ml_name; PyErr_Format(PyExc_TypeError, "%.200s() %s", name, message); #endif } #if CYTHON_COMPILING_IN_LIMITED_API static PyObject * __Pyx_CyFunction_get_module(__pyx_CyFunctionObject *op, void *context) { CYTHON_UNUSED_VAR(context); return PyObject_GetAttrString(op->func, "__module__"); } static int __Pyx_CyFunction_set_module(__pyx_CyFunctionObject *op, PyObject* value, void *context) { CYTHON_UNUSED_VAR(context); return PyObject_SetAttrString(op->func, "__module__", value); } #endif static PyGetSetDef __pyx_CyFunction_getsets[] = { {"func_doc", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0}, {"__doc__", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0}, {"func_name", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0}, {"__name__", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0}, {"__qualname__", (getter)__Pyx_CyFunction_get_qualname, (setter)__Pyx_CyFunction_set_qualname, 0, 0}, {"func_dict", (getter)__Pyx_CyFunction_get_dict, (setter)__Pyx_CyFunction_set_dict, 0, 0}, {"__dict__", (getter)__Pyx_CyFunction_get_dict, (setter)__Pyx_CyFunction_set_dict, 0, 0}, {"func_globals", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0}, {"__globals__", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0}, {"func_closure", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0}, {"__closure__", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0}, {"func_code", (getter)__Pyx_CyFunction_get_code, 0, 0, 0}, {"__code__", (getter)__Pyx_CyFunction_get_code, 0, 0, 0}, {"func_defaults", (getter)__Pyx_CyFunction_get_defaults, (setter)__Pyx_CyFunction_set_defaults, 0, 0}, {"__defaults__", (getter)__Pyx_CyFunction_get_defaults, (setter)__Pyx_CyFunction_set_defaults, 0, 0}, {"__kwdefaults__", (getter)__Pyx_CyFunction_get_kwdefaults, (setter)__Pyx_CyFunction_set_kwdefaults, 0, 0}, {"__annotations__", (getter)__Pyx_CyFunction_get_annotations, (setter)__Pyx_CyFunction_set_annotations, 0, 0}, {"_is_coroutine", (getter)__Pyx_CyFunction_get_is_coroutine, 0, 0, 0}, #if CYTHON_COMPILING_IN_LIMITED_API {"__module__", (getter)__Pyx_CyFunction_get_module, (setter)__Pyx_CyFunction_set_module, 0, 0}, #endif {0, 0, 0, 0, 0} }; static PyMemberDef __pyx_CyFunction_members[] = { #if !CYTHON_COMPILING_IN_LIMITED_API {"__module__", T_OBJECT, offsetof(PyCFunctionObject, m_module), 0, 0}, #endif {"__dictoffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_dict), READONLY, 0}, #if CYTHON_METH_FASTCALL #if CYTHON_BACKPORT_VECTORCALL || CYTHON_COMPILING_IN_LIMITED_API {"__vectorcalloffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_vectorcall), READONLY, 0}, #else {"__vectorcalloffset__", T_PYSSIZET, offsetof(PyCFunctionObject, vectorcall), READONLY, 0}, #endif #if CYTHON_COMPILING_IN_LIMITED_API {"__weaklistoffset__", T_PYSSIZET, offsetof(__pyx_CyFunctionObject, func_weakreflist), READONLY, 0}, #else {"__weaklistoffset__", T_PYSSIZET, offsetof(PyCFunctionObject, m_weakreflist), READONLY, 0}, #endif #endif {0, 0, 0, 0, 0} }; static PyObject * __Pyx_CyFunction_reduce(__pyx_CyFunctionObject *m, PyObject *args) { PyObject *result = NULL; CYTHON_UNUSED_VAR(args); __Pyx_BEGIN_CRITICAL_SECTION(m); Py_INCREF(m->func_qualname); result = m->func_qualname; __Pyx_END_CRITICAL_SECTION(); return result; } static PyMethodDef __pyx_CyFunction_methods[] = { {"__reduce__", (PyCFunction)__Pyx_CyFunction_reduce, METH_VARARGS, 0}, {0, 0, 0, 0} }; #if CYTHON_COMPILING_IN_LIMITED_API #define __Pyx_CyFunction_weakreflist(cyfunc) ((cyfunc)->func_weakreflist) #else #define __Pyx_CyFunction_weakreflist(cyfunc) (((PyCFunctionObject*)cyfunc)->m_weakreflist) #endif static PyObject *__Pyx_CyFunction_Init(__pyx_CyFunctionObject *op, PyMethodDef *ml, int flags, PyObject* qualname, PyObject *closure, PyObject *module, PyObject* globals, PyObject* code) { #if !CYTHON_COMPILING_IN_LIMITED_API PyCFunctionObject *cf = (PyCFunctionObject*) op; #endif if (unlikely(op == NULL)) return NULL; #if CYTHON_COMPILING_IN_LIMITED_API op->func = PyCFunction_NewEx(ml, (PyObject*)op, module); if (unlikely(!op->func)) return NULL; #endif op->flags = flags; __Pyx_CyFunction_weakreflist(op) = NULL; #if !CYTHON_COMPILING_IN_LIMITED_API cf->m_ml = ml; cf->m_self = (PyObject *) op; #endif Py_XINCREF(closure); op->func_closure = closure; #if !CYTHON_COMPILING_IN_LIMITED_API Py_XINCREF(module); cf->m_module = module; #endif op->func_dict = NULL; op->func_name = NULL; Py_INCREF(qualname); op->func_qualname = qualname; op->func_doc = NULL; #if PY_VERSION_HEX < 0x030900B1 || CYTHON_COMPILING_IN_LIMITED_API op->func_classobj = NULL; #else ((PyCMethodObject*)op)->mm_class = NULL; #endif op->func_globals = globals; Py_INCREF(op->func_globals); Py_XINCREF(code); op->func_code = code; op->defaults = NULL; op->defaults_tuple = NULL; op->defaults_kwdict = NULL; op->defaults_getter = NULL; op->func_annotations = NULL; op->func_is_coroutine = NULL; #if CYTHON_METH_FASTCALL switch (ml->ml_flags & (METH_VARARGS | METH_FASTCALL | METH_NOARGS | METH_O | METH_KEYWORDS | METH_METHOD)) { case METH_NOARGS: __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_NOARGS; break; case METH_O: __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_O; break; case METH_METHOD | METH_FASTCALL | METH_KEYWORDS: __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD; break; case METH_FASTCALL | METH_KEYWORDS: __Pyx_CyFunction_func_vectorcall(op) = __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS; break; case METH_VARARGS | METH_KEYWORDS: __Pyx_CyFunction_func_vectorcall(op) = NULL; break; default: PyErr_SetString(PyExc_SystemError, "Bad call flags for CyFunction"); Py_DECREF(op); return NULL; } #endif return (PyObject *) op; } static int __Pyx_CyFunction_clear(__pyx_CyFunctionObject *m) { Py_CLEAR(m->func_closure); #if CYTHON_COMPILING_IN_LIMITED_API Py_CLEAR(m->func); #else Py_CLEAR(((PyCFunctionObject*)m)->m_module); #endif Py_CLEAR(m->func_dict); Py_CLEAR(m->func_name); Py_CLEAR(m->func_qualname); Py_CLEAR(m->func_doc); Py_CLEAR(m->func_globals); Py_CLEAR(m->func_code); #if !CYTHON_COMPILING_IN_LIMITED_API #if PY_VERSION_HEX < 0x030900B1 Py_CLEAR(__Pyx_CyFunction_GetClassObj(m)); #else { PyObject *cls = (PyObject*) ((PyCMethodObject *) (m))->mm_class; ((PyCMethodObject *) (m))->mm_class = NULL; Py_XDECREF(cls); } #endif #endif Py_CLEAR(m->defaults_tuple); Py_CLEAR(m->defaults_kwdict); Py_CLEAR(m->func_annotations); Py_CLEAR(m->func_is_coroutine); Py_CLEAR(m->defaults); return 0; } static void __Pyx__CyFunction_dealloc(__pyx_CyFunctionObject *m) { if (__Pyx_CyFunction_weakreflist(m) != NULL) PyObject_ClearWeakRefs((PyObject *) m); __Pyx_CyFunction_clear(m); __Pyx_PyHeapTypeObject_GC_Del(m); } static void __Pyx_CyFunction_dealloc(__pyx_CyFunctionObject *m) { PyObject_GC_UnTrack(m); __Pyx__CyFunction_dealloc(m); } static int __Pyx_CyFunction_traverse(__pyx_CyFunctionObject *m, visitproc visit, void *arg) { { int e = __Pyx_call_type_traverse((PyObject*)m, 1, visit, arg); if (e) return e; } Py_VISIT(m->func_closure); #if CYTHON_COMPILING_IN_LIMITED_API Py_VISIT(m->func); #else Py_VISIT(((PyCFunctionObject*)m)->m_module); #endif Py_VISIT(m->func_dict); __Pyx_VISIT_CONST(m->func_name); __Pyx_VISIT_CONST(m->func_qualname); Py_VISIT(m->func_doc); Py_VISIT(m->func_globals); __Pyx_VISIT_CONST(m->func_code); #if !CYTHON_COMPILING_IN_LIMITED_API Py_VISIT(__Pyx_CyFunction_GetClassObj(m)); #endif Py_VISIT(m->defaults_tuple); Py_VISIT(m->defaults_kwdict); Py_VISIT(m->func_is_coroutine); Py_VISIT(m->defaults); return 0; } static PyObject* __Pyx_CyFunction_repr(__pyx_CyFunctionObject *op) { PyObject *repr; __Pyx_BEGIN_CRITICAL_SECTION(op); repr = PyUnicode_FromFormat("", op->func_qualname, (void *)op); __Pyx_END_CRITICAL_SECTION(); return repr; } static PyObject * __Pyx_CyFunction_CallMethod(PyObject *func, PyObject *self, PyObject *arg, PyObject *kw) { #if CYTHON_COMPILING_IN_LIMITED_API PyObject *f = ((__pyx_CyFunctionObject*)func)->func; PyCFunction meth; int flags; meth = PyCFunction_GetFunction(f); if (unlikely(!meth)) return NULL; flags = PyCFunction_GetFlags(f); if (unlikely(flags < 0)) return NULL; #else PyCFunctionObject* f = (PyCFunctionObject*)func; PyCFunction meth = f->m_ml->ml_meth; int flags = f->m_ml->ml_flags; #endif Py_ssize_t size; switch (flags & (METH_VARARGS | METH_KEYWORDS | METH_NOARGS | METH_O)) { case METH_VARARGS: if (likely(kw == NULL || PyDict_Size(kw) == 0)) return (*meth)(self, arg); break; case METH_VARARGS | METH_KEYWORDS: return (*(PyCFunctionWithKeywords)(void(*)(void))meth)(self, arg, kw); case METH_NOARGS: if (likely(kw == NULL || PyDict_Size(kw) == 0)) { #if CYTHON_ASSUME_SAFE_SIZE size = PyTuple_GET_SIZE(arg); #else size = PyTuple_Size(arg); if (unlikely(size < 0)) return NULL; #endif if (likely(size == 0)) return (*meth)(self, NULL); __Pyx_CyFunction_raise_argument_count_error( (__pyx_CyFunctionObject*)func, "takes no arguments", size); return NULL; } break; case METH_O: if (likely(kw == NULL || PyDict_Size(kw) == 0)) { #if CYTHON_ASSUME_SAFE_SIZE size = PyTuple_GET_SIZE(arg); #else size = PyTuple_Size(arg); if (unlikely(size < 0)) return NULL; #endif if (likely(size == 1)) { PyObject *result, *arg0; #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS arg0 = PyTuple_GET_ITEM(arg, 0); #else arg0 = __Pyx_PySequence_ITEM(arg, 0); if (unlikely(!arg0)) return NULL; #endif result = (*meth)(self, arg0); #if !(CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS) Py_DECREF(arg0); #endif return result; } __Pyx_CyFunction_raise_argument_count_error( (__pyx_CyFunctionObject*)func, "takes exactly one argument", size); return NULL; } break; default: PyErr_SetString(PyExc_SystemError, "Bad call flags for CyFunction"); return NULL; } __Pyx_CyFunction_raise_type_error( (__pyx_CyFunctionObject*)func, "takes no keyword arguments"); return NULL; } static CYTHON_INLINE PyObject *__Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject *kw) { PyObject *self, *result; #if CYTHON_COMPILING_IN_LIMITED_API self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)func)->func); if (unlikely(!self) && PyErr_Occurred()) return NULL; #else self = ((PyCFunctionObject*)func)->m_self; #endif result = __Pyx_CyFunction_CallMethod(func, self, arg, kw); return result; } static PyObject *__Pyx_CyFunction_CallAsMethod(PyObject *func, PyObject *args, PyObject *kw) { PyObject *result; __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *) func; #if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) __pyx_vectorcallfunc vc = __Pyx_CyFunction_func_vectorcall(cyfunc); if (vc) { #if CYTHON_ASSUME_SAFE_MACROS && CYTHON_ASSUME_SAFE_SIZE return __Pyx_PyVectorcall_FastCallDict(func, vc, &PyTuple_GET_ITEM(args, 0), (size_t)PyTuple_GET_SIZE(args), kw); #else (void) &__Pyx_PyVectorcall_FastCallDict; return PyVectorcall_Call(func, args, kw); #endif } #endif if ((cyfunc->flags & __Pyx_CYFUNCTION_CCLASS) && !(cyfunc->flags & __Pyx_CYFUNCTION_STATICMETHOD)) { Py_ssize_t argc; PyObject *new_args; PyObject *self; #if CYTHON_ASSUME_SAFE_SIZE argc = PyTuple_GET_SIZE(args); #else argc = PyTuple_Size(args); if (unlikely(argc < 0)) return NULL; #endif new_args = PyTuple_GetSlice(args, 1, argc); if (unlikely(!new_args)) return NULL; self = PyTuple_GetItem(args, 0); if (unlikely(!self)) { Py_DECREF(new_args); PyErr_Format(PyExc_TypeError, "unbound method %.200S() needs an argument", cyfunc->func_qualname); return NULL; } result = __Pyx_CyFunction_CallMethod(func, self, new_args, kw); Py_DECREF(new_args); } else { result = __Pyx_CyFunction_Call(func, args, kw); } return result; } #if CYTHON_METH_FASTCALL && (CYTHON_VECTORCALL || CYTHON_BACKPORT_VECTORCALL) static CYTHON_INLINE int __Pyx_CyFunction_Vectorcall_CheckArgs(__pyx_CyFunctionObject *cyfunc, Py_ssize_t nargs, PyObject *kwnames) { int ret = 0; if ((cyfunc->flags & __Pyx_CYFUNCTION_CCLASS) && !(cyfunc->flags & __Pyx_CYFUNCTION_STATICMETHOD)) { if (unlikely(nargs < 1)) { __Pyx_CyFunction_raise_type_error( cyfunc, "needs an argument"); return -1; } ret = 1; } if (unlikely(kwnames) && unlikely(__Pyx_PyTuple_GET_SIZE(kwnames))) { __Pyx_CyFunction_raise_type_error( cyfunc, "takes no keyword arguments"); return -1; } return ret; } static PyObject * __Pyx_CyFunction_Vectorcall_NOARGS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) { __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; #if CYTHON_BACKPORT_VECTORCALL Py_ssize_t nargs = (Py_ssize_t)nargsf; #else Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); #endif PyObject *self; #if CYTHON_COMPILING_IN_LIMITED_API PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); if (unlikely(!meth)) return NULL; #else PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; #endif switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, kwnames)) { case 1: self = args[0]; args += 1; nargs -= 1; break; case 0: #if CYTHON_COMPILING_IN_LIMITED_API self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); if (unlikely(!self) && PyErr_Occurred()) return NULL; #else self = ((PyCFunctionObject*)cyfunc)->m_self; #endif break; default: return NULL; } if (unlikely(nargs != 0)) { __Pyx_CyFunction_raise_argument_count_error( cyfunc, "takes no arguments", nargs); return NULL; } return meth(self, NULL); } static PyObject * __Pyx_CyFunction_Vectorcall_O(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) { __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; #if CYTHON_BACKPORT_VECTORCALL Py_ssize_t nargs = (Py_ssize_t)nargsf; #else Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); #endif PyObject *self; #if CYTHON_COMPILING_IN_LIMITED_API PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); if (unlikely(!meth)) return NULL; #else PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; #endif switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, kwnames)) { case 1: self = args[0]; args += 1; nargs -= 1; break; case 0: #if CYTHON_COMPILING_IN_LIMITED_API self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); if (unlikely(!self) && PyErr_Occurred()) return NULL; #else self = ((PyCFunctionObject*)cyfunc)->m_self; #endif break; default: return NULL; } if (unlikely(nargs != 1)) { __Pyx_CyFunction_raise_argument_count_error( cyfunc, "takes exactly one argument", nargs); return NULL; } return meth(self, args[0]); } static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) { __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; #if CYTHON_BACKPORT_VECTORCALL Py_ssize_t nargs = (Py_ssize_t)nargsf; #else Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); #endif PyObject *self; #if CYTHON_COMPILING_IN_LIMITED_API PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); if (unlikely(!meth)) return NULL; #else PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; #endif switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, NULL)) { case 1: self = args[0]; args += 1; nargs -= 1; break; case 0: #if CYTHON_COMPILING_IN_LIMITED_API self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); if (unlikely(!self) && PyErr_Occurred()) return NULL; #else self = ((PyCFunctionObject*)cyfunc)->m_self; #endif break; default: return NULL; } return ((__Pyx_PyCFunctionFastWithKeywords)(void(*)(void))meth)(self, args, nargs, kwnames); } static PyObject * __Pyx_CyFunction_Vectorcall_FASTCALL_KEYWORDS_METHOD(PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames) { __pyx_CyFunctionObject *cyfunc = (__pyx_CyFunctionObject *)func; PyTypeObject *cls = (PyTypeObject *) __Pyx_CyFunction_GetClassObj(cyfunc); #if CYTHON_BACKPORT_VECTORCALL Py_ssize_t nargs = (Py_ssize_t)nargsf; #else Py_ssize_t nargs = PyVectorcall_NARGS(nargsf); #endif PyObject *self; #if CYTHON_COMPILING_IN_LIMITED_API PyCFunction meth = PyCFunction_GetFunction(cyfunc->func); if (unlikely(!meth)) return NULL; #else PyCFunction meth = ((PyCFunctionObject*)cyfunc)->m_ml->ml_meth; #endif switch (__Pyx_CyFunction_Vectorcall_CheckArgs(cyfunc, nargs, NULL)) { case 1: self = args[0]; args += 1; nargs -= 1; break; case 0: #if CYTHON_COMPILING_IN_LIMITED_API self = PyCFunction_GetSelf(((__pyx_CyFunctionObject*)cyfunc)->func); if (unlikely(!self) && PyErr_Occurred()) return NULL; #else self = ((PyCFunctionObject*)cyfunc)->m_self; #endif break; default: return NULL; } return ((__Pyx_PyCMethod)(void(*)(void))meth)(self, cls, args, (size_t)nargs, kwnames); } #endif static PyType_Slot __pyx_CyFunctionType_slots[] = { {Py_tp_dealloc, (void *)__Pyx_CyFunction_dealloc}, {Py_tp_repr, (void *)__Pyx_CyFunction_repr}, {Py_tp_call, (void *)__Pyx_CyFunction_CallAsMethod}, {Py_tp_traverse, (void *)__Pyx_CyFunction_traverse}, {Py_tp_clear, (void *)__Pyx_CyFunction_clear}, {Py_tp_methods, (void *)__pyx_CyFunction_methods}, {Py_tp_members, (void *)__pyx_CyFunction_members}, {Py_tp_getset, (void *)__pyx_CyFunction_getsets}, {Py_tp_descr_get, (void *)__Pyx_PyMethod_New}, {0, 0}, }; static PyType_Spec __pyx_CyFunctionType_spec = { __PYX_TYPE_MODULE_PREFIX "cython_function_or_method", sizeof(__pyx_CyFunctionObject), 0, #ifdef Py_TPFLAGS_METHOD_DESCRIPTOR Py_TPFLAGS_METHOD_DESCRIPTOR | #endif #if CYTHON_METH_FASTCALL #if defined(Py_TPFLAGS_HAVE_VECTORCALL) Py_TPFLAGS_HAVE_VECTORCALL | #elif defined(_Py_TPFLAGS_HAVE_VECTORCALL) _Py_TPFLAGS_HAVE_VECTORCALL | #endif #endif // CYTHON_METH_FASTCALL #if PY_VERSION_HEX >= 0x030A0000 Py_TPFLAGS_IMMUTABLETYPE | #endif Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC | Py_TPFLAGS_BASETYPE, __pyx_CyFunctionType_slots }; static int __pyx_CyFunction_init(PyObject *module) { __pyx_mstatetype *mstate = __Pyx_PyModule_GetState(module); mstate->__pyx_CyFunctionType = __Pyx_FetchCommonTypeFromSpec( mstate->__pyx_CommonTypesMetaclassType, module, &__pyx_CyFunctionType_spec, NULL); if (unlikely(mstate->__pyx_CyFunctionType == NULL)) { return -1; } return 0; } static CYTHON_INLINE PyObject *__Pyx_CyFunction_InitDefaults(PyObject *func, PyTypeObject *defaults_type) { __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; m->defaults = PyObject_CallObject((PyObject*)defaults_type, NULL); // _PyObject_New(defaults_type); if (unlikely(!m->defaults)) return NULL; return m->defaults; } static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *func, PyObject *tuple) { __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; m->defaults_tuple = tuple; Py_INCREF(tuple); } static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsKwDict(PyObject *func, PyObject *dict) { __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; m->defaults_kwdict = dict; Py_INCREF(dict); } static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *func, PyObject *dict) { __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func; m->func_annotations = dict; Py_INCREF(dict); } /* CythonFunction */ static PyObject *__Pyx_CyFunction_New(PyMethodDef *ml, int flags, PyObject* qualname, PyObject *closure, PyObject *module, PyObject* globals, PyObject* code) { PyObject *op = __Pyx_CyFunction_Init( PyObject_GC_New(__pyx_CyFunctionObject, __pyx_mstate_global->__pyx_CyFunctionType), ml, flags, qualname, closure, module, globals, code ); if (likely(op)) { PyObject_GC_Track(op); } return op; } /* GetNameInClass */ static PyObject *__Pyx__GetNameInClass(PyObject *nmspace, PyObject *name) { PyObject *result; PyObject *dict; assert(PyType_Check(nmspace)); #if CYTHON_USE_TYPE_SLOTS dict = ((PyTypeObject*)nmspace)->tp_dict; Py_XINCREF(dict); #else dict = PyObject_GetAttr(nmspace, __pyx_mstate_global->__pyx_n_u_dict); #endif if (likely(dict)) { result = PyObject_GetItem(dict, name); Py_DECREF(dict); if (result) { return result; } } PyErr_Clear(); __Pyx_GetModuleGlobalNameUncached(result, name); return result; } /* CLineInTraceback */ #if CYTHON_CLINE_IN_TRACEBACK && CYTHON_CLINE_IN_TRACEBACK_RUNTIME static int __Pyx_CLineForTraceback(PyThreadState *tstate, int c_line) { PyObject *use_cline; PyObject *ptype, *pvalue, *ptraceback; #if CYTHON_COMPILING_IN_CPYTHON PyObject **cython_runtime_dict; #endif CYTHON_MAYBE_UNUSED_VAR(tstate); if (unlikely(!__pyx_mstate_global->__pyx_cython_runtime)) { return c_line; } __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); #if CYTHON_COMPILING_IN_CPYTHON cython_runtime_dict = _PyObject_GetDictPtr(__pyx_mstate_global->__pyx_cython_runtime); if (likely(cython_runtime_dict)) { __Pyx_BEGIN_CRITICAL_SECTION(*cython_runtime_dict); __PYX_PY_DICT_LOOKUP_IF_MODIFIED( use_cline, *cython_runtime_dict, __Pyx_PyDict_GetItemStr(*cython_runtime_dict, __pyx_mstate_global->__pyx_n_u_cline_in_traceback)) Py_XINCREF(use_cline); __Pyx_END_CRITICAL_SECTION(); } else #endif { PyObject *use_cline_obj = __Pyx_PyObject_GetAttrStrNoError(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback); if (use_cline_obj) { use_cline = PyObject_Not(use_cline_obj) ? Py_False : Py_True; Py_INCREF(use_cline); Py_DECREF(use_cline_obj); } else { PyErr_Clear(); use_cline = NULL; } } if (!use_cline) { c_line = 0; (void) PyObject_SetAttr(__pyx_mstate_global->__pyx_cython_runtime, __pyx_mstate_global->__pyx_n_u_cline_in_traceback, Py_False); } else if (use_cline == Py_False || (use_cline != Py_True && PyObject_Not(use_cline) != 0)) { c_line = 0; } Py_XDECREF(use_cline); __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 __Pyx_CachedCodeObjectType *__pyx__find_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line) { __Pyx_CachedCodeObjectType* code_object; int pos; if (unlikely(!code_line) || unlikely(!code_cache->entries)) { return NULL; } pos = __pyx_bisect_code_objects(code_cache->entries, code_cache->count, code_line); if (unlikely(pos >= code_cache->count) || unlikely(code_cache->entries[pos].code_line != code_line)) { return NULL; } code_object = code_cache->entries[pos].code_object; Py_INCREF(code_object); return code_object; } static __Pyx_CachedCodeObjectType *__pyx_find_code_object(int code_line) { #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS (void)__pyx__find_code_object; return NULL; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just miss. #else struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING __pyx_nonatomic_int_type old_count = __pyx_atomic_incr_acq_rel(&code_cache->accessor_count); if (old_count < 0) { __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); return NULL; } #endif __Pyx_CachedCodeObjectType *result = __pyx__find_code_object(code_cache, code_line); #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING __pyx_atomic_decr_acq_rel(&code_cache->accessor_count); #endif return result; #endif } static void __pyx__insert_code_object(struct __Pyx_CodeObjectCache *code_cache, int code_line, __Pyx_CachedCodeObjectType* code_object) { int pos, i; __Pyx_CodeObjectCacheEntry* entries = code_cache->entries; if (unlikely(!code_line)) { return; } if (unlikely(!entries)) { entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry)); if (likely(entries)) { code_cache->entries = entries; code_cache->max_count = 64; 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(code_cache->entries, code_cache->count, code_line); if ((pos < code_cache->count) && unlikely(code_cache->entries[pos].code_line == code_line)) { __Pyx_CachedCodeObjectType* tmp = entries[pos].code_object; entries[pos].code_object = code_object; Py_INCREF(code_object); Py_DECREF(tmp); return; } if (code_cache->count == code_cache->max_count) { int new_max = code_cache->max_count + 64; entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc( code_cache->entries, ((size_t)new_max) * sizeof(__Pyx_CodeObjectCacheEntry)); if (unlikely(!entries)) { return; } code_cache->entries = entries; code_cache->max_count = new_max; } for (i=code_cache->count; i>pos; i--) { entries[i] = entries[i-1]; } entries[pos].code_line = code_line; entries[pos].code_object = code_object; code_cache->count++; Py_INCREF(code_object); } static void __pyx_insert_code_object(int code_line, __Pyx_CachedCodeObjectType* code_object) { #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING && !CYTHON_ATOMICS (void)__pyx__insert_code_object; return; // Most implementation should have atomics. But otherwise, don't make it thread-safe, just fail. #else struct __Pyx_CodeObjectCache *code_cache = &__pyx_mstate_global->__pyx_code_cache; #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING __pyx_nonatomic_int_type expected = 0; if (!__pyx_atomic_int_cmp_exchange(&code_cache->accessor_count, &expected, INT_MIN)) { return; } #endif __pyx__insert_code_object(code_cache, code_line, code_object); #if CYTHON_COMPILING_IN_CPYTHON_FREETHREADING __pyx_atomic_sub(&code_cache->accessor_count, INT_MIN); #endif #endif } /* AddTraceback */ #include "compile.h" #include "frameobject.h" #include "traceback.h" #if PY_VERSION_HEX >= 0x030b00a6 && !CYTHON_COMPILING_IN_LIMITED_API && !defined(PYPY_VERSION) #ifndef Py_BUILD_CORE #define Py_BUILD_CORE 1 #endif #include "internal/pycore_frame.h" #endif #if CYTHON_COMPILING_IN_LIMITED_API static PyObject *__Pyx_PyCode_Replace_For_AddTraceback(PyObject *code, PyObject *scratch_dict, PyObject *firstlineno, PyObject *name) { PyObject *replace = NULL; if (unlikely(PyDict_SetItemString(scratch_dict, "co_firstlineno", firstlineno))) return NULL; if (unlikely(PyDict_SetItemString(scratch_dict, "co_name", name))) return NULL; replace = PyObject_GetAttrString(code, "replace"); if (likely(replace)) { PyObject *result = PyObject_Call(replace, __pyx_mstate_global->__pyx_empty_tuple, scratch_dict); Py_DECREF(replace); return result; } PyErr_Clear(); return NULL; } static void __Pyx_AddTraceback(const char *funcname, int c_line, int py_line, const char *filename) { PyObject *code_object = NULL, *py_py_line = NULL, *py_funcname = NULL, *dict = NULL; PyObject *replace = NULL, *getframe = NULL, *frame = NULL; PyObject *exc_type, *exc_value, *exc_traceback; int success = 0; if (c_line) { (void) __pyx_cfilenm; (void) __Pyx_CLineForTraceback(__Pyx_PyThreadState_Current, c_line); } PyErr_Fetch(&exc_type, &exc_value, &exc_traceback); code_object = __pyx_find_code_object(c_line ? -c_line : py_line); if (!code_object) { code_object = Py_CompileString("_getframe()", filename, Py_eval_input); if (unlikely(!code_object)) goto bad; py_py_line = PyLong_FromLong(py_line); if (unlikely(!py_py_line)) goto bad; py_funcname = PyUnicode_FromString(funcname); if (unlikely(!py_funcname)) goto bad; dict = PyDict_New(); if (unlikely(!dict)) goto bad; { PyObject *old_code_object = code_object; code_object = __Pyx_PyCode_Replace_For_AddTraceback(code_object, dict, py_py_line, py_funcname); Py_DECREF(old_code_object); } if (unlikely(!code_object)) goto bad; __pyx_insert_code_object(c_line ? -c_line : py_line, code_object); } else { dict = PyDict_New(); } getframe = PySys_GetObject("_getframe"); if (unlikely(!getframe)) goto bad; if (unlikely(PyDict_SetItemString(dict, "_getframe", getframe))) goto bad; frame = PyEval_EvalCode(code_object, dict, dict); if (unlikely(!frame) || frame == Py_None) goto bad; success = 1; bad: PyErr_Restore(exc_type, exc_value, exc_traceback); Py_XDECREF(code_object); Py_XDECREF(py_py_line); Py_XDECREF(py_funcname); Py_XDECREF(dict); Py_XDECREF(replace); if (success) { PyTraceBack_Here( (struct _frame*)frame); } Py_XDECREF(frame); } #else static PyCodeObject* __Pyx_CreateCodeObjectForTraceback( const char *funcname, int c_line, int py_line, const char *filename) { PyCodeObject *py_code = NULL; PyObject *py_funcname = NULL; if (c_line) { py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); if (!py_funcname) goto bad; funcname = PyUnicode_AsUTF8(py_funcname); if (!funcname) goto bad; } py_code = PyCode_NewEmpty(filename, funcname, py_line); Py_XDECREF(py_funcname); return py_code; bad: 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; PyObject *ptype, *pvalue, *ptraceback; 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) { __Pyx_ErrFetchInState(tstate, &ptype, &pvalue, &ptraceback); py_code = __Pyx_CreateCodeObjectForTraceback( funcname, c_line, py_line, filename); if (!py_code) { /* If the code object creation fails, then we should clear the fetched exception references and propagate the new exception */ Py_XDECREF(ptype); Py_XDECREF(pvalue); Py_XDECREF(ptraceback); goto bad; } __Pyx_ErrRestoreInState(tstate, ptype, pvalue, ptraceback); __pyx_insert_code_object(c_line ? -c_line : py_line, py_code); } py_frame = PyFrame_New( tstate, /*PyThreadState *tstate,*/ py_code, /*PyCodeObject *code,*/ __pyx_mstate_global->__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); } #endif /* 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_PyLong_From_int(int value) { #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const int neg_one = (int) -1, const_zero = (int) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (is_unsigned) { if (sizeof(int) < sizeof(long)) { return PyLong_FromLong((long) value); } else if (sizeof(int) <= sizeof(unsigned long)) { return PyLong_FromUnsignedLong((unsigned long) value); #if defined(HAVE_LONG_LONG) && !CYTHON_COMPILING_IN_PYPY } else if (sizeof(int) <= sizeof(unsigned PY_LONG_LONG)) { return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value); #endif } } else { if (sizeof(int) <= sizeof(long)) { return PyLong_FromLong((long) value); #ifdef HAVE_LONG_LONG } else if (sizeof(int) <= sizeof(PY_LONG_LONG)) { return PyLong_FromLongLong((PY_LONG_LONG) value); #endif } } { unsigned char *bytes = (unsigned char *)&value; #if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4 if (is_unsigned) { return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1); } else { return PyLong_FromNativeBytes(bytes, sizeof(value), -1); } #elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000 int one = 1; int little = (int)*(unsigned char *)&one; return _PyLong_FromByteArray(bytes, sizeof(int), little, !is_unsigned); #else int one = 1; int little = (int)*(unsigned char *)&one; PyObject *from_bytes, *result = NULL, *kwds = NULL; PyObject *py_bytes = NULL, *order_str = NULL; from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes"); if (!from_bytes) return NULL; py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(int)); if (!py_bytes) goto limited_bad; order_str = PyUnicode_FromString(little ? "little" : "big"); if (!order_str) goto limited_bad; { PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str }; if (!is_unsigned) { kwds = __Pyx_MakeVectorcallBuilderKwds(1); if (!kwds) goto limited_bad; if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad; } result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds); } limited_bad: Py_XDECREF(kwds); Py_XDECREF(order_str); Py_XDECREF(py_bytes); Py_XDECREF(from_bytes); return result; #endif } } /* CIntFromPy */ static CYTHON_INLINE int __Pyx_PyLong_As_int(PyObject *x) { #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const int neg_one = (int) -1, const_zero = (int) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (unlikely(!PyLong_Check(x))) { int val; PyObject *tmp = __Pyx_PyNumber_Long(x); if (!tmp) return (int) -1; val = __Pyx_PyLong_As_int(tmp); Py_DECREF(tmp); return val; } if (is_unsigned) { #if CYTHON_USE_PYLONG_INTERNALS if (unlikely(__Pyx_PyLong_IsNeg(x))) { goto raise_neg_overflow; } else if (__Pyx_PyLong_IsCompact(x)) { __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) } else { const digit* digits = __Pyx_PyLong_Digits(x); assert(__Pyx_PyLong_DigitCount(x) > 1); switch (__Pyx_PyLong_DigitCount(x)) { 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 && PY_VERSION_HEX < 0x030C00A7 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 if (__Pyx_PyLong_IsCompact(x)) { __PYX_VERIFY_RETURN_INT(int, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) } else { const digit* digits = __Pyx_PyLong_Digits(x); assert(__Pyx_PyLong_DigitCount(x) > 1); switch (__Pyx_PyLong_SignedDigitCount(x)) { 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 } } { int val; int ret = -1; #if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API Py_ssize_t bytes_copied = PyLong_AsNativeBytes( x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); if (unlikely(bytes_copied == -1)) { } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { goto raise_overflow; } else { ret = 0; } #elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; ret = _PyLong_AsByteArray((PyLongObject *)x, bytes, sizeof(val), is_little, !is_unsigned); #else PyObject *v; PyObject *stepval = NULL, *mask = NULL, *shift = NULL; int bits, remaining_bits, is_negative = 0; int chunk_size = (sizeof(long) < 8) ? 30 : 62; if (likely(PyLong_CheckExact(x))) { v = __Pyx_NewRef(x); } else { v = PyNumber_Long(x); if (unlikely(!v)) return (int) -1; assert(PyLong_CheckExact(v)); } { int result = PyObject_RichCompareBool(v, Py_False, Py_LT); if (unlikely(result < 0)) { Py_DECREF(v); return (int) -1; } is_negative = result == 1; } if (is_unsigned && unlikely(is_negative)) { Py_DECREF(v); goto raise_neg_overflow; } else if (is_negative) { stepval = PyNumber_Invert(v); Py_DECREF(v); if (unlikely(!stepval)) return (int) -1; } else { stepval = v; } v = NULL; val = (int) 0; mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; for (bits = 0; bits < (int) sizeof(int) * 8 - chunk_size; bits += chunk_size) { PyObject *tmp, *digit; long idigit; digit = PyNumber_And(stepval, mask); if (unlikely(!digit)) goto done; idigit = PyLong_AsLong(digit); Py_DECREF(digit); if (unlikely(idigit < 0)) goto done; val |= ((int) idigit) << bits; tmp = PyNumber_Rshift(stepval, shift); if (unlikely(!tmp)) goto done; Py_DECREF(stepval); stepval = tmp; } Py_DECREF(shift); shift = NULL; Py_DECREF(mask); mask = NULL; { long idigit = PyLong_AsLong(stepval); if (unlikely(idigit < 0)) goto done; remaining_bits = ((int) sizeof(int) * 8) - bits - (is_unsigned ? 0 : 1); if (unlikely(idigit >= (1L << remaining_bits))) goto raise_overflow; val |= ((int) idigit) << bits; } if (!is_unsigned) { if (unlikely(val & (((int) 1) << (sizeof(int) * 8 - 1)))) goto raise_overflow; if (is_negative) val = ~val; } ret = 0; done: Py_XDECREF(shift); Py_XDECREF(mask); Py_XDECREF(stepval); #endif if (unlikely(ret)) return (int) -1; 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; } /* CIntToPy */ static CYTHON_INLINE PyObject* __Pyx_PyLong_From_long(long value) { #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const long neg_one = (long) -1, const_zero = (long) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (is_unsigned) { if (sizeof(long) < sizeof(long)) { return PyLong_FromLong((long) value); } else if (sizeof(long) <= sizeof(unsigned long)) { return PyLong_FromUnsignedLong((unsigned long) value); #if defined(HAVE_LONG_LONG) && !CYTHON_COMPILING_IN_PYPY } 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 PyLong_FromLong((long) value); #ifdef HAVE_LONG_LONG } else if (sizeof(long) <= sizeof(PY_LONG_LONG)) { return PyLong_FromLongLong((PY_LONG_LONG) value); #endif } } { unsigned char *bytes = (unsigned char *)&value; #if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4 if (is_unsigned) { return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1); } else { return PyLong_FromNativeBytes(bytes, sizeof(value), -1); } #elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000 int one = 1; int little = (int)*(unsigned char *)&one; return _PyLong_FromByteArray(bytes, sizeof(long), little, !is_unsigned); #else int one = 1; int little = (int)*(unsigned char *)&one; PyObject *from_bytes, *result = NULL, *kwds = NULL; PyObject *py_bytes = NULL, *order_str = NULL; from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes"); if (!from_bytes) return NULL; py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(long)); if (!py_bytes) goto limited_bad; order_str = PyUnicode_FromString(little ? "little" : "big"); if (!order_str) goto limited_bad; { PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str }; if (!is_unsigned) { kwds = __Pyx_MakeVectorcallBuilderKwds(1); if (!kwds) goto limited_bad; if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad; } result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds); } limited_bad: Py_XDECREF(kwds); Py_XDECREF(order_str); Py_XDECREF(py_bytes); Py_XDECREF(from_bytes); return result; #endif } } /* CIntFromPy */ static CYTHON_INLINE unsigned int __Pyx_PyLong_As_unsigned_int(PyObject *x) { #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const unsigned int neg_one = (unsigned int) -1, const_zero = (unsigned int) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (unlikely(!PyLong_Check(x))) { unsigned int val; PyObject *tmp = __Pyx_PyNumber_Long(x); if (!tmp) return (unsigned int) -1; val = __Pyx_PyLong_As_unsigned_int(tmp); Py_DECREF(tmp); return val; } if (is_unsigned) { #if CYTHON_USE_PYLONG_INTERNALS if (unlikely(__Pyx_PyLong_IsNeg(x))) { goto raise_neg_overflow; } else if (__Pyx_PyLong_IsCompact(x)) { __PYX_VERIFY_RETURN_INT(unsigned int, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) } else { const digit* digits = __Pyx_PyLong_Digits(x); assert(__Pyx_PyLong_DigitCount(x) > 1); switch (__Pyx_PyLong_DigitCount(x)) { case 2: if ((8 * sizeof(unsigned int) > 1 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) } else if ((8 * sizeof(unsigned int) >= 2 * PyLong_SHIFT)) { return (unsigned int) (((((unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0])); } } break; case 3: if ((8 * sizeof(unsigned int) > 2 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) } else if ((8 * sizeof(unsigned int) >= 3 * PyLong_SHIFT)) { return (unsigned int) (((((((unsigned int)digits[2]) << PyLong_SHIFT) | (unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0])); } } break; case 4: if ((8 * sizeof(unsigned int) > 3 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned 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(unsigned int) >= 4 * PyLong_SHIFT)) { return (unsigned int) (((((((((unsigned int)digits[3]) << PyLong_SHIFT) | (unsigned int)digits[2]) << PyLong_SHIFT) | (unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0])); } } break; } } #endif #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX < 0x030C00A7 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 (unsigned int) -1; if (unlikely(result == 1)) goto raise_neg_overflow; } #endif if ((sizeof(unsigned int) <= sizeof(unsigned long))) { __PYX_VERIFY_RETURN_INT_EXC(unsigned int, unsigned long, PyLong_AsUnsignedLong(x)) #ifdef HAVE_LONG_LONG } else if ((sizeof(unsigned int) <= sizeof(unsigned PY_LONG_LONG))) { __PYX_VERIFY_RETURN_INT_EXC(unsigned int, unsigned PY_LONG_LONG, PyLong_AsUnsignedLongLong(x)) #endif } } else { #if CYTHON_USE_PYLONG_INTERNALS if (__Pyx_PyLong_IsCompact(x)) { __PYX_VERIFY_RETURN_INT(unsigned int, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) } else { const digit* digits = __Pyx_PyLong_Digits(x); assert(__Pyx_PyLong_DigitCount(x) > 1); switch (__Pyx_PyLong_SignedDigitCount(x)) { case -2: if ((8 * sizeof(unsigned int) - 1 > 1 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned int, long, -(long) (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) } else if ((8 * sizeof(unsigned int) - 1 > 2 * PyLong_SHIFT)) { return (unsigned int) (((unsigned int)-1)*(((((unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0]))); } } break; case 2: if ((8 * sizeof(unsigned int) > 1 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 2 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned int, unsigned long, (((((unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) } else if ((8 * sizeof(unsigned int) - 1 > 2 * PyLong_SHIFT)) { return (unsigned int) ((((((unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0]))); } } break; case -3: if ((8 * sizeof(unsigned int) - 1 > 2 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned int, long, -(long) (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) } else if ((8 * sizeof(unsigned int) - 1 > 3 * PyLong_SHIFT)) { return (unsigned int) (((unsigned int)-1)*(((((((unsigned int)digits[2]) << PyLong_SHIFT) | (unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0]))); } } break; case 3: if ((8 * sizeof(unsigned int) > 2 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 3 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned int, unsigned long, (((((((unsigned long)digits[2]) << PyLong_SHIFT) | (unsigned long)digits[1]) << PyLong_SHIFT) | (unsigned long)digits[0]))) } else if ((8 * sizeof(unsigned int) - 1 > 3 * PyLong_SHIFT)) { return (unsigned int) ((((((((unsigned int)digits[2]) << PyLong_SHIFT) | (unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0]))); } } break; case -4: if ((8 * sizeof(unsigned int) - 1 > 3 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned 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(unsigned int) - 1 > 4 * PyLong_SHIFT)) { return (unsigned int) (((unsigned int)-1)*(((((((((unsigned int)digits[3]) << PyLong_SHIFT) | (unsigned int)digits[2]) << PyLong_SHIFT) | (unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0]))); } } break; case 4: if ((8 * sizeof(unsigned int) > 3 * PyLong_SHIFT)) { if ((8 * sizeof(unsigned long) > 4 * PyLong_SHIFT)) { __PYX_VERIFY_RETURN_INT(unsigned 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(unsigned int) - 1 > 4 * PyLong_SHIFT)) { return (unsigned int) ((((((((((unsigned int)digits[3]) << PyLong_SHIFT) | (unsigned int)digits[2]) << PyLong_SHIFT) | (unsigned int)digits[1]) << PyLong_SHIFT) | (unsigned int)digits[0]))); } } break; } } #endif if ((sizeof(unsigned int) <= sizeof(long))) { __PYX_VERIFY_RETURN_INT_EXC(unsigned int, long, PyLong_AsLong(x)) #ifdef HAVE_LONG_LONG } else if ((sizeof(unsigned int) <= sizeof(PY_LONG_LONG))) { __PYX_VERIFY_RETURN_INT_EXC(unsigned int, PY_LONG_LONG, PyLong_AsLongLong(x)) #endif } } { unsigned int val; int ret = -1; #if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API Py_ssize_t bytes_copied = PyLong_AsNativeBytes( x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); if (unlikely(bytes_copied == -1)) { } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { goto raise_overflow; } else { ret = 0; } #elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; ret = _PyLong_AsByteArray((PyLongObject *)x, bytes, sizeof(val), is_little, !is_unsigned); #else PyObject *v; PyObject *stepval = NULL, *mask = NULL, *shift = NULL; int bits, remaining_bits, is_negative = 0; int chunk_size = (sizeof(long) < 8) ? 30 : 62; if (likely(PyLong_CheckExact(x))) { v = __Pyx_NewRef(x); } else { v = PyNumber_Long(x); if (unlikely(!v)) return (unsigned int) -1; assert(PyLong_CheckExact(v)); } { int result = PyObject_RichCompareBool(v, Py_False, Py_LT); if (unlikely(result < 0)) { Py_DECREF(v); return (unsigned int) -1; } is_negative = result == 1; } if (is_unsigned && unlikely(is_negative)) { Py_DECREF(v); goto raise_neg_overflow; } else if (is_negative) { stepval = PyNumber_Invert(v); Py_DECREF(v); if (unlikely(!stepval)) return (unsigned int) -1; } else { stepval = v; } v = NULL; val = (unsigned int) 0; mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; for (bits = 0; bits < (int) sizeof(unsigned int) * 8 - chunk_size; bits += chunk_size) { PyObject *tmp, *digit; long idigit; digit = PyNumber_And(stepval, mask); if (unlikely(!digit)) goto done; idigit = PyLong_AsLong(digit); Py_DECREF(digit); if (unlikely(idigit < 0)) goto done; val |= ((unsigned int) idigit) << bits; tmp = PyNumber_Rshift(stepval, shift); if (unlikely(!tmp)) goto done; Py_DECREF(stepval); stepval = tmp; } Py_DECREF(shift); shift = NULL; Py_DECREF(mask); mask = NULL; { long idigit = PyLong_AsLong(stepval); if (unlikely(idigit < 0)) goto done; remaining_bits = ((int) sizeof(unsigned int) * 8) - bits - (is_unsigned ? 0 : 1); if (unlikely(idigit >= (1L << remaining_bits))) goto raise_overflow; val |= ((unsigned int) idigit) << bits; } if (!is_unsigned) { if (unlikely(val & (((unsigned int) 1) << (sizeof(unsigned int) * 8 - 1)))) goto raise_overflow; if (is_negative) val = ~val; } ret = 0; done: Py_XDECREF(shift); Py_XDECREF(mask); Py_XDECREF(stepval); #endif if (unlikely(ret)) return (unsigned int) -1; return val; } raise_overflow: PyErr_SetString(PyExc_OverflowError, "value too large to convert to unsigned int"); return (unsigned int) -1; raise_neg_overflow: PyErr_SetString(PyExc_OverflowError, "can't convert negative value to unsigned int"); return (unsigned int) -1; } /* CIntToPy */ static CYTHON_INLINE PyObject* __Pyx_PyLong_From_word_t(word_t value) { #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const word_t neg_one = (word_t) -1, const_zero = (word_t) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (is_unsigned) { if (sizeof(word_t) < sizeof(long)) { return PyLong_FromLong((long) value); } else if (sizeof(word_t) <= sizeof(unsigned long)) { return PyLong_FromUnsignedLong((unsigned long) value); #if defined(HAVE_LONG_LONG) && !CYTHON_COMPILING_IN_PYPY } else if (sizeof(word_t) <= sizeof(unsigned PY_LONG_LONG)) { return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG) value); #endif } } else { if (sizeof(word_t) <= sizeof(long)) { return PyLong_FromLong((long) value); #ifdef HAVE_LONG_LONG } else if (sizeof(word_t) <= sizeof(PY_LONG_LONG)) { return PyLong_FromLongLong((PY_LONG_LONG) value); #endif } } { unsigned char *bytes = (unsigned char *)&value; #if !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d00A4 if (is_unsigned) { return PyLong_FromUnsignedNativeBytes(bytes, sizeof(value), -1); } else { return PyLong_FromNativeBytes(bytes, sizeof(value), -1); } #elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX < 0x030d0000 int one = 1; int little = (int)*(unsigned char *)&one; return _PyLong_FromByteArray(bytes, sizeof(word_t), little, !is_unsigned); #else int one = 1; int little = (int)*(unsigned char *)&one; PyObject *from_bytes, *result = NULL, *kwds = NULL; PyObject *py_bytes = NULL, *order_str = NULL; from_bytes = PyObject_GetAttrString((PyObject*)&PyLong_Type, "from_bytes"); if (!from_bytes) return NULL; py_bytes = PyBytes_FromStringAndSize((char*)bytes, sizeof(word_t)); if (!py_bytes) goto limited_bad; order_str = PyUnicode_FromString(little ? "little" : "big"); if (!order_str) goto limited_bad; { PyObject *args[3+(CYTHON_VECTORCALL ? 1 : 0)] = { NULL, py_bytes, order_str }; if (!is_unsigned) { kwds = __Pyx_MakeVectorcallBuilderKwds(1); if (!kwds) goto limited_bad; if (__Pyx_VectorcallBuilder_AddArgStr("signed", __Pyx_NewRef(Py_True), kwds, args+3, 0) < 0) goto limited_bad; } result = __Pyx_Object_Vectorcall_CallFromBuilder(from_bytes, args+1, 2 | __Pyx_PY_VECTORCALL_ARGUMENTS_OFFSET, kwds); } limited_bad: Py_XDECREF(kwds); Py_XDECREF(order_str); Py_XDECREF(py_bytes); Py_XDECREF(from_bytes); return result; #endif } } /* FormatTypeName */ #if CYTHON_COMPILING_IN_LIMITED_API && __PYX_LIMITED_VERSION_HEX < 0x030d0000 static __Pyx_TypeName __Pyx_PyType_GetFullyQualifiedName(PyTypeObject* tp) { PyObject *module = NULL, *name = NULL, *result = NULL; #if __PYX_LIMITED_VERSION_HEX < 0x030b0000 name = __Pyx_PyObject_GetAttrStr((PyObject *)tp, __pyx_mstate_global->__pyx_n_u_qualname); #else name = PyType_GetQualName(tp); #endif if (unlikely(name == NULL) || unlikely(!PyUnicode_Check(name))) goto bad; module = __Pyx_PyObject_GetAttrStr((PyObject *)tp, __pyx_mstate_global->__pyx_n_u_module); if (unlikely(module == NULL) || unlikely(!PyUnicode_Check(module))) goto bad; if (PyUnicode_CompareWithASCIIString(module, "builtins") == 0) { result = name; name = NULL; goto done; } result = PyUnicode_FromFormat("%U.%U", module, name); if (unlikely(result == NULL)) goto bad; done: Py_XDECREF(name); Py_XDECREF(module); return result; bad: PyErr_Clear(); if (name) { result = name; name = NULL; } else { result = __Pyx_NewRef(__pyx_mstate_global->__pyx_kp_u__7); } goto done; } #endif /* CIntFromPy */ static CYTHON_INLINE long __Pyx_PyLong_As_long(PyObject *x) { #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif const long neg_one = (long) -1, const_zero = (long) 0; #ifdef __Pyx_HAS_GCC_DIAGNOSTIC #pragma GCC diagnostic pop #endif const int is_unsigned = neg_one > const_zero; if (unlikely(!PyLong_Check(x))) { long val; PyObject *tmp = __Pyx_PyNumber_Long(x); if (!tmp) return (long) -1; val = __Pyx_PyLong_As_long(tmp); Py_DECREF(tmp); return val; } if (is_unsigned) { #if CYTHON_USE_PYLONG_INTERNALS if (unlikely(__Pyx_PyLong_IsNeg(x))) { goto raise_neg_overflow; } else if (__Pyx_PyLong_IsCompact(x)) { __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_upylong, __Pyx_PyLong_CompactValueUnsigned(x)) } else { const digit* digits = __Pyx_PyLong_Digits(x); assert(__Pyx_PyLong_DigitCount(x) > 1); switch (__Pyx_PyLong_DigitCount(x)) { 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 && PY_VERSION_HEX < 0x030C00A7 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 if (__Pyx_PyLong_IsCompact(x)) { __PYX_VERIFY_RETURN_INT(long, __Pyx_compact_pylong, __Pyx_PyLong_CompactValue(x)) } else { const digit* digits = __Pyx_PyLong_Digits(x); assert(__Pyx_PyLong_DigitCount(x) > 1); switch (__Pyx_PyLong_SignedDigitCount(x)) { 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 } } { long val; int ret = -1; #if PY_VERSION_HEX >= 0x030d00A6 && !CYTHON_COMPILING_IN_LIMITED_API Py_ssize_t bytes_copied = PyLong_AsNativeBytes( x, &val, sizeof(val), Py_ASNATIVEBYTES_NATIVE_ENDIAN | (is_unsigned ? Py_ASNATIVEBYTES_UNSIGNED_BUFFER | Py_ASNATIVEBYTES_REJECT_NEGATIVE : 0)); if (unlikely(bytes_copied == -1)) { } else if (unlikely(bytes_copied > (Py_ssize_t) sizeof(val))) { goto raise_overflow; } else { ret = 0; } #elif PY_VERSION_HEX < 0x030d0000 && !(CYTHON_COMPILING_IN_PYPY || CYTHON_COMPILING_IN_LIMITED_API) || defined(_PyLong_AsByteArray) int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; ret = _PyLong_AsByteArray((PyLongObject *)x, bytes, sizeof(val), is_little, !is_unsigned); #else PyObject *v; PyObject *stepval = NULL, *mask = NULL, *shift = NULL; int bits, remaining_bits, is_negative = 0; int chunk_size = (sizeof(long) < 8) ? 30 : 62; if (likely(PyLong_CheckExact(x))) { v = __Pyx_NewRef(x); } else { v = PyNumber_Long(x); if (unlikely(!v)) return (long) -1; assert(PyLong_CheckExact(v)); } { int result = PyObject_RichCompareBool(v, Py_False, Py_LT); if (unlikely(result < 0)) { Py_DECREF(v); return (long) -1; } is_negative = result == 1; } if (is_unsigned && unlikely(is_negative)) { Py_DECREF(v); goto raise_neg_overflow; } else if (is_negative) { stepval = PyNumber_Invert(v); Py_DECREF(v); if (unlikely(!stepval)) return (long) -1; } else { stepval = v; } v = NULL; val = (long) 0; mask = PyLong_FromLong((1L << chunk_size) - 1); if (unlikely(!mask)) goto done; shift = PyLong_FromLong(chunk_size); if (unlikely(!shift)) goto done; for (bits = 0; bits < (int) sizeof(long) * 8 - chunk_size; bits += chunk_size) { PyObject *tmp, *digit; long idigit; digit = PyNumber_And(stepval, mask); if (unlikely(!digit)) goto done; idigit = PyLong_AsLong(digit); Py_DECREF(digit); if (unlikely(idigit < 0)) goto done; val |= ((long) idigit) << bits; tmp = PyNumber_Rshift(stepval, shift); if (unlikely(!tmp)) goto done; Py_DECREF(stepval); stepval = tmp; } Py_DECREF(shift); shift = NULL; Py_DECREF(mask); mask = NULL; { long idigit = PyLong_AsLong(stepval); if (unlikely(idigit < 0)) goto done; remaining_bits = ((int) sizeof(long) * 8) - bits - (is_unsigned ? 0 : 1); if (unlikely(idigit >= (1L << remaining_bits))) goto raise_overflow; val |= ((long) idigit) << bits; } if (!is_unsigned) { if (unlikely(val & (((long) 1) << (sizeof(long) * 8 - 1)))) goto raise_overflow; if (is_negative) val = ~val; } ret = 0; done: Py_XDECREF(shift); Py_XDECREF(mask); Py_XDECREF(stepval); #endif if (unlikely(ret)) return (long) -1; 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; } /* FastTypeChecks */ #if CYTHON_COMPILING_IN_CPYTHON static int __Pyx_InBases(PyTypeObject *a, PyTypeObject *b) { while (a) { a = __Pyx_PyType_GetSlot(a, tp_base, PyTypeObject*); 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); } static CYTHON_INLINE int __Pyx_IsAnySubtype2(PyTypeObject *cls, PyTypeObject *a, PyTypeObject *b) { PyObject *mro; if (cls == a || cls == b) return 1; mro = cls->tp_mro; if (likely(mro)) { Py_ssize_t i, n; n = PyTuple_GET_SIZE(mro); for (i = 0; i < n; i++) { PyObject *base = PyTuple_GET_ITEM(mro, i); if (base == (PyObject *)a || base == (PyObject *)b) return 1; } return 0; } return __Pyx_InBases(cls, a) || __Pyx_InBases(cls, b); } static CYTHON_INLINE int __Pyx_inner_PyErr_GivenExceptionMatches2(PyObject *err, PyObject* exc_type1, PyObject *exc_type2) { if (exc_type1) { return __Pyx_IsAnySubtype2((PyTypeObject*)err, (PyTypeObject*)exc_type1, (PyTypeObject*)exc_type2); } else { return __Pyx_IsSubtype((PyTypeObject*)err, (PyTypeObject*)exc_type2); } } 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); for (i=0; i= 0x030b0000 return Py_Version & ~0xFFUL; #else static unsigned long __Pyx_cached_runtime_version = 0; if (__Pyx_cached_runtime_version == 0) { const char* rt_version = Py_GetVersion(); unsigned long version = 0; unsigned long factor = 0x01000000UL; unsigned int digit = 0; int i = 0; while (factor) { while ('0' <= rt_version[i] && rt_version[i] <= '9') { digit = digit * 10 + (unsigned int) (rt_version[i] - '0'); ++i; } version += factor * digit; if (rt_version[i] != '.') break; digit = 0; factor >>= 8; ++i; } __Pyx_cached_runtime_version = version; } return __Pyx_cached_runtime_version; #endif } /* CheckBinaryVersion */ static int __Pyx_check_binary_version(unsigned long ct_version, unsigned long rt_version, int allow_newer) { const unsigned long MAJOR_MINOR = 0xFFFF0000UL; if ((rt_version & MAJOR_MINOR) == (ct_version & MAJOR_MINOR)) return 0; if (likely(allow_newer && (rt_version & MAJOR_MINOR) > (ct_version & MAJOR_MINOR))) return 1; { char message[200]; PyOS_snprintf(message, sizeof(message), "compile time Python version %d.%d " "of module '%.100s' " "%s " "runtime version %d.%d", (int) (ct_version >> 24), (int) ((ct_version >> 16) & 0xFF), __Pyx_MODULE_NAME, (allow_newer) ? "was newer than" : "does not match", (int) (rt_version >> 24), (int) ((rt_version >> 16) & 0xFF) ); return PyErr_WarnEx(NULL, message, 1); } } /* NewCodeObj */ #if CYTHON_COMPILING_IN_LIMITED_API static PyObject* __Pyx__PyCode_New(int a, int p, int k, int l, int s, int f, PyObject *code, PyObject *c, PyObject* n, PyObject *v, PyObject *fv, PyObject *cell, PyObject* fn, PyObject *name, int fline, PyObject *lnos) { PyObject *exception_table = NULL; PyObject *types_module=NULL, *code_type=NULL, *result=NULL; #if __PYX_LIMITED_VERSION_HEX < 0x030b0000 PyObject *version_info; PyObject *py_minor_version = NULL; #endif long minor_version = 0; PyObject *type, *value, *traceback; PyErr_Fetch(&type, &value, &traceback); #if __PYX_LIMITED_VERSION_HEX >= 0x030b0000 minor_version = 11; #else if (!(version_info = PySys_GetObject("version_info"))) goto end; if (!(py_minor_version = PySequence_GetItem(version_info, 1))) goto end; minor_version = PyLong_AsLong(py_minor_version); Py_DECREF(py_minor_version); if (minor_version == -1 && PyErr_Occurred()) goto end; #endif if (!(types_module = PyImport_ImportModule("types"))) goto end; if (!(code_type = PyObject_GetAttrString(types_module, "CodeType"))) goto end; if (minor_version <= 7) { (void)p; result = PyObject_CallFunction(code_type, "iiiiiOOOOOOiOOO", a, k, l, s, f, code, c, n, v, fn, name, fline, lnos, fv, cell); } else if (minor_version <= 10) { result = PyObject_CallFunction(code_type, "iiiiiiOOOOOOiOOO", a,p, k, l, s, f, code, c, n, v, fn, name, fline, lnos, fv, cell); } else { if (!(exception_table = PyBytes_FromStringAndSize(NULL, 0))) goto end; result = PyObject_CallFunction(code_type, "iiiiiiOOOOOOOiOOOO", a,p, k, l, s, f, code, c, n, v, fn, name, name, fline, lnos, exception_table, fv, cell); } end: Py_XDECREF(code_type); Py_XDECREF(exception_table); Py_XDECREF(types_module); if (type) { PyErr_Restore(type, value, traceback); } return result; } #elif PY_VERSION_HEX >= 0x030B0000 static PyCodeObject* __Pyx__PyCode_New(int a, int p, int k, int l, int s, int f, PyObject *code, PyObject *c, PyObject* n, PyObject *v, PyObject *fv, PyObject *cell, PyObject* fn, PyObject *name, int fline, PyObject *lnos) { PyCodeObject *result; result = #if PY_VERSION_HEX >= 0x030C0000 PyUnstable_Code_NewWithPosOnlyArgs #else PyCode_NewWithPosOnlyArgs #endif (a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, name, fline, lnos, __pyx_mstate_global->__pyx_empty_bytes); #if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x030c00A1 if (likely(result)) result->_co_firsttraceable = 0; #endif return result; } #elif PY_VERSION_HEX >= 0x030800B2 && !CYTHON_COMPILING_IN_PYPY #define __Pyx__PyCode_New(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)\ PyCode_NewWithPosOnlyArgs(a, p, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) #else #define __Pyx__PyCode_New(a, p, 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 static PyObject* __Pyx_PyCode_New( const __Pyx_PyCode_New_function_description descr, PyObject * const *varnames, PyObject *filename, PyObject *funcname, const char *line_table, PyObject *tuple_dedup_map ) { PyObject *code_obj = NULL, *varnames_tuple_dedup = NULL, *code_bytes = NULL, *line_table_bytes = NULL; Py_ssize_t var_count = (Py_ssize_t) descr.nlocals; PyObject *varnames_tuple = PyTuple_New(var_count); if (unlikely(!varnames_tuple)) return NULL; for (Py_ssize_t i=0; i < var_count; i++) { Py_INCREF(varnames[i]); if (__Pyx_PyTuple_SET_ITEM(varnames_tuple, i, varnames[i]) != (0)) goto done; } #if CYTHON_COMPILING_IN_LIMITED_API varnames_tuple_dedup = PyDict_GetItem(tuple_dedup_map, varnames_tuple); if (!varnames_tuple_dedup) { if (unlikely(PyDict_SetItem(tuple_dedup_map, varnames_tuple, varnames_tuple) < 0)) goto done; varnames_tuple_dedup = varnames_tuple; } #else varnames_tuple_dedup = PyDict_SetDefault(tuple_dedup_map, varnames_tuple, varnames_tuple); if (unlikely(!varnames_tuple_dedup)) goto done; #endif #if CYTHON_AVOID_BORROWED_REFS Py_INCREF(varnames_tuple_dedup); #endif if (__PYX_LIMITED_VERSION_HEX >= (0x030b0000) && line_table != NULL && !CYTHON_COMPILING_IN_GRAAL) { line_table_bytes = PyBytes_FromStringAndSize(line_table, descr.line_table_length); if (unlikely(!line_table_bytes)) goto done; Py_ssize_t code_len = (descr.line_table_length * 2 + 4) & ~3; code_bytes = PyBytes_FromStringAndSize(NULL, code_len); if (unlikely(!code_bytes)) goto done; char* c_code_bytes = PyBytes_AsString(code_bytes); if (unlikely(!c_code_bytes)) goto done; memset(c_code_bytes, 0, (size_t) code_len); } code_obj = (PyObject*) __Pyx__PyCode_New( (int) descr.argcount, (int) descr.num_posonly_args, (int) descr.num_kwonly_args, (int) descr.nlocals, 0, (int) descr.flags, code_bytes ? code_bytes : __pyx_mstate_global->__pyx_empty_bytes, __pyx_mstate_global->__pyx_empty_tuple, __pyx_mstate_global->__pyx_empty_tuple, varnames_tuple_dedup, __pyx_mstate_global->__pyx_empty_tuple, __pyx_mstate_global->__pyx_empty_tuple, filename, funcname, (int) descr.first_line, (__PYX_LIMITED_VERSION_HEX >= (0x030b0000) && line_table_bytes) ? line_table_bytes : __pyx_mstate_global->__pyx_empty_bytes ); done: Py_XDECREF(code_bytes); Py_XDECREF(line_table_bytes); #if CYTHON_AVOID_BORROWED_REFS Py_XDECREF(varnames_tuple_dedup); #endif Py_DECREF(varnames_tuple); return code_obj; } /* InitStrings */ static int __Pyx_InitStrings(__Pyx_StringTabEntry const *t, PyObject **target, const char* const* encoding_names) { while (t->s) { PyObject *str; if (t->is_unicode) { if (t->intern) { str = PyUnicode_InternFromString(t->s); } else if (t->encoding) { str = PyUnicode_Decode(t->s, t->n - 1, encoding_names[t->encoding], NULL); } else { str = PyUnicode_FromStringAndSize(t->s, t->n - 1); } } else { str = PyBytes_FromStringAndSize(t->s, t->n - 1); } if (!str) return -1; *target = str; if (PyObject_Hash(str) == -1) return -1; ++t; ++target; } return 0; } #include static CYTHON_INLINE Py_ssize_t __Pyx_ssize_strlen(const char *s) { size_t len = strlen(s); if (unlikely(len > (size_t) PY_SSIZE_T_MAX)) { PyErr_SetString(PyExc_OverflowError, "byte string is too long"); return -1; } return (Py_ssize_t) len; } static CYTHON_INLINE PyObject* __Pyx_PyUnicode_FromString(const char* c_str) { Py_ssize_t len = __Pyx_ssize_strlen(c_str); if (unlikely(len < 0)) return NULL; return __Pyx_PyUnicode_FromStringAndSize(c_str, len); } static CYTHON_INLINE PyObject* __Pyx_PyByteArray_FromString(const char* c_str) { Py_ssize_t len = __Pyx_ssize_strlen(c_str); if (unlikely(len < 0)) return NULL; return PyByteArray_FromStringAndSize(c_str, len); } 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_UTF8 static CYTHON_INLINE const char* __Pyx_PyUnicode_AsStringAndSize(PyObject* o, Py_ssize_t *length) { if (unlikely(__Pyx_PyUnicode_READY(o) == -1)) return NULL; #if CYTHON_COMPILING_IN_LIMITED_API { const char* result; Py_ssize_t unicode_length; CYTHON_MAYBE_UNUSED_VAR(unicode_length); // only for __PYX_DEFAULT_STRING_ENCODING_IS_ASCII #if __PYX_LIMITED_VERSION_HEX < 0x030A0000 if (unlikely(PyArg_Parse(o, "s#", &result, length) < 0)) return NULL; #else result = PyUnicode_AsUTF8AndSize(o, length); #endif #if __PYX_DEFAULT_STRING_ENCODING_IS_ASCII unicode_length = PyUnicode_GetLength(o); if (unlikely(unicode_length < 0)) return NULL; if (unlikely(unicode_length != *length)) { PyUnicode_AsASCIIString(o); return NULL; } #endif return result; } #else #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_UTF8 if (PyUnicode_Check(o)) { return __Pyx_PyUnicode_AsStringAndSize(o, length); } else #endif if (PyByteArray_Check(o)) { #if (CYTHON_ASSUME_SAFE_SIZE && CYTHON_ASSUME_SAFE_MACROS) || (CYTHON_COMPILING_IN_PYPY && (defined(PyByteArray_AS_STRING) && defined(PyByteArray_GET_SIZE))) *length = PyByteArray_GET_SIZE(o); return PyByteArray_AS_STRING(o); #else *length = PyByteArray_Size(o); if (*length == -1) return NULL; return PyByteArray_AsString(o); #endif } else { 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_LongWrongResultType(PyObject* result) { __Pyx_TypeName result_type_name = __Pyx_PyType_GetFullyQualifiedName(Py_TYPE(result)); if (PyLong_Check(result)) { if (PyErr_WarnFormat(PyExc_DeprecationWarning, 1, "__int__ returned non-int (type " __Pyx_FMT_TYPENAME "). " "The ability to return an instance of a strict subclass of int is deprecated, " "and may be removed in a future version of Python.", result_type_name)) { __Pyx_DECREF_TypeName(result_type_name); Py_DECREF(result); return NULL; } __Pyx_DECREF_TypeName(result_type_name); return result; } PyErr_Format(PyExc_TypeError, "__int__ returned non-int (type " __Pyx_FMT_TYPENAME ")", result_type_name); __Pyx_DECREF_TypeName(result_type_name); Py_DECREF(result); return NULL; } static CYTHON_INLINE PyObject* __Pyx_PyNumber_Long(PyObject* x) { #if CYTHON_USE_TYPE_SLOTS PyNumberMethods *m; #endif PyObject *res = NULL; if (likely(PyLong_Check(x))) return __Pyx_NewRef(x); #if CYTHON_USE_TYPE_SLOTS m = Py_TYPE(x)->tp_as_number; if (likely(m && m->nb_int)) { res = m->nb_int(x); } #else if (!PyBytes_CheckExact(x) && !PyUnicode_CheckExact(x)) { res = PyNumber_Long(x); } #endif if (likely(res)) { if (unlikely(!PyLong_CheckExact(res))) { return __Pyx_PyNumber_LongWrongResultType(res); } } 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 (likely(PyLong_CheckExact(b))) { #if CYTHON_USE_PYLONG_INTERNALS if (likely(__Pyx_PyLong_IsCompact(b))) { return __Pyx_PyLong_CompactValue(b); } else { const digit* digits = __Pyx_PyLong_Digits(b); const Py_ssize_t size = __Pyx_PyLong_SignedDigitCount(b); 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 = PyLong_AsSsize_t(x); Py_DECREF(x); return ival; } static CYTHON_INLINE Py_hash_t __Pyx_PyIndex_AsHash_t(PyObject* o) { if (sizeof(Py_hash_t) == sizeof(Py_ssize_t)) { return (Py_hash_t) __Pyx_PyIndex_AsSsize_t(o); } else { Py_ssize_t ival; PyObject *x; x = PyNumber_Index(o); if (!x) return -1; ival = PyLong_AsLong(x); Py_DECREF(x); return ival; } } static CYTHON_INLINE PyObject *__Pyx_Owned_Py_None(int b) { CYTHON_UNUSED_VAR(b); return __Pyx_NewRef(Py_None); } static CYTHON_INLINE PyObject * __Pyx_PyBool_FromLong(long b) { return b ? __Pyx_NewRef(Py_True) : __Pyx_NewRef(Py_False); } static CYTHON_INLINE PyObject * __Pyx_PyLong_FromSize_t(size_t ival) { return PyLong_FromSize_t(ival); } #if CYTHON_USE_PYLONG_INTERNALS static CYTHON_INLINE int __Pyx_PyLong_CompactAsLong(PyObject *x, long *return_value) { if (unlikely(!__Pyx_PyLong_IsCompact(x))) return 0; Py_ssize_t value = __Pyx_PyLong_CompactValue(x); if ((sizeof(long) < sizeof(Py_ssize_t)) && unlikely(value != (long) value)) return 0; *return_value = (long) value; return 1; } #endif /* MultiPhaseInitModuleState */ #if CYTHON_PEP489_MULTI_PHASE_INIT && CYTHON_USE_MODULE_STATE #ifndef CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE #if (CYTHON_COMPILING_IN_LIMITED_API || PY_VERSION_HEX >= 0x030C0000) #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 1 #else #define CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE 0 #endif #endif #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE && !CYTHON_ATOMICS #error "Module state with PEP489 requires atomics. Currently that's one of\ C11, C++11, gcc atomic intrinsics or MSVC atomic intrinsics" #endif #if !CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE #define __Pyx_ModuleStateLookup_Lock() #define __Pyx_ModuleStateLookup_Unlock() #elif !CYTHON_COMPILING_IN_LIMITED_API && PY_VERSION_HEX >= 0x030d0000 static PyMutex __Pyx_ModuleStateLookup_mutex = {0}; #define __Pyx_ModuleStateLookup_Lock() PyMutex_Lock(&__Pyx_ModuleStateLookup_mutex) #define __Pyx_ModuleStateLookup_Unlock() PyMutex_Unlock(&__Pyx_ModuleStateLookup_mutex) #elif defined(__cplusplus) && __cplusplus >= 201103L #include static std::mutex __Pyx_ModuleStateLookup_mutex; #define __Pyx_ModuleStateLookup_Lock() __Pyx_ModuleStateLookup_mutex.lock() #define __Pyx_ModuleStateLookup_Unlock() __Pyx_ModuleStateLookup_mutex.unlock() #elif defined(__STDC_VERSION__) && (__STDC_VERSION__ > 201112L) && !defined(__STDC_NO_THREADS__) #include static mtx_t __Pyx_ModuleStateLookup_mutex; static once_flag __Pyx_ModuleStateLookup_mutex_once_flag = ONCE_FLAG_INIT; static void __Pyx_ModuleStateLookup_initialize_mutex(void) { mtx_init(&__Pyx_ModuleStateLookup_mutex, mtx_plain); } #define __Pyx_ModuleStateLookup_Lock()\ call_once(&__Pyx_ModuleStateLookup_mutex_once_flag, __Pyx_ModuleStateLookup_initialize_mutex);\ mtx_lock(&__Pyx_ModuleStateLookup_mutex) #define __Pyx_ModuleStateLookup_Unlock() mtx_unlock(&__Pyx_ModuleStateLookup_mutex) #elif defined(HAVE_PTHREAD_H) #include static pthread_mutex_t __Pyx_ModuleStateLookup_mutex = PTHREAD_MUTEX_INITIALIZER; #define __Pyx_ModuleStateLookup_Lock() pthread_mutex_lock(&__Pyx_ModuleStateLookup_mutex) #define __Pyx_ModuleStateLookup_Unlock() pthread_mutex_unlock(&__Pyx_ModuleStateLookup_mutex) #elif defined(_WIN32) #include // synchapi.h on its own doesn't work static SRWLOCK __Pyx_ModuleStateLookup_mutex = SRWLOCK_INIT; #define __Pyx_ModuleStateLookup_Lock() AcquireSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) #define __Pyx_ModuleStateLookup_Unlock() ReleaseSRWLockExclusive(&__Pyx_ModuleStateLookup_mutex) #else #error "No suitable lock available for CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE.\ Requires C standard >= C11, or C++ standard >= C++11,\ or pthreads, or the Windows 32 API, or Python >= 3.13." #endif typedef struct { int64_t id; PyObject *module; } __Pyx_InterpreterIdAndModule; typedef struct { char interpreter_id_as_index; Py_ssize_t count; Py_ssize_t allocated; __Pyx_InterpreterIdAndModule table[1]; } __Pyx_ModuleStateLookupData; #define __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE 32 #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE static __pyx_atomic_int_type __Pyx_ModuleStateLookup_read_counter = 0; #endif #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE static __pyx_atomic_ptr_type __Pyx_ModuleStateLookup_data = 0; #else static __Pyx_ModuleStateLookupData* __Pyx_ModuleStateLookup_data = NULL; #endif static __Pyx_InterpreterIdAndModule* __Pyx_State_FindModuleStateLookupTableLowerBound( __Pyx_InterpreterIdAndModule* table, Py_ssize_t count, int64_t interpreterId) { __Pyx_InterpreterIdAndModule* begin = table; __Pyx_InterpreterIdAndModule* end = begin + count; if (begin->id == interpreterId) { return begin; } while ((end - begin) > __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { __Pyx_InterpreterIdAndModule* halfway = begin + (end - begin)/2; if (halfway->id == interpreterId) { return halfway; } if (halfway->id < interpreterId) { begin = halfway; } else { end = halfway; } } for (; begin < end; ++begin) { if (begin->id >= interpreterId) return begin; } return begin; } static PyObject *__Pyx_State_FindModule(CYTHON_UNUSED void* dummy) { int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); if (interpreter_id == -1) return NULL; #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE __Pyx_ModuleStateLookupData* data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); { __pyx_atomic_incr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); if (likely(data)) { __Pyx_ModuleStateLookupData* new_data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_acquire(&__Pyx_ModuleStateLookup_data); if (likely(data == new_data)) { goto read_finished; } } __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); __Pyx_ModuleStateLookup_Lock(); __pyx_atomic_incr_relaxed(&__Pyx_ModuleStateLookup_read_counter); data = (__Pyx_ModuleStateLookupData*)__pyx_atomic_pointer_load_relaxed(&__Pyx_ModuleStateLookup_data); __Pyx_ModuleStateLookup_Unlock(); } read_finished:; #else __Pyx_ModuleStateLookupData* data = __Pyx_ModuleStateLookup_data; #endif __Pyx_InterpreterIdAndModule* found = NULL; if (unlikely(!data)) goto end; if (data->interpreter_id_as_index) { if (interpreter_id < data->count) { found = data->table+interpreter_id; } } else { found = __Pyx_State_FindModuleStateLookupTableLowerBound( data->table, data->count, interpreter_id); } end: { PyObject *result=NULL; if (found && found->id == interpreter_id) { result = found->module; } #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE __pyx_atomic_decr_acq_rel(&__Pyx_ModuleStateLookup_read_counter); #endif return result; } } #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE static void __Pyx_ModuleStateLookup_wait_until_no_readers(void) { while (__pyx_atomic_load(&__Pyx_ModuleStateLookup_read_counter) != 0); } #else #define __Pyx_ModuleStateLookup_wait_until_no_readers() #endif static int __Pyx_State_AddModuleInterpIdAsIndex(__Pyx_ModuleStateLookupData **old_data, PyObject* module, int64_t interpreter_id) { Py_ssize_t to_allocate = (*old_data)->allocated; while (to_allocate <= interpreter_id) { if (to_allocate == 0) to_allocate = 1; else to_allocate *= 2; } __Pyx_ModuleStateLookupData *new_data = *old_data; if (to_allocate != (*old_data)->allocated) { new_data = (__Pyx_ModuleStateLookupData *)realloc( *old_data, sizeof(__Pyx_ModuleStateLookupData)+(to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); if (!new_data) { PyErr_NoMemory(); return -1; } for (Py_ssize_t i = new_data->allocated; i < to_allocate; ++i) { new_data->table[i].id = i; new_data->table[i].module = NULL; } new_data->allocated = to_allocate; } new_data->table[interpreter_id].module = module; if (new_data->count < interpreter_id+1) { new_data->count = interpreter_id+1; } *old_data = new_data; return 0; } static void __Pyx_State_ConvertFromInterpIdAsIndex(__Pyx_ModuleStateLookupData *data) { __Pyx_InterpreterIdAndModule *read = data->table; __Pyx_InterpreterIdAndModule *write = data->table; __Pyx_InterpreterIdAndModule *end = read + data->count; for (; readmodule) { write->id = read->id; write->module = read->module; ++write; } } data->count = write - data->table; for (; writeid = 0; write->module = NULL; } data->interpreter_id_as_index = 0; } static int __Pyx_State_AddModule(PyObject* module, CYTHON_UNUSED void* dummy) { int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); if (interpreter_id == -1) return -1; int result = 0; __Pyx_ModuleStateLookup_Lock(); #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE __Pyx_ModuleStateLookupData *old_data = (__Pyx_ModuleStateLookupData *) __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); #else __Pyx_ModuleStateLookupData *old_data = __Pyx_ModuleStateLookup_data; #endif __Pyx_ModuleStateLookupData *new_data = old_data; if (!new_data) { new_data = (__Pyx_ModuleStateLookupData *)calloc(1, sizeof(__Pyx_ModuleStateLookupData)); if (!new_data) { result = -1; PyErr_NoMemory(); goto end; } new_data->allocated = 1; new_data->interpreter_id_as_index = 1; } __Pyx_ModuleStateLookup_wait_until_no_readers(); if (new_data->interpreter_id_as_index) { if (interpreter_id < __PYX_MODULE_STATE_LOOKUP_SMALL_SIZE) { result = __Pyx_State_AddModuleInterpIdAsIndex(&new_data, module, interpreter_id); goto end; } __Pyx_State_ConvertFromInterpIdAsIndex(new_data); } { Py_ssize_t insert_at = 0; { __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( new_data->table, new_data->count, interpreter_id); assert(lower_bound); insert_at = lower_bound - new_data->table; if (unlikely(insert_at < new_data->count && lower_bound->id == interpreter_id)) { lower_bound->module = module; goto end; // already in table, nothing more to do } } if (new_data->count+1 >= new_data->allocated) { Py_ssize_t to_allocate = (new_data->count+1)*2; new_data = (__Pyx_ModuleStateLookupData*)realloc( new_data, sizeof(__Pyx_ModuleStateLookupData) + (to_allocate-1)*sizeof(__Pyx_InterpreterIdAndModule)); if (!new_data) { result = -1; new_data = old_data; PyErr_NoMemory(); goto end; } new_data->allocated = to_allocate; } ++new_data->count; int64_t last_id = interpreter_id; PyObject *last_module = module; for (Py_ssize_t i=insert_at; icount; ++i) { int64_t current_id = new_data->table[i].id; new_data->table[i].id = last_id; last_id = current_id; PyObject *current_module = new_data->table[i].module; new_data->table[i].module = last_module; last_module = current_module; } } end: #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, new_data); #else __Pyx_ModuleStateLookup_data = new_data; #endif __Pyx_ModuleStateLookup_Unlock(); return result; } static int __Pyx_State_RemoveModule(CYTHON_UNUSED void* dummy) { int64_t interpreter_id = PyInterpreterState_GetID(__Pyx_PyInterpreterState_Get()); if (interpreter_id == -1) return -1; __Pyx_ModuleStateLookup_Lock(); #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE __Pyx_ModuleStateLookupData *data = (__Pyx_ModuleStateLookupData *) __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, 0); #else __Pyx_ModuleStateLookupData *data = __Pyx_ModuleStateLookup_data; #endif if (data->interpreter_id_as_index) { if (interpreter_id < data->count) { data->table[interpreter_id].module = NULL; } goto done; } { __Pyx_ModuleStateLookup_wait_until_no_readers(); __Pyx_InterpreterIdAndModule* lower_bound = __Pyx_State_FindModuleStateLookupTableLowerBound( data->table, data->count, interpreter_id); if (!lower_bound) goto done; if (lower_bound->id != interpreter_id) goto done; __Pyx_InterpreterIdAndModule *end = data->table+data->count; for (;lower_boundid = (lower_bound+1)->id; lower_bound->module = (lower_bound+1)->module; } } --data->count; if (data->count == 0) { free(data); data = NULL; } done: #if CYTHON_MODULE_STATE_LOOKUP_THREAD_SAFE __pyx_atomic_pointer_exchange(&__Pyx_ModuleStateLookup_data, data); #else __Pyx_ModuleStateLookup_data = data; #endif __Pyx_ModuleStateLookup_Unlock(); return 0; } #endif /* #### Code section: utility_code_pragmas_end ### */ #ifdef _MSC_VER #pragma warning( pop ) #endif /* #### Code section: end ### */ #endif /* Py_PYTHON_H */ inveniosoftware-contrib-intbitset-91de683/intbitset/intbitset.h000066400000000000000000000070161517417475300251470ustar00rootroot00000000000000// This file is part of Invenio. // Copyright (C) 2007, 2008, 2009, 2010, 2011, 2014, 2015, 2016 CERN. // // SPDX-License-Identifier: LGPL-3.0-or-later // // Invenio is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public License as // published by the Free Software Foundation; either version 3 of the // License, or (at your option) any later version. // // Invenio is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with Invenio; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. #ifndef INTBITSET_H #define INTBITSET_H #include #if PY_VERSION_HEX < 0x02050000 #ifndef PY_SSIZE_T_CLEAN typedef int Py_ssize_t; #endif #endif // Fake declarations: do not call them! #if PY_VERSION_HEX >= 0x03000000 PyObject* PyString_FromStringAndSize(const char *v, Py_ssize_t len); #endif typedef unsigned long long int word_t; typedef unsigned char bool_t; extern const int wordbytesize; extern const int wordbitsize; extern const int maxelem; typedef struct { int size; int allocated; word_t trailing_bits; int tot; word_t *bitset; } IntBitSet; IntBitSet *intBitSetCreate(register const int size, const bool_t trailing_bits); IntBitSet *intBitSetCreateFromBuffer(const void * const buf, const Py_ssize_t bufsize); IntBitSet *intBitSetResetFromBuffer(IntBitSet *const bitset, const void *const buf, const Py_ssize_t bufsize); IntBitSet *intBitSetReset(IntBitSet *const bitset); void intBitSetDestroy(IntBitSet *const bitset); IntBitSet *intBitSetClone(const IntBitSet * const bitset); int intBitSetGetSize(IntBitSet * const bitset); int intBitSetGetAllocated(const IntBitSet * const bitset); int intBitSetGetTot(IntBitSet * const bitset); void intBitSetResize(IntBitSet *const bitset, register const unsigned int allocated); bool_t intBitSetIsInElem(const IntBitSet * const bitset, register const unsigned int elem); void intBitSetAddElem(IntBitSet *const bitset, register const unsigned int elem); void intBitSetDelElem(IntBitSet *const bitset, register const unsigned int elem); bool_t intBitSetEmpty(const IntBitSet * const bitset); IntBitSet *intBitSetUnion(IntBitSet *const x, IntBitSet *const y); IntBitSet *intBitSetXor(IntBitSet *const x, IntBitSet *const y); IntBitSet *intBitSetIntersection(IntBitSet *const x, IntBitSet *const y); IntBitSet *intBitSetSub(IntBitSet *const x, IntBitSet *const y); IntBitSet *intBitSetIUnion(IntBitSet *const dst, IntBitSet *const src); IntBitSet *intBitSetIXor(IntBitSet *const dst, IntBitSet *const src); IntBitSet *intBitSetIIntersection(IntBitSet *const dst, IntBitSet *const src); IntBitSet *intBitSetISub(IntBitSet *const x, IntBitSet *const y); bool_t intBitSetIsDisjoint(const IntBitSet * const x, const IntBitSet * const y); int intBitSetAdaptMax(IntBitSet *const x, IntBitSet *const y); int intBitSetAdaptMin(IntBitSet *const x, IntBitSet *const y); int intBitSetGetNext(const IntBitSet *const x, register int last); int intBitSetGetLast(const IntBitSet *const x); /** Compare. * Compare two intbitset. * Returns 0 if the two bitset are equals. * Returns 1 if x is proper subset of y * Returns 2 if y is proper subset of x * Returns 3 if x != y */ unsigned char intBitSetCmp(IntBitSet *const x, IntBitSet *const y); #endif inveniosoftware-contrib-intbitset-91de683/intbitset/intbitset.pyx000066400000000000000000000776711517417475300255560ustar00rootroot00000000000000# This file is part of Invenio. # Copyright (C) 2007, 2008, 2009, 2010, 2011, 2013, 2014, 2015, 2016 CERN. # # SPDX-License-Identifier: LGPL-3.0-or-later # # Invenio is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # Invenio is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with Invenio; if not, write to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. # cython: infer_types=True # cython: language_level=2 """ Defines an intbitset data object to hold unordered sets of unsigned integers with ultra fast set operations, implemented via bit vectors and Python C extension to optimize speed and memory usage. Emulates the Python built-in set class interface with some additional specific methods such as its own fast dump and load marshalling functions. Uses real bits to optimize memory usage, so may have issues with endianness if you transport serialized bitsets between various machine architectures. Please note that no bigger than __maxelem__ elements can be added to an intbitset and, if CFG_INTBITSET_ENABLE_SANITY_CHECKS is disabled, you will receive unpredictable results. Note to developers: If you make modification to this file you have to manually regenerate intbitset.c by running: $ cython intbitset.pyx and then commit generated intbitset.c. """ #cython: infer_types=True import sys import zlib from array import array from cpython.buffer cimport PyBUF_SIMPLE, Py_buffer, PyObject_GetBuffer, PyBuffer_Release from cpython.ref cimport PyObject CFG_INTBITSET_ENABLE_SANITY_CHECKS = False from intbitset_helper import _ from intbitset_version import __version__ __all__ = ['intbitset', '__version__'] cdef extern from *: ## See: ## In order to avoid warnings with PyObject_AsReadBuffer ctypedef void* const_void_ptr "const void*" cdef extern from "intbitset.h": ctypedef int Py_ssize_t object PyBytes_FromStringAndSize(char *s, Py_ssize_t len) object PyString_FromStringAndSize(char *s, Py_ssize_t len) cdef extern from "intbitset.h": ctypedef unsigned long long int word_t #ctypedef unsigned char bool_t ctypedef struct IntBitSet: int size int allocated word_t trailing_bits int tot word_t *bitset int wordbytesize int wordbitsize int maxelem IntBitSet *intBitSetCreate(int size, bint trailing_bits) IntBitSet *intBitSetCreateFromBuffer(void *buf, int bufsize) IntBitSet *intBitSetResetFromBuffer(IntBitSet *bitset, void *buf, int bufsize) IntBitSet *intBitSetReset(IntBitSet *bitset) void intBitSetDestroy(IntBitSet *bitset) IntBitSet *intBitSetClone(IntBitSet *bitset) int intBitSetGetSize(IntBitSet *bitset) int intBitSetGetAllocated(IntBitSet *bitset) int intBitSetGetTot(IntBitSet * bitset) bint intBitSetIsInElem(IntBitSet *bitset, unsigned int elem) void intBitSetAddElem(IntBitSet *bitset, unsigned int elem) void intBitSetDelElem(IntBitSet *bitset, unsigned int elem) bint intBitSetEmpty(IntBitSet *bitset) IntBitSet *intBitSetUnion(IntBitSet *x, IntBitSet *y) IntBitSet *intBitSetIntersection(IntBitSet *x, IntBitSet *y) IntBitSet *intBitSetSub(IntBitSet *x, IntBitSet *y) IntBitSet *intBitSetXor(IntBitSet *x, IntBitSet *y) IntBitSet *intBitSetIUnion(IntBitSet *dst, IntBitSet *src) IntBitSet *intBitSetIIntersection(IntBitSet *dst, IntBitSet *src) IntBitSet *intBitSetISub(IntBitSet *x, IntBitSet *y) IntBitSet *intBitSetIXor(IntBitSet *x, IntBitSet *y) bint intBitSetIsDisjoint(IntBitSet *x, IntBitSet *y) int intBitSetGetNext(IntBitSet *x, int last) int intBitSetGetLast(IntBitSet *x) unsigned char intBitSetCmp(IntBitSet *x, IntBitSet *y) __maxelem__ = maxelem cdef class intbitset: """ Defines an intbitset data object to hold unordered sets of unsigned integers with ultra fast set operations, implemented via bit vectors and Python C extension to optimize speed and memory usage. Emulates the Python built-in set class interface with some additional specific methods such as its own fast dump and load marshalling functions. Uses real bits to optimize memory usage, so may have issues with endianness if you transport serialized bitsets between various machine architectures. The constructor accept the following parameters: rhs=0, int preallocate=-1, int trailing_bits=0, bint sanity_checks=CFG_INTBITSET_ENABLE_SANITY_CHECKS, int no_allocate=0: where rhs can be: * ``int/long`` for creating allocating empty intbitset that will hold at least rhs elements, before being resized * ``intbitset`` for cloning * ``bytes`` for retrieving an intbitset that was dumped into a byte string * ``array`` for retrieving an intbitset that was dumped into a string stored in an array * sequence made of integers for copying all the elements from the sequence. If minsize is specified than it is initially allocated enough space to hold up to minsize integers, otherwise the biggest element of the sequence will be used. * sequence made of tuples: then the first element of each tuple is considered as an integer (as in the sequence made of integers). The other arguments are: * ``preallocate`` is a suggested initial upper bound on the numbers that will be stored, by looking at rhs a sequence of number. * ``trailing_bits`` is 1, then the set will contain "all" the positive integers * ``no_allocate`` and ``sanity_checks`` are used internally and should never be set. """ cdef IntBitSet *bitset cdef bint sanity_checks def __cinit__( self not None, rhs=0, int preallocate=-1, int trailing_bits=0, bint sanity_checks=CFG_INTBITSET_ENABLE_SANITY_CHECKS, int no_allocate=0, ): cdef Py_ssize_t size = 0 cdef const_void_ptr buf = NULL cdef int elem cdef int last cdef int remelem cdef bint tuple_of_tuples cdef Py_buffer view self.sanity_checks = sanity_checks #print >> sys.stderr, "intbitset.__cinit__ is called" msg = "Error" self.bitset = NULL try: if no_allocate: return if type(rhs) in (int, long): if rhs < 0: raise ValueError("rhs can't be negative") self.bitset = intBitSetCreate(rhs, trailing_bits) elif type(rhs) is intbitset: self.bitset = intBitSetClone((rhs).bitset) elif type(rhs) in (bytes, array): try: if type(rhs) is array: rhs = rhs.tobytes() tmp = zlib.decompress(rhs) if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: raise ValueError("Unable to get buffer") try: buf = view.buf size = view.len if (size % wordbytesize): ## Wrong size! raise Exception() self.bitset = intBitSetCreateFromBuffer(buf, size) finally: PyBuffer_Release(&view) except Exception as e: raise ValueError("rhs is corrupted: %s" % str(e)) elif hasattr(rhs, '__iter__'): tuple_of_tuples = ( rhs and hasattr(rhs, '__getitem__') and hasattr(rhs[0], '__getitem__') ) try: if preallocate < 0: if rhs and (not hasattr(rhs, '__getitem__') or type(rhs[0]) is int): try: preallocate = max(rhs) except ValueError: preallocate = 0 else: preallocate = 0 if self.sanity_checks: if not (0 <= preallocate < maxelem): raise OverflowError("Can't store integers bigger than %s" % maxelem) self.bitset = intBitSetCreate(preallocate, trailing_bits) if trailing_bits: last = 0 if self.sanity_checks: if tuple_of_tuples: for tmp_tuple in rhs: elem = tmp_tuple[0] if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) for remelem from last <= remelem < elem: intBitSetDelElem(self.bitset, remelem) last = elem + 1 else: for elem in rhs: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) for remelem from last <= remelem < elem: intBitSetDelElem(self.bitset, remelem) last = elem + 1 else: if tuple_of_tuples: for tmp_tuple in rhs: elem = tmp_tuple[0] for remelem from last <= remelem < elem: intBitSetDelElem(self.bitset, remelem) last = elem + 1 else: for elem in rhs: for remelem from last <= remelem < elem: intBitSetDelElem(self.bitset, remelem) last = elem + 1 else: if self.sanity_checks: if tuple_of_tuples: for tmp_tuple in rhs: elem = tmp_tuple[0] if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) intBitSetAddElem(self.bitset, elem) else: for elem in rhs: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) intBitSetAddElem(self.bitset, elem) else: if tuple_of_tuples: for tmp_tuple in rhs: elem = tmp_tuple[0] intBitSetAddElem(self.bitset, elem) else: for elem in rhs: intBitSetAddElem(self.bitset, elem) except Exception as e: raise ValueError("retrieving integers from rhs is impossible: %s" % str(e)) else: raise TypeError("rhs is of unknown type %s" % type(rhs)) except: intBitSetDestroy(self.bitset) raise def __dealloc__(self not None): #print >> sys.stderr, "intbitset.__dealloc__ is called" intBitSetDestroy(self.bitset) def __contains__(self not None, int elem): if self.sanity_checks: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Element must be <= %s" % maxelem) return intBitSetIsInElem(self.bitset, elem) != 0 def __cmp__(self not None, intbitset rhs not None): raise TypeError("cannot compare intbitset using cmp()") def __richcmp__(self not None, rhs, int op): if not isinstance(self, intbitset) or not isinstance(rhs, intbitset): return False cdef short unsigned int tmp tmp = intBitSetCmp((self).bitset, (rhs).bitset) if op == 0: # < return tmp == 1 if op == 1: # <= return tmp <= 1 if op == 2: # == return tmp == 0 if op == 3: # != return tmp > 0 if op == 4: # > return tmp == 2 if op == 5: # >= return tmp in (0, 2) def __len__(self not None): return intBitSetGetTot(self.bitset) def __hash__(self not None): return hash( PyBytes_FromStringAndSize( self.bitset.bitset, wordbytesize * (intBitSetGetTot(self.bitset) / wordbitsize + 1) ) ) def __nonzero__(self not None): return not intBitSetEmpty(self.bitset) def __deepcopy__(self not None, memo): return intbitset(self) def __delitem__(self not None, int elem): if self.sanity_checks: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Element must be <= %s" % maxelem) intBitSetDelElem(self.bitset, elem) def __iadd__(self not None, rhs): cdef int elem if isinstance(rhs, (int, long)): if self.sanity_checks: if rhs < 0: raise ValueError("Negative numbers, not allowed") elif rhs > maxelem: raise OverflowError("rhs must be <= %s" % maxelem) intBitSetAddElem(self.bitset, rhs) elif isinstance(rhs, intbitset): intBitSetIUnion(self.bitset, ( rhs).bitset) else: if self.sanity_checks: for elem in rhs: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) intBitSetAddElem(self.bitset, elem) else: for elem in rhs: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) intBitSetAddElem(self.bitset, elem) return self def __isub__(self not None, rhs not None): """Remove all elements of another set from this set.""" cdef int elem if isinstance(rhs, (int, long)): if self.sanity_checks: if rhs < 0: raise ValueError("Negative numbers, not allowed") elif rhs > maxelem: raise OverflowError("rhs must be <= %s" % maxelem) intBitSetDelElem(self.bitset, rhs) elif isinstance(rhs, intbitset): intBitSetISub(self.bitset, ( rhs).bitset) else: if self.sanity_checks: for elem in rhs: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) intBitSetDelElem(self.bitset, elem) else: for elem in rhs: intBitSetDelElem(self.bitset, elem) return self def __sub__(self not None, intbitset rhs not None): """Return the difference of two intbitsets as a new set. (i.e. all elements that are in this intbitset but not the other.) """ cdef intbitset ret = intbitset(no_allocate=1) (ret).bitset = intBitSetSub(( self).bitset, rhs.bitset) return ret def __and__(self not None, intbitset rhs not None): """Return the intersection of two intbitsets as a new set. (i.e. all elements that are in both intbitsets.) """ cdef intbitset ret = intbitset(no_allocate=1) (ret).bitset = intBitSetIntersection(( self).bitset, rhs.bitset) return ret def __iand__(self not None, intbitset rhs not None): """Update a intbitset with the intersection of itself and another.""" intBitSetIIntersection(self.bitset, rhs.bitset) return self def __or__(self not None, intbitset rhs not None): """Return the union of two intbitsets as a new set. (i.e. all elements that are in either intbitsets.) """ cdef intbitset ret = intbitset(no_allocate=1) (ret).bitset = intBitSetUnion(( self).bitset, rhs.bitset) return ret def __ior__(self not None, intbitset rhs not None): """Update a intbitset with the union of itself and another.""" intBitSetIUnion(self.bitset, rhs.bitset) return self def __xor__(self not None, intbitset rhs not None): """Return the symmetric difference of two sets as a new set. (i.e. all elements that are in exactly one of the sets.) """ cdef intbitset ret = intbitset(no_allocate=1) (ret).bitset = intBitSetXor(( self).bitset, rhs.bitset) return ret def __ixor__(self not None, intbitset rhs not None): """Update an intbitset with the symmetric difference of itself and another. """ intBitSetIXor(self.bitset, rhs.bitset) return self def __repr__(self not None): finite_list = self.extract_finite_list() if self.bitset.trailing_bits: return "intbitset(%s, trailing_bits=True)" % repr(finite_list) else: return "intbitset(%s)" % repr(finite_list) def __str__(self not None): cdef int tot tot = intBitSetGetTot(self.bitset) if tot < 0: return "intbitset([...], trailing_bits=True)" elif tot > 10: begin_list = self[0:5] end_list = self[tot - 5:tot] ret = "intbitset([" for n in begin_list: ret += '%i, ' % n ret += "..., " for n in end_list: ret += '%i, ' % n ret = ret[:-2] ret += '])' return ret else: return self.__repr__() def __getitem__(self not None, object key): cdef Py_ssize_t i cdef int elem = -1 cdef int start cdef int end cdef int step if hasattr(key, 'indices'): ## This is a slice object! if self.bitset.trailing_bits and (key.start < 0 or key.stop < 0): raise IndexError("negative indexes are not allowed on infinite intbitset") retset = intbitset() start, end, step = key.indices(intBitSetGetTot(self.bitset)) if step < 0: raise ValueError("negative steps are not yet supported") for i in range(start): elem = intBitSetGetNext(self.bitset, elem) if elem < 0: return retset for i in range(end - start): elem = intBitSetGetNext(self.bitset, elem) if elem < 0: return retset if i % step == 0: retset.add(elem) return retset else: end = key if end < 0: if self.bitset.trailing_bits: raise IndexError("negative indexes are not allowed on infinite intbitset") end += intBitSetGetTot(self.bitset) if end < 0: raise IndexError("intbitset index out of range") if end >= intBitSetGetTot(self.bitset): raise IndexError("intbitset index out of range") for i in range(end + 1): elem = intBitSetGetNext(self.bitset, elem) return elem # pickle interface def __reduce__(self not None): return _, (self.fastdump(),) __safe_for_unpickling__ = True # Iterator interface def __iter__(self not None): if self.bitset.trailing_bits: raise OverflowError("It's impossible to iterate over an infinite set.") return intbitset_iterator(self) # Customized interface cpdef add(intbitset self, int elem): """Add an element to a set. This has no effect if the element is already present.""" if self.sanity_checks: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Element must be <= %s" % maxelem) intBitSetAddElem(self.bitset, elem) cpdef clear(intbitset self): intBitSetReset(self.bitset) cpdef discard(intbitset self, int elem): """Remove an element from a intbitset if it is a member. If the element is not a member, do nothing.""" if self.sanity_checks: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Element must be <= %s" % maxelem) intBitSetDelElem(self.bitset, elem) symmetric_difference = __xor__ symmetric_difference_update = __ixor__ cpdef issubset(intbitset self, rhs): """Report whether another set contains this set.""" return self.__le__(rhs) cpdef issuperset(intbitset self, rhs): """Report whether this set contains another set.""" return self.__ge__(rhs) # Dumping & Loading cpdef fastdump(intbitset self): """Return a compressed string representation suitable to be saved somewhere.""" cdef Py_ssize_t size size = intBitSetGetSize(( self).bitset) tmp = PyBytes_FromStringAndSize(self.bitset.bitset, ( size + 1) * wordbytesize) return zlib.compress(tmp) cpdef fastload(intbitset self, strdump): """Load a compressed string representation produced by a previous call to the fastdump method into the current intbitset. The previous content will be replaced.""" cdef Py_ssize_t size cdef const_void_ptr buf cdef Py_buffer view buf = NULL size = 0 try: if type(strdump) is array: strdump = strdump.tostring() # tmp needed to not be garbage collected tmp = zlib.decompress(strdump) if PyObject_GetBuffer(tmp, &view, PyBUF_SIMPLE) != 0: raise ValueError("Unable to get buffer") try: buf = view.buf size = view.len if (size % wordbytesize): ## Wrong size! raise Exception() intBitSetResetFromBuffer(( self).bitset, buf, size) finally: PyBuffer_Release(&view) except: raise ValueError("strdump is corrupted") cpdef copy(intbitset self): """Return a shallow copy of a set.""" return intbitset(self) cpdef pop(intbitset self): """Remove and return an arbitrary set element. Note: intbitset implementation of .pop() differs from the native ``set`` implementation by guaranteeing returning always the largest element. """ cdef int ret ret = intBitSetGetLast(self.bitset) if ret < 0: raise KeyError("pop from an empty or infinite intbitset") intBitSetDelElem(self.bitset, ret) return ret cpdef remove(intbitset self, int elem): """Remove an element from a set; it must be a member. If the element is not a member, raise a KeyError. """ if self.sanity_checks: if elem < 0: raise ValueError("Negative numbers, not allowed") elif elem > maxelem: raise OverflowError("Elements must be <= %s" % maxelem) if intBitSetIsInElem(self.bitset, elem): intBitSetDelElem(self.bitset, elem) else: raise KeyError(elem) cpdef strbits(intbitset self): """Return a string of 0s and 1s representing the content in memory of the intbitset. """ cdef int i cdef int last if ( self).bitset.trailing_bits: raise OverflowError("It's impossible to print an infinite set.") last = 0 ret = [] for i in self: ret.append('0'*(i-last)+'1') last = i+1 return ''.join(ret) def update(self not None, *args): """Update the intbitset, adding elements from all others.""" cdef intbitset iarg for arg in args: iarg = arg if hasattr(arg, "bitset") else intbitset(arg) intBitSetIUnion(self.bitset, iarg.bitset) union_update = update def intersection_update(self not None, *args): """Update the intbitset, keeping only elements found in it and all others.""" cdef intbitset iarg for arg in args: iarg = arg if hasattr(arg, "bitset") else intbitset(arg) intBitSetIIntersection(self.bitset, iarg.bitset) def difference_update(self not None, *args): """Update the intbitset, removing elements found in others.""" cdef intbitset iarg for arg in args: iarg = arg if hasattr(arg, "bitset") else intbitset(arg) intBitSetISub(self.bitset, iarg.bitset) def union(self not None, *args): """Return a new intbitset with elements from the intbitset and all others.""" cdef intbitset ret = intbitset(self) cdef intbitset iarg for arg in args: iarg = arg if hasattr(arg, "bitset") else intbitset(arg) intBitSetIUnion(ret.bitset, iarg.bitset) return ret def intersection(self not None, *args): """Return a new intbitset with elements common to the intbitset and all others.""" cdef intbitset ret = intbitset(self) cdef intbitset iarg for arg in args: iarg = arg if hasattr(arg, "bitset") else intbitset(arg) intBitSetIIntersection(ret.bitset, iarg.bitset) return ret def difference(self not None, *args): """Return a new intbitset with elements from the intbitset that are not in the others.""" cdef intbitset ret = intbitset(self) cdef intbitset iarg for arg in args: iarg = arg if hasattr(arg, "bitset") else intbitset(arg) intBitSetISub(ret.bitset, iarg.bitset) return ret def isdisjoint(self not None, intbitset rhs not None): """Return True if two intbitsets have a null intersection.""" return intBitSetIsDisjoint(self.bitset, rhs.bitset) cpdef update_with_signs(intbitset self, rhs): """Given a dictionary rhs whose keys are integers, remove all the integers whose value are less than 0 and add every integer whose value is 0 or more""" cdef int value try: if self.sanity_checks: for value, sign in rhs.iteritems(): if value < 0: raise ValueError("Negative numbers, not allowed") elif value > maxelem: raise OverflowError("Elements must <= %s" % maxelem) if sign < 0: intBitSetDelElem(self.bitset, value) else: intBitSetAddElem(self.bitset, value) else: for value, sign in rhs.iteritems(): if sign < 0: intBitSetDelElem(self.bitset, value) else: intBitSetAddElem(self.bitset, value) except AttributeError: raise TypeError("rhs should be a valid dictionary with integers keys and integer values") cpdef get_size(intbitset self): return intBitSetGetSize(self.bitset) cpdef get_allocated(intbitset self): return intBitSetGetAllocated(self.bitset) cpdef is_infinite(intbitset self): """Return True if the intbitset is infinite. (i.e. trailing_bits=True was used in the constructor.)""" return self.bitset.trailing_bits != 0 cpdef extract_finite_list(intbitset self, int up_to=-1): """Return a finite list of elements sufficient to be passed to intbitset constructor toghether with the proper value of trailing_bits in order to reproduce this intbitset. At least up_to integer are looked for when they are inside the intbitset but not necessarily needed to build the intbitset""" cdef int true_up_to cdef int last if self.sanity_checks and up_to > maxelem: raise OverflowError("up_to must be <= %s" % maxelem) ret = [] true_up_to = max(up_to, (intBitSetGetSize(self.bitset)) * wordbitsize) last = -1 while last < true_up_to: last = intBitSetGetNext(self.bitset, last) if last == -2: break ret.append(last) return ret cpdef get_wordbitsize(intbitset self): return wordbitsize cpdef get_wordbytsize(intbitset self): return wordbytesize cpdef tolist(intbitset self): """Legacy method to retrieve a list of all the elements inside an intbitset. """ if self.bitset.trailing_bits: raise OverflowError("It's impossible to retrieve a list of an infinite set") return self.extract_finite_list() cdef object __weakref__ cdef class intbitset_iterator: cdef int last cdef IntBitSet *bitset cdef bint sanity_checks def __cinit__(intbitset_iterator self, intbitset bitset not None): #print >> sys.stderr, "intbitset_iterator.__cinit__ is called" self.last = -1 ## A copy should be performed, in case the original bitset disappears ## as in "for x in intbitset([1,2,3])"! self.bitset = intBitSetClone(bitset.bitset) self.sanity_checks = CFG_INTBITSET_ENABLE_SANITY_CHECKS def __dealloc__(intbitset_iterator self): #print >> sys.stderr, "intbitset_iterator.__dealloc__ is called" intBitSetDestroy(self.bitset) def __next__(intbitset_iterator self): if self.last == -2: raise StopIteration() self.last = intBitSetGetNext(self.bitset, self.last) if self.sanity_checks and (self.bitset.allocated < self.bitset.size): raise MemoryError( "intbitset corrupted: allocated: %s, size: %s" % (self.bitset.allocated, self.bitset.size) ) if self.last < 0: self.last = -2 raise StopIteration() return self.last def __iter__(intbitset_iterator self): return self cdef object __weakref__ inveniosoftware-contrib-intbitset-91de683/intbitset/intbitset_helper.py000066400000000000000000000024341517417475300267060ustar00rootroot00000000000000# This file is part of Invenio. # Copyright (C) 2007, 2008, 2009, 2010, 2011, 2013, 2015, 2016 CERN. # # SPDX-License-Identifier: LGPL-3.0-or-later # # Invenio is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # Invenio is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with Invenio; if not, write to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. """ This function is needed only when load a pickled instanced of intbitset. It needs to be stored in a real .py file, because currently cython would have instantiate such a function as built-in function. """ def _(dump): """ As part of the pickle protocol, a callable that will instantiate the class is needed. It's called _ just to make it short and hidden :-) """ from intbitset import intbitset return intbitset(dump) inveniosoftware-contrib-intbitset-91de683/intbitset/intbitset_impl.c000066400000000000000000000372011517417475300261620ustar00rootroot00000000000000// This file is part of Invenio. // Copyright (C) 2007, 2008, 2009, 2010, 2011, 2014, 2015, 2016 CERN. // // SPDX-License-Identifier: LGPL-3.0-or-later // // Invenio is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public License as // published by the Free Software Foundation; either version 3 of the // License, or (at your option) any later version. // // Invenio is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with Invenio; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. #include #include #include #include "intbitset.h" // Fake declarations: do not call them! #if PY_VERSION_HEX >= 0x03000000 PyObject* PyString_FromStringAndSize(const char *v, Py_ssize_t len) { return NULL; } #endif const int wordbytesize = sizeof(word_t); const int wordbitsize = sizeof(word_t) * 8; const int maxelem = INT_MAX; IntBitSet *intBitSetCreate(register const int size, const bool_t trailing_bits) { register word_t *base; register word_t *end; IntBitSet *ret = PyMem_Malloc(sizeof(IntBitSet)); // fprintf(stderr, "intBitSetCreate called\n"); // At least one word -> the one who represent the trailing_bits ret->allocated = (size / wordbitsize + 1); ret->size = 0; // trailing_bits ret->trailing_bits = trailing_bits ? (word_t) ~0 : 0; if (trailing_bits) { base = ret->bitset = PyMem_Malloc(ret->allocated * wordbytesize); end = base + ret->allocated; for (; base < end; ++base) *base = (word_t) ~0; ret->tot = -1; } else { base = ret->bitset = PyMem_Malloc(ret->allocated * wordbytesize); end = base + ret->allocated; for (; base < end; ++base) *base = (word_t) 0; ret->tot = 0; } return ret; } IntBitSet *intBitSetResetFromBuffer(IntBitSet *const bitset, const void *const buf, const Py_ssize_t bufsize) { // fprintf(stderr, "intBitSetResetFromBuffer called\n"); register Py_ssize_t newallocate = bufsize/wordbytesize; if (newallocate > bitset->allocated) { PyMem_Free(bitset->bitset); bitset->bitset = PyMem_Malloc(bufsize); } bitset->allocated = newallocate; bitset->tot = -1; bitset->size = bitset->allocated - 1; memcpy(bitset->bitset, buf, bufsize); bitset->trailing_bits = *(bitset->bitset + bitset->allocated - 1) ? (word_t) ~0 : 0; return bitset; } IntBitSet *intBitSetReset(IntBitSet *const bitset) { // fprintf(stderr, "intBitSetReset called\n"); // NOTE: soft reset the memory. Instead of freeing it, which is slow // simply declare in the intbitset that the allocated memory is one only // word, and zero that word, so that as soon as more memory is needed // a realloc will be triggered. bitset->allocated = 1; bitset->size = -1; *bitset->bitset = 0; bitset->trailing_bits = 0; bitset->tot = 0; return bitset; } IntBitSet *intBitSetCreateFromBuffer(const void *const buf, const Py_ssize_t bufsize) { // fprintf(stderr, "intBitSetCreateFromBuffer called\n"); IntBitSet *ret = PyMem_Malloc(sizeof(IntBitSet)); ret->allocated = bufsize/wordbytesize; ret->bitset = PyMem_Malloc(bufsize); ret->size = ret->allocated - 1;; ret->tot = -1; memcpy(ret->bitset, buf, bufsize); ret->trailing_bits = *(ret->bitset + ret->allocated - 1) ? (word_t) ~0 : 0; return ret; } void intBitSetDestroy(IntBitSet *const bitset) { // fprintf(stderr, "intBitSetDestroy called\n"); if (bitset) { if (bitset->bitset) PyMem_Free(bitset->bitset); PyMem_Free(bitset); } } IntBitSet *intBitSetClone(const IntBitSet * const bitset) { // fprintf(stderr, "intBitSetClone called\n"); IntBitSet *ret = PyMem_Malloc(sizeof(IntBitSet)); ret->size = bitset->size; ret->tot = bitset->tot; ret->trailing_bits = bitset->trailing_bits; ret->allocated = bitset->allocated; ret->bitset = PyMem_Malloc(bitset->allocated * wordbytesize); memcpy(ret->bitset, bitset->bitset, bitset->allocated * wordbytesize); return ret; } int intBitSetGetSize(IntBitSet * const bitset) { register word_t *base; register word_t *end; if (bitset->size >= 0) return bitset->size; base = bitset->bitset; end = bitset->bitset + bitset->allocated - 2; for (; base < end && *end == bitset->trailing_bits; --end); bitset->size = ((int) (end - base) + 1); return bitset->size; } int intBitSetGetTot(IntBitSet *const bitset) { register word_t* base; #ifndef __GNUC__ register int i; #endif register int tot; register word_t *end; if (bitset->trailing_bits) return -1; if (bitset->tot < 0) { end = bitset->bitset + bitset->allocated; tot = 0; for (base = bitset->bitset; base < end; ++base) if (*base) #ifdef __GNUC__ // See: // tot += __builtin_popcountll(*base); #else for (i=0; itot = tot; } return bitset->tot; } int intBitSetGetAllocated(const IntBitSet * const bitset) { return bitset->allocated; } void intBitSetResize(IntBitSet *const bitset, register const unsigned int allocated) { // fprintf(stderr, "intBitSetResize called\n"); register word_t *base; register word_t *end; register word_t trailing_bits; if (allocated > bitset->allocated) { bitset->bitset = PyMem_Realloc(bitset->bitset, allocated * wordbytesize); base = bitset->bitset + bitset->allocated; end = bitset->bitset + allocated; trailing_bits = bitset->trailing_bits; for (; baseallocated = allocated; } } bool_t intBitSetIsInElem(const IntBitSet * const bitset, register const unsigned int elem) { return ((elem < bitset->allocated * wordbitsize) ? (bitset->bitset[elem / wordbitsize] & ((word_t) 1 << ((word_t)elem % (word_t)wordbitsize))) != 0 : bitset->trailing_bits != 0); } void intBitSetAddElem(IntBitSet *const bitset, register const unsigned int elem) { if (elem >= (bitset->allocated - 1) * wordbitsize) { if (bitset->trailing_bits) return; else intBitSetResize(bitset, (elem + elem/10)/wordbitsize+2); } bitset->bitset[elem / wordbitsize] |= ((word_t) 1 << (elem % wordbitsize)); bitset->tot = -1; bitset->size = -1; } void intBitSetDelElem(IntBitSet *const bitset, register const unsigned int elem) { if (elem >= (bitset->allocated - 1) * wordbitsize) { if (!bitset->trailing_bits) return; else intBitSetResize(bitset, (elem + elem/10)/wordbitsize+2); } bitset->bitset[elem / wordbitsize] &= (word_t) ~((word_t) 1 << (elem % wordbitsize)); bitset->tot = -1; bitset->size = -1; } bool_t intBitSetEmpty(const IntBitSet *const bitset) { register word_t *end; register word_t *base; if (bitset->trailing_bits) return 0; if (bitset->tot == 0) return 1; end = bitset->bitset + bitset->allocated; for (base = bitset->bitset; base < end; ++base) if (*base) return 0; return 1; } int intBitSetAdaptMax(IntBitSet *const x, IntBitSet *const y) { // Good idea but broken, it is kept for better time... // register int sizex = intBitSetGetSize(x); // register int sizey = intBitSetGetSize(y); // register int sizemax = ((sizex > sizey) ? sizex : sizey) + 1; // if (sizemax > x->allocated) // intBitSetResize(x, sizemax); // if (sizemax > y->allocated) // intBitSetResize(y, sizemax); // return sizemax;*/ register int allocated = (x->allocated > y->allocated) ? x->allocated : y->allocated; if (allocated > x->allocated) intBitSetResize(x, allocated); if (allocated > y->allocated) intBitSetResize(y, allocated); return allocated; } int intBitSetAdaptMin(IntBitSet *const x, IntBitSet *const y) { register int sizex; register int sizey; if (x->trailing_bits || y->trailing_bits) return intBitSetAdaptMax(x, y); sizex = intBitSetGetSize(x); sizey = intBitSetGetSize(y); return ((sizex < sizey) ? sizex : sizey) + 1; } IntBitSet *intBitSetUnion(IntBitSet *const x, IntBitSet *const y) { register word_t *xbase; register word_t *xend; register word_t *ybase; register word_t *retbase; register IntBitSet * ret = PyMem_Malloc(sizeof (IntBitSet)); ret->allocated = intBitSetAdaptMax(x, y); xbase = x->bitset; xend = x->bitset+ret->allocated; ybase = y->bitset; retbase = ret->bitset = PyMem_Malloc(wordbytesize * ret->allocated); ret->size = -1; ret->tot = -1; for (; xbase < xend; ++xbase, ++ybase, ++retbase) *(retbase) = *(xbase) | *(ybase); ret->trailing_bits = x->trailing_bits | y->trailing_bits; return ret; } IntBitSet *intBitSetXor(IntBitSet *const x, IntBitSet *const y) { register word_t *xbase; register word_t *xend; register word_t *ybase; register word_t *retbase; register IntBitSet * ret = PyMem_Malloc(sizeof (IntBitSet)); ret->allocated = intBitSetAdaptMax(x, y); xbase = x->bitset; xend = x->bitset+ret->allocated; ybase = y->bitset; retbase = ret->bitset = PyMem_Malloc(wordbytesize * ret->allocated); ret->size = -1; ret->tot = -1; for (; xbase < xend; ++xbase, ++ybase, ++retbase) *(retbase) = *(xbase) ^ *(ybase); ret->trailing_bits = x->trailing_bits ^ y->trailing_bits; return ret; } IntBitSet *intBitSetIntersection(IntBitSet *const x, IntBitSet *const y) { register word_t *xbase; register word_t *xend; register word_t *ybase; register word_t *retbase; register IntBitSet * ret = PyMem_Malloc(sizeof (IntBitSet)); ret->allocated = intBitSetAdaptMin(x, y); xbase = x->bitset; xend = x->bitset+ret->allocated; ybase = y->bitset; retbase = ret->bitset = PyMem_Malloc(wordbytesize * ret->allocated); ret->size = -1; ret->tot = -1; for (; xbase < xend; ++xbase, ++ybase, ++retbase) *(retbase) = *(xbase) & *(ybase); ret->trailing_bits = x->trailing_bits & y->trailing_bits; return ret; } IntBitSet *intBitSetSub(IntBitSet *const x, IntBitSet *const y) { register word_t *xbase; register word_t *ybase; register word_t *retbase; register word_t *retend; register IntBitSet * ret = PyMem_Malloc(sizeof (IntBitSet)); register int tmpsize = intBitSetAdaptMin(x, y); register word_t trailing_bits; ret->allocated = x->allocated > tmpsize ? x->allocated : tmpsize; xbase = x->bitset; ybase = y->bitset; retbase = ret->bitset = PyMem_Malloc(wordbytesize * ret->allocated); retend = ret->bitset+tmpsize; ret->size = -1; ret->tot = -1; for (; retbase < retend; ++xbase, ++ybase, ++retbase) *(retbase) = *(xbase) & ~*(ybase); retend = ret->bitset+ret->allocated; trailing_bits = y->trailing_bits; for (; retbase < retend; ++xbase, ++retbase) *retbase = *xbase & ~trailing_bits; ret->trailing_bits = x->trailing_bits & ~y->trailing_bits; return ret; } IntBitSet *intBitSetIUnion(IntBitSet *const dst, IntBitSet *const src) { register word_t *dstbase; register word_t *srcbase; register word_t *srcend; register int allocated = intBitSetAdaptMax(dst, src); dstbase = dst->bitset; srcbase = src->bitset; srcend = src->bitset + allocated; for (; srcbase < srcend; ++dstbase, ++srcbase) *dstbase |= *srcbase; dst->size = -1; dst->tot = -1; dst->trailing_bits |= src->trailing_bits; return dst; } IntBitSet *intBitSetIXor(IntBitSet *const dst, IntBitSet *const src) { register word_t *dstbase; register word_t *srcbase; register word_t *srcend; register int allocated = intBitSetAdaptMax(dst, src); dstbase = dst->bitset; srcbase = src->bitset; srcend = src->bitset + allocated; for (; srcbase < srcend; ++dstbase, ++srcbase) *dstbase ^= *srcbase; dst->size = -1; dst->tot = -1; dst->trailing_bits ^= src->trailing_bits; return dst; } IntBitSet *intBitSetIIntersection(IntBitSet *const dst, IntBitSet *const src) { register word_t *dstbase; register word_t *srcbase; register word_t *dstend; dst->allocated = intBitSetAdaptMin(dst, src); dstbase = dst->bitset; srcbase = src->bitset; dstend = dst->bitset + dst->allocated; for (; dstbase < dstend; ++dstbase, ++srcbase) *dstbase &= *srcbase; dst->size = -1; dst->tot = -1; dst->trailing_bits &= src->trailing_bits; return dst; } IntBitSet *intBitSetISub(IntBitSet *const dst, IntBitSet *const src) { register word_t *dstbase; register word_t *srcbase; register word_t *dstend; register int allocated = intBitSetAdaptMin(dst, src); register word_t trailing_bits; dstbase = dst->bitset; srcbase = src->bitset; dstend = dst->bitset + allocated; for (; dstbase < dstend; ++dstbase, ++srcbase) *dstbase &= ~*srcbase; dstend = dst->bitset + dst->allocated; trailing_bits = src->trailing_bits; for (; dstbase < dstend; ++dstbase) *dstbase &= ~trailing_bits; dst->size = -1; dst->tot = -1; dst->trailing_bits &= ~src->trailing_bits; return dst; } bool_t intBitSetIsDisjoint(const IntBitSet * const x, const IntBitSet * const y) { word_t *xword; word_t *xend; word_t *yword; xword = x->bitset; xend = x->bitset + intBitSetAdaptMin(x, y); yword = y->bitset; for (; xword < xend; ++xword, ++yword) { if ((*xword & *yword) != 0x0) return 0; // Not disjoint } return ((x->trailing_bits & y->trailing_bits) != 0) ? 0 : 1; } int intBitSetGetLast(const IntBitSet *const x) { register word_t *base = x->bitset; register word_t *end = x->bitset + x->allocated; register int i; if (x->trailing_bits) return -2; while (base < end) { if (*(--end)) for (i=wordbitsize-1; i>=0; --i) if ((*end & ((word_t) 1 << (word_t) i))) return (int) i + (int) (end - x->bitset) * wordbitsize; } return -1; } int intBitSetGetNext(const IntBitSet *const x, register int last) { register word_t *base = x->bitset + (++last / wordbitsize); register int i = last % wordbitsize; register word_t *end = x->bitset + x->allocated; while(base < end) { if (*base) for (; ibitset) * wordbitsize; i = 0; ++base; } return x->trailing_bits ? last : -2; } unsigned char intBitSetCmp(IntBitSet *const x, IntBitSet *const y) { register word_t *xbase; register word_t *xend; register word_t *ybase; register unsigned char ret = 0; register int allocated = intBitSetAdaptMax(x, y); xbase = x->bitset; xend = x->bitset+allocated; ybase = y->bitset; for (; ret != 3 && xbasetrailing_bits != (x->trailing_bits | y->trailing_bits)) * 2 + (x->trailing_bits != (x->trailing_bits | y->trailing_bits)); return ret; } inveniosoftware-contrib-intbitset-91de683/intbitset/intbitset_version.py000066400000000000000000000022741517417475300271160ustar00rootroot00000000000000# -*- coding: utf-8 -*- # # This file is part of intbitset # Copyright (C) 2015, 2016 CERN. # # SPDX-License-Identifier: LGPL-3.0-or-later # # intbitset is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # intbitset is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with intbitset; if not, write to the Free Software Foundation, # Inc., 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. # # In applying this licence, CERN does not waive the privileges and immunities # granted to it by virtue of its status as an Intergovernmental Organization # or submit itself to any jurisdiction. """Version information for intbitset.""" # Do not change the format of this next line. Doing so risks breaking # setup.py and docs/conf.py __version__ = "4.1.0" inveniosoftware-contrib-intbitset-91de683/setup.cfg000066400000000000000000000023011517417475300225750ustar00rootroot00000000000000# -*- coding: utf-8 -*- # # This file is part of intbitset # Copyright (C) 2013, 2015, 2016 CERN. # # SPDX-License-Identifier: LGPL-3.0-or-later # # intbitset is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # intbitset is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with intbitset; if not, write to the Free Software Foundation, # Inc., 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. # # In applying this licence, CERN does not waive the privileges and immunities # granted to it by virtue of its status as an Intergovernmental Organization # or submit itself to any jurisdiction. [build_sphinx] source-dir = docs/ build-dir = docs/_build all_files = 1 [metadata] license_files = LICENSE AUTHORS.rst README.rst CHANGELOG.rst inveniosoftware-contrib-intbitset-91de683/setup.py000066400000000000000000000050341517417475300224740ustar00rootroot00000000000000# -*- coding: utf-8 -*- # # This file is part of intbitset # Copyright (C) CERN and others # # SPDX-License-Identifier: LGPL-3.0-or-later # # intbitset is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # intbitset is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with intbitset; if not, write to the Free Software Foundation, # Inc., 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. # # In applying this licence, CERN does not waive the privileges and immunities # granted to it by virtue of its status as an Intergovernmental Organization # or submit itself to any jurisdiction. """C-based extension implementing fast integer bit sets.""" from setuptools import Extension from setuptools import setup setup( name="intbitset", version="4.1.2", url="http://github.com/inveniosoftware-contrib/intbitset/", license="LGPL-3.0-or-later", author="Invenio collaboration, maintained by Philippe Ombredanne and AboutCode.org", author_email="pombredanne@nexb.com", description="C-based extension implementing fast integer bit sets.", long_description=open("README.rst").read(), long_description_content_type="text/x-rst", package_dir={"": "intbitset"}, py_modules=["intbitset_helper", "intbitset_version"], ext_modules=[ Extension( "intbitset", ["intbitset/intbitset.c", "intbitset/intbitset_impl.c"], # extra_compile_args = [] # For debug -> extra_compile_args=['-ftree-vectorizer-verbose=2'] ) ], zip_safe=False, include_package_data=True, platforms="any", classifiers=[ "Environment :: Console", "Intended Audience :: Developers", "License :: OSI Approved :: GNU Lesser General Public License v3 or later (LGPLv3+)", "Operating System :: OS Independent", "Programming Language :: Cython", "Programming Language :: C", "Programming Language :: Python", "Topic :: Software Development :: Libraries :: Python Modules", "Programming Language :: Python :: 3", ], extras_require={"tests": ["pytest", "pytest-xdist"]} ) inveniosoftware-contrib-intbitset-91de683/tests/000077500000000000000000000000001517417475300221225ustar00rootroot00000000000000inveniosoftware-contrib-intbitset-91de683/tests/intbitset_example.int000066400000000000000000001107511517417475300263630ustar00rootroot00000000000000x} |]E}I V^Q^U!*/ ]>עe%`L .QU"PLWTĠPd -mrs;_o=З{̙3gΜ93qA_3c C@ u_䗫6;NK>縬 /!SD**/h_nnqhHn+gCCşLOw˯X;ۖwGؒWזbqKyAZQnÒ .[vG ?mҞ=4ECl u~膝c%w_W,^Vp3xcxHwZ.e]s˟[+~ܞuw7oj]T\2|.^rG_Vܲ.l"Iq˺E<0~ņ2A]n\AM2_A~W:˭KtbcIdyOR.eRbCʋhZR\ŵgEח[0ז*FPW,^k n+q^u~do%-%%$’_z7-ӱC,$)}c4qG]^qvIŻ7-/./Tuˊn &ܰ.mm\۾ {7^\NZ۶-$(Gw/bn@Kon)m#BO%HrcEK'}:5/erٺk6./|mpE7۶`ے=6]WϽ q'X\|kyɜDuкn)gL2?| ]/+.Z|wy7kWd1iǵ˭+G췒xx#SHm 򭤯ܰ`)ͲחKh.-d(1Җy 4l2LXuy7/-.>m-.B r7Ejװ`-IHFZ%$oW,ZE¶G'>x~,akH&[hdҭ7;K,jeHew\U^ªJ\byio^vٙWH5X,Y^qmG.*n"my[H,֞!Ve'Fx"A(AG/RBź%kn[Bŗ1n @]杭uNVOHzR [,%d. "FIun+Հt4UL1(H//g7]e7ncC:.];smK3n\M)Vt,=KDu o#}h:/~8Fmkn~eDRm_[L6-K/[4Ҕt i:a9gF\4TN+g9͵b}ycHmMѺuKwˬ_[{T޵^r@snXF>^Vz1bR2I3xEy~H:z.!Odrm6*?\zϕ:F\s&ʊ0F%ůo>LۃV6,w딣R.KK\teŧlYaM0^yˊ+O#zyQWi㺗/lI"Ǘo9[֫[7v<|LyAw_=zG1nzC儍D0~5vW;W{x1國yKXk r4 pA0a3P.]i>ÈqWr\#:^vܲ(WWwה,!};+g5t3ժ@"ߑ_2K]OYM)SQ'"<VV!JYZ֜9v!iP p[DyUYsNFf*1ڈ^9ptfr x_܅[tݖ7u]'xW|;W[zL]w}l{p桷|x꛻i0JO<ѩ%;W"M3'7MR!.:a|-Sp{H=.Lmǽ{?f0>cT`::B}p=]?ztgwI(\?3M}>^*>Ku-H8~/f5җsJOq08&&ܸ,!s oW`K['@+)/4i!聤Y-z@ \i(Yi6X%o\ orHjF0@+kղB !5ihVD;H)@F:V&[ (.h1,ȌM >AQ9qO| /BW V %Q22(F ^  aŸ/yht4$>hg%I^:J*eYR-G(~B R>hCH2j9`:ξ>@V$K!i2ߖճȅea]Tj)PeKlˁLD'YȃB "*=k{Ql@c@Z*(EkPd(K1zھ) I҃IFLG2H( 1gT)kf^?UJ;*ĪdpWDAVZ=/6VנfI THRP1*!]}?*z*Wiy:mub8P"?*QDvt1T-aJKV%ILTPir`,/S*Gb^ћF\yzxBItMgMŨ%6xl03E/!UnxC{$)dgE4 't"5qomRT$!Q9 cJJ PR~3ae m%!MA .ڀq,HEO.kd 퀪OrfOD+qz5T*I(}3ʌDy`5ԆRovU.HV4pEjZLML*I 6 U񨨨J *(+*<+or$=JU,dEl&H {bQmq:TH~q+e i'nv &^?p5;I+ R"Ӥ@=d;,Qp~1+Ai@5Iط/8|n(]VZ8'>h$Pb#˓TMPMFf 0%ZB!%N-a )>i53Weg{ao~/ľ="+<"gx.4ɒ.)`M)|/IGi&" 8EdxnJayisz:D]"Q!bL:٩ 3< {I ɂK]cNFzPfFE΋8[&(/!)iDjX_2ø{!5|6mQVV+S1IX" y<&\ZȀ*,Z@%<餔KOl$>-b݅Vz:WTZ ЉqYADOD:b iaTDxQ$N3UM)0xv$4 =1"p9{C+NbY# I *0z(/^iٳo U/S)⥔T3.9S(Ĺtb]pĘn\i)-0?MP|b+ Q]jE<^`{RH tzEQK\C }q=SQZ+ǫN?&)E6'a0-]EȨ N8="=B"Tx!~Mcq4vZL?lXY[{4@"&,GʊXAgB\#Ů* ׼eO 'Tl)Iv}pYMXوHuFyS"2Ӣ+xHeWo:"Zψ{TU4IN~Ǚ6x8arBMKIxKtT`dU9%_ )HD2  XUǦ ~i@ UtNt8ivpn0O+( O_ΐR}roQyOIQ472N)foV:"`$"e۸S^{Mnkh8c &D- I|MTD uPǸ=*3+tP#Bd{q+n屸s}$d|`q8yHy"t(RCe!S(lrҖy>Ɩ49e<`f3XO0(1#Jʋ?4d@(WOL\&rpTW|z\]:w AgU_90Mh{=IB*ni;.K 0N)3/>I en:0ѡ%t0;!nj8w)deø/XEo+&c4ěi33VInvbcϟb01QJԁH: #DR.5`<0ځJx/x/RѼ!lMg,FttφdpX(5*)N/T╛ OD${#٤цM2gzŘp+m҆m ֌'Eb ZELdC]xIUԢ[jFUm|eEH!i+5N-,b,3Ppra$.^tĽs2282c&x i!+^@(k1T5j55##m?RV$DJv:g {*ia]B|f:q-QL/+vyQcptQc!t*[Y?϶\7_edPB((.[&хHAX,bU4v`ŠO, ?0 ay-f*o~sݐ}{d9lNx^LbV zC3h$$VE(mIǎ,?.-rDC\Jq>%! i1$؂M mv+ UBq;spQd(ƽB_I #vbJ}{ 7W%yyS([M=P(ҘkO$ɓ7IIJ00FgR](cBKuy~XoJe|D >s-YR"-$OSpLZ}9}^C?㑮LFF@״=0%lzN;o.RCkL,{1`ڂH_ 6**""XS:U]ڥCyk%2I4xRռfKF!QgYaNH yF=K^s=K@S$ހ:[HDeQxYFBJQҊO׆fy`Ů&.%4ەjLL\g$p{(gxQ#KA$@j&70#8CG$I* ]+Dȋ69YUhpn}K-b*@6angJ VMm+kD 6-R( kɓ-ɻ|07h=T.FC{6Ofw!=)OH#^2@ĩ!8SBDcpũy<,#=>UߝJ8iKG#_TP.!qm>/)Dt0dOA͟3Pӟ6pץwpؑX15 kT-.EJn˪ aiYJyn@˭U켧ӶDT#de Յ߽R! JcRM$ZBh2IԼF 2hKXTڻff*IVL^Tr>5RKPVoL+M~5RK:L'@:(%XeKעS. ̸fw Vϒ}spFIG־ wFjO{Q\-%K`L4QH UN4eZkPy}8 ʴ-2xŅE0JQ,ݨ' 6Y! JaVOURFڤ#0SE4$Lڰ9,-F_K&I#oUXY [CR!3r!XM`4`>߮@OM)܇PCWPs9*ζ k:0B (OVLnM%$d(~ bU6HL؆܅jK2IM}`5fj!L[X~SS/Oz( ғcD: VGzT4rn%fU+Pj 2YPΔO#&c^<L ?-%vjR NvޓC͎SXp)Q~c0YȒڎBYSh2Ƨ0%|6Ȍ>W~ӭSUC01Az*ʌh\}ƐQfI{WUt {#epC6ʏ2R*jRB^ZA<:)rA^b4D?LTS=?_qGYTFhޠ߹qPZOkapN'Vie :>Ԃ1$fN/1xEV: ̓C*UD@N sO$T/K&@rqE71¹&(\KsC!xqbX1hpr$cv0',KODae)E)$˺m 6A z@^#_ qb1]Z\ж0@9O㰇Z DvJ$DnTzd` MsvX1%ʥQ`yMgBȠn&A#d:{ Ō#fnMm13DTFmiWL좖lU QmlFǁNg ήEAF Db&٭kivJ+t 3 :*v* ,|@rW?\Gh+ g?$PLa-9E8Cѭ4P Tl+AsEZ A02 $u͈5&~c+TЃm N~Ôjq+Oc+["V2i~pXŖ٨6 Ue^kN|3YHK@@2H3tjլiz.ykfN4fDk'雿hC/AƤ4w-7 La՗# c)5~AKl(^szУ?;`|E:W aIG,/6 tbr;؋![='Hokn ՝Læ !-Eکi& v~O;r}~ ?S@rTuJdT%%" k`8>2DZ ?*X4 ħAP @x64jNpmt 9ɀ]tM2'c0KCmVk*0n{B׳GT@_h_wsDs-37e T3Pdj |l ;ȵ-۴ɰo2E#-,`2N|`ZuqqP^TuR1kjB-K{idN̮tUbظ2<і-Xewz{1dr-?xD~ٞzȲ لƛ*π=?u/v:7G pniWn/Em˘趀 qݿl|Sx>vA{pdO <?%$b1VO~*#*Y ,}T.^1ݤ\2>,=o 5!~ 'YN bvɳC +ﺂ=`˷": ǾfWu9Y]q}1r[RU c}.+U'RU\}WCmA`(mpOۇ6ؖH毵  /B.Kr6!mx $jI|lh5О@f$PjdB\/L040jRc TNH/@zS>F{G>y{x`ymRuIeI ]@asr^-AFNA- A^' [+BZlj,t1V|@`3QG+WMu2:C,/QAmq&F핈4Fn_  H7^So˾wDK2Vbğ5U_+!MN.2ә l:P(,#jGZZRFjp%RVJYy\ACDkb&h a56Im;%qI Ed'uV`~!s2@xtȳ6AVQG X-qWAL-!TTX1q?io";F p-  iQa9EЛ 5Piqo,[!o+p0 aySp&a'- ^L0j4h|gࢾR~gOatX8L8++=xWj0єpY/pv DPP_MֽQ1lUP:ls.?fц:섬*Tf m*'LGQMVLЍ~VJnj-pW:S܉V(f >SP'6Ȍ$A}yz!ȯh (qjX tb?VFuCk?TaQKJ%/Zݯ74Ssduy`V_+s4 cFO3h#b)DYĨzl+ ^5AAXeWLmKόcDflnp^4B:h^#5wFT*)$cT[WJQn- PdnؠI^V?ֳ¬3䱭|õ-T١8_YYEZ  pE`g^o[L ^/@Z CLbs.]z;Fw 6I*UN͖R&$MSt߭{;y ؏w^݇~ӯޝM(jerx >ns󝿻?wD mtSnͺpK3D),(MwS`tr"1vJʾ{'+њUoOS2/}os ε{U.Bg#d)11HNܴN.>n}os/Jm i7lzhrca7?9W}~o=@M'ޛ0G ;`rLת;4# SYR&Eo. xϘΣoߌw'D}NnaG~FQ1j>LE5Ǭx}M|cw?Q݄OR-EO,տS>}{Gֶ?vY{_Qaw < w^*<aՏ1%Ko"CRtP1>~=wd3iMSG `D;m!Lo#[h?^" d-Cb\Iz11( /n C UrKʹ=l9ݟk8-= ) + 48^:xS}9 aSq `ڲAKRL)taOƀ1ð ]4x?0p˦|B1G(guݥn#c>м@֣?ɸ7$K$ɳ0\<;h8mH 0>:n2 ʇm:#o&eF&) xrj lp,'P!DݝQYPK Ẁ($}D yH4(08 ;f()TqM !:>uEWsJ2S_”r[?ik1&U85mP\ I:{'فh.ERHP62U*%,C1w[]c(~.Պ3`3Ԯj Nc(D1ɶm4{EWT\ DنBm{M e4S"t*IJI=5Pa;OYt}W` @)o\IA*pWyvA.j2ȗڻaZ63|C/vsʸоi$`f.,-\v{LgWge\9-@mLuoD"}u~hVab&Y?4?J?fH!|`QW|%յ&tU &Yĺ-V #0d-mO&Pʒ;<ܒDK ۜWuZ6QgS$-ߛc?S1pxs$4 M9k9o:S:ƸC*4C$`nF~F.C[H!m[e<;z0_NUh3>T u{8JRW3K!8^BEs (|ğEs+C66@O 栫$ܝr 3TMN@O_B^ηgpW jϓ̿lxBr$`&C ?BuAk; YE(V A^qW;N64:<3N 즃U'KSS[v] !_aw_Zf*g)~kE7uoj&@ wb\mϐl5ɺNCo5No&ڦWQsBkIN&mA& u4ewF~G-NYJ;)Zh8_2gc9uUs,Ŏcq5OPߥ"ia|xLn7&#SgD :2UP(ܶAҫ5\OTZ2G䧒i#\PRHf9yEsV rуGXm&/HK>}In<1Sjz Bi=J/Myzli6ݤ)K6RҮgaא4=|{nHMR]渫Q9[v^kM#\R{ }E?'Aoc6߿ISAab0l$%)Nl12:e y'_{Z#8 @H'}:~)r ǹ30%8{qIӖlב^ω^G~Jq[vxpKzpSK c94 ʱ~;hMv͏ ؅,XU[Q77X4\>i;Cl{$8ۺ#*_%$궿-gSr}\,"wتǀν.? pA8 3WHqs3q}ڱk㚼3g@^kxa5jA28aW7$h_ϦZY\|DN*@GTKEg'[;TgYAHCHikxɒIA[+Z*(@s_vȃAw0_jw.;^uꆺ_{KÜsyDsOs ^d,0 2]7\塯U~g4l [n֪ItÑIwoUvꄞ|KӴGOxx!Vzb{8(c;6(iu/Wov5iBF;kV~\`f 4ҡB(xa} ڛJ~n>~Uu ǹ9eVmg9jkX0䕳_;uN]˜+vkgQQg6Zt7)noq77܀4tgo:nD2.evCܥ\gXQtOΦmSeGPܘId%{Ja ⢩a 뜓;$pzgVC[S;16h̐@x0 #wHhm%Bvp?~K-歽.5MKUc>z6bi圳/1R`_uA)I7rh'rk;\leDj6Do04L[`/? )cj~vFvk}\MKcBBrThfRo&t1j>ԝ]⎐13A8@sKRަg^B0W*%HCؤ{=8]}e=!x(۬lrx}Q8?r|2~)ܝ|l(`%Ar8Gb $}]-Aޒ2Bv v|NrݺO{~t#Yhm\,=W{'oä!\_C̣ |huJ~#MNyEBi'zሒWy8\ Ҡ@ -6戮:''Ry)ݎp)nQs_?(#R\d`{(X݋$WҸTr|r % .o#Ð6$:MϭwSen yAc.q ƭU1L }X1{𰏞r#'uɌEoaE+mn/tq8IT>E 2gzr?U!t5j< eΗuַ}n6ݚAk FZ}TʡuWS"AyY>U?gC朔&5I5'uE+nۖ,z/ߋjEq/Yٌ @ i+u0\K7*cyjZT6+Y{@D fNh"heg7QH2 sq;B-g^ U\{]4*DC,SRqkVD \34n1Ҕ5'~y!\6]Tc z:Wa/T ݳDS82i'Jp*v7Fhqie4~kYuN ٬CV}!<ۊ{~!.7t' R9,6`a>oZ#2ʏ]h>ќ,02{Ƨвfq,{]c1`oWSuӦ6G_/띓B}<>w0tyؼ]%|#cIO Jx˘KOLaaj+nnЛ{GFGOҿЊMgN"3IҪ#Iݫmg-%3܈;G;#-G@/zYT1 cDV$FD 0In//"t1REM]AʝvDS!*uߚ?/U!prVoh|/z.gyx%݃Z6db_1P#\F/$3~ >rsN|Fܠ`ׅ<+iaTZy3I|AʧvdG k9>~זW̊/;B^KQ8:S(!N]ya*u'&t#TڨU#n4ɴ Y5@RTs vHxc+8bB˹-sjsH[[;[+ҕm=aO8z]Co:dp]&5JOgjΚt6pW:">֓Tf݅p[M<50>VԒ`g^qE0SV@Y<KxRVC .$ #nJzE2>W pA8辶.z@p#T3FUHXO2tdaaYV)zdh;F%I >kucx Tye@,>URѣy , m[;mk NH Od.6#5Bu띯D}sw$ {΢|pZ}GgZЙ[$W>+&o^{*ឦUmj }Y:Zpo=v/nŤ!p:1KBj(v]f=WBN )5 TtnhZR̢A4שhCVJ+i'}6DMW CSfJVʷ'V/Sӥ~ M8ݹl@l{}nCU)]MK7O `9fiHՓγO9-N{QfnmPf|_yz%KA&nO[DW?FpeW#ǡAas(e@7RӒ Ey4V_Y13mW~]L vd} T귣G[F;WP` #U,(FE3}1wnraxYyrޢ]>k(K!u0=$֭i|Σ3/ WSRH Kwr=hw=4؎CB&ۨ#ohϳRXГBMW; D|%h^w./[u(P*?? grr5UP,Js^֧yBHeM?RD/)!BVEݦ- '/=`muȅ! +#>.3AC/ |hXD\ZW5XB{L vF9aՍHvꕝ[fBQ 2_>@>f߾olߖV nDѶvK t*I`a$=:Tep%Rl$ԢxM@<*g v#f RR#|jtww,G^nc0`j0ۧxju=Q`}c&kZ H1N=6tMΗRTvf)A]\!^Ʃi%8usL^[iWȁCz2Js $[-2wdα^̑'@#Q!Z! 1L?#X8 U}4B!_ěgyNM4;l@۲1w؛B"F0髊PiM gcAΥ@[m7W:!>D5nS*ŵJ+pԥ.~X튮3q !3ƴyh\xxMwG!`XD%PQ/ O=ՉIJh ہhD_;EX鋌~oTJ WԲeO B W^E0PgمtBmvnZ <,;Њ&p/i}U:]1Zf`{Ѳm>.&'iY=+85T5.xX4KVMd]_8y|_r閝@#ołeWy}/w<޶53}ZιlΆc>u_Ķ–cO{S7'4~r-蜣¡K~|thz ~6D&:kW@5 3\@ّ:cio?V tYPl} $~װ+6ms:-H=+Xqu=d|2[yͣ%S/໾t\ Y  SQ4Spts/n|6oď&ŕX;H<3x0ag֖_p\"銾Z>L_4<;]."<%}OvaLm2t;B².;ҵk$:mHXA|< /;.umLt±!WEMӁaVdA[{&)C5d!~OMV)/ fgWɱ2ho15oMv1_H>$ysjM°4e rtr-iͫAR^hK?`1xv8ueVg/ENR#ۯVkRmP* h `v8gTo:g"` 2秺>QMp #^1JH4%LuY{6ۗdχ \v 7̱1Uho3$ ~,r 餼>Y#Ӈ#>.L`u0!*رNQ*T7x^ .ȞFD! äĽhe4UsjkՀɮt/O8CbjlkV02(pGC =m1NTYb̵! V-wVdߴ\Us0 AFO?) il3^rDDjjH̙E:wP0Bh]a2&/\A (#bLBM(]Wx057cJEsf~ZZV**Bf[RBRȱk=W'%JAvmÞD5{YӜ1m: s_- gEbZmr7]m'5`v{ñ8Mg2͈3W#ȺÒ qw((3Lҁ}Q(Hq qU$Ya{< uDܖP'}=ya/n%yR Wd?֊ C>ݔ֌jk'i5SBw%R#Pf:0FN{2;Y /~ew[f[I]8W,&R0mS~adGQSVίc^vY^F߹Y\~ޝЊRT{.d`$N TUA(M|=j.~3㵉䜐u=+ jP/P>!9 pmfz:kU+|a8aۑb+)iE8џhz 01d'\PM퍖IU.۟j.#ٴ:,ErTΕ^('>.bl.A]mV蘡70B?owKh^y^Nlӝ9CίO%2: q<]N@ ro`;~_F >D(L^%µT7@ s8I6] V רg+VU+VQ5@Hf,ZCŪE2KE dDr19ٜ=g̜~߽>3sf;{M|~M2}eFa.4&Y! >T'e!C `Jt|n:L[6n|l4k¼5|, $ʙ08FgۍW5[jkXSُ-A]fGq0^X@׵lJkMIR*Ċ=S[)2-ވa8n`lB#VeI=O^jL(-5P%Ejijd}Cn@=d/C5rA.0ۺP2ݓ,V76:U*.a5Fimnceۼsdȍ? 6C583[73o*Uo>wQw:ou&Ues]֪ƧṭidM7țj7Mƻ1ϴ .ޫ:z΋Pr1 4Nכּ.r;fw_O:.jma/쀟F1K4-m%.h֏;u\__˝_}`ŎE =Ϊ KzV*f<`=֔-hn(ULY^4R ܻ(~o%K\uT !F%ԓފ CM+g _~[b^1aObxK>3|${$߿Lb} ftZnnt%069rL M cPtƬhI˜?iC38p+:O4t_MBM,75~ %%(^LcU$|& tD:~}{_=dh3( vԚ 4OĊK~H#Xq Z q iE9onnjس[WЌ( X&5bl#c~SbXq Kq\bI K3ϯgՃxH@]ZlRz-F3qsEfrɋٰ܂}wҒL |5qױB1 !ι; +wl4,WȻN bحVi(pI9 >KS2$.$;UfH~C^%0cl1\J9X:ԍɓ0:pF!k&9iKgbQHӂuVba 2(G"UexI C"}VI],*cJX׷T61-2ľ!-5o|mL4ζS8W t 5-HK6C6K$ $d6@)W1agJHH/4t_  ʄjIRLfB{:emFݯ!AU+aϯ½̉=>c?edRHq=9uoһV)OՕkVXI5kx6Z\Ov/eI!^ 5DZE|Maҹ{Wgݏ}U]-ժU5M EUܸEP=_w*ә5JjY M-j#RwfCKa,i%UX&d?DeFGn)2H;8ͧ]]3#0 o%d",'r j7b"N¢i_anBUtTF!+àWw!:W]ֻRmC&R:LtfIG(Du@P Uln#ZW0ܬw׳$/m >P5u*D#8@1uL$Y[U(>"$wKDy{+AZ#d]ߊfm4hB*iIO❧iP(2ms AtQڿߥSUo ?N2x@abWo=<>T%A$k8ZI'bflݴ([cZߐOHLb}Kn{O_)AH&폑oclO^aˑgޫOeRorP|^G;Aԃ$ߎXѴta)uuXr6]zc4DymxvqE##OdsJՆc${x[2 (XNl@ҥx}zcL oր%[rdR3)cTcp]it8+_%`l`fXz .gKW+mۖ*kw,fWgזTLVOٿ#Dž9DwoEg긠b, L"C}E_ވȰ3-:'H[gA3Ӡ b (g mւ:ts#Aį9yeI) UyP/{@%N~!ٽ3l @%fYZB9WpuNNdh?<G\:XaL`C;C 4NgDthg];slҚ4t3RA $NZB-ihM\ѽûM5(l/[ YRȜ4; îΞ9e )bYf<=F 2255Pw4ﬔ|IǜJRMUЫ6J:eUҴwt5M{-OБn+rнZ?꾅c6*4GTlߤc9go1%J~u:J8uQE UÆ7tx4e"gHfP9l|vT F C͉Y]Ͳ27:=kcDUۈl(`Ȫ#Fidpկ`k#JL4֭IfOjCJ%*Ǜ:&Ld%ʨclFXd)5Zy>q=)GC,12,qJ=q ~!K̆W"F0;f#AU$LJPN⺭JBy9K~s$7jgSÝ@3o]ߟFb*P_կw6[e4P@c^cgnPH09늸_ߝ[~jtHma n8בY/h((&VP^ (F:iկ˼ݐPJMvj´Bʌ9w-]},5?NJ>p \Vn$/m)U^OܸD9+2&4LF4͊\j"~]xCrE 'Pґ u) S1A.-IH!6enj4M FWYe.AtÍN~ wUB/eGn-& J{g2dbeRyx,WO9KMeu|Bd^j,0<z/UAXeoݭpEN!9<zY[G=>]Pp 9KLf V&aIj?n8l(}ێ\ լ/x1'zfb% i'_^GO'I] %0鼳򬱉|:Ϻw>n,TPſV$ ՞xŹz RRɐ25D Ab(a%k2Np6I7wЊ;Ldoy5 ą HwydfN"*=%0/c^P0L*xTd9 s Eg,>҅1"!ota-JX0)dS 7ڄeɒ:ʛO]v_n "p,,v3L-2Nl%)?1aԠCIPU D$\3]bqg1R8#} j(uѹ]L54>=СxYAQ?5C룘M>Np+Hq傃gq?>f3mQ2\1o1|rد '$HtM7q{{UFYjhfLQL:ZbzDwLO!WȦ;TrOBY8GN9?r+1@^i戊٩0`p<=8Js4yo)Ǝߠtê޶opB&CNjBT"Ւ ZBvp$\rCtlNvYi56<-G;'>|#R};bc}Mm5L~F%3\rGwTƩQ?RF/_yW{ T2tIL"_誖z}[O3r}tydN\B?>^rL^O6\>J$ܐ NcΆbB/'_v!$G'w J2טofVQǃNSD H 0.qamL{3 }!s#!(7Nz~:c)umk-@ xr[U]2N[-4 d bИ0C'0X&E/ܬbV$G^n`2=gwea'P=@ÆZwi⸧8LLp 1ם1$'aҘ܂Wqg* =0n~ezQqPa0ppwAA[׳~EFХ}X}Q S| 7)1Q C_!GDx`~!]S#VJ|þ =k8}G{}:ryBuF2G הwD[n"/y]'ҸۏgAr8_DEurd]·t]P~X@z%W>9K >A]D }M4+wKH7uOQed -D)0Ecg p' q\Rt;ut,]RS ־EW>F|0 >%Msu% 68fL3Q#B äu]q';ut\Wb1FIz)- s?wxPœ>ԒHTS n" 2{L^bZ5r>Cs1H~̖%[vODÄ\G`)x=(#JwswD!;%; ŴŶxbJ^E};NG}8C'ի\ 0`Ϭ/O=0h%`xk2߂"gY-L-(sKQ}.DC%Cf7gus"4%z* i=HS,*pǼBxd=r>1 n;CQ~irs6W ܍_9E9h#3مN1ǻe64fHM &9'1*IȰEP:nl. Q.)3vep\vIlT.lhj暍׎-+EiZHYEQ)"T({xSy9B1Oo9w 0yCH3=.|+66;yd lJN.| zaʖIdK.`xB=!l/ßܴUOL'P挨J ėbYn|77 ..Qpyg/9( jQD1|$gxJ44vT`|UҤDQA_4cL QS]BNzq%onD+~'mE8tA'eØM"^ao!e \_P 2u"kedpj\.6($ !> H* n:;jR E{_Hzs,!Ggcgпhiԅɜl%krfj=x22O)7$ݑVHccV*:I.4KYr~h)1C pLs=\f s^:vcV1jϸBēg Ġk*ىo#ca%ؖdVnQbLbSŃBɎcHBqβCfd*cZ|^MJ$ {ƗKrIYj˔ps*X ^JVbpg5HVYQhf%jsxYAZ"F4Y9erUcfipo^Oޒ2bު_=V\eo `f'qJY.1Ri]`~66T"^7T0C+5]nOXs#dn Nj2l?sx;d.˜H'FQ/gAs pIkJkXB&sU .-3/$ҟ4:&>g r( -^5RWT:ဘl4^Ir?Q\0e8 xsqb|>FWU[|U> 4ͱ3HgeQj 9K-_=꥓=H~Gmtxf3lbHIU A~-3E]q{{Hv-b ޑ!kꆎ)Jj|ߚ Q}pg~  |bneV6afHS/#ot<1;&wRTT%Jt ;pIȑ)p➼μ+ l5 T}e D&JmG4aʢ|\Md2?_r_{mmЙy?XxamvZ,!O_06&0 (lrۀ|MIY hodu$&m1*+Gb"4~Jɺ]ot0.KNS&"#A9Lfk!ie 5`_K?mI^o*J[ )Zf3Bp6o#3c|Bm|x @? o S$/?5s3ۃfd6WU!bj&it^RW=OH{!,,0.[ԱopmfG. CS|+F F<%qcZGL<1O(_PkM>xO5*y~_ft l)X'ȏ>$U}F ͪ!l; 4 (ggnd(cH-۸LZ=*@!ቼ֋2O݄JA-ljx<@z5;7â١a`p3uD< PN#R} n~7gMa- YEA(!P2҂-8Z,6O5Fu+V l&KN|;R8*[D& gZ$VLcd|0jx&cIS*B? v]Y-S !Ý,fPl8b9䙀ʙcLuγOU BuG>hWO>G+uG-Lij!"|iŀz #'_ ıo; iAtFU݋ ?AQю:>E ;0[<@Q'6YhUǮE?̬9ɕhywj+J4㍾n5 B&\('%צdIᚑڄhsEᤀ[tp+*U¢O)'۷5O+HQ~;]t,p8Cq+or?5](Lt݋C:px6o0BTcX:SiЙ~P˪eJB r 3}cCm>qP\!~m=e.$)X։>,jg&E(.y% R+x=,!'#$waN5..q;f^.;uR֛ Β`m$.-5媁X [n" ,.%ƌyD~t \E/λg轆'|\*>tyzh.\HfnEAMH־]s9!J;XB1};]c{Ed v *{R*Qf;vooQO:ai. i aqukΩ$_I&`%w u:l3c[%T铀H]l)ꈞCU\@?آԽgهa]Ah{Cg:f_068} 6gÖۘwq|a(RbnN7}|3Z^ 0Jm MdZ:5{>'9vreq -"\#$X<h&}<2aa=6íaJHϪ iI6ׇaqm99v;hi:ۇr8;@Or9g-B{Yvk'׿=Ƹ"#x<qM<kpriY%s/_[@$ *wypd<U&$Li7ơ=l5H{SY8 (`xNűiOlc O@Pȋ*.D!8G/dr@q,YHJKVbr~8+` O.,JA7ޣe%2R)e1! 5MY[sD05pCECqu(*fY.Ug- `rM#N, O"(}ȉc#+)he>Rq;[^P+ڄ P@DQyЅx8X[Y0Rh'`7 >B#=w`.M bFv7ޘa<0F\<0 " .8>{Y$u8RgbT?3}q۰zѲ,&0DDKvgrz;n2X' |pPi?+inveniosoftware-contrib-intbitset-91de683/tests/test_intbitset.py000066400000000000000000000520551517417475300255470ustar00rootroot00000000000000# -*- coding: utf-8 -*- # # This file is part of intbitset. # Copyright (C) 2007, 2008, 2009, 2010, 2011, 2013, 2014, 2015, 2016 CERN. # # SPDX-License-Identifier: LGPL-3.0-or-later # # intbitset is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation; either version 3 of the # License, or (at your option) any later version. # # intbitset is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with intbitset; if not, write to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston MA 2110, USA. import copy import pickle import zlib from typing import NamedTuple import pytest from intbitset import intbitset def b(s): # carried from six return s.encode("latin-1") def check_bitset(intbitset1, msg=""): """ Run basic sanity checks on a bitset """ wordbitsize = intbitset1.get_wordbitsize() size1 = intbitset1.get_size() allocated1 = intbitset1.get_allocated() creator_list = intbitset1.extract_finite_list() up_to1 = creator_list and max(creator_list) or -1 assert up_to1 <= size1 * wordbitsize < allocated1 * wordbitsize, ( "up_to1=%s, size1=%s, allocated1=%s while testing %s during %s" % (up_to1, size1 * wordbitsize, allocated1 * wordbitsize, intbitset1, msg), ) tmp = intbitset(intbitset1.fastdump()) size2 = tmp.get_size() allocated2 = tmp.get_allocated() creator_list = tmp.extract_finite_list() up_to2 = creator_list and max(creator_list) or -1 assert up_to2 <= size2 * wordbitsize < allocated2 * wordbitsize, ( "After serialization up_to2=%s, size2=%s, allocated2=%s while testing %s during %s" % (up_to2, size2 * wordbitsize, allocated2 * wordbitsize, intbitset1, msg), ) TEST_SETS = [ [1024], [10, 20], [10, 40], [60, 70], [60, 80], [10, 20, 60, 70], [10, 40, 60, 80], [1000], [10000], [23, 45, 67, 89, 110, 130, 174, 1002, 2132, 23434], [700, 2000], list(range(1000, 1100)), [30], [31], [32], [33], [62], [63], [64], [65], [126], [127], [128], [129], ] class Function(NamedTuple): intbitset_function: str set_function: str int_function: str label: str inplace: bool AND_FUNC = Function( intbitset_function=intbitset.__and__, # NOQA set_function=set.__and__, int_function=int.__and__, label="intersection", inplace=False, ) IAND_FUNC = Function( intbitset_function=intbitset.__iand__, # NOQA set_function=set.__iand__, int_function=int.__and__, label="intersection_update", inplace=True, ) OR_FUNC = Function( intbitset_function=intbitset.__or__, # NOQA set_function=set.__or__, int_function=int.__or__, label="union", inplace=False, ) IOR_FUNC = Function( intbitset_function=intbitset.__ior__, # NOQA set_function=set.__ior__, int_function=int.__or__, label="union_update", inplace=True, ) XOR_FUNC = Function( intbitset_function=intbitset.__xor__, # NOQA set_function=set.__xor__, int_function=int.__xor__, label="symmetric_difference", inplace=False, ) IXOR_FUNC = Function( intbitset_function=intbitset.__ixor__, # NOQA set_function=set.__ixor__, int_function=int.__xor__, label="symmetric_difference_update", inplace=True, ) SUB_FUNC = Function( intbitset_function=intbitset.__sub__, # NOQA set_function=set.__sub__, int_function=int.__sub__, label="difference", inplace=False, ) ISUB_FUNC = Function( intbitset_function=intbitset.__isub__, # NOQA set_function=set.__isub__, int_function=int.__sub__, label="difference_update", inplace=True, ) FUNCTIONS = [ SUB_FUNC, ISUB_FUNC, AND_FUNC, IAND_FUNC, OR_FUNC, IOR_FUNC, XOR_FUNC, IXOR_FUNC, ] def check_functions_work(function, intbitset1, intbitset2): function = function orig1 = intbitset(intbitset1) orig2 = intbitset(intbitset2) msg = "Testing %s(%s, %s)" % ( function.intbitset_function.__name__, repr(intbitset1), repr(intbitset2), ) trailing1 = intbitset1.is_infinite() trailing2 = intbitset2.is_infinite() if function.inplace: function.intbitset_function(intbitset1, intbitset2) trailing1 = function.int_function(trailing1, trailing2) > 0 up_to = intbitset1.extract_finite_list() and max(intbitset1.extract_finite_list()) or -1 else: intbitset3 = function.intbitset_function(intbitset1, intbitset2) trailing3 = function.int_function(trailing1, trailing2) > 0 up_to = intbitset3.extract_finite_list() and max(intbitset3.extract_finite_list()) or -1 set1 = set(orig1.extract_finite_list(up_to)) set2 = set(orig2.extract_finite_list(up_to)) if function.inplace: function.set_function(set1, set2) else: set3 = function.set_function(set1, set2) check_bitset(intbitset1, msg) check_bitset(intbitset2, msg) if function.inplace: assert set1 & set(intbitset1.extract_finite_list(up_to)) == set( intbitset1.extract_finite_list(up_to) ), ( "%s not equal to %s after executing %s(%s, %s)" % ( set1, set(intbitset1.extract_finite_list(up_to)), function.intbitset_function.__name__, repr(orig1), repr(orig2), ), ) assert set1 | set(intbitset1.extract_finite_list(up_to)) == set1, ( "%s not equal to %s after executing %s(%s, %s)" % ( set1, set(intbitset1.extract_finite_list(up_to)), function.intbitset_function.__name__, repr(orig1), repr(orig2), ), ) assert trailing1 == intbitset1.is_infinite(), ( "%s is not %s as it is supposed to be after executing %s(%s, %s)" % ( intbitset1, trailing1 and "infinite" or "finite", function.intbitset_function.__name__, repr(orig1), repr(orig2), ), ) else: check_bitset(intbitset3, msg) assert set3 & set(intbitset3.extract_finite_list(up_to)) == set( intbitset3.extract_finite_list(up_to) ), ( "%s not equal to %s after executing %s(%s, %s)" % ( set3, set(intbitset3.extract_finite_list(up_to)), function.intbitset_function.__name__, repr(orig1), repr(orig2), ), ) assert set3 | set(intbitset3.extract_finite_list(up_to)) == set3, ( "%s not equal to %s after executing %s(%s, %s)" % ( set3, set(intbitset3.extract_finite_list(up_to)), function.intbitset_function.__name__, repr(orig1), repr(orig2), ), ) assert trailing3 == intbitset3.is_infinite(), ( "%s is not %s as it is supposed to be after executing %s(%s, %s)" % ( intbitset3, trailing3 and "infinite" or "finite", function.intbitset_function.__name__, repr(orig1), repr(orig2), ), ) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS, ) @pytest.mark.parametrize(argnames="set2", argvalues=TEST_SETS) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_normal_set_ops(set1, set2, function): check_functions_work(function, intbitset(set1), intbitset(set2)) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS, ) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_empty_set(set1, function): check_functions_work(function, intbitset(set1), intbitset([])) check_functions_work(function, intbitset([]), intbitset(set1)) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_empty_empty_set(function): check_functions_work(function, intbitset([]), intbitset([])) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS, ) @pytest.mark.parametrize(argnames="set2", argvalues=TEST_SETS) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_inifinite_set(set1, set2, function): check_functions_work(function, intbitset(set1), intbitset(set2, trailing_bits=True)) check_functions_work(function, intbitset(set1, trailing_bits=True), intbitset(set2)) check_functions_work( function, intbitset(set1, trailing_bits=True), intbitset(set2, trailing_bits=True), ) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS, ) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_infinite_vs_empty_set(set1, function): check_functions_work(function, intbitset(set1, trailing_bits=True), intbitset([])) check_functions_work(function, intbitset([]), intbitset(set1, trailing_bits=True)) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_infinite_empty_empty_set(function): check_functions_work(function, intbitset([]), intbitset(trailing_bits=True)) check_functions_work(function, intbitset(trailing_bits=True), intbitset([])) @pytest.mark.parametrize( argnames="function", argvalues=[ SUB_FUNC, AND_FUNC, IAND_FUNC, OR_FUNC, IOR_FUNC, XOR_FUNC, IXOR_FUNC, ], ) def test_no_segmentation_fault_intbitset_set(function): """intbitset - test no segmentation fault with foreign data types""" with pytest.raises(TypeError): # NOQA function.intbitset_function(intbitset([1, 2, 3]), set([1, 2, 3])) def test_no_segmentation_fault_intbitset_set_isub(): """intbitset - test no segmentation fault with foreign data types""" ISUB_FUNC.intbitset_function(intbitset([1, 2, 3]), set([1, 2, 3])) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_no_segmentation_fault_set_intbitset(function): function.set_function(set([1, 2, 3]), intbitset([1, 2, 3])) @pytest.mark.parametrize( argnames="function", argvalues=FUNCTIONS, ) def test_no_segmentation_fault_none_intbitset(function): """intbitset - test no segmentation fault with foreign data types""" with pytest.raises(TypeError): # NOQA function.intbitset_function(None, intbitset([1, 2, 3])) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_list_dump(set1): """intbitset - list dump""" assert set1 == list(intbitset(set1)) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_ascii_bit_dump(set1): """intbitset - ascii bit dump""" tot = 0 count = 0 for bit in intbitset(set1).strbits(): if bit == "0": assert count not in set1 elif bit == "1": assert count in set1 tot += 1 else: raise Exception() count += 1 assert len(set1) == tot @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_tuple_of_tuples(set1): """intbitset - support tuple of tuples""" tmp_tuple = tuple([(elem,) for elem in set1]) assert list(intbitset(set1)) == list(intbitset(tmp_tuple)) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_tuple_of_tuples_with_trailing_bits(set1): tmp_tuple = tuple([(elem,) for elem in set1]) assert intbitset(set1, trailing_bits=True) == intbitset(tmp_tuple, trailing_bits=True) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) @pytest.mark.parametrize( argnames="trailing_bits", argvalues=[True, False], ) def test_marshalling(set1, trailing_bits): assert intbitset(set1, trailing_bits=trailing_bits) == intbitset( intbitset(set1, trailing_bits=trailing_bits).fastdump() ) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) @pytest.mark.parametrize( argnames="trailing_bits", argvalues=[True, False], ) def test_pickling(set1, trailing_bits): assert intbitset(set1, trailing_bits=trailing_bits) == pickle.loads( pickle.dumps(intbitset(set1, trailing_bits=trailing_bits), -1) ) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_emptiness(set1): assert (not set(set1)) == (not intbitset(set1)) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_len(set1): intbitset1 = intbitset(set1) pythonset1 = set(set1) assert len(pythonset1) == len(intbitset1) intbitset1.add(76543) pythonset1.add(76543) assert len(pythonset1) == len(intbitset1) intbitset1.remove(76543) pythonset1.remove(76543) assert len(pythonset1) == len(intbitset1) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_clear(set1): intbitset1 = intbitset(set1) intbitset1.clear() assert list(intbitset1) == [] intbitset1 = intbitset(set1, trailing_bits=True) intbitset1.clear() assert list(intbitset1) == [] @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) @pytest.mark.parametrize( argnames="trailing_bits", argvalues=[True, False], ) def test_set_repr(set1, trailing_bits): intbitset1 = intbitset(set1, trailing_bits=trailing_bits) assert eval(repr(intbitset1)) == intbitset1 @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) @pytest.mark.parametrize( argnames="set2", argvalues=TEST_SETS + [[]], ) @pytest.mark.parametrize( argnames=["intbitset_op", "set_op"], argvalues=[ (intbitset.__eq__, set.__eq__), # NOQA (intbitset.__ge__, set.__ge__), # NOQA (intbitset.__gt__, set.__gt__), # NOQA (intbitset.__le__, set.__le__), # NOQA (intbitset.__lt__, set.__lt__), # NOQA (intbitset.__ne__, set.__ne__), # NOQA ], ) def test_intbitset_behaves_same_as_set_cmp(set1, set2, intbitset_op, set_op): """intbitset - (non infinite) set comparison""" expected = set_op(set(set1), set(set2)) result = intbitset_op(intbitset(set1), intbitset(set2)) assert expected == result @pytest.mark.parametrize( argnames="intbitset_op", argvalues=[ intbitset.__eq__, # NOQA intbitset.__ge__, # NOQA intbitset.__gt__, # NOQA intbitset.__le__, # NOQA intbitset.__lt__, # NOQA intbitset.__ne__, # NOQA ], ) def test_intbitset_richcmp_with_non_intbitset_return_false(intbitset_op): set1 = [1, 2, 3] assert not intbitset_op(intbitset(set1), set1) with pytest.raises(TypeError): # NOQA intbitset_op(set1, intbitset(set1)) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_update_with_signs(set1): dict1 = {10: -1, 20: 1, 23: -1, 27: 1, 33: -1, 56: 1, 70: -1, 74: 1} intbitset1 = intbitset(set1) intbitset1.update_with_signs(dict1) up_to = max(list(dict1.keys()) + set1) for i in range(up_to + 1): if dict1.get(i, i in set1 and 1 or -1) == 1: assert i in intbitset1, ( "%s was not correctly updated from %s by %s" % (repr(intbitset1), repr(set1), repr(dict1)), ) else: assert i not in intbitset1, ( "%s was not correctly updated from %s by %s" % (repr(intbitset1), repr(set1), repr(dict1)), ) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) @pytest.mark.parametrize( argnames="trailing_bits", argvalues=[True, False], ) def test_set_cloning(set1, trailing_bits): intbitset1 = intbitset(set1, trailing_bits=trailing_bits) intbitset2 = intbitset(intbitset1) intbitset3 = copy.deepcopy(intbitset2) check_bitset(intbitset1) check_bitset(intbitset2) check_bitset(intbitset3) assert intbitset2 == intbitset1 assert intbitset3 == intbitset1 def test_set_isdisjoint(): sets = [ intbitset(set([1, 2])), intbitset(set([3, 4])), intbitset(set([2, 3])), ] for set1 in sets: for set2 in sets: if set1 is not set2: assert set1.isdisjoint(set2) is set(set1).isdisjoint(set(set2)) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_pop(set1): intbitset1 = intbitset(set1) pythonlist1 = list(set1) while True: try: res1 = pythonlist1.pop() except IndexError: with pytest.raises(KeyError): # NOQA intbitset1.pop() check_bitset(intbitset1) break res2 = intbitset1.pop() check_bitset(intbitset1) assert res2 == res1 @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_getitem(set1): intbitset1 = intbitset(set1) pythonlist1 = list(set1) for i in range(-2 * len(set1) - 2, 2 * len(set1) + 2): try: res1 = pythonlist1[i] except IndexError: with pytest.raises(IndexError): # NOQA intbitset1.__getitem__(i) continue assert intbitset1[i] == res1 @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_getitem_slices(set1): intbitset1 = intbitset(set1) pythonlist1 = list(set1) for start in range(-2 * len(set1) - 2, 2 * len(set1) + 2): for stop in range(-2 * len(set1) - 2, 2 * len(set1) + 2): for step in range(1, 3): res1 = pythonlist1[start:stop:step] res2 = intbitset1[start:stop:step] assert list(res2) == res1, ( f"Failure: set={set1}, start={start}, stop={stop}, " f"step={step}, found={list(res2)}, " f"expected={res1}, " + "indices: " + str(slice(start, stop, step).indices(len(pythonlist1))) ) @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_iterator(set1): intbitset1 = intbitset(set1) check_bitset(intbitset1) tmp_set1 = [] for recid in intbitset1: check_bitset(intbitset1) tmp_set1.append(recid) check_bitset(intbitset1) assert tmp_set1 == set1 @pytest.mark.parametrize( argnames="set1", argvalues=TEST_SETS + [[]], ) def test_set_iterator2(set1): tmp_set1 = [] for recid in intbitset(set1): tmp_set1.append(recid) assert set1 == tmp_set1 @pytest.mark.parametrize( argnames="strdump", argvalues=[ b("ciao"), b(intbitset([2, 6000000]).strbits()), b("djflsdkfjsdljfsldkfjsldjlfk"), ], ids=lambda s: s[:30], ) def test_set_corruption(strdump): """intbitset - set corruption""" set1 = intbitset() # These should fail because they are not compressed with pytest.raises(ValueError): # NOQA intbitset(strdump) with pytest.raises(ValueError): # NOQA set1.fastload(strdump) # These should fail because they are not of the good length strdump = zlib.compress(strdump) with pytest.raises(ValueError): # NOQA intbitset(strdump) with pytest.raises(ValueError): # NOQA set1.fastload(strdump) @pytest.mark.parametrize( argnames=["original", "dumped", "dumped_trailing_bits"], argvalues=[ ( (20, 30, 1000, 40), b("x\x9cc`\x10p``d\x18\x18\x80d/\x00*\xb6\x00S"), b("x\x9cc`\x10p`\x18(\xf0\x1f\x01\x00k\xe6\x0bF"), ), ( (20, 30, 1000, 41), b("x\x9cc`\x10p``b\x18\x18\xc0\x88`\x02\x00+9\x00T"), b("x\x9cc`\x10p`\x18(\xf0\x1f\x01\x00k\xe6\x0bF"), ), ( (20, 30, 1001, 41), b("x\x9cc`\x10p``b\x18\x18\x80d/\x00+D\x00U"), b("x\x9cc`\x10p`\x18(\xf0\xef?\x1c\x00\x00k\xdb\x0bE"), ), ], ids=lambda s: s[0], ) def test_set_consistency(original, dumped, dumped_trailing_bits): intbitset1 = intbitset(original) intbitset2 = intbitset(original, trailing_bits=True) intbitset3 = intbitset(dumped) intbitset4 = intbitset(dumped_trailing_bits) check_bitset(intbitset1) check_bitset(intbitset2) check_bitset(intbitset3) check_bitset(intbitset4) assert intbitset1.fastdump() == dumped assert intbitset1 == intbitset3 assert intbitset2.fastdump() == dumped_trailing_bits assert intbitset2 == intbitset4 def test_empty_generator(): intbitset(range(0)) intbitset(i for i in range(0)) def test_do_not_allow_removal_of_none(): with pytest.raises(TypeError): # NOQA intbitset([1, 2, 3]) - None inveniosoftware-contrib-intbitset-91de683/tox.ini000066400000000000000000000004201517417475300222670ustar00rootroot00000000000000[tox] envlist = py37, py38, py39, py310, py311, docs [testenv] deps = pytest-xdist commands = pytest -n5 {posargs} [testenv:docs] basepython=python deps=sphinx commands= {envpython} setup.py build_sphinx -E -a {envpython} setup.py build_sphinx -E -a -b doctest