[libcamera-devel] [SimpleCam PATCH] cmake: Provide a sample CMakeLists.txt
Kieran Bingham
kieran.bingham at ideasonboard.com
Tue Aug 9 15:28:18 CEST 2022
Quoting Laurent Pinchart (2022-08-09 14:00:38)
> Hi Kieran,
>
> Thank you for the patch.
>
> On Tue, Aug 09, 2022 at 01:10:44PM +0100, Kieran Bingham via libcamera-devel wrote:
> > While libcamera uses meson as its build infrastructure, applications are
> > free to use other make systems. CMake is widely used, so add an example
> > CMakeLists.txt to support building simple-cam and linking against
> > libcamera using cmake.
> >
> > Signed-off-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
> > ---
> > CMakeLists.txt | 32 ++++++++++++++++++++++++++++++++
> > 1 file changed, 32 insertions(+)
> > create mode 100644 CMakeLists.txt
> >
> > diff --git a/CMakeLists.txt b/CMakeLists.txt
> > new file mode 100644
> > index 000000000000..fc8e734bdf59
> > --- /dev/null
> > +++ b/CMakeLists.txt
> > @@ -0,0 +1,32 @@
> > +cmake_minimum_required(VERSION 3.6)
> > +
> > +project(SimpleCam
> > + VERSION 1.0
>
> Should meson.build also set version to 1.0 ?
I don't think I care about it ;-)
I think I can drop the statement.
> > + DESCRIPTION "A small and documented example application for libcamera"
> > + LANGUAGES CXX)
> > +
> > +#set (CMAKE_EXPORT_COMPILE_COMMANDS ON)
>
> Should this line be dropped ? If you want to keep it as an example, I
> would add a comment before it.
Yes, this is just a leftover.
> > +set (CMAKE_CXX_STANDARD 17)
> > +
> > +find_package(PkgConfig)
> > +
> > +pkg_check_modules(LIBCAMERA REQUIRED IMPORTED_TARGET libcamera)
> > +message(STATUS "libcamera library found:")
> > +message(STATUS " version: ${LIBCAMERA_VERSION}")
> > +message(STATUS " libraries: ${LIBCAMERA_LINK_LIBRARIES}")
> > +message(STATUS " include path: ${LIBCAMERA_INCLUDE_DIRS}")
> > +
> > +# libevent is used specifically by simple-cam as it's event loop.
>
> s/it's/its/
>
> > +# Applications may use a different event handling implementation.
> > +pkg_check_modules(LIBEVENT REQUIRED IMPORTED_TARGET libevent_pthreads)
> > +message(STATUS "libevent_pthreads library found:")
> > +message(STATUS " version: ${LIBEVENT_VERSION}")
> > +message(STATUS " libraries: ${LIBEVENT_LINK_LIBRARIES}")
> > +message(STATUS " include path: ${LIBEVENT_INCLUDE_DIRS}")
> > +
> > +include_directories(${CMAKE_SOURCE_DIR} ${LIBCAMERA_INCLUDE_DIRS} ${LIBEVENT_INCLUDE_DIRS})
> > +
> > +add_executable(simple-cam simple-cam.cpp event_loop.cpp)
> > +
> > +target_link_libraries(simple-cam PkgConfig::LIBEVENT)
> > +target_link_libraries(simple-cam PkgConfig::LIBCAMERA)
>
> Could you also add the following compiler flags to match what we do in
> meson.build ?
Yes, I'll figure out how to add it.
>
> -Wall
> -Winvalid-pch
> -Wnon-virtual-dtor
> -Wextra
> -Werror
> -Wno-unused-parameter
>
> --
> Regards,
>
> Laurent Pinchart
More information about the libcamera-devel
mailing list