1 """class for handling .oe files
3 Reads the file and obtains its metadata"""
5 import re, oe, string, os, sys
8 from oe import debug, data, fetch, fatal
10 from oe.parse.ConfHandler import include, localpath, obtain, init
12 __func_start_regexp__ = re.compile( r"((?P<py>python)\s*)*(?P<func>\w+)\s*\(\s*\)\s*{$" )
13 __inherit_regexp__ = re.compile( r"inherit\s+(.+)" )
14 __export_func_regexp__ = re.compile( r"EXPORT_FUNCTIONS\s+(.+)" )
15 __addtask_regexp__ = re.compile("addtask\s+(?P<func>\w+)\s*((before\s*(?P<before>((.*(?=after))|(.*))))|(after\s*(?P<after>((.*(?=before))|(.*)))))*")
16 __addhandler_regexp__ = re.compile( r"addhandler\s+(.+)" )
17 __word__ = re.compile(r"\S+")
26 localfn = localpath(fn, d)
27 return localfn[-3:] == ".oe" or localfn[-8:] == ".oeclass"
29 def inherit(files, d):
30 __inherit_cache = data.getVar('__inherit_cache', d) or ""
34 file = data.expand(f, d)
35 if file[0] != "/" and file[-8:] != ".oeclass":
36 file = "classes/%s.oeclass" % file
38 if not file in string.split(__inherit_cache):
39 debug(2, "OE %s:%d: inheriting %s" % (fn, lineno, file))
40 __inherit_cache += " %s" % file
42 data.setVar('__inherit_cache', __inherit_cache, d)
45 def handle(fn, d = {}, include = 0):
46 global __func_start_regexp__, __inherit_regexp__, __export_func_regexp__, __addtask_regexp__, __addhandler_regexp__, __infunc__, __body__, __oepath_found__
53 debug(2, "OE " + fn + ": handle(data)")
55 debug(2, "OE " + fn + ": handle(data, include)")
57 (root, ext) = os.path.splitext(os.path.basename(fn))
60 classes.append(__classname__)
64 oldfile = data.getVar('FILE', d)
68 if not os.path.isabs(fn):
70 voepath = data.getVar("OEPATH", d)
72 oepath += voepath.split(":")
75 if os.access(os.path.join(p, fn), os.R_OK):
76 f = open(os.path.join(p, fn), 'r')
78 raise IOError("file not found")
82 data.setVar('FILE', fn, d)
86 i = string.split(data.getVar("INHERIT", d, 1) or "")
87 if not "base" in i and __classname__ != "base":
97 if not w: continue # skip empty lines
99 if s[0] == '#': continue # skip comments
101 s2 = f.readline()[:-1].strip()
103 feeder(lineno, s, fn, d)
104 if ext == ".oeclass":
105 classes.remove(__classname__)
108 set_automatic_vars(fn, d, include)
111 set_additional_vars(fn, d, include)
113 if data.getVarFlag(var, 'handler', d):
114 oe.event.register(data.getVar(var, d))
117 if not data.getVarFlag(var, 'task', d):
120 deps = data.getVarFlag(var, 'deps', d) or []
121 postdeps = data.getVarFlag(var, 'postdeps', d) or []
122 oe.build.add_task(var, deps, d)
124 pdeps = data.getVarFlag(p, 'deps', d) or []
126 data.setVarFlag(p, 'deps', pdeps, d)
127 oe.build.add_task(p, pdeps, d)
129 data.setVar('FILE', oldfile, d)
132 def feeder(lineno, s, fn, d):
133 global __func_start_regexp__, __inherit_regexp__, __export_func_regexp__, __addtask_regexp__, __addhandler_regexp__, __infunc__, __body__, __oepath_found__, classes, oe
137 data.setVar(__infunc__, string.join(__body__, '\n'), d)
138 data.setVarFlag(__infunc__, "func", 1, d)
145 m = __func_start_regexp__.match(s)
147 __infunc__ = m.group("func")
149 if data.getVar(key, d):
150 # clean up old version of this piece of metadata, as its
151 # flags could cause problems
152 data.setVarFlag(key, 'python', None, d)
153 if m.group("py") is not None:
154 data.setVarFlag(key, "python", "1", d)
156 data.setVarFlag(key, "python", None, d)
159 m = __export_func_regexp__.match(s)
162 n = __word__.findall(fns)
166 allvars.append(classes[-1] + "_" + f)
168 vars = [[ allvars[0], allvars[1] ]]
169 if len(classes) > 1 and classes[-2] is not None:
170 allvars.append(classes[-2] + "_" + f)
172 vars.append([allvars[2], allvars[1]])
173 vars.append([allvars[0], allvars[2]])
175 for (var, calledvar) in vars:
176 if data.getVar(var, d) and not data.getVarFlag(var, 'export_func', d):
179 if data.getVar(var, d):
180 data.setVarFlag(var, 'python', None, d)
181 data.setVarFlag(var, 'func', None, d)
183 for flag in [ "func", "python" ]:
184 if data.getVarFlag(calledvar, flag, d):
185 data.setVarFlag(var, flag, data.getVarFlag(calledvar, flag, d), d)
186 for flag in [ "dirs" ]:
187 if data.getVarFlag(var, flag, d):
188 data.setVarFlag(calledvar, flag, data.getVarFlag(var, flag, d), d)
190 if data.getVarFlag(calledvar, "python", d):
191 data.setVar(var, "\treturn oe.build.exec_func('" + calledvar + "', d)\n", d)
193 data.setVar(var, "\t" + calledvar + "\n", d)
194 data.setVarFlag(var, 'export_func', '1', d)
198 m = __addtask_regexp__.match(s)
200 func = m.group("func")
201 before = m.group("before")
202 after = m.group("after")
207 data.setVarFlag(var, "task", 1, d)
209 if after is not None:
210 # set up deps for function
211 data.setVarFlag(var, "deps", after.split(), d)
212 if before is not None:
213 # set up things that depend on this func
214 data.setVarFlag(var, "postdeps", before.split(), d)
217 m = __addhandler_regexp__.match(s)
220 hs = __word__.findall(fns)
222 data.setVarFlag(h, "handler", 1, d)
225 m = __inherit_regexp__.match(s)
229 n = __word__.findall(files)
233 from oe.parse import ConfHandler
234 return ConfHandler.feeder(lineno, s, fn, d)
236 __pkgsplit_cache__={}
237 def vars_from_file(mypkg, d):
239 return (None, None, None)
240 if mypkg in __pkgsplit_cache__:
241 return __pkgsplit_cache__[mypkg]
243 myfile = os.path.splitext(os.path.basename(mypkg))
244 parts = string.split(myfile[0], '_')
245 __pkgsplit_cache__[mypkg] = parts
251 parts.extend(tmplist)
254 def set_automatic_vars(file, d, include):
255 """Deduce per-package environment variables"""
257 debug(2, "OE %s: setting automatic vars" % file)
258 # pkg = oe.catpkgsplit(file)
259 # pkg = vars_from_fn(file, d)
261 # fatal("package file not in valid format")
262 # if not data.getVar('CATEGORY', d):
264 # fatal("package file not in valid format")
265 # data.setVar('CATEGORY', pkg[0], d)
266 # if not data.getVar('PN', d):
268 # fatal("package file not in valid format")
269 # data.setVar('PN', pkg[1], d)
270 # if not data.getVar('PV', d):
272 # fatal("package file not in valid format")
273 # data.setVar('PV', pkg[2], d)
274 # if not data.getVar('PR', d):
276 # fatal("package file not in valid format")
277 # data.setVar('PR', pkg[3], d)
279 data.setVar('P', '${PN}-${PV}', d)
280 data.setVar('PF', '${P}-${PR}', d)
282 for t in [ os.path.dirname(file), '${TOPDIR}/${CATEGORY}' ]:
283 if data.getVar('FILESDIR', d):
290 path = data.expand(os.path.join(t, s), d)
291 if not os.path.isabs(path):
292 path = os.path.abspath(path)
293 if os.access(path, os.R_OK):
294 data.setVar('FILESDIR', path, d)
297 if not data.getVar('WORKDIR', d):
298 data.setVar('WORKDIR', '${TMPDIR}/${CATEGORY}/${PF}', d)
299 if not data.getVar('T', d):
300 data.setVar('T', '${WORKDIR}/temp', d)
301 if not data.getVar('D', d):
302 data.setVar('D', '${WORKDIR}/image', d)
303 if not data.getVar('S', d):
304 data.setVar('S', '${WORKDIR}/${P}', d)
305 if not data.getVar('SLOT', d):
306 data.setVar('SLOT', '0', d)
308 def set_additional_vars(file, d, include):
309 """Deduce rest of variables, e.g. ${A} out of ${SRC_URI}"""
311 debug(2,"OE %s: set_additional_vars" % file)
313 src_uri = data.getVar('SRC_URI', d)
316 src_uri = data.expand(src_uri, d)
318 a = data.getVar('A', d)
320 a = data.expand(a, d).split()
326 fetch.init(src_uri.split())
327 except fetch.NoMethodError:
330 a += fetch.localpaths(d)
332 data.setVar('A', string.join(a), d)
335 # Add us to the handlers list
336 from oe.parse import handlers
337 handlers.append({'supports': supports, 'handle': handle, 'init': init})