mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-23 03:10:04 +08:00
59dcd03b70
* 修改hls拉流后closestream崩溃的bug Co-authored-by: 夏楚 <771730766@qq.com>
73 lines
2.3 KiB
C++
73 lines
2.3 KiB
C++
/*
|
|
* Copyright (c) 2020 The ZLMediaKit project authors. All Rights Reserved.
|
|
* Created by alex on 2021/4/6.
|
|
* This file is part of ZLMediaKit(https://github.com/xia-chu/ZLMediaKit).
|
|
*
|
|
* Use of this source code is governed by MIT license that can be found in the
|
|
* LICENSE file in the root of the source tree. All contributing project authors
|
|
* may be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include "TsPlayerImp.h"
|
|
#include "HlsPlayer.h"
|
|
|
|
using namespace std;
|
|
using namespace toolkit;
|
|
|
|
namespace mediakit {
|
|
|
|
TsPlayerImp::TsPlayerImp(const EventPoller::Ptr &poller) : PlayerImp<TsPlayer, PlayerBase>(poller) {}
|
|
|
|
void TsPlayerImp::onResponseBody(const char *data, size_t len) {
|
|
TsPlayer::onResponseBody(data, len);
|
|
if (!_decoder && _demuxer) {
|
|
_decoder = DecoderImp::createDecoder(DecoderImp::decoder_ts, _demuxer.get());
|
|
}
|
|
|
|
if (_decoder && _demuxer) {
|
|
_decoder->input((uint8_t *) data, len);
|
|
}
|
|
}
|
|
|
|
void TsPlayerImp::addTrackCompleted() {
|
|
PlayerImp<TsPlayer, PlayerBase>::onPlayResult(SockException(Err_success, "play http-ts success"));
|
|
}
|
|
|
|
void TsPlayerImp::onPlayResult(const SockException &ex) {
|
|
auto benchmark_mode = (*this)[Client::kBenchmarkMode].as<int>();
|
|
if (ex || benchmark_mode) {
|
|
PlayerImp<TsPlayer, PlayerBase>::onPlayResult(ex);
|
|
} else {
|
|
auto demuxer = std::make_shared<HlsDemuxer>();
|
|
demuxer->start(getPoller(), this);
|
|
_demuxer = std::move(demuxer);
|
|
}
|
|
}
|
|
|
|
void TsPlayerImp::onShutdown(const SockException &ex) {
|
|
while (_demuxer) {
|
|
try {
|
|
std::weak_ptr<TsPlayerImp> weak_self = static_pointer_cast<TsPlayerImp>(shared_from_this());
|
|
static_pointer_cast<HlsDemuxer>(_demuxer)->pushTask([weak_self, ex]() {
|
|
auto strong_self = weak_self.lock();
|
|
if (strong_self) {
|
|
strong_self->_demuxer = nullptr;
|
|
strong_self->onShutdown(ex);
|
|
}
|
|
});
|
|
return;
|
|
} catch (...) {
|
|
break;
|
|
}
|
|
}
|
|
PlayerImp<TsPlayer, PlayerBase>::onShutdown(ex);
|
|
}
|
|
|
|
vector<Track::Ptr> TsPlayerImp::getTracks(bool ready) const {
|
|
if (!_demuxer) {
|
|
return vector<Track::Ptr>();
|
|
}
|
|
return static_pointer_cast<HlsDemuxer>(_demuxer)->getTracks(ready);
|
|
}
|
|
|
|
}//namespace mediakit
|