Add support for Isar build system
Isar allows to build Debian-based images using bitbake and the usual layer structures. It's very similar to OE, we just need to account for a different init script name. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
This commit is contained in:
parent
f3cee3b296
commit
013af80599
@ -28,7 +28,7 @@ import logging
|
|||||||
import shutil
|
import shutil
|
||||||
import os
|
import os
|
||||||
from .libkas import (ssh_cleanup_agent, ssh_setup_agent, ssh_no_host_key_check,
|
from .libkas import (ssh_cleanup_agent, ssh_setup_agent, ssh_no_host_key_check,
|
||||||
run_cmd, get_oe_environ)
|
run_cmd, get_build_environ)
|
||||||
|
|
||||||
__license__ = 'MIT'
|
__license__ = 'MIT'
|
||||||
__copyright__ = 'Copyright (c) Siemens AG, 2017'
|
__copyright__ = 'Copyright (c) Siemens AG, 2017'
|
||||||
@ -168,7 +168,7 @@ class SetupEnviron(Command):
|
|||||||
return 'setup_environ'
|
return 'setup_environ'
|
||||||
|
|
||||||
def execute(self, config):
|
def execute(self, config):
|
||||||
config.environ.update(get_oe_environ(config, config.build_dir))
|
config.environ.update(get_build_environ(config, config.build_dir))
|
||||||
|
|
||||||
|
|
||||||
class WriteConfig(Command):
|
class WriteConfig(Command):
|
||||||
|
@ -158,29 +158,32 @@ def find_program(paths, name):
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
def get_oe_environ(config, build_dir):
|
def get_build_environ(config, build_dir):
|
||||||
"""
|
"""
|
||||||
Create the openembedded environment variables.
|
Create the build environment variables.
|
||||||
"""
|
"""
|
||||||
# pylint: disable=too-many-locals
|
# pylint: disable=too-many-locals
|
||||||
# nasty side effect function: running oe-init-build-env also
|
# nasty side effect function: running oe/isar-init-build-env also
|
||||||
# creates the conf directory
|
# creates the conf directory
|
||||||
|
|
||||||
oe_path = None
|
permutations = \
|
||||||
for repo in config.get_repos():
|
[(repo, script) for repo in config.get_repos()
|
||||||
if os.path.exists(repo.path + '/oe-init-build-env'):
|
for script in ['oe-init-build-env', 'isar-init-build-env']]
|
||||||
oe_path = repo.path
|
for (repo, script) in permutations:
|
||||||
|
if os.path.exists(repo.path + '/' + script):
|
||||||
|
init_path = repo.path
|
||||||
|
init_script = script
|
||||||
break
|
break
|
||||||
if not oe_path:
|
else:
|
||||||
logging.error('Did not find oe-init-build-env')
|
logging.error('Did not find any init-build-env script')
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
get_bb_env_file = tempfile.mktemp()
|
get_bb_env_file = tempfile.mktemp()
|
||||||
with open(get_bb_env_file, 'w') as fds:
|
with open(get_bb_env_file, 'w') as fds:
|
||||||
script = """#!/bin/bash
|
script = """#!/bin/bash
|
||||||
source oe-init-build-env $1 > /dev/null 2>&1
|
source %s $1 > /dev/null 2>&1
|
||||||
env
|
env
|
||||||
"""
|
""" % init_script
|
||||||
fds.write(script)
|
fds.write(script)
|
||||||
os.chmod(get_bb_env_file, 0o775)
|
os.chmod(get_bb_env_file, 0o775)
|
||||||
|
|
||||||
@ -188,7 +191,7 @@ def get_oe_environ(config, build_dir):
|
|||||||
env['PATH'] = '/bin:/usr/bin'
|
env['PATH'] = '/bin:/usr/bin'
|
||||||
|
|
||||||
(_, output) = run_cmd([get_bb_env_file, build_dir],
|
(_, output) = run_cmd([get_bb_env_file, build_dir],
|
||||||
cwd=oe_path, env=env, liveupdate=False)
|
cwd=init_path, env=env, liveupdate=False)
|
||||||
|
|
||||||
os.remove(get_bb_env_file)
|
os.remove(get_bb_env_file)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user