2015-10-09 11:03:59 -03:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# encoding: utf-8
|
|
|
|
|
2015-11-30 11:41:45 -04:00
|
|
|
from __future__ import print_function
|
|
|
|
|
2015-10-09 11:03:59 -03:00
|
|
|
import os.path
|
|
|
|
import sys
|
|
|
|
sys.path.insert(0, 'Tools/ardupilotwaf/')
|
|
|
|
|
|
|
|
import ardupilotwaf
|
2015-11-26 10:34:24 -04:00
|
|
|
import boards
|
2015-12-10 14:22:07 -04:00
|
|
|
|
2016-06-21 10:05:36 -03:00
|
|
|
from waflib import Build, ConfigSet, Configure, Context, Utils
|
|
|
|
|
2015-10-09 11:03:59 -03:00
|
|
|
# TODO: implement a command 'waf help' that shows the basic tasks a
|
|
|
|
# developer might want to do: e.g. how to configure a board, compile a
|
|
|
|
# vehicle, compile all the examples, add a new example. Should fit in
|
|
|
|
# less than a terminal screen, ideally commands should be copy
|
|
|
|
# pastable. Add the 'export waf="$PWD/waf"' trick to be copy-pastable
|
|
|
|
# as well.
|
|
|
|
|
2016-05-05 19:16:23 -03:00
|
|
|
# TODO: replace defines with the use of the generated ap_config.h file
|
2015-10-09 11:03:59 -03:00
|
|
|
# this makes recompilation at least when defines change. which might
|
|
|
|
# be sufficient.
|
|
|
|
|
2016-07-29 11:24:59 -03:00
|
|
|
def _set_build_context_variant(variant):
|
|
|
|
for c in Context.classes:
|
|
|
|
if not issubclass(c, Build.BuildContext):
|
|
|
|
continue
|
|
|
|
c.variant = variant
|
|
|
|
|
2015-12-10 14:22:07 -04:00
|
|
|
def init(ctx):
|
|
|
|
env = ConfigSet.ConfigSet()
|
|
|
|
try:
|
waf: don't use hard-coded path for environment cache path
The path for the "non-board" environment cache file was hard-coded, which was
causing the error below when the build was configured with the --out option
value different from the default path.
Traceback (most recent call last):
File "/home/gjsousa/ardupilot/modules/waf/waflib/Scripting.py", line 161, in waf_entry_point
run_commands()
File "/home/gjsousa/ardupilot/modules/waf/waflib/Scripting.py", line 263, in run_commands
ctx = run_command(cmd_name)
File "/home/gjsousa/ardupilot/modules/waf/waflib/Scripting.py", line 247, in run_command
ctx.execute()
File "/home/gjsousa/ardupilot/modules/waf/waflib/Scripting.py", line 598, in execute
return execute_method(self)
File "/home/gjsousa/ardupilot/modules/waf/waflib/Build.py", line 250, in execute
self.execute_build()
File "/home/gjsousa/ardupilot/modules/waf/waflib/Build.py", line 263, in execute_build
self.recurse([self.run_dir])
File "/home/gjsousa/ardupilot/modules/waf/waflib/Context.py", line 304, in recurse
user_function(self)
File "/home/gjsousa/ardupilot/wscript", line 246, in build
config_header = Utils.h_file(bld.bldnode.make_node('ap_config.h').abspath())
File "/home/gjsousa/ardupilot/modules/waf/waflib/Utils.py", line 208, in h_file
f = open(fname, 'rb')
IOError: [Errno 2] No such file or directory: '/tmp/build/ap_config.h'
2016-05-17 15:26:28 -03:00
|
|
|
p = os.path.join(Context.out_dir, Build.CACHE_DIR, Build.CACHE_SUFFIX)
|
|
|
|
env.load(p)
|
2015-12-10 14:22:07 -04:00
|
|
|
except:
|
|
|
|
return
|
|
|
|
|
2016-07-28 18:46:42 -03:00
|
|
|
Configure.autoconfig = 'clobber' if env.AUTOCONFIG else False
|
|
|
|
|
2016-05-06 18:44:12 -03:00
|
|
|
if 'VARIANT' not in env:
|
|
|
|
return
|
|
|
|
|
2015-12-10 14:22:07 -04:00
|
|
|
# define the variant build commands according to the board
|
2016-07-29 11:24:59 -03:00
|
|
|
_set_build_context_variant(env.VARIANT)
|
2015-12-10 14:22:07 -04:00
|
|
|
|
2015-10-09 11:03:59 -03:00
|
|
|
def options(opt):
|
2016-01-02 07:22:36 -04:00
|
|
|
opt.load('compiler_cxx compiler_c waf_unit_test python')
|
2016-02-17 08:48:08 -04:00
|
|
|
opt.load('ardupilotwaf')
|
2016-05-25 12:24:58 -03:00
|
|
|
opt.load('build_summary')
|
2016-02-17 08:48:08 -04:00
|
|
|
|
|
|
|
g = opt.ap_groups['configure']
|
2016-05-23 10:48:39 -03:00
|
|
|
|
2016-02-17 08:35:29 -04:00
|
|
|
boards_names = boards.get_boards_names()
|
|
|
|
g.add_option('--board',
|
2016-05-23 10:48:39 -03:00
|
|
|
action='store',
|
|
|
|
choices=boards_names,
|
|
|
|
default='sitl',
|
|
|
|
help='Target board to build, choices are %s.' % boards_names)
|
2015-10-09 11:03:59 -03:00
|
|
|
|
2016-07-28 15:18:01 -03:00
|
|
|
g.add_option('--debug',
|
|
|
|
action='store_true',
|
|
|
|
default=False,
|
|
|
|
help='Configure as debug variant.')
|
|
|
|
|
2016-07-28 18:46:42 -03:00
|
|
|
g.add_option('--no-autoconfig',
|
|
|
|
dest='autoconfig',
|
|
|
|
action='store_false',
|
|
|
|
default=True,
|
|
|
|
help='''
|
|
|
|
Disable autoconfiguration feature. By default, the build system triggers a
|
|
|
|
reconfiguration whenever it thinks it's necessary - this option disables that.
|
|
|
|
''')
|
|
|
|
|
2016-02-19 12:44:32 -04:00
|
|
|
g.add_option('--no-submodule-update',
|
2016-05-23 10:48:39 -03:00
|
|
|
dest='submodule_update',
|
|
|
|
action='store_false',
|
|
|
|
default=True,
|
|
|
|
help='''
|
|
|
|
Don't update git submodules. Useful for building with submodules at specific
|
|
|
|
revisions.
|
2017-06-05 10:22:09 -03:00
|
|
|
''')
|
|
|
|
|
|
|
|
g.add_option('--rsync-dest',
|
|
|
|
dest='rsync_dest',
|
|
|
|
action='store',
|
|
|
|
default='',
|
|
|
|
help='''
|
|
|
|
Destination for the rsync Waf command. It can be passed during configuration in
|
|
|
|
order to save typing.
|
2016-05-23 10:48:39 -03:00
|
|
|
''')
|
2016-02-19 12:44:32 -04:00
|
|
|
|
2016-02-17 09:13:37 -04:00
|
|
|
g.add_option('--enable-benchmarks',
|
2016-05-23 10:48:39 -03:00
|
|
|
action='store_true',
|
|
|
|
default=False,
|
|
|
|
help='Enable benchmarks.')
|
2016-02-17 09:13:37 -04:00
|
|
|
|
2016-05-25 23:06:19 -03:00
|
|
|
g.add_option('--disable-lttng', action='store_true',
|
|
|
|
default=False,
|
|
|
|
help="Don't use lttng even if supported by board and dependencies available")
|
|
|
|
|
2016-05-27 08:21:20 -03:00
|
|
|
g.add_option('--disable-libiio', action='store_true',
|
|
|
|
default=False,
|
|
|
|
help="Don't use libiio even if supported by board and dependencies available")
|
|
|
|
|
2016-07-13 10:50:31 -03:00
|
|
|
g.add_option('--disable-tests', action='store_true',
|
|
|
|
default=False,
|
|
|
|
help="Disable compilation and test execution")
|
|
|
|
|
2017-08-06 06:24:04 -03:00
|
|
|
g.add_option('--disable-header-checks', action='store_true',
|
|
|
|
default=False,
|
|
|
|
help="Disable checking of headers")
|
|
|
|
|
2016-07-12 23:26:24 -03:00
|
|
|
g.add_option('--static',
|
|
|
|
action='store_true',
|
|
|
|
default=False,
|
|
|
|
help='Force a static build')
|
|
|
|
|
2018-01-07 18:57:00 -04:00
|
|
|
g.add_option('--default-parameters',
|
|
|
|
default=None,
|
|
|
|
help='set default parameters to embed in the firmware')
|
|
|
|
|
2016-06-21 10:07:44 -03:00
|
|
|
def _collect_autoconfig_files(cfg):
|
|
|
|
for m in sys.modules.values():
|
|
|
|
paths = []
|
|
|
|
if hasattr(m, '__file__'):
|
|
|
|
paths.append(m.__file__)
|
|
|
|
elif hasattr(m, '__path__'):
|
|
|
|
for p in m.__path__:
|
|
|
|
paths.append(p)
|
|
|
|
|
|
|
|
for p in paths:
|
|
|
|
if p in cfg.files or not os.path.isfile(p):
|
|
|
|
continue
|
|
|
|
|
|
|
|
with open(p, 'rb') as f:
|
|
|
|
cfg.hash = Utils.h_list((cfg.hash, f.read()))
|
|
|
|
cfg.files.append(p)
|
|
|
|
|
2015-10-09 11:03:59 -03:00
|
|
|
def configure(cfg):
|
2015-12-10 14:22:07 -04:00
|
|
|
cfg.env.BOARD = cfg.options.board
|
2016-05-06 18:44:12 -03:00
|
|
|
cfg.env.DEBUG = cfg.options.debug
|
2016-07-28 18:46:42 -03:00
|
|
|
cfg.env.AUTOCONFIG = cfg.options.autoconfig
|
2016-05-06 18:44:12 -03:00
|
|
|
|
|
|
|
cfg.env.VARIANT = cfg.env.BOARD
|
|
|
|
if cfg.env.DEBUG:
|
|
|
|
cfg.env.VARIANT += '-debug'
|
2016-07-29 11:24:59 -03:00
|
|
|
|
|
|
|
_set_build_context_variant(cfg.env.VARIANT)
|
2016-05-06 18:44:12 -03:00
|
|
|
cfg.setenv(cfg.env.VARIANT)
|
2015-12-10 14:22:07 -04:00
|
|
|
|
2015-11-25 11:48:45 -04:00
|
|
|
cfg.env.BOARD = cfg.options.board
|
2016-05-06 18:44:12 -03:00
|
|
|
cfg.env.DEBUG = cfg.options.debug
|
|
|
|
|
2016-05-19 09:53:20 -03:00
|
|
|
# Allow to differentiate our build from the make build
|
|
|
|
cfg.define('WAF_BUILD', 1)
|
|
|
|
|
2016-07-28 18:46:42 -03:00
|
|
|
cfg.msg('Autoconfiguration', 'enabled' if cfg.options.autoconfig else 'disabled')
|
|
|
|
|
2016-07-12 23:26:24 -03:00
|
|
|
if cfg.options.static:
|
2016-07-19 12:10:21 -03:00
|
|
|
cfg.msg('Using static linking', 'yes', color='YELLOW')
|
|
|
|
cfg.env.STATIC_LINKING = True
|
2016-07-12 23:26:24 -03:00
|
|
|
|
2016-07-25 19:02:09 -03:00
|
|
|
cfg.load('ap_library')
|
|
|
|
|
2016-05-06 18:44:12 -03:00
|
|
|
cfg.msg('Setting board to', cfg.options.board)
|
2016-05-20 15:36:15 -03:00
|
|
|
cfg.get_board().configure(cfg)
|
2015-11-25 11:48:45 -04:00
|
|
|
|
2015-10-26 23:27:55 -03:00
|
|
|
cfg.load('clang_compilation_database')
|
2015-10-30 12:50:44 -03:00
|
|
|
cfg.load('waf_unit_test')
|
2016-01-02 07:22:36 -04:00
|
|
|
cfg.load('mavgen')
|
2017-04-02 11:56:50 -03:00
|
|
|
cfg.load('uavcangen')
|
2016-07-22 19:19:44 -03:00
|
|
|
|
|
|
|
cfg.env.SUBMODULE_UPDATE = cfg.options.submodule_update
|
|
|
|
|
|
|
|
cfg.start_msg('Source is git repository')
|
|
|
|
if cfg.srcnode.find_node('.git'):
|
|
|
|
cfg.end_msg('yes')
|
|
|
|
else:
|
|
|
|
cfg.end_msg('no')
|
|
|
|
cfg.env.SUBMODULE_UPDATE = False
|
|
|
|
|
2016-08-18 18:22:59 -03:00
|
|
|
cfg.msg('Update submodules', 'yes' if cfg.env.SUBMODULE_UPDATE else 'no')
|
|
|
|
cfg.load('git_submodule')
|
2016-07-22 19:19:44 -03:00
|
|
|
|
2016-02-17 09:13:37 -04:00
|
|
|
if cfg.options.enable_benchmarks:
|
|
|
|
cfg.load('gbenchmark')
|
2016-01-18 12:41:21 -04:00
|
|
|
cfg.load('gtest')
|
2016-01-07 07:16:53 -04:00
|
|
|
cfg.load('static_linking')
|
2016-05-25 12:24:58 -03:00
|
|
|
cfg.load('build_summary')
|
2015-11-12 17:39:30 -04:00
|
|
|
|
|
|
|
cfg.start_msg('Benchmarks')
|
|
|
|
if cfg.env.HAS_GBENCHMARK:
|
|
|
|
cfg.end_msg('enabled')
|
|
|
|
else:
|
|
|
|
cfg.end_msg('disabled', color='YELLOW')
|
2015-10-09 11:03:59 -03:00
|
|
|
|
2016-01-18 12:41:21 -04:00
|
|
|
cfg.start_msg('Unit tests')
|
|
|
|
if cfg.env.HAS_GTEST:
|
|
|
|
cfg.end_msg('enabled')
|
|
|
|
else:
|
|
|
|
cfg.end_msg('disabled', color='YELLOW')
|
2015-10-30 13:14:28 -03:00
|
|
|
|
2016-02-05 12:09:21 -04:00
|
|
|
cfg.env.append_value('GIT_SUBMODULES', 'mavlink')
|
|
|
|
|
2015-10-09 11:03:59 -03:00
|
|
|
cfg.env.prepend_value('INCLUDES', [
|
2016-01-02 07:22:36 -04:00
|
|
|
cfg.srcnode.abspath() + '/libraries/',
|
2016-01-13 16:52:56 -04:00
|
|
|
])
|
2015-10-09 11:03:59 -03:00
|
|
|
|
2017-06-05 10:22:09 -03:00
|
|
|
cfg.find_program('rsync', mandatory=False)
|
|
|
|
if cfg.options.rsync_dest:
|
|
|
|
cfg.msg('Setting rsync destination to', cfg.options.rsync_dest)
|
|
|
|
cfg.env.RSYNC_DEST = cfg.options.rsync_dest
|
|
|
|
|
2017-08-06 06:24:04 -03:00
|
|
|
if cfg.options.disable_header_checks:
|
|
|
|
cfg.msg('Disabling header checks', cfg.options.disable_header_checks)
|
|
|
|
cfg.env.DISABLE_HEADER_CHECKS = True
|
|
|
|
else:
|
|
|
|
cfg.env.DISABLE_HEADER_CHECKS = False
|
|
|
|
|
2015-10-09 11:03:59 -03:00
|
|
|
# TODO: Investigate if code could be changed to not depend on the
|
|
|
|
# source absolute path.
|
|
|
|
cfg.env.prepend_value('DEFINES', [
|
|
|
|
'SKETCHBOOK="' + cfg.srcnode.abspath() + '"',
|
|
|
|
])
|
|
|
|
|
2016-04-19 01:29:44 -03:00
|
|
|
# Always use system extensions
|
|
|
|
cfg.define('_GNU_SOURCE', 1)
|
|
|
|
|
2016-04-06 00:45:43 -03:00
|
|
|
cfg.write_config_header(os.path.join(cfg.variant, 'ap_config.h'))
|
2016-04-05 17:09:48 -03:00
|
|
|
|
2016-06-21 10:07:44 -03:00
|
|
|
_collect_autoconfig_files(cfg)
|
|
|
|
|
2015-11-04 09:34:11 -04:00
|
|
|
def collect_dirs_to_recurse(bld, globs, **kw):
|
2015-10-09 11:03:59 -03:00
|
|
|
dirs = []
|
2015-12-10 14:22:07 -04:00
|
|
|
globs = Utils.to_list(globs)
|
2016-03-09 18:36:35 -04:00
|
|
|
|
|
|
|
if bld.bldnode.is_child_of(bld.srcnode):
|
|
|
|
kw['excl'] = Utils.to_list(kw.get('excl', []))
|
|
|
|
kw['excl'].append(bld.bldnode.path_from(bld.srcnode))
|
|
|
|
|
2015-11-04 09:34:11 -04:00
|
|
|
for g in globs:
|
|
|
|
for d in bld.srcnode.ant_glob(g + '/wscript', **kw):
|
|
|
|
dirs.append(d.parent.relpath())
|
2015-10-09 11:03:59 -03:00
|
|
|
return dirs
|
|
|
|
|
2015-11-30 11:41:45 -04:00
|
|
|
def list_boards(ctx):
|
2015-11-26 10:34:24 -04:00
|
|
|
print(*boards.get_boards_names())
|
2015-11-30 11:41:45 -04:00
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
def _build_cmd_tweaks(bld):
|
2016-01-27 12:39:40 -04:00
|
|
|
if bld.cmd == 'check-all':
|
|
|
|
bld.options.all_tests = True
|
|
|
|
bld.cmd = 'check'
|
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
if bld.cmd == 'check':
|
|
|
|
if not bld.env.HAS_GTEST:
|
|
|
|
bld.fatal('check: gtest library is required')
|
2016-07-28 14:15:18 -03:00
|
|
|
bld.options.clear_failed_tests = True
|
2016-02-03 08:53:19 -04:00
|
|
|
|
2016-02-05 08:28:11 -04:00
|
|
|
def _build_dynamic_sources(bld):
|
2016-01-13 16:35:37 -04:00
|
|
|
bld(
|
|
|
|
features='mavgen',
|
|
|
|
source='modules/mavlink/message_definitions/v1.0/ardupilotmega.xml',
|
2016-05-16 02:16:03 -03:00
|
|
|
output_dir='libraries/GCS_MAVLink/include/mavlink/v2.0/',
|
2016-01-13 16:35:37 -04:00
|
|
|
name='mavlink',
|
2016-01-13 16:52:56 -04:00
|
|
|
# this below is not ideal, mavgen tool should set this, but that's not
|
|
|
|
# currently possible
|
|
|
|
export_includes=[
|
|
|
|
bld.bldnode.make_node('libraries').abspath(),
|
|
|
|
bld.bldnode.make_node('libraries/GCS_MAVLink').abspath(),
|
|
|
|
],
|
2016-01-13 16:35:37 -04:00
|
|
|
)
|
2016-01-02 07:22:36 -04:00
|
|
|
|
2018-03-01 03:26:28 -04:00
|
|
|
if bld.get_board().with_uavcan or bld.env.HAL_WITH_UAVCAN==True:
|
2017-04-02 11:56:50 -03:00
|
|
|
bld(
|
|
|
|
features='uavcangen',
|
|
|
|
source=bld.srcnode.ant_glob('modules/uavcan/dsdl/uavcan/**/*.uavcan'),
|
|
|
|
output_dir='modules/uavcan/libuavcan/include/dsdlc_generated',
|
|
|
|
name='uavcan',
|
|
|
|
export_includes=[
|
|
|
|
bld.bldnode.make_node('modules/uavcan/libuavcan/include/dsdlc_generated').abspath(),
|
|
|
|
]
|
|
|
|
)
|
|
|
|
|
2016-07-28 13:53:01 -03:00
|
|
|
def write_version_header(tsk):
|
|
|
|
bld = tsk.generator.bld
|
|
|
|
return bld.write_version_header(tsk.outputs[0].abspath())
|
|
|
|
|
|
|
|
bld(
|
|
|
|
name='ap_version',
|
|
|
|
target='ap_version.h',
|
|
|
|
vars=['AP_VERSION_ITEMS'],
|
|
|
|
rule=write_version_header,
|
|
|
|
)
|
|
|
|
|
2016-05-05 19:16:23 -03:00
|
|
|
bld.env.prepend_value('INCLUDES', [
|
|
|
|
bld.bldnode.abspath(),
|
|
|
|
])
|
|
|
|
|
2016-02-05 08:28:11 -04:00
|
|
|
def _build_common_taskgens(bld):
|
2015-10-09 11:03:59 -03:00
|
|
|
# NOTE: Static library with vehicle set to UNKNOWN, shared by all
|
|
|
|
# the tools and examples. This is the first step until the
|
|
|
|
# dependency on the vehicles is reduced. Later we may consider
|
|
|
|
# split into smaller pieces with well defined boundaries.
|
waf: use ardupilotwaf as a Waf tool
That will make it possible to replace calls of the form
`ardupilotwaf.<method>(bld, <keyword-args...>)` with
`bld.<method>(<keyword-args...>)` in the wscripts.
Advantages of that approach:
- there is no need to import ardupilotwaf in every single wscript
- it follows the same standard used by c and cxx tools (like bld.program,
bld.stlib etc)
- semantically, ap_program, ap_stlib, example etc are all build related
methods, so it makes sense to bind them to the build context
- from the wscripts' perspective, the code is cleaner, since ardupilotwaf,
which is not specific to just build contexts, isn't *explictly* used
2016-01-21 09:47:10 -04:00
|
|
|
bld.ap_stlib(
|
2015-10-09 11:03:59 -03:00
|
|
|
name='ap',
|
2016-07-25 17:31:08 -03:00
|
|
|
ap_vehicle='UNKNOWN',
|
|
|
|
ap_libraries=bld.ap_get_all_libraries(),
|
2015-10-09 11:03:59 -03:00
|
|
|
)
|
2016-02-02 16:38:42 -04:00
|
|
|
|
2016-07-13 10:50:31 -03:00
|
|
|
if bld.env.HAS_GTEST:
|
|
|
|
bld.libgtest(cxxflags=['-include', 'ap_config.h'])
|
2016-02-05 08:59:13 -04:00
|
|
|
|
2016-02-17 17:34:48 -04:00
|
|
|
if bld.env.HAS_GBENCHMARK:
|
|
|
|
bld.libbenchmark()
|
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
def _build_recursion(bld):
|
2016-02-02 16:38:42 -04:00
|
|
|
common_dirs_patterns = [
|
|
|
|
# TODO: Currently each vehicle also generate its own copy of the
|
|
|
|
# libraries. Fix this, or at least reduce the amount of
|
|
|
|
# vehicle-dependent libraries.
|
|
|
|
'*',
|
|
|
|
'Tools/*',
|
|
|
|
'libraries/*/examples/*',
|
2016-07-25 16:44:20 -03:00
|
|
|
'libraries/*/tests',
|
|
|
|
'libraries/*/utility/tests',
|
|
|
|
'libraries/*/benchmarks',
|
2016-02-02 16:38:42 -04:00
|
|
|
]
|
|
|
|
|
|
|
|
common_dirs_excl = [
|
|
|
|
'modules',
|
|
|
|
'libraries/AP_HAL_*',
|
|
|
|
'libraries/SITL',
|
|
|
|
]
|
|
|
|
|
|
|
|
hal_dirs_patterns = [
|
2016-10-25 15:29:29 -03:00
|
|
|
'libraries/%s/tests',
|
2016-07-25 16:44:20 -03:00
|
|
|
'libraries/%s/*/tests',
|
|
|
|
'libraries/%s/*/benchmarks',
|
2016-02-02 16:38:42 -04:00
|
|
|
'libraries/%s/examples/*',
|
|
|
|
]
|
|
|
|
|
|
|
|
dirs_to_recurse = collect_dirs_to_recurse(
|
|
|
|
bld,
|
|
|
|
common_dirs_patterns,
|
|
|
|
excl=common_dirs_excl,
|
|
|
|
)
|
|
|
|
|
|
|
|
for p in hal_dirs_patterns:
|
|
|
|
dirs_to_recurse += collect_dirs_to_recurse(
|
|
|
|
bld,
|
|
|
|
[p % l for l in bld.env.AP_LIBRARIES],
|
|
|
|
)
|
2015-10-09 11:03:59 -03:00
|
|
|
|
|
|
|
# NOTE: we need to sort to ensure the repeated sources get the
|
|
|
|
# same index, and random ordering of the filesystem doesn't cause
|
|
|
|
# recompilation.
|
2016-02-02 16:38:42 -04:00
|
|
|
dirs_to_recurse.sort()
|
|
|
|
|
|
|
|
for d in dirs_to_recurse:
|
2015-10-09 11:03:59 -03:00
|
|
|
bld.recurse(d)
|
2015-10-30 12:50:44 -03:00
|
|
|
|
2016-07-28 14:15:18 -03:00
|
|
|
def _build_post_funs(bld):
|
|
|
|
if bld.cmd == 'check':
|
|
|
|
bld.add_post_fun(ardupilotwaf.test_summary)
|
|
|
|
else:
|
|
|
|
bld.build_summary_post_fun()
|
|
|
|
|
|
|
|
if bld.env.SUBMODULE_UPDATE:
|
|
|
|
bld.git_submodule_post_fun()
|
2016-05-05 19:16:23 -03:00
|
|
|
|
2018-03-01 03:26:28 -04:00
|
|
|
def load_pre_build(bld):
|
|
|
|
'''allow for a pre_build() function in build modules'''
|
|
|
|
brd = bld.get_board()
|
|
|
|
if getattr(brd, 'pre_build', None):
|
|
|
|
brd.pre_build(bld)
|
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
def build(bld):
|
2016-05-20 09:16:01 -03:00
|
|
|
config_hash = Utils.h_file(bld.bldnode.make_node('ap_config.h').abspath())
|
|
|
|
bld.env.CCDEPS = config_hash
|
|
|
|
bld.env.CXXDEPS = config_hash
|
2016-04-05 17:09:48 -03:00
|
|
|
|
2016-02-05 08:28:11 -04:00
|
|
|
bld.post_mode = Build.POST_LAZY
|
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
bld.load('ardupilotwaf')
|
|
|
|
|
2016-07-25 19:02:09 -03:00
|
|
|
bld.env.AP_LIBRARIES_OBJECTS_KW.update(
|
2017-04-02 11:56:50 -03:00
|
|
|
use=['mavlink'],
|
2016-07-25 19:02:09 -03:00
|
|
|
cxxflags=['-include', 'ap_config.h'],
|
|
|
|
)
|
2018-03-01 03:26:28 -04:00
|
|
|
|
|
|
|
load_pre_build(bld)
|
|
|
|
|
2017-04-02 11:56:50 -03:00
|
|
|
if bld.get_board().with_uavcan:
|
|
|
|
bld.env.AP_LIBRARIES_OBJECTS_KW['use'] += ['uavcan']
|
2016-07-25 19:02:09 -03:00
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
_build_cmd_tweaks(bld)
|
2016-02-05 08:28:11 -04:00
|
|
|
|
2016-02-19 12:44:32 -04:00
|
|
|
if bld.env.SUBMODULE_UPDATE:
|
|
|
|
bld.add_group('git_submodules')
|
|
|
|
for name in bld.env.GIT_SUBMODULES:
|
|
|
|
bld.git_submodule(name)
|
2016-02-05 08:28:11 -04:00
|
|
|
|
|
|
|
bld.add_group('dynamic_sources')
|
|
|
|
_build_dynamic_sources(bld)
|
|
|
|
|
|
|
|
bld.add_group('build')
|
2016-05-20 15:36:15 -03:00
|
|
|
bld.get_board().build(bld)
|
2016-02-05 08:28:11 -04:00
|
|
|
_build_common_taskgens(bld)
|
|
|
|
|
2016-02-03 08:53:19 -04:00
|
|
|
_build_recursion(bld)
|
2015-10-30 12:50:44 -03:00
|
|
|
|
2016-07-28 14:15:18 -03:00
|
|
|
_build_post_funs(bld)
|
2016-05-05 19:16:23 -03:00
|
|
|
|
2016-01-27 12:16:37 -04:00
|
|
|
ardupilotwaf.build_command('check',
|
2016-01-27 12:07:36 -04:00
|
|
|
program_group_list='all',
|
|
|
|
doc='builds all programs and run tests',
|
|
|
|
)
|
2016-01-27 12:39:40 -04:00
|
|
|
ardupilotwaf.build_command('check-all',
|
|
|
|
program_group_list='all',
|
|
|
|
doc='shortcut for `waf check --alltests`',
|
|
|
|
)
|
2016-01-15 12:14:00 -04:00
|
|
|
|
2018-04-07 01:30:13 -03:00
|
|
|
for name in ('antennatracker', 'copter', 'heli', 'plane', 'rover', 'sub'):
|
2016-03-24 17:18:06 -03:00
|
|
|
ardupilotwaf.build_command(name,
|
|
|
|
program_group_list=name,
|
|
|
|
doc='builds %s programs' % name,
|
|
|
|
)
|
2016-01-27 08:57:29 -04:00
|
|
|
|
|
|
|
for program_group in ('all', 'bin', 'tools', 'examples', 'tests', 'benchmarks'):
|
2016-01-27 12:16:37 -04:00
|
|
|
ardupilotwaf.build_command(program_group,
|
2016-01-27 11:58:48 -04:00
|
|
|
program_group_list=program_group,
|
|
|
|
doc='builds all programs of %s group' % program_group,
|
|
|
|
)
|
2017-06-05 09:39:14 -03:00
|
|
|
|
|
|
|
class LocalInstallContext(Build.InstallContext):
|
|
|
|
"""runs install using BLD/install as destdir, where BLD is the build variant directory"""
|
2017-06-29 17:58:35 -03:00
|
|
|
cmd = 'localinstall'
|
2017-06-05 09:39:14 -03:00
|
|
|
|
|
|
|
def __init__(self, **kw):
|
|
|
|
super(LocalInstallContext, self).__init__(**kw)
|
|
|
|
self.local_destdir = os.path.join(self.variant_dir, 'install')
|
|
|
|
|
|
|
|
def execute(self):
|
|
|
|
old_destdir = self.options.destdir
|
|
|
|
self.options.destdir = self.local_destdir
|
|
|
|
r = super(LocalInstallContext, self).execute()
|
|
|
|
self.options.destdir = old_destdir
|
|
|
|
return r
|
2017-06-05 10:22:09 -03:00
|
|
|
|
|
|
|
class RsyncContext(LocalInstallContext):
|
2017-06-29 17:58:35 -03:00
|
|
|
"""runs localinstall and then rsyncs BLD/install with the target system"""
|
2017-06-05 10:22:09 -03:00
|
|
|
cmd = 'rsync'
|
|
|
|
|
|
|
|
def __init__(self, **kw):
|
|
|
|
super(RsyncContext, self).__init__(**kw)
|
|
|
|
self.add_pre_fun(RsyncContext.create_rsync_taskgen)
|
|
|
|
|
|
|
|
def create_rsync_taskgen(self):
|
|
|
|
if 'RSYNC' not in self.env:
|
|
|
|
self.fatal('rsync program seems not to be installed, can\'t continue')
|
|
|
|
|
|
|
|
self.add_group()
|
|
|
|
|
|
|
|
tg = self(
|
|
|
|
name='rsync',
|
|
|
|
rule='${RSYNC} -a ${RSYNC_SRC}/ ${RSYNC_DEST}',
|
|
|
|
always=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
tg.env.RSYNC_SRC = self.local_destdir
|
|
|
|
if self.options.rsync_dest:
|
|
|
|
self.env.RSYNC_DEST = self.options.rsync_dest
|
|
|
|
|
|
|
|
if 'RSYNC_DEST' not in tg.env:
|
|
|
|
self.fatal('Destination for rsync not defined. Either pass --rsync-dest here or during configuration.')
|
|
|
|
|
|
|
|
tg.post()
|