7#ifndef PACKAGER_MEDIA_FORMATS_PACKED_AUDIO_PACKED_AUDIO_SEGMENTER_H_
8#define PACKAGER_MEDIA_FORMATS_PACKED_AUDIO_PACKED_AUDIO_SEGMENTER_H_
13#include <packager/media/base/buffer_writer.h>
14#include <packager/media/base/stream_info.h>
15#include <packager/status.h>
20class AACAudioSpecificConfig;
25constexpr double kPackedAudioTimescale = 90000;
29constexpr char kTimestampOwnerIdentifier[] =
30 "com.apple.streaming.transportStreamTimestamp";
34constexpr char kAudioDescriptionOwnerIdentifier[] =
35 "com.apple.streaming.audioDescription";
79 virtual std::unique_ptr<AACAudioSpecificConfig> CreateAdtsConverter();
80 virtual std::unique_ptr<Id3Tag> CreateId3Tag();
82 Status EncryptionAudioSetup(
const MediaSample& sample);
83 Status StartNewSegment(
const MediaSample& first_sample);
85 const int32_t transport_stream_timestamp_offset_ = 0;
87 Codec codec_ = kUnknownCodec;
88 std::vector<uint8_t> audio_codec_config_;
91 double timescale_scale_ = 0.0;
93 bool start_of_new_segment_ =
true;
96 std::string audio_setup_information_;
98 std::unique_ptr<AACAudioSpecificConfig> adts_converter_;
All the methods that are virtual are virtual for mocking.