]> git.lyx.org Git - lyx.git/blobdiff - development/cmake/modules/FindICONV.cmake
cmake: disbale CPACK by default, it triggers too much requirements
[lyx.git] / development / cmake / modules / FindICONV.cmake
index bd3a49ad68623b163c13737c0acbd41225f6d2b9..3f2e7ce626d3a1b8c2ac508b463a69c9fda4ba4c 100644 (file)
 #  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 #  
 
+set(CMAKE_ALLOW_LOOSE_LOOP_CONSTRUCTS true)
+
 if (ICONV_INCLUDE_DIR)
   # Already in cache, be silent
   set(ICONV_FIND_QUIETLY TRUE)
-endif (ICONV_INCLUDE_DIR)
+endif()
 
-FIND_PATH(ICONV_INCLUDE_DIR iconv.h
+find_path(ICONV_INCLUDE_DIR iconv.h
  /usr/include
- /usr/local/include
-)
+ /usr/local/include)
 
 set(POTENTIAL_ICONV_LIBS iconv libiconv libiconv2)
-FIND_LIBRARY(ICONV_LIBRARY NAMES ${POTENTIAL_ICONV_LIBS}
-PATHS
- /usr/lib
- /usr/local/lib
-)
+
+find_library(ICONV_LIBRARY NAMES ${POTENTIAL_ICONV_LIBS}
+       PATHS /usr/lib /usr/local/lib)
 
 if(WIN32)
        set(ICONV_DLL_NAMES iconv.dll  libiconv.dll libiconv2.dll)
-       FIND_FILE(ICONV_DLL   
+       find_file(ICONV_DLL   
                                        NAMES ${ICONV_DLL_NAMES}
                                        PATHS ENV PATH
                                        NO_DEFAULT_PATH)
-       FIND_FILE(ICONV_DLL_HELP   
+       find_file(ICONV_DLL_HELP   
                                        NAMES ${ICONV_DLL_NAMES}
                                        PATHS ENV PATH
                                        ${ICONV_INCLUDE_DIR}/../bin)
-       IF(ICONV_FIND_REQUIRED)
-               IF(NOT ICONV_DLL AND NOT ICONV_DLL_HELP)
-                       MESSAGE(FATAL_ERROR "Could not find iconv.dll, please add correct your PATH environment variable")
-               ENDIF(NOT ICONV_DLL AND NOT ICONV_DLL_HELP)
-               IF(NOT ICONV_DLL AND ICONV_DLL_HELP)
-                       GET_FILENAME_COMPONENT(ICONV_DLL_HELP ${ICONV_DLL_HELP} PATH)
-                       MESSAGE(STATUS)
-                       MESSAGE(STATUS "Could not find iconv.dll in standard search path, please add ")
-                       MESSAGE(STATUS "${ICONV_DLL_HELP}")
-                       MESSAGE(STATUS "to your PATH environment variable.")
-                       MESSAGE(STATUS)
-                       MESSAGE(FATAL_ERROR "exit cmake")
-               ENDIF(NOT ICONV_DLL AND ICONV_DLL_HELP)
-       ENDIF(ICONV_FIND_REQUIRED)
-       IF (ICONV_INCLUDE_DIR AND ICONV_LIBRARY AND ICONV_DLL)
-               SET(ICONV_FOUND TRUE)
-       ENDIF (ICONV_INCLUDE_DIR AND ICONV_LIBRARY AND ICONV_DLL)
-ELSE(WIN32)
+       if(ICONV_FIND_REQUIRED)
+               if(NOT ICONV_DLL AND NOT ICONV_DLL_HELP)
+                       message(FATAL_ERROR "Could not find iconv.dll, please add correct your PATH environment variable")
+               endif()
+               if(NOT ICONV_DLL AND ICONV_DLL_HELP)
+                       get_filename_component(ICONV_DLL_HELP ${ICONV_DLL_HELP} PATH)
+                       message(STATUS)
+                       message(STATUS "Could not find iconv.dll in standard search path, please add ")
+                       message(STATUS "${ICONV_DLL_HELP}")
+                       message(STATUS "to your PATH environment variable.")
+                       message(STATUS)
+                       message(FATAL_ERROR "exit cmake")
+               endif()
+       endif()
+       if(ICONV_INCLUDE_DIR AND ICONV_LIBRARY AND ICONV_DLL)
+               set(ICONV_FOUND TRUE)
+       endif()
+else()
+       include(CheckFunctionExists)
        check_function_exists(iconv HAVE_ICONV_IN_LIBC)
-       IF (ICONV_INCLUDE_DIR AND HAVE_ICONV_IN_LIBC)
-               SET(ICONV_FOUND TRUE)
-               SET(ICONV_LIBRARY  CACHE TYPE STRING FORCE)
-       ENDIF (ICONV_INCLUDE_DIR AND HAVE_ICONV_IN_LIBC)
-       IF (ICONV_INCLUDE_DIR AND ICONV_LIBRARY)
-               SET(ICONV_FOUND TRUE)
-       ENDIF (ICONV_INCLUDE_DIR AND ICONV_LIBRARY)
-endif(WIN32)
+       if(ICONV_INCLUDE_DIR AND HAVE_ICONV_IN_LIBC)
+               set(ICONV_FOUND TRUE)
+               set(ICONV_LIBRARY  CACHE TYPE STRING FORCE)
+       endif()
+       if(ICONV_INCLUDE_DIR AND ICONV_LIBRARY)
+               set(ICONV_FOUND TRUE)
+       endif()
+endif()
 
 
 
-IF (ICONV_FOUND)
-   IF (NOT ICONV_FIND_QUIETLY)
-      MESSAGE(STATUS "Found iconv library: ${ICONV_LIBRARY}")
-      #MESSAGE(STATUS "Found iconv   dll  : ${ICONV_DLL}")
-   ENDIF (NOT ICONV_FIND_QUIETLY)
-ELSE (ICONV_FOUND)
-   IF (ICONV_FIND_REQUIRED)
-      MESSAGE(STATUS "Looked for iconv library named ${POTENTIAL_ICONV_LIBS}.")
-      MESSAGE(STATUS "Found no acceptable iconv library. This is fatal.")
-      MESSAGE(STATUS "iconv header: ${ICONV_INCLUDE_DIR}")
-      MESSAGE(STATUS "iconv lib   : ${ICONV_LIBRARY}")
-      MESSAGE(FATAL_ERROR "Could NOT find iconv library")
-   ENDIF (ICONV_FIND_REQUIRED)
-ENDIF (ICONV_FOUND)
+if(ICONV_FOUND)
+   if(NOT ICONV_FIND_QUIETLY)
+      message(STATUS "Found iconv library: ${ICONV_LIBRARY}")
+      #message(STATUS "Found iconv   dll  : ${ICONV_DLL}")
+   endif()
+else()
+   if(ICONV_FIND_REQUIRED)
+      message(STATUS "Looked for iconv library named ${POTENTIAL_ICONV_LIBS}.")
+      message(STATUS "Found no acceptable iconv library. This is fatal.")
+      message(STATUS "iconv header: ${ICONV_INCLUDE_DIR}")
+      message(STATUS "iconv lib   : ${ICONV_LIBRARY}")
+      message(FATAL_ERROR "Could NOT find iconv library")
+   endif()
+endif()
 
-MARK_AS_ADVANCED(ICONV_LIBRARY ICONV_INCLUDE_DIR)
+mark_as_advanced(ICONV_LIBRARY ICONV_INCLUDE_DIR ICONV_DLL ICONV_DLL_HELP)