summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2021-07-07 02:12:07 +0300
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>2021-07-22 17:13:53 +0300
commit66c955648febf926ce4e4e238d7f19d171619f5f (patch)
tree38b45be270a7a8e2c75c47d2bbfbc4566ee3809e /src
parent3d5093911396558b03b7f9815b3c467afc426f82 (diff)
cam: Move printing of camera information to CameraSession class
The three CamApp functions listControls(), listProperties() and infoConfiguration() operate on a camera. They would thus be better placed in the CameraSession class. Move them there. As they now have no error to return anymore, make them void functions. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Diffstat (limited to 'src')
-rw-r--r--src/cam/camera_session.cpp45
-rw-r--r--src/cam/camera_session.h4
-rw-r--r--src/cam/main.cpp101
3 files changed, 70 insertions, 80 deletions
diff --git a/src/cam/camera_session.cpp b/src/cam/camera_session.cpp
index 10e66446..ceb2c3ab 100644
--- a/src/cam/camera_session.cpp
+++ b/src/cam/camera_session.cpp
@@ -11,6 +11,7 @@
#include <sstream>
#include <libcamera/control_ids.h>
+#include <libcamera/property_ids.h>
#include "camera_session.h"
#include "event_loop.h"
@@ -89,6 +90,50 @@ CameraSession::~CameraSession()
camera_->release();
}
+void CameraSession::listControls() const
+{
+ for (const auto &ctrl : camera_->controls()) {
+ const ControlId *id = ctrl.first;
+ const ControlInfo &info = ctrl.second;
+
+ std::cout << "Control: " << id->name() << ": "
+ << info.toString() << std::endl;
+ }
+}
+
+void CameraSession::listProperties() const
+{
+ for (const auto &prop : camera_->properties()) {
+ const ControlId *id = properties::properties.at(prop.first);
+ const ControlValue &value = prop.second;
+
+ std::cout << "Property: " << id->name() << " = "
+ << value.toString() << std::endl;
+ }
+}
+
+void CameraSession::infoConfiguration() const
+{
+ unsigned int index = 0;
+ for (const StreamConfiguration &cfg : *config_) {
+ std::cout << index << ": " << cfg.toString() << std::endl;
+
+ const StreamFormats &formats = cfg.formats();
+ for (PixelFormat pixelformat : formats.pixelformats()) {
+ std::cout << " * Pixelformat: "
+ << pixelformat.toString() << " "
+ << formats.range(pixelformat).toString()
+ << std::endl;
+
+ for (const Size &size : formats.sizes(pixelformat))
+ std::cout << " - " << size.toString()
+ << std::endl;
+ }
+
+ index++;
+ }
+}
+
int CameraSession::start(const OptionsParser::Options &options)
{
int ret;
diff --git a/src/cam/camera_session.h b/src/cam/camera_session.h
index 88baf906..6221aada 100644
--- a/src/cam/camera_session.h
+++ b/src/cam/camera_session.h
@@ -35,6 +35,10 @@ public:
libcamera::Camera *camera() { return camera_.get(); }
libcamera::CameraConfiguration *config() { return config_.get(); }
+ void listControls() const;
+ void listProperties() const;
+ void infoConfiguration() const;
+
int start(const OptionsParser::Options &options);
void stop();
diff --git a/src/cam/main.cpp b/src/cam/main.cpp
index cba0793a..4fe0c4c3 100644
--- a/src/cam/main.cpp
+++ b/src/cam/main.cpp
@@ -39,9 +39,6 @@ private:
void cameraRemoved(std::shared_ptr<Camera> cam);
void captureDone();
int parseOptions(int argc, char *argv[]);
- int listControls();
- int listProperties();
- int infoConfiguration();
int run();
static std::string cameraName(const Camera *camera);
@@ -158,74 +155,6 @@ int CamApp::parseOptions(int argc, char *argv[])
return 0;
}
-int CamApp::listControls()
-{
- if (!session_) {
- std::cout << "Cannot list controls without a camera"
- << std::endl;
- return -EINVAL;
- }
-
- for (const auto &ctrl : session_->camera()->controls()) {
- const ControlId *id = ctrl.first;
- const ControlInfo &info = ctrl.second;
-
- std::cout << "Control: " << id->name() << ": "
- << info.toString() << std::endl;
- }
-
- return 0;
-}
-
-int CamApp::listProperties()
-{
- if (!session_) {
- std::cout << "Cannot list properties without a camera"
- << std::endl;
- return -EINVAL;
- }
-
- for (const auto &prop : session_->camera()->properties()) {
- const ControlId *id = properties::properties.at(prop.first);
- const ControlValue &value = prop.second;
-
- std::cout << "Property: " << id->name() << " = "
- << value.toString() << std::endl;
- }
-
- return 0;
-}
-
-int CamApp::infoConfiguration()
-{
- if (!session_) {
- std::cout << "Cannot print stream information without a camera"
- << std::endl;
- return -EINVAL;
- }
-
- unsigned int index = 0;
- for (const StreamConfiguration &cfg : *session_->config()) {
- std::cout << index << ": " << cfg.toString() << std::endl;
-
- const StreamFormats &formats = cfg.formats();
- for (PixelFormat pixelformat : formats.pixelformats()) {
- std::cout << " * Pixelformat: "
- << pixelformat.toString() << " "
- << formats.range(pixelformat).toString()
- << std::endl;
-
- for (const Size &size : formats.sizes(pixelformat))
- std::cout << " - " << size.toString()
- << std::endl;
- }
-
- index++;
- }
-
- return 0;
-}
-
void CamApp::cameraAdded(std::shared_ptr<Camera> cam)
{
std::cout << "Camera Added: " << cam->id() << std::endl;
@@ -269,21 +198,33 @@ int CamApp::run()
}
if (options_.isSet(OptListControls)) {
- ret = listControls();
- if (ret)
- return ret;
+ if (!session_) {
+ std::cout << "Cannot list controls without a camera"
+ << std::endl;
+ return -EINVAL;
+ }
+
+ session_->listControls();
}
if (options_.isSet(OptListProperties)) {
- ret = listProperties();
- if (ret)
- return ret;
+ if (!session_) {
+ std::cout << "Cannot list properties without a camera"
+ << std::endl;
+ return -EINVAL;
+ }
+
+ session_->listProperties();
}
if (options_.isSet(OptInfo)) {
- ret = infoConfiguration();
- if (ret)
- return ret;
+ if (!session_) {
+ std::cout << "Cannot print stream information without a camera"
+ << std::endl;
+ return -EINVAL;
+ }
+
+ session_->infoConfiguration();
}
if (options_.isSet(OptCapture)) {