| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678 |
- # - Find wxWindows (wxWidgets) installation
- # This module finds if wxWindows/wxWidgets is installed and determines where
- # the include files and libraries are. It also determines what the name of
- # the library is. This code sets the following variables:
- #
- # WXWINDOWS_FOUND = system has WxWindows
- # WXWINDOWS_LIBRARIES = path to the wxWindows libraries
- # on Unix/Linux with additional
- # linker flags from
- # "wx-config --libs"
- # CMAKE_WXWINDOWS_CXX_FLAGS = Compiler flags for wxWindows,
- # essentially "`wx-config --cxxflags`"
- # on Linux
- # WXWINDOWS_INCLUDE_DIR = where to find "wx/wx.h" and "wx/setup.h"
- # WXWINDOWS_LINK_DIRECTORIES = link directories, useful for rpath on
- # Unix
- # WXWINDOWS_DEFINITIONS = extra defines
- #
- # DEPRECATED
- # CMAKE_WX_CAN_COMPILE
- # WXWINDOWS_LIBRARY
- # CMAKE_WX_CXX_FLAGS
- # WXWINDOWS_INCLUDE_PATH
- #
- # OPTIONS
- # If you need OpenGL support please
- # SET(WXWINDOWS_USE_GL 1)
- # in your CMakeLists.txt *before* you include this file.
- #
- # For convenience include Use_wxWindows.cmake in your project's
- # CMakeLists.txt using INCLUDE(Use_wxWindows).
- #
- # USAGE
- # SET(WXWINDOWS_USE_GL 1)
- # FIND_PACKAGE(wxWindows)
- #
- # NOTES
- # wxWidgets 2.6.x is supported for monolithic builds
- # e.g. compiled in wx/build/msw dir as:
- # nmake -f makefile.vc BUILD=debug SHARED=0 USE_OPENGL=1 MONOLITHIC=1
- #
- # AUTHOR
- # Jan Woetzel <http://www.mip.informatik.uni-kiel.de/~jw> (07/2003-01/2006)
- # ------------------------------------------------------------------
- #
- # -removed OPTION for CMAKE_WXWINDOWS_USE_GL. Force the developer to SET it before calling this.
- # -major update for wx 2.6.2 and monolithic build option. (10/2005)
- #
- # STATUS
- # tested with:
- # cmake 1.6.7, Linux (Suse 7.3), wxWindows 2.4.0, gcc 2.95
- # cmake 1.6.7, Linux (Suse 8.2), wxWindows 2.4.0, gcc 3.3
- # cmake 1.6.7, Linux (Suse 8.2), wxWindows 2.4.1-patch1, gcc 3.3
- # cmake 1.6.7, MS Windows XP home, wxWindows 2.4.1, MS Visual Studio .net 7 2002 (static build)
- # cmake 2.0.5 on Windows XP and Suse Linux 9.2
- # cmake 2.0.6 on Windows XP and Suse Linux 9.2, wxWidgets 2.6.2 MONOLITHIC build
- # cmake 2.2.2 on Windows XP, MS Visual Studio .net 2003 7.1 wxWidgets 2.6.2 MONOLITHIC build
- #
- # TODO
- # -OPTION for unicode builds
- # -further testing of DLL linking under MS WIN32
- # -better support for non-monolithic builds
- #
- IF(WIN32)
- SET(WIN32_STYLE_FIND 1)
- ENDIF(WIN32)
- IF(MINGW)
- SET(WIN32_STYLE_FIND 0)
- SET(UNIX_STYLE_FIND 1)
- ENDIF(MINGW)
- IF(UNIX)
- SET(UNIX_STYLE_FIND 1)
- ENDIF(UNIX)
- IF(WIN32_STYLE_FIND)
- ## ######################################################################
- ##
- ## Windows specific:
- ##
- ## candidates for root/base directory of wxwindows
- ## should have subdirs include and lib containing include/wx/wx.h
- ## fix the root dir to avoid mixing of headers/libs from different
- ## versions/builds:
-
- SET (WXWINDOWS_POSSIBLE_ROOT_PATHS
- $ENV{WXWIN}
- "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\wxWidgets_is1;Inno Setup: App Path]" ## WX 2.6.x
- "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\wxWindows_is1;Inno Setup: App Path]" ## WX 2.4.x
- C:\\wxWidgets-2.6.2
- D:\\wxWidgets-2.6.2
- C:\\wxWidgets-2.6.1
- D:\\wxWidgets-2.6.1
- C:\\wxWindows-2.4.2
- D:\\wxWindows-2.4.2
- )
-
- ## WX supports monolithic and multiple smaller libs (since 2.5.x), we prefer monolithic for now.
- ## monolithic = WX is built as a single big library
- ## e.g. compile on WIN32 as "nmake -f makefile.vc MONOLITHIC=1 BUILD=debug SHARED=0 USE_OPENGL=1" (JW)
- OPTION(WXWINDOWS_USE_MONOLITHIC "Use monolithic build of WX??" ON)
- MARK_AS_ADVANCED(WXWINDOWS_USE_MONOLITHIC)
- ## GL libs used?
- OPTION(WXWINDOWS_USE_GL "Use Wx with GL support(glcanvas)?" ON)
- MARK_AS_ADVANCED(WXWINDOWS_USE_GL)
- ## avoid mixing of headers and libs between multiple installed WX versions,
- ## select just one tree here:
- FIND_PATH(WXWINDOWS_ROOT_DIR include/wx/wx.h
- ${WXWINDOWS_POSSIBLE_ROOT_PATHS} )
- # MESSAGE("DBG found WXWINDOWS_ROOT_DIR: ${WXWINDOWS_ROOT_DIR}")
-
-
- ## find libs for combination of static/shared with release/debug
- ## be careful if you add something here,
- ## avoid mixing of headers and libs of different wx versions,
- ## there may be multiple WX version s installed.
- SET (WXWINDOWS_POSSIBLE_LIB_PATHS
- "${WXWINDOWS_ROOT_DIR}/lib"
- )
-
- ## monolithic?
- IF (WXWINDOWS_USE_MONOLITHIC)
-
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY
- NAMES wx wxmsw wxmsw26
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static release build library" )
-
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY
- NAMES wxd wxmswd wxmsw26d
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug build library" )
-
- FIND_LIBRARY(WXWINDOWS_SHARED_LIBRARY
- NAMES wxmsw26 wxmsw262 wxmsw24 wxmsw242 wxmsw241 wxmsw240 wx23_2 wx22_9
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows shared release build library" )
-
- FIND_LIBRARY(WXWINDOWS_SHARED_DEBUG_LIBRARY
- NAMES wxmsw26d wxmsw262d wxmsw24d wxmsw241d wxmsw240d wx23_2d wx22_9d
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows shared debug build library " )
- ##
- ## required for WXWINDOWS_USE_GL
- ## gl lib is always build separate:
- ##
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_GL
- NAMES wx_gl wxmsw_gl wxmsw26_gl
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static release build GL library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_GL
- NAMES wxd_gl wxmswd_gl wxmsw26d_gl
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug build GL library" )
-
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_PNG
- NAMES wxpngd
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug png library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_PNG
- NAMES wxpng
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static png library" )
-
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_TIFF
- NAMES wxtiffd
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug tiff library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_TIFF
- NAMES wxtiff
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static tiff library" )
-
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_JPEG
- NAMES wxjpegd wxjpgd
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug jpeg library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_JPEG
- NAMES wxjpeg wxjpg
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static jpeg library" )
-
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_ZLIB
- NAMES wxzlibd
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug zlib library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_ZLIB
- NAMES wxzlib
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static zib library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_REGEX
- NAMES wxregexd
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static debug regex library" )
- FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_REGEX
- NAMES wxregex
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows static regex library" )
-
-
-
- ## untested:
- FIND_LIBRARY(WXWINDOWS_SHARED_LIBRARY_GL
- NAMES wx_gl wxmsw_gl wxmsw26_gl
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows shared release build GL library" )
- FIND_LIBRARY(WXWINDOWS_SHARED_DEBUG_LIBRARY_GL
- NAMES wxd_gl wxmswd_gl wxmsw26d_gl
- PATHS
- "${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
- ${WXWINDOWS_POSSIBLE_LIB_PATHS}
- DOC "wxWindows shared debug build GL library" )
-
-
- ELSE (WXWINDOWS_USE_MONOLITHIC)
- ## WX is built as multiple small pieces libraries instead of monolithic
-
- ## DEPECATED (jw) replaced by more general WXWINDOWS_USE_MONOLITHIC ON/OFF
- # OPTION(WXWINDOWS_SEPARATE_LIBS_BUILD "Is wxWindows build with separate libs?" OFF)
-
- ## HACK: This is very dirty.
- ## because the libs of a particular version are explicitly listed
- ## and NOT searched/verified.
- ## TODO: Really search for each lib, then decide for
- ## monolithic x debug x shared x GL (=16 combinations) for at least 18 libs
- ## --> about 288 combinations
- ## thus we need a different approach so solve this correctly ...
-
- MESSAGE(STATUS "Warning: You are trying to use wxWidgets without monolithic build (WXWINDOWS_SEPARATE_LIBS_BUILD). This is a HACK, libraries are not verified! (JW).")
-
- SET(WXWINDOWS_STATIC_LIBS ${WXWINDOWS_STATIC_LIBS}
- wxbase26
- wxbase26_net
- wxbase26_odbc
- wxbase26_xml
- wxmsw26_adv
- wxmsw26_core
- wxmsw26_dbgrid
- wxmsw26_gl
- wxmsw26_html
- wxmsw26_media
- wxmsw26_qa
- wxmsw26_xrc
- wxexpat
- wxjpeg
- wxpng
- wxregex
- wxtiff
- wxzlib
- comctl32
- rpcrt4
- wsock32
- )
- ## HACK: feed in to optimized / debug libaries if both were FOUND.
- SET(WXWINDOWS_STATIC_DEBUG_LIBS ${WXWINDOWS_STATIC_DEBUG_LIBS}
- wxbase26d
- wxbase26d_net
- wxbase26d_odbc
- wxbase26d_xml
- wxmsw26d_adv
- wxmsw26d_core
- wxmsw26d_dbgrid
- wxmsw26d_gl
- wxmsw26d_html
- wxmsw26d_media
- wxmsw26d_qa
- wxmsw26d_xrc
- wxexpatd
- wxjpegd
- wxpngd
- wxregexd
- wxtiffd
- wxzlibd
- comctl32
- rpcrt4
- wsock32
- )
- ENDIF (WXWINDOWS_USE_MONOLITHIC)
-
-
- ##
- ## now we should have found all WX libs available on the system.
- ## let the user decide which of the available onse to use.
- ##
-
- ## if there is at least one shared lib available
- ## let user choose wether to use shared or static wxwindows libs
- IF(WXWINDOWS_SHARED_LIBRARY OR WXWINDOWS_SHARED_DEBUG_LIBRARY)
- ## default value OFF because wxWindows MSVS default build is static
- OPTION(WXWINDOWS_USE_SHARED_LIBS
- "Use shared versions (dll) of wxWindows libraries?" OFF)
- MARK_AS_ADVANCED(WXWINDOWS_USE_SHARED_LIBS)
- ENDIF(WXWINDOWS_SHARED_LIBRARY OR WXWINDOWS_SHARED_DEBUG_LIBRARY)
-
- ## add system libraries wxwindows always seems to depend on
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- comctl32
- rpcrt4
- wsock32
- )
-
- IF (NOT WXWINDOWS_USE_SHARED_LIBS)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ## these ones dont seem required, in particular ctl3d32 is not neccesary (Jan Woetzel 07/2003)
- # ctl3d32
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_ZLIB} optimized ${WXWINDOWS_STATIC_LIBRARY_ZLIB}
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_REGEX} optimized ${WXWINDOWS_STATIC_LIBRARY_REGEX}
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_PNG} optimized ${WXWINDOWS_STATIC_LIBRARY_PNG}
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_JPEG} optimized ${WXWINDOWS_STATIC_LIBRARY_JPEG}
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_TIFF} optimized ${WXWINDOWS_STATIC_LIBRARY_TIFF}
- )
- ENDIF (NOT WXWINDOWS_USE_SHARED_LIBS)
- ## opengl/glu: TODO/FIXME: better use FindOpenGL.cmake here
- ## assume release versions of glu an dopengl, here.
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- opengl32
- glu32 )
- ENDIF (WXWINDOWS_USE_GL)
-
- ##
- ## select between use of shared or static wxWindows lib then set libs to use
- ## for debug and optimized build. so the user can switch between debug and
- ## release build e.g. within MS Visual Studio without running cmake with a
- ## different build directory again.
- ##
- ## then add the build specific include dir for wx/setup.h
- ##
-
- IF(WXWINDOWS_USE_SHARED_LIBS)
- ##MESSAGE("DBG wxWindows use shared lib selected.")
- ## assume that both builds use the same setup(.h) for simplicity
-
- ## shared: both wx (debug and release) found?
- ## assume that both builds use the same setup(.h) for simplicity
- IF(WXWINDOWS_SHARED_DEBUG_LIBRARY AND WXWINDOWS_SHARED_LIBRARY)
- ##MESSAGE("DBG wx shared: debug and optimized found.")
- FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
- ${WXWINDOWS_ROOT_DIR}/lib/mswdlld
- ${WXWINDOWS_ROOT_DIR}/lib/mswdll
- ${WXWINDOWS_ROOT_DIR}/lib/vc_dll/mswd
- ${WXWINDOWS_ROOT_DIR}/lib/vc_dll/msw )
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- debug ${WXWINDOWS_SHARED_DEBUG_LIBRARY}
- optimized ${WXWINDOWS_SHARED_LIBRARY} )
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- debug ${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL}
- optimized ${WXWINDOWS_SHARED_LIBRARY_GL} )
- ENDIF (WXWINDOWS_USE_GL)
- ENDIF(WXWINDOWS_SHARED_DEBUG_LIBRARY AND WXWINDOWS_SHARED_LIBRARY)
-
- ## shared: only debug wx lib found?
- IF(WXWINDOWS_SHARED_DEBUG_LIBRARY)
- IF(NOT WXWINDOWS_SHARED_LIBRARY)
- ##MESSAGE("DBG wx shared: debug (but no optimized) found.")
- FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
- ${WXWINDOWS_ROOT_DIR}/lib/mswdlld
- ${WXWINDOWS_ROOT_DIR}/lib/vc_dll/mswd )
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_SHARED_DEBUG_LIBRARY} )
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL} )
- ENDIF (WXWINDOWS_USE_GL)
- ENDIF(NOT WXWINDOWS_SHARED_LIBRARY)
- ENDIF(WXWINDOWS_SHARED_DEBUG_LIBRARY)
-
- ## shared: only release wx lib found?
- IF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
- IF(WXWINDOWS_SHARED_LIBRARY)
- ##MESSAGE("DBG wx shared: optimized (but no debug) found.")
- FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
- ${WXWINDOWS_ROOT_DIR}/lib/mswdll
- ${WXWINDOWS_ROOT_DIR}/lib/vc_dll/msw )
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_SHARED_DEBUG_LIBRARY} )
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL} )
- ENDIF (WXWINDOWS_USE_GL)
- ENDIF(WXWINDOWS_SHARED_LIBRARY)
- ENDIF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
-
- ## shared: none found?
- IF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
- IF(NOT WXWINDOWS_SHARED_LIBRARY)
- MESSAGE(STATUS
- "No shared wxWindows lib found, but WXWINDOWS_USE_SHARED_LIBS=${WXWINDOWS_USE_SHARED_LIBS}.")
- ENDIF(NOT WXWINDOWS_SHARED_LIBRARY)
- ENDIF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
- #########################################################################################
- ELSE(WXWINDOWS_USE_SHARED_LIBS)
- ##jw: DEPRECATED IF(NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
-
- ## static: both wx (debug and release) found?
- ## assume that both builds use the same setup(.h) for simplicity
- IF(WXWINDOWS_STATIC_DEBUG_LIBRARY AND WXWINDOWS_STATIC_LIBRARY)
- ##MESSAGE("DBG wx static: debug and optimized found.")
- FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
- ${WXWINDOWS_ROOT_DIR}/lib/mswd
- ${WXWINDOWS_ROOT_DIR}/lib/msw
- ${WXWINDOWS_ROOT_DIR}/lib/vc_lib/mswd
- ${WXWINDOWS_ROOT_DIR}/lib/vc_lib/msw )
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY}
- optimized ${WXWINDOWS_STATIC_LIBRARY} )
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_GL}
- optimized ${WXWINDOWS_STATIC_LIBRARY_GL} )
- ENDIF (WXWINDOWS_USE_GL)
- ENDIF(WXWINDOWS_STATIC_DEBUG_LIBRARY AND WXWINDOWS_STATIC_LIBRARY)
-
- ## static: only debug wx lib found?
- IF(WXWINDOWS_STATIC_DEBUG_LIBRARY)
- IF(NOT WXWINDOWS_STATIC_LIBRARY)
- ##MESSAGE("DBG wx static: debug (but no optimized) found.")
- FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
- ${WXWINDOWS_ROOT_DIR}/lib/mswd
- ${WXWINDOWS_ROOT_DIR}/lib/vc_lib/mswd )
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_STATIC_DEBUG_LIBRARY} )
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_STATIC_DEBUG_LIBRARY_GL} )
- ENDIF (WXWINDOWS_USE_GL)
- ENDIF(NOT WXWINDOWS_STATIC_LIBRARY)
- ENDIF(WXWINDOWS_STATIC_DEBUG_LIBRARY)
-
- ## static: only release wx lib found?
- IF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY)
- IF(WXWINDOWS_STATIC_LIBRARY)
- ##MESSAGE("DBG wx static: optimized (but no debug) found.")
- FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
- ${WXWINDOWS_ROOT_DIR}/lib/msw
- ${WXWINDOWS_ROOT_DIR}/lib/vc_lib/msw )
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_STATIC_LIBRARY} )
- IF (WXWINDOWS_USE_GL)
- SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
- ${WXWINDOWS_STATIC_LIBRARY_GL} )
- ENDIF (WXWINDOWS_USE_GL)
- ENDIF(WXWINDOWS_STATIC_LIBRARY)
- ENDIF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY)
-
- ## static: none found?
- IF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY AND NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
- IF(NOT WXWINDOWS_STATIC_LIBRARY)
- MESSAGE(STATUS
- "No static wxWindows lib found, but WXWINDOWS_USE_SHARED_LIBS=${WXWINDOWS_USE_SHARED_LIBS}.")
- ENDIF(NOT WXWINDOWS_STATIC_LIBRARY)
- ENDIF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY AND NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
- ENDIF(WXWINDOWS_USE_SHARED_LIBS)
-
-
- ## not neccessary in wxWindows 2.4.1 and 2.6.2
- ## but it may fix a previous bug, see
- ## http://lists.wxwindows.org/cgi-bin/ezmlm-cgi?8:mss:37574:200305:mpdioeneabobmgjenoap
- OPTION(WXWINDOWS_SET_DEFINITIONS "Set additional defines for wxWindows" OFF)
- MARK_AS_ADVANCED(WXWINDOWS_SET_DEFINITIONS)
- IF (WXWINDOWS_SET_DEFINITIONS)
- SET(WXWINDOWS_DEFINITIONS "-DWINVER=0x400")
- ELSE (WXWINDOWS_SET_DEFINITIONS)
- # clear:
- SET(WXWINDOWS_DEFINITIONS "")
- ENDIF (WXWINDOWS_SET_DEFINITIONS)
-
-
-
- ## Find the include directories for wxwindows
- ## the first, build specific for wx/setup.h was determined before.
- ## add inc dir for general for "wx/wx.h"
- FIND_PATH(WXWINDOWS_INCLUDE_DIR wx/wx.h
- "${WXWINDOWS_ROOT_DIR}/include" )
- ## append the build specific include dir for wx/setup.h:
- IF (WXWINDOWS_INCLUDE_DIR_SETUPH)
- SET(WXWINDOWS_INCLUDE_DIR ${WXWINDOWS_INCLUDE_DIR} ${WXWINDOWS_INCLUDE_DIR_SETUPH} )
- ENDIF (WXWINDOWS_INCLUDE_DIR_SETUPH)
-
-
-
- MARK_AS_ADVANCED(
- WXWINDOWS_ROOT_DIR
- WXWINDOWS_INCLUDE_DIR
- WXWINDOWS_INCLUDE_DIR_SETUPH
- WXWINDOWS_STATIC_LIBRARY
- WXWINDOWS_STATIC_LIBRARY_GL
- WXWINDOWS_STATIC_DEBUG_LIBRARY
- WXWINDOWS_STATIC_DEBUG_LIBRARY_GL
- WXWINDOWS_STATIC_LIBRARY_ZLIB
- WXWINDOWS_STATIC_DEBUG_LIBRARY_ZLIB
- WXWINDOWS_STATIC_LIBRARY_REGEX
- WXWINDOWS_STATIC_DEBUG_LIBRARY_REGEX
- WXWINDOWS_STATIC_LIBRARY_PNG
- WXWINDOWS_STATIC_DEBUG_LIBRARY_PNG
- WXWINDOWS_STATIC_LIBRARY_JPEG
- WXWINDOWS_STATIC_DEBUG_LIBRARY_JPEG
- WXWINDOWS_STATIC_DEBUG_LIBRARY_TIFF
- WXWINDOWS_STATIC_LIBRARY_TIFF
- WXWINDOWS_SHARED_LIBRARY
- WXWINDOWS_SHARED_DEBUG_LIBRARY
- WXWINDOWS_SHARED_LIBRARY_GL
- WXWINDOWS_SHARED_DEBUG_LIBRARY_GL
- )
-
-
- ELSE(WIN32_STYLE_FIND)
- IF (UNIX_STYLE_FIND)
- ## ######################################################################
- ##
- ## UNIX/Linux specific:
- ##
- ## use backquoted wx-config to query and set flags and libs:
- ## 06/2003 Jan Woetzel
- ##
-
- OPTION(WXWINDOWS_USE_SHARED_LIBS "Use shared versions (.so) of wxWindows libraries" ON)
- MARK_AS_ADVANCED(WXWINDOWS_USE_SHARED_LIBS)
- # JW removed option and force the develper th SET it.
- # OPTION(WXWINDOWS_USE_GL "use wxWindows with GL support (use additional
- # --gl-libs for wx-config)?" OFF)
-
- # wx-config should be in your path anyhow, usually no need to set WXWIN or
- # search in ../wx or ../../wx
- FIND_PROGRAM(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE wx-config
- $ENV{WXWIN}
- $ENV{WXWIN}/bin
- ../wx/bin
- ../../wx/bin )
-
- # check wether wx-config was found:
- IF(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
- # use shared/static wx lib?
- # remember: always link shared to use systems GL etc. libs (no static
- # linking, just link *against* static .a libs)
- IF(WXWINDOWS_USE_SHARED_LIBS)
- SET(WX_CONFIG_ARGS_LIBS "--libs")
- ELSE(WXWINDOWS_USE_SHARED_LIBS)
- SET(WX_CONFIG_ARGS_LIBS "--static --libs")
- ENDIF(WXWINDOWS_USE_SHARED_LIBS)
-
- # do we need additionial wx GL stuff like GLCanvas ?
- IF(WXWINDOWS_USE_GL)
- SET(WX_CONFIG_ARGS_LIBS "${WX_CONFIG_ARGS_LIBS} --gl-libs" )
- ENDIF(WXWINDOWS_USE_GL)
- ##MESSAGE("DBG: WX_CONFIG_ARGS_LIBS=${WX_CONFIG_ARGS_LIBS}===")
-
- # set CXXFLAGS to be fed into CMAKE_CXX_FLAGS by the user:
- SET(CMAKE_WXWINDOWS_CXX_FLAGS "`${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE} --cxxflags|sed -e s/-I/-isystem/g`")
- ##MESSAGE("DBG: for compilation:
- ##CMAKE_WXWINDOWS_CXX_FLAGS=${CMAKE_WXWINDOWS_CXX_FLAGS}===")
- # keep the back-quoted string for clarity
- SET(WXWINDOWS_LIBRARIES "`${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE} ${WX_CONFIG_ARGS_LIBS}`")
- ##MESSAGE("DBG2: for linking:
- ##WXWINDOWS_LIBRARIES=${WXWINDOWS_LIBRARIES}===")
-
- # evaluate wx-config output to separate linker flags and linkdirs for
- # rpath:
- EXEC_PROGRAM(${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE}
- ARGS ${WX_CONFIG_ARGS_LIBS}
- OUTPUT_VARIABLE WX_CONFIG_LIBS )
-
- ## extract linkdirs (-L) for rpath
- ## use regular expression to match wildcard equivalent "-L*<endchar>"
- ## with <endchar> is a space or a semicolon
- STRING(REGEX MATCHALL "[-][L]([^ ;])+" WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX "${WX_CONFIG_LIBS}" )
- # MESSAGE("DBG WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX=${WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX}")
-
- ## remove prefix -L because we need the pure directory for LINK_DIRECTORIES
- ## replace -L by ; because the separator seems to be lost otherwise (bug or
- ## feature?)
- IF(WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX)
- STRING(REGEX REPLACE "[-][L]" ";" WXWINDOWS_LINK_DIRECTORIES ${WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX} )
- # MESSAGE("DBG WXWINDOWS_LINK_DIRECTORIES=${WXWINDOWS_LINK_DIRECTORIES}")
- ENDIF(WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX)
-
-
- ## replace space separated string by semicolon separated vector to make it
- ## work with LINK_DIRECTORIES
- SEPARATE_ARGUMENTS(WXWINDOWS_LINK_DIRECTORIES)
-
- MARK_AS_ADVANCED(
- CMAKE_WXWINDOWS_CXX_FLAGS
- WXWINDOWS_INCLUDE_DIR
- WXWINDOWS_LIBRARIES
- CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE
- )
-
-
- ## we really need wx-config...
- ELSE(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
- MESSAGE(STATUS "Cannot find wx-config anywhere on the system. Please put the file into your path or specify it in CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE.")
- MARK_AS_ADVANCED(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
- ENDIF(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
-
-
- ELSE(UNIX_STYLE_FIND)
- MESSAGE(STATUS "FindwxWindows.cmake: Platform unknown/unsupported by FindwxWindows.cmake. It's neither WIN32 nor UNIX")
- ENDIF(UNIX_STYLE_FIND)
- ENDIF(WIN32_STYLE_FIND)
- IF(WXWINDOWS_LIBRARIES)
- IF(WXWINDOWS_INCLUDE_DIR OR CMAKE_WXWINDOWS_CXX_FLAGS)
- ## found all we need.
- SET(WXWINDOWS_FOUND 1)
-
- ## set deprecated variables for backward compatibility:
- SET(CMAKE_WX_CAN_COMPILE ${WXWINDOWS_FOUND})
- SET(WXWINDOWS_LIBRARY ${WXWINDOWS_LIBRARIES})
- SET(WXWINDOWS_INCLUDE_PATH ${WXWINDOWS_INCLUDE_DIR})
- SET(WXWINDOWS_LINK_DIRECTORIES ${WXWINDOWS_LINK_DIRECTORIES})
- SET(CMAKE_WX_CXX_FLAGS ${CMAKE_WXWINDOWS_CXX_FLAGS})
-
- ENDIF(WXWINDOWS_INCLUDE_DIR OR CMAKE_WXWINDOWS_CXX_FLAGS)
- ENDIF(WXWINDOWS_LIBRARIES)
|