diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2018-11-15 22:47:51 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-11-15 22:47:51 +0200 |
commit | c104251d2ef1ca1c4b8caea52fa6ab2da1dbaefe (patch) | |
tree | 0beb5ebae4bdbaf8e2385f644e7e6a8c406d0213 /mesonbuild/interpreter.py | |
parent | 6a2dc7576e00e849510f7bc1f939d66d0b2f6f80 (diff) | |
parent | 0ab27add49cedb6f5985dfba7ba40c8d29ae91dc (diff) | |
download | meson-c104251d2ef1ca1c4b8caea52fa6ab2da1dbaefe.zip meson-c104251d2ef1ca1c4b8caea52fa6ab2da1dbaefe.tar.gz meson-c104251d2ef1ca1c4b8caea52fa6ab2da1dbaefe.tar.bz2 |
Merge pull request #4216 from dcbaker/wip/config-file
native file support
Diffstat (limited to 'mesonbuild/interpreter.py')
-rw-r--r-- | mesonbuild/interpreter.py | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py index d7a5b66..e820afb 100644 --- a/mesonbuild/interpreter.py +++ b/mesonbuild/interpreter.py @@ -2748,8 +2748,7 @@ external dependencies (including libraries) must go to "dependencies".''') self.coredata. base_options[optname] = oobj self.emit_base_options_warnings(enabled_opts) - def program_from_cross_file(self, prognames, silent=False): - cross_info = self.environment.cross_info + def _program_from_file(self, prognames, bins, silent): for p in prognames: if hasattr(p, 'held_object'): p = p.held_object @@ -2757,11 +2756,19 @@ external dependencies (including libraries) must go to "dependencies".''') continue # Always points to a local (i.e. self generated) file. if not isinstance(p, str): raise InterpreterException('Executable name must be a string') - prog = ExternalProgram.from_cross_info(cross_info, p) + prog = ExternalProgram.from_bin_list(bins, p) if prog.found(): return ExternalProgramHolder(prog) return None + def program_from_cross_file(self, prognames, silent=False): + bins = self.environment.cross_info.config['binaries'] + return self._program_from_file(prognames, bins, silent) + + def program_from_config_file(self, prognames, silent=False): + bins = self.environment.config_info.binaries + return self._program_from_file(prognames, bins, silent) + def program_from_system(self, args, silent=False): # Search for scripts relative to current subdir. # Do not cache found programs because find_program('foobar') @@ -2816,10 +2823,14 @@ external dependencies (including libraries) must go to "dependencies".''') def find_program_impl(self, args, native=False, required=True, silent=True): if not isinstance(args, list): args = [args] + progobj = self.program_from_overrides(args, silent=silent) - if progobj is None and self.build.environment.is_cross_build(): - if not native: + if progobj is None: + if self.build.environment.is_cross_build() and not native: progobj = self.program_from_cross_file(args, silent=silent) + else: + progobj = self.program_from_config_file(args, silent=silent) + if progobj is None: progobj = self.program_from_system(args, silent=silent) if required and (progobj is None or not progobj.found()): |