log.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. package wire
  2. import (
  3. "fmt"
  4. "strings"
  5. "github.com/lucas-clemente/quic-go/internal/utils"
  6. )
  7. // LogFrame logs a frame, either sent or received
  8. func LogFrame(logger utils.Logger, frame Frame, sent bool) {
  9. if !logger.Debug() {
  10. return
  11. }
  12. dir := "<-"
  13. if sent {
  14. dir = "->"
  15. }
  16. switch f := frame.(type) {
  17. case *StreamFrame:
  18. logger.Debugf("\t%s &wire.StreamFrame{StreamID: %d, FinBit: %t, Offset: 0x%x, Data length: 0x%x, Offset + Data length: 0x%x}", dir, f.StreamID, f.FinBit, f.Offset, f.DataLen(), f.Offset+f.DataLen())
  19. case *StopWaitingFrame:
  20. if sent {
  21. logger.Debugf("\t%s &wire.StopWaitingFrame{LeastUnacked: 0x%x, PacketNumberLen: 0x%x}", dir, f.LeastUnacked, f.PacketNumberLen)
  22. } else {
  23. logger.Debugf("\t%s &wire.StopWaitingFrame{LeastUnacked: 0x%x}", dir, f.LeastUnacked)
  24. }
  25. case *AckFrame:
  26. if len(f.AckRanges) > 1 {
  27. ackRanges := make([]string, len(f.AckRanges))
  28. for i, r := range f.AckRanges {
  29. ackRanges[i] = fmt.Sprintf("{Largest: %#x, Smallest: %#x}", r.Largest, r.Smallest)
  30. }
  31. logger.Debugf("\t%s &wire.AckFrame{LargestAcked: %#x, LowestAcked: %#x, AckRanges: {%s}, DelayTime: %s}", dir, f.LargestAcked(), f.LowestAcked(), strings.Join(ackRanges, ", "), f.DelayTime.String())
  32. } else {
  33. logger.Debugf("\t%s &wire.AckFrame{LargestAcked: %#x, LowestAcked: %#x, DelayTime: %s}", dir, f.LargestAcked(), f.LowestAcked(), f.DelayTime.String())
  34. }
  35. default:
  36. logger.Debugf("\t%s %#v", dir, frame)
  37. }
  38. }