diff options
Diffstat (limited to 'mesonbuild')
-rw-r--r-- | mesonbuild/environment.py | 3 | ||||
-rw-r--r-- | mesonbuild/interpreter.py | 15 |
2 files changed, 18 insertions, 0 deletions
diff --git a/mesonbuild/environment.py b/mesonbuild/environment.py index e1e4613..3868301 100644 --- a/mesonbuild/environment.py +++ b/mesonbuild/environment.py @@ -771,6 +771,9 @@ class CrossBuildInfo(): def get_stdlib(self, language): return self.config['properties'][language + '_stdlib'] + def get_properties(self): + return self.config['properties'] + # Wehn compiling a cross compiler we use the native compiler for everything. # But not when cross compiling a cross compiler. def need_cross_compiler(self): diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py index 5281be5..df4cb0d 100644 --- a/mesonbuild/interpreter.py +++ b/mesonbuild/interpreter.py @@ -866,6 +866,7 @@ class MesonMain(InterpreterObject): 'install_dependency_manifest': self.install_dependency_manifest_method, 'project_version': self.project_version_method, 'project_name' : self.project_name_method, + 'get_cross_property': self.get_cross_property_method, }) def add_install_script_method(self, args, kwargs): @@ -965,6 +966,20 @@ class MesonMain(InterpreterObject): def project_name_method(self, args, kwargs): return self.interpreter.active_projectname + def get_cross_property_method(self, args, kwargs): + if len(args) < 1 or len(args) > 2: + raise InterpreterException('Must have one or two arguments.') + propname = args[0] + if not isinstance(propname, str): + raise InterpreterException('Property name must be string.') + try: + props = self.interpreter.environment.cross_info.get_properties() + return props[propname] + except Exception: + if len(args) == 2: + return args[1] + raise InterpreterException('Unknown cross property: %s.' % propname) + class Interpreter(): def __init__(self, build, backend, subproject='', subdir='', subproject_dir='subprojects'): |