mbed official / mbed-sdk-tools
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