mediamtx/internal/recorder/format_mpegts_segment.go
Alessandro Ros 02e2b9d640
recorder: write additional infos inside segments (#5083)
write stream ID, segment number, DTS, NTP in a dedicated box. This
allows to improve the merge algorithm in the playback server.
2025-10-13 12:34:44 +02:00

72 lines
1.3 KiB
Go

package recorder
import (
"os"
"path/filepath"
"time"
"github.com/bluenviron/mediamtx/internal/logger"
"github.com/bluenviron/mediamtx/internal/recordstore"
)
type formatMPEGTSSegment struct {
pathFormat2 string
flush func() error
onSegmentCreate OnSegmentCreateFunc
onSegmentComplete OnSegmentCompleteFunc
startDTS time.Duration
startNTP time.Time
log logger.Writer
path string
fi *os.File
lastFlush time.Duration
lastDTS time.Duration
}
func (s *formatMPEGTSSegment) initialize() {
s.lastFlush = s.startDTS
s.lastDTS = s.startDTS
}
func (s *formatMPEGTSSegment) close() error {
err := s.flush()
if s.fi != nil {
s.log.Log(logger.Debug, "closing segment %s", s.path)
err2 := s.fi.Close()
if err == nil {
err = err2
}
if err2 == nil {
duration := s.lastDTS - s.startDTS
s.onSegmentComplete(s.path, duration)
}
}
return err
}
func (s *formatMPEGTSSegment) Write(p []byte) (int, error) {
if s.fi == nil {
s.path = recordstore.Path{Start: s.startNTP}.Encode(s.pathFormat2)
s.log.Log(logger.Debug, "creating segment %s", s.path)
err := os.MkdirAll(filepath.Dir(s.path), 0o755)
if err != nil {
return 0, err
}
fi, err := os.Create(s.path)
if err != nil {
return 0, err
}
s.onSegmentCreate(s.path)
s.fi = fi
}
return s.fi.Write(p)
}