diff --git a/geometry/BUILD.bazel b/geometry/BUILD.bazel index fb0a67b892dc..03545843bdbc 100644 --- a/geometry/BUILD.bazel +++ b/geometry/BUILD.bazel @@ -87,7 +87,7 @@ drake_cc_library( "//geometry/proximity:hydroelastic_callback", "//geometry/proximity:obj_to_surface_mesh", "//geometry/proximity:penetration_as_point_pair_callback", - "@fcl", + "@fcl_internal//:fcl", "@fmt", ], ) @@ -668,7 +668,7 @@ drake_cc_googletest( "//geometry/proximity:hydroelastic_callback", "//geometry/proximity:make_sphere_mesh", "//math", - "@fcl", + "@fcl_internal//:fcl", ], ) diff --git a/geometry/proximity/BUILD.bazel b/geometry/proximity/BUILD.bazel index 8509daf55c38..fe0aa73c6f24 100644 --- a/geometry/proximity/BUILD.bazel +++ b/geometry/proximity/BUILD.bazel @@ -146,7 +146,7 @@ drake_cc_library( ":collision_filter", ":proximity_utilities", "//geometry:geometry_ids", - "@fcl", + "@fcl_internal//:fcl", ], ) @@ -234,7 +234,7 @@ drake_cc_library( "//geometry:geometry_ids", "//geometry/query_results:signed_distance_to_point", "//math:geometric_transform", - "@fcl", + "@fcl_internal//:fcl", ], ) @@ -285,7 +285,7 @@ drake_cc_library( ":collision_filter", ":proximity_utilities", "//common:sorted_pair", - "@fcl", + "@fcl_internal//:fcl", "@fmt", ], ) @@ -312,7 +312,7 @@ drake_cc_library( "//geometry:proximity_properties", "//geometry/query_results:contact_surface", "//math:geometric_transform", - "@fcl", + "@fcl_internal//:fcl", "@fmt", ], ) @@ -683,7 +683,7 @@ drake_cc_library( "//common:nice_type_name", "//geometry/query_results:penetration_as_point_pair", "//geometry/query_results:signed_distance_to_point", - "@fcl", + "@fcl_internal//:fcl", ], ) @@ -734,7 +734,7 @@ drake_cc_library( "//common:sorted_pair", "//geometry:geometry_ids", "//geometry:shape_specification", - "@fcl", + "@fcl_internal//:fcl", "@fmt", ], ) @@ -870,7 +870,7 @@ drake_cc_library( "//geometry:utilities", "//geometry/proximity:proximity_utilities", "//math:geometric_transform", - "@fcl", + "@fcl_internal//:fcl", ], ) diff --git a/tools/install/check_licenses.bzl b/tools/install/check_licenses.bzl index 08fbf0b296bd..32827353a4c7 100644 --- a/tools/install/check_licenses.bzl +++ b/tools/install/check_licenses.bzl @@ -4,7 +4,7 @@ load("@drake//tools/install:install.bzl", "InstallInfo") # List of exact file names of license files LICENSE_LITERALS = [ - "BSD-LICENSE", # @ccd + "BSD-LICENSE", # @ccd_internal "COPYING", "Copyright.txt", # @vtk "EULA.pdf", # @gurobi diff --git a/tools/workspace/BUILD.bazel b/tools/workspace/BUILD.bazel index 45537cde836e..3f61412ab5eb 100644 --- a/tools/workspace/BUILD.bazel +++ b/tools/workspace/BUILD.bazel @@ -77,12 +77,12 @@ drake_py_binary( ) _DRAKE_EXTERNAL_PACKAGE_INSTALLS = ["@%s//:install" % p for p in [ - "ccd", + "ccd_internal", "com_jidesoft_jide_oss", "common_robotics_utilities", "commons_io", "curl_internal", - "fcl", + "fcl_internal", "fmt", "gz_math_internal", "gz_utils_internal", diff --git a/tools/workspace/ccd/package.BUILD.bazel b/tools/workspace/ccd/package.BUILD.bazel index d1d84cc6bcd8..636c2626226b 100644 --- a/tools/workspace/ccd/package.BUILD.bazel +++ b/tools/workspace/ccd/package.BUILD.bazel @@ -4,10 +4,6 @@ load( "@drake//tools/workspace:cmake_configure_file.bzl", "cmake_configure_file", ) -load( - "@drake//tools/install:install.bzl", - "install", -) licenses(["notice"]) # BSD-3-Clause @@ -58,9 +54,5 @@ cc_library( defines = ["CCD_STATIC_DEFINE"], includes = ["src"], linkstatic = 1, -) - -install( - name = "install", - docs = ["BSD-LICENSE"], + deprecation = "DRAKE DEPRECATED: The @ccd external is deprecated. The deprecated code will be removed from Drake on or after 2023-05-01.", # noqa, ) diff --git a/tools/workspace/ccd_internal/BUILD.bazel b/tools/workspace/ccd_internal/BUILD.bazel new file mode 100644 index 000000000000..7198e3bb9b53 --- /dev/null +++ b/tools/workspace/ccd_internal/BUILD.bazel @@ -0,0 +1,5 @@ +# -*- python -*- + +load("//tools/lint:lint.bzl", "add_lint_tests") + +add_lint_tests() diff --git a/tools/workspace/ccd_internal/package.BUILD.bazel b/tools/workspace/ccd_internal/package.BUILD.bazel new file mode 100644 index 000000000000..d1d84cc6bcd8 --- /dev/null +++ b/tools/workspace/ccd_internal/package.BUILD.bazel @@ -0,0 +1,66 @@ +# -*- python -*- + +load( + "@drake//tools/workspace:cmake_configure_file.bzl", + "cmake_configure_file", +) +load( + "@drake//tools/install:install.bzl", + "install", +) + +licenses(["notice"]) # BSD-3-Clause + +package( + default_visibility = ["//visibility:public"], +) + +# Generates config.h based on the defines= we want in Drake. +cmake_configure_file( + name = "config", + src = "src/ccd/config.h.cmake.in", + out = "src/ccd/config.h", + defines = ["CCD_DOUBLE"], + visibility = ["//visibility:private"], +) + +# Guessing headers with +# install(... +# guess_hdrs = "PACKAGE", +# ) +# fails and lists internal headers in addition to the public headers. +CCD_PUBLIC_HEADERS = [ + "src/ccd/ccd.h", + "src/ccd/config.h", + "src/ccd/compiler.h", + "src/ccd/quat.h", + "src/ccd/vec3.h", + "src/ccd/ccd_export.h", +] + +# Options used when building the ccd code. Handled by cmake in upstream code +CCD_COPTS = [ + "-Wno-all", + "-fvisibility=hidden", +] + +# Generates the library exported to users. Upstream's CMake code lists out all +# sources instead of globbing, but conveniently puts the public headers in one +# place and private sources and headers in another; we'll use globbing here. +cc_library( + name = "ccd", + srcs = glob([ + "src/*.c", + "src/*.h", + ]), + hdrs = CCD_PUBLIC_HEADERS, + copts = CCD_COPTS, + defines = ["CCD_STATIC_DEFINE"], + includes = ["src"], + linkstatic = 1, +) + +install( + name = "install", + docs = ["BSD-LICENSE"], +) diff --git a/tools/workspace/ccd_internal/repository.bzl b/tools/workspace/ccd_internal/repository.bzl new file mode 100644 index 000000000000..92f29d832819 --- /dev/null +++ b/tools/workspace/ccd_internal/repository.bzl @@ -0,0 +1,15 @@ +# -*- python -*- + +load("@drake//tools/workspace:github.bzl", "github_archive") + +def ccd_internal_repository( + name, + mirrors = None): + github_archive( + name = name, + repository = "danfis/libccd", + commit = "7931e764a19ef6b21b443376c699bbc9c6d4fba8", + sha256 = "479994a86d32e2effcaad64204142000ee6b6b291fd1859ac6710aee8d00a482", # noqa + build_file = ":package.BUILD.bazel", + mirrors = mirrors, + ) diff --git a/tools/workspace/default.bzl b/tools/workspace/default.bzl index ddb294a94ea8..e1f4e2974021 100644 --- a/tools/workspace/default.bzl +++ b/tools/workspace/default.bzl @@ -8,6 +8,7 @@ load("@drake//tools/workspace/blas:repository.bzl", "blas_repository") load("@drake//tools/workspace/buildifier:repository.bzl", "buildifier_repository") # noqa load("@drake//tools/workspace/cc:repository.bzl", "cc_repository") load("@drake//tools/workspace/ccd:repository.bzl", "ccd_repository") +load("@drake//tools/workspace/ccd_internal:repository.bzl", "ccd_internal_repository") # noqa load("@drake//tools/workspace/cds:repository.bzl", "cds_repository") load("@drake//tools/workspace/clang_cindex_python3_internal:repository.bzl", "clang_cindex_python3_internal_repository") # noqa load("@drake//tools/workspace/clp:repository.bzl", "clp_repository") @@ -24,7 +25,8 @@ load("@drake//tools/workspace/drake_visualizer:repository.bzl", "drake_visualize load("@drake//tools/workspace/dreal:repository.bzl", "dreal_repository") load("@drake//tools/workspace/eigen:repository.bzl", "eigen_repository") load("@drake//tools/workspace/expat:repository.bzl", "expat_repository") -load("@drake//tools/workspace/fcl:repository.bzl", "fcl_repository") +load("@drake//tools/workspace/fcl:repository.bzl", "fcl_repository") # noqa +load("@drake//tools/workspace/fcl_internal:repository.bzl", "fcl_internal_repository") # noqa load("@drake//tools/workspace/fmt:repository.bzl", "fmt_repository") load("@drake//tools/workspace/gflags:repository.bzl", "gflags_repository") load("@drake//tools/workspace/gfortran:repository.bzl", "gfortran_repository") @@ -126,6 +128,8 @@ def add_default_repositories(excludes = [], mirrors = DEFAULT_MIRRORS): cc_repository(name = "cc") if "ccd" not in excludes: ccd_repository(name = "ccd", mirrors = mirrors) + if "ccd_internal" not in excludes: + ccd_internal_repository(name = "ccd_internal", mirrors = mirrors) if "cds" not in excludes: # N.B. This repository is deprecated for removal on 2023-02-01. # For details see https://github.com/RobotLocomotion/drake/pull/18156. @@ -166,6 +170,8 @@ def add_default_repositories(excludes = [], mirrors = DEFAULT_MIRRORS): expat_repository(name = "expat") if "fcl" not in excludes: fcl_repository(name = "fcl", mirrors = mirrors) + if "fcl_internal" not in excludes: + fcl_internal_repository(name = "fcl_internal", mirrors = mirrors) if "fmt" not in excludes: fmt_repository(name = "fmt", mirrors = mirrors) if "gflags" not in excludes: diff --git a/tools/workspace/fcl/package.BUILD.bazel b/tools/workspace/fcl/package.BUILD.bazel index 1189063c819b..0d9793c05e73 100644 --- a/tools/workspace/fcl/package.BUILD.bazel +++ b/tools/workspace/fcl/package.BUILD.bazel @@ -4,10 +4,6 @@ load( "@drake//tools/workspace:cmake_configure_file.bzl", "cmake_configure_file", ) -load( - "@drake//tools/install:install.bzl", - "install", -) load( "@drake//tools/workspace:generate_export_header.bzl", "generate_export_header", @@ -136,9 +132,5 @@ cc_library( "@ccd", "@eigen", ], -) - -install( - name = "install", - docs = ["LICENSE"], + deprecation = "DRAKE DEPRECATED: The @fcl external is deprecated. The deprecated code will be removed from Drake on or after 2023-05-01.", # noqa, ) diff --git a/tools/workspace/fcl_internal/BUILD.bazel b/tools/workspace/fcl_internal/BUILD.bazel new file mode 100644 index 000000000000..3fd11df9ff21 --- /dev/null +++ b/tools/workspace/fcl_internal/BUILD.bazel @@ -0,0 +1,7 @@ +# -*- python -*- + +load("//tools/lint:lint.bzl", "add_lint_tests") + +exports_files(["version-from-xml.sed"]) + +add_lint_tests() diff --git a/tools/workspace/fcl_internal/package.BUILD.bazel b/tools/workspace/fcl_internal/package.BUILD.bazel new file mode 100644 index 000000000000..0747ebd51a87 --- /dev/null +++ b/tools/workspace/fcl_internal/package.BUILD.bazel @@ -0,0 +1,144 @@ +# -*- python -*- + +load( + "@drake//tools/workspace:cmake_configure_file.bzl", + "cmake_configure_file", +) +load( + "@drake//tools/install:install.bzl", + "install", +) +load( + "@drake//tools/workspace:generate_export_header.bzl", + "generate_export_header", +) +load( + "@drake//tools/workspace:generate_include_header.bzl", + "drake_generate_include_header", +) + +licenses(["notice"]) # BSD-3-Clause + +package( + default_visibility = ["//visibility:public"], +) + +# Generate header to provide ABI export symbols for fcl. +generate_export_header( + out = "include/fcl/export.h", + lib = "fcl", + static_define = "FCL_STATIC_DEFINE", +) + +# Generates a version.cmake stub based on package.xml contents. +genrule( + name = "version-from-xml.cmake_genrule", + srcs = [ + "package.xml", + "@drake//tools/workspace/fcl_internal:version-from-xml.sed", + ], + outs = [ + "version-from-xml.cmake", + ], + cmd = " ".join([ + "sed", + "-f $(execpath @drake//tools/workspace/fcl_internal:version-from-xml.sed)", # noqa + "-n $(execpath package.xml) > $@", + "&&", + "test -s $@", + ]), +) + +# Generates config.h based on the version numbers in CMake code. +cmake_configure_file( + name = "config", + src = "include/fcl/config.h.in", + out = "include/fcl/config.h", + cmakelists = [ + ":version-from-xml.cmake", + ], + defines = [ + "OCTOMAP_MAJOR_VERSION=0", + "OCTOMAP_MINOR_VERSION=0", + "OCTOMAP_PATCH_VERSION=0", + "GENERATED_FILE_MARKER=GENERATED FILE DO NOT EDIT", + ], + visibility = ["//visibility:private"], +) + +# Provide all headers (except octomap-related ones) for simplicitly, even +# though many of these will not have their '*.cpp' mate compiled. +_HDRS = glob( + include = [ + "include/**/*.h", + ], + exclude = [ + "**/octree/**", + ], + allow_empty = False, +) + +# To minimize the build footprint, only build the fraction of FCL that is +# needed by Drake. +_DRAKE_RELEVANT_SRCS = glob( + include = [ + "src/**/*.cpp", + ], + exclude = [ + # We use none of this code. + "**/*conservative_advancement*.cpp", + "**/*continuous_collision*.cpp", + "**/octree/**", + "src/common/**", + "src/math/motion/**", + "src/math/sampler/**", + # We list out the few of these that we need immediately below. + "src/broadphase/*.cpp", + "src/broadphase/detail/*.cpp", + "src/math/*.cpp", + "src/math/detail/*.cpp", + ], + allow_empty = False, +) + [ + "src/broadphase/broadphase_collision_manager.cpp", + "src/broadphase/broadphase_dynamic_AABB_tree.cpp", + "src/broadphase/detail/morton.cpp", + "src/math/geometry.cpp", + "src/math/triangle.cpp", + "src/math/detail/polysolver.cpp", + "src/math/detail/project.cpp", +] + +# Generates fcl.h, which consists of #include statements for *all* of the other +# headers in the library (!!!). The first line is '#pragma once' followed by +# one line like '#include "fcl/common/types.h"' for each non-generated header. +drake_generate_include_header( + name = "fcl_h_genrule", + out = "include/fcl/fcl.h", + hdrs = _HDRS, +) + +cc_library( + name = "fcl", + srcs = _DRAKE_RELEVANT_SRCS, + hdrs = _HDRS + [ + ":config", + ":fcl_h_genrule", + ":include/fcl/export.h", + ], + copts = ["-fvisibility=hidden"], + defines = [ + "FCL_STATIC_DEFINE", + ], + includes = ["include"], + linkstatic = 1, + deps = [ + "@ccd_internal//:ccd", + "@eigen", + ], +) + +install( + name = "install", + docs = ["LICENSE"], +) diff --git a/tools/workspace/fcl_internal/repository.bzl b/tools/workspace/fcl_internal/repository.bzl new file mode 100644 index 000000000000..642f7de8aeeb --- /dev/null +++ b/tools/workspace/fcl_internal/repository.bzl @@ -0,0 +1,15 @@ +# -*- python -*- + +load("@drake//tools/workspace:github.bzl", "github_archive") + +def fcl_internal_repository( + name, + mirrors = None): + github_archive( + name = name, + repository = "flexible-collision-library/fcl", + commit = "df2702ca5e703dec98ebd725782ce13862e87fc8", + sha256 = "3ebcf2470a3ee372440cdec4cb78d1723411c3cf84f419679c2c85317c4c2dae", # noqa + build_file = ":package.BUILD.bazel", + mirrors = mirrors, + ) diff --git a/tools/workspace/fcl_internal/version-from-xml.sed b/tools/workspace/fcl_internal/version-from-xml.sed new file mode 100644 index 000000000000..7deca92e612a --- /dev/null +++ b/tools/workspace/fcl_internal/version-from-xml.sed @@ -0,0 +1,4 @@ +s|.*\(\([0-9]*\)\.\([0-9]*\)\.\([0-9]*\)\).*|set(FCL_VERSION \1)\ +set(FCL_MAJOR_VERSION \2)\ +set(FCL_MINOR_VERSION \3)\ +set(FCL_PATCH_VERSION \4)|p