From 49e97fb704467e6be6d485fa84566b12dee93de1 Mon Sep 17 00:00:00 2001 From: Ross Burton Date: Wed, 4 Jul 2018 15:59:18 +0100 Subject: [PATCH] gtkdoc: pass the cross compiler if cross compiling When cross-compiling, tell gtkdoc to use the cross compile instead of the target compiler. --- mesonbuild/modules/gnome.py | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/mesonbuild/modules/gnome.py b/mesonbuild/modules/gnome.py index f3eabdae4..9b04333ea 100644 --- a/mesonbuild/modules/gnome.py +++ b/mesonbuild/modules/gnome.py @@ -848,20 +848,27 @@ This will become a hard error in the future.''') if not isinstance(incd.held_object, (str, build.IncludeDirs)): raise MesonException( 'Gir include dirs should be include_directories().') + cflags.update(get_include_args(inc_dirs)) - cflags.update(state.environment.coredata.get_external_args('c')) ldflags = OrderedSet() ldflags.update(internal_ldflags) - ldflags.update(state.environment.coredata.get_external_link_args('c')) ldflags.update(external_ldflags) + + if state.environment.is_cross_build(): + compiler = state.environment.coredata.cross_compilers.get('c') + else: + cflags.update(state.environment.coredata.get_external_args('c')) + ldflags.update(state.environment.coredata.get_external_link_args('c')) + compiler = state.environment.coredata.compilers.get('c') + + if compiler: + args += ['--cc=%s' % ' '.join(compiler.get_exelist())] + args += ['--ld=%s' % ' '.join(compiler.get_linker_exelist())] if cflags: args += ['--cflags=%s' % ' '.join(cflags)] if ldflags: args += ['--ldflags=%s' % ' '.join(ldflags)] - compiler = state.environment.coredata.compilers.get('c') - if compiler: - args += ['--cc=%s' % ' '.join(compiler.get_exelist())] - args += ['--ld=%s' % ' '.join(compiler.get_linker_exelist())] + return args