TSDuck v3.40-4033
MPEG Transport Stream Toolkit
|
This class analyzes T2-MI (DVB-T2 Modulator Interface) from TS packets. More...
#include <tsT2MIDemux.h>
Public Types | |
using | SuperClass = AbstractDemux |
Explicit reference to superclass. | |
Public Member Functions | |
T2MIDemux (DuckContext &duck, T2MIHandlerInterface *t2mi_handler=nullptr, const PIDSet &pid_filter=NoPID) | |
Constructor. | |
virtual | ~T2MIDemux () override |
Destructor. | |
virtual void | addPID (PID pid) |
Add one PID to filter. | |
virtual void | addPIDs (const PIDSet &pids) |
Add several PID's to filter. | |
int | demuxId () const |
Get the "demux id" value, as previously stored by the application. | |
virtual void | feedPacket (const TSPacket &pkt) override |
The following method feeds the demux with a TS packet. | |
virtual bool | hasPID (PID pid) const |
Check if a PID is filtered. | |
virtual size_t | pidCount () const |
Get the current number of PID's being filtered. | |
virtual void | removePID (PID pid) |
Remove one PID to filter. | |
virtual void | reset () |
Reset the demux. | |
virtual void | resetPID (PID pid) |
Reset the demuxing context for one single PID. | |
void | setDemuxId (int id) |
Set some arbitrary "demux id" value. | |
void | setHandler (T2MIHandlerInterface *h) |
Replace the T2-MI handler. | |
virtual void | setPIDFilter (const PIDSet &pid_filter) |
Replace the list of PID's to filter. | |
Protected Member Functions | |
bool | afterCallingHandler (bool executeDelayedOperations=true) |
Helper for subclass, after invoking an application-defined handler. | |
void | beforeCallingHandler (PID pid=PID_NULL) |
Helper for subclass, before invoking an application-defined handler. | |
virtual void | immediateReset () override |
Reset the demux immediately. | |
virtual void | immediateResetPID (PID pid) override |
Reset the demuxing context for one single PID immediately. | |
Protected Attributes | |
DuckContext & | _duck |
The TSDuck execution context is accessible to all subclasses. | |
PacketCounter | _packet_count = 0 |
Number of TS packets in the demultiplexed stream. | |
PIDSet | _pid_filter {} |
Current set of filtered PID's. | |
This class analyzes T2-MI (DVB-T2 Modulator Interface) from TS packets.
TS packets from the outer transport stream are passed one by one to the demux. The signalization is analyzed. Services with at least one T2-MI component are signaled to a handler. A T2-MI component is spotted by the presence of a T2MI_descriptor in the PMT.
The application decides which T2-MI PID's should be demuxed. These PID's can be selected from the beginning or in response to the discovery of T2-MI PID's.
|
explicit |
Constructor.
[in,out] | duck | TSDuck execution context. The reference is kept inside the demux. |
[in] | t2mi_handler | The object to invoke when T2-MI information is found. |
[in] | pid_filter | The set of T2-MI PID's to demux. |
|
overridevirtual |
The following method feeds the demux with a TS packet.
[in] | pkt | A TS packet. |
Reimplemented from ts::AbstractDemux.
|
inline |
Replace the T2-MI handler.
[in] | h | The new handler. |
|
overrideprotectedvirtual |
Reset the demux immediately.
Reimplemented from ts::AbstractDemux.
|
overrideprotectedvirtual |
Reset the demuxing context for one single PID immediately.
[in] | pid | The PID to reset. |
Reimplemented from ts::AbstractDemux.
|
virtualinherited |
Replace the list of PID's to filter.
The method resetPID() is invoked on each removed PID.
[in] | pid_filter | The list of PID's to filter. |
|
virtualinherited |
|
virtualinherited |
Add several PID's to filter.
[in] | pids | The list of new PID's to filter. |
Reimplemented in ts::MPEDemux.
|
virtualinherited |
Remove one PID to filter.
The method resetPID() is invoked on pid.
[in] | pid | The PID to no longer filter. |
Reimplemented in ts::MPEDemux.
|
virtualinherited |
Get the current number of PID's being filtered.
|
virtualinherited |
Check if a PID is filtered.
[in] | pid | The PID to test. |
|
virtualinherited |
Reset the demux.
Useful when the transport stream changes. The PID filter and the handlers are not modified.
If invoked in an application-handler, the operation is delayed until the handler terminates. For subclass implementers, see beforeCallingHandler() and override immediateReset() instead of reset().
Reimplemented in ts::StandaloneTableDemux.
|
virtualinherited |
Reset the demuxing context for one single PID.
Forget all previous partially demuxed data on this PID.
If invoked in an application-handler, the operation is delayed until the handler terminates. For subclass implementers, see beforeCallingHandler() and override immediateResetPID() instead of resetPID().
[in] | pid | The PID to reset. |
Reimplemented in ts::StandaloneTableDemux.
|
inlineinherited |
Set some arbitrary "demux id" value.
This value is chosen and set by the application. It can be retrieved later if a table or section handler is used by several demux. The demux id is not interpreted by the demux, it is only stored for the application. The initial value of a demux id is zero.
[in] | id | Application-defined demux id to assign. |
|
inlineinherited |
Get the "demux id" value, as previously stored by the application.
Helper for subclass, before invoking an application-defined handler.
The idea is to protect the integrity of the demux during the execution of an application-defined handler. The handler is invoked in the middle of an operation but the handler may call reset() or resetPID(). Executing the reset in the middle of an operation may be problematic. By using beforeCallingHandler() and afterCallingHandler(), all reset operations in between are delayed after the execution of the handler.
Example:
[in] | pid | The PID for which the handler will be called. All reset operations on this PID will be delayed until afterCallingHandler(). |
|
protectedinherited |
Helper for subclass, after invoking an application-defined handler.
[in] | executeDelayedOperations | When true (the default), execute all pending reset operations. |