@@ -3271,8 +3271,8 @@ macro_rules! locked_close_channel {
3271
3271
}};
3272
3272
($self: ident, $peer_state: expr, $funded_chan: expr, $shutdown_res_mut: expr, FUNDED) => {{
3273
3273
if let Some((_, funding_txo, _, update)) = $shutdown_res_mut.monitor_update.take() {
3274
- handle_new_monitor_update !($self, funding_txo, update, $peer_state,
3275
- $funded_chan.context, REMAIN_LOCKED_UPDATE_ACTIONS_PROCESSED_LATER );
3274
+ handle_new_monitor_update_todo_name !($self, funding_txo, update, $peer_state,
3275
+ $funded_chan.context);
3276
3276
}
3277
3277
// If there's a possibility that we need to generate further monitor updates for this
3278
3278
// channel, we need to store the last update_id of it. However, we don't want to insert
@@ -3666,6 +3666,7 @@ macro_rules! handle_post_close_monitor_update {
3666
3666
idx,
3667
3667
_internal_outer,
3668
3668
{
3669
+ // If we get a monitor update for a closed channel
3669
3670
let _ = in_flight_updates.remove(idx);
3670
3671
if in_flight_updates.is_empty() {
3671
3672
let update_actions = $peer_state
@@ -3683,6 +3684,33 @@ macro_rules! handle_post_close_monitor_update {
3683
3684
}};
3684
3685
}
3685
3686
3687
+ macro_rules! handle_new_monitor_update_todo_name {
3688
+ (
3689
+ $self: ident, $funding_txo: expr, $update: expr, $peer_state: expr, $chan_context: expr
3690
+ ) => {{
3691
+ let logger = WithChannelContext::from(&$self.logger, &$chan_context, None);
3692
+ let chan_id = $chan_context.channel_id();
3693
+ let counterparty_node_id = $chan_context.get_counterparty_node_id();
3694
+ let in_flight_updates;
3695
+ let idx;
3696
+ handle_new_monitor_update!(
3697
+ $self,
3698
+ $funding_txo,
3699
+ $update,
3700
+ $peer_state,
3701
+ logger,
3702
+ chan_id,
3703
+ counterparty_node_id,
3704
+ in_flight_updates,
3705
+ idx,
3706
+ _internal_outer,
3707
+ {
3708
+ let _ = in_flight_updates.remove(idx);
3709
+ }
3710
+ )
3711
+ }};
3712
+ }
3713
+
3686
3714
macro_rules! handle_new_monitor_update {
3687
3715
(
3688
3716
$self: ident, $funding_txo: expr, $update: expr, $peer_state: expr, $logger: expr,
@@ -3732,31 +3760,6 @@ macro_rules! handle_new_monitor_update {
3732
3760
false
3733
3761
}
3734
3762
}};
3735
- (
3736
- $self: ident, $funding_txo: expr, $update: expr, $peer_state: expr, $chan_context: expr,
3737
- REMAIN_LOCKED_UPDATE_ACTIONS_PROCESSED_LATER
3738
- ) => {{
3739
- let logger = WithChannelContext::from(&$self.logger, &$chan_context, None);
3740
- let chan_id = $chan_context.channel_id();
3741
- let counterparty_node_id = $chan_context.get_counterparty_node_id();
3742
- let in_flight_updates;
3743
- let idx;
3744
- handle_new_monitor_update!(
3745
- $self,
3746
- $funding_txo,
3747
- $update,
3748
- $peer_state,
3749
- logger,
3750
- chan_id,
3751
- counterparty_node_id,
3752
- in_flight_updates,
3753
- idx,
3754
- _internal_outer,
3755
- {
3756
- let _ = in_flight_updates.remove(idx);
3757
- }
3758
- )
3759
- }};
3760
3763
(
3761
3764
$self: ident, $funding_txo: expr, $update: expr, $peer_state_lock: expr, $peer_state: expr,
3762
3765
$per_peer_state_lock: expr, $chan: expr
@@ -14039,13 +14042,12 @@ where
14039
14042
insert_short_channel_id!(short_to_chan_info, funded_channel);
14040
14043
14041
14044
if let Some(monitor_update) = monitor_update_opt {
14042
- handle_new_monitor_update !(
14045
+ handle_new_monitor_update_todo_name !(
14043
14046
self,
14044
14047
funding_txo,
14045
14048
monitor_update,
14046
14049
peer_state,
14047
- funded_channel.context,
14048
- REMAIN_LOCKED_UPDATE_ACTIONS_PROCESSED_LATER
14050
+ funded_channel.context
14049
14051
);
14050
14052
to_process_monitor_update_actions.push((
14051
14053
counterparty_node_id, channel_id
0 commit comments