-
Notifications
You must be signed in to change notification settings - Fork 301
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 <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
@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 <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
Signed-off-by: LucasHaug <lucas.haug@hotmail.com>
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 <lucas.haug@hotmail.com> * Add argc argv splitter to dynamic bridge Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Add argc argv splitter to paramter bridge Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Update github action Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix parameter bridge argv split Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Remove static argv reading Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Add command parser to parameter bridge Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix compilation errors Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix compilation errors Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix parameter bidge command parser Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Refactor to add command parser utils file Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Add github action issue workaround Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Ty to run github action inside container Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix ROS2 args when no ROS1 args Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Revert changes on GitHub Action config Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Change parameter bridge ROS init order Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Rename parser functions Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Add get_option_values function Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix wrong help for the parameter bridge Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Fix get_option_values parser function Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Refactor bridges to use the get_option_values Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Add running scetion to README Signed-off-by: LucasHaug <lucas.haug@hotmail.com> * Add print pairs to parameter bridge --------- Signed-off-by: LucasHaug <lucas.haug@hotmail.com> Co-authored-by: LucasHaug <lucas.haug@hotmail.com>
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.