mirror of https://github.com/ARMmbed/mbed-os.git
173 lines
4.7 KiB
Python
173 lines
4.7 KiB
Python
"""
|
|
mbed SDK
|
|
Copyright (c) 2011-2013 ARM Limited
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
"""
|
|
import sys
|
|
import inspect
|
|
import os
|
|
from os import listdir, remove, makedirs
|
|
from shutil import copyfile
|
|
from os.path import isdir, join, exists, split, relpath, splitext
|
|
from subprocess import Popen, PIPE, STDOUT, call
|
|
|
|
|
|
def cmd(l, check=True, verbose=False, shell=False, cwd=None):
|
|
text = l if shell else ' '.join(l)
|
|
if verbose:
|
|
print text
|
|
rc = call(l, shell=shell, cwd=cwd)
|
|
if check and rc != 0:
|
|
raise Exception('ERROR %d: "%s"' % (rc, text))
|
|
|
|
|
|
def run_cmd(command, wd=None, redirect=False):
|
|
assert is_cmd_valid(command[0])
|
|
p = Popen(command, stdout=PIPE, stderr=STDOUT if redirect else PIPE, cwd=wd)
|
|
_stdout, _stderr = p.communicate()
|
|
return _stdout, _stderr, p.returncode
|
|
|
|
|
|
def run_cmd_ext(command):
|
|
assert is_cmd_valid(command[0])
|
|
p = Popen(command, stdout=PIPE, stderr=PIPE)
|
|
_stdout, _stderr = p.communicate()
|
|
return _stdout, _stderr, p.returncode
|
|
|
|
|
|
def is_cmd_valid(cmd):
|
|
caller = get_caller_name()
|
|
abspath = find_cmd_abspath(cmd)
|
|
if not abspath:
|
|
error("%s: Command '%s' can't be found" % (caller, cmd))
|
|
if not is_exec(abspath):
|
|
error("%s: Command '%s' resolves to file '%s' which is not executable" % (caller, cmd, abspath))
|
|
return True
|
|
|
|
|
|
def is_exec(path):
|
|
return os.access(path, os.X_OK) or os.access(path+'.exe', os.X_OK)
|
|
|
|
|
|
def find_cmd_abspath(cmd):
|
|
""" Returns the absolute path to a command.
|
|
None is returned if no absolute path was found.
|
|
"""
|
|
if exists(cmd) or exists(cmd + '.exe'):
|
|
return os.path.abspath(cmd)
|
|
if not 'PATH' in os.environ:
|
|
raise Exception("Can't find command path for current platform ('%s')" % sys.platform)
|
|
PATH=os.environ['PATH']
|
|
for path in PATH.split(os.pathsep):
|
|
abspath = '%s/%s' % (path, cmd)
|
|
if exists(abspath) or exists(abspath + '.exe'):
|
|
return abspath
|
|
|
|
|
|
def mkdir(path):
|
|
if not exists(path):
|
|
makedirs(path)
|
|
|
|
|
|
def copy_file(src, dst):
|
|
""" Implement the behaviour of "shutil.copy(src, dst)" without copying the
|
|
permissions (this was causing errors with directories mounted with samba)
|
|
"""
|
|
if isdir(dst):
|
|
_, file = split(src)
|
|
dst = join(dst, file)
|
|
copyfile(src, dst)
|
|
|
|
|
|
def delete_dir_files(dir):
|
|
if not exists(dir):
|
|
return
|
|
|
|
for f in listdir(dir):
|
|
file = join(dir, f)
|
|
if not isdir(file):
|
|
remove(file)
|
|
|
|
|
|
def get_caller_name(steps=2):
|
|
"""
|
|
When called inside a function, it returns the name
|
|
of the caller of that function.
|
|
"""
|
|
return inspect.stack()[steps][3]
|
|
|
|
|
|
def error(msg):
|
|
print("ERROR: %s" % msg)
|
|
sys.exit(1)
|
|
|
|
|
|
def rel_path(path, base, dot=False):
|
|
p = relpath(path, base)
|
|
if dot and not p.startswith('.'):
|
|
p = './' + p
|
|
return p
|
|
|
|
|
|
class ToolException(Exception):
|
|
pass
|
|
|
|
class NotSupportedException(Exception):
|
|
pass
|
|
|
|
def split_path(path):
|
|
base, file = split(path)
|
|
name, ext = splitext(file)
|
|
return base, name, ext
|
|
|
|
|
|
def args_error(parser, message):
|
|
print "\n\n%s\n\n" % message
|
|
parser.print_help()
|
|
sys.exit()
|
|
|
|
|
|
def construct_enum(**enums):
|
|
""" Create your own pseudo-enums """
|
|
return type('Enum', (), enums)
|
|
|
|
|
|
def check_required_modules(required_modules, verbose=True):
|
|
""" Function checks for Python modules which should be "importable" (installed)
|
|
before test suite can be used.
|
|
@return returns True if all modules are installed already
|
|
"""
|
|
import imp
|
|
not_installed_modules = []
|
|
for module_name in required_modules:
|
|
try:
|
|
imp.find_module(module_name)
|
|
except ImportError as e:
|
|
# We also test against a rare case: module is an egg file
|
|
try:
|
|
__import__(module_name)
|
|
except ImportError as e:
|
|
not_installed_modules.append(module_name)
|
|
if verbose:
|
|
print "Error: %s" % e
|
|
|
|
if verbose:
|
|
if not_installed_modules:
|
|
print "Warning: Module(s) %s not installed. Please install required module(s) before using this script."% (', '.join(not_installed_modules))
|
|
|
|
if not_installed_modules:
|
|
return False
|
|
else:
|
|
return True
|