-
Notifications
You must be signed in to change notification settings - Fork 302
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
Improve bridge command parser #396
base: master
Are you sure you want to change the base?
Conversation
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
@clalancette @sloretz @wjwwood This PR hangs out for while (2 weeks) and needs to be reviewed. |
Hey! Before I do my review, can I double check that this PR is just concerned with splitting the ROS args so there's no case where a command parser mutates a shared list of commands before a second parser reads it? Also I'm not sure if the workflow changes should be lumped into this PR, it might be better to split it off into its own PR, or is it a required dependency for the rest of the changes here? |
Hey thanks for the reply, the idea here was to just split the arguments. But I changed the dynamic bridge So basically the idea in both bridges was to, when passing arguments in the command line, use a structure like:
The bridge specific parameters are removed from the arguments list before passing the list to the
Make sense, I added them here so the bridge could be built in the GitHub Action, but I can open another PR with it. |
I wonder if we should do this:
And also continue to support the current case (but deprecate it with a warning when the |
I think is a valid option, I can work on that |
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
Signed-off-by: LucasHaug <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pending green CI
May we merge this @methylDragon? |
Thanks for this nice improvement! It works for me. |
@methylDragon Any thoughts about a new warning on CI ?
|
* Refactor command parser to use vector of char* Signed-off-by: LucasHaug <[email protected]> * Add argc argv splitter to dynamic bridge Signed-off-by: LucasHaug <[email protected]> * Add argc argv splitter to paramter bridge Signed-off-by: LucasHaug <[email protected]> * Update github action Signed-off-by: LucasHaug <[email protected]> * Fix parameter bridge argv split Signed-off-by: LucasHaug <[email protected]> * Remove static argv reading Signed-off-by: LucasHaug <[email protected]> * Add command parser to parameter bridge Signed-off-by: LucasHaug <[email protected]> * Fix compilation errors Signed-off-by: LucasHaug <[email protected]> * Fix compilation errors Signed-off-by: LucasHaug <[email protected]> * Fix parameter bidge command parser Signed-off-by: LucasHaug <[email protected]> * Refactor to add command parser utils file Signed-off-by: LucasHaug <[email protected]> * Add github action issue workaround Signed-off-by: LucasHaug <[email protected]> * Ty to run github action inside container Signed-off-by: LucasHaug <[email protected]> * Fix ROS2 args when no ROS1 args Signed-off-by: LucasHaug <[email protected]> * Revert changes on GitHub Action config Signed-off-by: LucasHaug <[email protected]> * Change parameter bridge ROS init order Signed-off-by: LucasHaug <[email protected]> * Rename parser functions Signed-off-by: LucasHaug <[email protected]> * Add get_option_values function Signed-off-by: LucasHaug <[email protected]> * Fix wrong help for the parameter bridge Signed-off-by: LucasHaug <[email protected]> * Fix get_option_values parser function Signed-off-by: LucasHaug <[email protected]> * Refactor bridges to use the get_option_values Signed-off-by: LucasHaug <[email protected]> * Add running scetion to README Signed-off-by: LucasHaug <[email protected]> * Add print pairs to parameter bridge --------- Signed-off-by: LucasHaug <[email protected]> Co-authored-by: LucasHaug <[email protected]>
This PR attempts to improve the usability of the dynamic bridge and the parameter bridge by splitting the ROS1 and ROS2 arguments into two separate lists of arguments. This solves the issue #316 and also enables the possibility to set namespaces, node names, remappings, etc, for the ROS1 node and for the ROS2 node, isolatting the ROS1 arguments from the ROS2 argumetns. Additionaly the command parser from the parameter bridge was fixed in order to be more similar to the dynamic bridge.
Besides that, I made some changes to the GitHub action, witch can be discussed, in order to simplify the setup of the environment where the package is built for the action.