Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge 10 -> main #430

Merged
merged 26 commits into from
Mar 14, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
fac43a8
Set GZ_TOOLS_VER to 2 for consistency with rest of Garden and Harmoni…
traversaro Oct 3, 2023
0622409
Fix cross-compilation support for gz-msg10 (#392)
traversaro Oct 11, 2023
edd9632
Miscellaneous housekeeping (#398)
mjcarroll Oct 13, 2023
3d7793f
Enables cmd commands on Windows (#402)
Voldivh Oct 23, 2023
1b0b0f8
Fix compiler warning in `generator.cc` (#403)
arjo129 Oct 28, 2023
8021595
Fix memory leak in generator plugin code (#404)
mjcarroll Oct 30, 2023
25759b6
Miscellaneous cleanups of protobuf generator plugin (#405)
mjcarroll Oct 30, 2023
3d60486
Added missing parts to the `CMakeLists.txt` code. (#400)
jrutgeer Nov 3, 2023
4f32cf4
Ensure that tests pass fine with GZ_RELOCATABLE_INSTALL option enable…
traversaro Nov 7, 2023
29cfe33
Bazel: Fix py_binary location (#406)
mjcarroll Dec 11, 2023
47eed13
Update CI badges in README (#412)
iche033 Dec 21, 2023
ce3ccb9
Add proto message for MaterialColor. (#414)
bperseghetti Jan 15, 2024
35a267f
Update material_color to use Entity. (#415)
bperseghetti Jan 17, 2024
a97d59b
Add EntityMatch Enum to MaterialColor (#416)
bperseghetti Jan 17, 2024
b7b08ab
Prepare for 10.1.0~pre1 (#417)
azeey Jan 17, 2024
6936306
Prepare for 10.1.0-pre1 (increment version) (#418)
azeey Jan 18, 2024
daeb089
Prepare for 10.1.0 (#419)
azeey Jan 22, 2024
2b66954
Remove duplicate find_package(Python3) call (#420)
scpeters Jan 24, 2024
ea68ca0
Merge branch 'gz-msgs9' into 9_to_10
caguero Jan 26, 2024
50f2f00
Merge 9 ➡️ 10 (#421)
mjcarroll Jan 29, 2024
b35b9fd
Conditionally use cmake_path on cmake < 3.20 (#424)
mjcarroll Feb 3, 2024
fd36d69
Allow topic and service to construct messages from description files …
mjcarroll Mar 11, 2024
727ea7b
Merge branch 'gz-msgs9' into gz-msgs10
mjcarroll Mar 11, 2024
1939fb0
Include descriptors target
mjcarroll Mar 11, 2024
f253f69
port: gz-msgs9 to gz-msgs10 (#429)
mjcarroll Mar 11, 2024
3656ce2
merge from gz-msgs10
iche033 Mar 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ test_sources = glob(
"test/desc",
],
defines = [
'GZ_MSGS_TEST_PATH=\\"msgs/test\\"',
'GZ_MSGS_TEST_PATH=\\"msgs/test\\"',
],
deps = [
":msgs",
Expand Down
57 changes: 36 additions & 21 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -25,34 +25,49 @@ gz_configure_project(VERSION_SUFFIX
#============================================================================

# Cross-compilation related options
# In a cross-compilation scenario, it is possible that the gz_msgs_gen
# In a cross-compilation scenario, it is possible that the
# ${PROJECT_NAME}_protoc_plugin
# generator compiled for the target machine cannot be used to generate
# the C++ code corresponding to the .proto definition. For this scenario,
# the following two options can be used as follows.
# the C++ code corresponding to the .proto definition.
# Similarly, it is possible that Python3::Interpreter and protobuf::protoc
# found via find_package are not executable that can be run during the build.
# To avoid, that the following options can be used as follows.
# First of all, gz-msgs is compiled targeting the host machine, and in the
# build targeting the host, the INSTALL_GZ_MSGS_GEN_EXECUTABLE option is
# enabled:
# > cmake -DINSTALL_GZ_MSGS_GEN_EXECUTABLE:BOOL=ON ..
# ensuring that the gz_msgs_gen is installed in
# <host_install_prefix>/bin/gz_msgs_gen . Then, the same version of gz-msgs
# build targeting the host, ensuring that the ${PROJECT_NAME}_protoc_plugin
# is installed in <host_install_prefix>/bin/${PROJECT_NAME}_protoc_plugin .
# Then, the same version of gz-msgs
# can be cross-compiled, and in the cross-compilation build the location of the
# host gz_msgs_gen is specified via the GZ_MSGS_GEN_EXECUTABLE
# CMake cache variable:
# > cmake -GZ_MSGS_GEN_EXECUTABLE=<host_install_prefix>/bin/gz_msgs_gen ..
# host gz_msgs_gen is specified via the GZ_MSGS_GEN_EXECUTABLE CMake option.
# Similarly to gz-msgs, also a copy of protoc and of the Python interpreter need
# to be installed in the host at <host_install_prefix>/bin, and they can be passed
# to the build appropriate CMake options:
# > cmake -Dgz-msgs<MajVer>_PROTO_GENERATOR_PLUGIN=gz-msgs<MajVer>_protoc_plugin
# > -Dgz-msgs<MajVer>_PROTOC_EXECUTABLE=<host_install_prefix>/bin/protoc
# > -Dgz-msgs<MajVer>_PYTHON_INTERPRETER=<host_install_prefix>/bin/python
# > ..
# In case the gz-msgs CMake functions are used also in downstream projects,
# the same variables can be passed when configuring the downsream projects.

option(
INSTALL_GZ_MSGS_GEN_EXECUTABLE
"Install the gz_msgs_gen executable."
OFF)
set(
${PROJECT_NAME}_PROTO_GENERATOR_PLUGIN
"${PROJECT_NAME}_protoc_plugin"
CACHE STRING
"gz_msgs_gen executable used in the gz-msgs CMake functions.")
mark_as_advanced(${PROJECT_NAME}_PROTO_GENERATOR_PLUGIN)

mark_as_advanced(INSTALL_GZ_MSGS_GEN_EXECUTABLE)
set(
${PROJECT_NAME}_PROTOC_EXECUTABLE
protobuf::protoc
CACHE STRING
"protoc target or executable used in the gz-msgs CMake functions.")
mark_as_advanced(${PROJECT_NAME}_PROTOC_EXECUTABLE)

set(
GZ_MSGS_GEN_EXECUTABLE
"$<TARGET_FILE:gz_msgs_gen>"
${PROJECT_NAME}_PYTHON_INTERPRETER
Python3::Interpreter
CACHE STRING
"gz_msgs_gen executable used in the gz_msgs_protoc CMake function.")
mark_as_advanced(GZ_MSGS_GEN_EXECUTABLE)
"python target or executable used in the gz-msgs CMake functions.")
mark_as_advanced(${PROJECT_NAME}_PYTHON_INTERPRETER)

# Python interfaces vars
option(USE_SYSTEM_PATHS_FOR_PYTHON_INSTALLATION
Expand Down Expand Up @@ -92,7 +107,7 @@ find_package(Python3 REQUIRED COMPONENTS Interpreter)
# Note that CLI files are installed regardless of whether the dependency is
# available during build time
find_program(HAVE_GZ_TOOLS gz)
set(GZ_TOOLS_VER 1)
set(GZ_TOOLS_VER 2)

#--------------------------------------
# Find Tinyxml2
Expand Down
34 changes: 34 additions & 0 deletions Changelog.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,40 @@

## Gazebo Msgs 10.x

### Gazebo Msgs 10.1.0 (2024-01-22)

1. Add proto message for MaterialColor.
* [Pull request #414](https://github.com/gazebosim/gz-msgs/pull/414)
* [Pull request #415](https://github.com/gazebosim/gz-msgs/pull/415)
* [Pull request #416](https://github.com/gazebosim/gz-msgs/pull/416)

1. Update CI badges in README
* [Pull request #412](https://github.com/gazebosim/gz-msgs/pull/412)

1. Ensure that tests pass fine with GZ_RELOCATABLE_INSTALL option enabled
* [Pull request #394](https://github.com/gazebosim/gz-msgs/pull/394)

1. Added missing parts to the `CMakeLists.txt` code.
* [Pull request #400](https://github.com/gazebosim/gz-msgs/pull/400)

1. Miscellaneous cleanups of protobuf generator plugin
* [Pull request #405](https://github.com/gazebosim/gz-msgs/pull/405)

1. Fix memory leak in generator plugin code
* [Pull request #404](https://github.com/gazebosim/gz-msgs/pull/404)

1. Enables cmd commands on Windows
* [Pull request #402](https://github.com/gazebosim/gz-msgs/pull/402)

1. Miscellaneous housekeeping
* [Pull request #398](https://github.com/gazebosim/gz-msgs/pull/398)

1. Fix cross-compilation support for gz-msg10
* [Pull request #392](https://github.com/gazebosim/gz-msgs/pull/392)

1. Do not redefine GZ_PYTHON_INSTALL_PATH if it is already defined
* [Pull request #393](https://github.com/gazebosim/gz-msgs/pull/393)

### Gazebo Msgs 10.0.0 (2023-09-29)

1. Add missing `<functional>` header
Expand Down
8 changes: 4 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@

Build | Status
-- | --
Test coverage | [![codecov](https://codecov.io/gh/gazebosim/gz-msgs/branch/main/graph/badge.svg)](https://codecov.io/gh/gazebosim/gz-msgs)
Ubuntu Focal | [![Build Status](https://build.osrfoundation.org/buildStatus/icon?job=ignition_msgs-ci-main-focal-amd64)](https://build.osrfoundation.org/job/ignition_msgs-ci-main-focal-amd64)
Homebrew | [![Build Status](https://build.osrfoundation.org/buildStatus/icon?job=ignition_msgs-ci-main-homebrew-amd64)](https://build.osrfoundation.org/job/ignition_msgs-ci-main-homebrew-amd64)
Windows | [![Build Status](https://build.osrfoundation.org/buildStatus/icon?job=ign_msgs-ci-win)](https://build.osrfoundation.org/job/ign_msgs-ci-win)
Test coverage | [![codecov](https://codecov.io/gh/gazebosim/gz-msgs/tree/main/graph/badge.svg)](https://codecov.io/gh/gazebosim/gz-msgs/tree/main)
Ubuntu Jammy | [![Build Status](https://build.osrfoundation.org/buildStatus/icon?job=gz_msgs-ci-main-jammy-amd64)](https://build.osrfoundation.org/job/gz_msgs-ci-main-jammy-amd64)
Homebrew | [![Build Status](https://build.osrfoundation.org/buildStatus/icon?job=gz_msgs-ci-main-homebrew-amd64)](https://build.osrfoundation.org/job/gz_msgs-ci-main-homebrew-amd64)
Windows | [![Build Status](https://build.osrfoundation.org/buildStatus/icon?job=gz_msgs-main-win)](https://build.osrfoundation.org/job/gz_msgs-main-win)

Gazebo Messages is a component in the [Gazebo](http://gazebosim.org)
framework, a set of libraries designed to rapidly develop robot applications.
Expand Down
10 changes: 8 additions & 2 deletions cmake/gz_msgs_factory.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
# One value arguments:
# FACTORY_GEN_SCRIPT - Location of the factory generator script
# PROTO_PACKAGE - Protobuf package the file belongs to (e.g. "gz.msgs")
# PROTOC_EXEC - Path to protoc
# PYTHON_INTERPRETER - Target or path to the Python interpreter to use to execute the generator script
# OUTPUT_CPP_DIR - Path where C++ files are saved
# OUTPUT_CPP_HH_VAR - A CMake variable name containing a list that the C++ headers should be appended to
# OUTPUT_CPP_CC_VAR - A Cmake variable name containing a list that the C++ sources should be appended to
Expand All @@ -18,13 +18,19 @@ function(gz_msgs_factory)
set(oneValueArgs
FACTORY_GEN_SCRIPT
PROTO_PACKAGE
PYTHON_INTERPRETER
OUTPUT_CPP_DIR
OUTPUT_CPP_HH_VAR
OUTPUT_CPP_CC_VAR)
set(multiValueArgs INPUT_PROTOS PROTO_PATH)

cmake_parse_arguments(gz_msgs_factory "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})

# Default values for optional parameters
if (NOT DEFINED gz_msgs_factory_PYTHON_INTERPRETER)
set(gz_msgs_factory_PYTHON_INTERPRETER Python3::Interpreter)
endif()

_gz_msgs_proto_pkg_to_path(${gz_msgs_factory_PROTO_PACKAGE} proto_package_dir)

set(output_header "${gz_msgs_factory_OUTPUT_CPP_DIR}/${proto_package_dir}/MessageTypes.hh")
Expand Down Expand Up @@ -57,7 +63,7 @@ function(gz_msgs_factory)

add_custom_command(
OUTPUT ${output_files}
COMMAND Python3::Interpreter
COMMAND ${gz_msgs_factory_PYTHON_INTERPRETER}
ARGS ${gz_msgs_factory_FACTORY_GEN_SCRIPT} ${GENERATE_ARGS}
DEPENDS
${depends_index}
Expand Down
41 changes: 38 additions & 3 deletions cmake/gz_msgs_generate.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
# The implementation of gz_msgs_generate_messages
# Options:
# One value arguments:
# PYTHON_INTERPRETER - Target or path to the python interpreter used
# PROTO_PACKAGE - Protobuf package the file belongs to (e.g. "gz.msgs")
# MSGS_GEN_SCRIPT - Location of the messge generator script
# GZ_PROTOC_PLUGIN - Location of the gazebo generator plugin
Expand All @@ -20,6 +21,8 @@ function(gz_msgs_generate_messages_impl)
set(options "")
set(oneValueArgs
# Inputs
PYTHON_INTERPRETER
PROTOC_EXEC
PROTO_PACKAGE MSGS_GEN_SCRIPT GZ_PROTOC_PLUGIN FACTORY_GEN_SCRIPT PROTO_PATH
DEPENDENCY_DESCRIPTIONS
DLLEXPORT_DECL
Expand All @@ -33,6 +36,15 @@ function(gz_msgs_generate_messages_impl)
set(multiValueArgs INPUT_PROTOS)

cmake_parse_arguments(generate_messages "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})

# Default values for optional parameters
if (NOT DEFINED generate_messages_PYTHON_INTERPRETER)
set(generate_messages_PYTHON_INTERPRETER Python3::Interpreter)
endif()
if (NOT DEFINED generate_messages_PROTOC_EXEC)
set(generate_messages_PROTOC_EXEC protobuf::protoc)
endif()

_gz_msgs_proto_pkg_to_string(${generate_messages_PROTO_PACKAGE} gen_dir)
_gz_msgs_proto_pkg_to_path(${generate_messages_PROTO_PACKAGE} proto_package_dir)
set(output_directory ${generate_messages_OUTPUT_DIRECTORY})
Expand All @@ -42,14 +54,16 @@ function(gz_msgs_generate_messages_impl)

foreach(proto_file ${generate_messages_INPUT_PROTOS})
gz_msgs_protoc(
PYTHON_INTERPRETER
${generate_messages_PYTHON_INTERPRETER}
MSGS_GEN_SCRIPT
${generate_messages_MSGS_GEN_SCRIPT}
PROTO_PACKAGE
${generate_messages_PROTO_PACKAGE}
INPUT_PROTO
${proto_file}
PROTOC_EXEC
protobuf::protoc
${generate_messages_PROTOC_EXEC}
GZ_PROTOC_PLUGIN
${generate_messages_GZ_PROTOC_PLUGIN}
PROTO_PATH
Expand Down Expand Up @@ -81,6 +95,8 @@ function(gz_msgs_generate_messages_impl)
endforeach()

gz_msgs_factory(
PYTHON_INTERPRETER
${generate_messages_PYTHON_INTERPRETER}
FACTORY_GEN_SCRIPT
${generate_messages_FACTORY_GEN_SCRIPT}
PROTO_PACKAGE
Expand Down Expand Up @@ -130,6 +146,7 @@ endfunction()
##################################################
# Options:
# One value arguments:
# PROTOC_EXEC - protoc target or executable to use
# PROTO_PATH - Base directory of the proto files
# DEPENDENCY_DESCRIPTIONS - Variable containing all depedency description files
# OUTPUT_DIRECTORY - Directory of output gz_desc file
Expand All @@ -140,6 +157,7 @@ function(gz_msgs_generate_desc_impl)
set(options "")
set(oneValueArgs
# Inputs
PROTOC_EXEC
PROTO_PATH
DEPENDENCY_DESCRIPTIONS
OUTPUT_DIRECTORY
Expand All @@ -148,6 +166,10 @@ function(gz_msgs_generate_desc_impl)

cmake_parse_arguments(generate_messages "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})

if (NOT DEFINED generate_messages_PROTOC_EXEC)
set(generate_messages_PROTOC_EXEC protobuf::protoc)
endif()

set(ARGS)
list(APPEND ARGS -I${generate_messages_PROTO_PATH})
list(APPEND ARGS --descriptor_set_out=${generate_messages_OUTPUT_FILENAME})
Expand All @@ -161,7 +183,7 @@ function(gz_msgs_generate_desc_impl)

add_custom_command(
OUTPUT ${generate_messages_OUTPUT_FILENAME}
COMMAND protobuf::protoc
COMMAND ${generate_messages_PROTOC_EXEC}
ARGS ${ARGS}
DEPENDS ${generate_messages_INPUT_PROTOS}
COMMENT "Generating descriptor set"
Expand All @@ -175,6 +197,8 @@ endfunction()
# TARGET - Target (static library) to create
# PROTO_PACKAGE - Protobuf package the file belongs to (e.g. "gz.msgs")
# MSGS_GEN_SCRIPT - Location of the messge generator script
# PYTHON_INTERPRETER - Target or path to the python interpreter used
# PROTOC_EXEC - Protoc target or executable to use
# GZ_PROTOC_PLUGIN - Location of the gazebo generator plugin
# FACTORY_GEN_SCRIPT - Location of the factory generator script
# MSGS_LIB - gz-msgs library to link to
Expand All @@ -186,7 +210,7 @@ endfunction()
# that depend on gz-msgs
function(gz_msgs_generate_messages_lib)
set(options "")
set(oneValueArgs TARGET PROTO_PACKAGE MSGS_GEN_SCRIPT GZ_PROTOC_PLUGIN FACTORY_GEN_SCRIPT MSGS_LIB PROTO_PATH)
set(oneValueArgs TARGET PROTO_PACKAGE MSGS_GEN_SCRIPT PYTHON_INTERPRETER PROTOC_EXEC GZ_PROTOC_PLUGIN FACTORY_GEN_SCRIPT MSGS_LIB PROTO_PATH)
set(multiValueArgs INPUT_PROTOS DEPENDENCIES)

cmake_parse_arguments(generate_messages "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
Expand All @@ -205,9 +229,19 @@ function(gz_msgs_generate_messages_lib)
list(APPEND depends_msgs_desc ${msgs_desc_file})
endforeach()

# Default values for optional parameters
if (NOT DEFINED generate_messages_PYTHON_INTERPRETER)
set(generate_messages_PYTHON_INTERPRETER Python3::Interpreter)
endif()
if (NOT DEFINED generate_messages_PROTOC_EXEC)
set(generate_messages_PROTOC_EXEC protobuf::protoc)
endif()

gz_msgs_generate_messages_impl(
PROTO_PACKAGE ${generate_messages_PROTO_PACKAGE}
MSGS_GEN_SCRIPT ${generate_messages_MSGS_GEN_SCRIPT}
PYTHON_INTERPRETER ${generate_messages_PYTHON_INTERPRETER}
PROTOC_EXEC ${generate_messages_PROTOC_EXEC}
GZ_PROTOC_PLUGIN ${generate_messages_GZ_PROTOC_PLUGIN}
FACTORY_GEN_SCRIPT ${generate_messages_FACTORY_GEN_SCRIPT}
PROTO_PATH ${generate_messages_PROTO_PATH}
Expand All @@ -221,6 +255,7 @@ function(gz_msgs_generate_messages_lib)
)

gz_msgs_generate_desc_impl(
PROTOC_EXEC ${generate_messages_PROTOC_EXEC}
INPUT_PROTOS ${generate_messages_INPUT_PROTOS}
PROTO_PATH ${generate_messages_PROTO_PATH}
DEPENDENCY_DESCRIPTIONS ${depends_msgs_desc}
Expand Down
19 changes: 17 additions & 2 deletions cmake/gz_msgs_protoc.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
# GENERATE_CPP - generates c++ code for the message if specified
# GENERATE_PYTHON - generates python code for the message if specified
# One value arguments:
# PYTHON_INTERPRETER - Target or path to the Python interpreter to use to run generation scripts
# MSGS_GEN_SCRIPT - Path to the message generation python script
# PROTO_PACKAGE - Protobuf package the file belongs to (e.g. "gz.msgs")
# PROTOC_EXEC - Path to protoc
Expand All @@ -22,6 +23,7 @@
function(gz_msgs_protoc)
set(options GENERATE_CPP GENERATE_PYTHON)
set(oneValueArgs
PYTHON_INTERPRETER
MSGS_GEN_SCRIPT
PROTO_PACKAGE
PROTOC_EXEC
Expand All @@ -38,6 +40,13 @@ function(gz_msgs_protoc)

cmake_parse_arguments(gz_msgs_protoc "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})

if (NOT DEFINED gz_msgs_protoc_PYTHON_INTERPRETER)
set(gz_msgs_protoc_PYTHON_INTERPRETER Python3::Interpreter)
endif()
if (NOT DEFINED gz_msgs_protoc_PROTOC_EXEC)
set(gz_msgs_protoc_PROTOC_EXEC protobuf::protoc)
endif()

get_filename_component(ABS_FIL ${gz_msgs_protoc_INPUT_PROTO} ABSOLUTE)
get_filename_component(FIL_WE ${gz_msgs_protoc_INPUT_PROTO} NAME_WE)

Expand Down Expand Up @@ -85,8 +94,14 @@ function(gz_msgs_protoc)
set(${gz_msgs_protoc_OUTPUT_PYTHON_VAR} ${${gz_msgs_protoc_OUTPUT_PYTHON_VAR}} PARENT_SCOPE)
endif()

if(TARGET ${gz_msgs_protoc_PROTOC_EXEC})
set(gz_msgs_protoc_PROTOC_EXEC_FILE_ABS_PATH "$<TARGET_FILE:${gz_msgs_protoc_PROTOC_EXEC}>")
else()
set(gz_msgs_protoc_PROTOC_EXEC_FILE_ABS_PATH ${gz_msgs_protoc_PROTOC_EXEC})
endif()

set(GENERATE_ARGS
--protoc-exec "$<TARGET_FILE:${gz_msgs_protoc_PROTOC_EXEC}>"
--protoc-exec "${gz_msgs_protoc_PROTOC_EXEC_FILE_ABS_PATH}"
--gz-generator-bin "${gz_msgs_protoc_GZ_PROTOC_PLUGIN}"
--proto-path "${gz_msgs_protoc_PROTO_PATH}"
--input-path "${ABS_FIL}"
Expand Down Expand Up @@ -118,7 +133,7 @@ function(gz_msgs_protoc)

add_custom_command(
OUTPUT ${output_files}
COMMAND Python3::Interpreter
COMMAND ${gz_msgs_protoc_PYTHON_INTERPRETER}
ARGS ${gz_msgs_protoc_MSGS_GEN_SCRIPT} ${GENERATE_ARGS}
DEPENDS
${ABS_FIL}
Expand Down
8 changes: 6 additions & 2 deletions conf/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
# Used only for internal testing.
set(gz_library_path "${CMAKE_BINARY_DIR}/test/lib/ruby/gz/cmd${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}")
set(gz_library_path "${CMAKE_BINARY_DIR}/test/lib/$<CONFIG>/ruby/gz/cmd${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}")

# Generate a configuration file for internal testing.
# Note that the major version of the library is included in the name.
# Ex: transport0.yaml
configure_file(
"${GZ_DESIGNATION}.yaml.in"
"${CMAKE_BINARY_DIR}/test/conf/${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}.yaml" @ONLY)
"${CMAKE_CURRENT_BINARY_DIR}/${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}.yaml.configured" @ONLY)

file(GENERATE
OUTPUT "${CMAKE_BINARY_DIR}/test/conf/$<CONFIG>/${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}.yaml"
INPUT "${CMAKE_CURRENT_BINARY_DIR}/${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}.yaml.configured")

# Used for the installed version.
set(gz_library_path "${CMAKE_INSTALL_PREFIX}/lib/ruby/gz/cmd${GZ_DESIGNATION}${PROJECT_VERSION_MAJOR}")
Expand Down
Loading
Loading