diff -r 5770be2d5f3f -r e617c9cf6dd3 CMakeLists.txt --- a/CMakeLists.txt Sat Feb 14 16:40:09 2009 +0200 +++ b/CMakeLists.txt Mon Feb 16 01:32:12 2009 +0200 @@ -1,18 +1,62 @@ cmake_minimum_required(VERSION 2.6) +project(lua-lm C) -# Define targets +## User options +option(DEBUG "Enable debugging output" OFF) + +## Define targets add_library(loudmouth MODULE util.c lm_types.c lm_proxy.c lm_ssl.c lm_connection.c lm_message.c lm_message_node.c lm_message_handler.c lm.c) +get_target_property(lua-lm_SOURCES loudmouth SOURCES) +configure_file(config.h.in config.h) -# Check for dependencies +## Packaging information +set(CPACK_PACKAGE_NAME liblua5.1-loudmouth) +set(CPACK_PACKAGE_VERSION_MAJOR 0) +set(CPACK_PACKAGE_VERSION_MINOR 0) +set(CPACK_PACKAGE_VERSION_PATCH 0) +set(CPACK_PACKAGE_VENDOR "IsBear") +set(CPACK_PACKAGE_CONTACT "Myhailo Danylenko ") +set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Loudmouth XMPP client library lua interface") +set(CPACK_PACKAGE_DESCRIPTION_FILE ${lua-lm_SOURCE_DIR}/README) +set(CPACK_RESOURCE_FILE_LICENSE ${lua-lm_SOURCE_DIR}/COPYING) +set(CPACK_RESOURCE_FILE_README ${lua-lm_SOURCE_DIR}/README) +set(CPACK_RESOURCE_FILE_WELCOME ${lua-lm_SOURCE_DIR}/README) +set(CPACK_DEBIAN_PACKAGE_SECTION libs) +set(CPACK_SOURCE_GENERATOR TBZ2) +set(CPACK_GENERATOR DEB) +# FIXME: Detect architecture. How? Though, it anyway produces nonconformant deb names... +set(CPACK_SYSTEM_NAME i386) +# XXX: Set package name directly to get rid of -Sources? +set(CPACK_SOURCE_IGNORE_FILES "/\\\\..*;\\\\.swp;~$;/build/;\\\\.tar\\\\.;\\\\.deb;\\\\.so") +include(CPack) + +## Gather information about system find_package(Lua51 REQUIRED) - +execute_process(COMMAND lua -e "print ( package.path )" OUTPUT_VARIABLE LUA_PATH OUTPUT_STRIP_TRAILING_WHITESPACE) +execute_process(COMMAND lua -e "print ( package.cpath )" OUTPUT_VARIABLE LUA_CPATH OUTPUT_STRIP_TRAILING_WHITESPACE) find_package(PkgConfig REQUIRED) +pkg_check_modules(GLIB REQUIRED glib-2.0) pkg_check_modules(LM REQUIRED loudmouth-1.0) -pkg_check_modules(GLIB REQUIRED glib-2.0) -# Set building options +## Set up compiler include_directories(SYSTEM ${LUA_INCLUDE_DIR} ${GLIB_INCLUDE_DIRS} ${LM_INCLUDE_DIRS}) target_link_libraries(loudmouth ${LUA_LIBRARIES} ${GLIB_LIBRARIES} ${LM_LIBRARIES}) +include_directories(${lua-lm_SOURCE_DIR} ${lua-lm_BINARY_DIR}) set_target_properties(loudmouth PROPERTIES PREFIX "") +## Extra targets +add_custom_command(OUTPUT ${lua-lm_BINARY_DIR}/loudmouth.html COMMAND ${lua-lm_SOURCE_DIR}/docgen.pl ${lua-lm_SOURCES} > ${lua-lm_BINARY_DIR}/loudmouth.html DEPENDS ${lua-lm_SOURCE_DIR}/docgen.pl ${lua-lm_SOURCES} WORKING_DIRECTORY ${lua-lm_SOURCE_DIR}) +add_custom_target(doc ALL DEPENDS ${lua-lm_BINARY_DIR}/loudmouth.html) +add_custom_target(test COMMAND env "LUA_PATH=${lua-lm_SOURCE_DIR}/?.lua;${LUA_PATH}" "LUA_CPATH=${lua-lm_SOURCE_DIR}/?.so;${lua-lm_BINARY_DIR}/?.so;${LUA_CPATH}" lua ${lua-lm_SOURCE_DIR}/test.lua DEPENDS loudmouth VERBATIM) + +## Set up installer +install(TARGETS loudmouth DESTINATION lib/lua/5.1) +install(FILES lm.lua DESTINATION share/lua/5.1) +install(FILES test.lua DESTINATION share/doc/${CPACK_PACKAGE_NAME}/examples) +install(FILES ${lua-lm_BINARY_DIR}/loudmouth.html DESTINATION share/doc/${CPACK_PACKAGE_NAME}) +install(FILES README DESTINATION share/doc/${CPACK_PACKAGE_NAME}) +install(FILES TODO DESTINATION share/doc/${CPACK_PACKAGE_NAME}) +install(FILES COPYING DESTINATION share/doc/${CPACK_PACKAGE_NAME}) + +## The End ## vim: se ts=4: ##