HLS: 解决hls断流重新生成后异常的bug

This commit is contained in:
xiongziliang 2022-02-13 21:06:32 +08:00
parent e37982adee
commit 83c1f29253
3 changed files with 11 additions and 6 deletions

View File

@ -92,7 +92,7 @@ void HlsMaker::inputData(void *data, size_t len, uint32_t timestamp, bool is_idr
}
} else {
//resetTracks时触发此逻辑
flushLastSegment(true);
flushLastSegment(false);
}
}
@ -151,6 +151,7 @@ bool HlsMaker::isLive() {
void HlsMaker::clear() {
_file_index = 0;
_last_timestamp = 0;
_last_seg_timestamp = 0;
_seg_dur_list.clear();
_last_file_name.clear();

View File

@ -37,12 +37,16 @@ HlsMakerImp::HlsMakerImp(const string &m3u8_file,
}
HlsMakerImp::~HlsMakerImp() {
clearCache(false);
clearCache(false, true);
}
void HlsMakerImp::clearCache(bool immediately) {
void HlsMakerImp::clearCache() {
clearCache(true, false);
}
void HlsMakerImp::clearCache(bool immediately, bool eof) {
//录制完了
flushLastSegment(true);
flushLastSegment(eof);
if (!isLive()) {
return;
}

View File

@ -45,9 +45,8 @@ public:
/**
*
* @param immediately
*/
void clearCache(bool immediately = true);
void clearCache();
protected:
std::string onOpenSegment(uint64_t index) override ;
@ -58,6 +57,7 @@ protected:
private:
std::shared_ptr<FILE> makeFile(const std::string &file,bool setbuf = false);
void clearCache(bool immediately, bool eof);
private:
int _buf_size;