Log instead of raise if Boost module invalid

BOOST_LIBS could become outdated in future versions, which would result
in dependency('boost', modules : [ 'foo' ], required : false) to fail,
although required was set to false. Therefore turn the exception into
log_fail(). If required was set to true, this will still be caught since
is_found remains False.

This also improves logging by printing all invalid module names instead
of only the first one.
pull/2624/head
Jan Niklas Hasse 7 years ago committed by Jussi Pakkanen
parent 18b42c5370
commit c3d143298b
  1. 7
      mesonbuild/dependencies/misc.py

@ -66,6 +66,11 @@ class BoostDependency(ExternalDependency):
self.is_multithreading = threading == "multi" self.is_multithreading = threading == "multi"
self.requested_modules = self.get_requested(kwargs) self.requested_modules = self.get_requested(kwargs)
invalid_modules = [c for c in self.requested_modules if 'boost_' + c not in BOOST_LIBS]
if invalid_modules:
mlog.debug('Invalid Boost modules: ' + ', '.join(invalid_modules))
self.log_fail()
return
self.boost_root = None self.boost_root = None
self.boost_roots = [] self.boost_roots = []
@ -198,8 +203,6 @@ class BoostDependency(ExternalDependency):
for c in candidates: for c in candidates:
if not isinstance(c, str): if not isinstance(c, str):
raise DependencyException('Boost module argument is not a string.') raise DependencyException('Boost module argument is not a string.')
if 'boost_' + c not in BOOST_LIBS:
raise DependencyException('Dependency {} not found. It is not a valid boost library.'.format(c))
return candidates return candidates
def validate_requested(self): def validate_requested(self):

Loading…
Cancel
Save