feat(wallet): use the new CombinedChangeSet of bdk_persist
				
					
				
			This commit is contained in:
		
							parent
							
								
									0958ff56b2
								
							
						
					
					
						commit
						b8aa76cd05
					
				| @ -20,7 +20,7 @@ bitcoin = { version = "0.31.0", features = ["serde", "base64", "rand-std"], defa | ||||
| serde = { version = "^1.0", features = ["derive"] } | ||||
| serde_json = { version = "^1.0" } | ||||
| bdk_chain = { path = "../chain", version = "0.14.0", features = ["miniscript", "serde"], default-features = false } | ||||
| bdk_persist = { path = "../persist", version = "0.2.0" } | ||||
| bdk_persist = { path = "../persist", version = "0.2.0", features = ["miniscript", "serde"], default-features = false } | ||||
| 
 | ||||
| # Optional dependencies | ||||
| bip39 = { version = "2.0", optional = true } | ||||
|  | ||||
| @ -22,7 +22,7 @@ use alloc::{ | ||||
| pub use bdk_chain::keychain::Balance; | ||||
| use bdk_chain::{ | ||||
|     indexed_tx_graph, | ||||
|     keychain::{self, KeychainTxOutIndex}, | ||||
|     keychain::KeychainTxOutIndex, | ||||
|     local_chain::{ | ||||
|         self, ApplyHeaderError, CannotConnectError, CheckPoint, CheckPointIter, LocalChain, | ||||
|     }, | ||||
| @ -134,72 +134,7 @@ impl From<SyncResult> for Update { | ||||
| } | ||||
| 
 | ||||
| /// The changes made to a wallet by applying an [`Update`].
 | ||||
| #[derive(Debug, Clone, PartialEq, serde::Serialize, serde::Deserialize, Default)] | ||||
| pub struct ChangeSet { | ||||
|     /// Changes to the [`LocalChain`].
 | ||||
|     ///
 | ||||
|     /// [`LocalChain`]: local_chain::LocalChain
 | ||||
|     pub chain: local_chain::ChangeSet, | ||||
| 
 | ||||
|     /// Changes to [`IndexedTxGraph`].
 | ||||
|     ///
 | ||||
|     /// [`IndexedTxGraph`]: bdk_chain::indexed_tx_graph::IndexedTxGraph
 | ||||
|     pub indexed_tx_graph: indexed_tx_graph::ChangeSet< | ||||
|         ConfirmationTimeHeightAnchor, | ||||
|         keychain::ChangeSet<KeychainKind>, | ||||
|     >, | ||||
| 
 | ||||
|     /// Stores the network type of the wallet.
 | ||||
|     pub network: Option<Network>, | ||||
| } | ||||
| 
 | ||||
| impl Append for ChangeSet { | ||||
|     fn append(&mut self, other: Self) { | ||||
|         Append::append(&mut self.chain, other.chain); | ||||
|         Append::append(&mut self.indexed_tx_graph, other.indexed_tx_graph); | ||||
|         if other.network.is_some() { | ||||
|             debug_assert!( | ||||
|                 self.network.is_none() || self.network == other.network, | ||||
|                 "network type must be consistent" | ||||
|             ); | ||||
|             self.network = other.network; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn is_empty(&self) -> bool { | ||||
|         self.chain.is_empty() && self.indexed_tx_graph.is_empty() | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl From<local_chain::ChangeSet> for ChangeSet { | ||||
|     fn from(chain: local_chain::ChangeSet) -> Self { | ||||
|         Self { | ||||
|             chain, | ||||
|             ..Default::default() | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl | ||||
|     From< | ||||
|         indexed_tx_graph::ChangeSet< | ||||
|             ConfirmationTimeHeightAnchor, | ||||
|             keychain::ChangeSet<KeychainKind>, | ||||
|         >, | ||||
|     > for ChangeSet | ||||
| { | ||||
|     fn from( | ||||
|         indexed_tx_graph: indexed_tx_graph::ChangeSet< | ||||
|             ConfirmationTimeHeightAnchor, | ||||
|             keychain::ChangeSet<KeychainKind>, | ||||
|         >, | ||||
|     ) -> Self { | ||||
|         Self { | ||||
|             indexed_tx_graph, | ||||
|             ..Default::default() | ||||
|         } | ||||
|     } | ||||
| } | ||||
| pub type ChangeSet = bdk_persist::CombinedChangeSet<KeychainKind, ConfirmationTimeHeightAnchor>; | ||||
| 
 | ||||
| /// A derived address and the index it was found at.
 | ||||
| /// For convenience this automatically derefs to `Address`
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user