[PATCH 2/3] apps: cam: Print control enum values more nicely

Umang Jain umang.jain at ideasonboard.com
Wed Sep 11 08:27:02 CEST 2024


Hi Paul

Thank you for the patch

On 11/09/24 2:18 am, Paul Elder wrote:
> 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 at ideasonboard.com>

Reviewed-by: Umang Jain <umang.jain at ideasonboard.com>
>
> ---
> No change in v2
> ---
>   src/apps/cam/camera_session.cpp | 12 ++++++++++--
>   1 file changed, 10 insertions(+), 2 deletions(-)
>
> 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;
> +			}
> +		}
>   	}
>   }
>   



More information about the libcamera-devel mailing list