for toolchain in glob.glob(element+ "/" + const.GCC_NAME):
if not os.path.islink(toolchain):
toolchains.append(toolchain)
- return toolchains
+ return list(set(toolchains))
def getToolchainInfo(output):
info = {}
include(definition[0], D)
D["CPU_NAME"] = definition[0].split(".")[0]
D["DEFINITION_PATH"] = definition[1] + "/" + definition[0]
- return D
\ No newline at end of file
+ del D["include"]
+ return D
+
+def getDefinitionBlocks(text):
+ block = []
+ block_tmp = re.findall(r"/\*{2}\s*([^*]*\*(?:[^/*][^*]*\*+)*)/\s*#define\s+(.*?)\s*?$", text, re.MULTILINE)
+ for comment, define in block_tmp:
+ block.append((" ".join(re.findall(r"^\s*\*?\s*(.*?)\s*?$", comment, re.MULTILINE)), define))
+ block += re.findall(r"/{3}<?\s*(.*)\s*#define\s+(.*)\s*?$", text, re.MULTILINE)
+ block += [(comment, define) for define, comment in re.findall(r"#define\s*(.*?)\s*/{3}<\s*(.*?)\s*?$", text, re.MULTILINE)]
+ return block
+
+def loadModuleInfos(path):
+ moduleInfos = {}
+ for definition in findDefinitions(const.MODULE_CONFIGURATION, path):
+ moduleName = definition[0].replace("cfg_", "").replace(".h", "")
+ moduleInfos[moduleName] = []
+ for element in getDefinitionBlocks(open(definition[1] + "/" + definition[0], "r").read()):
+ moduleInfos[moduleName].append(element)
+ return moduleInfos