mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-05 17:43:37 +00:00
Merge pull request #761 from JackDandy/feature/ChangePythonVersionCheck
Add strict Python version check (>= 2.7.9 and < 3.0), ** exit ** if incorrect version
This commit is contained in:
commit
aa89a3fedf
7 changed files with 63 additions and 18 deletions
|
@ -1,5 +1,6 @@
|
|||
### 0.12.0 (2016-xx-xx xx:xx:xx UTC)
|
||||
|
||||
* Add strict Python version check (equal to, or higher than 2.7.9 and less than 3.0), **exit** if incorrect version
|
||||
* Update unidecode library 0.04.11 to 0.04.18 (fd57cbf)
|
||||
* Update xmltodict library 0.9.2 (579a005) to 0.9.2 (eac0031)
|
||||
* Update Tornado Web Server 4.3.dev1 (1b6157d) to 4.4.dev1 (c2b4d05)
|
||||
|
@ -117,7 +118,7 @@
|
|||
* Add detection of password protected rars with config/Post Processing/'Unpack downloads' enabled
|
||||
* Change post process to cleanup filenames with config/Post Processing/'Unpack downloads' enabled
|
||||
* Change post process to join incrementally named (i.e. file.001 to file.nnn) split files
|
||||
* Change replace unrar2 lib with rarfile 3.0 and UnRAR.exe 5.40 beta 4 freeware
|
||||
* Change replace unrar2 lib with rarfile 3.0 and UnRAR.exe 5.40 freeware
|
||||
* Change post process "Copy" to delete redundant files after use
|
||||
|
||||
[develop changelog]
|
||||
|
@ -125,6 +126,8 @@
|
|||
* Change revert test_common.py include file placement so Travis builds don't fail
|
||||
* Fix Nyaa and TT torrent providers
|
||||
* Change PrivateHD torrent provider
|
||||
* Fix Add from Trakt
|
||||
* Change unpack files once only in auto post processing copy mode
|
||||
|
||||
|
||||
### 0.11.14 (2016-07-25 03:10:00 UTC)
|
||||
|
|
|
@ -33,8 +33,9 @@ import subprocess
|
|||
import time
|
||||
import threading
|
||||
|
||||
if sys.version_info < (2, 6):
|
||||
print('Sorry, requires Python 2.6 or 2.7.')
|
||||
if not (2, 7, 9) <= sys.version_info < (3, 0):
|
||||
print('Python %s.%s.%s detected.' % sys.version_info[:3])
|
||||
print('Sorry, SickGear requires Python 2.7.9 or higher. Python 3 is not supported.')
|
||||
sys.exit(1)
|
||||
|
||||
try:
|
||||
|
|
|
@ -244,7 +244,7 @@
|
|||
title="<span style='color: rgb(66, 139, 202)'>$re.sub(r'(?m)\s+\((?:19|20)\d\d\)\s*$', '', $title_html)</span>#if $this_show['genres']#<br /><div style='font-weight:bold'>(<em>$this_show['genres']</em>)</div>#end if#
|
||||
<p style='margin:0 0 2px'>#echo re.sub(r'([,\.!][^,\.!]*?)$', '...', re.sub(r'([!\?\.])(?=\w)', r'\1 ', $overview))#</p>
|
||||
<p><span style='font-weight:bold;font-size:0.9em;color:#888'><em>#if $kwargs and 'newseasons' == $mode#Air#else#First air#end if##echo ('s', 'ed')[$this_show['when_past']]#: $this_show['premiered_str']</em></span>
|
||||
#if $this_show['ended_str']# - <span style='font-weight:bold;font-size:0.9em;color:#888'><em>Ended: $this_show['ended_str']</em></span>#end if#</p>
|
||||
#if $this_show.get('ended_str')# - <span style='font-weight:bold;font-size:0.9em;color:#888'><em>Ended: $this_show['ended_str']</em></span>#end if#</p>
|
||||
<span style='float:right'>Click for more at <span class='boldest'>$browse_type</span></span>">
|
||||
#if 'poster' in $this_show['images']:
|
||||
#set $image = $this_show['images']['poster']['thumb']
|
||||
|
|
|
@ -302,6 +302,7 @@ function fetch_branches() {
|
|||
$.each(branches, function (i, text) {
|
||||
add_option_to_branches(text);
|
||||
});
|
||||
$('#branchVersion').find('option[value=' + data['current'] + ']').attr('selected','selected');
|
||||
$('#branchCheckout').removeAttr('disabled');
|
||||
} else {
|
||||
add_option_to_branches('No branches available');
|
||||
|
|
Binary file not shown.
|
@ -19,11 +19,13 @@
|
|||
from __future__ import with_statement
|
||||
|
||||
from functools import partial
|
||||
import datetime
|
||||
import os
|
||||
import re
|
||||
import shutil
|
||||
import stat
|
||||
import sys
|
||||
import time
|
||||
|
||||
import sickbeard
|
||||
from sickbeard import postProcessor
|
||||
|
@ -39,6 +41,11 @@ from sickbeard import failedProcessor
|
|||
|
||||
import lib.rarfile.rarfile as rarfile
|
||||
|
||||
try:
|
||||
import json
|
||||
except ImportError:
|
||||
from lib import simplejson as json
|
||||
|
||||
try:
|
||||
from lib.send2trash import send2trash
|
||||
except ImportError:
|
||||
|
@ -190,13 +197,13 @@ class ProcessTVShow(object):
|
|||
|
||||
path, dirs, files = self._get_path_dir_files(dir_name, nzb_name, pp_type)
|
||||
|
||||
sync_files = filter(helpers.isSyncFile, files)
|
||||
|
||||
# Don't post process if files are still being synced and option is activated
|
||||
if sync_files and sickbeard.POSTPONE_IF_SYNC_FILES:
|
||||
if sickbeard.POSTPONE_IF_SYNC_FILES and any(filter(helpers.isSyncFile, files)):
|
||||
self._log_helper(u'Found temporary sync files, skipping post process', logger.ERROR)
|
||||
return self.result
|
||||
|
||||
if not process_method:
|
||||
process_method = sickbeard.PROCESS_METHOD
|
||||
|
||||
self._log_helper(u'Processing folder... %s' % path)
|
||||
|
||||
work_files = []
|
||||
|
@ -204,7 +211,8 @@ class ProcessTVShow(object):
|
|||
if joined:
|
||||
work_files += [joined]
|
||||
|
||||
rar_files = filter(helpers.is_first_rar_volume, files)
|
||||
rar_files, rarfile_history = self.unused_archives(
|
||||
path, filter(helpers.is_first_rar_volume, files), pp_type, process_method)
|
||||
rar_content = self._unrar(path, rar_files, force)
|
||||
if self.fail_detected:
|
||||
self._process_failed(dir_name, nzb_name)
|
||||
|
@ -228,9 +236,6 @@ class ProcessTVShow(object):
|
|||
if 2 <= len(video_files):
|
||||
nzb_name = None
|
||||
|
||||
if not process_method:
|
||||
process_method = sickbeard.PROCESS_METHOD
|
||||
|
||||
# self._set_process_success()
|
||||
|
||||
# Don't Link media when the media is extracted from a rar in the same path
|
||||
|
@ -266,14 +271,12 @@ class ProcessTVShow(object):
|
|||
|
||||
for walk_path, walk_dir, files in ek.ek(os.walk, ek.ek(os.path.join, path, directory), topdown=False):
|
||||
|
||||
sync_files = filter(helpers.isSyncFile, files)
|
||||
|
||||
# Don't post process if files are still being synced and option is activated
|
||||
if sync_files and sickbeard.POSTPONE_IF_SYNC_FILES:
|
||||
if sickbeard.POSTPONE_IF_SYNC_FILES and any(filter(helpers.isSyncFile, files)):
|
||||
self._log_helper(u'Found temporary sync files, skipping post process', logger.ERROR)
|
||||
return self.result
|
||||
|
||||
rar_files = filter(helpers.is_first_rar_volume, files)
|
||||
rar_files, rarfile_history = self.unused_archives(
|
||||
walk_path, filter(helpers.is_first_rar_volume, files), pp_type, process_method, rarfile_history)
|
||||
rar_content = self._unrar(walk_path, rar_files, force)
|
||||
work_files += [ek.ek(os.path.join, walk_path, item) for item in rar_content]
|
||||
if self.fail_detected:
|
||||
|
@ -346,6 +349,43 @@ class ProcessTVShow(object):
|
|||
|
||||
return self.result
|
||||
|
||||
@staticmethod
|
||||
def unused_archives(path, archives, pp_type, process_method, archive_history=None):
|
||||
|
||||
archive_history = (archive_history, {})[not archive_history]
|
||||
if ('auto' == pp_type and sickbeard.PROCESS_AUTOMATICALLY
|
||||
and 'copy' == process_method and sickbeard.UNPACK):
|
||||
|
||||
archive_history_file = ek.ek(os.path.join, sickbeard.DATA_DIR, 'archive_history.txt')
|
||||
|
||||
if not archive_history:
|
||||
try:
|
||||
with open(archive_history_file, 'r') as fh:
|
||||
archive_history = json.loads(fh.read(10 * 1024 * 1024))
|
||||
except (IOError, ValueError, Exception):
|
||||
pass
|
||||
|
||||
init_history_cnt = len(archive_history)
|
||||
|
||||
for archive in archive_history.keys():
|
||||
if not ek.ek(os.path.isfile, archive):
|
||||
del archive_history[archive]
|
||||
|
||||
unused_files = list(set([ek.ek(os.path.join, path, x) for x in archives]) - set(archive_history.keys()))
|
||||
archives = [ek.ek(os.path.basename, x) for x in unused_files]
|
||||
if unused_files:
|
||||
for f in unused_files:
|
||||
archive_history.setdefault(f, time.mktime(datetime.datetime.utcnow().timetuple()))
|
||||
|
||||
if init_history_cnt != len(archive_history):
|
||||
try:
|
||||
with open(archive_history_file, 'w') as fh:
|
||||
fh.write(json.dumps(archive_history))
|
||||
except (IOError, Exception):
|
||||
pass
|
||||
|
||||
return archives, archive_history
|
||||
|
||||
def _validate_dir(self, path, dir_name, nzb_name_original, failed):
|
||||
|
||||
self._log_helper(u'Processing sub dir: ' + dir_name)
|
||||
|
|
|
@ -4330,7 +4330,7 @@ class ConfigGeneral(Config):
|
|||
def fetch_branches():
|
||||
try:
|
||||
branches = sickbeard.versionCheckScheduler.action.list_remote_branches()
|
||||
return json.dumps({'result': 'success', 'branches': branches})
|
||||
return json.dumps({'result': 'success', 'branches': branches, 'current': sickbeard.BRANCH or 'master'})
|
||||
except Exception as e:
|
||||
logger.log(u'exception msg: ' + str(e), logger.DEBUG)
|
||||
return json.dumps({'result': 'fail'})
|
||||
|
|
Loading…
Reference in a new issue