import os
import fnmatch
+import glob
+import re
+
+import const
def isBertosDir(directory):
return os.path.exists(directory + "/VERSION")
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):
- defintions[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