2017-04-02 17:02:41 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from logging import getLogger
|
|
|
|
from threading import Thread, Lock
|
|
|
|
|
2017-08-19 13:42:15 +02:00
|
|
|
from xbmc import sleep, Player
|
2017-08-18 10:37:30 +02:00
|
|
|
from xbmcgui import DialogProgressBG
|
2017-04-02 17:02:41 +02:00
|
|
|
|
2017-05-17 13:55:24 +02:00
|
|
|
from utils import thread_methods, language as lang
|
2017-04-02 17:02:41 +02:00
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
log = getLogger("PLEX."+__name__)
|
|
|
|
|
|
|
|
GET_METADATA_COUNT = 0
|
|
|
|
PROCESS_METADATA_COUNT = 0
|
|
|
|
PROCESSING_VIEW_NAME = ''
|
|
|
|
LOCK = Lock()
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
|
2017-08-19 14:39:00 +02:00
|
|
|
@thread_methods(add_stops=['SUSPEND_LIBRARY_THREAD', 'STOP_SYNC'])
|
2017-04-02 17:02:41 +02:00
|
|
|
class Threaded_Show_Sync_Info(Thread):
|
|
|
|
"""
|
|
|
|
Threaded class to show the Kodi statusbar of the metadata download.
|
|
|
|
|
|
|
|
Input:
|
|
|
|
total: Total number of items to get
|
2017-08-18 10:37:30 +02:00
|
|
|
item_type:
|
2017-04-02 17:02:41 +02:00
|
|
|
"""
|
2017-08-18 10:37:30 +02:00
|
|
|
def __init__(self, total, item_type):
|
2017-04-02 17:02:41 +02:00
|
|
|
self.total = total
|
|
|
|
self.item_type = item_type
|
|
|
|
Thread.__init__(self)
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
"""
|
|
|
|
Catch all exceptions and log them
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
self.__run()
|
|
|
|
except Exception as e:
|
|
|
|
log.error('Exception %s' % e)
|
|
|
|
import traceback
|
|
|
|
log.error("Traceback:\n%s" % traceback.format_exc())
|
|
|
|
|
|
|
|
def __run(self):
|
|
|
|
"""
|
|
|
|
Do the work
|
|
|
|
"""
|
|
|
|
log.debug('Show sync info thread started')
|
|
|
|
# cache local variables because it's faster
|
2017-08-19 12:51:58 +02:00
|
|
|
total = self.total
|
2017-08-18 10:37:30 +02:00
|
|
|
dialog = DialogProgressBG('dialoglogProgressBG')
|
2017-05-17 10:09:50 +02:00
|
|
|
thread_stopped = self.thread_stopped
|
2017-05-11 20:16:19 +02:00
|
|
|
dialog.create("%s %s: %s %s"
|
|
|
|
% (lang(39714), self.item_type, str(total), lang(39715)))
|
2017-08-19 13:42:15 +02:00
|
|
|
player = Player()
|
2017-04-02 17:02:41 +02:00
|
|
|
|
|
|
|
total = 2 * total
|
|
|
|
totalProgress = 0
|
2017-08-19 13:42:15 +02:00
|
|
|
while thread_stopped() is False and not player.isPlaying():
|
2017-04-02 17:02:41 +02:00
|
|
|
with LOCK:
|
|
|
|
get_progress = GET_METADATA_COUNT
|
|
|
|
process_progress = PROCESS_METADATA_COUNT
|
|
|
|
viewName = PROCESSING_VIEW_NAME
|
|
|
|
totalProgress = get_progress + process_progress
|
|
|
|
try:
|
|
|
|
percentage = int(float(totalProgress) / float(total)*100.0)
|
|
|
|
except ZeroDivisionError:
|
|
|
|
percentage = 0
|
|
|
|
dialog.update(percentage,
|
2017-05-11 20:16:19 +02:00
|
|
|
message="%s %s. %s %s: %s"
|
2017-04-02 17:02:41 +02:00
|
|
|
% (get_progress,
|
2017-05-11 20:16:19 +02:00
|
|
|
lang(39712),
|
2017-04-02 17:02:41 +02:00
|
|
|
process_progress,
|
2017-05-11 20:16:19 +02:00
|
|
|
lang(39713),
|
2017-04-02 17:02:41 +02:00
|
|
|
viewName))
|
|
|
|
# Sleep for x milliseconds
|
|
|
|
sleep(200)
|
|
|
|
dialog.close()
|
|
|
|
log.debug('Show sync info thread terminated')
|