Skip to main content

Type stubs (PEP 561) for gmpy2 2.2.1: GMP, MPFR, and MPC support.

Project description

gmpy2-stubs

PyPI version PyPI - Downloads GitHub last commit (branch) License

Type stubs for the gmpy2 library (version 2.2.1).

gmpy2 is a C-coded Python extension module that supports multiple-precision arithmetic. It provides access to the GMP (GNU Multiple Precision Arithmetic Library), MPFR (Multiple-Precision Floating-Point Reliable Library), and MPC (Multiple-Precision Complex Library) libraries. gmpy2 itself does not include type hints. This package provides them.

IMPORTANT CAVEAT: gmpy2 Runtime Behavior

Please be aware: The underlying gmpy2 library, which these stubs provide type hints for, can crash the Python interpreter in case of memory allocation failure. This is due to the memory management behavior of the wrapped GMP library.

To mitigate this risk when using gmpy2 in your code:

  • Estimate the potential size of calculation results.
  • Prevent or handle calculations that could exhaust available system memory.

Failure to account for this may lead to unexpected program termination.

Installation

pip install gmpy2-stubs

or, if you'd like to use a specific version:

pip install gmpy2-stubs==2.2.1.3

Usage

These stubs are automatically used by static type checkers like mypy and pyright when you have both gmpy2 and gmpy2-stubs installed. You do not need to import anything from gmpy2-stubs directly.

import gmpy2

# Type hints are available here!
x = gmpy2.mpz(123)
y = gmpy2.sqrt(x)
print(y)

Limitations: inspect.signature()

It's important to understand that these stubs are designed for static type checking. They will not affect the behavior of runtime introspection tools like inspect.signature().

gmpy2, like many C extension modules, does not provide complete runtime signature information. The standard library's inspect.signature() function relies on information that is usually available for pure Python functions (like docstrings and argument annotations) but is often missing or incomplete for C extensions.

There have been discussions about improving this situation, including:

Therefore, if you use inspect.signature() on gmpy2 functions, you will likely get a generic signature (e.g., (*args, **kwargs)) rather than a detailed one. This is a limitation of the current Python introspection mechanisms, not a limitation of these stubs. The stubs will provide full type information to static type checkers.

Contributing

Contributions and improvements to these stubs are very welcome! Please submit pull requests or open issues on the GitHub repository.

License

These stubs are licensed under the MIT License (see the LICENSE file). gmpy2 itself is licensed under the LGPLv3+ license.

Author

David Osipov (personal@david-osipov.vision)

Acknowledgements

Thanks to the gmpy2 developers for creating this powerful library!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gmpy2_stubs-2.2.1.5.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gmpy2_stubs-2.2.1.5-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file gmpy2_stubs-2.2.1.5.tar.gz.

File metadata

  • Download URL: gmpy2_stubs-2.2.1.5.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for gmpy2_stubs-2.2.1.5.tar.gz
Algorithm Hash digest
SHA256 9bcd5ab0bfbe881d39664f6b63046258dd91e38593a4cd930244874aaf82c770
MD5 aa8131301e163a9a2614c61176be8188
BLAKE2b-256 58362339da62e9af9a1bb12f2fbc1b4225a8c62c837b2115cb732b89eaed0764

See more details on using hashes here.

Provenance

The following attestation bundles were made for gmpy2_stubs-2.2.1.5.tar.gz:

Publisher: pypi-publish.yml on DavidOsipov/gmpy2-stubs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file gmpy2_stubs-2.2.1.5-py3-none-any.whl.

File metadata

  • Download URL: gmpy2_stubs-2.2.1.5-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for gmpy2_stubs-2.2.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8d6c6db2603628e1c9d65e49db8f99e2a592e99a0eecee2591084b18a193b4fe
MD5 7e2657fcd34c5daec5924573d23bf475
BLAKE2b-256 77d81444c88c3dd1e3eaea85a6c917fee9481f833a5ba805e87b59c4a1a565d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for gmpy2_stubs-2.2.1.5-py3-none-any.whl:

Publisher: pypi-publish.yml on DavidOsipov/gmpy2-stubs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page