pyo3/Cargo.toml

129 lines
4.6 KiB
TOML
Raw Normal View History

2015-01-05 16:05:53 +00:00
[package]
2017-05-13 05:05:00 +00:00
name = "pyo3"
2023-07-30 16:54:44 +00:00
version = "0.19.2"
2017-08-12 16:31:14 +00:00
description = "Bindings to Python interpreter"
authors = ["PyO3 Project and Contributors <https://github.com/PyO3>"]
2015-04-19 05:50:50 +00:00
readme = "README.md"
2018-05-30 13:03:31 +00:00
keywords = ["pyo3", "python", "cpython", "ffi"]
2017-05-13 05:05:00 +00:00
homepage = "https://github.com/pyo3/pyo3"
2018-08-30 21:19:23 +00:00
repository = "https://github.com/pyo3/pyo3"
2018-11-02 21:32:18 +00:00
documentation = "https://docs.rs/crate/pyo3/"
2017-01-20 23:41:44 +00:00
categories = ["api-bindings", "development-tools::ffi"]
2017-07-23 18:21:01 +00:00
license = "Apache-2.0"
exclude = ["/.gitignore", ".cargo/config", "/codecov.yml", "/Makefile", "/pyproject.toml", "/noxfile.py", "/.github", "/tests/test_compile_error.rs", "/tests/ui"]
edition = "2021"
2023-06-04 08:29:24 +00:00
rust-version = "1.56"
2015-01-05 16:05:53 +00:00
2015-03-08 14:29:44 +00:00
[dependencies]
cfg-if = "1.0"
libc = "0.2.62"
2022-03-21 00:58:26 +00:00
parking_lot = ">= 0.11, < 0.13"
2023-05-21 07:56:55 +00:00
memoffset = "0.9"
# ffi bindings to the python interpreter, split into a separate crate so they can be used independently
2023-07-30 16:54:44 +00:00
pyo3-ffi = { path = "pyo3-ffi", version = "=0.19.2" }
2022-01-25 13:46:27 +00:00
# support crates for macros feature
2023-07-30 16:54:44 +00:00
pyo3-macros = { path = "pyo3-macros", version = "=0.19.2", optional = true }
indoc = { version = "2.0.1", optional = true }
unindent = { version = "0.2.1", optional = true }
# support crate for multiple-pymethods feature
2022-07-03 13:38:26 +00:00
inventory = { version = "0.3.0", optional = true }
# crate integrations that can be added using the eponymous features
anyhow = { version = "1.0", optional = true }
chrono = { version = "0.4", default-features = false, optional = true }
2021-11-18 11:38:47 +00:00
eyre = { version = ">= 0.4, < 0.7", optional = true }
hashbrown = { version = ">= 0.9, < 0.15", optional = true }
indexmap = { version = ">= 1.6, < 3", optional = true }
num-bigint = { version = "0.4", optional = true }
num-complex = { version = ">= 0.2, < 0.5", optional = true }
rust_decimal = { version = "1.0.0", default-features = false, optional = true }
serde = { version = "1.0", optional = true }
2017-06-18 15:41:20 +00:00
2018-04-21 18:01:41 +00:00
[dev-dependencies]
2019-02-01 14:05:37 +00:00
assert_approx_eq = "1.1.0"
chrono = { version = "0.4" }
# Required for "and $N others" normalization
trybuild = ">=1.0.70"
proptest = { version = "1.0", default-features = false, features = ["std"] }
2023-01-11 15:10:11 +00:00
send_wrapper = "0.6"
2022-03-04 22:41:25 +00:00
serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0.61"
2022-05-02 22:47:09 +00:00
rayon = "1.0.2"
rust_decimal = { version = "1.8.0", features = ["std"] }
2022-05-14 21:12:47 +00:00
widestring = "0.5.1"
[build-dependencies]
2023-07-30 16:54:44 +00:00
pyo3-build-config = { path = "pyo3-build-config", version = "0.19.2", features = ["resolve-config"] }
[features]
default = ["macros"]
# Enables pyo3::inspect module and additional type information on FromPyObject
# and IntoPy traits
experimental-inspect = []
# Enables macros: #[pyclass], #[pymodule], #[pyfunction] etc.
2021-12-28 01:25:01 +00:00
macros = ["pyo3-macros", "indoc", "unindent"]
2021-03-02 22:34:25 +00:00
# Enables multiple #[pymethods] per #[pyclass]
2021-08-19 20:55:39 +00:00
multiple-pymethods = ["inventory", "pyo3-macros/multiple-pymethods"]
# Use this feature when building an extension module.
# It tells the linker to keep the python symbols unresolved,
# so that the module can also be used with statically linked python interpreters.
extension-module = ["pyo3-ffi/extension-module"]
2020-10-31 07:35:14 +00:00
# Use the Python limited API. See https://www.python.org/dev/peps/pep-0384/ for more.
abi3 = ["pyo3-build-config/abi3", "pyo3-ffi/abi3", "pyo3-macros/abi3"]
2020-10-31 07:35:14 +00:00
# With abi3, we can manually set the minimum Python version.
2022-01-25 13:46:27 +00:00
abi3-py37 = ["abi3-py38", "pyo3-build-config/abi3-py37", "pyo3-ffi/abi3-py37"]
abi3-py38 = ["abi3-py39", "pyo3-build-config/abi3-py38", "pyo3-ffi/abi3-py38"]
abi3-py39 = ["abi3-py310", "pyo3-build-config/abi3-py39", "pyo3-ffi/abi3-py39"]
2022-11-23 08:08:12 +00:00
abi3-py310 = ["abi3-py311", "pyo3-build-config/abi3-py310", "pyo3-ffi/abi3-py310"]
abi3-py311 = ["abi3", "pyo3-build-config/abi3-py311", "pyo3-ffi/abi3-py311"]
# Automatically generates `python3.dll` import libraries for Windows targets.
generate-import-lib = ["pyo3-ffi/generate-import-lib"]
2023-02-22 21:46:42 +00:00
# Changes `Python::with_gil` to automatically initialize the Python interpreter if needed.
auto-initialize = []
# Optimizes PyObject to Vec conversion and so on.
2020-06-17 08:10:00 +00:00
nightly = []
2017-06-11 23:35:24 +00:00
# Activates all additional features
# This is mostly intended for testing purposes - activating *all* of these isn't particularly useful.
full = [
"macros",
2022-07-03 13:38:26 +00:00
# "multiple-pymethods", # TODO re-add this when MSRV is greater than 1.62
"chrono",
"num-bigint",
"num-complex",
"hashbrown",
"serde",
"indexmap",
"eyre",
"anyhow",
"experimental-inspect",
"rust_decimal",
]
[workspace]
members = [
2022-01-25 13:46:27 +00:00
"pyo3-ffi",
"pyo3-build-config",
2020-12-13 11:29:39 +00:00
"pyo3-macros",
"pyo3-macros-backend",
"pytests",
2021-12-21 22:21:42 +00:00
"examples",
2018-08-21 22:02:37 +00:00
]
[package.metadata.docs.rs]
no-default-features = true
features = ["macros", "num-bigint", "num-complex", "hashbrown", "serde", "multiple-pymethods", "indexmap", "eyre", "chrono", "rust_decimal"]
2021-05-16 07:11:37 +00:00
rustdoc-args = ["--cfg", "docsrs"]