Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Diff: build_api.py
- Revision:
- 13:ab47a20b66f0
- Parent:
- 9:2d27d77ada5c
- Child:
- 14:ee1b877e6839
--- a/build_api.py Tue Jun 14 11:33:06 2016 +0100
+++ b/build_api.py Thu Jul 14 20:21:19 2016 +0100
@@ -88,7 +88,7 @@
config = Config(target, src_paths)
# If the 'target' argument is a string, convert it to a target instance
- if isinstance(target, str):
+ if isinstance(target, basestring):
try:
target = TARGET_MAP[target]
except KeyError:
@@ -105,8 +105,27 @@
for path in src_paths[1:]:
resources.add(toolchain.scan_resources(path))
- config.add_config_files(resources.json_files)
- return config.get_config_data()
+ # Update configuration files until added features creates no changes
+ prev_features = set()
+ while True:
+ # Update the configuration with any .json files found while scanning
+ config.add_config_files(resources.json_files)
+
+ # Add features while we find new ones
+ features = config.get_features()
+ if features == prev_features:
+ break
+
+ for feature in features:
+ if feature in resources.features:
+ resources += resources.features[feature]
+
+ prev_features = features
+ config.validate_config()
+
+ cfg, macros = config.get_config_data()
+ features = config.get_features()
+ return cfg, macros, features
def build_project(src_path, build_path, target, toolchain_name,
libraries_paths=None, options=None, linker_script=None,
@@ -126,14 +145,11 @@
abs_path = abspath(first_src_path)
project_name = basename(normpath(abs_path))
- for path in src_paths:
- profile = get_build_profile(path)
-
# If the configuration object was not yet created, create it now
config = config or Config(target, src_paths)
# If the 'target' argument is a string, convert it to a target instance
- if isinstance(target, str):
+ if isinstance(target, basestring):
try:
target = TARGET_MAP[target]
except KeyError:
@@ -141,7 +157,7 @@
# Toolchain instance
try:
- toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, notify, macros, silent, extra_verbose=extra_verbose, profile=profile)
+ toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, notify, macros, silent, extra_verbose=extra_verbose)
except KeyError as e:
raise KeyError("Toolchain %s not supported" % toolchain_name)
@@ -198,16 +214,15 @@
else:
resources.inc_dirs.append(inc_dirs)
- # Update the configuration with any .json files found while scanning
- config.add_config_files(resources.json_files)
- # And add the configuration macros to the toolchain
- toolchain.add_macros(config.get_config_data_macros())
+ # Load resources into the config system which might expand/modify resources based on config data
+ resources = config.load_resources(resources)
+
+ # Set the toolchain's configuration data
+ toolchain.set_config_data(config.get_config_data())
# Compile Sources
- for path in src_paths:
- src = toolchain.scan_resources(path)
- objects = toolchain.compile_sources(src, build_path, resources.inc_dirs)
- resources.objects.extend(objects)
+ objects = toolchain.compile_sources(resources, build_path, resources.inc_dirs)
+ resources.objects.extend(objects)
# Link Program
res, _ = toolchain.link_program(resources, build_path, name)
@@ -240,7 +255,7 @@
add_result_to_report(report, cur_result)
# Let Exception propagate
- raise e
+ raise
def build_library(src_paths, build_path, target, toolchain_name,
dependencies_paths=None, options=None, name=None, clean=False, archive=True,
@@ -267,6 +282,16 @@
# We will use default project name based on project folder name
name = project_name
+ # If the configuration object was not yet created, create it now
+ config = Config(target, src_paths)
+
+ # If the 'target' argument is a string, convert it to a target instance
+ if isinstance(target, basestring):
+ try:
+ target = TARGET_MAP[target]
+ except KeyError:
+ raise KeyError("Target '%s' not found" % target)
+
if report != None:
start = time()
@@ -292,12 +317,9 @@
raise Exception(error_msg)
- for path in src_paths:
- profile = get_build_profile(path)
-
try:
# Toolchain instance
- toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, macros=macros, notify=notify, silent=silent, extra_verbose=extra_verbose, profile=profile)
+ toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, macros=macros, notify=notify, silent=silent, extra_verbose=extra_verbose)
toolchain.VERBOSE = verbose
toolchain.jobs = jobs
toolchain.build_all = clean
@@ -309,13 +331,6 @@
for path in src_paths:
# Scan resources
resource = toolchain.scan_resources(path)
-
- # Copy headers, objects and static libraries - all files needed for static lib
- toolchain.copy_files(resource.headers, build_path, rel_path=resource.base_path)
- toolchain.copy_files(resource.objects, build_path, rel_path=resource.base_path)
- toolchain.copy_files(resource.libraries, build_path, rel_path=resource.base_path)
- if resource.linker_script:
- toolchain.copy_files(resource.linker_script, build_path, rel_path=resource.base_path)
# Extend resources collection
if not resources:
@@ -350,18 +365,25 @@
else:
tmp_path = build_path
- # Handle configuration
- config = Config(target)
- # Update the configuration with any .json files found while scanning
- config.add_config_files(resources.json_files)
- # And add the configuration macros to the toolchain
- toolchain.add_macros(config.get_config_data_macros())
+ # Load resources into the config system which might expand/modify resources based on config data
+ resources = config.load_resources(resources)
+
+ # Set the toolchain's configuration data
+ toolchain.set_config_data(config.get_config_data())
+
+ # Copy headers, objects and static libraries - all files needed for static lib
+ toolchain.copy_files(resources.headers, build_path, resources=resources)
+ toolchain.copy_files(resources.objects, build_path, resources=resources)
+ toolchain.copy_files(resources.libraries, build_path, resources=resources)
+ if resources.linker_script:
+ toolchain.copy_files(resources.linker_script, build_path, resources=resources)
+
+ if resource.hex_files:
+ toolchain.copy_files(resources.hex_files, build_path, resources=resources)
# Compile Sources
- for path in src_paths:
- src = toolchain.scan_resources(path)
- objects = toolchain.compile_sources(src, abspath(tmp_path), resources.inc_dirs)
- resources.objects.extend(objects)
+ objects = toolchain.compile_sources(resources, abspath(tmp_path), resources.inc_dirs)
+ resources.objects.extend(objects)
if archive:
toolchain.build_library(objects, build_path, name)
@@ -462,7 +484,7 @@
try:
# Toolchain instance
- toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, macros=macros, notify=notify, silent=silent, extra_verbose=extra_verbose, profile=profile)
+ toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, macros=macros, notify=notify, silent=silent, extra_verbose=extra_verbose)
toolchain.VERBOSE = verbose
toolchain.jobs = jobs
toolchain.build_all = clean
@@ -499,7 +521,8 @@
# Copy Headers
for resource in resources:
- toolchain.copy_files(resource.headers, build_path, rel_path=resource.base_path)
+ toolchain.copy_files(resource.headers, build_path, resources=resource)
+
dependencies_include_dir.extend(toolchain.scan_resources(build_path).inc_dirs)
# Compile Sources
@@ -527,8 +550,6 @@
if toolchain_output:
cur_result["output"] += toolchain_output
- cur_result["output"] += str(e)
-
add_result_to_report(report, cur_result)
# Let Exception propagate
@@ -562,9 +583,6 @@
return False
- for path in src_paths:
- profile = get_build_profile(path)
-
try:
# Toolchain
toolchain = TOOLCHAIN_CLASSES[toolchain_name](target, options, macros=macros, notify=notify, silent=silent, extra_verbose=extra_verbose)
@@ -602,7 +620,7 @@
# Target specific sources
HAL_SRC = join(MBED_TARGETS_PATH, "hal")
hal_implementation = toolchain.scan_resources(HAL_SRC)
- toolchain.copy_files(hal_implementation.headers + hal_implementation.hex_files + hal_implementation.libraries, BUILD_TARGET, HAL_SRC)
+ toolchain.copy_files(hal_implementation.headers + hal_implementation.hex_files + hal_implementation.libraries, BUILD_TARGET, resources=hal_implementation)
incdirs = toolchain.scan_resources(BUILD_TARGET).inc_dirs
objects = toolchain.compile_sources(hal_implementation, TMP_PATH, [MBED_LIBRARIES] + incdirs)
@@ -780,7 +798,7 @@
hal_implementation = toolchain.scan_resources(HAL_SRC)
# Copy files before analysis
- toolchain.copy_files(hal_implementation.headers + hal_implementation.hex_files, BUILD_TARGET, HAL_SRC)
+ toolchain.copy_files(hal_implementation.headers + hal_implementation.hex_files, BUILD_TARGET, resources=hal_implementation)
incdirs = toolchain.scan_resources(BUILD_TARGET)
target_includes = ["-I%s" % i for i in incdirs.inc_dirs]
@@ -884,7 +902,7 @@
# Copy Headers
for resource in resources:
- toolchain.copy_files(resource.headers, build_path, rel_path=resource.base_path)
+ toolchain.copy_files(resource.headers, build_path, resources=resource)
includes += ["-I%s" % i for i in resource.inc_dirs]
c_sources += " ".join(resource.c_sources) + " "
cpp_sources += " ".join(resource.cpp_sources) + " "
@@ -1000,152 +1018,3 @@
paths.append(root)
return paths
-
-def get_build_profile(path):
- profile = None
- builds = get_build_ids(path)
- for build in builds:
- if MBED_SDK_REV_MAP.has_key(build):
- idx = MBED_SDK_REV_MAP[build]
-
- if idx is None:
- profile = 'v5'
- elif idx <= 43:
- profile = 'v1'
- elif idx <= 68:
- profile = 'v2'
- elif idx <= 76:
- profile = 'v3'
- elif idx <= 105:
- profile = 'v4'
- else:
- profile = 'v5'
-
- return profile
-
-def get_build_ids(path):
- builds = []
-
- for (root, dirs, files) in walk(path):
- for d in copy(dirs):
- if d.startswith('.'):
- dirs.remove(d)
-
- for filename in filter(lambda s: s.endswith(".bld"), files):
- try:
- # TODO check user has permission to link against build
- url = open(join(root, filename), 'r').read()
- builds.append(re.sub(r'^.+/(.*?)$', r'\1', url))
- except:
- pass
-
- return builds
-
-MBED_SDK_REV_MAP = {
- '8ed44a420e5c': 105,
- 'b9ad9a133dc7': 104,
- 'bad568076d81': 103,
- 'da0ca467f8b5': 102,
- '7cff1c4259d7': 101,
- 'cbbeb26dbd92': 100,
- 'dbbf35b96557': 99,
- '8ab26030e058': 98,
- '433970e64889': 97,
- '487b796308b0': 96,
- '7e07b6fb45cf': 95,
- '9ad691361fac': 94,
- 'e188a91d3eaa': 93,
- '4fc01daae5a5': 92,
- '031413cf7a89': 91,
- 'cb3d968589d8': 90,
- '552587b429a1': 89,
- '9327015d4013': 88,
- '6213f644d804': 87,
- '04dd9b1680ae': 86,
- '024bf7f99721': 85,
- '0b3ab51c8877': 84,
- '8a40adfe8776': 83,
- '6473597d706e': 82,
- '7d30d6019079': 81,
- '8e73be2a2ac1': 80,
- '0c05e21ae27e': 79,
- 'ed8466a608b4': 78,
- '869cf507173a': 77,
- '824293ae5e43': 76,
- 'dc225afb6914': 75,
- 'a842253909c9': 74,
- '1efda918f0ba': 73,
- '4096f863f923': 72,
- '8fabd470bb6e': 71,
- '673126e12c73': 70,
- '4a7918f48478': 69,
- 'f37f3b9c9f0b': 68,
- 'a9913a65894f': 67,
- '9c8f0e3462fb': 66,
- '5798e58a58b1': 65,
- 'e3affc9e7238': 64,
- 'b3110cd2dd17': 63,
- '7e6c9f46b3bd': 62,
- '5e5da4a5990b': 61,
- '3d0ef94e36ec': 60,
- '0883845fe643': 59,
- '0954ebd79f59': 58,
- '0480438fc29c': 57,
- '3753e96f3c8b': 56,
- 'd722ed6a4237': 55,
- '71b101360fb9': 54,
- '63cdd78b2dc1': 53,
- '09236a68d21b': 52,
- 'a076018f59af': 51,
- 'b60934f96c0c': 50,
- 'eeb8a2a33ec9': 49,
- '49c296715c73': 48,
- '134def52cfa0': 47,
- '890817bdcffb': 46,
- '3d775a932e1d': 45,
- '24d45a770a51': 44,
- 'e2ed12d17f06': 43,
- 'cd19af002ccc': 42,
- '10b9abbe79a6': 41,
- '976df7c37ad5': 40,
- '737756e0b479': 39,
- '4c0c40fd0593': 38,
- '14f4805c468c': 37,
- 'b4b9f287a47e': 36,
- '5284544d04b6': 35,
- '7495d544864f': 34,
- '5364839841bd': 33,
- '3b05dd009342': 32,
- 'a7ef757f598c': 31,
- '3991a86798e3': 30,
- '078e4b97a13e': 29,
- '667d61c9177b': 28,
- '7110ebee3484': 27,
- '63bcd7ba4912': 26,
- '9a9732ce53a1': 25,
- 'e2ac27c8e93e': 24,
- '74b8d43b5817': 23,
- '9114680c05da': 22,
- '3944f1e2fa4f': 21,
- '029aa53d7323': 20,
- 'e6be4cd80aad': 19,
- 'b3c9f16cbb96': 18,
- '49a220cc26e0': 17,
- '32af5db564d4': 16,
- 'd1a9de3f4fe0': 15,
- '20a79241b4a0': 14,
- 'a0336ede94ce': 13,
- 'f63353af7be8': 12,
- '1c1ebd0324fa': 11,
- 'fcb9359f0959': 10,
- 'cf0d45ce28a6': 9,
- '00a04e5cd407': 8,
- '15d74db76485': 7,
- '3fd6a337c7cc': 6,
- '62573be585e9': 5,
- '5d1359a283bc': 4,
- 'aefd12a1f1c5': 3,
- '969fc1867111': 2,
- '6b7f447ca868': 1,
- '82220227f4fa': 0,
-}
\ No newline at end of file
