vdr 2.8.1
recording.h
Go to the documentation of this file.
1/*
2 * recording.h: Recording file handling
3 *
4 * See the main source file 'vdr.c' for copyright information and
5 * how to reach the author.
6 *
7 * $Id: recording.h 5.27 2026/03/14 15:50:43 kls Exp $
8 */
9
10#ifndef __RECORDING_H
11#define __RECORDING_H
12
13#include <time.h>
14#include "channels.h"
15#include "config.h"
16#include "epg.h"
17#include "thread.h"
18#include "timers.h"
19#include "tools.h"
20#include "remux.h"
21
22#define FOLDERDELIMCHAR '~'
23
24extern int DirectoryPathMax;
25extern int DirectoryNameMax;
26extern bool DirectoryEncoding;
27extern int InstanceId;
28
30 ruNone = 0x0000, // the recording is currently unused
31 ruTimer = 0x0001, // the recording is currently written to by a timer
32 ruReplay = 0x0002, // the recording is being replayed
33 // mutually exclusive:
34 ruCut = 0x0004, // the recording is being cut
35 ruMove = 0x0008, // the recording is being moved
36 ruCopy = 0x0010, // the recording is being copied
37 // mutually exclusive:
38 ruSrc = 0x0020, // the recording is the source of a cut, move or copy process
39 ruDst = 0x0040, // the recording is the destination of a cut, move or copy process
40 //
41 ruPending = 0x0080, // the recording is pending a cut, move or copy process
42 ruCanceled = 0x8000, // the operation has been canceled, waiting for cleanup
43 };
44
46void AssertFreeDiskSpace(int Priority = 0, bool Force = false);
51
53private:
54 char *fileName;
55 time_t fileTime;
56 int index;
58public:
59 cResumeFile(const char *FileName, bool IsPesRecording);
61 void SetFileName(const char *FileName);
62 time_t FileTime(void);
63 int Index(void);
64 int Read(void);
65 bool Save(int Index);
66 void Reset(void);
67 void Delete(void);
68 };
69
71 friend class cRecording;
72private:
73 time_t modified;
76 const cEvent *event;
78 char *aux;
80 uint16_t frameWidth;
81 uint16_t frameHeight;
86 char *fileName;
87 int errors;
89 cRecordingInfo(const cChannel *Channel = NULL, const cEvent *Event = NULL);
90 bool Read(FILE *f, bool Force = false);
91public:
92 cRecordingInfo(const char *FileName);
94 tChannelID ChannelID(void) const { return channelID; }
95 const char *ChannelName(void) const { return channelName; }
96 const cEvent *GetEvent(void) const { return event; }
97 const char *Title(void) const { return event->Title(); }
98 const char *ShortText(void) const { return event->ShortText(); }
99 const char *Description(void) const { return event->Description(); }
100 const cComponents *Components(void) const { return event->Components(); }
101 const char *Aux(void) const { return aux; }
102 double FramesPerSecond(void) const { return framesPerSecond; }
103 int Priority(void) const { return priority; }
104 int Lifetime(void) const { return lifetime; }
105 int ParentalRating(void) { return event->ParentalRating(); }
106 uint16_t FrameWidth(void) const { return frameWidth; }
107 uint16_t FrameHeight(void) const { return frameHeight; }
108 eScanType ScanType(void) const { return scanType; }
109 char ScanTypeChar(void) const { return ScanTypeChars[scanType]; }
110 eAspectRatio AspectRatio(void) const { return aspectRatio; }
111 const char *AspectRatioText(void) const { return AspectRatioTexts[aspectRatio]; }
112 cString FrameParams(void) const;
114 void SetPriority(int Priority);
115 void SetLifetime(int Lifetime);
116 void SetTitle(const char *Title);
117 void SetShortText(const char *ShortText);
118 void SetDescription(const char *Description);
121 void SetFileName(const char *FileName);
122 int Errors(void) const { return errors; } // returns -1 if undefined
123 int TmpErrors(void) const { return tmpErrors; } // returns -1 if undefined
124 void SetErrors(int Errors, int TmpErrors = 0);
125 bool Write(FILE *f, const char *Prefix = "") const;
126 bool Read(bool Force = false);
127 bool Write(void) const;
128 [[deprecated("use SetTitle(), SetShortText() and SetDescription() instead")]]
129 void SetData(const char *Title, const char *ShortText, const char *Description);
130 void SetAux(const char *Aux);
131 };
132
133class cRecording : public cListObject {
134 friend class cRecordings;
135private:
136 int id;
138 mutable char *titleBuffer;
139 mutable char *sortBufferName;
140 mutable char *sortBufferTime;
141 mutable char *fileName;
142 mutable char *name;
143 mutable int fileSizeMB;
144 mutable int numFrames;
148 mutable int isOnVideoDirectoryFileSystem; // -1 = unknown, 0 = no, 1 = yes
150 cRecording(const cRecording&); // can't copy cRecording
151 cRecording &operator=(const cRecording &); // can't assign cRecording
152 static char *StripEpisodeName(char *s, bool Strip);
153 char *SortName(void) const;
154 void ClearSortName(void);
155 void SetId(int Id); // should only be set by cRecordings
156 time_t start;
157 time_t deleted;
158public:
159 cRecording(cTimer *Timer, const cEvent *Event);
160 cRecording(const char *FileName);
161 virtual ~cRecording() override;
162 int Id(void) const { return id; }
163 time_t Start(void) const { return start; }
164 int Priority(void) const { return info->Priority(); }
165 int Lifetime(void) const { return info->Lifetime(); }
166 time_t Deleted(void) const { return deleted; }
167 bool RetentionExpired(void) const;
168 void SetDeleted(void);
169 virtual int Compare(const cListObject &ListObject) const override;
170 bool IsInPath(const char *Path) const;
173 cString Folder(void) const;
176 cString BaseName(void) const;
179 const char *Name(void) const { return name; }
182 const char *FileName(void) const;
185 const char *Title(char Delimiter = ' ', bool NewIndicator = false, int Level = -1) const;
186 cRecordingInfo *Info(void) const { return info; }
187 const char *PrefixFileName(char Prefix);
188 int HierarchyLevels(void) const;
189 void ResetResume(void) const;
190 void DeleteResume(void) const;
191 double FramesPerSecond(void) const { return info->FramesPerSecond(); }
192 int NumFrames(void) const;
195 int NumFramesAfterEdit(void) const;
199 int LengthInSeconds(void) const;
201 int LengthInSecondsAfterEdit(void) const;
204 int FileSizeMB(void) const;
207 int GetResume(void) const;
210 time_t GetLastReplayTime(void) const;
213 bool IsNew(void) const { return GetResume() <= 0; }
214 bool IsEdited(void) const;
215 bool IsPesRecording(void) const { return isPesRecording; }
216 bool IsOnVideoDirectoryFileSystem(void) const;
217 bool HasMarks(void) const;
219 bool DeleteMarks(void);
223 void ReadInfo(bool Force = false);
224 bool WriteInfo(const char *OtherFileName = NULL);
228 void SetStartTime(time_t Start);
236 bool ChangePriorityLifetime(int NewPriority, int NewLifetime);
240 bool ChangeName(const char *NewName);
247 bool Delete(void);
252 bool Remove(void);
256 bool Undelete(void);
261 int IsInUse(void) const;
269 };
270
272
273class cRecordings : public cList<cRecording> {
274private:
277 static int lastRecordingId;
278 static char *updateFileName;
279 static time_t lastUpdate;
281 static const char *UpdateFileName(void);
282public:
283 cRecordings(bool Deleted = false);
284 virtual ~cRecordings() override;
285 static const cRecordings *GetRecordingsRead(cStateKey &StateKey, int TimeoutMs = 0) { return recordings.Lock(StateKey, false, TimeoutMs) ? &recordings : NULL; }
288 static cRecordings *GetRecordingsWrite(cStateKey &StateKey, int TimeoutMs = 0) { return recordings.Lock(StateKey, true, TimeoutMs) ? &recordings : NULL; }
291 static const cRecordings *GetDeletedRecordingsRead(cStateKey &StateKey, int TimeoutMs = 0) { return deletedRecordings.Lock(StateKey, false, TimeoutMs) ? &deletedRecordings : NULL; }
294 static cRecordings *GetDeletedRecordingsWrite(cStateKey &StateKey, int TimeoutMs = 0) { return deletedRecordings.Lock(StateKey, true, TimeoutMs) ? &deletedRecordings : NULL; }
297 static void Update(bool Wait = false);
301 static void TouchUpdate(void);
305 static bool NeedsUpdate(void);
306 void ResetResume(const char *ResumeFileName = NULL);
307 void ClearSortNames(void);
308 const cRecording *GetById(int Id) const;
309 cRecording *GetById(int Id) { return const_cast<cRecording *>(static_cast<const cRecordings *>(this)->GetById(Id)); };
310 const cRecording *GetByName(const char *FileName) const;
311 cRecording *GetByName(const char *FileName) { return const_cast<cRecording *>(static_cast<const cRecordings *>(this)->GetByName(FileName)); }
312 void Add(cRecording *Recording);
313 void AddByName(const char *FileName, bool TriggerUpdate = true);
314 [[deprecated("use explicit locking, deleting etc.")]] void DelByName(const char *FileName);
315 void UpdateByName(const char *FileName);
316 int TotalFileSizeMB(void) const;
317 double MBperMinute(void) const;
320 int PathIsInUse(const char *Path) const;
328 int GetNumRecordingsInPath(const char *Path) const;
332 bool MoveRecordings(const char *OldPath, const char *NewPath);
341 };
342
343// Provide lock controlled access to the list:
344
345DEF_LIST_LOCK(Recordings);
346DEF_LIST_LOCK2(Recordings, DeletedRecordings);
347
348// These macros provide a convenient way of locking the global recordings list
349// and making sure the lock is released as soon as the current scope is left
350// (note that these macros wait forever to obtain the lock!):
351
352#define LOCK_RECORDINGS_READ USE_LIST_LOCK_READ(Recordings)
353#define LOCK_RECORDINGS_WRITE USE_LIST_LOCK_WRITE(Recordings)
354#define LOCK_DELETEDRECORDINGS_READ USE_LIST_LOCK_READ2(Recordings, DeletedRecordings)
355#define LOCK_DELETEDRECORDINGS_WRITE USE_LIST_LOCK_WRITE2(Recordings, DeletedRecordings)
356
358
360private:
364 bool error;
365 cRecordingsHandlerEntry *Get(const char *FileName);
366protected:
367 virtual void Action(void) override;
368public:
369 cRecordingsHandler(void);
370 virtual ~cRecordingsHandler() override;
371 bool Add(int Usage, const char *FileNameSrc, const char *FileNameDst = NULL);
379 void Del(const char *FileName);
384 void DelAll(void);
386 int GetUsage(const char *FileName);
388 int GetRequiredDiskSpaceMB(const char *FileName = NULL);
392 bool Finished(bool &Error);
397 };
398
400
401#define DEFAULTFRAMESPERSECOND 25.0
402
403class cMark : public cListObject {
404 friend class cMarks; // for sorting
405private:
409public:
410 cMark(int Position = 0, const char *Comment = NULL, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
411 virtual ~cMark() override;
412 int Position(void) const { return position; }
413 const char *Comment(void) const { return comment; }
415 void SetComment(const char *Comment) { comment = Comment; }
416 cString ToText(void);
417 bool Parse(const char *s);
418 bool Save(FILE *f);
419 };
420
421class cMarks : public cConfig<cMark> {
422private:
430public:
431 cMarks(void): cConfig<cMark>("Marks") {};
432 static cString MarksFileName(const cRecording *Recording);
435 static bool DeleteMarksFile(const cRecording *Recording);
436 bool Load(const char *RecordingFileName, double FramesPerSecond = DEFAULTFRAMESPERSECOND, bool IsPesRecording = false);
437 bool Update(void);
438 bool Save(void);
439 void Align(void);
440 void Sort(void);
441 void Add(int Position);
447 const cMark *Get(int Position) const;
448 const cMark *GetPrev(int Position) const;
449 const cMark *GetNext(int Position) const;
450 const cMark *GetNextBegin(const cMark *EndMark = NULL) const;
454 const cMark *GetNextEnd(const cMark *BeginMark) const;
457 int GetNumSequences(void) const;
463 int GetFrameAfterEdit(int Frame, int LastFrame) const;
467 cMark *Get(int Position) { return const_cast<cMark *>(static_cast<const cMarks *>(this)->Get(Position)); }
468 cMark *GetPrev(int Position) { return const_cast<cMark *>(static_cast<const cMarks *>(this)->GetPrev(Position)); }
469 cMark *GetNext(int Position) { return const_cast<cMark *>(static_cast<const cMarks *>(this)->GetNext(Position)); }
470 cMark *GetNextBegin(const cMark *EndMark = NULL) { return const_cast<cMark *>(static_cast<const cMarks *>(this)->GetNextBegin(EndMark)); }
471 cMark *GetNextEnd(const cMark *BeginMark) { return const_cast<cMark *>(static_cast<const cMarks *>(this)->GetNextEnd(BeginMark)); }
472 };
473
474class cErrors : public cVector<int> {
475 };
476
477#define RUC_BEFORERECORDING "before"
478#define RUC_STARTRECORDING "started"
479#define RUC_AFTERRECORDING "after"
480#define RUC_EDITINGRECORDING "editing"
481#define RUC_EDITEDRECORDING "edited"
482#define RUC_DELETERECORDING "deleted"
483#define RUC_RENAMEDRECORDING "renamed" // same directory, only the base name is changed
484#define RUC_MOVEDRECORDING "moved" // different directory (and maybe base name), or "copy" to other filesystem + delete original (triggers copying->copied->deleted)
485#define RUC_COPYINGRECORDING "copying"
486#define RUC_COPIEDRECORDING "copied"
487
489private:
490 static const char *command;
491public:
492 static void SetCommand(const char *Command) { command = Command; }
493 static void InvokeCommand(const char *State, const char *RecordingFileName, const char *SourceFileName = NULL);
494 };
495
496// The maximum size of a single frame:
497#define MAXFRAMESIZE (3 * KILOBYTE(1024) / TS_SIZE * TS_SIZE) // multiple of TS_SIZE to avoid breaking up TS packets
498
499// The maximum file size is limited by the range that can be covered
500// with a 40 bit 'unsigned int', which is 1TB. The actual maximum value
501// used is 6MB below the theoretical maximum, to have some safety (the
502// actual file size may be slightly higher because we stop recording only
503// before the next independent frame, to have a complete Group Of Pictures):
504#define MAXVIDEOFILESIZETS 1048570 // MB
505#define MAXVIDEOFILESIZEPES 2000 // MB
506#define MINVIDEOFILESIZE 100 // MB
507#define MAXVIDEOFILESIZEDEFAULT MAXVIDEOFILESIZEPES
508
509struct tIndexTs;
511
513private:
514 int f;
516 int size, last;
518 tIndexTs *index;
524 void ConvertFromPes(tIndexTs *IndexTs, int Count);
525 void ConvertToPes(tIndexTs *IndexTs, int Count);
526 bool CatchUp(int Index = -1);
527public:
528 cIndexFile(const char *FileName, bool Record, bool IsPesRecording = false, bool PauseLive = false);
529 [[deprecated("use cIndexFile(::cIndexFile(const char *, bool, bool, bool) instead")]]
530 cIndexFile(const char *FileName, bool Record, bool IsPesRecording, bool PauseLive, bool Update)
531 :cIndexFile(FileName, Record, IsPesRecording, PauseLive) {}
532 ~cIndexFile();
533 bool Ok(void) { return index != NULL; }
534 bool Write(bool Independent, uint16_t FileNumber, off_t FileOffset, bool Errors = false, bool Missing = false);
535 bool Get(int Index, uint16_t *FileNumber, off_t *FileOffset, bool *Independent = NULL, int *Length = NULL, bool *Errors = NULL, bool *Missing = NULL);
536 const cErrors *GetErrors(void);
538 int GetNextIFrame(int Index, bool Forward, uint16_t *FileNumber = NULL, off_t *FileOffset = NULL, int *Length = NULL);
539 int GetClosestIFrame(int Index);
544 int Get(uint16_t FileNumber, off_t FileOffset);
545 int Last(void) { CatchUp(); return last; }
547 int GetResume(void) { return resumeFile.Read(); }
548 bool StoreResume(int Index) { return resumeFile.Save(Index); }
549 bool IsStillRecording(void);
550 void Delete(void);
551 static int GetLength(const char *FileName, bool IsPesRecording = false);
554 static cString IndexFileName(const char *FileName, bool IsPesRecording);
555 };
556
558private:
560 uint16_t fileNumber;
562 bool record;
565public:
566 cFileName(const char *FileName, bool Record, bool Blocking = false, bool IsPesRecording = false);
567 ~cFileName();
568 const char *Name(void) { return fileName; }
569 uint16_t Number(void) { return fileNumber; }
570 [[deprecated("will be removed in a future version, if your plugin uses this function, contact vdr@tvdr.de")]]
571 bool GetLastPatPmtVersions(int &PatVersion, int &PmtVersion);
572 cUnbufferedFile *Open(void);
573 void Close(void);
574 cUnbufferedFile *SetOffset(int Number, off_t Offset = 0); // yes, Number is int for easier internal calculating
576 };
577
579private:
582 void Add(const char *Title);
583public:
584 bool Load(const char *FileName);
585 bool Save(void) const;
586 void Append(const char *Title);
587 bool Contains(const char *Title) const;
588 };
589
591
592cString IndexToHMSF(int Index, bool WithFrame = false, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
593 // Converts the given index to a string, optionally containing the frame number.
594int HMSFToIndex(const char *HMSF, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
595 // Converts the given string (format: "hh:mm:ss.ff") to an index.
596int SecondsToFrames(int Seconds, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
597 // Returns the number of frames corresponding to the given number of seconds.
598
599int ReadFrame(cUnbufferedFile *f, uchar *b, int Length, int Max);
600
601char *ExchangeChars(char *s, bool ToFileSystem);
602 // Exchanges the characters in the given string to or from a file system
603 // specific representation (depending on ToFileSystem). The given string will
604 // be modified and may be reallocated if more space is needed. The return
605 // value points to the resulting string, which may be different from s.
606
607bool GenerateIndex(const char *FileName);
610[[deprecated("use GenerateIndex(const char *FileName) instead")]]
611inline bool GenerateIndex(const char *FileName, bool Update) { return GenerateIndex(FileName); }
612
616bool HasRecordingsSortMode(const char *Directory);
617void GetRecordingsSortMode(const char *Directory);
618void SetRecordingsSortMode(const char *Directory, eRecordingsSortMode SortMode);
619void IncRecordingsSortMode(const char *Directory);
620
621void SetRecordingTimerId(const char *Directory, const char *TimerId);
622cString GetRecordingTimerId(const char *Directory);
623
624int FileSizeMBafterEdit(const char *FileName);
625bool EnoughFreeDiskSpaceForEdit(const char *FileName);
626
627#endif //__RECORDING_H
cConfig(const char *NeedsLocking=NULL)
Definition config.h:133
cStringList doneRecordings
Definition recording.h:581
bool Save(void) const
Definition recording.c:3454
void Add(const char *Title)
Definition recording.c:3473
cString fileName
Definition recording.h:580
void Append(const char *Title)
Definition recording.c:3478
bool Load(const char *FileName)
Definition recording.c:3433
bool Contains(const char *Title) const
Definition recording.c:3501
Definition epg.h:74
bool isPesRecording
Definition recording.h:564
cUnbufferedFile * NextFile(void)
Definition recording.c:3424
uint16_t Number(void)
Definition recording.h:569
bool record
Definition recording.h:562
void Close(void)
Definition recording.c:3372
uint16_t fileNumber
Definition recording.h:560
cUnbufferedFile * Open(void)
Definition recording.c:3348
cFileName(const char *FileName, bool Record, bool Blocking=false, bool IsPesRecording=false)
Definition recording.c:3273
char * fileName
Definition recording.h:561
char * pFileNumber
Definition recording.h:561
const char * Name(void)
Definition recording.h:568
bool GetLastPatPmtVersions(int &PatVersion, int &PmtVersion)
Definition recording.c:3297
bool blocking
Definition recording.h:563
cUnbufferedFile * SetOffset(int Number, off_t Offset=0)
Definition recording.c:3382
cUnbufferedFile * file
Definition recording.h:559
int GetNextIFrame(int Index, bool Forward, uint16_t *FileNumber=NULL, off_t *FileOffset=NULL, int *Length=NULL)
Definition recording.c:3132
bool Write(bool Independent, uint16_t FileNumber, off_t FileOffset, bool Errors=false, bool Missing=false)
Definition recording.c:3074
cResumeFile resumeFile
Definition recording.h:520
bool IsStillRecording(void)
Definition recording.c:3212
void ConvertFromPes(tIndexTs *IndexTs, int Count)
Definition recording.c:2993
cIndexFile(const char *FileName, bool Record, bool IsPesRecording=false, bool PauseLive=false)
Definition recording.c:2890
static int GetLength(const char *FileName, bool IsPesRecording=false)
Calculates the recording length (number of frames) without actually reading the index file.
Definition recording.c:3229
bool CatchUp(int Index=-1)
Definition recording.c:3018
const cErrors * GetErrors(void)
Returns the frame indexes of errors in the recording (if any).
Definition recording.c:3121
int GetResume(void)
Definition recording.h:547
void ConvertToPes(tIndexTs *IndexTs, int Count)
Definition recording.c:3005
bool isPesRecording
Definition recording.h:519
cErrors errors
Definition recording.h:521
cIndexFile(const char *FileName, bool Record, bool IsPesRecording, bool PauseLive, bool Update)
Definition recording.h:530
int lastErrorIndex
Definition recording.h:517
cString fileName
Definition recording.h:515
bool StoreResume(int Index)
Definition recording.h:548
cIndexFileGenerator * indexFileGenerator
Definition recording.h:522
static cString IndexFileName(const char *FileName, bool IsPesRecording)
Definition recording.c:2988
int GetClosestIFrame(int Index)
Returns the index of the I-frame that is closest to the given Index (or Index itself,...
Definition recording.c:3170
bool Ok(void)
Definition recording.h:533
cMutex mutex
Definition recording.h:523
bool Get(int Index, uint16_t *FileNumber, off_t *FileOffset, bool *Independent=NULL, int *Length=NULL, bool *Errors=NULL, bool *Missing=NULL)
Definition recording.c:3091
void Delete(void)
Definition recording.c:3217
int Last(void)
Returns the index of the last entry in this file, or -1 if the file is empty.
Definition recording.h:545
tIndexTs * index
Definition recording.h:518
cListObject(const cListObject &ListObject)
Definition tools.h:547
Definition tools.h:644
cList(const char *NeedsLocking=NULL)
Definition tools.h:646
cMark(int Position=0, const char *Comment=NULL, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition recording.c:2399
cString comment
Definition recording.h:408
int position
Definition recording.h:407
bool Parse(const char *s)
Definition recording.c:2415
friend class cMarks
Definition recording.h:404
bool Save(FILE *f)
Definition recording.c:2429
cString ToText(void)
Definition recording.c:2410
const char * Comment(void) const
Definition recording.h:413
double framesPerSecond
Definition recording.h:406
void SetPosition(int Position)
Definition recording.h:414
int Position(void) const
Definition recording.h:412
virtual ~cMark() override
Definition recording.c:2406
void SetComment(const char *Comment)
Definition recording.h:415
int GetNumSequences(void) const
Returns the actual number of sequences to be cut from the recording.
Definition recording.c:2595
double framesPerSecond
Definition recording.h:425
void Add(int Position)
If this cMarks object is used by multiple threads, the caller must Lock() it before calling Add() and...
Definition recording.c:2528
const cMark * GetNextBegin(const cMark *EndMark=NULL) const
Returns the next "begin" mark after EndMark, skipping any marks at the same position as EndMark.
Definition recording.c:2561
const cMark * GetNext(int Position) const
Definition recording.c:2552
bool Update(void)
Definition recording.c:2464
bool Load(const char *RecordingFileName, double FramesPerSecond=DEFAULTFRAMESPERSECOND, bool IsPesRecording=false)
Definition recording.c:2452
time_t lastFileTime
Definition recording.h:428
const cMark * GetNextEnd(const cMark *BeginMark) const
Returns the next "end" mark after BeginMark, skipping any marks at the same position as BeginMark.
Definition recording.c:2577
const cMark * Get(int Position) const
Definition recording.c:2534
cString recordingFileName
Definition recording.h:423
bool isPesRecording
Definition recording.h:426
time_t nextUpdate
Definition recording.h:427
cString fileName
Definition recording.h:424
static bool DeleteMarksFile(const cRecording *Recording)
Definition recording.c:2441
void Align(void)
Definition recording.c:2504
int GetFrameAfterEdit(int Frame, int LastFrame) const
Returns the number of the given Frame within the region covered by begin/end sequences.
Definition recording.c:2612
void Sort(void)
Definition recording.c:2516
cMark * Get(int Position)
Definition recording.h:467
cMark * GetNextEnd(const cMark *BeginMark)
Definition recording.h:471
cMarks(void)
Definition recording.h:431
cMark * GetNextBegin(const cMark *EndMark=NULL)
Definition recording.h:470
cMark * GetPrev(int Position)
Definition recording.h:468
static cString MarksFileName(const cRecording *Recording)
Returns the marks file name for the given Recording (regardless whether such a file actually exists).
Definition recording.c:2436
cMark * GetNext(int Position)
Definition recording.h:469
bool Save(void)
Definition recording.c:2495
const cMark * GetPrev(int Position) const
Definition recording.c:2543
time_t lastChange
Definition recording.h:429
char ScanTypeChar(void) const
Definition recording.h:109
const char * ChannelName(void) const
Definition recording.h:95
void SetFramesPerSecond(double FramesPerSecond)
Definition recording.c:501
cEvent * ownEvent
Definition recording.h:77
const cEvent * GetEvent(void) const
Definition recording.h:96
int TmpErrors(void) const
Definition recording.h:123
uint16_t FrameHeight(void) const
Definition recording.h:107
const cEvent * event
Definition recording.h:76
uint16_t frameHeight
Definition recording.h:81
void SetTitle(const char *Title)
Definition recording.c:516
void SetDescription(const char *Description)
Definition recording.c:526
int Errors(void) const
Definition recording.h:122
const char * AspectRatioText(void) const
Definition recording.h:111
int Priority(void) const
Definition recording.h:103
const char * ShortText(void) const
Definition recording.h:98
eAspectRatio aspectRatio
Definition recording.h:83
eScanType ScanType(void) const
Definition recording.h:108
int Lifetime(void) const
Definition recording.h:104
cRecordingInfo(const cChannel *Channel=NULL, const cEvent *Event=NULL)
Definition recording.c:392
bool Write(void) const
Definition recording.c:699
int ParentalRating(void)
Definition recording.h:105
void SetLifetime(int Lifetime)
Definition recording.c:511
const char * Title(void) const
Definition recording.h:97
tChannelID channelID
Definition recording.h:74
cString FrameParams(void) const
Definition recording.c:715
const char * Aux(void) const
Definition recording.h:101
eScanType scanType
Definition recording.h:82
friend class cRecording
Definition recording.h:71
tChannelID ChannelID(void) const
Definition recording.h:94
void SetFileName(const char *FileName)
Definition recording.c:544
void SetPriority(int Priority)
Definition recording.c:506
void SetParentalRating(int ParentalRating)
Definition recording.c:531
time_t modified
Definition recording.h:73
char * channelName
Definition recording.h:75
uint16_t FrameWidth(void) const
Definition recording.h:106
void SetFrameParams(uint16_t FrameWidth, uint16_t FrameHeight, eScanType ScanType, eAspectRatio AspectRatio)
Definition recording.c:536
void SetShortText(const char *ShortText)
Definition recording.c:521
void SetAux(const char *Aux)
Definition recording.c:495
void SetData(const char *Title, const char *ShortText, const char *Description)
Definition recording.c:485
const char * Description(void) const
Definition recording.h:99
eAspectRatio AspectRatio(void) const
Definition recording.h:110
bool Read(FILE *f, bool Force=false)
Definition recording.c:557
uint16_t frameWidth
Definition recording.h:80
void SetErrors(int Errors, int TmpErrors=0)
Definition recording.c:551
double framesPerSecond
Definition recording.h:79
double FramesPerSecond(void) const
Definition recording.h:102
char * fileName
Definition recording.h:86
const cComponents * Components(void) const
Definition recording.h:100
static const char * command
Definition recording.h:490
static void InvokeCommand(const char *State, const char *RecordingFileName, const char *SourceFileName=NULL)
Definition recording.c:2648
static void SetCommand(const char *Command)
Definition recording.h:492
virtual int Compare(const cListObject &ListObject) const override
Must return 0 if this object is equal to ListObject, a positive value if it is "greater",...
Definition recording.c:1210
int isOnVideoDirectoryFileSystem
Definition recording.h:148
virtual ~cRecording() override
Definition recording.c:1110
time_t deleted
Definition recording.h:157
cRecordingInfo * info
Definition recording.h:149
bool ChangePriorityLifetime(int NewPriority, int NewLifetime)
Changes the priority and lifetime of this recording to the given values.
Definition recording.c:1398
bool HasMarks(void) const
Returns true if this recording has any editing marks.
Definition recording.c:1355
cRecording & operator=(const cRecording &)
bool WriteInfo(const char *OtherFileName=NULL)
Writes the info file of this recording.
Definition recording.c:1370
time_t GetLastReplayTime(void) const
Returns the time this recording was last replayed (which is actually the timestamp of the resume file...
Definition recording.c:1191
int IsInUse(void) const
Checks whether this recording is currently in use and therefore shall not be tampered with.
Definition recording.c:1524
bool ChangeName(const char *NewName)
Changes the name of this recording to the given value.
Definition recording.c:1422
bool Undelete(void)
Changes the file name (both internally and on disk) to make this a "normal" recording.
Definition recording.c:1494
void ResetResume(void) const
Definition recording.c:1540
void ReadInfo(bool Force=false)
Definition recording.c:1365
bool IsNew(void) const
Definition recording.h:213
bool Delete(void)
Changes the file name (both internally and on disk) to make this a "deleted" recording.
Definition recording.c:1451
cString Folder(void) const
Returns the name of the folder this recording is stored in (without the video directory).
Definition recording.c:1227
bool isPesRecording
Definition recording.h:147
void DeleteResume(void) const
Definition recording.c:1546
void ClearSortName(void)
Definition recording.c:1174
char * sortBufferName
Definition recording.h:139
int NumFrames(void) const
Returns the number of frames in this recording.
Definition recording.c:1552
bool IsEdited(void) const
Definition recording.c:1342
int Id(void) const
Definition recording.h:162
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...
Definition recording.c:1186
bool IsInPath(const char *Path) const
Returns true if this recording is stored anywhere under the given Path.
Definition recording.c:1219
int fileSizeMB
Definition recording.h:143
void SetId(int Id)
Definition recording.c:1181
void SetStartTime(time_t Start)
Sets the start time of this recording to the given value.
Definition recording.c:1391
char * SortName(void) const
Definition recording.c:1150
const char * Name(void) const
Returns the full name of the recording (without the video directory).
Definition recording.h:179
cResumeFile * resume
Definition recording.h:137
time_t Start(void) const
Definition recording.h:163
int Lifetime(void) const
Definition recording.h:165
int NumFramesAfterEdit(void) const
Returns the number of frames in the edited version of this recording.
Definition recording.c:1563
const char * FileName(void) const
Returns the full path name to the recording directory, including the video directory and the actual '...
Definition recording.c:1239
cRecordingInfo * Info(void) const
Definition recording.h:186
const char * PrefixFileName(char Prefix)
Definition recording.c:1320
bool DeleteMarks(void)
Deletes the editing marks from this recording (if any).
Definition recording.c:1360
bool IsOnVideoDirectoryFileSystem(void) const
Definition recording.c:1348
int HierarchyLevels(void) const
Definition recording.c:1331
int FileSizeMB(void) const
Returns the total file size of this recording (in MB), or -1 if the file size is unknown.
Definition recording.c:1590
cString BaseName(void) const
Returns the base name of this recording (without the video directory and folder).
Definition recording.c:1234
char * fileName
Definition recording.h:141
char * titleBuffer
Definition recording.h:138
void SetDeleted(void)
Definition recording.c:1205
int Priority(void) const
Definition recording.h:164
const char * Title(char Delimiter=' ', bool NewIndicator=false, int Level=-1) const
Definition recording.c:1257
int instanceId
Definition recording.h:146
bool Remove(void)
Actually removes the file from the disk.
Definition recording.c:1483
char * name
Definition recording.h:142
cRecording(const cRecording &)
char * sortBufferTime
Definition recording.h:140
int LengthInSecondsAfterEdit(void) const
Returns the length (in seconds) of the edited version of this recording, or -1 in case of error.
Definition recording.c:1582
bool RetentionExpired(void) const
Definition recording.c:1196
time_t start
Definition recording.h:156
int numFrames
Definition recording.h:144
double FramesPerSecond(void) const
Definition recording.h:191
bool IsPesRecording(void) const
Definition recording.h:215
time_t Deleted(void) const
Definition recording.h:166
static char * StripEpisodeName(char *s, bool Strip)
Definition recording.c:1121
int LengthInSeconds(void) const
Returns the length (in seconds) of this recording, or -1 in case of error.
Definition recording.c:1574
friend class cRecordings
Definition recording.h:134
void DelAll(void)
Deletes/terminates all operations.
Definition recording.c:2349
virtual ~cRecordingsHandler() override
Definition recording.c:2268
cRecordingsHandlerEntry * Get(const char *FileName)
Definition recording.c:2298
bool Add(int Usage, const char *FileNameSrc, const char *FileNameDst=NULL)
Adds the given FileNameSrc to the recordings handler for (later) processing.
Definition recording.c:2311
bool Finished(bool &Error)
Returns true if all operations in the list have been finished.
Definition recording.c:2382
int GetUsage(const char *FileName)
Returns the usage type for the given FileName.
Definition recording.c:2356
cList< cRecordingsHandlerEntry > operations
Definition recording.h:362
void Del(const char *FileName)
Deletes the given FileName from the list of operations.
Definition recording.c:2342
virtual void Action(void) override
A derived cThread class must implement the code it wants to execute as a separate thread in this func...
Definition recording.c:2273
int GetRequiredDiskSpaceMB(const char *FileName=NULL)
Returns the total disk space required to process all actions.
Definition recording.c:2364
void ResetResume(const char *ResumeFileName=NULL)
Definition recording.c:1939
void UpdateByName(const char *FileName)
Definition recording.c:1859
static const char * UpdateFileName(void)
Definition recording.c:1751
double MBperMinute(void) const
Returns the average data rate (in MB/min) of all recordings, or -1 if this value is unknown.
Definition recording.c:1878
cRecording * GetByName(const char *FileName)
Definition recording.h:311
virtual ~cRecordings() override
Definition recording.c:1744
cRecordings(bool Deleted=false)
Definition recording.c:1739
int GetNumRecordingsInPath(const char *Path) const
Returns the total number of recordings in the given Path, including all sub-folders of Path.
Definition recording.c:1909
static const cRecordings * GetRecordingsRead(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of recordings for read access.
Definition recording.h:285
const cRecording * GetById(int Id) const
Definition recording.c:1786
static const cRecordings * GetDeletedRecordingsRead(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of deleted recordings for read access.
Definition recording.h:291
static cRecordings * GetDeletedRecordingsWrite(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of deleted recordings for write access.
Definition recording.h:294
static time_t lastUpdate
Definition recording.h:279
static cRecordings deletedRecordings
Definition recording.h:276
void AddByName(const char *FileName, bool TriggerUpdate=true)
Definition recording.c:1812
static cRecordings recordings
Definition recording.h:275
int TotalFileSizeMB(void) const
Definition recording.c:1867
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.
Definition recording.c:1774
static cRecordings * GetRecordingsWrite(cStateKey &StateKey, int TimeoutMs=0)
Gets the list of recordings for write access.
Definition recording.h:288
static void TouchUpdate(void)
Touches the '.update' file in the video directory, so that other instances of VDR that access the sam...
Definition recording.c:1758
void Add(cRecording *Recording)
Definition recording.c:1806
static cVideoDirectoryScannerThread * videoDirectoryScannerThread
Definition recording.h:280
void DelByName(const char *FileName)
Definition recording.c:1823
bool MoveRecordings(const char *OldPath, const char *NewPath)
Moves all recordings in OldPath to NewPath.
Definition recording.c:1919
static bool NeedsUpdate(void)
Definition recording.c:1766
cRecording * GetById(int Id)
Definition recording.h:309
void ClearSortNames(void)
Definition recording.c:1947
static int lastRecordingId
Definition recording.h:277
const cRecording * GetByName(const char *FileName) const
Definition recording.c:1795
static char * updateFileName
Definition recording.h:278
int PathIsInUse(const char *Path) const
Checks whether any recording in the given Path is currently in use and therefore the whole Path shall...
Definition recording.c:1899
bool isPesRecording
Definition recording.h:57
bool Save(int Index)
Definition recording.c:333
void Reset(void)
Definition recording.c:373
time_t FileTime(void)
Definition recording.c:272
char * fileName
Definition recording.h:54
int Index(void)
Definition recording.c:279
void SetFileName(const char *FileName)
Definition recording.c:258
time_t fileTime
Definition recording.h:55
int Read(void)
Definition recording.c:286
void Delete(void)
Definition recording.c:378
cResumeFile(const char *FileName, bool IsPesRecording)
Definition recording.c:244
cThread(const char *Description=NULL, bool LowPriority=false)
Creates a new thread.
Definition thread.c:239
cUnbufferedFile is used for large files that are mainly written or read in a streaming manner,...
Definition tools.h:507
cVector(const cVector &Vector)
Definition tools.h:720
int DirectoryNameMax
Definition recording.c:75
int DirectoryPathMax
Definition recording.c:74
eRecordingsSortMode RecordingsSortMode
Definition recording.c:3574
int InstanceId
Definition recording.c:77
bool DirectoryEncoding
Definition recording.c:76
cDoneRecordings DoneRecordingsPattern
Definition recording.c:3431
cRecordingsHandler RecordingsHandler
Definition recording.c:2259
eRecordingUsage
Definition recording.h:29
@ ruSrc
Definition recording.h:38
@ ruCut
Definition recording.h:34
@ ruReplay
Definition recording.h:32
@ ruCopy
Definition recording.h:36
@ ruCanceled
Definition recording.h:42
@ ruTimer
Definition recording.h:31
@ ruDst
Definition recording.h:39
@ ruNone
Definition recording.h:30
@ ruMove
Definition recording.h:35
@ ruPending
Definition recording.h:41
cString GetRecordingTimerId(const char *Directory)
Definition recording.c:3629
eRecordingsSortMode
Definition recording.h:614
@ rsmName
Definition recording.h:614
@ rsmTime
Definition recording.h:614
#define DEFAULTFRAMESPERSECOND
Definition recording.h:401
int HMSFToIndex(const char *HMSF, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition recording.c:3540
eRecordingsSortDir
Definition recording.h:613
@ rsdDescending
Definition recording.h:613
@ rsdAscending
Definition recording.h:613
void GetRecordingsSortMode(const char *Directory)
Definition recording.c:3581
bool GenerateIndex(const char *FileName)
Generates the index of the existing recording with the given FileName.
Definition recording.c:3238
bool HasRecordingsSortMode(const char *Directory)
Definition recording.c:3576
bool EnoughFreeDiskSpaceForEdit(const char *FileName)
Definition recording.c:3661
char * ExchangeChars(char *s, bool ToFileSystem)
Definition recording.c:759
void IncRecordingsSortMode(const char *Directory)
Definition recording.c:3600
void SetRecordingsSortMode(const char *Directory, eRecordingsSortMode SortMode)
Definition recording.c:3592
int FileSizeMBafterEdit(const char *FileName)
Definition recording.c:3646
int ReadFrame(cUnbufferedFile *f, uchar *b, int Length, int Max)
Definition recording.c:3558
void SetRecordingTimerId(const char *Directory, const char *TimerId)
Definition recording.c:3611
void RemoveDeletedRecordings(void)
Definition recording.c:135
int SecondsToFrames(int Seconds, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition recording.c:3551
cString IndexToHMSF(int Index, bool WithFrame=false, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition recording.c:3524
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...
Definition recording.c:152
const char * AspectRatioTexts[]
Definition remux.c:2163
const char * ScanTypeChars
Definition remux.c:2162
eAspectRatio
Definition remux.h:514
eScanType
Definition remux.h:507
#define DEF_LIST_LOCK(Class)
Definition tools.h:699
unsigned char uchar
Definition tools.h:31
#define DEF_LIST_LOCK2(Class, Name)
Definition tools.h:682