aboutsummaryrefslogtreecommitdiffstats
path: root/cmakeconfig/EetCxxConfig.cmake.in
diff options
context:
space:
mode:
authorSavio Sena <savio@expertisesolutions.com.br>2014-05-03 00:55:51 +0200
committerCedric Bail <cedric.bail@free.fr>2014-05-03 00:56:32 +0200
commit46b6e8a563bd429690e7bffba4e98d06aa40798d (patch)
treeb7a2aebfc32bcc6d7a2600072a00d69a9f68d9a1 /cmakeconfig/EetCxxConfig.cmake.in
parenteina-cxx: add eina_integer_sequence, eina_optional and their tests. (diff)
downloadefl-46b6e8a563bd429690e7bffba4e98d06aa40798d.tar.gz
eolian_cxx: initial version of the EFL C++ Bindings Generator.
Summary: This patch adds 'eolian_cxx' -- a C++ bindings generator -- to the EFL tree. Eolian Cxx uses Eolian API to read .eo files and generate .eo.hh. It relies/depends on Eo Cxx and Eina Cxx (both non-generated bindings). src/bin/eolian_cxx: The eolian_cxx program. src/lib/eolian_cxx: A header-only library that implements the C++ code generation that binds the .eo classes. =Examples= src/examples/eolian_cxx/eolian_cxx_simple_01.cc: The simplest example, it just uses some "dummy" generated C++ classes. src/examples/eolian_cxx/eolian_cxx_inherit_01.cc: Illustrates how pure C++ classes inherit from .eo generated classes. src/examples/evas/evas_cxx_rectangle.cc: More realistic example using the generated bindings Evas Cxx. Still a bit shallow because we don't have full fledged .eo descriptions yet, but will be improved. =Important= The generated code is not supported and not a stable API/ABI. It is here to gather people interest and get review before we set things in stone for release 1.11. @feature Reviewers: cedric, smohanty, raster, stefan_schmidt CC: felipealmeida, JackDanielZ, cedric, stefan Differential Revision: https://phab.enlightenment.org/D805 Signed-off-by: Cedric Bail <cedric.bail@free.fr>
Diffstat (limited to 'cmakeconfig/EetCxxConfig.cmake.in')
-rw-r--r--cmakeconfig/EetCxxConfig.cmake.in30
1 files changed, 30 insertions, 0 deletions
diff --git a/cmakeconfig/EetCxxConfig.cmake.in b/cmakeconfig/EetCxxConfig.cmake.in
new file mode 100644
index 0000000000..18b0713340
--- /dev/null
+++ b/cmakeconfig/EetCxxConfig.cmake.in
@@ -0,0 +1,30 @@
+# - Try to find eet
+# Once done this will define
+# EET_CXX_FOUND - System has eet
+# EET_CXX_INCLUDE_DIRS - The eet include directories
+# EET_CXX_LIBRARIES - The libraries needed to use eet
+# EET_CXX_DEFINITIONS - Compiler switches required for using eet
+
+set(MY_PKG eet_cxx)
+
+find_package(PkgConfig)
+if ("${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}.${CMAKE_PATCH_VERSION}" VERSION_GREATER "2.8.1")
+ # "QUIET" was introduced in 2.8.2
+ set(_QUIET QUIET)
+endif ()
+pkg_check_modules(PC_EET_CXX ${_QUIET} ${MY_PKG})
+find_library(EET_CXX_LIBRARY
+ NAMES ${PC_EET_CXX_LIBRARIES}
+ HINTS ${PC_EET_CXX_LIBDIR} ${PC_EET_CXX_LIBRARY_DIRS} )
+
+set(EET_CXX_DEFINITIONS ${PC_EET_CXX_CFLAGS_OTHER})
+set(EET_CXX_LIBRARIES ${EET_CXX_LIBRARY})
+set(EET_CXX_INCLUDE_DIRS ${PC_EET_CXX_INCLUDE_DIRS})
+
+include(FindPackageHandleStandardArgs)
+# handle the QUIETLY and REQUIRED arguments and set EET_CXX_FOUND to TRUE
+# if all listed variables are TRUE
+find_package_handle_standard_args(${MY_PKG} DEFAULT_MSG
+ EET_CXX_LIBRARIES EET_CXX_INCLUDE_DIRS)
+
+mark_as_advanced(EET_CXX_INCLUDE_DIRS EET_CXX_LIBRARY EET_CXX_LIBRARIES EET_CXX_DEFINITIONS)