[2/2] apps: cam: Print control enum values more nicely
diff mbox series

Message ID 20240910180729.2096985-3-paul.elder@ideasonboard.com
State Superseded
Headers show
Series
  • libcamera: controls: Add enum information to
Related show

Commit Message

Paul Elder Sept. 10, 2024, 6:07 p.m. UTC
Now that enum names can be obtained from ControlId, use that information
to print out the list of supported enum values in --list-controls.

Signed-off-by: Paul Elder <paul.elder@ideasonboard.com>
---
 src/apps/cam/camera_session.cpp | 12 ++++++++++--
 1 file changed, 10 insertions(+), 2 deletions(-)

Patch
diff mbox series

diff --git a/src/apps/cam/camera_session.cpp b/src/apps/cam/camera_session.cpp
index 097dc4792..964f2e8c3 100644
--- a/src/apps/cam/camera_session.cpp
+++ b/src/apps/cam/camera_session.cpp
@@ -159,8 +159,16 @@  CameraSession::~CameraSession()
 void CameraSession::listControls() const
 {
 	for (const auto &[id, info] : camera_->controls()) {
-		std::cout << "Control: " << id->name() << ": "
-			  << info.toString() << std::endl;
+		if (info.values().size() == 0) {
+			std::cout << "Control: " << id->name() << ": "
+				  << info.toString() << std::endl;
+		} else {
+			std::cout << "Control: " << id->name() << ": " << std::endl;
+			for (const auto &value : info.values()) {
+				int32_t val = value.get<int32_t>();
+				std::cout << "  - " << id->enumName(val) << " (" << val << ")" << std::endl;
+			}
+		}
 	}
 }