diff options
author | murgatroid99 <mlumish@google.com> | 2016-01-12 14:32:40 -0800 |
---|---|---|
committer | murgatroid99 <mlumish@google.com> | 2016-01-12 14:32:40 -0800 |
commit | 4518bf7f108b80445365f8d70da777a648fbe0f5 (patch) | |
tree | a28723956bccb7da9e6287a4faae12681f67c170 /tools/buildgen/plugins | |
parent | 0ade2d415ff5dbc9fca7b942809ef7179db08ef7 (diff) |
Allow transitive dependencies plugin to process non-existent libs without crashing
Diffstat (limited to 'tools/buildgen/plugins')
-rw-r--r-- | tools/buildgen/plugins/transitive_dependencies.py | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/tools/buildgen/plugins/transitive_dependencies.py b/tools/buildgen/plugins/transitive_dependencies.py index 1fc76a3cd5..01e7f61ea9 100644 --- a/tools/buildgen/plugins/transitive_dependencies.py +++ b/tools/buildgen/plugins/transitive_dependencies.py @@ -1,4 +1,4 @@ -# Copyright 2015, Google Inc. +# Copyright 2015-2016, Google Inc. # All rights reserved. # # Redistribution and use in source and binary forms, with or without @@ -36,10 +36,13 @@ of the list of dependencies. """ def get_lib(libs, name): - return next(lib for lib in libs if lib['name']==name) + try: + return next(lib for lib in libs if lib['name']==name) + except StopIteration: + return None def transitive_deps(lib, libs): - if 'deps' in lib: + if lib is not None and 'deps' in lib: # Recursively call transitive_deps on each dependency, and take the union return set.union(set(lib['deps']), *[set(transitive_deps(get_lib(libs, dep), libs)) |