|
|
@ -1,4 +1,4 @@ |
|
|
|
#!/usr/bin/env python |
|
|
|
#!/usr/bin/env python3 |
|
|
|
|
|
|
|
|
|
|
|
# Copyright 2016 gRPC authors. |
|
|
|
# Copyright 2016 gRPC authors. |
|
|
|
# |
|
|
|
# |
|
|
@ -14,8 +14,6 @@ |
|
|
|
# See the License for the specific language governing permissions and |
|
|
|
# See the License for the specific language governing permissions and |
|
|
|
# limitations under the License. |
|
|
|
# limitations under the License. |
|
|
|
|
|
|
|
|
|
|
|
from __future__ import print_function |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import ast |
|
|
|
import ast |
|
|
|
import os |
|
|
|
import os |
|
|
|
import re |
|
|
|
import re |
|
|
@ -27,8 +25,8 @@ os.chdir(os.path.join(os.path.dirname(sys.argv[0]), '../../..')) |
|
|
|
git_hash_pattern = re.compile('[0-9a-f]{40}') |
|
|
|
git_hash_pattern = re.compile('[0-9a-f]{40}') |
|
|
|
|
|
|
|
|
|
|
|
# Parse git hashes from submodules |
|
|
|
# Parse git hashes from submodules |
|
|
|
git_submodules = subprocess.check_output('git submodule', |
|
|
|
git_submodules = subprocess.check_output( |
|
|
|
shell=True).strip().split('\n') |
|
|
|
'git submodule', shell=True).decode().strip().split('\n') |
|
|
|
git_submodule_hashes = { |
|
|
|
git_submodule_hashes = { |
|
|
|
re.search(git_hash_pattern, s).group() for s in git_submodules |
|
|
|
re.search(git_hash_pattern, s).group() for s in git_submodules |
|
|
|
} |
|
|
|
} |
|
|
@ -148,17 +146,14 @@ build_rules = { |
|
|
|
'git_repository': lambda **args: eval_state.git_repository(**args), |
|
|
|
'git_repository': lambda **args: eval_state.git_repository(**args), |
|
|
|
'grpc_python_deps': lambda: None, |
|
|
|
'grpc_python_deps': lambda: None, |
|
|
|
} |
|
|
|
} |
|
|
|
exec(bazel_file) in build_rules |
|
|
|
exec((bazel_file), build_rules) |
|
|
|
for name in _GRPC_DEP_NAMES: |
|
|
|
for name in _GRPC_DEP_NAMES: |
|
|
|
assert name in names_and_urls.keys() |
|
|
|
assert name in list(names_and_urls.keys()) |
|
|
|
if len(_GRPC_DEP_NAMES) != len(names_and_urls.keys()): |
|
|
|
assert len(_GRPC_DEP_NAMES) == len(list(names_and_urls.keys())) |
|
|
|
assert False, "Diff: " + (str(set(_GRPC_DEP_NAMES) - set(names_and_urls)) + |
|
|
|
|
|
|
|
"," + |
|
|
|
|
|
|
|
str(set(names_and_urls) - set(_GRPC_DEP_NAMES))) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# There are some "bazel-only" deps that are exceptions to this sanity check, |
|
|
|
# There are some "bazel-only" deps that are exceptions to this sanity check, |
|
|
|
# we don't require that there is a corresponding git module for these. |
|
|
|
# we don't require that there is a corresponding git module for these. |
|
|
|
names_without_bazel_only_deps = names_and_urls.keys() |
|
|
|
names_without_bazel_only_deps = list(names_and_urls.keys()) |
|
|
|
for dep_name in _GRPC_BAZEL_ONLY_DEPS: |
|
|
|
for dep_name in _GRPC_BAZEL_ONLY_DEPS: |
|
|
|
names_without_bazel_only_deps.remove(dep_name) |
|
|
|
names_without_bazel_only_deps.remove(dep_name) |
|
|
|
archive_urls = [names_and_urls[name] for name in names_without_bazel_only_deps] |
|
|
|
archive_urls = [names_and_urls[name] for name in names_without_bazel_only_deps] |
|
|
@ -195,7 +190,7 @@ for name in _GRPC_DEP_NAMES: |
|
|
|
'git_repository': lambda **args: state.git_repository(**args), |
|
|
|
'git_repository': lambda **args: state.git_repository(**args), |
|
|
|
'grpc_python_deps': lambda *args, **kwargs: None, |
|
|
|
'grpc_python_deps': lambda *args, **kwargs: None, |
|
|
|
} |
|
|
|
} |
|
|
|
exec(bazel_file) in rules |
|
|
|
exec((bazel_file), rules) |
|
|
|
assert name not in names_and_urls_with_overridden_name.keys() |
|
|
|
assert name not in list(names_and_urls_with_overridden_name.keys()) |
|
|
|
|
|
|
|
|
|
|
|
sys.exit(0) |
|
|
|
sys.exit(0) |
|
|
|