vdr  2.0.6
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 2.46.1.1 2013/12/25 10:54:05 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 
21 #define FOLDERDELIMCHAR '~'
22 
23 extern int DirectoryPathMax;
24 extern int DirectoryNameMax;
25 extern bool DirectoryEncoding;
26 extern int InstanceId;
27 
28 void RemoveDeletedRecordings(void);
29 void ClearVanishedRecordings(void);
30 void AssertFreeDiskSpace(int Priority = 0, bool Force = false);
35 
36 class cResumeFile {
37 private:
38  char *fileName;
40 public:
41  cResumeFile(const char *FileName, bool IsPesRecording);
42  ~cResumeFile();
43  int Read(void);
44  bool Save(int Index);
45  void Delete(void);
46  };
47 
49  friend class cRecording;
50 private:
52  char *channelName;
53  const cEvent *event;
55  char *aux;
57  int priority;
58  int lifetime;
59  char *fileName;
60  cRecordingInfo(const cChannel *Channel = NULL, const cEvent *Event = NULL);
61  bool Read(FILE *f);
62  void SetData(const char *Title, const char *ShortText, const char *Description);
63  void SetAux(const char *Aux);
64 public:
65  cRecordingInfo(const char *FileName);
67  tChannelID ChannelID(void) const { return channelID; }
68  const char *ChannelName(void) const { return channelName; }
69  const cEvent *GetEvent(void) const { return event; }
70  const char *Title(void) const { return event->Title(); }
71  const char *ShortText(void) const { return event->ShortText(); }
72  const char *Description(void) const { return event->Description(); }
73  const cComponents *Components(void) const { return event->Components(); }
74  const char *Aux(void) const { return aux; }
75  double FramesPerSecond(void) const { return framesPerSecond; }
77  bool Write(FILE *f, const char *Prefix = "") const;
78  bool Read(void);
79  bool Write(void) const;
80  };
81 
82 class cRecording : public cListObject {
83  friend class cRecordings;
84 private:
85  mutable int resume;
86  mutable char *titleBuffer;
87  mutable char *sortBufferName;
88  mutable char *sortBufferTime;
89  mutable char *fileName;
90  mutable char *name;
91  mutable int fileSizeMB;
92  mutable int numFrames;
93  int channel;
96  mutable int isOnVideoDirectoryFileSystem; // -1 = unknown, 0 = no, 1 = yes
99  cRecording(const cRecording&); // can't copy cRecording
100  cRecording &operator=(const cRecording &); // can't assign cRecording
101  static char *StripEpisodeName(char *s, bool Strip);
102  char *SortName(void) const;
103  void ClearSortName(void);
104  int GetResume(void) const;
105  time_t start;
106  int priority;
107  int lifetime;
108  time_t deleted;
109 public:
110  cRecording(cTimer *Timer, const cEvent *Event);
111  cRecording(const char *FileName);
112  virtual ~cRecording();
113  time_t Start(void) const { return start; }
114  int Priority(void) const { return priority; }
115  int Lifetime(void) const { return lifetime; }
116  time_t Deleted(void) const { return deleted; }
117  virtual int Compare(const cListObject &ListObject) const;
118  const char *Name(void) const { return name; }
119  const char *FileName(void) const;
120  const char *Title(char Delimiter = ' ', bool NewIndicator = false, int Level = -1) const;
121  const cRecordingInfo *Info(void) const { return info; }
122  const char *PrefixFileName(char Prefix);
123  int HierarchyLevels(void) const;
124  void ResetResume(void) const;
125  double FramesPerSecond(void) const { return framesPerSecond; }
126  int NumFrames(void) const;
129  int LengthInSeconds(void) const;
131  int FileSizeMB(void) const;
134  bool IsNew(void) const { return GetResume() <= 0; }
135  bool IsEdited(void) const;
136  bool IsPesRecording(void) const { return isPesRecording; }
137  bool IsOnVideoDirectoryFileSystem(void) const;
138  void ReadInfo(void);
139  bool WriteInfo(void);
140  void SetStartTime(time_t Start);
148  bool Delete(void);
151  bool Remove(void);
154  bool Undelete(void);
158  };
159 
160 class cRecordings : public cList<cRecording>, public cThread {
161 private:
162  static char *updateFileName;
163  bool deleted;
164  bool initial;
165  time_t lastUpdate;
166  int state;
167  const char *UpdateFileName(void);
168  void Refresh(bool Foreground = false);
169  void ScanVideoDir(const char *DirName, bool Foreground = false, int LinkLevel = 0, int DirLevel = 0);
170 protected:
171  void Action(void);
172 public:
173  cRecordings(bool Deleted = false);
174  virtual ~cRecordings();
175  bool Load(void) { return Update(true); }
179  bool Update(bool Wait = false);
185  void TouchUpdate(void);
189  bool NeedsUpdate(void);
190  void ChangeState(void) { state++; }
191  bool StateChanged(int &State);
192  void ResetResume(const char *ResumeFileName = NULL);
193  void ClearSortNames(void);
194  cRecording *GetByName(const char *FileName);
195  void AddByName(const char *FileName, bool TriggerUpdate = true);
196  void DelByName(const char *FileName);
197  void UpdateByName(const char *FileName);
198  int TotalFileSizeMB(void);
199  double MBperMinute(void);
202  };
203 
206 extern cRecordings Recordings;
208 
209 #define DEFAULTFRAMESPERSECOND 25.0
210 
211 class cMark : public cListObject {
212  friend class cMarks; // for sorting
213 private:
215  int position;
217 public:
218  cMark(int Position = 0, const char *Comment = NULL, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
219  virtual ~cMark();
220  int Position(void) const { return position; }
221  const char *Comment(void) const { return comment; }
222  void SetPosition(int Position) { position = Position; }
223  void SetComment(const char *Comment) { comment = Comment; }
224  cString ToText(void);
225  bool Parse(const char *s);
226  bool Save(FILE *f);
227  };
228 
229 class cMarks : public cConfig<cMark> {
230 private:
235  time_t nextUpdate;
236  time_t lastFileTime;
237  time_t lastChange;
238 public:
239  bool Load(const char *RecordingFileName, double FramesPerSecond = DEFAULTFRAMESPERSECOND, bool IsPesRecording = false);
240  bool Update(void);
241  bool Save(void);
242  void Align(void);
243  void Sort(void);
244  void Add(int Position);
245  cMark *Get(int Position);
246  cMark *GetPrev(int Position);
247  cMark *GetNext(int Position);
248  cMark *GetNextBegin(cMark *EndMark = NULL);
252  cMark *GetNextEnd(cMark *BeginMark);
255  int GetNumSequences(void);
261  };
262 
263 #define RUC_BEFORERECORDING "before"
264 #define RUC_AFTERRECORDING "after"
265 #define RUC_EDITEDRECORDING "edited"
266 #define RUC_DELETERECORDING "deleted"
267 
269 private:
270  static const char *command;
271 public:
272  static void SetCommand(const char *Command) { command = Command; }
273  static void InvokeCommand(const char *State, const char *RecordingFileName, const char *SourceFileName = NULL);
274  };
275 
276 // The maximum size of a single frame (up to HDTV 1920x1080):
277 #define MAXFRAMESIZE (KILOBYTE(1024) / TS_SIZE * TS_SIZE) // multiple of TS_SIZE to avoid breaking up TS packets
278 
279 // The maximum file size is limited by the range that can be covered
280 // with a 40 bit 'unsigned int', which is 1TB. The actual maximum value
281 // used is 6MB below the theoretical maximum, to have some safety (the
282 // actual file size may be slightly higher because we stop recording only
283 // before the next independent frame, to have a complete Group Of Pictures):
284 #define MAXVIDEOFILESIZETS 1048570 // MB
285 #define MAXVIDEOFILESIZEPES 2000 // MB
286 #define MINVIDEOFILESIZE 100 // MB
287 #define MAXVIDEOFILESIZEDEFAULT MAXVIDEOFILESIZEPES
288 
289 struct tIndexTs;
290 class cIndexFileGenerator;
291 
292 class cIndexFile {
293 private:
294  int f;
296  int size, last;
302  void ConvertFromPes(tIndexTs *IndexTs, int Count);
303  void ConvertToPes(tIndexTs *IndexTs, int Count);
304  bool CatchUp(int Index = -1);
305 public:
306  cIndexFile(const char *FileName, bool Record, bool IsPesRecording = false, bool PauseLive = false);
307  ~cIndexFile();
308  bool Ok(void) { return index != NULL; }
309  bool Write(bool Independent, uint16_t FileNumber, off_t FileOffset);
310  bool Get(int Index, uint16_t *FileNumber, off_t *FileOffset, bool *Independent = NULL, int *Length = NULL);
311  int GetNextIFrame(int Index, bool Forward, uint16_t *FileNumber = NULL, off_t *FileOffset = NULL, int *Length = NULL);
312  int GetClosestIFrame(int Index);
317  int Get(uint16_t FileNumber, off_t FileOffset);
318  int Last(void) { CatchUp(); return last; }
320  int GetResume(void) { return resumeFile.Read(); }
321  bool StoreResume(int Index) { return resumeFile.Save(Index); }
322  bool IsStillRecording(void);
323  void Delete(void);
324  static int GetLength(const char *FileName, bool IsPesRecording = false);
327  static cString IndexFileName(const char *FileName, bool IsPesRecording);
328  };
329 
330 class cFileName {
331 private:
333  uint16_t fileNumber;
335  bool record;
336  bool blocking;
338 public:
339  cFileName(const char *FileName, bool Record, bool Blocking = false, bool IsPesRecording = false);
340  ~cFileName();
341  const char *Name(void) { return fileName; }
342  uint16_t Number(void) { return fileNumber; }
343  bool GetLastPatPmtVersions(int &PatVersion, int &PmtVersion);
344  cUnbufferedFile *Open(void);
345  void Close(void);
346  cUnbufferedFile *SetOffset(int Number, off_t Offset = 0); // yes, Number is int for easier internal calculating
347  cUnbufferedFile *NextFile(void);
348  };
349 
350 cString IndexToHMSF(int Index, bool WithFrame = false, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
351  // Converts the given index to a string, optionally containing the frame number.
352 int HMSFToIndex(const char *HMSF, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
353  // Converts the given string (format: "hh:mm:ss.ff") to an index.
354 int SecondsToFrames(int Seconds, double FramesPerSecond = DEFAULTFRAMESPERSECOND);
355  // Returns the number of frames corresponding to the given number of seconds.
356 
357 int ReadFrame(cUnbufferedFile *f, uchar *b, int Length, int Max);
358 
359 char *ExchangeChars(char *s, bool ToFileSystem);
360  // Exchanges the characters in the given string to or from a file system
361  // specific representation (depending on ToFileSystem). The given string will
362  // be modified and may be reallocated if more space is needed. The return
363  // value points to the resulting string, which may be different from s.
364 
365 bool GenerateIndex(const char *FileName);
366 
369 bool HasRecordingsSortMode(const char *Directory);
370 void GetRecordingsSortMode(const char *Directory);
371 void SetRecordingsSortMode(const char *Directory, eRecordingsSortMode SortMode);
372 void IncRecordingsSortMode(const char *Directory);
373 
374 #endif //__RECORDING_H
bool initial
Definition: recording.h:164
unsigned char uchar
Definition: tools.h:30
Definition: epg.h:71
void SetFramesPerSecond(double FramesPerSecond)
Definition: recording.c:430
int Priority(void) const
Definition: recording.h:114
int Position(void) const
Definition: recording.h:220
bool 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:1369
int TotalFileSizeMB(void)
Definition: recording.c:1435
tIndexTs * index
Definition: recording.h:297
int NumFrames(void) const
Returns the number of frames in this recording.
Definition: recording.c:1214
void Refresh(bool Foreground=false)
Definition: recording.c:1276
static char * StripEpisodeName(char *s, bool Strip)
Definition: recording.c:929
bool DirectoryEncoding
Definition: recording.c:72
#define DEFAULTFRAMESPERSECOND
Definition: recording.h:209
time_t Start(void) const
Definition: recording.h:113
cRecordingInfo * info
Definition: recording.h:98
cEvent * ownEvent
Definition: recording.h:54
char * fileName
Definition: recording.h:59
char * sortBufferName
Definition: recording.h:87
bool Load(void)
Loads the current list of recordings and returns true if there is anything in it (for compatibility w...
Definition: recording.h:175
cMark * GetPrev(int Position)
Definition: recording.c:1617
const cRecordingInfo * Info(void) const
Definition: recording.h:121
void ResetResume(const char *ResumeFileName=NULL)
Definition: recording.c:1467
const cEvent * event
Definition: recording.h:53
bool CatchUp(int Index=-1)
Definition: recording.c:1994
cResumeFile(const char *FileName, bool IsPesRecording)
Definition: recording.c:231
bool Save(FILE *f)
Definition: recording.c:1519
void ChangeState(void)
Definition: recording.h:190
bool isPesRecording
Definition: recording.h:298
const char * ShortText(void) const
Definition: recording.h:71
bool IsEdited(void) const
Definition: recording.c:1104
int HMSFToIndex(const char *HMSF, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition: recording.c:2407
char * name
Definition: recording.h:90
void Sort(void)
Definition: recording.c:1590
static void InvokeCommand(const char *State, const char *RecordingFileName, const char *SourceFileName=NULL)
Definition: recording.c:1690
double FramesPerSecond(void) const
Definition: recording.h:125
cMark * GetNextBegin(cMark *EndMark=NULL)
Returns the next "begin" mark after EndMark, skipping any marks at the same position as EndMark...
Definition: recording.c:1635
cUnbufferedFile * SetOffset(int Number, off_t Offset=0)
Definition: recording.c:2342
const char * Title(char Delimiter= ' ', bool NewIndicator=false, int Level=-1) const
Definition: recording.c:1021
time_t deleted
Definition: recording.h:108
int GetNextIFrame(int Index, bool Forward, uint16_t *FileNumber=NULL, off_t *FileOffset=NULL, int *Length=NULL)
Definition: recording.c:2093
void Align(void)
Definition: recording.c:1578
bool IsOnVideoDirectoryFileSystem(void) const
Definition: recording.c:1111
cMutex mutex
Definition: recording.h:301
int fileSizeMB
Definition: recording.h:91
cUnbufferedFile * NextFile(void)
Definition: recording.c:2384
Definition: tools.h:479
bool Ok(void)
Definition: recording.h:308
tChannelID channelID
Definition: recording.h:51
const cComponents * Components(void) const
Definition: recording.h:73
cString IndexToHMSF(int Index, bool WithFrame=false, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition: recording.c:2391
virtual ~cMark()
Definition: recording.c:1496
double FramesPerSecond(void) const
Definition: recording.h:75
void ResetResume(void) const
Definition: recording.c:1209
cRecording(const cRecording &)
bool IsNew(void) const
Definition: recording.h:134
int Last(void)
Returns the index of the last entry in this file, or -1 if the file is empty.
Definition: recording.h:318
time_t start
Definition: recording.h:105
void SetPosition(int Position)
Definition: recording.h:222
void SetAux(const char *Aux)
Definition: recording.c:424
eRecordingsSortMode
Definition: recording.h:367
cUnbufferedFile is used for large files that are mainly written or read in a streaming manner...
Definition: tools.h:408
static cString IndexFileName(const char *FileName, bool IsPesRecording)
Definition: recording.c:1964
bool GetLastPatPmtVersions(int &PatVersion, int &PmtVersion)
Definition: recording.c:2258
static void SetCommand(const char *Command)
Definition: recording.h:272
uint16_t Number(void)
Definition: recording.h:342
static const char * command
Definition: recording.h:270
bool HasRecordingsSortMode(const char *Directory)
Definition: recording.c:2443
Definition: timers.h:27
void IncRecordingsSortMode(const char *Directory)
Definition: recording.c:2466
bool Save(int Index)
Definition: recording.c:294
eRecordingsSortMode RecordingsSortMode
Definition: recording.c:2441
bool isPesRecording
Definition: recording.h:39
char * SortName(void) const
Definition: recording.c:958
cMark * GetNextEnd(cMark *BeginMark)
Returns the next "end" mark after BeginMark, skipping any marks at the same position as BeginMark...
Definition: recording.c:1651
int priority
Definition: recording.h:106
double framesPerSecond
Definition: recording.h:97
cMark(int Position=0, const char *Comment=NULL, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition: recording.c:1489
double framesPerSecond
Definition: recording.h:56
cRecording & operator=(const cRecording &)
cRecording * GetByName(const char *FileName)
Definition: recording.c:1380
cIndexFile(const char *FileName, bool Record, bool IsPesRecording=false, bool PauseLive=false)
Definition: recording.c:1872
cMark * GetNext(int Position)
Definition: recording.c:1626
void ReadInfo(void)
Definition: recording.c:1118
const char * Comment(void) const
Definition: recording.h:221
bool isPesRecording
Definition: recording.h:234
char * aux
Definition: recording.h:55
void RemoveDeletedRecordings(void)
Definition: recording.c:123
time_t lastChange
Definition: recording.h:237
bool deleted
Definition: recording.h:163
virtual ~cRecording()
Definition: recording.c:919
char * ExchangeChars(char *s, bool ToFileSystem)
Definition: recording.c:566
char * sortBufferTime
Definition: recording.h:88
bool record
Definition: recording.h:335
bool isPesRecording
Definition: recording.h:95
time_t Deleted(void) const
Definition: recording.h:116
void SetData(const char *Title, const char *ShortText, const char *Description)
Definition: recording.c:414
int GetResume(void) const
Definition: recording.c:988
int LengthInSeconds(void) const
Returns the length (in seconds) of this recording, or -1 in case of error.
Definition: recording.c:1225
bool blocking
Definition: recording.h:336
int instanceId
Definition: recording.h:94
bool GenerateIndex(const char *FileName)
Definition: recording.c:2199
void UpdateByName(const char *FileName)
Definition: recording.c:1427
char * channelName
Definition: recording.h:52
int position
Definition: recording.h:215
int lifetime
Definition: recording.h:107
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:140
void SetStartTime(time_t Start)
Sets the start time of this recording to the given value.
Definition: recording.c:1139
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:1233
int InstanceId
Definition: recording.c:73
bool Delete(void)
Changes the file name so that it will no longer be visible in the "Recordings" menu Returns false in ...
Definition: recording.c:1146
tChannelID ChannelID(void) const
Definition: recording.h:67
void ConvertToPes(tIndexTs *IndexTs, int Count)
Definition: recording.c:1981
cUnbufferedFile * Open(void)
Definition: recording.c:2309
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:2190
int Lifetime(void) const
Definition: recording.h:115
int isOnVideoDirectoryFileSystem
Definition: recording.h:96
void ConvertFromPes(tIndexTs *IndexTs, int Count)
Definition: recording.c:1969
char * pFileNumber
Definition: recording.h:334
int GetClosestIFrame(int Index)
Returns the index of the I-frame that is closest to the given Index (or Index itself, if it already points to an I-frame).
Definition: recording.c:2131
bool Write(void) const
Definition: recording.c:525
char * fileName
Definition: recording.h:334
static char * updateFileName
Definition: recording.h:162
Definition: thread.h:63
bool Read(void)
Definition: recording.c:507
int HierarchyLevels(void) const
Definition: recording.c:1093
void Action(void)
A derived cThread class must implement the code it wants to execute as a separate thread in this func...
Definition: recording.c:1264
bool WriteInfo(void)
Definition: recording.c:1126
void TouchUpdate(void)
Touches the '.update' file in the video directory, so that other instances of VDR that access the sam...
Definition: recording.c:1353
int SecondsToFrames(int Seconds, double FramesPerSecond=DEFAULTFRAMESPERSECOND)
Definition: recording.c:2418
bool Parse(const char *s)
Definition: recording.c:1505
const char * UpdateFileName(void)
Definition: recording.c:1269
bool Remove(void)
Actually removes the file from the disk Returns false in case of error.
Definition: recording.c:1172
const char * Name(void)
Definition: recording.h:341
cString fileName
Definition: recording.h:232
cRecordings DeletedRecordings
bool StoreResume(int Index)
Definition: recording.h:321
cIndexFileGenerator * indexFileGenerator
Definition: recording.h:300
cString comment
Definition: recording.h:216
cRecordings(bool Deleted=false)
Definition: recording.c:1250
void GetRecordingsSortMode(const char *Directory)
Definition: recording.c:2448
int ReadFrame(cUnbufferedFile *f, uchar *b, int Length, int Max)
Definition: recording.c:2425
char * titleBuffer
Definition: recording.h:86
int GetNumSequences(void)
Returns the actual number of sequences to be cut from the recording.
Definition: recording.c:1669
void SetRecordingsSortMode(const char *Directory, eRecordingsSortMode SortMode)
Definition: recording.c:2458
int channel
Definition: recording.h:93
void ScanVideoDir(const char *DirName, bool Foreground=false, int LinkLevel=0, int DirLevel=0)
Definition: recording.c:1286
cMark * Get(int Position)
Definition: recording.c:1608
cFileName(const char *FileName, bool Record, bool Blocking=false, bool IsPesRecording=false)
Definition: recording.c:2234
int GetResume(void)
Definition: recording.h:320
cString fileName
Definition: recording.h:295
void Delete(void)
Definition: recording.c:2178
time_t lastFileTime
Definition: recording.h:236
bool NeedsUpdate(void)
Definition: recording.c:1361
void Close(void)
Definition: recording.c:2333
void Delete(void)
Definition: recording.c:322
void ClearSortName(void)
Definition: recording.c:982
double MBperMinute(void)
Returns the average data rate (in MB/min) of all recordings, or -1 if this value is unknown...
Definition: recording.c:1447
void Add(int Position)
Definition: recording.c:1602
const cEvent * GetEvent(void) const
Definition: recording.h:69
const char * Description(void) const
Definition: recording.h:72
const char * Name(void) const
Definition: recording.h:118
double framesPerSecond
Definition: recording.h:233
void ClearVanishedRecordings(void)
Definition: recording.c:223
cResumeFile resumeFile
Definition: recording.h:299
Definition: thread.h:77
void DelByName(const char *FileName)
Definition: recording.c:1405
char * fileName
Definition: recording.h:38
const char * Title(void) const
Definition: recording.h:70
bool Update(void)
Definition: recording.c:1538
void ClearSortNames(void)
Definition: recording.c:1477
bool StateChanged(int &State)
Definition: recording.c:1345
int Read(void)
Definition: recording.c:249
int resume
Definition: recording.h:85
bool Load(const char *RecordingFileName, double FramesPerSecond=DEFAULTFRAMESPERSECOND, bool IsPesRecording=false)
Definition: recording.c:1526
cRecordingInfo(const cChannel *Channel=NULL, const cEvent *Event=NULL)
Definition: recording.c:334
time_t nextUpdate
Definition: recording.h:235
bool Get(int Index, uint16_t *FileNumber, off_t *FileOffset, bool *Independent=NULL, int *Length=NULL)
Definition: recording.c:2067
const char * ChannelName(void) const
Definition: recording.h:68
bool IsStillRecording(void)
Definition: recording.c:2173
void SetComment(const char *Comment)
Definition: recording.h:223
const char * Aux(void) const
Definition: recording.h:74
bool isPesRecording
Definition: recording.h:337
uint16_t fileNumber
Definition: recording.h:333
cString recordingFileName
Definition: recording.h:231
char * fileName
Definition: recording.h:89
cRecordings Recordings
Any access to Recordings that loops through the list of recordings needs to hold a thread lock on thi...
Definition: recording.c:1246
int DirectoryPathMax
Definition: recording.c:70
const char * FileName(void) const
Definition: recording.c:1003
time_t lastUpdate
Definition: recording.h:165
virtual int Compare(const cListObject &ListObject) const
Must return 0 if this object is equal to ListObject, a positive value if it is "greater", and a negative value if it is "smaller".
Definition: recording.c:997
const char * PrefixFileName(char Prefix)
Definition: recording.c:1082
bool Save(void)
Definition: recording.c:1569
cUnbufferedFile * file
Definition: recording.h:332
int numFrames
Definition: recording.h:92
void AddByName(const char *FileName, bool TriggerUpdate=true)
Definition: recording.c:1392
bool IsPesRecording(void) const
Definition: recording.h:136
virtual ~cRecordings()
Definition: recording.c:1259
bool Write(bool Independent, uint16_t FileNumber, off_t FileOffset)
Definition: recording.c:2050
int DirectoryNameMax
Definition: recording.c:71
double framesPerSecond
Definition: recording.h:214
bool Undelete(void)
Changes the file name so that it will be visible in the "Recordings" menu again and not processed by ...
Definition: recording.c:1183
Definition: tools.h:166
cString ToText(void)
Definition: recording.c:1500