summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorManolo Gouy <Manolo>2015-04-08 11:37:14 +0000
committerManolo Gouy <Manolo>2015-04-08 11:37:14 +0000
commit4b5b11a1cb0ecc8c2dc557cb87f897aa0fc1e1d5 (patch)
treec2db9a2038473a10c5c9da2addc623efde048e19
parentab78d7ee61b4d2bbfb8210fee4e7ba64c81f3b4c (diff)
CMake building on Mac OS: use a simpler way to put files within app bundles.
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3@10688 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
-rw-r--r--CMake/macros.cmake28
-rw-r--r--test/CMakeLists.txt9
2 files changed, 16 insertions, 21 deletions
diff --git a/CMake/macros.cmake b/CMake/macros.cmake
index ef45bc034..623104d9a 100644
--- a/CMake/macros.cmake
+++ b/CMake/macros.cmake
@@ -103,22 +103,17 @@ macro(CREATE_EXAMPLE NAME SOURCES LIBRARIES)
endif(flsrcs)
if(APPLE)
- unset(RESOURCE_PATH)
+ unset(ICON_NAME)
if(${tname} STREQUAL "blocks" OR ${tname} STREQUAL "checkers" OR ${tname} STREQUAL "sudoku")
set( ICON_NAME ${tname}.icns )
- set( RESOURCE_PATH "${PROJECT_SOURCE_DIR}/test/${tname}.app/Contents/Resources/${ICON_NAME}" )
- elseif(${tname} STREQUAL "demo")
- set( RESOURCE_PATH "${PROJECT_SOURCE_DIR}/test/demo.menu" )
endif(${tname} STREQUAL "blocks" OR ${tname} STREQUAL "checkers" OR ${tname} STREQUAL "sudoku")
-
- if(DEFINED RESOURCE_PATH)
- add_executable(${tname} MACOSX_BUNDLE ${srcs} ${RESOURCE_PATH})
- if(${tname} STREQUAL "demo")
- target_compile_definitions(demo PUBLIC USING_XCODE)
- endif(${tname} STREQUAL "demo")
- else()
- add_executable(${tname} MACOSX_BUNDLE ${srcs} ${${tname}_FLTK_UI_SRCS})
- endif(DEFINED RESOURCE_PATH)
+ add_executable(${tname} MACOSX_BUNDLE ${srcs} ${${tname}_FLTK_UI_SRCS})
+ if(DEFINED ICON_NAME)
+ set_target_properties(${tname} PROPERTIES MACOSX_BUNDLE_ICON_FILE ${ICON_NAME})
+ endif(DEFINED ICON_NAME)
+ if(${tname} STREQUAL "demo")
+ target_compile_definitions(demo PUBLIC USING_XCODE)
+ endif(${tname} STREQUAL "demo")
else()
add_executable(${tname} WIN32 ${srcs} ${${tname}_FLTK_UI_SRCS})
endif(APPLE)
@@ -126,13 +121,6 @@ macro(CREATE_EXAMPLE NAME SOURCES LIBRARIES)
set_target_properties(${tname}
PROPERTIES OUTPUT_NAME ${oname}
)
- if(APPLE AND DEFINED RESOURCE_PATH)
- if(NOT ${tname} STREQUAL "demo")
- set_target_properties(${tname} PROPERTIES MACOSX_BUNDLE_ICON_FILE ${ICON_NAME})
- endif(NOT ${tname} STREQUAL "demo")
- set_target_properties(${tname} PROPERTIES RESOURCE ${RESOURCE_PATH})
- endif(APPLE AND DEFINED RESOURCE_PATH)
-
target_link_libraries(${tname} ${LIBRARIES})
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 82d67e27b..ec924d827 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -110,7 +110,14 @@ endif(FLTK_HAVE_CAIRO)
# - maybe more ...
# use a target filename to make sure the target directory gets created
-configure_file(demo.menu ${EXECUTABLE_OUTPUT_PATH}/demo.menu COPYONLY)
+if(APPLE) #copy files to bundle resources
+ configure_file(demo.menu ${EXECUTABLE_OUTPUT_PATH}/demo.app/Contents/Resources/demo.menu COPYONLY)
+ configure_file(blocks.app/Contents/Resources/blocks.icns ${EXECUTABLE_OUTPUT_PATH}/blocks.app/Contents/Resources/blocks.icns COPYONLY)
+ configure_file(checkers.app/Contents/Resources/checkers.icns ${EXECUTABLE_OUTPUT_PATH}/checkers.app/Contents/Resources/checkers.icns COPYONLY)
+ configure_file(sudoku.app/Contents/Resources/sudoku.icns ${EXECUTABLE_OUTPUT_PATH}/sudoku.app/Contents/Resources/sudoku.icns COPYONLY)
+else()
+ configure_file(demo.menu ${EXECUTABLE_OUTPUT_PATH}/demo.menu COPYONLY)
+endif(APPLE)
# use target directory only to avoid redundancy
configure_file(rgb.txt ${EXECUTABLE_OUTPUT_PATH} COPYONLY)