mpy-cross/mpy_cross: Fix default path to mpy-cross binary.

Needed to be updated to use build/mpy-cross.

Also fixes some other issues in the Python wrapper:
 - Rename find_mpy_cross_binary to _find_mpy_cross_binary
 - Fix passing of -march arg.
 - Decode stdout from subprocess.
 - Print stdout from mpy-cross in __main__.py.

Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
This commit is contained in:
Jim Mussared 2022-09-28 01:04:05 +10:00
parent bdbc44474f
commit 71050870b8
2 changed files with 8 additions and 6 deletions

View File

@ -62,9 +62,11 @@ class CrossCompileError(Exception):
def find_mpy_cross_binary(mpy_cross): def find_mpy_cross_binary(mpy_cross):
def _find_mpy_cross_binary(mpy_cross):
if mpy_cross: if mpy_cross:
return mpy_cross return mpy_cross
return os.path.abspath(os.path.join(os.path.dirname(__file__), "../mpy-cross")) return os.path.abspath(os.path.join(os.path.dirname(__file__), "../build/mpy-cross"))
def compile(src, dest=None, src_path=None, opt=None, march=None, mpy_cross=None, extra_args=None): def compile(src, dest=None, src_path=None, opt=None, march=None, mpy_cross=None, extra_args=None):
@ -82,7 +84,7 @@ def compile(src, dest=None, src_path=None, opt=None, march=None, mpy_cross=None,
args += ["-o", dest] args += ["-o", dest]
if march: if march:
args += ["-march", march] args += ["-march=" + march]
if opt is not None: if opt is not None:
args += ["-O{}".format(opt)] args += ["-O{}".format(opt)]
@ -96,7 +98,7 @@ def compile(src, dest=None, src_path=None, opt=None, march=None, mpy_cross=None,
def run(args, mpy_cross=None): def run(args, mpy_cross=None):
mpy_cross = find_mpy_cross_binary(mpy_cross) mpy_cross = _find_mpy_cross_binary(mpy_cross)
if not os.path.exists(mpy_cross): if not os.path.exists(mpy_cross):
raise CrossCompileError("mpy-cross binary not found at {}.".format(mpy_cross)) raise CrossCompileError("mpy-cross binary not found at {}.".format(mpy_cross))
@ -108,6 +110,6 @@ def run(args, mpy_cross=None):
pass pass
try: try:
subprocess.check_output([mpy_cross] + args, stderr=subprocess.STDOUT) return subprocess.check_output([mpy_cross] + args, stderr=subprocess.STDOUT).decode()
except subprocess.CalledProcessError as er: except subprocess.CalledProcessError as er:
raise CrossCompileError(er.output) raise CrossCompileError(er.output.decode())

View File

@ -32,7 +32,7 @@ import sys
from . import run, CrossCompileError from . import run, CrossCompileError
try: try:
run(sys.argv[1:]) print(run(sys.argv[1:]))
except CrossCompileError as er: except CrossCompileError as er:
print(er.args[0], file=sys.stderr) print(er.args[0], file=sys.stderr)
raise SystemExit(1) raise SystemExit(1)