diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2005-10-28 21:46:44 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2005-10-28 21:46:44 (GMT) |
commit | 18d9adde9649fee733ceb6f464fbc6f2b71daa6c (patch) | |
tree | 5562f7330775a6252d367a70d6d66a3f59a92759 /Modules/FindSDL_ttf.cmake | |
parent | c78df4615355431db6b50c750258f3a5975b9321 (diff) | |
download | CMake-18d9adde9649fee733ceb6f464fbc6f2b71daa6c.zip CMake-18d9adde9649fee733ceb6f464fbc6f2b71daa6c.tar.gz CMake-18d9adde9649fee733ceb6f464fbc6f2b71daa6c.tar.bz2 |
ENH: changes from Eric Wing, bug 2249
Diffstat (limited to 'Modules/FindSDL_ttf.cmake')
-rw-r--r-- | Modules/FindSDL_ttf.cmake | 45 |
1 files changed, 36 insertions, 9 deletions
diff --git a/Modules/FindSDL_ttf.cmake b/Modules/FindSDL_ttf.cmake index 52d52b1..5523cf9 100644 --- a/Modules/FindSDL_ttf.cmake +++ b/Modules/FindSDL_ttf.cmake @@ -16,35 +16,62 @@ # People will have to manually change the cache values of # SDLTTF_LIBRARY to override this selection. FIND_PATH(SDLTTF_INCLUDE_DIR SDL_ttf.h + $ENV{SDLTTFDIR}/include + $ENV{SDLDIR}/include ~/Library/Frameworks/SDL_ttf.framework/Headers /Library/Frameworks/SDL_ttf.framework/Headers - $ENV{SDLDIR}/include - $ENV{SDLTTFDIR}/include + /usr/local/include/SDL /usr/include/SDL + /usr/local/include/SDL12 + /usr/local/include/SDL11 # FreeBSD ports /usr/include/SDL12 /usr/include/SDL11 - /usr/include - /usr/local/include/SDL - /usr/local/include/SDL12 - /usr/local/include/SDL11 /usr/local/include + /usr/include + /sw/include/SDL # Fink /sw/include + /opt/local/include/SDL # DarwinPorts + /opt/local/include + /opt/csw/include/SDL # Blastwave + /opt/csw/include + /opt/include/SDL + /opt/include ) # I'm not sure if I should do a special casing for Apple. It is # unlikely that other Unix systems will find the framework path. # But if they do ([Next|Open|GNU]Step?), # do they want the -framework option also? IF(${SDLTTF_INCLUDE_DIR} MATCHES ".framework") - SET (SDLTTF_LIBRARY "-framework SDL_ttf" CACHE STRING "SDL_ttf framework for OSX") + # Extract the path the framework resides in so we can use it for the -F flag + STRING(REGEX REPLACE "(.*)/.*\\.framework/.*" "\\1" SDLTTF_FRAMEWORK_PATH_TEMP ${SDLTTF_INCLUDE_DIR}) + IF("${SDLTTF_FRAMEWORK_PATH_TEMP}" STREQUAL "/Library/Frameworks" + OR "${SDLTTF_FRAMEWORK_PATH_TEMP}" STREQUAL "/System/Library/Frameworks" + ) + # String is in default search path, don't need to use -F + SET(SDLTTF_LIBRARY "-framework SDL_ttf" CACHE STRING "SDL_ttf framework for OSX") + ELSE("${SDLTTF_FRAMEWORK_PATH_TEMP}" STREQUAL "/Library/Frameworks" + OR "${SDLTTF_FRAMEWORK_PATH_TEMP}" STREQUAL "/System/Library/Frameworks" + ) + # String is not /Library/Frameworks, need to use -F + SET(SDLTTF_LIBRARY "-F${SDLTTF_FRAMEWORK_PATH_TEMP} -framework SDL_ttf" CACHE STRING "SDL_ttf framework for OSX") + ENDIF("${SDLTTF_FRAMEWORK_PATH_TEMP}" STREQUAL "/Library/Frameworks" + OR "${SDLTTF_FRAMEWORK_PATH_TEMP}" STREQUAL "/System/Library/Frameworks" + ) + # Clear the temp variable so nobody can see it + SET(SDLTTF_FRAMEWORK_PATH_TEMP "" CACHE INTERNAL "") + ELSE(${SDLTTF_INCLUDE_DIR} MATCHES ".framework") FIND_LIBRARY(SDLTTF_LIBRARY NAMES SDL_ttf PATHS - $ENV{SDLDIR}/lib $ENV{SDLTTFDIR}/lib - /usr/lib + $ENV{SDLDIR}/lib /usr/local/lib + /usr/lib /sw/lib + /opt/local/lib + /opt/csw/lib + /opt/lib ) ENDIF(${SDLTTF_INCLUDE_DIR} MATCHES ".framework") |