21#define FOLDERDELIMCHAR '~'
56 cResumeFile(
const char *FileName,
bool IsPesRecording);
84 const char *
Title(
void)
const {
return event->Title(); }
85 const char *
ShortText(
void)
const {
return event->ShortText(); }
86 const char *
Description(
void)
const {
return event->Description(); }
88 const char *
Aux(
void)
const {
return aux; }
94 bool Write(FILE *f,
const char *Prefix =
"")
const;
96 bool Write(
void)
const;
133 int Id(
void)
const {
return id; }
140 bool IsInPath(
const char *Path)
const;
155 const char *
Title(
char Delimiter =
' ',
bool NewIndicator =
false,
int Level = -1)
const;
183 bool WriteInfo(
const char *OtherFileName = NULL);
252 static void Update(
bool Wait =
false);
261 void ResetResume(
const char *ResumeFileName = NULL);
268 void AddByName(
const char *FileName,
bool TriggerUpdate =
true);
307#define LOCK_RECORDINGS_READ USE_LIST_LOCK_READ(Recordings)
308#define LOCK_RECORDINGS_WRITE USE_LIST_LOCK_WRITE(Recordings)
309#define LOCK_DELETEDRECORDINGS_READ USE_LIST_LOCK_READ2(Recordings, DeletedRecordings)
310#define LOCK_DELETEDRECORDINGS_WRITE USE_LIST_LOCK_WRITE2(Recordings, DeletedRecordings)
322 virtual void Action(
void);
326 bool Add(
int Usage,
const char *FileNameSrc,
const char *FileNameDst = NULL);
334 void Del(
const char *FileName);
352#define DEFAULTFRAMESPERSECOND 25.0
368 bool Parse(
const char *s);
392 void Add(
int Position);
398 const cMark *
Get(
int Position)
const;
421#define RUC_BEFORERECORDING "before"
422#define RUC_STARTRECORDING "started"
423#define RUC_AFTERRECORDING "after"
424#define RUC_EDITINGRECORDING "editing"
425#define RUC_EDITEDRECORDING "edited"
426#define RUC_DELETERECORDING "deleted"
427#define RUC_RENAMEDRECORDING "renamed"
428#define RUC_MOVEDRECORDING "moved"
429#define RUC_COPYINGRECORDING "copying"
430#define RUC_COPIEDRECORDING "copied"
437 static void InvokeCommand(
const char *State,
const char *RecordingFileName,
const char *SourceFileName = NULL);
441#define MAXFRAMESIZE (KILOBYTE(1024) / TS_SIZE * TS_SIZE)
448#define MAXVIDEOFILESIZETS 1048570
449#define MAXVIDEOFILESIZEPES 2000
450#define MINVIDEOFILESIZE 100
451#define MAXVIDEOFILESIZEDEFAULT MAXVIDEOFILESIZEPES
470 cIndexFile(
const char *FileName,
bool Record,
bool IsPesRecording =
false,
bool PauseLive =
false,
bool Update =
false);
473 bool Write(
bool Independent, uint16_t FileNumber, off_t FileOffset);
474 bool Get(
int Index, uint16_t *FileNumber, off_t *FileOffset,
bool *Independent = NULL,
int *Length = NULL);
475 int GetNextIFrame(
int Index,
bool Forward, uint16_t *FileNumber = NULL, off_t *FileOffset = NULL,
int *Length = NULL);
481 int Get(uint16_t FileNumber, off_t FileOffset);
488 static int GetLength(
const char *FileName,
bool IsPesRecording =
false);
503 cFileName(
const char *FileName,
bool Record,
bool Blocking =
false,
bool IsPesRecording =
false);
518 void Add(
const char *Title);
520 bool Load(
const char *FileName);
521 bool Save(
void)
const;
522 void Append(
const char *Title);
523 bool Contains(
const char *Title)
const;
543bool GenerateIndex(
const char *FileName,
bool Update =
false);
cStringList doneRecordings
void Add(const char *Title)
void Append(const char *Title)
bool Load(const char *FileName)
bool Contains(const char *Title) const
cUnbufferedFile * NextFile(void)
cUnbufferedFile * Open(void)
cFileName(const char *FileName, bool Record, bool Blocking=false, bool IsPesRecording=false)
bool GetLastPatPmtVersions(int &PatVersion, int &PmtVersion)
cUnbufferedFile * SetOffset(int Number, off_t Offset=0)
int GetNextIFrame(int Index, bool Forward, uint16_t *FileNumber=NULL, off_t *FileOffset=NULL, int *Length=NULL)
bool IsStillRecording(void)
void ConvertFromPes(tIndexTs *IndexTs, int Count)
bool Write(bool Independent, uint16_t FileNumber, off_t FileOffset)
static int GetLength(const char *FileName, bool IsPesRecording=false)
Calculates the recording length (number of frames) without actually reading the index file.
bool CatchUp(int Index=-1)
void ConvertToPes(tIndexTs *IndexTs, int Count)
bool StoreResume(int Index)
cIndexFile(const char *FileName, bool Record, bool IsPesRecording=false, bool PauseLive=false, bool Update=false)
static cString IndexFileName(const char *FileName, bool IsPesRecording)
bool Get(int Index, uint16_t *FileNumber, off_t *FileOffset, bool *Independent=NULL, int *Length=NULL)
int GetClosestIFrame(int Index)
Returns the index of the I-frame that is closest to the given Index (or Index itself,...
int Last(void)
Returns the index of the last entry in this file, or -1 if the file is empty.
cIndexFileGenerator * indexFileGenerator
bool Lock(cStateKey &StateKey, bool Write=false, int TimeoutMs=0) const
Tries to get a lock on this list and returns true if successful.
cMark(int Position=0, const char *Comment=NULL, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
bool Parse(const char *s)
const char * Comment(void) const
void SetPosition(int Position)
void SetComment(const char *Comment)
int GetNumSequences(void) const
Returns the actual number of sequences to be cut from the recording.
void Add(int Position)
If this cMarks object is used by multiple threads, the caller must Lock() it before calling Add() and...
const cMark * GetNextBegin(const cMark *EndMark=NULL) const
Returns the next "begin" mark after EndMark, skipping any marks at the same position as EndMark.
const cMark * GetNext(int Position) const
bool Load(const char *RecordingFileName, double FramesPerSecond=DEFAULTFRAMESPERSECOND, bool IsPesRecording=false)
const cMark * GetNextEnd(const cMark *BeginMark) const
Returns the next "end" mark after BeginMark, skipping any marks at the same position as BeginMark.
const cMark * Get(int Position) const
cString recordingFileName
static bool DeleteMarksFile(const cRecording *Recording)
cMark * Get(int Position)
cMark * GetNextEnd(const cMark *BeginMark)
cMark * GetNextBegin(const cMark *EndMark=NULL)
cMark * GetPrev(int Position)
static cString MarksFileName(const cRecording *Recording)
Returns the marks file name for the given Recording (regardless whether such a file actually exists).
cMark * GetNext(int Position)
const cMark * GetPrev(int Position) const
const char * ChannelName(void) const
void SetFramesPerSecond(double FramesPerSecond)
const cEvent * GetEvent(void) const
const char * ShortText(void) const
cRecordingInfo(const cChannel *Channel=NULL, const cEvent *Event=NULL)
const char * Title(void) const
const char * Aux(void) const
tChannelID ChannelID(void) const
void SetFileName(const char *FileName)
void SetErrors(int Errors)
void SetAux(const char *Aux)
void SetData(const char *Title, const char *ShortText, const char *Description)
const char * Description(void) const
double FramesPerSecond(void) const
const cComponents * Components(void) const
static void InvokeCommand(const char *State, const char *RecordingFileName, const char *SourceFileName=NULL)
static const char * command
static void SetCommand(const char *Command)
int isOnVideoDirectoryFileSystem
virtual int Compare(const cListObject &ListObject) const
Must return 0 if this object is equal to ListObject, a positive value if it is "greater",...
bool ChangePriorityLifetime(int NewPriority, int NewLifetime)
Changes the priority and lifetime of this recording to the given values.
bool HasMarks(void) const
Returns true if this recording has any editing marks.
cRecording & operator=(const cRecording &)
bool WriteInfo(const char *OtherFileName=NULL)
Writes in info file of this recording.
int IsInUse(void) const
Checks whether this recording is currently in use and therefore shall not be tampered with.
bool ChangeName(const char *NewName)
Changes the name of this recording to the given value.
bool Undelete(void)
Changes the file name so that it will be visible in the "Recordings" menu again and not processed by ...
void ResetResume(void) const
bool Delete(void)
Changes the file name so that it will no longer be visible in the "Recordings" menu Returns false in ...
cString Folder(void) const
Returns the name of the folder this recording is stored in (without the video directory).
int NumFrames(void) const
Returns the number of frames in this recording.
bool IsEdited(void) const
int GetResume(void) const
Returns the index of the frame where replay of this recording shall be resumed, or -1 in case of an e...
bool IsInPath(const char *Path) const
Returns true if this recording is stored anywhere under the given Path.
void SetStartTime(time_t Start)
Sets the start time of this recording to the given value.
char * SortName(void) const
const char * Name(void) const
Returns the full name of the recording (without the video directory).
const char * FileName(void) const
Returns the full path name to the recording directory, including the video directory and the actual '...
cRecordingInfo * Info(void) const
const char * PrefixFileName(char Prefix)
bool DeleteMarks(void)
Deletes the editing marks from this recording (if any).
bool IsOnVideoDirectoryFileSystem(void) const
int HierarchyLevels(void) const
int FileSizeMB(void) const
Returns the total file size of this recording (in MB), or -1 if the file size is unknown.
cString BaseName(void) const
Returns the base name of this recording (without the video directory and folder).
const char * Title(char Delimiter=' ', bool NewIndicator=false, int Level=-1) const
bool Remove(void)
Actually removes the file from the disk Returns false in case of error.
cRecording(const cRecording &)
double FramesPerSecond(void) const
bool IsPesRecording(void) const
time_t Deleted(void) const
static char * StripEpisodeName(char *s, bool Strip)
int LengthInSeconds(void) const
Returns the length (in seconds) of this recording, or -1 in case of error.
void DelAll(void)
Deletes/terminates all operations.
cRecordingsHandlerEntry * Get(const char *FileName)
bool Add(int Usage, const char *FileNameSrc, const char *FileNameDst=NULL)
Adds the given FileNameSrc to the recordings handler for (later) processing.
bool Finished(bool &Error)
Returns true if all operations in the list have been finished.
virtual void Action(void)
A derived cThread class must implement the code it wants to execute as a separate thread in this func...
int GetUsage(const char *FileName)
Returns the usage type for the given FileName.
cList< cRecordingsHandlerEntry > operations
void Del(const char *FileName)
Deletes the given FileName from the list of operations.
virtual ~cRecordingsHandler()
void ResetResume(const char *ResumeFileName=NULL)
static cVideoDirectoryScannerThread * videoDirectoryScannerThread
void UpdateByName(const char *FileName)
static const char * UpdateFileName(void)
double MBperMinute(void) const
Returns the average data rate (in MB/min) of all recordings, or -1 if this value is unknown.
cRecording * GetByName(const char *FileName)
cRecordings(bool Deleted=false)
static cRecordings deletedRecordings
int GetNumRecordingsInPath(const char *Path) const
Returns the total number of recordings in the given Path, including all sub-folders of Path.
static const cRecordings * GetRecordingsRead(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of recordings for read access.
const cRecording * GetById(int Id) const
static int lastRecordingId
static const cRecordings * GetDeletedRecordingsRead(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of deleted recordings for read access.
static cRecordings * GetDeletedRecordingsWrite(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of deleted recordings for write access.
void AddByName(const char *FileName, bool TriggerUpdate=true)
int TotalFileSizeMB(void) const
static void Update(bool Wait=false)
Triggers an update of the list of recordings, which will run as a separate thread if Wait is false.
static cRecordings * GetRecordingsWrite(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of recordings for write access.
static void TouchUpdate(void)
Touches the '.update' file in the video directory, so that other instances of VDR that access the sam...
void Add(cRecording *Recording)
static cRecordings recordings
void DelByName(const char *FileName)
bool MoveRecordings(const char *OldPath, const char *NewPath)
Moves all recordings in OldPath to NewPath.
static bool NeedsUpdate(void)
cRecording * GetById(int Id)
void ClearSortNames(void)
static char * updateFileName
const cRecording * GetByName(const char *FileName) const
int PathIsInUse(const char *Path) const
Checks whether any recording in the given Path is currently in use and therefore the whole Path shall...
cResumeFile(const char *FileName, bool IsPesRecording)
cUnbufferedFile is used for large files that are mainly written or read in a streaming manner,...
cString GetRecordingTimerId(const char *Directory)
#define DEFAULTFRAMESPERSECOND
int HMSFToIndex(const char *HMSF, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
void GetRecordingsSortMode(const char *Directory)
eRecordingsSortMode RecordingsSortMode
bool HasRecordingsSortMode(const char *Directory)
DEF_LIST_LOCK(Recordings)
char * ExchangeChars(char *s, bool ToFileSystem)
void IncRecordingsSortMode(const char *Directory)
void SetRecordingsSortMode(const char *Directory, eRecordingsSortMode SortMode)
cDoneRecordings DoneRecordingsPattern
DEF_LIST_LOCK2(Recordings, DeletedRecordings)
int ReadFrame(cUnbufferedFile *f, uchar *b, int Length, int Max)
cRecordingsHandler RecordingsHandler
void SetRecordingTimerId(const char *Directory, const char *TimerId)
void RemoveDeletedRecordings(void)
int SecondsToFrames(int Seconds, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
cString IndexToHMSF(int Index, bool WithFrame=false, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
bool GenerateIndex(const char *FileName, bool Update=false)
Generates the index of the existing recording with the given FileName.
void AssertFreeDiskSpace(int Priority=0, bool Force=false)
The special Priority value -1 means that we shall get rid of any deleted recordings faster than norma...