mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-05 17:43:37 +00:00
Fixed issues with added new shows not showing any episodes.
Fixed issues with duplicate downloads of the same season/episode caused by multithreading.
This commit is contained in:
parent
fc94243546
commit
9084d7de19
3 changed files with 33 additions and 10 deletions
|
@ -111,6 +111,11 @@ def snatchEpisode(result, endStatus=SNATCHED):
|
|||
|
||||
if result is None: return False
|
||||
|
||||
# don't notify when we re-download an episode
|
||||
for curEpObj in result.episodes:
|
||||
if curEpObj.status in Quality.SNATCHED + Quality.SNATCHED_PROPER + Quality.SNATCHED_BEST:
|
||||
return 2
|
||||
|
||||
result.priority = 0 # -1 = low, 0 = normal, 1 = high
|
||||
if sickbeard.ALLOW_HIGH_PRIORITY:
|
||||
# if it aired recently make it high priority
|
||||
|
|
|
@ -126,11 +126,12 @@ class ManualSearchQueueItem(generic_queue.QueueItem):
|
|||
for foundResult in [item for sublist in foundResults for item in sublist]:
|
||||
time.sleep(0.01)
|
||||
|
||||
# just use the first result for now
|
||||
logger.log(u"Downloading " + foundResult.name + " from " + foundResult.provider.name)
|
||||
|
||||
result = search.snatchEpisode(foundResult)
|
||||
|
||||
# duplicate snatch detected due to multithreading
|
||||
if result == 2:
|
||||
continue
|
||||
|
||||
providerModule = foundResult.provider
|
||||
if not result:
|
||||
ui.notifications.error(
|
||||
|
@ -138,9 +139,10 @@ class ManualSearchQueueItem(generic_queue.QueueItem):
|
|||
elif providerModule == None:
|
||||
ui.notifications.error('Provider is configured incorrectly, unable to download')
|
||||
|
||||
self.success = result
|
||||
# just use the first result for now
|
||||
logger.log(u"Downloading " + foundResult.name + " from " + foundResult.provider.name)
|
||||
|
||||
self.finish()
|
||||
self.success = result
|
||||
|
||||
def process(self, curProvider):
|
||||
if self.ep_obj.show.air_by_date:
|
||||
|
@ -154,8 +156,8 @@ class ManualSearchQueueItem(generic_queue.QueueItem):
|
|||
# don't let this linger if something goes wrong
|
||||
if self.success == None:
|
||||
self.success = False
|
||||
generic_queue.QueueItem.finish(self)
|
||||
|
||||
else:
|
||||
generic_queue.QueueItem.finish(self)
|
||||
|
||||
class RSSSearchQueueItem(generic_queue.QueueItem):
|
||||
def __init__(self):
|
||||
|
@ -186,7 +188,11 @@ class RSSSearchQueueItem(generic_queue.QueueItem):
|
|||
if len(foundResults):
|
||||
for curResult in [item for sublist in foundResults for item in sublist]:
|
||||
time.sleep(0.01)
|
||||
search.snatchEpisode(curResult)
|
||||
result = search.snatchEpisode(curResult)
|
||||
|
||||
# duplicate snatch detected due to multithreading
|
||||
if result == 2:
|
||||
continue
|
||||
else:
|
||||
logger.log(u"RSS Feed search found nothing to snatch ...")
|
||||
|
||||
|
@ -289,7 +295,12 @@ class BacklogQueueItem(generic_queue.QueueItem):
|
|||
for curResult in [item for sublist in foundResults for item in sublist]:
|
||||
time.sleep(0.01)
|
||||
|
||||
search.snatchEpisode(curResult)
|
||||
result = search.snatchEpisode(curResult)
|
||||
|
||||
# duplicate snatch detected due to multithreading
|
||||
if result == 2:
|
||||
continue
|
||||
|
||||
else:
|
||||
logger.log(u"Backlog search found nothing to snatch ...")
|
||||
|
||||
|
@ -365,7 +376,13 @@ class FailedQueueItem(generic_queue.QueueItem):
|
|||
for curResult in [item for sublist in foundResults for item in sublist]:
|
||||
time.sleep(0.01)
|
||||
|
||||
self.success = search.snatchEpisode(curResult)
|
||||
result = search.snatchEpisode(curResult)
|
||||
|
||||
# duplicate snatch detected due to multithreading
|
||||
if result == 2:
|
||||
continue
|
||||
|
||||
self.success = result
|
||||
else:
|
||||
logger.log(u"Retry failed download search found nothing to snatch ...")
|
||||
|
||||
|
|
|
@ -18,6 +18,7 @@
|
|||
|
||||
from __future__ import with_statement
|
||||
|
||||
import time
|
||||
import os.path
|
||||
import datetime
|
||||
import threading
|
||||
|
|
Loading…
Reference in a new issue