2017-04-15 10:07:02 +00:00
|
|
|
# coding: utf8
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import sys
|
2017-04-15 11:05:15 +00:00
|
|
|
import ujson
|
2017-07-25 16:57:59 +00:00
|
|
|
import itertools
|
2017-10-12 20:22:04 +00:00
|
|
|
import locale
|
2017-04-15 10:07:02 +00:00
|
|
|
|
2017-05-31 13:25:21 +00:00
|
|
|
from thinc.neural.util import copy_array
|
2017-05-31 12:14:29 +00:00
|
|
|
|
2017-04-15 10:07:02 +00:00
|
|
|
try:
|
|
|
|
import cPickle as pickle
|
|
|
|
except ImportError:
|
|
|
|
import pickle
|
|
|
|
|
|
|
|
try:
|
|
|
|
import copy_reg
|
|
|
|
except ImportError:
|
|
|
|
import copyreg as copy_reg
|
|
|
|
|
2017-05-18 12:12:45 +00:00
|
|
|
try:
|
|
|
|
from cupy.cuda.stream import Stream as CudaStream
|
|
|
|
except ImportError:
|
|
|
|
CudaStream = None
|
|
|
|
|
|
|
|
try:
|
|
|
|
import cupy
|
|
|
|
except ImportError:
|
|
|
|
cupy = None
|
|
|
|
|
2017-10-27 10:23:49 +00:00
|
|
|
try:
|
2017-10-27 12:33:42 +00:00
|
|
|
from thinc.neural.optimizers import Optimizer
|
2017-10-27 10:23:49 +00:00
|
|
|
except ImportError:
|
2017-10-27 12:33:42 +00:00
|
|
|
from thinc.neural.optimizers import Adam as Optimizer
|
2017-05-18 12:12:45 +00:00
|
|
|
|
2018-03-28 10:45:53 +00:00
|
|
|
try:
|
|
|
|
import urllib
|
|
|
|
except ImportError:
|
|
|
|
import urllib2 as urllib
|
|
|
|
|
|
|
|
try:
|
2018-03-28 22:08:16 +00:00
|
|
|
from urllib.error import HTTPError
|
2018-03-28 10:45:53 +00:00
|
|
|
except ImportError:
|
2018-03-28 22:08:16 +00:00
|
|
|
from urllib2 import HTTPError
|
2018-03-28 10:45:53 +00:00
|
|
|
|
2017-05-18 12:12:31 +00:00
|
|
|
pickle = pickle
|
|
|
|
copy_reg = copy_reg
|
|
|
|
CudaStream = CudaStream
|
|
|
|
cupy = cupy
|
2017-05-31 13:25:21 +00:00
|
|
|
copy_array = copy_array
|
2018-03-28 10:45:53 +00:00
|
|
|
urllib = urllib
|
2017-07-25 16:57:59 +00:00
|
|
|
izip = getattr(itertools, 'izip', zip)
|
2017-04-15 10:07:02 +00:00
|
|
|
|
|
|
|
is_windows = sys.platform.startswith('win')
|
|
|
|
is_linux = sys.platform.startswith('linux')
|
|
|
|
is_osx = sys.platform == 'darwin'
|
|
|
|
|
2018-02-18 12:29:56 +00:00
|
|
|
# See: https://github.com/benjaminp/six/blob/master/six.py
|
|
|
|
is_python2 = sys.version_info[0] == 2
|
|
|
|
is_python3 = sys.version_info[0] == 3
|
|
|
|
is_python_pre_3_5 = is_python2 or (is_python3 and sys.version_info[1] < 5)
|
2017-04-15 10:07:02 +00:00
|
|
|
|
|
|
|
if is_python2:
|
|
|
|
bytes_ = str
|
2017-11-20 13:03:42 +00:00
|
|
|
unicode_ = unicode # noqa: F821
|
|
|
|
basestring_ = basestring # noqa: F821
|
|
|
|
input_ = raw_input # noqa: F821
|
2017-08-19 20:32:16 +00:00
|
|
|
json_dumps = lambda data: ujson.dumps(data, indent=2, escape_forward_slashes=False).decode('utf8')
|
2017-05-07 21:24:56 +00:00
|
|
|
path2str = lambda path: str(path).decode('utf8')
|
2018-03-28 22:08:16 +00:00
|
|
|
url_open = urllib.urlopen
|
2017-04-15 10:07:02 +00:00
|
|
|
|
|
|
|
elif is_python3:
|
|
|
|
bytes_ = bytes
|
|
|
|
unicode_ = str
|
|
|
|
basestring_ = str
|
|
|
|
input_ = input
|
2017-08-19 20:32:16 +00:00
|
|
|
json_dumps = lambda data: ujson.dumps(data, indent=2, escape_forward_slashes=False)
|
2017-05-07 21:24:56 +00:00
|
|
|
path2str = lambda path: str(path)
|
2018-03-28 22:08:16 +00:00
|
|
|
url_open = urllib.request.urlopen
|
|
|
|
|
|
|
|
|
|
|
|
def url_read(url):
|
|
|
|
file_ = url_open(url)
|
|
|
|
code = file_.getcode()
|
|
|
|
if code != 200:
|
|
|
|
raise HTTPError(url, code, "Cannot GET url", [], file_)
|
|
|
|
data = file_.read()
|
|
|
|
return data
|
2017-04-15 10:07:02 +00:00
|
|
|
|
2017-07-31 23:11:35 +00:00
|
|
|
|
|
|
|
def b_to_str(b_str):
|
|
|
|
if is_python2:
|
|
|
|
return b_str
|
|
|
|
# important: if no encoding is set, string becomes "b'...'"
|
|
|
|
return str(b_str, encoding='utf8')
|
|
|
|
|
|
|
|
|
2017-05-31 20:21:44 +00:00
|
|
|
def getattr_(obj, name, *default):
|
|
|
|
if is_python3 and isinstance(name, bytes):
|
|
|
|
name = name.decode('utf8')
|
|
|
|
return getattr(obj, name, *default)
|
|
|
|
|
2017-04-15 10:07:02 +00:00
|
|
|
|
|
|
|
def symlink_to(orig, dest):
|
2017-04-15 10:17:27 +00:00
|
|
|
if is_python2 and is_windows:
|
2017-04-15 10:07:02 +00:00
|
|
|
import subprocess
|
2017-05-07 21:24:56 +00:00
|
|
|
subprocess.call(['mklink', '/d', path2str(orig), path2str(dest)], shell=True)
|
2017-04-15 10:17:27 +00:00
|
|
|
else:
|
|
|
|
orig.symlink_to(dest)
|
2017-04-15 10:07:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
def is_config(python2=None, python3=None, windows=None, linux=None, osx=None):
|
2017-10-27 12:39:09 +00:00
|
|
|
return ((python2 is None or python2 == is_python2) and
|
|
|
|
(python3 is None or python3 == is_python3) and
|
|
|
|
(windows is None or windows == is_windows) and
|
|
|
|
(linux is None or linux == is_linux) and
|
|
|
|
(osx is None or osx == is_osx))
|
2017-05-31 12:14:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
def normalize_string_keys(old):
|
2017-10-27 12:39:09 +00:00
|
|
|
"""Given a dictionary, make sure keys are unicode strings, not bytes."""
|
2017-05-31 12:14:29 +00:00
|
|
|
new = {}
|
2017-05-31 19:08:16 +00:00
|
|
|
for key, value in old.items():
|
2017-05-31 12:14:29 +00:00
|
|
|
if isinstance(key, bytes_):
|
|
|
|
new[key.decode('utf8')] = value
|
|
|
|
else:
|
|
|
|
new[key] = value
|
|
|
|
return new
|
|
|
|
|
|
|
|
|
2017-08-18 19:56:47 +00:00
|
|
|
def import_file(name, loc):
|
|
|
|
loc = str(loc)
|
2018-02-09 15:03:35 +00:00
|
|
|
if is_python_pre_3_5:
|
|
|
|
import imp
|
2017-08-18 19:56:47 +00:00
|
|
|
return imp.load_source(name, loc)
|
|
|
|
else:
|
2018-02-09 15:03:35 +00:00
|
|
|
import importlib.util
|
2017-08-19 20:32:07 +00:00
|
|
|
spec = importlib.util.spec_from_file_location(name, str(loc))
|
2017-08-18 19:56:47 +00:00
|
|
|
module = importlib.util.module_from_spec(spec)
|
|
|
|
spec.loader.exec_module(module)
|
|
|
|
return module
|
2017-10-12 20:22:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
def locale_escape(string, errors='replace'):
|
|
|
|
'''
|
|
|
|
Mangle non-supported characters, for savages with ascii terminals.
|
|
|
|
'''
|
|
|
|
encoding = locale.getpreferredencoding()
|
|
|
|
string = string.encode(encoding, errors).decode('utf8')
|
|
|
|
return string
|