Skip to content

Commit a8ec78a

Browse files
committed
Inline generic bounds rather than using the where clause
The bindings generator is pretty naive in its generic resolution and doesn't like `where` clauses for bounds that are simple traits. This should eventually change, but for now its simplest to just inline the relevant generic bounds.
1 parent ee6ee3f commit a8ec78a

File tree

1 file changed

+2
-4
lines changed

1 file changed

+2
-4
lines changed

lightning/src/util/persist.rs

Lines changed: 2 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -26,13 +26,12 @@ pub trait KVStorePersister {
2626
}
2727

2828
/// Trait that handles persisting a [`ChannelManager`], [`NetworkGraph`], and [`WriteableScore`] to disk.
29-
pub trait Persister<'a, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref, S>
29+
pub trait Persister<'a, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref, S: WriteableScore<'a>>
3030
where M::Target: 'static + chain::Watch<Signer>,
3131
T::Target: 'static + BroadcasterInterface,
3232
K::Target: 'static + KeysInterface<Signer = Signer>,
3333
F::Target: 'static + FeeEstimator,
3434
L::Target: 'static + Logger,
35-
S: WriteableScore<'a>,
3635
{
3736
/// Persist the given ['ChannelManager'] to disk, returning an error if persistence failed.
3837
fn persist_manager(&self, channel_manager: &ChannelManager<Signer, M, T, K, F, L>) -> Result<(), io::Error>;
@@ -44,13 +43,12 @@ pub trait Persister<'a, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L:
4443
fn persist_scorer(&self, scorer: &S) -> Result<(), io::Error>;
4544
}
4645

47-
impl<'a, A: KVStorePersister, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref, S> Persister<'a, Signer, M, T, K, F, L, S> for A
46+
impl<'a, A: KVStorePersister, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref, S: WriteableScore<'a>> Persister<'a, Signer, M, T, K, F, L, S> for A
4847
where M::Target: 'static + chain::Watch<Signer>,
4948
T::Target: 'static + BroadcasterInterface,
5049
K::Target: 'static + KeysInterface<Signer = Signer>,
5150
F::Target: 'static + FeeEstimator,
5251
L::Target: 'static + Logger,
53-
S: WriteableScore<'a>,
5452
{
5553
/// Persist the given ['ChannelManager'] to disk with the name "manager", returning an error if persistence failed.
5654
fn persist_manager(&self, channel_manager: &ChannelManager<Signer, M, T, K, F, L>) -> Result<(), io::Error> {

0 commit comments

Comments
 (0)