KDE/kdelibs/cmake/modules
Alexander Neundorf
neundorf at kde.org
Tue Jan 23 22:38:25 CET 2007
SVN commit 626609 by neundorf:
add a macro KDE4_CREATE_EXPORTS_HEADER(fileName libName)
which should create an exports header for the given lib
This happen via configure_file() from the template file kde4exportsheader.h.in
Is this ok this way ?
Please let me know.
Alex
CCMAIL: kde-buildsystem at kde.org
M +15 -3 KDE4Macros.cmake
A kde4exportsheader.h.in
--- trunk/KDE/kdelibs/cmake/modules/KDE4Macros.cmake #626608:626609
@@ -794,12 +794,24 @@
ENDMACRO(KDE4_REMOVE_OBSOLETE_CMAKE_FILES)
+
MACRO(KDE4_NO_ENABLE_FINAL _project_name)
if(KDE4_ENABLE_FINAL)
- set(KDE4_ENABLE_FINAL OFF)
- REMOVE_DEFINITIONS(-DKDE_USE_FINAL)
- MESSAGE(STATUS "You used enable-final argument but \"${_project_name}\" doesn't support it. Try to fix compile it and remove KDE4_NO_ENABLE_FINAL macro. Thanks")
+ set(KDE4_ENABLE_FINAL OFF)
+ remove_definitions(-DKDE_USE_FINAL)
+ message(STATUS "You used enable-final argument but \"${_project_name}\" doesn't support it. Try to fix compile it and remove KDE4_NO_ENABLE_FINAL macro. Thanks")
endif(KDE4_ENABLE_FINAL)
ENDMACRO(KDE4_NO_ENABLE_FINAL _project_name)
+
+macro(KDE4_CREATE_EXPORTS_HEADER _outputFile _libName)
+ string(TOUPPER ${_libName} _libNameUpperCase)
+ # the next line is is required, because in CMake arguments to macros are not real
+ # variables, but handled differently. The next line create a real CMake variable,
+ # so configure_file() will replace it correctly.
+ set(_libName ${_libName})
+ # compared to write(FILE) configure_file() only really writes the file if the
+ # contents have changed. Otherwise we would have a lot of recompiles.
+ configure_file(${KDE4_MODULE_DIR}/kde4exportsheader.h.in ${_outputFile})
+endmacro(KDE4_CREATE_EXPORTS_HEADER _outputFile _libName)
More information about the Kde-buildsystem
mailing list