diff --git a/WORKSPACE b/WORKSPACE index ffebcde55414cb..04d0e0d3fa193d 100644 --- a/WORKSPACE +++ b/WORKSPACE @@ -20,7 +20,7 @@ tf_workspace() # Specify the minimum required bazel version. load("//tensorflow:tensorflow.bzl", "check_version") -check_version("0.1.4") +check_version("0.2.0") # TENSORBOARD_BOWER_AUTOGENERATED_BELOW_THIS_LINE_DO_NOT_EDIT diff --git a/configure b/configure index 5d6397da57de27..98048ba91db480 100755 --- a/configure +++ b/configure @@ -2,17 +2,6 @@ DO_NOT_SUBMIT_WARNING="Unofficial setting. DO NOT SUBMIT!!!" -## Verify that the submodule google/protobuf is available -# TODO(cais): Remove this check once protobuf is no longer depended upon -if [[ ! -f "google/protobuf/protobuf.bzl" ]]; then - echo "ERROR: It appears that the required submodule google/protobuf is not "\ -"available in this TensorFlow git clone." - echo "Please be sure to use the --recurse-submodules flag when performing "\ -"git clone of TensorFlow." - - exit 1 -fi - ## Set up python-related environment settings while true; do fromuser="" diff --git a/gmock.BUILD b/gmock.BUILD new file mode 100644 index 00000000000000..82abf2754086ba --- /dev/null +++ b/gmock.BUILD @@ -0,0 +1,28 @@ +cc_library( + name = "gtest", + srcs = [ + "gmock-1.7.0/gtest/src/gtest-all.cc", + "gmock-1.7.0/src/gmock-all.cc", + ], + hdrs = glob([ + "gmock-1.7.0/**/*.h", + "gmock-1.7.0/gtest/src/*.cc", + "gmock-1.7.0/src/*.cc", + ]), + includes = [ + "gmock-1.7.0", + "gmock-1.7.0/gtest", + "gmock-1.7.0/gtest/include", + "gmock-1.7.0/include", + ], + linkopts = ["-pthread"], + visibility = ["//visibility:public"], +) + +cc_library( + name = "gtest_main", + srcs = ["gmock-1.7.0/src/gmock_main.cc"], + linkopts = ["-pthread"], + visibility = ["//visibility:public"], + deps = [":gtest"], +) diff --git a/tensorflow/contrib/ffmpeg/default/BUILD b/tensorflow/contrib/ffmpeg/default/BUILD index e1b7bb61924019..6e25a61e430fa5 100644 --- a/tensorflow/contrib/ffmpeg/default/BUILD +++ b/tensorflow/contrib/ffmpeg/default/BUILD @@ -16,7 +16,7 @@ cc_library( "//tensorflow/contrib/ffmpeg:ffmpeg_lib.h", ], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", ], ) diff --git a/tensorflow/contrib/layers/kernels/BUILD b/tensorflow/contrib/layers/kernels/BUILD index 62926e2df41ea6..c540147cd89565 100644 --- a/tensorflow/contrib/layers/kernels/BUILD +++ b/tensorflow/contrib/layers/kernels/BUILD @@ -11,7 +11,7 @@ cc_library( name = "bucketization_kernel", srcs = ["bucketization_kernel.cc"], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", "//third_party/eigen3", ], @@ -22,7 +22,7 @@ cc_library( name = "sparse_feature_cross_kernel", srcs = ["sparse_feature_cross_kernel.cc"], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", "//third_party/eigen3", ], diff --git a/tensorflow/contrib/linear_optimizer/kernels/BUILD b/tensorflow/contrib/linear_optimizer/kernels/BUILD index ac9a33ccc4d53d..8a92fa20330e9a 100644 --- a/tensorflow/contrib/linear_optimizer/kernels/BUILD +++ b/tensorflow/contrib/linear_optimizer/kernels/BUILD @@ -21,7 +21,7 @@ cc_library( "squared-loss.h", ], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", ], ) @@ -43,7 +43,7 @@ cc_library( srcs = ["resources.cc"], hdrs = ["resources.h"], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", "//third_party/eigen3", ], @@ -66,9 +66,9 @@ cc_library( name = "sdca_ops", srcs = ["sdca_ops.cc"], deps = [ + "@protobuf//:protobuf", ":loss_updaters", ":resources", - "//google/protobuf", "//tensorflow/core:framework_headers_lib", "//tensorflow/core/kernels:bounds_check_lib", "//third_party/eigen3", diff --git a/tensorflow/contrib/metrics/kernels/BUILD b/tensorflow/contrib/metrics/kernels/BUILD index 4ba121db83a234..71dac11c80fa7e 100644 --- a/tensorflow/contrib/metrics/kernels/BUILD +++ b/tensorflow/contrib/metrics/kernels/BUILD @@ -11,7 +11,7 @@ cc_library( name = "set_kernels", srcs = ["set_kernels.cc"], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", "//third_party/eigen3", ], diff --git a/tensorflow/contrib/tensor_forest/BUILD b/tensorflow/contrib/tensor_forest/BUILD index 33c66a6bc2c8ac..c9934e50ac89f4 100644 --- a/tensorflow/contrib/tensor_forest/BUILD +++ b/tensorflow/contrib/tensor_forest/BUILD @@ -25,7 +25,7 @@ cc_library( "core/ops/tree_utils.h", ], deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", "//third_party/eigen3", ], diff --git a/tensorflow/core/platform/default/build_config.bzl b/tensorflow/core/platform/default/build_config.bzl index c20db730795260..f6eb40f600a259 100644 --- a/tensorflow/core/platform/default/build_config.bzl +++ b/tensorflow/core/platform/default/build_config.bzl @@ -1,7 +1,7 @@ # Platform-specific build configurations. -load("//google/protobuf:protobuf.bzl", "cc_proto_library") -load("//google/protobuf:protobuf.bzl", "py_proto_library") +load("@protobuf//:protobuf.bzl", "cc_proto_library") +load("@protobuf//:protobuf.bzl", "py_proto_library") # configure may change the following line to True WITH_GCP_SUPPORT = False @@ -31,29 +31,39 @@ def tf_proto_library_cc(name, srcs = [], has_services = None, cc_api_version = 2, go_api_version = 2, java_api_version = 2, py_api_version = 2): - native.filegroup(name=name + "_proto_srcs", - srcs=srcs + tf_deps(deps, "_proto_srcs"), - testonly=testonly,) + native.filegroup( + name = name + "_proto_srcs", + srcs = srcs + tf_deps(deps, "_proto_srcs"), + testonly = testonly, + ) use_grpc_plugin = None if cc_grpc_version: use_grpc_plugin = True - cc_proto_library(name=name + "_cc", - srcs=srcs + tf_deps(deps, "_proto_srcs"), - deps=deps + ["//google/protobuf:cc_wkt_protos"], - cc_libs = cc_libs + ["//google/protobuf:protobuf"], - use_grpc_plugin = use_grpc_plugin, - testonly=testonly, - visibility=visibility,) + cc_proto_library( + name = name + "_cc", + srcs = srcs + tf_deps(deps, "_proto_srcs"), + deps = deps + ["@protobuf//:cc_wkt_protos"], + cc_libs = cc_libs + ["@protobuf//:protobuf"], + protoc = "@protobuf//:protoc", + default_runtime = "@protobuf//:protobuf", + use_grpc_plugin = use_grpc_plugin, + testonly = testonly, + visibility = visibility, + ) def tf_proto_library_py(name, srcs=[], deps=[], visibility=[], testonly=0, srcs_version="PY2AND3"): - py_proto_library(name = name + "_py", - srcs = srcs, - srcs_version = srcs_version, - deps = deps, - visibility = visibility, - testonly = testonly) + py_proto_library( + name = name + "_py", + srcs = srcs, + srcs_version = srcs_version, + deps = deps, + protoc = "@protobuf//:protoc", + default_runtime = "@protobuf//:protobuf_python", + visibility = visibility, + testonly = testonly, + ) def tf_proto_library(name, srcs = [], has_services = None, deps = [], visibility = [], testonly = 0, @@ -61,19 +71,23 @@ def tf_proto_library(name, srcs = [], has_services = None, cc_api_version = 2, go_api_version = 2, java_api_version = 2, py_api_version = 2): - tf_proto_library_cc(name=name, - srcs=srcs + tf_deps(deps, "_proto_srcs"), - deps=deps, - cc_libs=cc_libs, - testonly=testonly, - visibility=visibility,) - - tf_proto_library_py(name=name, - srcs=srcs + tf_deps(deps, "_proto_srcs"), - srcs_version="PY2AND3", - deps=deps + ["//google/protobuf:protobuf_python"], - testonly=testonly, - visibility=visibility,) + tf_proto_library_cc( + name = name, + srcs = srcs + tf_deps(deps, "_proto_srcs"), + deps = deps, + cc_libs = cc_libs, + testonly = testonly, + visibility = visibility, + ) + + tf_proto_library_py( + name = name, + srcs = srcs + tf_deps(deps, "_proto_srcs"), + srcs_version = "PY2AND3", + deps = deps + ["@protobuf//:protobuf_python"], + testonly = testonly, + visibility = visibility, + ) def tf_additional_lib_srcs(): return [ diff --git a/tensorflow/g3doc/api_docs/python/constant_op.md b/tensorflow/g3doc/api_docs/python/constant_op.md index 008174f9d6f60c..1aaf39bd50b970 100644 --- a/tensorflow/g3doc/api_docs/python/constant_op.md +++ b/tensorflow/g3doc/api_docs/python/constant_op.md @@ -60,7 +60,7 @@ tf.zeros_like(tensor) ==> [[0, 0, 0], [0, 0, 0]] * `tensor`: A `Tensor`. * `dtype`: A type for the returned `Tensor`. Must be `float32`, `float64`, - `int8`, `int16`, `int32`, `int64`, `uint8`, or `complex64`. + `int8`, `int16`, `int32`, `int64`, `uint8`, `complex64`, or `complex128`. * `name`: A name for the operation (optional). @@ -119,7 +119,7 @@ tf.ones_like(tensor) ==> [[1, 1, 1], [1, 1, 1]] * `tensor`: A `Tensor`. * `dtype`: A type for the returned `Tensor`. Must be `float32`, `float64`, - `int8`, `int16`, `int32`, `int64`, `uint8`, or `complex64`. + `int8`, `int16`, `int32`, `int64`, `uint8`, `complex64` or `complex128`. * `name`: A name for the operation (optional). diff --git a/tensorflow/g3doc/api_docs/python/nn.md b/tensorflow/g3doc/api_docs/python/nn.md index 06305b097bae0e..3db704e9d9b1aa 100644 --- a/tensorflow/g3doc/api_docs/python/nn.md +++ b/tensorflow/g3doc/api_docs/python/nn.md @@ -163,7 +163,7 @@ case where both types are quantized. * `value`: A `Tensor` with type `float`, `double`, `int64`, `int32`, `uint8`, - `int16`, `int8`, or `complex64`. + `int16`, `int8`, `complex64` or `complex128`. * `bias`: A 1-D `Tensor` with size matching the last dimension of `value`. Must be the same type as `value` unless `value` is a quantized type, in which case a different quantized type may be used. @@ -186,7 +186,7 @@ Specifically, `y = 1 / (1 + exp(-x))`. ##### Args: -* `x`: A Tensor with type `float`, `double`, `int32`, `complex64`, `int64`, +* `x`: A Tensor with type `float`, `double`, `int32`, `complex64`, `complex128`, `int64`, or `qint32`. * `name`: A name for the operation (optional). @@ -205,7 +205,7 @@ Computes hyperbolic tangent of `x` element-wise. ##### Args: -* `x`: A Tensor with type `float`, `double`, `int32`, `complex64`, `int64`, +* `x`: A Tensor with type `float`, `double`, `int32`, `complex64`, `complex128`, `int64`, or `qint32`. * `name`: A name for the operation (optional). diff --git a/tensorflow/python/BUILD b/tensorflow/python/BUILD index 4b290f15097b54..b7e2a462e5792d 100644 --- a/tensorflow/python/BUILD +++ b/tensorflow/python/BUILD @@ -134,7 +134,7 @@ cc_binary( }), linkshared = 1, deps = [ - "//google/protobuf", + "@protobuf//:protobuf", "//tensorflow/core:framework_headers_lib", ], ) @@ -885,7 +885,7 @@ py_library( name = "util", srcs = glob(["util/**/*.py"]), srcs_version = "PY2AND3", - deps = ["//google/protobuf:protobuf_python"], + deps = ["@protobuf//:protobuf_python"], ) tf_proto_library( diff --git a/tensorflow/tensorflow.bzl b/tensorflow/tensorflow.bzl index 4eb5619ecd72d2..bc22150f237cdc 100644 --- a/tensorflow/tensorflow.bzl +++ b/tensorflow/tensorflow.bzl @@ -539,7 +539,7 @@ def cc_header_only_library(name, deps=[], **kwargs): def tf_custom_op_library_additional_deps(): return [ - "//google/protobuf", + "@protobuf//:protobuf", "//third_party/eigen3", "//tensorflow/core:framework_headers_lib", ] diff --git a/tensorflow/tools/benchmark/BUILD b/tensorflow/tools/benchmark/BUILD index ef7aa2398e9393..e926a456732ab1 100644 --- a/tensorflow/tools/benchmark/BUILD +++ b/tensorflow/tools/benchmark/BUILD @@ -61,7 +61,7 @@ tf_cc_test( # --host_crosstool_top=@bazel_tools//tools/cpp:toolchain # # NOTE: currently '-pthread' must be removed from the LINK_OPTS variable -# in google/protobuf/BUILD to sucessfully build for Android. This is temporary +# in @protobuf//:BUILD to sucessfully build for Android. This is temporary # pending an update of the version of the protobuf library that Tensorflow # uses. cc_binary( diff --git a/tensorflow/tools/pip_package/BUILD b/tensorflow/tools/pip_package/BUILD index dbf89e5bc67357..0253f1e218900f 100644 --- a/tensorflow/tools/pip_package/BUILD +++ b/tensorflow/tools/pip_package/BUILD @@ -27,10 +27,10 @@ sh_binary( "MANIFEST.in", "README", "setup.py", - "//tensorflow/core:framework_headers", ":other_headers", ":simple_console", "//tensorflow:tensorflow_py", + "//tensorflow/core:framework_headers", "//tensorflow/examples/tutorials/mnist:package", "//tensorflow/models/embedding:package", "//tensorflow/models/image/alexnet:all_files", diff --git a/tensorflow/tools/pip_package/build_pip_package.sh b/tensorflow/tools/pip_package/build_pip_package.sh index 7f123937e8bbd5..fd60d1da6e66ea 100755 --- a/tensorflow/tools/pip_package/build_pip_package.sh +++ b/tensorflow/tools/pip_package/build_pip_package.sh @@ -61,8 +61,9 @@ function main() { # protobuf pip package doesn't ship with header files. Copy the headers # over so user defined ops can be compiled. + mkdir -p ${TMPDIR}/google rsync --include "*/" --include "*.h" --exclude "*" --prune-empty-dirs -a \ - $RUNFILES/google ${TMPDIR} + $RUNFILES/external/protobuf ${TMPDIR}/google rsync -a $RUNFILES/third_party/eigen3 ${TMPDIR}/third_party cp tensorflow/tools/pip_package/MANIFEST.in ${TMPDIR} diff --git a/tensorflow/workspace.bzl b/tensorflow/workspace.bzl index b95f84ce5e43e8..5632f6850b7cc8 100644 --- a/tensorflow/workspace.bzl +++ b/tensorflow/workspace.bzl @@ -4,13 +4,6 @@ # within the workspace (e.g. "tensorflow/"), and tf_repo_name is the name of the # local_repository rule (e.g. "@tf"). def tf_workspace(path_prefix = "", tf_repo_name = ""): - native.new_http_archive( - name = "gmock_archive", - url = "https://archive.openswitch.net/gmock-1.7.0.zip", - sha256 = "26fcbb5925b74ad5fc8c26b0495dfc96353f4d553492eb97e85a8a6d2f43095b", - build_file = path_prefix + "google/protobuf/gmock.BUILD", - ) - native.new_http_archive( name = "eigen_archive", url = "https://bitbucket.org/eigen/eigen/get/f3a13643ac1f.tar.gz", @@ -18,16 +11,6 @@ def tf_workspace(path_prefix = "", tf_repo_name = ""): build_file = path_prefix + "eigen.BUILD", ) - native.bind( - name = "gtest", - actual = "@gmock_archive//:gtest", - ) - - native.bind( - name = "gtest_main", - actual = "@gmock_archive//:gtest_main", - ) - native.git_repository( name = "re2", remote = "https://github.com/google/re2.git", @@ -85,16 +68,44 @@ def tf_workspace(path_prefix = "", tf_repo_name = ""): actual = "@six_archive//:six", ) + native.git_repository( + name = "protobuf", + remote = "https://github.com/google/protobuf", + commit = "ed87c1fe2c6e1633cadb62cf54b2723b2b25c280", + ) + + native.new_http_archive( + name = "gmock_archive", + url = "https://archive.openswitch.net/gmock-1.7.0.zip", + sha256 = "26fcbb5925b74ad5fc8c26b0495dfc96353f4d553492eb97e85a8a6d2f43095b", + build_file = path_prefix + "gmock.BUILD", + ) + + native.bind( + name = "gtest", + actual = "@gmock_archive//:gtest", + ) + + native.bind( + name = "gtest_main", + actual = "@gmock_archive//:gtest_main", + ) + + native.bind( + name = "python_headers", + actual = tf_repo_name + "//util/python:python_headers", + ) + # grpc expects //external:protobuf_clib and //external:protobuf_compiler # to point to the protobuf's compiler library. native.bind( name = "protobuf_clib", - actual = tf_repo_name + "//google/protobuf:protoc_lib", + actual = "@protobuf//:protoc_lib", ) native.bind( name = "protobuf_compiler", - actual = tf_repo_name + "//google/protobuf:protoc_lib", + actual = "@protobuf//:protoc_lib", ) native.git_repository( diff --git a/tools/bazel.rc.template b/tools/bazel.rc.template index 2a88b98f3472d3..d3e70e7a4fc58b 100644 --- a/tools/bazel.rc.template +++ b/tools/bazel.rc.template @@ -9,3 +9,7 @@ build --define=allow_oversize_protos=true build --spawn_strategy=standalone test --spawn_strategy=standalone run --spawn_strategy=standalone + +build --genrule_strategy=standalone +test --genrule_strategy=standalone +run --genrule_strategy=standalone