[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [41947] trunk/blender/source/creator/ CMakeLists.txt: centralize some of the came install commands, were being copied between osx/win/linux
Campbell Barton
ideasman42 at gmail.com
Thu Nov 17 19:23:35 CET 2011
Revision: 41947
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=41947
Author: campbellbarton
Date: 2011-11-17 18:23:34 +0000 (Thu, 17 Nov 2011)
Log Message:
-----------
centralize some of the came install commands, were being copied between osx/win/linux
Modified Paths:
--------------
trunk/blender/source/creator/CMakeLists.txt
Modified: trunk/blender/source/creator/CMakeLists.txt
===================================================================
--- trunk/blender/source/creator/CMakeLists.txt 2011-11-17 17:25:26 UTC (rev 41946)
+++ trunk/blender/source/creator/CMakeLists.txt 2011-11-17 18:23:34 UTC (rev 41947)
@@ -233,10 +233,6 @@
set(TARGETDIR ${EXECUTABLE_OUTPUT_PATH})
endif()
-
-# -----------------------------------------------------------------------------
-# Install Targets
-
set(BLENDER_TEXT_FILES
${CMAKE_SOURCE_DIR}/release/text/GPL-license.txt
${CMAKE_SOURCE_DIR}/release/text/Python-license.txt
@@ -244,8 +240,11 @@
${CMAKE_SOURCE_DIR}/release/text/readme.html
)
-if(UNIX AND NOT APPLE)
+# -----------------------------------------------------------------------------
+# Platform Spesific Var: TARGETDIR_VER
+
+if(UNIX AND NOT APPLE)
if(WITH_INSTALL_PORTABLE)
set(TARGETDIR_VER ${TARGETDIR}/${BLENDER_VERSION})
else()
@@ -256,19 +255,61 @@
endif()
endif()
- # important to make a clean install each time
- # else old scripts get loaded.
+elseif(WIN32)
+ set(TARGETDIR_VER ${TARGETDIR}/${BLENDER_VERSION})
+
+elseif(APPLE)
+ set(TARGETDIR_VER ${TARGETDIR}/blender.app/Contents/MacOS/${BLENDER_VERSION})
+
+endif()
+
+
+# -----------------------------------------------------------------------------
+# Install Targets (Generic, All Platforms)
+
+
+# important to make a clean install each time, else old scripts get loaded.
+install(
+ CODE
+ "file(REMOVE_RECURSE ${TARGETDIR_VER})"
+)
+
+if(WITH_PYTHON)
+ # install(CODE "message(\"copying blender scripts...\")")
install(
- CODE
- "file(REMOVE_RECURSE ${TARGETDIR_VER})"
+ DIRECTORY ${CMAKE_SOURCE_DIR}/release/scripts
+ DESTINATION ${TARGETDIR_VER}
+ PATTERN ".svn" EXCLUDE
+ PATTERN "__pycache__" EXCLUDE
)
+endif()
+# localization
+if(WITH_INTERNATIONAL)
+ install(
+ DIRECTORY
+ ${CMAKE_SOURCE_DIR}/release/datafiles/locale
+ ${CMAKE_SOURCE_DIR}/release/datafiles/fonts
+ DESTINATION ${TARGETDIR_VER}/datafiles
+ PATTERN ".svn" EXCLUDE
+ )
+endif()
+
+# helpful tip when using make
+if("${CMAKE_GENERATOR}" MATCHES ".*Makefiles.*")
# message after building.
add_custom_command(
TARGET blender POST_BUILD MAIN_DEPENDENCY blender
COMMAND ${CMAKE_COMMAND} -E echo 'now run: \"make install\" to copy runtime files & scripts to ${TARGETDIR_VER}'
)
+endif()
+
+# -----------------------------------------------------------------------------
+# Install Targets (Platform Specific)
+
+if(UNIX AND NOT APPLE)
+
# there are a few differences between portable and system install
if(WITH_INSTALL_PORTABLE)
install(
@@ -348,16 +389,6 @@
)
endif()
- if(WITH_INTERNATIONAL)
- install(
- DIRECTORY
- ${CMAKE_SOURCE_DIR}/release/datafiles/locale
- ${CMAKE_SOURCE_DIR}/release/datafiles/fonts
- DESTINATION ${TARGETDIR_VER}/datafiles
- PATTERN ".svn" EXCLUDE
- )
- endif()
-
# plugins in blender 2.5 don't work at the moment.
#
# install(
@@ -367,14 +398,6 @@
# )
if(WITH_PYTHON)
- # install(CODE "message(\"copying blender scripts...\")")
- install(
- DIRECTORY ${CMAKE_SOURCE_DIR}/release/scripts
- DESTINATION ${TARGETDIR_VER}
- PATTERN ".svn" EXCLUDE
- PATTERN "__pycache__" EXCLUDE
- )
-
if(WITH_PYTHON_INSTALL)
# Copy the systems python into the install directory
# Scons copy in tools/Blender.py
@@ -403,28 +426,13 @@
endif()
elseif(WIN32)
- set(TARGETDIR_VER ${TARGETDIR}/${BLENDER_VERSION})
-
- install( # same as linux!, deduplicate
- CODE
- "file(REMOVE_RECURSE ${TARGETDIR_VER})"
- )
-
- install( # same as linux!, deduplicate
+ install(
FILES ${BLENDER_TEXT_FILES}
DESTINATION ${TARGETDIR}
)
- if(WITH_INTERNATIONAL) # same as linux!, deduplicate
+ if(WITH_INTERNATIONAL)
install(
- DIRECTORY
- ${CMAKE_SOURCE_DIR}/release/datafiles/locale
- ${CMAKE_SOURCE_DIR}/release/datafiles/fonts
- DESTINATION ${TARGETDIR_VER}/datafiles
- PATTERN ".svn" EXCLUDE
- )
-
- install(
FILES ${LIBDIR}/gettext/lib/gnu_gettext.dll
DESTINATION ${TARGETDIR}
)
@@ -446,13 +454,6 @@
# )
if(WITH_PYTHON)
- # install(CODE "message(\"copying blender scripts...\")")
- install( # same as linux!, deduplicate
- DIRECTORY ${CMAKE_SOURCE_DIR}/release/scripts
- DESTINATION ${TARGETDIR_VER}
- PATTERN ".svn" EXCLUDE
- PATTERN "__pycache__" EXCLUDE
- )
install(
FILES ${LIBDIR}/python/lib/python32.dll
@@ -584,30 +585,7 @@
endif()
elseif(APPLE)
- set(SOURCEDIR ${CMAKE_SOURCE_DIR}/source/darwin/blender.app)
- set(SOURCEINFO ${SOURCEDIR}/Contents/Info.plist)
- set(TARGETDIR_VER ${TARGETDIR}/blender.app/Contents/MacOS/${BLENDER_VERSION})
- # setup Info.plist
- execute_process(COMMAND date "+%Y-%m-%d" OUTPUT_VARIABLE BLENDER_DATE OUTPUT_STRIP_TRAILING_WHITESPACE)
-
- set_target_properties(blender PROPERTIES
- MACOSX_BUNDLE_INFO_PLIST ${SOURCEINFO}
- MACOSX_BUNDLE_SHORT_VERSION_STRING ${BLENDER_VERSION}
- MACOSX_BUNDLE_LONG_VERSION_STRING "${BLENDER_VERSION} ${BLENDER_DATE}")
-
- # important to make a clean install each time else old scripts get loaded.
- install(
- CODE
- "file(REMOVE_RECURSE ${TARGETDIR_VER})"
- )
-
- # message after building.
- add_custom_command(
- TARGET blender POST_BUILD MAIN_DEPENDENCY blender
- COMMAND ${CMAKE_COMMAND} -E echo 'now run: \"make install\" to copy runtime files & scripts to ${TARGETDIR_VER}'
- )
-
# handy install macro to exclude files, we use \$ escape for the "to"
# argument when calling so ${BUILD_TYPE} does not get expanded
macro(install_dir from to)
@@ -625,6 +603,17 @@
)
endmacro()
+ set(OSX_APP_SOURCEDIR ${CMAKE_SOURCE_DIR}/source/darwin/blender.app)
+
+ # setup Info.plist
+ execute_process(COMMAND date "+%Y-%m-%d" OUTPUT_VARIABLE BLENDER_DATE OUTPUT_STRIP_TRAILING_WHITESPACE)
+
+ set_target_properties(blender PROPERTIES
+ MACOSX_BUNDLE_INFO_PLIST ${OSX_APP_SOURCEDIR}/Contents/Info.plist
+ MACOSX_BUNDLE_SHORT_VERSION_STRING ${BLENDER_VERSION}
+ MACOSX_BUNDLE_LONG_VERSION_STRING "${BLENDER_VERSION} ${BLENDER_DATE}")
+
+
# install release and app files
install(
FILES ${BLENDER_TEXT_FILES}
@@ -632,26 +621,15 @@
)
install(
- FILES ${SOURCEDIR}/Contents/PkgInfo
+ FILES ${OSX_APP_SOURCEDIR}/Contents/PkgInfo
DESTINATION ${TARGETDIR}/blender.app/Contents
)
install_dir(
- ${SOURCEDIR}/Contents/Resources
+ ${OSX_APP_SOURCEDIR}/Contents/Resources
\${TARGETDIR}/blender.app/Contents/
)
- # localization
- if(WITH_INTERNATIONAL)
- install(
- DIRECTORY
- ${CMAKE_SOURCE_DIR}/release/datafiles/locale
- ${CMAKE_SOURCE_DIR}/release/datafiles/fonts
- DESTINATION ${TARGETDIR_VER}/datafiles
- PATTERN ".svn" EXCLUDE
- )
- endif()
-
# python
if(WITH_PYTHON)
# the python zip is first extract as part of the build process,
@@ -678,18 +656,13 @@
\${TARGETDIR_VER}
)
- # copy scripts
- install_dir(
- ${CMAKE_SOURCE_DIR}/release/scripts
- \${TARGETDIR_VER}
- )
endif()
# install blenderplayer bundle - copy of blender.app above. re-using macros et al
# note we are using OSX Bundle as base and copying Blender dummy bundle on top of it
if(WITH_GAMEENGINE AND WITH_PLAYER)
- set(PLAYER_SOURCEDIR ${CMAKE_SOURCE_DIR}/source/darwin/blenderplayer.app)
- set(PLAYER_SOURCEINFO ${PLAYER_SOURCEDIR}/Contents/Info.plist)
+ set(OSX_APP_PLAYER_SOURCEDIR ${CMAKE_SOURCE_DIR}/source/darwin/blenderplayer.app)
+ set(PLAYER_SOURCEINFO ${OSX_APP_PLAYER_SOURCEDIR}/Contents/Info.plist)
set(PLAYER_TARGETDIR_VER ${TARGETDIR}/blenderplayer.app/Contents/MacOS/${BLENDER_VERSION})
@@ -700,12 +673,12 @@
)
install(
- FILES ${PLAYER_SOURCEDIR}/Contents/PkgInfo
+ FILES ${OSX_APP_PLAYER_SOURCEDIR}/Contents/PkgInfo
DESTINATION ${TARGETDIR}/blenderplayer.app/Contents
)
install_dir(
- ${PLAYER_SOURCEDIR}/Contents/Resources
+ ${OSX_APP_PLAYER_SOURCEDIR}/Contents/Resources
\${TARGETDIR}/blenderplayer.app/Contents/
)
@@ -728,6 +701,11 @@
endif()
endif()
+# -----------------------------------------------------------------------------
+# Generic Install, for all targets
+
+
+
# install more files specified elsewhere
delayed_do_install(${TARGETDIR_VER})
More information about the Bf-blender-cvs
mailing list