summaryrefslogtreecommitdiff
path: root/include/libcamera
diff options
context:
space:
mode:
Diffstat (limited to 'include/libcamera')
-rw-r--r--include/libcamera/camera.h15
-rw-r--r--include/libcamera/camera_manager.h8
2 files changed, 13 insertions, 10 deletions
diff --git a/include/libcamera/camera.h b/include/libcamera/camera.h
index 9a7579d6..2ea1a688 100644
--- a/include/libcamera/camera.h
+++ b/include/libcamera/camera.h
@@ -7,22 +7,25 @@
#ifndef __LIBCAMERA_CAMERA_H__
#define __LIBCAMERA_CAMERA_H__
+#include <memory>
#include <string>
namespace libcamera {
-class Camera
+class Camera final
{
public:
- Camera(const std::string &name);
+ static std::shared_ptr<Camera> create(const std::string &name);
+
+ Camera(const Camera &) = delete;
+ void operator=(const Camera &) = delete;
const std::string &name() const;
- void get();
- void put();
private:
- virtual ~Camera() { };
- int ref_;
+ explicit Camera(const std::string &name);
+ ~Camera();
+
std::string name_;
};
diff --git a/include/libcamera/camera_manager.h b/include/libcamera/camera_manager.h
index 4b941fd9..9ade29d7 100644
--- a/include/libcamera/camera_manager.h
+++ b/include/libcamera/camera_manager.h
@@ -24,10 +24,10 @@ public:
int start();
void stop();
- const std::vector<Camera *> &cameras() const { return cameras_; }
- Camera *get(const std::string &name);
+ const std::vector<std::shared_ptr<Camera>> &cameras() const { return cameras_; }
+ std::shared_ptr<Camera> get(const std::string &name);
- void addCamera(Camera *camera);
+ void addCamera(std::shared_ptr<Camera> camera);
static CameraManager *instance();
@@ -42,7 +42,7 @@ private:
std::unique_ptr<DeviceEnumerator> enumerator_;
std::vector<PipelineHandler *> pipes_;
- std::vector<Camera *> cameras_;
+ std::vector<std::shared_ptr<Camera>> cameras_;
std::unique_ptr<EventDispatcher> dispatcher_;
};