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):
+ """
+ Take a text and return a list of tuple (description, name-value).
+ """
+ block = []
+ block_tmp = re.findall(r"/\*{2}\s*([^*]*\*(?:[^/*][^*]*\*+)*)/\s*#define\s+((?:[^/]*?/?)+)\s*?(?:/{2,3}[^<].*?)?$", text, re.MULTILINE)
+ for comment, define in block_tmp:
+ block.append((" ".join(re.findall(r"^\s*\*?\s*(.*?)\s*?(?:/{2}.*?)?$", comment, re.MULTILINE)).strip(), define))
+ block += re.findall(r"/{3}\s*([^<].*?)\s*#define\s+((?:[^/]*?/?)+)\s*?(?:/{2,3}[^<].*?)?$", text, re.MULTILINE)
+ block += [(comment, define) for define, comment in re.findall(r"#define\s*(.*?)\s*/{3}<\s*(.+?)\s*?(?:/{2,3}[^<].*?)?$", text, re.MULTILINE)]
+ return block
+
+def formatModuleNameValue(text):
+ """
+ Take the given string and return a tuple with the name of the parameter in the first position
+ and the value in the second.
+ """
+ block = re.findall("\s*([^\s]+)\s*(.+?)\s*$", text, re.MULTILINE)
+ return block[0]
+
+def loadModuleInfos(path):
+ """
+ Return the module configurations found in the given path as a dict with the name as key
+ and a list of tuple as value. The tuple have the format (name, value, description).
+ """
+ moduleInfos = {}
+ for definition in findDefinitions(const.MODULE_CONFIGURATION, path):
+ moduleName = definition[0].replace("cfg_", "").replace(".h", "")
+ moduleInfos[moduleName] = []
+ for description, define in getDefinitionBlocks(open(definition[1] + "/" + definition[0], "r").read()):
+ name, value = formatModuleNameValue(define)
+ moduleInfos[moduleName].append((name, value, description))
+ return moduleInfos