Refactor reruns

This commit is contained in:
kamel5 2020-07-13 11:49:21 +02:00
parent f156e44599
commit 6f14ddae8a
9 changed files with 77 additions and 68 deletions

View File

@ -16,6 +16,7 @@ cDesignerConfig::cDesignerConfig() {
debugImageLoading = 0; debugImageLoading = 0;
replaceDecPoint = false; replaceDecPoint = false;
//settings for rerun display //settings for rerun display
useSubtitleRerun = 0;
rerunAmount = 10; rerunAmount = 10;
rerunDistance = 2; rerunDistance = 2;
rerunMaxChannel = 0; rerunMaxChannel = 0;
@ -510,6 +511,7 @@ bool cDesignerConfig::SetupParse(const char *Name, const char *Value) {
else if (!strcasecmp(Name, "LimitChannelLogoCache")) limitLogoCache = atoi(Value); else if (!strcasecmp(Name, "LimitChannelLogoCache")) limitLogoCache = atoi(Value);
else if (!strcasecmp(Name, "NumberLogosInitially")) numLogosPerSizeInitial = atoi(Value); else if (!strcasecmp(Name, "NumberLogosInitially")) numLogosPerSizeInitial = atoi(Value);
else if (!strcasecmp(Name, "NumberLogosMax")) numLogosMax = atoi(Value); else if (!strcasecmp(Name, "NumberLogosMax")) numLogosMax = atoi(Value);
else if (!strcasecmp(Name, "UseSubtitleRerun")) useSubtitleRerun = atoi(Value);
else if (!strcasecmp(Name, "RerunAmount")) rerunAmount = atoi(Value); else if (!strcasecmp(Name, "RerunAmount")) rerunAmount = atoi(Value);
else if (!strcasecmp(Name, "RerunDistance")) rerunDistance = atoi(Value); else if (!strcasecmp(Name, "RerunDistance")) rerunDistance = atoi(Value);
else if (!strcasecmp(Name, "RerunMaxChannel")) rerunMaxChannel = atoi(Value); else if (!strcasecmp(Name, "RerunMaxChannel")) rerunMaxChannel = atoi(Value);

View File

@ -110,6 +110,7 @@ public:
int limitLogoCache; int limitLogoCache;
int numLogosMax; int numLogosMax;
int debugImageLoading; int debugImageLoading;
int useSubtitleRerun;
int rerunAmount; int rerunAmount;
int rerunDistance; int rerunDistance;
int rerunMaxChannel; int rerunMaxChannel;

View File

@ -353,13 +353,15 @@ bool cViewDetailEpg::Parse(bool forced) {
tokenContainer->AddIntToken((int)eDmDetailedEpgIT::year, sStartTime->tm_year + 1900); tokenContainer->AddIntToken((int)eDmDetailedEpgIT::year, sStartTime->tm_year + 1900);
tokenContainer->AddIntToken((int)eDmDetailedEpgIT::daynumeric, sStartTime->tm_mday); tokenContainer->AddIntToken((int)eDmDetailedEpgIT::daynumeric, sStartTime->tm_mday);
tokenContainer->AddIntToken((int)eDmDetailedEpgIT::month, sStartTime->tm_mon+1); tokenContainer->AddIntToken((int)eDmDetailedEpgIT::month, sStartTime->tm_mon+1);
const cChannel* channel = NULL;
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301) #if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
{
LOCK_CHANNELS_READ; LOCK_CHANNELS_READ;
const cChannels* channels = Channels; channel = Channels->GetByChannelID(event->ChannelID());
}
#else #else
cChannels* channels = &Channels; channel = Channels.GetByChannelID(event->ChannelID());
#endif #endif
const cChannel *channel = channels->GetByChannelID(event->ChannelID());
if (channel) { if (channel) {
tokenContainer->AddStringToken((int)eDmDetailedEpgST::channelname, channel->Name()); tokenContainer->AddStringToken((int)eDmDetailedEpgST::channelname, channel->Name());
tokenContainer->AddIntToken((int)eDmDetailedEpgIT::channelnumber, channel->Number()); tokenContainer->AddIntToken((int)eDmDetailedEpgIT::channelnumber, channel->Number());
@ -385,7 +387,10 @@ bool cViewDetailEpg::Parse(bool forced) {
tokenContainer->AddStringToken((int)eDmDetailedEpgST::vps, *event->GetVpsString()); tokenContainer->AddStringToken((int)eDmDetailedEpgST::vps, *event->GetVpsString());
cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns = LoadReruns(); cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns = LoadReruns();
int numReruns = NumReruns(reruns); int numReruns = 0;
if (reruns && reruns->Count() > 0)
numReruns = reruns->Count();
vector<int> loopInfo; vector<int> loopInfo;
//num reruns //num reruns
loopInfo.push_back(numReruns); loopInfo.push_back(numReruns);
@ -395,7 +400,7 @@ bool cViewDetailEpg::Parse(bool forced) {
loopInfo.push_back(numActors); loopInfo.push_back(numActors);
tokenContainer->CreateLoopTokenContainer(&loopInfo); tokenContainer->CreateLoopTokenContainer(&loopInfo);
if (numReruns > 0) { if (numReruns > 0) {
tokenContainer->AddIntToken((int)eDmDetailedEpgIT::hasreruns, 1); tokenContainer->AddIntToken((int)eDmDetailedEpgIT::hasreruns, numReruns);
SetReruns(reruns); SetReruns(reruns);
} }
if (scrapInfoAvailable) { if (scrapInfoAvailable) {
@ -411,42 +416,43 @@ cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *cViewDetailEpg::LoadR
if (!epgSearchPlugin) if (!epgSearchPlugin)
return NULL; return NULL;
if (isempty(event->Title())) if (!event || isempty(event->Title()))
return NULL; return NULL;
Epgsearch_searchresults_v1_0 data; Epgsearch_searchresults_v1_0 data;
data.query = (char*)event->Title(); std::string strQuery = event->Title();
if (config.useSubtitleRerun && !isempty(event->ShortText())) {
strQuery += "~";
strQuery += event->ShortText();
}
data.query = (char *)strQuery.c_str();
data.mode = 0; data.mode = 0;
data.channelNr = 0; data.channelNr = 0;
data.useTitle = true; data.useTitle = true;
data.useSubTitle = true; data.useSubTitle = true;
data.useDescription = false; data.useDescription = false;
cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *result = NULL;
if (epgSearchPlugin->Service("Epgsearch-searchresults-v1.0", &data))
result = data.pResultList;
return result;
}
int cViewDetailEpg::NumReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns) {
if (!reruns || reruns->Count() < 2)
return 0;
int maxNumReruns = config.rerunAmount; int maxNumReruns = config.rerunAmount;
int rerunDistance = config.rerunDistance * 3600; int rerunDistance = config.rerunDistance * 3600;
int rerunMaxChannel = config.rerunMaxChannel; int rerunMaxChannel = config.rerunMaxChannel;
int i = 0; int i = 0;
for (Epgsearch_searchresults_v1_0::cServiceSearchResult *r = reruns->First(); r && i < maxNumReruns; r = reruns->Next(r)) {
cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns = NULL;
if (epgSearchPlugin->Service("Epgsearch-searchresults-v1.0", &data)) {
cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *result = data.pResultList;
if (result) {
for (Epgsearch_searchresults_v1_0::cServiceSearchResult *r = result->First(); r && i < maxNumReruns; r = result->Next(r)) {
time_t eventStart = event->StartTime(); time_t eventStart = event->StartTime();
time_t rerunStart = r->event->StartTime(); time_t rerunStart = r->event->StartTime();
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301) #if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
LOCK_CHANNELS_READ; LOCK_CHANNELS_READ;
const cChannels* channels = Channels; const cChannel *channel = Channels->GetByChannelID(r->event->ChannelID(), true, true);
#else #else
cChannels* channels = &Channels; const cChannel *channel = Channels.GetByChannelID(r->event->ChannelID(), true, true);
#endif #endif
const cChannel *channel = channels->GetByChannelID(r->event->ChannelID(), true, true);
//check for identical event //check for identical event
if ((event->ChannelID() == r->event->ChannelID()) && (eventStart == rerunStart)) if ((event->ChannelID() == r->event->ChannelID()) && (eventStart == rerunStart))
continue; continue;
@ -458,41 +464,27 @@ int cViewDetailEpg::NumReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearch
if (rerunMaxChannel > 0) if (rerunMaxChannel > 0)
if (channel && channel->Number() > rerunMaxChannel) if (channel && channel->Number() > rerunMaxChannel)
continue; continue;
if (!reruns) reruns = new cList<Epgsearch_searchresults_v1_0::cServiceSearchResult>;
reruns->Add(r);
i++; i++;
} }
return i; }
}
return reruns;
} }
void cViewDetailEpg::SetReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns) { void cViewDetailEpg::SetReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns) {
if (!reruns || reruns->Count() < 2) if (!reruns || reruns->Count() < 1)
return; return;
int maxNumReruns = config.rerunAmount;
int rerunDistance = config.rerunDistance * 3600;
int rerunMaxChannel = config.rerunMaxChannel;
int i = 0; int i = 0;
for (Epgsearch_searchresults_v1_0::cServiceSearchResult *r = reruns->First(); r && i < maxNumReruns; r = reruns->Next(r)) { for (Epgsearch_searchresults_v1_0::cServiceSearchResult *r = reruns->First(); r; r = reruns->Next(r)) {
time_t eventStart = event->StartTime();
time_t rerunStart = r->event->StartTime();
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301) #if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
LOCK_CHANNELS_READ; LOCK_CHANNELS_READ;
const cChannels* channels = Channels; const cChannel *channel = Channels->GetByChannelID(r->event->ChannelID(), true, true);
#else #else
cChannels* channels = &Channels; const cChannel *channel = Channels.GetByChannelID(r->event->ChannelID(), true, true);
#endif #endif
const cChannel *channel = channels->GetByChannelID(r->event->ChannelID(), true, true);
//check for identical event
if ((event->ChannelID() == r->event->ChannelID()) && (eventStart == rerunStart))
continue;
//check for timely distance
if (rerunDistance > 0)
if (rerunStart - eventStart < rerunDistance)
continue;
//check for maxchannel
if (rerunMaxChannel > 0)
if (channel && channel->Number() > rerunMaxChannel)
continue;
tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::title, r->event->Title()); tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::title, r->event->Title());
tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::shorttext, r->event->ShortText()); tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::shorttext, r->event->ShortText());
tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::start, *(r->event->GetTimeString())); tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::start, *(r->event->GetTimeString()));
@ -511,6 +503,8 @@ void cViewDetailEpg::SetReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearc
tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::channelname, ""); tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::channelname, "");
tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::channelnumber, ""); tokenContainer->AddLoopToken(rerunsIndex, i, (int)eRerunsLT::channelnumber, "");
} }
if (r == reruns->Last())
break;
i++; i++;
} }
} }
@ -812,11 +806,10 @@ void cViewDetailRec::SetRecInfos(void) {
if (info) { if (info) {
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301) #if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
LOCK_CHANNELS_READ; LOCK_CHANNELS_READ;
const cChannels* channels = Channels; const cChannel *channel = Channels->GetByChannelID(info->ChannelID());
#else #else
cChannels* channels = &Channels; const cChannel *channel = Channels.GetByChannelID(info->ChannelID());
#endif #endif
const cChannel *channel = channels->GetByChannelID(info->ChannelID());
if (channel) { if (channel) {
tokenContainer->AddStringToken((int)eDmDetailedRecST::recchannelname, channel->Name()); tokenContainer->AddStringToken((int)eDmDetailedRecST::recchannelname, channel->Name());
tokenContainer->AddStringToken((int)eDmDetailedRecST::recchannelid, *channel->GetChannelID().ToString()); tokenContainer->AddStringToken((int)eDmDetailedRecST::recchannelid, *channel->GetChannelID().ToString());

View File

@ -44,7 +44,6 @@ protected:
int rerunsIndex; int rerunsIndex;
int actorsIndex; int actorsIndex;
cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *LoadReruns(void); cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *LoadReruns(void);
int NumReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns);
void SetReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns); void SetReruns(cList<Epgsearch_searchresults_v1_0::cServiceSearchResult> *reruns);
void SetEpgPictures(int eventId); void SetEpgPictures(int eventId);
public: public:

View File

@ -6,7 +6,7 @@ msgid ""
msgstr "" msgstr ""
"Project-Id-Version: vdr-skindesigner 0.0.1\n" "Project-Id-Version: vdr-skindesigner 0.0.1\n"
"Report-Msgid-Bugs-To: <see README>\n" "Report-Msgid-Bugs-To: <see README>\n"
"POT-Creation-Date: 2016-07-03 07:31+0200\n" "POT-Creation-Date: 2020-07-15 13:04+0200\n"
"PO-Revision-Date: 2014-09-27 11:02+0200\n" "PO-Revision-Date: 2014-09-27 11:02+0200\n"
"Last-Translator: Louis Braun <louis.braun@gmx.de>\n" "Last-Translator: Louis Braun <louis.braun@gmx.de>\n"
"Language-Team: \n" "Language-Team: \n"
@ -96,6 +96,9 @@ msgstr "Maximale Anzahl Custom Tokens"
msgid "Reruns" msgid "Reruns"
msgstr "Wiederholungen" msgstr "Wiederholungen"
msgid "Use Subtitle for reruns"
msgstr "Untertitel vergleichen"
msgid "Maximum number of reruns to display" msgid "Maximum number of reruns to display"
msgstr "Anzahl anzuzeigender Wiederholungen" msgstr "Anzahl anzuzeigender Wiederholungen"

View File

@ -6,7 +6,7 @@ msgid ""
msgstr "" msgstr ""
"Project-Id-Version: vdr-skindesigner 0.2.0\n" "Project-Id-Version: vdr-skindesigner 0.2.0\n"
"Report-Msgid-Bugs-To: <see README>\n" "Report-Msgid-Bugs-To: <see README>\n"
"POT-Creation-Date: 2016-07-03 07:31+0200\n" "POT-Creation-Date: 2020-07-15 13:04+0200\n"
"PO-Revision-Date: 2015-01-25 01:25+0200\n" "PO-Revision-Date: 2015-01-25 01:25+0200\n"
"Last-Translator: Rolf Ahrenberg\n" "Last-Translator: Rolf Ahrenberg\n"
"Language-Team: Finnish\n" "Language-Team: Finnish\n"
@ -96,6 +96,9 @@ msgstr "Mukautettujen tokenien maksimimäärä"
msgid "Reruns" msgid "Reruns"
msgstr "Uusinnat" msgstr "Uusinnat"
msgid "Use Subtitle for reruns"
msgstr ""
msgid "Maximum number of reruns to display" msgid "Maximum number of reruns to display"
msgstr "Näytettävien uusintojen maksimimäärä" msgstr "Näytettävien uusintojen maksimimäärä"

View File

@ -6,7 +6,7 @@ msgid ""
msgstr "" msgstr ""
"Project-Id-Version: vdr-skindesigner 0.0.1\n" "Project-Id-Version: vdr-skindesigner 0.0.1\n"
"Report-Msgid-Bugs-To: <see README>\n" "Report-Msgid-Bugs-To: <see README>\n"
"POT-Creation-Date: 2016-07-03 07:31+0200\n" "POT-Creation-Date: 2020-07-15 13:04+0200\n"
"PO-Revision-Date: 2015-08-09 11:02+0200\n" "PO-Revision-Date: 2015-08-09 11:02+0200\n"
"Last-Translator: fiveten_59\n" "Last-Translator: fiveten_59\n"
"Language-Team: Italian\n" "Language-Team: Italian\n"
@ -96,6 +96,9 @@ msgstr "Numero massimo di token personalizzati"
msgid "Reruns" msgid "Reruns"
msgstr "Riavvii" msgstr "Riavvii"
msgid "Use Subtitle for reruns"
msgstr ""
msgid "Maximum number of reruns to display" msgid "Maximum number of reruns to display"
msgstr "NUmero massimo di riavvii da visualizzare" msgstr "NUmero massimo di riavvii da visualizzare"

View File

@ -128,6 +128,7 @@ cSkinDesignerSetup::cSkinDesignerSetup(skindesignerapi::cPluginStructure *skinPr
limitLogoCache = config.limitLogoCache; limitLogoCache = config.limitLogoCache;
numLogosMax = config.numLogosMax; numLogosMax = config.numLogosMax;
debugImageLoading = config.debugImageLoading; debugImageLoading = config.debugImageLoading;
useSubtitleRerun = config.useSubtitleRerun;
rerunAmount = config.rerunAmount; rerunAmount = config.rerunAmount;
rerunDistance = config.rerunDistance; rerunDistance = config.rerunDistance;
rerunMaxChannel = config.rerunMaxChannel; rerunMaxChannel = config.rerunMaxChannel;
@ -269,6 +270,7 @@ void cSkinDesignerSetup::Store(void) {
config.limitLogoCache = limitLogoCache; config.limitLogoCache = limitLogoCache;
config.numLogosMax = numLogosMax; config.numLogosMax = numLogosMax;
config.debugImageLoading = debugImageLoading; config.debugImageLoading = debugImageLoading;
config.useSubtitleRerun = useSubtitleRerun;
config.rerunAmount = rerunAmount; config.rerunAmount = rerunAmount;
config.rerunDistance = rerunDistance; config.rerunDistance = rerunDistance;
config.rerunMaxChannel = rerunMaxChannel; config.rerunMaxChannel = rerunMaxChannel;
@ -294,6 +296,7 @@ void cSkinDesignerSetup::Store(void) {
SetupStore("LimitChannelLogoCache", limitLogoCache); SetupStore("LimitChannelLogoCache", limitLogoCache);
SetupStore("NumberLogosInitially", numLogosPerSizeInitial); SetupStore("NumberLogosInitially", numLogosPerSizeInitial);
SetupStore("NumberLogosMax", numLogosMax); SetupStore("NumberLogosMax", numLogosMax);
SetupStore("UseSubtitleRerun", useSubtitleRerun);
SetupStore("RerunAmount", rerunAmount); SetupStore("RerunAmount", rerunAmount);
SetupStore("RerunDistance", rerunDistance); SetupStore("RerunDistance", rerunDistance);
SetupStore("RerunMaxChannel", rerunMaxChannel); SetupStore("RerunMaxChannel", rerunMaxChannel);
@ -315,6 +318,7 @@ void cSkinDesignerSetup::PluginSetup(void) {
Add(new cMenuEditIntItem(tr("Maximum number of custom tokens"), &numCustomTokens, 0, 100)); Add(new cMenuEditIntItem(tr("Maximum number of custom tokens"), &numCustomTokens, 0, 100));
Add(InfoItem(tr("Reruns"))); Add(InfoItem(tr("Reruns")));
Add(new cMenuEditBoolItem(tr("Use Subtitle for reruns"), &useSubtitleRerun));
Add(new cMenuEditIntItem(tr("Maximum number of reruns to display"), &rerunAmount, 1, 100)); Add(new cMenuEditIntItem(tr("Maximum number of reruns to display"), &rerunAmount, 1, 100));
Add(new cMenuEditIntItem(tr("Minimum timely distance of rerun (in hours)"), &rerunDistance, 0, 1000)); Add(new cMenuEditIntItem(tr("Minimum timely distance of rerun (in hours)"), &rerunDistance, 0, 1000));
Add(new cMenuEditIntItem(tr("Limit Channel Numbers"), &rerunMaxChannel, 0, 1000, tr("no limit"))); Add(new cMenuEditIntItem(tr("Limit Channel Numbers"), &rerunMaxChannel, 0, 1000, tr("no limit")));

View File

@ -45,6 +45,7 @@ private:
int limitLogoCache; int limitLogoCache;
int numLogosMax; int numLogosMax;
int debugImageLoading; int debugImageLoading;
int useSubtitleRerun;
int rerunAmount; int rerunAmount;
int rerunDistance; int rerunDistance;
int rerunMaxChannel; int rerunMaxChannel;