mirror of
https://github.com/SickGear/SickGear.git
synced 2024-12-21 02:03:38 +00:00
32987134ba
Cleanup most init warnings. Cleanup some vars, pythonic instead of js. Some typos and python var/func names for Scheduler. Remove legacy handlers deprecated in 2020. Remove some legacy tagged stuff. Cleanup ConfigParser and 23.py Change cleanup vendored scandir. Remove redundant pkg_resources.py in favour of the vendor folder. Remove backports. Remove trakt checker. Change remove redundant WindowsSelectorEventLoopPolicy from webserveInit. Cleanup varnames and providers Various minor tidy ups to remove ide warnings.
167 lines
5.7 KiB
Python
167 lines
5.7 KiB
Python
# coding=utf-8
|
|
#
|
|
# This file is part of SickGear.
|
|
#
|
|
# SickGear is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# SickGear is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with SickGear. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
from base64 import encodebytes as b64encodebytes
|
|
from collections import deque
|
|
# noinspection PyUnresolvedReferences
|
|
from configparser import ConfigParser
|
|
# noinspection PyUnresolvedReferences
|
|
from enum import Enum
|
|
from itertools import islice, zip_longest
|
|
# noinspection PyUnresolvedReferences
|
|
from inspect import getfullargspec as getargspec
|
|
# noinspection PyUnresolvedReferences
|
|
from os import scandir, DirEntry
|
|
# noinspection PyUnresolvedReferences
|
|
from subprocess import Popen
|
|
from sys import version_info
|
|
|
|
import datetime
|
|
# noinspection PyUnresolvedReferences, PyPep8Naming
|
|
import xml.etree.ElementTree as etree
|
|
|
|
# noinspection PyUnresolvedReferences
|
|
from six.moves.urllib.parse import quote, quote_plus, unquote as six_unquote, unquote_plus as six_unquote_plus, \
|
|
urlencode, urlsplit, urlunparse, urlunsplit
|
|
|
|
# noinspection PyUnreachableCode
|
|
if False:
|
|
# ----------------------
|
|
# resolve typing imports
|
|
# ----------------------
|
|
# noinspection PyUnresolvedReferences
|
|
from typing import Any, AnyStr, Callable, Dict, Iterable, Iterator, List, Optional, Tuple, Union
|
|
# -------------------
|
|
# resolve pyc imports
|
|
# -------------------
|
|
# noinspection PyTypeChecker
|
|
quote = quote_plus = None # type: Callable
|
|
# noinspection PyTypeChecker
|
|
urlencode = urlsplit = urlunparse = urlunsplit = None # type: Callable
|
|
|
|
|
|
def map_consume(*args):
|
|
# type: (...) -> None
|
|
"""Run a lambda over elements without returning anything"""
|
|
deque(map(*args), maxlen=0)
|
|
|
|
|
|
def consume(iterator, n=None):
|
|
# type: (Iterator, Optional[int]) -> None
|
|
"""Advance the iterator n-steps ahead. If n is None, consume entirely. Returns nothing.
|
|
|
|
Useful if a method returns an Iterator that is not used, but still all should be called,
|
|
for example if each iter element calls a function that should be called for all or
|
|
given amount of elements in Iterator
|
|
|
|
examples:
|
|
consume(filter_iter(...)) # consumes all elements of given function that returns an Iterator
|
|
consume(filter_iter(...), 3) # consumes next 3 elements of given function that returns an Iterator
|
|
"""
|
|
# Use functions that consume iterators at C speed.
|
|
if n is None:
|
|
# feed the entire iterator into a zero-length deque
|
|
deque(iterator, maxlen=0)
|
|
else:
|
|
# advance to the empty slice starting at position n
|
|
next(islice(iterator, n, n), None)
|
|
|
|
|
|
def decode_str(s, encoding='utf-8', errors=None):
|
|
# type: (...) -> AnyStr
|
|
if isinstance(s, bytes):
|
|
if None is errors:
|
|
return s.decode(encoding)
|
|
return s.decode(encoding, errors)
|
|
return s
|
|
|
|
|
|
def html_unescape(s):
|
|
# type: (AnyStr) -> AnyStr
|
|
"""helper to remove special character quoting"""
|
|
if (3, 4) > version_info:
|
|
# noinspection PyUnresolvedReferences
|
|
from six.moves.html_parser import HTMLParser
|
|
# noinspection PyDeprecation
|
|
return HTMLParser().unescape(s)
|
|
|
|
# noinspection PyCompatibility,PyUnresolvedReferences
|
|
from html import unescape
|
|
return unescape(s)
|
|
|
|
|
|
def list_range(*args, **kwargs):
|
|
# type: (...) -> List
|
|
return list(range(*args, **kwargs))
|
|
|
|
|
|
def urlparse(url, scheme='', allow_fragments=True):
|
|
"""return ParseResult where netloc is populated from path if required, no need to test .netloc anymore"""
|
|
# noinspection PyUnresolvedReferences
|
|
from six.moves.urllib.parse import urlparse as _urlparse, ParseResult
|
|
parsed_url = _urlparse(url, scheme, allow_fragments)
|
|
if '' != parsed_url.netloc:
|
|
return parsed_url
|
|
# fix occasional cases where '' == netloc and its data is in parsed_result.path
|
|
# noinspection PyArgumentList
|
|
fix = ParseResult(scheme=parsed_url.scheme, netloc=parsed_url.path, path=url,
|
|
params=parsed_url.params, query=parsed_url.query, fragment=parsed_url.fragment)
|
|
return fix
|
|
|
|
|
|
def make_btih(s):
|
|
from base64 import b16encode, b32decode
|
|
return decode_str(b16encode(b32decode(s)))
|
|
|
|
|
|
def b64decodestring(s):
|
|
# type: (Union[bytes, AnyStr]) -> AnyStr
|
|
from base64 import b64decode
|
|
return decode_str(b64decode(s))
|
|
|
|
|
|
def b64encodestring(s, keep_eol=False):
|
|
# type: (AnyStr, Union[bool]) -> AnyStr
|
|
data = decode_str(b64encodebytes(decode_bytes(s)))
|
|
if keep_eol:
|
|
return data
|
|
return data.rstrip()
|
|
|
|
|
|
native_timestamp = datetime.datetime.timestamp # type: Callable[[datetime.datetime], float]
|
|
|
|
|
|
def unquote(string, encoding='utf-8', errors='replace'):
|
|
return decode_str(six_unquote(decode_str(string, encoding, errors), encoding=encoding, errors=errors),
|
|
encoding, errors)
|
|
|
|
|
|
def unquote_plus(string, encoding='utf-8', errors='replace'):
|
|
return decode_str(six_unquote_plus(decode_str(string, encoding, errors), encoding=encoding, errors=errors),
|
|
encoding, errors)
|
|
|
|
|
|
def decode_bytes(d, encoding='utf-8', errors='replace'):
|
|
if not isinstance(d, bytes):
|
|
# noinspection PyArgumentList
|
|
return bytes(d, encoding=encoding, errors=errors)
|
|
return d
|
|
|
|
|
|
def map_none(*args):
|
|
# type: (...) -> List
|
|
return list(zip_longest(*args))
|