summaryrefslogtreecommitdiffstats
path: root/bitbake/bin/bitbake-runtask
blob: 6a0ecdc555a95c8f340279bf4fabab10a90cbaf1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#!/usr/bin/env python

import os
import sys
import warnings
sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(sys.argv[0])), 'lib'))
from bb import fetch2
import logging

logger = logging.getLogger("BitBake")

try:
    import cPickle as pickle
except ImportError:
    import pickle
    bb.msg.note(1, bb.msg.domain.Cache, "Importing cPickle failed. Falling back to a very slow implementation.")

class BBConfiguration(object):
    """
    Manages build options and configurations for one run
    """

    def __init__(self, **options):
        self.data = {}
        self.file = []
        self.cmd = None
        self.dump_signatures = True
        self.prefile = []
        self.postfile = []
        self.parse_only = True

    def __getattr__(self, attribute):
        try:
            return super(BBConfiguration, self).__getattribute__(attribute)
        except AttributeError:
            return None

_warnings_showwarning = warnings.showwarning
def _showwarning(message, category, filename, lineno, file=None, line=None):
    """Display python warning messages using bb.msg"""
    if file is not None:
        if _warnings_showwarning is not None:
            _warnings_showwarning(message, category, filename, lineno, file, line)
    else:
        s = warnings.formatwarning(message, category, filename, lineno)
        s = s.split("\n")[0]
        bb.msg.warn(None, s)

warnings.showwarning = _showwarning
warnings.simplefilter("ignore", DeprecationWarning)

import bb.event
import bb.cooker

buildfile = sys.argv[1]
taskname = sys.argv[2]
if len(sys.argv) >= 4:
    dryrun = sys.argv[3]    
else:
    dryrun = False
if len(sys.argv) >= 5:
    hashfile = sys.argv[4]
    p = pickle.Unpickler(file(hashfile, "rb"))
    hashdata = p.load()
else:
    hashdata = None

handler = bb.event.LogHandler()
logger.addHandler(handler)

#An example to make debug log messages show up
#bb.msg.init_msgconfig(True, 3, [])

console = logging.StreamHandler(sys.stdout)
format = bb.msg.BBLogFormatter("%(levelname)s: %(message)s")
bb.msg.addDefaultlogFilter(console)
console.setFormatter(format)

def worker_fire(event, d):
    if isinstance(event, logging.LogRecord):
        console.handle(event)
bb.event.worker_fire = worker_fire
bb.event.worker_pid = os.getpid()

initialenv = os.environ.copy()
config = BBConfiguration()

def register_idle_function(self, function, data):
    pass

cooker = bb.cooker.BBCooker(config, register_idle_function, initialenv)
config_data = cooker.configuration.data
cooker.status = config_data
cooker.handleCollections(config_data.getVar("BBFILE_COLLECTIONS", 1))

fn, cls = bb.cache.Cache.virtualfn2realfn(buildfile)
buildfile = cooker.matchFile(fn)
fn = bb.cache.Cache.realfn2virtual(buildfile, cls)

cooker.buildSetVars()

# Load data into the cache for fn and parse the loaded cache data
the_data = bb.cache.Cache.loadDataFull(fn, cooker.get_file_appends(fn), cooker.configuration.data)

if taskname.endswith("_setscene"):
    the_data.setVarFlag(taskname, "quieterrors", "1")

if hashdata:
    bb.parse.siggen.set_taskdata(hashdata["hashes"], hashdata["deps"])
    for h in hashdata["hashes"]:
        the_data.setVar("BBHASH_%s" % h, hashdata["hashes"][h])
    for h in hashdata["deps"]:
        the_data.setVar("BBHASHDEPS_%s" % h, hashdata["deps"][h])

ret = 0
if dryrun != "True":
    ret = bb.build.exec_task(fn, taskname, the_data)
sys.exit(ret)