lnwallet: fix bug in extractHtlcResolutions, ensure slice is contiguous

This commit fixes an existing bug within extractHtlcResolutions. The
prior code would use an index to assign the returned
OutgoingHtlcResolutions into a single slice. However, this is invalid
as there are two cases where an HTLC might be skipped: if it’s an
incoming HTLC, or if the HLTC itself is dust from the PoV of the
commitment chain.

To fix this, we now instead use append to add items to the slice. This
ensure that we don’t have any “empty” items in between fully populated
items.
This commit is contained in:
Olaoluwa Osuntokun 2017-09-29 14:32:11 -07:00
parent 2141b481ef
commit dc764c992c
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21

@ -3521,8 +3521,8 @@ func extractHtlcResolutions(feePerKw btcutil.Amount, ourCommit bool,
csvDelay = localChanCfg.CsvDelay csvDelay = localChanCfg.CsvDelay
} }
htlcResolutions := make([]OutgoingHtlcResolution, len(htlcs)) htlcResolutions := make([]OutgoingHtlcResolution, 0, len(htlcs))
for i, htlc := range htlcs { for _, htlc := range htlcs {
// Skip any incoming HTLC's, as unless we have the pre-image to // Skip any incoming HTLC's, as unless we have the pre-image to
// spend them, they'll eventually be swept by the party that // spend them, they'll eventually be swept by the party that
// offered the HTLC after the timeout. // offered the HTLC after the timeout.
@ -3548,7 +3548,7 @@ func extractHtlcResolutions(feePerKw btcutil.Amount, ourCommit bool,
} }
// TODO(roasbeef): needs to point to proper amount including // TODO(roasbeef): needs to point to proper amount including
htlcResolutions[i] = *ohr htlcResolutions = append(htlcResolutions, *ohr)
} }
return htlcResolutions, localKey, nil return htlcResolutions, localKey, nil