From b39e276958b010825d8d030add4945b6ecd2ba3b Mon Sep 17 00:00:00 2001 From: gregory guy Date: Thu, 7 Feb 2019 15:18:06 +0100 Subject: [PATCH] conversion to the cmake building system Signed-off-by: gregory guy --- CMakeLists.txt | 78 +++++++++++++++++++++++++++++++++++++++++++ ConfigureChecks.cmake | 35 +++++++++++++++++++ config.h.cmake | 8 +++++ doc/CMakeLists.txt | 1 + doc/en/CMakeLists.txt | 1 + po/CMakeLists.txt | 5 +++ src/CMakeLists.txt | 72 +++++++++++++++++++++++++++++++++++++++ src/menuhandler.cpp | 2 +- src/tastylistview.cpp | 2 +- src/tastymenu.cpp | 1 + 10 files changed, 203 insertions(+), 2 deletions(-) create mode 100644 CMakeLists.txt create mode 100644 ConfigureChecks.cmake create mode 100644 config.h.cmake create mode 100644 doc/CMakeLists.txt create mode 100644 doc/en/CMakeLists.txt create mode 100644 po/CMakeLists.txt create mode 100644 src/CMakeLists.txt diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..8698ff4 --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,78 @@ +############################################ +# # +# Improvements and feedbacks are welcome # +# # +# This file is released under GPL >= 3 # +# # +############################################ + + +cmake_minimum_required( VERSION 2.8 ) + + +#### general package setup + +project( tastymenu ) +set( VERSION R14.1.0 ) + + +#### include essential cmake modules + +include( FindPkgConfig ) +include( CheckFunctionExists ) +include( CheckSymbolExists ) +include( CheckIncludeFile ) +include( CheckLibraryExists ) +include( CheckCSourceCompiles ) +include( CheckCXXSourceCompiles ) + + +#### include our cmake modules + +set( CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake/modules" ) +include( TDEMacros ) + + +##### setup install paths + +include( TDESetupPaths ) +tde_setup_paths( ) + + +##### optional stuff + +option( WITH_ALL_OPTIONS "Enable all optional support" OFF ) +option( WITH_GCC_VISIBILITY "Enable fvisibility and fvisibility-inlines-hidden" ${WITH_ALL_OPTIONS} ) + + +##### user requested modules + +option( BUILD_ALL "Build all" ON ) +option( BUILD_DOC "Build documentation" ${BUILD_ALL} ) +option( BUILD_TRANSLATIONS "Build translations" ${BUILD_ALL} ) + + +##### configure checks + +include( ConfigureChecks.cmake ) + + +###### global compiler settings + +add_definitions( -DHAVE_CONFIG_H -UTQT_NO_ASCII_CAST ) + +set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${TQT_CXX_FLAGS}" ) +set( CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--no-undefined" ) +set( CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,--no-undefined" ) + + +##### directories + +add_subdirectory( src ) +tde_conditional_add_subdirectory( BUILD_DOC doc ) +tde_conditional_add_subdirectory( BUILD_TRANSLATIONS po ) + + +##### write configure files + +configure_file( config.h.cmake config.h @ONLY ) diff --git a/ConfigureChecks.cmake b/ConfigureChecks.cmake new file mode 100644 index 0000000..fa7d77d --- /dev/null +++ b/ConfigureChecks.cmake @@ -0,0 +1,35 @@ +########################################### +# # +# Improvements and feedback are welcome # +# # +# This file is released under GPL >= 3 # +# # +########################################### + + +# required stuff +find_package( TQt ) +find_package( TDE ) + +tde_setup_architecture_flags( ) + +include(TestBigEndian) +test_big_endian(WORDS_BIGENDIAN) + +tde_setup_largefiles( ) + + +##### check for gcc visibility support + +if( WITH_GCC_VISIBILITY ) + tde_setup_gcc_visibility( ) +endif( WITH_GCC_VISIBILITY ) + + +##### check for X11/Xau + +find_package( X11 QUIET ) +pkg_search_module( LIBXAU xau ) +if( NOT LIBXAU_FOUND ) + tde_message_fatal( "libXau is required, but was not found on your system" ) +endif( NOT LIBXAU_FOUND ) diff --git a/config.h.cmake b/config.h.cmake new file mode 100644 index 0000000..61ede3a --- /dev/null +++ b/config.h.cmake @@ -0,0 +1,8 @@ +#define VERSION "@VERSION@" + +// Defined if you have fvisibility and fvisibility-inlines-hidden support. +#cmakedefine __KDE_HAVE_GCC_VISIBILITY 1 + +/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most + significant byte first (like Motorola and SPARC, unlike Intel). */ +#cmakedefine WORDS_BIGENDIAN @WORDS_BIGENDIAN@ diff --git a/doc/CMakeLists.txt b/doc/CMakeLists.txt new file mode 100644 index 0000000..c938175 --- /dev/null +++ b/doc/CMakeLists.txt @@ -0,0 +1 @@ +add_subdirectory( en ) diff --git a/doc/en/CMakeLists.txt b/doc/en/CMakeLists.txt new file mode 100644 index 0000000..ba3ef3e --- /dev/null +++ b/doc/en/CMakeLists.txt @@ -0,0 +1 @@ +tde_create_handbook( DESTINATION ${PROJECT_NAME} ) diff --git a/po/CMakeLists.txt b/po/CMakeLists.txt new file mode 100644 index 0000000..597c341 --- /dev/null +++ b/po/CMakeLists.txt @@ -0,0 +1,5 @@ +file( GLOB _srcs RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} *.po ) + +if( _srcs ) + tde_create_translation( LANG auto OUTPUT_NAME ${PROJECT_NAME} ) +endif( ) diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt new file mode 100644 index 0000000..1b8feb0 --- /dev/null +++ b/src/CMakeLists.txt @@ -0,0 +1,72 @@ +include_directories( + ${CMAKE_BINARY_DIR} + ${CMAKE_CURRENT_BINARY_DIR} + ${CMAKE_CURRENT_SOURCE_DIR} + ${TDE_INCLUDE_DIR} + ${TQT_INCLUDE_DIRS} + ${X11_INCLUDE_DIR} +) + +link_directories( + ${TQT_LIBRARY_DIRS} + ${TDE_LIB_DIR} +) + + +##### buttons.h (header) + +file( GLOB _pics ${CMAKE_CURRENT_SOURCE_DIR}/pics/*.png ) + +set( _header buttons.h ) + +add_custom_command( + OUTPUT ${_header} + COMMAND ${UIC_EXECUTABLE} + ARGS -o ${_header} -embed buttons ${_pics} + DEPENDS ${_pics} +) + + +##### tastymenu_panelapplet (kpart) + +set_source_files_properties( + menuhandler.cpp + PROPERTIES OBJECT_DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${_header} +) + +tde_add_kpart( tastymenu_panelapplet AUTOMOC + + SOURCES + appearance.ui + behaviour.ui + menu.ui + tastytooltipwidget.ui + tastymenu.cpp + menuhandler.cpp + dmctl.cpp + tastylistview.cpp + misc.cpp + tastytooltip.cpp + tastybutton.cpp + prefs.kcfgc + LINK + tdecore-shared + tdeui-shared + tdeio-shared + ${LIBXAU_LIBRARIES} + + DESTINATION ${PLUGIN_INSTALL_DIR} +) + + +##### other data + +install( + FILES tastymenu.desktop + DESTINATION ${DATA_INSTALL_DIR}/kicker/applets +) + +install( + FILES tastymenu.kcfg + DESTINATION ${KCFG_INSTALL_DIR} +) diff --git a/src/menuhandler.cpp b/src/menuhandler.cpp index 8ee4508..d3a4a79 100644 --- a/src/menuhandler.cpp +++ b/src/menuhandler.cpp @@ -1708,5 +1708,5 @@ void MenuHandler::switchWindowMode() prefSkel->writeConfig(); } - +#include "menuhandler.moc" //EOF diff --git a/src/tastylistview.cpp b/src/tastylistview.cpp index cb6d629..f958bfc 100644 --- a/src/tastylistview.cpp +++ b/src/tastylistview.cpp @@ -594,7 +594,7 @@ void TastyListViewItem::paintCell ( TQPainter * p, const TQColorGroup & cg, int pBuf.end(); p->drawPixmap( 0, 0, buffer ); } - +#include "tastylistview.moc" //EOF diff --git a/src/tastymenu.cpp b/src/tastymenu.cpp index a581123..263398c 100644 --- a/src/tastymenu.cpp +++ b/src/tastymenu.cpp @@ -490,3 +490,4 @@ extern "C" parent, "tastymenu"); } } +#include "tastymenu.moc"