def prepare(self, config_only=False, config_params=None, quiet=0): if self.tracking: extrafeatures = [bb.cooker.CookerFeatures.BASEDATASTORE_TRACKING] else: extrafeatures = [] if not config_params: config_params = TinfoilConfigParameters(config_only=config_only, quiet=quiet) cookerconfig = CookerConfiguration() cookerconfig.setConfigParameters(config_params) server, self.server_connection, ui_module = setup_bitbake(config_params, cookerconfig, extrafeatures) self.ui_module = ui_module if self.server_connection: _server_connections.append(self.server_connection) if config_only: config_params.updateToServer(self.server_connection.connection, os.environ.copy()) self.run_command('parseConfiguration') else: self.run_actions(config_params) self.config_data = bb.data.init() connector = TinfoilDataStoreConnector(self, None) self.config_data.setVar('_remote_data', connector) self.cooker = TinfoilCookerAdapter(self) self.cooker_data = self.cooker.recipecaches[''] else: raise Exception('Failed to start bitbake server')
def prepare(self, config_only=False, config_params=None, quiet=0, extra_features=None): if self.tracking: extrafeatures = [bb.cooker.CookerFeatures.BASEDATASTORE_TRACKING] else: extrafeatures = [] if extra_features: extrafeatures += extra_features if not config_params: config_params = TinfoilConfigParameters(config_only=config_only, quiet=quiet) cookerconfig = CookerConfiguration() cookerconfig.setConfigParameters(config_params) server, self.server_connection, ui_module = setup_bitbake( config_params, cookerconfig, extrafeatures, setup_logging=False) self.ui_module = ui_module # Ensure the path to bitbake's bin directory is in PATH so that things like # bitbake-worker can be run (usually this is the case, but it doesn't have to be) path = os.getenv('PATH').split(':') bitbakebinpath = os.path.abspath( os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..', 'bin')) for entry in path: if entry.endswith(os.sep): entry = entry[:-1] if os.path.abspath(entry) == bitbakebinpath: break else: path.insert(0, bitbakebinpath) os.environ['PATH'] = ':'.join(path) if self.server_connection: _server_connections.append(self.server_connection) if config_only: config_params.updateToServer(self.server_connection.connection, os.environ.copy()) self.run_command('parseConfiguration') else: self.run_actions(config_params) self.config_data = bb.data.init() connector = TinfoilDataStoreConnector(self, None) self.config_data.setVar('_remote_data', connector) self.cooker = TinfoilCookerAdapter(self) self.cooker_data = self.cooker.recipecaches[''] else: raise Exception('Failed to start bitbake server')
def prepare(self, config_only=False, config_params=None, quiet=0): if self.tracking: extrafeatures = [bb.cooker.CookerFeatures.BASEDATASTORE_TRACKING] else: extrafeatures = [] if not config_params: config_params = TinfoilConfigParameters(config_only=config_only, quiet=quiet) cookerconfig = CookerConfiguration() cookerconfig.setConfigParameters(config_params) server, self.server_connection, ui_module = setup_bitbake(config_params, cookerconfig, extrafeatures) self.ui_module = ui_module # Ensure the path to bitbake's bin directory is in PATH so that things like # bitbake-worker can be run (usually this is the case, but it doesn't have to be) path = os.getenv('PATH').split(':') bitbakebinpath = os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..', 'bin')) for entry in path: if entry.endswith(os.sep): entry = entry[:-1] if os.path.abspath(entry) == bitbakebinpath: break else: path.insert(0, bitbakebinpath) os.environ['PATH'] = ':'.join(path) if self.server_connection: _server_connections.append(self.server_connection) if config_only: config_params.updateToServer(self.server_connection.connection, os.environ.copy()) self.run_command('parseConfiguration') else: self.run_actions(config_params) self.config_data = bb.data.init() connector = TinfoilDataStoreConnector(self, None) self.config_data.setVar('_remote_data', connector) self.cooker = TinfoilCookerAdapter(self) self.cooker_data = self.cooker.recipecaches[''] else: raise Exception('Failed to start bitbake server')
def prepare(self, config_only=False, config_params=None, quiet=0, extra_features=None): """ Prepares the underlying BitBake system to be used via tinfoil. This function must be called prior to calling any of the other functions in the API. NOTE: if you call prepare() you must absolutely call shutdown() before your code terminates. You can use a "with" block to ensure this happens e.g. with bb.tinfoil.Tinfoil() as tinfoil: tinfoil.prepare() ... Parameters: config_only: True to read only the configuration and not load the cache / parse recipes. This is useful if you just want to query the value of a variable at the global level or you want to do anything else that doesn't involve knowing anything about the recipes in the current configuration. False loads the cache / parses recipes. config_params: optionally specify your own configuration parameters. If not specified an instance of TinfoilConfigParameters will be created internally. quiet: quiet level controlling console output - equivalent to bitbake's -q/--quiet option. Default of 0 gives the same output level as normal bitbake execution. extra_features: extra features to be added to the feature set requested from the server. See CookerFeatures._feature_list for possible features. """ self.quiet = quiet if self.tracking: extrafeatures = [bb.cooker.CookerFeatures.BASEDATASTORE_TRACKING] else: extrafeatures = [] if extra_features: extrafeatures += extra_features if not config_params: config_params = TinfoilConfigParameters(config_only=config_only, quiet=quiet) if not config_only: # Disable local loggers because the UI module is going to set up its own for handler in self.localhandlers: self.logger.handlers.remove(handler) self.localhandlers = [] self.server_connection, ui_module = setup_bitbake(config_params, extrafeatures) self.ui_module = ui_module # Ensure the path to bitbake's bin directory is in PATH so that things like # bitbake-worker can be run (usually this is the case, but it doesn't have to be) path = os.getenv('PATH').split(':') bitbakebinpath = os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..', 'bin')) for entry in path: if entry.endswith(os.sep): entry = entry[:-1] if os.path.abspath(entry) == bitbakebinpath: break else: path.insert(0, bitbakebinpath) os.environ['PATH'] = ':'.join(path) if self.server_connection: _server_connections.append(self.server_connection) if config_only: config_params.updateToServer(self.server_connection.connection, os.environ.copy()) self.run_command('parseConfiguration') else: self.run_actions(config_params) self.recipes_parsed = True self.config_data = TinfoilDataStoreConnector(self, 0) self.cooker = TinfoilCookerAdapter(self) self.cooker_data = self.cooker.recipecaches[''] else: raise Exception('Failed to start bitbake server')
def prepare(self, config_only=False, config_params=None, quiet=0, extra_features=None): """ Prepares the underlying BitBake system to be used via tinfoil. This function must be called prior to calling any of the other functions in the API. NOTE: if you call prepare() you must absolutely call shutdown() before your code terminates. You can use a "with" block to ensure this happens e.g. with bb.tinfoil.Tinfoil() as tinfoil: tinfoil.prepare() ... Parameters: config_only: True to read only the configuration and not load the cache / parse recipes. This is useful if you just want to query the value of a variable at the global level or you want to do anything else that doesn't involve knowing anything about the recipes in the current configuration. False loads the cache / parses recipes. config_params: optionally specify your own configuration parameters. If not specified an instance of TinfoilConfigParameters will be created internally. quiet: quiet level controlling console output - equivalent to bitbake's -q/--quiet option. Default of 0 gives the same output level as normal bitbake execution. extra_features: extra features to be added to the feature set requested from the server. See CookerFeatures._feature_list for possible features. """ self.quiet = quiet if self.tracking: extrafeatures = [bb.cooker.CookerFeatures.BASEDATASTORE_TRACKING] else: extrafeatures = [] if extra_features: extrafeatures += extra_features if not config_params: config_params = TinfoilConfigParameters(config_only=config_only, quiet=quiet) cookerconfig = CookerConfiguration() cookerconfig.setConfigParameters(config_params) if not config_only: # Disable local loggers because the UI module is going to set up its own for handler in self.localhandlers: self.logger.handlers.remove(handler) self.localhandlers = [] self.server_connection, ui_module = setup_bitbake(config_params, cookerconfig, extrafeatures) self.ui_module = ui_module # Ensure the path to bitbake's bin directory is in PATH so that things like # bitbake-worker can be run (usually this is the case, but it doesn't have to be) path = os.getenv('PATH').split(':') bitbakebinpath = os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..', 'bin')) for entry in path: if entry.endswith(os.sep): entry = entry[:-1] if os.path.abspath(entry) == bitbakebinpath: break else: path.insert(0, bitbakebinpath) os.environ['PATH'] = ':'.join(path) if self.server_connection: _server_connections.append(self.server_connection) if config_only: config_params.updateToServer(self.server_connection.connection, os.environ.copy()) self.run_command('parseConfiguration') else: self.run_actions(config_params) self.recipes_parsed = True self.config_data = bb.data.init() connector = TinfoilDataStoreConnector(self, None) self.config_data.setVar('_remote_data', connector) self.cooker = TinfoilCookerAdapter(self) self.cooker_data = self.cooker.recipecaches[''] else: raise Exception('Failed to start bitbake server')