aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar murgatroid99 <mlumish@google.com>2016-01-12 14:32:40 -0800
committerGravatar murgatroid99 <mlumish@google.com>2016-01-12 14:32:40 -0800
commit4518bf7f108b80445365f8d70da777a648fbe0f5 (patch)
treea28723956bccb7da9e6287a4faae12681f67c170
parent0ade2d415ff5dbc9fca7b942809ef7179db08ef7 (diff)
Allow transitive dependencies plugin to process non-existent libs without crashing
-rw-r--r--tools/buildgen/plugins/transitive_dependencies.py9
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))