• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

lightningnetwork / lnd / 15635919293

13 Jun 2025 01:37PM UTC coverage: 56.351% (-2.0%) from 58.333%
15635919293

Pull #9903

github

web-flow
Merge 174181006 into 35102e7c3
Pull Request #9903: docs: add sphinx replay description

108065 of 191770 relevant lines covered (56.35%)

22781.11 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

80.95
/lnutils/log.go
1
package lnutils
2

3
import (
4
        "log/slog"
5
        "strings"
6

7
        "github.com/btcsuite/btcd/btcec/v2"
8
        "github.com/btcsuite/btclog/v2"
9
        "github.com/davecgh/go-spew/spew"
10
)
11

12
// LogClosure is used to provide a closure over expensive logging operations so
13
// don't have to be performed when the logging level doesn't warrant it.
14
type LogClosure func() string
15

16
// String invokes the underlying function and returns the result.
17
func (c LogClosure) String() string {
4✔
18
        return c()
4✔
19
}
4✔
20

21
// NewLogClosure returns a new closure over a function that returns a string
22
// which itself provides a Stringer interface so that it can be used with the
23
// logging system.
24
func NewLogClosure(c func() string) LogClosure {
2,955✔
25
        return LogClosure(c)
2,955✔
26
}
2,955✔
27

28
// SpewLogClosure takes an interface and returns the string of it created from
29
// `spew.Sdump` in a LogClosure.
30
func SpewLogClosure(a any) LogClosure {
9,095✔
31
        return func() string {
9,099✔
32
                return spew.Sdump(a)
4✔
33
        }
4✔
34
}
35

36
// NewSeparatorClosure returns a new closure that logs a separator line.
37
func NewSeparatorClosure() LogClosure {
1✔
38
        return func() string {
1✔
39
                return strings.Repeat("=", 80)
×
40
        }
×
41
}
42

43
// LogPubKey returns a slog attribute for logging a public key in hex format.
44
func LogPubKey(key string, pubKey *btcec.PublicKey) slog.Attr {
27✔
45
        // Handle nil pubkey gracefully, although callers should ideally prevent
27✔
46
        // this.
27✔
47
        if pubKey == nil {
27✔
48
                return btclog.Fmt(key, "<nil>")
×
49
        }
×
50

51
        return btclog.Hex6(key, pubKey.SerializeCompressed())
27✔
52
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc