aboutsummaryrefslogtreecommitdiffstats
path: root/cmakeconfig
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
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')
-rw-r--r--cmakeconfig/EcoreCxxConfig.cmake.in66
-rw-r--r--cmakeconfig/EetCxxConfig.cmake.in30
-rw-r--r--cmakeconfig/EinaCxxConfig.cmake.in30
-rw-r--r--cmakeconfig/EoCxxConfig.cmake.in30
-rw-r--r--cmakeconfig/EolianCxxConfig.cmake.in30
-rw-r--r--cmakeconfig/EvasCxxConfig.cmake.in30
6 files changed, 216 insertions, 0 deletions
diff --git a/cmakeconfig/EcoreCxxConfig.cmake.in b/cmakeconfig/EcoreCxxConfig.cmake.in
new file mode 100644
index 0000000000..4dcd580286
--- /dev/null
+++ b/cmakeconfig/EcoreCxxConfig.cmake.in
@@ -0,0 +1,66 @@
+# - Try to find ecore_cxx
+# Once done this will define
+#
+# ECORE_CXX_FOUND - System has ecore_cxx
+# ECORE_CXX_INCLUDE_DIRS - The ecore_cxx include directories
+# ECORE_CXX_LIBRARIES - The libraries needed to use ecore_cxx
+# ECORE_CXX_DEFINITIONS - Compiler switches required for using ecore_cxx
+#
+# When the COMPONENTS keyword was passed to find_package(),
+# the following variables are defined for additional Ecore_Cxx modules
+# such as Evas, X, Imf, Imf_Evas.
+#
+# ECORE_CXX_*_FOUND - System has ecore_cxx *
+# ECORE_CXX_*_INCLUDE_DIRS - The ecore_cxx include directories
+# ECORE_CXX_*_LIBRARIES - The libraries needed to use ecore_cxx
+# ECORE_CXX_*_DEFINITIONS - Compiler switches required for using ecore_cxx * module.
+
+set(MY_PKG ecore_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_LIBECORE_CXX ${_QUIET} ${MY_PKG})
+
+find_library(ECORE_CXX_LIBRARY
+ NAMES ${PC_LIBECORE_CXX_LIBRARIES}
+ HINTS ${PC_LIBECORE_CXX_LIBDIR} ${PC_LIBECORE_CXX_LIBRARY_DIRS} )
+
+set(ECORE_CXX_DEFINITIONS ${PC_LIBECORE_CXX_CFLAGS_OTHER})
+set(ECORE_CXX_LIBRARIES ${ECORE_CXX_LIBRARY})
+set(ECORE_CXX_INCLUDE_DIRS ${PC_LIBECORE_CXX_INCLUDE_DIRS})
+
+include(FindPackageHandleStandardArgs)
+# handle the QUIETLY and REQUIRED arguments and set ECORE_CXX_FOUND to TRUE
+# if all listed variables are TRUE
+find_package_handle_standard_args(${MY_PKG} DEFAULT_MSG
+ ECORE_CXX_LIBRARIES ECORE_CXX_INCLUDE_DIRS)
+
+mark_as_advanced(ECORE_CXX_INCLUDE_DIRS ECORE_CXX_LIBRARY ECORE_CXX_LIBRARIES ECORE_CXX_DEFINITIONS)
+
+if (Ecore_Cxx_FIND_COMPONENTS)
+ foreach(_component ${Ecore_Cxx_FIND_COMPONENTS})
+ string(TOUPPER ${_component} _COMPONENT)
+ string(TOLOWER ${_component} _component)
+ string(REGEX REPLACE "_" "-" _MODULE_PKGNAME "ecore_cxx-${_component}")
+
+ pkg_check_modules(PC_LIBECORE_CXX_${_COMPONENT} ${_QUIET} ${_MODULE_PKGNAME})
+
+ find_library(ECORE_CXX_${_COMPONENT}_LIBRARY
+ NAMES ${PC_LIBECORE_CXX_${_COMPONENT}_LIBRARIES}
+ HINTS ${PC_LIBECORE_CXX_${_COMPONENT}_LIBDIR}
+ ${PC_LIBECORE_CXX_${_COMPONENT}_LIBRARY_DIRS})
+
+ set(ECORE_CXX_${_COMPONENT}_DEFINITIONS ${PC_LIBECORE_CXX_${_COMPONENT}_CFLAGS_OTHER})
+ set(ECORE_CXX_${_COMPONENT}_LIBRARIES ${ECORE_CXX_${_COMPONENT}_LIBRARY})
+ set(ECORE_CXX_${_COMPONENT}_INCLUDE_DIRS ${PC_LIBECORE_CXX_${_COMPONENT}_INCLUDE_DIRS})
+
+ include(FindPackageHandleStandardArgs)
+ # handle the QUIETLY and REQUIRED arguments and set ECORE_CXX_*_FOUND to TRUE
+ # if all listed variables are TRUE
+ find_package_handle_standard_args(ecore_cxx_${_component} DEFAULT_MSG
+ ECORE_CXX_${_COMPONENT}_LIBRARIES ECORE_CXX_${_COMPONENT}_INCLUDE_DIRS)
+ endforeach(_component)
+endif(Ecore_Cxx_FIND_COMPONENTS)
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)
diff --git a/cmakeconfig/EinaCxxConfig.cmake.in b/cmakeconfig/EinaCxxConfig.cmake.in
new file mode 100644
index 0000000000..f2f5658b63
--- /dev/null
+++ b/cmakeconfig/EinaCxxConfig.cmake.in
@@ -0,0 +1,30 @@
+# - Try to find eina
+# Once done this will define
+# EINA_CXX_FOUND - System has eina
+# EINA_CXX_INCLUDE_DIRS - The eina include directories
+# EINA_CXX_LIBRARIES - The libraries needed to use eina
+# EINA_CXX_DEFINITIONS - Compiler switches required for using eina
+
+set(MY_PKG eina_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_EINA_CXX ${_QUIET} ${MY_PKG})
+find_library(EINA_CXX_LIBRARY
+ NAMES ${PC_EINA_CXX_LIBRARIES}
+ HINTS ${PC_EINA_CXX_LIBDIR} ${PC_EINA_CXX_LIBRARY_DIRS} )
+
+set(EINA_CXX_DEFINITIONS ${PC_EINA_CXX_CFLAGS_OTHER})
+set(EINA_CXX_LIBRARIES ${EINA_CXX_LIBRARY})
+set(EINA_CXX_INCLUDE_DIRS ${PC_EINA_CXX_INCLUDE_DIRS})
+
+include(FindPackageHandleStandardArgs)
+# handle the QUIETLY and REQUIRED arguments and set EINA_CXX_FOUND to TRUE
+# if all listed variables are TRUE
+find_package_handle_standard_args(${MY_PKG} DEFAULT_MSG
+ EINA_CXX_LIBRARIES EINA_CXX_INCLUDE_DIRS)
+
+mark_as_advanced(EINA_CXX_INCLUDE_DIRS EINA_CXX_LIBRARY EINA_CXX_LIBRARIES EINA_CXX_DEFINITIONS)
diff --git a/cmakeconfig/EoCxxConfig.cmake.in b/cmakeconfig/EoCxxConfig.cmake.in
new file mode 100644
index 0000000000..94a9790da9
--- /dev/null
+++ b/cmakeconfig/EoCxxConfig.cmake.in
@@ -0,0 +1,30 @@
+# - Try to find eo
+# Once done this will define
+# EO_CXX_FOUND - System has eo
+# EO_CXX_INCLUDE_DIRS - The eo include directories
+# EO_CXX_LIBRARIES - The libraries needed to use eo
+# EO_CXX_DEFINITIONS - Compiler switches required for using eo
+
+set(MY_PKG eo_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_EO_CXX ${_QUIET} ${MY_PKG})
+find_library(EO_CXX_LIBRARY
+ NAMES ${PC_EO_CXX_LIBRARIES}
+ HINTS ${PC_EO_CXX_LIBDIR} ${PC_EO_CXX_LIBRARY_DIRS} )
+
+set(EO_CXX_DEFINITIONS ${PC_EO_CXX_CFLAGS_OTHER})
+set(EO_CXX_LIBRARIES ${EO_CXX_LIBRARY})
+set(EO_CXX_INCLUDE_DIRS ${PC_EO_CXX_INCLUDE_DIRS})
+
+include(FindPackageHandleStandardArgs)
+# handle the QUIETLY and REQUIRED arguments and set EO_CXX_FOUND to TRUE
+# if all listed variables are TRUE
+find_package_handle_standard_args(${MY_PKG} DEFAULT_MSG
+ EO_CXX_LIBRARIES EO_CXX_INCLUDE_DIRS)
+
+mark_as_advanced(EO_CXX_INCLUDE_DIRS EO_CXX_LIBRARY EO_CXX_LIBRARIES EO_CXX_DEFINITIONS)
diff --git a/cmakeconfig/EolianCxxConfig.cmake.in b/cmakeconfig/EolianCxxConfig.cmake.in
new file mode 100644
index 0000000000..2f7101f0a7
--- /dev/null
+++ b/cmakeconfig/EolianCxxConfig.cmake.in
@@ -0,0 +1,30 @@
+# - Try to find eolian
+# Once done this will define
+# EOLIAN_CXX_FOUND - System has eolian
+# EOLIAN_CXX_INCLUDE_DIRS - The eolian include directories
+# EOLIAN_CXX_LIBRARIES - The libraries needed to use eolian
+# EOLIAN_CXX_DEFINITIONS - Compiler switches required for using eolian
+
+set(MY_PKG eolian_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_EOLIAN_CXX ${_QUIET} ${MY_PKG})
+find_library(EOLIAN_CXX_LIBRARY
+ NAMES ${PC_EOLIAN_CXX_LIBRARIES}
+ HINTS ${PC_EOLIAN_CXX_LIBDIR} ${PC_EOLIAN_CXX_LIBRARY_DIRS} )
+
+set(EOLIAN_CXX_DEFINITIONS ${PC_EOLIAN_CXX_CFLAGS_OTHER})
+set(EOLIAN_CXX_LIBRARIES ${EOLIAN_CXX_LIBRARY})
+set(EOLIAN_CXX_INCLUDE_DIRS ${PC_EOLIAN_CXX_INCLUDE_DIRS})
+
+include(FindPackageHandleStandardArgs)
+# handle the QUIETLY and REQUIRED arguments and set EOLIAN_CXX_FOUND to TRUE
+# if all listed variables are TRUE
+find_package_handle_standard_args(${MY_PKG} DEFAULT_MSG
+ EOLIAN_CXX_LIBRARIES EOLIAN_CXX_INCLUDE_DIRS)
+
+mark_as_advanced(EOLIAN_CXX_INCLUDE_DIRS EOLIAN_CXX_LIBRARY EOLIAN_CXX_LIBRARIES EOLIAN_CXX_DEFINITIONS)
diff --git a/cmakeconfig/EvasCxxConfig.cmake.in b/cmakeconfig/EvasCxxConfig.cmake.in
new file mode 100644
index 0000000000..e45e111646
--- /dev/null
+++ b/cmakeconfig/EvasCxxConfig.cmake.in
@@ -0,0 +1,30 @@
+# - Try to find evas
+# Once done this will define
+# EVAS_CXX_FOUND - System has evas
+# EVAS_CXX_INCLUDE_DIRS - The evas include directories
+# EVAS_CXX_LIBRARIES - The libraries needed to use evas
+# EVAS_CXX_DEFINITIONS - Compiler switches required for using evas
+
+set(MY_PKG evas_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_EVAS_CXX ${_QUIET} ${MY_PKG})
+find_library(EVAS_CXX_LIBRARY
+ NAMES ${PC_EVAS_CXX_LIBRARIES}
+ HINTS ${PC_EVAS_CXX_LIBDIR} ${PC_EVAS_CXX_LIBRARY_DIRS} )
+
+set(EVAS_CXX_DEFINITIONS ${PC_EVAS_CXX_CFLAGS_OTHER})
+set(EVAS_CXX_LIBRARIES ${EVAS_CXX_LIBRARY})
+set(EVAS_CXX_INCLUDE_DIRS ${PC_EVAS_CXX_INCLUDE_DIRS})
+
+include(FindPackageHandleStandardArgs)
+# handle the QUIETLY and REQUIRED arguments and set EVAS_CXX_FOUND to TRUE
+# if all listed variables are TRUE
+find_package_handle_standard_args(${MY_PKG} DEFAULT_MSG
+ EVAS_CXX_LIBRARIES EVAS_CXX_INCLUDE_DIRS)
+
+mark_as_advanced(EVAS_CXX_INCLUDE_DIRS EVAS_CXX_LIBRARY EVAS_CXX_LIBRARIES EVAS_CXX_DEFINITIONS)