Difference between revisions of "Documentation/4.1/Developers/Build Module"
From Slicer Wiki
m |
m |
||
| Line 2: | Line 2: | ||
The following examples are specific to unix-like platforms and can easily be adapted for Windows. | The following examples are specific to unix-like platforms and can easily be adapted for Windows. | ||
| + | |||
| + | |||
Assuming the source code of your module is located in folder <code>MyModule</code>, externally building modules could be achieved doing: | Assuming the source code of your module is located in folder <code>MyModule</code>, externally building modules could be achieved doing: | ||
| Line 10: | Line 12: | ||
$ make | $ make | ||
</pre> | </pre> | ||
| + | |||
| + | |||
For this to work, in addition to invoke <code>cmake_minimum_required</code> at the top of the top-level <code>CMakeLists.txt</code>, it's important to make sure the following line are added after setting <code>MODULE_NAME</code>: | For this to work, in addition to invoke <code>cmake_minimum_required</code> at the top of the top-level <code>CMakeLists.txt</code>, it's important to make sure the following line are added after setting <code>MODULE_NAME</code>: | ||
| Line 19: | Line 23: | ||
endif() | endif() | ||
</pre> | </pre> | ||
| + | |||
For example: | For example: | ||
| + | |||
<pre> | <pre> | ||
| − | cmake_minimum_required(VERSION 2.8.7) | + | cmake_minimum_required(VERSION 2.8.7) <- - - - ADD THIS |
#----------------------------------------------------------------------------- | #----------------------------------------------------------------------------- | ||
| Line 31: | Line 37: | ||
#----------------------------------------------------------------------------- | #----------------------------------------------------------------------------- | ||
| − | if(NOT Slicer_SOURCE_DIR) | + | if(NOT Slicer_SOURCE_DIR) <- - - - - - - - - - ADD THIS |
| − | find_package(Slicer REQUIRED) | + | find_package(Slicer REQUIRED) <- - - - - - - ADD THIS |
| − | include(${Slicer_USE_FILE}) | + | include(${Slicer_USE_FILE}) <- - - - - - - - ADD THIS |
endif() | endif() | ||
Revision as of 09:06, 20 June 2012
Home < Documentation < 4.1 < Developers < Build ModuleThe different type of modules supported by Slicer can easily be build outside of the Slicer source tree.
The following examples are specific to unix-like platforms and can easily be adapted for Windows.
Assuming the source code of your module is located in folder MyModule, externally building modules could be achieved doing:
$ mkdir MyModule-build $ cd MyModule-build $ cmake -DSlicer_DIR:PATH=/path/to/Slicer-Superbuild/Slicer-build ../MyModule $ make
For this to work, in addition to invoke cmake_minimum_required at the top of the top-level CMakeLists.txt, it's important to make sure the following line are added after setting MODULE_NAME:
#-----------------------------------------------------------------------------
if(NOT Slicer_SOURCE_DIR)
find_package(Slicer REQUIRED)
include(${Slicer_USE_FILE})
endif()
For example:
cmake_minimum_required(VERSION 2.8.7) <- - - - ADD THIS
#-----------------------------------------------------------------------------
set(MODULE_NAME MyModule)
set(MODULE_TITLE ${MODULE_NAME})
string(TOUPPER ${MODULE_NAME} MODULE_NAME_UPPER)
#-----------------------------------------------------------------------------
if(NOT Slicer_SOURCE_DIR) <- - - - - - - - - - ADD THIS
find_package(Slicer REQUIRED) <- - - - - - - ADD THIS
include(${Slicer_USE_FILE}) <- - - - - - - - ADD THIS
endif()
#-----------------------------------------------------------------------------
add_subdirectory(Logic)
#-----------------------------------------------------------------------------
set(MODULE_EXPORT_DIRECTIVE "Q_SLICER_QTMODULES_${MODULE_NAME_UPPER}_EXPORT")
[...]