diff options
author | Suren A. Chilingaryan <csa@suren.me> | 2020-03-27 20:15:30 +0100 |
---|---|---|
committer | Suren A. Chilingaryan <csa@suren.me> | 2020-03-27 20:15:30 +0100 |
commit | 324411a3e033c7f05b77e3bff829b55d674438da (patch) | |
tree | 1988ded680ccdecc2dd4d4a4b6ee6923dfb3dfd6 /cmake/FindGLIB2.cmake | |
parent | 17727d5938b0c82483c0375b33171645533b4fa5 (diff) | |
download | regularization-324411a3e033c7f05b77e3bff829b55d674438da.tar.gz regularization-324411a3e033c7f05b77e3bff829b55d674438da.tar.bz2 regularization-324411a3e033c7f05b77e3bff829b55d674438da.tar.xz regularization-324411a3e033c7f05b77e3bff829b55d674438da.zip |
Optimized TNV routine (10x performance, 1/3 memcory consumption)
Diffstat (limited to 'cmake/FindGLIB2.cmake')
-rw-r--r-- | cmake/FindGLIB2.cmake | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/cmake/FindGLIB2.cmake b/cmake/FindGLIB2.cmake new file mode 100644 index 0000000..2940d9f --- /dev/null +++ b/cmake/FindGLIB2.cmake @@ -0,0 +1,54 @@ +# - Try to find the GLIB2 libraries +# Once done this will define +# +# GLIB2_FOUND - system has glib2 +# GLIB2_DIR - path to the glib2 base directory +# GLIB2_INCLUDE_DIR - the glib2 include directory +# GLIB2_LIBRARIES - glib2 library + +set(GLIB2_DIR GLIB2_DIR-NOTFOUND CACHE PATH "Location of GLIB2 package") + +if(GLIB2_INCLUDE_DIR AND GLIB2_LIBRARIES) + # Already in cache, be silent + set(GLIB2_FIND_QUIETLY TRUE) +endif(GLIB2_INCLUDE_DIR AND GLIB2_LIBRARIES) + +if (GLIB2_DIR) + set(PKG_GLIB_LIBRARY_DIRS ${GLIB2_DIR}/lib${CMAKE_BUILD_ARCH} ${GLIB2_DIR}/lib) + set(PKG_GLIB_INCLUDE_DIRS ${GLIB2_DIR}/include/) +else (GLIB2_DIR) + if (NOT WIN32) + find_package(PkgConfig REQUIRED) + pkg_check_modules(PKG_GLIB REQUIRED glib-2.0) + endif(NOT WIN32) +endif (GLIB2_DIR) + +find_path(GLIB2_MAIN_INCLUDE_DIR glib.h + PATH_SUFFIXES glib-2.0 + PATHS ${PKG_GLIB_INCLUDE_DIRS} ) + +# search the glibconfig.h include dir under the same root where the library is found +find_library(GLIB2_LIBRARIES + NAMES glib-2.0 + PATHS ${PKG_GLIB_LIBRARY_DIRS} ) + +find_library(GTHREAD2_LIBRARIES + NAMES gthread-2.0 + PATHS ${PKG_GLIB_LIBRARY_DIRS} ) + +find_path(GLIB2_INTERNAL_INCLUDE_DIR glibconfig.h + PATH_SUFFIXES glib-2.0/include + PATHS ${PKG_GLIB_INCLUDE_DIRS} ${PKG_GLIB_LIBRARY_DIRS} ${CMAKE_SYSTEM_LIBRARY_PATH}) + +set(GLIB2_INCLUDE_DIR ${GLIB2_MAIN_INCLUDE_DIR}) + +# not sure if this include dir is optional or required +# for now it is optional +if(GLIB2_INTERNAL_INCLUDE_DIR) + set(GLIB2_INCLUDE_DIR ${GLIB2_INCLUDE_DIR} ${GLIB2_INTERNAL_INCLUDE_DIR}) +endif(GLIB2_INTERNAL_INCLUDE_DIR) + +include(FindPackageHandleStandardArgs) +find_package_handle_standard_args(GLIB2 DEFAULT_MSG GLIB2_LIBRARIES GTHREAD2_LIBRARIES GLIB2_MAIN_INCLUDE_DIR) + +mark_as_advanced(GLIB2_INCLUDE_DIR GLIB2_LIBRARIES GTHREAD2_LIBRARIES GLIB2_INTERNAL_INCLUDE_DIR GLIB2_MAIN_INCLUDE_DIR) |