Skip to content
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

imp: further minimization of prost imports #1000

Merged
merged 5 commits into from
Dec 2, 2023
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
- [`ibc`] Minimize `prost` dependency by introducing `ToVec` trait
- Now `prost` is only imported in `ibc-primitives` crate
- Remove error variants originating from `prost` (Breaking change)
- Eliminate the need for the `bytes` dependency
([\#997](https://github.com/cosmos/ibc-rs/issues/997))

This file was deleted.

2 changes: 0 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -48,12 +48,10 @@ authors = ["Informal Systems <[email protected]>"]
[workspace.dependencies]
# external dependencies
borsh = { version = "0.10", default-features = false }
bytes = { version = "1.5.0", default-features = false }
displaydoc = { version = "0.2", default-features = false }
derive_more = { version = "0.99.17", default-features = false, features = ["from", "into", "display", "try_into"] }
num-traits = { version = "0.2.17", default-features = false }
primitive-types = { version = "0.12.2", default-features = false, features = ["serde_no_std"] }
prost = { version = "0.12", default-features = false }
rstest = "0.18.2"
schemars = { version = "0.8.15" }
sha2 = { version = "0.10.8", default-features = false }
Expand Down
25 changes: 6 additions & 19 deletions ci/cw-check/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

16 changes: 0 additions & 16 deletions ci/no-std-check/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 4 additions & 7 deletions ibc-clients/ics07-tendermint/src/client_state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@
CommitmentPrefix, CommitmentProofBytes, CommitmentRoot,
};
use ibc_core_commitment_types::merkle::{apply_prefix, MerkleProof};
use ibc_core_commitment_types::proto::v1::MerkleProof as RawMerkleProof;
use ibc_core_host::types::identifiers::{ClientId, ClientType};
use ibc_core_host::types::path::{
ClientConsensusStatePath, ClientStatePath, Path, UpgradeClientPath,
Expand Down Expand Up @@ -199,9 +198,8 @@
value: Vec<u8>,
) -> Result<(), ClientError> {
let merkle_path = apply_prefix(prefix, vec![path.to_string()]);
let merkle_proof: MerkleProof = RawMerkleProof::try_from(proof.clone())
.map_err(ClientError::InvalidCommitmentProof)?
.into();
let merkle_proof =
MerkleProof::try_from(proof.clone()).map_err(ClientError::InvalidCommitmentProof)?;

Check warning on line 202 in ibc-clients/ics07-tendermint/src/client_state.rs

View check run for this annotation

Codecov / codecov/patch

ibc-clients/ics07-tendermint/src/client_state.rs#L201-L202

Added lines #L201 - L202 were not covered by tests

merkle_proof
.verify_membership(
Expand All @@ -222,9 +220,8 @@
path: Path,
) -> Result<(), ClientError> {
let merkle_path = apply_prefix(prefix, vec![path.to_string()]);
let merkle_proof: MerkleProof = RawMerkleProof::try_from(proof.clone())
.map_err(ClientError::InvalidCommitmentProof)?
.into();
let merkle_proof =
MerkleProof::try_from(proof.clone()).map_err(ClientError::InvalidCommitmentProof)?;

Check warning on line 224 in ibc-clients/ics07-tendermint/src/client_state.rs

View check run for this annotation

Codecov / codecov/patch

ibc-clients/ics07-tendermint/src/client_state.rs#L223-L224

Added lines #L223 - L224 were not covered by tests

merkle_proof
.verify_non_membership(&self.0.proof_specs, root.clone().into(), merkle_path)
Expand Down
4 changes: 0 additions & 4 deletions ibc-clients/ics07-tendermint/types/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,7 @@ all-features = true
[dependencies]
# external dependencies
borsh = { workspace = true, optional = true }
bytes = { workspace = true }
displaydoc = { workspace = true }
prost = { workspace = true }
serde = { workspace = true, optional = true }

# ibc dependencies
Expand All @@ -48,9 +46,7 @@ tendermint-rpc = { workspace = true }
[features]
default = ["std"]
std = [
"bytes/std",
"displaydoc/std",
"prost/std",
"serde/std",
"serde_json/std",
"ibc-core-client-types/std",
Expand Down
20 changes: 8 additions & 12 deletions ibc-clients/ics07-tendermint/types/src/client_state.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
use ibc_proto::ibc::core::client::v1::Height as RawHeight;
use ibc_proto::ibc::lightclients::tendermint::v1::ClientState as RawTmClientState;
use ibc_proto::Protobuf;
use prost::Message;
use tendermint::chain::id::MAX_LENGTH as MaxChainIdLen;
use tendermint::trust_threshold::TrustThresholdFraction as TendermintTrustThresholdFraction;
use tendermint_light_client_verifier::options::Options;
Expand Down Expand Up @@ -346,20 +345,17 @@
type Error = ClientError;

fn try_from(raw: Any) -> Result<Self, Self::Error> {
use core::ops::Deref;

use bytes::Buf;

fn decode_client_state<B: Buf>(buf: B) -> Result<ClientState, Error> {
RawTmClientState::decode(buf)
.map_err(Error::Decode)?
.try_into()
fn decode_client_state(value: &[u8]) -> Result<ClientState, ClientError> {
let client_state = Protobuf::<RawTmClientState>::decode_vec(value).map_err(|e| {
ClientError::Other {
description: e.to_string(),
}

Check warning on line 352 in ibc-clients/ics07-tendermint/types/src/client_state.rs

View check run for this annotation

Codecov / codecov/patch

ibc-clients/ics07-tendermint/types/src/client_state.rs#L350-L352

Added lines #L350 - L352 were not covered by tests
})?;
Ok(client_state)
}

match raw.type_url.as_str() {
TENDERMINT_CLIENT_STATE_TYPE_URL => {
decode_client_state(raw.value.deref()).map_err(Into::into)
}
TENDERMINT_CLIENT_STATE_TYPE_URL => decode_client_state(&raw.value),
_ => Err(ClientError::UnknownClientStateType {
client_state_type: raw.type_url,
}),
Expand Down
Loading
Loading