[PATCH v1 5/6] Documentation: guides: pipeline-handler: Simplify format collection
Kieran Bingham
kieran.bingham at ideasonboard.com
Tue Dec 10 14:41:55 CET 2024
Quoting Barnabás Pőcze (2024-12-09 17:48:05)
> I believe a simple range based for loop is easier to understand
> here than `std::transform()`. Furthermore, using a for loop enables
> the easy filtering of invalid pixel formats.
>
I agree, I find the std::transform() difficult to interpret.
I prefer this - but it probably needs to be tested in the vivid pipeline
handler and updated on that tree too to keep these consistent.
Reviewed-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
> Signed-off-by: Barnabás Pőcze <barnabas.pocze at ideasonboard.com>
> ---
> Documentation/guides/pipeline-handler.rst | 18 +++++++-----------
> 1 file changed, 7 insertions(+), 11 deletions(-)
>
> diff --git a/Documentation/guides/pipeline-handler.rst b/Documentation/guides/pipeline-handler.rst
> index b65145e3a..a798733db 100644
> --- a/Documentation/guides/pipeline-handler.rst
> +++ b/Documentation/guides/pipeline-handler.rst
> @@ -827,9 +827,7 @@ To generate a ``StreamConfiguration``, you need a list of pixel formats and
> frame sizes which are supported as outputs of the stream. You can fetch a map of
> the ``V4LPixelFormat`` and ``SizeRange`` supported by the underlying output
> device, but the pipeline handler needs to convert this to a
> -``libcamera::PixelFormat`` type to pass to applications. We do this here using
> -``std::transform`` to convert the formats and populate a new ``PixelFormat`` map
> -as shown below.
> +``libcamera::PixelFormat`` type to pass to applications.
>
> Continue adding the following code example to our ``generateConfiguration``
> implementation.
> @@ -839,14 +837,12 @@ implementation.
> std::map<V4L2PixelFormat, std::vector<SizeRange>> v4l2Formats =
> data->video_->formats();
> std::map<PixelFormat, std::vector<SizeRange>> deviceFormats;
> - std::transform(v4l2Formats.begin(), v4l2Formats.end(),
> - std::inserter(deviceFormats, deviceFormats.begin()),
> - [&](const decltype(v4l2Formats)::value_type &format) {
> - return decltype(deviceFormats)::value_type{
> - format.first.toPixelFormat(),
> - format.second
> - };
> - });
> +
> + for (auto &[v4l2PixelFormat, sizes] : v4l2Formats) {
> + PixelFormat pixelFormat = v4l2PixelFormat.toPixelFormat();
> + if (pixelFormat.isValid())
> + deviceFormats.try_emplace(pixelFormat, std::move(sizes));
> + }
>
> The `StreamFormats`_ class holds information about the pixel formats and frame
> sizes that a stream can support. The class groups size information by the pixel
> --
> 2.47.1
>
More information about the libcamera-devel
mailing list