From b1fdb18f1e1fc11f9993b9a1172b819266889166 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alejandro=20Hern=C3=A1ndez=20Cordero?= Date: Wed, 24 Jul 2024 10:14:45 +0200 Subject: [PATCH] Updated rcpputils path API (#2579) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Alejandro Hernández Cordero --- rclcpp/include/rclcpp/logger.hpp | 29 +++++++++++++++++++ rclcpp/src/rclcpp/logger.cpp | 29 +++++++++++++++++++ .../node_interfaces/test_node_parameters.cpp | 3 +- rclcpp/test/rclcpp/test_logger.cpp | 15 +++------- rclcpp/test/rclcpp/test_node.cpp | 3 +- rclcpp/test/rclcpp/test_parameter_client.cpp | 9 +++--- rclcpp_components/src/component_manager.cpp | 9 +++--- .../test/test_component_manager.cpp | 3 +- 8 files changed, 78 insertions(+), 22 deletions(-) diff --git a/rclcpp/include/rclcpp/logger.hpp b/rclcpp/include/rclcpp/logger.hpp index 3b8e8a1625..ee244fd988 100644 --- a/rclcpp/include/rclcpp/logger.hpp +++ b/rclcpp/include/rclcpp/logger.hpp @@ -15,6 +15,7 @@ #ifndef RCLCPP__LOGGER_HPP_ #define RCLCPP__LOGGER_HPP_ +#include #include #include #include @@ -77,6 +78,14 @@ RCLCPP_PUBLIC Logger get_node_logger(const rcl_node_t * node); +// TODO(ahcorde): Remove deprecated class on the next release (in Rolling after Kilted). +#if !defined(_WIN32) +# pragma GCC diagnostic push +# pragma GCC diagnostic ignored "-Wdeprecated-declarations" +#else // !defined(_WIN32) +# pragma warning(push) +# pragma warning(disable: 4996) +#endif /// Get the current logging directory. /** * For more details of how the logging directory is determined, @@ -85,10 +94,30 @@ get_node_logger(const rcl_node_t * node); * \returns the logging directory being used. * \throws rclcpp::exceptions::RCLError if an unexpected error occurs. */ +[[deprecated("use rclcpp::get_log_directory instead of rclcpp::get_logging_directory")]] RCLCPP_PUBLIC rcpputils::fs::path get_logging_directory(); +// remove warning suppression +#if !defined(_WIN32) +# pragma GCC diagnostic pop +#else // !defined(_WIN32) +# pragma warning(pop) +#endif + +/// Get the current logging directory. +/** + * For more details of how the logging directory is determined, + * see rcl_logging_get_logging_directory(). + * + * \returns the logging directory being used. + * \throws rclcpp::exceptions::RCLError if an unexpected error occurs. + */ +RCLCPP_PUBLIC +std::filesystem::path +get_log_directory(); + class Logger { public: diff --git a/rclcpp/src/rclcpp/logger.cpp b/rclcpp/src/rclcpp/logger.cpp index 2e83c07013..788ae31d31 100644 --- a/rclcpp/src/rclcpp/logger.cpp +++ b/rclcpp/src/rclcpp/logger.cpp @@ -12,6 +12,7 @@ // See the License for the specific language governing permissions and // limitations under the License. +#include #include #include #include @@ -54,6 +55,14 @@ get_node_logger(const rcl_node_t * node) return rclcpp::get_logger(logger_name); } +// TODO(ahcorde): Remove deprecated class on the next release (in Rolling after Kilted). +#if !defined(_WIN32) +# pragma GCC diagnostic push +# pragma GCC diagnostic ignored "-Wdeprecated-declarations" +#else // !defined(_WIN32) +# pragma warning(push) +# pragma warning(disable: 4996) +#endif rcpputils::fs::path get_logging_directory() { @@ -67,6 +76,26 @@ get_logging_directory() allocator.deallocate(log_dir, allocator.state); return path; } +// remove warning suppression +#if !defined(_WIN32) +# pragma GCC diagnostic pop +#else // !defined(_WIN32) +# pragma warning(pop) +#endif + +std::filesystem::path +get_log_directory() +{ + char * log_dir = NULL; + auto allocator = rcutils_get_default_allocator(); + rcl_logging_ret_t ret = rcl_logging_get_logging_directory(allocator, &log_dir); + if (RCL_LOGGING_RET_OK != ret) { + rclcpp::exceptions::throw_from_rcl_error(ret); + } + std::string path{log_dir}; + allocator.deallocate(log_dir, allocator.state); + return path; +} Logger Logger::get_child(const std::string & suffix) diff --git a/rclcpp/test/rclcpp/node_interfaces/test_node_parameters.cpp b/rclcpp/test/rclcpp/node_interfaces/test_node_parameters.cpp index d262c67a9a..0cc06792a8 100644 --- a/rclcpp/test/rclcpp/node_interfaces/test_node_parameters.cpp +++ b/rclcpp/test/rclcpp/node_interfaces/test_node_parameters.cpp @@ -21,6 +21,7 @@ #include #include +#include #include #include #include @@ -61,7 +62,7 @@ class TestNodeParameters : public ::testing::Test std::shared_ptr node; rclcpp::node_interfaces::NodeParameters * node_parameters; - rcpputils::fs::path test_resources_path{TEST_RESOURCES_DIRECTORY}; + std::filesystem::path test_resources_path{TEST_RESOURCES_DIRECTORY}; }; TEST_F(TestNodeParameters, construct_destruct_rcl_errors) { diff --git a/rclcpp/test/rclcpp/test_logger.cpp b/rclcpp/test/rclcpp/test_logger.cpp index 83d42f0ce8..35118cf2df 100644 --- a/rclcpp/test/rclcpp/test_logger.cpp +++ b/rclcpp/test/rclcpp/test_logger.cpp @@ -14,6 +14,7 @@ #include +#include #include #include @@ -210,15 +211,7 @@ TEST(TestLogger, get_logging_directory) { ASSERT_EQ(true, rcutils_set_env("ROS_LOG_DIR", nullptr)); ASSERT_EQ(true, rcutils_set_env("ROS_HOME", nullptr)); - auto path = rclcpp::get_logging_directory(); - auto expected_path = rcpputils::fs::path{"/fake_home_dir"} / ".ros" / "log"; - - // TODO(ivanpauno): Add operator== to rcpputils::fs::path - auto it = path.cbegin(); - auto eit = expected_path.cbegin(); - for (; it != path.cend() && eit != expected_path.cend(); ++it, ++eit) { - EXPECT_EQ(*eit, *it); - } - EXPECT_EQ(it, path.cend()); - EXPECT_EQ(eit, expected_path.cend()); + auto path = rclcpp::get_log_directory(); + auto expected_path = std::filesystem::path{"/fake_home_dir"} / ".ros" / "log"; + EXPECT_EQ(path, expected_path); } diff --git a/rclcpp/test/rclcpp/test_node.cpp b/rclcpp/test/rclcpp/test_node.cpp index ad73aadc2a..c956b273be 100644 --- a/rclcpp/test/rclcpp/test_node.cpp +++ b/rclcpp/test/rclcpp/test_node.cpp @@ -15,6 +15,7 @@ #include #include +#include #include #include #include @@ -56,7 +57,7 @@ class TestNode : public ::testing::Test test_resources_path /= "test_node"; } - rcpputils::fs::path test_resources_path{TEST_RESOURCES_DIRECTORY}; + std::filesystem::path test_resources_path{TEST_RESOURCES_DIRECTORY}; }; /* diff --git a/rclcpp/test/rclcpp/test_parameter_client.cpp b/rclcpp/test/rclcpp/test_parameter_client.cpp index afc48a652b..caefa0d6c8 100644 --- a/rclcpp/test/rclcpp/test_parameter_client.cpp +++ b/rclcpp/test/rclcpp/test_parameter_client.cpp @@ -15,6 +15,7 @@ #include #include +#include #include #include #include @@ -935,7 +936,7 @@ TEST_F(TestParameterClient, async_parameter_load_parameters) { auto asynchronous_client = std::make_shared(load_node, "/namespace/load_node"); // load parameters - rcpputils::fs::path test_resources_path{TEST_RESOURCES_DIRECTORY}; + std::filesystem::path test_resources_path{TEST_RESOURCES_DIRECTORY}; const std::string parameters_filepath = ( test_resources_path / "test_node" / "load_parameters.yaml").string(); auto load_future = asynchronous_client->load_parameters(parameters_filepath); @@ -961,7 +962,7 @@ TEST_F(TestParameterClient, sync_parameter_load_parameters) { auto synchronous_client = std::make_shared(load_node); // load parameters - rcpputils::fs::path test_resources_path{TEST_RESOURCES_DIRECTORY}; + std::filesystem::path test_resources_path{TEST_RESOURCES_DIRECTORY}; const std::string parameters_filepath = ( test_resources_path / "test_node" / "load_parameters.yaml").string(); auto load_future = synchronous_client->load_parameters(parameters_filepath); @@ -983,7 +984,7 @@ TEST_F(TestParameterClient, async_parameter_load_parameters_complicated_regex) { auto asynchronous_client = std::make_shared(load_node, "/namespace/load_node"); // load parameters - rcpputils::fs::path test_resources_path{TEST_RESOURCES_DIRECTORY}; + std::filesystem::path test_resources_path{TEST_RESOURCES_DIRECTORY}; const std::string parameters_filepath = ( test_resources_path / "test_node" / "load_complicated_parameters.yaml").string(); auto load_future = asynchronous_client->load_parameters(parameters_filepath); @@ -1013,7 +1014,7 @@ TEST_F(TestParameterClient, async_parameter_load_no_valid_parameter) { auto asynchronous_client = std::make_shared(load_node, "/namespace/load_node"); // load parameters - rcpputils::fs::path test_resources_path{TEST_RESOURCES_DIRECTORY}; + std::filesystem::path test_resources_path{TEST_RESOURCES_DIRECTORY}; const std::string parameters_filepath = ( test_resources_path / "test_node" / "no_valid_parameters.yaml").string(); EXPECT_THROW( diff --git a/rclcpp_components/src/component_manager.cpp b/rclcpp_components/src/component_manager.cpp index 7b77af9c92..f73cd8954a 100644 --- a/rclcpp_components/src/component_manager.cpp +++ b/rclcpp_components/src/component_manager.cpp @@ -14,6 +14,7 @@ #include "rclcpp_components/component_manager.hpp" +#include #include #include #include @@ -95,11 +96,11 @@ ComponentManager::get_component_resources( throw ComponentManagerException("Invalid resource entry"); } - std::string library_path = parts[1]; - if (!rcpputils::fs::path(library_path).is_absolute()) { - library_path = base_path + "/" + library_path; + std::filesystem::path library_path = parts[1]; + if (!library_path.is_absolute()) { + library_path = (base_path / library_path); } - resources.push_back({parts[0], library_path}); + resources.push_back({parts[0], library_path.string()}); } return resources; } diff --git a/rclcpp_components/test/test_component_manager.cpp b/rclcpp_components/test/test_component_manager.cpp index ebc86ff6f0..d4df8e7d08 100644 --- a/rclcpp_components/test/test_component_manager.cpp +++ b/rclcpp_components/test/test_component_manager.cpp @@ -14,6 +14,7 @@ #include +#include #include #include "rclcpp_components/component_manager.hpp" @@ -51,7 +52,7 @@ TEST_F(TestComponentManager, get_component_resources_valid) EXPECT_EQ("test_rclcpp_components::TestComponentBar", resources[1].first); EXPECT_EQ("test_rclcpp_components::TestComponentNoNode", resources[2].first); - namespace fs = rcpputils::fs; + namespace fs = std::filesystem; EXPECT_TRUE(fs::exists(fs::path(resources[0].second))); EXPECT_TRUE(fs::exists(fs::path(resources[1].second))); EXPECT_TRUE(fs::exists(fs::path(resources[2].second)));