Documentation ¶
Overview ¶
Package mkvcore provides the core functionality of Matroska/WebM multimedia writer.
The package implements block data writer for EBML based multi-track media container.
Index ¶
- Variables
- type BlockCloser
- type BlockInterceptor
- type BlockReadCloser
- type BlockReadCloserWithTrackEntry
- type BlockReadWriterOptionFn
- type BlockReadWriterOptions
- type BlockReader
- type BlockReaderOption
- type BlockReaderOptionFn
- type BlockReaderOptions
- type BlockSorterRule
- type BlockWriteCloser
- type BlockWriter
- type BlockWriterOption
- type BlockWriterOptionFn
- func WithBlockInterceptor(interceptor BlockInterceptor) BlockWriterOptionFn
- func WithEBMLHeader(h interface{}) BlockWriterOptionFn
- func WithMarshalOptions(opts ...ebml.MarshalOption) BlockWriterOptionFn
- func WithMaxKeyframeInterval(mainTrackNumber uint64, interval int64) BlockWriterOptionFn
- func WithSeekHead(enable bool) BlockWriterOptionFn
- func WithSegmentInfo(i interface{}) BlockWriterOptionFn
- type BlockWriterOptions
- type MultiTrackBlockSorterOption
- type MultiTrackBlockSorterOptions
- type TrackDescription
- type TrackEntry
- type TrackEntryGetter
Constants ¶
This section is empty.
Variables ¶
var ErrIgnoreOldFrame = errors.New("too old frame")
ErrIgnoreOldFrame means that a frame has too old timestamp and ignored.
var ErrInvalidTrackNumber = errors.New("invalid track number")
ErrInvalidTrackNumber means that a track number is invalid. The track number must be larger than 0.
Functions ¶
This section is empty.
Types ¶
type BlockCloser ¶
type BlockCloser interface { // Close the stream frame writer. // Output Matroska will be closed after closing all FrameWriter. Close() error }
BlockCloser is a Matroska closer interface.
type BlockInterceptor ¶
type BlockInterceptor interface { // Intercept reads blocks of each track, filters, and writes. Intercept(r []BlockReader, w []BlockWriter) }
BlockInterceptor is a interface of block stream muxer.
func MustBlockInterceptor ¶ added in v0.16.0
func MustBlockInterceptor(interceptor BlockInterceptor, err error) BlockInterceptor
MustBlockInterceptor panics if creation of a BlockInterceptor fails, such as when the NewMultiTrackBlockSorter function fails.
func NewMultiTrackBlockSorter ¶
func NewMultiTrackBlockSorter(opts ...MultiTrackBlockSorterOption) (BlockInterceptor, error)
NewMultiTrackBlockSorter creates BlockInterceptor, which sorts blocks on multiple tracks by timestamp. Either WithMaxDelayedPackets or WithMaxTimescaleDelay must be specified. If both are specified, then the first rule that is satisfied causes the packets to get written (thus a backlog of a max packets or max time scale will cause any older packets than the one satisfying the rule to be discarded). The index of TrackEntry sorts blocks with the same timestamp. Place the audio track before the video track to meet WebM Interceptor Guidelines.
type BlockReadCloser ¶
type BlockReadCloser interface { BlockReader BlockCloser }
BlockReadCloser groups Reader and Closer.
type BlockReadCloserWithTrackEntry ¶ added in v0.15.0
type BlockReadCloserWithTrackEntry interface { BlockReadCloser TrackEntryGetter }
BlockReadCloserWithTrackEntry groups BlockReadCloser and TrackEntryGetter.
func NewSimpleBlockReader ¶ added in v0.15.0
func NewSimpleBlockReader(r io.Reader, opts ...BlockReaderOption) ([]BlockReadCloserWithTrackEntry, error)
NewSimpleBlockReader creates BlockReadCloserWithTrackEntry for each track specified as tracks argument. It reads SimpleBlock-s and BlockGroup.Block-s. Any optional data in BlockGroup are dropped. If you need full data, consider implementing a custom reader using ebml.Unmarshal.
Note that, keyframe flag from BlockGroup.Block may be incorrect. If you have knowledge about this, please consider fixing it.
type BlockReadWriterOptionFn ¶ added in v0.15.0
type BlockReadWriterOptionFn func(*BlockReadWriterOptions) error
BlockReadWriterOptionFn configures a BlockReadWriterOptions.
func WithOnErrorHandler ¶
func WithOnErrorHandler(handler func(error)) BlockReadWriterOptionFn
WithOnErrorHandler registers marshal error handler.
func WithOnFatalHandler ¶
func WithOnFatalHandler(handler func(error)) BlockReadWriterOptionFn
WithOnFatalHandler registers marshal error handler.
func (BlockReadWriterOptionFn) ApplyToBlockReaderOptions ¶ added in v0.15.0
func (o BlockReadWriterOptionFn) ApplyToBlockReaderOptions(opts *BlockReaderOptions) error
ApplyToBlockReaderOptions implements BlockReaderOption.
func (BlockReadWriterOptionFn) ApplyToBlockWriterOptions ¶ added in v0.15.0
func (o BlockReadWriterOptionFn) ApplyToBlockWriterOptions(opts *BlockWriterOptions) error
ApplyToBlockWriterOptions implements BlockWriterOption.
type BlockReadWriterOptions ¶ added in v0.15.0
type BlockReadWriterOptions struct {
// contains filtered or unexported fields
}
BlockReadWriterOptions stores options for BlockWriter and BlockReader.
type BlockReader ¶
type BlockReader interface { // Read a block from the connected Matroska reader. Read() (b []byte, keyframe bool, timestamp int64, err error) }
BlockReader is a Matroska block reader interface.
type BlockReaderOption ¶ added in v0.15.0
type BlockReaderOption interface {
ApplyToBlockReaderOptions(opts *BlockReaderOptions) error
}
BlockReaderOption configures a BlockReaderOptions.
type BlockReaderOptionFn ¶ added in v0.15.0
type BlockReaderOptionFn func(*BlockReaderOptions) error
BlockReaderOptionFn configures a BlockReaderOptions.
func WithUnmarshalOptions ¶ added in v0.15.0
func WithUnmarshalOptions(opts ...ebml.UnmarshalOption) BlockReaderOptionFn
WithUnmarshalOptions passes ebml.UnmarshalOption to ebml.Unmarshal.
func (BlockReaderOptionFn) ApplyToBlockReaderOptions ¶ added in v0.15.0
func (o BlockReaderOptionFn) ApplyToBlockReaderOptions(opts *BlockReaderOptions) error
ApplyToBlockReaderOptions implements BlockReaderOption.
type BlockReaderOptions ¶ added in v0.15.0
type BlockReaderOptions struct { BlockReadWriterOptions // contains filtered or unexported fields }
BlockReaderOptions stores options for BlockReader.
type BlockSorterRule ¶
type BlockSorterRule int
BlockSorterRule is a type of BlockSorter behaviour for outdated frame.
const ( BlockSorterDropOutdated BlockSorterRule = iota BlockSorterWriteOutdated )
List of BlockSorterRules.
type BlockWriteCloser ¶
type BlockWriteCloser interface { BlockWriter BlockCloser }
BlockWriteCloser groups Writer and Closer.
func NewSimpleBlockWriter ¶
func NewSimpleBlockWriter(w0 io.WriteCloser, tracks []TrackDescription, opts ...BlockWriterOption) ([]BlockWriteCloser, error)
NewSimpleBlockWriter creates BlockWriteCloser for each track specified as tracks argument. Blocks will be written to the writer as EBML SimpleBlocks. Given io.WriteCloser will be closed automatically; don't close it by yourself. Frames written to each track must be sorted by their timestamp.
type BlockWriter ¶
type BlockWriter interface { // Write a block to the connected Matroska writer. // timestamp is in millisecond. Write(keyframe bool, timestamp int64, b []byte) (int, error) }
BlockWriter is a Matroska block writer interface.
type BlockWriterOption ¶
type BlockWriterOption interface {
ApplyToBlockWriterOptions(opts *BlockWriterOptions) error
}
BlockWriterOption configures a BlockWriterOptions.
type BlockWriterOptionFn ¶ added in v0.15.0
type BlockWriterOptionFn func(*BlockWriterOptions) error
BlockWriterOptionFn configures a BlockWriterOptions.
func WithBlockInterceptor ¶
func WithBlockInterceptor(interceptor BlockInterceptor) BlockWriterOptionFn
WithBlockInterceptor registers BlockInterceptor.
func WithEBMLHeader ¶
func WithEBMLHeader(h interface{}) BlockWriterOptionFn
WithEBMLHeader sets EBML header.
func WithMarshalOptions ¶
func WithMarshalOptions(opts ...ebml.MarshalOption) BlockWriterOptionFn
WithMarshalOptions passes ebml.MarshalOption to ebml.Marshal.
func WithMaxKeyframeInterval ¶
func WithMaxKeyframeInterval(mainTrackNumber uint64, interval int64) BlockWriterOptionFn
WithMaxKeyframeInterval sets maximum keyframe interval of the main (video) track. Using this option starts the cluster with a key frame if possible. interval must be given in the scale of timecode.
func WithSeekHead ¶
func WithSeekHead(enable bool) BlockWriterOptionFn
WithSeekHead enables SeekHead calculation
func WithSegmentInfo ¶
func WithSegmentInfo(i interface{}) BlockWriterOptionFn
WithSegmentInfo sets Segment.Info.
func (BlockWriterOptionFn) ApplyToBlockWriterOptions ¶ added in v0.15.0
func (o BlockWriterOptionFn) ApplyToBlockWriterOptions(opts *BlockWriterOptions) error
ApplyToBlockWriterOptions implements BlockWriterOption.
type BlockWriterOptions ¶
type BlockWriterOptions struct { BlockReadWriterOptions // contains filtered or unexported fields }
BlockWriterOptions stores options for BlockWriter.
type MultiTrackBlockSorterOption ¶ added in v0.16.0
type MultiTrackBlockSorterOption func(*MultiTrackBlockSorterOptions) error
MultiTrackBlockSorterOption configures a MultiTrackBlockSorterOptions.
func WithMaxDelayedPackets ¶ added in v0.16.0
func WithMaxDelayedPackets(maxDelayedPackets int) MultiTrackBlockSorterOption
WithMaxDelayedPackets set the maximum number of packets that may be delayed within each track.
func WithMaxTimescaleDelay ¶ added in v0.16.0
func WithMaxTimescaleDelay(maxTimescaleDelay int64) MultiTrackBlockSorterOption
WithMaxTimescaleDelay set the maximum allowed delay between tracks for a given timescale.
func WithSortRule ¶ added in v0.16.0
func WithSortRule(rule BlockSorterRule) MultiTrackBlockSorterOption
WithSortRule set the sort rule to apply to how packet ordering should be treated within the webm container.
type MultiTrackBlockSorterOptions ¶ added in v0.16.0
type MultiTrackBlockSorterOptions struct {
// contains filtered or unexported fields
}
MultiTrackBlockSorterOptions stores options for BlockWriter.
type TrackDescription ¶
type TrackDescription struct { TrackNumber uint64 TrackEntry interface{} }
TrackDescription stores track number and its TrackEntry struct.
type TrackEntry ¶ added in v0.15.0
type TrackEntry struct { TrackNumber uint64 TrackUID uint64 TrackType uint8 FlagEnabled uint8 FlagDefault uint8 FlagForced uint8 FlagLacing uint8 MinCache uint64 DefaultDuration uint64 MaxBlockAdditionID uint64 Name string Language string LanguageIETF string CodecID string CodecDecodeAll uint8 SeekPreRoll uint64 }
TrackEntry is a TrackEntry struct with all mandatory elements and commonly used elements.
type TrackEntryGetter ¶ added in v0.15.0
type TrackEntryGetter interface {
TrackEntry() TrackEntry
}
TrackEntryGetter is a interface to get TrackEntry.