diff options
author | Kieran Bingham <kieran.bingham@ideasonboard.com> | 2021-06-25 00:09:15 +0100 |
---|---|---|
committer | Kieran Bingham <kieran.bingham@ideasonboard.com> | 2021-06-25 16:11:03 +0100 |
commit | 6410d1d37c1ea9d1d168840a7ba063facb0bc9d6 (patch) | |
tree | d23c636895d51df3b4b6fe128f322132203a3a26 /src/libcamera/class.cpp | |
parent | cbdc93e9d1666010d49e06940158a37c61cc6fa7 (diff) |
libcamera/base: Move class helpers to the base library
Move the class support infrastructure to the base library.
Reviewed-by: Paul Elder <paul.elder@ideasonboard.com>
Reviewed-by: Hirokazu Honda <hiroh@chromium.org>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com>
Diffstat (limited to 'src/libcamera/class.cpp')
-rw-r--r-- | src/libcamera/class.cpp | 190 |
1 files changed, 0 insertions, 190 deletions
diff --git a/src/libcamera/class.cpp b/src/libcamera/class.cpp deleted file mode 100644 index 28c35633..00000000 --- a/src/libcamera/class.cpp +++ /dev/null @@ -1,190 +0,0 @@ -/* SPDX-License-Identifier: LGPL-2.1-or-later */ -/* - * Copyright (C) 2020, Google Inc. - * - * class.cpp - Utilities and helpers for classes - */ - -#include <libcamera/class.h> - -/** - * \file class.h - * \brief Utilities to help constructing class interfaces - * - * The extensible class can be inherited to create public classes with stable - * ABIs. - */ - -namespace libcamera { - -/** - * \def LIBCAMERA_DISABLE_COPY - * \brief Disable copy construction and assignment of the \a klass - * \param klass The name of the class - * - * Example usage: - * \code{.cpp} - * class NonCopyable - * { - * public: - * NonCopyable(); - * ... - * - * private: - * LIBCAMERA_DISABLE_COPY(NonCopyable) - * }; - * \endcode - */ - -/** - * \def LIBCAMERA_DISABLE_MOVE - * \brief Disable move construction and assignment of the \a klass - * \param klass The name of the class - * - * Example usage: - * \code{.cpp} - * class NonMoveable - * { - * public: - * NonMoveable(); - * ... - * - * private: - * LIBCAMERA_DISABLE_MOVE(NonMoveable) - * }; - * \endcode - */ - -/** - * \def LIBCAMERA_DISABLE_COPY_AND_MOVE - * \brief Disable copy and move construction and assignment of the \a klass - * \param klass The name of the class - * - * Example usage: - * \code{.cpp} - * class NonCopyableNonMoveable - * { - * public: - * NonCopyableNonMoveable(); - * ... - * - * private: - * LIBCAMERA_DISABLE_COPY_AND_MOVE(NonCopyableNonMoveable) - * }; - * \endcode - */ - -/** - * \def LIBCAMERA_DECLARE_PRIVATE - * \brief Declare private data for a public class - * - * The LIBCAMERA_DECLARE_PRIVATE() macro plumbs the infrastructure necessary to - * make a class manage its private data through a d-pointer. It shall be used at - * the very top of the class definition. - */ - -/** - * \def LIBCAMERA_DECLARE_PUBLIC - * \brief Declare public data for a private class - * \param klass The public class name - * - * The LIBCAMERA_DECLARE_PUBLIC() macro is the counterpart of - * LIBCAMERA_DECLARE_PRIVATE() to be used in the private data class. It shall be - * used at the very top of the private class definition, with the public class - * name passed as the \a klass parameter. - */ - -/** - * \def LIBCAMERA_D_PTR() - * \brief Retrieve the private data pointer - * - * This macro can be used in any member function of a class that inherits, - * directly or indirectly, from the Extensible class, to create a local - * variable named 'd' that points to the class' private data instance. - */ - -/** - * \def LIBCAMERA_O_PTR() - * \brief Retrieve the public instance corresponding to the private data - * - * This macro is the counterpart of LIBCAMERA_D_PTR() for private data classes. - * It can be used in any member function of the private data class to create a - * local variable named 'o' that points to the public class instance - * corresponding to the private data. - */ - -/** - * \class Extensible - * \brief Base class to manage private data through a d-pointer - * - * The Extensible class provides a base class to implement the - * <a href="https://wiki.qt.io/D-Pointer">d-pointer</a> design pattern (also - * known as <a href="https://en.wikipedia.org/wiki/Opaque_pointer">opaque pointer</a> - * or <a href="https://en.cppreference.com/w/cpp/language/pimpl">pImpl idiom</a>). - * It helps creating public classes that can be extended without breaking their - * ABI. Such classes store their private data in a separate private data object, - * referenced by a pointer in the public class (hence the name d-pointer). - * - * Classes that follow this design pattern are referred herein as extensible - * classes. To be extensible, a class PublicClass shall: - * - * - inherit from the Extensible class or from another extensible class - * - invoke the LIBCAMERA_DECLARE_PRIVATE() macro at the very top of the class - * definition - * - define a private data class named PublicClass::Private that inherits from - * the Private data class of the base class - * - invoke the LIBCAMERA_DECLARE_PUBLIC() macro at the very top of the Private - * data class definition - * - pass a pointer to a newly allocated Private data object to the constructor - * of the base class - * - * Additionally, if the PublicClass is not final, it shall expose one or more - * constructors that takes a pointer to a Private data instance, to be used by - * derived classes. - * - * The Private class is fully opaque to users of the libcamera public API. - * Internally, it can be kept private to the implementation of PublicClass, or - * be exposed to other classes. In the latter case, the members of the Private - * class need to be qualified with appropriate access specifiers. The - * PublicClass and Private classes always have full access to each other's - * protected and private members. - */ - -/** - * \brief Construct an instance of an Extensible class - * \param[in] d Pointer to the private data instance - */ -Extensible::Extensible(Extensible::Private *d) - : d_(d) -{ -} - -/** - * \var Extensible::d_ - * \brief Pointer to the private data instance - */ - -/** - * \class Extensible::Private - * \brief Base class for private data managed through a d-pointer - */ - -/** - * \brief Construct an instance of an Extensible class private data - * \param[in] o Pointer to the public class object - */ -Extensible::Private::Private(Extensible *o) - : o_(o) -{ -} - -Extensible::Private::~Private() -{ -} - -/** - * \var Extensible::Private::o_ - * \brief Pointer to the public class object - */ - -} /* namespace libcamera */ |