Skip to content

Commit

Permalink
upgrade to 0.21.1
Browse files Browse the repository at this point in the history
Summary:
NOTE: If your `hg bisect` brings you here & the error you are seeing looks like ` expected Result<&PyAny, PyErr>, found Result<Bound<'_, PyAny>, 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](PyO3/pyo3#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](PyO3/pyo3#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](PyO3/pyo3#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::<T, S>::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
  • Loading branch information
diliop authored and facebook-github-bot committed May 3, 2024
1 parent ac53274 commit 26cacec
Show file tree
Hide file tree
Showing 29 changed files with 89 additions and 88 deletions.
121 changes: 61 additions & 60 deletions hphp/hack/src/Cargo.lock

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ ocamlrep_caml_builtins = { version = "0.1.0", git = "https://github.com/facebook
ocamlrep_ocamlpool = { version = "0.1.0", git = "https://github.com/facebook/ocamlrep/", branch = "main" }
oxidized = { version = "0.0.0", path = "../../../../oxidized" }
oxidized_by_ref = { version = "0.0.0", path = "../../../../oxidized_by_ref" }
rayon = "1.2"
rayon = "1.9.0"
relative_path = { version = "0.0.0", path = "../../../../utils/rust/relative_path" }
si_addendum = { version = "0.0.0", path = "../../../../utils/cargo/si_addendum" }
unwrap_ocaml = { version = "0.0.0", path = "../../../../utils/unwrap_ocaml" }
2 changes: 1 addition & 1 deletion hphp/hack/src/decl/cargo/rust_decl_ffi/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,5 +26,5 @@ ocamlrep_ocamlpool = { version = "0.1.0", git = "https://github.com/facebook/oca
oxidized = { version = "0.0.0", path = "../../../oxidized" }
oxidized_by_ref = { version = "0.0.0", path = "../../../oxidized_by_ref" }
parser_core_types = { version = "0.0.0", path = "../../../parser/cargo/core_types" }
rayon = "1.2"
rayon = "1.9.0"
relative_path = { version = "0.0.0", path = "../../../utils/rust/relative_path" }
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,4 @@ crate-type = ["lib", "staticlib"]
[dependencies]
itertools = "0.11.0"
log = { version = "0.4.17", features = ["kv_unstable", "kv_unstable_std"] }
rayon = "1.2"
rayon = "1.9.0"
2 changes: 1 addition & 1 deletion hphp/hack/src/depgraph/cargo/depgraph_reader/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@ crate-type = ["lib", "staticlib"]
bytemuck = { version = "1.14", features = ["derive", "min_const_generics"] }
dep = { version = "0.0.0", path = "../dep" }
memmap2 = "0.5.10"
rayon = "1.2"
rayon = "1.9.0"
static_assertions = "1.1.0"
vint64 = "1.0.1"
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ depgraph_writer = { version = "0.0.0", path = "../../../cargo/depgraph_writer" }
hash = { version = "0.0.0", path = "../../../../utils/hash" }
log = { version = "0.4.17", features = ["kv_unstable", "kv_unstable_std"] }
newtype = { version = "0.0.0", path = "../../../../utils/newtype" }
rayon = "1.2"
rayon = "1.9.0"
smallvec = { version = "1.6.1", features = ["serde", "specialization", "union"] }
vint64 = "1.0.1"
zstd = { version = "0.13", features = ["experimental", "zstdmt"] }
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,6 @@ path = "lib.rs"
bytemuck = { version = "1.14", features = ["derive", "min_const_generics"] }
depgraph_reader = { version = "0.0.0", path = "../../cargo/depgraph_reader" }
memmap2 = "0.5.10"
rayon = "1.2"
rayon = "1.9.0"
vint64 = "1.0.1"
zstd = { version = "0.13", features = ["experimental", "zstdmt"] }
2 changes: 1 addition & 1 deletion hphp/hack/src/depgraph/hhdg/cargo/hhdg/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,4 +17,4 @@ clap = { version = "3.2.25", features = ["derive", "env", "regex", "unicode", "w
depgraph_reader = { version = "0.0.0", path = "../../../cargo/depgraph_reader" }
hash = { version = "0.0.0", path = "../../../../utils/hash" }
human_readable_dep_map = { version = "0.0.0", path = "../../../cargo/human_readable_dep_map" }
rayon = "1.2"
rayon = "1.9.0"
2 changes: 1 addition & 1 deletion hphp/hack/src/hackc/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ positioned_by_ref_parser = { version = "0.0.0", path = "../parser/api/cargo/posi
positioned_full_trivia_parser = { version = "0.0.0", path = "../parser/api/cargo/positioned_full_trivia_parser" }
positioned_parser = { version = "0.0.0", path = "../parser/api/cargo/positioned_parser" }
profile_rust = { version = "0.0.0", path = "../utils/perf/cargo/profile" }
rayon = "1.2"
rayon = "1.9.0"
regex = "1.9.2"
relative_path = { version = "0.0.0", path = "../utils/rust/relative_path" }
sem_diff = { version = "0.0.0", path = "sem_diff" }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ ast_scope = { version = "0.0.0", path = "../ast_scope" }
env = { version = "0.0.0", path = "../env" }
hhbc = { version = "0.0.0", path = "../../../hhbc/cargo/hhbc" }
hhbc_string_utils = { version = "0.0.0", path = "../../../utils/cargo/hhbc_string_utils" }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
itertools = "0.11.0"
naming_special_names_rust = { version = "0.0.0", path = "../../../../naming" }
oxidized = { version = "0.0.0", path = "../../../../oxidized" }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hackc/emitter/cargo/emit_unit/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ hash = { version = "0.0.0", path = "../../../../utils/hash" }
hhbc = { version = "0.0.0", path = "../../../hhbc/cargo/hhbc" }
hhbc_string_utils = { version = "0.0.0", path = "../../../utils/cargo/hhbc_string_utils" }
hhvm_types_ffi = { version = "0.0.0", path = "../../../hhvm_cxx/hhvm_types" }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
instruction_sequence = { version = "0.0.0", path = "../instruction_sequence" }
itertools = "0.11.0"
label_rewriter = { version = "0.0.0", path = "../label_rewriter" }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hackc/emitter/cargo/env/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ decl_provider = { version = "0.0.0", path = "../../../decl_provider" }
global_state = { version = "0.0.0", path = "../global_state" }
hhbc = { version = "0.0.0", path = "../../../hhbc/cargo/hhbc" }
hhbc_string_utils = { version = "0.0.0", path = "../../../utils/cargo/hhbc_string_utils" }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
instruction_sequence = { version = "0.0.0", path = "../instruction_sequence" }
naming_special_names_rust = { version = "0.0.0", path = "../../../../naming" }
options = { version = "0.0.0", path = "../../../compile/cargo/options" }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hackc/ir/ir_core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ ffi = { version = "0.0.0", path = "../../ffi/ffi" }
hash = { version = "0.0.0", path = "../../../utils/hash" }
hhbc = { version = "0.0.0", path = "../../hhbc/cargo/hhbc" }
hhvm_types_ffi = { version = "0.0.0", path = "../../hhvm_cxx/hhvm_types" }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
intern = { version = "0.1.0", path = "../../../utils/intern" }
macros = { version = "0.0.0", path = "../macros" }
maplit = "1.0"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ ocamlrep_ocamlpool = { version = "0.1.0", git = "https://github.com/facebook/oca
oxidized = { version = "0.0.0", path = "../../../oxidized" }
oxidized_by_ref = { version = "0.0.0", path = "../../../oxidized_by_ref" }
pos = { version = "0.0.0", path = "../../pos/cargo/pos" }
rayon = "1.2"
rayon = "1.9.0"
relative_path = { version = "0.0.0", path = "../../../utils/rust/relative_path" }
tempfile = "3.8"
ty = { version = "0.0.0", path = "../../ty/cargo/ty" }
2 changes: 1 addition & 1 deletion hphp/hack/src/hackrs/cargo/decl_repo_rust/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ jwalk = "0.6"
oxidized = { version = "0.0.0", path = "../../../oxidized" }
pos = { version = "0.0.0", path = "../../pos/cargo/pos" }
procfs = "0.15.1"
rayon = "1.2"
rayon = "1.9.0"
rusqlite = { version = "0.29.0", features = ["backup", "blob", "column_decltype", "limits"] }
serde = { version = "1.0.185", features = ["derive", "rc"] }
serde_json = { version = "1.0.100", features = ["float_roundtrip", "unbounded_depth"] }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ datastore = { version = "0.0.0", path = "../../../datastore" }
decl_enforceability = { version = "0.0.0", path = "../../../decl_enforceability" }
eq_modulo_pos = { version = "0.0.0", path = "../../../../utils/eq_modulo_pos" }
hash = { version = "0.0.0", path = "../../../../utils/hash" }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
itertools = "0.11.0"
oxidized = { version = "0.0.0", path = "../../../../oxidized" }
pos = { version = "0.0.0", path = "../../../pos/cargo/pos" }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hackrs/folded_decl_provider/provider.rs
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ impl<R: Reason> LazyFoldedDeclProvider<R> {
};
stack.insert(name);
let parents = self.decl_class_parents(stack, &mut errors, &shallow_class)?;
stack.remove(&name);
stack.swap_remove(&name);
Ok(Some(DeclFolder::decl_class(
&self.opts,
&shallow_class,
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hackrs/folded_decl_provider/subst.rs
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ impl<'a, R: Reason> Substitution<'a, R> {
let outer_subst = self;
let mut subst = self.subst.clone();
for tp in tparams.iter() {
subst.0.remove(tp.name.id_ref());
subst.0.swap_remove(tp.name.id_ref());
}
let subst = Substitution { subst: &subst };
let params = ft
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ moka = { version = "0.12.5", features = ["future", "sync"] }
naming_provider = { version = "0.0.0", path = "../../../naming_provider/cargo/naming_provider" }
oxidized = { version = "0.0.0", path = "../../../../oxidized" }
pos = { version = "0.0.0", path = "../../../pos/cargo/pos" }
rayon = "1.2"
rayon = "1.9.0"
serde = { version = "1.0.185", features = ["derive", "rc"] }
shallow_decl_provider = { version = "0.0.0", path = "../../../shallow_decl_provider/cargo/shallow_decl_provider" }
ty = { version = "0.0.0", path = "../../../ty/cargo/ty" }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hackrs/pos/cargo/pos/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ bumpalo = { version = "3.14.0", features = ["allocator_api", "collections"] }
eq_modulo_pos = { version = "0.0.0", path = "../../../../utils/eq_modulo_pos" }
hh24_types = { version = "0.0.0", path = "../../../../utils/hh24_types" }
im = { version = "15.1", features = ["rayon", "serde"] }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
intern = { version = "0.1.0", path = "../../../../utils/intern" }
ocamlrep = { version = "0.1.0", git = "https://github.com/facebook/ocamlrep/", branch = "main" }
oxidized = { version = "0.0.0", path = "../../../../oxidized" }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/hh_fanout/cargo/hh_fanout_build/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -24,5 +24,5 @@ log = { version = "0.4.17", features = ["kv_unstable", "kv_unstable_std"] }
memmap2 = "0.5.10"
newtype = { version = "0.0.0", path = "../../../utils/newtype" }
parking_lot = { version = "0.12.1", features = ["send_guard"] }
rayon = "1.2"
rayon = "1.9.0"
smallvec = { version = "1.6.1", features = ["serde", "specialization", "union"] }
2 changes: 1 addition & 1 deletion hphp/hack/src/hh_naming_table_builder/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ hhi = { version = "0.0.0", path = "../hhi/rust" }
names = { version = "0.0.0", path = "../naming/names_rust" }
oxidized = { version = "0.0.0", path = "../oxidized" }
oxidized_by_ref = { version = "0.0.0", path = "../oxidized_by_ref" }
rayon = "1.2"
rayon = "1.9.0"
relative_path = { version = "0.0.0", path = "../utils/rust/relative_path" }
si_addendum = { version = "0.0.0", path = "../utils/cargo/si_addendum" }
slog = { version = "2.7", features = ["max_level_trace", "nested-values"] }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/package/types.rs
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,6 @@ impl Iterator for NameSet {
}
impl NameSet {
pub fn take(&mut self, value: &Spanned<String>) -> Option<Spanned<String>> {
self.0.take(value)
self.0.swap_take(value)
}
}
2 changes: 1 addition & 1 deletion hphp/hack/src/rust_to_ocaml/rust_to_ocaml/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ attr_parser = { version = "0.0.0", path = "../attr_parser" }
clap = { version = "3.2.25", features = ["derive", "env", "regex", "unicode", "wrap_help"] }
convert_case = "0.4.0"
derive_more = "0.99.17"
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"] }
signed_source = { version = "0.0.0", path = "../../utils/rust/signed_source" }
syn = { version = "1.0.109", features = ["extra-traits", "fold", "full", "visit", "visit-mut"] }
Expand Down
2 changes: 1 addition & 1 deletion hphp/hack/src/utils/eq_modulo_pos/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,5 @@ arena_collections = { version = "0.0.0", path = "../../arena_collections" }
bstr = { version = "1.4.0", features = ["serde", "std", "unicode"] }
eq_modulo_pos_derive = { version = "0.0.0", path = "../eq_modulo_pos_derive" }
hcons = { version = "0.0.0", path = "../../hcons" }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
ocamlrep_caml_builtins = { version = "0.1.0", git = "https://github.com/facebook/ocamlrep/", branch = "main" }
2 changes: 1 addition & 1 deletion hphp/hack/src/utils/hash/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,5 +12,5 @@ path = "lib.rs"

[dependencies]
dashmap = { version = "5.5.3", features = ["rayon", "serde"] }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
rustc-hash = "1.1.0"
2 changes: 1 addition & 1 deletion hphp/hack/src/utils/intern/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ license = "MIT"
[dependencies]
fnv = "1.0"
hashbrown = { version = "0.14.3", features = ["raw", "serde"] }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
once_cell = "1.12"
parking_lot = { version = "0.12.1", features = ["send_guard"] }
serde = { version = "1.0.185", features = ["derive", "rc"] }
Expand Down
2 changes: 1 addition & 1 deletion third-party/thrift/src/thrift/lib/rust/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ bytes = { version = "1.6.0", features = ["serde"] }
futures = { version = "0.3.30", features = ["async-await", "compat"] }
ghost = "0.1.17"
num-derive = "0.3.3"
num-traits = "0.2"
num-traits = "0.2.18"
ordered-float = { version = "3.7", features = ["serde"] }
panic-message = "0.3"
serde_json = { version = "1.0.100", features = ["float_roundtrip", "unbounded_depth"] }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ anyhow = "1.0.75"
codegen_includer_proc_macro = { version = "0.1.0", git = "https://github.com/facebookexperimental/rust-shed.git", branch = "main" }
fbthrift = { version = "0.0.1+unstable", path = "../../.." }
futures = { version = "0.3.30", features = ["async-await", "compat"] }
indexmap = { version = "2.1.0", features = ["arbitrary", "rayon", "serde"] }
indexmap = { version = "2.2.6", features = ["arbitrary", "rayon", "serde"] }
once_cell = "1.12"
ref-cast = "1.0.18"
serde = { version = "1.0.185", features = ["derive", "rc"] }
Expand Down

0 comments on commit 26cacec

Please sign in to comment.