diff options
| author | Martin Jansa <Martin.Jansa@gmail.com> | 2012-10-02 22:56:01 +0200 |
|---|---|---|
| committer | Koen Kooi <koen@dominion.thruhere.net> | 2012-10-05 12:17:40 +0200 |
| commit | 58cb1dfe3efbcdfc2969daf4010784d06b9c543a (patch) | |
| tree | dde27c5a8df45b3c66927742cd7259cd96ea432b /meta-oe/classes | |
| parent | 68f05443333afa527e3b24e4caae6115dfb6b6b6 (diff) | |
| download | meta-openembedded-58cb1dfe3efbcdfc2969daf4010784d06b9c543a.tar.gz | |
srctree: remove this bbclass
* it's depending on clean.bbclass which isn't in meta-oe and oe-core now has externalsrc.bbclass
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
Diffstat (limited to 'meta-oe/classes')
| -rw-r--r-- | meta-oe/classes/srctree.bbclass | 123 |
1 files changed, 0 insertions, 123 deletions
diff --git a/meta-oe/classes/srctree.bbclass b/meta-oe/classes/srctree.bbclass deleted file mode 100644 index 1457e5618d..0000000000 --- a/meta-oe/classes/srctree.bbclass +++ /dev/null | |||
| @@ -1,123 +0,0 @@ | |||
| 1 | # Copyright (C) 2009 Chris Larson <clarson@kergoth.com> | ||
| 2 | # Released under the MIT license (see COPYING.MIT for the terms) | ||
| 3 | # | ||
| 4 | # srctree.bbclass enables operation inside of an existing source tree for a | ||
| 5 | # project, rather than using the fetch/unpack/patch idiom. | ||
| 6 | # | ||
| 7 | # By default, it expects that you're keeping the recipe(s) inside the | ||
| 8 | # aforementioned source tree, but you could override S to point at an external | ||
| 9 | # directory and place the recipes in a normal collection/overlay, if you so | ||
| 10 | # chose. | ||
| 11 | # | ||
| 12 | # It also provides some convenience python functions for assembling your | ||
| 13 | # do_clean, if you want to leverage things like 'git clean' to simplify the | ||
| 14 | # operation. | ||
| 15 | |||
| 16 | |||
| 17 | # Grab convenience methods & sane default for do_clean | ||
| 18 | inherit clean | ||
| 19 | |||
| 20 | # Build here | ||
| 21 | S = "${FILE_DIRNAME}" | ||
| 22 | SRC_URI = "" | ||
| 23 | |||
| 24 | def remove_tasks(deltasks, d): | ||
| 25 | for task in filter(lambda k: d.getVarFlag(k, "task"), d.keys()): | ||
| 26 | deps = d.getVarFlag(task, "deps") | ||
| 27 | for preptask in deltasks: | ||
| 28 | if preptask in deps: | ||
| 29 | deps.remove(preptask) | ||
| 30 | d.setVarFlag(task, "deps", deps) | ||
| 31 | |||
| 32 | addtask configure after do_setscene | ||
| 33 | |||
| 34 | def merge_tasks(d): | ||
| 35 | """ | ||
| 36 | Merges all of the operations that occur prior to do_populate_sysroot | ||
| 37 | into do_populate_sysroot. | ||
| 38 | |||
| 39 | This is necessary because of recipe variants (normal, native, cross, | ||
| 40 | sdk). If a bitbake run happens to want to build more than one of | ||
| 41 | these variants in a single run, it's possible for them to step on one | ||
| 42 | another's toes, due to the shared ${S}. Interleaved | ||
| 43 | configure/compile/install amongst variants will break things badly. | ||
| 44 | """ | ||
| 45 | from itertools import chain | ||
| 46 | from bb import note | ||
| 47 | |||
| 48 | def __gather_taskdeps(task, seen): | ||
| 49 | for dep in d.getVarFlag(task, "deps"): | ||
| 50 | if not dep in seen: | ||
| 51 | __gather_taskdeps(dep, seen) | ||
| 52 | if not task in seen: | ||
| 53 | seen.append(task) | ||
| 54 | |||
| 55 | def gather_taskdeps(task): | ||
| 56 | items = [] | ||
| 57 | __gather_taskdeps(task, items) | ||
| 58 | return items | ||
| 59 | |||
| 60 | newtask = "do_populate_sysroot_post" | ||
| 61 | mergedtasks = gather_taskdeps(newtask) | ||
| 62 | mergedtasks.pop() | ||
| 63 | |||
| 64 | for task in (key for key in d.keys() | ||
| 65 | if d.getVarFlag(key, "task") and | ||
| 66 | not key in mergedtasks): | ||
| 67 | deps = d.getVarFlag(task, "deps") | ||
| 68 | for mergetask in mergedtasks: | ||
| 69 | if mergetask in (d.getVarFlag(task, "recrdeptask"), | ||
| 70 | d.getVarFlag(task, "recdeptask"), | ||
| 71 | d.getVarFlag(task, "deptask")): | ||
| 72 | continue | ||
| 73 | |||
| 74 | if mergetask in deps: | ||
| 75 | deps.remove(mergetask) | ||
| 76 | #note("removing dep on %s from %s" % (mergetask, task)) | ||
| 77 | |||
| 78 | if not newtask in deps: | ||
| 79 | #note("adding dep on %s to %s" % (newtask, task)) | ||
| 80 | deps.append(newtask) | ||
| 81 | d.setVarFlag(task, "deps", deps) | ||
| 82 | |||
| 83 | # Pull cross recipe task deps over | ||
| 84 | depends = [] | ||
| 85 | deptask = [] | ||
| 86 | for task in mergedtasks[:-1]: | ||
| 87 | depends.append(d.getVarFlag(task, "depends") or "") | ||
| 88 | deptask.append(d.getVarFlag(task, "deptask") or "") | ||
| 89 | |||
| 90 | d.setVarFlag("do_populate_sysroot_post", "depends", " ".join(depends)) | ||
| 91 | d.setVarFlag("do_populate_sysroot_post", "deptask", " ".join(deptask)) | ||
| 92 | |||
| 93 | python () { | ||
| 94 | remove_tasks(["do_patch", "do_unpack", "do_fetch"], d) | ||
| 95 | b = d.getVar("B", True) | ||
| 96 | if not b or b == d.getVar("S", True): | ||
| 97 | merge_tasks(d) | ||
| 98 | } | ||
| 99 | |||
| 100 | # Manually run do_install & all of its deps | ||
| 101 | python do_populate_sysroot_post () { | ||
| 102 | from os.path import exists | ||
| 103 | from bb.build import exec_func, make_stamp | ||
| 104 | from bb import note | ||
| 105 | |||
| 106 | stamp = d.getVar("STAMP", True) | ||
| 107 | |||
| 108 | def rec_exec_task(task, seen): | ||
| 109 | for dep in d.getVarFlag(task, "deps"): | ||
| 110 | if not dep in seen: | ||
| 111 | rec_exec_task(dep, seen) | ||
| 112 | seen.add(task) | ||
| 113 | if not exists("%s.%s" % (stamp, task)): | ||
| 114 | note("%s: executing task %s" % (d.getVar("PF", True), task)) | ||
| 115 | exec_func(task, d) | ||
| 116 | flags = d.getVarFlags(task) | ||
| 117 | if not flags.get('nostamp') and not flags.get('selfstamp'): | ||
| 118 | make_stamp(task, d) | ||
| 119 | |||
| 120 | rec_exec_task("do_populate_sysroot", set()) | ||
| 121 | } | ||
| 122 | addtask populate_sysroot_post after do_populate_sysroot | ||
| 123 | do_populate_sysroot_post[lockfiles] += "${S}/.lock" | ||
