1 | # |
---|
2 | # ORXONOX - the hottest 3D action shooter ever to exist |
---|
3 | # > www.orxonox.net < |
---|
4 | # |
---|
5 | # This program is free software; you can redistribute it and/or |
---|
6 | # modify it under the terms of the GNU General Public License |
---|
7 | # as published by the Free Software Foundation; either version 2 |
---|
8 | # of the License, or (at your option) any later version. |
---|
9 | # |
---|
10 | # This program is distributed in the hope that it will be useful, |
---|
11 | # but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
12 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
13 | # GNU General Public License for more details. |
---|
14 | # |
---|
15 | # You should have received a copy of the GNU General Public License along |
---|
16 | # with this program; if not, write to the Free Software Foundation, |
---|
17 | # Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
---|
18 | # |
---|
19 | # |
---|
20 | # Author: |
---|
21 | # Reto Grieder |
---|
22 | # Description: |
---|
23 | # Configures the binary output directory with files required for Orxonox |
---|
24 | # to run like orxonox.ini or the default keybindings. |
---|
25 | # Also creates a run-script in the root directory of the build tree. |
---|
26 | # |
---|
27 | |
---|
28 | SET(READ_ONLY_CONFIG_FILES |
---|
29 | def_keybindings.ini |
---|
30 | def_masterKeybindings.ini |
---|
31 | disco.txt |
---|
32 | irc.tcl |
---|
33 | remote.tcl |
---|
34 | telnet_server.tcl |
---|
35 | ) |
---|
36 | |
---|
37 | SET(WRITABLE_CONFIG_FILES |
---|
38 | ) |
---|
39 | |
---|
40 | # Not getting installed |
---|
41 | SET(ORXONOX_INI orxonox.ini) |
---|
42 | |
---|
43 | IF(TARDIS) |
---|
44 | # OGRE can't find fonts to display config screen on Tardis, |
---|
45 | # so providing default config file here (bug). |
---|
46 | LIST(APPEND WRITABLE_CONFIG_FILES ogre.cfg) |
---|
47 | ENDIF(TARDIS) |
---|
48 | |
---|
49 | # We need the same code for both READ_ONLY and WRITABLE config files |
---|
50 | MACRO(CONFIGURE_FILES _file_name _build_configs _read_only_arg) |
---|
51 | SET(_read_only ${_read_only_arg}) |
---|
52 | FOREACH(_build_config ${_build_configs}) |
---|
53 | # Is there an extra file in bin/Debug or bin/Release? |
---|
54 | IF(${_build_config} MATCHES "Rel") |
---|
55 | SET(_build_config_short "Release") |
---|
56 | ELSE() |
---|
57 | SET(_build_config_short "Debug") |
---|
58 | ENDIF() |
---|
59 | IF(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${_build_config_short}/${_file_name}) |
---|
60 | SET(_in_file ${CMAKE_CURRENT_SOURCE_DIR}/${_build_config_short}/${_file_name}) |
---|
61 | ELSE() |
---|
62 | SET(_in_file ${CMAKE_CURRENT_SOURCE_DIR}/${_file_name}) |
---|
63 | ENDIF() |
---|
64 | |
---|
65 | # Copy to the folder named like the build config for Visual Studio |
---|
66 | IF(CMAKE_CONFIGURATION_TYPES) |
---|
67 | SET(_out_file ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${_build_config}/${_file_name}) |
---|
68 | ELSE() |
---|
69 | SET(_out_file ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${_file_name}) |
---|
70 | ENDIF() |
---|
71 | # Only copy if target file doesn't exist. This may result in problems but |
---|
72 | # otherwise we might delete a user's config |
---|
73 | IF(NOT EXISTS ${_out_file} OR _read_only) |
---|
74 | CONFIGURE_FILE(${_in_file} ${_out_file} @ONLY) |
---|
75 | ENDIF() |
---|
76 | ENDFOREACH(_build_config) |
---|
77 | ENDMACRO(CONFIGURE_FILES) |
---|
78 | |
---|
79 | # Copy config files to all Visual Studio output directories |
---|
80 | IF(CMAKE_CONFIGURATION_TYPES) |
---|
81 | SET(BUILD_CONFIGS ${CMAKE_CONFIGURATION_TYPES}) |
---|
82 | ELSE() |
---|
83 | SET(CONFIG_OUT_PATHS_REL ".") |
---|
84 | SET(BUILD_CONFIGS ${CMAKE_BUILD_TYPE}) |
---|
85 | ENDIF() |
---|
86 | |
---|
87 | FOREACH(_file_name ${READ_ONLY_CONFIG_FILES}) |
---|
88 | CONFIGURE_FILES("${_file_name}" "${BUILD_CONFIGS}" TRUE) |
---|
89 | ENDFOREACH(_file_name) |
---|
90 | FOREACH(_file_name ${WRITABLE_CONFIG_FILES} ${ORXONOX_INI}) |
---|
91 | CONFIGURE_FILES("${_file_name}" "${BUILD_CONFIGS}" FALSE) |
---|
92 | ENDFOREACH(_file_name) |
---|
93 | |
---|
94 | |
---|
95 | ################ Installation ################# |
---|
96 | |
---|
97 | # Not using collective call to allow configuration with CMake. |
---|
98 | FOREACH(_file ${READ_ONLY_CONFIG_FILES} ${WRITABLE_CONFIG_FILES}) |
---|
99 | IF(CMAKE_CONFIGURATION_TYPES) |
---|
100 | FOREACH(_configuration ${CMAKE_CONFIGURATION_TYPES}) |
---|
101 | INSTALL(FILES ${CMAKE_BINARY_DIR}/bin/${_configuration}/${_file} |
---|
102 | DESTINATION bin CONFIGURATIONS ${_configuration}) |
---|
103 | ENDFOREACH(_configuration) |
---|
104 | ELSE() |
---|
105 | INSTALL(FILES ${CMAKE_BINARY_DIR}/bin/${_file} DESTINATION bin) |
---|
106 | ENDIF() |
---|
107 | ENDFOREACH(_file) |
---|
108 | |
---|
109 | |
---|
110 | ################ Run Scripts ################## |
---|
111 | |
---|
112 | # Create a run script for both Windows and Linux in the source root path if |
---|
113 | # CMake is not used to create multi-configuration project files |
---|
114 | IF(NOT CMAKE_CONFIGURATION_TYPES) |
---|
115 | IF(WIN32) |
---|
116 | SET(RUN_SCRIPT run.bat) |
---|
117 | # Note: Do not use FILE(TO_NATIVE_PATH) because it doesn't work for MinGW |
---|
118 | STRING(REGEX REPLACE "^([A-Z]\\:)\\/.*$" "\\1" WINDOWS_DRIVE_CHANGE ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) |
---|
119 | STRING(REPLACE "/" "\\" CMAKE_RUNTIME_OUTPUT_DIRECTORY_WINDOWS ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) |
---|
120 | STRING(REPLACE "/" "\\" ORXONOX_RUNTIME_LIBRARY_DIRECTORY_WINDOWS ${ORXONOX_RUNTIME_LIBRARY_DIRECTORY}) |
---|
121 | ELSE(UNIX) |
---|
122 | SET(RUN_SCRIPT run) |
---|
123 | ENDIF(WIN32) |
---|
124 | CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/${RUN_SCRIPT} ${CMAKE_SOURCE_DIR}/${RUN_SCRIPT} @ONLY) |
---|
125 | CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/${RUN_SCRIPT} ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${RUN_SCRIPT} @ONLY) |
---|
126 | ENDIF(NOT CMAKE_CONFIGURATION_TYPES) |
---|