timeshift detection for remote timers

This commit is contained in:
louis 2016-06-12 11:02:28 +02:00
parent 49823486f6
commit a9cbdf00fe
3 changed files with 23 additions and 0 deletions

View File

@ -91,6 +91,12 @@ void cSDDisplayReplay::SetTimeShiftValues(const cRecording *recording) {
int usage = recording->IsInUse(); int usage = recording->IsInUse();
if (usage & ruTimer) if (usage & ruTimer)
isTimeShift = true; isTimeShift = true;
else {
cGlobalTimers globalTimers;
globalTimers.LoadTimers();
if (globalTimers.IsRecording(recording))
isTimeShift = true;
}
#endif #endif
if (!isTimeShift) if (!isTimeShift)
return; return;

View File

@ -167,6 +167,22 @@ const char* cGlobalTimers::RemoteHost(int i) {
return ""; return "";
} }
bool cGlobalTimers::IsRecording(const cRecording *rec) {
if (!rec || !rec->Name())
return false;
std::string recName = rec->Name();
int size = Size();
for (int i=0; i<size; i++) {
const cTimer *t = At(i);
const char *timerFile = t->File();
if (!t->Matches() || !timerFile)
continue;
if (recName.find(timerFile) != std::string::npos)
return true;
}
return false;
}
void cGlobalTimers::ClearTimers(void) { void cGlobalTimers::ClearTimers(void) {
if (isEpg2VdrTimers) { if (isEpg2VdrTimers) {
int size = Size(); int size = Size();

View File

@ -27,6 +27,7 @@ class cGlobalTimers : public cVector<const cTimer *> {
int NumTimerConfilicts(void); int NumTimerConfilicts(void);
bool IsRemoteTimer(int i); bool IsRemoteTimer(int i);
const char* RemoteHost(int i); const char* RemoteHost(int i);
bool IsRecording(const cRecording *rec);
void ClearTimers(void); void ClearTimers(void);
static void StartRefreshThread(void); static void StartRefreshThread(void);
static void StopRefreshThread(void); static void StopRefreshThread(void);