diff --git a/CHANGES.md b/CHANGES.md
index 2b2d233e..855484dd 100644
--- a/CHANGES.md
+++ b/CHANGES.md
@@ -29,6 +29,8 @@
* Add coverage testing and coveralls support
* Update feedparser library 5.1.3 to 5.2.0 (8c62940)
* Remove feedcache implementation and library
+* Change py2 exception clauses to py2/3 compatible clauses
+* Add py2/3 regression testing for exception clauses
[develop changelog]
* Update Requests library 2.7.0 (ab1f493) to 2.7.0 (8b5e457)
diff --git a/SickBeard.py b/SickBeard.py
index d49154e5..e40a48ce 100755
--- a/SickBeard.py
+++ b/SickBeard.py
@@ -387,7 +387,7 @@ class SickGear(object):
pid = os.fork() # @UndefinedVariable - only available in UNIX
if pid != 0:
os._exit(0)
- except OSError, e:
+ except OSError as e:
sys.stderr.write('fork #1 failed: %d (%s)\n' % (e.errno, e.strerror))
sys.exit(1)
@@ -402,7 +402,7 @@ class SickGear(object):
pid = os.fork() # @UndefinedVariable - only available in UNIX
if pid != 0:
os._exit(0)
- except OSError, e:
+ except OSError as e:
sys.stderr.write('fork #2 failed: %d (%s)\n' % (e.errno, e.strerror))
sys.exit(1)
@@ -412,7 +412,7 @@ class SickGear(object):
logger.log(u'Writing PID: %s to %s' % (pid, self.PIDFILE))
try:
file(self.PIDFILE, 'w').write('%s\n' % pid)
- except IOError, e:
+ except IOError as e:
logger.log_error_and_exit(
u'Unable to write PID file: %s Error: %s [%s]' % (self.PIDFILE, e.strerror, e.errno))
@@ -456,7 +456,7 @@ class SickGear(object):
curShow = TVShow(int(sqlShow['indexer']), int(sqlShow['indexer_id']))
curShow.nextEpisode()
sickbeard.showList.append(curShow)
- except Exception, e:
+ except Exception as e:
logger.log(
u'There was an error creating the show in %s: %s' % (sqlShow['location'], str(e).decode('utf-8',
'replace')),
diff --git a/autoProcessTV/mediaToSickbeard.py b/autoProcessTV/mediaToSickbeard.py
index 8c1b5d16..cf321b50 100755
--- a/autoProcessTV/mediaToSickbeard.py
+++ b/autoProcessTV/mediaToSickbeard.py
@@ -22,7 +22,7 @@ try:
fp = open(configFilename, 'r')
config.readfp(fp)
fp.close()
-except IOError, e:
+except IOError as e:
print 'Could not find/read Sickbeard config.ini: ' + str(e)
print 'Possibly wrong mediaToSickbeard.py location. Ensure the file is in the autoProcessTV subdir of your Sickbeard installation'
time.sleep(3)
@@ -180,7 +180,7 @@ def main():
sess = requests.Session()
sess.post(login_url, data={'username': username, 'password': password}, stream=True, verify=False)
response = sess.get(url, auth=(username, password), params=params, verify=False, allow_redirects=False)
- except Exception, e:
+ except Exception as e:
scriptlogger.error(u': Unknown exception raised when opening url: ' + str(e))
time.sleep(3)
sys.exit()
diff --git a/sickbeard/browser.py b/sickbeard/browser.py
index c087e6cb..e9517daa 100644
--- a/sickbeard/browser.py
+++ b/sickbeard/browser.py
@@ -84,7 +84,7 @@ def foldersAtPath(path, includeParent=False, includeFiles=False):
try:
fileList = [{'name': filename, 'path': ek.ek(os.path.join, path, filename)} for filename in
ek.ek(os.listdir, path)]
- except OSError, e:
+ except OSError as e:
logger.log(u'Unable to open %s: %r / %s' % (path, e, e), logger.WARNING)
fileList = [{'name': filename, 'path': ek.ek(os.path.join, parentPath, filename)} for filename in
ek.ek(os.listdir, parentPath)]
diff --git a/sickbeard/clients/generic.py b/sickbeard/clients/generic.py
index 4ad0785c..00e4ceb5 100644
--- a/sickbeard/clients/generic.py
+++ b/sickbeard/clients/generic.py
@@ -53,19 +53,19 @@ class GenericClient(object):
try:
response = self.session.__getattribute__(method)(self.url, params=params, data=data, files=files,
timeout=120, verify=False)
- except requests.exceptions.ConnectionError, e:
+ except requests.exceptions.ConnectionError as e:
logger.log(self.name + u': Unable to connect ' + ex(e), logger.ERROR)
return False
except (requests.exceptions.MissingSchema, requests.exceptions.InvalidURL):
logger.log(self.name + u': Invalid Host', logger.ERROR)
return False
- except requests.exceptions.HTTPError, e:
+ except requests.exceptions.HTTPError as e:
logger.log(self.name + u': Invalid HTTP Request ' + ex(e), logger.ERROR)
return False
- except requests.exceptions.Timeout, e:
+ except requests.exceptions.Timeout as e:
logger.log(self.name + u': Connection Timeout ' + ex(e), logger.ERROR)
return False
- except Exception, e:
+ except Exception as e:
logger.log(self.name + u': Unknown exception raised when sending torrent to ' + self.name + ': ' + ex(e),
logger.ERROR)
return False
@@ -199,7 +199,7 @@ class GenericClient(object):
if result.priority != 0 and not self._set_torrent_priority(result):
logger.log(self.name + u': Unable to set priority for Torrent', logger.ERROR)
- except Exception, e:
+ except Exception as e:
logger.log(self.name + u': Failed Sending Torrent: ' + result.name + ' - ' + result.hash, logger.ERROR)
logger.log(self.name + u': Exception raised when sending torrent: ' + ex(e), logger.DEBUG)
return r_code
diff --git a/sickbeard/db.py b/sickbeard/db.py
index 248cf8db..f6a1be14 100644
--- a/sickbeard/db.py
+++ b/sickbeard/db.py
@@ -95,7 +95,7 @@ class DBConnection(object):
self.connection.commit()
logger.log(u'Transaction with ' + str(len(querylist)) + u' queries executed', logger.DEBUG)
return sqlResult
- except sqlite3.OperationalError, e:
+ except sqlite3.OperationalError as e:
sqlResult = []
if self.connection:
self.connection.rollback()
@@ -106,7 +106,7 @@ class DBConnection(object):
else:
logger.log(u'DB error: ' + ex(e), logger.ERROR)
raise
- except sqlite3.DatabaseError, e:
+ except sqlite3.DatabaseError as e:
if self.connection:
self.connection.rollback()
logger.log(u'Fatal error executing query: ' + ex(e), logger.ERROR)
@@ -135,7 +135,7 @@ class DBConnection(object):
self.connection.commit()
# get out of the connection attempt loop since we were successful
break
- except sqlite3.OperationalError, e:
+ except sqlite3.OperationalError as e:
if 'unable to open database file' in e.args[0] or 'database is locked' in e.args[0]:
logger.log(u'DB error: ' + ex(e), logger.WARNING)
attempt += 1
@@ -143,7 +143,7 @@ class DBConnection(object):
else:
logger.log(u'DB error: ' + ex(e), logger.ERROR)
raise
- except sqlite3.DatabaseError, e:
+ except sqlite3.DatabaseError as e:
logger.log(u'Fatal error executing query: ' + ex(e), logger.ERROR)
raise
@@ -252,7 +252,7 @@ def _processUpgrade(connection, upgradeClass):
logger.log(u'Database upgrade required: %s' % prettyName(upgradeClass.__name__), logger.MESSAGE)
try:
instance.execute()
- except sqlite3.DatabaseError, e:
+ except sqlite3.DatabaseError as e:
# attemping to restore previous DB backup and perform upgrade
try:
instance.execute()
@@ -442,7 +442,7 @@ def MigrationCode(myDB):
try:
update = schema[db_version](myDB)
db_version = update.execute()
- except Exception, e:
+ except Exception as e:
myDB.close()
logger.log(u'Failed to update database with error: %s attempting recovery...' % ex(e), logger.ERROR)
diff --git a/sickbeard/failed_history.py b/sickbeard/failed_history.py
index 39184c41..c7f09718 100644
--- a/sickbeard/failed_history.py
+++ b/sickbeard/failed_history.py
@@ -132,7 +132,7 @@ def revertEpisode(epObj):
epObj.status = WANTED
epObj.saveToDB()
- except EpisodeNotFoundException, e:
+ except EpisodeNotFoundException as e:
logger.log(u"Unable to create episode, please set its status manually: " + ex(e),
logger.WARNING)
@@ -146,7 +146,7 @@ def markFailed(epObj):
epObj.status = Quality.compositeStatus(FAILED, quality)
epObj.saveToDB()
- except EpisodeNotFoundException, e:
+ except EpisodeNotFoundException as e:
logger.log(u"Unable to get episode, please set its status manually: " + ex(e), logger.WARNING)
return log_str
diff --git a/sickbeard/helpers.py b/sickbeard/helpers.py
index 24f2fb19..24eecaf0 100644
--- a/sickbeard/helpers.py
+++ b/sickbeard/helpers.py
@@ -286,7 +286,7 @@ def hardlinkFile(srcFile, destFile):
try:
ek.ek(link, srcFile, destFile)
fixSetGroupID(destFile)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed to create hardlink of " + srcFile + " at " + destFile + ": " + ex(e) + ". Copying instead",
logger.ERROR)
copyFile(srcFile, destFile)
@@ -326,7 +326,7 @@ def make_dirs(path):
try:
logger.log(u"Folder " + path + " doesn't exist, creating it", logger.DEBUG)
ek.ek(os.makedirs, path)
- except (OSError, IOError), e:
+ except (OSError, IOError) as e:
logger.log(u"Failed creating " + path + " : " + ex(e), logger.ERROR)
return False
@@ -350,7 +350,7 @@ def make_dirs(path):
chmodAsParent(ek.ek(os.path.normpath, sofar))
# do the library update for synoindex
notifiers.synoindex_notifier.addFolder(sofar)
- except (OSError, IOError), e:
+ except (OSError, IOError) as e:
logger.log(u"Failed creating " + sofar + " : " + ex(e), logger.ERROR)
return False
@@ -397,7 +397,7 @@ def rename_ep_file(cur_path, new_path, old_path_length=0):
try:
logger.log(u"Renaming file from " + cur_path + " to " + new_path)
ek.ek(os.rename, cur_path, new_path)
- except (OSError, IOError), e:
+ except (OSError, IOError) as e:
logger.log(u"Failed renaming " + cur_path + " to " + new_path + ": " + ex(e), logger.ERROR)
return False
@@ -433,7 +433,7 @@ def delete_empty_folders(check_empty_dir, keep_dir=None):
ek.ek(os.rmdir, check_empty_dir)
# do the library update for synoindex
notifiers.synoindex_notifier.deleteFolder(check_empty_dir)
- except OSError, e:
+ except OSError as e:
logger.log(u"Unable to delete " + check_empty_dir + ": " + repr(e) + " / " + str(e), logger.WARNING)
break
check_empty_dir = ek.ek(os.path.dirname, check_empty_dir)
@@ -596,7 +596,7 @@ def create_https_certificates(ssl_cert, ssl_key):
from OpenSSL import crypto # @UnresolvedImport
from lib.certgen import createKeyPair, createCertRequest, createCertificate, TYPE_RSA, \
serial # @UnresolvedImport
- except Exception, e:
+ except Exception as e:
logger.log(u"pyopenssl module missing, please install for https access", logger.WARNING)
return False
@@ -642,7 +642,7 @@ def parse_xml(data, del_xmlns=False):
try:
parsedXML = etree.fromstring(data)
- except Exception, e:
+ except Exception as e:
logger.log(u"Error trying to parse xml data. Error: " + ex(e), logger.DEBUG)
parsedXML = None
@@ -664,7 +664,7 @@ def backupVersionedFile(old_file, version):
shutil.copy(old_file, new_file)
logger.log(u'Backup done', logger.DEBUG)
break
- except Exception, e:
+ except Exception as e:
logger.log(u'Error while trying to back up %s to %s : %s' % (old_file, new_file, ex(e)), logger.WARNING)
num_tries += 1
time.sleep(3)
@@ -692,7 +692,7 @@ def restoreVersionedFile(backup_file, version):
u"Trying to backup " + new_file + " to " + new_file + "." + "r" + str(version) + " before restoring backup",
logger.DEBUG)
shutil.move(new_file, new_file + '.' + 'r' + str(version))
- except Exception, e:
+ except Exception as e:
logger.log(
u"Error while trying to backup DB file " + restore_file + " before proceeding with restore: " + ex(e),
logger.WARNING)
@@ -708,7 +708,7 @@ def restoreVersionedFile(backup_file, version):
shutil.copy(restore_file, new_file)
logger.log(u"Restore done", logger.DEBUG)
break
- except Exception, e:
+ except Exception as e:
logger.log(u"Error while trying to restore " + restore_file + ": " + ex(e), logger.WARNING)
numTries += 1
time.sleep(1)
@@ -946,14 +946,14 @@ def set_up_anidb_connection():
auth = False
try:
auth = sickbeard.ADBA_CONNECTION.authed()
- except Exception, e:
+ except Exception as e:
logger.log(u'exception msg: ' + str(e))
pass
if not auth:
try:
sickbeard.ADBA_CONNECTION.auth(sickbeard.ANIDB_USERNAME, sickbeard.ANIDB_PASSWORD)
- except Exception, e:
+ except Exception as e:
logger.log(u'exception msg: ' + str(e))
return False
else:
@@ -1164,16 +1164,16 @@ def getURL(url, post_data=None, params=None, headers=None, timeout=30, session=N
% (url, resp.status_code, http_err_text), logger.DEBUG)
return
- except requests.exceptions.HTTPError, e:
+ except requests.exceptions.HTTPError as e:
logger.log(u"HTTP error " + str(e.errno) + " while loading URL " + url, logger.WARNING)
return
- except requests.exceptions.ConnectionError, e:
+ except requests.exceptions.ConnectionError as e:
logger.log(u"Connection error " + str(e.message) + " while loading URL " + url, logger.WARNING)
return
- except requests.exceptions.Timeout, e:
+ except requests.exceptions.Timeout as e:
logger.log(u"Connection timed out " + str(e.message) + " while loading URL " + url, logger.WARNING)
return
- except requests.exceptions.ReadTimeout, e:
+ except requests.exceptions.ReadTimeout as e:
logger.log(u'Read timed out ' + str(e.message) + ' while loading URL ' + url, logger.WARNING)
return
except Exception:
@@ -1230,19 +1230,19 @@ def download_file(url, filename, session=None):
fp.flush()
chmodAsParent(filename)
- except requests.exceptions.HTTPError, e:
+ except requests.exceptions.HTTPError as e:
_remove_file_failed(filename)
logger.log(u"HTTP error " + str(e.errno) + " while loading URL " + url, logger.WARNING)
return False
- except requests.exceptions.ConnectionError, e:
+ except requests.exceptions.ConnectionError as e:
_remove_file_failed(filename)
logger.log(u"Connection error " + str(e.message) + " while loading URL " + url, logger.WARNING)
return False
- except requests.exceptions.Timeout, e:
+ except requests.exceptions.Timeout as e:
_remove_file_failed(filename)
logger.log(u"Connection timed out " + str(e.message) + " while loading URL " + url, logger.WARNING)
return False
- except EnvironmentError, e:
+ except EnvironmentError as e:
_remove_file_failed(filename)
logger.log(u"Unable to save the file: " + ex(e), logger.ERROR)
return False
@@ -1282,7 +1282,7 @@ def clearCache(force=False):
if force or (update_datetime - cache_file_modified > max_age):
try:
ek.ek(os.remove, cache_file)
- except OSError, e:
+ except OSError as e:
logger.log(u"Unable to clean " + cache_root + ": " + repr(e) + " / " + str(e),
logger.WARNING)
break
diff --git a/sickbeard/metadata/generic.py b/sickbeard/metadata/generic.py
index 69ba9f00..d4457432 100644
--- a/sickbeard/metadata/generic.py
+++ b/sickbeard/metadata/generic.py
@@ -305,7 +305,7 @@ class GenericMetadata():
helpers.chmodAsParent(nfo_file_path)
return True
- except IOError, e:
+ except IOError as e:
logger.log(
u"Unable to write file to " + nfo_file_path + " - are you sure the folder is writable? " + ex(e),
logger.ERROR)
@@ -432,7 +432,7 @@ class GenericMetadata():
data.write(nfo_file, encoding="utf-8")
nfo_file.close()
helpers.chmodAsParent(nfo_file_path)
- except IOError, e:
+ except IOError as e:
logger.log(u"Unable to write file to " + nfo_file_path + " - are you sure the folder is writable? " + ex(e),
logger.ERROR)
return False
@@ -477,7 +477,7 @@ class GenericMetadata():
data.write(nfo_file, encoding="utf-8")
nfo_file.close()
helpers.chmodAsParent(nfo_file_path)
- except IOError, e:
+ except IOError as e:
logger.log(u"Unable to write file to " + nfo_file_path + " - are you sure the folder is writable? " + ex(e),
logger.ERROR)
return False
@@ -725,7 +725,7 @@ class GenericMetadata():
outFile.write(image_data)
outFile.close()
helpers.chmodAsParent(image_path)
- except IOError, e:
+ except IOError as e:
logger.log(
u"Unable to write image to " + image_path + " - are you sure the show folder is writable? " + ex(e),
logger.ERROR)
@@ -761,7 +761,7 @@ class GenericMetadata():
t = sickbeard.indexerApi(show_obj.indexer).indexer(**lINDEXER_API_PARMS)
indexer_show_obj = t[show_obj.indexerid]
- except (sickbeard.indexer_error, IOError), e:
+ except (sickbeard.indexer_error, IOError) as e:
logger.log(u"Unable to look up show on " + sickbeard.indexerApi(
show_obj.indexer).name + ", not downloading images: " + ex(e), logger.ERROR)
return None
@@ -822,7 +822,7 @@ class GenericMetadata():
t = sickbeard.indexerApi(show_obj.indexer).indexer(**lINDEXER_API_PARMS)
indexer_show_obj = t[show_obj.indexerid]
- except (sickbeard.indexer_error, IOError), e:
+ except (sickbeard.indexer_error, IOError) as e:
logger.log(u"Unable to look up show on " + sickbeard.indexerApi(
show_obj.indexer).name + ", not downloading images: " + ex(e), logger.ERROR)
return result
@@ -875,7 +875,7 @@ class GenericMetadata():
t = sickbeard.indexerApi(show_obj.indexer).indexer(**lINDEXER_API_PARMS)
indexer_show_obj = t[show_obj.indexerid]
- except (sickbeard.indexer_error, IOError), e:
+ except (sickbeard.indexer_error, IOError) as e:
logger.log(u"Unable to look up show on " + sickbeard.indexerApi(
show_obj.indexer).name + ", not downloading images: " + ex(e), logger.ERROR)
return result
@@ -953,7 +953,7 @@ class GenericMetadata():
logger.log(u"Invalid Indexer ID (" + str(indexer_id) + "), not using metadata file", logger.WARNING)
return empty_return
- except Exception, e:
+ except Exception as e:
logger.log(
u"There was an error parsing your existing metadata file: '" + metadata_path + "' error: " + ex(e),
logger.WARNING)
@@ -984,7 +984,7 @@ class GenericMetadata():
elif poster and result['poster_path']:
return "{0}{1}{2}".format(base_url, max_size, result['poster_path'])
- except Exception, e:
+ except Exception as e:
pass
logger.log(u"Could not find any posters or background for " + show.name, logger.DEBUG)
diff --git a/sickbeard/metadata/kodi.py b/sickbeard/metadata/kodi.py
index 6a3a1c96..a771d84f 100644
--- a/sickbeard/metadata/kodi.py
+++ b/sickbeard/metadata/kodi.py
@@ -234,9 +234,9 @@ class KODIMetadata(generic.GenericMetadata):
try:
t = sickbeard.indexerApi(ep_obj.show.indexer).indexer(**lINDEXER_API_PARMS)
myShow = t[ep_obj.show.indexerid]
- except sickbeard.indexer_shownotfound, e:
+ except sickbeard.indexer_shownotfound as e:
raise exceptions.ShowNotFoundException(e.message)
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u'Unable to connect to ' + sickbeard.indexerApi(
ep_obj.show.indexer).name + ' while creating meta files - skipping - ' + ex(e), logger.ERROR)
return
diff --git a/sickbeard/metadata/mede8er.py b/sickbeard/metadata/mede8er.py
index d26dfe32..3b7e6a7b 100644
--- a/sickbeard/metadata/mede8er.py
+++ b/sickbeard/metadata/mede8er.py
@@ -236,9 +236,9 @@ class Mede8erMetadata(mediabrowser.MediaBrowserMetadata):
t = sickbeard.indexerApi(ep_obj.show.indexer).indexer(**lINDEXER_API_PARMS)
myShow = t[ep_obj.show.indexerid]
- except sickbeard.indexer_shownotfound, e:
+ except sickbeard.indexer_shownotfound as e:
raise exceptions.ShowNotFoundException(e.message)
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u"Unable to connect to TVDB while creating meta files - skipping - " + ex(e), logger.ERROR)
return False
diff --git a/sickbeard/metadata/mediabrowser.py b/sickbeard/metadata/mediabrowser.py
index 0606ccf7..e57a53bd 100644
--- a/sickbeard/metadata/mediabrowser.py
+++ b/sickbeard/metadata/mediabrowser.py
@@ -408,9 +408,9 @@ class MediaBrowserMetadata(generic.GenericMetadata):
t = sickbeard.indexerApi(ep_obj.show.indexer).indexer(**lINDEXER_API_PARMS)
myShow = t[ep_obj.show.indexerid]
- except sickbeard.indexer_shownotfound, e:
+ except sickbeard.indexer_shownotfound as e:
raise exceptions.ShowNotFoundException(e.message)
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u"Unable to connect to " + sickbeard.indexerApi(
ep_obj.show.indexer).name + " while creating meta files - skipping - " + ex(e), logger.ERROR)
return False
diff --git a/sickbeard/metadata/tivo.py b/sickbeard/metadata/tivo.py
index 406ad901..13254567 100644
--- a/sickbeard/metadata/tivo.py
+++ b/sickbeard/metadata/tivo.py
@@ -181,9 +181,9 @@ class TIVOMetadata(generic.GenericMetadata):
t = sickbeard.indexerApi(ep_obj.show.indexer).indexer(**lINDEXER_API_PARMS)
myShow = t[ep_obj.show.indexerid]
- except sickbeard.indexer_shownotfound, e:
+ except sickbeard.indexer_shownotfound as e:
raise exceptions.ShowNotFoundException(str(e))
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u"Unable to connect to " + sickbeard.indexerApi(
ep_obj.show.indexer).name + " while creating meta files - skipping - " + str(e), logger.ERROR)
return False
@@ -327,7 +327,7 @@ class TIVOMetadata(generic.GenericMetadata):
helpers.chmodAsParent(nfo_file_path)
- except EnvironmentError, e:
+ except EnvironmentError as e:
logger.log(u"Unable to write file to " + nfo_file_path + " - are you sure the folder is writable? " + ex(e),
logger.ERROR)
return False
diff --git a/sickbeard/metadata/wdtv.py b/sickbeard/metadata/wdtv.py
index bb36f6e1..e53a7bb6 100644
--- a/sickbeard/metadata/wdtv.py
+++ b/sickbeard/metadata/wdtv.py
@@ -192,9 +192,9 @@ class WDTVMetadata(generic.GenericMetadata):
t = sickbeard.indexerApi(ep_obj.show.indexer).indexer(**lINDEXER_API_PARMS)
myShow = t[ep_obj.show.indexerid]
- except sickbeard.indexer_shownotfound, e:
+ except sickbeard.indexer_shownotfound as e:
raise exceptions.ShowNotFoundException(e.message)
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u"Unable to connect to " + sickbeard.indexerApi(
ep_obj.show.indexer).name + " while creating meta files - skipping - " + ex(e), logger.ERROR)
return False
diff --git a/sickbeard/metadata/xbmc_12plus.py b/sickbeard/metadata/xbmc_12plus.py
index 04ff8e4c..8081dfba 100644
--- a/sickbeard/metadata/xbmc_12plus.py
+++ b/sickbeard/metadata/xbmc_12plus.py
@@ -234,9 +234,9 @@ class XBMC_12PlusMetadata(generic.GenericMetadata):
try:
t = sickbeard.indexerApi(ep_obj.show.indexer).indexer(**lINDEXER_API_PARMS)
myShow = t[ep_obj.show.indexerid]
- except sickbeard.indexer_shownotfound, e:
+ except sickbeard.indexer_shownotfound as e:
raise exceptions.ShowNotFoundException(e.message)
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u"Unable to connect to " + sickbeard.indexerApi(
ep_obj.show.indexer).name + " while creating meta files - skipping - " + ex(e), logger.ERROR)
return
diff --git a/sickbeard/name_parser/parser.py b/sickbeard/name_parser/parser.py
index d0d90171..e638fa41 100644
--- a/sickbeard/name_parser/parser.py
+++ b/sickbeard/name_parser/parser.py
@@ -95,7 +95,7 @@ class NameParser(object):
for cur_pattern_num, (cur_pattern_name, cur_pattern) in enumerate(regexItem):
try:
cur_regex = re.compile(cur_pattern, re.VERBOSE | re.IGNORECASE)
- except re.error, errormsg:
+ except re.error as errormsg:
logger.log(u"WARNING: Invalid episode_pattern, %s. %s" % (errormsg, cur_pattern))
else:
self.compiled_regexes[index].append([cur_pattern_num, cur_pattern_name, cur_regex])
@@ -166,7 +166,7 @@ class NameParser(object):
day = tmp_month
try:
result.air_date = datetime.date(year, month, day)
- except ValueError, e:
+ except ValueError as e:
raise InvalidNameException(ex(e))
if 'extra_info' in named_groups:
@@ -257,7 +257,7 @@ class NameParser(object):
except sickbeard.indexer_episodenotfound:
logger.log(u"Unable to find episode with date " + str(bestResult.air_date) + " for show " + bestResult.show.name + ", skipping", logger.WARNING)
episode_numbers = []
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u"Unable to contact " + sickbeard.indexerApi(bestResult.show.indexer).name + ": " + ex(e), logger.WARNING)
episode_numbers = []
diff --git a/sickbeard/naming.py b/sickbeard/naming.py
index aebfa1f4..e5818a66 100644
--- a/sickbeard/naming.py
+++ b/sickbeard/naming.py
@@ -188,7 +188,7 @@ def validate_name(pattern, multi=None, anime_type=None, file_only=False, abd=Fal
try:
result = parser.parse(new_name)
- except Exception, e:
+ except Exception as e:
logger.log(u"Unable to parse " + new_name + ", not valid", logger.DEBUG)
return False
diff --git a/sickbeard/notifiers/boxcar2.py b/sickbeard/notifiers/boxcar2.py
index 68118e35..72140eaa 100755
--- a/sickbeard/notifiers/boxcar2.py
+++ b/sickbeard/notifiers/boxcar2.py
@@ -62,7 +62,7 @@ class Boxcar2Notifier:
handle = urllib2.urlopen(req, data)
handle.close()
- except urllib2.URLError, e:
+ except urllib2.URLError as e:
# if we get an error back that doesn't have an error code then who knows what's really happening
if not hasattr(e, 'code'):
logger.log(u'BOXCAR2: Notification failed.' + ex(e), logger.ERROR)
diff --git a/sickbeard/notifiers/growl.py b/sickbeard/notifiers/growl.py
index 09e670ec..b66649a2 100644
--- a/sickbeard/notifiers/growl.py
+++ b/sickbeard/notifiers/growl.py
@@ -142,7 +142,7 @@ class GrowlNotifier:
return self._send_growl(opts, message)
else:
return False
- except Exception, e:
+ except Exception as e:
logger.log(u"GROWL: Unable to send growl to " + opts['host'] + ":" + str(opts['port']) + " - " + ex(e), logger.WARNING)
return False
@@ -186,7 +186,7 @@ class GrowlNotifier:
try:
return self._send(opts['host'], opts['port'], register.encode(), opts['debug'])
- except Exception, e:
+ except Exception as e:
logger.log(u"GROWL: Unable to send growl to " + opts['host'] + ":" + str(opts['port']) + " - " + ex(e), logger.WARNING)
return False
diff --git a/sickbeard/notifiers/kodi.py b/sickbeard/notifiers/kodi.py
index 55252f36..3655a7b2 100644
--- a/sickbeard/notifiers/kodi.py
+++ b/sickbeard/notifiers/kodi.py
@@ -102,7 +102,7 @@ class KODINotifier:
try:
response = urllib2.urlopen(req)
- except urllib2.URLError, e:
+ except urllib2.URLError as e:
logger.log(u'KODI: Warning: Couldn\'t contact Kodi at ' + host + '- ' + ex(e), logger.WARNING)
return False
@@ -112,11 +112,11 @@ class KODINotifier:
response.close()
logger.log(u'KODI: JSON response: ' + str(result), logger.DEBUG)
return result # need to return response for parsing
- except ValueError, e:
+ except ValueError as e:
logger.log(u'KODI: Unable to decode JSON response: ' + response, logger.WARNING)
return False
- except IOError, e:
+ except IOError as e:
logger.log(u'KODI: Warning: Couldn\'t contact Kodi at ' + host + ' - ' + ex(e), logger.WARNING)
return False
diff --git a/sickbeard/notifiers/libnotify.py b/sickbeard/notifiers/libnotify.py
index 276b23fe..90a45ad1 100644
--- a/sickbeard/notifiers/libnotify.py
+++ b/sickbeard/notifiers/libnotify.py
@@ -44,13 +44,13 @@ def diagnose():
else:
try:
bus = dbus.SessionBus()
- except dbus.DBusException, e:
+ except dbus.DBusException as e:
return (u"
Error: unable to connect to D-Bus session bus: %s
."
u"
Are you running SickGear in a desktop session?") % (cgi.escape(e),)
try:
bus.get_object('org.freedesktop.Notifications',
'/org/freedesktop/Notifications')
- except dbus.DBusException, e:
+ except dbus.DBusException as e:
return (u"
Error: there doesn't seem to be a notification daemon available: %s
"
u"
Try installing notification-daemon or notify-osd.") % (cgi.escape(e),)
return u"
Error: Unable to send notification."
diff --git a/sickbeard/notifiers/nmj.py b/sickbeard/notifiers/nmj.py
index 14516756..e755205b 100644
--- a/sickbeard/notifiers/nmj.py
+++ b/sickbeard/notifiers/nmj.py
@@ -121,13 +121,13 @@ class NMJNotifier:
req = urllib2.Request(mount)
logger.log(u"Try to mount network drive via url: %s" % (mount), logger.DEBUG)
handle = urllib2.urlopen(req)
- except IOError, e:
+ except IOError as e:
if hasattr(e, 'reason'):
logger.log(u"NMJ: Could not contact Popcorn Hour on host %s: %s" % (host, e.reason), logger.WARNING)
elif hasattr(e, 'code'):
logger.log(u"NMJ: Problem with Popcorn Hour on host %s: %s" % (host, e.code), logger.WARNING)
return False
- except Exception, e:
+ except Exception as e:
logger.log(u"NMJ: Unknown exception: " + ex(e), logger.ERROR)
return False
@@ -148,13 +148,13 @@ class NMJNotifier:
logger.log(u"Sending NMJ scan update command via url: %s" % (updateUrl), logger.DEBUG)
handle = urllib2.urlopen(req)
response = handle.read()
- except IOError, e:
+ except IOError as e:
if hasattr(e, 'reason'):
logger.log(u"NMJ: Could not contact Popcorn Hour on host %s: %s" % (host, e.reason), logger.WARNING)
elif hasattr(e, 'code'):
logger.log(u"NMJ: Problem with Popcorn Hour on host %s: %s" % (host, e.code), logger.WARNING)
return False
- except Exception, e:
+ except Exception as e:
logger.log(u"NMJ: Unknown exception: " + ex(e), logger.ERROR)
return False
@@ -162,7 +162,7 @@ class NMJNotifier:
try:
et = etree.fromstring(response)
result = et.findtext("returnValue")
- except SyntaxError, e:
+ except SyntaxError as e:
logger.log(u"Unable to parse XML returned from the Popcorn Hour: %s" % (e), logger.ERROR)
return False
diff --git a/sickbeard/notifiers/nmjv2.py b/sickbeard/notifiers/nmjv2.py
index 3f8a440a..4d50ae37 100644
--- a/sickbeard/notifiers/nmjv2.py
+++ b/sickbeard/notifiers/nmjv2.py
@@ -90,7 +90,7 @@ class NMJv2Notifier:
sickbeard.NMJv2_DATABASE = DB_path
return True
- except IOError, e:
+ except IOError as e:
logger.log(u"Warning: Couldn't contact popcorn hour on host %s: %s" % (host, e), logger.WARNING)
return False
return False
@@ -119,19 +119,19 @@ class NMJv2Notifier:
time.sleep(300.0 / 1000.0)
handle2 = urllib2.urlopen(req)
response2 = handle2.read()
- except IOError, e:
+ except IOError as e:
logger.log(u"Warning: Couldn't contact popcorn hour on host %s: %s" % (host, e), logger.WARNING)
return False
try:
et = etree.fromstring(response1)
result1 = et.findtext("returnValue")
- except SyntaxError, e:
+ except SyntaxError as e:
logger.log(u"Unable to parse XML returned from the Popcorn Hour: update_scandir, %s" % (e), logger.ERROR)
return False
try:
et = etree.fromstring(response2)
result2 = et.findtext("returnValue")
- except SyntaxError, e:
+ except SyntaxError as e:
logger.log(u"Unable to parse XML returned from the Popcorn Hour: scanner_start, %s" % (e), logger.ERROR)
return False
diff --git a/sickbeard/notifiers/plex.py b/sickbeard/notifiers/plex.py
index 1262f798..182b7784 100644
--- a/sickbeard/notifiers/plex.py
+++ b/sickbeard/notifiers/plex.py
@@ -88,7 +88,7 @@ class PLEXNotifier:
# could return result response = re.compile('
(.+\w)').findall(result)
return 'OK'
- except (urllib2.URLError, IOError), e:
+ except (urllib2.URLError, IOError) as e:
logger.log(u'PLEX: Warning: Couldn\'t contact Plex at ' + fixStupidEncodings(url) + ' ' + ex(e), logger.WARNING)
return False
@@ -219,7 +219,7 @@ class PLEXNotifier:
try:
xml_tree = etree.parse(urllib.urlopen(url))
media_container = xml_tree.getroot()
- except IOError, e:
+ except IOError as e:
logger.log(u'PLEX: Error while trying to contact Plex Media Server: ' + ex(e), logger.ERROR)
hosts_failed.append(cur_host)
continue
@@ -255,7 +255,7 @@ class PLEXNotifier:
try:
force and urllib.urlopen(url)
host_list.append(cur_host)
- except Exception, e:
+ except Exception as e:
logger.log(u'PLEX: Error updating library section for Plex Media Server: ' + ex(e), logger.ERROR)
hosts_failed.append(cur_host)
diff --git a/sickbeard/notifiers/pushbullet.py b/sickbeard/notifiers/pushbullet.py
index 8aa3e97f..7254cc68 100644
--- a/sickbeard/notifiers/pushbullet.py
+++ b/sickbeard/notifiers/pushbullet.py
@@ -74,7 +74,7 @@ class PushbulletNotifier:
handle.close()
except socket.timeout:
return False
- except urllib2.URLError, e:
+ except urllib2.URLError as e:
if e.code == 404:
logger.log(u'PUSHBULLET: Access token is wrong/not associated to a device.', logger.ERROR)
diff --git a/sickbeard/notifiers/pushover.py b/sickbeard/notifiers/pushover.py
index f48a763d..d6ccaa55 100644
--- a/sickbeard/notifiers/pushover.py
+++ b/sickbeard/notifiers/pushover.py
@@ -97,7 +97,7 @@ class PushoverNotifier:
handle = urllib2.urlopen(req, data)
handle.close()
- except urllib2.URLError, e:
+ except urllib2.URLError as e:
# HTTP status 404 if the provided email address isn't a Pushover user.
if e.code == 404:
logger.log(u'PUSHOVER: Username is wrong/not a Pushover email. Pushover will send an email to it', logger.WARNING)
diff --git a/sickbeard/notifiers/pytivo.py b/sickbeard/notifiers/pytivo.py
index 733cedee..00f19c11 100644
--- a/sickbeard/notifiers/pytivo.py
+++ b/sickbeard/notifiers/pytivo.py
@@ -91,14 +91,14 @@ class pyTivoNotifier:
try:
response = urlopen(request) #@UnusedVariable
- except HTTPError , e:
+ except HTTPError as e:
if hasattr(e, 'reason'):
logger.log(u"pyTivo notification: Error, failed to reach a server - " + e.reason, logger.ERROR)
return False
elif hasattr(e, 'code'):
logger.log(u"pyTivo notification: Error, the server couldn't fulfill the request - " + e.code, logger.ERROR)
return False
- except Exception, e:
+ except Exception as e:
logger.log(u"PYTIVO: Unknown exception: " + ex(e), logger.ERROR)
return False
else:
diff --git a/sickbeard/notifiers/synoindex.py b/sickbeard/notifiers/synoindex.py
index ac4a73ad..1727eaf6 100644
--- a/sickbeard/notifiers/synoindex.py
+++ b/sickbeard/notifiers/synoindex.py
@@ -58,7 +58,7 @@ class synoIndexNotifier:
cwd=sickbeard.PROG_DIR)
out, err = p.communicate() #@UnusedVariable
logger.log(u"Script result: " + str(out), logger.DEBUG)
- except OSError, e:
+ except OSError as e:
logger.log(u"Unable to run synoindex: " + ex(e), logger.ERROR)
def deleteFolder(self, cur_path):
@@ -83,7 +83,7 @@ class synoIndexNotifier:
cwd=sickbeard.PROG_DIR)
out, err = p.communicate() #@UnusedVariable
logger.log(u"Script result: " + str(out), logger.DEBUG)
- except OSError, e:
+ except OSError as e:
logger.log(u"Unable to run synoindex: " + ex(e), logger.ERROR)
diff --git a/sickbeard/notifiers/synologynotifier.py b/sickbeard/notifiers/synologynotifier.py
index b6889075..b0e2f129 100644
--- a/sickbeard/notifiers/synologynotifier.py
+++ b/sickbeard/notifiers/synologynotifier.py
@@ -56,7 +56,7 @@ class synologyNotifier:
cwd=sickbeard.PROG_DIR)
out, err = p.communicate() #@UnusedVariable
logger.log(u"Script result: " + str(out), logger.DEBUG)
- except OSError, e:
+ except OSError as e:
logger.log(u"Unable to run synodsmnotify: " + ex(e))
diff --git a/sickbeard/notifiers/tweet.py b/sickbeard/notifiers/tweet.py
index b6e11f4b..c67f538e 100644
--- a/sickbeard/notifiers/tweet.py
+++ b/sickbeard/notifiers/tweet.py
@@ -129,7 +129,7 @@ class TwitterNotifier:
try:
api.PostUpdate(message.encode('utf8'))
- except Exception, e:
+ except Exception as e:
logger.log(u"Error Sending Tweet: " + ex(e), logger.ERROR)
return False
diff --git a/sickbeard/notifiers/xbmc.py b/sickbeard/notifiers/xbmc.py
index 4086fb13..d963486d 100644
--- a/sickbeard/notifiers/xbmc.py
+++ b/sickbeard/notifiers/xbmc.py
@@ -247,7 +247,7 @@ class XBMCNotifier:
logger.log(u"XBMC HTTP response: " + result.replace('\n', ''), logger.DEBUG)
return result
- except (urllib2.URLError, IOError), e:
+ except (urllib2.URLError, IOError) as e:
logger.log(u"Warning: Couldn't contact XBMC HTTP at " + fixStupidEncodings(url) + " " + ex(e),
logger.WARNING)
return False
@@ -304,7 +304,7 @@ class XBMCNotifier:
encSqlXML = urllib.quote(sqlXML, ':\\/<>')
try:
et = etree.fromstring(encSqlXML)
- except SyntaxError, e:
+ except SyntaxError as e:
logger.log(u"Unable to parse XML returned from XBMC: " + ex(e), logger.ERROR)
return False
@@ -385,7 +385,7 @@ class XBMCNotifier:
try:
response = urllib2.urlopen(req)
- except urllib2.URLError, e:
+ except urllib2.URLError as e:
logger.log(u"Error while trying to retrieve XBMC API version for " + host + ": " + ex(e),
logger.WARNING)
return False
@@ -396,11 +396,11 @@ class XBMCNotifier:
response.close()
logger.log(u"XBMC JSON response: " + str(result), logger.DEBUG)
return result # need to return response for parsing
- except ValueError, e:
+ except ValueError as e:
logger.log(u"Unable to decode JSON: " + response, logger.WARNING)
return False
- except IOError, e:
+ except IOError as e:
logger.log(u"Warning: Couldn't contact XBMC JSON API at " + fixStupidEncodings(url) + " " + ex(e),
logger.WARNING)
return False
diff --git a/sickbeard/nzbSplitter.py b/sickbeard/nzbSplitter.py
index f9026da5..950a0473 100644
--- a/sickbeard/nzbSplitter.py
+++ b/sickbeard/nzbSplitter.py
@@ -92,7 +92,7 @@ def saveNZB(nzbName, nzbString):
with ek.ek(open, nzbName + ".nzb", 'w') as nzb_fh:
nzb_fh.write(nzbString)
- except EnvironmentError, e:
+ except EnvironmentError as e:
logger.log(u"Unable to save NZB: " + ex(e), logger.ERROR)
diff --git a/sickbeard/nzbget.py b/sickbeard/nzbget.py
index a09cb47c..cf47edef 100644
--- a/sickbeard/nzbget.py
+++ b/sickbeard/nzbget.py
@@ -63,7 +63,7 @@ def sendNZB(nzb, proper=False):
logger.ERROR)
return False
- except xmlrpclib.ProtocolError, e:
+ except xmlrpclib.ProtocolError as e:
if (e.errmsg == "Unauthorized"):
logger.log(u"NZBget username or password is incorrect.", logger.ERROR)
else:
diff --git a/sickbeard/postProcessor.py b/sickbeard/postProcessor.py
index a6ede856..81ff23fc 100644
--- a/sickbeard/postProcessor.py
+++ b/sickbeard/postProcessor.py
@@ -234,7 +234,7 @@ class PostProcessor(object):
ek.ek(send2trash, cur_file)
else:
ek.ek(os.remove, cur_file)
- except OSError, e:
+ except OSError as e:
self._log(u'Unable to delete file %s: %s' % (cur_file, str(e.strerror)), logger.DEBUG)
if True is not ek.ek(os.path.isfile, cur_file):
@@ -329,7 +329,7 @@ class PostProcessor(object):
helpers.moveFile(cur_file_path, new_file_path)
helpers.chmodAsParent(new_file_path)
self._log(u'Moved file from' + (success_tmpl % (cur_file_path, new_file_path)), logger.DEBUG)
- except (IOError, OSError), e:
+ except (IOError, OSError) as e:
self._log(u'Unable to move file %s
.. %s' % (success_tmpl % (cur_file_path, new_file_path), str(e)), logger.ERROR)
raise e
@@ -350,7 +350,7 @@ class PostProcessor(object):
helpers.copyFile(cur_file_path, new_file_path)
helpers.chmodAsParent(new_file_path)
self._log(u'Copied file from' + (success_tmpl % (cur_file_path, new_file_path)), logger.DEBUG)
- except (IOError, OSError), e:
+ except (IOError, OSError) as e:
self._log(u'Unable to copy %s
.. %s' % (success_tmpl % (cur_file_path, new_file_path), str(e)), logger.ERROR)
raise e
@@ -371,7 +371,7 @@ class PostProcessor(object):
helpers.hardlinkFile(cur_file_path, new_file_path)
helpers.chmodAsParent(new_file_path)
self._log(u'Hard linked file from' + (success_tmpl % (cur_file_path, new_file_path)), logger.DEBUG)
- except (IOError, OSError), e:
+ except (IOError, OSError) as e:
self._log(u'Unable to link file %s
.. %s' % (success_tmpl % (cur_file_path, new_file_path), str(e)), logger.ERROR)
raise e
@@ -393,7 +393,7 @@ class PostProcessor(object):
helpers.chmodAsParent(new_file_path)
self._log(u'Moved then symbolic linked file from' + (success_tmpl % (cur_file_path, new_file_path)),
logger.DEBUG)
- except (IOError, OSError), e:
+ except (IOError, OSError) as e:
self._log(u'Unable to link file %s
.. %s' % (success_tmpl % (cur_file_path, new_file_path), str(e)), logger.ERROR)
raise e
@@ -543,7 +543,7 @@ class PostProcessor(object):
try:
(cur_show, cur_season, cur_episodes, cur_quality) = cur_attempt()
- except (InvalidNameException, InvalidShowException), e:
+ except (InvalidNameException, InvalidShowException) as e:
logger.log(u'Unable to parse, skipping: ' + ex(e), logger.DEBUG)
continue
@@ -621,7 +621,7 @@ class PostProcessor(object):
# now that we've figured out which episode this file is just load it manually
try:
cur_ep = show.getEpisode(season, episode)
- except exceptions.EpisodeNotFoundException, e:
+ except exceptions.EpisodeNotFoundException as e:
self._log(u'Unable to create episode: ' + ex(e), logger.DEBUG)
raise exceptions.PostProcessingFailed()
@@ -706,10 +706,10 @@ class PostProcessor(object):
out, err = p.communicate() # @UnusedVariable
self._log(u'Script result: ' + str(out), logger.DEBUG)
- except OSError, e:
+ except OSError as e:
self._log(u'Unable to run extra_script: ' + ex(e))
- except Exception, e:
+ except Exception as e:
self._log(u'Unable to run extra_script: ' + ex(e))
def _safe_replace(self, ep_obj, new_ep_quality):
@@ -1048,5 +1048,5 @@ class PostProcessor(object):
self._log(u'Adding the file to the anidb mylist', logger.DEBUG)
try:
self.anidbEpisode.add_to_mylist(status=1) # status = 1 sets the status of the file to "internal HDD"
- except Exception, e:
+ except Exception as e:
self._log(u'exception msg: ' + str(e))
diff --git a/sickbeard/processTV.py b/sickbeard/processTV.py
index 606ef5e6..5abd23c5 100644
--- a/sickbeard/processTV.py
+++ b/sickbeard/processTV.py
@@ -97,7 +97,7 @@ class ProcessTVShow(object):
# try deleting folder
try:
shutil.rmtree(folder)
- except (OSError, IOError), e:
+ except (OSError, IOError) as e:
logger.log(u'Warning: unable to delete folder: %s: %s' % (folder, ex(e)), logger.WARNING)
return False
@@ -128,14 +128,14 @@ class ProcessTVShow(object):
self._log_helper(u'Changing ReadOnly flag for file ' + cur_file)
try:
ek.ek(os.chmod, cur_file_path, stat.S_IWRITE)
- except OSError, e:
+ except OSError as e:
self._log_helper(u'Cannot change permissions of %s: %s' % (cur_file_path, str(e.strerror)))
try:
if use_trash:
ek.ek(send2trash, cur_file_path)
else:
ek.ek(os.remove, cur_file_path)
- except OSError, e:
+ except OSError as e:
self._log_helper(u'Unable to delete file %s: %s' % (cur_file, str(e.strerror)))
if True is not ek.ek(os.path.isfile, cur_file_path):
@@ -401,7 +401,7 @@ class ProcessTVShow(object):
rar_handle.extract(path=path, withSubpath=False, overwrite=False)
unpacked_files += [os.path.basename(x.filename) for x in rar_handle.infolist() if not x.isdir]
del rar_handle
- except Exception, e:
+ except Exception as e:
self._log_helper(u'Failed to unpack archive %s: %s' % (archive, ex(e)), logger.ERROR)
self._set_process_success(False)
continue
@@ -509,7 +509,7 @@ class ProcessTVShow(object):
processor = postProcessor.PostProcessor(cur_video_file_path, nzb_name, process_method, force_replace, use_trash=use_trash)
file_success = processor.process()
process_fail_message = ''
- except exceptions.PostProcessingFailed, e:
+ except exceptions.PostProcessingFailed as e:
file_success = False
process_fail_message = '
.. ' + ex(e)
@@ -560,7 +560,7 @@ class ProcessTVShow(object):
processor = failedProcessor.FailedProcessor(dir_name, nzb_name)
self._set_process_success(processor.process())
process_fail_message = ''
- except exceptions.FailedProcessingFailed, e:
+ except exceptions.FailedProcessingFailed as e:
self._set_process_success(False)
process_fail_message = ex(e)
diff --git a/sickbeard/properFinder.py b/sickbeard/properFinder.py
index 77504819..9b94a65d 100644
--- a/sickbeard/properFinder.py
+++ b/sickbeard/properFinder.py
@@ -74,10 +74,10 @@ def _getProperList():
try:
curPropers = curProvider.findPropers(search_date)
- except exceptions.AuthException, e:
+ except exceptions.AuthException as e:
logger.log(u'Authentication error: ' + ex(e), logger.ERROR)
continue
- except Exception, e:
+ except Exception as e:
logger.log(u'Error while searching ' + curProvider.name + ', skipping: ' + ex(e), logger.ERROR)
logger.log(traceback.format_exc(), logger.DEBUG)
continue
diff --git a/sickbeard/providers/bitsoup.py b/sickbeard/providers/bitsoup.py
index 7bfa865f..1e3971a5 100644
--- a/sickbeard/providers/bitsoup.py
+++ b/sickbeard/providers/bitsoup.py
@@ -74,7 +74,7 @@ class BitSoupProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
@@ -195,7 +195,7 @@ class BitSoupProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(), logger.ERROR)
#For each search mode sort all the items by seeders
diff --git a/sickbeard/providers/btn.py b/sickbeard/providers/btn.py
index 73361a4e..ab44e7bd 100644
--- a/sickbeard/providers/btn.py
+++ b/sickbeard/providers/btn.py
@@ -123,7 +123,7 @@ class BTNProvider(generic.TorrentProvider):
try:
parsedJSON = server.getTorrents(apikey, params, int(results_per_page), int(offset))
- except jsonrpclib.jsonrpc.ProtocolError, error:
+ except jsonrpclib.jsonrpc.ProtocolError as error:
logger.log(u"JSON-RPC protocol error while accessing " + self.name + ": " + ex(error), logger.ERROR)
parsedJSON = {'api-error': ex(error)}
return parsedJSON
@@ -131,11 +131,11 @@ class BTNProvider(generic.TorrentProvider):
except socket.timeout:
logger.log(u"Timeout while accessing " + self.name, logger.WARNING)
- except socket.error, error:
+ except socket.error as error:
# Note that sometimes timeouts are thrown as socket errors
logger.log(u"Socket error while accessing " + self.name + ": " + error[1], logger.ERROR)
- except Exception, error:
+ except Exception as error:
errorstring = str(error)
if (errorstring.startswith('<') and errorstring.endswith('>')):
errorstring = errorstring[1:-1]
diff --git a/sickbeard/providers/freshontv.py b/sickbeard/providers/freshontv.py
index 505b2ea9..aef74e26 100755
--- a/sickbeard/providers/freshontv.py
+++ b/sickbeard/providers/freshontv.py
@@ -83,7 +83,7 @@ class FreshOnTVProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to %s provider: %s' % (self.name, ex(e)), logger.ERROR)
return False
@@ -232,7 +232,7 @@ class FreshOnTVProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u'Failed parsing %s Traceback: %s' % (self.name, traceback.format_exc()), logger.ERROR)
# For each search mode sort all the items by seeders
diff --git a/sickbeard/providers/hdtorrents.py b/sickbeard/providers/hdtorrents.py
index eeb699f4..e9c19c4b 100644
--- a/sickbeard/providers/hdtorrents.py
+++ b/sickbeard/providers/hdtorrents.py
@@ -86,7 +86,7 @@ class HDTorrentsProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
@@ -255,7 +255,7 @@ class HDTorrentsProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(), logger.ERROR)
#For each search mode sort all the items by seeders
diff --git a/sickbeard/providers/iptorrents.py b/sickbeard/providers/iptorrents.py
index 174ded22..15b1866d 100644
--- a/sickbeard/providers/iptorrents.py
+++ b/sickbeard/providers/iptorrents.py
@@ -70,7 +70,7 @@ class IPTorrentsProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
@@ -198,7 +198,7 @@ class IPTorrentsProvider(generic.TorrentProvider):
logger.log(u"Found result: " + torrent_name + " (" + torrent_details_url + ")", logger.DEBUG)
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(), logger.ERROR)
results += items[mode]
diff --git a/sickbeard/providers/kat.py b/sickbeard/providers/kat.py
index 2bf50127..172a77f6 100644
--- a/sickbeard/providers/kat.py
+++ b/sickbeard/providers/kat.py
@@ -139,7 +139,7 @@ class KATProvider(generic.TorrentProvider):
return title
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(), logger.ERROR)
@@ -267,7 +267,7 @@ class KATProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed to parsing " + self.name + " Traceback: " + traceback.format_exc(),
logger.ERROR)
diff --git a/sickbeard/providers/nextgen.py b/sickbeard/providers/nextgen.py
index 1cdc125c..c700f1e0 100644
--- a/sickbeard/providers/nextgen.py
+++ b/sickbeard/providers/nextgen.py
@@ -230,7 +230,7 @@ class NextGenProvider(generic.TorrentProvider):
logger.WARNING)
continue
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(),
logger.ERROR)
diff --git a/sickbeard/providers/rsstorrent.py b/sickbeard/providers/rsstorrent.py
index 73afb1ff..1bb956ac 100644
--- a/sickbeard/providers/rsstorrent.py
+++ b/sickbeard/providers/rsstorrent.py
@@ -116,13 +116,13 @@ class TorrentRssProvider(generic.TorrentProvider):
torrent_file = self.getURL(url)
try:
bdecode(torrent_file)
- except Exception, e:
+ except Exception as e:
self.dumpHTML(torrent_file)
return (False, 'Torrent link is not a valid torrent file: ' + ex(e))
return (True, 'RSS feed Parsed correctly')
- except Exception, e:
+ except Exception as e:
return (False, 'Error when trying to load RSS: ' + ex(e))
def dumpHTML(self, data):
@@ -134,7 +134,7 @@ class TorrentRssProvider(generic.TorrentProvider):
fileOut.write(data)
fileOut.close()
helpers.chmodAsParent(dumpName)
- except IOError, e:
+ except IOError as e:
logger.log("Unable to save the file: " + ex(e), logger.ERROR)
return False
logger.log(u"Saved custom_torrent html dump " + dumpName + " ", logger.MESSAGE)
diff --git a/sickbeard/providers/scc.py b/sickbeard/providers/scc.py
index e4956c50..c3709472 100644
--- a/sickbeard/providers/scc.py
+++ b/sickbeard/providers/scc.py
@@ -68,7 +68,7 @@ class SCCProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, headers=self.headers, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to %s provider: %s' % (self.name, ex(e)), logger.ERROR)
return False
@@ -210,7 +210,7 @@ class SCCProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u'Failed parsing %s Traceback: %s' % (self.name, traceback.format_exc()), logger.ERROR)
# For each search mode sort all the items by seeders
diff --git a/sickbeard/providers/speedcd.py b/sickbeard/providers/speedcd.py
index 5db305e9..ee443e22 100644
--- a/sickbeard/providers/speedcd.py
+++ b/sickbeard/providers/speedcd.py
@@ -62,7 +62,7 @@ class SpeedCDProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
diff --git a/sickbeard/providers/tokyotoshokan.py b/sickbeard/providers/tokyotoshokan.py
index e25637d6..9a061216 100644
--- a/sickbeard/providers/tokyotoshokan.py
+++ b/sickbeard/providers/tokyotoshokan.py
@@ -101,7 +101,7 @@ class TokyoToshokanProvider(generic.TorrentProvider):
item = title.lstrip(), url
results.append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed to parsing " + self.name + " Traceback: " + traceback.format_exc(), logger.ERROR)
diff --git a/sickbeard/providers/torrentbytes.py b/sickbeard/providers/torrentbytes.py
index 0c246388..7707c412 100644
--- a/sickbeard/providers/torrentbytes.py
+++ b/sickbeard/providers/torrentbytes.py
@@ -65,7 +65,7 @@ class TorrentBytesProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
@@ -190,7 +190,7 @@ class TorrentBytesProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u'Failed parsing ' + self.name + ' Traceback: ' + traceback.format_exc(), logger.ERROR)
# For each search mode sort all the items by seeders
diff --git a/sickbeard/providers/torrentday.py b/sickbeard/providers/torrentday.py
index 5e992e3e..6b08c170 100644
--- a/sickbeard/providers/torrentday.py
+++ b/sickbeard/providers/torrentday.py
@@ -76,7 +76,7 @@ class TorrentDayProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
diff --git a/sickbeard/providers/torrentleech.py b/sickbeard/providers/torrentleech.py
index bbc2a73f..092e5113 100644
--- a/sickbeard/providers/torrentleech.py
+++ b/sickbeard/providers/torrentleech.py
@@ -69,7 +69,7 @@ class TorrentLeechProvider(generic.TorrentProvider):
try:
response = self.session.post(self.urls['login'], data=login_params, timeout=30, verify=False)
- except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError), e:
+ except (requests.exceptions.ConnectionError, requests.exceptions.HTTPError) as e:
logger.log(u'Unable to connect to ' + self.name + ' provider: ' + ex(e), logger.ERROR)
return False
@@ -190,7 +190,7 @@ class TorrentLeechProvider(generic.TorrentProvider):
items[mode].append(item)
- except Exception, e:
+ except Exception as e:
logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(), logger.ERROR)
#For each search mode sort all the items by seeders
diff --git a/sickbeard/sab.py b/sickbeard/sab.py
index ee05242b..6e00d559 100644
--- a/sickbeard/sab.py
+++ b/sickbeard/sab.py
@@ -99,11 +99,11 @@ def sendNZB(nzb):
f = opener.open(req)
- except (EOFError, IOError), e:
+ except (EOFError, IOError) as e:
logger.log(u"Unable to connect to SABnzbd: " + ex(e), logger.ERROR)
return False
- except httplib.InvalidURL, e:
+ except httplib.InvalidURL as e:
logger.log(u"Invalid SABnzbd host, check your config: " + ex(e), logger.ERROR)
return False
@@ -115,7 +115,7 @@ def sendNZB(nzb):
# if we opened the URL connection then read the result from SAB
try:
result = f.readlines()
- except Exception, e:
+ except Exception as e:
logger.log(u"Error trying to get result from SABnzbd, NZB not sent: " + ex(e), logger.ERROR)
return False
@@ -144,7 +144,7 @@ def sendNZB(nzb):
def _checkSabResponse(f):
try:
result = f.readlines()
- except Exception, e:
+ except Exception as e:
logger.log(u"Error trying to get result from SABnzbd" + ex(e), logger.ERROR)
return False, "Error from SABnzbd"
@@ -156,7 +156,7 @@ def _checkSabResponse(f):
sabJson = {}
try:
sabJson = json.loads(sabText)
- except ValueError, e:
+ except ValueError as e:
pass
if sabText == "Missing authentication":
@@ -172,10 +172,10 @@ def _checkSabResponse(f):
def _sabURLOpenSimple(url):
try:
f = urllib.urlopen(url)
- except (EOFError, IOError), e:
+ except (EOFError, IOError) as e:
logger.log(u"Unable to connect to SABnzbd: " + ex(e), logger.ERROR)
return False, "Unable to connect"
- except httplib.InvalidURL, e:
+ except httplib.InvalidURL as e:
logger.log(u"Invalid SABnzbd host, check your config: " + ex(e), logger.ERROR)
return False, "Invalid SABnzbd host"
if f is None:
diff --git a/sickbeard/scene_numbering.py b/sickbeard/scene_numbering.py
index 9bcdaf49..4ee45dd5 100644
--- a/sickbeard/scene_numbering.py
+++ b/sickbeard/scene_numbering.py
@@ -526,7 +526,7 @@ def xem_refresh(indexer_id, indexer, force=False):
else:
logger.log(u"Empty lookup result - no XEM data for show %s on %s" % (
indexer_id, sickbeard.indexerApi(indexer).name,), logger.DEBUG)
- except Exception, e:
+ except Exception as e:
logger.log(
u"Exception while refreshing XEM data for show " + str(indexer_id) + " on " + sickbeard.indexerApi(
indexer).name + ": " + ex(e), logger.WARNING)
diff --git a/sickbeard/scheduler.py b/sickbeard/scheduler.py
index 8c33a55f..e2713ff3 100644
--- a/sickbeard/scheduler.py
+++ b/sickbeard/scheduler.py
@@ -88,7 +88,7 @@ class Scheduler(threading.Thread):
logger.log(u"Starting new thread: " + self.name, logger.DEBUG)
self.action.run()
- except Exception, e:
+ except Exception as e:
logger.log(u"Exception generated in thread " + self.name + ": " + ex(e), logger.ERROR)
logger.log(repr(traceback.format_exc()), logger.DEBUG)
diff --git a/sickbeard/search.py b/sickbeard/search.py
index 654a49d0..2743b1bd 100644
--- a/sickbeard/search.py
+++ b/sickbeard/search.py
@@ -78,7 +78,7 @@ def _downloadResult(result):
helpers.chmodAsParent(fileName)
- except EnvironmentError, e:
+ except EnvironmentError as e:
logger.log(u"Error trying to save NZB to black hole: " + ex(e), logger.ERROR)
newResult = False
elif resProvider.providerType == "torrent":
@@ -483,10 +483,10 @@ def searchProviders(show, episodes, manualSearch=False):
try:
curProvider.cache._clearCache()
searchResults = curProvider.findSearchResults(show, episodes, search_mode, manualSearch)
- except exceptions.AuthException, e:
+ except exceptions.AuthException as e:
logger.log(u"Authentication error: " + ex(e), logger.ERROR)
break
- except Exception, e:
+ except Exception as e:
logger.log(u"Error while searching " + curProvider.name + ", skipping: " + ex(e), logger.ERROR)
logger.log(traceback.format_exc(), logger.DEBUG)
break
diff --git a/sickbeard/showUpdater.py b/sickbeard/showUpdater.py
index 88867524..b42e2101 100644
--- a/sickbeard/showUpdater.py
+++ b/sickbeard/showUpdater.py
@@ -94,7 +94,7 @@ class ShowUpdater():
piList.append(curQueueItem)
- except (exceptions.CantUpdateException, exceptions.CantRefreshException), e:
+ except (exceptions.CantUpdateException, exceptions.CantRefreshException) as e:
logger.log(u'Automatic update failed: ' + ex(e), logger.ERROR)
ui.ProgressIndicators.setIndicator('dailyUpdate', ui.QueueProgressIndicator('Daily Update', piList))
diff --git a/sickbeard/show_queue.py b/sickbeard/show_queue.py
index c1226b64..5784cdd5 100644
--- a/sickbeard/show_queue.py
+++ b/sickbeard/show_queue.py
@@ -308,7 +308,7 @@ class QueueItemAdd(ShowQueueItem):
self.indexer).name) + ' but contains no season/episode data.')
self._finishEarly()
return
- except Exception, e:
+ except Exception as e:
logger.log(u'Unable to find show ID:' + str(self.indexer_id) + ' on Indexer: ' + str(
sickbeard.indexerApi(self.indexer).name), logger.ERROR)
ui.notifications.error('Unable to add show',
@@ -349,7 +349,7 @@ class QueueItemAdd(ShowQueueItem):
if self.show.classification and 'sports' in self.show.classification.lower():
self.show.sports = 1
- except sickbeard.indexer_exception, e:
+ except sickbeard.indexer_exception as e:
logger.log(
u'Unable to add show due to an error with ' + sickbeard.indexerApi(self.indexer).name + ': ' + ex(e),
logger.ERROR)
@@ -369,7 +369,7 @@ class QueueItemAdd(ShowQueueItem):
self._finishEarly()
return
- except Exception, e:
+ except Exception as e:
logger.log(u'Error trying to add show: ' + ex(e), logger.ERROR)
logger.log(traceback.format_exc(), logger.DEBUG)
self._finishEarly()
@@ -379,7 +379,7 @@ class QueueItemAdd(ShowQueueItem):
try:
self.show.saveToDB()
- except Exception, e:
+ except Exception as e:
logger.log(u'Error saving the show to the database: ' + ex(e), logger.ERROR)
logger.log(traceback.format_exc(), logger.DEBUG)
self._finishEarly()
@@ -390,7 +390,7 @@ class QueueItemAdd(ShowQueueItem):
try:
self.show.loadEpisodesFromIndexer()
- except Exception, e:
+ except Exception as e:
logger.log(
u'Error with ' + sickbeard.indexerApi(self.show.indexer).name + ', not creating episode list: ' + ex(e),
logger.ERROR)
@@ -398,7 +398,7 @@ class QueueItemAdd(ShowQueueItem):
try:
self.show.loadEpisodesFromDir()
- except Exception, e:
+ except Exception as e:
logger.log(u'Error searching directory for episodes: ' + ex(e), logger.ERROR)
logger.log(traceback.format_exc(), logger.DEBUG)
@@ -587,11 +587,11 @@ class QueueItemUpdate(ShowQueueItem):
result = self.show.loadFromIndexer(cache=not self.force)
if None is not result:
return
- except sickbeard.indexer_error, e:
+ except sickbeard.indexer_error as e:
logger.log(u'Unable to contact ' + sickbeard.indexerApi(self.show.indexer).name + ', aborting: ' + ex(e),
logger.WARNING)
return
- except sickbeard.indexer_attributenotfound, e:
+ except sickbeard.indexer_attributenotfound as e:
logger.log(u'Data retrieved from ' + sickbeard.indexerApi(
self.show.indexer).name + ' was incomplete, aborting: ' + ex(e), logger.ERROR)
return
@@ -601,7 +601,7 @@ class QueueItemUpdate(ShowQueueItem):
try:
self.show.saveToDB()
- except Exception, e:
+ except Exception as e:
logger.log(u'Error saving the episode to the database: ' + ex(e), logger.ERROR)
logger.log(traceback.format_exc(), logger.DEBUG)
@@ -613,7 +613,7 @@ class QueueItemUpdate(ShowQueueItem):
logger.log(u'Loading all episodes from ' + sickbeard.indexerApi(self.show.indexer).name + '', logger.DEBUG)
try:
IndexerEpList = self.show.loadEpisodesFromIndexer(cache=not self.force)
- except sickbeard.indexer_exception, e:
+ except sickbeard.indexer_exception as e:
logger.log(u'Unable to get info from ' + sickbeard.indexerApi(
self.show.indexer).name + ', the show info will not be refreshed: ' + ex(e), logger.ERROR)
IndexerEpList = None
diff --git a/sickbeard/tv.py b/sickbeard/tv.py
index 1e8628f6..a3138797 100644
--- a/sickbeard/tv.py
+++ b/sickbeard/tv.py
@@ -412,7 +412,7 @@ class TVShow(object):
logger.log(str(self.indexerid) + u": Creating episode from " + mediaFile, logger.DEBUG)
try:
curEpisode = self.makeEpFromFile(ek.ek(os.path.join, self._location, mediaFile))
- except (exceptions.ShowNotFoundException, exceptions.EpisodeNotFoundException), e:
+ except (exceptions.ShowNotFoundException, exceptions.EpisodeNotFoundException) as e:
logger.log(u"Episode " + mediaFile + " returned an exception: " + ex(e), logger.ERROR)
continue
except exceptions.EpisodeDeletedException:
@@ -493,7 +493,7 @@ class TVShow(object):
if curSeason not in cachedSeasons:
try:
cachedSeasons[curSeason] = cachedShow[curSeason]
- except sickbeard.indexer_seasonnotfound, e:
+ except sickbeard.indexer_seasonnotfound as e:
logger.log(u"Error when trying to load the episode from " + sickbeard.indexerApi(
self.indexer).name + ": " + e.message, logger.WARNING)
deleteEp = True
@@ -921,9 +921,9 @@ class TVShow(object):
logger.log(u'Retrieving show info from IMDb', logger.DEBUG)
try:
self._get_imdb_info()
- except imdb_exceptions.IMDbError, e:
+ except imdb_exceptions.IMDbError as e:
logger.log(u'Something is wrong with IMDb api: ' + ex(e), logger.WARNING)
- except Exception, e:
+ except Exception as e:
logger.log(u'Error loading IMDb info: ' + ex(e), logger.ERROR)
logger.log(u'' + traceback.format_exc(), logger.DEBUG)
@@ -1051,7 +1051,7 @@ class TVShow(object):
else:
os.remove(cache_file)
- except OSError, e:
+ except OSError as e:
logger.log(u'Unable to %s %s: %s / %s' % (action, cache_file, repr(e), str(e)), logger.WARNING)
# remove entire show folder
@@ -1079,7 +1079,7 @@ class TVShow(object):
except exceptions.ShowDirNotFoundException:
logger.log(u"Show folder does not exist, no need to %s %s" % (action, self._location), logger.WARNING)
- except OSError, e:
+ except OSError as e:
logger.log(u'Unable to %s %s: %s / %s' % (action, self._location, repr(e), str(e)), logger.WARNING)
def populateCache(self):
@@ -1681,7 +1681,7 @@ class TVEpisode(object):
else:
myEp = cachedSeason[episode]
- except (sickbeard.indexer_error, IOError), e:
+ except (sickbeard.indexer_error, IOError) as e:
logger.log(u"" + sickbeard.indexerApi(self.indexer).name + " threw up an error: " + ex(e), logger.DEBUG)
# if the episode is already valid just log it, if not throw it up
if self.name:
@@ -1846,12 +1846,12 @@ class TVEpisode(object):
if ek.ek(os.path.isfile, nfoFile):
try:
showXML = etree.ElementTree(file=nfoFile)
- except (SyntaxError, ValueError), e:
+ except (SyntaxError, ValueError) as e:
logger.log(u"Error loading the NFO, backing up the NFO and skipping for now: " + ex(e),
logger.ERROR) # TODO: figure out what's wrong and fix it
try:
ek.ek(os.rename, nfoFile, nfoFile + ".old")
- except Exception, e:
+ except Exception as e:
logger.log(
u"Failed to rename your episode's NFO file - you need to delete it or fix it: " + ex(e),
logger.ERROR)
@@ -2175,7 +2175,7 @@ class TVEpisode(object):
try:
np = NameParser(name, showObj=show, naming_pattern=True)
parse_result = np.parse(name)
- except (InvalidNameException, InvalidShowException), e:
+ except (InvalidNameException, InvalidShowException) as e:
logger.log(u"Unable to get parse release_group: " + ex(e), logger.DEBUG)
return ''
diff --git a/sickbeard/tvcache.py b/sickbeard/tvcache.py
index 25083d87..f8fa3389 100644
--- a/sickbeard/tvcache.py
+++ b/sickbeard/tvcache.py
@@ -42,7 +42,7 @@ class CacheDBConnection(db.DBConnection):
try:
if not self.hasTable('lastUpdate'):
self.action('CREATE TABLE lastUpdate (provider TEXT, time NUMERIC)')
- except Exception, e:
+ except Exception as e:
if str(e) != 'table lastUpdate already exists':
raise
diff --git a/sickbeard/versionChecker.py b/sickbeard/versionChecker.py
index 98a46eb5..98e21f34 100644
--- a/sickbeard/versionChecker.py
+++ b/sickbeard/versionChecker.py
@@ -379,7 +379,7 @@ class GitUpdateManager(UpdateManager):
else:
try:
self._check_github_for_update()
- except Exception, e:
+ except Exception as e:
logger.log(u"Unable to contact github, can't check for update: " + repr(e), logger.ERROR)
return False
@@ -464,7 +464,7 @@ class SourceUpdateManager(UpdateManager):
# need this to run first to set self._newest_commit_hash
try:
self._check_github_for_update()
- except Exception, e:
+ except Exception as e:
logger.log(u"Unable to contact github, can't check for update: " + repr(e), logger.ERROR)
return False
@@ -611,7 +611,7 @@ class SourceUpdateManager(UpdateManager):
os.chmod(new_path, stat.S_IWRITE)
os.remove(new_path)
os.renames(old_path, new_path)
- except Exception, e:
+ except Exception as e:
logger.log(u"Unable to update " + new_path + ': ' + ex(e), logger.DEBUG)
os.remove(old_path) # Trash the updated file without moving in new path
continue
@@ -623,7 +623,7 @@ class SourceUpdateManager(UpdateManager):
sickbeard.CUR_COMMIT_HASH = self._newest_commit_hash
sickbeard.CUR_COMMIT_BRANCH = self.branch
- except Exception, e:
+ except Exception as e:
logger.log(u"Error while trying to update: " + ex(e), logger.ERROR)
logger.log(u"Traceback: " + traceback.format_exc(), logger.DEBUG)
return False
diff --git a/sickbeard/webapi.py b/sickbeard/webapi.py
index 63ba6183..3733a45f 100644
--- a/sickbeard/webapi.py
+++ b/sickbeard/webapi.py
@@ -119,7 +119,7 @@ class Api(webserve.BaseHandler):
else: # if debug was not set we wrap the "call_dispatcher" in a try block to assure a json output
try:
outDict = _call_dispatcher(self, args, kwargs)
- except Exception, e: # real internal error oohhh nooo :(
+ except Exception as e: # real internal error oohhh nooo :(
logger.log(u"API :: " + ex(e), logger.ERROR)
errorData = {"error_msg": ex(e),
"args": args,
@@ -140,7 +140,7 @@ class Api(webserve.BaseHandler):
if 'jsonp' in self.request.query_arguments:
out = self.request.arguments['jsonp'] + '(' + out + ');' # wrap with JSONP call if requested
- except Exception, e: # if we fail to generate the output fake an error
+ except Exception as e: # if we fail to generate the output fake an error
logger.log(u'API :: ' + traceback.format_exc(), logger.DEBUG)
out = '{"result":"' + result_type_map[RESULT_ERROR] + '", "message": "error while composing output: "' + ex(
e) + '"}'
@@ -205,7 +205,7 @@ def call_dispatcher(handler, args, kwargs):
curOutDict = TVDBShorthandWrapper(handler, curArgs, curKwargs, cmd).run()
else:
curOutDict = _responds(RESULT_ERROR, "No such cmd: '" + cmd + "'")
- except ApiError, e: # Api errors that we raised, they are harmless
+ except ApiError as e: # Api errors that we raised, they are harmless
curOutDict = _responds(RESULT_ERROR, msg=ex(e))
else: # if someone chained one of the forbiden cmds they will get an error for this one cmd
curOutDict = _responds(RESULT_ERROR, msg="The cmd '" + cmd + "' is not supported while chaining")
@@ -1609,7 +1609,7 @@ class CMD_SickBeardSearchIndexers(ApiCall):
try:
apiData = t[str(self.name).encode()]
- except Exception, e:
+ except Exception as e:
pass
if not apiData:
@@ -2537,7 +2537,7 @@ class CMD_ShowUpdate(ApiCall):
try:
sickbeard.showQueueScheduler.action.updateShow(showObj, True) #@UndefinedVariable
return _responds(RESULT_SUCCESS, msg=str(showObj.name) + " has queued to be updated")
- except exceptions.CantUpdateException, e:
+ except exceptions.CantUpdateException as e:
logger.log(u"API:: Unable to update " + str(showObj.name) + ". " + str(ex(e)), logger.ERROR)
return _responds(RESULT_FAILURE, msg="Unable to update " + str(showObj.name))
diff --git a/sickbeard/webserve.py b/sickbeard/webserve.py
index f16ef14e..b1094446 100644
--- a/sickbeard/webserve.py
+++ b/sickbeard/webserve.py
@@ -1262,7 +1262,7 @@ class Home(MainHandler):
try:
anime = adba.Anime(sickbeard.ADBA_CONNECTION, name=showObj.name)
t.groups = anime.get_groups()
- except Exception, e:
+ except Exception as e:
t.groups.append(dict([('name', 'Fail:AniDB connect. Restart sg else check debug log'), ('rating', ''), ('range', '')]))
else:
t.groups.append(dict([('name', 'Did not initialise AniDB. Check debug log if reqd.'), ('rating', ''), ('range', '')]))
@@ -1344,7 +1344,7 @@ class Home(MainHandler):
showObj.flatten_folders = flatten_folders
try:
sickbeard.showQueueScheduler.action.refreshShow(showObj) # @UndefinedVariable
- except exceptions.CantRefreshException, e:
+ except exceptions.CantRefreshException as e:
errors.append('Unable to refresh this show: ' + ex(e))
showObj.paused = paused
@@ -1374,7 +1374,7 @@ class Home(MainHandler):
showObj.location = location
try:
sickbeard.showQueueScheduler.action.refreshShow(showObj) # @UndefinedVariable
- except exceptions.CantRefreshException, e:
+ except exceptions.CantRefreshException as e:
errors.append('Unable to refresh this show:' + ex(e))
# grab updated info from TVDB
# showObj.loadEpisodesFromIndexer()
@@ -1391,7 +1391,7 @@ class Home(MainHandler):
try:
sickbeard.showQueueScheduler.action.updateShow(showObj, True) # @UndefinedVariable
time.sleep(cpu_presets[sickbeard.CPU_PRESET])
- except exceptions.CantUpdateException, e:
+ except exceptions.CantUpdateException as e:
errors.append('Unable to force an update on the show.')
if do_update_exceptions:
@@ -1399,14 +1399,14 @@ class Home(MainHandler):
scene_exceptions.update_scene_exceptions(showObj.indexerid, exceptions_list) # @UndefinedVdexerid)
buildNameCache(showObj)
time.sleep(cpu_presets[sickbeard.CPU_PRESET])
- except exceptions.CantUpdateException, e:
+ except exceptions.CantUpdateException as e:
errors.append('Unable to force an update on scene exceptions of the show.')
if do_update_scene_numbering:
try:
sickbeard.scene_numbering.xem_refresh(showObj.indexerid, showObj.indexer) # @UndefinedVariable
time.sleep(cpu_presets[sickbeard.CPU_PRESET])
- except exceptions.CantUpdateException, e:
+ except exceptions.CantUpdateException as e:
errors.append('Unable to force an update on scene numbering of the show.')
if directCall:
@@ -1456,7 +1456,7 @@ class Home(MainHandler):
# force the update from the DB
try:
sickbeard.showQueueScheduler.action.refreshShow(showObj) # @UndefinedVariable
- except exceptions.CantRefreshException, e:
+ except exceptions.CantRefreshException as e:
ui.notifications.error('Unable to refresh this show.',
ex(e))
@@ -1477,7 +1477,7 @@ class Home(MainHandler):
# force the update
try:
sickbeard.showQueueScheduler.action.updateShow(showObj, bool(force), bool(web))
- except exceptions.CantUpdateException, e:
+ except exceptions.CantUpdateException as e:
ui.notifications.error('Unable to update this show.',
ex(e))
@@ -1985,7 +1985,7 @@ class Home(MainHandler):
try:
anime = adba.Anime(sickbeard.ADBA_CONNECTION, name=show_name)
groups = anime.get_groups()
- except Exception, e:
+ except Exception as e:
logger.log(u'exception msg: ' + str(e), logger.DEBUG)
return json.dumps({'result': 'fail', 'resp': 'connect'})
@@ -2062,7 +2062,7 @@ class NewHomeAddShows(Home):
try:
# add search results
results.setdefault(indexer, []).extend(t[search_term])
- except Exception, e:
+ except Exception as e:
continue
map(final_results.extend,
@@ -3117,7 +3117,7 @@ class Manage(MainHandler):
try:
sickbeard.showQueueScheduler.action.updateShow(showObj, True, True) # @UndefinedVariable
updates.append(showObj.name)
- except exceptions.CantUpdateException, e:
+ except exceptions.CantUpdateException as e:
errors.append('Unable to update show ' + showObj.name + ': ' + ex(e))
# don't bother refreshing shows that were updated anyway
@@ -3125,7 +3125,7 @@ class Manage(MainHandler):
try:
sickbeard.showQueueScheduler.action.refreshShow(showObj) # @UndefinedVariable
refreshes.append(showObj.name)
- except exceptions.CantRefreshException, e:
+ except exceptions.CantRefreshException as e:
errors.append('Unable to refresh show ' + showObj.name + ': ' + ex(e))
if curShowID in toRename:
@@ -3612,7 +3612,7 @@ class ConfigGeneral(Config):
try:
pulls = sickbeard.versionCheckScheduler.action.list_remote_pulls()
return json.dumps({'result': 'success', 'pulls': pulls})
- except Exception, e:
+ except Exception as e:
logger.log(u'exception msg: ' + str(e), logger.DEBUG)
return json.dumps({'result': 'fail'})
@@ -3621,7 +3621,7 @@ class ConfigGeneral(Config):
try:
branches = sickbeard.versionCheckScheduler.action.list_remote_branches()
return json.dumps({'result': 'success', 'branches': branches})
- except Exception, e:
+ except Exception as e:
logger.log(u'exception msg: ' + str(e), logger.DEBUG)
return json.dumps({'result': 'fail'})
@@ -3905,7 +3905,7 @@ class ConfigPostProcessing(Config):
return 'supported'
logger.log(u'Rar Not Supported: Can not read the content of test file', logger.ERROR)
return 'not supported'
- except Exception, e:
+ except Exception as e:
logger.log(u'Rar Not Supported: ' + ex(e), logger.ERROR)
return 'not supported'
diff --git a/tests/compatibility_tests.py b/tests/compatibility_tests.py
new file mode 100644
index 00000000..14918905
--- /dev/null
+++ b/tests/compatibility_tests.py
@@ -0,0 +1,28 @@
+import unittest
+
+import subprocess
+import os
+
+class CompatibilityTests(unittest.TestCase):
+
+ def test_except(self):
+ path = os.path.abspath('..')
+ pyfiles = []
+ for rootdir in ['sickbeard', 'tests']:
+ for dirpath, subdirs, files in os.walk(os.path.join(path, rootdir)):
+ for x in files:
+ if x.endswith('.py'):
+ pyfiles.append(os.path.join(dirpath, x))
+
+ pyfiles.append(os.path.join(path,'SickBeard.py'))
+
+ output = subprocess.Popen('2to3 -f except %s' % ' '.join(pyfiles), shell=True, stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE).communicate()[0]
+ if output:
+ print('Changes to be made for Python 2/3 compatibility as follows:')
+ print(output)
+ self.fail('Python 2/3 incompatibility detected')
+
+if __name__ == '__main__':
+ suite = unittest.TestLoader().loadTestsFromTestCase(QualityTests)
+ unittest.TextTestRunner(verbosity=2).run(suite)
\ No newline at end of file
diff --git a/tests/test_lib.py b/tests/test_lib.py
index 85990756..8aca7bb7 100644
--- a/tests/test_lib.py
+++ b/tests/test_lib.py
@@ -149,7 +149,7 @@ class TestCacheDBConnection(TestDBConnection, object):
sql = "CREATE TABLE " + providerName + " (name TEXT, season NUMERIC, episodes TEXT, indexerid NUMERIC, url TEXT, time NUMERIC, quality TEXT);"
self.connection.execute(sql)
self.connection.commit()
- except sqlite3.OperationalError, e:
+ except sqlite3.OperationalError as e:
if str(e) != "table " + providerName + " already exists":
raise
@@ -158,7 +158,7 @@ class TestCacheDBConnection(TestDBConnection, object):
sql = "CREATE TABLE lastUpdate (provider TEXT, time NUMERIC);"
self.connection.execute(sql)
self.connection.commit()
- except sqlite3.OperationalError, e:
+ except sqlite3.OperationalError as e:
if str(e) != "table lastUpdate already exists":
raise
diff --git a/tests/xem_tests.py b/tests/xem_tests.py
index 98602e05..c6fbccbf 100644
--- a/tests/xem_tests.py
+++ b/tests/xem_tests.py
@@ -61,7 +61,7 @@ class XEMBasicTests(test.SickbeardTestDBCase):
try:
curShow = TVShow(int(sqlShow["indexer"]), int(sqlShow["indexer_id"]))
sickbeard.showList.append(curShow)
- except Exception, e:
+ except Exception as e:
print "There was an error creating the show"
def test_formating(self):