ENH: Applying patch from bug#3443 to implement FindwxWidgets.cmake properly. It also updates the UseWX test and WXDialog sources to use the new find script.
This commit is contained in:
parent
b377c8ac72
commit
3c9744f406
|
@ -1 +1,654 @@
|
||||||
INCLUDE(FindwxWindows)
|
# - Find a wxWidgets (a.k.a., wxWindows) installation.
|
||||||
|
# This module finds if wxWidgets is installed and selects a default
|
||||||
|
# configuration to use.
|
||||||
|
#
|
||||||
|
# The following variables are searched for and set to defaults in case
|
||||||
|
# of multiple choices. Change them if the defaults are not desired:
|
||||||
|
#
|
||||||
|
# wxWidgets_ROOT_DIR - Base wxWidgets directory
|
||||||
|
# (e.g., C:/wxWidgets-2.6.3).
|
||||||
|
# wxWidgets_LIB_DIR - Path to wxWidgets libraries
|
||||||
|
# (e.g., C:/wxWidgets-2.6.3/lib/vc_lib).
|
||||||
|
# wxWidgets_CONFIGURATION - Configuration to use
|
||||||
|
# (e.g., msw, mswd, mswu, mswunivud, etc.)
|
||||||
|
# wxWidgets_USE_LIBS - Libraries to use besides the common
|
||||||
|
# required ones; set to base and core by
|
||||||
|
# default. You couls also list them in
|
||||||
|
# FIND_PACKAGE(wxWidgets REQUIRED
|
||||||
|
# <components>)
|
||||||
|
#
|
||||||
|
# HAVE_ISYSTEM - if true wx warnings are suppressed on g++
|
||||||
|
# by replacing -I with -isystem
|
||||||
|
#
|
||||||
|
# The following are set after configuration is done:
|
||||||
|
#
|
||||||
|
# wxWidgets_FOUND - Set to TRUE if wxWidgets was found.
|
||||||
|
# wxWidgets_INCLUDE_DIRS - Include directories for WIN32
|
||||||
|
# i.e., where to find "wx/wx.h" and
|
||||||
|
# "wx/setup.h"; possibly empty for unices.
|
||||||
|
# wxWidgets_LIBRARIES - Path to the wxWidgets libraries.
|
||||||
|
# wxWidgets_LIBRARY_DIRS - compile time link dirs, useful for
|
||||||
|
# rpath on UNIX. Typically an empty string
|
||||||
|
# in WIN32 environment.
|
||||||
|
# wxWidgets_DEFINITIONS - Contains defines required to compile/link
|
||||||
|
# against WX, e.g. -DWXUSINGDLL
|
||||||
|
# wxWidgets_CXX_FLAGS - Include dirs and ompiler flags for
|
||||||
|
# unices, empty on WIN32. Esentially
|
||||||
|
# "`wx-config --cxxflags`".
|
||||||
|
# wxWidgets_USE_FILE - convenience include file
|
||||||
|
#
|
||||||
|
# Sample usage:
|
||||||
|
#
|
||||||
|
# SET(wxWidgets_USE_LIBS base core gl net)
|
||||||
|
# FIND_PACKAGE(wxWidgets)
|
||||||
|
# IF(wxWidgets_FOUND)
|
||||||
|
# INCLUDE(${wxWidgets_USE_FILE})
|
||||||
|
# # and for each of your dependant executable/library targets:
|
||||||
|
# TARGET_LINK_LIBRARIES(<YourTarget> ${wxWidgets_LIBRARIES})
|
||||||
|
# ENDIF(wxWidgets_FOUND)
|
||||||
|
#
|
||||||
|
# Sample usage with monolithic wx build:
|
||||||
|
# SET(wxWidgets_USE_LIBS msw26 expat jpeg gl png regex tiff zlib)
|
||||||
|
# ...
|
||||||
|
|
||||||
|
# NOTES
|
||||||
|
#
|
||||||
|
# This module has been tested on the WIN32 platform with wxWidgets
|
||||||
|
# 2.6.2, 2.6.3, and 2.5.3. However, it has been designed to
|
||||||
|
# easily extend support to all possible builds, e.g., static/shared,
|
||||||
|
# debug/release, unicode, universal, multilib/monolithic, etc..
|
||||||
|
#
|
||||||
|
# If you want to use the module and your build type is not supported
|
||||||
|
# out-of-the-box, please contact me to exchange information on how
|
||||||
|
# your system is setup and I'll try to add support for it.
|
||||||
|
#
|
||||||
|
# AUTHOR
|
||||||
|
#
|
||||||
|
# Miguel A. Figueroa-Villanueva (miguelf at ieee dot org).
|
||||||
|
# Jan Woetzel (jw at mip.informatik.uni-kiel.de).
|
||||||
|
#
|
||||||
|
# Based on previous works of:
|
||||||
|
# Jan Woetzel (FindwxWindows.cmake),
|
||||||
|
# Jorgen Bodde and Jerry Fath (FindwxWin.cmake).
|
||||||
|
|
||||||
|
#
|
||||||
|
# TODO/ideas
|
||||||
|
#
|
||||||
|
# (1) Option/Setting to use all available wx libs
|
||||||
|
# In contrast to expert developer who lists the
|
||||||
|
# minimal set of required libs in wxWidgets_USE_LIBS
|
||||||
|
# there is the newbie user:
|
||||||
|
# - who just wants to link against WX with more 'magic'
|
||||||
|
# - doesn't know the internal structure of WX or how it was built,
|
||||||
|
# in particular if it is monolithic or not
|
||||||
|
# - want to link against all available WX libs
|
||||||
|
# Basically, the intent here is to mimic what wx-config would do by
|
||||||
|
# default (i.e., `wx-config --libs`).
|
||||||
|
#
|
||||||
|
# Possible solution:
|
||||||
|
# Add a reserved keyword "std" that initializes to what wx-config
|
||||||
|
# would default to. If the user has not set the wxWidgets_USE_LIBS,
|
||||||
|
# default to "std" instead of "base core" as it is now. To implement
|
||||||
|
# "std" will basically boil down to a FOR_EACH lib-FOUND, but maybe
|
||||||
|
# checking whether a minimal set was found.
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Helper macro to control the debugging output globally.
|
||||||
|
# - NOTE: This and all the DBG_MSG calls should be removed after the
|
||||||
|
# module stabilizes.
|
||||||
|
#
|
||||||
|
MACRO(DBG_MSG _MSG)
|
||||||
|
# MESSAGE(STATUS "${CMAKE_CURRENT_LIST_FILE}(${CMAKE_CURRENT_LIST_LINE}): ${_MSG}")
|
||||||
|
ENDMACRO(DBG_MSG)
|
||||||
|
|
||||||
|
# for compatibility with CMake 2.4.2
|
||||||
|
# emulate wxWidgets_FIND_COMPONENTS
|
||||||
|
IF (NOT wxWidgets_FIND_COMPONENTS)
|
||||||
|
SET(wxWidgets_FIND_COMPONENTS "")
|
||||||
|
FOREACH(COMPONENT
|
||||||
|
base
|
||||||
|
core
|
||||||
|
adv
|
||||||
|
dbgrid
|
||||||
|
expat
|
||||||
|
gl
|
||||||
|
jpeg
|
||||||
|
html
|
||||||
|
media
|
||||||
|
msw msw26 msw27 msw28
|
||||||
|
mono
|
||||||
|
net
|
||||||
|
odbc
|
||||||
|
png
|
||||||
|
qa
|
||||||
|
regex
|
||||||
|
tiff
|
||||||
|
# std # no true lib/component - list for compatibility with _USE_LIBS ?
|
||||||
|
xml
|
||||||
|
xrc
|
||||||
|
zlib
|
||||||
|
)
|
||||||
|
IF (${wxWidgets_FIND_REQUIRED_${COMPONENT}})
|
||||||
|
SET(wxWidgets_FIND_COMPONENTS ${wxWidgets_FIND_COMPONENTS} ${COMPONENT})
|
||||||
|
ENDIF(${wxWidgets_FIND_REQUIRED_${COMPONENT}})
|
||||||
|
ENDFOREACH(COMPONENT)
|
||||||
|
ENDIF (NOT wxWidgets_FIND_COMPONENTS)
|
||||||
|
|
||||||
|
DBG_MSG("wxWidgets_FIND_COMPONENTS=${wxWidgets_FIND_COMPONENTS}")
|
||||||
|
|
||||||
|
#
|
||||||
|
# Clear return values in case the module is loaded more than once.
|
||||||
|
#
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
#
|
||||||
|
SET(wxWidgets_INCLUDE_DIRS "")
|
||||||
|
SET(wxWidgets_LIBRARIES "")
|
||||||
|
SET(wxWidgets_LIBRARY_DIRS "")
|
||||||
|
SET(wxWidgets_CXX_FLAGS "")
|
||||||
|
|
||||||
|
#=====================================================================
|
||||||
|
#=====================================================================
|
||||||
|
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)
|
||||||
|
|
||||||
|
# global settings for std and common wx libs
|
||||||
|
# logic could determine _USE_MONOLITHIC automatically
|
||||||
|
# but let the user decide for now.
|
||||||
|
IF (wxWidgets_USE_MONOLITHIC)
|
||||||
|
SET(wxWidgets_STD_LIBRARIES mono )
|
||||||
|
ELSE (wxWidgets_USE_MONOLITHIC)
|
||||||
|
SET(wxWidgets_STD_LIBRARIES base core ) # this is default
|
||||||
|
ENDIF(wxWidgets_USE_MONOLITHIC)
|
||||||
|
|
||||||
|
#useful common wx libs needed by almost all components
|
||||||
|
SET(wxWidgets_COMMON_LIBRARIES png tiff jpeg zlib regex expat)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# WIN32: Helper MACROS
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Get filename components for a configuration. For example,
|
||||||
|
# if _CONFIGURATION = mswunivud, then _UNV=univ, _UCD=u _DBG=d
|
||||||
|
# if _CONFIGURATION = mswu, then _UNV="", _UCD=u _DBG=""
|
||||||
|
#
|
||||||
|
MACRO(WX_GET_NAME_COMPONENTS _CONFIGURATION _UNV _UCD _DBG)
|
||||||
|
STRING(REGEX MATCH "univ" ${_UNV} "${_CONFIGURATION}")
|
||||||
|
STRING(REGEX REPLACE "msw.*(u)[d]*$" "u" ${_UCD} "${_CONFIGURATION}")
|
||||||
|
IF(${_UCD} STREQUAL ${_CONFIGURATION})
|
||||||
|
SET(${_UCD} "")
|
||||||
|
ENDIF(${_UCD} STREQUAL ${_CONFIGURATION})
|
||||||
|
STRING(REGEX MATCH "d$" ${_DBG} "${_CONFIGURATION}")
|
||||||
|
ENDMACRO(WX_GET_NAME_COMPONENTS)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Find libraries associated to a configuration.
|
||||||
|
#
|
||||||
|
MACRO(WX_FIND_LIBS _UNV _UCD _DBG)
|
||||||
|
DBG_MSG("m_unv = ${_UNV}")
|
||||||
|
DBG_MSG("m_ucd = ${_UCD}")
|
||||||
|
DBG_MSG("m_dbg = ${_DBG}")
|
||||||
|
|
||||||
|
# Find wxWidgets common libraries
|
||||||
|
FOREACH(LIB png tiff jpeg zlib regex expat)
|
||||||
|
FIND_LIBRARY(WX_${LIB}${_DBG}
|
||||||
|
NAMES
|
||||||
|
wx${LIB}${_UCD}${_DBG} # for regex
|
||||||
|
wx${LIB}${_DBG}
|
||||||
|
PATHS ${WX_LIB_DIR}
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
MARK_AS_ADVANCED(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
|
||||||
|
# Find wxWidgets multilib base libraries
|
||||||
|
FIND_LIBRARY(WX_base${_DBG}
|
||||||
|
NAMES
|
||||||
|
wxbase26${_UCD}${_DBG}
|
||||||
|
wxbase25${_UCD}${_DBG}
|
||||||
|
PATHS ${WX_LIB_DIR}
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
MARK_AS_ADVANCED(WX_base${_DBG})
|
||||||
|
FOREACH(LIB net odbc xml)
|
||||||
|
FIND_LIBRARY(WX_${LIB}${_DBG}
|
||||||
|
NAMES
|
||||||
|
wxbase26${_UCD}${_DBG}_${LIB}
|
||||||
|
wxbase25${_UCD}${_DBG}_${LIB}
|
||||||
|
PATHS ${WX_LIB_DIR}
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
MARK_AS_ADVANCED(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
|
||||||
|
# Find wxWidgets monolithic library
|
||||||
|
FIND_LIBRARY(WX_mono${_DBG}
|
||||||
|
NAMES
|
||||||
|
wxmsw${_UNV}26${_UCD}${_DBG}
|
||||||
|
wxmsw${_UNV}25${_UCD}${_DBG}
|
||||||
|
PATHS ${WX_LIB_DIR}
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
MARK_AS_ADVANCED(WX_mono${_DBG})
|
||||||
|
|
||||||
|
# Find wxWidgets multilib libraries
|
||||||
|
FOREACH(LIB core adv html media xrc dbgrid gl qa)
|
||||||
|
FIND_LIBRARY(WX_${LIB}${_DBG}
|
||||||
|
NAMES
|
||||||
|
wxmsw${_UNV}26${_UCD}${_DBG}_${LIB}
|
||||||
|
wxmsw${_UNV}25${_UCD}${_DBG}_${LIB}
|
||||||
|
PATHS ${WX_LIB_DIR}
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
MARK_AS_ADVANCED(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
ENDMACRO(WX_FIND_LIBS)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Clear all library paths, so that FIND_LIBRARY refinds them.
|
||||||
|
#
|
||||||
|
# Clear a lib, reset its found flag, and mark as advanced.
|
||||||
|
MACRO(WX_CLEAR_LIB _LIB)
|
||||||
|
SET(${_LIB} "${_LIB}-NOTFOUND" CACHE FILEPATH "Cleared." FORCE)
|
||||||
|
SET(${_LIB}_FOUND FALSE)
|
||||||
|
MARK_AS_ADVANCED(${_LIB})
|
||||||
|
ENDMACRO(WX_CLEAR_LIB)
|
||||||
|
# Clear all debug or release library paths (arguments are "d" or "").
|
||||||
|
MACRO(WX_CLEAR_ALL_LIBS _DBG)
|
||||||
|
# Clear wxWidgets common libraries
|
||||||
|
FOREACH(LIB png tiff jpeg zlib regex expat)
|
||||||
|
WX_CLEAR_LIB(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
|
||||||
|
# Clear wxWidgets multilib base libraries
|
||||||
|
WX_CLEAR_LIB(WX_base${_DBG})
|
||||||
|
FOREACH(LIB net odbc xml)
|
||||||
|
WX_CLEAR_LIB(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
|
||||||
|
# Clear wxWidgets monolithic library
|
||||||
|
WX_CLEAR_LIB(WX_mono${_DBG})
|
||||||
|
|
||||||
|
# Clear wxWidgets multilib libraries
|
||||||
|
FOREACH(LIB core adv html media xrc dbgrid gl qa)
|
||||||
|
WX_CLEAR_LIB(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
ENDMACRO(WX_CLEAR_ALL_LIBS)
|
||||||
|
# Clear all wxWidgets debug libraries.
|
||||||
|
MACRO(WX_CLEAR_ALL_DBG_LIBS)
|
||||||
|
WX_CLEAR_ALL_LIBS("d")
|
||||||
|
ENDMACRO(WX_CLEAR_ALL_DBG_LIBS)
|
||||||
|
# Clear all wxWidgets release libraries.
|
||||||
|
MACRO(WX_CLEAR_ALL_REL_LIBS)
|
||||||
|
WX_CLEAR_ALL_LIBS("")
|
||||||
|
ENDMACRO(WX_CLEAR_ALL_REL_LIBS)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Set the wxWidgets_LIBRARIES variable.
|
||||||
|
# Also, Sets output variable wxWidgets_FOUND to FALSE if it fails.
|
||||||
|
#
|
||||||
|
MACRO(WX_SET_LIBRARIES _LIBS _DBG)
|
||||||
|
IF(WX_USE_REL_AND_DBG)
|
||||||
|
DBG_MSG("looking for ${${_LIBS}}")
|
||||||
|
FOREACH(LIB ${${_LIBS}})
|
||||||
|
DBG_MSG("Finding ${LIB} and ${LIB}d")
|
||||||
|
DBG_MSG("WX_${LIB} : ${WX_${LIB}}")
|
||||||
|
DBG_MSG("WX_${LIB}d : ${WX_${LIB}d}")
|
||||||
|
IF(WX_${LIB} AND WX_${LIB}d)
|
||||||
|
DBG_MSG("Found ${LIB} and ${LIB}d")
|
||||||
|
SET(wxWidgets_LIBRARIES ${wxWidgets_LIBRARIES}
|
||||||
|
debug ${WX_${LIB}d}
|
||||||
|
optimized ${WX_${LIB}}
|
||||||
|
)
|
||||||
|
ELSE(WX_${LIB} AND WX_${LIB}d)
|
||||||
|
DBG_MSG("- not found due to missing WX_${LIB}=${WX_${LIB}} or WX_${LIB}d=${WX_${LIB}d}")
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
ENDIF(WX_${LIB} AND WX_${LIB}d)
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
ELSE(WX_USE_REL_AND_DBG)
|
||||||
|
FOREACH(LIB ${${_LIBS}})
|
||||||
|
DBG_MSG("Finding ${LIB}${_DBG}")
|
||||||
|
DBG_MSG("WX_${LIB}${_DBG} : ${WX_${LIB}${_DBG}}")
|
||||||
|
IF(WX_${LIB}${_DBG})
|
||||||
|
DBG_MSG("Found ${LIB}${_DBG}")
|
||||||
|
SET(wxWidgets_LIBRARIES ${wxWidgets_LIBRARIES}
|
||||||
|
${WX_${LIB}${_DBG}}
|
||||||
|
)
|
||||||
|
ELSE(WX_${LIB}${_DBG})
|
||||||
|
DBG_MSG("- not found due to missing WX_${LIB}${_DBG}=${WX_${LIB}${_DBG}}")
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
ENDIF(WX_${LIB}${_DBG})
|
||||||
|
ENDFOREACH(LIB)
|
||||||
|
ENDIF(WX_USE_REL_AND_DBG)
|
||||||
|
|
||||||
|
FOREACH(LIB ${${_LIBS}})
|
||||||
|
DBG_MSG("required: ${LIB}")
|
||||||
|
IF(LIB STREQUAL "gl")
|
||||||
|
DBG_MSG("gl required: ${LIB}")
|
||||||
|
SET(wxWidgets_LIBRARIES ${wxWidgets_LIBRARIES}
|
||||||
|
opengl32
|
||||||
|
glu32
|
||||||
|
)
|
||||||
|
ENDIF(LIB STREQUAL "gl")
|
||||||
|
ENDFOREACH(LIB ${${_LIBS}})
|
||||||
|
|
||||||
|
SET(wxWidgets_LIBRARIES ${wxWidgets_LIBRARIES}
|
||||||
|
winmm
|
||||||
|
comctl32
|
||||||
|
rpcrt4
|
||||||
|
wsock32
|
||||||
|
)
|
||||||
|
ENDMACRO(WX_SET_LIBRARIES)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# WIN32: Start actual work.
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Look for an installation tree.
|
||||||
|
#
|
||||||
|
FIND_PATH(wxWidgets_ROOT_DIR include/wx/wx.h
|
||||||
|
$ENV{WXWIN}
|
||||||
|
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\wxWidgets_is1;Inno Setup: App Path]" ## WX 2.6.x
|
||||||
|
C:/wxWidgets-2.6.3
|
||||||
|
D:/wxWidgets-2.6.3
|
||||||
|
C:/wxWidgets-2.6.2
|
||||||
|
D:/wxWidgets-2.6.2
|
||||||
|
C:/wxWidgets-2.6.1
|
||||||
|
D:/wxWidgets-2.6.1
|
||||||
|
C:/wxWidgets-2.6.0
|
||||||
|
D:/wxWidgets-2.6.0
|
||||||
|
C:/wxWidgets-2.5.5
|
||||||
|
D:/wxWidgets-2.5.5
|
||||||
|
C:/wxWidgets-2.5.4
|
||||||
|
D:/wxWidgets-2.5.4
|
||||||
|
C:/wxWidgets-2.5.3
|
||||||
|
D:/wxWidgets-2.5.3
|
||||||
|
C:/wxWidgets-2.5.2
|
||||||
|
D:/wxWidgets-2.5.2
|
||||||
|
C:/wxWidgets-2.5.1
|
||||||
|
D:/wxWidgets-2.5.1
|
||||||
|
DOC "wxWidgets base/installation directory?"
|
||||||
|
)
|
||||||
|
|
||||||
|
# If wxWidgets_ROOT_DIR changed, clear all libraries and lib dir.
|
||||||
|
IF(NOT WX_ROOT_DIR STREQUAL wxWidgets_ROOT_DIR)
|
||||||
|
SET(WX_ROOT_DIR ${wxWidgets_ROOT_DIR} CACHE INTERNAL "wxWidgets_ROOT_DIR")
|
||||||
|
# WX_CLEAR_ALL_DBG_LIBS()
|
||||||
|
# WX_CLEAR_ALL_REL_LIBS()
|
||||||
|
SET(wxWidgets_LIB_DIR "wxWidgets_LIB_DIR-NOTFOUND" CACHE PATH "Cleared." FORCE)
|
||||||
|
ENDIF(NOT WX_ROOT_DIR STREQUAL wxWidgets_ROOT_DIR)
|
||||||
|
|
||||||
|
IF(WX_ROOT_DIR)
|
||||||
|
|
||||||
|
# select one default tree inside the already determined wx tree
|
||||||
|
# prefer static/shared order usually consistent with build settings
|
||||||
|
IF(BUILD_SHARED_LIBS)
|
||||||
|
FIND_PATH(wxWidgets_LIB_DIR
|
||||||
|
NAMES wxpng.lib wxpngd.lib
|
||||||
|
PATHS
|
||||||
|
${WX_ROOT_DIR}/lib/vc_dll # prefer shared
|
||||||
|
${WX_ROOT_DIR}/lib/vc_lib
|
||||||
|
DOC "Path to wxWidgets libraries?"
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
ELSE(BUILD_SHARED_LIBS)
|
||||||
|
FIND_PATH(wxWidgets_LIB_DIR
|
||||||
|
NAMES wxpng.lib wxpngd.lib
|
||||||
|
PATHS
|
||||||
|
${WX_ROOT_DIR}/lib/vc_lib # prefer static
|
||||||
|
${WX_ROOT_DIR}/lib/vc_dll
|
||||||
|
DOC "Path to wxWidgets libraries?"
|
||||||
|
NO_DEFAULT_PATH
|
||||||
|
)
|
||||||
|
ENDIF(BUILD_SHARED_LIBS)
|
||||||
|
|
||||||
|
# If wxWidgets_LIB_DIR changed, clear all libraries.
|
||||||
|
IF(NOT WX_LIB_DIR STREQUAL wxWidgets_LIB_DIR)
|
||||||
|
SET(WX_LIB_DIR ${wxWidgets_LIB_DIR} CACHE INTERNAL "wxWidgets_LIB_DIR")
|
||||||
|
WX_CLEAR_ALL_DBG_LIBS()
|
||||||
|
WX_CLEAR_ALL_REL_LIBS()
|
||||||
|
ENDIF(NOT WX_LIB_DIR STREQUAL wxWidgets_LIB_DIR)
|
||||||
|
|
||||||
|
IF(WX_LIB_DIR)
|
||||||
|
SET(wxWidgets_FOUND TRUE)
|
||||||
|
|
||||||
|
IF(WX_LIB_DIR MATCHES ".*[dD][lL][lL].*")
|
||||||
|
DBG_MSG("detected SHARED/DLL tree WX_LIB_DIR=${WX_LIB_DIR}")
|
||||||
|
# add define for correct dllimport to link against WX DLL
|
||||||
|
SET(wxWidgets_DEFINITIONS "-DWXUSINGDLL")
|
||||||
|
ENDIF(WX_LIB_DIR MATCHES ".*[dD][lL][lL].*")
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# WIN32: ???
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
# Search for possible configuration type availabilities
|
||||||
|
# ***** SET(WX_LAST_CFG "")
|
||||||
|
FOREACH(CFG mswunivud mswunivd mswud mswd mswunivu mswuniv mswu msw)
|
||||||
|
SET(WX_${CFG}_FOUND FALSE)
|
||||||
|
IF(EXISTS ${WX_LIB_DIR}/${CFG})
|
||||||
|
SET(WX_CONFIGURATION_LIST ${WX_CONFIGURATION_LIST} ${CFG})
|
||||||
|
SET(WX_${CFG}_FOUND TRUE)
|
||||||
|
SET(WX_CONFIGURATION ${CFG})
|
||||||
|
ENDIF(EXISTS ${WX_LIB_DIR}/${CFG})
|
||||||
|
ENDFOREACH(CFG)
|
||||||
|
|
||||||
|
# ***** SET(WX_USE_REL_AND_DBG FALSE)
|
||||||
|
IF(WX_CONFIGURATION)
|
||||||
|
# if selected configuration wasn't found, force the default one
|
||||||
|
# else, use it but still force a refresh for the list in doc string
|
||||||
|
IF(NOT WX_${wxWidgets_CONFIGURATION}_FOUND)
|
||||||
|
SET(wxWidgets_CONFIGURATION ${WX_CONFIGURATION} CACHE STRING
|
||||||
|
"Set wxWidgets configuration (${WX_CONFIGURATION_LIST})" FORCE)
|
||||||
|
ELSE(NOT WX_${wxWidgets_CONFIGURATION}_FOUND)
|
||||||
|
SET(wxWidgets_CONFIGURATION ${wxWidgets_CONFIGURATION} CACHE STRING
|
||||||
|
"Set wxWidgets configuration (${WX_CONFIGURATION_LIST})" FORCE)
|
||||||
|
ENDIF(NOT WX_${wxWidgets_CONFIGURATION}_FOUND)
|
||||||
|
|
||||||
|
# if release config was selected, and both release/debug exist
|
||||||
|
IF(WX_${wxWidgets_CONFIGURATION}d_FOUND)
|
||||||
|
OPTION(wxWidgets_USE_REL_AND_DBG
|
||||||
|
"Use release and debug configurations?" TRUE)
|
||||||
|
SET(WX_USE_REL_AND_DBG ${wxWidgets_USE_REL_AND_DBG})
|
||||||
|
ELSE(WX_${wxWidgets_CONFIGURATION}d_FOUND)
|
||||||
|
# if the option exists, force it to false
|
||||||
|
IF(wxWidgets_USE_REL_AND_DBG)
|
||||||
|
SET(wxWidgets_USE_REL_AND_DBG FALSE CACHE BOOL
|
||||||
|
"No ${wxWidgets_CONFIGURATION}d found." FORCE)
|
||||||
|
ENDIF(wxWidgets_USE_REL_AND_DBG)
|
||||||
|
SET(WX_USE_REL_AND_DBG FALSE)
|
||||||
|
ENDIF(WX_${wxWidgets_CONFIGURATION}d_FOUND)
|
||||||
|
|
||||||
|
# Get configuration parameters from the name.
|
||||||
|
WX_GET_NAME_COMPONENTS(${wxWidgets_CONFIGURATION} UNV UCD DBG)
|
||||||
|
|
||||||
|
# Set wxWidgets main include directory.
|
||||||
|
IF(EXISTS ${WX_ROOT_DIR}/include/wx/wx.h)
|
||||||
|
SET(wxWidgets_INCLUDE_DIRS ${WX_ROOT_DIR}/include)
|
||||||
|
ELSE(EXISTS ${WX_ROOT_DIR}/include/wx/wx.h)
|
||||||
|
DBG_MSG("WXWIDGET_FOUND FALSE because WX_ROOT_DIR=${WX_ROOT_DIR} has no ${WX_ROOT_DIR}/include/wx/wx.h")
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
ENDIF(EXISTS ${WX_ROOT_DIR}/include/wx/wx.h)
|
||||||
|
|
||||||
|
# Set wxWidgets lib setup include directory.
|
||||||
|
IF(EXISTS ${WX_LIB_DIR}/${wxWidgets_CONFIGURATION}/wx/setup.h)
|
||||||
|
SET(wxWidgets_INCLUDE_DIRS ${wxWidgets_INCLUDE_DIRS}
|
||||||
|
${WX_LIB_DIR}/${wxWidgets_CONFIGURATION})
|
||||||
|
ELSE(EXISTS ${WX_LIB_DIR}/${wxWidgets_CONFIGURATION}/wx/setup.h)
|
||||||
|
DBG_MSG("WXWIDGET_FOUND FALSE because ${WX_LIB_DIR}/${wxWidgets_CONFIGURATION}/wx/setup.h does not exists.")
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
ENDIF(EXISTS ${WX_LIB_DIR}/${wxWidgets_CONFIGURATION}/wx/setup.h)
|
||||||
|
#FIND_PATH(WX_SETUP_INCLUDE_DIR wx/setup.h
|
||||||
|
# ${WX_LIB_DIR}/${wxWidgets_CONFIGURATION})
|
||||||
|
#MARK_AS_ADVANCED(WX_SETUP_INCLUDE_DIR)
|
||||||
|
|
||||||
|
# Find wxWidgets libraries.
|
||||||
|
WX_FIND_LIBS("${UNV}" "${UCD}" "${DBG}")
|
||||||
|
IF(WX_USE_REL_AND_DBG)
|
||||||
|
WX_FIND_LIBS("${UNV}" "${UCD}" "d")
|
||||||
|
ENDIF(WX_USE_REL_AND_DBG)
|
||||||
|
|
||||||
|
# we support adding components by _USE_LIBS or REQUIRED _COMPONENTS
|
||||||
|
IF (wxWidgets_FIND_COMPONENTS)
|
||||||
|
LIST(APPEND wxWidgets_USE_LIBS ${wxWidgets_FIND_COMPONENTS})
|
||||||
|
ENDIF(wxWidgets_FIND_COMPONENTS)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Libraries we are interested in.
|
||||||
|
IF(NOT wxWidgets_USE_LIBS)
|
||||||
|
# Default minimal use setting (i.e., link to only core,base).
|
||||||
|
SET(wxWidgets_USE_LIBS ${wxWidgets_STD_LIBRARIES} )
|
||||||
|
ENDIF(NOT wxWidgets_USE_LIBS)
|
||||||
|
|
||||||
|
IF (wxWidgets_USE_LIBS MATCHES std)
|
||||||
|
# replace std by the list of STD libs
|
||||||
|
LIST(APPEND wxWidgets_USE_LIBS ${wxWidgets_STD_LIBRARIES} )
|
||||||
|
LIST(REMOVE_ITEM wxWidgets_USE_LIBS std)
|
||||||
|
# TODO: check that "mono" and base,core aren't added together
|
||||||
|
ENDIF (wxWidgets_USE_LIBS MATCHES std)
|
||||||
|
|
||||||
|
# Always add the common required libs.
|
||||||
|
LIST(APPEND wxWidgets_USE_LIBS ${wxWidgets_COMMON_LIBRARIES} )
|
||||||
|
|
||||||
|
# Settings for requested libs (i.e., include dir, libraries, etc.).
|
||||||
|
WX_SET_LIBRARIES(wxWidgets_USE_LIBS "${DBG}")
|
||||||
|
|
||||||
|
ENDIF(WX_CONFIGURATION)
|
||||||
|
ENDIF(WX_LIB_DIR)
|
||||||
|
ENDIF(WX_ROOT_DIR)
|
||||||
|
|
||||||
|
|
||||||
|
#=====================================================================
|
||||||
|
#=====================================================================
|
||||||
|
ELSE(WIN32_STYLE_FIND)
|
||||||
|
IF(UNIX_STYLE_FIND)
|
||||||
|
|
||||||
|
FIND_PROGRAM(wxWidgets_CONFIG_EXECUTABLE wx-config)
|
||||||
|
IF(wxWidgets_CONFIG_EXECUTABLE)
|
||||||
|
SET(wxWidgets_FOUND TRUE)
|
||||||
|
|
||||||
|
# run the wx-config program to get cxxflags
|
||||||
|
EXEC_PROGRAM(${wxWidgets_CONFIG_EXECUTABLE}
|
||||||
|
ARGS "--cxxflags"
|
||||||
|
OUTPUT_VARIABLE wxWidgets_CXX_FLAGS
|
||||||
|
RETURN_VALUE RET)
|
||||||
|
IF(RET EQUAL 0)
|
||||||
|
# parse definitions from cxxflags
|
||||||
|
STRING(REGEX MATCHALL "-D.*[^ ;]+" wxWidgets_DEFINITIONS ${wxWidgets_CXX_FLAGS})
|
||||||
|
DBG_MSG("\nwxWidgets_DEFINITIONS=${wxWidgets_DEFINITIONS}")
|
||||||
|
# drop -D* from CXXFLAGS
|
||||||
|
STRING(REGEX REPLACE "-D[^ ;]*" "" wxWidgets_CXX_FLAGS ${wxWidgets_CXX_FLAGS})
|
||||||
|
|
||||||
|
# parse incdirs from cxxflags, drop -I prefix
|
||||||
|
STRING(REGEX MATCHALL "-I.*[^ ;]+" wxWidgets_INCLUDE_DIRS ${wxWidgets_CXX_FLAGS})
|
||||||
|
STRING(REGEX REPLACE "-I" "" wxWidgets_INCLUDE_DIRS "${wxWidgets_INCLUDE_DIRS}")
|
||||||
|
# convert space to semicolons for list
|
||||||
|
STRING(REGEX REPLACE " " ";" wxWidgets_INCLUDE_DIRS "${wxWidgets_INCLUDE_DIRS}")
|
||||||
|
|
||||||
|
# drop -I* from CXXFLAGS - postponed until -isystem is available to INCLUDE_DIRECTORIES to avoid pedantic warnings
|
||||||
|
#STRING(REGEX REPLACE "-I[^ ;]*" "" wxWidgets_CXX_FLAGS ${wxWidgets_CXX_FLAGS})
|
||||||
|
|
||||||
|
IF (HAVE_ISYSTEM) # does the compiler support -isystem ?
|
||||||
|
IF (NOT APPLE) # -isystem seem unsuppored on Mac
|
||||||
|
IF(CMAKE_COMPILER_IS_GNUCC AND CMAKE_COMPILER_IS_GNUCXX )
|
||||||
|
IF (CMAKE_CXX_COMPILER MATCHES g\\+\\+) # just to be sure
|
||||||
|
# handle WX include dirs as system directories - ignores pedantic warnings with gcc
|
||||||
|
# replace -I by -isystem
|
||||||
|
STRING(REGEX REPLACE "-I" "-isystem" wxWidgets_CXX_FLAGS ${wxWidgets_CXX_FLAGS})
|
||||||
|
ENDIF(CMAKE_CXX_COMPILER MATCHES g\\+\\+)
|
||||||
|
ENDIF(CMAKE_COMPILER_IS_GNUCC AND CMAKE_COMPILER_IS_GNUCXX )
|
||||||
|
ENDIF(NOT APPLE)
|
||||||
|
ENDIF(HAVE_ISYSTEM)
|
||||||
|
|
||||||
|
ELSE(RET EQUAL 0)
|
||||||
|
DBG_MSG("${wxWidgets_CONFIG_EXECUTABLE} --cxxflags FAILED with RET=${RET}")
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
ENDIF(RET EQUAL 0)
|
||||||
|
|
||||||
|
|
||||||
|
# run the wx-config program to get the libs
|
||||||
|
# - NOTE: wx-config doesn't verify that the libs requested exist
|
||||||
|
# it just produces the names. Maybe a TRY_COMPILE would
|
||||||
|
# be useful here...
|
||||||
|
#STRING(REPLACE ";" "," wxWidgets_USE_LIBS "${wxWidgets_USE_LIBS}")
|
||||||
|
STRING(REGEX REPLACE ";" "," wxWidgets_USE_LIBS "${wxWidgets_USE_LIBS}")
|
||||||
|
EXEC_PROGRAM(${wxWidgets_CONFIG_EXECUTABLE}
|
||||||
|
ARGS "--libs ${wxWidgets_USE_LIBS}"
|
||||||
|
OUTPUT_VARIABLE wxWidgets_LIBRARIES
|
||||||
|
RETURN_VALUE RET)
|
||||||
|
IF(RET EQUAL 0)
|
||||||
|
STRING(REGEX REPLACE " " ";" wxWidgets_LIBRARIES "${wxWidgets_LIBRARIES}")
|
||||||
|
STRING(REGEX REPLACE "-framework;" "-framework "
|
||||||
|
wxWidgets_LIBRARIES
|
||||||
|
"${wxWidgets_LIBRARIES}")
|
||||||
|
|
||||||
|
# extract linkdirs (-L) for rpath (i.e., LINK_DIRECTORIES)
|
||||||
|
STRING(REGEX MATCHALL "-L[^ ;]+"
|
||||||
|
wxWidgets_LIBRARY_DIRS
|
||||||
|
"${wxWidgets_LIBRARIES}")
|
||||||
|
STRING(REGEX REPLACE "-L" ""
|
||||||
|
wxWidgets_LIBRARY_DIRS "${wxWidgets_LIBRARY_DIRS}")
|
||||||
|
|
||||||
|
# convert space to semicolons for list
|
||||||
|
STRING(REGEX REPLACE " " ";" wxWidgets_LIBRARY_DIRS "${wxWidgets_LIBRARY_DIRS}")
|
||||||
|
ELSE(RET EQUAL 0)
|
||||||
|
SET(wxWidgets_FOUND FALSE)
|
||||||
|
ENDIF(RET EQUAL 0)
|
||||||
|
ENDIF(wxWidgets_CONFIG_EXECUTABLE)
|
||||||
|
|
||||||
|
ELSE(UNIX_STYLE_FIND)
|
||||||
|
IF(NOT wxWidgets_FIND_QUIETLY)
|
||||||
|
MESSAGE(STATUS "${CMAKE_CURRENT_LIST_FILE}(${CMAKE_CURRENT_LIST_LINE}): \n"
|
||||||
|
" Platform unknown/unsupported. It's neither WIN32 nor UNIX style find.")
|
||||||
|
ENDIF(NOT wxWidgets_FIND_QUIETLY)
|
||||||
|
ENDIF(UNIX_STYLE_FIND)
|
||||||
|
ENDIF(WIN32_STYLE_FIND)
|
||||||
|
|
||||||
|
|
||||||
|
# add convenience use file
|
||||||
|
IF (wxWidgets_FOUND)
|
||||||
|
# get dir of this file which may reside in
|
||||||
|
# - CMAKE_MAKE_ROOT/Modules on CMake installation
|
||||||
|
# - CMAKE_MODULE_PATH if user prefers his own specialized version
|
||||||
|
GET_FILENAME_COMPONENT(wxWidgets_CURRENT_LIST_DIR ${CMAKE_CURRENT_LIST_FILE} PATH)
|
||||||
|
SET(wxWidgets_USE_FILE "${wxWidgets_CURRENT_LIST_DIR}/UsewxWidgets.cmake")
|
||||||
|
# check
|
||||||
|
IF (NOT EXISTS ${wxWidgets_USE_FILE})
|
||||||
|
IF (NOT wxWidgets_FIND_QUIETLY)
|
||||||
|
MESSAGE(SEND_ERROR "Your Find/Use wxWidgets installation is wrong. wxWidgets_USE_FILE=${wxWidgets_USE_FILE} not found.")
|
||||||
|
ENDIF(NOT wxWidgets_FIND_QUIETLY)
|
||||||
|
ENDIF(NOT EXISTS ${wxWidgets_USE_FILE})
|
||||||
|
ENDIF(wxWidgets_FOUND)
|
||||||
|
|
||||||
|
DBG_MSG("wxWidgets_FOUND : ${wxWidgets_FOUND}")
|
||||||
|
DBG_MSG("wxWidgets_INCLUDE_DIRS : ${wxWidgets_INCLUDE_DIRS}")
|
||||||
|
DBG_MSG("wxWidgets_LIBRARY_DIRS : ${wxWidgets_LIBRARY_DIRS}")
|
||||||
|
DBG_MSG("wxWidgets_CXX_FLAGS : ${wxWidgets_CXX_FLAGS}")
|
||||||
|
DBG_MSG("wxWidgets_USE_FILE : ${wxWidgets_USE_FILE}")
|
||||||
|
DBG_MSG("wxWidgets_FIND_COMPONENTS : ${wxWidgets_FIND_COMPONENTS}")
|
||||||
|
DBG_MSG("wxWidgets_USE_LIBS : ${wxWidgets_USE_LIBS}")
|
||||||
|
|
||||||
|
#=====================================================================
|
||||||
|
#=====================================================================
|
||||||
|
IF(NOT wxWidgets_FOUND)
|
||||||
|
# make FIND_PACKAGE friendly
|
||||||
|
IF(NOT wxWidgets_FIND_QUIETLY)
|
||||||
|
IF(wxWidgets_FIND_REQUIRED)
|
||||||
|
MESSAGE(FATAL_ERROR
|
||||||
|
"wxWidgets required, please specify it's location.")
|
||||||
|
ELSE(wxWidgets_FIND_REQUIRED)
|
||||||
|
MESSAGE(STATUS "ERROR: wxWidgets was not found.")
|
||||||
|
ENDIF(wxWidgets_FIND_REQUIRED)
|
||||||
|
ENDIF(NOT wxWidgets_FIND_QUIETLY)
|
||||||
|
ENDIF(NOT wxWidgets_FOUND)
|
||||||
|
|
|
@ -1,54 +1,59 @@
|
||||||
# - Find wxWindows (wxWidgets) installation
|
# - Find wxWindows (wxWidgets) installation
|
||||||
# This module finds if wxWindows/wxWidgets is installed and determines where
|
# 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 include files and libraries are. It also determines what the name of
|
||||||
# the library is. This code sets the following variables:
|
# the library is.
|
||||||
#
|
# Please note this file is DEPRECATED and replaced by FindwxWidgets.cmake.
|
||||||
# WXWINDOWS_FOUND = system has WxWindows
|
# This code sets the following variables:
|
||||||
|
#
|
||||||
|
# WXWINDOWS_FOUND = system has WxWindows
|
||||||
# WXWINDOWS_LIBRARIES = path to the wxWindows libraries
|
# WXWINDOWS_LIBRARIES = path to the wxWindows libraries
|
||||||
# on Unix/Linux with additional
|
# on Unix/Linux with additional
|
||||||
# linker flags from
|
# linker flags from
|
||||||
# "wx-config --libs"
|
# "wx-config --libs"
|
||||||
# CMAKE_WXWINDOWS_CXX_FLAGS = Compiler flags for wxWindows,
|
# CMAKE_WXWINDOWS_CXX_FLAGS = Compiler flags for wxWindows,
|
||||||
# essentially "`wx-config --cxxflags`"
|
# essentially "`wx-config --cxxflags`"
|
||||||
# on Linux
|
# on Linux
|
||||||
# WXWINDOWS_INCLUDE_DIR = where to find "wx/wx.h" and "wx/setup.h"
|
# WXWINDOWS_INCLUDE_DIR = where to find "wx/wx.h" and "wx/setup.h"
|
||||||
# WXWINDOWS_LINK_DIRECTORIES = link directories, useful for rpath on
|
# WXWINDOWS_LINK_DIRECTORIES = link directories, useful for rpath on
|
||||||
# Unix
|
# Unix
|
||||||
# WXWINDOWS_DEFINITIONS = extra defines
|
# WXWINDOWS_DEFINITIONS = extra defines
|
||||||
#
|
#
|
||||||
|
# OPTIONS
|
||||||
|
# If you need OpenGL support please
|
||||||
|
# SET(WXWINDOWS_USE_GL 1)
|
||||||
|
# in your CMakeLists.txt *before* you include this file.
|
||||||
|
#
|
||||||
|
# HAVE_ISYSTEM - true required to replace -I by -isystem on g++
|
||||||
|
#
|
||||||
|
# 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
|
||||||
|
#
|
||||||
# DEPRECATED
|
# DEPRECATED
|
||||||
|
#
|
||||||
# CMAKE_WX_CAN_COMPILE
|
# CMAKE_WX_CAN_COMPILE
|
||||||
# WXWINDOWS_LIBRARY
|
# WXWINDOWS_LIBRARY
|
||||||
# CMAKE_WX_CXX_FLAGS
|
# CMAKE_WX_CXX_FLAGS
|
||||||
# WXWINDOWS_INCLUDE_PATH
|
# 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
|
# AUTHOR
|
||||||
# Jan Woetzel <http://www.mip.informatik.uni-kiel.de/~jw> (07/2003-01/2006)
|
# 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.
|
# -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)
|
# -major update for wx 2.6.2 and monolithic build option. (10/2005)
|
||||||
#
|
#
|
||||||
# STATUS
|
# STATUS
|
||||||
# tested with:
|
# tested with:
|
||||||
# cmake 1.6.7, Linux (Suse 7.3), wxWindows 2.4.0, gcc 2.95
|
# 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.0, gcc 3.3
|
||||||
|
@ -87,19 +92,19 @@ IF(WIN32_STYLE_FIND)
|
||||||
## should have subdirs include and lib containing include/wx/wx.h
|
## should have subdirs include and lib containing include/wx/wx.h
|
||||||
## fix the root dir to avoid mixing of headers/libs from different
|
## fix the root dir to avoid mixing of headers/libs from different
|
||||||
## versions/builds:
|
## versions/builds:
|
||||||
|
|
||||||
SET (WXWINDOWS_POSSIBLE_ROOT_PATHS
|
SET (WXWINDOWS_POSSIBLE_ROOT_PATHS
|
||||||
$ENV{WXWIN}
|
$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\\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
|
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\wxWindows_is1;Inno Setup: App Path]" ## WX 2.4.x
|
||||||
C:\\wxWidgets-2.6.2
|
C:\\wxWidgets-2.6.2
|
||||||
D:\\wxWidgets-2.6.2
|
D:\\wxWidgets-2.6.2
|
||||||
C:\\wxWidgets-2.6.1
|
C:\\wxWidgets-2.6.1
|
||||||
D:\\wxWidgets-2.6.1
|
D:\\wxWidgets-2.6.1
|
||||||
C:\\wxWindows-2.4.2
|
C:\\wxWindows-2.4.2
|
||||||
D:\\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.
|
## 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
|
## 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)
|
## e.g. compile on WIN32 as "nmake -f makefile.vc MONOLITHIC=1 BUILD=debug SHARED=0 USE_OPENGL=1" (JW)
|
||||||
|
@ -112,49 +117,49 @@ IF(WIN32_STYLE_FIND)
|
||||||
|
|
||||||
|
|
||||||
## avoid mixing of headers and libs between multiple installed WX versions,
|
## avoid mixing of headers and libs between multiple installed WX versions,
|
||||||
## select just one tree here:
|
## select just one tree here:
|
||||||
FIND_PATH(WXWINDOWS_ROOT_DIR include/wx/wx.h
|
FIND_PATH(WXWINDOWS_ROOT_DIR include/wx/wx.h
|
||||||
${WXWINDOWS_POSSIBLE_ROOT_PATHS} )
|
${WXWINDOWS_POSSIBLE_ROOT_PATHS} )
|
||||||
# MESSAGE("DBG found WXWINDOWS_ROOT_DIR: ${WXWINDOWS_ROOT_DIR}")
|
# MESSAGE("DBG found WXWINDOWS_ROOT_DIR: ${WXWINDOWS_ROOT_DIR}")
|
||||||
|
|
||||||
|
|
||||||
## find libs for combination of static/shared with release/debug
|
## find libs for combination of static/shared with release/debug
|
||||||
## be careful if you add something here,
|
## be careful if you add something here,
|
||||||
## avoid mixing of headers and libs of different wx versions,
|
## avoid mixing of headers and libs of different wx versions,
|
||||||
## there may be multiple WX version s installed.
|
## there may be multiple WX version s installed.
|
||||||
SET (WXWINDOWS_POSSIBLE_LIB_PATHS
|
SET (WXWINDOWS_POSSIBLE_LIB_PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib"
|
"${WXWINDOWS_ROOT_DIR}/lib"
|
||||||
)
|
)
|
||||||
|
|
||||||
## monolithic?
|
## monolithic?
|
||||||
IF (WXWINDOWS_USE_MONOLITHIC)
|
IF (WXWINDOWS_USE_MONOLITHIC)
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY
|
||||||
NAMES wx wxmsw wxmsw26
|
NAMES wx wxmsw wxmsw26
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static release build library" )
|
DOC "wxWindows static release build library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY
|
||||||
NAMES wxd wxmswd wxmsw26d
|
NAMES wxd wxmswd wxmsw26d
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug build library" )
|
DOC "wxWindows static debug build library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_SHARED_LIBRARY
|
FIND_LIBRARY(WXWINDOWS_SHARED_LIBRARY
|
||||||
NAMES wxmsw26 wxmsw262 wxmsw24 wxmsw242 wxmsw241 wxmsw240 wx23_2 wx22_9
|
NAMES wxmsw26 wxmsw262 wxmsw24 wxmsw242 wxmsw241 wxmsw240 wx23_2 wx22_9
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows shared release build library" )
|
DOC "wxWindows shared release build library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_SHARED_DEBUG_LIBRARY
|
FIND_LIBRARY(WXWINDOWS_SHARED_DEBUG_LIBRARY
|
||||||
NAMES wxmsw26d wxmsw262d wxmsw24d wxmsw241d wxmsw240d wx23_2d wx22_9d
|
NAMES wxmsw26d wxmsw262d wxmsw24d wxmsw241d wxmsw240d wx23_2d wx22_9d
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows shared debug build library " )
|
DOC "wxWindows shared debug build library " )
|
||||||
|
|
||||||
|
|
||||||
|
@ -163,124 +168,124 @@ IF(WIN32_STYLE_FIND)
|
||||||
## gl lib is always build separate:
|
## gl lib is always build separate:
|
||||||
##
|
##
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_GL
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_GL
|
||||||
NAMES wx_gl wxmsw_gl wxmsw26_gl
|
NAMES wx_gl wxmsw_gl wxmsw26_gl
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static release build GL library" )
|
DOC "wxWindows static release build GL library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_GL
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_GL
|
||||||
NAMES wxd_gl wxmswd_gl wxmsw26d_gl
|
NAMES wxd_gl wxmswd_gl wxmsw26d_gl
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug build GL library" )
|
DOC "wxWindows static debug build GL library" )
|
||||||
|
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_PNG
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_PNG
|
||||||
NAMES wxpngd
|
NAMES wxpngd
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug png library" )
|
DOC "wxWindows static debug png library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_PNG
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_PNG
|
||||||
NAMES wxpng
|
NAMES wxpng
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static png library" )
|
DOC "wxWindows static png library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_TIFF
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_TIFF
|
||||||
NAMES wxtiffd
|
NAMES wxtiffd
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug tiff library" )
|
DOC "wxWindows static debug tiff library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_TIFF
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_TIFF
|
||||||
NAMES wxtiff
|
NAMES wxtiff
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static tiff library" )
|
DOC "wxWindows static tiff library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_JPEG
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_JPEG
|
||||||
NAMES wxjpegd wxjpgd
|
NAMES wxjpegd wxjpgd
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug jpeg library" )
|
DOC "wxWindows static debug jpeg library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_JPEG
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_JPEG
|
||||||
NAMES wxjpeg wxjpg
|
NAMES wxjpeg wxjpg
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static jpeg library" )
|
DOC "wxWindows static jpeg library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_ZLIB
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_ZLIB
|
||||||
NAMES wxzlibd
|
NAMES wxzlibd
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug zlib library" )
|
DOC "wxWindows static debug zlib library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_ZLIB
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_ZLIB
|
||||||
NAMES wxzlib
|
NAMES wxzlib
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static zib library" )
|
DOC "wxWindows static zib library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_REGEX
|
FIND_LIBRARY(WXWINDOWS_STATIC_DEBUG_LIBRARY_REGEX
|
||||||
NAMES wxregexd
|
NAMES wxregexd
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static debug regex library" )
|
DOC "wxWindows static debug regex library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_REGEX
|
FIND_LIBRARY(WXWINDOWS_STATIC_LIBRARY_REGEX
|
||||||
NAMES wxregex
|
NAMES wxregex
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_lib"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows static regex library" )
|
DOC "wxWindows static regex library" )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## untested:
|
## untested:
|
||||||
FIND_LIBRARY(WXWINDOWS_SHARED_LIBRARY_GL
|
FIND_LIBRARY(WXWINDOWS_SHARED_LIBRARY_GL
|
||||||
NAMES wx_gl wxmsw_gl wxmsw26_gl
|
NAMES wx_gl wxmsw_gl wxmsw26_gl
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows shared release build GL library" )
|
DOC "wxWindows shared release build GL library" )
|
||||||
|
|
||||||
FIND_LIBRARY(WXWINDOWS_SHARED_DEBUG_LIBRARY_GL
|
FIND_LIBRARY(WXWINDOWS_SHARED_DEBUG_LIBRARY_GL
|
||||||
NAMES wxd_gl wxmswd_gl wxmsw26d_gl
|
NAMES wxd_gl wxmswd_gl wxmsw26d_gl
|
||||||
PATHS
|
PATHS
|
||||||
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
"${WXWINDOWS_ROOT_DIR}/lib/vc_dll"
|
||||||
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
${WXWINDOWS_POSSIBLE_LIB_PATHS}
|
||||||
DOC "wxWindows shared debug build GL library" )
|
DOC "wxWindows shared debug build GL library" )
|
||||||
|
|
||||||
|
|
||||||
ELSE (WXWINDOWS_USE_MONOLITHIC)
|
ELSE (WXWINDOWS_USE_MONOLITHIC)
|
||||||
## WX is built as multiple small pieces libraries instead of monolithic
|
## WX is built as multiple small pieces libraries instead of monolithic
|
||||||
|
|
||||||
## DEPECATED (jw) replaced by more general WXWINDOWS_USE_MONOLITHIC ON/OFF
|
## DEPECATED (jw) replaced by more general WXWINDOWS_USE_MONOLITHIC ON/OFF
|
||||||
# OPTION(WXWINDOWS_SEPARATE_LIBS_BUILD "Is wxWindows build with separate libs?" OFF)
|
# OPTION(WXWINDOWS_SEPARATE_LIBS_BUILD "Is wxWindows build with separate libs?" OFF)
|
||||||
|
|
||||||
## HACK: This is very dirty.
|
## HACK: This is very dirty.
|
||||||
## because the libs of a particular version are explicitly listed
|
## because the libs of a particular version are explicitly listed
|
||||||
## and NOT searched/verified.
|
## and NOT searched/verified.
|
||||||
## TODO: Really search for each lib, then decide for
|
## TODO: Really search for each lib, then decide for
|
||||||
## monolithic x debug x shared x GL (=16 combinations) for at least 18 libs
|
## monolithic x debug x shared x GL (=16 combinations) for at least 18 libs
|
||||||
## --> about 288 combinations
|
## --> about 288 combinations
|
||||||
## thus we need a different approach so solve this correctly ...
|
## 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).")
|
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}
|
SET(WXWINDOWS_STATIC_LIBS ${WXWINDOWS_STATIC_LIBS}
|
||||||
wxbase26
|
wxbase26
|
||||||
wxbase26_net
|
wxbase26_net
|
||||||
|
@ -304,7 +309,7 @@ IF(WIN32_STYLE_FIND)
|
||||||
rpcrt4
|
rpcrt4
|
||||||
wsock32
|
wsock32
|
||||||
)
|
)
|
||||||
## HACK: feed in to optimized / debug libaries if both were FOUND.
|
## HACK: feed in to optimized / debug libaries if both were FOUND.
|
||||||
SET(WXWINDOWS_STATIC_DEBUG_LIBS ${WXWINDOWS_STATIC_DEBUG_LIBS}
|
SET(WXWINDOWS_STATIC_DEBUG_LIBS ${WXWINDOWS_STATIC_DEBUG_LIBS}
|
||||||
wxbase26d
|
wxbase26d
|
||||||
wxbase26d_net
|
wxbase26d_net
|
||||||
|
@ -329,29 +334,29 @@ IF(WIN32_STYLE_FIND)
|
||||||
wsock32
|
wsock32
|
||||||
)
|
)
|
||||||
ENDIF (WXWINDOWS_USE_MONOLITHIC)
|
ENDIF (WXWINDOWS_USE_MONOLITHIC)
|
||||||
|
|
||||||
|
|
||||||
##
|
##
|
||||||
## now we should have found all WX libs available on the system.
|
## now we should have found all WX libs available on the system.
|
||||||
## let the user decide which of the available onse to use.
|
## let the user decide which of the available onse to use.
|
||||||
##
|
##
|
||||||
|
|
||||||
## if there is at least one shared lib available
|
## if there is at least one shared lib available
|
||||||
## let user choose wether to use shared or static wxwindows libs
|
## let user choose wether to use shared or static wxwindows libs
|
||||||
IF(WXWINDOWS_SHARED_LIBRARY OR WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
IF(WXWINDOWS_SHARED_LIBRARY OR WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
## default value OFF because wxWindows MSVS default build is static
|
## default value OFF because wxWindows MSVS default build is static
|
||||||
OPTION(WXWINDOWS_USE_SHARED_LIBS
|
OPTION(WXWINDOWS_USE_SHARED_LIBS
|
||||||
"Use shared versions (dll) of wxWindows libraries?" OFF)
|
"Use shared versions (dll) of wxWindows libraries?" OFF)
|
||||||
MARK_AS_ADVANCED(WXWINDOWS_USE_SHARED_LIBS)
|
MARK_AS_ADVANCED(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
ENDIF(WXWINDOWS_SHARED_LIBRARY OR WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
ENDIF(WXWINDOWS_SHARED_LIBRARY OR WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
|
|
||||||
## add system libraries wxwindows always seems to depend on
|
## add system libraries wxwindows always seems to depend on
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
comctl32
|
comctl32
|
||||||
rpcrt4
|
rpcrt4
|
||||||
wsock32
|
wsock32
|
||||||
)
|
)
|
||||||
|
|
||||||
IF (NOT WXWINDOWS_USE_SHARED_LIBS)
|
IF (NOT WXWINDOWS_USE_SHARED_LIBS)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
## these ones dont seem required, in particular ctl3d32 is not neccesary (Jan Woetzel 07/2003)
|
## these ones dont seem required, in particular ctl3d32 is not neccesary (Jan Woetzel 07/2003)
|
||||||
|
@ -364,34 +369,34 @@ IF(WIN32_STYLE_FIND)
|
||||||
)
|
)
|
||||||
ENDIF (NOT WXWINDOWS_USE_SHARED_LIBS)
|
ENDIF (NOT WXWINDOWS_USE_SHARED_LIBS)
|
||||||
|
|
||||||
## opengl/glu: TODO/FIXME: better use FindOpenGL.cmake here
|
## opengl/glu: TODO/FIXME: better use FindOpenGL.cmake here
|
||||||
## assume release versions of glu an dopengl, here.
|
## assume release versions of glu an dopengl, here.
|
||||||
IF (WXWINDOWS_USE_GL)
|
IF (WXWINDOWS_USE_GL)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
opengl32
|
opengl32
|
||||||
glu32 )
|
glu32 )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
|
|
||||||
##
|
##
|
||||||
## select between use of shared or static wxWindows lib then set libs to use
|
## 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
|
## 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
|
## release build e.g. within MS Visual Studio without running cmake with a
|
||||||
## different build directory again.
|
## different build directory again.
|
||||||
##
|
##
|
||||||
## then add the build specific include dir for wx/setup.h
|
## then add the build specific include dir for wx/setup.h
|
||||||
##
|
##
|
||||||
|
|
||||||
IF(WXWINDOWS_USE_SHARED_LIBS)
|
IF(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
##MESSAGE("DBG wxWindows use shared lib selected.")
|
##MESSAGE("DBG wxWindows use shared lib selected.")
|
||||||
## assume that both builds use the same setup(.h) for simplicity
|
## assume that both builds use the same setup(.h) for simplicity
|
||||||
|
|
||||||
## shared: both wx (debug and release) found?
|
## shared: both wx (debug and release) found?
|
||||||
## assume that both builds use the same setup(.h) for simplicity
|
## assume that both builds use the same setup(.h) for simplicity
|
||||||
IF(WXWINDOWS_SHARED_DEBUG_LIBRARY AND WXWINDOWS_SHARED_LIBRARY)
|
IF(WXWINDOWS_SHARED_DEBUG_LIBRARY AND WXWINDOWS_SHARED_LIBRARY)
|
||||||
##MESSAGE("DBG wx shared: debug and optimized found.")
|
##MESSAGE("DBG wx shared: debug and optimized found.")
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/mswdlld
|
${WXWINDOWS_ROOT_DIR}/lib/mswdlld
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/mswdll
|
${WXWINDOWS_ROOT_DIR}/lib/mswdll
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/mswd
|
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/mswd
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/msw )
|
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/msw )
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
|
@ -403,29 +408,29 @@ IF(WIN32_STYLE_FIND)
|
||||||
optimized ${WXWINDOWS_SHARED_LIBRARY_GL} )
|
optimized ${WXWINDOWS_SHARED_LIBRARY_GL} )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
ENDIF(WXWINDOWS_SHARED_DEBUG_LIBRARY AND WXWINDOWS_SHARED_LIBRARY)
|
ENDIF(WXWINDOWS_SHARED_DEBUG_LIBRARY AND WXWINDOWS_SHARED_LIBRARY)
|
||||||
|
|
||||||
## shared: only debug wx lib found?
|
## shared: only debug wx lib found?
|
||||||
IF(WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
IF(WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
IF(NOT WXWINDOWS_SHARED_LIBRARY)
|
IF(NOT WXWINDOWS_SHARED_LIBRARY)
|
||||||
##MESSAGE("DBG wx shared: debug (but no optimized) found.")
|
##MESSAGE("DBG wx shared: debug (but no optimized) found.")
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/mswdlld
|
${WXWINDOWS_ROOT_DIR}/lib/mswdlld
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/mswd )
|
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/mswd )
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_SHARED_DEBUG_LIBRARY} )
|
${WXWINDOWS_SHARED_DEBUG_LIBRARY} )
|
||||||
IF (WXWINDOWS_USE_GL)
|
IF (WXWINDOWS_USE_GL)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL} )
|
${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL} )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
ENDIF(NOT WXWINDOWS_SHARED_LIBRARY)
|
ENDIF(NOT WXWINDOWS_SHARED_LIBRARY)
|
||||||
ENDIF(WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
ENDIF(WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
|
|
||||||
## shared: only release wx lib found?
|
## shared: only release wx lib found?
|
||||||
IF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
IF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
IF(WXWINDOWS_SHARED_LIBRARY)
|
IF(WXWINDOWS_SHARED_LIBRARY)
|
||||||
##MESSAGE("DBG wx shared: optimized (but no debug) found.")
|
##MESSAGE("DBG wx shared: optimized (but no debug) found.")
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/mswdll
|
${WXWINDOWS_ROOT_DIR}/lib/mswdll
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/msw )
|
${WXWINDOWS_ROOT_DIR}/lib/vc_dll/msw )
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_SHARED_DEBUG_LIBRARY} )
|
${WXWINDOWS_SHARED_DEBUG_LIBRARY} )
|
||||||
|
@ -433,13 +438,13 @@ IF(WIN32_STYLE_FIND)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL} )
|
${WXWINDOWS_SHARED_DEBUG_LIBRARY_GL} )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
ENDIF(WXWINDOWS_SHARED_LIBRARY)
|
ENDIF(WXWINDOWS_SHARED_LIBRARY)
|
||||||
ENDIF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
ENDIF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
|
|
||||||
## shared: none found?
|
## shared: none found?
|
||||||
IF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
IF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
IF(NOT WXWINDOWS_SHARED_LIBRARY)
|
IF(NOT WXWINDOWS_SHARED_LIBRARY)
|
||||||
MESSAGE(STATUS
|
MESSAGE(STATUS
|
||||||
"No shared wxWindows lib found, but WXWINDOWS_USE_SHARED_LIBS=${WXWINDOWS_USE_SHARED_LIBS}.")
|
"No shared wxWindows lib found, but WXWINDOWS_USE_SHARED_LIBS=${WXWINDOWS_USE_SHARED_LIBS}.")
|
||||||
ENDIF(NOT WXWINDOWS_SHARED_LIBRARY)
|
ENDIF(NOT WXWINDOWS_SHARED_LIBRARY)
|
||||||
ENDIF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
ENDIF(NOT WXWINDOWS_SHARED_DEBUG_LIBRARY)
|
||||||
|
@ -448,15 +453,15 @@ IF(WIN32_STYLE_FIND)
|
||||||
ELSE(WXWINDOWS_USE_SHARED_LIBS)
|
ELSE(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
|
|
||||||
##jw: DEPRECATED IF(NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
|
##jw: DEPRECATED IF(NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
|
||||||
|
|
||||||
## static: both wx (debug and release) found?
|
## static: both wx (debug and release) found?
|
||||||
## assume that both builds use the same setup(.h) for simplicity
|
## assume that both builds use the same setup(.h) for simplicity
|
||||||
IF(WXWINDOWS_STATIC_DEBUG_LIBRARY AND WXWINDOWS_STATIC_LIBRARY)
|
IF(WXWINDOWS_STATIC_DEBUG_LIBRARY AND WXWINDOWS_STATIC_LIBRARY)
|
||||||
##MESSAGE("DBG wx static: debug and optimized found.")
|
##MESSAGE("DBG wx static: debug and optimized found.")
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/mswd
|
${WXWINDOWS_ROOT_DIR}/lib/mswd
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/msw
|
${WXWINDOWS_ROOT_DIR}/lib/msw
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/mswd
|
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/mswd
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/msw )
|
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/msw )
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY}
|
debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY}
|
||||||
|
@ -465,77 +470,77 @@ IF(WIN32_STYLE_FIND)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_GL}
|
debug ${WXWINDOWS_STATIC_DEBUG_LIBRARY_GL}
|
||||||
optimized ${WXWINDOWS_STATIC_LIBRARY_GL} )
|
optimized ${WXWINDOWS_STATIC_LIBRARY_GL} )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
ENDIF(WXWINDOWS_STATIC_DEBUG_LIBRARY AND WXWINDOWS_STATIC_LIBRARY)
|
ENDIF(WXWINDOWS_STATIC_DEBUG_LIBRARY AND WXWINDOWS_STATIC_LIBRARY)
|
||||||
|
|
||||||
## static: only debug wx lib found?
|
## static: only debug wx lib found?
|
||||||
IF(WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
IF(WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
||||||
IF(NOT WXWINDOWS_STATIC_LIBRARY)
|
IF(NOT WXWINDOWS_STATIC_LIBRARY)
|
||||||
##MESSAGE("DBG wx static: debug (but no optimized) found.")
|
##MESSAGE("DBG wx static: debug (but no optimized) found.")
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/mswd
|
${WXWINDOWS_ROOT_DIR}/lib/mswd
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/mswd )
|
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/mswd )
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_STATIC_DEBUG_LIBRARY} )
|
${WXWINDOWS_STATIC_DEBUG_LIBRARY} )
|
||||||
IF (WXWINDOWS_USE_GL)
|
IF (WXWINDOWS_USE_GL)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_STATIC_DEBUG_LIBRARY_GL} )
|
${WXWINDOWS_STATIC_DEBUG_LIBRARY_GL} )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
ENDIF(NOT WXWINDOWS_STATIC_LIBRARY)
|
ENDIF(NOT WXWINDOWS_STATIC_LIBRARY)
|
||||||
ENDIF(WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
ENDIF(WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
||||||
|
|
||||||
## static: only release wx lib found?
|
## static: only release wx lib found?
|
||||||
IF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
IF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
||||||
IF(WXWINDOWS_STATIC_LIBRARY)
|
IF(WXWINDOWS_STATIC_LIBRARY)
|
||||||
##MESSAGE("DBG wx static: optimized (but no debug) found.")
|
##MESSAGE("DBG wx static: optimized (but no debug) found.")
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR_SETUPH wx/setup.h
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/msw
|
${WXWINDOWS_ROOT_DIR}/lib/msw
|
||||||
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/msw )
|
${WXWINDOWS_ROOT_DIR}/lib/vc_lib/msw )
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_STATIC_LIBRARY} )
|
${WXWINDOWS_STATIC_LIBRARY} )
|
||||||
IF (WXWINDOWS_USE_GL)
|
IF (WXWINDOWS_USE_GL)
|
||||||
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
SET(WXWINDOWS_LIBRARIES ${WXWINDOWS_LIBRARIES}
|
||||||
${WXWINDOWS_STATIC_LIBRARY_GL} )
|
${WXWINDOWS_STATIC_LIBRARY_GL} )
|
||||||
ENDIF (WXWINDOWS_USE_GL)
|
ENDIF (WXWINDOWS_USE_GL)
|
||||||
ENDIF(WXWINDOWS_STATIC_LIBRARY)
|
ENDIF(WXWINDOWS_STATIC_LIBRARY)
|
||||||
ENDIF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
ENDIF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY)
|
||||||
|
|
||||||
## static: none found?
|
## static: none found?
|
||||||
IF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY AND NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
|
IF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY AND NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
|
||||||
IF(NOT WXWINDOWS_STATIC_LIBRARY)
|
IF(NOT WXWINDOWS_STATIC_LIBRARY)
|
||||||
MESSAGE(STATUS
|
MESSAGE(STATUS
|
||||||
"No static wxWindows lib found, but WXWINDOWS_USE_SHARED_LIBS=${WXWINDOWS_USE_SHARED_LIBS}.")
|
"No static wxWindows lib found, but WXWINDOWS_USE_SHARED_LIBS=${WXWINDOWS_USE_SHARED_LIBS}.")
|
||||||
ENDIF(NOT WXWINDOWS_STATIC_LIBRARY)
|
ENDIF(NOT WXWINDOWS_STATIC_LIBRARY)
|
||||||
ENDIF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY AND NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
|
ENDIF(NOT WXWINDOWS_STATIC_DEBUG_LIBRARY AND NOT WXWINDOWS_SEPARATE_LIBS_BUILD)
|
||||||
ENDIF(WXWINDOWS_USE_SHARED_LIBS)
|
ENDIF(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
|
|
||||||
|
|
||||||
## not neccessary in wxWindows 2.4.1 and 2.6.2
|
## not neccessary in wxWindows 2.4.1 and 2.6.2
|
||||||
## but it may fix a previous bug, see
|
## but it may fix a previous bug, see
|
||||||
## http://lists.wxwindows.org/cgi-bin/ezmlm-cgi?8:mss:37574:200305:mpdioeneabobmgjenoap
|
## http://lists.wxwindows.org/cgi-bin/ezmlm-cgi?8:mss:37574:200305:mpdioeneabobmgjenoap
|
||||||
OPTION(WXWINDOWS_SET_DEFINITIONS "Set additional defines for wxWindows" OFF)
|
OPTION(WXWINDOWS_SET_DEFINITIONS "Set additional defines for wxWindows" OFF)
|
||||||
MARK_AS_ADVANCED(WXWINDOWS_SET_DEFINITIONS)
|
MARK_AS_ADVANCED(WXWINDOWS_SET_DEFINITIONS)
|
||||||
IF (WXWINDOWS_SET_DEFINITIONS)
|
IF (WXWINDOWS_SET_DEFINITIONS)
|
||||||
SET(WXWINDOWS_DEFINITIONS "-DWINVER=0x400")
|
SET(WXWINDOWS_DEFINITIONS "-DWINVER=0x400")
|
||||||
ELSE (WXWINDOWS_SET_DEFINITIONS)
|
ELSE (WXWINDOWS_SET_DEFINITIONS)
|
||||||
# clear:
|
# clear:
|
||||||
SET(WXWINDOWS_DEFINITIONS "")
|
SET(WXWINDOWS_DEFINITIONS "")
|
||||||
ENDIF (WXWINDOWS_SET_DEFINITIONS)
|
ENDIF (WXWINDOWS_SET_DEFINITIONS)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Find the include directories for wxwindows
|
## Find the include directories for wxwindows
|
||||||
## the first, build specific for wx/setup.h was determined before.
|
## the first, build specific for wx/setup.h was determined before.
|
||||||
## add inc dir for general for "wx/wx.h"
|
## add inc dir for general for "wx/wx.h"
|
||||||
FIND_PATH(WXWINDOWS_INCLUDE_DIR wx/wx.h
|
FIND_PATH(WXWINDOWS_INCLUDE_DIR wx/wx.h
|
||||||
"${WXWINDOWS_ROOT_DIR}/include" )
|
"${WXWINDOWS_ROOT_DIR}/include" )
|
||||||
## append the build specific include dir for wx/setup.h:
|
## append the build specific include dir for wx/setup.h:
|
||||||
IF (WXWINDOWS_INCLUDE_DIR_SETUPH)
|
IF (WXWINDOWS_INCLUDE_DIR_SETUPH)
|
||||||
SET(WXWINDOWS_INCLUDE_DIR ${WXWINDOWS_INCLUDE_DIR} ${WXWINDOWS_INCLUDE_DIR_SETUPH} )
|
SET(WXWINDOWS_INCLUDE_DIR ${WXWINDOWS_INCLUDE_DIR} ${WXWINDOWS_INCLUDE_DIR_SETUPH} )
|
||||||
ENDIF (WXWINDOWS_INCLUDE_DIR_SETUPH)
|
ENDIF (WXWINDOWS_INCLUDE_DIR_SETUPH)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
MARK_AS_ADVANCED(
|
MARK_AS_ADVANCED(
|
||||||
WXWINDOWS_ROOT_DIR
|
WXWINDOWS_ROOT_DIR
|
||||||
WXWINDOWS_INCLUDE_DIR
|
WXWINDOWS_INCLUDE_DIR
|
||||||
|
@ -557,28 +562,28 @@ IF(WIN32_STYLE_FIND)
|
||||||
WXWINDOWS_SHARED_LIBRARY
|
WXWINDOWS_SHARED_LIBRARY
|
||||||
WXWINDOWS_SHARED_DEBUG_LIBRARY
|
WXWINDOWS_SHARED_DEBUG_LIBRARY
|
||||||
WXWINDOWS_SHARED_LIBRARY_GL
|
WXWINDOWS_SHARED_LIBRARY_GL
|
||||||
WXWINDOWS_SHARED_DEBUG_LIBRARY_GL
|
WXWINDOWS_SHARED_DEBUG_LIBRARY_GL
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
ELSE(WIN32_STYLE_FIND)
|
ELSE(WIN32_STYLE_FIND)
|
||||||
|
|
||||||
IF (UNIX_STYLE_FIND)
|
IF (UNIX_STYLE_FIND)
|
||||||
## ######################################################################
|
## ######################################################################
|
||||||
##
|
##
|
||||||
## UNIX/Linux specific:
|
## UNIX/Linux specific:
|
||||||
##
|
##
|
||||||
## use backquoted wx-config to query and set flags and libs:
|
## use backquoted wx-config to query and set flags and libs:
|
||||||
## 06/2003 Jan Woetzel
|
## 06/2003 Jan Woetzel
|
||||||
##
|
##
|
||||||
|
|
||||||
OPTION(WXWINDOWS_USE_SHARED_LIBS "Use shared versions (.so) of wxWindows libraries" ON)
|
OPTION(WXWINDOWS_USE_SHARED_LIBS "Use shared versions (.so) of wxWindows libraries" ON)
|
||||||
MARK_AS_ADVANCED(WXWINDOWS_USE_SHARED_LIBS)
|
MARK_AS_ADVANCED(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
|
|
||||||
# JW removed option and force the develper th SET it.
|
# JW removed option and force the develper th SET it.
|
||||||
# OPTION(WXWINDOWS_USE_GL "use wxWindows with GL support (use additional
|
# OPTION(WXWINDOWS_USE_GL "use wxWindows with GL support (use additional
|
||||||
# --gl-libs for wx-config)?" OFF)
|
# --gl-libs for wx-config)?" OFF)
|
||||||
|
|
||||||
# wx-config should be in your path anyhow, usually no need to set WXWIN or
|
# wx-config should be in your path anyhow, usually no need to set WXWIN or
|
||||||
# search in ../wx or ../../wx
|
# search in ../wx or ../../wx
|
||||||
FIND_PROGRAM(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE wx-config
|
FIND_PROGRAM(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE wx-config
|
||||||
|
@ -586,76 +591,86 @@ ELSE(WIN32_STYLE_FIND)
|
||||||
$ENV{WXWIN}/bin
|
$ENV{WXWIN}/bin
|
||||||
../wx/bin
|
../wx/bin
|
||||||
../../wx/bin )
|
../../wx/bin )
|
||||||
|
|
||||||
# check wether wx-config was found:
|
# check wether wx-config was found:
|
||||||
IF(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
|
IF(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
|
||||||
|
|
||||||
# use shared/static wx lib?
|
# use shared/static wx lib?
|
||||||
# remember: always link shared to use systems GL etc. libs (no static
|
# remember: always link shared to use systems GL etc. libs (no static
|
||||||
# linking, just link *against* static .a libs)
|
# linking, just link *against* static .a libs)
|
||||||
IF(WXWINDOWS_USE_SHARED_LIBS)
|
IF(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
SET(WX_CONFIG_ARGS_LIBS "--libs")
|
SET(WX_CONFIG_ARGS_LIBS "--libs")
|
||||||
ELSE(WXWINDOWS_USE_SHARED_LIBS)
|
ELSE(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
SET(WX_CONFIG_ARGS_LIBS "--static --libs")
|
SET(WX_CONFIG_ARGS_LIBS "--static --libs")
|
||||||
ENDIF(WXWINDOWS_USE_SHARED_LIBS)
|
ENDIF(WXWINDOWS_USE_SHARED_LIBS)
|
||||||
|
|
||||||
# do we need additionial wx GL stuff like GLCanvas ?
|
# do we need additionial wx GL stuff like GLCanvas ?
|
||||||
IF(WXWINDOWS_USE_GL)
|
IF(WXWINDOWS_USE_GL)
|
||||||
SET(WX_CONFIG_ARGS_LIBS "${WX_CONFIG_ARGS_LIBS} --gl-libs" )
|
SET(WX_CONFIG_ARGS_LIBS "${WX_CONFIG_ARGS_LIBS} --gl-libs" )
|
||||||
ENDIF(WXWINDOWS_USE_GL)
|
ENDIF(WXWINDOWS_USE_GL)
|
||||||
##MESSAGE("DBG: WX_CONFIG_ARGS_LIBS=${WX_CONFIG_ARGS_LIBS}===")
|
##MESSAGE("DBG: WX_CONFIG_ARGS_LIBS=${WX_CONFIG_ARGS_LIBS}===")
|
||||||
|
|
||||||
# set CXXFLAGS to be fed into CMAKE_CXX_FLAGS by the user:
|
# 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`")
|
IF (HAVE_ISYSTEM) # does the compiler support -isystem ?
|
||||||
|
IF (NOT APPLE) # -isystem seem sto be unsuppored on Mac
|
||||||
|
IF(CMAKE_COMPILER_IS_GNUCC AND CMAKE_COMPILER_IS_GNUCXX )
|
||||||
|
IF (CMAKE_CXX_COMPILER MATCHES g\\+\\+)
|
||||||
|
SET(CMAKE_WXWINDOWS_CXX_FLAGS "`${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE} --cxxflags|sed -e s/-I/-isystem/g`")
|
||||||
|
ELSE(CMAKE_CXX_COMPILER MATCHES g\\+\\+)
|
||||||
|
SET(CMAKE_WXWINDOWS_CXX_FLAGS "`${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE} --cxxflags`")
|
||||||
|
ENDIF(CMAKE_CXX_COMPILER MATCHES g\\+\\+)
|
||||||
|
ENDIF(CMAKE_COMPILER_IS_GNUCC AND CMAKE_COMPILER_IS_GNUCXX )
|
||||||
|
ENDIF (NOT APPLE)
|
||||||
|
ENDIF (HAVE_ISYSTEM)
|
||||||
##MESSAGE("DBG: for compilation:
|
##MESSAGE("DBG: for compilation:
|
||||||
##CMAKE_WXWINDOWS_CXX_FLAGS=${CMAKE_WXWINDOWS_CXX_FLAGS}===")
|
##CMAKE_WXWINDOWS_CXX_FLAGS=${CMAKE_WXWINDOWS_CXX_FLAGS}===")
|
||||||
|
|
||||||
# keep the back-quoted string for clarity
|
# keep the back-quoted string for clarity
|
||||||
SET(WXWINDOWS_LIBRARIES "`${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE} ${WX_CONFIG_ARGS_LIBS}`")
|
SET(WXWINDOWS_LIBRARIES "`${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE} ${WX_CONFIG_ARGS_LIBS}`")
|
||||||
##MESSAGE("DBG2: for linking:
|
##MESSAGE("DBG2: for linking:
|
||||||
##WXWINDOWS_LIBRARIES=${WXWINDOWS_LIBRARIES}===")
|
##WXWINDOWS_LIBRARIES=${WXWINDOWS_LIBRARIES}===")
|
||||||
|
|
||||||
# evaluate wx-config output to separate linker flags and linkdirs for
|
# evaluate wx-config output to separate linker flags and linkdirs for
|
||||||
# rpath:
|
# rpath:
|
||||||
EXEC_PROGRAM(${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE}
|
EXEC_PROGRAM(${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE}
|
||||||
ARGS ${WX_CONFIG_ARGS_LIBS}
|
ARGS ${WX_CONFIG_ARGS_LIBS}
|
||||||
OUTPUT_VARIABLE WX_CONFIG_LIBS )
|
OUTPUT_VARIABLE WX_CONFIG_LIBS )
|
||||||
|
|
||||||
## extract linkdirs (-L) for rpath
|
## extract linkdirs (-L) for rpath
|
||||||
## use regular expression to match wildcard equivalent "-L*<endchar>"
|
## use regular expression to match wildcard equivalent "-L*<endchar>"
|
||||||
## with <endchar> is a space or a semicolon
|
## with <endchar> is a space or a semicolon
|
||||||
STRING(REGEX MATCHALL "[-][L]([^ ;])+" WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX "${WX_CONFIG_LIBS}" )
|
STRING(REGEX MATCHALL "[-][L]([^ ;])+" WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX "${WX_CONFIG_LIBS}" )
|
||||||
# MESSAGE("DBG WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX=${WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX}")
|
# MESSAGE("DBG WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX=${WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX}")
|
||||||
|
|
||||||
## remove prefix -L because we need the pure directory for LINK_DIRECTORIES
|
## 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
|
## replace -L by ; because the separator seems to be lost otherwise (bug or
|
||||||
## feature?)
|
## feature?)
|
||||||
IF(WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX)
|
IF(WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX)
|
||||||
STRING(REGEX REPLACE "[-][L]" ";" WXWINDOWS_LINK_DIRECTORIES ${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}")
|
# MESSAGE("DBG WXWINDOWS_LINK_DIRECTORIES=${WXWINDOWS_LINK_DIRECTORIES}")
|
||||||
ENDIF(WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX)
|
ENDIF(WXWINDOWS_LINK_DIRECTORIES_WITH_PREFIX)
|
||||||
|
|
||||||
|
|
||||||
## replace space separated string by semicolon separated vector to make it
|
## replace space separated string by semicolon separated vector to make it
|
||||||
## work with LINK_DIRECTORIES
|
## work with LINK_DIRECTORIES
|
||||||
SEPARATE_ARGUMENTS(WXWINDOWS_LINK_DIRECTORIES)
|
SEPARATE_ARGUMENTS(WXWINDOWS_LINK_DIRECTORIES)
|
||||||
|
|
||||||
MARK_AS_ADVANCED(
|
MARK_AS_ADVANCED(
|
||||||
CMAKE_WXWINDOWS_CXX_FLAGS
|
CMAKE_WXWINDOWS_CXX_FLAGS
|
||||||
WXWINDOWS_INCLUDE_DIR
|
WXWINDOWS_INCLUDE_DIR
|
||||||
WXWINDOWS_LIBRARIES
|
WXWINDOWS_LIBRARIES
|
||||||
CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE
|
CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
## we really need wx-config...
|
## we really need wx-config...
|
||||||
ELSE(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
|
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.")
|
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)
|
MARK_AS_ADVANCED(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
|
||||||
ENDIF(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
|
ENDIF(CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ELSE(UNIX_STYLE_FIND)
|
ELSE(UNIX_STYLE_FIND)
|
||||||
MESSAGE(STATUS "FindwxWindows.cmake: Platform unknown/unsupported by FindwxWindows.cmake. It's neither WIN32 nor UNIX")
|
MESSAGE(STATUS "FindwxWindows.cmake: Platform unknown/unsupported by FindwxWindows.cmake. It's neither WIN32 nor UNIX")
|
||||||
ENDIF(UNIX_STYLE_FIND)
|
ENDIF(UNIX_STYLE_FIND)
|
||||||
|
@ -666,13 +681,13 @@ IF(WXWINDOWS_LIBRARIES)
|
||||||
IF(WXWINDOWS_INCLUDE_DIR OR CMAKE_WXWINDOWS_CXX_FLAGS)
|
IF(WXWINDOWS_INCLUDE_DIR OR CMAKE_WXWINDOWS_CXX_FLAGS)
|
||||||
## found all we need.
|
## found all we need.
|
||||||
SET(WXWINDOWS_FOUND 1)
|
SET(WXWINDOWS_FOUND 1)
|
||||||
|
|
||||||
## set deprecated variables for backward compatibility:
|
## set deprecated variables for backward compatibility:
|
||||||
SET(CMAKE_WX_CAN_COMPILE ${WXWINDOWS_FOUND})
|
SET(CMAKE_WX_CAN_COMPILE ${WXWINDOWS_FOUND})
|
||||||
SET(WXWINDOWS_LIBRARY ${WXWINDOWS_LIBRARIES})
|
SET(WXWINDOWS_LIBRARY ${WXWINDOWS_LIBRARIES})
|
||||||
SET(WXWINDOWS_INCLUDE_PATH ${WXWINDOWS_INCLUDE_DIR})
|
SET(WXWINDOWS_INCLUDE_PATH ${WXWINDOWS_INCLUDE_DIR})
|
||||||
SET(WXWINDOWS_LINK_DIRECTORIES ${WXWINDOWS_LINK_DIRECTORIES})
|
SET(WXWINDOWS_LINK_DIRECTORIES ${WXWINDOWS_LINK_DIRECTORIES})
|
||||||
SET(CMAKE_WX_CXX_FLAGS ${CMAKE_WXWINDOWS_CXX_FLAGS})
|
SET(CMAKE_WX_CXX_FLAGS ${CMAKE_WXWINDOWS_CXX_FLAGS})
|
||||||
|
|
||||||
ENDIF(WXWINDOWS_INCLUDE_DIR OR CMAKE_WXWINDOWS_CXX_FLAGS)
|
ENDIF(WXWINDOWS_INCLUDE_DIR OR CMAKE_WXWINDOWS_CXX_FLAGS)
|
||||||
ENDIF(WXWINDOWS_LIBRARIES)
|
ENDIF(WXWINDOWS_LIBRARIES)
|
||||||
|
|
|
@ -1,43 +1,50 @@
|
||||||
# - Find wxWindows installation
|
#
|
||||||
#
|
|
||||||
# This convenience include finds if wxWindows is installed
|
# This convenience include finds if wxWindows is installed
|
||||||
# and set the appropriate libs, incdirs, flags etc.
|
# and set the appropriate libs, incdirs, flags etc.
|
||||||
# INCLUDE_DIRECTORIES, LINK_DIRECTORIES and ADD_DEFINITIONS
|
|
||||||
# are called.
|
|
||||||
# author Jan Woetzel <jw -at- mip.informatik.uni-kiel.de> (07/2003)
|
# author Jan Woetzel <jw -at- mip.informatik.uni-kiel.de> (07/2003)
|
||||||
#
|
##
|
||||||
# if you are sure you need GL then
|
# -----------------------------------------------------
|
||||||
# SET(WXWINDOWS_USE_GL 1)
|
# USAGE:
|
||||||
# *before* you include this file.
|
# just include Use_wxWindows.cmake
|
||||||
|
# in your projects CMakeLists.txt
|
||||||
|
# INCLUDE( ${CMAKE_MODULE_PATH}/Use_wxWindows.cmake)
|
||||||
|
##
|
||||||
|
# if you are sure you need GL then
|
||||||
|
# SET(WXWINDOWS_USE_GL 1)
|
||||||
|
# *before* you include this file.
|
||||||
#
|
#
|
||||||
|
# -----------------------------------------------------
|
||||||
|
# 16.Feb.2004: changed INCLUDE to FIND_PACKAGE to read from users own non-system CMAKE_MODULE_PATH (Jan Woetzel JW)
|
||||||
|
# 07/2006: rewrite as FindwxWidgets.cmake, kept for backward compatibilty JW
|
||||||
|
|
||||||
|
MESSAGE(STATUS "Use_wxWindows.cmake is DEPRECATED. \n"
|
||||||
|
"Please use FIND_PACKAGE(wxWidgets) and INCLUDE(${wxWidgets_USE_FILE}) instead. (JW)")
|
||||||
|
|
||||||
|
|
||||||
INCLUDE(FindwxWindows)
|
# ------------------------
|
||||||
|
|
||||||
|
FIND_PACKAGE( wxWindows )
|
||||||
|
|
||||||
IF(WXWINDOWS_FOUND)
|
IF(WXWINDOWS_FOUND)
|
||||||
|
|
||||||
#MESSAGE("DBG Use_wxWindows.cmake: WXWINDOWS_INCLUDE_DIR=${WXWINDOWS_INCLUDE_DIR} WXWINDOWS_LINK_DIRECTORIES=${WXWINDOWS_LINK_DIRECTORIES} WXWINDOWS_LIBRARIES=${WXWINDOWS_LIBRARIES} CMAKE_WXWINDOWS_CXX_FLAGS=${CMAKE_WXWINDOWS_CXX_FLAGS} WXWINDOWS_DEFINITIONS=${WXWINDOWS_DEFINITIONS}")
|
#MESSAGE("DBG Use_wxWindows.cmake: WXWINDOWS_INCLUDE_DIR=${WXWINDOWS_INCLUDE_DIR} WXWINDOWS_LINK_DIRECTORIES=${WXWINDOWS_LINK_DIRECTORIES} WXWINDOWS_LIBRARIES=${WXWINDOWS_LIBRARIES} CMAKE_WXWINDOWS_CXX_FLAGS=${CMAKE_WXWINDOWS_CXX_FLAGS} WXWINDOWS_DEFINITIONS=${WXWINDOWS_DEFINITIONS}")
|
||||||
|
|
||||||
IF(WXWINDOWS_INCLUDE_DIR)
|
IF(WXWINDOWS_INCLUDE_DIR)
|
||||||
INCLUDE_DIRECTORIES(${WXWINDOWS_INCLUDE_DIR})
|
INCLUDE_DIRECTORIES(${WXWINDOWS_INCLUDE_DIR})
|
||||||
ENDIF(WXWINDOWS_INCLUDE_DIR)
|
ENDIF(WXWINDOWS_INCLUDE_DIR)
|
||||||
|
IF(WXWINDOWS_LINK_DIRECTORIES)
|
||||||
IF(WXWINDOWS_LINK_DIRECTORIES)
|
|
||||||
LINK_DIRECTORIES(${WXWINDOWS_LINK_DIRECTORIES})
|
LINK_DIRECTORIES(${WXWINDOWS_LINK_DIRECTORIES})
|
||||||
ENDIF(WXWINDOWS_LINK_DIRECTORIES)
|
ENDIF(WXWINDOWS_LINK_DIRECTORIES)
|
||||||
|
|
||||||
IF(WXWINDOWS_LIBRARIES)
|
IF(WXWINDOWS_LIBRARIES)
|
||||||
LINK_LIBRARIES(${WXWINDOWS_LIBRARIES})
|
LINK_LIBRARIES(${WXWINDOWS_LIBRARIES})
|
||||||
ENDIF(WXWINDOWS_LIBRARIES)
|
ENDIF(WXWINDOWS_LIBRARIES)
|
||||||
|
|
||||||
IF (CMAKE_WXWINDOWS_CXX_FLAGS)
|
IF (CMAKE_WXWINDOWS_CXX_FLAGS)
|
||||||
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_WXWINDOWS_CXX_FLAGS}")
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${CMAKE_WXWINDOWS_CXX_FLAGS}")
|
||||||
ENDIF(CMAKE_WXWINDOWS_CXX_FLAGS)
|
ENDIF(CMAKE_WXWINDOWS_CXX_FLAGS)
|
||||||
|
|
||||||
IF(WXWINDOWS_DEFINITIONS)
|
IF(WXWINDOWS_DEFINITIONS)
|
||||||
ADD_DEFINITIONS(${WXWINDOWS_DEFINITIONS})
|
ADD_DEFINITIONS(${WXWINDOWS_DEFINITIONS})
|
||||||
ENDIF(WXWINDOWS_DEFINITIONS)
|
ENDIF(WXWINDOWS_DEFINITIONS)
|
||||||
|
|
||||||
ELSE(WXWINDOWS_FOUND)
|
ELSE(WXWINDOWS_FOUND)
|
||||||
MESSAGE(SEND_ERROR "wxWindows not found by Use_wxWindows.cmake")
|
MESSAGE(SEND_ERROR "wxWindows not found by Use_wxWindows.cmake")
|
||||||
ENDIF(WXWINDOWS_FOUND)
|
ENDIF(WXWINDOWS_FOUND)
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,67 @@
|
||||||
# - Same as Use_wxWindows
|
# - Convenience include for using wxWidgets library
|
||||||
|
# Finds if wxWidgets is installed
|
||||||
|
# and set the appropriate libs, incdirs, flags etc.
|
||||||
|
# INCLUDE_DIRECTORIES, LINK_DIRECTORIES and ADD_DEFINITIONS
|
||||||
|
# are called.
|
||||||
#
|
#
|
||||||
|
# USAGE
|
||||||
|
# SET( wxWidgets_USE_LIBS gl xml xrc ) # optionally: more than wx std libs
|
||||||
|
# FIND_PACKAGE(wxWidgets REQUIRED)
|
||||||
|
# INCLUDE( ${xWidgets_USE_FILE} )
|
||||||
|
# ... add your targets here, e.g. ADD_EXECUTABLE/ ADD_LIBRARY ...
|
||||||
|
# TARGET_LINK_LIBRARIERS( <yourWxDependantTarget> ${wxWidgets_LIBRARIES})
|
||||||
|
#
|
||||||
|
# DEPRECATED
|
||||||
|
# LINK_LIBRARIES is not called in favor of adding dependencies per target.
|
||||||
|
#
|
||||||
|
# AUTHOR
|
||||||
|
# Jan Woetzel <jw -at- mip.informatik.uni-kiel.de>
|
||||||
|
|
||||||
INCLUDE(Use_wxWindows)
|
|
||||||
|
# debug message and logging.
|
||||||
|
# comment these out for distribution
|
||||||
|
IF (NOT LOGFILE )
|
||||||
|
# SET(LOGFILE "${PROJECT_BINARY_DIR}/CMakeOutput.log")
|
||||||
|
ENDIF (NOT LOGFILE )
|
||||||
|
MACRO(MSG _MSG)
|
||||||
|
# FILE(APPEND ${LOGFILE} "${CMAKE_CURRENT_LIST_FILE}(${CMAKE_CURRENT_LIST_LINE}): ${_MSG}\n")
|
||||||
|
# MESSAGE(STATUS "${CMAKE_CURRENT_LIST_FILE}(${CMAKE_CURRENT_LIST_LINE}): ${_MSG}")
|
||||||
|
ENDMACRO(MSG)
|
||||||
|
|
||||||
|
|
||||||
|
MSG("wxWidgets_FOUND=${wxWidgets_FOUND}")
|
||||||
|
IF (wxWidgets_FOUND)
|
||||||
|
IF (wxWidgets_INCLUDE_DIRS)
|
||||||
|
INCLUDE_DIRECTORIES( ${wxWidgets_INCLUDE_DIRS} )
|
||||||
|
MSG("wxWidgets_INCLUDE_DIRS=${wxWidgets_INCLUDE_DIRS}")
|
||||||
|
ENDIF(wxWidgets_INCLUDE_DIRS)
|
||||||
|
|
||||||
|
IF (wxWidgets_LIBRARY_DIRS)
|
||||||
|
LINK_DIRECTORIES(${wxWidgets_LIBRARY_DIRS})
|
||||||
|
MSG("wxWidgets_LIBRARY_DIRS=${wxWidgets_LIBRARY_DIRS}")
|
||||||
|
ENDIF(wxWidgets_LIBRARY_DIRS)
|
||||||
|
|
||||||
|
IF (wxWidgets_DEFINITIONS)
|
||||||
|
ADD_DEFINITIONS( ${wxWidgets_DEFINITIONS} )
|
||||||
|
MSG("wxWidgets_DEFINITIONS=${wxWidgets_DEFINITIONS}")
|
||||||
|
ENDIF(wxWidgets_DEFINITIONS)
|
||||||
|
|
||||||
|
IF (wxWidgets_CXX_FLAGS)
|
||||||
|
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${wxWidgets_CXX_FLAGS}")
|
||||||
|
MSG("wxWidgets_CXX_FLAGS=${wxWidgets_CXX_FLAGS}")
|
||||||
|
ENDIF(wxWidgets_CXX_FLAGS)
|
||||||
|
|
||||||
|
# DEPRECATED JW
|
||||||
|
# just for backward compatibility: add deps to all targets
|
||||||
|
# library projects better use advanced FIND_PACKAGE(wxWidgets) directly.
|
||||||
|
#IF(wxWidgets_LIBRARIES)
|
||||||
|
# LINK_LIBRARIES(${wxWidgets_LIBRARIES})
|
||||||
|
# # BUG: str too long: MSG("wxWidgets_LIBRARIES=${wxWidgets_LIBRARIES}")
|
||||||
|
# IF(LOGFILE)
|
||||||
|
# FILE(APPEND ${LOGFILE} "${CMAKE_CURRENT_LIST_FILE}(${CMAKE_CURRENT_LIST_LINE}): ${wxWidgets_LIBRARIES}\n")
|
||||||
|
# ENDIF(LOGFILE)
|
||||||
|
#ENDIF(wxWidgets_LIBRARIES)
|
||||||
|
|
||||||
|
ELSE (wxWidgets_FOUND)
|
||||||
|
MESSAGE("wxWidgets requested but not found.")
|
||||||
|
ENDIF(wxWidgets_FOUND)
|
||||||
|
|
|
@ -326,11 +326,11 @@ IF(BUILD_MFCDialog)
|
||||||
ENDIF(BUILD_MFCDialog)
|
ENDIF(BUILD_MFCDialog)
|
||||||
|
|
||||||
# WX Widgets GUI
|
# WX Widgets GUI
|
||||||
OPTION(CMAKE_BUILD_WX_DIALOG "Build wxWidgets dialog for CMake" FALSE)
|
OPTION(BUILD_WXDialog "Build wxWidgets dialog for CMake" FALSE)
|
||||||
MARK_AS_ADVANCED(CMAKE_BUILD_WX_DIALOG)
|
MARK_AS_ADVANCED(BUILD_WXDialog)
|
||||||
IF(CMAKE_BUILD_WX_DIALOG)
|
IF(BUILD_WXDialog)
|
||||||
SUBDIRS(WXDialog)
|
SUBDIRS(WXDialog)
|
||||||
ENDIF(CMAKE_BUILD_WX_DIALOG)
|
ENDIF(BUILD_WXDialog)
|
||||||
|
|
||||||
# Testing
|
# Testing
|
||||||
IF (NOT DART_ROOT)
|
IF (NOT DART_ROOT)
|
||||||
|
@ -1076,9 +1076,8 @@ IF(BUILD_TESTING)
|
||||||
ENDIF(JAVA_COMPILE AND JAVA_RUNTIME AND JAVA_ARCHIVE AND NOT MINGW)
|
ENDIF(JAVA_COMPILE AND JAVA_RUNTIME AND JAVA_ARCHIVE AND NOT MINGW)
|
||||||
ENDIF(NOT CMAKE_TEST_GENERATOR MATCHES "Xcode")
|
ENDIF(NOT CMAKE_TEST_GENERATOR MATCHES "Xcode")
|
||||||
|
|
||||||
|
IF(BUILD_WXDialog AND wxWidgets_CONFIG_EXECUTABLE)
|
||||||
IF (CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE OR WXWINDOWS_INCLUDE_DIR)
|
# Will be set if the WX gui is on
|
||||||
# Will be set if the wxwindows gui is on
|
|
||||||
ADD_TEST(UseWX ${CMAKE_CTEST_COMMAND}
|
ADD_TEST(UseWX ${CMAKE_CTEST_COMMAND}
|
||||||
--build-and-test
|
--build-and-test
|
||||||
"${CMake_SOURCE_DIR}/Tests/UseWX"
|
"${CMake_SOURCE_DIR}/Tests/UseWX"
|
||||||
|
@ -1086,11 +1085,11 @@ IF(BUILD_TESTING)
|
||||||
--build-generator ${CMAKE_TEST_GENERATOR}
|
--build-generator ${CMAKE_TEST_GENERATOR}
|
||||||
--build-makeprogram ${CMAKE_TEST_MAKEPROGRAM}
|
--build-makeprogram ${CMAKE_TEST_MAKEPROGRAM}
|
||||||
--build-exe-dir ${CMake_BINARY_DIR}/Tests/UseWX
|
--build-exe-dir ${CMake_BINARY_DIR}/Tests/UseWX
|
||||||
--build-project UsewxWindows
|
--build-project UsewxWidgets
|
||||||
--build-options -DCMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE:FILEPATH=${CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE}
|
--build-options -DwxWidgets_CONFIG_EXECUTABLE=${wxWidgets_CONFIG_EXECUTABLE}
|
||||||
--test-command UseWX
|
--test-command UseWX
|
||||||
)
|
)
|
||||||
ENDIF (CMAKE_WXWINDOWS_WXCONFIG_EXECUTABLE OR WXWINDOWS_INCLUDE_DIR)
|
ENDIF(BUILD_WXDialog AND wxWidgets_CONFIG_EXECUTABLE)
|
||||||
|
|
||||||
IF(UNIX)
|
IF(UNIX)
|
||||||
STRING(COMPARE EQUAL "${CMAKE_INSTALL_PREFIX}" "${CMake_BINARY_DIR}/Tests/TestShellInstall/Prefix"
|
STRING(COMPARE EQUAL "${CMAKE_INSTALL_PREFIX}" "${CMake_BINARY_DIR}/Tests/TestShellInstall/Prefix"
|
||||||
|
|
|
@ -9,88 +9,79 @@
|
||||||
## License: wxWidgets License
|
## License: wxWidgets License
|
||||||
##---------------------------------------------------------------------------
|
##---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# wxWindows -> wxWidgets Jan Woetzel 07/2006
|
||||||
|
# tested with wx 2.6.3 with "multilib" build on Windows XP
|
||||||
|
|
||||||
#wxWidgets build related stuff
|
# CMake Options
|
||||||
SET(WXW_USE_DEBUG OFF)
|
|
||||||
SET(WXW_USE_UNICODE OFF)
|
|
||||||
SET(WXW_USE_SHARED OFF)
|
|
||||||
SET(WXW_USE_UNIV OFF)
|
|
||||||
SET(WXW_USE_MONO OFF)
|
|
||||||
SET(WXW_FILE_VERSION "26")
|
|
||||||
SET(WXW_VERSION "2.6")
|
|
||||||
|
|
||||||
#CMake Options
|
|
||||||
SET(CMAKE_VERBOSE_MAKEFILE TRUE)
|
SET(CMAKE_VERBOSE_MAKEFILE TRUE)
|
||||||
|
|
||||||
IF(WIN32)
|
# suppress wx header warnings?
|
||||||
INCLUDE (${CMAKE_SOURCE_DIR}/Source/WXDialog/bin/FindwxW.cmake)
|
#SET(HAVE_ISYSTEM 1)
|
||||||
ELSE(WIN32)
|
|
||||||
INCLUDE (${CMAKE_SOURCE_DIR}/Source/WXDialog/bin/FindwxWin.cmake)
|
|
||||||
|
|
||||||
# sync flags
|
|
||||||
SET(WXWIDGETS_FOUND ${WXWINDOWS_FOUND})
|
|
||||||
SET(WXWIDGETS_INCLUDE_DIR ${WXWINDOWS_INCLUDE_DIR})
|
|
||||||
SET(WXWIDGETS_LINK_DIRECTORIES ${WXWINDOWS_LINK_DIRECTORIES})
|
|
||||||
SET(WXWIDGETS_LIBRARIES ${WXWINDOWS_LIBRARIES})
|
|
||||||
ENDIF(WIN32)
|
|
||||||
|
|
||||||
# Old find script
|
# in addition to wx std libs we need
|
||||||
|
SET( wxWidgets_USE_LIBS
|
||||||
|
std
|
||||||
|
html adv xml xrc )
|
||||||
|
FIND_PACKAGE(wxWidgets REQUIRED)
|
||||||
|
#INCLUDE(${CMAKE_ROOT}/Modules/FindwxWidgets.cmake)
|
||||||
|
|
||||||
## Start using wx stuff when it is fully found and set
|
# Start using wx stuff when it is fully found and set
|
||||||
IF(WXWIDGETS_FOUND)
|
IF(wxWidgets_FOUND)
|
||||||
|
INCLUDE( ${wxWidgets_USE_FILE} )
|
||||||
|
|
||||||
SET (CMAKE_SRCS
|
SET (CMAKE_SRCS
|
||||||
CMakeSetupFrame.cpp
|
CMakeSetupFrame.cpp
|
||||||
CMakeSetup.cpp
|
CMakeSetup.cpp
|
||||||
CMakeSetupFrame.h
|
CMakeSetupFrame.h
|
||||||
CMakeSetup.h
|
CMakeSetup.h
|
||||||
PropertyList.cpp
|
PropertyList.cpp
|
||||||
PropertyList.h
|
PropertyList.h
|
||||||
app_resources.cpp
|
app_resources.cpp
|
||||||
app_resources.h
|
app_resources.h
|
||||||
progressdlg.cpp
|
progressdlg.cpp
|
||||||
progressdlg.h
|
progressdlg.h
|
||||||
aboutdlg.cpp
|
aboutdlg.cpp
|
||||||
aboutdlg.h
|
aboutdlg.h
|
||||||
optionsdlg.cpp
|
optionsdlg.cpp
|
||||||
optionsdlg.h
|
optionsdlg.h
|
||||||
config.h
|
config.h
|
||||||
CommandLineInfo.cpp
|
CommandLineInfo.cpp
|
||||||
CommandLineInfo.h )
|
CommandLineInfo.h )
|
||||||
|
|
||||||
# include .rc when windows
|
# include .rc when windows
|
||||||
|
IF(WIN32)
|
||||||
IF(WIN32)
|
SET ( CMAKE_SRCS ${CMAKE_SRCS} CMakeSetup.rc )
|
||||||
SET ( CMAKE_SRCS
|
ENDIF(WIN32)
|
||||||
${CMAKE_SRCS}
|
|
||||||
CMakeSetup.rc )
|
INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/Source/WXDialog
|
||||||
ENDIF(WIN32)
|
${wxWidgets_INCLUDE_DIR} )
|
||||||
|
LINK_DIRECTORIES( ${wxWidgets_LINK_DIRECTORIES}
|
||||||
INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/Source/WXDialog
|
${CMake_BINARY_DIR}/Source
|
||||||
${WXWIDGETS_INCLUDE_DIR})
|
${CMake_BINARY_DIR}/Source/kwsys )
|
||||||
LINK_DIRECTORIES( ${WXWIDGETS_LINK_DIRECTORIES} ${CMake_BINARY_DIR}/Source ${CMake_BINARY_DIR}/Source/kwsys )
|
|
||||||
IF(APPLE)
|
IF(APPLE)
|
||||||
ADD_EXECUTABLE(WXDialog MACOSX_BUNDLE ${CMAKE_SRCS})
|
ADD_EXECUTABLE(WXDialog MACOSX_BUNDLE ${CMAKE_SRCS})
|
||||||
ELSE(APPLE)
|
ELSE(APPLE)
|
||||||
ADD_EXECUTABLE(WXDialog WIN32 ${CMAKE_SRCS})
|
ADD_EXECUTABLE(WXDialog WIN32 ${CMAKE_SRCS})
|
||||||
ENDIF(APPLE)
|
ENDIF(APPLE)
|
||||||
INSTALL_TARGETS(/bin WXDialog)
|
INSTALL_TARGETS(/bin WXDialog)
|
||||||
SET(CMAKE_CXX_FLAGS "${CMAKE_WX_CXX_FLAGS}")
|
|
||||||
SET(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -D__WXDEBUG__ -DWXDEBUG=1")
|
# not required on MSVS beause bound to _DEBUG,
|
||||||
|
# but other compiler may need it.
|
||||||
IF(LINUX)
|
# However, the define prevents multiple build configurations
|
||||||
ADD_DEFINITIONS( -DLINUX=1 )
|
# in one build tree,
|
||||||
ENDIF(LINUX)
|
# e.g. MSVS supports Debug;Release
|
||||||
|
# TODO: shall we add the define or not -
|
||||||
# if the checkbox view functionality is not desired,
|
# favor multi config or all compilers? (JW)
|
||||||
# exclude this part from the smple
|
SET(CMAKE_CXX_FLAGS_DEBUG
|
||||||
SET(WXWIDGETS_LIBRARIES ${WXWIDGETS_LIBRARIES})
|
"${CMAKE_CXX_FLAGS_DEBUG} -D__WXDEBUG__ -DWXDEBUG=1")
|
||||||
TARGET_LINK_LIBRARIES(WXDialog ${WXWIDGETS_LIBRARIES} cmsys CMakeLib)
|
|
||||||
|
IF(LINUX)
|
||||||
# if UPX is found, make a target
|
ADD_DEFINITIONS( -DLINUX=1 )
|
||||||
|
ENDIF(LINUX)
|
||||||
#INCLUDE (${CMAKE_SOURCE_DIR}/Source/WXDialog/bin/FindUPX.cmake)
|
|
||||||
#IF(UPX_FOUND)
|
# if the checkbox view functionality is not desired,
|
||||||
#END(UPX_FOUND)
|
# exclude this part from the smple
|
||||||
|
TARGET_LINK_LIBRARIES(WXDialog ${wxWidgets_LIBRARIES} cmsys CMakeLib)
|
||||||
ENDIF(WXWIDGETS_FOUND)
|
|
||||||
|
ENDIF(wxWidgets_FOUND)
|
||||||
|
|
|
@ -5,14 +5,11 @@
|
||||||
# UPX_FOUND Is set to 1 when upx is found
|
# UPX_FOUND Is set to 1 when upx is found
|
||||||
|
|
||||||
FIND_PATH(UPX_PROGRAM_PATH upx.exe
|
FIND_PATH(UPX_PROGRAM_PATH upx.exe
|
||||||
"c:\Program Files\upx"
|
${UPX_DIR}
|
||||||
"d:\Program Files\upx"
|
$ENV{UPX_DIR}
|
||||||
"e:\Program Files\upx"
|
"$ENV{ProgramFiles}/upx"
|
||||||
"f:\Program Files\upx"
|
|
||||||
"g:\Program Files\upx"
|
|
||||||
"h:\Program Files\upx"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# when found, note this as target
|
# when found, note this as target
|
||||||
IF(UPX_PROGRAM_PATH)
|
IF(UPX_PROGRAM_PATH)
|
||||||
SET(UPX_FOUND 1)
|
SET(UPX_FOUND 1)
|
||||||
|
|
|
@ -1,3 +1,6 @@
|
||||||
|
|
||||||
|
MESSAGE("${CMAKE_CURRENT_FILE} is deprecated, please use FindwxWidgets.cmake instead.")
|
||||||
|
|
||||||
#
|
#
|
||||||
# FindwxW.cmake
|
# FindwxW.cmake
|
||||||
# v1.01 2005-05-27
|
# v1.01 2005-05-27
|
||||||
|
@ -14,6 +17,7 @@
|
||||||
# WXWIDGETS_INCLUDE_DIR = all include path of wxWindows
|
# WXWIDGETS_INCLUDE_DIR = all include path of wxWindows
|
||||||
# WXWIDGETS_DEFINITIONS = all flags of wxWindows
|
# WXWIDGETS_DEFINITIONS = all flags of wxWindows
|
||||||
|
|
||||||
|
|
||||||
# NOTE: This module REQUIRES that an environment variable named WXWIN
|
# NOTE: This module REQUIRES that an environment variable named WXWIN
|
||||||
# be set to the base wxWidgets installation directory.
|
# be set to the base wxWidgets installation directory.
|
||||||
# Under Unix, you must also set and environment variable named WXWINCFG
|
# Under Unix, you must also set and environment variable named WXWINCFG
|
||||||
|
|
|
@ -1,3 +1,8 @@
|
||||||
|
|
||||||
|
|
||||||
|
MESSAGE("${CMAKE_CURRENT_FILE} is deprecated, please use FindwxWidgets.cmake instead.")
|
||||||
|
|
||||||
|
|
||||||
##---------------------------------------------------------------------------
|
##---------------------------------------------------------------------------
|
||||||
## $RCSfile$
|
## $RCSfile$
|
||||||
## $Source$
|
## $Source$
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
|
||||||
|
MESSAGE("${CMAKE_CURRENT_FILE} is deprecated, please use FindwxWidgets.cmake instead.")
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# UsewxW.cmake
|
# UsewxW.cmake
|
||||||
# v1.0 2005-05-27
|
# v1.0 2005-05-27
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
PROJECT (UsewxWindows)
|
PROJECT (UsewxWidgets)
|
||||||
|
|
||||||
INCLUDE( ${CMAKE_ROOT}/Modules/Use_wxWindows.cmake)
|
FIND_PACKAGE(wxWidgets REQUIRED)
|
||||||
|
INCLUDE( ${wxWidgets_USE_FILE} )
|
||||||
|
|
||||||
ADD_EXECUTABLE (UseWX WIN32 WX.cxx)
|
ADD_EXECUTABLE (UseWX WIN32 WX.cxx)
|
||||||
|
TARGET_LINK_LIBRARIES(UseWX ${wxWidgets_LIBRARIES} )
|
||||||
#TODO:
|
|
||||||
#- dll linking is not working on WIN32, need to '-DWXUSINGDLL' to preprocessor
|
|
||||||
|
|
||||||
|
|
|
@ -51,9 +51,13 @@ bool MyApp::OnInit()
|
||||||
|
|
||||||
//Testing if link to wx debug library
|
//Testing if link to wx debug library
|
||||||
#ifdef __WXDEBUG__
|
#ifdef __WXDEBUG__
|
||||||
printf("If you read this you're in debug mode.\n");
|
printf("If you read this you're in __WXDEBUG__ debug mode.\n");
|
||||||
#endif //__WXDEBUG__
|
#endif //__WXDEBUG__
|
||||||
|
|
||||||
|
#ifdef _DEBUG
|
||||||
|
printf("If you read this then _DEBUG is defined.\n");
|
||||||
|
#endif //_DEBUG
|
||||||
|
|
||||||
wxChar ch = wxT('*');
|
wxChar ch = wxT('*');
|
||||||
wxString s = wxT("Hello, world!");
|
wxString s = wxT("Hello, world!");
|
||||||
int len = s.Len();
|
int len = s.Len();
|
||||||
|
|
Loading…
Reference in New Issue