summaryrefslogtreecommitdiff
path: root/src/cam/stream_options.cpp
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2022-10-20 00:44:55 +0300
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>2022-10-20 13:36:25 +0300
commit84ad104499d9efc0253dae1a60ee070ed375ad95 (patch)
treed10fd53eb79cebb28fa3f72b18b46dddb6382b83 /src/cam/stream_options.cpp
parentdaf3f4b59f4ea0ecb42c6a39fe909f071d3a2842 (diff)
Move test applications to src/apps/
The cam and qcam test application share code, currently through a crude hack that references the cam source files directly from the qcam meson.build file. To prepare for the introduction of hosting that code in a static library, move all applications to src/apps/. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Paul Elder <paul.elder@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Diffstat (limited to 'src/cam/stream_options.cpp')
-rw-r--r--src/cam/stream_options.cpp134
1 files changed, 0 insertions, 134 deletions
diff --git a/src/cam/stream_options.cpp b/src/cam/stream_options.cpp
deleted file mode 100644
index 3a5625f5..00000000
--- a/src/cam/stream_options.cpp
+++ /dev/null
@@ -1,134 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-or-later */
-/*
- * Copyright (C) 2020, Raspberry Pi Ltd
- *
- * stream_options.cpp - Helper to parse options for streams
- */
-#include "stream_options.h"
-
-#include <iostream>
-
-#include <libcamera/color_space.h>
-
-using namespace libcamera;
-
-StreamKeyValueParser::StreamKeyValueParser()
-{
- addOption("role", OptionString,
- "Role for the stream (viewfinder, video, still, raw)",
- ArgumentRequired);
- addOption("width", OptionInteger, "Width in pixels",
- ArgumentRequired);
- addOption("height", OptionInteger, "Height in pixels",
- ArgumentRequired);
- addOption("pixelformat", OptionString, "Pixel format name",
- ArgumentRequired);
- addOption("colorspace", OptionString, "Color space",
- ArgumentRequired);
-}
-
-KeyValueParser::Options StreamKeyValueParser::parse(const char *arguments)
-{
- KeyValueParser::Options options = KeyValueParser::parse(arguments);
- StreamRole role;
-
- if (options.valid() && options.isSet("role") &&
- !parseRole(&role, options)) {
- std::cerr << "Unknown stream role "
- << options["role"].toString() << std::endl;
- options.invalidate();
- }
-
- return options;
-}
-
-StreamRoles StreamKeyValueParser::roles(const OptionValue &values)
-{
- /* If no configuration values to examine default to viewfinder. */
- if (values.empty())
- return { StreamRole::Viewfinder };
-
- const std::vector<OptionValue> &streamParameters = values.toArray();
-
- StreamRoles roles;
- for (auto const &value : streamParameters) {
- StreamRole role;
-
- /* If role is invalid or not set default to viewfinder. */
- if (!parseRole(&role, value.toKeyValues()))
- role = StreamRole::Viewfinder;
-
- roles.push_back(role);
- }
-
- return roles;
-}
-
-int StreamKeyValueParser::updateConfiguration(CameraConfiguration *config,
- const OptionValue &values)
-{
- if (!config) {
- std::cerr << "No configuration provided" << std::endl;
- return -EINVAL;
- }
-
- /* If no configuration values nothing to do. */
- if (values.empty())
- return 0;
-
- const std::vector<OptionValue> &streamParameters = values.toArray();
-
- if (config->size() != streamParameters.size()) {
- std::cerr
- << "Number of streams in configuration "
- << config->size()
- << " does not match number of streams parsed "
- << streamParameters.size()
- << std::endl;
- return -EINVAL;
- }
-
- unsigned int i = 0;
- for (auto const &value : streamParameters) {
- KeyValueParser::Options opts = value.toKeyValues();
- StreamConfiguration &cfg = config->at(i++);
-
- if (opts.isSet("width") && opts.isSet("height")) {
- cfg.size.width = opts["width"];
- cfg.size.height = opts["height"];
- }
-
- if (opts.isSet("pixelformat"))
- cfg.pixelFormat = PixelFormat::fromString(opts["pixelformat"].toString());
-
- if (opts.isSet("colorspace"))
- cfg.colorSpace = ColorSpace::fromString(opts["colorspace"].toString());
- }
-
- return 0;
-}
-
-bool StreamKeyValueParser::parseRole(StreamRole *role,
- const KeyValueParser::Options &options)
-{
- if (!options.isSet("role"))
- return false;
-
- std::string name = options["role"].toString();
-
- if (name == "viewfinder") {
- *role = StreamRole::Viewfinder;
- return true;
- } else if (name == "video") {
- *role = StreamRole::VideoRecording;
- return true;
- } else if (name == "still") {
- *role = StreamRole::StillCapture;
- return true;
- } else if (name == "raw") {
- *role = StreamRole::Raw;
- return true;
- }
-
- return false;
-}