diff --git a/tvdbseries.c b/tvdbseries.c index 4fc2192..663e622 100644 --- a/tvdbseries.c +++ b/tvdbseries.c @@ -108,6 +108,7 @@ void cTVDBSeries::InsertMedia(int mediaType, int imgWidth, int imgHeight, string case msBanner2: case msBanner3: banners.push_back(media); + break; case msSeasonPoster: seasonPosters.insert(pair(season, media)); break; diff --git a/update.c b/update.c index 8394678..a023181 100644 --- a/update.c +++ b/update.c @@ -30,6 +30,7 @@ cUpdate::cUpdate(cScrapManager *manager) : cThread("update thread started", true selectReadScrapedEventsInit = 0; selectReadScrapedEvents = 0; selectImg = 0; + selectEpisodeImg = 0; selectSeasonPoster = 0; selectActors = 0; selectActorThumbs = 0; @@ -184,9 +185,24 @@ int cUpdate::initDb() { selectImg->build(")"); selectImg->build(" from %s where ", tSeriesMedia->TableName()); selectImg->bind(cTableSeriesMedia::fiSeriesId, cDBS::bndIn | cDBS::bndSet); - selectImg->bind(cTableSeriesMedia::fiEpisodeId, cDBS::bndIn | cDBS::bndSet, " and "); status += selectImg->prepare(); + // select episode image + + imageSize.setField(&imageSizeDef); + selectEpisodeImg = new cDbStatement(tSeriesMedia); + selectEpisodeImg->build("select "); + selectEpisodeImg->bind(cTableSeriesMedia::fiMediaWidth, cDBS::bndOut); + selectEpisodeImg->bind(cTableSeriesMedia::fiMediaHeight, cDBS::bndOut, ", "); + selectEpisodeImg->bind(cTableSeriesMedia::fiMediaContent, cDBS::bndOut, ", "); + selectEpisodeImg->build(", length("); + selectEpisodeImg->bind(&imageSize, cDBS::bndOut); + selectEpisodeImg->build(")"); + selectEpisodeImg->build(" from %s where ", tSeriesMedia->TableName()); + selectEpisodeImg->bind(cTableSeriesMedia::fiSeriesId, cDBS::bndIn | cDBS::bndSet); + selectEpisodeImg->bind(cTableSeriesMedia::fiEpisodeId, cDBS::bndIn | cDBS::bndSet, " and "); + status += selectEpisodeImg->prepare(); + // select poster image posterSize.setField(&imageSizeDef); @@ -360,6 +376,7 @@ int cUpdate::exitDb() { delete selectReadScrapedEvents; selectReadScrapedEvents = 0; delete selectReadScrapedEventsInit; selectReadScrapedEventsInit = 0; delete selectImg; selectImg = 0; + delete selectEpisodeImg; selectEpisodeImg = 0; delete selectSeasonPoster; selectSeasonPoster = 0; delete selectActors; selectActors = 0; delete selectActorThumbs; selectActorThumbs = 0; @@ -537,7 +554,7 @@ void cUpdate::LoadEpisodeImage(cTVDBSeries *series, int episodeId, string path) tSeriesMedia->setValue(cTableSeriesMedia::fiSeriesId, series->id); tSeriesMedia->setValue(cTableSeriesMedia::fiEpisodeId, episodeId); - int res = selectImg->find(); + int res = selectEpisodeImg->find(); if (res) { if (!imgExists) { @@ -552,7 +569,7 @@ void cUpdate::LoadEpisodeImage(cTVDBSeries *series, int episodeId, string path) series->InsertEpisodeImage(episodeId, imgWidth, imgHeight, imgPath); } - selectImg->freeResult(); + selectEpisodeImg->freeResult(); } void cUpdate::LoadSeasonPoster(cTVDBSeries *series, int season, string path) { @@ -708,7 +725,6 @@ string cUpdate::LoadMediaSeries(int seriesId, int mediaType, string path, int wi tSeriesMedia->clear(); tSeriesMedia->setValue(cTableSeriesMedia::fiSeriesId, seriesId); tSeriesMedia->setValue(cTableSeriesMedia::fiMediaType, mediaType); - int res = selectImg->find(); if (res) { int size = imageSize.getIntValue(); diff --git a/update.h b/update.h index 484dc3c..55d6b19 100644 --- a/update.h +++ b/update.h @@ -76,6 +76,7 @@ class cUpdate : public cThread { cDbStatement* selectReadScrapedEventsInit; cDbStatement* selectReadScrapedEvents; cDbStatement* selectImg; + cDbStatement* selectEpisodeImg; cDbStatement* selectSeasonPoster; cDbStatement* selectActors; cDbStatement* selectActorThumbs;