diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2019-04-02 23:10:16 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-02 23:10:16 +0300 |
commit | b1aa54bb2911ecf0f26391a9b1e0a6cd308913b5 (patch) | |
tree | 6ce41b5ac3e03f3cda19ee6dda5669789a5fcedd /mesonbuild/ast/introspection.py | |
parent | ff477d2b3f5ddc582140e6d357e52f1cb1da74ce (diff) | |
parent | 6da0df95c11fac6037d421ae8cf80af146d321da (diff) | |
download | meson-b1aa54bb2911ecf0f26391a9b1e0a6cd308913b5.zip meson-b1aa54bb2911ecf0f26391a9b1e0a6cd308913b5.tar.gz meson-b1aa54bb2911ecf0f26391a9b1e0a6cd308913b5.tar.bz2 |
Merge pull request #5197 from mensinda/introDepBugFix
mintro: Fix crash when required is a function (closes #5177)
Diffstat (limited to 'mesonbuild/ast/introspection.py')
-rw-r--r-- | mesonbuild/ast/introspection.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/mesonbuild/ast/introspection.py b/mesonbuild/ast/introspection.py index 5745d29..5a12e29 100644 --- a/mesonbuild/ast/introspection.py +++ b/mesonbuild/ast/introspection.py @@ -20,7 +20,7 @@ from .. import compilers, environment, mesonlib, optinterpreter from .. import coredata as cdata from ..interpreterbase import InvalidArguments from ..build import Executable, Jar, SharedLibrary, SharedModule, StaticLibrary -from ..mparser import ArithmeticNode, ArrayNode, ElementaryNode, IdNode, FunctionNode, StringNode +from ..mparser import BaseNode, ArithmeticNode, ArrayNode, ElementaryNode, IdNode, FunctionNode, StringNode import os build_target_functions = ['executable', 'jar', 'library', 'shared_library', 'shared_module', 'static_library', 'both_libraries'] @@ -142,6 +142,8 @@ class IntrospectionInterpreter(AstInterpreter): condition_level = node.condition_level if hasattr(node, 'condition_level') else 0 if isinstance(required, ElementaryNode): required = required.value + if not isinstance(required, bool): + required = False self.dependencies += [{ 'name': name, 'required': required, @@ -189,6 +191,8 @@ class IntrospectionInterpreter(AstInterpreter): # Make sure nothing can crash when creating the build class kwargs_reduced = {k: v for k, v in kwargs.items() if k in targetclass.known_kwargs and k in ['install', 'build_by_default', 'build_always']} + kwargs_reduced = {k: v.value if isinstance(v, ElementaryNode) else v for k, v in kwargs_reduced.items()} + kwargs_reduced = {k: v for k, v in kwargs_reduced.items() if not isinstance(v, BaseNode)} is_cross = False objects = [] empty_sources = [] # Passing the unresolved sources list causes errors |