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

Add line break after first open paren in multiline function call #148

Closed
wants to merge 1 commit into from

Conversation

rotu
Copy link
Contributor

@rotu rotu commented Jul 3, 2019

Update line break behavior to match the developer guide:

https://index.ros.org/doc/ros2/Contributing/Developer-Guide/

When a function call cannot fit on one line, wrap at the open parenthesis (not in between arguments) and start them on the next line with a 2-space indent. Continue with the 2-space indent on subsequent lines for more arguments. (Note that the Google style guide is internally contradictory on this point.)

@dirk-thomas
Copy link
Contributor

The change itself looks good. But testing the existing code base with this shows numerous places where we don't adhere to the rule: https://ci.ros2.org/job/ci_linux/7579/testReport/

Before this can be merged those would need to be addressed so that the tests pass cleanly.

@rotu
Copy link
Contributor Author

rotu commented Jul 16, 2019

Ouch! So I guess the questions to ask:

  1. Are there any other changes to the ament_uncrustify rules that should take place at this time so we only need to do this once?
  2. Are there any shortcuts, or do I have to just open a bajillion PRs?

@dirk-thomas
Copy link
Contributor

Are there any other changes to the ament_uncrustify rules that should take place at this time so we only need to do this once?

I don't know for sure - I haven't checked. Feel free to either look into that or just land these changes for now (I would think if there are others they shouldn't be as invasive).

Are there any shortcuts, or do I have to just open a bajillion PRs?

The number of PRs should not exceed the number of repos - but that number will likely be double digit 😒 I don't think there is a way to reduce that.

@rotu rotu force-pushed the uncrustify-dev-guide branch from 5b170c8 to 49595c2 Compare July 17, 2019 19:05
@rotu rotu force-pushed the uncrustify-dev-guide branch 2 times, most recently from 6e96947 to d513211 Compare August 6, 2019 01:15
@rotu
Copy link
Contributor Author

rotu commented Aug 6, 2019

Blech. I've really made a mess of this. It looks like we have to keep indent_paren_open_brace false.

dirk-thomas pushed a commit to ros2/rclcpp that referenced this pull request Aug 7, 2019
* Add line break after first open paren in multiline function call

as per developer guide:
https://index.ros.org/doc/ros2/Contributing/Developer-Guide/#open-versus-cuddled-braces
see ament/ament_lint#148

Signed-off-by: Dan Rose <[email protected]>

Fix dedent when first function argument starts with a brace

Signed-off-by: Dan Rose <[email protected]>

Line break with multiline if condition
Remove line breaks where allowed.

Signed-off-by: Dan Rose <[email protected]>

Fixup after rebase

Signed-off-by: Dan Rose <[email protected]>

Fixup again after reverting indent_paren_open_brace

Signed-off-by: Dan Rose <[email protected]>

* Revert comment spacing change, condense some lines

Signed-off-by: Dan Rose <[email protected]>
rotu added a commit to RoverRobotics-forks/demos that referenced this pull request Aug 15, 2019
@hidmic
Copy link
Contributor

hidmic commented Sep 6, 2019

Alright, I gave this a shot. Some conclusions and a request for feedback follow.

Reconciling clang-format with the code style that uncrustify currently enforces throughout our code base has not been possible. It's simply not as flexible and configurable as uncrustify is (e.g. uncrustify allows one to ignore details altogether whereas clang-format usually does not). Thus, it became a matter of getting ament_clang_format's default configuration as close as possible to what we have right now while not violating the GSG nor the ROS2 C++ style guide, and hopefully adapt uncrustify's right after.

I think I've managed to do the former. Here you can find the modified .clang-format configuration file and here is rclcpp re-formatted. I'm still far from a fully compatible uncrustify configuration but it'd be good for someone else to take a rough look at the results before investing more time.

@dirk-thomas
Copy link
Contributor

Here you can find the modified .clang-format configuration file

The diff is unnecessary difficult to read. Before the file only contained the config values which were different from the based-on-style. Your diff re-adds a lot of configuration keys even though they only use the same value as defined in the based-on-style. Please share an actual diff of options which have changed to make it easier to review what options had to be modified. It would also be good to have an example for each changed option where / how it applies to the code base to see why how it affects it (comparing the old and the new format).

@hidmic
Copy link
Contributor

hidmic commented Sep 7, 2019

True, sorry about that. Too many combinations.

I've removed all redundant settings from the .clang-format patch.

Applying the existing .clang-format configuration file yields this diff. Each option has the following effects on said patch:

  • SpaceAfterTemplateKeyword: false (diff)
  • BinPackArguments: false (diff)
  • BinPackParameters: false (diff)
  • BreakBeforeTernaryOperators: false (diff)
  • AllowShortFunctionsOnASingleLine: None (diff)

Given that settings that Keep... do not enforce anything but keep what's already there, these cannot be applied incrementally. Reformatting master yields:

  • KeepEmptyLinesAtTheStartOfBlocks: true + MaxEmptyLinesToKeep: 1 (diff)

@rotu
Copy link
Contributor Author

rotu commented Sep 7, 2019

@hidmic I think maybe this should be moved to its own PR

wjwwood pushed a commit to ros2/rclcpp that referenced this pull request Oct 14, 2019
Signed-off-by: alberto <[email protected]>

better use of node_topic create subscription

Signed-off-by: alberto <[email protected]>

added intra process manager test

Signed-off-by: alberto <[email protected]>

fixed ring buffer and added test

Signed-off-by: alberto <[email protected]>

added intra process buffer test

Signed-off-by: alberto <[email protected]>

added intra process buffer test

Signed-off-by: alberto <[email protected]>

Signed-off-by: alberto <[email protected]>

removed intra-process methods from subscription base

Signed-off-by: alberto <[email protected]>

using lock_guard instead of unique_lock, renamed var without camel case

Signed-off-by: alberto <[email protected]>

using unordered set and references in intra process manager

Signed-off-by: alberto <[email protected]>

subscription intra-process does not depend anymore on subscription, but has a copy of the callback

Signed-off-by: alberto <[email protected]>

changed buffer API to use rvo

Signed-off-by: Alberto <[email protected]>

avoid copying shared_ptr

Signed-off-by: alberto <[email protected]>

revert not needed changes to create_subscription

Signed-off-by: alberto <[email protected]>

updated tests according to new buffer APIs

Signed-off-by: alberto <[email protected]>

updated types in ring buffer implementation avoid using uint32_t

Signed-off-by: alberto <[email protected]>

using unique ptr for buffers in subscription_intra_process

Signed-off-by: alberto <[email protected]>

added missing std::move in subscription_intra_process constructor

Signed-off-by: alberto <[email protected]>

use consisting names for ring_buffer_implementation members

Signed-off-by: alberto <[email protected]>

addressing typos, one-liners and similar from ivanpauno review

Signed-off-by: alberto <[email protected]>

moved subscription_intra_process_base to its own files and moved non templated method from derived class

Signed-off-by: alberto <[email protected]>

removed forward declarations, fixed include subscription_intra_process_base

Signed-off-by: alberto <[email protected]>

removed member variable from do_intra_process_publish signature

Signed-off-by: alberto <[email protected]>

declare public before private in intra_process_manager_impl

Signed-off-by: alberto <[email protected]>

made matches_any_intra_process_publishers const

Signed-off-by: alberto <[email protected]>

using const reference in get_all_matching_publishers

Signed-off-by: alberto <[email protected]>

added deleter and alloc templates in intra_process_buffer

Signed-off-by: alberto <[email protected]>

added RCLCPP_WARN to intra_process_manager_impl

Signed-off-by: alberto <[email protected]>

passing context from node to subscription_intra_process

Signed-off-by: alberto <[email protected]>

using allocators in intra_process_manager

Signed-off-by: alberto <[email protected]>

use size_t instead of int in ring buffer indices

Signed-off-by: alberto <[email protected]>

creating buffer inside subscription_intra_process constructor

Signed-off-by: alberto <[email protected]>

fix lint errors

Signed-off-by: alberto <[email protected]>

throw error if trying to dequeue when buffer empty; remove duplicated methods in intra_process_buffer

Signed-off-by: alberto <[email protected]>

added todo for creating an rmw function for checking qos compatibility

Signed-off-by: alberto <[email protected]>

test fixes

Signed-off-by: alberto <[email protected]>

refactored intra_process_manager, removed ipm impl

Signed-off-by: alberto <[email protected]>

added mutex in intra_process_manager add_* methods

Signed-off-by: Soragna, Alberto <[email protected]>

added allocator to intra_process_buffer

Signed-off-by: Soragna, Alberto <[email protected]>

added invalid intra_process qos test for subscription

Signed-off-by: Soragna, Alberto <[email protected]>

throw error if history size is 0 with keep last and ipc

Signed-off-by: Soragna, Alberto <[email protected]>

using allocator when creating unique_ptr from shared_ptr

Signed-off-by: Soragna, Alberto <[email protected]>

adding deleter template argument to intra_process buffer

Signed-off-by: Soragna, Alberto <[email protected]>

fix linter

Signed-off-by: Soragna, Alberto <[email protected]>

throw error with callbackT different from messageT

Signed-off-by: Soragna, Alberto <[email protected]>

updated deleter template argument in subscription factory

Signed-off-by: Soragna, Alberto <[email protected]>

Fix typo in test fixture tear down method name (#787)

Signed-off-by: Jacob Perron <[email protected]>

Add free function for creating service clients (#788)

Equivalent to the free function for creating a service.
Resolves #768

Signed-off-by: Jacob Perron <[email protected]>

Cmake infrastructure for creating components (#784)

*cmake macro to create components for libraries with multiple nodes

Signed-off-by: Siddharth Kucheria <[email protected]>

Allow registering multiple on_parameters_set_callback (#772)

Signed-off-by: ivanpauno <[email protected]>

fix for multiple nodes not being recognized (#790)

Signed-off-by: Siddharth Kucheria <[email protected]>

Remove non-package from ament_target_dependencies() (#793)

Signed-off-by: Shane Loretz <[email protected]>

fix linter issue (#795)

Signed-off-by: Siddharth Kucheria <[email protected]>

Make TimeSource ignore use_sim_time events coming from other nodes. (#799)

Signed-off-by: Michel Hidalgo <[email protected]>

passing deleter template parameter

Signed-off-by: Soragna, Alberto <[email protected]>

small fixes for failing tests

Signed-off-by: Soragna, Alberto <[email protected]>

fixed imports in test_intra_process_manager

Signed-off-by: Soragna, Alberto <[email protected]>

using RCLCPP_SMART_PTR_ALIASES_ONLY and RCLCPP_PUBLIC macros

Signed-off-by: Soragna, Alberto <[email protected]>

added RCLCPP_PUBLIC macros and virtual destructor to sub intra_process base

Signed-off-by: Soragna, Alberto <[email protected]>

added unique_ptr alias to macros

Signed-off-by: Soragna, Alberto <[email protected]>

updated test_intra_process_manager.cpp

Signed-off-by: Soragna, Alberto <[email protected]>

remove mock msgs from rclcpp (#800)

Signed-off-by: Karsten Knese <[email protected]>

Add line break after first open paren in multiline function call (#785)

* Add line break after first open paren in multiline function call

as per developer guide:
https://index.ros.org/doc/ros2/Contributing/Developer-Guide/#open-versus-cuddled-braces
see ament/ament_lint#148

Signed-off-by: Dan Rose <[email protected]>

Fix dedent when first function argument starts with a brace

Signed-off-by: Dan Rose <[email protected]>

Line break with multiline if condition
Remove line breaks where allowed.

Signed-off-by: Dan Rose <[email protected]>

Fixup after rebase

Signed-off-by: Dan Rose <[email protected]>

Fixup again after reverting indent_paren_open_brace

Signed-off-by: Dan Rose <[email protected]>

* Revert comment spacing change, condense some lines

Signed-off-by: Dan Rose <[email protected]>

Adapt to '--ros-args ... [--]'-based ROS args extraction (#816)

* Use --ros-args to deal with node arguments in rclcpp.

Signed-off-by: Michel Hidalgo <[email protected]>

* Document implicit --ros-args flag in NodeOptions::arguments().

Signed-off-by: Michel Hidalgo <[email protected]>

* Add missing size_t to int cast.

Signed-off-by: Michel Hidalgo <[email protected]>

* Only add implicit --ros-args flag if not present already.

Signed-off-by: Michel Hidalgo <[email protected]>

* Add some rclcpp::NodeOptions test coverage.

Signed-off-by: Michel Hidalgo <[email protected]>

* Address peer review comments.

Signed-off-by: Michel Hidalgo <[email protected]>

* Please cpplint and uncrustify.

Signed-off-by: Michel Hidalgo <[email protected]>

Guard against making multiple result requests for a goal handle (#808)

This fixes a runtime error caused by a race condition when making consecutive requests for the
result.
Specifically, this happens if the user provides a result callback when sending a goal and then
calls async_get_result shortly after.

Resolves #783

Signed-off-by: Jacob Perron <[email protected]>

Explain return value of spin_until_future_complete (#792)

Signed-off-by: Dan Rose <[email protected]>

Allow passing logger by const ref (#820)

Signed-off-by: Karsten Knese <[email protected]>

Delete unnecessary call for get_node_by_group (#823)

Signed-off-by: Tomoya.Fujita <[email protected]>

Fix get_node_interfaces functions taking a pointer (#821)

Signed-off-by: ivanpauno <[email protected]>

add callback group as member variable and constructor arg (#811)

Signed-off-by: bpwilcox <[email protected]>

remove callback group as member variable

Wrap documentation examples in code blocks (#830)

This makes the code examples easier to read in the generated documentation.

Signed-off-by: Jacob Perron <[email protected]>

Crash in callback group pointer vector iterator (#814)

Signed-off-by: Guillaume Autran <[email protected]>

add mutex in add/remove_node and wait_for_work to protect concurrent use/change of memory_strategy_ (#837)

Signed-off-by: Dirk Thomas <[email protected]>

Fix hang with timers in MultiThreadedExecutor (#835) (#836)

Signed-off-by: Todd Malsbary <[email protected]>

Use of -r/--remap flags where appropriate. (#834)

Signed-off-by: Michel Hidalgo <[email protected]>

Force explicit --ros-args in NodeOptions::arguments(). (#845)

Signed-off-by: Michel Hidalgo <[email protected]>

Fail on invalid and unknown ROS specific arguments (#842)

* Fail on invalid and unknown ROS specific arguments.

Signed-off-by: Michel Hidalgo <[email protected]>

* Revert changes to utilities.hpp in rclcpp

Signed-off-by: Michel Hidalgo <[email protected]>

* Fully revert change to utilities.hpp

Signed-off-by: Michel Hidalgo <[email protected]>

Fix typo in deprecated warning. (#848)

"it's" instead of its

Signed-off-by: Luca Della Vedova <[email protected]>

Add throwing parameter name if parameter is not set (#833)

* added throwing parameter name if parameter is not set

Signed-off-by: Alex <[email protected]>
Signed-off-by: ivanpauno <[email protected]>

check valid timer handler 1st to reduce the time window for scan. (#841)

Signed-off-by: Tomoya.Fujita <[email protected]>

remove features and related code which were deprecated in dashing (#852)

Signed-off-by: William Woodall <[email protected]>

reset error message before setting a new one, embed the original one (#854)

Signed-off-by: Dirk Thomas <[email protected]>

restored virtual destructor in publisher_base

Signed-off-by: Soragna, Alberto <[email protected]>
wjwwood pushed a commit to alsora/rclcpp that referenced this pull request Oct 19, 2019
Signed-off-by: alberto <[email protected]>

better use of node_topic create subscription

Signed-off-by: alberto <[email protected]>

added intra process manager test

Signed-off-by: alberto <[email protected]>

fixed ring buffer and added test

Signed-off-by: alberto <[email protected]>

added intra process buffer test

Signed-off-by: alberto <[email protected]>

added intra process buffer test

Signed-off-by: alberto <[email protected]>

Signed-off-by: alberto <[email protected]>

removed intra-process methods from subscription base

Signed-off-by: alberto <[email protected]>

using lock_guard instead of unique_lock, renamed var without camel case

Signed-off-by: alberto <[email protected]>

using unordered set and references in intra process manager

Signed-off-by: alberto <[email protected]>

subscription intra-process does not depend anymore on subscription, but has a copy of the callback

Signed-off-by: alberto <[email protected]>

changed buffer API to use rvo

Signed-off-by: Alberto <[email protected]>

avoid copying shared_ptr

Signed-off-by: alberto <[email protected]>

revert not needed changes to create_subscription

Signed-off-by: alberto <[email protected]>

updated tests according to new buffer APIs

Signed-off-by: alberto <[email protected]>

updated types in ring buffer implementation avoid using uint32_t

Signed-off-by: alberto <[email protected]>

using unique ptr for buffers in subscription_intra_process

Signed-off-by: alberto <[email protected]>

added missing std::move in subscription_intra_process constructor

Signed-off-by: alberto <[email protected]>

use consisting names for ring_buffer_implementation members

Signed-off-by: alberto <[email protected]>

addressing typos, one-liners and similar from ivanpauno review

Signed-off-by: alberto <[email protected]>

moved subscription_intra_process_base to its own files and moved non templated method from derived class

Signed-off-by: alberto <[email protected]>

removed forward declarations, fixed include subscription_intra_process_base

Signed-off-by: alberto <[email protected]>

removed member variable from do_intra_process_publish signature

Signed-off-by: alberto <[email protected]>

declare public before private in intra_process_manager_impl

Signed-off-by: alberto <[email protected]>

made matches_any_intra_process_publishers const

Signed-off-by: alberto <[email protected]>

using const reference in get_all_matching_publishers

Signed-off-by: alberto <[email protected]>

added deleter and alloc templates in intra_process_buffer

Signed-off-by: alberto <[email protected]>

added RCLCPP_WARN to intra_process_manager_impl

Signed-off-by: alberto <[email protected]>

passing context from node to subscription_intra_process

Signed-off-by: alberto <[email protected]>

using allocators in intra_process_manager

Signed-off-by: alberto <[email protected]>

use size_t instead of int in ring buffer indices

Signed-off-by: alberto <[email protected]>

creating buffer inside subscription_intra_process constructor

Signed-off-by: alberto <[email protected]>

fix lint errors

Signed-off-by: alberto <[email protected]>

throw error if trying to dequeue when buffer empty; remove duplicated methods in intra_process_buffer

Signed-off-by: alberto <[email protected]>

added todo for creating an rmw function for checking qos compatibility

Signed-off-by: alberto <[email protected]>

test fixes

Signed-off-by: alberto <[email protected]>

refactored intra_process_manager, removed ipm impl

Signed-off-by: alberto <[email protected]>

added mutex in intra_process_manager add_* methods

Signed-off-by: Soragna, Alberto <[email protected]>

added allocator to intra_process_buffer

Signed-off-by: Soragna, Alberto <[email protected]>

added invalid intra_process qos test for subscription

Signed-off-by: Soragna, Alberto <[email protected]>

throw error if history size is 0 with keep last and ipc

Signed-off-by: Soragna, Alberto <[email protected]>

using allocator when creating unique_ptr from shared_ptr

Signed-off-by: Soragna, Alberto <[email protected]>

adding deleter template argument to intra_process buffer

Signed-off-by: Soragna, Alberto <[email protected]>

fix linter

Signed-off-by: Soragna, Alberto <[email protected]>

throw error with callbackT different from messageT

Signed-off-by: Soragna, Alberto <[email protected]>

updated deleter template argument in subscription factory

Signed-off-by: Soragna, Alberto <[email protected]>

Fix typo in test fixture tear down method name (ros2#787)

Signed-off-by: Jacob Perron <[email protected]>

Add free function for creating service clients (ros2#788)

Equivalent to the free function for creating a service.
Resolves ros2#768

Signed-off-by: Jacob Perron <[email protected]>

Cmake infrastructure for creating components (ros2#784)

*cmake macro to create components for libraries with multiple nodes

Signed-off-by: Siddharth Kucheria <[email protected]>

Allow registering multiple on_parameters_set_callback (ros2#772)

Signed-off-by: ivanpauno <[email protected]>

fix for multiple nodes not being recognized (ros2#790)

Signed-off-by: Siddharth Kucheria <[email protected]>

Remove non-package from ament_target_dependencies() (ros2#793)

Signed-off-by: Shane Loretz <[email protected]>

fix linter issue (ros2#795)

Signed-off-by: Siddharth Kucheria <[email protected]>

Make TimeSource ignore use_sim_time events coming from other nodes. (ros2#799)

Signed-off-by: Michel Hidalgo <[email protected]>

passing deleter template parameter

Signed-off-by: Soragna, Alberto <[email protected]>

small fixes for failing tests

Signed-off-by: Soragna, Alberto <[email protected]>

fixed imports in test_intra_process_manager

Signed-off-by: Soragna, Alberto <[email protected]>

using RCLCPP_SMART_PTR_ALIASES_ONLY and RCLCPP_PUBLIC macros

Signed-off-by: Soragna, Alberto <[email protected]>

added RCLCPP_PUBLIC macros and virtual destructor to sub intra_process base

Signed-off-by: Soragna, Alberto <[email protected]>

added unique_ptr alias to macros

Signed-off-by: Soragna, Alberto <[email protected]>

updated test_intra_process_manager.cpp

Signed-off-by: Soragna, Alberto <[email protected]>

remove mock msgs from rclcpp (ros2#800)

Signed-off-by: Karsten Knese <[email protected]>

Add line break after first open paren in multiline function call (ros2#785)

* Add line break after first open paren in multiline function call

as per developer guide:
https://index.ros.org/doc/ros2/Contributing/Developer-Guide/#open-versus-cuddled-braces
see ament/ament_lint#148

Signed-off-by: Dan Rose <[email protected]>

Fix dedent when first function argument starts with a brace

Signed-off-by: Dan Rose <[email protected]>

Line break with multiline if condition
Remove line breaks where allowed.

Signed-off-by: Dan Rose <[email protected]>

Fixup after rebase

Signed-off-by: Dan Rose <[email protected]>

Fixup again after reverting indent_paren_open_brace

Signed-off-by: Dan Rose <[email protected]>

* Revert comment spacing change, condense some lines

Signed-off-by: Dan Rose <[email protected]>

Adapt to '--ros-args ... [--]'-based ROS args extraction (ros2#816)

* Use --ros-args to deal with node arguments in rclcpp.

Signed-off-by: Michel Hidalgo <[email protected]>

* Document implicit --ros-args flag in NodeOptions::arguments().

Signed-off-by: Michel Hidalgo <[email protected]>

* Add missing size_t to int cast.

Signed-off-by: Michel Hidalgo <[email protected]>

* Only add implicit --ros-args flag if not present already.

Signed-off-by: Michel Hidalgo <[email protected]>

* Add some rclcpp::NodeOptions test coverage.

Signed-off-by: Michel Hidalgo <[email protected]>

* Address peer review comments.

Signed-off-by: Michel Hidalgo <[email protected]>

* Please cpplint and uncrustify.

Signed-off-by: Michel Hidalgo <[email protected]>

Guard against making multiple result requests for a goal handle (ros2#808)

This fixes a runtime error caused by a race condition when making consecutive requests for the
result.
Specifically, this happens if the user provides a result callback when sending a goal and then
calls async_get_result shortly after.

Resolves ros2#783

Signed-off-by: Jacob Perron <[email protected]>

Explain return value of spin_until_future_complete (ros2#792)

Signed-off-by: Dan Rose <[email protected]>

Allow passing logger by const ref (ros2#820)

Signed-off-by: Karsten Knese <[email protected]>

Delete unnecessary call for get_node_by_group (ros2#823)

Signed-off-by: Tomoya.Fujita <[email protected]>

Fix get_node_interfaces functions taking a pointer (ros2#821)

Signed-off-by: ivanpauno <[email protected]>

add callback group as member variable and constructor arg (ros2#811)

Signed-off-by: bpwilcox <[email protected]>

remove callback group as member variable

Wrap documentation examples in code blocks (ros2#830)

This makes the code examples easier to read in the generated documentation.

Signed-off-by: Jacob Perron <[email protected]>

Crash in callback group pointer vector iterator (ros2#814)

Signed-off-by: Guillaume Autran <[email protected]>

add mutex in add/remove_node and wait_for_work to protect concurrent use/change of memory_strategy_ (ros2#837)

Signed-off-by: Dirk Thomas <[email protected]>

Fix hang with timers in MultiThreadedExecutor (ros2#835) (ros2#836)

Signed-off-by: Todd Malsbary <[email protected]>

Use of -r/--remap flags where appropriate. (ros2#834)

Signed-off-by: Michel Hidalgo <[email protected]>

Force explicit --ros-args in NodeOptions::arguments(). (ros2#845)

Signed-off-by: Michel Hidalgo <[email protected]>

Fail on invalid and unknown ROS specific arguments (ros2#842)

* Fail on invalid and unknown ROS specific arguments.

Signed-off-by: Michel Hidalgo <[email protected]>

* Revert changes to utilities.hpp in rclcpp

Signed-off-by: Michel Hidalgo <[email protected]>

* Fully revert change to utilities.hpp

Signed-off-by: Michel Hidalgo <[email protected]>

Fix typo in deprecated warning. (ros2#848)

"it's" instead of its

Signed-off-by: Luca Della Vedova <[email protected]>

Add throwing parameter name if parameter is not set (ros2#833)

* added throwing parameter name if parameter is not set

Signed-off-by: Alex <[email protected]>
Signed-off-by: ivanpauno <[email protected]>

check valid timer handler 1st to reduce the time window for scan. (ros2#841)

Signed-off-by: Tomoya.Fujita <[email protected]>

remove features and related code which were deprecated in dashing (ros2#852)

Signed-off-by: William Woodall <[email protected]>

reset error message before setting a new one, embed the original one (ros2#854)

Signed-off-by: Dirk Thomas <[email protected]>

restored virtual destructor in publisher_base

Signed-off-by: Soragna, Alberto <[email protected]>
clalancette pushed a commit to ros2/rclcpp that referenced this pull request Oct 21, 2019
* basic ipc implementation from alsora/new_ipc_proposal

Signed-off-by: alberto <[email protected]>

better use of node_topic create subscription

Signed-off-by: alberto <[email protected]>

added intra process manager test

Signed-off-by: alberto <[email protected]>

fixed ring buffer and added test

Signed-off-by: alberto <[email protected]>

added intra process buffer test

Signed-off-by: alberto <[email protected]>

added intra process buffer test

Signed-off-by: alberto <[email protected]>

Signed-off-by: alberto <[email protected]>

removed intra-process methods from subscription base

Signed-off-by: alberto <[email protected]>

using lock_guard instead of unique_lock, renamed var without camel case

Signed-off-by: alberto <[email protected]>

using unordered set and references in intra process manager

Signed-off-by: alberto <[email protected]>

subscription intra-process does not depend anymore on subscription, but has a copy of the callback

Signed-off-by: alberto <[email protected]>

changed buffer API to use rvo

Signed-off-by: Alberto <[email protected]>

avoid copying shared_ptr

Signed-off-by: alberto <[email protected]>

revert not needed changes to create_subscription

Signed-off-by: alberto <[email protected]>

updated tests according to new buffer APIs

Signed-off-by: alberto <[email protected]>

updated types in ring buffer implementation avoid using uint32_t

Signed-off-by: alberto <[email protected]>

using unique ptr for buffers in subscription_intra_process

Signed-off-by: alberto <[email protected]>

added missing std::move in subscription_intra_process constructor

Signed-off-by: alberto <[email protected]>

use consisting names for ring_buffer_implementation members

Signed-off-by: alberto <[email protected]>

addressing typos, one-liners and similar from ivanpauno review

Signed-off-by: alberto <[email protected]>

moved subscription_intra_process_base to its own files and moved non templated method from derived class

Signed-off-by: alberto <[email protected]>

removed forward declarations, fixed include subscription_intra_process_base

Signed-off-by: alberto <[email protected]>

removed member variable from do_intra_process_publish signature

Signed-off-by: alberto <[email protected]>

declare public before private in intra_process_manager_impl

Signed-off-by: alberto <[email protected]>

made matches_any_intra_process_publishers const

Signed-off-by: alberto <[email protected]>

using const reference in get_all_matching_publishers

Signed-off-by: alberto <[email protected]>

added deleter and alloc templates in intra_process_buffer

Signed-off-by: alberto <[email protected]>

added RCLCPP_WARN to intra_process_manager_impl

Signed-off-by: alberto <[email protected]>

passing context from node to subscription_intra_process

Signed-off-by: alberto <[email protected]>

using allocators in intra_process_manager

Signed-off-by: alberto <[email protected]>

use size_t instead of int in ring buffer indices

Signed-off-by: alberto <[email protected]>

creating buffer inside subscription_intra_process constructor

Signed-off-by: alberto <[email protected]>

fix lint errors

Signed-off-by: alberto <[email protected]>

throw error if trying to dequeue when buffer empty; remove duplicated methods in intra_process_buffer

Signed-off-by: alberto <[email protected]>

added todo for creating an rmw function for checking qos compatibility

Signed-off-by: alberto <[email protected]>

test fixes

Signed-off-by: alberto <[email protected]>

refactored intra_process_manager, removed ipm impl

Signed-off-by: alberto <[email protected]>

added mutex in intra_process_manager add_* methods

Signed-off-by: Soragna, Alberto <[email protected]>

added allocator to intra_process_buffer

Signed-off-by: Soragna, Alberto <[email protected]>

added invalid intra_process qos test for subscription

Signed-off-by: Soragna, Alberto <[email protected]>

throw error if history size is 0 with keep last and ipc

Signed-off-by: Soragna, Alberto <[email protected]>

using allocator when creating unique_ptr from shared_ptr

Signed-off-by: Soragna, Alberto <[email protected]>

adding deleter template argument to intra_process buffer

Signed-off-by: Soragna, Alberto <[email protected]>

fix linter

Signed-off-by: Soragna, Alberto <[email protected]>

throw error with callbackT different from messageT

Signed-off-by: Soragna, Alberto <[email protected]>

updated deleter template argument in subscription factory

Signed-off-by: Soragna, Alberto <[email protected]>

Fix typo in test fixture tear down method name (#787)

Signed-off-by: Jacob Perron <[email protected]>

Add free function for creating service clients (#788)

Equivalent to the free function for creating a service.
Resolves #768

Signed-off-by: Jacob Perron <[email protected]>

Cmake infrastructure for creating components (#784)

*cmake macro to create components for libraries with multiple nodes

Signed-off-by: Siddharth Kucheria <[email protected]>

Allow registering multiple on_parameters_set_callback (#772)

Signed-off-by: ivanpauno <[email protected]>

fix for multiple nodes not being recognized (#790)

Signed-off-by: Siddharth Kucheria <[email protected]>

Remove non-package from ament_target_dependencies() (#793)

Signed-off-by: Shane Loretz <[email protected]>

fix linter issue (#795)

Signed-off-by: Siddharth Kucheria <[email protected]>

Make TimeSource ignore use_sim_time events coming from other nodes. (#799)

Signed-off-by: Michel Hidalgo <[email protected]>

passing deleter template parameter

Signed-off-by: Soragna, Alberto <[email protected]>

small fixes for failing tests

Signed-off-by: Soragna, Alberto <[email protected]>

fixed imports in test_intra_process_manager

Signed-off-by: Soragna, Alberto <[email protected]>

using RCLCPP_SMART_PTR_ALIASES_ONLY and RCLCPP_PUBLIC macros

Signed-off-by: Soragna, Alberto <[email protected]>

added RCLCPP_PUBLIC macros and virtual destructor to sub intra_process base

Signed-off-by: Soragna, Alberto <[email protected]>

added unique_ptr alias to macros

Signed-off-by: Soragna, Alberto <[email protected]>

updated test_intra_process_manager.cpp

Signed-off-by: Soragna, Alberto <[email protected]>

remove mock msgs from rclcpp (#800)

Signed-off-by: Karsten Knese <[email protected]>

Add line break after first open paren in multiline function call (#785)

* Add line break after first open paren in multiline function call

as per developer guide:
https://index.ros.org/doc/ros2/Contributing/Developer-Guide/#open-versus-cuddled-braces
see ament/ament_lint#148

Signed-off-by: Dan Rose <[email protected]>

Fix dedent when first function argument starts with a brace

Signed-off-by: Dan Rose <[email protected]>

Line break with multiline if condition
Remove line breaks where allowed.

Signed-off-by: Dan Rose <[email protected]>

Fixup after rebase

Signed-off-by: Dan Rose <[email protected]>

Fixup again after reverting indent_paren_open_brace

Signed-off-by: Dan Rose <[email protected]>

* Revert comment spacing change, condense some lines

Signed-off-by: Dan Rose <[email protected]>

Adapt to '--ros-args ... [--]'-based ROS args extraction (#816)

* Use --ros-args to deal with node arguments in rclcpp.

Signed-off-by: Michel Hidalgo <[email protected]>

* Document implicit --ros-args flag in NodeOptions::arguments().

Signed-off-by: Michel Hidalgo <[email protected]>

* Add missing size_t to int cast.

Signed-off-by: Michel Hidalgo <[email protected]>

* Only add implicit --ros-args flag if not present already.

Signed-off-by: Michel Hidalgo <[email protected]>

* Add some rclcpp::NodeOptions test coverage.

Signed-off-by: Michel Hidalgo <[email protected]>

* Address peer review comments.

Signed-off-by: Michel Hidalgo <[email protected]>

* Please cpplint and uncrustify.

Signed-off-by: Michel Hidalgo <[email protected]>

Guard against making multiple result requests for a goal handle (#808)

This fixes a runtime error caused by a race condition when making consecutive requests for the
result.
Specifically, this happens if the user provides a result callback when sending a goal and then
calls async_get_result shortly after.

Resolves #783

Signed-off-by: Jacob Perron <[email protected]>

Explain return value of spin_until_future_complete (#792)

Signed-off-by: Dan Rose <[email protected]>

Allow passing logger by const ref (#820)

Signed-off-by: Karsten Knese <[email protected]>

Delete unnecessary call for get_node_by_group (#823)

Signed-off-by: Tomoya.Fujita <[email protected]>

Fix get_node_interfaces functions taking a pointer (#821)

Signed-off-by: ivanpauno <[email protected]>

add callback group as member variable and constructor arg (#811)

Signed-off-by: bpwilcox <[email protected]>

remove callback group as member variable

Wrap documentation examples in code blocks (#830)

This makes the code examples easier to read in the generated documentation.

Signed-off-by: Jacob Perron <[email protected]>

Crash in callback group pointer vector iterator (#814)

Signed-off-by: Guillaume Autran <[email protected]>

add mutex in add/remove_node and wait_for_work to protect concurrent use/change of memory_strategy_ (#837)

Signed-off-by: Dirk Thomas <[email protected]>

Fix hang with timers in MultiThreadedExecutor (#835) (#836)

Signed-off-by: Todd Malsbary <[email protected]>

Use of -r/--remap flags where appropriate. (#834)

Signed-off-by: Michel Hidalgo <[email protected]>

Force explicit --ros-args in NodeOptions::arguments(). (#845)

Signed-off-by: Michel Hidalgo <[email protected]>

Fail on invalid and unknown ROS specific arguments (#842)

* Fail on invalid and unknown ROS specific arguments.

Signed-off-by: Michel Hidalgo <[email protected]>

* Revert changes to utilities.hpp in rclcpp

Signed-off-by: Michel Hidalgo <[email protected]>

* Fully revert change to utilities.hpp

Signed-off-by: Michel Hidalgo <[email protected]>

Fix typo in deprecated warning. (#848)

"it's" instead of its

Signed-off-by: Luca Della Vedova <[email protected]>

Add throwing parameter name if parameter is not set (#833)

* added throwing parameter name if parameter is not set

Signed-off-by: Alex <[email protected]>
Signed-off-by: ivanpauno <[email protected]>

check valid timer handler 1st to reduce the time window for scan. (#841)

Signed-off-by: Tomoya.Fujita <[email protected]>

remove features and related code which were deprecated in dashing (#852)

Signed-off-by: William Woodall <[email protected]>

reset error message before setting a new one, embed the original one (#854)

Signed-off-by: Dirk Thomas <[email protected]>

restored virtual destructor in publisher_base

Signed-off-by: Soragna, Alberto <[email protected]>

* fixup a few things after rebase

Signed-off-by: William Woodall <[email protected]>

* refactor some API's and get code compiling again

Signed-off-by: William Woodall <[email protected]>

* docs and style changes (whitespace)

Signed-off-by: William Woodall <[email protected]>

* move new intra process internals into experimental namespace

Signed-off-by: William Woodall <[email protected]>

* uncrustify

Signed-off-by: William Woodall <[email protected]>

* fix issues with LoanedMessages after rebase

Signed-off-by: William Woodall <[email protected]>

* more fixups

Signed-off-by: William Woodall <[email protected]>

* readd logic for avoiding in compatible QoS

Signed-off-by: William Woodall <[email protected]>

* avoid an error when intra process is disabled

Signed-off-by: William Woodall <[email protected]>

* change intra process to preserve pointer in cyclic_pipeline

Signed-off-by: William Woodall <[email protected]>

* fix issue matching topics in intra process

Signed-off-by: William Woodall <[email protected]>

* fix some issues with the tests after latest behavior change

Signed-off-by: William Woodall <[email protected]>

* address review feedback

Signed-off-by: William Woodall <[email protected]>

* fix the initialization order

Signed-off-by: William Woodall <[email protected]>

* avoid possible loss of data warning

Signed-off-by: William Woodall <[email protected]>

* more fixes related to initialization

Signed-off-by: William Woodall <[email protected]>

* fix use of custom allocators

Signed-off-by: William Woodall <[email protected]>
@rotu rotu force-pushed the uncrustify-dev-guide branch from d513211 to 18351a8 Compare December 5, 2019 17:09
Signed-off-by: Dan Rose <[email protected]>

maintain alignment

Signed-off-by: Dan Rose <[email protected]>

Set indent_paren_open_brace=true

Since we indent the arguments after a newline, this prevents a visual dedent when using a braced argument:

BAD:
```
    ASSERT_THROW(
    {
      auto client = node->create_client<ListParameters>(
        "invalid_service?"
      );
    },
      rclcpp::exceptions::InvalidServiceNameError
    );
```
GOOD:
```
    ASSERT_THROW(
      {
        auto client = node->create_client<ListParameters>(
          "invalid_service?"
        );
      },
      rclcpp::exceptions::InvalidServiceNameError
    );
```

Signed-off-by: Dan Rose <[email protected]>

Revert "Set indent_paren_open_brace=true"

This reverts commit 49595c2.
As it turns out, indent_paren_open_brace has other affects and the actual bug was indent_align_paren

Signed-off-by: Dan Rose <[email protected]>
@rotu rotu force-pushed the uncrustify-dev-guide branch from 18351a8 to 97f1777 Compare December 5, 2019 17:09
@ivanpauno
Copy link

Closing as this have been opened for a while and there haven't been any further movement.
A PR adjusting linters closer to the developer guide that doesn't create false positives, together with PRs fixing the places where the code wasn't following the style guide correctly, will be welcomed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backlog enhancement New feature or request in progress Actively being worked on (Kanban column)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants