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 list_hardware_components CLI #796

Closed
8 tasks
destogl opened this issue Aug 4, 2022 · 3 comments · Fixed by #891
Closed
8 tasks

Add list_hardware_components CLI #796

destogl opened this issue Aug 4, 2022 · 3 comments · Fixed by #891

Comments

@destogl
Copy link
Member

destogl commented Aug 4, 2022

Background

Add CLI command for list_hardware_components service and make nice colored output of it.

See for example how list_hardware_interfaces CLI is done.

Instructions

Hi, this is a good-first-issue issue. This means we've worked to make it more legible to people who either haven't contributed to our codebase before, or even folks who haven't contributed to open source before.

We're interested in helping you take the first step, and can answer questions and help you out along the way. Note that we're especially interested in contributions from underrepresented groups!

We know that creating a pull request is the biggest barrier for new contributors. This issue is for you 💝

If you have contributed before, consider leaving this PR for someone new, and looking through our general bug issues. Thanks!

🤔 What you will need to know.

Nothing. This issue is meant to welcome you to Open Source :) We are happy to walk you through the process.

📋 Step by Step

  • 🙋 Claim this issue: Comment below. If someone else has claimed it, ask if they've opened a pull request already and if they're stuck -- maybe you can help them solve a problem or move it along!

  • 🗄️ Create a local workspace for making your changes and testing following these instructions, for Step3 use "Download Source Code" section with these instructions.

  • 🍴 Fork the repository using the handy button at the top of the repository page and clone it into ~/ws_ros2_control/src/ros-controls/ros2_control, here is a guide that you can follow (You will have to remove or empty the existing ros2_control folder before cloning your own fork)

  • Checkout a new branch using git checkout -b <branch_name>

  • 🤖 Apply pre-commit auto formatting, by running pip3 install pre-commit and running pre-commit install in the ros2_control repo.

  • 💾 Commit and Push your changes

  • 🔀 Start a Pull Request to request to merge your code into master. There are two ways that you can start a pull request:

  1. If you are not familiar with GitHub or how to create a pull request, here is a guide you can follow on how GitHub works.
  • 🏁 Done Ask in comments for a review :)

Is someone else already working on this?

🔗- We encourage contributors to link to the original issue in their pull request so all users can easily see if someone's already started on it.

👥- If someone seems stuck, offer them some help!

🤔❓ Questions?

Don’t hesitate to ask questions or to get help if you feel like you are getting stuck. For example leave a comment below!
Furthermore, you find helpful resources here:

Good luck with your first issue!

@Serafadam
Copy link

Hey, a week ago I posted on colcon-core repository with an idea to use rich library from python to improve readability of colcon's output, maybe this could also be applied here?

@mcevoyandy
Copy link
Contributor

How should this message be printed out?

Using rrbot.launch.py as an example should formatting be something like this?

Hardware Component 0
	name: RRBot
	type: system
	plugin name: ros2_control_demo_hardware/RRBotSystemPositionOnlyHardware
	state: id=3 label=active
	command interfaces
		joint1/position [available] [unclaimed]
		joint2/position [available] [unclaimed]
	state interfaces
		joint1/position [available] [unclaimed]
		joint2/position [available] [unclaimed]

For state, is there a better format or coloring to tie it to available states here?
What are the cases where ListHardwareComponents.srv returns more than one component?

@bmagyar
Copy link
Member

bmagyar commented Jan 10, 2023

I like the above example!
Also, the cases of multiple components returned are when you have a robot made up of multiple self-contained components, the canonical one being a robot arm attached to a mobile base or a robot arm with a sensor attached

mcevoyandy added a commit to mcevoyandy/ros2_control that referenced this issue Jan 10, 2023
mcevoyandy added a commit to mcevoyandy/ros2_control that referenced this issue Jan 10, 2023
@github-project-automation github-project-automation bot moved this from Todo to Done in Roadmap / Features Feb 8, 2023
mergify bot pushed a commit that referenced this issue Feb 10, 2023
destogl pushed a commit that referenced this issue Feb 14, 2023
(cherry picked from commit e7bab63)

Co-authored-by: Andy McEvoy <[email protected]>
mamueluth pushed a commit to StoglRobotics-forks/ros2_control that referenced this issue Feb 16, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Done
Development

Successfully merging a pull request may close this issue.

4 participants