initial hard-coded cmake build system for mbed.a

pull/1213/head
James Crosby 2015-06-19 12:20:06 +01:00
parent bb7d4bd4db
commit 8c8cbb65b0
2 changed files with 111 additions and 0 deletions

View File

@ -0,0 +1,84 @@
#!!! TODO stuff in this pre-amble will be defined by the target description,
#hard-coding for now...
set(MBED_LEGACY_TARGET_DEFINITIONS "NORDIC" "NRF51822_MKIT" "MCU_NRF51822" "MCU_NORDIC_16K")
set(MBED_LEGACY_TOOLCHAIN "GCC_ARM")
add_definitions("-DNRF51")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99")
# mbed-2 yotta-compatible build system:
# the mbed.a library is built from two sets of source files + include
# directories:
#
# MBED_COMMON_SOURCES: the source files that are the same for all targets,
# these are easily found by globbing:
#
file(GLOB MBED_COMMON_SOURCES "common/*.cpp" "common/*.c")
#
# (always include the hal header directory, too)
set(MBED_COMMON_INCLUDE_DIRS "hal")
# and MBED_TARGET_SOURCES: these depend on which target we are building for. To
# find these we need to walk the directories in targets/, and wherever we see a
# TARGET_<something> name, recurse only if <something> matches what we're
# currently building for
macro(mbed_find_target_dirs PARENT_DIRECTORY SOURCES_LIST INCLUDES_LIST)
# append this directory to the search path:
list(APPEND ${INCLUDES_LIST} "${PARENT_DIRECTORY}")
# add all source files in this directory to the sources list:
file(GLOB sources "${PARENT_DIRECTORY}/*.cpp" "${PARENT_DIRECTORY}/*.c")
list(APPEND ${SOURCES_LIST} ${sources})
# get a list of all subdirectories that we want to recurse into:
file(GLOB dir_children RELATIVE "${PARENT_DIRECTORY}" "${PARENT_DIRECTORY}/*")
set(matching_subdirs "")
foreach(child ${dir_children})
if(IS_DIRECTORY "${PARENT_DIRECTORY}/${child}")
# is this directory name a magic one?
if(${child} MATCHES "^TARGET_")
# target-magic: recurse if the MBED_LEGACY_TARGET_DEFINITIONS **list**
# contains a matching value:
foreach(legacy_magic_def ${MBED_LEGACY_TARGET_DEFINITIONS})
# we could probably unroll the list into a single regex if
# this is a performance problem:
if(${child} MATCHES "^TARGET_${legacy_magic_def}$")
list(APPEND matching_subdirs ${child})
break()
endif()
endforeach()
elseif(${child} MATCHES "^TOOLCHAIN_")
if(${child} MATCHES "^TOOLCHAIN_${MBED_LEGACY_TOOLCHAIN}$")
# toolchain-magic: (recurse if the MBED_LEGACY_TOOLCHAIN matches
# this name)
list(APPEND matching_subdirs ${child})
endif()
else()
# not special: always recurse into this directory
list(APPEND matching_subdirs ${child})
endif()
endif()
endforeach()
#message("matching_subdirs: ${matching_subdirs}")
# recurse:
foreach(subdir ${matching_subdirs})
mbed_find_target_dirs("${PARENT_DIRECTORY}/${subdir}" ${SOURCES_LIST} ${INCLUDES_LIST})
endforeach()
endmacro()
set(MBED_TARGET_SOURCES "")
set(MBED_TARGET_INCLUDE_DIRS "")
mbed_find_target_dirs("${CMAKE_CURRENT_SOURCE_DIR}/targets" MBED_TARGET_SOURCES MBED_TARGET_INCLUDE_DIRS)
#message("found target sources: ${MBED_TARGET_SOURCES}")
#message("found target include dirs: ${MBED_TARGET_INCLUDE_DIRS}")
# finally, we can construct a library using the determined set of include paths
# + source files. Note that the library name must match the name of the yotta
# module (defined in module.json) for this module to link properly with other
# yotta modules.
include_directories(${MBED_COMMON_INCLUDE_DIRS})
include_directories(${MBED_TARGET_INCLUDE_DIRS})
add_library(mbed
${MBED_COMMON_SOURCES}
${MBED_TARGET_SOURCES}
)

View File

@ -0,0 +1,27 @@
{
"name": "mbed",
"version": "2.0.0-a0",
"description": "mbed SDK (for mbed 2.0)",
"keywords": [
"mbed"
],
"author": "Bogdan Marinescu <bogdan.marinescu@arm.com>",
"repository": {
"url": "git@github.com:mbedmicro/mbed.git",
"type": "git"
},
"homepage": "https://github.com/mbedmicro/mbed",
"licenses": [
{
"url": "https://spdx.org/licenses/Apache-2.0",
"type": "Apache-2.0"
}
],
"extraIncludes": [
"api"
],
"dependencies": {
},
"targetDependencies": {
}
}