From 6f87dad8d551d5c4036248ed8c656c13c4378e30 Mon Sep 17 00:00:00 2001 From: Dimitris Iliopoulos Date: Fri, 3 May 2024 07:58:42 -0700 Subject: [PATCH] upgrade to 0.21.1 Summary: NOTE: If your `hg bisect` brings you here & the error you are seeing looks like ` expected Result<&PyAny, PyErr>, found Result, PyErr>` then see these [migration notes](https://pyo3.rs/v0.21.0/migration.html#from-020-to-021) for the fix or click on `fbcode/security/ace/pyo3/authz.rs` or similar files from bellow to see what the fix is! In order to upgrade `pyo3` to [`0.21.1`](https://github.com/PyO3/pyo3/releases/tag/v0.21.1), the following had to take place: ## [PyO3] * Address [migration notes](https://pyo3.rs/v0.21.0/migration.html#from-020-to-021) for `Bound<'py, T>` * Address [#3595](https://github.com/PyO3/pyo3/pull/3595) - this is done in a crude way for now since there are many call sites depending on `fbcode/dba/rust/common/service_address/py/pyo3_conversion_helper.rs` which would require a more thorough review. * Address [#3821](https://github.com/PyO3/pyo3/pull/3821) - `pyo3-build-config` is now dependent on and used by PyO3 macros. Currently, the only thing that gets checked is `abi3` compatibility. To address that, we introduce a fixup for that automatically generate `pyo3-build-config*.txt` configuration files, given an `fbsource` Python version. We are tryin to stay as close to `pyo3-build-config*.txt` spec as possible even though only a single bool from that file is ever since there is validation for the other fields but also to future proof future changes. By also generating this file ourselves, we prevent PyO3 from attempting to locate a Python interpreter some other way which seems to start leaking into the PyO3 API as an implementation choice already. ## [PyPi + Rust] * Upgrade `orjson` to [`3.10.1`](https://github.com/ijl/orjson/releases/tag/3.10.1) * Added `README.md` notes for future upgrades * Upgrade `py-polars` to [`0.20.22`](https://github.com/pola-rs/polars/releases/tag/py-0.20.22) * Removed `py-polars` and `polars` from `target_os = "windows"`. The `third-party/pypi/polars` Python extension has only been supported for Mac and Linux for a while now so its only natural to do that on the Rust side as well. What is more, `polars-util` is bringing in `stacker = = "0.1.14"` which does not build on Windows mostly because its using a much more recent version of `libc` than we use in `third-party/rust` (see P1228807344) * Upgrade `pydantic-core` to [`2.18.2`](https://github.com/pydantic/pydantic-core/releases/tag/v2.18.2) * Removed old `third-party/pypi/pydantic-core` versions * Upgrade `safetensors` to [`0.4.3`](https://github.com/huggingface/safetensors/releases/tag/v0.4.3) * Patch `third-party/pypi/cryptography/41.0.7` to account for PyO3's [#2975](https://github.com/PyO3/pyo3/pull/2975) (`0.19.0`) where `pyo3::once_cell` was renamed to `pyo3::sync` (see D56826865) * Upgrade `tokenizers` and `tokenizers-python` to [`0.19.1`](https://github.com/huggingface/tokenizers/releases/tag/v0.19.1) * Removed old `third-party/pypi/tokenizers` versions * Fixed `third-party/pypi/tokenizers/BUCK` * Migrated `third-party/pypi/tokenizers/0.19.1/BUCK` to mirror other Python packages that bind to Rust crates e.g. `libcst`, `polars` etc. * Removed Windows support from `third-party/pypi/tokenizers` ## [Rust] * Upgrade `indexmap` to [`2.2.6`](https://github.com/indexmap-rs/indexmap/releases/tag/2.2.6) * Both latest `pydantic-core` and `c2pa` depend on `serde_json > 1.0.112` which brings in `indexmap = 2.2.1`. The latter has deprecated `.take` and `.remove` on both `IndexMap` and `IndexSet` leading to a bunch of errors (see bellow), all addressed: ```bash error: use of deprecated method `indexmap::set::IndexSet::::take`: `take` disrupts the set order -- use `swap_take` or `shift_take` for explicit behavior. --> fbcode/hphp/hack/src/package/types.rs:76:16 | 76 | self.0.take(value) | ^^^^ | = note: `-D deprecated` implied by `-D warnings` = help: to override `-D warnings` add `#[allow(deprecated)]` ``` Reviewed By: capickett Differential Revision: D56671179 fbshipit-source-id: 3ae69c069b7f005570c1a06d37194cf056282a18 --- eden/scm/lib/auth/Cargo.toml | 2 +- eden/scm/lib/cats/Cargo.toml | 2 +- eden/scm/lib/cliparser/Cargo.toml | 2 +- eden/scm/lib/config/set/Cargo.toml | 2 +- eden/scm/lib/config/static/macros/Cargo.toml | 2 +- eden/scm/lib/config/union/Cargo.toml | 2 +- eden/scm/lib/dag/Cargo.toml | 2 +- eden/scm/lib/third-party/streampager/Cargo.toml | 2 +- eden/scm/lib/tracing-collector/Cargo.toml | 2 +- 9 files changed, 9 insertions(+), 9 deletions(-) diff --git a/eden/scm/lib/auth/Cargo.toml b/eden/scm/lib/auth/Cargo.toml index db3fe5e43551d..f2c86e3ae6799 100644 --- a/eden/scm/lib/auth/Cargo.toml +++ b/eden/scm/lib/auth/Cargo.toml @@ -9,7 +9,7 @@ edition = "2021" anyhow = "1.0.75" chrono = { version = "0.4", features = ["clock", "serde", "std"], default-features = false } configmodel = { version = "0.1.0", path = "../config/model" } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } pem = "3.0.3" simple_asn1 = "0.5.4" thiserror = "1.0.49" diff --git a/eden/scm/lib/cats/Cargo.toml b/eden/scm/lib/cats/Cargo.toml index b032283084d5d..20d7528aa4b70 100644 --- a/eden/scm/lib/cats/Cargo.toml +++ b/eden/scm/lib/cats/Cargo.toml @@ -8,7 +8,7 @@ edition = "2021" [dependencies] anyhow = "1.0.75" configmodel = { version = "0.1.0", path = "../config/model" } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } serde = { version = "1.0.185", features = ["derive", "rc"] } serde_json = { version = "1.0.100", features = ["float_roundtrip", "unbounded_depth"] } thiserror = "1.0.49" diff --git a/eden/scm/lib/cliparser/Cargo.toml b/eden/scm/lib/cliparser/Cargo.toml index 776b0f001c5bc..8bcecb5ee55cb 100644 --- a/eden/scm/lib/cliparser/Cargo.toml +++ b/eden/scm/lib/cliparser/Cargo.toml @@ -9,7 +9,7 @@ edition = "2021" [dependencies] anyhow = "1.0.75" cpython = { version = "0.7.1", features = ["python3-sys"], optional = true, default-features = false } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } serde = { version = "1.0.185", features = ["derive", "rc"] } shlex = "1.3" thiserror = "1.0.49" diff --git a/eden/scm/lib/config/set/Cargo.toml b/eden/scm/lib/config/set/Cargo.toml index 1ac6002600691..09fa92a647e27 100644 --- a/eden/scm/lib/config/set/Cargo.toml +++ b/eden/scm/lib/config/set/Cargo.toml @@ -8,7 +8,7 @@ edition = "2021" [dependencies] configmodel = { version = "0.1.0", path = "../model" } hgrc-parser = { version = "0.1.0", path = "../hgrc-parser" } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } minibytes = { version = "0.1.0", path = "../../minibytes" } tracing = { version = "0.1.40", features = ["attributes"] } util = { version = "0.1.0", path = "../../util" } diff --git a/eden/scm/lib/config/static/macros/Cargo.toml b/eden/scm/lib/config/static/macros/Cargo.toml index 1a70a1774c982..b15d84ceaef44 100644 --- a/eden/scm/lib/config/static/macros/Cargo.toml +++ b/eden/scm/lib/config/static/macros/Cargo.toml @@ -12,4 +12,4 @@ proc-macro = true [dependencies] hgrc-parser = { version = "0.1.0", path = "../../hgrc-parser" } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } diff --git a/eden/scm/lib/config/union/Cargo.toml b/eden/scm/lib/config/union/Cargo.toml index 80af63de5bc1f..29f1db7a4a28a 100644 --- a/eden/scm/lib/config/union/Cargo.toml +++ b/eden/scm/lib/config/union/Cargo.toml @@ -7,7 +7,7 @@ edition = "2021" [dependencies] configmodel = { version = "0.1.0", path = "../model" } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } [dev-dependencies] staticconfig = { version = "0.1.0", path = "../static" } diff --git a/eden/scm/lib/dag/Cargo.toml b/eden/scm/lib/dag/Cargo.toml index e008805642cc7..f1277f1fdb762 100644 --- a/eden/scm/lib/dag/Cargo.toml +++ b/eden/scm/lib/dag/Cargo.toml @@ -17,7 +17,7 @@ fail = { version = "0.4", features = ["failpoints"] } fs2 = { version = "0.4", optional = true } futures = { version = "0.3.30", features = ["async-await", "compat"] } indexedlog = { version = "0.1.0", path = "../indexedlog", optional = true } -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } mincode = { version = "0.1.0", path = "../mincode" } minibytes = { version = "0.1.0", path = "../minibytes", default-features = false } nonblocking = { version = "0.1.0", path = "../nonblocking" } diff --git a/eden/scm/lib/third-party/streampager/Cargo.toml b/eden/scm/lib/third-party/streampager/Cargo.toml index 90bdc42c39e8c..678b1671ad23b 100644 --- a/eden/scm/lib/third-party/streampager/Cargo.toml +++ b/eden/scm/lib/third-party/streampager/Cargo.toml @@ -14,7 +14,7 @@ categories = ["command-line-utilities", "text-processing"] bit-set = "0.5" dirs = "2.0" enum_dispatch = "0.3.5" -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } lazy_static = "1.4" lru = "0.11.1" memmap2 = "0.5.10" diff --git a/eden/scm/lib/tracing-collector/Cargo.toml b/eden/scm/lib/tracing-collector/Cargo.toml index 5916342b4c488..9b931878f4b08 100644 --- a/eden/scm/lib/tracing-collector/Cargo.toml +++ b/eden/scm/lib/tracing-collector/Cargo.toml @@ -6,7 +6,7 @@ version = "0.1.0" edition = "2021" [dependencies] -indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] } +indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] } libc = "0.2.139" parking_lot = { version = "0.12.1", features = ["send_guard"] } serde = { version = "1.0.185", features = ["derive", "rc"] }