cargo vendor
This commit is contained in:
parent
e0cff923ae
commit
685ab6f86c
@ -1,20 +1,24 @@
|
|||||||
# [source.crates-io]
|
[source.crates-io]
|
||||||
# replace-with = "vendored-sources"
|
replace-with = "vendored-sources"
|
||||||
|
|
||||||
# [source."git+git://git.proxmox.com/git/perlmod.git"]
|
[source."git+git://git.proxmox.com/git/perlmod.git"]
|
||||||
# git = "git://git.proxmox.com/git/perlmod.git"
|
git = "git://git.proxmox.com/git/perlmod.git"
|
||||||
# replace-with = "vendored-sources"
|
replace-with = "vendored-sources"
|
||||||
|
|
||||||
# [source."git+git://git.proxmox.com/git/proxmox-resource-scheduling.git"]
|
[source."git+git://git.proxmox.com/git/proxmox-resource-scheduling.git"]
|
||||||
# git = "git://git.proxmox.com/git/proxmox-resource-scheduling.git"
|
git = "git://git.proxmox.com/git/proxmox-resource-scheduling.git"
|
||||||
# replace-with = "vendored-sources"
|
replace-with = "vendored-sources"
|
||||||
|
|
||||||
# [source."git+https://gitea.basealt.ru/konevsa/proxmox.newest.git"]
|
[source."git+https://gitea.basealt.ru/konevsa/apt-pkg-native"]
|
||||||
# git = "https://gitea.basealt.ru/konevsa/proxmox.newest.git"
|
git = "https://gitea.basealt.ru/konevsa/apt-pkg-native"
|
||||||
# replace-with = "vendored-sources"
|
replace-with = "vendored-sources"
|
||||||
|
|
||||||
# [source.vendored-sources]
|
[source."git+https://gitea.basealt.ru/konevsa/proxmox.newest.git"]
|
||||||
# directory = "vendor"
|
git = "https://gitea.basealt.ru/konevsa/proxmox.newest.git"
|
||||||
|
replace-with = "vendored-sources"
|
||||||
|
|
||||||
|
[source.vendored-sources]
|
||||||
|
directory = "vendor"
|
||||||
|
|
||||||
# Local path overrides
|
# Local path overrides
|
||||||
# NOTE: You must run `cargo update` after changing this for it to take effect!
|
# NOTE: You must run `cargo update` after changing this for it to take effect!
|
||||||
|
416
pve-rs/Cargo.lock
generated
416
pve-rs/Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
2
pve-rs/vendor/addr2line/.cargo-checksum.json
vendored
2
pve-rs/vendor/addr2line/.cargo-checksum.json
vendored
@ -1 +1 @@
|
|||||||
{"files":{"CHANGELOG.md":"01913c77e69a9646b0a0e05faecabadbbb0e25c6881cd20f9881d8253fe7fffb","Cargo.lock":"f9ade5097a66241857a25f0777fe609b53a75c545a6f387fdea959bd6ad846f0","Cargo.toml":"860f20b5774b91eaa65069229364ae565d0685202650dc41b0fcb46aa85a4685","LICENSE-APACHE":"a60eea817514531668d7e00765731449fe14d059d3249e0bc93b36de45f759f2","LICENSE-MIT":"e99d88d232bf57d70f0fb87f6b496d44b6653f99f8a63d250a54c61ea4bcde40","README.md":"704f9c668989619bdb2f57217db47ac8ca5c468007b083c985b5595b69d303d3","src/bin/addr2line.rs":"727dc70cbb9d7ecc0fd44149df35ea7a4a372ca29e52260fd31232932cd3171e","src/frame.rs":"de3b23388c36a0874db5569d1f49ce6cc52ef2006b9ae9b9a3eba7654b201e2b","src/function.rs":"7fc741622c44c24fdf54c8a44cbdee058d49da33974bc86cd45b70c143071e68","src/lazy.rs":"ec230b69a0d194fe253227a41903231ca70a88f896af7a6f8a5a7d9ac63bf618","src/lib.rs":"fafd0bcb6fdd8f700c3660ce82f4d3f728fe79041c04336f92a6cce2ba50e427","src/line.rs":"049e9b1526ae3433a6001e8377245131e9cbd056d17e67a9b34898598a4f1c28","src/loader.rs":"d5639a90b6e692e83d59ddbff592c5a40a0764929165345086961ee4c98a4597","src/lookup.rs":"0d28a2fd00f0696f8fb50cdc88cb7d55a910df8bf3052b7c74ae50a387346e67","src/unit.rs":"f4399c401759e14db5d596cfddfe2c8a0591a81c18d9adaedba7d243cc3bd192","tests/correctness.rs":"04692661bd02053789eff1af9faaff3c4ffe637801edc69f7e37eb993a95b2ad","tests/output_equivalence.rs":"54f4bd926ed46da96b0dab020c713df03e74f616f15ac8b70515d1cd9685f97a","tests/parse.rs":"2b56ab29fe20bfccb5694d3f79de6799d9a1726e655c75f6edada498eecb46c4"},"package":"f5fb1d8e4442bd405fdfd1dacb42792696b0cf9cb15882e5d097b742a676d375"}
|
{"files":{"CHANGELOG.md":"0d04c7dddcffba3d83d4a05466c9b79cf13360c33f081fc9800596716bf954ce","Cargo.lock":"783a3adbf5047e30e0aa52f28dc6a0134534de715e5a36fd402c17e2eba43b1a","Cargo.toml":"940373297f67456852d5236a1eb7a3856bc672c69529cbbe6052ce5f85221170","LICENSE-APACHE":"a60eea817514531668d7e00765731449fe14d059d3249e0bc93b36de45f759f2","LICENSE-MIT":"e99d88d232bf57d70f0fb87f6b496d44b6653f99f8a63d250a54c61ea4bcde40","README.md":"c635ed91d7b0c87ff2f0f311cd1a31336d2cbc4d011965d3b58afaca073538d9","src/bin/addr2line.rs":"3da8c7657604578961f2bf89052b94e6c59c55abe27a2707913f98875d666124","src/frame.rs":"de3b23388c36a0874db5569d1f49ce6cc52ef2006b9ae9b9a3eba7654b201e2b","src/function.rs":"7fc741622c44c24fdf54c8a44cbdee058d49da33974bc86cd45b70c143071e68","src/lazy.rs":"ec230b69a0d194fe253227a41903231ca70a88f896af7a6f8a5a7d9ac63bf618","src/lib.rs":"8bf9fe3f3ced8ff84d60fdd456a8ff6e73170825cd696b0291b4644c01e620d2","src/line.rs":"049e9b1526ae3433a6001e8377245131e9cbd056d17e67a9b34898598a4f1c28","src/loader.rs":"9ad08da02599b9742a9821742fd84dbe0294838b6faa5f5753eacddc6101ffc1","src/lookup.rs":"0d28a2fd00f0696f8fb50cdc88cb7d55a910df8bf3052b7c74ae50a387346e67","src/unit.rs":"f4399c401759e14db5d596cfddfe2c8a0591a81c18d9adaedba7d243cc3bd192"},"package":"dfbe277e56a376000877090da837660b4427aad530e3028d44e0bffe4f89a1c1"}
|
31
pve-rs/vendor/addr2line/CHANGELOG.md
vendored
31
pve-rs/vendor/addr2line/CHANGELOG.md
vendored
@ -2,6 +2,37 @@
|
|||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
## 0.24.2 (2024/10/04)
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
* Enabled caching of DWARF abbreviations.
|
||||||
|
[#318](https://github.com/gimli-rs/addr2line/pull/318)
|
||||||
|
|
||||||
|
* Changed the `addr2line` binary to prefer symbol names over DWARF names.
|
||||||
|
[#332](https://github.com/gimli-rs/addr2line/pull/332)
|
||||||
|
|
||||||
|
* Updated `gimli` dependency.
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
* Added `Context::from_arc_dwarf`.
|
||||||
|
[#327](https://github.com/gimli-rs/addr2line/pull/327)
|
||||||
|
|
||||||
|
* Added benchmark comparison.
|
||||||
|
[#315](https://github.com/gimli-rs/addr2line/pull/315)
|
||||||
|
[#321](https://github.com/gimli-rs/addr2line/pull/321)
|
||||||
|
[#322](https://github.com/gimli-rs/addr2line/pull/322)
|
||||||
|
[#325](https://github.com/gimli-rs/addr2line/pull/325)
|
||||||
|
|
||||||
|
* Added more tests.
|
||||||
|
[#328](https://github.com/gimli-rs/addr2line/pull/328)
|
||||||
|
[#330](https://github.com/gimli-rs/addr2line/pull/330)
|
||||||
|
[#331](https://github.com/gimli-rs/addr2line/pull/331)
|
||||||
|
[#333](https://github.com/gimli-rs/addr2line/pull/333)
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
## 0.24.1 (2024/07/26)
|
## 0.24.1 (2024/07/26)
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
209
pve-rs/vendor/addr2line/Cargo.lock
generated
vendored
209
pve-rs/vendor/addr2line/Cargo.lock
generated
vendored
@ -4,16 +4,16 @@ version = 3
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "addr2line"
|
name = "addr2line"
|
||||||
version = "0.22.0"
|
version = "0.24.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "6e4503c46a5c0c7844e948c9a4d6acd9f50cccb4de1c48eb9e291ea17470c678"
|
checksum = "f5fb1d8e4442bd405fdfd1dacb42792696b0cf9cb15882e5d097b742a676d375"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"gimli 0.29.0",
|
"gimli",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "addr2line"
|
name = "addr2line"
|
||||||
version = "0.24.1"
|
version = "0.24.2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"backtrace",
|
"backtrace",
|
||||||
"clap",
|
"clap",
|
||||||
@ -21,7 +21,7 @@ dependencies = [
|
|||||||
"cpp_demangle",
|
"cpp_demangle",
|
||||||
"fallible-iterator",
|
"fallible-iterator",
|
||||||
"findshlibs",
|
"findshlibs",
|
||||||
"gimli 0.31.0",
|
"gimli",
|
||||||
"libtest-mimic",
|
"libtest-mimic",
|
||||||
"memmap2",
|
"memmap2",
|
||||||
"object",
|
"object",
|
||||||
@ -33,10 +33,10 @@ dependencies = [
|
|||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "adler"
|
name = "adler2"
|
||||||
version = "1.0.2"
|
version = "2.0.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe"
|
checksum = "512761e0bb2578dd7380c6baaa0f4ce03e84f95e960231d1dec8bf4d7d6e2627"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "anstream"
|
name = "anstream"
|
||||||
@ -89,17 +89,17 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "backtrace"
|
name = "backtrace"
|
||||||
version = "0.3.73"
|
version = "0.3.74"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5cc23269a4f8976d0a4d2e7109211a419fe30e8d88d677cd60b6bc79c5732e0a"
|
checksum = "8d82cb332cdfaed17ae235a638438ac4d4839913cc2af585c3c6746e8f8bee1a"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"addr2line 0.22.0",
|
"addr2line 0.24.1",
|
||||||
"cc",
|
|
||||||
"cfg-if",
|
"cfg-if",
|
||||||
"libc",
|
"libc",
|
||||||
"miniz_oxide",
|
"miniz_oxide",
|
||||||
"object",
|
"object",
|
||||||
"rustc-demangle",
|
"rustc-demangle",
|
||||||
|
"windows-targets",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -108,17 +108,14 @@ version = "2.6.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de"
|
checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "byteorder"
|
|
||||||
version = "1.5.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cc"
|
name = "cc"
|
||||||
version = "1.1.6"
|
version = "1.1.24"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "2aba8f4e9906c7ce3c73463f62a7f0c65183ada1a2d47e397cc8810827f9694f"
|
checksum = "812acba72f0a070b003d3697490d2b55b837230ae7c6c6497f05cc2ddbb8d938"
|
||||||
|
dependencies = [
|
||||||
|
"shlex",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cfg-if"
|
name = "cfg-if"
|
||||||
@ -128,9 +125,9 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "clap"
|
name = "clap"
|
||||||
version = "4.5.11"
|
version = "4.5.19"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "35723e6a11662c2afb578bcf0b88bf6ea8e21282a953428f240574fcc3a2b5b3"
|
checksum = "7be5744db7978a28d9df86a214130d106a89ce49644cbc4e3f0c22c3fba30615"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"clap_builder",
|
"clap_builder",
|
||||||
"clap_derive",
|
"clap_derive",
|
||||||
@ -138,9 +135,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "clap_builder"
|
name = "clap_builder"
|
||||||
version = "4.5.11"
|
version = "4.5.19"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "49eb96cbfa7cfa35017b7cd548c75b14c3118c98b423041d70562665e07fb0fa"
|
checksum = "a5fbc17d3ef8278f55b282b2a2e75ae6f6c7d4bb70ed3d0382375104bfafdb4b"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anstream",
|
"anstream",
|
||||||
"anstyle",
|
"anstyle",
|
||||||
@ -151,9 +148,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "clap_derive"
|
name = "clap_derive"
|
||||||
version = "4.5.11"
|
version = "4.5.18"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5d029b67f89d30bbb547c89fd5161293c0aec155fc691d7924b64550662db93e"
|
checksum = "4ac6a0c7b1a9e9a5186361f67dfa1b88213572f427fb9ab038efb2bd8c582dab"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"heck",
|
"heck",
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
@ -175,15 +172,15 @@ checksum = "d3fd119d74b830634cea2a0f58bbd0d54540518a14397557951e79340abc28c0"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "compiler_builtins"
|
name = "compiler_builtins"
|
||||||
version = "0.1.113"
|
version = "0.1.131"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f7a6025b8e1885a239509ec7a00859e721eecb5725a64206ab1a6a96f7b55660"
|
checksum = "d18d2ba094b78965890b2912f45dc8cb6bb3aff315ef54755ec33223b6454502"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cpp_demangle"
|
name = "cpp_demangle"
|
||||||
version = "0.4.3"
|
version = "0.4.4"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7e8227005286ec39567949b33df9896bcadfa6051bccca2488129f108ca23119"
|
checksum = "96e58d342ad113c2b878f16d5d034c03be492ae460cdbc02b7f0f2284d310c7d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cfg-if",
|
"cfg-if",
|
||||||
]
|
]
|
||||||
@ -233,9 +230,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "flate2"
|
name = "flate2"
|
||||||
version = "1.0.30"
|
version = "1.0.34"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5f54427cfd1c7829e2a139fcefea601bf088ebca651d2bf53ebc600eac295dae"
|
checksum = "a1b589b4dc103969ad3cf85c950899926ec64300a1a46d76c03a6072957036f0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crc32fast",
|
"crc32fast",
|
||||||
"miniz_oxide",
|
"miniz_oxide",
|
||||||
@ -243,15 +240,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gimli"
|
name = "gimli"
|
||||||
version = "0.29.0"
|
version = "0.31.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "40ecd4077b5ae9fd2e9e169b102c6c330d0605168eb0e8bf79952b256dbefffd"
|
checksum = "07e28edb80900c19c28f1072f2e8aeca7fa06b23cd4169cefe1af5aa3260783f"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "gimli"
|
|
||||||
version = "0.31.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "32085ea23f3234fc7846555e85283ba4de91e21016dc0455a16286d87a292d64"
|
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"compiler_builtins",
|
"compiler_builtins",
|
||||||
"fallible-iterator",
|
"fallible-iterator",
|
||||||
@ -286,9 +277,9 @@ checksum = "bbd2bcb4c963f2ddae06a2efc7e9f3591312473c50c6685e1f298068316e66fe"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "libc"
|
name = "libc"
|
||||||
version = "0.2.155"
|
version = "0.2.159"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "97b3888a4aecf77e811145cadf6eef5901f4782c53886191b2f693f24761847c"
|
checksum = "561d97a539a36e26a9a5fad1ea11a3039a67714694aaa379433e580854bc3dc5"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "libtest-mimic"
|
name = "libtest-mimic"
|
||||||
@ -316,20 +307,20 @@ checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "memmap2"
|
name = "memmap2"
|
||||||
version = "0.9.4"
|
version = "0.9.5"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "fe751422e4a8caa417e13c3ea66452215d7d63e19e604f4980461212f3ae1322"
|
checksum = "fd3f7eed9d3848f8b98834af67102b720745c4ec028fcd0aa0239277e7de374f"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "miniz_oxide"
|
name = "miniz_oxide"
|
||||||
version = "0.7.4"
|
version = "0.8.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b8a240ddb74feaf34a79a7add65a741f3167852fba007066dcac1ca548d89c08"
|
checksum = "e2d80299ef12ff69b16a84bb182e3b9df68b5a91574d3d4fa6e41b65deec4df1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"adler",
|
"adler2",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -344,9 +335,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "object"
|
name = "object"
|
||||||
version = "0.36.2"
|
version = "0.36.5"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3f203fa8daa7bb185f760ae12bd8e097f63d17041dcdcaf675ac54cdf863170e"
|
checksum = "aedf0a2d09c573ed1d8d85b30c119153926a2b36dce0ab28322c09a117a4683e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"flate2",
|
"flate2",
|
||||||
"memchr",
|
"memchr",
|
||||||
@ -364,9 +355,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "quote"
|
name = "quote"
|
||||||
version = "1.0.36"
|
version = "1.0.37"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7"
|
checksum = "b5b9d34b8991d19d98081b46eacdd8eb58c6f2b201139f7c5f643cc155a633af"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
]
|
]
|
||||||
@ -391,9 +382,9 @@ checksum = "1956f5517128a2b6f23ab2dadf1a976f4f5b27962e7724c2bf3d45e539ec098c"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustix"
|
name = "rustix"
|
||||||
version = "0.38.34"
|
version = "0.38.37"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "70dc5ec042f7a43c4a73241207cecc9873a06d45debb38b329f8541d85c2730f"
|
checksum = "8acb788b847c24f28525660c4d7758620a7210875711f79e7f663cc152726811"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags",
|
"bitflags",
|
||||||
"errno",
|
"errno",
|
||||||
@ -404,14 +395,19 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruzstd"
|
name = "ruzstd"
|
||||||
version = "0.7.0"
|
version = "0.7.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "5022b253619b1ba797f243056276bed8ed1a73b0f5a7ce7225d524067644bf8f"
|
checksum = "99c3938e133aac070997ddc684d4b393777d293ba170f2988c8fd5ea2ad4ce21"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"byteorder",
|
|
||||||
"twox-hash",
|
"twox-hash",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "shlex"
|
||||||
|
version = "1.3.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "smallvec"
|
name = "smallvec"
|
||||||
version = "1.13.2"
|
version = "1.13.2"
|
||||||
@ -438,9 +434,9 @@ checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "syn"
|
name = "syn"
|
||||||
version = "2.0.72"
|
version = "2.0.79"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "dc4b9b9bf2add8093d3f2c0204471e951b2285580335de42f9d2534f3ae7a8af"
|
checksum = "89132cd0bf050864e1d38dc3bbc07a0eb8e7530af26344d3d2bbbef83499f590"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
@ -458,12 +454,12 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "terminal_size"
|
name = "terminal_size"
|
||||||
version = "0.3.0"
|
version = "0.4.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "21bebf2b7c9e0a515f6e0f8c51dc0f8e4696391e6f1ff30379559f8365fb0df7"
|
checksum = "4f599bd7ca042cfdf8f4512b277c02ba102247820f9d9d4a9f521f496751a6ef"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"rustix",
|
"rustix",
|
||||||
"windows-sys 0.48.0",
|
"windows-sys 0.59.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -493,9 +489,9 @@ checksum = "6af6ae20167a9ece4bcb41af5b80f8a1f1df981f6391189ce00fd257af04126a"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-ident"
|
name = "unicode-ident"
|
||||||
version = "1.0.12"
|
version = "1.0.13"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
|
checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "utf8parse"
|
name = "utf8parse"
|
||||||
@ -521,11 +517,11 @@ checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "winapi-util"
|
name = "winapi-util"
|
||||||
version = "0.1.8"
|
version = "0.1.9"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "4d4cc384e1e73b93bafa6fb4f1df8c41695c8a91cf9c4c64358067d15a7b6c6b"
|
checksum = "cf221c93e13a30d793f7645a0e7762c55d169dbb0a49671918a2319d289b10bb"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"windows-sys 0.52.0",
|
"windows-sys 0.59.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -534,37 +530,22 @@ version = "0.4.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
|
checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows-sys"
|
|
||||||
version = "0.48.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9"
|
|
||||||
dependencies = [
|
|
||||||
"windows-targets 0.48.5",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows-sys"
|
name = "windows-sys"
|
||||||
version = "0.52.0"
|
version = "0.52.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d"
|
checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"windows-targets 0.52.6",
|
"windows-targets",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows-targets"
|
name = "windows-sys"
|
||||||
version = "0.48.5"
|
version = "0.59.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c"
|
checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"windows_aarch64_gnullvm 0.48.5",
|
"windows-targets",
|
||||||
"windows_aarch64_msvc 0.48.5",
|
|
||||||
"windows_i686_gnu 0.48.5",
|
|
||||||
"windows_i686_msvc 0.48.5",
|
|
||||||
"windows_x86_64_gnu 0.48.5",
|
|
||||||
"windows_x86_64_gnullvm 0.48.5",
|
|
||||||
"windows_x86_64_msvc 0.48.5",
|
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -573,46 +554,28 @@ version = "0.52.6"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973"
|
checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"windows_aarch64_gnullvm 0.52.6",
|
"windows_aarch64_gnullvm",
|
||||||
"windows_aarch64_msvc 0.52.6",
|
"windows_aarch64_msvc",
|
||||||
"windows_i686_gnu 0.52.6",
|
"windows_i686_gnu",
|
||||||
"windows_i686_gnullvm",
|
"windows_i686_gnullvm",
|
||||||
"windows_i686_msvc 0.52.6",
|
"windows_i686_msvc",
|
||||||
"windows_x86_64_gnu 0.52.6",
|
"windows_x86_64_gnu",
|
||||||
"windows_x86_64_gnullvm 0.52.6",
|
"windows_x86_64_gnullvm",
|
||||||
"windows_x86_64_msvc 0.52.6",
|
"windows_x86_64_msvc",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_aarch64_gnullvm"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_aarch64_gnullvm"
|
name = "windows_aarch64_gnullvm"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3"
|
checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_aarch64_msvc"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_aarch64_msvc"
|
name = "windows_aarch64_msvc"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469"
|
checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_i686_gnu"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_i686_gnu"
|
name = "windows_i686_gnu"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
@ -625,48 +588,24 @@ version = "0.52.6"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66"
|
checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_i686_msvc"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_i686_msvc"
|
name = "windows_i686_msvc"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66"
|
checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_x86_64_gnu"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_x86_64_gnu"
|
name = "windows_x86_64_gnu"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78"
|
checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_x86_64_gnullvm"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_x86_64_gnullvm"
|
name = "windows_x86_64_gnullvm"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d"
|
checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "windows_x86_64_msvc"
|
|
||||||
version = "0.48.5"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "windows_x86_64_msvc"
|
name = "windows_x86_64_msvc"
|
||||||
version = "0.52.6"
|
version = "0.52.6"
|
||||||
|
32
pve-rs/vendor/addr2line/Cargo.toml
vendored
32
pve-rs/vendor/addr2line/Cargo.toml
vendored
@ -13,7 +13,8 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.65"
|
rust-version = "1.65"
|
||||||
name = "addr2line"
|
name = "addr2line"
|
||||||
version = "0.24.1"
|
version = "0.24.2"
|
||||||
|
build = false
|
||||||
include = [
|
include = [
|
||||||
"/CHANGELOG.md",
|
"/CHANGELOG.md",
|
||||||
"/Cargo.lock",
|
"/Cargo.lock",
|
||||||
@ -22,8 +23,11 @@ include = [
|
|||||||
"/LICENSE-MIT",
|
"/LICENSE-MIT",
|
||||||
"/README.md",
|
"/README.md",
|
||||||
"/src",
|
"/src",
|
||||||
"/tests",
|
|
||||||
]
|
]
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
description = "A cross-platform symbolication library written in Rust, using `gimli`"
|
description = "A cross-platform symbolication library written in Rust, using `gimli`"
|
||||||
documentation = "https://docs.rs/addr2line"
|
documentation = "https://docs.rs/addr2line"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
@ -45,26 +49,15 @@ debug = 2
|
|||||||
[profile.release]
|
[profile.release]
|
||||||
debug = 2
|
debug = 2
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "addr2line"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
name = "addr2line"
|
name = "addr2line"
|
||||||
|
path = "src/bin/addr2line.rs"
|
||||||
required-features = ["bin"]
|
required-features = ["bin"]
|
||||||
|
|
||||||
[[test]]
|
|
||||||
name = "output_equivalence"
|
|
||||||
harness = false
|
|
||||||
required-features = ["bin"]
|
|
||||||
|
|
||||||
[[test]]
|
|
||||||
name = "correctness"
|
|
||||||
required-features = [
|
|
||||||
"loader",
|
|
||||||
"fallible-iterator",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[test]]
|
|
||||||
name = "parse"
|
|
||||||
required-features = ["loader"]
|
|
||||||
|
|
||||||
[dependencies.alloc]
|
[dependencies.alloc]
|
||||||
version = "1.0.0"
|
version = "1.0.0"
|
||||||
optional = true
|
optional = true
|
||||||
@ -96,7 +89,7 @@ optional = true
|
|||||||
default-features = false
|
default-features = false
|
||||||
|
|
||||||
[dependencies.gimli]
|
[dependencies.gimli]
|
||||||
version = "0.31.0"
|
version = "0.31.1"
|
||||||
features = ["read"]
|
features = ["read"]
|
||||||
default-features = false
|
default-features = false
|
||||||
|
|
||||||
@ -141,6 +134,7 @@ bin = [
|
|||||||
"loader",
|
"loader",
|
||||||
"rustc-demangle",
|
"rustc-demangle",
|
||||||
"cpp_demangle",
|
"cpp_demangle",
|
||||||
|
"fallible-iterator",
|
||||||
"smallvec",
|
"smallvec",
|
||||||
"dep:clap",
|
"dep:clap",
|
||||||
]
|
]
|
||||||
|
6
pve-rs/vendor/addr2line/README.md
vendored
6
pve-rs/vendor/addr2line/README.md
vendored
@ -31,8 +31,10 @@ The DWARF information is parsed lazily where possible.
|
|||||||
|
|
||||||
The library aims to perform similarly to equivalent existing tools such
|
The library aims to perform similarly to equivalent existing tools such
|
||||||
as `addr2line` from binutils, `eu-addr2line` from elfutils, and
|
as `addr2line` from binutils, `eu-addr2line` from elfutils, and
|
||||||
`llvm-symbolize` from the llvm project, and in the past some benchmarking
|
`llvm-addr2line` from the llvm project. Current benchmarks show a performance
|
||||||
was done that indicates a comparable performance.
|
improvement in all cases:
|
||||||
|
|
||||||
|
![addr2line runtime](benchmark-time.svg)
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
|
19
pve-rs/vendor/addr2line/src/bin/addr2line.rs
vendored
19
pve-rs/vendor/addr2line/src/bin/addr2line.rs
vendored
@ -1,3 +1,4 @@
|
|||||||
|
use fallible_iterator::FallibleIterator;
|
||||||
use std::borrow::Cow;
|
use std::borrow::Cow;
|
||||||
use std::io::{BufRead, Lines, StdinLock, Write};
|
use std::io::{BufRead, Lines, StdinLock, Write};
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
@ -210,7 +211,7 @@ fn main() {
|
|||||||
if opts.do_functions || opts.do_inlines {
|
if opts.do_functions || opts.do_inlines {
|
||||||
let mut printed_anything = false;
|
let mut printed_anything = false;
|
||||||
if let Some(probe) = probe {
|
if let Some(probe) = probe {
|
||||||
let mut frames = ctx.find_frames(probe).unwrap();
|
let mut frames = ctx.find_frames(probe).unwrap().peekable();
|
||||||
let mut first = true;
|
let mut first = true;
|
||||||
while let Some(frame) = frames.next().unwrap() {
|
while let Some(frame) = frames.next().unwrap() {
|
||||||
if opts.pretty && !first {
|
if opts.pretty && !first {
|
||||||
@ -219,15 +220,25 @@ fn main() {
|
|||||||
first = false;
|
first = false;
|
||||||
|
|
||||||
if opts.do_functions {
|
if opts.do_functions {
|
||||||
if let Some(func) = frame.function {
|
// Only use the symbol table if this isn't an inlined function.
|
||||||
|
let symbol = if matches!(frames.peek(), Ok(None)) {
|
||||||
|
ctx.find_symbol(probe)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
};
|
||||||
|
if symbol.is_some() {
|
||||||
|
// Prefer the symbol table over the DWARF name because:
|
||||||
|
// - the symbol can include a clone suffix
|
||||||
|
// - llvm may omit the linkage name in the DWARF with -g1
|
||||||
|
print_function(symbol, None, opts.demangle);
|
||||||
|
} else if let Some(func) = frame.function {
|
||||||
print_function(
|
print_function(
|
||||||
func.raw_name().ok().as_deref(),
|
func.raw_name().ok().as_deref(),
|
||||||
func.language,
|
func.language,
|
||||||
opts.demangle,
|
opts.demangle,
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
let name = ctx.find_symbol(probe);
|
print_function(None, None, opts.demangle);
|
||||||
print_function(name, None, opts.demangle);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if opts.pretty {
|
if opts.pretty {
|
||||||
|
15
pve-rs/vendor/addr2line/src/lib.rs
vendored
15
pve-rs/vendor/addr2line/src/lib.rs
vendored
@ -139,7 +139,12 @@ impl<R: gimli::Reader> Context<R> {
|
|||||||
/// Construct a new `Context` from an existing [`gimli::Dwarf`] object.
|
/// Construct a new `Context` from an existing [`gimli::Dwarf`] object.
|
||||||
#[inline]
|
#[inline]
|
||||||
pub fn from_dwarf(sections: gimli::Dwarf<R>) -> Result<Context<R>, Error> {
|
pub fn from_dwarf(sections: gimli::Dwarf<R>) -> Result<Context<R>, Error> {
|
||||||
let sections = Arc::new(sections);
|
Self::from_arc_dwarf(Arc::new(sections))
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Construct a new `Context` from an existing [`gimli::Dwarf`] object.
|
||||||
|
#[inline]
|
||||||
|
pub fn from_arc_dwarf(sections: Arc<gimli::Dwarf<R>>) -> Result<Context<R>, Error> {
|
||||||
let units = ResUnits::parse(§ions)?;
|
let units = ResUnits::parse(§ions)?;
|
||||||
let sup_units = if let Some(sup) = sections.sup.as_ref() {
|
let sup_units = if let Some(sup) = sections.sup.as_ref() {
|
||||||
SupUnits::parse(sup)?
|
SupUnits::parse(sup)?
|
||||||
@ -390,10 +395,10 @@ impl<R: gimli::Reader> RangeAttributes<R> {
|
|||||||
} else if let (Some(begin), Some(end)) = (self.low_pc, self.high_pc) {
|
} else if let (Some(begin), Some(end)) = (self.low_pc, self.high_pc) {
|
||||||
add_range(gimli::Range { begin, end });
|
add_range(gimli::Range { begin, end });
|
||||||
} else if let (Some(begin), Some(size)) = (self.low_pc, self.size) {
|
} else if let (Some(begin), Some(size)) = (self.low_pc, self.size) {
|
||||||
add_range(gimli::Range {
|
// If `begin` is a -1 tombstone, this will overflow and the check in
|
||||||
begin,
|
// `add_range` will ignore it.
|
||||||
end: begin + size,
|
let end = begin.wrapping_add(size);
|
||||||
});
|
add_range(gimli::Range { begin, end });
|
||||||
}
|
}
|
||||||
Ok(added_any)
|
Ok(added_any)
|
||||||
}
|
}
|
||||||
|
1
pve-rs/vendor/addr2line/src/loader.rs
vendored
1
pve-rs/vendor/addr2line/src/loader.rs
vendored
@ -209,6 +209,7 @@ impl<'a> LoaderInternal<'a> {
|
|||||||
if let Some(sup_object) = &sup_object {
|
if let Some(sup_object) = &sup_object {
|
||||||
dwarf.load_sup(|id| load_section(Some(id.name()), sup_object, endian, arena_data))?;
|
dwarf.load_sup(|id| load_section(Some(id.name()), sup_object, endian, arena_data))?;
|
||||||
}
|
}
|
||||||
|
dwarf.populate_abbreviations_cache(gimli::AbbreviationsCacheStrategy::Duplicates);
|
||||||
|
|
||||||
let ctx = Context::from_dwarf(dwarf)?;
|
let ctx = Context::from_dwarf(dwarf)?;
|
||||||
|
|
||||||
|
57
pve-rs/vendor/addr2line/tests/correctness.rs
vendored
57
pve-rs/vendor/addr2line/tests/correctness.rs
vendored
@ -1,57 +0,0 @@
|
|||||||
use addr2line::Loader;
|
|
||||||
use fallible_iterator::FallibleIterator;
|
|
||||||
use findshlibs::{IterationControl, SharedLibrary, TargetSharedLibrary};
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
#[allow(clippy::fn_to_numeric_cast)]
|
|
||||||
fn correctness() {
|
|
||||||
let path = std::env::current_exe().unwrap();
|
|
||||||
let ctx = Loader::new(&path).unwrap();
|
|
||||||
let module_base = ctx.relative_address_base();
|
|
||||||
|
|
||||||
let mut bias = None;
|
|
||||||
TargetSharedLibrary::each(|lib| {
|
|
||||||
bias = Some((lib.virtual_memory_bias().0 as u64).wrapping_sub(module_base));
|
|
||||||
IterationControl::Break
|
|
||||||
});
|
|
||||||
|
|
||||||
#[allow(unused_mut)]
|
|
||||||
let mut test = |sym: u64, expected_prefix: &str| {
|
|
||||||
let ip = sym.wrapping_sub(bias.unwrap());
|
|
||||||
|
|
||||||
let frames = ctx.find_frames(ip).unwrap();
|
|
||||||
let frame = frames.last().unwrap().unwrap();
|
|
||||||
let name = frame.function.as_ref().unwrap().demangle().unwrap();
|
|
||||||
// Old rust versions generate DWARF with wrong linkage name,
|
|
||||||
// so only check the start.
|
|
||||||
if !name.starts_with(expected_prefix) {
|
|
||||||
panic!("incorrect name '{}', expected {:?}", name, expected_prefix);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
test(test_function as u64, "correctness::test_function");
|
|
||||||
test(
|
|
||||||
small::test_function as u64,
|
|
||||||
"correctness::small::test_function",
|
|
||||||
);
|
|
||||||
test(auxiliary::foo as u64, "auxiliary::foo");
|
|
||||||
}
|
|
||||||
|
|
||||||
mod small {
|
|
||||||
pub fn test_function() {
|
|
||||||
println!("y");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_function() {
|
|
||||||
println!("x");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn zero_function() {
|
|
||||||
let path = std::env::current_exe().unwrap();
|
|
||||||
let ctx = Loader::new(&path).unwrap();
|
|
||||||
for probe in 0..10 {
|
|
||||||
assert!(ctx.find_frames(probe).unwrap().count().unwrap() < 10);
|
|
||||||
}
|
|
||||||
}
|
|
134
pve-rs/vendor/addr2line/tests/output_equivalence.rs
vendored
134
pve-rs/vendor/addr2line/tests/output_equivalence.rs
vendored
@ -1,134 +0,0 @@
|
|||||||
use std::env;
|
|
||||||
use std::ffi::OsStr;
|
|
||||||
use std::path::Path;
|
|
||||||
use std::process::Command;
|
|
||||||
|
|
||||||
use backtrace::Backtrace;
|
|
||||||
use findshlibs::{IterationControl, SharedLibrary, TargetSharedLibrary};
|
|
||||||
use libtest_mimic::{Arguments, Failed, Trial};
|
|
||||||
|
|
||||||
#[inline(never)]
|
|
||||||
fn make_trace() -> Vec<String> {
|
|
||||||
fn foo() -> Backtrace {
|
|
||||||
bar()
|
|
||||||
}
|
|
||||||
#[inline(never)]
|
|
||||||
fn bar() -> Backtrace {
|
|
||||||
baz()
|
|
||||||
}
|
|
||||||
#[inline(always)]
|
|
||||||
fn baz() -> Backtrace {
|
|
||||||
Backtrace::new_unresolved()
|
|
||||||
}
|
|
||||||
|
|
||||||
let mut base_addr = None;
|
|
||||||
TargetSharedLibrary::each(|lib| {
|
|
||||||
base_addr = Some(lib.virtual_memory_bias().0 as isize);
|
|
||||||
IterationControl::Break
|
|
||||||
});
|
|
||||||
let addrfix = -base_addr.unwrap();
|
|
||||||
|
|
||||||
let trace = foo();
|
|
||||||
trace
|
|
||||||
.frames()
|
|
||||||
.iter()
|
|
||||||
.take(5)
|
|
||||||
.map(|x| format!("{:p}", (x.ip() as *const u8).wrapping_offset(addrfix)))
|
|
||||||
.collect()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn run_cmd<P: AsRef<OsStr>>(exe: P, me: &Path, flags: Option<&str>, trace: &str) -> String {
|
|
||||||
let mut cmd = Command::new(exe);
|
|
||||||
cmd.env("LC_ALL", "C"); // GNU addr2line is localized, we aren't
|
|
||||||
cmd.env("RUST_BACKTRACE", "1"); // if a child crashes, we want to know why
|
|
||||||
|
|
||||||
if let Some(flags) = flags {
|
|
||||||
cmd.arg(flags);
|
|
||||||
}
|
|
||||||
cmd.arg("--exe").arg(me).arg(trace);
|
|
||||||
|
|
||||||
let output = cmd.output().unwrap();
|
|
||||||
|
|
||||||
assert!(output.status.success());
|
|
||||||
String::from_utf8(output.stdout).unwrap()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn run_test(flags: Option<&str>) -> Result<(), Failed> {
|
|
||||||
let me = env::current_exe().unwrap();
|
|
||||||
let mut exe = me.clone();
|
|
||||||
assert!(exe.pop());
|
|
||||||
if exe.file_name().unwrap().to_str().unwrap() == "deps" {
|
|
||||||
assert!(exe.pop());
|
|
||||||
}
|
|
||||||
exe.push("addr2line");
|
|
||||||
|
|
||||||
assert!(exe.is_file());
|
|
||||||
|
|
||||||
let trace = make_trace();
|
|
||||||
|
|
||||||
// HACK: GNU addr2line has a bug where looking up multiple addresses can cause the second
|
|
||||||
// lookup to fail. Workaround by doing one address at a time.
|
|
||||||
for addr in &trace {
|
|
||||||
let theirs = run_cmd("addr2line", &me, flags, addr);
|
|
||||||
let ours = run_cmd(&exe, &me, flags, addr);
|
|
||||||
|
|
||||||
// HACK: GNU addr2line does not tidy up paths properly, causing double slashes to be printed.
|
|
||||||
// We consider our behavior to be correct, so we fix their output to match ours.
|
|
||||||
let theirs = theirs.replace("//", "/");
|
|
||||||
|
|
||||||
assert!(
|
|
||||||
theirs == ours,
|
|
||||||
"Output not equivalent:
|
|
||||||
|
|
||||||
$ addr2line {0} --exe {1} {2}
|
|
||||||
{4}
|
|
||||||
$ {3} {0} --exe {1} {2}
|
|
||||||
{5}
|
|
||||||
|
|
||||||
|
|
||||||
",
|
|
||||||
flags.unwrap_or(""),
|
|
||||||
me.display(),
|
|
||||||
trace.join(" "),
|
|
||||||
exe.display(),
|
|
||||||
theirs,
|
|
||||||
ours
|
|
||||||
);
|
|
||||||
}
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
static FLAGS: &str = "aipsf";
|
|
||||||
|
|
||||||
fn make_tests() -> Vec<Trial> {
|
|
||||||
(0..(1 << FLAGS.len()))
|
|
||||||
.map(|bits| {
|
|
||||||
if bits == 0 {
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
let mut param = String::new();
|
|
||||||
param.push('-');
|
|
||||||
for (i, flag) in FLAGS.chars().enumerate() {
|
|
||||||
if (bits & (1 << i)) != 0 {
|
|
||||||
param.push(flag);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Some(param)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.map(|param| {
|
|
||||||
Trial::test(
|
|
||||||
format!("addr2line {}", param.as_deref().unwrap_or_default()),
|
|
||||||
move || run_test(param.as_deref()),
|
|
||||||
)
|
|
||||||
})
|
|
||||||
.collect()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
if !cfg!(target_os = "linux") {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let args = Arguments::from_args();
|
|
||||||
libtest_mimic::run(&args, make_tests()).exit();
|
|
||||||
}
|
|
85
pve-rs/vendor/addr2line/tests/parse.rs
vendored
85
pve-rs/vendor/addr2line/tests/parse.rs
vendored
@ -1,85 +0,0 @@
|
|||||||
use std::borrow::Cow;
|
|
||||||
use std::env;
|
|
||||||
use std::fs::File;
|
|
||||||
use std::path::{self, PathBuf};
|
|
||||||
|
|
||||||
use object::Object;
|
|
||||||
|
|
||||||
fn release_fixture_path() -> PathBuf {
|
|
||||||
if let Ok(p) = env::var("ADDR2LINE_FIXTURE_PATH") {
|
|
||||||
return p.into();
|
|
||||||
}
|
|
||||||
|
|
||||||
let mut path = PathBuf::new();
|
|
||||||
if let Ok(dir) = env::var("CARGO_MANIFEST_DIR") {
|
|
||||||
path.push(dir);
|
|
||||||
}
|
|
||||||
path.push("fixtures");
|
|
||||||
path.push("addr2line-release");
|
|
||||||
path
|
|
||||||
}
|
|
||||||
|
|
||||||
fn with_file<F: FnOnce(&object::File<'_>)>(target: &path::Path, f: F) {
|
|
||||||
let file = File::open(target).unwrap();
|
|
||||||
let map = unsafe { memmap2::Mmap::map(&file).unwrap() };
|
|
||||||
let file = object::File::parse(&*map).unwrap();
|
|
||||||
f(&file)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn dwarf_load<'a>(object: &object::File<'a>) -> gimli::DwarfSections<Cow<'a, [u8]>> {
|
|
||||||
let load_section = |id: gimli::SectionId| -> Result<Cow<'a, [u8]>, gimli::Error> {
|
|
||||||
use object::ObjectSection;
|
|
||||||
|
|
||||||
let data = object
|
|
||||||
.section_by_name(id.name())
|
|
||||||
.and_then(|section| section.data().ok())
|
|
||||||
.unwrap_or(&[][..]);
|
|
||||||
Ok(Cow::Borrowed(data))
|
|
||||||
};
|
|
||||||
gimli::DwarfSections::load(&load_section).unwrap()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn dwarf_borrow<'a>(
|
|
||||||
dwarf: &'a gimli::DwarfSections<Cow<'_, [u8]>>,
|
|
||||||
) -> gimli::Dwarf<gimli::EndianSlice<'a, gimli::LittleEndian>> {
|
|
||||||
let borrow_section: &dyn for<'b> Fn(
|
|
||||||
&'b Cow<'_, [u8]>,
|
|
||||||
) -> gimli::EndianSlice<'b, gimli::LittleEndian> =
|
|
||||||
&|section| gimli::EndianSlice::new(section, gimli::LittleEndian);
|
|
||||||
dwarf.borrow(&borrow_section)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn parse_base() {
|
|
||||||
let target = release_fixture_path();
|
|
||||||
|
|
||||||
with_file(&target, |file| {
|
|
||||||
let dwarf = dwarf_load(file);
|
|
||||||
let dwarf = dwarf_borrow(&dwarf);
|
|
||||||
addr2line::Context::from_dwarf(dwarf).unwrap();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn parse_lines() {
|
|
||||||
let target = release_fixture_path();
|
|
||||||
|
|
||||||
with_file(&target, |file| {
|
|
||||||
let dwarf = dwarf_load(file);
|
|
||||||
let dwarf = dwarf_borrow(&dwarf);
|
|
||||||
let context = addr2line::Context::from_dwarf(dwarf).unwrap();
|
|
||||||
context.parse_lines().unwrap();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn parse_functions() {
|
|
||||||
let target = release_fixture_path();
|
|
||||||
|
|
||||||
with_file(&target, |file| {
|
|
||||||
let dwarf = dwarf_load(file);
|
|
||||||
let dwarf = dwarf_borrow(&dwarf);
|
|
||||||
let context = addr2line::Context::from_dwarf(dwarf).unwrap();
|
|
||||||
context.parse_functions().unwrap();
|
|
||||||
});
|
|
||||||
}
|
|
2
pve-rs/vendor/anyhow/.cargo-checksum.json
vendored
2
pve-rs/vendor/anyhow/.cargo-checksum.json
vendored
@ -1 +1 @@
|
|||||||
{"files":{"Cargo.toml":"50daeb84465695fb01975f29be1529b1c09010d9e6440d0f92034285f00e8203","LICENSE-APACHE":"62c7a1e35f56406896d7aa7ca52d0cc0d272ac022b5d2796e7d6905db8a3636a","LICENSE-MIT":"23f18e03dc49df91622fe2a76176497404e46ced8a715d9d2b67a7446571cca3","README.md":"6e608b9068b4ebab4b85944f047ea386f0288a99c615ac4a32ac45a7da4e5e33","build.rs":"914eb6158687216432aed82e357af5dff2d957d8c7746d075f7a778ba39df146","build/probe.rs":"ee0a4518493c0b3cca121ed2e937b1779eb7e8313a5c4d5fc5aea28ff015366b","rust-toolchain.toml":"6bbb61302978c736b2da03e4fb40e3beab908f85d533ab46fd541e637b5f3e0f","src/backtrace.rs":"578b395a66b21d0e90c503546011138b057f6f27147c51667490da66d22edd54","src/chain.rs":"85af447405f075633fab186b7f1c94d7f33a36474f239c50a961b2d6197d5426","src/context.rs":"1be432c32752778041e8acf0e7d98d4f6291ce53fd7df5bbb0167824bbea57f7","src/ensure.rs":"9763f418b5397764549866c111ec6db3a7bdc4c30ad95c3bbfc56c5434ea8c09","src/error.rs":"cb47593520baa6dc9372bea3d0e8e318f7ec09734f88e7d9d6b9b0c1e17c1507","src/fmt.rs":"adf4be906b29900153bfb4b767a6049d58697dc3bcce7dfbb85ca773f5de5b33","src/kind.rs":"d8cc91e73653049ca0b5593f36aee8632fcc85847b36005b90ecd9a6f0de13cb","src/lib.rs":"8647691e7cf073cb8df0a5c69d55b6adfebf9f2ab93b7c0817621021c0762384","src/macros.rs":"17fb103e68a5befa768857314c3ca4d81d1dacfea0738bbb9c7597a485243499","src/ptr.rs":"4cb31d2f815b178daf951bfb94a1930383e056c0ca68d494603f45d8eea35d50","src/wrapper.rs":"d4e45caee3c2d861d4609a8141310d5c901af59a57d5f0a0de30251347dbd23c","tests/common/mod.rs":"f9088c2d7afafa64ff730b629272045b776bfafc2f5957508242da630635f2e1","tests/compiletest.rs":"4e381aa8ca3eabb7ac14d1e0c3700b3223e47640547a6988cfa13ad68255f60f","tests/drop/mod.rs":"08c3e553c1cc0d2dbd936fc45f4b5b1105057186affd6865e8d261e05f0f0646","tests/test_autotrait.rs":"ecccf9202a33611f64b76598806aa82abec2560ae058e32f63fb2fb3ef225be9","tests/test_backtrace.rs":"60afdd7ee5850dc22625ff486fe41c47fd322db874a93c4871ddfed2bf603930","tests/test_boxed.rs":"6b26db0e2eb72afe9af7352ea820837aab90f8d486294616dd5dc34c1b94038c","tests/test_chain.rs":"3a8a8d7569913bd98c0e27c69d0bda35101e7fde7c056ed57cdd8ed018e4cbcb","tests/test_context.rs":"8409c53b328562c11e822bd6c3cd17e0d4d50b9bbb8fc3617333fd77303a6a33","tests/test_convert.rs":"7e7a8b4772a427a911014ac4d1083f9519000e786177f898808980dd9bdfde61","tests/test_downcast.rs":"797e69a72d125758c4c4897e5dc776d549d52cc9a6a633e0a33193f588a62b88","tests/test_ensure.rs":"4014ead6596793f5eecd55cbaafa49286b75cee7b7092a8b9b8286fcd813a6da","tests/test_ffi.rs":"d0cb4c1d6d9154090982dee72ae3ebe05a5981f976058c3250f1c9da5a45edef","tests/test_fmt.rs":"0e49b48f08e4faaf03e2f202e1efc5250018876c4e1b01b8379d7a38ae8df870","tests/test_macros.rs":"68673942662a43bceee62aaed69c25d7ddbc55e25d62d528e13033c3e2e756cd","tests/test_repr.rs":"034dee888abd08741e11ac2e95ef4fcb2ab3943d0a76e8e976db404658e1a252","tests/test_source.rs":"b80723cf635a4f8c4df21891b34bfab9ed2b2aa407e7a2f826d24e334cd5f88e","tests/ui/chained-comparison.rs":"6504b03d95b5acc232a7f4defc9f343b2be6733bf475fa0992e8e6545b912bd4","tests/ui/chained-comparison.stderr":"7f1d0a8c251b0ede2d30b3087ec157fc660945c97a642c4a5acf5a14ec58de34","tests/ui/empty-ensure.rs":"ab5bf37c846a0d689f26ce9257a27228411ed64154f9c950f1602d88a355d94b","tests/ui/empty-ensure.stderr":"315782f5f4246290fe190e3767b22c3dcaffaabc19c5ace0373537d53e765278","tests/ui/ensure-nonbool.rs":"7e57cb93fbcd82959b36586ed6bd2ad978b051fe5facd5274651fde6b1600905","tests/ui/ensure-nonbool.stderr":"0b4d1611e3bb65081bf38c1e49b1f12e5096738f276608661016e68f1fe13f7c","tests/ui/must-use.rs":"fb59860b43f673bf4a430a6036ba463e95028844d8dd4243cfe5ebc7f2be582f","tests/ui/must-use.stderr":"c2848c5f254b4c061eea6714d9baf709924aba06619eaf2a8b3aee1266b75f9e","tests/ui/no-impl.rs":"fab6cbf2f6ea510b86f567dfb3b7c31250a9fd71ae5d110dbb9188be569ec593","tests/ui/no-impl.stderr":"0d8ed712d25de898eae18cfdffc575a47f4d5596346058cf6cd50d016c4f8ce8","tests/ui/temporary-value.rs":"4dcc96271b2403e6372cf4cfc813445e5ce4365fc6e156b6bc38274098499a70","tests/ui/temporary-value.stderr":"171f6c1c962503855480696e5d39e68946ec2a027b61a6f36ca1ad1b40265c5d","tests/ui/wrong-interpolation.rs":"9c44d4674c2dccd27b9dedd03341346ec02d993b41793ee89b5755202e7e367e","tests/ui/wrong-interpolation.stderr":"301e60e2eb9401782c7dc0b3580613a4cb2aafd4cc8065734a630a62e1161aa5"},"package":"10f00e1f6e58a40e807377c75c6a7f97bf9044fab57816f2414e6f5f4499d7b8"}
|
{"files":{"Cargo.toml":"b9c67d404778b8bc5bbd695cd3afb809a9c7cc4655be31efa5d809c1b0e1a5a8","LICENSE-APACHE":"62c7a1e35f56406896d7aa7ca52d0cc0d272ac022b5d2796e7d6905db8a3636a","LICENSE-MIT":"23f18e03dc49df91622fe2a76176497404e46ced8a715d9d2b67a7446571cca3","README.md":"136d2b44cc4060192516f18e43ec3eafb65693c1819a80a867e7a00c60a45ee6","build.rs":"27bcb3380f8b9b52a12d1aedad324858a94de974f17efa86ff93aa7e556b3798","build/probe.rs":"ee0a4518493c0b3cca121ed2e937b1779eb7e8313a5c4d5fc5aea28ff015366b","rust-toolchain.toml":"6bbb61302978c736b2da03e4fb40e3beab908f85d533ab46fd541e637b5f3e0f","src/backtrace.rs":"bbaa0e0e228475c9c9532786e305cf04f53729f386c48adb1d93bb8ce07f37ad","src/chain.rs":"85af447405f075633fab186b7f1c94d7f33a36474f239c50a961b2d6197d5426","src/context.rs":"1be432c32752778041e8acf0e7d98d4f6291ce53fd7df5bbb0167824bbea57f7","src/ensure.rs":"9763f418b5397764549866c111ec6db3a7bdc4c30ad95c3bbfc56c5434ea8c09","src/error.rs":"274c175ec92f4aa8bf479d39cf3023d1ead9865a242a0a63ad3998aea57219a6","src/fmt.rs":"adf4be906b29900153bfb4b767a6049d58697dc3bcce7dfbb85ca773f5de5b33","src/kind.rs":"d8cc91e73653049ca0b5593f36aee8632fcc85847b36005b90ecd9a6f0de13cb","src/lib.rs":"0534dd480fff1f6fa19e3e202dcd981047597eeb693406d0a7bc6f795cb4faf0","src/macros.rs":"875797636fde708dcb9c82e0cb3107cf38334086274aaada267fb5bfd60547a9","src/ptr.rs":"4cb31d2f815b178daf951bfb94a1930383e056c0ca68d494603f45d8eea35d50","src/wrapper.rs":"d4e45caee3c2d861d4609a8141310d5c901af59a57d5f0a0de30251347dbd23c","tests/common/mod.rs":"f9088c2d7afafa64ff730b629272045b776bfafc2f5957508242da630635f2e1","tests/compiletest.rs":"4e381aa8ca3eabb7ac14d1e0c3700b3223e47640547a6988cfa13ad68255f60f","tests/drop/mod.rs":"08c3e553c1cc0d2dbd936fc45f4b5b1105057186affd6865e8d261e05f0f0646","tests/test_autotrait.rs":"ba9bc18416115cb48fd08675a3e7fc89584de7926dad6b2be6645dc13d5931df","tests/test_backtrace.rs":"60afdd7ee5850dc22625ff486fe41c47fd322db874a93c4871ddfed2bf603930","tests/test_boxed.rs":"6b26db0e2eb72afe9af7352ea820837aab90f8d486294616dd5dc34c1b94038c","tests/test_chain.rs":"3a8a8d7569913bd98c0e27c69d0bda35101e7fde7c056ed57cdd8ed018e4cbcb","tests/test_context.rs":"8409c53b328562c11e822bd6c3cd17e0d4d50b9bbb8fc3617333fd77303a6a33","tests/test_convert.rs":"7e7a8b4772a427a911014ac4d1083f9519000e786177f898808980dd9bdfde61","tests/test_downcast.rs":"797e69a72d125758c4c4897e5dc776d549d52cc9a6a633e0a33193f588a62b88","tests/test_ensure.rs":"4014ead6596793f5eecd55cbaafa49286b75cee7b7092a8b9b8286fcd813a6da","tests/test_ffi.rs":"d0cb4c1d6d9154090982dee72ae3ebe05a5981f976058c3250f1c9da5a45edef","tests/test_fmt.rs":"0e49b48f08e4faaf03e2f202e1efc5250018876c4e1b01b8379d7a38ae8df870","tests/test_macros.rs":"68673942662a43bceee62aaed69c25d7ddbc55e25d62d528e13033c3e2e756cd","tests/test_repr.rs":"034dee888abd08741e11ac2e95ef4fcb2ab3943d0a76e8e976db404658e1a252","tests/test_source.rs":"b80723cf635a4f8c4df21891b34bfab9ed2b2aa407e7a2f826d24e334cd5f88e","tests/ui/chained-comparison.rs":"6504b03d95b5acc232a7f4defc9f343b2be6733bf475fa0992e8e6545b912bd4","tests/ui/chained-comparison.stderr":"7f1d0a8c251b0ede2d30b3087ec157fc660945c97a642c4a5acf5a14ec58de34","tests/ui/empty-ensure.rs":"ab5bf37c846a0d689f26ce9257a27228411ed64154f9c950f1602d88a355d94b","tests/ui/empty-ensure.stderr":"315782f5f4246290fe190e3767b22c3dcaffaabc19c5ace0373537d53e765278","tests/ui/ensure-nonbool.rs":"7e57cb93fbcd82959b36586ed6bd2ad978b051fe5facd5274651fde6b1600905","tests/ui/ensure-nonbool.stderr":"0b4d1611e3bb65081bf38c1e49b1f12e5096738f276608661016e68f1fe13f7c","tests/ui/must-use.rs":"fb59860b43f673bf4a430a6036ba463e95028844d8dd4243cfe5ebc7f2be582f","tests/ui/must-use.stderr":"c2848c5f254b4c061eea6714d9baf709924aba06619eaf2a8b3aee1266b75f9e","tests/ui/no-impl.rs":"fab6cbf2f6ea510b86f567dfb3b7c31250a9fd71ae5d110dbb9188be569ec593","tests/ui/no-impl.stderr":"0d8ed712d25de898eae18cfdffc575a47f4d5596346058cf6cd50d016c4f8ce8","tests/ui/temporary-value.rs":"4dcc96271b2403e6372cf4cfc813445e5ce4365fc6e156b6bc38274098499a70","tests/ui/temporary-value.stderr":"171f6c1c962503855480696e5d39e68946ec2a027b61a6f36ca1ad1b40265c5d","tests/ui/wrong-interpolation.rs":"9c44d4674c2dccd27b9dedd03341346ec02d993b41793ee89b5755202e7e367e","tests/ui/wrong-interpolation.stderr":"301e60e2eb9401782c7dc0b3580613a4cb2aafd4cc8065734a630a62e1161aa5"},"package":"c042108f3ed77fd83760a5fd79b53be043192bb3b9dba91d8c574c0ada7850c8"}
|
3
pve-rs/vendor/anyhow/Cargo.toml
vendored
3
pve-rs/vendor/anyhow/Cargo.toml
vendored
@ -13,9 +13,10 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.39"
|
rust-version = "1.39"
|
||||||
name = "anyhow"
|
name = "anyhow"
|
||||||
version = "1.0.87"
|
version = "1.0.91"
|
||||||
authors = ["David Tolnay <dtolnay@gmail.com>"]
|
authors = ["David Tolnay <dtolnay@gmail.com>"]
|
||||||
build = "build.rs"
|
build = "build.rs"
|
||||||
|
autolib = false
|
||||||
autobins = false
|
autobins = false
|
||||||
autoexamples = false
|
autoexamples = false
|
||||||
autotests = false
|
autotests = false
|
||||||
|
8
pve-rs/vendor/anyhow/README.md
vendored
8
pve-rs/vendor/anyhow/README.md
vendored
@ -136,10 +136,10 @@ Cargo.toml. A global allocator is required.
|
|||||||
anyhow = { version = "1.0", default-features = false }
|
anyhow = { version = "1.0", default-features = false }
|
||||||
```
|
```
|
||||||
|
|
||||||
Since the `?`-based error conversions would normally rely on the
|
With versions of Rust older than 1.81, no_std mode may require an additional
|
||||||
`std::error::Error` trait which is only available through std, no_std mode will
|
`.map_err(Error::msg)` when working with a non-Anyhow error type inside a
|
||||||
require an explicit `.map_err(Error::msg)` when working with a non-Anyhow error
|
function that returns Anyhow's error type, as the trait that `?`-based error
|
||||||
type inside a function that returns Anyhow's error type.
|
conversions are defined by is only available in std in those old versions.
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
|
|
||||||
|
33
pve-rs/vendor/anyhow/build.rs
vendored
33
pve-rs/vendor/anyhow/build.rs
vendored
@ -1,5 +1,7 @@
|
|||||||
use std::env;
|
use std::env;
|
||||||
use std::ffi::OsString;
|
use std::ffi::OsString;
|
||||||
|
use std::fs;
|
||||||
|
use std::io::ErrorKind;
|
||||||
use std::iter;
|
use std::iter;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
use std::process::{self, Command, Stdio};
|
use std::process::{self, Command, Stdio};
|
||||||
@ -68,6 +70,7 @@ fn main() {
|
|||||||
if rustc >= 80 {
|
if rustc >= 80 {
|
||||||
println!("cargo:rustc-check-cfg=cfg(anyhow_nightly_testing)");
|
println!("cargo:rustc-check-cfg=cfg(anyhow_nightly_testing)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(anyhow_no_core_error)");
|
println!("cargo:rustc-check-cfg=cfg(anyhow_no_core_error)");
|
||||||
|
println!("cargo:rustc-check-cfg=cfg(anyhow_no_core_unwind_safe)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(anyhow_no_fmt_arguments_as_str)");
|
println!("cargo:rustc-check-cfg=cfg(anyhow_no_fmt_arguments_as_str)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(anyhow_no_ptr_addr_of)");
|
println!("cargo:rustc-check-cfg=cfg(anyhow_no_ptr_addr_of)");
|
||||||
println!("cargo:rustc-check-cfg=cfg(anyhow_no_unsafe_op_in_unsafe_fn_lint)");
|
println!("cargo:rustc-check-cfg=cfg(anyhow_no_unsafe_op_in_unsafe_fn_lint)");
|
||||||
@ -91,6 +94,12 @@ fn main() {
|
|||||||
println!("cargo:rustc-cfg=anyhow_no_unsafe_op_in_unsafe_fn_lint");
|
println!("cargo:rustc-cfg=anyhow_no_unsafe_op_in_unsafe_fn_lint");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if rustc < 56 {
|
||||||
|
// core::panic::{UnwindSafe, RefUnwindSafe}
|
||||||
|
// https://blog.rust-lang.org/2021/10/21/Rust-1.56.0.html#stabilized-apis
|
||||||
|
println!("cargo:rustc-cfg=anyhow_no_core_unwind_safe");
|
||||||
|
}
|
||||||
|
|
||||||
if !error_generic_member_access && cfg!(feature = "std") && rustc >= 65 {
|
if !error_generic_member_access && cfg!(feature = "std") && rustc >= 65 {
|
||||||
// std::backtrace::Backtrace
|
// std::backtrace::Backtrace
|
||||||
// https://blog.rust-lang.org/2022/11/03/Rust-1.65.0.html#stabilized-apis
|
// https://blog.rust-lang.org/2022/11/03/Rust-1.65.0.html#stabilized-apis
|
||||||
@ -118,8 +127,16 @@ fn compile_probe(rustc_bootstrap: bool) -> bool {
|
|||||||
|
|
||||||
let rustc = cargo_env_var("RUSTC");
|
let rustc = cargo_env_var("RUSTC");
|
||||||
let out_dir = cargo_env_var("OUT_DIR");
|
let out_dir = cargo_env_var("OUT_DIR");
|
||||||
|
let out_subdir = Path::new(&out_dir).join("probe");
|
||||||
let probefile = Path::new("build").join("probe.rs");
|
let probefile = Path::new("build").join("probe.rs");
|
||||||
|
|
||||||
|
if let Err(err) = fs::create_dir(&out_subdir) {
|
||||||
|
if err.kind() != ErrorKind::AlreadyExists {
|
||||||
|
eprintln!("Failed to create {}: {}", out_subdir.display(), err);
|
||||||
|
process::exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let rustc_wrapper = env::var_os("RUSTC_WRAPPER").filter(|wrapper| !wrapper.is_empty());
|
let rustc_wrapper = env::var_os("RUSTC_WRAPPER").filter(|wrapper| !wrapper.is_empty());
|
||||||
let rustc_workspace_wrapper =
|
let rustc_workspace_wrapper =
|
||||||
env::var_os("RUSTC_WORKSPACE_WRAPPER").filter(|wrapper| !wrapper.is_empty());
|
env::var_os("RUSTC_WORKSPACE_WRAPPER").filter(|wrapper| !wrapper.is_empty());
|
||||||
@ -141,7 +158,7 @@ fn compile_probe(rustc_bootstrap: bool) -> bool {
|
|||||||
.arg("--emit=dep-info,metadata")
|
.arg("--emit=dep-info,metadata")
|
||||||
.arg("--cap-lints=allow")
|
.arg("--cap-lints=allow")
|
||||||
.arg("--out-dir")
|
.arg("--out-dir")
|
||||||
.arg(out_dir)
|
.arg(&out_subdir)
|
||||||
.arg(probefile);
|
.arg(probefile);
|
||||||
|
|
||||||
if let Some(target) = env::var_os("TARGET") {
|
if let Some(target) = env::var_os("TARGET") {
|
||||||
@ -157,10 +174,22 @@ fn compile_probe(rustc_bootstrap: bool) -> bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
match cmd.status() {
|
let success = match cmd.status() {
|
||||||
Ok(status) => status.success(),
|
Ok(status) => status.success(),
|
||||||
Err(_) => false,
|
Err(_) => false,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Clean up to avoid leaving nondeterministic absolute paths in the dep-info
|
||||||
|
// file in OUT_DIR, which causes nonreproducible builds in build systems
|
||||||
|
// that treat the entire OUT_DIR as an artifact.
|
||||||
|
if let Err(err) = fs::remove_dir_all(&out_subdir) {
|
||||||
|
if err.kind() != ErrorKind::NotFound {
|
||||||
|
eprintln!("Failed to clean up {}: {}", out_subdir.display(), err);
|
||||||
|
process::exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
success
|
||||||
}
|
}
|
||||||
|
|
||||||
fn rustc_minor_version() -> Option<u32> {
|
fn rustc_minor_version() -> Option<u32> {
|
||||||
|
4
pve-rs/vendor/anyhow/src/backtrace.rs
vendored
4
pve-rs/vendor/anyhow/src/backtrace.rs
vendored
@ -406,6 +406,6 @@ mod capture {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn _assert_send_sync() {
|
fn _assert_send_sync() {
|
||||||
fn _assert<T: Send + Sync>() {}
|
fn assert<T: Send + Sync>() {}
|
||||||
_assert::<Backtrace>();
|
assert::<Backtrace>();
|
||||||
}
|
}
|
||||||
|
10
pve-rs/vendor/anyhow/src/error.rs
vendored
10
pve-rs/vendor/anyhow/src/error.rs
vendored
@ -12,9 +12,13 @@ use core::fmt::{self, Debug, Display};
|
|||||||
use core::mem::ManuallyDrop;
|
use core::mem::ManuallyDrop;
|
||||||
#[cfg(any(feature = "std", not(anyhow_no_core_error)))]
|
#[cfg(any(feature = "std", not(anyhow_no_core_error)))]
|
||||||
use core::ops::{Deref, DerefMut};
|
use core::ops::{Deref, DerefMut};
|
||||||
|
#[cfg(not(anyhow_no_core_unwind_safe))]
|
||||||
|
use core::panic::{RefUnwindSafe, UnwindSafe};
|
||||||
#[cfg(not(anyhow_no_ptr_addr_of))]
|
#[cfg(not(anyhow_no_ptr_addr_of))]
|
||||||
use core::ptr;
|
use core::ptr;
|
||||||
use core::ptr::NonNull;
|
use core::ptr::NonNull;
|
||||||
|
#[cfg(all(feature = "std", anyhow_no_core_unwind_safe))]
|
||||||
|
use std::panic::{RefUnwindSafe, UnwindSafe};
|
||||||
|
|
||||||
impl Error {
|
impl Error {
|
||||||
/// Create a new error object from any error type.
|
/// Create a new error object from any error type.
|
||||||
@ -1015,3 +1019,9 @@ impl AsRef<dyn StdError> for Error {
|
|||||||
&**self
|
&**self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(any(feature = "std", not(anyhow_no_core_unwind_safe)))]
|
||||||
|
impl UnwindSafe for Error {}
|
||||||
|
|
||||||
|
#[cfg(any(feature = "std", not(anyhow_no_core_unwind_safe)))]
|
||||||
|
impl RefUnwindSafe for Error {}
|
||||||
|
11
pve-rs/vendor/anyhow/src/lib.rs
vendored
11
pve-rs/vendor/anyhow/src/lib.rs
vendored
@ -201,12 +201,12 @@
|
|||||||
//! anyhow = { version = "1.0", default-features = false }
|
//! anyhow = { version = "1.0", default-features = false }
|
||||||
//! ```
|
//! ```
|
||||||
//!
|
//!
|
||||||
//! Since the `?`-based error conversions would normally rely on the
|
//! With versions of Rust older than 1.81, no_std mode may require an additional
|
||||||
//! `std::error::Error` trait which is only available through std, no_std mode
|
//! `.map_err(Error::msg)` when working with a non-Anyhow error type inside a
|
||||||
//! will require an explicit `.map_err(Error::msg)` when working with a
|
//! function that returns Anyhow's error type, as the trait that `?`-based error
|
||||||
//! non-Anyhow error type inside a function that returns Anyhow's error type.
|
//! conversions are defined by is only available in std in those old versions.
|
||||||
|
|
||||||
#![doc(html_root_url = "https://docs.rs/anyhow/1.0.87")]
|
#![doc(html_root_url = "https://docs.rs/anyhow/1.0.91")]
|
||||||
#![cfg_attr(error_generic_member_access, feature(error_generic_member_access))]
|
#![cfg_attr(error_generic_member_access, feature(error_generic_member_access))]
|
||||||
#![no_std]
|
#![no_std]
|
||||||
#![deny(dead_code, unused_imports, unused_mut)]
|
#![deny(dead_code, unused_imports, unused_mut)]
|
||||||
@ -227,6 +227,7 @@
|
|||||||
clippy::module_name_repetitions,
|
clippy::module_name_repetitions,
|
||||||
clippy::must_use_candidate,
|
clippy::must_use_candidate,
|
||||||
clippy::needless_doctest_main,
|
clippy::needless_doctest_main,
|
||||||
|
clippy::needless_lifetimes,
|
||||||
clippy::new_ret_no_self,
|
clippy::new_ret_no_self,
|
||||||
clippy::redundant_else,
|
clippy::redundant_else,
|
||||||
clippy::return_self_not_must_use,
|
clippy::return_self_not_must_use,
|
||||||
|
11
pve-rs/vendor/anyhow/src/macros.rs
vendored
11
pve-rs/vendor/anyhow/src/macros.rs
vendored
@ -1,9 +1,10 @@
|
|||||||
/// Return early with an error.
|
/// Return early with an error.
|
||||||
///
|
///
|
||||||
/// This macro is equivalent to `return Err(`[`anyhow!($args...)`][anyhow!]`)`.
|
/// This macro is equivalent to
|
||||||
|
/// <code>return Err([anyhow!($args\...)][anyhow!])</code>.
|
||||||
///
|
///
|
||||||
/// The surrounding function's or closure's return value is required to be
|
/// The surrounding function's or closure's return value is required to be
|
||||||
/// `Result<_,`[`anyhow::Error`][crate::Error]`>`.
|
/// <code>Result<_, [anyhow::Error][crate::Error]></code>.
|
||||||
///
|
///
|
||||||
/// [anyhow!]: crate::anyhow
|
/// [anyhow!]: crate::anyhow
|
||||||
///
|
///
|
||||||
@ -69,11 +70,11 @@ macro_rules! __ensure {
|
|||||||
($ensure:item) => {
|
($ensure:item) => {
|
||||||
/// Return early with an error if a condition is not satisfied.
|
/// Return early with an error if a condition is not satisfied.
|
||||||
///
|
///
|
||||||
/// This macro is equivalent to `if !$cond { return
|
/// This macro is equivalent to
|
||||||
/// Err(`[`anyhow!($args...)`][anyhow!]`); }`.
|
/// <code>if !$cond { return Err([anyhow!($args\...)][anyhow!]); }</code>.
|
||||||
///
|
///
|
||||||
/// The surrounding function's or closure's return value is required to be
|
/// The surrounding function's or closure's return value is required to be
|
||||||
/// `Result<_,`[`anyhow::Error`][crate::Error]`>`.
|
/// <code>Result<_, [anyhow::Error][crate::Error]></code>.
|
||||||
///
|
///
|
||||||
/// Analogously to `assert!`, `ensure!` takes a condition and exits the function
|
/// Analogously to `assert!`, `ensure!` takes a condition and exits the function
|
||||||
/// if the condition fails. Unlike `assert!`, `ensure!` returns an `Error`
|
/// if the condition fails. Unlike `assert!`, `ensure!` returns an `Error`
|
||||||
|
19
pve-rs/vendor/anyhow/tests/test_autotrait.rs
vendored
19
pve-rs/vendor/anyhow/tests/test_autotrait.rs
vendored
@ -1,6 +1,7 @@
|
|||||||
#![allow(clippy::extra_unused_type_parameters)]
|
#![allow(clippy::extra_unused_type_parameters)]
|
||||||
|
|
||||||
use anyhow::Error;
|
use anyhow::Error;
|
||||||
|
use std::panic::{RefUnwindSafe, UnwindSafe};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_send() {
|
fn test_send() {
|
||||||
@ -13,3 +14,21 @@ fn test_sync() {
|
|||||||
fn assert_sync<T: Sync>() {}
|
fn assert_sync<T: Sync>() {}
|
||||||
assert_sync::<Error>();
|
assert_sync::<Error>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_unwind_safe() {
|
||||||
|
fn assert_unwind_safe<T: UnwindSafe>() {}
|
||||||
|
assert_unwind_safe::<Error>();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_ref_unwind_safe() {
|
||||||
|
fn assert_ref_unwind_safe<T: RefUnwindSafe>() {}
|
||||||
|
assert_ref_unwind_safe::<Error>();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_unpin() {
|
||||||
|
fn assert_unpin<T: Unpin>() {}
|
||||||
|
assert_unpin::<Error>();
|
||||||
|
}
|
||||||
|
1
pve-rs/vendor/apt-pkg-native/.cargo-checksum.json
vendored
Normal file
1
pve-rs/vendor/apt-pkg-native/.cargo-checksum.json
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
{"files":{".cargo/config.toml":"77e9219c27274120197571fd165cbe4121963b5ad3bc0b20b383c86ef0ce6c2b",".gear/apt-pkg-native.spec":"f51204bd4903cc45b54c2066cc3b4775317460627182fd3180323f48ffe3aec4",".gear/rules":"25289e6d0b29990912683a33fa413644f829ff93fd77f8d982651c5cad1a7e3e",".gear/upstream/remotes":"be2df2cc7562819711aaac7d934e0c908096271d1c4175ecbc0a86eeabf5195b",".travis.yml":"c3fdf6173e81b6bf7e1b0399a1767ef55ea9867d0c86b12c3d91f6e717a8d1db","Cargo.lock":"f4c20f001b8884426eadb198b99556bbd62e3a0da8fb40d46444b5e988866113","Cargo.toml":"f25eb040338f607a7fee7b3eaedbea965491d17c50606bdcb3ceb6b684813dd0","LICENSE.MIT":"54e17baced243561c869877e68c2ac8736f17a2c1266062ad9fb1ebf3ed1967c","README.md":"d44dc795397fe707f6cc605d1f801c1cb8490e804861f1ac938945eb6f294cd3","apt-pkg-c/.gitignore":"659109c3f137e0b4f610d98f017adf80a01551689187a6778dc8fa0d54ea26a4","apt-pkg-c/Makefile":"a8472bde3198669e9af22dd1bfc187baa30a3b2b25490ef6ff3185ec3c0d1fc0","apt-pkg-c/lib.cpp":"baeae62600f975c1294c2d68f157e871c329f2c7d8534409f7f39e8100e71f21","build.rs":"e4cf0afcb5cf6887ea1d971eb3de9224d4186cb58ffff4f9592c4f4d73362946","examples/epochs.rs":"be32926cbad6eede80f7530178bb827eb02c958f6be82b30f5c6f5f21dc399d1","examples/list.rs":"0c20b92819ec94291a36a3805315ec52a2777147b211be0962c287127fbe515c","examples/on-sid/.dockerignore":"25ca4d0088686695559d7c5c7666166a6cb731b76fff8ebb1b90d598325c107c","examples/on-sid/Dockerfile":"dbc6cc6a7cb82854662308e27a7fced5256e4aac4b672bc5e307b55bf357e380","examples/on-sid/Makefile":"12353f6701bf4b685a60a9000021bbb41ff536843deb056810d52e33d00bfa12","examples/on-sid/sources.list":"050b38c58e546cd9c98ea4731cf58317b5611c734d372814f92b905a7c7767a0","examples/on-trusty/.dockerignore":"25ca4d0088686695559d7c5c7666166a6cb731b76fff8ebb1b90d598325c107c","examples/on-trusty/Dockerfile":"12f2231aa631687c868534ad8b0fb80b8ef1225791515ec44391e7e512f34d84","examples/on-trusty/Makefile":"5db72b4ffff06c351a81626d8b93e5d3cf222840b7a38cf927ccbecc57bd21aa","examples/on-trusty/uprust.sh":"22aa1f7f4c4b9be99a9d7e13ad45b2aec6714165a0578dd5ef81ca11f55ea24e","examples/policy.rs":"c7afd85c85e79acb2d5d10c362992a48a982f68222d724d11422ca90df2a09fe","examples/sources.rs":"9fb1f5bf21679a77b2c985945543da8ed748e786a9977a1d755be68b2f82b16f","src/citer.rs":"e03662241b7da607171a48870e97939d7c8309bc4a4d7c33697a851d8cc12178","src/lib.rs":"3fcd694e85be9d770baa2a92e02befc4f62a610044d55200fb441806286b9a68","src/raw.rs":"5c0060d052062885f9f7142e1b0274411199aa28696d5078a54ed23c23504606","src/sane.rs":"5e96611ee81f8cd02f20b8254a58f0dc4096f8e01c7b49b387e39b93ba15898f","src/simple.rs":"177994ecd9e106345c4efebe1ec38bb521a970332f12da9d9eda4b3563af5e2b"},"package":null}
|
5
pve-rs/vendor/apt-pkg-native/.cargo/config.toml
vendored
Normal file
5
pve-rs/vendor/apt-pkg-native/.cargo/config.toml
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[source.crates-io]
|
||||||
|
replace-with = "vendored-sources"
|
||||||
|
|
||||||
|
[source.vendored-sources]
|
||||||
|
directory = "vendor"
|
41
pve-rs/vendor/apt-pkg-native/.gear/apt-pkg-native.spec
vendored
Normal file
41
pve-rs/vendor/apt-pkg-native/.gear/apt-pkg-native.spec
vendored
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
%define bin_name lib%name
|
||||||
|
Name: apt-pkg-native
|
||||||
|
Version: 0.3.2
|
||||||
|
Release: alt1
|
||||||
|
|
||||||
|
Summary: Rust bindings for libapt-pkg
|
||||||
|
License: MIT
|
||||||
|
Group: Development/Tools
|
||||||
|
Url: https://github.com/FauxFaux/apt-pkg-native-rs
|
||||||
|
|
||||||
|
Source: %name-%version.tar
|
||||||
|
|
||||||
|
BuildRequires(pre): rpm-build-rust
|
||||||
|
BuildRequires: /proc
|
||||||
|
BuildRequires: rust-cargo
|
||||||
|
BuildRequires: gcc-c++
|
||||||
|
BuildRequires: libapt-devel
|
||||||
|
|
||||||
|
%description
|
||||||
|
This crate provides bindings to libapt-pkg.
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup
|
||||||
|
|
||||||
|
%build
|
||||||
|
%rust_build --features alt-linux
|
||||||
|
# --features ye-olde-apt
|
||||||
|
|
||||||
|
%install
|
||||||
|
%rust_install %bin_name
|
||||||
|
|
||||||
|
%check
|
||||||
|
%rust_test
|
||||||
|
|
||||||
|
%files
|
||||||
|
%_bindir/*
|
||||||
|
%doc LICENSE-MIT README.md
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Mon Jun 19 2023 Alexander Burmatov <thatman@altlinux.org> 0.3.2-alt1
|
||||||
|
- Initial build for Sisyphus.
|
2
pve-rs/vendor/apt-pkg-native/.gear/rules
vendored
Normal file
2
pve-rs/vendor/apt-pkg-native/.gear/rules
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
spec: .gear/apt-pkg-native.spec
|
||||||
|
tar: .
|
3
pve-rs/vendor/apt-pkg-native/.gear/upstream/remotes
vendored
Normal file
3
pve-rs/vendor/apt-pkg-native/.gear/upstream/remotes
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[remote "upstream"]
|
||||||
|
url = git@github.com:FauxFaux/apt-pkg-native-rs.git
|
||||||
|
fetch = +refs/heads/*:refs/remotes/upstream/*
|
18
pve-rs/vendor/apt-pkg-native/.travis.yml
vendored
Normal file
18
pve-rs/vendor/apt-pkg-native/.travis.yml
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
language: rust
|
||||||
|
rust:
|
||||||
|
- nightly
|
||||||
|
- beta
|
||||||
|
- stable
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
allow_failures:
|
||||||
|
- rust: nightly
|
||||||
|
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- build-essential
|
||||||
|
- libapt-pkg-dev
|
||||||
|
|
||||||
|
dist: bionic
|
||||||
|
sudo: false
|
68
pve-rs/vendor/apt-pkg-native/Cargo.toml
vendored
Normal file
68
pve-rs/vendor/apt-pkg-native/Cargo.toml
vendored
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO
|
||||||
|
#
|
||||||
|
# When uploading crates to the registry Cargo will automatically
|
||||||
|
# "normalize" Cargo.toml files for maximal compatibility
|
||||||
|
# with all versions of Cargo and also rewrite `path` dependencies
|
||||||
|
# to registry (e.g., crates.io) dependencies.
|
||||||
|
#
|
||||||
|
# If you are reading this file be aware that the original Cargo.toml
|
||||||
|
# will likely look very different (and much more reasonable).
|
||||||
|
# See Cargo.toml.orig for the original contents.
|
||||||
|
|
||||||
|
[package]
|
||||||
|
edition = "2018"
|
||||||
|
name = "apt-pkg-native"
|
||||||
|
version = "0.3.2"
|
||||||
|
authors = ["Chris West (Faux) <git@goeswhere.com>"]
|
||||||
|
build = "build.rs"
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
|
description = "Bindings for libapt-pkg"
|
||||||
|
readme = "README.md"
|
||||||
|
categories = [
|
||||||
|
"api-bindings",
|
||||||
|
"os",
|
||||||
|
]
|
||||||
|
license = "MIT"
|
||||||
|
repository = "https://github.com/FauxFaux/apt-pkg-native-rs"
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "apt_pkg_native"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "epochs"
|
||||||
|
path = "examples/epochs.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "list"
|
||||||
|
path = "examples/list.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "policy"
|
||||||
|
path = "examples/policy.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "sources"
|
||||||
|
path = "examples/sources.rs"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
lazy_static = "1"
|
||||||
|
libc = "0.2"
|
||||||
|
|
||||||
|
[dev-dependencies]
|
||||||
|
boolinator = "2"
|
||||||
|
itertools = "0.9"
|
||||||
|
|
||||||
|
[build-dependencies]
|
||||||
|
cc = "1.0"
|
||||||
|
|
||||||
|
[features]
|
||||||
|
alt-linux = []
|
||||||
|
default = []
|
||||||
|
ye-olde-apt = []
|
||||||
|
|
||||||
|
[badges.travis-ci]
|
||||||
|
repository = "FauxFaux/apt-pkg-native-rs"
|
21
pve-rs/vendor/apt-pkg-native/LICENSE.MIT
vendored
Normal file
21
pve-rs/vendor/apt-pkg-native/LICENSE.MIT
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) 2017 Chris West
|
||||||
|
|
||||||
|
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.
|
62
pve-rs/vendor/apt-pkg-native/README.md
vendored
Normal file
62
pve-rs/vendor/apt-pkg-native/README.md
vendored
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
This crate provides bindings to `libapt-pkg`.
|
||||||
|
|
||||||
|
[![Build status](https://api.travis-ci.org/FauxFaux/apt-pkg-native-rs.png)](https://travis-ci.org/FauxFaux/apt-pkg-native-rs)
|
||||||
|
[![](http://meritbadge.herokuapp.com/apt-pkg-native)](https://crates.io/crates/apt-pkg-native)
|
||||||
|
|
||||||
|
|
||||||
|
### Documentation and Examples
|
||||||
|
|
||||||
|
See the `examples/` folder for some partial implementations of some commands.
|
||||||
|
|
||||||
|
https://docs.rs/apt-pkg-native
|
||||||
|
|
||||||
|
### License Note
|
||||||
|
|
||||||
|
While the code in this crate is available under a permissive MIT license,
|
||||||
|
it is useless without [`libapt-pkg`](https://tracker.debian.org/pkg/apt),
|
||||||
|
which is GPL2+.
|
||||||
|
|
||||||
|
### Building
|
||||||
|
|
||||||
|
`libapt-pkg-dev` must be installed. The [`cc`](https://crates.io/crates/cc)
|
||||||
|
crate is used to try and find a native compiler.
|
||||||
|
|
||||||
|
The `ye-olde-apt` feature provides support for `apt <1.2` (Ubuntu 14.04 (Trusty),
|
||||||
|
Debian 7 (Jessie) (2015)). This works by just deleting methods which are not
|
||||||
|
available in that version. See
|
||||||
|
[#2](https://github.com/FauxFaux/apt-pkg-native-rs/issues/2#issuecomment-351180818).
|
||||||
|
|
||||||
|
|
||||||
|
### Thread safety
|
||||||
|
|
||||||
|
It is intended that the crate should be usable from multiple threads.
|
||||||
|
However, this is generally implemented using singletons, which may be really
|
||||||
|
annoying for your use-case.
|
||||||
|
|
||||||
|
The current way the singleton is managed is awful, and it's not been fixed
|
||||||
|
while I've been learning about the problems. A major version bump, and a
|
||||||
|
proper singleton, may resolve some of the issues. This needs to be done eventually.
|
||||||
|
|
||||||
|
`apt` does not have a concurrency model: you may not use threads.
|
||||||
|
|
||||||
|
Since `apt` 1.4 or 1.5 (in Debian Stretch (2017), but not in Xenial 16.04),
|
||||||
|
some operations are thread safe: it should be possible to initialise the cache
|
||||||
|
twice in parallel. As these versions of `apt` are not widespread, the API of
|
||||||
|
this crate does not attempt to expose this.
|
||||||
|
|
||||||
|
|
||||||
|
### Alternatives
|
||||||
|
|
||||||
|
There is a similar project at [rust-apt](https://crates.io/crates/rust-apt).
|
||||||
|
|
||||||
|
|
||||||
|
### Switching distro with `docker`
|
||||||
|
|
||||||
|
`examples/on-sid` has a docker file which builds a minimum Debian image with
|
||||||
|
typical package lists downloaded. You can run a tool in it, from this directory,
|
||||||
|
by:
|
||||||
|
|
||||||
|
```
|
||||||
|
(cd examples/on-sid && make)
|
||||||
|
docker run -v $(pwd):/mnt sid-sources-list /mnt/target/release/examples/sources
|
||||||
|
```
|
1
pve-rs/vendor/apt-pkg-native/apt-pkg-c/.gitignore
vendored
Normal file
1
pve-rs/vendor/apt-pkg-native/apt-pkg-c/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
lib.o
|
10
pve-rs/vendor/apt-pkg-native/apt-pkg-c/Makefile
vendored
Normal file
10
pve-rs/vendor/apt-pkg-native/apt-pkg-c/Makefile
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
CXXFLAGS=-Wall -Wextra -g
|
||||||
|
|
||||||
|
all: clean check
|
||||||
|
|
||||||
|
check: lib.o
|
||||||
|
|
||||||
|
lib.o: lib.cpp
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(RM) lib.o
|
671
pve-rs/vendor/apt-pkg-native/apt-pkg-c/lib.cpp
vendored
Normal file
671
pve-rs/vendor/apt-pkg-native/apt-pkg-c/lib.cpp
vendored
Normal file
@ -0,0 +1,671 @@
|
|||||||
|
#include <sstream>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include <apt-pkg/cachefile.h>
|
||||||
|
#include <apt-pkg/pkgcache.h>
|
||||||
|
#include <apt-pkg/pkgrecords.h>
|
||||||
|
#include <apt-pkg/version.h>
|
||||||
|
|
||||||
|
#include <apt-pkg/init.h>
|
||||||
|
#include <apt-pkg/pkgsystem.h>
|
||||||
|
#include <apt-pkg/policy.h>
|
||||||
|
|
||||||
|
struct PCache {
|
||||||
|
// Owned by us.
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
pkgCacheFile *cache_file;
|
||||||
|
#else
|
||||||
|
CacheFile *cache_file;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Borrowed from cache_file.
|
||||||
|
pkgCache *cache;
|
||||||
|
|
||||||
|
// Owned by us.
|
||||||
|
pkgRecords *records;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PPkgIterator {
|
||||||
|
// Owned by us.
|
||||||
|
pkgCache::PkgIterator iterator;
|
||||||
|
|
||||||
|
// Borrow of "static" PCache.
|
||||||
|
PCache *cache;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PVerIterator {
|
||||||
|
// Owned by us.
|
||||||
|
pkgCache::VerIterator iterator;
|
||||||
|
|
||||||
|
// Borrowed from PCache.
|
||||||
|
pkgCache::PkgIterator *pkg;
|
||||||
|
|
||||||
|
// Borrow of "static" PCache.
|
||||||
|
PCache *cache;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PDepIterator {
|
||||||
|
// Owned by us.
|
||||||
|
pkgCache::DepIterator iterator;
|
||||||
|
|
||||||
|
// Borrowed from PCache.
|
||||||
|
pkgCache::VerIterator *ver;
|
||||||
|
|
||||||
|
// Borrow of "static" PCache.
|
||||||
|
PCache *cache;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PVerFileIterator {
|
||||||
|
// Owned by us.
|
||||||
|
pkgCache::VerFileIterator iterator;
|
||||||
|
|
||||||
|
// Borrow of "static" PCache.
|
||||||
|
PCache *cache;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PPkgFileIterator {
|
||||||
|
// Owned by us.
|
||||||
|
pkgCache::PkgFileIterator iterator;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PVerFileParser {
|
||||||
|
pkgRecords::Parser *parser;
|
||||||
|
};
|
||||||
|
|
||||||
|
extern "C" {
|
||||||
|
void init_config_system();
|
||||||
|
|
||||||
|
PCache *pkg_cache_create();
|
||||||
|
void pkg_cache_release(PCache *cache);
|
||||||
|
|
||||||
|
int32_t pkg_cache_compare_versions(PCache *cache, const char *left, const char *right);
|
||||||
|
|
||||||
|
// pkg_iter creation and deletion
|
||||||
|
PPkgIterator *pkg_cache_pkg_iter(PCache *cache);
|
||||||
|
PPkgIterator *pkg_cache_find_name(PCache *cache, const char *name);
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
PPkgIterator *pkg_cache_find_name_arch(PCache *cache, const char *name, const char *arch);
|
||||||
|
#else
|
||||||
|
PPkgIterator *pkg_cache_find_name_arch(PCache *cache, const char *name);
|
||||||
|
#endif
|
||||||
|
void pkg_iter_release(PPkgIterator *iterator);
|
||||||
|
|
||||||
|
// pkg_iter mutation
|
||||||
|
void pkg_iter_next(PPkgIterator *iterator);
|
||||||
|
bool pkg_iter_end(PPkgIterator *iterator);
|
||||||
|
|
||||||
|
// pkg_iter access
|
||||||
|
const char *pkg_iter_name(PPkgIterator *iterator);
|
||||||
|
const char *pkg_iter_arch(PPkgIterator *iterator);
|
||||||
|
const char *pkg_iter_current_version(PPkgIterator *iterator);
|
||||||
|
const char *pkg_iter_candidate_version(PPkgIterator *iterator);
|
||||||
|
|
||||||
|
// ver_iter creation and deletion
|
||||||
|
PVerIterator *pkg_iter_ver_iter(PPkgIterator *iterator);
|
||||||
|
void ver_iter_release(PVerIterator *iterator);
|
||||||
|
|
||||||
|
// ver_iter mutation
|
||||||
|
void ver_iter_next(PVerIterator *iterator);
|
||||||
|
bool ver_iter_end(PVerIterator *iterator);
|
||||||
|
|
||||||
|
// ver_iter access
|
||||||
|
const char *ver_iter_version(PVerIterator *iterator);
|
||||||
|
const char *ver_iter_section(PVerIterator *iterator);
|
||||||
|
const char *ver_iter_arch(PVerIterator *iterator);
|
||||||
|
const char *ver_iter_priority_type(PVerIterator *wrapper);
|
||||||
|
|
||||||
|
#ifndef YE_OLDE_APT
|
||||||
|
const char *ver_iter_source_package(PVerIterator *iterator);
|
||||||
|
const char *ver_iter_source_version(PVerIterator *iterator);
|
||||||
|
int32_t ver_iter_priority(PVerIterator *iterator);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// dep_iter creation and deletion
|
||||||
|
PDepIterator *ver_iter_dep_iter(PVerIterator *iterator);
|
||||||
|
void dep_iter_release(PDepIterator *iterator);
|
||||||
|
|
||||||
|
// dep_iter mutation
|
||||||
|
void dep_iter_next(PDepIterator *iterator);
|
||||||
|
bool dep_iter_end(PDepIterator *iterator);
|
||||||
|
|
||||||
|
// dep_iter access
|
||||||
|
PPkgIterator *dep_iter_target_pkg(PDepIterator *iterator);
|
||||||
|
const char *dep_iter_target_ver(PDepIterator *iterator);
|
||||||
|
const char *dep_iter_comp_type(PDepIterator *iterator);
|
||||||
|
const char *dep_iter_dep_type(PDepIterator *iterator);
|
||||||
|
|
||||||
|
// ver_file_iter creation and deletion
|
||||||
|
PVerFileIterator *ver_iter_ver_file_iter(PVerIterator *iterator);
|
||||||
|
void ver_file_iter_release(PVerFileIterator *iterator);
|
||||||
|
|
||||||
|
// ver_file_iter mutation
|
||||||
|
void ver_file_iter_next(PVerFileIterator *iterator);
|
||||||
|
bool ver_file_iter_end(PVerFileIterator *iterator);
|
||||||
|
|
||||||
|
// ver_file_parser creation
|
||||||
|
PVerFileParser *ver_file_iter_get_parser(PVerFileIterator *iterator);
|
||||||
|
|
||||||
|
// ver_file_parser access
|
||||||
|
const char *ver_file_parser_short_desc(PVerFileParser *parser);
|
||||||
|
const char *ver_file_parser_long_desc(PVerFileParser *parser);
|
||||||
|
const char *ver_file_parser_maintainer(PVerFileParser *parser);
|
||||||
|
const char *ver_file_parser_homepage(PVerFileParser *parser);
|
||||||
|
|
||||||
|
// ver_file_iter has no accessors, only the creation of pkg_file_iter
|
||||||
|
|
||||||
|
|
||||||
|
// pkg_file_iter creation
|
||||||
|
PPkgFileIterator *ver_file_iter_pkg_file_iter(PVerFileIterator *iterator);
|
||||||
|
void pkg_file_iter_release(PPkgFileIterator *iterator);
|
||||||
|
|
||||||
|
// pkg_file_iter mutation
|
||||||
|
void pkg_file_iter_next(PPkgFileIterator *iterator);
|
||||||
|
bool pkg_file_iter_end(PPkgFileIterator *iterator);
|
||||||
|
|
||||||
|
// pkg_file_iter access
|
||||||
|
const char *pkg_file_iter_file_name(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_archive(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_version(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_origin(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_codename(PPkgFileIterator *iterator);
|
||||||
|
|
||||||
|
const char *pkg_file_iter_label(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_site(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_component(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_architecture(PPkgFileIterator *iterator);
|
||||||
|
const char *pkg_file_iter_index_type(PPkgFileIterator *iterator);
|
||||||
|
}
|
||||||
|
|
||||||
|
void init_config_system() {
|
||||||
|
pkgInitConfig(*_config);
|
||||||
|
pkgInitSystem(*_config, _system);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
|
||||||
|
PCache *pkg_cache_create() {
|
||||||
|
pkgCacheFile *cache_file = new pkgCacheFile();
|
||||||
|
pkgCache *cache = cache_file->GetPkgCache();
|
||||||
|
pkgRecords *records = new pkgRecords(*cache);
|
||||||
|
|
||||||
|
PCache *ret = new PCache();
|
||||||
|
ret->cache_file = cache_file;
|
||||||
|
ret->cache = cache;
|
||||||
|
ret->records = records;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
const char *to_c_string(std::string s);
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
bool can_commit() {
|
||||||
|
// Allow user with effective SU to acquire lock
|
||||||
|
return geteuid() == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// See ALT's apt/cmdline
|
||||||
|
// Used to print out the progress
|
||||||
|
// Set to stdout for now
|
||||||
|
ostream progress_stream(0);
|
||||||
|
|
||||||
|
PCache *pkg_cache_create() {
|
||||||
|
// Maybe should be set to false sometimes
|
||||||
|
// (Set to can_commit() for now)
|
||||||
|
// We should lock for installation, etc.
|
||||||
|
// For read-only access no locking needed
|
||||||
|
// In apt-shell, WithLock is always set according to (geteuid() == 0).
|
||||||
|
const bool WithLock = can_commit();
|
||||||
|
|
||||||
|
CacheFile *cache_file = new CacheFile(progress_stream, WithLock);
|
||||||
|
cache_file->Open();
|
||||||
|
|
||||||
|
if (cache_file->CheckDeps(true) == false) {
|
||||||
|
delete cache_file;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
// cast operator from CacheFile to pkgCache*
|
||||||
|
pkgCache *cache = *cache_file;
|
||||||
|
pkgRecords *records = new pkgRecords(*cache);
|
||||||
|
|
||||||
|
PCache *ret = new PCache();
|
||||||
|
ret->cache_file = cache_file;
|
||||||
|
ret->cache = cache;
|
||||||
|
ret->records = records;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void pkg_cache_release(PCache *cache) {
|
||||||
|
// TODO: is cache->cache cleaned up with cache->cache_file?
|
||||||
|
delete cache->records;
|
||||||
|
delete cache->cache_file;
|
||||||
|
delete cache;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t pkg_cache_compare_versions(PCache *cache, const char *left, const char *right) {
|
||||||
|
// an int is returned here; presumably it will always be -1, 0 or 1.
|
||||||
|
return cache->cache->VS->DoCmpVersion(left, left+strlen(left), right, right+strlen(right));
|
||||||
|
}
|
||||||
|
|
||||||
|
PPkgIterator *pkg_cache_pkg_iter(PCache *cache) {
|
||||||
|
PPkgIterator *wrapper = new PPkgIterator();
|
||||||
|
wrapper->iterator = cache->cache->PkgBegin();
|
||||||
|
wrapper->cache = cache;
|
||||||
|
return wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
PPkgIterator *pkg_cache_find_name(PCache *cache, const char *name) {
|
||||||
|
PPkgIterator *wrapper = new PPkgIterator();
|
||||||
|
wrapper->iterator = cache->cache->FindPkg(name);
|
||||||
|
wrapper->cache = cache;
|
||||||
|
return wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
|
||||||
|
PPkgIterator *pkg_cache_find_name_arch(PCache *cache, const char *name, const char *arch) {
|
||||||
|
PPkgIterator *wrapper = new PPkgIterator();
|
||||||
|
wrapper->iterator = cache->cache->FindPkg(name, arch);
|
||||||
|
wrapper->cache = cache;
|
||||||
|
return wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
PPkgIterator *pkg_cache_find_name_arch(PCache *cache, const char *name) {
|
||||||
|
PPkgIterator *wrapper = new PPkgIterator();
|
||||||
|
wrapper->iterator = cache->cache->FindPkg(name);
|
||||||
|
wrapper->cache = cache;
|
||||||
|
return wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void pkg_iter_release(PPkgIterator *wrapper) {
|
||||||
|
delete wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void pkg_iter_next(PPkgIterator *wrapper) {
|
||||||
|
++wrapper->iterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool pkg_iter_end(PPkgIterator *wrapper) {
|
||||||
|
return wrapper->cache->cache->PkgEnd() == wrapper->iterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_iter_name(PPkgIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Name();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
|
||||||
|
const char *pkg_iter_arch(PPkgIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Arch();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_iter_current_version(PPkgIterator *wrapper) {
|
||||||
|
return wrapper->iterator.CurVersion();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_iter_candidate_version(PPkgIterator *wrapper) {
|
||||||
|
pkgCache::VerIterator it = wrapper->cache->cache_file->GetPolicy()->GetCandidateVer(wrapper->iterator);
|
||||||
|
if (it.end()) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
return it.VerStr();
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
const char *pkg_iter_arch(PPkgIterator *wrapper) {
|
||||||
|
pkgCache::VerIterator it = wrapper->iterator.VersionList();
|
||||||
|
|
||||||
|
if (it.end()) {
|
||||||
|
// It's a virtual package
|
||||||
|
// Let's take some of providers and take it's arch
|
||||||
|
pkgCache::PrvIterator provide_list = wrapper->iterator.ProvidesList();
|
||||||
|
if (provide_list.end()) {
|
||||||
|
// Return 'something' in case of broken packages
|
||||||
|
// I would prefer returning nullptr,
|
||||||
|
// but Rust-side requires it to be non-null
|
||||||
|
return to_c_string("Undefined");
|
||||||
|
}
|
||||||
|
pkgCache::PkgIterator provide = provide_list.OwnerPkg();
|
||||||
|
if (provide.end()) {
|
||||||
|
return to_c_string("Undefined");
|
||||||
|
}
|
||||||
|
|
||||||
|
PPkgIterator new_wrapper;
|
||||||
|
new_wrapper.iterator = provide;
|
||||||
|
new_wrapper.cache = wrapper->cache;
|
||||||
|
|
||||||
|
return pkg_iter_arch(&new_wrapper);
|
||||||
|
} else {
|
||||||
|
return it.Arch();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_iter_current_version(PPkgIterator *wrapper) {
|
||||||
|
pkgCache::VerIterator it = wrapper->iterator.CurrentVer();
|
||||||
|
|
||||||
|
if (it.end()) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
return it.VerStr();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_iter_candidate_version(PPkgIterator *wrapper) {
|
||||||
|
// pkgCache::VerIterator it = wrapper->cache->cache_file->GetPolicy(Progress)->GetCandidateVer(wrapper->iterator);
|
||||||
|
// Getting rid of GetPolicy call by creating PkgPolicy object via constructor (no need in OpProgress)
|
||||||
|
// (This is done this way in cmdline apt utility (see ALT's apt/cmdline sources))
|
||||||
|
pkgPolicy plcy(wrapper->cache->cache);
|
||||||
|
pkgCache::VerIterator it = plcy.GetCandidateVer(wrapper->iterator);
|
||||||
|
|
||||||
|
if (it.end()) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
return it.VerStr();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
PVerIterator *pkg_iter_ver_iter(PPkgIterator *wrapper) {
|
||||||
|
PVerIterator *new_wrapper = new PVerIterator();
|
||||||
|
new_wrapper->iterator = wrapper->iterator.VersionList();
|
||||||
|
new_wrapper->pkg = &wrapper->iterator;
|
||||||
|
new_wrapper->cache = wrapper->cache;
|
||||||
|
return new_wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ver_iter_release(PVerIterator *wrapper) {
|
||||||
|
delete wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ver_iter_next(PVerIterator *wrapper) {
|
||||||
|
++wrapper->iterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ver_iter_end(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const char *ver_iter_version(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.VerStr();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_iter_section(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Section();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_iter_priority_type(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.PriorityType();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef YE_OLDE_APT
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
|
||||||
|
const char *ver_iter_source_package(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.SourcePkgName();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_iter_source_version(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.SourceVerStr();
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t ver_iter_priority(PVerIterator *wrapper) {
|
||||||
|
// The priority is a "short", which is roughly a (signed) int16_t;
|
||||||
|
// going bigger just in case
|
||||||
|
return wrapper->cache->cache_file->GetPolicy()->GetPriority(wrapper->iterator);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef ALT_LINUX
|
||||||
|
|
||||||
|
const char *ver_iter_source_package(PVerIterator *wrapper) {
|
||||||
|
pkgRecords *recs = wrapper->cache->records;
|
||||||
|
pkgRecords::Parser &parse = recs->Lookup(wrapper->iterator.FileList());
|
||||||
|
|
||||||
|
// It's okay to return raw pointer to heap memory, due to convention in Rust-caller
|
||||||
|
// (it will be freed by an owning wrapper)
|
||||||
|
return to_c_string(parse.SourcePkg());
|
||||||
|
}
|
||||||
|
|
||||||
|
// SHOULD BE REMOVED FROM ALT'S VERSION! MEANINGLESS!
|
||||||
|
// Apt only works with rpms and not src.rpm
|
||||||
|
const char *ver_iter_source_version(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.VerStr();
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t ver_iter_priority(PVerIterator *wrapper) {
|
||||||
|
// return wrapper->cache->cache_file->GetPolicy(Progress)->GetPriority(*wrapper->pkg);
|
||||||
|
// Getting rid of GetPolicy call by creating PkgPolicy object with constructor (no need in OpProgress)
|
||||||
|
// (This is done this way in cmdline apt utility (see ALT's apt/cmdline sources))
|
||||||
|
pkgPolicy plcy(wrapper->cache->cache);
|
||||||
|
|
||||||
|
return plcy.GetPriority(*wrapper->pkg);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char *ver_iter_arch(PVerIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Arch();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
PDepIterator *ver_iter_dep_iter(PVerIterator *wrapper) {
|
||||||
|
PDepIterator *new_wrapper = new PDepIterator();
|
||||||
|
new_wrapper->iterator = wrapper->iterator.DependsList();
|
||||||
|
new_wrapper->cache = wrapper->cache;
|
||||||
|
return new_wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void dep_iter_release(PDepIterator *wrapper) {
|
||||||
|
delete wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void dep_iter_next(PDepIterator *wrapper) {
|
||||||
|
++wrapper->iterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool dep_iter_end(PDepIterator *wrapper) {
|
||||||
|
return wrapper->iterator.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
PPkgIterator *dep_iter_target_pkg(PDepIterator *wrapper) {
|
||||||
|
PPkgIterator *new_wrapper = new PPkgIterator();
|
||||||
|
new_wrapper->iterator = wrapper->iterator.TargetPkg();
|
||||||
|
new_wrapper->cache = wrapper->cache;
|
||||||
|
return new_wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *dep_iter_target_ver(PDepIterator *wrapper) {
|
||||||
|
return wrapper->iterator.TargetVer();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *dep_iter_comp_type(PDepIterator *wrapper) {
|
||||||
|
return wrapper->iterator.CompType();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *dep_iter_dep_type(PDepIterator *wrapper) {
|
||||||
|
return wrapper->iterator.DepType();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
PVerFileIterator *ver_iter_ver_file_iter(PVerIterator *wrapper) {
|
||||||
|
PVerFileIterator *new_wrapper = new PVerFileIterator();
|
||||||
|
new_wrapper->iterator = wrapper->iterator.FileList();
|
||||||
|
new_wrapper->cache = wrapper->cache;
|
||||||
|
return new_wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ver_file_iter_release(PVerFileIterator *wrapper) {
|
||||||
|
delete wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ver_file_iter_next(PVerFileIterator *wrapper) {
|
||||||
|
++wrapper->iterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
PVerFileParser *ver_file_iter_get_parser(PVerFileIterator *wrapper) {
|
||||||
|
PVerFileParser *parser = new PVerFileParser();
|
||||||
|
parser->parser = &wrapper->cache->records->Lookup(wrapper->iterator);
|
||||||
|
return parser;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *to_c_string(std::string s) {
|
||||||
|
char *cstr = new char[s.length()+1];
|
||||||
|
std::strcpy(cstr, s.c_str());
|
||||||
|
return cstr;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_short_desc(PVerFileParser *parser) {
|
||||||
|
std::string desc = parser->parser->ShortDesc();
|
||||||
|
return to_c_string(desc);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_long_desc(PVerFileParser *parser) {
|
||||||
|
std::string desc = parser->parser->LongDesc();
|
||||||
|
return to_c_string(desc);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *ver_file_parser_maintainer(PVerFileParser *parser) {
|
||||||
|
std::string maint = parser->parser->Maintainer();
|
||||||
|
return to_c_string(maint);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
|
||||||
|
const char *ver_file_parser_homepage(PVerFileParser *parser) {
|
||||||
|
std::string hp = parser->parser->Homepage();
|
||||||
|
return to_c_string(hp);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
|
||||||
|
// Should be erased from Alt's version or Alt's Apt should provide
|
||||||
|
// functionality for getting homepage address
|
||||||
|
const char *ver_file_parser_homepage(PVerFileParser *parser) {
|
||||||
|
// Unimplementable in ALT via PVerFileParser
|
||||||
|
// Maybe should remove it in ALT version of lib (or just return nullptr)
|
||||||
|
// Not sure in use of nullptr due to possible absense of checks from caller
|
||||||
|
// So return dummy string
|
||||||
|
return to_c_string("Not Specified");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
bool ver_file_iter_end(PVerFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
PPkgFileIterator *ver_file_iter_pkg_file_iter(PVerFileIterator *wrapper) {
|
||||||
|
PPkgFileIterator *new_wrapper = new PPkgFileIterator();
|
||||||
|
new_wrapper->iterator = wrapper->iterator.File();
|
||||||
|
return new_wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void pkg_file_iter_release(PPkgFileIterator *wrapper) {
|
||||||
|
delete wrapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
void pkg_file_iter_next(PPkgFileIterator *wrapper) {
|
||||||
|
++wrapper->iterator;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool pkg_file_iter_end(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_file_iter_file_name(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.FileName();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
const char *pkg_file_iter_archive(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Archive();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
const char *pkg_file_iter_archive(PPkgFileIterator *wrapper) {
|
||||||
|
const char *archive = wrapper->iterator.Archive();
|
||||||
|
if (archive == nullptr) {
|
||||||
|
// Should be non-null
|
||||||
|
return to_c_string("Not Specified");
|
||||||
|
}
|
||||||
|
return archive;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char *pkg_file_iter_version(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Version();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_file_iter_origin(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Origin();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
|
||||||
|
const char *pkg_file_iter_codename(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Codename();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
|
||||||
|
const char *pkg_file_iter_codename(PPkgFileIterator *wrapper) {
|
||||||
|
// From Debian docs:
|
||||||
|
/* "The Codename field shall describe the codename of the release.*/
|
||||||
|
// Analogues in ALT is Branch name.
|
||||||
|
return wrapper->iterator.Label();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char *pkg_file_iter_label(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Label();
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *pkg_file_iter_site(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Site();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
const char *pkg_file_iter_component(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Component();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
const char *pkg_file_iter_component(PPkgFileIterator *wrapper) {
|
||||||
|
const char *component = wrapper->iterator.Component();
|
||||||
|
if (component == nullptr) {
|
||||||
|
// Should be non-null
|
||||||
|
return to_c_string("Not Specified");
|
||||||
|
}
|
||||||
|
return component;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
const char *pkg_file_iter_architecture(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.Architecture();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef ALT_LINUX
|
||||||
|
const char *pkg_file_iter_index_type(PPkgFileIterator *wrapper) {
|
||||||
|
return wrapper->iterator.IndexType();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
const char *pkg_file_iter_index_type(PPkgFileIterator *wrapper) {
|
||||||
|
const char *index_type = wrapper->iterator.IndexType();
|
||||||
|
if (index_type == nullptr) {
|
||||||
|
// Should be non-null
|
||||||
|
return to_c_string("Not Specified");
|
||||||
|
}
|
||||||
|
return index_type;
|
||||||
|
}
|
||||||
|
#endif
|
33
pve-rs/vendor/apt-pkg-native/build.rs
vendored
Normal file
33
pve-rs/vendor/apt-pkg-native/build.rs
vendored
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
extern crate cc;
|
||||||
|
|
||||||
|
const SRC: &str = "apt-pkg-c/lib.cpp";
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
println!("cargo:rerun-if-changed={}", SRC);
|
||||||
|
|
||||||
|
let mut build = cc::Build::new();
|
||||||
|
build.file(SRC);
|
||||||
|
build.cpp(true);
|
||||||
|
#[cfg(feature = "alt-linux")]
|
||||||
|
{
|
||||||
|
build.flag("-std=gnu++17");
|
||||||
|
}
|
||||||
|
#[cfg(not(feature = "alt-linux"))]
|
||||||
|
{
|
||||||
|
build.flag("-std=gnu++11");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "ye-olde-apt")]
|
||||||
|
{
|
||||||
|
build.define("YE_OLDE_APT", "1");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "alt-linux")]
|
||||||
|
{
|
||||||
|
build.define("ALT_LINUX", "1");
|
||||||
|
}
|
||||||
|
|
||||||
|
build.compile("libapt-pkg-c.a");
|
||||||
|
|
||||||
|
println!("cargo:rustc-link-lib=apt-pkg");
|
||||||
|
}
|
14
pve-rs/vendor/apt-pkg-native/examples/epochs.rs
vendored
Normal file
14
pve-rs/vendor/apt-pkg-native/examples/epochs.rs
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
use apt_pkg_native::Cache;
|
||||||
|
|
||||||
|
use boolinator::Boolinator;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
for item in cache.iter().filter_map(|f| {
|
||||||
|
f.versions()
|
||||||
|
.any(|version| version.version().contains(':'))
|
||||||
|
.as_some_from(|| f.name())
|
||||||
|
}) {
|
||||||
|
println!("{}", item);
|
||||||
|
}
|
||||||
|
}
|
15
pve-rs/vendor/apt-pkg-native/examples/list.rs
vendored
Normal file
15
pve-rs/vendor/apt-pkg-native/examples/list.rs
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
use itertools::Itertools;
|
||||||
|
|
||||||
|
use apt_pkg_native::simple;
|
||||||
|
use apt_pkg_native::Cache;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
for item in cache.iter().map(simple::BinaryPackageVersions::new) {
|
||||||
|
println!(
|
||||||
|
"{} [{}]",
|
||||||
|
item.pkg,
|
||||||
|
item.versions.iter().map(|x| format!("{}", x)).join(", ")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
1
pve-rs/vendor/apt-pkg-native/examples/on-sid/.dockerignore
vendored
Normal file
1
pve-rs/vendor/apt-pkg-native/examples/on-sid/.dockerignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
Makefile
|
9
pve-rs/vendor/apt-pkg-native/examples/on-sid/Dockerfile
vendored
Normal file
9
pve-rs/vendor/apt-pkg-native/examples/on-sid/Dockerfile
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
FROM debian:sid
|
||||||
|
|
||||||
|
COPY sources.list /etc/apt/sources.list
|
||||||
|
|
||||||
|
ARG http_proxy
|
||||||
|
RUN env http_proxy=${http_proxy} apt-get update
|
||||||
|
|
||||||
|
WORKDIR /mnt
|
||||||
|
|
5
pve-rs/vendor/apt-pkg-native/examples/on-sid/Makefile
vendored
Normal file
5
pve-rs/vendor/apt-pkg-native/examples/on-sid/Makefile
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
build:
|
||||||
|
docker build --network=mope --build-arg http_proxy=http://urika:3142 --tag sid-sources-list .
|
||||||
|
|
||||||
|
clean:
|
||||||
|
docker rmi sid-sources-list
|
2
pve-rs/vendor/apt-pkg-native/examples/on-sid/sources.list
vendored
Normal file
2
pve-rs/vendor/apt-pkg-native/examples/on-sid/sources.list
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
deb http://deb.debian.org/debian sid main contrib non-free
|
||||||
|
deb-src http://deb.debian.org/debian sid main contrib non-free
|
1
pve-rs/vendor/apt-pkg-native/examples/on-trusty/.dockerignore
vendored
Normal file
1
pve-rs/vendor/apt-pkg-native/examples/on-trusty/.dockerignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
Makefile
|
11
pve-rs/vendor/apt-pkg-native/examples/on-trusty/Dockerfile
vendored
Normal file
11
pve-rs/vendor/apt-pkg-native/examples/on-trusty/Dockerfile
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
FROM ubuntu:trusty
|
||||||
|
|
||||||
|
ARG http_proxy
|
||||||
|
RUN env http_proxy=${http_proxy} apt-get update \
|
||||||
|
&& apt-get install -y build-essential libapt-pkg-dev curl
|
||||||
|
|
||||||
|
COPY uprust.sh /root/uprust.sh
|
||||||
|
|
||||||
|
RUN bash /root/uprust.sh --default-toolchain nightly -y
|
||||||
|
|
||||||
|
WORKDIR /mnt
|
10
pve-rs/vendor/apt-pkg-native/examples/on-trusty/Makefile
vendored
Normal file
10
pve-rs/vendor/apt-pkg-native/examples/on-trusty/Makefile
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
build:
|
||||||
|
docker build --network=mope --build-arg http_proxy=http://urika:3142 --tag trusty-dev-vm .
|
||||||
|
|
||||||
|
run: build
|
||||||
|
docker run --network=mope -v $(shell pwd)/../..:/mnt -it trusty-dev-vm
|
||||||
|
|
||||||
|
clean:
|
||||||
|
docker rmi trusty-dev-vm
|
||||||
|
|
||||||
|
.PHONY: build run
|
362
pve-rs/vendor/apt-pkg-native/examples/on-trusty/uprust.sh
vendored
Normal file
362
pve-rs/vendor/apt-pkg-native/examples/on-trusty/uprust.sh
vendored
Normal file
@ -0,0 +1,362 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
# file at the top-level directory of this distribution and at
|
||||||
|
# http://rust-lang.org/COPYRIGHT.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
# <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
# option. This file may not be copied, modified, or distributed
|
||||||
|
# except according to those terms.
|
||||||
|
|
||||||
|
# This is just a little script that can be curled from the internet to
|
||||||
|
# install rustup. It just does platform detection, curls the installer
|
||||||
|
# and runs it.
|
||||||
|
|
||||||
|
set -u
|
||||||
|
|
||||||
|
RUSTUP_UPDATE_ROOT="https://static.rust-lang.org/rustup/dist"
|
||||||
|
|
||||||
|
#XXX: If you change anything here, please make the same changes in setup_mode.rs
|
||||||
|
usage() {
|
||||||
|
cat 1>&2 <<EOF
|
||||||
|
rustup-init 1.0.0 (408ed84 2017-02-11)
|
||||||
|
The installer for rustup
|
||||||
|
|
||||||
|
USAGE:
|
||||||
|
rustup-init [FLAGS] [OPTIONS]
|
||||||
|
|
||||||
|
FLAGS:
|
||||||
|
-v, --verbose Enable verbose output
|
||||||
|
-y Disable confirmation prompt.
|
||||||
|
--no-modify-path Don't configure the PATH environment variable
|
||||||
|
-h, --help Prints help information
|
||||||
|
-V, --version Prints version information
|
||||||
|
|
||||||
|
OPTIONS:
|
||||||
|
--default-host <default-host> Choose a default host triple
|
||||||
|
--default-toolchain <default-toolchain> Choose a default toolchain to install
|
||||||
|
--default-toolchain none Do not install any toolchains
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
main() {
|
||||||
|
need_cmd uname
|
||||||
|
need_cmd curl
|
||||||
|
need_cmd mktemp
|
||||||
|
need_cmd chmod
|
||||||
|
need_cmd mkdir
|
||||||
|
need_cmd rm
|
||||||
|
need_cmd rmdir
|
||||||
|
|
||||||
|
get_architecture || return 1
|
||||||
|
local _arch="$RETVAL"
|
||||||
|
assert_nz "$_arch" "arch"
|
||||||
|
|
||||||
|
local _ext=""
|
||||||
|
case "$_arch" in
|
||||||
|
*windows*)
|
||||||
|
_ext=".exe"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
local _url="$RUSTUP_UPDATE_ROOT/$_arch/rustup-init$_ext"
|
||||||
|
|
||||||
|
local _dir="$(mktemp -d 2>/dev/null || ensure mktemp -d -t rustup)"
|
||||||
|
local _file="$_dir/rustup-init$_ext"
|
||||||
|
|
||||||
|
local _ansi_escapes_are_valid=false
|
||||||
|
if [ -t 2 ]; then
|
||||||
|
if [ "${TERM+set}" = 'set' ]; then
|
||||||
|
case "$TERM" in
|
||||||
|
xterm*|rxvt*|urxvt*|linux*|vt*)
|
||||||
|
_ansi_escapes_are_valid=true
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# check if we have to use /dev/tty to prompt the user
|
||||||
|
local need_tty=yes
|
||||||
|
for arg in "$@"; do
|
||||||
|
case "$arg" in
|
||||||
|
-h|--help)
|
||||||
|
usage
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
-y)
|
||||||
|
# user wants to skip the prompt -- we don't need /dev/tty
|
||||||
|
need_tty=no
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if $_ansi_escapes_are_valid; then
|
||||||
|
printf "\33[1minfo:\33[0m downloading installer\n" 1>&2
|
||||||
|
else
|
||||||
|
printf '%s\n' 'info: downloading installer' 1>&2
|
||||||
|
fi
|
||||||
|
|
||||||
|
ensure mkdir -p "$_dir"
|
||||||
|
ensure curl -sSfL "$_url" -o "$_file"
|
||||||
|
ensure chmod u+x "$_file"
|
||||||
|
if [ ! -x "$_file" ]; then
|
||||||
|
printf '%s\n' "Cannot execute $_file (likely because of mounting /tmp as noexec)." 1>&2
|
||||||
|
printf '%s\n' "Please copy the file to a location where you can execute binaries and run ./rustup-init$_ext." 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$need_tty" = "yes" ]; then
|
||||||
|
# The installer is going to want to ask for confirmation by
|
||||||
|
# reading stdin. This script was piped into `sh` though and
|
||||||
|
# doesn't have stdin to pass to its children. Instead we're going
|
||||||
|
# to explicitly connect /dev/tty to the installer's stdin.
|
||||||
|
if [ ! -t 1 ]; then
|
||||||
|
err "Unable to run interactively. Run with -y to accept defaults, --help for additional options"
|
||||||
|
fi
|
||||||
|
|
||||||
|
ignore "$_file" "$@" < /dev/tty
|
||||||
|
else
|
||||||
|
ignore "$_file" "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
local _retval=$?
|
||||||
|
|
||||||
|
ignore rm "$_file"
|
||||||
|
ignore rmdir "$_dir"
|
||||||
|
|
||||||
|
return "$_retval"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_bitness() {
|
||||||
|
need_cmd head
|
||||||
|
# Architecture detection without dependencies beyond coreutils.
|
||||||
|
# ELF files start out "\x7fELF", and the following byte is
|
||||||
|
# 0x01 for 32-bit and
|
||||||
|
# 0x02 for 64-bit.
|
||||||
|
# The printf builtin on some shells like dash only supports octal
|
||||||
|
# escape sequences, so we use those.
|
||||||
|
local _current_exe_head=$(head -c 5 /proc/self/exe )
|
||||||
|
if [ "$_current_exe_head" = "$(printf '\177ELF\001')" ]; then
|
||||||
|
echo 32
|
||||||
|
elif [ "$_current_exe_head" = "$(printf '\177ELF\002')" ]; then
|
||||||
|
echo 64
|
||||||
|
else
|
||||||
|
err "unknown platform bitness"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
get_endianness() {
|
||||||
|
local cputype=$1
|
||||||
|
local suffix_eb=$2
|
||||||
|
local suffix_el=$3
|
||||||
|
|
||||||
|
# detect endianness without od/hexdump, like get_bitness() does.
|
||||||
|
need_cmd head
|
||||||
|
need_cmd tail
|
||||||
|
|
||||||
|
local _current_exe_endianness="$(head -c 6 /proc/self/exe | tail -c 1)"
|
||||||
|
if [ "$_current_exe_endianness" = "$(printf '\001')" ]; then
|
||||||
|
echo "${cputype}${suffix_el}"
|
||||||
|
elif [ "$_current_exe_endianness" = "$(printf '\002')" ]; then
|
||||||
|
echo "${cputype}${suffix_eb}"
|
||||||
|
else
|
||||||
|
err "unknown platform endianness"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
get_architecture() {
|
||||||
|
|
||||||
|
local _ostype="$(uname -s)"
|
||||||
|
local _cputype="$(uname -m)"
|
||||||
|
|
||||||
|
if [ "$_ostype" = Linux ]; then
|
||||||
|
if [ "$(uname -o)" = Android ]; then
|
||||||
|
local _ostype=Android
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$_ostype" = Darwin -a "$_cputype" = i386 ]; then
|
||||||
|
# Darwin `uname -s` lies
|
||||||
|
if sysctl hw.optional.x86_64 | grep -q ': 1'; then
|
||||||
|
local _cputype=x86_64
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$_ostype" in
|
||||||
|
|
||||||
|
Android)
|
||||||
|
local _ostype=linux-android
|
||||||
|
;;
|
||||||
|
|
||||||
|
Linux)
|
||||||
|
local _ostype=unknown-linux-gnu
|
||||||
|
;;
|
||||||
|
|
||||||
|
FreeBSD)
|
||||||
|
local _ostype=unknown-freebsd
|
||||||
|
;;
|
||||||
|
|
||||||
|
NetBSD)
|
||||||
|
local _ostype=unknown-netbsd
|
||||||
|
;;
|
||||||
|
|
||||||
|
DragonFly)
|
||||||
|
local _ostype=unknown-dragonfly
|
||||||
|
;;
|
||||||
|
|
||||||
|
Darwin)
|
||||||
|
local _ostype=apple-darwin
|
||||||
|
;;
|
||||||
|
|
||||||
|
MINGW* | MSYS* | CYGWIN*)
|
||||||
|
local _ostype=pc-windows-gnu
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
err "unrecognized OS type: $_ostype"
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "$_cputype" in
|
||||||
|
|
||||||
|
i386 | i486 | i686 | i786 | x86)
|
||||||
|
local _cputype=i686
|
||||||
|
;;
|
||||||
|
|
||||||
|
xscale | arm)
|
||||||
|
local _cputype=arm
|
||||||
|
if [ "$_ostype" = "linux-android" ]; then
|
||||||
|
local _ostype=linux-androideabi
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
armv6l)
|
||||||
|
local _cputype=arm
|
||||||
|
if [ "$_ostype" = "linux-android" ]; then
|
||||||
|
local _ostype=linux-androideabi
|
||||||
|
else
|
||||||
|
local _ostype="${_ostype}eabihf"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
armv7l | armv8l)
|
||||||
|
local _cputype=armv7
|
||||||
|
if [ "$_ostype" = "linux-android" ]; then
|
||||||
|
local _ostype=linux-androideabi
|
||||||
|
else
|
||||||
|
local _ostype="${_ostype}eabihf"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
aarch64)
|
||||||
|
local _cputype=aarch64
|
||||||
|
;;
|
||||||
|
|
||||||
|
x86_64 | x86-64 | x64 | amd64)
|
||||||
|
local _cputype=x86_64
|
||||||
|
;;
|
||||||
|
|
||||||
|
mips)
|
||||||
|
local _cputype="$(get_endianness $_cputype "" 'el')"
|
||||||
|
;;
|
||||||
|
|
||||||
|
mips64)
|
||||||
|
local _bitness="$(get_bitness)"
|
||||||
|
if [ $_bitness = "32" ]; then
|
||||||
|
if [ $_ostype = "unknown-linux-gnu" ]; then
|
||||||
|
# 64-bit kernel with 32-bit userland
|
||||||
|
# endianness suffix is appended later
|
||||||
|
local _cputype=mips
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
# only n64 ABI is supported for now
|
||||||
|
local _ostype="${_ostype}abi64"
|
||||||
|
fi
|
||||||
|
|
||||||
|
local _cputype="$(get_endianness $_cputype "" 'el')"
|
||||||
|
;;
|
||||||
|
|
||||||
|
ppc)
|
||||||
|
local _cputype=powerpc
|
||||||
|
;;
|
||||||
|
|
||||||
|
ppc64)
|
||||||
|
local _cputype=powerpc64
|
||||||
|
;;
|
||||||
|
|
||||||
|
ppc64le)
|
||||||
|
local _cputype=powerpc64le
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
err "unknown CPU type: $_cputype"
|
||||||
|
|
||||||
|
esac
|
||||||
|
|
||||||
|
# Detect 64-bit linux with 32-bit userland
|
||||||
|
if [ $_ostype = unknown-linux-gnu -a $_cputype = x86_64 ]; then
|
||||||
|
if [ "$(get_bitness)" = "32" ]; then
|
||||||
|
local _cputype=i686
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Detect armv7 but without the CPU features Rust needs in that build,
|
||||||
|
# and fall back to arm.
|
||||||
|
# See https://github.com/rust-lang-nursery/rustup.rs/issues/587.
|
||||||
|
if [ $_ostype = "unknown-linux-gnueabihf" -a $_cputype = armv7 ]; then
|
||||||
|
if ensure grep '^Features' /proc/cpuinfo | grep -q -v neon; then
|
||||||
|
# At least one processor does not have NEON.
|
||||||
|
local _cputype=arm
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
local _arch="$_cputype-$_ostype"
|
||||||
|
|
||||||
|
RETVAL="$_arch"
|
||||||
|
}
|
||||||
|
|
||||||
|
say() {
|
||||||
|
echo "rustup: $1"
|
||||||
|
}
|
||||||
|
|
||||||
|
err() {
|
||||||
|
say "$1" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
need_cmd() {
|
||||||
|
if ! command -v "$1" > /dev/null 2>&1
|
||||||
|
then err "need '$1' (command not found)"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
need_ok() {
|
||||||
|
if [ $? != 0 ]; then err "$1"; fi
|
||||||
|
}
|
||||||
|
|
||||||
|
assert_nz() {
|
||||||
|
if [ -z "$1" ]; then err "assert_nz $2"; fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Run a command that should never fail. If the command fails execution
|
||||||
|
# will immediately terminate with an error showing the failing
|
||||||
|
# command.
|
||||||
|
ensure() {
|
||||||
|
"$@"
|
||||||
|
need_ok "command failed: $*"
|
||||||
|
}
|
||||||
|
|
||||||
|
# This is just for indicating that commands' results are being
|
||||||
|
# intentionally ignored. Usually, because it's being executed
|
||||||
|
# as part of error handling.
|
||||||
|
ignore() {
|
||||||
|
"$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
main "$@" || exit 1
|
52
pve-rs/vendor/apt-pkg-native/examples/policy.rs
vendored
Normal file
52
pve-rs/vendor/apt-pkg-native/examples/policy.rs
vendored
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
use std::env;
|
||||||
|
|
||||||
|
use apt_pkg_native::simple;
|
||||||
|
use apt_pkg_native::Cache;
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let pkg = env::args()
|
||||||
|
.nth(1)
|
||||||
|
.expect("usage: first argument: package name");
|
||||||
|
let arch = env::args().nth(2);
|
||||||
|
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
let mut found = match arch {
|
||||||
|
Some(arch) => cache.find_by_name_arch(pkg.as_str(), arch.as_str()),
|
||||||
|
None => cache.find_by_name(pkg.as_str()),
|
||||||
|
};
|
||||||
|
|
||||||
|
if let Some(view) = found.next() {
|
||||||
|
println!("{}:{}:", view.name(), view.arch());
|
||||||
|
|
||||||
|
let installed_version = view
|
||||||
|
.current_version()
|
||||||
|
.unwrap_or_else(|| "(none)".to_string());
|
||||||
|
println!(" Installed: {}", installed_version);
|
||||||
|
println!(
|
||||||
|
" Candidate: {}",
|
||||||
|
view.candidate_version()
|
||||||
|
.unwrap_or_else(|| "(none)".to_string(),)
|
||||||
|
);
|
||||||
|
|
||||||
|
println!(" Version table:");
|
||||||
|
for simple::VersionOrigins { version, origins } in
|
||||||
|
view.versions().map(simple::VersionOrigins::new)
|
||||||
|
{
|
||||||
|
let marker = if version.version == installed_version {
|
||||||
|
"***"
|
||||||
|
} else {
|
||||||
|
" "
|
||||||
|
};
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
println!(" {} {} {}", marker, version.version, version.priority,);
|
||||||
|
#[cfg(feature = "ye-olde-apt")]
|
||||||
|
println!(" {} {}", marker, version.version,);
|
||||||
|
|
||||||
|
for origin in origins {
|
||||||
|
println!(" {:4} {}", "XXX", origin);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
println!("unrecognised package: {}", pkg);
|
||||||
|
}
|
||||||
|
}
|
84
pve-rs/vendor/apt-pkg-native/examples/sources.rs
vendored
Normal file
84
pve-rs/vendor/apt-pkg-native/examples/sources.rs
vendored
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
use std::collections::HashMap;
|
||||||
|
use std::collections::HashSet;
|
||||||
|
/// A port of a randomly selected Python program:
|
||||||
|
///
|
||||||
|
/// ```python
|
||||||
|
/// #!/usr/bin/python3
|
||||||
|
/// import collections
|
||||||
|
/// import apt
|
||||||
|
/// cache = apt.cache.Cache()
|
||||||
|
/// def versions_in(suite):
|
||||||
|
/// source_versions = collections.defaultdict(set)
|
||||||
|
///
|
||||||
|
/// for package in cache:
|
||||||
|
/// for version in package.versions:
|
||||||
|
/// if suite and suite not in (origin.archive for origin in version.origins):
|
||||||
|
/// continue
|
||||||
|
/// source_versions[version.source_name].add(version.source_version)
|
||||||
|
/// return source_versions
|
||||||
|
///
|
||||||
|
/// if '__main__' == __name__:
|
||||||
|
/// import sys
|
||||||
|
/// sources = versions_in(sys.argv[1] if len(sys.argv) > 1 else None)
|
||||||
|
/// for src in sorted(sources.keys()):
|
||||||
|
/// # sort lexographically for determinism, not for any other reason
|
||||||
|
/// for ver in sorted(sources[src]):
|
||||||
|
/// print('{}={}'.format(src, ver))
|
||||||
|
/// ```
|
||||||
|
use std::env;
|
||||||
|
|
||||||
|
use apt_pkg_native::Cache;
|
||||||
|
|
||||||
|
#[cfg(feature = "ye-olde-apt")]
|
||||||
|
fn main() {
|
||||||
|
eprintln!("ye-olde-apt pre-dates source versions")
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
fn main() {
|
||||||
|
let archive_filter = env::args().nth(1);
|
||||||
|
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
let mut source_versions = HashMap::new();
|
||||||
|
{
|
||||||
|
let mut all_packages = cache.iter();
|
||||||
|
|
||||||
|
while let Some(binary) = all_packages.next() {
|
||||||
|
let mut binary_versions = binary.versions();
|
||||||
|
while let Some(version) = binary_versions.next() {
|
||||||
|
if let Some(ref target_archive) = archive_filter {
|
||||||
|
if version
|
||||||
|
.origin_iter()
|
||||||
|
.map(|origin| origin.file().next().unwrap().archive())
|
||||||
|
.any(|archive| archive == *target_archive)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
source_versions
|
||||||
|
.entry(version.source_package())
|
||||||
|
.or_insert_with(HashSet::new)
|
||||||
|
.insert(version.source_version());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for src in lexicographic_sort(source_versions.keys()) {
|
||||||
|
let mut sorted_versions: Vec<&String> = source_versions[src].iter().collect();
|
||||||
|
sorted_versions.sort_by(|left, right| cache.compare_versions(left, right));
|
||||||
|
for ver in sorted_versions {
|
||||||
|
println!("{}={}", src, ver);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn lexicographic_sort<I, T>(input: I) -> Vec<T>
|
||||||
|
where
|
||||||
|
T: Ord + Clone,
|
||||||
|
I: Iterator<Item = T>,
|
||||||
|
{
|
||||||
|
let mut val: Vec<T> = input.collect();
|
||||||
|
val.sort();
|
||||||
|
val
|
||||||
|
}
|
183
pve-rs/vendor/apt-pkg-native/src/citer.rs
vendored
Normal file
183
pve-rs/vendor/apt-pkg-native/src/citer.rs
vendored
Normal file
@ -0,0 +1,183 @@
|
|||||||
|
use std::marker::PhantomData;
|
||||||
|
use std::ops::Deref;
|
||||||
|
|
||||||
|
pub trait RawIterator {
|
||||||
|
type View;
|
||||||
|
|
||||||
|
fn is_end(&self) -> bool;
|
||||||
|
fn next(&mut self);
|
||||||
|
|
||||||
|
fn as_view(&self) -> Self::View;
|
||||||
|
|
||||||
|
fn release(&mut self);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct CIterator<R>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
{
|
||||||
|
pub first: bool,
|
||||||
|
pub raw: R,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<R> Drop for CIterator<R>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
{
|
||||||
|
fn drop(&mut self) {
|
||||||
|
self.raw.release();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct Borrowed<'i, R>
|
||||||
|
where
|
||||||
|
R: 'i + RawIterator,
|
||||||
|
{
|
||||||
|
it: PhantomData<&'i CIterator<R>>,
|
||||||
|
val: R::View,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'i, R> Deref for Borrowed<'i, R>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
{
|
||||||
|
type Target = R::View;
|
||||||
|
|
||||||
|
fn deref(&self) -> &R::View {
|
||||||
|
&self.val
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<R> CIterator<R>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
{
|
||||||
|
pub fn next(&mut self) -> Option<Borrowed<R>> {
|
||||||
|
if self.raw.is_end() {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
|
||||||
|
if !self.first {
|
||||||
|
self.raw.next();
|
||||||
|
}
|
||||||
|
|
||||||
|
self.first = false;
|
||||||
|
|
||||||
|
// we don't want to observe the end marker
|
||||||
|
if self.raw.is_end() {
|
||||||
|
None
|
||||||
|
} else {
|
||||||
|
Some(Borrowed {
|
||||||
|
it: PhantomData,
|
||||||
|
val: self.raw.as_view(),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn map<F, B>(self, f: F) -> CMap<R, F>
|
||||||
|
where
|
||||||
|
F: FnMut(&R::View) -> B,
|
||||||
|
{
|
||||||
|
CMap { it: self, f }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn filter_map<F, B>(self, f: F) -> CFilterMap<R, F>
|
||||||
|
where
|
||||||
|
F: FnMut(&R::View) -> Option<B>,
|
||||||
|
{
|
||||||
|
CFilterMap { it: self, f }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn any<F>(mut self, mut f: F) -> bool
|
||||||
|
where
|
||||||
|
F: FnMut(&R::View) -> bool,
|
||||||
|
{
|
||||||
|
while let Some(view) = self.next() {
|
||||||
|
if (f)(&view) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
false
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn all<F>(mut self, mut f: F) -> bool
|
||||||
|
where
|
||||||
|
F: FnMut(&R::View) -> bool,
|
||||||
|
{
|
||||||
|
while let Some(view) = self.next() {
|
||||||
|
if !(f)(&view) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
true
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn count(mut self) -> usize {
|
||||||
|
// Not sure this is actually better than self.map(|_| ()).count()
|
||||||
|
|
||||||
|
let mut count = 0;
|
||||||
|
|
||||||
|
while !self.raw.is_end() {
|
||||||
|
self.raw.next();
|
||||||
|
count += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
count
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
|
||||||
|
pub struct CMap<R, F>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
{
|
||||||
|
it: CIterator<R>,
|
||||||
|
f: F,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<B, R, F> Iterator for CMap<R, F>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
F: FnMut(&R::View) -> B,
|
||||||
|
{
|
||||||
|
type Item = B;
|
||||||
|
|
||||||
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
|
match self.it.next() {
|
||||||
|
Some(ref x) => Some((self.f)(x)),
|
||||||
|
None => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[must_use = "iterator adaptors are lazy and do nothing unless consumed"]
|
||||||
|
pub struct CFilterMap<R, F>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
{
|
||||||
|
it: CIterator<R>,
|
||||||
|
f: F,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<B, R, F> Iterator for CFilterMap<R, F>
|
||||||
|
where
|
||||||
|
R: RawIterator,
|
||||||
|
F: FnMut(&R::View) -> Option<B>,
|
||||||
|
{
|
||||||
|
type Item = B;
|
||||||
|
|
||||||
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
|
loop {
|
||||||
|
match self.it.next() {
|
||||||
|
Some(ref x) => {
|
||||||
|
if let Some(y) = (self.f)(x) {
|
||||||
|
return Some(y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
None => return None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
86
pve-rs/vendor/apt-pkg-native/src/lib.rs
vendored
Normal file
86
pve-rs/vendor/apt-pkg-native/src/lib.rs
vendored
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
//! Here lies bindings to `libapt-pkg`, which is what the `apt`, `apt-get`, `apt-cache`, etc.
|
||||||
|
//! commands use to view and manipulate the state of packages on the system.
|
||||||
|
//!
|
||||||
|
//! Currently, not much is exposed. You can pretty much only view basic package
|
||||||
|
//! information, like with `apt-cache policy foo`.
|
||||||
|
//!
|
||||||
|
//! `libapt-pkg` has basically no documentation. `python-apt` is slightly better,
|
||||||
|
//! but is also pretty inconsistent on the documentation front. The design of this
|
||||||
|
//! crate is closer to `libapt-pkg`, despite it being pretty insane.
|
||||||
|
//!
|
||||||
|
//! The core concept here is an "iterator". Forget everything you know about iterators,
|
||||||
|
//! these iterators are pretty much pointers. The crate attempts to make them act
|
||||||
|
//! a bit more like Rust `Iterator`s, but is crippled by the insanity.
|
||||||
|
//!
|
||||||
|
//! Methods which "find" something will reposition one of these "iterators" at the right place
|
||||||
|
//! in an existing stream of items.
|
||||||
|
//!
|
||||||
|
//! I recommend using `.map()` to turn an "iterator" into a Rust type as soon as possible.
|
||||||
|
//! The returned map-like thing *is* a Rust `Iterator`, so you can do normal operations on it.
|
||||||
|
//!
|
||||||
|
//! Here's an example: normally you wouldn't need this ugly `.map(|_| ())` (read as "map anything
|
||||||
|
//! to the empty object"), but here, it is *also* converting a sh... apt "iterator" into a
|
||||||
|
//! real Iterator.
|
||||||
|
//!
|
||||||
|
//! ```rust,no_run
|
||||||
|
//! extern crate apt_pkg_native;
|
||||||
|
//! let mut cache = apt_pkg_native::Cache::get_singleton();
|
||||||
|
//! let total_packages = cache.iter().map(|_| ()).count();
|
||||||
|
//! ```
|
||||||
|
//!
|
||||||
|
//! `libapt-pkg` also just segfaults if you do anything wrong, or re-use anything at the wrong time,
|
||||||
|
//! or etc. I've tried to hide this, but I advise you not to push or outsmart the borrow checker.
|
||||||
|
|
||||||
|
mod citer;
|
||||||
|
mod raw;
|
||||||
|
pub mod sane;
|
||||||
|
pub mod simple;
|
||||||
|
|
||||||
|
pub use crate::sane::Cache;
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn pretty_print_all() {
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
let read_all_and_count = cache.iter().map(simple::BinaryPackageVersions::new).count();
|
||||||
|
assert!(read_all_and_count > 2);
|
||||||
|
assert_eq!(read_all_and_count, cache.iter().count());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn find_a_package() {
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
|
||||||
|
if let Some(view) = cache.find_by_name("apt").next() {
|
||||||
|
assert_eq!("apt", view.name());
|
||||||
|
} else {
|
||||||
|
panic!("not found!");
|
||||||
|
}
|
||||||
|
|
||||||
|
assert!(cache
|
||||||
|
.find_by_name("this-package-doesnt-exist-and-if-someone-makes-it-ill-be-really-angry")
|
||||||
|
.next()
|
||||||
|
.is_none());
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn compare_versions() {
|
||||||
|
use std::cmp::Ordering;
|
||||||
|
let cache = Cache::get_singleton();
|
||||||
|
assert_eq!(Ordering::Less, cache.compare_versions("3.0", "3.1"));
|
||||||
|
assert_eq!(Ordering::Greater, cache.compare_versions("3.1", "3.0"));
|
||||||
|
assert_eq!(Ordering::Equal, cache.compare_versions("3.0", "3.0"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn reload() {
|
||||||
|
let mut cache = Cache::get_singleton();
|
||||||
|
cache.reload();
|
||||||
|
cache.reload();
|
||||||
|
cache.reload();
|
||||||
|
cache.reload();
|
||||||
|
}
|
||||||
|
}
|
167
pve-rs/vendor/apt-pkg-native/src/raw.rs
vendored
Normal file
167
pve-rs/vendor/apt-pkg-native/src/raw.rs
vendored
Normal file
@ -0,0 +1,167 @@
|
|||||||
|
/// In general:
|
||||||
|
/// * `*mut c_void` are to be released by the appropriate function
|
||||||
|
/// * `*const c_chars` are short-term borrows
|
||||||
|
/// * `*mut c_chars` are to be freed by `libc::free`.
|
||||||
|
use std::sync::Mutex;
|
||||||
|
|
||||||
|
use lazy_static::lazy_static;
|
||||||
|
use libc::c_char;
|
||||||
|
use libc::c_void;
|
||||||
|
|
||||||
|
pub type PCache = *mut c_void;
|
||||||
|
pub type PPkgIterator = *mut c_void;
|
||||||
|
pub type PVerIterator = *mut c_void;
|
||||||
|
pub type PDepIterator = *mut c_void;
|
||||||
|
pub type PVerFileIterator = *mut c_void;
|
||||||
|
pub type PPkgFileIterator = *mut c_void;
|
||||||
|
pub type PVerFileParser = *mut c_void;
|
||||||
|
|
||||||
|
#[link(name = "apt-pkg-c", kind = "static")]
|
||||||
|
#[link(name = "apt-pkg")]
|
||||||
|
extern "C" {
|
||||||
|
/// Must be called exactly once, before anything else?
|
||||||
|
fn init_config_system();
|
||||||
|
fn pkg_cache_create() -> PCache;
|
||||||
|
fn pkg_cache_release(cache: PCache);
|
||||||
|
|
||||||
|
pub fn pkg_cache_compare_versions(
|
||||||
|
cache: PCache,
|
||||||
|
left: *const c_char,
|
||||||
|
right: *const c_char,
|
||||||
|
) -> i32;
|
||||||
|
|
||||||
|
// Package iterators
|
||||||
|
// =================
|
||||||
|
|
||||||
|
pub fn pkg_cache_pkg_iter(cache: PCache) -> PPkgIterator;
|
||||||
|
pub fn pkg_cache_find_name(cache: PCache, name: *const c_char) -> PPkgIterator;
|
||||||
|
|
||||||
|
#[cfg(not(feature = "alt-linux"))]
|
||||||
|
pub fn pkg_cache_find_name_arch(
|
||||||
|
cache: PCache,
|
||||||
|
name: *const c_char,
|
||||||
|
arch: *const c_char,
|
||||||
|
) -> PPkgIterator;
|
||||||
|
#[cfg(feature = "alt-linux")]
|
||||||
|
pub fn pkg_cache_find_name_arch(
|
||||||
|
cache: PCache,
|
||||||
|
name: *const c_char,
|
||||||
|
) -> PPkgIterator;
|
||||||
|
|
||||||
|
pub fn pkg_iter_release(iterator: PPkgIterator);
|
||||||
|
|
||||||
|
pub fn pkg_iter_next(iterator: PPkgIterator);
|
||||||
|
pub fn pkg_iter_end(iterator: PPkgIterator) -> bool;
|
||||||
|
|
||||||
|
// Package iterator accessors
|
||||||
|
// ==========================
|
||||||
|
|
||||||
|
pub fn pkg_iter_name(iterator: PPkgIterator) -> *const c_char;
|
||||||
|
pub fn pkg_iter_arch(iterator: PPkgIterator) -> *const c_char;
|
||||||
|
pub fn pkg_iter_current_version(iterator: PPkgIterator) -> *const c_char;
|
||||||
|
pub fn pkg_iter_candidate_version(iterator: PPkgIterator) -> *const c_char;
|
||||||
|
|
||||||
|
// Version iterators
|
||||||
|
// =================
|
||||||
|
|
||||||
|
pub fn pkg_iter_ver_iter(pkg: PPkgIterator) -> PVerIterator;
|
||||||
|
pub fn ver_iter_release(iterator: PVerIterator);
|
||||||
|
|
||||||
|
pub fn ver_iter_next(iterator: PVerIterator);
|
||||||
|
pub fn ver_iter_end(iterator: PVerIterator) -> bool;
|
||||||
|
|
||||||
|
// Version accessors
|
||||||
|
// =================
|
||||||
|
|
||||||
|
pub fn ver_iter_version(iterator: PVerIterator) -> *mut c_char;
|
||||||
|
pub fn ver_iter_section(iterator: PVerIterator) -> *mut c_char;
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub fn ver_iter_source_package(iterator: PVerIterator) -> *mut c_char;
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub fn ver_iter_source_version(iterator: PVerIterator) -> *mut c_char;
|
||||||
|
pub fn ver_iter_arch(iterator: PVerIterator) -> *mut c_char;
|
||||||
|
pub fn ver_iter_priority_type(iterator: PVerIterator) -> *mut c_char;
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub fn ver_iter_priority(iterator: PVerIterator) -> i32;
|
||||||
|
|
||||||
|
// Dependency iterators
|
||||||
|
// ====================
|
||||||
|
|
||||||
|
pub fn ver_iter_dep_iter(iterator: PVerIterator) -> PDepIterator;
|
||||||
|
pub fn dep_iter_release(iterator: PDepIterator);
|
||||||
|
|
||||||
|
pub fn dep_iter_next(iterator: PDepIterator);
|
||||||
|
pub fn dep_iter_end(iterator: PDepIterator) -> bool;
|
||||||
|
|
||||||
|
// Dependency accessors
|
||||||
|
// ====================
|
||||||
|
|
||||||
|
pub fn dep_iter_target_pkg(iterator: PDepIterator) -> PPkgIterator;
|
||||||
|
pub fn dep_iter_target_ver(iterator: PDepIterator) -> *const c_char;
|
||||||
|
pub fn dep_iter_comp_type(iterator: PDepIterator) -> *const c_char;
|
||||||
|
pub fn dep_iter_dep_type(iterator: PDepIterator) -> *const c_char;
|
||||||
|
|
||||||
|
pub fn ver_iter_ver_file_iter(iterator: PVerIterator) -> PVerFileIterator;
|
||||||
|
pub fn ver_file_iter_release(iterator: PVerFileIterator);
|
||||||
|
|
||||||
|
pub fn ver_file_iter_next(iterator: PVerFileIterator);
|
||||||
|
pub fn ver_file_iter_end(iterator: PVerFileIterator) -> bool;
|
||||||
|
|
||||||
|
pub fn ver_file_iter_get_parser(iterator: PVerFileIterator) -> PVerFileParser;
|
||||||
|
pub fn ver_file_parser_short_desc(parser: PVerFileParser) -> *const c_char;
|
||||||
|
pub fn ver_file_parser_long_desc(parser: PVerFileParser) -> *const c_char;
|
||||||
|
pub fn ver_file_parser_maintainer(parser: PVerFileParser) -> *const c_char;
|
||||||
|
pub fn ver_file_parser_homepage(parser: PVerFileParser) -> *const c_char;
|
||||||
|
|
||||||
|
pub fn ver_file_iter_pkg_file_iter(iterator: PVerFileIterator) -> PPkgFileIterator;
|
||||||
|
pub fn pkg_file_iter_release(iterator: PPkgFileIterator);
|
||||||
|
|
||||||
|
pub fn pkg_file_iter_next(iterator: PPkgFileIterator);
|
||||||
|
pub fn pkg_file_iter_end(iterator: PPkgFileIterator) -> bool;
|
||||||
|
|
||||||
|
pub fn pkg_file_iter_file_name(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_archive(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_version(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_origin(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_codename(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_label(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_site(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_component(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_architecture(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
pub fn pkg_file_iter_index_type(iterator: PPkgFileIterator) -> *const c_char;
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn pkg_cache_get_singleton() -> &'static CACHE_SINGLETON {
|
||||||
|
&CACHE_SINGLETON
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct CacheHolder {
|
||||||
|
pub ptr: PCache,
|
||||||
|
}
|
||||||
|
|
||||||
|
unsafe impl Send for CacheHolder {}
|
||||||
|
|
||||||
|
impl CacheHolder {
|
||||||
|
pub fn re_up(&mut self) {
|
||||||
|
unsafe {
|
||||||
|
pkg_cache_release(self.ptr);
|
||||||
|
self.ptr = pkg_cache_create();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lazy_static! {
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub static ref CACHE_SINGLETON: Mutex<CacheHolder> = {
|
||||||
|
unsafe {
|
||||||
|
init_config_system();
|
||||||
|
Mutex::new(CacheHolder {
|
||||||
|
ptr: pkg_cache_create()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
546
pve-rs/vendor/apt-pkg-native/src/sane.rs
vendored
Normal file
546
pve-rs/vendor/apt-pkg-native/src/sane.rs
vendored
Normal file
@ -0,0 +1,546 @@
|
|||||||
|
use std::cmp;
|
||||||
|
use std::ffi;
|
||||||
|
use std::marker::PhantomData;
|
||||||
|
use std::sync::MutexGuard;
|
||||||
|
|
||||||
|
use crate::citer::CIterator;
|
||||||
|
use crate::citer::RawIterator;
|
||||||
|
use crate::raw;
|
||||||
|
|
||||||
|
/// A reference to the package cache singleton,
|
||||||
|
/// from which most functionality can be accessed.
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct Cache {
|
||||||
|
ptr_mutex: &'static raw::CACHE_SINGLETON,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Cache {
|
||||||
|
/// Get a reference to the singleton.
|
||||||
|
pub fn get_singleton() -> Cache {
|
||||||
|
Cache {
|
||||||
|
ptr_mutex: raw::pkg_cache_get_singleton(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Drop the cache, and re-create it from scratch.
|
||||||
|
///
|
||||||
|
/// It's super important that there are no other outstanding
|
||||||
|
/// references to the cache at this point. Again, I remind you
|
||||||
|
/// not to try and outsmart the borrow checker. It doesn't know
|
||||||
|
/// how much trouble there is in here.
|
||||||
|
pub fn reload(&mut self) {
|
||||||
|
self.ptr_mutex.lock().expect("poisoned mutex").re_up()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Walk through all of the packages, in a random order.
|
||||||
|
///
|
||||||
|
/// If there are multiple architectures, multiple architectures will be returned.
|
||||||
|
///
|
||||||
|
/// See the module documentation for apologies about how this isn't an iterator.
|
||||||
|
pub fn iter(&mut self) -> CIterator<PkgIterator> {
|
||||||
|
let lock = self.ptr_mutex.lock().expect("poisoned mutex");
|
||||||
|
unsafe {
|
||||||
|
let raw_iter = raw::pkg_cache_pkg_iter(lock.ptr);
|
||||||
|
PkgIterator::new(lock, raw_iter)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Find a package by name. It's not clear whether this picks a random arch,
|
||||||
|
/// or the primary one.
|
||||||
|
///
|
||||||
|
/// The returned iterator will either be at the end, or at a package with the name.
|
||||||
|
pub fn find_by_name(&mut self, name: &str) -> CIterator<PkgIterator> {
|
||||||
|
let lock = self.ptr_mutex.lock().expect("poisoned mutex");
|
||||||
|
unsafe {
|
||||||
|
let name = ffi::CString::new(name).unwrap();
|
||||||
|
let ptr = raw::pkg_cache_find_name(lock.ptr, name.as_ptr());
|
||||||
|
PkgIterator::new(lock, ptr)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Find a package by name and architecture.
|
||||||
|
///
|
||||||
|
/// The returned iterator will either be at the end, or at a matching package.
|
||||||
|
pub fn find_by_name_arch(&mut self, name: &str, arch: &str) -> CIterator<PkgIterator> {
|
||||||
|
let lock = self.ptr_mutex.lock().expect("poisoned mutex");
|
||||||
|
unsafe {
|
||||||
|
let name = ffi::CString::new(name).unwrap();
|
||||||
|
let arch = ffi::CString::new(arch).unwrap();
|
||||||
|
|
||||||
|
#[cfg(feature = "alt-linux")]
|
||||||
|
let ptr = raw::pkg_cache_find_name_arch(lock.ptr, name.as_ptr());
|
||||||
|
|
||||||
|
#[cfg(not(feature = "alt-linux"))]
|
||||||
|
let ptr = raw::pkg_cache_find_name_arch(lock.ptr, name.as_ptr(), arch.as_ptr());
|
||||||
|
|
||||||
|
PkgIterator::new(lock, ptr)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Compare two versions, returning an `Ordering`, as used by most Rusty `sort()` methods.
|
||||||
|
///
|
||||||
|
/// This uses the "versioning scheme" currently set, which, in theory, can change,
|
||||||
|
/// but in practice is always the "Standard .deb" scheme. As of 2017, there aren't even any
|
||||||
|
/// other implementations. As such, this may eventually become a static method somewhere.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
/// # let mut cache = apt_pkg_native::Cache::get_singleton();
|
||||||
|
/// let mut packages = vec!["3.0", "3.1", "3.0~1"];
|
||||||
|
/// packages.sort_by(|left, right| cache.compare_versions(left, right));
|
||||||
|
/// assert_eq!(vec!["3.0~1", "3.0", "3.1"], packages);
|
||||||
|
/// ```
|
||||||
|
pub fn compare_versions(&self, left: &str, right: &str) -> cmp::Ordering {
|
||||||
|
unsafe {
|
||||||
|
let left = ffi::CString::new(left).unwrap();
|
||||||
|
let right = ffi::CString::new(right).unwrap();
|
||||||
|
|
||||||
|
let lock = self.ptr_mutex.lock().expect("poisoned mutex");
|
||||||
|
raw::pkg_cache_compare_versions(lock.ptr, left.as_ptr(), right.as_ptr()).cmp(&0)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An "iterator"/pointer to a point in a package list.
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct PkgIterator<'c> {
|
||||||
|
cache: MutexGuard<'c, raw::CacheHolder>,
|
||||||
|
ptr: raw::PPkgIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> PkgIterator<'c> {
|
||||||
|
fn new(cache: MutexGuard<'c, raw::CacheHolder>, ptr: raw::PCache) -> CIterator<Self> {
|
||||||
|
CIterator {
|
||||||
|
first: true,
|
||||||
|
raw: PkgIterator { cache, ptr },
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: could this be a ref to the iterator?
|
||||||
|
// TODO: Can't get the lifetimes to work.
|
||||||
|
pub struct PkgView<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PPkgIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> RawIterator for PkgIterator<'c> {
|
||||||
|
type View = PkgView<'c>;
|
||||||
|
|
||||||
|
fn is_end(&self) -> bool {
|
||||||
|
unsafe { raw::pkg_iter_end(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn next(&mut self) {
|
||||||
|
unsafe { raw::pkg_iter_next(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn as_view(&self) -> Self::View {
|
||||||
|
assert!(!self.is_end());
|
||||||
|
|
||||||
|
PkgView {
|
||||||
|
ptr: self.ptr,
|
||||||
|
cache: PhantomData,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn release(&mut self) {
|
||||||
|
unsafe { raw::pkg_iter_release(self.ptr) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Actual accessors
|
||||||
|
impl<'c> PkgView<'c> {
|
||||||
|
pub fn name(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::pkg_iter_name(self.ptr))
|
||||||
|
.expect("packages always have names")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn arch(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::pkg_iter_arch(self.ptr))
|
||||||
|
.expect("packages always have architectures")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn current_version(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_iter_current_version(self.ptr)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn candidate_version(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_iter_candidate_version(self.ptr)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn versions(&self) -> CIterator<VerIterator> {
|
||||||
|
CIterator {
|
||||||
|
first: true,
|
||||||
|
raw: VerIterator {
|
||||||
|
cache: PhantomData,
|
||||||
|
ptr: unsafe { raw::pkg_iter_ver_iter(self.ptr) },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Represents a single PkgView without associated PkgIterator. Derefs to
|
||||||
|
/// regular PkgView and releases the internal iterator on drop.
|
||||||
|
pub struct SinglePkgView<'c> {
|
||||||
|
view: PkgView<'c>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> std::ops::Deref for SinglePkgView<'c> {
|
||||||
|
type Target = PkgView<'c>;
|
||||||
|
|
||||||
|
fn deref(&self) -> &Self::Target {
|
||||||
|
&self.view
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> Drop for SinglePkgView<'c> {
|
||||||
|
fn drop(&mut self) {
|
||||||
|
unsafe {
|
||||||
|
raw::pkg_iter_release(self.view.ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An "iterator"/pointer to a point in a version list.
|
||||||
|
pub struct VerIterator<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PVerIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct VerView<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PVerIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> RawIterator for VerIterator<'c> {
|
||||||
|
type View = VerView<'c>;
|
||||||
|
|
||||||
|
fn is_end(&self) -> bool {
|
||||||
|
unsafe { raw::ver_iter_end(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn next(&mut self) {
|
||||||
|
unsafe { raw::ver_iter_next(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn as_view(&self) -> Self::View {
|
||||||
|
assert!(!self.is_end());
|
||||||
|
|
||||||
|
VerView {
|
||||||
|
ptr: self.ptr,
|
||||||
|
cache: self.cache,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn release(&mut self) {
|
||||||
|
unsafe { raw::ver_iter_release(self.ptr) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Actual accessors
|
||||||
|
impl<'c> VerView<'c> {
|
||||||
|
pub fn version(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::ver_iter_version(self.ptr))
|
||||||
|
.expect("versions always have a version")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn arch(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::ver_iter_arch(self.ptr))
|
||||||
|
.expect("versions always have an arch")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn section(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_iter_section(self.ptr)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn priority_type(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_iter_priority_type(self.ptr)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub fn source_package(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::ver_iter_source_package(self.ptr))
|
||||||
|
.expect("versions always have a source package")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub fn source_version(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::ver_iter_source_version(self.ptr))
|
||||||
|
.expect("versions always have a source_version")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub fn priority(&self) -> i32 {
|
||||||
|
unsafe { raw::ver_iter_priority(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn origin_iter(&self) -> CIterator<VerFileIterator> {
|
||||||
|
CIterator {
|
||||||
|
first: true,
|
||||||
|
raw: VerFileIterator {
|
||||||
|
cache: PhantomData,
|
||||||
|
ptr: unsafe { raw::ver_iter_ver_file_iter(self.ptr) },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn dep_iter(&self) -> CIterator<DepIterator> {
|
||||||
|
CIterator {
|
||||||
|
first: true,
|
||||||
|
raw: DepIterator {
|
||||||
|
cache: PhantomData,
|
||||||
|
ptr: unsafe { raw::ver_iter_dep_iter(self.ptr) },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An "iterator"/pointer to a point in a dependency list.
|
||||||
|
pub struct DepIterator<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PDepIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct DepView<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PDepIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> RawIterator for DepIterator<'c> {
|
||||||
|
type View = DepView<'c>;
|
||||||
|
|
||||||
|
fn is_end(&self) -> bool {
|
||||||
|
unsafe { raw::dep_iter_end(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn next(&mut self) {
|
||||||
|
unsafe { raw::dep_iter_next(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn as_view(&self) -> Self::View {
|
||||||
|
assert!(!self.is_end());
|
||||||
|
|
||||||
|
DepView {
|
||||||
|
ptr: self.ptr,
|
||||||
|
cache: self.cache,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn release(&mut self) {
|
||||||
|
unsafe { raw::dep_iter_release(self.ptr) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Actual accessors
|
||||||
|
impl<'c> DepView<'c> {
|
||||||
|
pub fn target_pkg(&self) -> SinglePkgView {
|
||||||
|
let ptr = unsafe { raw::dep_iter_target_pkg(self.ptr) };
|
||||||
|
SinglePkgView {
|
||||||
|
view: PkgView {
|
||||||
|
cache: self.cache,
|
||||||
|
ptr,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn target_ver(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::dep_iter_target_ver(self.ptr))
|
||||||
|
.expect("dependency always has target version")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn comp_type(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::dep_iter_comp_type(self.ptr))
|
||||||
|
.expect("dependency always has comp type")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn dep_type(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::dep_iter_dep_type(self.ptr))
|
||||||
|
.expect("dependency always has dep type")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An "iterator"/pointer to a point in a version's file list(?).
|
||||||
|
pub struct VerFileIterator<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PVerFileIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: could this be a ref to the iterator?
|
||||||
|
// TODO: Can't get the lifetimes to work.
|
||||||
|
pub struct VerFileView<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PVerFileIterator,
|
||||||
|
parser: raw::PVerFileParser,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> RawIterator for VerFileIterator<'c> {
|
||||||
|
type View = VerFileView<'c>;
|
||||||
|
|
||||||
|
fn is_end(&self) -> bool {
|
||||||
|
unsafe { raw::ver_file_iter_end(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn next(&mut self) {
|
||||||
|
unsafe { raw::ver_file_iter_next(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn as_view(&self) -> Self::View {
|
||||||
|
assert!(!self.is_end());
|
||||||
|
|
||||||
|
let parser = unsafe { raw::ver_file_iter_get_parser(self.ptr) };
|
||||||
|
|
||||||
|
VerFileView {
|
||||||
|
ptr: self.ptr,
|
||||||
|
cache: self.cache,
|
||||||
|
parser,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn release(&mut self) {
|
||||||
|
unsafe { raw::ver_file_iter_release(self.ptr) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> VerFileView<'c> {
|
||||||
|
pub fn file(&self) -> CIterator<PkgFileIterator> {
|
||||||
|
CIterator {
|
||||||
|
first: true,
|
||||||
|
raw: PkgFileIterator {
|
||||||
|
cache: PhantomData,
|
||||||
|
ptr: unsafe { raw::ver_file_iter_pkg_file_iter(self.ptr) },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn short_desc(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_short_desc(self.parser)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn long_desc(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_long_desc(self.parser)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn maintainer(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_maintainer(self.parser)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn homepage(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::ver_file_parser_homepage(self.parser)) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An "iterator"/pointer to a point in a file list.
|
||||||
|
pub struct PkgFileIterator<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PPkgFileIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: could this be a ref to the iterator?
|
||||||
|
// TODO: Can't get the lifetimes to work.
|
||||||
|
pub struct PkgFileView<'c> {
|
||||||
|
cache: PhantomData<&'c MutexGuard<'c, raw::CacheHolder>>,
|
||||||
|
ptr: raw::PPkgFileIterator,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> RawIterator for PkgFileIterator<'c> {
|
||||||
|
type View = PkgFileView<'c>;
|
||||||
|
|
||||||
|
fn is_end(&self) -> bool {
|
||||||
|
unsafe { raw::pkg_file_iter_end(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn next(&mut self) {
|
||||||
|
unsafe { raw::pkg_file_iter_next(self.ptr) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn as_view(&self) -> Self::View {
|
||||||
|
assert!(!self.is_end());
|
||||||
|
|
||||||
|
PkgFileView {
|
||||||
|
ptr: self.ptr,
|
||||||
|
cache: self.cache,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn release(&mut self) {
|
||||||
|
unsafe { raw::pkg_file_iter_release(self.ptr) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'c> PkgFileView<'c> {
|
||||||
|
pub fn file_name(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::pkg_file_iter_file_name(self.ptr))
|
||||||
|
.expect("package file always has a file name")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn archive(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::pkg_file_iter_archive(self.ptr))
|
||||||
|
.expect("package file always has an archive")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn version(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_file_iter_version(self.ptr)) }
|
||||||
|
}
|
||||||
|
pub fn origin(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_file_iter_origin(self.ptr)) }
|
||||||
|
}
|
||||||
|
pub fn codename(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_file_iter_codename(self.ptr)) }
|
||||||
|
}
|
||||||
|
pub fn label(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_file_iter_label(self.ptr)) }
|
||||||
|
}
|
||||||
|
pub fn site(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_file_iter_site(self.ptr)) }
|
||||||
|
}
|
||||||
|
pub fn component(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::pkg_file_iter_component(self.ptr))
|
||||||
|
.expect("package file always has a component")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn architecture(&self) -> Option<String> {
|
||||||
|
unsafe { make_owned_ascii_string(raw::pkg_file_iter_architecture(self.ptr)) }
|
||||||
|
}
|
||||||
|
pub fn index_type(&self) -> String {
|
||||||
|
unsafe {
|
||||||
|
make_owned_ascii_string(raw::pkg_file_iter_index_type(self.ptr))
|
||||||
|
.expect("package file always has a index_type")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unsafe fn make_owned_ascii_string(ptr: *const libc::c_char) -> Option<String> {
|
||||||
|
if ptr.is_null() {
|
||||||
|
None
|
||||||
|
} else {
|
||||||
|
Some(
|
||||||
|
ffi::CStr::from_ptr(ptr)
|
||||||
|
.to_str()
|
||||||
|
.expect("value should always be low-ascii")
|
||||||
|
.to_string(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
189
pve-rs/vendor/apt-pkg-native/src/simple.rs
vendored
Normal file
189
pve-rs/vendor/apt-pkg-native/src/simple.rs
vendored
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
//! Some structs representing basic concepts, and utilities to copy out of "iterators".
|
||||||
|
|
||||||
|
use std::fmt;
|
||||||
|
|
||||||
|
use crate::sane;
|
||||||
|
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
|
pub struct BinaryPackage {
|
||||||
|
pub name: String,
|
||||||
|
pub arch: String,
|
||||||
|
pub current_version: Option<String>,
|
||||||
|
pub candidate_version: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BinaryPackage {
|
||||||
|
pub fn new(view: &sane::PkgView) -> Self {
|
||||||
|
BinaryPackage {
|
||||||
|
name: view.name(),
|
||||||
|
arch: view.arch(),
|
||||||
|
current_version: view.current_version(),
|
||||||
|
candidate_version: view.candidate_version(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for BinaryPackage {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
write!(f, "{}:{}", self.name, self.arch)?;
|
||||||
|
if let Some(ref version) = self.current_version {
|
||||||
|
write!(f, " @ {}", version)?;
|
||||||
|
}
|
||||||
|
if let Some(ref version) = self.candidate_version {
|
||||||
|
write!(f, " -> {}", version)?;
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
|
pub struct Version {
|
||||||
|
pub version: String,
|
||||||
|
pub arch: String,
|
||||||
|
pub section: Option<String>,
|
||||||
|
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub source_package: String,
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub source_version: String,
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
pub priority: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Version {
|
||||||
|
pub fn new(view: &sane::VerView) -> Self {
|
||||||
|
Version {
|
||||||
|
version: view.version(),
|
||||||
|
arch: view.arch(),
|
||||||
|
section: view.section(),
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
source_package: view.source_package(),
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
source_version: view.source_version(),
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
priority: view.priority(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for Version {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
write!(f, "{}:{}", self.version, self.arch)?;
|
||||||
|
if let Some(ref section) = self.section {
|
||||||
|
write!(f, " in {}", section)?;
|
||||||
|
}
|
||||||
|
#[cfg(not(feature = "ye-olde-apt"))]
|
||||||
|
write!(
|
||||||
|
f,
|
||||||
|
" from {}:{} at {}",
|
||||||
|
self.source_package, self.source_version, self.priority,
|
||||||
|
)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
|
pub struct Origin {
|
||||||
|
pub file_name: String,
|
||||||
|
pub archive: String,
|
||||||
|
pub version: Option<String>,
|
||||||
|
pub origin: Option<String>,
|
||||||
|
pub codename: Option<String>,
|
||||||
|
pub label: Option<String>,
|
||||||
|
pub site: Option<String>,
|
||||||
|
pub component: String,
|
||||||
|
pub architecture: Option<String>,
|
||||||
|
pub index_type: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Origin {
|
||||||
|
pub fn from_ver_file(view: &sane::VerFileView) -> Option<Self> {
|
||||||
|
// TODO: don't think this deref-ref should really be necessary?
|
||||||
|
view.file().next().map(|x| Self::new(&*x))
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn new(view: &sane::PkgFileView) -> Self {
|
||||||
|
Origin {
|
||||||
|
file_name: view.file_name(),
|
||||||
|
archive: view.archive(),
|
||||||
|
version: view.version(),
|
||||||
|
origin: view.origin(),
|
||||||
|
codename: view.codename(),
|
||||||
|
label: view.label(),
|
||||||
|
site: view.site(),
|
||||||
|
component: view.component(),
|
||||||
|
architecture: view.architecture(),
|
||||||
|
index_type: view.index_type(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for Origin {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
// trying to simulate apt-cache policy, but a lot of information is missing
|
||||||
|
if self.site.is_some()
|
||||||
|
&& self.origin.is_some()
|
||||||
|
&& self.label.is_some()
|
||||||
|
&& self.codename.is_some()
|
||||||
|
&& self.architecture.is_some()
|
||||||
|
{
|
||||||
|
write!(
|
||||||
|
f,
|
||||||
|
"TODO://{}/TODO(o:{}/l:{}/c:{}) {}/{} {} (f:{})",
|
||||||
|
self.site.as_ref().unwrap(),
|
||||||
|
self.origin.as_ref().unwrap(),
|
||||||
|
self.label.as_ref().unwrap(),
|
||||||
|
self.codename.as_ref().unwrap(),
|
||||||
|
self.archive,
|
||||||
|
self.component,
|
||||||
|
self.architecture.as_ref().unwrap(),
|
||||||
|
self.file_name
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
write!(f, "{}", self.file_name)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
|
pub struct VersionOrigins {
|
||||||
|
pub version: Version,
|
||||||
|
pub origins: Vec<Origin>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl VersionOrigins {
|
||||||
|
pub fn new(view: &sane::VerView) -> Self {
|
||||||
|
VersionOrigins {
|
||||||
|
version: Version::new(view),
|
||||||
|
origins: view
|
||||||
|
.origin_iter()
|
||||||
|
.map(|o| {
|
||||||
|
Origin::from_ver_file(o)
|
||||||
|
.expect("a version's origin should always have a backing file")
|
||||||
|
})
|
||||||
|
.collect(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
|
pub struct BinaryPackageVersions {
|
||||||
|
pub pkg: BinaryPackage,
|
||||||
|
pub versions: Vec<Version>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BinaryPackageVersions {
|
||||||
|
pub fn new(view: &sane::PkgView) -> Self {
|
||||||
|
BinaryPackageVersions {
|
||||||
|
pkg: BinaryPackage::new(view),
|
||||||
|
versions: view.versions().map(Version::new).collect(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for BinaryPackageVersions {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
write!(f, "{} + {} versions", self.pkg, self.versions.len())
|
||||||
|
}
|
||||||
|
}
|
2
pve-rs/vendor/autocfg/.cargo-checksum.json
vendored
2
pve-rs/vendor/autocfg/.cargo-checksum.json
vendored
@ -1 +1 @@
|
|||||||
{"files":{"Cargo.lock":"8e60b691c883629c1e19c8dad7c4c18cded1a85c2e8f2e2a77e7a96957f865a7","Cargo.toml":"f8c2d5675773b7ddff8801c3c17ff9d26e9632fe2027a6b81ceb7bda67d71bfd","LICENSE-APACHE":"a60eea817514531668d7e00765731449fe14d059d3249e0bc93b36de45f759f2","LICENSE-MIT":"27995d58ad5c1145c1a8cd86244ce844886958a35eb2b78c6b772748669999ac","README.md":"51238410cbbb06b149a794d954ff4d5943da566a97e71dc3aa8b5fa5a9b538b6","examples/integers.rs":"589ff4271566dfa322becddf3e2c7b592e6e0bc97b02892ce75619b7e452e930","examples/nightly.rs":"ac8b5a9aa1e04465e44f5053b3c899b635e07af058c73aa8b45176bf4b5912f9","examples/paths.rs":"1b30e466b824ce8df7ad0a55334424131d9d2573d6cf9f7d5d50c09c8901d526","examples/traits.rs":"cbee6a3e1f7db60b02ae25b714926517144a77cb492021f492774cf0e1865a9e","examples/versions.rs":"38535e6d9f5bfae0de474a3db79a40e8f5da8ba9334c5ff4c363de9bc99d4d12","src/error.rs":"fd8ff67c64f7cd1b9f81325a81de4baa34c39d6ae298bdb33f9829cc91acac39","src/lib.rs":"7b00cd501b52bab797bf047ada2a446e16fc2b8b05567670d8b8b7ada3179f55","src/rustc.rs":"a8a213ddb64a05c1a1af933bcb331a98879e942b167c33d8f94f9f60ebb14e29","src/tests.rs":"594a1cff6fef4a0f8b5f962a668fda4030db5005f37f01eeb06d692fc48a60df","src/version.rs":"4f7d23b36f01c7be1871be86c038d6cb4689e145d67c82d3793690e9aa05b133","tests/no_std.rs":"cc5619466c6e955552f30ed2f80ba8ddf45c3d5d257f628f54dedc0da978f6aa","tests/rustflags.rs":"5c8169b88216055019db61b5d7baf4abdf675e3b14b54f5037bb1e3acd0a5d3f","tests/wrap_ignored":"a9e241edf584a0702066b25bc15c5bbfd8a1019e14fb655fc4f47a67360065ca","tests/wrappers.rs":"e8eb0eb5ac28ecd9e3473b5ddc321b1d4d523a6fb0c072255ac37d40674aa35c"},"package":"0c4b4d0bd25bd0b74681c0ad21497610ce1b7c91b1022cd21c80c6fbdd9476b0"}
|
{"files":{"Cargo.lock":"c53e68eabea3d0b6dbc762cdc0c0bd105a7ac97c76e0b8c5f492d0b94074469c","Cargo.toml":"624e428251fce7244aa71fe7764c1556bc8077ee4579ad7e5803cc8a74061673","LICENSE-APACHE":"a60eea817514531668d7e00765731449fe14d059d3249e0bc93b36de45f759f2","LICENSE-MIT":"27995d58ad5c1145c1a8cd86244ce844886958a35eb2b78c6b772748669999ac","README.md":"21308cfaaea9e841e01a43b7ec77304c1daeea8d0e3ec8fe5022d8e56acc4eb2","examples/integers.rs":"589ff4271566dfa322becddf3e2c7b592e6e0bc97b02892ce75619b7e452e930","examples/nightly.rs":"ac8b5a9aa1e04465e44f5053b3c899b635e07af058c73aa8b45176bf4b5912f9","examples/paths.rs":"1b30e466b824ce8df7ad0a55334424131d9d2573d6cf9f7d5d50c09c8901d526","examples/traits.rs":"cbee6a3e1f7db60b02ae25b714926517144a77cb492021f492774cf0e1865a9e","examples/versions.rs":"38535e6d9f5bfae0de474a3db79a40e8f5da8ba9334c5ff4c363de9bc99d4d12","src/error.rs":"fd8ff67c64f7cd1b9f81325a81de4baa34c39d6ae298bdb33f9829cc91acac39","src/lib.rs":"b40828305eb18bcaad11608fbbf82d97fe381803fbf1b89a1511f0675ba49e6c","src/rustc.rs":"a8a213ddb64a05c1a1af933bcb331a98879e942b167c33d8f94f9f60ebb14e29","src/tests.rs":"b39f4d880ad343e65307a9e0c381954ea27adce4732f825516ce7952e2e5a91d","src/version.rs":"4f7d23b36f01c7be1871be86c038d6cb4689e145d67c82d3793690e9aa05b133","tests/no_std.rs":"18859dc4992fe1769887bde05f03d28f1ce524eafd17646d3fbcb4379422761a","tests/rustflags.rs":"e8ded4d57ba25379a38ab48456d67df14f82abbbb5f6bb66221c6decbcb517a3","tests/support/mod.rs":"32087d365b438ac3f62df9bb066d8d648b80cb130a5c777afcb2f21fbb68d88e","tests/tests.rs":"abd41a6a937ee58d7dcb541384705f87ec47294f6af6dab821441d50fd66ee7d","tests/wrap_ignored":"a9e241edf584a0702066b25bc15c5bbfd8a1019e14fb655fc4f47a67360065ca","tests/wrappers.rs":"b5137fe36768eaef277fb8650b0fe45b2c675d9e60b1b49d39f2ec95082c285b"},"package":"ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26"}
|
5
pve-rs/vendor/autocfg/Cargo.lock
generated
vendored
5
pve-rs/vendor/autocfg/Cargo.lock
generated
vendored
@ -1,7 +1,6 @@
|
|||||||
# This file is automatically @generated by Cargo.
|
# This file is automatically @generated by Cargo.
|
||||||
# It is not intended for manual editing.
|
# It is not intended for manual editing.
|
||||||
version = 3
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "autocfg"
|
name = "autocfg"
|
||||||
version = "1.3.0"
|
version = "1.4.0"
|
||||||
|
|
||||||
|
47
pve-rs/vendor/autocfg/Cargo.toml
vendored
47
pve-rs/vendor/autocfg/Cargo.toml
vendored
@ -12,9 +12,14 @@
|
|||||||
[package]
|
[package]
|
||||||
rust-version = "1.0"
|
rust-version = "1.0"
|
||||||
name = "autocfg"
|
name = "autocfg"
|
||||||
version = "1.3.0"
|
version = "1.4.0"
|
||||||
authors = ["Josh Stone <cuviper@gmail.com>"]
|
authors = ["Josh Stone <cuviper@gmail.com>"]
|
||||||
|
build = false
|
||||||
exclude = ["/.github/**"]
|
exclude = ["/.github/**"]
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
description = "Automatic cfg for Rust compiler features"
|
description = "Automatic cfg for Rust compiler features"
|
||||||
documentation = "https://docs.rs/autocfg/"
|
documentation = "https://docs.rs/autocfg/"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
@ -27,4 +32,44 @@ categories = ["development-tools::build-utils"]
|
|||||||
license = "Apache-2.0 OR MIT"
|
license = "Apache-2.0 OR MIT"
|
||||||
repository = "https://github.com/cuviper/autocfg"
|
repository = "https://github.com/cuviper/autocfg"
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "autocfg"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "integers"
|
||||||
|
path = "examples/integers.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "nightly"
|
||||||
|
path = "examples/nightly.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "paths"
|
||||||
|
path = "examples/paths.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "traits"
|
||||||
|
path = "examples/traits.rs"
|
||||||
|
|
||||||
|
[[example]]
|
||||||
|
name = "versions"
|
||||||
|
path = "examples/versions.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "no_std"
|
||||||
|
path = "tests/no_std.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "rustflags"
|
||||||
|
path = "tests/rustflags.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "tests"
|
||||||
|
path = "tests/tests.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "wrappers"
|
||||||
|
path = "tests/wrappers.rs"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
7
pve-rs/vendor/autocfg/README.md
vendored
7
pve-rs/vendor/autocfg/README.md
vendored
@ -43,6 +43,13 @@ should only be used when the compiler supports it.
|
|||||||
|
|
||||||
## Release Notes
|
## Release Notes
|
||||||
|
|
||||||
|
- 1.4.0 (2024-09-26)
|
||||||
|
|
||||||
|
- Add `emit_possibility` for Rust 1.80's [checked cfgs], and call that
|
||||||
|
automatically for methods that conditionally `emit`, by @Techcable.
|
||||||
|
|
||||||
|
[checked cfgs]: https://blog.rust-lang.org/2024/05/06/check-cfg.html
|
||||||
|
|
||||||
- 1.3.0 (2024-05-03)
|
- 1.3.0 (2024-05-03)
|
||||||
|
|
||||||
- Add `probe_raw` for direct control of the code that will be test-compiled.
|
- Add `probe_raw` for direct control of the code that will be test-compiled.
|
||||||
|
87
pve-rs/vendor/autocfg/src/lib.rs
vendored
87
pve-rs/vendor/autocfg/src/lib.rs
vendored
@ -20,7 +20,8 @@
|
|||||||
//!
|
//!
|
||||||
//! fn main() {
|
//! fn main() {
|
||||||
//! # // Normally, cargo will set `OUT_DIR` for build scripts.
|
//! # // Normally, cargo will set `OUT_DIR` for build scripts.
|
||||||
//! # std::env::set_var("OUT_DIR", "target");
|
//! # let exe = std::env::current_exe().unwrap();
|
||||||
|
//! # std::env::set_var("OUT_DIR", exe.parent().unwrap());
|
||||||
//! let ac = autocfg::new();
|
//! let ac = autocfg::new();
|
||||||
//! ac.emit_has_type("i128");
|
//! ac.emit_has_type("i128");
|
||||||
//!
|
//!
|
||||||
@ -91,6 +92,7 @@ pub struct AutoCfg {
|
|||||||
target: Option<OsString>,
|
target: Option<OsString>,
|
||||||
no_std: bool,
|
no_std: bool,
|
||||||
rustflags: Vec<String>,
|
rustflags: Vec<String>,
|
||||||
|
uuid: u64,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Writes a config flag for rustc on standard out.
|
/// Writes a config flag for rustc on standard out.
|
||||||
@ -98,6 +100,12 @@ pub struct AutoCfg {
|
|||||||
/// This looks like: `cargo:rustc-cfg=CFG`
|
/// This looks like: `cargo:rustc-cfg=CFG`
|
||||||
///
|
///
|
||||||
/// Cargo will use this in arguments to rustc, like `--cfg CFG`.
|
/// Cargo will use this in arguments to rustc, like `--cfg CFG`.
|
||||||
|
///
|
||||||
|
/// This does not automatically call [`emit_possibility`]
|
||||||
|
/// so the compiler my generate an [`unexpected_cfgs` warning][check-cfg-flags].
|
||||||
|
/// However, all the builtin emit methods on [`AutoCfg`] call [`emit_possibility`] automatically.
|
||||||
|
///
|
||||||
|
/// [check-cfg-flags]: https://blog.rust-lang.org/2024/05/06/check-cfg.html
|
||||||
pub fn emit(cfg: &str) {
|
pub fn emit(cfg: &str) {
|
||||||
println!("cargo:rustc-cfg={}", cfg);
|
println!("cargo:rustc-cfg={}", cfg);
|
||||||
}
|
}
|
||||||
@ -123,6 +131,25 @@ pub fn rerun_env(var: &str) {
|
|||||||
println!("cargo:rerun-if-env-changed={}", var);
|
println!("cargo:rerun-if-env-changed={}", var);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Indicates to rustc that a config flag should not generate an [`unexpected_cfgs` warning][check-cfg-flags]
|
||||||
|
///
|
||||||
|
/// This looks like `cargo:rustc-check-cfg=cfg(VAR)`
|
||||||
|
///
|
||||||
|
/// As of rust 1.80, the compiler does [automatic checking of cfgs at compile time][check-cfg-flags].
|
||||||
|
/// All custom configuration flags must be known to rustc, or they will generate a warning.
|
||||||
|
/// This is done automatically when calling the builtin emit methods on [`AutoCfg`],
|
||||||
|
/// but not when calling [`autocfg::emit`](crate::emit) directly.
|
||||||
|
///
|
||||||
|
/// Versions before rust 1.80 will simply ignore this directive.
|
||||||
|
///
|
||||||
|
/// This function indicates to the compiler that the config flag never has a value.
|
||||||
|
/// If this is not desired, see [the blog post][check-cfg].
|
||||||
|
///
|
||||||
|
/// [check-cfg-flags]: https://blog.rust-lang.org/2024/05/06/check-cfg.html
|
||||||
|
pub fn emit_possibility(cfg: &str) {
|
||||||
|
println!("cargo:rustc-check-cfg=cfg({})", cfg);
|
||||||
|
}
|
||||||
|
|
||||||
/// Creates a new `AutoCfg` instance.
|
/// Creates a new `AutoCfg` instance.
|
||||||
///
|
///
|
||||||
/// # Panics
|
/// # Panics
|
||||||
@ -176,6 +203,7 @@ impl AutoCfg {
|
|||||||
rustc_version: rustc_version,
|
rustc_version: rustc_version,
|
||||||
target: target,
|
target: target,
|
||||||
no_std: false,
|
no_std: false,
|
||||||
|
uuid: new_uuid(),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Sanity check with and without `std`.
|
// Sanity check with and without `std`.
|
||||||
@ -227,21 +255,27 @@ impl AutoCfg {
|
|||||||
/// Sets a `cfg` value of the form `rustc_major_minor`, like `rustc_1_29`,
|
/// Sets a `cfg` value of the form `rustc_major_minor`, like `rustc_1_29`,
|
||||||
/// if the current `rustc` is at least that version.
|
/// if the current `rustc` is at least that version.
|
||||||
pub fn emit_rustc_version(&self, major: usize, minor: usize) {
|
pub fn emit_rustc_version(&self, major: usize, minor: usize) {
|
||||||
|
let cfg_flag = format!("rustc_{}_{}", major, minor);
|
||||||
|
emit_possibility(&cfg_flag);
|
||||||
if self.probe_rustc_version(major, minor) {
|
if self.probe_rustc_version(major, minor) {
|
||||||
emit(&format!("rustc_{}_{}", major, minor));
|
emit(&cfg_flag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn probe_fmt<'a>(&self, source: Arguments<'a>) -> Result<(), Error> {
|
/// Returns a new (hopefully unique) crate name for probes.
|
||||||
|
fn new_crate_name(&self) -> String {
|
||||||
#[allow(deprecated)]
|
#[allow(deprecated)]
|
||||||
static ID: AtomicUsize = ATOMIC_USIZE_INIT;
|
static ID: AtomicUsize = ATOMIC_USIZE_INIT;
|
||||||
|
|
||||||
let id = ID.fetch_add(1, Ordering::Relaxed);
|
let id = ID.fetch_add(1, Ordering::Relaxed);
|
||||||
|
format!("autocfg_{:016x}_{}", self.uuid, id)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn probe_fmt<'a>(&self, source: Arguments<'a>) -> Result<(), Error> {
|
||||||
let mut command = self.rustc.command();
|
let mut command = self.rustc.command();
|
||||||
command
|
command
|
||||||
.arg("--crate-name")
|
.arg("--crate-name")
|
||||||
.arg(format!("probe{}", id))
|
.arg(self.new_crate_name())
|
||||||
.arg("--crate-type=lib")
|
.arg("--crate-type=lib")
|
||||||
.arg("--out-dir")
|
.arg("--out-dir")
|
||||||
.arg(&self.out_dir)
|
.arg(&self.out_dir)
|
||||||
@ -291,7 +325,8 @@ impl AutoCfg {
|
|||||||
/// ```
|
/// ```
|
||||||
/// # extern crate autocfg;
|
/// # extern crate autocfg;
|
||||||
/// # // Normally, cargo will set `OUT_DIR` for build scripts.
|
/// # // Normally, cargo will set `OUT_DIR` for build scripts.
|
||||||
/// # std::env::set_var("OUT_DIR", "target");
|
/// # let exe = std::env::current_exe().unwrap();
|
||||||
|
/// # std::env::set_var("OUT_DIR", exe.parent().unwrap());
|
||||||
/// let ac = autocfg::new();
|
/// let ac = autocfg::new();
|
||||||
/// assert!(ac.probe_raw("#![no_builtins]").is_ok());
|
/// assert!(ac.probe_raw("#![no_builtins]").is_ok());
|
||||||
/// ```
|
/// ```
|
||||||
@ -306,7 +341,8 @@ impl AutoCfg {
|
|||||||
/// ```
|
/// ```
|
||||||
/// # extern crate autocfg;
|
/// # extern crate autocfg;
|
||||||
/// # // Normally, cargo will set `OUT_DIR` for build scripts.
|
/// # // Normally, cargo will set `OUT_DIR` for build scripts.
|
||||||
/// # std::env::set_var("OUT_DIR", "target");
|
/// # let exe = std::env::current_exe().unwrap();
|
||||||
|
/// # std::env::set_var("OUT_DIR", exe.parent().unwrap());
|
||||||
/// let ac = autocfg::new();
|
/// let ac = autocfg::new();
|
||||||
/// let code = r#"
|
/// let code = r#"
|
||||||
/// #![feature(slice_group_by)]
|
/// #![feature(slice_group_by)]
|
||||||
@ -336,8 +372,10 @@ impl AutoCfg {
|
|||||||
|
|
||||||
/// Emits a config value `has_CRATE` if `probe_sysroot_crate` returns true.
|
/// Emits a config value `has_CRATE` if `probe_sysroot_crate` returns true.
|
||||||
pub fn emit_sysroot_crate(&self, name: &str) {
|
pub fn emit_sysroot_crate(&self, name: &str) {
|
||||||
|
let cfg_flag = format!("has_{}", mangle(name));
|
||||||
|
emit_possibility(&cfg_flag);
|
||||||
if self.probe_sysroot_crate(name) {
|
if self.probe_sysroot_crate(name) {
|
||||||
emit(&format!("has_{}", mangle(name)));
|
emit(&cfg_flag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -357,13 +395,12 @@ impl AutoCfg {
|
|||||||
/// Any non-identifier characters in the `path` will be replaced with
|
/// Any non-identifier characters in the `path` will be replaced with
|
||||||
/// `_` in the generated config value.
|
/// `_` in the generated config value.
|
||||||
pub fn emit_has_path(&self, path: &str) {
|
pub fn emit_has_path(&self, path: &str) {
|
||||||
if self.probe_path(path) {
|
self.emit_path_cfg(path, &format!("has_{}", mangle(path)));
|
||||||
emit(&format!("has_{}", mangle(path)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Emits the given `cfg` value if `probe_path` returns true.
|
/// Emits the given `cfg` value if `probe_path` returns true.
|
||||||
pub fn emit_path_cfg(&self, path: &str, cfg: &str) {
|
pub fn emit_path_cfg(&self, path: &str, cfg: &str) {
|
||||||
|
emit_possibility(cfg);
|
||||||
if self.probe_path(path) {
|
if self.probe_path(path) {
|
||||||
emit(cfg);
|
emit(cfg);
|
||||||
}
|
}
|
||||||
@ -385,13 +422,12 @@ impl AutoCfg {
|
|||||||
/// Any non-identifier characters in the trait `name` will be replaced with
|
/// Any non-identifier characters in the trait `name` will be replaced with
|
||||||
/// `_` in the generated config value.
|
/// `_` in the generated config value.
|
||||||
pub fn emit_has_trait(&self, name: &str) {
|
pub fn emit_has_trait(&self, name: &str) {
|
||||||
if self.probe_trait(name) {
|
self.emit_trait_cfg(name, &format!("has_{}", mangle(name)));
|
||||||
emit(&format!("has_{}", mangle(name)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Emits the given `cfg` value if `probe_trait` returns true.
|
/// Emits the given `cfg` value if `probe_trait` returns true.
|
||||||
pub fn emit_trait_cfg(&self, name: &str, cfg: &str) {
|
pub fn emit_trait_cfg(&self, name: &str, cfg: &str) {
|
||||||
|
emit_possibility(cfg);
|
||||||
if self.probe_trait(name) {
|
if self.probe_trait(name) {
|
||||||
emit(cfg);
|
emit(cfg);
|
||||||
}
|
}
|
||||||
@ -413,13 +449,12 @@ impl AutoCfg {
|
|||||||
/// Any non-identifier characters in the type `name` will be replaced with
|
/// Any non-identifier characters in the type `name` will be replaced with
|
||||||
/// `_` in the generated config value.
|
/// `_` in the generated config value.
|
||||||
pub fn emit_has_type(&self, name: &str) {
|
pub fn emit_has_type(&self, name: &str) {
|
||||||
if self.probe_type(name) {
|
self.emit_type_cfg(name, &format!("has_{}", mangle(name)));
|
||||||
emit(&format!("has_{}", mangle(name)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Emits the given `cfg` value if `probe_type` returns true.
|
/// Emits the given `cfg` value if `probe_type` returns true.
|
||||||
pub fn emit_type_cfg(&self, name: &str, cfg: &str) {
|
pub fn emit_type_cfg(&self, name: &str, cfg: &str) {
|
||||||
|
emit_possibility(cfg);
|
||||||
if self.probe_type(name) {
|
if self.probe_type(name) {
|
||||||
emit(cfg);
|
emit(cfg);
|
||||||
}
|
}
|
||||||
@ -438,6 +473,7 @@ impl AutoCfg {
|
|||||||
|
|
||||||
/// Emits the given `cfg` value if `probe_expression` returns true.
|
/// Emits the given `cfg` value if `probe_expression` returns true.
|
||||||
pub fn emit_expression_cfg(&self, expr: &str, cfg: &str) {
|
pub fn emit_expression_cfg(&self, expr: &str, cfg: &str) {
|
||||||
|
emit_possibility(cfg);
|
||||||
if self.probe_expression(expr) {
|
if self.probe_expression(expr) {
|
||||||
emit(cfg);
|
emit(cfg);
|
||||||
}
|
}
|
||||||
@ -456,6 +492,7 @@ impl AutoCfg {
|
|||||||
|
|
||||||
/// Emits the given `cfg` value if `probe_constant` returns true.
|
/// Emits the given `cfg` value if `probe_constant` returns true.
|
||||||
pub fn emit_constant_cfg(&self, expr: &str, cfg: &str) {
|
pub fn emit_constant_cfg(&self, expr: &str, cfg: &str) {
|
||||||
|
emit_possibility(cfg);
|
||||||
if self.probe_constant(expr) {
|
if self.probe_constant(expr) {
|
||||||
emit(cfg);
|
emit(cfg);
|
||||||
}
|
}
|
||||||
@ -533,3 +570,21 @@ fn rustflags(target: &Option<OsString>, dir: &Path) -> Vec<String> {
|
|||||||
|
|
||||||
Vec::new()
|
Vec::new()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Generates a numeric ID to use in probe crate names.
|
||||||
|
///
|
||||||
|
/// This attempts to be random, within the constraints of Rust 1.0 and no dependencies.
|
||||||
|
fn new_uuid() -> u64 {
|
||||||
|
const FNV_OFFSET_BASIS: u64 = 0xcbf2_9ce4_8422_2325;
|
||||||
|
const FNV_PRIME: u64 = 0x100_0000_01b3;
|
||||||
|
|
||||||
|
// This set should have an actual random hasher.
|
||||||
|
let set: std::collections::HashSet<u64> = (0..256).collect();
|
||||||
|
|
||||||
|
// Feed the `HashSet`-shuffled order into FNV-1a.
|
||||||
|
let mut hash: u64 = FNV_OFFSET_BASIS;
|
||||||
|
for x in set {
|
||||||
|
hash = (hash ^ x).wrapping_mul(FNV_PRIME);
|
||||||
|
}
|
||||||
|
hash
|
||||||
|
}
|
||||||
|
136
pve-rs/vendor/autocfg/src/tests.rs
vendored
136
pve-rs/vendor/autocfg/src/tests.rs
vendored
@ -1,36 +1,5 @@
|
|||||||
use super::AutoCfg;
|
|
||||||
use std::env;
|
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
impl AutoCfg {
|
|
||||||
fn core_std(&self, path: &str) -> String {
|
|
||||||
let krate = if self.no_std { "core" } else { "std" };
|
|
||||||
format!("{}::{}", krate, path)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn assert_std(&self, probe_result: bool) {
|
|
||||||
assert_eq!(!self.no_std, probe_result);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn assert_min(&self, major: usize, minor: usize, probe_result: bool) {
|
|
||||||
assert_eq!(self.probe_rustc_version(major, minor), probe_result);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn for_test() -> Result<Self, super::error::Error> {
|
|
||||||
match env::var_os("TESTS_TARGET_DIR") {
|
|
||||||
Some(d) => Self::with_dir(d),
|
|
||||||
None => Self::with_dir("target"),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn autocfg_version() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
println!("version: {:?}", ac.rustc_version);
|
|
||||||
assert!(ac.probe_rustc_version(1, 0));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn version_cmp() {
|
fn version_cmp() {
|
||||||
use super::version::Version;
|
use super::version::Version;
|
||||||
@ -44,111 +13,6 @@ fn version_cmp() {
|
|||||||
assert!(Version::new(2, 0, 0) > v123);
|
assert!(Version::new(2, 0, 0) > v123);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_add() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
let add = ac.core_std("ops::Add");
|
|
||||||
let add_rhs = add.clone() + "<i32>";
|
|
||||||
let add_rhs_output = add.clone() + "<i32, Output = i32>";
|
|
||||||
let dyn_add_rhs_output = "dyn ".to_string() + &*add_rhs_output;
|
|
||||||
assert!(ac.probe_path(&add));
|
|
||||||
assert!(ac.probe_trait(&add));
|
|
||||||
assert!(ac.probe_trait(&add_rhs));
|
|
||||||
assert!(ac.probe_trait(&add_rhs_output));
|
|
||||||
ac.assert_min(1, 27, ac.probe_type(&dyn_add_rhs_output));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_as_ref() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
let as_ref = ac.core_std("convert::AsRef");
|
|
||||||
let as_ref_str = as_ref.clone() + "<str>";
|
|
||||||
let dyn_as_ref_str = "dyn ".to_string() + &*as_ref_str;
|
|
||||||
assert!(ac.probe_path(&as_ref));
|
|
||||||
assert!(ac.probe_trait(&as_ref_str));
|
|
||||||
assert!(ac.probe_type(&as_ref_str));
|
|
||||||
ac.assert_min(1, 27, ac.probe_type(&dyn_as_ref_str));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_i128() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
let i128_path = ac.core_std("i128");
|
|
||||||
ac.assert_min(1, 26, ac.probe_path(&i128_path));
|
|
||||||
ac.assert_min(1, 26, ac.probe_type("i128"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_sum() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
let sum = ac.core_std("iter::Sum");
|
|
||||||
let sum_i32 = sum.clone() + "<i32>";
|
|
||||||
let dyn_sum_i32 = "dyn ".to_string() + &*sum_i32;
|
|
||||||
ac.assert_min(1, 12, ac.probe_path(&sum));
|
|
||||||
ac.assert_min(1, 12, ac.probe_trait(&sum));
|
|
||||||
ac.assert_min(1, 12, ac.probe_trait(&sum_i32));
|
|
||||||
ac.assert_min(1, 12, ac.probe_type(&sum_i32));
|
|
||||||
ac.assert_min(1, 27, ac.probe_type(&dyn_sum_i32));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_std() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
ac.assert_std(ac.probe_sysroot_crate("std"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_alloc() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
ac.assert_min(1, 36, ac.probe_sysroot_crate("alloc"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_bad_sysroot_crate() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
assert!(!ac.probe_sysroot_crate("doesnt_exist"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_no_std() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
assert!(ac.probe_type("i32"));
|
|
||||||
assert!(ac.probe_type("[i32]"));
|
|
||||||
ac.assert_std(ac.probe_type("Vec<i32>"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_expression() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
assert!(ac.probe_expression(r#""test".trim_left()"#));
|
|
||||||
ac.assert_min(1, 30, ac.probe_expression(r#""test".trim_start()"#));
|
|
||||||
ac.assert_std(ac.probe_expression("[1, 2, 3].to_vec()"));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_constant() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
assert!(ac.probe_constant("1 + 2 + 3"));
|
|
||||||
ac.assert_min(1, 33, ac.probe_constant("{ let x = 1 + 2 + 3; x * x }"));
|
|
||||||
ac.assert_min(1, 39, ac.probe_constant(r#""test".len()"#));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn probe_raw() {
|
|
||||||
let ac = AutoCfg::for_test().unwrap();
|
|
||||||
let prefix = if ac.no_std { "#![no_std]\n" } else { "" };
|
|
||||||
let f = |s| format!("{}{}", prefix, s);
|
|
||||||
|
|
||||||
// This attribute **must** be used at the crate level.
|
|
||||||
assert!(ac.probe_raw(&f("#![no_builtins]")).is_ok());
|
|
||||||
|
|
||||||
assert!(ac.probe_raw(&f("#![deny(dead_code)] fn x() {}")).is_err());
|
|
||||||
assert!(ac.probe_raw(&f("#![allow(dead_code)] fn x() {}")).is_ok());
|
|
||||||
assert!(ac
|
|
||||||
.probe_raw(&f("#![deny(dead_code)] pub fn x() {}"))
|
|
||||||
.is_ok());
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn dir_does_not_contain_target() {
|
fn dir_does_not_contain_target() {
|
||||||
assert!(!super::dir_contains_target(
|
assert!(!super::dir_contains_target(
|
||||||
|
7
pve-rs/vendor/autocfg/tests/no_std.rs
vendored
7
pve-rs/vendor/autocfg/tests/no_std.rs
vendored
@ -2,6 +2,8 @@ extern crate autocfg;
|
|||||||
|
|
||||||
use std::env;
|
use std::env;
|
||||||
|
|
||||||
|
mod support;
|
||||||
|
|
||||||
/// Tests that we can control the use of `#![no_std]`.
|
/// Tests that we can control the use of `#![no_std]`.
|
||||||
#[test]
|
#[test]
|
||||||
fn no_std() {
|
fn no_std() {
|
||||||
@ -10,10 +12,9 @@ fn no_std() {
|
|||||||
env::remove_var("TARGET");
|
env::remove_var("TARGET");
|
||||||
|
|
||||||
// Use the same path as this test binary.
|
// Use the same path as this test binary.
|
||||||
let dir = env::current_exe().unwrap().parent().unwrap().to_path_buf();
|
let out = support::out_dir();
|
||||||
env::set_var("OUT_DIR", &format!("{}", dir.display()));
|
|
||||||
|
|
||||||
let mut ac = autocfg::AutoCfg::new().unwrap();
|
let mut ac = autocfg::AutoCfg::with_dir(out.as_ref()).unwrap();
|
||||||
assert!(!ac.no_std());
|
assert!(!ac.no_std());
|
||||||
assert!(ac.probe_path("std::mem"));
|
assert!(ac.probe_path("std::mem"));
|
||||||
|
|
||||||
|
13
pve-rs/vendor/autocfg/tests/rustflags.rs
vendored
13
pve-rs/vendor/autocfg/tests/rustflags.rs
vendored
@ -2,18 +2,19 @@ extern crate autocfg;
|
|||||||
|
|
||||||
use std::env;
|
use std::env;
|
||||||
|
|
||||||
|
mod support;
|
||||||
|
|
||||||
/// Tests that autocfg uses the RUSTFLAGS or CARGO_ENCODED_RUSTFLAGS
|
/// Tests that autocfg uses the RUSTFLAGS or CARGO_ENCODED_RUSTFLAGS
|
||||||
/// environment variables when running rustc.
|
/// environment variables when running rustc.
|
||||||
#[test]
|
#[test]
|
||||||
fn test_with_sysroot() {
|
fn test_with_sysroot() {
|
||||||
// Use the same path as this test binary.
|
let dir = support::exe_dir();
|
||||||
let dir = env::current_exe().unwrap().parent().unwrap().to_path_buf();
|
let out = support::out_dir();
|
||||||
env::set_var("OUT_DIR", &format!("{}", dir.display()));
|
|
||||||
|
|
||||||
// If we have encoded rustflags, they take precedence, even if empty.
|
// If we have encoded rustflags, they take precedence, even if empty.
|
||||||
env::set_var("CARGO_ENCODED_RUSTFLAGS", "");
|
env::set_var("CARGO_ENCODED_RUSTFLAGS", "");
|
||||||
env::set_var("RUSTFLAGS", &format!("-L {}", dir.display()));
|
env::set_var("RUSTFLAGS", &format!("-L {}", dir.display()));
|
||||||
let ac = autocfg::AutoCfg::new().unwrap();
|
let ac = autocfg::AutoCfg::with_dir(out.as_ref()).unwrap();
|
||||||
assert!(ac.probe_sysroot_crate("std"));
|
assert!(ac.probe_sysroot_crate("std"));
|
||||||
assert!(!ac.probe_sysroot_crate("autocfg"));
|
assert!(!ac.probe_sysroot_crate("autocfg"));
|
||||||
|
|
||||||
@ -22,12 +23,12 @@ fn test_with_sysroot() {
|
|||||||
"CARGO_ENCODED_RUSTFLAGS",
|
"CARGO_ENCODED_RUSTFLAGS",
|
||||||
&format!("-L\x1f{}", dir.display()),
|
&format!("-L\x1f{}", dir.display()),
|
||||||
);
|
);
|
||||||
let ac = autocfg::AutoCfg::new().unwrap();
|
let ac = autocfg::AutoCfg::with_dir(out.as_ref()).unwrap();
|
||||||
assert!(ac.probe_sysroot_crate("autocfg"));
|
assert!(ac.probe_sysroot_crate("autocfg"));
|
||||||
|
|
||||||
// Try the old-style RUSTFLAGS, ensuring HOST != TARGET.
|
// Try the old-style RUSTFLAGS, ensuring HOST != TARGET.
|
||||||
env::remove_var("CARGO_ENCODED_RUSTFLAGS");
|
env::remove_var("CARGO_ENCODED_RUSTFLAGS");
|
||||||
env::set_var("HOST", "lol");
|
env::set_var("HOST", "lol");
|
||||||
let ac = autocfg::AutoCfg::new().unwrap();
|
let ac = autocfg::AutoCfg::with_dir(out.as_ref()).unwrap();
|
||||||
assert!(ac.probe_sysroot_crate("autocfg"));
|
assert!(ac.probe_sysroot_crate("autocfg"));
|
||||||
}
|
}
|
||||||
|
21
pve-rs/vendor/autocfg/tests/support/mod.rs
vendored
Normal file
21
pve-rs/vendor/autocfg/tests/support/mod.rs
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
use std::borrow::Cow;
|
||||||
|
use std::env;
|
||||||
|
use std::path::{Path, PathBuf};
|
||||||
|
|
||||||
|
/// The directory containing this test binary.
|
||||||
|
pub fn exe_dir() -> PathBuf {
|
||||||
|
let exe = env::current_exe().unwrap();
|
||||||
|
exe.parent().unwrap().to_path_buf()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The directory to use for test probes.
|
||||||
|
pub fn out_dir() -> Cow<'static, Path> {
|
||||||
|
if let Some(tmpdir) = option_env!("CARGO_TARGET_TMPDIR") {
|
||||||
|
Cow::Borrowed(tmpdir.as_ref())
|
||||||
|
} else if let Some(tmpdir) = env::var_os("TESTS_TARGET_DIR") {
|
||||||
|
Cow::Owned(tmpdir.into())
|
||||||
|
} else {
|
||||||
|
// Use the same path as this test binary.
|
||||||
|
Cow::Owned(exe_dir())
|
||||||
|
}
|
||||||
|
}
|
138
pve-rs/vendor/autocfg/tests/tests.rs
vendored
Normal file
138
pve-rs/vendor/autocfg/tests/tests.rs
vendored
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
extern crate autocfg;
|
||||||
|
|
||||||
|
use autocfg::AutoCfg;
|
||||||
|
|
||||||
|
mod support;
|
||||||
|
|
||||||
|
fn core_std(ac: &AutoCfg, path: &str) -> String {
|
||||||
|
let krate = if ac.no_std() { "core" } else { "std" };
|
||||||
|
format!("{}::{}", krate, path)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn assert_std(ac: &AutoCfg, probe_result: bool) {
|
||||||
|
assert_eq!(!ac.no_std(), probe_result);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn assert_min(ac: &AutoCfg, major: usize, minor: usize, probe_result: bool) {
|
||||||
|
assert_eq!(ac.probe_rustc_version(major, minor), probe_result);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn autocfg_for_test() -> AutoCfg {
|
||||||
|
AutoCfg::with_dir(support::out_dir().as_ref()).unwrap()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn autocfg_version() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert!(ac.probe_rustc_version(1, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_add() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
let add = core_std(&ac, "ops::Add");
|
||||||
|
let add_rhs = add.clone() + "<i32>";
|
||||||
|
let add_rhs_output = add.clone() + "<i32, Output = i32>";
|
||||||
|
let dyn_add_rhs_output = "dyn ".to_string() + &*add_rhs_output;
|
||||||
|
assert!(ac.probe_path(&add));
|
||||||
|
assert!(ac.probe_trait(&add));
|
||||||
|
assert!(ac.probe_trait(&add_rhs));
|
||||||
|
assert!(ac.probe_trait(&add_rhs_output));
|
||||||
|
assert_min(&ac, 1, 27, ac.probe_type(&dyn_add_rhs_output));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_as_ref() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
let as_ref = core_std(&ac, "convert::AsRef");
|
||||||
|
let as_ref_str = as_ref.clone() + "<str>";
|
||||||
|
let dyn_as_ref_str = "dyn ".to_string() + &*as_ref_str;
|
||||||
|
assert!(ac.probe_path(&as_ref));
|
||||||
|
assert!(ac.probe_trait(&as_ref_str));
|
||||||
|
assert!(ac.probe_type(&as_ref_str));
|
||||||
|
assert_min(&ac, 1, 27, ac.probe_type(&dyn_as_ref_str));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_i128() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
let i128_path = core_std(&ac, "i128");
|
||||||
|
assert_min(&ac, 1, 26, ac.probe_path(&i128_path));
|
||||||
|
assert_min(&ac, 1, 26, ac.probe_type("i128"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_sum() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
let sum = core_std(&ac, "iter::Sum");
|
||||||
|
let sum_i32 = sum.clone() + "<i32>";
|
||||||
|
let dyn_sum_i32 = "dyn ".to_string() + &*sum_i32;
|
||||||
|
assert_min(&ac, 1, 12, ac.probe_path(&sum));
|
||||||
|
assert_min(&ac, 1, 12, ac.probe_trait(&sum));
|
||||||
|
assert_min(&ac, 1, 12, ac.probe_trait(&sum_i32));
|
||||||
|
assert_min(&ac, 1, 12, ac.probe_type(&sum_i32));
|
||||||
|
assert_min(&ac, 1, 27, ac.probe_type(&dyn_sum_i32));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_std() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert_std(&ac, ac.probe_sysroot_crate("std"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_alloc() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert_min(&ac, 1, 36, ac.probe_sysroot_crate("alloc"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_bad_sysroot_crate() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert!(!ac.probe_sysroot_crate("doesnt_exist"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_no_std() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert!(ac.probe_type("i32"));
|
||||||
|
assert!(ac.probe_type("[i32]"));
|
||||||
|
assert_std(&ac, ac.probe_type("Vec<i32>"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_expression() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert!(ac.probe_expression(r#""test".trim_left()"#));
|
||||||
|
assert_min(&ac, 1, 30, ac.probe_expression(r#""test".trim_start()"#));
|
||||||
|
assert_std(&ac, ac.probe_expression("[1, 2, 3].to_vec()"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_constant() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
assert!(ac.probe_constant("1 + 2 + 3"));
|
||||||
|
assert_min(
|
||||||
|
&ac,
|
||||||
|
1,
|
||||||
|
33,
|
||||||
|
ac.probe_constant("{ let x = 1 + 2 + 3; x * x }"),
|
||||||
|
);
|
||||||
|
assert_min(&ac, 1, 39, ac.probe_constant(r#""test".len()"#));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn probe_raw() {
|
||||||
|
let ac = autocfg_for_test();
|
||||||
|
let prefix = if ac.no_std() { "#![no_std]\n" } else { "" };
|
||||||
|
let f = |s| format!("{}{}", prefix, s);
|
||||||
|
|
||||||
|
// This attribute **must** be used at the crate level.
|
||||||
|
assert!(ac.probe_raw(&f("#![no_builtins]")).is_ok());
|
||||||
|
|
||||||
|
assert!(ac.probe_raw(&f("#![deny(dead_code)] fn x() {}")).is_err());
|
||||||
|
assert!(ac.probe_raw(&f("#![allow(dead_code)] fn x() {}")).is_ok());
|
||||||
|
assert!(ac
|
||||||
|
.probe_raw(&f("#![deny(dead_code)] pub fn x() {}"))
|
||||||
|
.is_ok());
|
||||||
|
}
|
10
pve-rs/vendor/autocfg/tests/wrappers.rs
vendored
10
pve-rs/vendor/autocfg/tests/wrappers.rs
vendored
@ -2,6 +2,8 @@ extern crate autocfg;
|
|||||||
|
|
||||||
use std::env;
|
use std::env;
|
||||||
|
|
||||||
|
mod support;
|
||||||
|
|
||||||
/// Tests that autocfg uses the RUSTC_WRAPPER and/or RUSTC_WORKSPACE_WRAPPER
|
/// Tests that autocfg uses the RUSTC_WRAPPER and/or RUSTC_WORKSPACE_WRAPPER
|
||||||
/// environment variables when running rustc.
|
/// environment variables when running rustc.
|
||||||
#[test]
|
#[test]
|
||||||
@ -15,9 +17,7 @@ fn test_wrappers() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use the same path as this test binary.
|
let out = support::out_dir();
|
||||||
let dir = env::current_exe().unwrap().parent().unwrap().to_path_buf();
|
|
||||||
env::set_var("OUT_DIR", &format!("{}", dir.display()));
|
|
||||||
|
|
||||||
// This is used as a heuristic to detect rust-lang/cargo#9601.
|
// This is used as a heuristic to detect rust-lang/cargo#9601.
|
||||||
env::set_var("CARGO_ENCODED_RUSTFLAGS", "");
|
env::set_var("CARGO_ENCODED_RUSTFLAGS", "");
|
||||||
@ -30,7 +30,7 @@ fn test_wrappers() {
|
|||||||
set("RUSTC_WRAPPER", rustc);
|
set("RUSTC_WRAPPER", rustc);
|
||||||
set("RUSTC_WORKSPACE_WRAPPER", workspace);
|
set("RUSTC_WORKSPACE_WRAPPER", workspace);
|
||||||
|
|
||||||
let ac = autocfg::AutoCfg::new().unwrap();
|
let ac = autocfg::AutoCfg::with_dir(out.as_ref()).unwrap();
|
||||||
if rustc == Some(false) || workspace == Some(false) {
|
if rustc == Some(false) || workspace == Some(false) {
|
||||||
// Everything should fail with bad wrappers.
|
// Everything should fail with bad wrappers.
|
||||||
assert!(!ac.probe_type("usize"));
|
assert!(!ac.probe_type("usize"));
|
||||||
@ -48,7 +48,7 @@ fn test_wrappers() {
|
|||||||
// by using something that doesn't pass through at all.
|
// by using something that doesn't pass through at all.
|
||||||
env::set_var("RUSTC_WRAPPER", "./tests/wrap_ignored");
|
env::set_var("RUSTC_WRAPPER", "./tests/wrap_ignored");
|
||||||
env::set_var("RUSTC_WORKSPACE_WRAPPER", "/bin/false");
|
env::set_var("RUSTC_WORKSPACE_WRAPPER", "/bin/false");
|
||||||
let ac = autocfg::AutoCfg::new().unwrap();
|
let ac = autocfg::AutoCfg::with_dir(out.as_ref()).unwrap();
|
||||||
assert!(ac.probe_type("mesize")); // anything goes!
|
assert!(ac.probe_type("mesize")); // anything goes!
|
||||||
|
|
||||||
// Make sure we also got the version from that wrapper.
|
// Make sure we also got the version from that wrapper.
|
||||||
|
2
pve-rs/vendor/bytes/.cargo-checksum.json
vendored
2
pve-rs/vendor/bytes/.cargo-checksum.json
vendored
@ -1 +1 @@
|
|||||||
{"files":{"CHANGELOG.md":"dab5bedf72d2caebd61a9feef156f98eb31677e14f95bc99888e21b20ce579bc","Cargo.toml":"5d32feb935f873448d6d999c8463b3a6263284cf198986f107a0adef72bfca0a","LICENSE":"45f522cacecb1023856e46df79ca625dfc550c94910078bd8aec6e02880b3d42","README.md":"c1b2b54999d4829f9f64fb41cbdf05a72d565be0dd078a8633d34631147498a1","SECURITY.md":"a3335079977c2f13bad59e323fdc1056bdae5adfe55f18d15ac2c930d741828c","benches/buf.rs":"72e6b6120b52d568da068f17c66a793d65602e400c595778581b63092e41d8dc","benches/bytes.rs":"7084e564f8568f52c9fdb76a06e58701aa7f0c776209d29a0f60c38a19748203","benches/bytes_mut.rs":"1326fe6224b26826228e02b4133151e756f38152c2d9cfe66adf83af76c3ec98","ci/miri.sh":"1ee54575b55a0e495e52ca1a934beed674bc8f375f03c4cfc3e81d221ec4fe98","ci/test-stable.sh":"b21b9265d8d65c1f3d50c64e40d41c66a870d897325119d1f78d601727bbb562","ci/tsan.sh":"466b86b19225dd26c756cf2252cb1973f87a145642c99364b462ed7ceb55c7dd","clippy.toml":"8522f448dfa3b33ac334ce47d233ebb6b58e8ae115e45107a64fc1b4510fe560","src/buf/buf_impl.rs":"8616fdf6f6e0f3d9b3870fbf85a78f7907006656d05032bbd2966c73f0a13b1c","src/buf/buf_mut.rs":"133a0a898df73a0e545b28e8875d3ae457df0d164c1345b5aceb4ecb67aee371","src/buf/chain.rs":"c933958f04c4ecd39a18db34c04ea51cc601180d43ee6924fed2fb44b96fe8c7","src/buf/iter.rs":"d4dca5b7f9b1cb441f22ac1862e28b10086721879163a810955aefb5cd7f3e58","src/buf/limit.rs":"e005ba140b70f68654877c96b981a220477e415ff5c92438c1b0cb9bc866d872","src/buf/mod.rs":"3f60295316d44b510b942abb31a0d975ae488bd4b52c87f5252d73f88f82715a","src/buf/reader.rs":"cda8bc221a1de06c7395d5c6e80f8a5924198eafbc2decc0909082ce8781d789","src/buf/take.rs":"ce7f4644986797dae3e6bdaa8f65c8ff0a9b0d4b80f749c735ed4777b96dcb2c","src/buf/uninit_slice.rs":"ce0029ebe6fd76617a457676e581c756d6026bb02b9c24718286668b962c23a1","src/buf/vec_deque.rs":"8d552c26ac6ce28a471f74c388e4749432e86b1d8f5a9759b9fc32a2549d395f","src/buf/writer.rs":"7589e9ea054d01d133b230130113a2de20b4f221a5e5c754809b583052601ea2","src/bytes.rs":"b1367f27701a5b8d75a5c0ece1d91f08d284abc62f7b80572d3b3b70c0df2ee2","src/bytes_mut.rs":"378194077a8dc2d7ad4b97c73fd4494ba99ec893921987d93eaf0f2bc0df5330","src/fmt/debug.rs":"97b23cfa1d2701fa187005421302eeb260e635cd4f9a9e02b044ff89fcc8b8ad","src/fmt/hex.rs":"13755ec6f1b79923e1f1a05c51b179a38c03c40bb8ed2db0210e8901812e61e7","src/fmt/mod.rs":"176da4e359da99b8e5cf16e480cb7b978f574876827f1b9bb9c08da4d74ac0f5","src/lib.rs":"226bb979808d8dcc8ff1643029b74a672b1779d6b7153a9e180777b77906191f","src/loom.rs":"eb3f577d8cce39a84155c241c4dc308f024631f02085833f7fe9f0ea817bcea9","src/serde.rs":"3ecd7e828cd4c2b7db93c807cb1548fad209e674df493edf7cda69a7b04d405d","tests/test_buf.rs":"a7be350258f0433cfb9ba9e4583d6bb356c964ac34a781f586fd78fbd2c4bb02","tests/test_buf_mut.rs":"3e6a12a4f546dbf1a0e1346ab2b7ff707fdaf01a06b21714ca64b141484a76c3","tests/test_bytes.rs":"eb3b0cf10a6ada6e2ec71c3546a5477c1b1c1e22044a182391df0f57cda6fad4","tests/test_bytes_odd_alloc.rs":"ad5df84a35038359413199762c65017989d905e6e965a7b863beaa9962a7e1e8","tests/test_bytes_vec_alloc.rs":"dd7e3c3a71abcfdcad7e3b2f52a6bd106ad6ea0d4bc634372e81dae097233cf0","tests/test_chain.rs":"e9f094539bb42b3135f50033c44122a6b44cf0f953e51e8b488f43243f1e7f10","tests/test_debug.rs":"13299107172809e8cbbd823964ac9450cd0d6b6de79f2e6a2e0f44b9225a0593","tests/test_iter.rs":"665e1837c1294d7695ffa352a666ce8673fb46fa603164556524e87d5517a6cb","tests/test_reader.rs":"bf83669d4e0960dad6aa47b46a9a454814fab626eb83572aba914c3d71618f43","tests/test_serde.rs":"2691f891796ba259de0ecf926de05c514f4912cc5fcd3e6a1591efbcd23ed4d0","tests/test_take.rs":"db01bf6855097f318336e90d12c0725a92cee426d330e477a6bd1d32dac34a27"},"package":"8318a53db07bb3f8dca91a600466bdb3f2eaadeedfdbcf02e1accbad9271ba50"}
|
{"files":{"CHANGELOG.md":"c5fce829116f7930c93ac10392eb1f58ab9b84322b33318b6ec864d0eeb880f6","Cargo.toml":"af0137d8b9f6720d284b383ef252a5d9d48b644939990310324a69ccadf797d8","LICENSE":"45f522cacecb1023856e46df79ca625dfc550c94910078bd8aec6e02880b3d42","README.md":"c1b2b54999d4829f9f64fb41cbdf05a72d565be0dd078a8633d34631147498a1","SECURITY.md":"a3335079977c2f13bad59e323fdc1056bdae5adfe55f18d15ac2c930d741828c","benches/buf.rs":"72e6b6120b52d568da068f17c66a793d65602e400c595778581b63092e41d8dc","benches/bytes.rs":"7084e564f8568f52c9fdb76a06e58701aa7f0c776209d29a0f60c38a19748203","benches/bytes_mut.rs":"1326fe6224b26826228e02b4133151e756f38152c2d9cfe66adf83af76c3ec98","ci/miri.sh":"13b2db3432fcdf9e2db6ef9e6ec20d063c0ce63542981a6f77e09306e1e2198e","ci/test-stable.sh":"b21b9265d8d65c1f3d50c64e40d41c66a870d897325119d1f78d601727bbb562","ci/tsan.sh":"466b86b19225dd26c756cf2252cb1973f87a145642c99364b462ed7ceb55c7dd","clippy.toml":"8522f448dfa3b33ac334ce47d233ebb6b58e8ae115e45107a64fc1b4510fe560","src/buf/buf_impl.rs":"73092a4cea9d0657e7e54875ee8018e31ad9306524984a67529f9a6d5e790f4a","src/buf/buf_mut.rs":"20bfb57681d1f0cb7c7610e12b9a06233235ba6f20100f7eb2f23a5f4cf0de90","src/buf/chain.rs":"c933958f04c4ecd39a18db34c04ea51cc601180d43ee6924fed2fb44b96fe8c7","src/buf/iter.rs":"d4dca5b7f9b1cb441f22ac1862e28b10086721879163a810955aefb5cd7f3e58","src/buf/limit.rs":"e005ba140b70f68654877c96b981a220477e415ff5c92438c1b0cb9bc866d872","src/buf/mod.rs":"3f60295316d44b510b942abb31a0d975ae488bd4b52c87f5252d73f88f82715a","src/buf/reader.rs":"cda8bc221a1de06c7395d5c6e80f8a5924198eafbc2decc0909082ce8781d789","src/buf/take.rs":"ce7f4644986797dae3e6bdaa8f65c8ff0a9b0d4b80f749c735ed4777b96dcb2c","src/buf/uninit_slice.rs":"52629b93ff7a08db45fc69395580b34fa3609fd9309ea01f86e58488b02b08a3","src/buf/vec_deque.rs":"8d552c26ac6ce28a471f74c388e4749432e86b1d8f5a9759b9fc32a2549d395f","src/buf/writer.rs":"7589e9ea054d01d133b230130113a2de20b4f221a5e5c754809b583052601ea2","src/bytes.rs":"c4cf6e8f6770c4bfe62181460aaab5f36b9392a92cfbb7fd4a5a5e42ac6dc3db","src/bytes_mut.rs":"76e6a2e68ffa433b694671f673aa16dc2d4a414e73d1037fd8f3d801251901ce","src/fmt/debug.rs":"97b23cfa1d2701fa187005421302eeb260e635cd4f9a9e02b044ff89fcc8b8ad","src/fmt/hex.rs":"13755ec6f1b79923e1f1a05c51b179a38c03c40bb8ed2db0210e8901812e61e7","src/fmt/mod.rs":"176da4e359da99b8e5cf16e480cb7b978f574876827f1b9bb9c08da4d74ac0f5","src/lib.rs":"226bb979808d8dcc8ff1643029b74a672b1779d6b7153a9e180777b77906191f","src/loom.rs":"eb3f577d8cce39a84155c241c4dc308f024631f02085833f7fe9f0ea817bcea9","src/serde.rs":"3ecd7e828cd4c2b7db93c807cb1548fad209e674df493edf7cda69a7b04d405d","tests/test_buf.rs":"827a965d3635eed132317248172add380679a3aaa0a26752bb77ea6ff8a458d5","tests/test_buf_mut.rs":"3e6a12a4f546dbf1a0e1346ab2b7ff707fdaf01a06b21714ca64b141484a76c3","tests/test_bytes.rs":"38885e993df0f22586d38e43a24bcb90799e7b4f03aefc2330fd06a54ab6fb9a","tests/test_bytes_odd_alloc.rs":"ad5df84a35038359413199762c65017989d905e6e965a7b863beaa9962a7e1e8","tests/test_bytes_vec_alloc.rs":"dd7e3c3a71abcfdcad7e3b2f52a6bd106ad6ea0d4bc634372e81dae097233cf0","tests/test_chain.rs":"e9f094539bb42b3135f50033c44122a6b44cf0f953e51e8b488f43243f1e7f10","tests/test_debug.rs":"13299107172809e8cbbd823964ac9450cd0d6b6de79f2e6a2e0f44b9225a0593","tests/test_iter.rs":"665e1837c1294d7695ffa352a666ce8673fb46fa603164556524e87d5517a6cb","tests/test_reader.rs":"bf83669d4e0960dad6aa47b46a9a454814fab626eb83572aba914c3d71618f43","tests/test_serde.rs":"2691f891796ba259de0ecf926de05c514f4912cc5fcd3e6a1591efbcd23ed4d0","tests/test_take.rs":"db01bf6855097f318336e90d12c0725a92cee426d330e477a6bd1d32dac34a27"},"package":"9ac0150caa2ae65ca5bd83f25c7de183dea78d4d366469f148435e2acfbad0da"}
|
18
pve-rs/vendor/bytes/CHANGELOG.md
vendored
18
pve-rs/vendor/bytes/CHANGELOG.md
vendored
@ -1,3 +1,21 @@
|
|||||||
|
# 1.8.0 (October 21, 2024)
|
||||||
|
|
||||||
|
- Guarantee address in `split_off`/`split_to` for empty slices (#740)
|
||||||
|
|
||||||
|
# 1.7.2 (September 17, 2024)
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- Fix default impl of `Buf::{get_int, get_int_le}` (#732)
|
||||||
|
|
||||||
|
### Documented
|
||||||
|
|
||||||
|
- Fix double spaces in comments and doc comments (#731)
|
||||||
|
|
||||||
|
### Internal changes
|
||||||
|
|
||||||
|
- Ensure BytesMut::advance reduces capacity (#728)
|
||||||
|
|
||||||
# 1.7.1 (August 1, 2024)
|
# 1.7.1 (August 1, 2024)
|
||||||
|
|
||||||
This release reverts the following change due to a regression:
|
This release reverts the following change due to a regression:
|
||||||
|
67
pve-rs/vendor/bytes/Cargo.toml
vendored
67
pve-rs/vendor/bytes/Cargo.toml
vendored
@ -13,11 +13,16 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.39"
|
rust-version = "1.39"
|
||||||
name = "bytes"
|
name = "bytes"
|
||||||
version = "1.7.1"
|
version = "1.8.0"
|
||||||
authors = [
|
authors = [
|
||||||
"Carl Lerche <me@carllerche.com>",
|
"Carl Lerche <me@carllerche.com>",
|
||||||
"Sean McArthur <sean@seanmonstar.com>",
|
"Sean McArthur <sean@seanmonstar.com>",
|
||||||
]
|
]
|
||||||
|
build = false
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
description = "Types and traits for working with bytes"
|
description = "Types and traits for working with bytes"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
keywords = [
|
keywords = [
|
||||||
@ -38,6 +43,66 @@ rustdoc-args = [
|
|||||||
"docsrs",
|
"docsrs",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "bytes"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_buf"
|
||||||
|
path = "tests/test_buf.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_buf_mut"
|
||||||
|
path = "tests/test_buf_mut.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_bytes"
|
||||||
|
path = "tests/test_bytes.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_bytes_odd_alloc"
|
||||||
|
path = "tests/test_bytes_odd_alloc.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_bytes_vec_alloc"
|
||||||
|
path = "tests/test_bytes_vec_alloc.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_chain"
|
||||||
|
path = "tests/test_chain.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_debug"
|
||||||
|
path = "tests/test_debug.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_iter"
|
||||||
|
path = "tests/test_iter.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_reader"
|
||||||
|
path = "tests/test_reader.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_serde"
|
||||||
|
path = "tests/test_serde.rs"
|
||||||
|
|
||||||
|
[[test]]
|
||||||
|
name = "test_take"
|
||||||
|
path = "tests/test_take.rs"
|
||||||
|
|
||||||
|
[[bench]]
|
||||||
|
name = "buf"
|
||||||
|
path = "benches/buf.rs"
|
||||||
|
|
||||||
|
[[bench]]
|
||||||
|
name = "bytes"
|
||||||
|
path = "benches/bytes.rs"
|
||||||
|
|
||||||
|
[[bench]]
|
||||||
|
name = "bytes_mut"
|
||||||
|
path = "benches/bytes_mut.rs"
|
||||||
|
|
||||||
[dependencies.serde]
|
[dependencies.serde]
|
||||||
version = "1.0.60"
|
version = "1.0.60"
|
||||||
features = ["alloc"]
|
features = ["alloc"]
|
||||||
|
3
pve-rs/vendor/bytes/ci/miri.sh
vendored
3
pve-rs/vendor/bytes/ci/miri.sh
vendored
@ -1,8 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
rustup toolchain install nightly --component miri
|
rustup component add miri
|
||||||
rustup override set nightly
|
|
||||||
cargo miri setup
|
cargo miri setup
|
||||||
|
|
||||||
export MIRIFLAGS="-Zmiri-strict-provenance"
|
export MIRIFLAGS="-Zmiri-strict-provenance"
|
||||||
|
10
pve-rs/vendor/bytes/src/buf/buf_impl.rs
vendored
10
pve-rs/vendor/bytes/src/buf/buf_impl.rs
vendored
@ -66,6 +66,12 @@ macro_rules! buf_get_impl {
|
|||||||
}};
|
}};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://en.wikipedia.org/wiki/Sign_extension
|
||||||
|
fn sign_extend(val: u64, nbytes: usize) -> i64 {
|
||||||
|
let shift = (8 - nbytes) * 8;
|
||||||
|
(val << shift) as i64 >> shift
|
||||||
|
}
|
||||||
|
|
||||||
/// Read bytes from a buffer.
|
/// Read bytes from a buffer.
|
||||||
///
|
///
|
||||||
/// A buffer stores bytes in memory such that read operations are infallible.
|
/// A buffer stores bytes in memory such that read operations are infallible.
|
||||||
@ -923,7 +929,7 @@ pub trait Buf {
|
|||||||
/// This function panics if there is not enough remaining data in `self`, or
|
/// This function panics if there is not enough remaining data in `self`, or
|
||||||
/// if `nbytes` is greater than 8.
|
/// if `nbytes` is greater than 8.
|
||||||
fn get_int(&mut self, nbytes: usize) -> i64 {
|
fn get_int(&mut self, nbytes: usize) -> i64 {
|
||||||
buf_get_impl!(be => self, i64, nbytes);
|
sign_extend(self.get_uint(nbytes), nbytes)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Gets a signed n-byte integer from `self` in little-endian byte order.
|
/// Gets a signed n-byte integer from `self` in little-endian byte order.
|
||||||
@ -944,7 +950,7 @@ pub trait Buf {
|
|||||||
/// This function panics if there is not enough remaining data in `self`, or
|
/// This function panics if there is not enough remaining data in `self`, or
|
||||||
/// if `nbytes` is greater than 8.
|
/// if `nbytes` is greater than 8.
|
||||||
fn get_int_le(&mut self, nbytes: usize) -> i64 {
|
fn get_int_le(&mut self, nbytes: usize) -> i64 {
|
||||||
buf_get_impl!(le => self, i64, nbytes);
|
sign_extend(self.get_uint_le(nbytes), nbytes)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Gets a signed n-byte integer from `self` in native-endian byte order.
|
/// Gets a signed n-byte integer from `self` in native-endian byte order.
|
||||||
|
10
pve-rs/vendor/bytes/src/buf/buf_mut.rs
vendored
10
pve-rs/vendor/bytes/src/buf/buf_mut.rs
vendored
@ -1107,7 +1107,7 @@ pub unsafe trait BufMut {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Writes an IEEE754 single-precision (4 bytes) floating point number to
|
/// Writes an IEEE754 single-precision (4 bytes) floating point number to
|
||||||
/// `self` in big-endian byte order.
|
/// `self` in big-endian byte order.
|
||||||
///
|
///
|
||||||
/// The current position is advanced by 4.
|
/// The current position is advanced by 4.
|
||||||
@ -1131,7 +1131,7 @@ pub unsafe trait BufMut {
|
|||||||
self.put_u32(n.to_bits());
|
self.put_u32(n.to_bits());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Writes an IEEE754 single-precision (4 bytes) floating point number to
|
/// Writes an IEEE754 single-precision (4 bytes) floating point number to
|
||||||
/// `self` in little-endian byte order.
|
/// `self` in little-endian byte order.
|
||||||
///
|
///
|
||||||
/// The current position is advanced by 4.
|
/// The current position is advanced by 4.
|
||||||
@ -1183,7 +1183,7 @@ pub unsafe trait BufMut {
|
|||||||
self.put_u32_ne(n.to_bits());
|
self.put_u32_ne(n.to_bits());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Writes an IEEE754 double-precision (8 bytes) floating point number to
|
/// Writes an IEEE754 double-precision (8 bytes) floating point number to
|
||||||
/// `self` in big-endian byte order.
|
/// `self` in big-endian byte order.
|
||||||
///
|
///
|
||||||
/// The current position is advanced by 8.
|
/// The current position is advanced by 8.
|
||||||
@ -1207,7 +1207,7 @@ pub unsafe trait BufMut {
|
|||||||
self.put_u64(n.to_bits());
|
self.put_u64(n.to_bits());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Writes an IEEE754 double-precision (8 bytes) floating point number to
|
/// Writes an IEEE754 double-precision (8 bytes) floating point number to
|
||||||
/// `self` in little-endian byte order.
|
/// `self` in little-endian byte order.
|
||||||
///
|
///
|
||||||
/// The current position is advanced by 8.
|
/// The current position is advanced by 8.
|
||||||
@ -1231,7 +1231,7 @@ pub unsafe trait BufMut {
|
|||||||
self.put_u64_le(n.to_bits());
|
self.put_u64_le(n.to_bits());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Writes an IEEE754 double-precision (8 bytes) floating point number to
|
/// Writes an IEEE754 double-precision (8 bytes) floating point number to
|
||||||
/// `self` in native-endian byte order.
|
/// `self` in native-endian byte order.
|
||||||
///
|
///
|
||||||
/// The current position is advanced by 8.
|
/// The current position is advanced by 8.
|
||||||
|
2
pve-rs/vendor/bytes/src/buf/uninit_slice.rs
vendored
2
pve-rs/vendor/bytes/src/buf/uninit_slice.rs
vendored
@ -110,7 +110,7 @@ impl UninitSlice {
|
|||||||
unsafe { self[index..].as_mut_ptr().write(byte) }
|
unsafe { self[index..].as_mut_ptr().write(byte) }
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Copies bytes from `src` into `self`.
|
/// Copies bytes from `src` into `self`.
|
||||||
///
|
///
|
||||||
/// The length of `src` must be the same as `self`.
|
/// The length of `src` must be the same as `self`.
|
||||||
///
|
///
|
||||||
|
37
pve-rs/vendor/bytes/src/bytes.rs
vendored
37
pve-rs/vendor/bytes/src/bytes.rs
vendored
@ -142,6 +142,7 @@ impl Bytes {
|
|||||||
Bytes::from_static(EMPTY)
|
Bytes::from_static(EMPTY)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Creates a new empty `Bytes`.
|
||||||
#[cfg(all(loom, test))]
|
#[cfg(all(loom, test))]
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
const EMPTY: &[u8] = &[];
|
const EMPTY: &[u8] = &[];
|
||||||
@ -172,6 +173,7 @@ impl Bytes {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Creates a new `Bytes` from a static slice.
|
||||||
#[cfg(all(loom, test))]
|
#[cfg(all(loom, test))]
|
||||||
pub fn from_static(bytes: &'static [u8]) -> Self {
|
pub fn from_static(bytes: &'static [u8]) -> Self {
|
||||||
Bytes {
|
Bytes {
|
||||||
@ -182,6 +184,22 @@ impl Bytes {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Creates a new `Bytes` with length zero and the given pointer as the address.
|
||||||
|
fn new_empty_with_ptr(ptr: *const u8) -> Self {
|
||||||
|
debug_assert!(!ptr.is_null());
|
||||||
|
|
||||||
|
// Detach this pointer's provenance from whichever allocation it came from, and reattach it
|
||||||
|
// to the provenance of the fake ZST [u8;0] at the same address.
|
||||||
|
let ptr = without_provenance(ptr as usize);
|
||||||
|
|
||||||
|
Bytes {
|
||||||
|
ptr,
|
||||||
|
len: 0,
|
||||||
|
data: AtomicPtr::new(ptr::null_mut()),
|
||||||
|
vtable: &STATIC_VTABLE,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Returns the number of bytes contained in this `Bytes`.
|
/// Returns the number of bytes contained in this `Bytes`.
|
||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
@ -364,7 +382,9 @@ impl Bytes {
|
|||||||
/// Splits the bytes into two at the given index.
|
/// Splits the bytes into two at the given index.
|
||||||
///
|
///
|
||||||
/// Afterwards `self` contains elements `[0, at)`, and the returned `Bytes`
|
/// Afterwards `self` contains elements `[0, at)`, and the returned `Bytes`
|
||||||
/// contains elements `[at, len)`.
|
/// contains elements `[at, len)`. It's guaranteed that the memory does not
|
||||||
|
/// move, that is, the address of `self` does not change, and the address of
|
||||||
|
/// the returned slice is `at` bytes after that.
|
||||||
///
|
///
|
||||||
/// This is an `O(1)` operation that just increases the reference count and
|
/// This is an `O(1)` operation that just increases the reference count and
|
||||||
/// sets a few indices.
|
/// sets a few indices.
|
||||||
@ -387,11 +407,11 @@ impl Bytes {
|
|||||||
#[must_use = "consider Bytes::truncate if you don't need the other half"]
|
#[must_use = "consider Bytes::truncate if you don't need the other half"]
|
||||||
pub fn split_off(&mut self, at: usize) -> Self {
|
pub fn split_off(&mut self, at: usize) -> Self {
|
||||||
if at == self.len() {
|
if at == self.len() {
|
||||||
return Bytes::new();
|
return Bytes::new_empty_with_ptr(self.ptr.wrapping_add(at));
|
||||||
}
|
}
|
||||||
|
|
||||||
if at == 0 {
|
if at == 0 {
|
||||||
return mem::replace(self, Bytes::new());
|
return mem::replace(self, Bytes::new_empty_with_ptr(self.ptr));
|
||||||
}
|
}
|
||||||
|
|
||||||
assert!(
|
assert!(
|
||||||
@ -436,11 +456,12 @@ impl Bytes {
|
|||||||
#[must_use = "consider Bytes::advance if you don't need the other half"]
|
#[must_use = "consider Bytes::advance if you don't need the other half"]
|
||||||
pub fn split_to(&mut self, at: usize) -> Self {
|
pub fn split_to(&mut self, at: usize) -> Self {
|
||||||
if at == self.len() {
|
if at == self.len() {
|
||||||
return mem::replace(self, Bytes::new());
|
let end_ptr = self.ptr.wrapping_add(at);
|
||||||
|
return mem::replace(self, Bytes::new_empty_with_ptr(end_ptr));
|
||||||
}
|
}
|
||||||
|
|
||||||
if at == 0 {
|
if at == 0 {
|
||||||
return Bytes::new();
|
return Bytes::new_empty_with_ptr(self.ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
assert!(
|
assert!(
|
||||||
@ -1301,7 +1322,7 @@ unsafe fn shallow_clone_vec(
|
|||||||
offset: *const u8,
|
offset: *const u8,
|
||||||
len: usize,
|
len: usize,
|
||||||
) -> Bytes {
|
) -> Bytes {
|
||||||
// If the buffer is still tracked in a `Vec<u8>`. It is time to
|
// If the buffer is still tracked in a `Vec<u8>`. It is time to
|
||||||
// promote the vec to an `Arc`. This could potentially be called
|
// promote the vec to an `Arc`. This could potentially be called
|
||||||
// concurrently, so some care must be taken.
|
// concurrently, so some care must be taken.
|
||||||
|
|
||||||
@ -1424,6 +1445,10 @@ where
|
|||||||
new_addr as *mut u8
|
new_addr as *mut u8
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn without_provenance(ptr: usize) -> *const u8 {
|
||||||
|
core::ptr::null::<u8>().wrapping_add(ptr)
|
||||||
|
}
|
||||||
|
|
||||||
// compile-fails
|
// compile-fails
|
||||||
|
|
||||||
/// ```compile_fail
|
/// ```compile_fail
|
||||||
|
4
pve-rs/vendor/bytes/src/bytes_mut.rs
vendored
4
pve-rs/vendor/bytes/src/bytes_mut.rs
vendored
@ -291,7 +291,9 @@ impl BytesMut {
|
|||||||
/// Splits the bytes into two at the given index.
|
/// Splits the bytes into two at the given index.
|
||||||
///
|
///
|
||||||
/// Afterwards `self` contains elements `[0, at)`, and the returned
|
/// Afterwards `self` contains elements `[0, at)`, and the returned
|
||||||
/// `BytesMut` contains elements `[at, capacity)`.
|
/// `BytesMut` contains elements `[at, capacity)`. It's guaranteed that the
|
||||||
|
/// memory does not move, that is, the address of `self` does not change,
|
||||||
|
/// and the address of the returned slice is `at` bytes after that.
|
||||||
///
|
///
|
||||||
/// This is an `O(1)` operation that just increases the reference count
|
/// This is an `O(1)` operation that just increases the reference count
|
||||||
/// and sets a few indices.
|
/// and sets a few indices.
|
||||||
|
13
pve-rs/vendor/bytes/tests/test_buf.rs
vendored
13
pve-rs/vendor/bytes/tests/test_buf.rs
vendored
@ -36,6 +36,19 @@ fn test_get_u16() {
|
|||||||
assert_eq!(0x5421, buf.get_u16_le());
|
assert_eq!(0x5421, buf.get_u16_le());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_get_int() {
|
||||||
|
let mut buf = &b"\xd6zomg"[..];
|
||||||
|
assert_eq!(-42, buf.get_int(1));
|
||||||
|
let mut buf = &b"\xd6zomg"[..];
|
||||||
|
assert_eq!(-42, buf.get_int_le(1));
|
||||||
|
|
||||||
|
let mut buf = &b"\xfe\x1d\xc0zomg"[..];
|
||||||
|
assert_eq!(0xffffffffffc01dfeu64 as i64, buf.get_int_le(3));
|
||||||
|
let mut buf = &b"\xfe\x1d\xc0zomg"[..];
|
||||||
|
assert_eq!(0xfffffffffffe1dc0u64 as i64, buf.get_int(3));
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[should_panic]
|
#[should_panic]
|
||||||
fn test_get_u16_buffer_underflow() {
|
fn test_get_u16_buffer_underflow() {
|
||||||
|
117
pve-rs/vendor/bytes/tests/test_bytes.rs
vendored
117
pve-rs/vendor/bytes/tests/test_bytes.rs
vendored
@ -676,6 +676,43 @@ fn advance_bytes_mut() {
|
|||||||
assert_eq!(a, b"d zomg wat wat"[..]);
|
assert_eq!(a, b"d zomg wat wat"[..]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Ensures BytesMut::advance reduces always capacity
|
||||||
|
//
|
||||||
|
// See https://github.com/tokio-rs/bytes/issues/725
|
||||||
|
#[test]
|
||||||
|
fn advance_bytes_mut_remaining_capacity() {
|
||||||
|
// reduce the search space under miri
|
||||||
|
let max_capacity = if cfg!(miri) { 16 } else { 256 };
|
||||||
|
for capacity in 0..=max_capacity {
|
||||||
|
for len in 0..=capacity {
|
||||||
|
for advance in 0..=len {
|
||||||
|
eprintln!("testing capacity={capacity}, len={len}, advance={advance}");
|
||||||
|
let mut buf = BytesMut::with_capacity(capacity);
|
||||||
|
|
||||||
|
buf.resize(len, 42);
|
||||||
|
assert_eq!(buf.len(), len, "resize should write `len` bytes");
|
||||||
|
assert_eq!(
|
||||||
|
buf.remaining(),
|
||||||
|
len,
|
||||||
|
"Buf::remaining() should equal BytesMut::len"
|
||||||
|
);
|
||||||
|
|
||||||
|
buf.advance(advance);
|
||||||
|
assert_eq!(
|
||||||
|
buf.remaining(),
|
||||||
|
len - advance,
|
||||||
|
"Buf::advance should reduce the remaining len"
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
buf.capacity(),
|
||||||
|
capacity - advance,
|
||||||
|
"Buf::advance should reduce the remaining capacity"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[should_panic]
|
#[should_panic]
|
||||||
fn advance_past_len() {
|
fn advance_past_len() {
|
||||||
@ -1362,3 +1399,83 @@ fn try_reclaim_arc() {
|
|||||||
buf.advance(2);
|
buf.advance(2);
|
||||||
assert_eq!(true, buf.try_reclaim(6));
|
assert_eq!(true, buf.try_reclaim(6));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn split_off_empty_addr() {
|
||||||
|
let mut buf = Bytes::from(vec![0; 1024]);
|
||||||
|
|
||||||
|
let ptr_start = buf.as_ptr();
|
||||||
|
let ptr_end = ptr_start.wrapping_add(1024);
|
||||||
|
|
||||||
|
let empty_end = buf.split_off(1024);
|
||||||
|
assert_eq!(empty_end.len(), 0);
|
||||||
|
assert_eq!(empty_end.as_ptr(), ptr_end);
|
||||||
|
|
||||||
|
let _ = buf.split_off(0);
|
||||||
|
assert_eq!(buf.len(), 0);
|
||||||
|
assert_eq!(buf.as_ptr(), ptr_start);
|
||||||
|
|
||||||
|
// Is miri happy about the provenance?
|
||||||
|
let _ = &empty_end[..];
|
||||||
|
let _ = &buf[..];
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn split_to_empty_addr() {
|
||||||
|
let mut buf = Bytes::from(vec![0; 1024]);
|
||||||
|
|
||||||
|
let ptr_start = buf.as_ptr();
|
||||||
|
let ptr_end = ptr_start.wrapping_add(1024);
|
||||||
|
|
||||||
|
let empty_start = buf.split_to(0);
|
||||||
|
assert_eq!(empty_start.len(), 0);
|
||||||
|
assert_eq!(empty_start.as_ptr(), ptr_start);
|
||||||
|
|
||||||
|
let _ = buf.split_to(1024);
|
||||||
|
assert_eq!(buf.len(), 0);
|
||||||
|
assert_eq!(buf.as_ptr(), ptr_end);
|
||||||
|
|
||||||
|
// Is miri happy about the provenance?
|
||||||
|
let _ = &empty_start[..];
|
||||||
|
let _ = &buf[..];
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn split_off_empty_addr_mut() {
|
||||||
|
let mut buf = BytesMut::from([0; 1024].as_slice());
|
||||||
|
|
||||||
|
let ptr_start = buf.as_ptr();
|
||||||
|
let ptr_end = ptr_start.wrapping_add(1024);
|
||||||
|
|
||||||
|
let empty_end = buf.split_off(1024);
|
||||||
|
assert_eq!(empty_end.len(), 0);
|
||||||
|
assert_eq!(empty_end.as_ptr(), ptr_end);
|
||||||
|
|
||||||
|
let _ = buf.split_off(0);
|
||||||
|
assert_eq!(buf.len(), 0);
|
||||||
|
assert_eq!(buf.as_ptr(), ptr_start);
|
||||||
|
|
||||||
|
// Is miri happy about the provenance?
|
||||||
|
let _ = &empty_end[..];
|
||||||
|
let _ = &buf[..];
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn split_to_empty_addr_mut() {
|
||||||
|
let mut buf = BytesMut::from([0; 1024].as_slice());
|
||||||
|
|
||||||
|
let ptr_start = buf.as_ptr();
|
||||||
|
let ptr_end = ptr_start.wrapping_add(1024);
|
||||||
|
|
||||||
|
let empty_start = buf.split_to(0);
|
||||||
|
assert_eq!(empty_start.len(), 0);
|
||||||
|
assert_eq!(empty_start.as_ptr(), ptr_start);
|
||||||
|
|
||||||
|
let _ = buf.split_to(1024);
|
||||||
|
assert_eq!(buf.len(), 0);
|
||||||
|
assert_eq!(buf.as_ptr(), ptr_end);
|
||||||
|
|
||||||
|
// Is miri happy about the provenance?
|
||||||
|
let _ = &empty_start[..];
|
||||||
|
let _ = &buf[..];
|
||||||
|
}
|
||||||
|
2
pve-rs/vendor/cc/.cargo-checksum.json
vendored
2
pve-rs/vendor/cc/.cargo-checksum.json
vendored
@ -1 +1 @@
|
|||||||
{"files":{"CHANGELOG.md":"8fbb094907ab39e364881b157a48c28035db3aeb5a12703bd2b66db3d477d06f","Cargo.toml":"ebd3771889005853b63973024cf9c220d37c74218ff3bbfab1591ce3393e0e2d","LICENSE-APACHE":"a60eea817514531668d7e00765731449fe14d059d3249e0bc93b36de45f759f2","LICENSE-MIT":"378f5840b258e2779c39418f3f2d7b2ba96f1c7917dd6be0713f88305dbda397","README.md":"f1ddbede208a5b78333a25dac0a7598e678e9b601a7d99a791069bddaf180dfe","clippy.toml":"aa7850db4350883c8f373bd0d6b4d19bf3b75f13c1c238e24368c109cb52fb1d","src/command_helpers.rs":"0b54800fe5c89cd102a5f872fe1a843c1a58e026bc4bbc611e207914b8c84dda","src/detect_compiler_family.c":"97ca4b021495611e828becea6187add37414186a16dfedd26c2947cbce6e8b2f","src/lib.rs":"a0e3ce90d8d8655b56f14aa185381992cb504912991b8ca8c44f1cd4d059b23b","src/parallel/async_executor.rs":"4ce24435fff6b6555b43fee042c16bd65d4150d0346567f246b9190d85b45983","src/parallel/job_token.rs":"f4ed0a03d89a42bfd5527133d12b267af519b745f3f2b997ed293df15a2641b8","src/parallel/mod.rs":"55fb4c2d15e66677b2ed5ffa6d65ea161bcf1a1e1dc7910ee3bde06f2f67ab14","src/parallel/once_lock.rs":"d13e4cb82d6bca3297ca8671d83a40dd5affd7ac89191d733dd451867181bb02","src/parallel/stderr.rs":"74384d41198740a6fce0877f144262db09fb091225fa8fbfa771314bb11487c6","src/target_info.rs":"f939a570c99d897fdd37cd491a4ee0657e2c7480ec71acbd9cbee48732d4bfbc","src/tempfile.rs":"ebafb5b0e5d08b0706916ed911d4245240e60c3e2d0c9a1630c520842988a2b3","src/tool.rs":"2e6550062e021f2b394388172bbb01e86fe6a94d2395bcb3c85a9e86690da1a9","src/utilities.rs":"a13bb0a351fcef72823485b1b5dc4f514c533fa4feac95deb66ed9e5fbfe7b53","src/windows/com.rs":"a2800ddb81215fff2bf618336f5c4ff8e8bdb746dd18b795873c7304b3f2a5e3","src/windows/find_tools.rs":"dd6b2450909cd8334a2aa2ce856bcc72a9654d92422267d6345d5fabfcbf57c5","src/windows/mod.rs":"34cfa201cfbcac7ccaa3ea5295d3e4200439af3cc5c6433baf81502596040a89","src/windows/registry.rs":"c521b72c825e8095843e73482ffa810ed066ad8bb9f86e6db0c5c143c171aba1","src/windows/setup_config.rs":"754439cbab492afd44c9755abcbec1a41c9b2c358131cee2df13c0e996dbbec8","src/windows/vs_instances.rs":"946527cf8fd32c3472f6a2884dcdec290763101097334c7478f9c24c3950db6b","src/windows/winapi.rs":"250d51c1826d1a2329e9889dd9f058cfce253dbf2a678b076147c6cdb5db046c","src/windows/windows_sys.rs":"e2714c8307bfa083b9745eb0e46cadd7f98d7b88abf45a7637172019324e34b8","src/windows/windows_targets.rs":"5b4648ebc22b028caca9f4b4bf8881fe2d094b7bec217264ba2e6e2c49d1ccee"},"package":"b62ac837cdb5cb22e10a256099b4fc502b1dfe560cb282963a974d7abd80e476"}
|
{"files":{"CHANGELOG.md":"4c2d7e4367b23e9232a1a08f93c6cd739d9c54394d8f6a58b1674101e7fd70ed","Cargo.toml":"8531bf0801327dae7536893352efc21e1864af5cbb854547c3850a4905a88f36","LICENSE-APACHE":"a60eea817514531668d7e00765731449fe14d059d3249e0bc93b36de45f759f2","LICENSE-MIT":"378f5840b258e2779c39418f3f2d7b2ba96f1c7917dd6be0713f88305dbda397","README.md":"f1ddbede208a5b78333a25dac0a7598e678e9b601a7d99a791069bddaf180dfe","clippy.toml":"aa7850db4350883c8f373bd0d6b4d19bf3b75f13c1c238e24368c109cb52fb1d","src/command_helpers.rs":"63742844930bd693e029fa93b734d21c64453c1d9c58f792b3363b28a4c0e86d","src/detect_compiler_family.c":"97ca4b021495611e828becea6187add37414186a16dfedd26c2947cbce6e8b2f","src/lib.rs":"68e35fadafc880de1f59c327f5bc1681837c1009089dcdf6815798e76bbcc39f","src/parallel/async_executor.rs":"4ce24435fff6b6555b43fee042c16bd65d4150d0346567f246b9190d85b45983","src/parallel/job_token.rs":"f4ed0a03d89a42bfd5527133d12b267af519b745f3f2b997ed293df15a2641b8","src/parallel/mod.rs":"55fb4c2d15e66677b2ed5ffa6d65ea161bcf1a1e1dc7910ee3bde06f2f67ab14","src/parallel/once_lock.rs":"d13e4cb82d6bca3297ca8671d83a40dd5affd7ac89191d733dd451867181bb02","src/parallel/stderr.rs":"74384d41198740a6fce0877f144262db09fb091225fa8fbfa771314bb11487c6","src/target_info.rs":"447d3083f24e10fe4c449925b349b3d14ab2ff103c0d9f942ea9b581873442e1","src/tempfile.rs":"ebafb5b0e5d08b0706916ed911d4245240e60c3e2d0c9a1630c520842988a2b3","src/tool.rs":"2e6550062e021f2b394388172bbb01e86fe6a94d2395bcb3c85a9e86690da1a9","src/utilities.rs":"a13bb0a351fcef72823485b1b5dc4f514c533fa4feac95deb66ed9e5fbfe7b53","src/windows/com.rs":"a2800ddb81215fff2bf618336f5c4ff8e8bdb746dd18b795873c7304b3f2a5e3","src/windows/find_tools.rs":"dd6b2450909cd8334a2aa2ce856bcc72a9654d92422267d6345d5fabfcbf57c5","src/windows/mod.rs":"34cfa201cfbcac7ccaa3ea5295d3e4200439af3cc5c6433baf81502596040a89","src/windows/registry.rs":"c521b72c825e8095843e73482ffa810ed066ad8bb9f86e6db0c5c143c171aba1","src/windows/setup_config.rs":"754439cbab492afd44c9755abcbec1a41c9b2c358131cee2df13c0e996dbbec8","src/windows/vs_instances.rs":"946527cf8fd32c3472f6a2884dcdec290763101097334c7478f9c24c3950db6b","src/windows/winapi.rs":"250d51c1826d1a2329e9889dd9f058cfce253dbf2a678b076147c6cdb5db046c","src/windows/windows_sys.rs":"e2714c8307bfa083b9745eb0e46cadd7f98d7b88abf45a7637172019324e34b8","src/windows/windows_targets.rs":"5b4648ebc22b028caca9f4b4bf8881fe2d094b7bec217264ba2e6e2c49d1ccee"},"package":"c2e7962b54006dcfcc61cb72735f4d89bb97061dd6a7ed882ec6b8ee53714c6f"}
|
81
pve-rs/vendor/cc/CHANGELOG.md
vendored
81
pve-rs/vendor/cc/CHANGELOG.md
vendored
@ -6,6 +6,87 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
|
|
||||||
## [Unreleased]
|
## [Unreleased]
|
||||||
|
|
||||||
|
## [1.1.31](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.30...cc-v1.1.31) - 2024-10-19
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Add comment explaining why cc does not rebuild on env PATH change ([#1247](https://github.com/rust-lang/cc-rs/pull/1247))
|
||||||
|
|
||||||
|
## [1.1.30](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.29...cc-v1.1.30) - 2024-10-11
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Don't pass -fPIC by default on wasm ([#1245](https://github.com/rust-lang/cc-rs/pull/1245))
|
||||||
|
|
||||||
|
## [1.1.29](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.28...cc-v1.1.29) - 2024-10-11
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Regenerate target info ([#1243](https://github.com/rust-lang/cc-rs/pull/1243))
|
||||||
|
|
||||||
|
## [1.1.28](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.27...cc-v1.1.28) - 2024-10-06
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Environment variables: For one accepting boolean, treat "0", "false" and empty env as false ([#1238](https://github.com/rust-lang/cc-rs/pull/1238))
|
||||||
|
|
||||||
|
## [1.1.27](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.26...cc-v1.1.27) - 2024-10-06
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Revert "Use debug version of MSVC runtime library on debug ([#1231](https://github.com/rust-lang/cc-rs/pull/1231))" ([#1237](https://github.com/rust-lang/cc-rs/pull/1237))
|
||||||
|
- Disable `CC_ENABLE_DEBUG_OUTPUT` if it is set to "0" ([#1234](https://github.com/rust-lang/cc-rs/pull/1234))
|
||||||
|
|
||||||
|
## [1.1.26](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.25...cc-v1.1.26) - 2024-10-06
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Use debug version of MSVC runtime library on debug ([#1231](https://github.com/rust-lang/cc-rs/pull/1231))
|
||||||
|
|
||||||
|
## [1.1.25](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.24...cc-v1.1.25) - 2024-10-05
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Remove incorrect "lib" prefixes in CXXSTDLIB doc comments ([#1228](https://github.com/rust-lang/cc-rs/pull/1228))
|
||||||
|
|
||||||
|
## [1.1.24](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.23...cc-v1.1.24) - 2024-10-01
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Fix wasm32-wasip1-threads: shared-memory disallowed due to not compiled with 'atomics' or 'bulk-memory' features ([#1221](https://github.com/rust-lang/cc-rs/pull/1221))
|
||||||
|
- Reduce the need for the host target triple ([#1224](https://github.com/rust-lang/cc-rs/pull/1224))
|
||||||
|
- Add auto cancellation for CI jobs ([#1222](https://github.com/rust-lang/cc-rs/pull/1222))
|
||||||
|
|
||||||
|
## [1.1.23](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.22...cc-v1.1.23) - 2024-09-30
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Update doc for detecting changes/upgrades of compilers ([#1218](https://github.com/rust-lang/cc-rs/pull/1218))
|
||||||
|
|
||||||
|
## [1.1.22](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.21...cc-v1.1.22) - 2024-09-27
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Don't rerun if PATH changes ([#1215](https://github.com/rust-lang/cc-rs/pull/1215))
|
||||||
|
|
||||||
|
## [1.1.21](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.20...cc-v1.1.21) - 2024-09-18
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- disable pic for targets that end in `-none` ([#1212](https://github.com/rust-lang/cc-rs/pull/1212))
|
||||||
|
|
||||||
|
## [1.1.20](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.19...cc-v1.1.20) - 2024-09-17
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Add buildcache as known Rust and C/C++ compiler wrapper ([#1209](https://github.com/rust-lang/cc-rs/pull/1209))
|
||||||
|
|
||||||
|
## [1.1.19](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.18...cc-v1.1.19) - 2024-09-15
|
||||||
|
|
||||||
|
### Other
|
||||||
|
|
||||||
|
- Add support arm64e-apple-darwin ([#1207](https://github.com/rust-lang/cc-rs/pull/1207))
|
||||||
|
|
||||||
## [1.1.18](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.17...cc-v1.1.18) - 2024-09-07
|
## [1.1.18](https://github.com/rust-lang/cc-rs/compare/cc-v1.1.17...cc-v1.1.18) - 2024-09-07
|
||||||
|
|
||||||
### Other
|
### Other
|
||||||
|
2
pve-rs/vendor/cc/Cargo.toml
vendored
2
pve-rs/vendor/cc/Cargo.toml
vendored
@ -13,7 +13,7 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.63"
|
rust-version = "1.63"
|
||||||
name = "cc"
|
name = "cc"
|
||||||
version = "1.1.18"
|
version = "1.1.31"
|
||||||
authors = ["Alex Crichton <alex@alexcrichton.com>"]
|
authors = ["Alex Crichton <alex@alexcrichton.com>"]
|
||||||
build = false
|
build = false
|
||||||
exclude = [
|
exclude = [
|
||||||
|
5
pve-rs/vendor/cc/src/command_helpers.rs
vendored
5
pve-rs/vendor/cc/src/command_helpers.rs
vendored
@ -44,7 +44,10 @@ impl CargoOutput {
|
|||||||
metadata: true,
|
metadata: true,
|
||||||
warnings: true,
|
warnings: true,
|
||||||
output: OutputKind::Forward,
|
output: OutputKind::Forward,
|
||||||
debug: std::env::var_os("CC_ENABLE_DEBUG_OUTPUT").is_some(),
|
debug: match std::env::var_os("CC_ENABLE_DEBUG_OUTPUT") {
|
||||||
|
Some(v) => v != "0" && v != "false" && v != "",
|
||||||
|
None => false,
|
||||||
|
},
|
||||||
checked_dbg_var: Arc::new(AtomicBool::new(false)),
|
checked_dbg_var: Arc::new(AtomicBool::new(false)),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
112
pve-rs/vendor/cc/src/lib.rs
vendored
112
pve-rs/vendor/cc/src/lib.rs
vendored
@ -283,6 +283,9 @@ pub struct Build {
|
|||||||
ccbin: bool,
|
ccbin: bool,
|
||||||
std: Option<Arc<str>>,
|
std: Option<Arc<str>>,
|
||||||
target: Option<Arc<str>>,
|
target: Option<Arc<str>>,
|
||||||
|
/// The host compiler.
|
||||||
|
///
|
||||||
|
/// Try to not access this directly, and instead prefer `cfg!(...)`.
|
||||||
host: Option<Arc<str>>,
|
host: Option<Arc<str>>,
|
||||||
out_dir: Option<Arc<Path>>,
|
out_dir: Option<Arc<Path>>,
|
||||||
opt_level: Option<Arc<str>>,
|
opt_level: Option<Arc<str>>,
|
||||||
@ -658,11 +661,13 @@ impl Build {
|
|||||||
.cargo_metadata(self.cargo_output.metadata)
|
.cargo_metadata(self.cargo_output.metadata)
|
||||||
.target(target)
|
.target(target)
|
||||||
.opt_level(0)
|
.opt_level(0)
|
||||||
.host(&self.get_host()?)
|
|
||||||
.debug(false)
|
.debug(false)
|
||||||
.cpp(self.cpp)
|
.cpp(self.cpp)
|
||||||
.cuda(self.cuda)
|
.cuda(self.cuda)
|
||||||
.emit_rerun_if_env_changed(self.emit_rerun_if_env_changed);
|
.emit_rerun_if_env_changed(self.emit_rerun_if_env_changed);
|
||||||
|
if let Some(host) = &self.host {
|
||||||
|
cfg.host(host);
|
||||||
|
}
|
||||||
cfg.try_get_compiler()?
|
cfg.try_get_compiler()?
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -839,8 +844,8 @@ impl Build {
|
|||||||
/// The name of the C++ standard library to link is decided by:
|
/// The name of the C++ standard library to link is decided by:
|
||||||
/// 1. If [`cpp_link_stdlib`](Build::cpp_link_stdlib) is set, use its value.
|
/// 1. If [`cpp_link_stdlib`](Build::cpp_link_stdlib) is set, use its value.
|
||||||
/// 2. Else if the `CXXSTDLIB` environment variable is set, use its value.
|
/// 2. Else if the `CXXSTDLIB` environment variable is set, use its value.
|
||||||
/// 3. Else the default is `libc++` for OS X and BSDs, `libc++_shared` for Android,
|
/// 3. Else the default is `c++` for OS X and BSDs, `c++_shared` for Android,
|
||||||
/// `None` for MSVC and `libstdc++` for anything else.
|
/// `None` for MSVC and `stdc++` for anything else.
|
||||||
pub fn cpp(&mut self, cpp: bool) -> &mut Build {
|
pub fn cpp(&mut self, cpp: bool) -> &mut Build {
|
||||||
self.cpp = cpp;
|
self.cpp = cpp;
|
||||||
self
|
self
|
||||||
@ -1269,6 +1274,17 @@ impl Build {
|
|||||||
/// Define whether metadata should be emitted for cargo to detect environment
|
/// Define whether metadata should be emitted for cargo to detect environment
|
||||||
/// changes that should trigger a rebuild.
|
/// changes that should trigger a rebuild.
|
||||||
///
|
///
|
||||||
|
/// NOTE that cc does not emit metadata to detect changes for `PATH`, since it could
|
||||||
|
/// be changed every comilation yet does not affect the result of compilation
|
||||||
|
/// (i.e. rust-analyzer adds temporary directory to `PATH`).
|
||||||
|
///
|
||||||
|
/// cc in general, has no way detecting changes to compiler, as there are so many ways to
|
||||||
|
/// change it and sidestep the detection, for example the compiler might be wrapped in a script
|
||||||
|
/// so detecting change of the file, or using checksum won't work.
|
||||||
|
///
|
||||||
|
/// We recommend users to decide for themselves, if they want rebuild if the compiler has been upgraded
|
||||||
|
/// or changed, and how to detect that.
|
||||||
|
///
|
||||||
/// This has no effect if the `cargo_metadata` option is `false`.
|
/// This has no effect if the `cargo_metadata` option is `false`.
|
||||||
///
|
///
|
||||||
/// This option defaults to `true`.
|
/// This option defaults to `true`.
|
||||||
@ -1841,7 +1857,7 @@ impl Build {
|
|||||||
let mut cmd = self.get_base_compiler()?;
|
let mut cmd = self.get_base_compiler()?;
|
||||||
|
|
||||||
// Disable default flag generation via `no_default_flags` or environment variable
|
// Disable default flag generation via `no_default_flags` or environment variable
|
||||||
let no_defaults = self.no_default_flags || self.getenv("CRATE_CC_NO_DEFAULTS").is_some();
|
let no_defaults = self.no_default_flags || self.getenv_boolean("CRATE_CC_NO_DEFAULTS");
|
||||||
|
|
||||||
if !no_defaults {
|
if !no_defaults {
|
||||||
self.add_default_flags(&mut cmd, &target, &opt_level)?;
|
self.add_default_flags(&mut cmd, &target, &opt_level)?;
|
||||||
@ -1980,11 +1996,13 @@ impl Build {
|
|||||||
cmd.push_cc_arg("-fdata-sections".into());
|
cmd.push_cc_arg("-fdata-sections".into());
|
||||||
}
|
}
|
||||||
// Disable generation of PIC on bare-metal for now: rust-lld doesn't support this yet
|
// Disable generation of PIC on bare-metal for now: rust-lld doesn't support this yet
|
||||||
if self.pic.unwrap_or(
|
if self.pic.unwrap_or_else(|| {
|
||||||
!target.contains("windows")
|
!target.contains("windows")
|
||||||
&& !target.contains("-none-")
|
&& !target.contains("-none-")
|
||||||
&& !target.contains("uefi"),
|
&& !target.ends_with("-none")
|
||||||
) {
|
&& !target.contains("uefi")
|
||||||
|
&& !Build::is_wasi_target(target)
|
||||||
|
}) {
|
||||||
cmd.push_cc_arg("-fPIC".into());
|
cmd.push_cc_arg("-fPIC".into());
|
||||||
// PLT only applies if code is compiled with PIC support,
|
// PLT only applies if code is compiled with PIC support,
|
||||||
// and only for ELF targets.
|
// and only for ELF targets.
|
||||||
@ -2002,6 +2020,10 @@ impl Build {
|
|||||||
format!("--sysroot={}", Path::new(&wasi_sysroot).display()).into(),
|
format!("--sysroot={}", Path::new(&wasi_sysroot).display()).into(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if target.contains("threads") {
|
||||||
|
cmd.push_cc_arg("-pthread".into());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2697,7 +2719,7 @@ impl Build {
|
|||||||
let arch = if is_mac {
|
let arch = if is_mac {
|
||||||
match arch_str {
|
match arch_str {
|
||||||
"i686" => AppleArchSpec::Device("-m32"),
|
"i686" => AppleArchSpec::Device("-m32"),
|
||||||
"x86_64" | "x86_64h" | "aarch64" => AppleArchSpec::Device("-m64"),
|
"x86_64" | "x86_64h" | "aarch64" | "arm64e" => AppleArchSpec::Device("-m64"),
|
||||||
_ => {
|
_ => {
|
||||||
return Err(Error::new(
|
return Err(Error::new(
|
||||||
ErrorKind::ArchitectureInvalid,
|
ErrorKind::ArchitectureInvalid,
|
||||||
@ -2854,7 +2876,6 @@ impl Build {
|
|||||||
out_dir,
|
out_dir,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
let host = self.get_host()?;
|
|
||||||
let target = self.get_target()?;
|
let target = self.get_target()?;
|
||||||
let target = &*target;
|
let target = &*target;
|
||||||
let (env, msvc, gnu, traditional, clang) = if self.cpp {
|
let (env, msvc, gnu, traditional, clang) = if self.cpp {
|
||||||
@ -2867,7 +2888,7 @@ impl Build {
|
|||||||
// is not flag-compatible with "gcc". This history casts a long shadow,
|
// is not flag-compatible with "gcc". This history casts a long shadow,
|
||||||
// and many modern illumos distributions today ship GCC as "gcc" without
|
// and many modern illumos distributions today ship GCC as "gcc" without
|
||||||
// also making it available as "cc".
|
// also making it available as "cc".
|
||||||
let default = if host.contains("solaris") || host.contains("illumos") {
|
let default = if cfg!(target_os = "solaris") || cfg!(target_os = "illumos") {
|
||||||
gnu
|
gnu
|
||||||
} else {
|
} else {
|
||||||
traditional
|
traditional
|
||||||
@ -2932,7 +2953,7 @@ impl Build {
|
|||||||
let tool = match tool_opt {
|
let tool = match tool_opt {
|
||||||
Some(t) => t,
|
Some(t) => t,
|
||||||
None => {
|
None => {
|
||||||
let compiler = if host.contains("windows") && target.contains("windows") {
|
let compiler = if cfg!(windows) && target.contains("windows") {
|
||||||
if target.contains("msvc") {
|
if target.contains("msvc") {
|
||||||
msvc.to_string()
|
msvc.to_string()
|
||||||
} else {
|
} else {
|
||||||
@ -2946,7 +2967,7 @@ impl Build {
|
|||||||
{
|
{
|
||||||
clang.to_string()
|
clang.to_string()
|
||||||
} else if target.contains("android") {
|
} else if target.contains("android") {
|
||||||
autodetect_android_compiler(target, &host, gnu, clang)
|
autodetect_android_compiler(target, gnu, clang)
|
||||||
} else if target.contains("cloudabi") {
|
} else if target.contains("cloudabi") {
|
||||||
format!("{}-{}", target, traditional)
|
format!("{}-{}", target, traditional)
|
||||||
} else if Build::is_wasi_target(target) {
|
} else if Build::is_wasi_target(target) {
|
||||||
@ -2965,7 +2986,7 @@ impl Build {
|
|||||||
format!("arm-kmc-eabi-{}", gnu)
|
format!("arm-kmc-eabi-{}", gnu)
|
||||||
} else if target.starts_with("aarch64-kmc-solid_") {
|
} else if target.starts_with("aarch64-kmc-solid_") {
|
||||||
format!("aarch64-kmc-elf-{}", gnu)
|
format!("aarch64-kmc-elf-{}", gnu)
|
||||||
} else if &*self.get_host()? != target {
|
} else if self.get_is_cross_compile()? {
|
||||||
let prefix = self.prefix_for_target(target);
|
let prefix = self.prefix_for_target(target);
|
||||||
match prefix {
|
match prefix {
|
||||||
Some(prefix) => {
|
Some(prefix) => {
|
||||||
@ -3030,8 +3051,7 @@ impl Build {
|
|||||||
// on Windows is restricted to around 8k characters instead of around 32k characters.
|
// on Windows is restricted to around 8k characters instead of around 32k characters.
|
||||||
// To remove this limit, we call the main clang binary directly and construct the
|
// To remove this limit, we call the main clang binary directly and construct the
|
||||||
// `--target=` ourselves.
|
// `--target=` ourselves.
|
||||||
if host.contains("windows") && android_clang_compiler_uses_target_arg_internally(&tool.path)
|
if cfg!(windows) && android_clang_compiler_uses_target_arg_internally(&tool.path) {
|
||||||
{
|
|
||||||
if let Some(path) = tool.path.file_name() {
|
if let Some(path) = tool.path.file_name() {
|
||||||
let file_name = path.to_str().unwrap().to_owned();
|
let file_name = path.to_str().unwrap().to_owned();
|
||||||
let (target, clang) = file_name.split_at(file_name.rfind('-').unwrap());
|
let (target, clang) = file_name.split_at(file_name.rfind('-').unwrap());
|
||||||
@ -3088,7 +3108,7 @@ impl Build {
|
|||||||
// No explicit CC wrapper was detected, but check if RUSTC_WRAPPER
|
// No explicit CC wrapper was detected, but check if RUSTC_WRAPPER
|
||||||
// is defined and is a build accelerator that is compatible with
|
// is defined and is a build accelerator that is compatible with
|
||||||
// C/C++ compilers (e.g. sccache)
|
// C/C++ compilers (e.g. sccache)
|
||||||
const VALID_WRAPPERS: &[&str] = &["sccache", "cachepot"];
|
const VALID_WRAPPERS: &[&str] = &["sccache", "cachepot", "buildcache"];
|
||||||
|
|
||||||
let rustc_wrapper = self.getenv("RUSTC_WRAPPER")?;
|
let rustc_wrapper = self.getenv("RUSTC_WRAPPER")?;
|
||||||
let wrapper_path = Path::new(&rustc_wrapper);
|
let wrapper_path = Path::new(&rustc_wrapper);
|
||||||
@ -3142,7 +3162,14 @@ impl Build {
|
|||||||
//
|
//
|
||||||
// It's true that everything here is a bit of a pain, but apparently if
|
// It's true that everything here is a bit of a pain, but apparently if
|
||||||
// you're not literally make or bash then you get a lot of bug reports.
|
// you're not literally make or bash then you get a lot of bug reports.
|
||||||
let mut known_wrappers = vec!["ccache", "distcc", "sccache", "icecc", "cachepot"];
|
let mut known_wrappers = vec![
|
||||||
|
"ccache",
|
||||||
|
"distcc",
|
||||||
|
"sccache",
|
||||||
|
"icecc",
|
||||||
|
"cachepot",
|
||||||
|
"buildcache",
|
||||||
|
];
|
||||||
let custom_wrapper = self.getenv("CC_KNOWN_WRAPPER_CUSTOM");
|
let custom_wrapper = self.getenv("CC_KNOWN_WRAPPER_CUSTOM");
|
||||||
if custom_wrapper.is_some() {
|
if custom_wrapper.is_some() {
|
||||||
known_wrappers.push(custom_wrapper.as_deref().unwrap().to_str().unwrap());
|
known_wrappers.push(custom_wrapper.as_deref().unwrap().to_str().unwrap());
|
||||||
@ -3175,8 +3202,8 @@ impl Build {
|
|||||||
/// Returns the C++ standard library:
|
/// Returns the C++ standard library:
|
||||||
/// 1. If [`cpp_link_stdlib`](cc::Build::cpp_link_stdlib) is set, uses its value.
|
/// 1. If [`cpp_link_stdlib`](cc::Build::cpp_link_stdlib) is set, uses its value.
|
||||||
/// 2. Else if the `CXXSTDLIB` environment variable is set, uses its value.
|
/// 2. Else if the `CXXSTDLIB` environment variable is set, uses its value.
|
||||||
/// 3. Else the default is `libc++` for OS X and BSDs, `libc++_shared` for Android,
|
/// 3. Else the default is `c++` for OS X and BSDs, `c++_shared` for Android,
|
||||||
/// `None` for MSVC and `libstdc++` for anything else.
|
/// `None` for MSVC and `stdc++` for anything else.
|
||||||
fn get_cpp_link_stdlib(&self) -> Result<Option<Cow<'_, Path>>, Error> {
|
fn get_cpp_link_stdlib(&self) -> Result<Option<Cow<'_, Path>>, Error> {
|
||||||
match &self.cpp_link_stdlib {
|
match &self.cpp_link_stdlib {
|
||||||
Some(s) => Ok(s.as_deref().map(Path::new).map(Cow::Borrowed)),
|
Some(s) => Ok(s.as_deref().map(Path::new).map(Cow::Borrowed)),
|
||||||
@ -3411,7 +3438,7 @@ impl Build {
|
|||||||
// Use the GNU-variant to match other Unix systems.
|
// Use the GNU-variant to match other Unix systems.
|
||||||
name = format!("g{}", tool).into();
|
name = format!("g{}", tool).into();
|
||||||
self.cmd(&name)
|
self.cmd(&name)
|
||||||
} else if self.get_host()? != target {
|
} else if self.get_is_cross_compile()? {
|
||||||
match self.prefix_for_target(&target) {
|
match self.prefix_for_target(&target) {
|
||||||
Some(p) => {
|
Some(p) => {
|
||||||
// GCC uses $target-gcc-ar, whereas binutils uses $target-ar -- try both.
|
// GCC uses $target-gcc-ar, whereas binutils uses $target-ar -- try both.
|
||||||
@ -3625,11 +3652,13 @@ impl Build {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_host(&self) -> Result<Cow<'_, str>, Error> {
|
fn get_is_cross_compile(&self) -> Result<bool, Error> {
|
||||||
match &self.host {
|
let target = self.get_target()?;
|
||||||
Some(h) => Ok(Cow::Borrowed(h)),
|
let host: Cow<'_, str> = match &self.host {
|
||||||
None => self.getenv_unwrap_str("HOST").map(Cow::Owned),
|
Some(h) => Cow::Borrowed(h),
|
||||||
}
|
None => Cow::Owned(self.getenv_unwrap_str("HOST")?),
|
||||||
|
};
|
||||||
|
Ok(host != target)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_opt_level(&self) -> Result<Cow<'_, str>, Error> {
|
fn get_opt_level(&self) -> Result<Cow<'_, str>, Error> {
|
||||||
@ -3640,15 +3669,12 @@ impl Build {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn get_debug(&self) -> bool {
|
fn get_debug(&self) -> bool {
|
||||||
self.debug.unwrap_or_else(|| match self.getenv("DEBUG") {
|
self.debug.unwrap_or_else(|| self.getenv_boolean("DEBUG"))
|
||||||
Some(s) => &*s != "false",
|
|
||||||
None => false,
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_shell_escaped_flags(&self) -> bool {
|
fn get_shell_escaped_flags(&self) -> bool {
|
||||||
self.shell_escaped_flags
|
self.shell_escaped_flags
|
||||||
.unwrap_or_else(|| self.getenv("CC_SHELL_ESCAPED_FLAGS").is_some())
|
.unwrap_or_else(|| self.getenv_boolean("CC_SHELL_ESCAPED_FLAGS"))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_dwarf_version(&self) -> Option<u32> {
|
fn get_dwarf_version(&self) -> Option<u32> {
|
||||||
@ -3710,7 +3736,9 @@ impl Build {
|
|||||||
if let Some(val) = self.env_cache.read().unwrap().get(v).cloned() {
|
if let Some(val) = self.env_cache.read().unwrap().get(v).cloned() {
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
if self.emit_rerun_if_env_changed && !provided_by_cargo(v) {
|
// Excluding `PATH` prevents spurious rebuilds on Windows, see
|
||||||
|
// <https://github.com/rust-lang/cc-rs/pull/1215> for details.
|
||||||
|
if self.emit_rerun_if_env_changed && !provided_by_cargo(v) && v != "PATH" {
|
||||||
self.cargo_output
|
self.cargo_output
|
||||||
.print_metadata(&format_args!("cargo:rerun-if-env-changed={}", v));
|
.print_metadata(&format_args!("cargo:rerun-if-env-changed={}", v));
|
||||||
}
|
}
|
||||||
@ -3724,6 +3752,14 @@ impl Build {
|
|||||||
r
|
r
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// get boolean flag that is either true or false
|
||||||
|
fn getenv_boolean(&self, v: &str) -> bool {
|
||||||
|
match self.getenv(v) {
|
||||||
|
Some(s) => &*s != "0" && &*s != "false" && !s.is_empty(),
|
||||||
|
None => false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn getenv_unwrap(&self, v: &str) -> Result<Arc<OsStr>, Error> {
|
fn getenv_unwrap(&self, v: &str) -> Result<Arc<OsStr>, Error> {
|
||||||
match self.getenv(v) {
|
match self.getenv(v) {
|
||||||
Some(s) => Ok(s),
|
Some(s) => Ok(s),
|
||||||
@ -3746,8 +3782,11 @@ impl Build {
|
|||||||
|
|
||||||
fn getenv_with_target_prefixes(&self, var_base: &str) -> Result<Arc<OsStr>, Error> {
|
fn getenv_with_target_prefixes(&self, var_base: &str) -> Result<Arc<OsStr>, Error> {
|
||||||
let target = self.get_target()?;
|
let target = self.get_target()?;
|
||||||
let host = self.get_host()?;
|
let kind = if self.get_is_cross_compile()? {
|
||||||
let kind = if host == target { "HOST" } else { "TARGET" };
|
"TARGET"
|
||||||
|
} else {
|
||||||
|
"HOST"
|
||||||
|
};
|
||||||
let target_u = target.replace('-', "_");
|
let target_u = target.replace('-', "_");
|
||||||
let res = self
|
let res = self
|
||||||
.getenv(&format!("{}_{}", var_base, target))
|
.getenv(&format!("{}_{}", var_base, target))
|
||||||
@ -3780,8 +3819,7 @@ impl Build {
|
|||||||
|
|
||||||
fn fix_env_for_apple_os(&self, cmd: &mut Command) -> Result<(), Error> {
|
fn fix_env_for_apple_os(&self, cmd: &mut Command) -> Result<(), Error> {
|
||||||
let target = self.get_target()?;
|
let target = self.get_target()?;
|
||||||
let host = self.get_host()?;
|
if cfg!(target_os = "macos") && target.contains("apple-darwin") {
|
||||||
if host.contains("apple-darwin") && target.contains("apple-darwin") {
|
|
||||||
// Additionally, `IPHONEOS_DEPLOYMENT_TARGET` must not be set when using the Xcode linker at
|
// Additionally, `IPHONEOS_DEPLOYMENT_TARGET` must not be set when using the Xcode linker at
|
||||||
// "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/ld",
|
// "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/ld",
|
||||||
// although this is apparently ignored when using the linker at "/usr/bin/ld".
|
// although this is apparently ignored when using the linker at "/usr/bin/ld".
|
||||||
@ -4190,7 +4228,7 @@ fn android_clang_compiler_uses_target_arg_internally(clang_path: &Path) -> bool
|
|||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
fn autodetect_android_compiler(target: &str, host: &str, gnu: &str, clang: &str) -> String {
|
fn autodetect_android_compiler(target: &str, gnu: &str, clang: &str) -> String {
|
||||||
let new_clang_key = match target {
|
let new_clang_key = match target {
|
||||||
"aarch64-linux-android" => Some("aarch64"),
|
"aarch64-linux-android" => Some("aarch64"),
|
||||||
"armv7-linux-androideabi" => Some("armv7a"),
|
"armv7-linux-androideabi" => Some("armv7a"),
|
||||||
@ -4230,7 +4268,7 @@ fn autodetect_android_compiler(target: &str, host: &str, gnu: &str, clang: &str)
|
|||||||
// if not, use clang
|
// if not, use clang
|
||||||
if Command::new(&gnu_compiler).output().is_ok() {
|
if Command::new(&gnu_compiler).output().is_ok() {
|
||||||
gnu_compiler
|
gnu_compiler
|
||||||
} else if host.contains("windows") && Command::new(&clang_compiler_cmd).output().is_ok() {
|
} else if cfg!(windows) && Command::new(&clang_compiler_cmd).output().is_ok() {
|
||||||
clang_compiler_cmd
|
clang_compiler_cmd
|
||||||
} else {
|
} else {
|
||||||
clang_compiler
|
clang_compiler
|
||||||
|
3
pve-rs/vendor/cc/src/target_info.rs
vendored
3
pve-rs/vendor/cc/src/target_info.rs
vendored
@ -2,6 +2,9 @@
|
|||||||
//! in dev-tools/gen-target-info if you need to make changes.
|
//! in dev-tools/gen-target-info if you need to make changes.
|
||||||
|
|
||||||
pub const RISCV_ARCH_MAPPING: &[(&str, &str)] = &[
|
pub const RISCV_ARCH_MAPPING: &[(&str, &str)] = &[
|
||||||
|
("riscv32e", "riscv32"),
|
||||||
|
("riscv32em", "riscv32"),
|
||||||
|
("riscv32emc", "riscv32"),
|
||||||
("riscv32gc", "riscv32"),
|
("riscv32gc", "riscv32"),
|
||||||
("riscv32i", "riscv32"),
|
("riscv32i", "riscv32"),
|
||||||
("riscv32im", "riscv32"),
|
("riscv32im", "riscv32"),
|
||||||
|
2
pve-rs/vendor/flate2/.cargo-checksum.json
vendored
2
pve-rs/vendor/flate2/.cargo-checksum.json
vendored
File diff suppressed because one or more lines are too long
10
pve-rs/vendor/flate2/Cargo.lock
generated
vendored
10
pve-rs/vendor/flate2/Cargo.lock
generated
vendored
@ -52,7 +52,7 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "flate2"
|
name = "flate2"
|
||||||
version = "1.0.33"
|
version = "1.0.34"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cloudflare-zlib-sys",
|
"cloudflare-zlib-sys",
|
||||||
"crc32fast",
|
"crc32fast",
|
||||||
@ -93,9 +93,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "libz-rs-sys"
|
name = "libz-rs-sys"
|
||||||
version = "0.2.1"
|
version = "0.3.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7ec231cd2039ed0e15e72467a2eabcdf6ff103e8a95e01eb8e2fb6f4c0661be7"
|
checksum = "b6fe3b2b1132d0a04912e2ea4f1196212562ba7775abe9f3b32d49489b17b75d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"zlib-rs",
|
"zlib-rs",
|
||||||
]
|
]
|
||||||
@ -193,6 +193,6 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "zlib-rs"
|
name = "zlib-rs"
|
||||||
version = "0.2.1"
|
version = "0.3.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "e942bb8453553ee59b701f977d5331a512f8dd07906153bbe050cb9bb58a4811"
|
checksum = "4bf919c619da9eaede02291295e9c5ae230fc7b5f2a5f4257ff859b075111faf"
|
||||||
|
4
pve-rs/vendor/flate2/Cargo.toml
vendored
4
pve-rs/vendor/flate2/Cargo.toml
vendored
@ -13,7 +13,7 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.56.1"
|
rust-version = "1.56.1"
|
||||||
name = "flate2"
|
name = "flate2"
|
||||||
version = "1.0.33"
|
version = "1.0.34"
|
||||||
authors = [
|
authors = [
|
||||||
"Alex Crichton <alex@alexcrichton.com>",
|
"Alex Crichton <alex@alexcrichton.com>",
|
||||||
"Josh Triplett <josh@joshtriplett.org>",
|
"Josh Triplett <josh@joshtriplett.org>",
|
||||||
@ -177,7 +177,7 @@ version = "1.1.16"
|
|||||||
optional = true
|
optional = true
|
||||||
|
|
||||||
[dependencies.libz-rs-sys]
|
[dependencies.libz-rs-sys]
|
||||||
version = "0.2.1"
|
version = "0.3.0"
|
||||||
features = [
|
features = [
|
||||||
"std",
|
"std",
|
||||||
"rust-allocator",
|
"rust-allocator",
|
||||||
|
2
pve-rs/vendor/flate2/src/ffi/c.rs
vendored
2
pve-rs/vendor/flate2/src/ffi/c.rs
vendored
@ -447,7 +447,7 @@ mod c_backend {
|
|||||||
#[cfg(feature = "zlib-ng")]
|
#[cfg(feature = "zlib-ng")]
|
||||||
const ZLIB_VERSION: &'static str = "2.1.0.devel\0";
|
const ZLIB_VERSION: &'static str = "2.1.0.devel\0";
|
||||||
#[cfg(all(not(feature = "zlib-ng"), feature = "zlib-rs"))]
|
#[cfg(all(not(feature = "zlib-ng"), feature = "zlib-rs"))]
|
||||||
const ZLIB_VERSION: &'static str = "0.1.0\0";
|
const ZLIB_VERSION: &'static str = "1.3.0-zlib-rs-0.3.0\0";
|
||||||
#[cfg(not(any(feature = "zlib-ng", feature = "zlib-rs")))]
|
#[cfg(not(any(feature = "zlib-ng", feature = "zlib-rs")))]
|
||||||
const ZLIB_VERSION: &'static str = "1.2.8\0";
|
const ZLIB_VERSION: &'static str = "1.2.8\0";
|
||||||
|
|
||||||
|
14
pve-rs/vendor/flate2/src/lib.rs
vendored
14
pve-rs/vendor/flate2/src/lib.rs
vendored
@ -192,6 +192,18 @@ impl Compression {
|
|||||||
///
|
///
|
||||||
/// The integer here is typically on a scale of 0-9 where 0 means "no
|
/// The integer here is typically on a scale of 0-9 where 0 means "no
|
||||||
/// compression" and 9 means "take as long as you'd like".
|
/// compression" and 9 means "take as long as you'd like".
|
||||||
|
///
|
||||||
|
/// ### Backend differences
|
||||||
|
///
|
||||||
|
/// The [`miniz_oxide`](https://crates.io/crates/miniz_oxide) backend for flate2
|
||||||
|
/// does not support level 0 or `Compression::none()`. Instead it interprets them
|
||||||
|
/// as the default compression level, which is quite slow.
|
||||||
|
/// `Compression::fast()` should be used instead.
|
||||||
|
///
|
||||||
|
/// `miniz_oxide` also supports a non-compliant compression level 10.
|
||||||
|
/// It is even slower and may result in higher compression, but
|
||||||
|
/// **only miniz_oxide will be able to read the data** compressed with level 10.
|
||||||
|
/// Do **not** use level 10 if you need other software to be able to read it!
|
||||||
pub const fn new(level: u32) -> Compression {
|
pub const fn new(level: u32) -> Compression {
|
||||||
Compression(level)
|
Compression(level)
|
||||||
}
|
}
|
||||||
@ -213,7 +225,7 @@ impl Compression {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Returns an integer representing the compression level, typically on a
|
/// Returns an integer representing the compression level, typically on a
|
||||||
/// scale of 0-9
|
/// scale of 0-9. See [`new`](Self::new) for details about compression levels.
|
||||||
pub fn level(&self) -> u32 {
|
pub fn level(&self) -> u32 {
|
||||||
self.0
|
self.0
|
||||||
}
|
}
|
||||||
|
1
pve-rs/vendor/fmt2io/.cargo-checksum.json
vendored
Normal file
1
pve-rs/vendor/fmt2io/.cargo-checksum.json
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
{"files":{"CHANGELOG.md":"04652d7c24426c471cae8b682ca4a1698de375a090a6b70ece2b41951ba33640","Cargo.toml":"a51fa0ef99f3ad34aef64907151d80c723a6143cba3aaa38b4f2e35cc82f1537","LICENSE":"7399628e08f01b7d94d42395ac7f50b95aad25faffa670d39c8b2d0281adf551","README.md":"a66c6718d61c2cabe11e2f41cbfc5dca5293b77b5927b9466fa09a3ead6b8d56","clippy.toml":"e0f282c75faa7e46c2630843826bb78f39dd2a6dea78dab7f960d34f730fb396","src/lib.rs":"eba884c4ffb319eecf896fe67351ace042660d36af9d32e955ab137c16b74493"},"package":"6b6129284da9f7e5296cc22183a63f24300e945e297705dcc0672f7df01d62c8"}
|
18
pve-rs/vendor/fmt2io/CHANGELOG.md
vendored
Normal file
18
pve-rs/vendor/fmt2io/CHANGELOG.md
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# Changes
|
||||||
|
|
||||||
|
## 1.0.0 - Fri Sep 6 2024
|
||||||
|
|
||||||
|
* The crate is now considered stable
|
||||||
|
* Support Rust 1.0.0
|
||||||
|
* Various documentation improvements
|
||||||
|
* Fixed the `maintenance` badge
|
||||||
|
|
||||||
|
## 0.2.0 - Tue Jun 22 2021
|
||||||
|
|
||||||
|
Breaking change: the `write` function can now return any value in the `Ok` variant.
|
||||||
|
This is breaking because the number of generic arguments changed,
|
||||||
|
however if you didn't use turbofish to specify them there's no real break for you.
|
||||||
|
|
||||||
|
## 0.1.0 - Tue Nov 6 2018
|
||||||
|
|
||||||
|
Initial version capable of bridging `fmt` to `io` writes that didn't produce any value.
|
39
pve-rs/vendor/fmt2io/Cargo.toml
vendored
Normal file
39
pve-rs/vendor/fmt2io/Cargo.toml
vendored
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO
|
||||||
|
#
|
||||||
|
# When uploading crates to the registry Cargo will automatically
|
||||||
|
# "normalize" Cargo.toml files for maximal compatibility
|
||||||
|
# with all versions of Cargo and also rewrite `path` dependencies
|
||||||
|
# to registry (e.g., crates.io) dependencies.
|
||||||
|
#
|
||||||
|
# If you are reading this file be aware that the original Cargo.toml
|
||||||
|
# will likely look very different (and much more reasonable).
|
||||||
|
# See Cargo.toml.orig for the original contents.
|
||||||
|
|
||||||
|
[package]
|
||||||
|
name = "fmt2io"
|
||||||
|
version = "1.0.0"
|
||||||
|
authors = ["Martin Habovstiak <martin.habovstiak@gmail.com>"]
|
||||||
|
build = false
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
|
description = "A bridge between std::io::Write and std::fmt::Write."
|
||||||
|
readme = "README.md"
|
||||||
|
keywords = [
|
||||||
|
"fmt",
|
||||||
|
"io",
|
||||||
|
"Write",
|
||||||
|
"wrapper",
|
||||||
|
"bridge",
|
||||||
|
]
|
||||||
|
categories = ["rust-patterns"]
|
||||||
|
license = "MITNFA"
|
||||||
|
repository = "https://github.com/Kixunil/fmt2io"
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "fmt2io"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
|
[badges.maintenance]
|
||||||
|
status = "as-is"
|
9
pve-rs/vendor/fmt2io/LICENSE
vendored
Normal file
9
pve-rs/vendor/fmt2io/LICENSE
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
Copyright (c) 2024 Martin Habovštiak
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
Distributions of all or part of the Software intended to be used by the recipients as they would use the unmodified Software, containing modifications that substantially alter, remove, or disable functionality of the Software, outside of the documented configuration mechanisms provided by the Software, shall be modified such that the Original Author's bug reporting email addresses and urls are either replaced with the contact information of the parties responsible for the changes, or removed entirely.
|
||||||
|
|
||||||
|
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.
|
42
pve-rs/vendor/fmt2io/README.md
vendored
Normal file
42
pve-rs/vendor/fmt2io/README.md
vendored
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
Fmt to IO
|
||||||
|
=========
|
||||||
|
|
||||||
|
A bridge between `std::io::Write` and `std::fmt::Write`.
|
||||||
|
|
||||||
|
About
|
||||||
|
-----
|
||||||
|
|
||||||
|
Have you ever implemented a nice algorithm that generically uses `fmt::Write`
|
||||||
|
only to find out it doesn't work with `io::Write`? Worry no more - this is the
|
||||||
|
solution!
|
||||||
|
|
||||||
|
This crate provides a simple `write` function which takes your `io::Write`r,
|
||||||
|
converts it to `fmt::Write`r and provides it to your closure. This way, you
|
||||||
|
can easily bridge the two traits and have truly generic code.
|
||||||
|
|
||||||
|
Maintenance status
|
||||||
|
------------------
|
||||||
|
|
||||||
|
Passively maintained/done.
|
||||||
|
|
||||||
|
The crate does one thing and one thing only.
|
||||||
|
It works as expected and has sensible API.
|
||||||
|
It didn't need to be changed for a very long time and only had one significant code change since
|
||||||
|
its creation.
|
||||||
|
The other changes were purely for cleanup before 1.0 release.
|
||||||
|
It's also very small so there's pretty much zero chance of bugs.
|
||||||
|
Therefore I consider it done.
|
||||||
|
It's not dead, there just doesn't seem to be anything that needs changing.
|
||||||
|
|
||||||
|
MSRV
|
||||||
|
----
|
||||||
|
|
||||||
|
The minimal supported version of Rust is **1.0.0**.
|
||||||
|
This is not a joke, the crate really doesn't require any fancy compiler features.
|
||||||
|
However I don't object to raising the MSRV up to what's in Debian stable if some really good
|
||||||
|
reason arises. This is highly unlikely to happen.
|
||||||
|
|
||||||
|
License
|
||||||
|
-------
|
||||||
|
|
||||||
|
MITNFA
|
1
pve-rs/vendor/fmt2io/clippy.toml
vendored
Normal file
1
pve-rs/vendor/fmt2io/clippy.toml
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
msrv = "1.0.0"
|
105
pve-rs/vendor/fmt2io/src/lib.rs
vendored
Normal file
105
pve-rs/vendor/fmt2io/src/lib.rs
vendored
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
//! Have you ever implemented a nice algorithm that generically uses `fmt::Write`
|
||||||
|
//! only to find out it doesn't work with `io::Write`? Worry no more - this is the
|
||||||
|
//! solution!
|
||||||
|
//!
|
||||||
|
//! This crate provides a simple `write` function which takes your `io::Write`r,
|
||||||
|
//! converts it to `fmt::Write`r and provides it to your closure. This way, you
|
||||||
|
//! can easily bridge the two traits and have truly generic code.
|
||||||
|
//!
|
||||||
|
//! Example
|
||||||
|
//! -------
|
||||||
|
//!
|
||||||
|
//! ```rust
|
||||||
|
//! use std::fmt::Write;
|
||||||
|
//!
|
||||||
|
//! let mut out = Vec::new();
|
||||||
|
//!
|
||||||
|
//! fmt2io::write(&mut out, |writer| write!(writer, "Hello world!"))?;
|
||||||
|
//! assert_eq!(out, "Hello world!".as_bytes());
|
||||||
|
//!
|
||||||
|
//! # Ok::<(), std::io::Error>(())
|
||||||
|
//! ```
|
||||||
|
//!
|
||||||
|
//! Maintenance status
|
||||||
|
//! ------------------
|
||||||
|
//!
|
||||||
|
//! Passively maintained/done.
|
||||||
|
//!
|
||||||
|
//! The crate does one thing and one thing only.
|
||||||
|
//! It works as expected and has sensible API.
|
||||||
|
//! It didn't need to be changed for a very long time and only had one significant code change since
|
||||||
|
//! its creation.
|
||||||
|
//! The other changes were purely for cleanup before 1.0 release.
|
||||||
|
//! It's also very small so there's pretty much zero chance of bugs.
|
||||||
|
//! Therefore I consider it done.
|
||||||
|
//! It's not dead, there just doesn't seem to be anything that needs changing.
|
||||||
|
//!
|
||||||
|
//! MSRV
|
||||||
|
//! ----
|
||||||
|
//!
|
||||||
|
//! The minimal supported version of Rust is **1.0.0**.
|
||||||
|
//! This is not a joke, the crate really doesn't require any fancy compiler features.
|
||||||
|
//! However I don't object to raising the MSRV up to what's in Debian stable if some really good
|
||||||
|
//! reason arises. This is highly unlikely to happen.
|
||||||
|
|
||||||
|
use std::{fmt, io};
|
||||||
|
|
||||||
|
/// Converts given [`io::Write`]r to [`fmt::Write`]r.
|
||||||
|
///
|
||||||
|
/// The [`Writer`] is constructed from your `writer` which you
|
||||||
|
/// can use to write UTF-8 data to. The function returns underlying io
|
||||||
|
/// Error, if there has been one.
|
||||||
|
///
|
||||||
|
/// This function uses closure instead of directly exposing [`Writer`]
|
||||||
|
/// in order to make error handling ergonomic/idiomatic.
|
||||||
|
///
|
||||||
|
/// See the [crate-level documentation](crate) for an example.
|
||||||
|
///
|
||||||
|
/// ## Panics
|
||||||
|
///
|
||||||
|
/// This function panics if `writer` didn't return an error but you
|
||||||
|
/// return `Err` from the closure. Return `Ok(Err(YourError))` to handle
|
||||||
|
/// your own error cases.
|
||||||
|
pub fn write<R, W, F>(writer: W, f: F) -> io::Result<R> where W: io::Write, F: FnOnce(&mut Writer<W>) -> Result<R, fmt::Error> {
|
||||||
|
let mut writer = Writer {
|
||||||
|
writer: writer,
|
||||||
|
result: Ok(()),
|
||||||
|
};
|
||||||
|
|
||||||
|
let result = f(&mut writer);
|
||||||
|
|
||||||
|
writer.result.map(move |_| result.unwrap())
|
||||||
|
}
|
||||||
|
|
||||||
|
/// A bridge between [`std::io::Write`] and [`std::fmt::Write`].
|
||||||
|
///
|
||||||
|
/// This struct provides [`fmt::Write`] implementation for inner
|
||||||
|
/// writers implementing [`io::Write`]. It must be used within the
|
||||||
|
/// [`write()`] function.
|
||||||
|
///
|
||||||
|
/// See the documentation of [`write()`] for more information.
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct Writer<W: io::Write> {
|
||||||
|
writer: W,
|
||||||
|
result: Result<(), io::Error>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<W: io::Write> fmt::Write for Writer<W> {
|
||||||
|
fn write_str(&mut self, s: &str) -> Result<(), fmt::Error> {
|
||||||
|
self.writer.write_all(s.as_bytes()).map_err(|err| { self.result = Err(err); fmt::Error })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
#[test]
|
||||||
|
fn it_works() {
|
||||||
|
use std::fmt::Write;
|
||||||
|
|
||||||
|
let mut out = Vec::new();
|
||||||
|
|
||||||
|
::write(&mut out, |writer| write!(writer, "Hello world!")).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(out, "Hello world!".as_bytes());
|
||||||
|
}
|
||||||
|
}
|
@ -1 +1 @@
|
|||||||
{"files":{"Cargo.toml":"21a7215adbf49919270abecb9deb8d81a32383f4d2163d82869139cbffe6648e","LICENSE-APACHE":"275c491d6d1160553c32fd6127061d7f9606c3ea25abfad6ca3f6ed088785427","LICENSE-MIT":"6652c868f35dfe5e8ef636810a4e576b9d663f3a17fb0f5613ad73583e1b88fd","README.md":"e8258273fed6f1796485777655118f2369fd3f000191e9d8cdbd10bf052946a9","src/future.rs":"0cb559fad0d43566dab959e929c4631c25cf749e2e29a5444fbcad464c9262ae","src/lib.rs":"eacd5816fbb914ca061d49ff6203723ebbe639eb7c45ebfa8a0613069d174111","src/stream.rs":"f1c7ab84161c5d5b424655b257fc3183eb6f2ed5324ba4006a70f9a4b0dc8872","src/task/__internal/atomic_waker.rs":"e5184bcc772c1472a2f0f9899bd3e388b74b771d327d801a5ea7e4aca6e57715","src/task/__internal/mod.rs":"1cc15fd61942a29ea558c5f4d5782e46adcfd914cab82be084a6882fa9afc122","src/task/mod.rs":"e213602a2fe5ae78ad5f1ca20e6d32dcbab17aba5b6b072fb927a72da99b4a11","src/task/poll.rs":"74c2717c1f9a37587a367da1b690d1cd2312e95dbaffca42be4755f1cd164bb8"},"package":"dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d"}
|
{"files":{"Cargo.toml":"c0ee4bd5904127f284fff848d01d9e6539e1762e6c1291f55025a9bf0b754827","LICENSE-APACHE":"275c491d6d1160553c32fd6127061d7f9606c3ea25abfad6ca3f6ed088785427","LICENSE-MIT":"6652c868f35dfe5e8ef636810a4e576b9d663f3a17fb0f5613ad73583e1b88fd","README.md":"e8258273fed6f1796485777655118f2369fd3f000191e9d8cdbd10bf052946a9","src/future.rs":"bdbe034548271aef0c3dd8a6d087a5861e5920848c9e33a8949dbc40407c0ca7","src/lib.rs":"e545004177a7cd13257a3a562d2d44a5e0cff45687fc912b69e3d510fa397396","src/stream.rs":"11f0b4360287dd870c1b674db84f2452ddc38fbaf475cca27d374b65211af72d","src/task/__internal/atomic_waker.rs":"0418206de25768f691944c81f61ccec2c362751e56757bf812385c8ef01081fe","src/task/__internal/mod.rs":"1cc15fd61942a29ea558c5f4d5782e46adcfd914cab82be084a6882fa9afc122","src/task/mod.rs":"e213602a2fe5ae78ad5f1ca20e6d32dcbab17aba5b6b072fb927a72da99b4a11","src/task/poll.rs":"74c2717c1f9a37587a367da1b690d1cd2312e95dbaffca42be4755f1cd164bb8"},"package":"05f29059c0c2090612e8d742178b0580d2dc940c837851ad723096f87af6663e"}
|
22
pve-rs/vendor/futures-core/Cargo.toml
vendored
22
pve-rs/vendor/futures-core/Cargo.toml
vendored
@ -13,7 +13,12 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.36"
|
rust-version = "1.36"
|
||||||
name = "futures-core"
|
name = "futures-core"
|
||||||
version = "0.3.30"
|
version = "0.3.31"
|
||||||
|
build = false
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
description = """
|
description = """
|
||||||
The core traits and types in for the `futures` library.
|
The core traits and types in for the `futures` library.
|
||||||
"""
|
"""
|
||||||
@ -29,6 +34,10 @@ rustdoc-args = [
|
|||||||
"docsrs",
|
"docsrs",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "futures_core"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
[dependencies.portable-atomic]
|
[dependencies.portable-atomic]
|
||||||
version = "1.3"
|
version = "1.3"
|
||||||
features = ["require-cas"]
|
features = ["require-cas"]
|
||||||
@ -43,3 +52,14 @@ cfg-target-has-atomic = []
|
|||||||
default = ["std"]
|
default = ["std"]
|
||||||
std = ["alloc"]
|
std = ["alloc"]
|
||||||
unstable = []
|
unstable = []
|
||||||
|
|
||||||
|
[lints.rust]
|
||||||
|
missing_debug_implementations = "warn"
|
||||||
|
rust_2018_idioms = "warn"
|
||||||
|
single_use_lifetimes = "warn"
|
||||||
|
unreachable_pub = "warn"
|
||||||
|
|
||||||
|
[lints.rust.unexpected_cfgs]
|
||||||
|
level = "warn"
|
||||||
|
priority = 0
|
||||||
|
check-cfg = ["cfg(futures_sanitizer)"]
|
||||||
|
10
pve-rs/vendor/futures-core/src/future.rs
vendored
10
pve-rs/vendor/futures-core/src/future.rs
vendored
@ -9,10 +9,20 @@ pub use core::future::Future;
|
|||||||
|
|
||||||
/// An owned dynamically typed [`Future`] for use in cases where you can't
|
/// An owned dynamically typed [`Future`] for use in cases where you can't
|
||||||
/// statically type your result or need to add some indirection.
|
/// statically type your result or need to add some indirection.
|
||||||
|
///
|
||||||
|
/// This type is often created by the [`boxed`] method on [`FutureExt`]. See its documentation for more.
|
||||||
|
///
|
||||||
|
/// [`boxed`]: https://docs.rs/futures/latest/futures/future/trait.FutureExt.html#method.boxed
|
||||||
|
/// [`FutureExt`]: https://docs.rs/futures/latest/futures/future/trait.FutureExt.html
|
||||||
#[cfg(feature = "alloc")]
|
#[cfg(feature = "alloc")]
|
||||||
pub type BoxFuture<'a, T> = Pin<alloc::boxed::Box<dyn Future<Output = T> + Send + 'a>>;
|
pub type BoxFuture<'a, T> = Pin<alloc::boxed::Box<dyn Future<Output = T> + Send + 'a>>;
|
||||||
|
|
||||||
/// `BoxFuture`, but without the `Send` requirement.
|
/// `BoxFuture`, but without the `Send` requirement.
|
||||||
|
///
|
||||||
|
/// This type is often created by the [`boxed_local`] method on [`FutureExt`]. See its documentation for more.
|
||||||
|
///
|
||||||
|
/// [`boxed_local`]: https://docs.rs/futures/latest/futures/future/trait.FutureExt.html#method.boxed_local
|
||||||
|
/// [`FutureExt`]: https://docs.rs/futures/latest/futures/future/trait.FutureExt.html
|
||||||
#[cfg(feature = "alloc")]
|
#[cfg(feature = "alloc")]
|
||||||
pub type LocalBoxFuture<'a, T> = Pin<alloc::boxed::Box<dyn Future<Output = T> + 'a>>;
|
pub type LocalBoxFuture<'a, T> = Pin<alloc::boxed::Box<dyn Future<Output = T> + 'a>>;
|
||||||
|
|
||||||
|
8
pve-rs/vendor/futures-core/src/lib.rs
vendored
8
pve-rs/vendor/futures-core/src/lib.rs
vendored
@ -1,9 +1,6 @@
|
|||||||
//! Core traits and types for asynchronous operations in Rust.
|
//! Core traits and types for asynchronous operations in Rust.
|
||||||
|
|
||||||
#![cfg_attr(not(feature = "std"), no_std)]
|
#![no_std]
|
||||||
#![warn(missing_debug_implementations, missing_docs, rust_2018_idioms, unreachable_pub)]
|
|
||||||
// It cannot be included in the published code because this lints have false positives in the minimum required version.
|
|
||||||
#![cfg_attr(test, warn(single_use_lifetimes))]
|
|
||||||
#![doc(test(
|
#![doc(test(
|
||||||
no_crate_inject,
|
no_crate_inject,
|
||||||
attr(
|
attr(
|
||||||
@ -11,9 +8,12 @@
|
|||||||
allow(dead_code, unused_assignments, unused_variables)
|
allow(dead_code, unused_assignments, unused_variables)
|
||||||
)
|
)
|
||||||
))]
|
))]
|
||||||
|
#![warn(missing_docs, /* unsafe_op_in_unsafe_fn */)] // unsafe_op_in_unsafe_fn requires Rust 1.52
|
||||||
|
|
||||||
#[cfg(feature = "alloc")]
|
#[cfg(feature = "alloc")]
|
||||||
extern crate alloc;
|
extern crate alloc;
|
||||||
|
#[cfg(feature = "std")]
|
||||||
|
extern crate std;
|
||||||
|
|
||||||
pub mod future;
|
pub mod future;
|
||||||
#[doc(no_inline)]
|
#[doc(no_inline)]
|
||||||
|
20
pve-rs/vendor/futures-core/src/stream.rs
vendored
20
pve-rs/vendor/futures-core/src/stream.rs
vendored
@ -6,10 +6,20 @@ use core::task::{Context, Poll};
|
|||||||
|
|
||||||
/// An owned dynamically typed [`Stream`] for use in cases where you can't
|
/// An owned dynamically typed [`Stream`] for use in cases where you can't
|
||||||
/// statically type your result or need to add some indirection.
|
/// statically type your result or need to add some indirection.
|
||||||
|
///
|
||||||
|
/// This type is often created by the [`boxed`] method on [`StreamExt`]. See its documentation for more.
|
||||||
|
///
|
||||||
|
/// [`boxed`]: https://docs.rs/futures/latest/futures/stream/trait.StreamExt.html#method.boxed
|
||||||
|
/// [`StreamExt`]: https://docs.rs/futures/latest/futures/stream/trait.StreamExt.html
|
||||||
#[cfg(feature = "alloc")]
|
#[cfg(feature = "alloc")]
|
||||||
pub type BoxStream<'a, T> = Pin<alloc::boxed::Box<dyn Stream<Item = T> + Send + 'a>>;
|
pub type BoxStream<'a, T> = Pin<alloc::boxed::Box<dyn Stream<Item = T> + Send + 'a>>;
|
||||||
|
|
||||||
/// `BoxStream`, but without the `Send` requirement.
|
/// `BoxStream`, but without the `Send` requirement.
|
||||||
|
///
|
||||||
|
/// This type is often created by the [`boxed_local`] method on [`StreamExt`]. See its documentation for more.
|
||||||
|
///
|
||||||
|
/// [`boxed_local`]: https://docs.rs/futures/latest/futures/stream/trait.StreamExt.html#method.boxed_local
|
||||||
|
/// [`StreamExt`]: https://docs.rs/futures/latest/futures/stream/trait.StreamExt.html
|
||||||
#[cfg(feature = "alloc")]
|
#[cfg(feature = "alloc")]
|
||||||
pub type LocalBoxStream<'a, T> = Pin<alloc::boxed::Box<dyn Stream<Item = T> + 'a>>;
|
pub type LocalBoxStream<'a, T> = Pin<alloc::boxed::Box<dyn Stream<Item = T> + 'a>>;
|
||||||
|
|
||||||
@ -38,15 +48,15 @@ pub trait Stream {
|
|||||||
/// stream state:
|
/// stream state:
|
||||||
///
|
///
|
||||||
/// - `Poll::Pending` means that this stream's next value is not ready
|
/// - `Poll::Pending` means that this stream's next value is not ready
|
||||||
/// yet. Implementations will ensure that the current task will be notified
|
/// yet. Implementations will ensure that the current task will be notified
|
||||||
/// when the next value may be ready.
|
/// when the next value may be ready.
|
||||||
///
|
///
|
||||||
/// - `Poll::Ready(Some(val))` means that the stream has successfully
|
/// - `Poll::Ready(Some(val))` means that the stream has successfully
|
||||||
/// produced a value, `val`, and may produce further values on subsequent
|
/// produced a value, `val`, and may produce further values on subsequent
|
||||||
/// `poll_next` calls.
|
/// `poll_next` calls.
|
||||||
///
|
///
|
||||||
/// - `Poll::Ready(None)` means that the stream has terminated, and
|
/// - `Poll::Ready(None)` means that the stream has terminated, and
|
||||||
/// `poll_next` should not be invoked again.
|
/// `poll_next` should not be invoked again.
|
||||||
///
|
///
|
||||||
/// # Panics
|
/// # Panics
|
||||||
///
|
///
|
||||||
|
@ -206,6 +206,7 @@ impl AtomicWaker {
|
|||||||
/// Create an `AtomicWaker`.
|
/// Create an `AtomicWaker`.
|
||||||
pub const fn new() -> Self {
|
pub const fn new() -> Self {
|
||||||
// Make sure that task is Sync
|
// Make sure that task is Sync
|
||||||
|
#[allow(dead_code)]
|
||||||
trait AssertSync: Sync {}
|
trait AssertSync: Sync {}
|
||||||
impl AssertSync for Waker {}
|
impl AssertSync for Waker {}
|
||||||
|
|
||||||
|
@ -1 +1 @@
|
|||||||
{"files":{"Cargo.toml":"a2f46c222bebd5fae127414ffb34535af67be92b58bafcc39a16523ffc33ee83","LICENSE-APACHE":"275c491d6d1160553c32fd6127061d7f9606c3ea25abfad6ca3f6ed088785427","LICENSE-MIT":"6652c868f35dfe5e8ef636810a4e576b9d663f3a17fb0f5613ad73583e1b88fd","README.md":"575430be5c47352d85f36b44dcc2c2851a6a19e2384593415c4af22c6654cee7","src/lib.rs":"526e9700c28250b7512f122952257d57adc38eb001af92ef25bdb48a8c453175"},"package":"a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1"}
|
{"files":{"Cargo.toml":"1b91c3dcf4888590e4e0499bbc7f261d97278782875032bef60952b4f47c5872","LICENSE-APACHE":"275c491d6d1160553c32fd6127061d7f9606c3ea25abfad6ca3f6ed088785427","LICENSE-MIT":"6652c868f35dfe5e8ef636810a4e576b9d663f3a17fb0f5613ad73583e1b88fd","README.md":"575430be5c47352d85f36b44dcc2c2851a6a19e2384593415c4af22c6654cee7","src/lib.rs":"ff0a57a4c0eea4b7677404cdca237729f0af9c5dfc9539d23583a71ac7e9cc42"},"package":"9e5c1b78ca4aae1ac06c48a526a655760685149f0d465d21f37abfe57ce075c6"}
|
22
pve-rs/vendor/futures-io/Cargo.toml
vendored
22
pve-rs/vendor/futures-io/Cargo.toml
vendored
@ -13,7 +13,12 @@
|
|||||||
edition = "2018"
|
edition = "2018"
|
||||||
rust-version = "1.36"
|
rust-version = "1.36"
|
||||||
name = "futures-io"
|
name = "futures-io"
|
||||||
version = "0.3.30"
|
version = "0.3.31"
|
||||||
|
build = false
|
||||||
|
autobins = false
|
||||||
|
autoexamples = false
|
||||||
|
autotests = false
|
||||||
|
autobenches = false
|
||||||
description = """
|
description = """
|
||||||
The `AsyncRead`, `AsyncWrite`, `AsyncSeek`, and `AsyncBufRead` traits for the futures-rs library.
|
The `AsyncRead`, `AsyncWrite`, `AsyncSeek`, and `AsyncBufRead` traits for the futures-rs library.
|
||||||
"""
|
"""
|
||||||
@ -29,9 +34,24 @@ rustdoc-args = [
|
|||||||
"docsrs",
|
"docsrs",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[lib]
|
||||||
|
name = "futures_io"
|
||||||
|
path = "src/lib.rs"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = ["std"]
|
default = ["std"]
|
||||||
std = []
|
std = []
|
||||||
unstable = []
|
unstable = []
|
||||||
|
|
||||||
|
[lints.rust]
|
||||||
|
missing_debug_implementations = "warn"
|
||||||
|
rust_2018_idioms = "warn"
|
||||||
|
single_use_lifetimes = "warn"
|
||||||
|
unreachable_pub = "warn"
|
||||||
|
|
||||||
|
[lints.rust.unexpected_cfgs]
|
||||||
|
level = "warn"
|
||||||
|
priority = 0
|
||||||
|
check-cfg = ["cfg(futures_sanitizer)"]
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user