Bump minimum CMake version and termo
And some related cleanup or unification.
This commit is contained in:
parent
0e147b2ef1
commit
4be24e17c3
|
@ -1,35 +1,29 @@
|
||||||
project (ponymap C)
|
cmake_minimum_required (VERSION 3.0)
|
||||||
cmake_minimum_required (VERSION 2.8.5)
|
project (ponymap VERSION 0.1.0 LANGUAGES C)
|
||||||
|
|
||||||
# Moar warnings
|
# Moar warnings
|
||||||
if ("${CMAKE_C_COMPILER_ID}" MATCHES "GNU" OR CMAKE_COMPILER_IS_GNUCC)
|
if ("${CMAKE_C_COMPILER_ID}" MATCHES "GNU" OR CMAKE_COMPILER_IS_GNUCC)
|
||||||
# -Wunused-function is pretty annoying here, as everything is static
|
# -Wunused-function is pretty annoying here, as everything is static
|
||||||
set (CMAKE_C_FLAGS
|
set (CMAKE_C_FLAGS
|
||||||
"${CMAKE_C_FLAGS} -std=c99 -Wall -Wextra -Wno-unused-function")
|
"${CMAKE_C_FLAGS} -std=c99 -Wall -Wextra -Wno-unused-function")
|
||||||
endif ("${CMAKE_C_COMPILER_ID}" MATCHES "GNU" OR CMAKE_COMPILER_IS_GNUCC)
|
endif ()
|
||||||
|
|
||||||
# Version
|
|
||||||
set (project_VERSION_MAJOR "0")
|
|
||||||
set (project_VERSION_MINOR "1")
|
|
||||||
set (project_VERSION_PATCH "0")
|
|
||||||
|
|
||||||
set (project_VERSION "${project_VERSION_MAJOR}")
|
|
||||||
set (project_VERSION "${project_VERSION}.${project_VERSION_MINOR}")
|
|
||||||
set (project_VERSION "${project_VERSION}.${project_VERSION_PATCH}")
|
|
||||||
|
|
||||||
if ("${CMAKE_SYSTEM_NAME}" MATCHES "BSD")
|
|
||||||
# Need this in FreeBSD and OpenBSD respectively;
|
|
||||||
# our POSIX version macros make it undefined
|
|
||||||
add_definitions (-D__BSD_VISIBLE=1 -D_BSD_SOURCE=1)
|
|
||||||
endif ("${CMAKE_SYSTEM_NAME}" MATCHES "BSD")
|
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
|
set (CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/liberty/cmake)
|
||||||
|
include (AddThreads)
|
||||||
|
|
||||||
find_package (Curses)
|
find_package (Curses)
|
||||||
find_package (PkgConfig REQUIRED)
|
find_package (PkgConfig REQUIRED)
|
||||||
pkg_check_modules (jansson REQUIRED jansson)
|
pkg_check_modules (jansson REQUIRED jansson)
|
||||||
pkg_check_modules (libssl REQUIRED libssl libcrypto)
|
pkg_check_modules (libssl REQUIRED libssl libcrypto)
|
||||||
pkg_check_modules (ncursesw ncursesw)
|
pkg_check_modules (ncursesw ncursesw)
|
||||||
|
|
||||||
|
if ("${CMAKE_SYSTEM_NAME}" MATCHES "BSD")
|
||||||
|
# Need this in FreeBSD and OpenBSD respectively;
|
||||||
|
# our POSIX version macros make it undefined
|
||||||
|
add_definitions (-D__BSD_VISIBLE=1 -D_BSD_SOURCE=1)
|
||||||
|
endif ()
|
||||||
|
|
||||||
if (ncursesw_FOUND)
|
if (ncursesw_FOUND)
|
||||||
set (project_libraries ${ncursesw_LIBRARIES})
|
set (project_libraries ${ncursesw_LIBRARIES})
|
||||||
include_directories (${ncursesw_INCLUDE_DIRS})
|
include_directories (${ncursesw_INCLUDE_DIRS})
|
||||||
|
@ -37,9 +31,9 @@ if (ncursesw_FOUND)
|
||||||
elseif (CURSES_FOUND)
|
elseif (CURSES_FOUND)
|
||||||
set (project_libraries ${CURSES_LIBRARY})
|
set (project_libraries ${CURSES_LIBRARY})
|
||||||
include_directories (${CURSES_INCLUDE_DIR})
|
include_directories (${CURSES_INCLUDE_DIR})
|
||||||
else (CURSES_FOUND)
|
else ()
|
||||||
message (SEND_ERROR "Curses not found")
|
message (SEND_ERROR "Curses not found")
|
||||||
endif (ncursesw_FOUND)
|
endif ()
|
||||||
|
|
||||||
# FIXME: for "lua" we also need to check that it is < 5.5
|
# FIXME: for "lua" we also need to check that it is < 5.5
|
||||||
# which doesn't seem to be possible with FindPkgConfig
|
# which doesn't seem to be possible with FindPkgConfig
|
||||||
|
@ -49,26 +43,25 @@ option (WITH_LUA "Enable experimental support for Lua plugins" ${lua_FOUND})
|
||||||
if (WITH_LUA)
|
if (WITH_LUA)
|
||||||
if (NOT lua_FOUND)
|
if (NOT lua_FOUND)
|
||||||
message (FATAL_ERROR "Lua library not found")
|
message (FATAL_ERROR "Lua library not found")
|
||||||
endif (NOT lua_FOUND)
|
endif ()
|
||||||
|
|
||||||
list (APPEND project_libraries ${lua_LIBRARIES})
|
list (APPEND project_libraries ${lua_LIBRARIES})
|
||||||
include_directories (${lua_INCLUDE_DIRS})
|
include_directories (${lua_INCLUDE_DIRS})
|
||||||
link_directories (${lua_LIBRARY_DIRS})
|
link_directories (${lua_LIBRARY_DIRS})
|
||||||
endif (WITH_LUA)
|
endif ()
|
||||||
|
|
||||||
list (APPEND project_libraries ${libssl_LIBRARIES} ${jansson_LIBRARIES})
|
list (APPEND project_libraries ${libssl_LIBRARIES} ${jansson_LIBRARIES})
|
||||||
include_directories (${libssl_INCLUDE_DIRS} ${jansson_INCLUDE_DIRS})
|
include_directories (${libssl_INCLUDE_DIRS} ${jansson_INCLUDE_DIRS})
|
||||||
link_directories (${libssl_LIBRARY_DIRS} ${jansson_LIBRARY_DIRS})
|
link_directories (${libssl_LIBRARY_DIRS} ${jansson_LIBRARY_DIRS})
|
||||||
|
|
||||||
# -lpthread is only there for debugging (gdb & errno)
|
|
||||||
# -lrt is only for glibc < 2.17
|
# -lrt is only for glibc < 2.17
|
||||||
# -liconv may or may not be a part of libc
|
# -liconv may or may not be a part of libc
|
||||||
foreach (extra iconv dl rt pthread)
|
foreach (extra iconv dl rt)
|
||||||
find_library (extra_lib_${extra} ${extra})
|
find_library (extra_lib_${extra} ${extra})
|
||||||
if (extra_lib_${extra})
|
if (extra_lib_${extra})
|
||||||
list (APPEND project_libraries ${extra})
|
list (APPEND project_libraries ${extra})
|
||||||
endif (extra_lib_${extra})
|
endif ()
|
||||||
endforeach (extra)
|
endforeach ()
|
||||||
|
|
||||||
# Project source files
|
# Project source files
|
||||||
set (project_sources ${PROJECT_NAME}.c)
|
set (project_sources ${PROJECT_NAME}.c)
|
||||||
|
@ -83,6 +76,7 @@ include_directories (${PROJECT_SOURCE_DIR} ${PROJECT_BINARY_DIR})
|
||||||
# Build and install the main executable
|
# Build and install the main executable
|
||||||
add_executable (${PROJECT_NAME} ${project_sources} ${project_headers})
|
add_executable (${PROJECT_NAME} ${project_sources} ${project_headers})
|
||||||
target_link_libraries (${PROJECT_NAME} ${project_libraries})
|
target_link_libraries (${PROJECT_NAME} ${project_libraries})
|
||||||
|
add_threads (${PROJECT_NAME})
|
||||||
|
|
||||||
install (TARGETS ${PROJECT_NAME} DESTINATION ${CMAKE_INSTALL_BINDIR})
|
install (TARGETS ${PROJECT_NAME} DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||||
install (FILES LICENSE DESTINATION ${CMAKE_INSTALL_DOCDIR})
|
install (FILES LICENSE DESTINATION ${CMAKE_INSTALL_DOCDIR})
|
||||||
|
@ -91,6 +85,7 @@ install (FILES LICENSE DESTINATION ${CMAKE_INSTALL_DOCDIR})
|
||||||
add_library (plugin-http SHARED plugins/http.c plugin-api.h
|
add_library (plugin-http SHARED plugins/http.c plugin-api.h
|
||||||
http-parser/http_parser.c http-parser/http_parser.h)
|
http-parser/http_parser.c http-parser/http_parser.h)
|
||||||
target_link_libraries (plugin-http ${project_libraries})
|
target_link_libraries (plugin-http ${project_libraries})
|
||||||
|
add_threads (plugin-http)
|
||||||
set_target_properties (plugin-http PROPERTIES OUTPUT_NAME http PREFIX "")
|
set_target_properties (plugin-http PROPERTIES OUTPUT_NAME http PREFIX "")
|
||||||
install (TARGETS plugin-http DESTINATION ${plugin_dir})
|
install (TARGETS plugin-http DESTINATION ${plugin_dir})
|
||||||
|
|
||||||
|
@ -102,21 +97,22 @@ if (WITH_LUA)
|
||||||
list (APPEND plugins lua-loader)
|
list (APPEND plugins lua-loader)
|
||||||
foreach (lua_plugin ${lua_plugins})
|
foreach (lua_plugin ${lua_plugins})
|
||||||
install (FILES plugins/${lua_plugin}.lua DESTINATION ${plugin_dir})
|
install (FILES plugins/${lua_plugin}.lua DESTINATION ${plugin_dir})
|
||||||
endforeach (lua_plugin)
|
endforeach ()
|
||||||
endif (WITH_LUA)
|
endif ()
|
||||||
foreach (plugin ${plugins})
|
foreach (plugin ${plugins})
|
||||||
set (target plugin-${plugin})
|
set (target plugin-${plugin})
|
||||||
add_library (${target} SHARED plugins/${plugin}.c plugin-api.h)
|
add_library (${target} SHARED plugins/${plugin}.c plugin-api.h)
|
||||||
target_link_libraries (${target} ${project_libraries})
|
target_link_libraries (${target} ${project_libraries})
|
||||||
|
add_threads (${target})
|
||||||
set_target_properties (${target} PROPERTIES OUTPUT_NAME ${plugin} PREFIX "")
|
set_target_properties (${target} PROPERTIES OUTPUT_NAME ${plugin} PREFIX "")
|
||||||
install (TARGETS ${target} DESTINATION ${plugin_dir})
|
install (TARGETS ${target} DESTINATION ${plugin_dir})
|
||||||
endforeach (plugin)
|
endforeach ()
|
||||||
|
|
||||||
# Generate documentation from program help
|
# Generate documentation from program help
|
||||||
find_program (HELP2MAN_EXECUTABLE help2man)
|
find_program (HELP2MAN_EXECUTABLE help2man)
|
||||||
if (NOT HELP2MAN_EXECUTABLE)
|
if (NOT HELP2MAN_EXECUTABLE)
|
||||||
message (FATAL_ERROR "help2man not found")
|
message (FATAL_ERROR "help2man not found")
|
||||||
endif (NOT HELP2MAN_EXECUTABLE)
|
endif ()
|
||||||
|
|
||||||
foreach (page ${PROJECT_NAME})
|
foreach (page ${PROJECT_NAME})
|
||||||
set (page_output "${PROJECT_BINARY_DIR}/${page}.1")
|
set (page_output "${PROJECT_BINARY_DIR}/${page}.1")
|
||||||
|
@ -126,7 +122,7 @@ foreach (page ${PROJECT_NAME})
|
||||||
"${PROJECT_BINARY_DIR}/${page}" -o ${page_output}
|
"${PROJECT_BINARY_DIR}/${page}" -o ${page_output}
|
||||||
DEPENDS ${page}
|
DEPENDS ${page}
|
||||||
COMMENT "Generating man page for ${page}" VERBATIM)
|
COMMENT "Generating man page for ${page}" VERBATIM)
|
||||||
endforeach (page)
|
endforeach ()
|
||||||
|
|
||||||
add_custom_target (docs ALL DEPENDS ${project_MAN_PAGES})
|
add_custom_target (docs ALL DEPENDS ${project_MAN_PAGES})
|
||||||
|
|
||||||
|
@ -134,23 +130,22 @@ foreach (page ${project_MAN_PAGES})
|
||||||
string (REGEX MATCH "\\.([0-9])$" manpage_suffix "${page}")
|
string (REGEX MATCH "\\.([0-9])$" manpage_suffix "${page}")
|
||||||
install (FILES "${page}"
|
install (FILES "${page}"
|
||||||
DESTINATION "${CMAKE_INSTALL_MANDIR}/man${CMAKE_MATCH_1}")
|
DESTINATION "${CMAKE_INSTALL_MANDIR}/man${CMAKE_MATCH_1}")
|
||||||
endforeach (page)
|
endforeach ()
|
||||||
|
|
||||||
# CPack
|
# CPack
|
||||||
set (CPACK_PACKAGE_DESCRIPTION_SUMMARY "Experimental network scanner")
|
set (CPACK_PACKAGE_DESCRIPTION_SUMMARY "Experimental network scanner")
|
||||||
set (CPACK_PACKAGE_VERSION ${project_VERSION})
|
|
||||||
set (CPACK_PACKAGE_VENDOR "Premysl Eric Janouch")
|
set (CPACK_PACKAGE_VENDOR "Premysl Eric Janouch")
|
||||||
set (CPACK_PACKAGE_CONTACT "Přemysl Eric Janouch <p@janouch.name>")
|
set (CPACK_PACKAGE_CONTACT "Přemysl Eric Janouch <p@janouch.name>")
|
||||||
set (CPACK_RESOURCE_FILE_LICENSE "${PROJECT_SOURCE_DIR}/LICENSE")
|
set (CPACK_RESOURCE_FILE_LICENSE "${PROJECT_SOURCE_DIR}/LICENSE")
|
||||||
|
|
||||||
set (CPACK_GENERATOR "TGZ;ZIP")
|
set (CPACK_GENERATOR "TGZ;ZIP")
|
||||||
set (CPACK_PACKAGE_FILE_NAME
|
set (CPACK_PACKAGE_FILE_NAME
|
||||||
"${PROJECT_NAME}-${project_VERSION}-${CMAKE_SYSTEM_NAME}-${CMAKE_SYSTEM_PROCESSOR}")
|
"${PROJECT_NAME}-${PROJECT_VERSION}-${CMAKE_SYSTEM_NAME}-${CMAKE_SYSTEM_PROCESSOR}")
|
||||||
set (CPACK_PACKAGE_INSTALL_DIRECTORY "${PROJECT_NAME}-${project_VERSION}")
|
set (CPACK_PACKAGE_INSTALL_DIRECTORY "${PROJECT_NAME}-${PROJECT_VERSION}")
|
||||||
|
|
||||||
set (CPACK_SOURCE_GENERATOR "TGZ;ZIP")
|
set (CPACK_SOURCE_GENERATOR "TGZ;ZIP")
|
||||||
set (CPACK_SOURCE_IGNORE_FILES "/\\\\.git;/build;/CMakeLists.txt.user")
|
set (CPACK_SOURCE_IGNORE_FILES "/\\\\.git;/build;/CMakeLists.txt.user")
|
||||||
set (CPACK_SOURCE_PACKAGE_FILE_NAME "${PROJECT_NAME}-${project_VERSION}")
|
set (CPACK_SOURCE_PACKAGE_FILE_NAME "${PROJECT_NAME}-${PROJECT_VERSION}")
|
||||||
|
|
||||||
set (CPACK_SET_DESTDIR TRUE)
|
set (CPACK_SET_DESTDIR TRUE)
|
||||||
include (CPack)
|
include (CPack)
|
||||||
|
|
|
@ -22,7 +22,7 @@ a package with the latest development version from Archlinux's AUR.
|
||||||
|
|
||||||
Building and Usage
|
Building and Usage
|
||||||
------------------
|
------------------
|
||||||
Build dependencies: CMake, pkg-config, help2man +
|
Build dependencies: CMake >= 3.0, pkg-config, help2man +
|
||||||
Runtime dependenices: curses, openssl, Jansson, lua >= 5.3 (optional)
|
Runtime dependenices: curses, openssl, Jansson, lua >= 5.3 (optional)
|
||||||
|
|
||||||
$ git clone --recursive https://git.janouch.name/p/ponymap.git
|
$ git clone --recursive https://git.janouch.name/p/ponymap.git
|
||||||
|
@ -40,9 +40,6 @@ Or you can try telling CMake to make a package for you. For Debian it is:
|
||||||
$ cpack -G DEB
|
$ cpack -G DEB
|
||||||
# dpkg -i ponymap-*.deb
|
# dpkg -i ponymap-*.deb
|
||||||
|
|
||||||
Note that for versions of CMake before 2.8.9, you need to prefix `cpack` with
|
|
||||||
`fakeroot` or file ownership will end up wrong.
|
|
||||||
|
|
||||||
Having the program installed, simply run it with no arguments to retrieve
|
Having the program installed, simply run it with no arguments to retrieve
|
||||||
a usage text. Have fun scanning.
|
a usage text. Have fun scanning.
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
#ifndef CONFIG_H
|
#ifndef CONFIG_H
|
||||||
#define CONFIG_H
|
#define CONFIG_H
|
||||||
|
|
||||||
#define PROGRAM_NAME "${CMAKE_PROJECT_NAME}"
|
#define PROGRAM_NAME "${PROJECT_NAME}"
|
||||||
#define PROGRAM_VERSION "${project_VERSION}"
|
#define PROGRAM_VERSION "${PROJECT_VERSION}"
|
||||||
|
|
||||||
#cmakedefine WITH_LUA
|
#cmakedefine WITH_LUA
|
||||||
#define PLUGIN_DIR "${CMAKE_INSTALL_PREFIX}/${plugin_dir}"
|
#define PLUGIN_DIR "${CMAKE_INSTALL_PREFIX}/${plugin_dir}"
|
||||||
|
|
2
liberty
2
liberty
|
@ -1 +1 @@
|
||||||
Subproject commit 1a76b2032e6d18d9f95d9d0bb98edc26023c8618
|
Subproject commit d71c47f8ce7aecdc4856630e9d73a48912be68c1
|
|
@ -470,8 +470,7 @@ indicator_set_status (struct indicator *self, char *status)
|
||||||
bool refresh = self->shown;
|
bool refresh = self->shown;
|
||||||
indicator_hide (self);
|
indicator_hide (self);
|
||||||
|
|
||||||
free (self->status);
|
cstr_set (&self->status, status);
|
||||||
self->status = status;
|
|
||||||
|
|
||||||
if (refresh)
|
if (refresh)
|
||||||
indicator_show (self);
|
indicator_show (self);
|
||||||
|
|
Loading…
Reference in New Issue