-
Notifications
You must be signed in to change notification settings - Fork 87
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bump rusqlite
to 0.31
#403
Conversation
Oh I see a similar PR for |
b6bf6ba
to
065f128
Compare
Mhh, please note that we don't like to arbitrarily bump dependencies if there is no good reason for it. Generally, given that LDK Node already wraps BDK, I don't think users should run a SQLite-backed BDK wallet in parallel. So the quoted reason isn't a super great motivation. However, you mentioned offline that you're working on
I doubt they'd be will to do this. @dpc Would you benefit from bumping |
.github/workflows/rust.yml
Outdated
cargo update -p proptest --precise "1.2.0" --verbose # proptest 1.3.0 requires rustc 1.64.0 | ||
cargo update -p regex --precise "1.9.6" --verbose # regex 1.10.0 requires rustc 1.65.0 | ||
cargo update -p home --precise "0.5.5" --verbose # home v0.5.9 requires rustc 1.70 or newer | ||
cargo update -p tokio --precise "1.38.1" --verbose # tokio v1.39.0 requires rustc 1.70 or newer | ||
cargo update -p tokio-util --precise "0.7.11" --verbose # tokio-util v0.7.12 requires rustc 1.70 or newer | ||
cargo update -p idna_adapter --precise "1.1.0" --verbose # url 2.5.3 switched to idna 1.0.3 and ICU4X, which requires rustc 1.67 or newer. Here we opt to keep using unicode-rs by pinning idna_adapter as described here: https://docs.rs/crate/idna_adapter/1.2.0 | ||
cargo update -p indexmap --precise "2.5.0" --verbose # indexmap 2.6.0 upgraded to hashbrown 0.15, which unfortunately bumped their MSRV to rustc 1.65 with the 0.15.1 release | ||
cargo update -p cc --precise "1.0.105" --verbose # cc 1.0.106 bumps MSRV to 1.67 | ||
cargo update -p time --precise "0.3.20" --verbose # time 0.3.21 bumps MSRV to 1.65 | ||
cargo update -p zstd-sys --precise "2.0.8+zstd.1.5.5" --verbose # no changelogs available |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think we want to start pinning compression algorithms if it can be avoided (and previously always found a way to avoid bumping zstd
in particular). Could you explain why it suddenly is necessary?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am unsure at the moment. I will look into this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Embarrassing mistake. zstd-sys
is brought in from electrsd
and is not related. This was negligence on my part copying pins from another CI.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Embarrassing mistake. zstd-sys is brought in from electrsd and is not related.
I assume the same could be true for cc
and time
?
This was negligence on my part copying pins from another CI.
No worries, nbd really!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
time
is an optional dependency of rusqlite
and you are right ldk-node
does not use it.
cc
is a build dependency of libsqlite3-sys
which broke MSRV on a patch version. I was unsure if this was necessary or not and I will try without it.
edit: yes cc
appeared unnecessary as well
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alright, one last nit regarding the pinning: mind moving dropping the hashlink
pin to a separate commit and explaining why we can now do so in the commit message?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updated with those changes
Yes. For the record, having |
065f128
to
a69e258
Compare
I updated and removed the |
At Edit: Actually, never mind. I tried that, turns out that there's no way to have conditional sys dependencies because of cargo bug/limitation.
|
The flaky CI test is unrelated/preexisting, you might need to kick CI once more to have this pass. |
Really this is a bug in sqlite-sys. If they want to use export a heap of C symbols they need to rename them on a per-version basis. We could work around them being broken, but ideally we wouldn't have to cause it looks like we're far from the only library that's gonna cause this. |
73d9e6c
to
8057467
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alright, I think mod the tiny nit above this LGTM.
IIUC this would at least temporarily improve things for users of BDK/kyoto
, while not making the situation worse for Fedimint (correct me if I'm wrong @dpc),
👍 All things being equal, newer is better. |
`hashlink` `0.9.1` is a member of `rusqlite` `0.31.0`, which uses `hashbrown`. Previously `hashbrown` broke MSRV on a patch version (0.14.4), but `hashlink` uses the next minor version of `hashbrown` (0.15.1) which does adhere MSRV
8057467
to
f1e702d
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
hashbrown
0.14.1
relaxes the MSRV to1.63.0
according to this changelog, and, indeed, I compiled and tested locally on the 1.63 toolchain. I remove that here, as well as add the necessary pins forrusqlite
0.31
.Motivation for this would be to allow users to depend on both BDK and
ldk-node
withrusqlite
backends for each. Of courseldk-node
usesbdk_wallet
, but users may also bring in the dependency themselves for more advanced usage.