/usr/lib/vtk-5.8/CMake/vtkWrapTcl.cmake is in libvtk5-dev 5.8.0-14.1ubuntu3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 | #
# a cmake implementation of the Wrap Tcl command
# it takes an optional VERSION parameter that will be output
# to the .data file as VERSION ${VERSION}.
# vtkWrapTclInit will then recognize the VERSION keyword, extract the version
# and make sure the corresponding Tcl package is 'provided' with that version.
#
MACRO(VTK_WRAP_TCL2 TARGET)
# convert to the WRAP3 signature
SET(MODE SOURCE_LIST)
SET(SOURCES)
FOREACH(ARG ${ARGN})
SET (MODE_CHANGED 0)
IF ("${ARG}" MATCHES SOURCES)
SET (MODE SOURCE_LIST)
SET(MODE_CHANGED 1)
ENDIF ("${ARG}" MATCHES SOURCES)
IF ("${ARG}" MATCHES COMMANDS)
SET (MODE COMMANDS)
SET(MODE_CHANGED 1)
ENDIF ("${ARG}" MATCHES COMMANDS)
IF (NOT MODE_CHANGED)
IF (MODE MATCHES SOURCES)
SET(SOURCES ${SOURCES} ${ARG})
ENDIF (MODE MATCHES SOURCES)
IF (MODE MATCHES COMMANDS)
SET(COMMANDS ${COMMANDS} ${ARG})
ENDIF (MODE MATCHES COMMANDS)
IF (MODE MATCHES SOURCE_LIST)
SET(SOURCE_LIST_NAME "${ARG}")
SET (MODE SOURCES)
ENDIF (MODE MATCHES SOURCE_LIST)
ENDIF (NOT MODE_CHANGED)
ENDFOREACH(ARG)
VTK_WRAP_TCL3(${TARGET} ${SOURCE_LIST_NAME} "${SOURCES}" "${COMMANDS}")
ENDMACRO(VTK_WRAP_TCL2)
MACRO(VTK_WRAP_TCL3 TARGET SRC_LIST_NAME SOURCES COMMANDS)
IF(NOT VTK_WRAP_TCL_INIT_EXE)
MESSAGE(SEND_ERROR "VTK_WRAP_TCL_INIT_EXE not specified when calling VTK_WRAP_TCL3")
ENDIF(NOT VTK_WRAP_TCL_INIT_EXE)
IF(NOT VTK_WRAP_TCL_EXE)
MESSAGE(SEND_ERROR "VTK_WRAP_TCL_EXE not specified when calling VTK_WRAP_TCL3")
ENDIF(NOT VTK_WRAP_TCL_EXE)
IF(CMAKE_GENERATOR MATCHES "NMake Makefiles")
SET(verbatim "")
SET(quote "\"")
ELSE(CMAKE_GENERATOR MATCHES "NMake Makefiles")
SET(verbatim "VERBATIM")
SET(quote "")
ENDIF(CMAKE_GENERATOR MATCHES "NMake Makefiles")
# Initialize the custom target counter.
IF(VTK_WRAP_TCL_NEED_CUSTOM_TARGETS)
SET(VTK_WRAP_TCL_CUSTOM_COUNT "")
SET(VTK_WRAP_TCL_CUSTOM_NAME ${TARGET})
SET(VTK_WRAP_TCL_CUSTOM_LIST)
ENDIF(VTK_WRAP_TCL_NEED_CUSTOM_TARGETS)
# start writing the input file for the init file
SET(VTK_WRAPPER_INIT_DATA "${TARGET}")
IF (${ARGC} GREATER 4)
SET(VTK_WRAPPER_INIT_DATA
"${VTK_WRAPPER_INIT_DATA}\nVERSION ${ARGV4}")
ENDIF (${ARGC} GREATER 4)
GET_DIRECTORY_PROPERTY(TMP_DEF_LIST DEFINITION COMPILE_DEFINITIONS)
SET(TMP_DEFINITIONS)
FOREACH(TMP_DEF ${TMP_DEF_LIST})
SET(TMP_DEFINITIONS ${TMP_DEFINITIONS} -D "${quote}${TMP_DEF}${quote}")
ENDFOREACH(TMP_DEF ${TMP_DEF_LIST})
IF(VTK_WRAP_INCLUDE_DIRS)
SET(TMP_INCLUDE_DIRS ${VTK_WRAP_INCLUDE_DIRS})
ELSE(VTK_WRAP_INCLUDE_DIRS)
SET(TMP_INCLUDE_DIRS ${VTK_INCLUDE_DIRS})
ENDIF(VTK_WRAP_INCLUDE_DIRS)
SET(TMP_INCLUDE)
FOREACH(INCLUDE_DIR ${TMP_INCLUDE_DIRS})
SET(TMP_INCLUDE ${TMP_INCLUDE} -I "${quote}${INCLUDE_DIR}${quote}")
ENDFOREACH(INCLUDE_DIR ${TMP_INCLUDE_DIRS})
IF (VTK_WRAP_HINTS)
SET(TMP_HINTS "--hints" "${quote}${VTK_WRAP_HINTS}${quote}")
ELSE (VTK_WRAP_HINTS)
SET(TMP_HINTS)
ENDIF (VTK_WRAP_HINTS)
IF (KIT_HIERARCHY_FILE)
SET(TMP_HIERARCHY "--types" "${quote}${KIT_HIERARCHY_FILE}${quote}")
ELSE (KIT_HIERARCHY_FILE)
SET(TMP_HIERARCHY)
ENDIF (KIT_HIERARCHY_FILE)
# For each class
FOREACH(FILE ${SOURCES})
# should we wrap the file?
GET_SOURCE_FILE_PROPERTY(TMP_WRAP_EXCLUDE ${FILE} WRAP_EXCLUDE)
# if we should wrap it
IF (NOT TMP_WRAP_EXCLUDE)
# what is the filename without the extension
GET_FILENAME_COMPONENT(TMP_FILENAME ${FILE} NAME_WE)
# the input file might be full path so handle that
GET_FILENAME_COMPONENT(TMP_FILEPATH ${FILE} PATH)
# compute the input filename
IF (TMP_FILEPATH)
SET(TMP_INPUT ${TMP_FILEPATH}/${TMP_FILENAME}.h)
ELSE (TMP_FILEPATH)
SET(TMP_INPUT ${CMAKE_CURRENT_SOURCE_DIR}/${TMP_FILENAME}.h)
ENDIF (TMP_FILEPATH)
# is it abstract?
GET_SOURCE_FILE_PROPERTY(TMP_ABSTRACT ${FILE} ABSTRACT)
IF (TMP_ABSTRACT)
SET(TMP_CONCRETE "--abstract")
ELSE (TMP_ABSTRACT)
SET(TMP_CONCRETE "--concrete")
# add the info to the init file
SET(VTK_WRAPPER_INIT_DATA
"${VTK_WRAPPER_INIT_DATA}\n${TMP_FILENAME}")
ENDIF (TMP_ABSTRACT)
# new source file is nameTcl.cxx, add to resulting list
SET(${SRC_LIST_NAME} ${${SRC_LIST_NAME}}
${TMP_FILENAME}Tcl.cxx)
# add custom command to output
ADD_CUSTOM_COMMAND(
OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${TMP_FILENAME}Tcl.cxx
DEPENDS ${VTK_WRAP_TCL_EXE} ${VTK_WRAP_HINTS}
${KIT_HIERARCHY_FILE}
MAIN_DEPENDENCY "${TMP_INPUT}"
COMMAND ${VTK_WRAP_TCL_EXE}
ARGS
${TMP_CONCRETE}
${TMP_HINTS}
${TMP_HIERARCHY}
${TMP_DEFINITIONS}
${TMP_INCLUDE}
"${quote}${TMP_INPUT}${quote}"
"${quote}${CMAKE_CURRENT_BINARY_DIR}/${TMP_FILENAME}Tcl.cxx${quote}"
COMMENT "Tcl Wrapping - generating ${TMP_FILENAME}Tcl.cxx"
${verbatim}
)
# Add this output to a custom target if needed.
IF(VTK_WRAP_TCL_NEED_CUSTOM_TARGETS)
SET(VTK_WRAP_TCL_CUSTOM_LIST ${VTK_WRAP_TCL_CUSTOM_LIST}
${CMAKE_CURRENT_BINARY_DIR}/${TMP_FILENAME}Tcl.cxx)
SET(VTK_WRAP_TCL_CUSTOM_COUNT ${VTK_WRAP_TCL_CUSTOM_COUNT}x)
IF(VTK_WRAP_TCL_CUSTOM_COUNT MATCHES "^${VTK_WRAP_TCL_CUSTOM_LIMIT}$")
SET(VTK_WRAP_TCL_CUSTOM_NAME ${VTK_WRAP_TCL_CUSTOM_NAME}Hack)
ADD_CUSTOM_TARGET(${VTK_WRAP_TCL_CUSTOM_NAME} DEPENDS ${VTK_WRAP_TCL_CUSTOM_LIST})
SET(KIT_TCL_DEPS ${VTK_WRAP_TCL_CUSTOM_NAME})
SET(VTK_WRAP_TCL_CUSTOM_LIST)
SET(VTK_WRAP_TCL_CUSTOM_COUNT)
ENDIF(VTK_WRAP_TCL_CUSTOM_COUNT MATCHES "^${VTK_WRAP_TCL_CUSTOM_LIMIT}$")
ENDIF(VTK_WRAP_TCL_NEED_CUSTOM_TARGETS)
ENDIF (NOT TMP_WRAP_EXCLUDE)
ENDFOREACH(FILE)
# finish the data file for the init file
FOREACH(CMD ${COMMANDS})
SET(VTK_WRAPPER_INIT_DATA
"${VTK_WRAPPER_INIT_DATA}\nCOMMAND ${CMD}")
ENDFOREACH(CMD ${COMMANDS})
SET(dir ${CMAKE_CURRENT_SOURCE_DIR})
CONFIGURE_FILE(
${VTK_CMAKE_DIR}/vtkWrapperInit.data.in
${CMAKE_CURRENT_BINARY_DIR}/${TARGET}Init.data
COPY_ONLY
IMMEDIATE
)
ADD_CUSTOM_COMMAND(
OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${TARGET}Init.cxx
DEPENDS ${VTK_WRAP_TCL_INIT_EXE}
${CMAKE_CURRENT_BINARY_DIR}/${TARGET}Init.data
COMMAND ${VTK_WRAP_TCL_INIT_EXE}
ARGS
"${quote}${CMAKE_CURRENT_BINARY_DIR}/${TARGET}Init.data${quote}"
"${quote}${CMAKE_CURRENT_BINARY_DIR}/${TARGET}Init.cxx${quote}"
COMMENT "Tcl Wrapping - generating ${TARGET}Init.cxx"
${verbatim}
)
# Create the Init File
SET(${SRC_LIST_NAME} ${${SRC_LIST_NAME}} ${TARGET}Init.cxx)
ENDMACRO(VTK_WRAP_TCL3)
IF (VTK_WRAP_TCL_FIND_LIBS)
GET_FILENAME_COMPONENT(_CURRENT_DIR "${CMAKE_CURRENT_LIST_FILE}" PATH)
INCLUDE("${_CURRENT_DIR}/FindTCL.cmake")
IF(VTK_WRAP_TCL AND NOT TCL_FOUND)
MESSAGE(FATAL_ERROR "Tcl was not found. Install the Tcl development package (see http://tcl.tk or ActiveState Tcl) and set the appropriate variables (TCL_INCLUDE_PATH, TCL_LIBRARY, TCL_TCLSH) or disable VTK_WRAP_TCL.")
ENDIF(VTK_WRAP_TCL AND NOT TCL_FOUND)
IF(VTK_USE_TK AND NOT TK_FOUND)
MESSAGE(FATAL_ERROR "Tk was not found. Install the Tk development package (see http://tcl.tk or ActiveState Tcl) and set the appropriate variables (TK_INCLUDE_PATH, TK_LIBRARY, TK_WISH) or disable VTK_USE_TK.")
ENDIF(VTK_USE_TK AND NOT TK_FOUND)
SET(VTK_TCL_LIBRARIES ${TCL_LIBRARY})
IF(TCL_LIBRARY_DEBUG)
SET(VTK_TCL_LIBRARIES optimized ${TCL_LIBRARY} debug ${TCL_LIBRARY_DEBUG})
ENDIF(TCL_LIBRARY_DEBUG)
IF(UNIX)
# The tcl library needs the math library on unix.
SET(VTK_TCL_LIBRARIES ${VTK_TCL_LIBRARIES} m)
ENDIF(UNIX)
IF(VTK_USE_TK AND TK_FOUND)
SET(VTK_TK_LIBRARIES ${TK_LIBRARY} ${VTK_TCL_LIBRARIES})
IF(TK_LIBRARY_DEBUG)
SET(VTK_TK_LIBRARIES optimized ${TK_LIBRARY} debug ${TK_LIBRARY_DEBUG} ${VTK_TCL_LIBRARIES})
ENDIF(TK_LIBRARY_DEBUG)
ENDIF(VTK_USE_TK AND TK_FOUND)
INCLUDE(${VTK_CMAKE_DIR}/vtkTclTkMacros.cmake)
# Hide useless settings provided by FindTCL.
FOREACH(entry
TK_WISH)
SET(${entry} "${${entry}}" CACHE INTERNAL "This value is not used by VTK.")
ENDFOREACH(entry)
# Need Tk sources on windows
IF(WIN32)
FIND_PATH(TK_XLIB_PATH
X11/Xlib.h ${TK_INCLUDE_PATH}
${TK_INCLUDE_PATH}/../xlib)
MARK_AS_ADVANCED(TK_XLIB_PATH)
ENDIF(WIN32)
ENDIF (VTK_WRAP_TCL_FIND_LIBS)
# VS 6 does not like needing to run a huge number of custom commands
# when building a single target. Generate some extra custom targets
# that run the custom commands before the main target is built. This
# is a hack to work-around the limitation. The test to enable it is
# done here since it does not need to be done for every macro
# invocation.
IF(CMAKE_GENERATOR MATCHES "^Visual Studio 6$")
SET(VTK_WRAP_TCL_NEED_CUSTOM_TARGETS 1)
SET(VTK_WRAP_TCL_CUSTOM_LIMIT x)
# Limit the number of custom commands in each target
# to 2^7.
FOREACH(t 1 2 3 4 5 6 7)
SET(VTK_WRAP_TCL_CUSTOM_LIMIT
${VTK_WRAP_TCL_CUSTOM_LIMIT}${VTK_WRAP_TCL_CUSTOM_LIMIT})
ENDFOREACH(t)
ENDIF(CMAKE_GENERATOR MATCHES "^Visual Studio 6$")
|