X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Examples%2Fpsi2tsModule%2Fpsi2ts.cc;h=6878c38079a9ee334f1234cc331cdf3bd1098554;hb=0fb5ed1adf2f67dbf47fdfed3f3c8be989cf3618;hp=2ff2538ba0f31818e66d255bc8805fdd3810374b;hpb=7dffbd59c43b82572bad98d4c838b1ed368b9a14;p=senf.git diff --git a/Examples/psi2tsModule/psi2ts.cc b/Examples/psi2tsModule/psi2ts.cc index 2ff2538..6878c38 100644 --- a/Examples/psi2tsModule/psi2ts.cc +++ b/Examples/psi2tsModule/psi2ts.cc @@ -43,31 +43,39 @@ namespace { } -prefix_ Psi2TsModule::Psi2TsModule() +prefix_ Psi2TsModule::Psi2TsModule(unsigned pid, senf::ClockService::clock_type timeout) { + pid_ = pid; continuity_counter_ = 0; state_ = IDLE; route( input, output ); input.onRequest( &Psi2TsModule::onRequest ); + timeout_ = timeout; } - +#include prefix_ void Psi2TsModule::onRequest() { senf::PacketData & section = input.read().data(); iterator sec_end = section.end(); iterator begin = section.begin(); iterator end = section.begin(); - advance_max( end, 184, sec_end); - + advance_max( end, 183, sec_end); + do { senf::TransportPacket tsPacket (senf::TransportPacket::create(188)); tsPacket->continuity_counter() = next_continuity_counter(); + tsPacket->pid() = pid_; if (state_ == IDLE) { state_ = PROC; - tsPacket->pusi() = true; + tsPacket->setPUSI(true); + tsPacket->pointer_field() = 0; } senf::PacketData & payloadData (tsPacket.next().data()); - std::copy( begin, end, payloadData.begin() ); + std::fill( + std::copy( begin, end, payloadData.begin() ), + payloadData.end(), + 0xff + ); tsPacket.finalize(); output.write( tsPacket);