workspace(name = "com_github_grpc_grpc")

load("//bazel:grpc_deps.bzl", "grpc_deps", "grpc_test_only_deps")

grpc_deps()

grpc_test_only_deps()

load("//bazel:grpc_extra_deps.bzl", "grpc_extra_deps")

grpc_extra_deps()

register_execution_platforms(
    "//third_party/toolchains:rbe_windows",
)

register_toolchains(
    "//third_party/toolchains/bazel_0.26.0_rbe_windows:cc-toolchain-x64_windows",
)

load("@bazel_toolchains//rules/exec_properties:exec_properties.bzl", "create_exec_properties_dict", "custom_exec_properties", "merge_dicts")

custom_exec_properties(
    name = "grpc_custom_exec_properties",
    constants = {
        "LARGE_MACHINE": merge_dicts(
            create_exec_properties_dict(),
            # TODO(jtattermusch): specifying 'labels = {"abc": "xyz"}' in create_exec_properties_dict
            # is not possible without https://github.com/bazelbuild/bazel-toolchains/pull/748
            # and currently the toolchain we're using is too old for that. To be able to select worker
            # pools through labels, we use a workaround and populate the corresponding label values
            # manually (see create_exec_properties_dict logic for how labels get transformed)
            # Remove this workaround once we transition to a new-enough bazel toolchain.
            # The next line corresponds to 'labels = {"os": "ubuntu", "machine_size": "large"}'
            {
                "label:os": "ubuntu",
                "label:machine_size": "large",
            },
        ),
    },
)

load("@bazel_toolchains//rules:rbe_repo.bzl", "rbe_autoconfig")

# Create toolchain configuration for remote execution.
rbe_autoconfig(
    name = "rbe_default",
    exec_properties = merge_dicts(
        create_exec_properties_dict(
            docker_add_capabilities = "SYS_PTRACE",
            docker_privileged = True,
            os_family = "Linux",
        ),
        # TODO(jtattermusch): specifying 'labels = {"abc": "xyz"}' in create_exec_properties_dict
        # is not possible without https://github.com/bazelbuild/bazel-toolchains/pull/748
        # and currently the toolchain we're using is too old for that. To be able to select worker
        # pools through labels, we use a workaround and populate the corresponding label values
        # manually (see create_exec_properties_dict logic for how labels get transformed)
        # Remove this workaround once we transition to a new-enough bazel toolchain.
        # The next line corresponds to 'labels = {"os": "ubuntu", "machine_size": "small"}'
        {
            "label:os": "ubuntu",
            "label:machine_size": "small",
        },
    ),
    # use exec_properties instead of deprecated remote_execution_properties
    use_legacy_platform_definition = False,
)

load("@bazel_toolchains//rules:environments.bzl", "clang_env")
load("@bazel_skylib//lib:dicts.bzl", "dicts")

# Create msan toolchain configuration for remote execution.
rbe_autoconfig(
    name = "rbe_msan",
    env = dicts.add(
        clang_env(),
        {
            "BAZEL_LINKOPTS": "-lc++:-lc++abi:-lm",
        },
    ),
)

load("@io_bazel_rules_python//python:pip.bzl", "pip_import", "pip_repositories")

pip_import(
    name = "grpc_python_dependencies",
    requirements = "@com_github_grpc_grpc//:requirements.bazel.txt",
)

load("@grpc_python_dependencies//:requirements.bzl", "pip_install")

pip_repositories()

pip_install()