Skip to content

Commit

Permalink
[workspace] Deprecate the stduuid external (RobotLocomotion#18610)
Browse files Browse the repository at this point in the history
Co-Authored-By: Betsy McPhail <[email protected]>
Co-Authored-By: Matthew Woehlke <[email protected]>
Co-Authored-By: Russ Tedrake <[email protected]>
  • Loading branch information
4 people authored and Marco A. Gutierrez committed Feb 6, 2023
1 parent cfc9456 commit 500bce4
Show file tree
Hide file tree
Showing 9 changed files with 99 additions and 13 deletions.
2 changes: 1 addition & 1 deletion geometry/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -471,7 +471,7 @@ drake_cc_library(
"//common:unused",
"@common_robotics_utilities",
"@msgpack_internal//:msgpack",
"@stduuid",
"@stduuid_internal//:stduuid",
"@uwebsockets",
],
)
Expand Down
2 changes: 1 addition & 1 deletion geometry/meshcat.cc
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,8 @@
#include <App.h>
#include <common_robotics_utilities/base64_helpers.hpp>
#include <drake_vendor/msgpack.hpp>
#include <drake_vendor/uuid.h>
#include <fmt/format.h>
#include <uuid.h>

#include "drake/common/drake_throw.h"
#include "drake/common/find_resource.h"
Expand Down
1 change: 1 addition & 0 deletions tools/workspace/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,7 @@ _DRAKE_EXTERNAL_PACKAGE_INSTALLS = ["@%s//:install" % p for p in [
"sdformat_internal",
"spdlog",
"statsjs",
"stduuid_internal",
"tinyobjloader",
"tinyxml2_internal",
"usockets",
Expand Down
3 changes: 3 additions & 0 deletions tools/workspace/default.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ load("@drake//tools/workspace/spdlog:repository.bzl", "spdlog_repository")
load("@drake//tools/workspace/stable_baselines3_internal:repository.bzl", "stable_baselines3_internal_repository") # noqa
load("@drake//tools/workspace/statsjs:repository.bzl", "statsjs_repository")
load("@drake//tools/workspace/stduuid:repository.bzl", "stduuid_repository")
load("@drake//tools/workspace/stduuid_internal:repository.bzl", "stduuid_internal_repository") # noqa
load("@drake//tools/workspace/styleguide:repository.bzl", "styleguide_repository") # noqa
load("@drake//tools/workspace/suitesparse:repository.bzl", "suitesparse_repository") # noqa
load("@drake//tools/workspace/tinyobjloader:repository.bzl", "tinyobjloader_repository") # noqa
Expand Down Expand Up @@ -297,6 +298,8 @@ def add_default_repositories(excludes = [], mirrors = DEFAULT_MIRRORS):
statsjs_repository(name = "statsjs", mirrors = mirrors)
if "stduuid" not in excludes:
stduuid_repository(name = "stduuid", mirrors = mirrors)
if "stduuid_internal" not in excludes:
stduuid_internal_repository(name = "stduuid_internal", mirrors = mirrors) # noqa
if "styleguide" not in excludes:
styleguide_repository(name = "styleguide", mirrors = mirrors)
if "suitesparse" not in excludes:
Expand Down
12 changes: 1 addition & 11 deletions tools/workspace/stduuid/package.BUILD.bazel
Original file line number Diff line number Diff line change
@@ -1,10 +1,5 @@
# -*- python -*-

load(
"@drake//tools/install:install.bzl",
"install",
)

licenses(["notice"]) # MIT

package(default_visibility = ["//visibility:public"])
Expand All @@ -14,10 +9,5 @@ cc_library(
hdrs = glob(["include/uuid.h", "gsl/*"]),
includes = ["include", "."],
linkstatic = 1,
)

# Install the license file.
install(
name = "install",
docs = ["LICENSE"],
deprecation = "DRAKE DEPRECATED: The @stduuid external is deprecated. The deprecated code will be removed from Drake on or after 2023-05-01.", # noqa,
)
8 changes: 8 additions & 0 deletions tools/workspace/stduuid_internal/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
# -*- python -*-

# This file exists to make our directory into a Bazel package, so that our
# neighboring *.bzl file can be loaded elsewhere.

load("//tools/lint:lint.bzl", "add_lint_tests")

add_lint_tests()
34 changes: 34 additions & 0 deletions tools/workspace/stduuid_internal/package.BUILD.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
# -*- python -*-

load(
"@drake//tools/install:install.bzl",
"install",
)

licenses(["notice"]) # MIT

package(default_visibility = ["//visibility:public"])

# TODO(jwnimmer-tri) Once we require >= C++20, i.e., once we drop support for
# Ubuntu 20.04 Focal, then we should remove the thus-unused gsl cc_library.
cc_library(
name = "gsl",
hdrs = glob(["gsl/*"], allow_empty = False),
includes = ["."],
linkstatic = 1,
)

cc_library(
name = "stduuid",
hdrs = ["include/uuid.h"],
strip_include_prefix = "include",
include_prefix = "drake_vendor",
linkstatic = 1,
deps = [":gsl"],
)

# Install the license file.
install(
name = "install",
docs = ["LICENSE"],
)
31 changes: 31 additions & 0 deletions tools/workspace/stduuid_internal/patches/vendor.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
Add vendoring namespace and disable std::hash

This prevents ODR violations in case downstream code also links to stduuid.

--- include/uuid.h
+++ include/uuid.h
@@ -49,6 +49,7 @@

#endif

+inline namespace drake_vendor __attribute__ ((visibility ("hidden"))) {
namespace uuids
{
#ifdef __cpp_lib_span
@@ -900,7 +901,9 @@
};
#endif
}
+} // namespace drake_vendor

+#if 0 // Disable std::hash<> specialization.
namespace std
{
template <>
@@ -947,5 +950,6 @@
}
};
}
+#endif

#endif /* STDUUID_H */
19 changes: 19 additions & 0 deletions tools/workspace/stduuid_internal/repository.bzl
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# -*- mode: python -*-
# vi: set ft=python :

load("@drake//tools/workspace:github.bzl", "github_archive")

def stduuid_internal_repository(
name,
mirrors = None):
github_archive(
name = name,
repository = "mariusbancila/stduuid",
commit = "3afe7193facd5d674de709fccc44d5055e144d7a",
sha256 = "e11f9bf30c7f9c03d8e9a3a3fd7fe016eb5d8d9b89a2fe2c11b5f049e1d97916", # noqa
build_file = ":package.BUILD.bazel",
patches = [
":patches/vendor.patch",
],
mirrors = mirrors,
)

0 comments on commit 500bce4

Please sign in to comment.