2017-04-02 17:02:41 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
2018-07-12 18:46:02 +02:00
|
|
|
from __future__ import absolute_import, division, unicode_literals
|
2017-04-02 17:02:41 +02:00
|
|
|
from logging import getLogger
|
|
|
|
from threading import Thread
|
|
|
|
from Queue import Empty
|
|
|
|
from xbmc import sleep
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
from .. import utils
|
|
|
|
from .. import itemtypes
|
|
|
|
from . import sync_info
|
2017-04-02 17:02:41 +02:00
|
|
|
|
|
|
|
###############################################################################
|
2018-04-17 20:18:25 +02:00
|
|
|
LOG = getLogger("PLEX." + __name__)
|
2017-04-02 17:02:41 +02:00
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
|
2018-06-21 19:24:37 +02:00
|
|
|
@utils.thread_methods(add_stops=['SUSPEND_LIBRARY_THREAD',
|
|
|
|
'STOP_SYNC',
|
|
|
|
'SUSPEND_SYNC'])
|
2018-04-17 20:18:25 +02:00
|
|
|
class ThreadedProcessMetadata(Thread):
|
2017-04-02 17:02:41 +02:00
|
|
|
"""
|
|
|
|
Not yet implemented for more than 1 thread - if ever. Only to be called by
|
|
|
|
ONE thread!
|
|
|
|
Processes the XML metadata in the queue
|
|
|
|
|
|
|
|
Input:
|
|
|
|
queue: Queue.Queue() object that you'll need to fill up with
|
|
|
|
the downloaded XML eTree objects
|
2018-04-17 20:18:25 +02:00
|
|
|
item_class: as used to call functions in itemtypes.py e.g. 'Movies' =>
|
2017-04-02 17:02:41 +02:00
|
|
|
itemtypes.Movies()
|
|
|
|
"""
|
2018-04-17 20:18:25 +02:00
|
|
|
def __init__(self, queue, item_class):
|
2017-04-02 17:02:41 +02:00
|
|
|
self.queue = queue
|
2018-04-17 20:18:25 +02:00
|
|
|
self.item_class = item_class
|
2017-04-02 17:02:41 +02:00
|
|
|
Thread.__init__(self)
|
|
|
|
|
|
|
|
def terminate_now(self):
|
|
|
|
"""
|
|
|
|
Needed to terminate this thread, because there might be items left in
|
|
|
|
the queue which could cause other threads to hang
|
|
|
|
"""
|
|
|
|
while not self.queue.empty():
|
|
|
|
# Still try because remaining item might have been taken
|
|
|
|
try:
|
|
|
|
self.queue.get(block=False)
|
|
|
|
except Empty:
|
|
|
|
sleep(10)
|
|
|
|
continue
|
|
|
|
else:
|
|
|
|
self.queue.task_done()
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
"""
|
|
|
|
Do the work
|
|
|
|
"""
|
2018-04-17 20:18:25 +02:00
|
|
|
LOG.debug('Processing thread started')
|
2017-04-02 17:02:41 +02:00
|
|
|
# Constructs the method name, e.g. itemtypes.Movies
|
2018-04-17 20:18:25 +02:00
|
|
|
item_fct = getattr(itemtypes, self.item_class)
|
2018-09-02 18:18:45 +02:00
|
|
|
# cache local variables because it's faster
|
|
|
|
queue = self.queue
|
|
|
|
stopped = self.stopped
|
2017-04-02 17:02:41 +02:00
|
|
|
with item_fct() as item_class:
|
2018-09-02 18:18:45 +02:00
|
|
|
while stopped() is False:
|
2017-04-02 17:02:41 +02:00
|
|
|
# grabs item from queue
|
|
|
|
try:
|
2018-09-02 18:18:45 +02:00
|
|
|
item = queue.get(block=False)
|
2017-04-02 17:02:41 +02:00
|
|
|
except Empty:
|
|
|
|
sleep(20)
|
|
|
|
continue
|
|
|
|
# Do the work
|
|
|
|
item_method = getattr(item_class, item['method'])
|
2018-07-10 20:28:06 +02:00
|
|
|
if item.get('children') is not None:
|
2018-04-17 20:18:25 +02:00
|
|
|
item_method(item['xml'][0],
|
|
|
|
viewtag=item['view_name'],
|
|
|
|
viewid=item['view_id'],
|
2017-04-02 17:02:41 +02:00
|
|
|
children=item['children'])
|
|
|
|
else:
|
2018-04-17 20:18:25 +02:00
|
|
|
item_method(item['xml'][0],
|
|
|
|
viewtag=item['view_name'],
|
|
|
|
viewid=item['view_id'])
|
2017-04-02 17:02:41 +02:00
|
|
|
# Keep track of where we are at
|
|
|
|
with sync_info.LOCK:
|
|
|
|
sync_info.PROCESS_METADATA_COUNT += 1
|
|
|
|
sync_info.PROCESSING_VIEW_NAME = item['title']
|
2018-09-02 18:18:45 +02:00
|
|
|
queue.task_done()
|
2017-04-02 17:02:41 +02:00
|
|
|
self.terminate_now()
|
2018-04-17 20:18:25 +02:00
|
|
|
LOG.debug('Processing thread terminated')
|