Merge rust-bitcoin/rust-bitcoin#1714: update rust-secp to 0.27.0
bef7992ce5Update readme to mention pin for 1.47 (Tobin C. Harding)58033cf14epin serde dep on 1.47 (Tobin C. Harding)f5f4a33fa9pin serde dep on 1.41 (Andrew Poelstra)ee9b297e98ci: update dupe check to whitelist syn (Andrew Poelstra)6aa640ff8dupdate rust-secp to 0.27.0 (Andrew Poelstra) Pull request description: Also remove the spurious dev-dependency copy of rust-secp, which should've been updated to remove the "recovery" feature in https://www.github.com/rust-bitcoin/rust-bitcoin/pull/545 and then been removed entirely in https://www.github.com/rust-bitcoin/rust-bitcoin/pull/1387 ACKs for top commit: Kixunil: ACKbef7992ce5tcharding: ACKbef7992ce5Tree-SHA512: 7d1bf062dc6920bcafa85311b4b5ed348e31fb20aa21156e545bf7a4cc4c194e2b6dcfd0d3c6db3df337e4e2cd0f7b74f41ea421549521f07080feb88fbd9382
This commit is contained in:
		
						commit
						2f404f9b5c
					
				|  | @ -79,8 +79,11 @@ For more information please see `./CONTRIBUTING.md`. | ||||||
| This library should always compile with any combination of features (minus | This library should always compile with any combination of features (minus | ||||||
| `no-std`) on **Rust 1.41.1** or **Rust 1.47** with `no-std`. | `no-std`) on **Rust 1.41.1** or **Rust 1.47** with `no-std`. | ||||||
| 
 | 
 | ||||||
| To build with the MSRV you will need to pin some dependencies, currently this is | To build with the MSRV you will need to pin some dependencies (also for `no-std`): | ||||||
| only `syn`, and can be achieved using `cargo update -p syn --precise 1.0.107`. | ``` | ||||||
|  | cargo update -p serde --precise 1.0.156 | ||||||
|  | cargo update -p syn --precise 1.0.107 | ||||||
|  | ``` | ||||||
| 
 | 
 | ||||||
| ## Installing Rust | ## Installing Rust | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -37,7 +37,7 @@ rustdoc-args = ["--cfg", "docsrs"] | ||||||
| bitcoin-internals = { path = "../internals", package = "bitcoin-private", version = "0.1.0" } | bitcoin-internals = { path = "../internals", package = "bitcoin-private", version = "0.1.0" } | ||||||
| bech32 = { version = "0.9.0", default-features = false } | bech32 = { version = "0.9.0", default-features = false } | ||||||
| bitcoin_hashes = { version = "0.12.0", default-features = false } | bitcoin_hashes = { version = "0.12.0", default-features = false } | ||||||
| secp256k1 = { git = "https://github.com/rust-bitcoin/rust-secp256k1", tag = "2023-03-05--fix-hashes", default-features = false, features = ["bitcoin_hashes"] } | secp256k1 = { version = "0.27.0", default-features = false, features = ["bitcoin_hashes"] } | ||||||
| hex_lit = "0.1.1" | hex_lit = "0.1.1" | ||||||
| 
 | 
 | ||||||
| base64 = { version = "0.13.0", optional = true } | base64 = { version = "0.13.0", optional = true } | ||||||
|  | @ -50,7 +50,6 @@ actual-serde = { package = "serde", version = "1.0.103", default-features = fals | ||||||
| serde_json = "1.0.0" | serde_json = "1.0.0" | ||||||
| serde_test = "1.0.19" | serde_test = "1.0.19" | ||||||
| serde_derive = "1.0.103" | serde_derive = "1.0.103" | ||||||
| secp256k1 = { git = "https://github.com/rust-bitcoin/rust-secp256k1", tag = "2023-03-05--fix-hashes", features = ["recovery"] } |  | ||||||
| bincode = "1.3.1" | bincode = "1.3.1" | ||||||
| 
 | 
 | ||||||
| [target.'cfg(mutate)'.dev-dependencies] | [target.'cfg(mutate)'.dev-dependencies] | ||||||
|  |  | ||||||
|  | @ -25,13 +25,28 @@ fi | ||||||
| 
 | 
 | ||||||
| # Pin dependencies as required if we are using MSRV toolchain. | # Pin dependencies as required if we are using MSRV toolchain. | ||||||
| if cargo --version | grep "1\.41"; then | if cargo --version | grep "1\.41"; then | ||||||
|  |     # 1.0.157 uses syn 2.0 which requires edition 2018 | ||||||
|  |     cargo update -p serde --precise 1.0.156 | ||||||
|     # 1.0.108 uses `matches!` macro so does not work with Rust 1.41.1, bad `syn` no biscuit. |     # 1.0.108 uses `matches!` macro so does not work with Rust 1.41.1, bad `syn` no biscuit. | ||||||
|     cargo update -p syn --precise 1.0.107 |     cargo update -p syn --precise 1.0.107 | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | # Pin dependencies as above (required for no-std tests that use Rust 1.47 toolchain). | ||||||
|  | if cargo --version | grep "1\.47"; then | ||||||
|  |     cargo update -p serde --precise 1.0.156 | ||||||
|  |     cargo update -p syn --precise 1.0.107 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| # We should not have any duplicate dependencies. This catches mistakes made upgrading dependencies | # We should not have any duplicate dependencies. This catches mistakes made upgrading dependencies | ||||||
| # in one crate and not in another (e.g. upgrade bitcoin_hashes in bitcoin but not in secp). | # in one crate and not in another (e.g. upgrade bitcoin_hashes in bitcoin but not in secp). | ||||||
| duplicate_dependencies=$(cargo tree  --target=all --all-features --duplicates | wc -l) | duplicate_dependencies=$( | ||||||
|  |     # Only show the actual duplicated deps, not their reverse tree, then | ||||||
|  |     # whitelist the 'syn' crate which is duplicated but it's not our fault. | ||||||
|  |     cargo tree  --target=all --all-features --duplicates \ | ||||||
|  |         | grep '^[0-9A-Za-z]' \ | ||||||
|  |         | grep -v 'syn' \ | ||||||
|  |         | wc -l | ||||||
|  | ) | ||||||
| if [ "$duplicate_dependencies" -ne 0 ]; then | if [ "$duplicate_dependencies" -ne 0 ]; then | ||||||
|     echo "Dependency tree is broken, contains duplicates" |     echo "Dependency tree is broken, contains duplicates" | ||||||
|     cargo tree  --target=all --all-features --duplicates |     cargo tree  --target=all --all-features --duplicates | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue