X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=wizard%2Fbertos_utils.py;h=e8033d7d8e564815a949781a5cc3a915c1a2e66b;hb=8c583d29bc943d84345d0078cb31d2b6fbaa53f4;hp=e5a21d9b4989fa898ee518f9e55d936d88df9b66;hpb=7aaf72a1c2b435d9704f0161459f1b338ec608c5;p=bertos.git diff --git a/wizard/bertos_utils.py b/wizard/bertos_utils.py index e5a21d9b..e8033d7d 100644 --- a/wizard/bertos_utils.py +++ b/wizard/bertos_utils.py @@ -11,6 +11,10 @@ import os import fnmatch +import glob +import re + +import const def isBertosDir(directory): return os.path.exists(directory + "/VERSION") @@ -23,11 +27,121 @@ def createBertosProject(directory): os.mkdir(directory) open(directory + "/project.bertos", "w") +def getSystemPath(): + path = os.environ["PATH"] + if os.name == "nt": + path = path.split(";") + else: + path = path.split(":") + return path + +def findToolchains(pathList): + toolchains = [] + for element in pathList: + for toolchain in glob.glob(element+ "/" + const.GCC_NAME): + if not os.path.islink(toolchain): + toolchains.append(toolchain) + return list(set(toolchains)) + +def getToolchainInfo(output): + info = {} + expr = re.compile("Target: .*") + target = expr.findall(output) + if len(target) == 1: + info["target"] = target[0].split("Target: ")[1] + expr = re.compile("gcc version [0-9,.]*") + version = expr.findall(output) + if len(version) == 1: + info["version"] = version[0].split("gcc version ")[1] + expr = re.compile("gcc version [0-9,.]* \(.*\)") + build = expr.findall(output) + if len(build) == 1: + build = build[0].split("gcc version ")[1] + build = build[build.find("(") + 1 : build.find(")")] + info["build"] = build + expr = re.compile("Configured with: .*") + configured = expr.findall(output) + if len(configured) == 1: + info["configured"] = configured[0].split("Configured with: ")[1] + expr = re.compile("Thread model: .*") + thread = expr.findall(output) + if len(thread) == 1: + info["thread"] = thread[0].split("Thread model: ")[1] + return info + def findDefinitions(ftype, path): - l = os.walk(path) - definitions = {} - for element in l: + L = os.walk(path) + for element in L: for filename in element[2]: - if fnmatch.fnmatch(filename, "*." + ftype): - definitions[filename] = element[0] - return definitions \ No newline at end of file + if fnmatch.fnmatch(filename, ftype): + yield (filename, element[0]) + +def loadCpuInfos(path): + cpuInfos = [] + for definition in findDefinitions(const.CPU_DEFINITION, path): + cpuInfos.append(getInfos(definition)) + return cpuInfos + +def getInfos(definition): + D = {} + D.update(const.CPU_DEF) + def include(filename, dict = D, directory=definition[1]): + execfile(directory + "/" + filename, {}, D) + D["include"] = include + include(definition[0], D) + D["CPU_NAME"] = definition[0].split(".")[0] + D["DEFINITION_PATH"] = definition[1] + "/" + definition[0] + 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 getDescriptionInformations(text): + """ + Take the doxygen comment and strip the wizard informations, returning the tuple + (comment, wizard_informations) + """ + informations = {} + index = text.find("$WIZARD") + if index != -1: + exec(text[index + 1:]) + informations.update(WIZARD) + return text[:index].strip(), informations + + +def loadModuleInfos(path): + """ + Return the module configurations found in the given path as a dict with the name as key + and a dict as value. The value dict has the parameter name as key and has "value" and "description" + fields. + """ + moduleInfos = {} + for definition in findDefinitions(const.MODULE_CONFIGURATION, path): + moduleName = definition[0].replace("cfg_", "").replace(".h", "") + moduleInfos[moduleName] = {} + for comment, define in getDefinitionBlocks(open(definition[1] + "/" + definition[0], "r").read()): + name, value = formatModuleNameValue(define) + description, informations = getDescriptionInformations(comment) + moduleInfos[moduleName][name] = {} + moduleInfos[moduleName][name]["value"] = value + moduleInfos[moduleName][name]["description"] = description + moduleInfos[moduleName][name]["informations"] = informations + return moduleInfos