22#define LOC QString("HDHRRec[%1]: ") \
23 .arg(m_tvrec ? m_tvrec->GetInputId() : -1)
29 LOG(VB_GENERAL, LOG_WARNING,
LOC +
"Card already open");
38 LOG(VB_RECORD, LOG_INFO,
LOC +
"Using TSStreamData");
48 LOG(VB_RECORD, LOG_INFO,
LOC +
"HDHR opened successfully");
55 LOG(VB_RECORD, LOG_INFO,
LOC +
"Close() -- begin");
61 LOG(VB_RECORD, LOG_INFO,
LOC +
"Close() -- end");
79 LOG(VB_RECORD, LOG_INFO,
LOC +
"run -- begin");
84 m_error =
"Failed to open HDHRRecorder device";
129 LOG(VB_GENERAL, LOG_WARNING,
LOC +
130 "Recording will not commence until a PMT is set.");
131 std::this_thread::sleep_for(5ms);
137 m_error =
"Stream handler died unexpectedly.";
142 LOG(VB_RECORD, LOG_INFO,
LOC +
"run -- ending...");
156 LOG(VB_RECORD, LOG_INFO,
LOC +
"run -- end");
virtual int GetInputID(void) const
QString GetSIStandard(void) const
Returns PSIP table standard: MPEG, DVB, ATSC, or OpenCable.
QString m_error
non-empty iff irrecoverable recording error detected
void FinishRecording(void) override
Flushes the ringbuffer, and if this is not a live LiveTV recording saves the position map and filesiz...
ProgramMapTable * m_inputPmt
PMT on input side.
bool IsErrored(void) override
Tells us whether an unrecoverable error has been encountered.
void ResetForNewFile(void) override
void HandleSingleProgramPAT(ProgramAssociationTable *pat, bool insert) override
MPEGStreamData * m_streamData
virtual void SetStreamData(MPEGStreamData *data)
void HandleSingleProgramPMT(ProgramMapTable *pmt, bool insert) override
QString GetDevice(void) const override
Returns String representing device, useful for debugging.
void StartNewFile(void) override
void run(void) override
run() starts the recording process, and does not exit until the recording is complete.
HDHRStreamHandler * m_streamHandler
QString GetSIStandard(void) const override
bool PauseAndWait(std::chrono::milliseconds timeout=100ms) override
If m_requestPause is true, sets pause and blocks up to timeout milliseconds or until unpaused,...
static HDHRStreamHandler * Get(const QString &devname, int inputid, int majorid)
void AddListener(MPEGStreamData *data, bool=false, bool=false, const QString &output_file=QString()) override
static void Return(HDHRStreamHandler *&ref, int inputid)
const ProgramMapTable * PMTSingleProgram(void) const
void AddWritingListener(TSPacketListener *val)
void RemoveWritingListener(TSPacketListener *val)
const ProgramAssociationTable * PATSingleProgram(void) const
void RemoveAVListener(TSPacketListenerAV *val)
virtual void AddListeningPID(uint pid, PIDPriority priority=kPIDPriorityNormal)
void AddAVListener(TSPacketListenerAV *val)
virtual bool IsRecordingRequested(void)
Tells us if StopRecording() has been called.
bool m_recording
True while recording is actually being performed.
QWaitCondition m_pauseWait
MythMediaBuffer * m_ringBuffer
virtual bool IsPaused(bool holding_lock=false) const
Returns true iff recorder is paused.
bool m_requestRecording
True if API call has requested a recording be [re]started.
QWaitCondition m_unpauseWait
QWaitCondition m_recordingWait
virtual bool AddNamedOutputFile(const QString &filename)
Called with _listener_lock locked just after adding new output file.
bool IsRunning(void) const
virtual void RemoveListener(MPEGStreamData *data)
Specialized version of MPEGStreamData which is used to 'blindly' record the entire MPTS transport fro...
void RecorderPaused(void)
This is a callback, called by the "recorder" instance when it has actually paused.
uint GetInputId(void) const
Returns the inputid.
#define LOC
-*- Mode: c++ -*- HDHRRecorder Copyright (c) 2006-2009 by Silicondust Engineering Ltd,...
#define LOG(_MASK_, _LEVEL_, _QSTRING_)