X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Examples%2Fpsi2tsModule%2Fpsi2ts.cc;h=55366cf9f05eff4dd424b0375ddab06ae239792a;hb=20c3dbf64b3beed10655dceaee5791680fb25383;hp=f8da4fb34139eaa13303916582c4f9374c45cb84;hpb=da51b382a8a19c8a42bd6d9266ee966aefde6349;p=senf.git diff --git a/Examples/psi2tsModule/psi2ts.cc b/Examples/psi2tsModule/psi2ts.cc index f8da4fb..55366cf 100644 --- a/Examples/psi2tsModule/psi2ts.cc +++ b/Examples/psi2tsModule/psi2ts.cc @@ -43,30 +43,32 @@ namespace { } -prefix_ Psi2TsModule::Psi2TsModule(unsigned pid) +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::fill( @@ -75,9 +77,9 @@ prefix_ void Psi2TsModule::onRequest() 0xff ); tsPacket.finalize(); - + output.write( tsPacket); - + advance_max( begin, 184, sec_end); advance_max( end, 184, sec_end); } while (begin != end);