1
0
Fork 0
forked from External/mediamtx
mediamtx/internal/record/format_mpegts_segment.go
Alessandro Ros 3eabe6ac54
expose MTX_SEGMENT_DURATION to runOnRecordSegmentComplete (#3440) (#2983) (#3456)
* improve tests

* add duration to OnSegmentComplete

* expose MTX_SEGMENT_DURATION to runOnRecordSegmentComplete

* add tests
2024-06-11 18:30:40 +02:00

68 lines
1.2 KiB
Go

package record
import (
"os"
"path/filepath"
"time"
"github.com/bluenviron/mediamtx/internal/logger"
)
type formatMPEGTSSegment struct {
f *formatMPEGTS
startDTS time.Duration
startNTP time.Time
path string
fi *os.File
lastFlush time.Duration
lastDTS time.Duration
}
func (s *formatMPEGTSSegment) initialize() {
s.lastFlush = s.startDTS
s.lastDTS = s.startDTS
s.f.dw.setTarget(s)
}
func (s *formatMPEGTSSegment) close() error {
err := s.f.bw.Flush()
if s.fi != nil {
s.f.a.agent.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.f.a.agent.OnSegmentComplete(s.path, duration)
}
}
return err
}
func (s *formatMPEGTSSegment) Write(p []byte) (int, error) {
if s.fi == nil {
s.path = Path{Start: s.startNTP}.Encode(s.f.a.pathFormat)
s.f.a.agent.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.f.a.agent.OnSegmentCreate(s.path)
s.fi = fi
}
return s.fi.Write(p)
}