Merge pull request #1793 from refi64/py2-cleanup
Pre-Python 3.4 cleanup (including Python 2)
This commit is contained in:
commit
5b20fa9dfb
@ -11,5 +11,5 @@ import sys
|
|||||||
|
|
||||||
if len(sys.argv) > 1:
|
if len(sys.argv) > 1:
|
||||||
sys.argv.pop(0)
|
sys.argv.pop(0)
|
||||||
imp.load_source("__main__", sys.argv[0])
|
hy.importer._import_from_path('__main__', sys.argv[0])
|
||||||
sys.exit(0) # right?
|
sys.exit(0) # right?
|
||||||
|
@ -157,3 +157,11 @@ runpy = importlib.import_module('runpy')
|
|||||||
|
|
||||||
_runpy_get_code_from_file = runpy._get_code_from_file
|
_runpy_get_code_from_file = runpy._get_code_from_file
|
||||||
runpy._get_code_from_file = _get_code_from_file
|
runpy._get_code_from_file = _get_code_from_file
|
||||||
|
|
||||||
|
|
||||||
|
def _import_from_path(name, path):
|
||||||
|
"""A helper function that imports a module from the given path."""
|
||||||
|
spec = importlib.util.spec_from_file_location(name, path)
|
||||||
|
mod = importlib.util.module_from_spec(spec)
|
||||||
|
spec.loader.exec_module(mod)
|
||||||
|
return mod
|
||||||
|
8
setup.py
8
setup.py
@ -39,8 +39,6 @@ install_requires = [
|
|||||||
if os.name == 'nt':
|
if os.name == 'nt':
|
||||||
install_requires.append('pyreadline>=2.1')
|
install_requires.append('pyreadline>=2.1')
|
||||||
|
|
||||||
ver = sys.version_info[0]
|
|
||||||
|
|
||||||
setup(
|
setup(
|
||||||
name=PKG,
|
name=PKG,
|
||||||
version=__version__,
|
version=__version__,
|
||||||
@ -49,11 +47,11 @@ setup(
|
|||||||
entry_points={
|
entry_points={
|
||||||
'console_scripts': [
|
'console_scripts': [
|
||||||
'hy = hy.cmdline:hy_main',
|
'hy = hy.cmdline:hy_main',
|
||||||
'hy%d = hy.cmdline:hy_main' % ver,
|
'hy3 = hy.cmdline:hy_main',
|
||||||
'hyc = hy.cmdline:hyc_main',
|
'hyc = hy.cmdline:hyc_main',
|
||||||
'hyc%d = hy.cmdline:hyc_main' % ver,
|
'hyc3 = hy.cmdline:hyc_main',
|
||||||
'hy2py = hy.cmdline:hy2py_main',
|
'hy2py = hy.cmdline:hy2py_main',
|
||||||
'hy2py%d = hy.cmdline:hy2py_main' % ver,
|
'hy2py3 = hy.cmdline:hy2py_main',
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
packages=find_packages(exclude=['tests*']),
|
packages=find_packages(exclude=['tests*']),
|
||||||
|
@ -3,10 +3,11 @@
|
|||||||
# license. See the LICENSE.
|
# license. See the LICENSE.
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import imp
|
import importlib.util
|
||||||
|
import py_compile
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
import py_compile
|
import hy.importer
|
||||||
|
|
||||||
|
|
||||||
def test_pyc():
|
def test_pyc():
|
||||||
@ -16,10 +17,11 @@ def test_pyc():
|
|||||||
f.flush()
|
f.flush()
|
||||||
|
|
||||||
cfile = py_compile.compile(f.name)
|
cfile = py_compile.compile(f.name)
|
||||||
|
|
||||||
assert os.path.exists(cfile)
|
assert os.path.exists(cfile)
|
||||||
|
|
||||||
mod = imp.load_compiled('pyc', cfile)
|
try:
|
||||||
|
mod = hy.importer._import_from_path('pyc', cfile)
|
||||||
|
finally:
|
||||||
os.remove(cfile)
|
os.remove(cfile)
|
||||||
|
|
||||||
assert mod.pyctest('Foo') == 'XFooY'
|
assert mod.pyctest('Foo') == 'XFooY'
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
import math, itertools
|
import math, itertools
|
||||||
from hy import mangle
|
from hy import mangle
|
||||||
from hy._compat import PY36
|
from hy._compat import PY36
|
||||||
|
import hy.importer
|
||||||
|
|
||||||
|
|
||||||
def test_direct_import():
|
def test_direct_import():
|
||||||
@ -19,7 +20,8 @@ def test_hy2py_import(tmpdir):
|
|||||||
["hy2py", "tests/resources/pydemo.hy"]).decode("UTF-8")
|
["hy2py", "tests/resources/pydemo.hy"]).decode("UTF-8")
|
||||||
path = tmpdir.join("pydemo.py")
|
path = tmpdir.join("pydemo.py")
|
||||||
path.write(python_code)
|
path.write(python_code)
|
||||||
assert_stuff(import_from_path("pydemo", path))
|
# Note: explicit "str" is needed for 3.5.
|
||||||
|
assert_stuff(hy.importer._import_from_path("pydemo", str(path)))
|
||||||
|
|
||||||
|
|
||||||
def assert_stuff(m):
|
def assert_stuff(m):
|
||||||
@ -116,15 +118,3 @@ def assert_stuff(m):
|
|||||||
assert (m.C2.attr1, m.C2.attr2) == (5, 6)
|
assert (m.C2.attr1, m.C2.attr2) == (5, 6)
|
||||||
|
|
||||||
assert m.closed == ["v2", "v1"]
|
assert m.closed == ["v2", "v1"]
|
||||||
|
|
||||||
|
|
||||||
def import_from_path(name, path):
|
|
||||||
if PY36:
|
|
||||||
import importlib.util
|
|
||||||
spec = importlib.util.spec_from_file_location(name, path)
|
|
||||||
m = importlib.util.module_from_spec(spec)
|
|
||||||
spec.loader.exec_module(m)
|
|
||||||
else:
|
|
||||||
import imp
|
|
||||||
m = imp.load_source(name, str(path))
|
|
||||||
return m
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user