@@ -2223,6 +2223,8 @@ where L::Target: Logger {
2223
2223
// if the amount being transferred over this path is lower.
2224
2224
// We do this for now, but this is a subject for removal.
2225
2225
if let Some ( mut available_value_contribution_msat) = htlc_maximum_msat. checked_sub( $next_hops_fee_msat) {
2226
+ let cltv_expiry_delta = $candidate. cltv_expiry_delta( ) ;
2227
+ let htlc_minimum_msat = $candidate. htlc_minimum_msat( ) ;
2226
2228
let used_liquidity_msat = used_liquidities
2227
2229
. get( & $candidate. id( ) )
2228
2230
. map_or( 0 , |used_liquidity_msat| {
@@ -2245,7 +2247,7 @@ where L::Target: Logger {
2245
2247
. checked_sub( 2 * MEDIAN_HOP_CLTV_EXPIRY_DELTA )
2246
2248
. unwrap_or( payment_params. max_total_cltv_expiry_delta - final_cltv_expiry_delta) ;
2247
2249
let hop_total_cltv_delta = ( $next_hops_cltv_delta as u32 )
2248
- . saturating_add( $candidate . cltv_expiry_delta( ) ) ;
2250
+ . saturating_add( cltv_expiry_delta) ;
2249
2251
let exceeds_cltv_delta_limit = hop_total_cltv_delta > max_total_cltv_expiry_delta;
2250
2252
2251
2253
let value_contribution_msat = cmp:: min( available_value_contribution_msat, $next_hops_value_contribution) ;
@@ -2255,7 +2257,6 @@ where L::Target: Logger {
2255
2257
// Can't overflow due to how the values were computed right above.
2256
2258
None => unreachable!( ) ,
2257
2259
} ;
2258
- let htlc_minimum_msat = $candidate. htlc_minimum_msat( ) ;
2259
2260
#[ allow( unused_comparisons) ] // $next_hops_path_htlc_minimum_msat is 0 in some calls so rustc complains
2260
2261
let over_path_minimum_msat = amount_to_transfer_over_msat >= htlc_minimum_msat &&
2261
2262
amount_to_transfer_over_msat >= $next_hops_path_htlc_minimum_msat;
@@ -2345,12 +2346,14 @@ where L::Target: Logger {
2345
2346
// payment path (upstream to the payee). To avoid that, we recompute
2346
2347
// path fees knowing the final path contribution after constructing it.
2347
2348
let curr_min = cmp:: max(
2348
- $next_hops_path_htlc_minimum_msat, $candidate . htlc_minimum_msat( )
2349
+ $next_hops_path_htlc_minimum_msat, htlc_minimum_msat
2349
2350
) ;
2350
- let path_htlc_minimum_msat = compute_fees_saturating( curr_min, $candidate. fees( ) )
2351
+ let candidate_fees = $candidate. fees( ) ;
2352
+ let src_node_counter = $candidate. src_node_counter( ) ;
2353
+ let path_htlc_minimum_msat = compute_fees_saturating( curr_min, candidate_fees)
2351
2354
. saturating_add( curr_min) ;
2352
2355
2353
- let dist_entry = & mut dist[ $candidate . src_node_counter( ) as usize ] ;
2356
+ let dist_entry = & mut dist[ src_node_counter as usize ] ;
2354
2357
let old_entry = if let Some ( hop) = dist_entry {
2355
2358
hop
2356
2359
} else {
@@ -2394,7 +2397,7 @@ where L::Target: Logger {
2394
2397
if src_node_id != our_node_id {
2395
2398
// Note that `u64::max_value` means we'll always fail the
2396
2399
// `old_entry.total_fee_msat > total_fee_msat` check below
2397
- hop_use_fee_msat = compute_fees_saturating( amount_to_transfer_over_msat, $candidate . fees ( ) ) ;
2400
+ hop_use_fee_msat = compute_fees_saturating( amount_to_transfer_over_msat, candidate_fees ) ;
2398
2401
total_fee_msat = total_fee_msat. saturating_add( hop_use_fee_msat) ;
2399
2402
}
2400
2403
0 commit comments