#Where to find local cmake scripts
set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/modules)
-INCLUDE(UseLemon)
-INCLUDE(UseMakeDissectorReg)
-INCLUDE(UseMakeTapReg)
-INCLUDE(UseAsn2Wrs)
+include(UseLemon)
+include(UseMakeDissectorReg)
+include(UseMakeTapReg)
+include(UseAsn2Wrs)
# Under linux the release mode (CMAKE_BUILD_TYPE=release) defines NDEBUG
${CMAKE_BINARY_DIR}
${CMAKE_SOURCE_DIR}
${CMAKE_SOURCE_DIR}/epan
+ ${CMAKE_SOURCE_DIR}/filetap
${CMAKE_SOURCE_DIR}/tools/lemon
${CMAKE_SOURCE_DIR}/wiretap
)
-#Where to put libraries
+#Where to put executables and libraries in the build tree
+if(NOT ARCHIVE_OUTPUT_PATH)
+ set(ARCHIVE_OUTPUT_PATH ${Wireshark_BINARY_DIR}/run CACHE INTERNAL
+ "Single output directory for building all archives.")
+endif()
+if(NOT EXECUTABLE_OUTPUT_PATH)
+ set(EXECUTABLE_OUTPUT_PATH ${Wireshark_BINARY_DIR}/run CACHE INTERNAL
+ "Single output directory for building all executables.")
+endif()
if(NOT LIBRARY_OUTPUT_PATH)
- set(LIBRARY_OUTPUT_PATH ${Wireshark_BINARY_DIR}/lib CACHE INTERNAL
+ set(LIBRARY_OUTPUT_PATH ${Wireshark_BINARY_DIR}/run CACHE INTERNAL
"Single output directory for building all libraries.")
endif()
-
-include(CMakeOptions.txt)
+include( CMakeOptions.txt )
+if( DUMPCAP_INSTALL_OPTION STREQUAL "suid" )
+ set( DUMPCAP_SETUID "SETUID" )
+else()
+ set( DUMPCAP_SETUID )
+endif()
+if( NOT CMAKE_SYSTEM_NAME STREQUAL "Linux" AND
+ DUMPCAP_INSTALL_OPTION STREQUAL "capabilities" )
+ message( WARNING "Capabilities are only supported on Linux" )
+ set( DUMPCAP_INSTALL_OPTION )
+endif()
if( CMAKE_C_COMPILER_ID MATCHES "MSVC")
+ if (MSVC10)
+ set(MSC_VER_REQUIRED 1600)
+ elseif(MSVC11)
+ set(MSC_VER_REQUIRED 1700)
+ elseif(MSVC12)
+ set(MSC_VER_REQUIRED 1800)
+ else()
+ message(FATAL_ERROR "You are using an unsupported version of MSVC")
+ endif()
set(LOCAL_CFLAGS
/Zi
/W3
## 4295: array is too small to include a terminating null character
set(WARNINGS_CFLAGS "/w34295")
+ # FIXME: WINPCAP_VERSION cannot be determined from source or executable.
+ set(WINPCAP_VERSION "unknown")
set(WIRESHARK_C_FLAGS
- # FIXME: This doen't work as PCAP_VERSION will be determined later
- "/DPCAP_VERSION=${PCAP_VERSION}"
+ "/DWINPCAP_VERSION=${WINPCAP_VERSION}"
${LOCAL_CFLAGS}
${WARNINGS_CFLAGS}
)
-Wpointer-arith
-Warray-bounds
-Wformat-security
- -Wshorten-64-to-32
-Wvla
-Waddress
- -Warray-bounds
-Wattributes
-Wdiv-by-zero
-Wignored-qualifiers
-Wstrict-prototypes
-Wlogical-op
-Wjump-misses-init
+ # The Qt headers generate a ton of shortening errors on 64-bit systems
+ # so only enable this for C for now.
+ -Wshorten-64-to-32
+ )
+
+ set(WIRESHARK_CPP_ONLY_FLAGS
)
set(WIRESHARK_EXTRA_C_FLAGS
-Wcast-qual
-Wformat-security
-Wredundant-decls
+ -Wheader-guard
+ -fwrapv
+ -fno-strict-overflow
+ -fno-delete-null-pointer-checks
# All the registration functions block these for now.
-Wmissing-declarations
)
-Wmissing-prototypes
)
+ set(WIRESHARK_EXTRA_CPP_ONLY_FLAGS
+ )
+
# With clang some tests don't fail properly during testing but only
# during real compiles
if(ENABLE_EXTRA_GCC_CHECKS) # This overrides -Werror
set(WIRESHARK_C_FLAGS ${WIRESHARK_C_FLAGS} ${WIRESHARK_EXTRA_C_FLAGS})
set(WIRESHARK_C_ONLY_FLAGS ${WIRESHARK_C_ONLY_FLAGS} ${WIRESHARK_EXTRA_C_ONLY_FLAGS})
+ set(WIRESHARK_CPP_ONLY_FLAGS ${WIRESHARK_CPP_ONLY_FLAGS} ${WIRESHARK_EXTRA_CPP_ONLY_FLAGS})
endif()
add_definitions(
)
endif()
+set( C_FLAG_TESTS ${WIRESHARK_C_FLAGS} ${WIRESHARK_C_ONLY_FLAGS} )
+set( CPP_FLAG_TESTS ${WIRESHARK_C_FLAGS} ${WIRESHARK_CPP_ONLY_FLAGS} )
+
# Counterhack to work around some cache magic in CHECK_C_SOURCE_COMPILES
include(CheckCCompilerFlag)
+include(CheckCXXCompilerFlag)
if(NOT DISABLE_WERROR AND NOT ENABLE_EXTRA_GCC_CHECKS)
check_c_compiler_flag(-Werror=unknown-warning-option WERR_UNKNOWN)
set(CMAKE_REQUIRED_FLAGS -Werror=unknown-warning-option )
endif()
-set(C 0)
# Sigh: Have to use THIS_FLAG instead of ${F} for some reason
-foreach(THIS_FLAG ${WIRESHARK_C_FLAGS})
- set(F WS_C_FLAG_${C})
+foreach(THIS_FLAG ${C_FLAG_TESTS})
+ string( REGEX REPLACE "[^a-zA-Z0-9_]+" "_" F ${THIS_FLAG} )
set(${F} ${THIS_FLAG})
- set(V WS_C_FLAG_VALID${C})
- message(STATUS "Checking for flag: ${${F}}")
+ set(V C_${F}_VALID)
+ message(STATUS "Checking for c-compiler flag: ${THIS_FLAG}")
check_c_compiler_flag(${${F}} ${V})
if (${${V}})
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${${F}}")
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${${F}}")
endif()
- math(EXPR C "${C} + 1")
endforeach()
-# Continue increasing C from previous loop
-foreach(THIS_FLAG ${WIRESHARK_C_ONLY_FLAGS})
- set(F WS_C_FLAG_${C})
+foreach(THIS_FLAG ${CPP_FLAG_TESTS})
+ string( REGEX REPLACE "[^a-zA-Z0-9_]+" "_" F ${THIS_FLAG} )
set(${F} ${THIS_FLAG})
- set(V WS_C_FLAG_VALID${C})
- message(STATUS "Checking for flag: ${${F}}")
- check_c_compiler_flag(${${F}} ${V})
+ set(V CPP_${F}_VALID)
+ message(STATUS "Checking for c++-compiler flag: ${THIS_FLAG}")
+ check_cxx_compiler_flag(${${F}} ${V})
if (${${V}})
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${${F}}")
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${${F}}")
endif()
- math(EXPR C "${C} + 1")
endforeach()
message(STATUS "C-Flags: ${CMAKE_C_FLAGS}\nCXX-Flags: ${CMAKE_CXX_FLAGS}")
check_c_compiler_flag(-fvisibility=hidden FVHIDDEN)
-if((FVHIDDEN))
+if(FVHIDDEN)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fvisibility=hidden")
else() # TODO add alternate compiler flags for hiding symbols
message(WARNING "Hiding shared library symbols is not supported by the compiler."
# somewhere. The if WIN32 in this place is annoying as well.
if( WIN32 )
set( QT5_BASE_PATH "$ENV{QT5_BASE_DIR}" )
- set( CMAKE_PREFIX_PATH "${QT5_BASE_PATH}\\msvc2010" )
+ set( CMAKE_PREFIX_PATH "${QT5_BASE_PATH}" )
+ # Used for the creation of setpath.bat
set( QT5_DLL_PATH "${CMAKE_PREFIX_PATH}/bin/dummy" )
set( WS_ALL_LIBS ${WS_ALL_LIBS} ${QT5_DLL_PATH} )
endif()
set(PACKAGELIST ${PACKAGELIST} NL)
endif()
+if(ENABLE_SBC)
+ set(PACKAGELIST ${PACKAGELIST} SBC)
+endif()
+
# Capabilities
if(ENABLE_CAP)
- set(PACKAGELIST ${PACKAGELIST} CAP)
+ set(PACKAGELIST ${PACKAGELIST} CAP SETCAP)
endif()
if(ENABLE_PYTHON)
set(PACKAGELIST ${PACKAGELIST} POD)
-set(PROGLIST text2pcap mergecap capinfos editcap reordercap dumpcap)
+if(ENABLE_GUIDES)
+ set(PACKAGELIST ${PACKAGELIST} DOXYGEN)
+endif()
+
+set(PROGLIST text2pcap mergecap capinfos captype editcap reordercap dumpcap)
#Sort the package list
list(SORT PACKAGELIST)
if(HAVE_LIBNL AND HAVE_AIRPCAP)
message(ERROR "Airpcap and Libnl support are mutually exclusive")
endif()
+if(HAVE_LIBSBC)
+ set(HAVE_SBC 1)
+endif()
# No matter which version of GTK is present
if(GTK2_FOUND OR GTK3_FOUND)
set(GTK_FOUND ON)
# That's the name autofoo uses
if(HAVE_LIBZLIB)
set(HAVE_LIBZ 1)
+ # Always include the "true" zlib includes first. This works around a
+ # bug in the Windows setup of GTK[23] which has a faulty zconf.h.
+ include_directories(BEFORE ${ZLIB_INCLUDE_DIRS})
endif()
if (Qt5Widgets_FOUND)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${Qt5Widgets_EXECUTABLE_COMPILE_FLAGS}")
set(DATAFILE_DIR "${CMAKE_INSTALL_PREFIX}/share/${CPACK_PACKAGE_NAME}")
-SET_PROPERTY(GLOBAL PROPERTY USE_FOLDERS ON)
+set_property(GLOBAL PROPERTY USE_FOLDERS ON)
if(ENABLE_PLUGINS)
set(HAVE_PLUGINS 1)
set(PLUGIN_DIR="${DATAFILE_DIR}/plugins/${CPACK_PACKAGE_VERSION}")
+ set(PLUGIN_INSTALL_DIR="${CMAKE_INSTALL_LIBDIR}/@CPACK_PACKAGE_NAME@/plugins/${CPACK_PACKAGE_VERSION}")
set(PLUGIN_SRC_DIRS
- plugins/asn1
plugins/docsis
plugins/ethercat
plugins/gryphon
add_subdirectory( asn1 EXCLUDE_FROM_ALL )
add_subdirectory( codecs )
add_subdirectory( epan )
+add_subdirectory( filetap )
add_subdirectory( tools/lemon )
add_subdirectory( ui )
add_subdirectory( wiretap )
add_subdirectory( wsutil )
-add_custom_target(dumpabi DEPENDS dumpabi-libwireshark dumpabi-libwiretap dumpabi-libwsutil color.h)
+add_custom_target(dumpabi DEPENDS dumpabi-libwireshark dumpabi-libfiletap dumpabi-libwiretap dumpabi-libwsutil color.h)
if(ENABLE_ECHLD)
add_subdirectory( echld )
endif()
configure_file(${CMAKE_SOURCE_DIR}/cmakeconfig.h.in ${CMAKE_BINARY_DIR}/config.h)
+configure_file(${CMAKE_SOURCE_DIR}/wireshark.pc.in ${CMAKE_BINARY_DIR}/wireshark.pc @ONLY)
+if( ENABLE_GUIDES )
+ configure_file(
+ ${CMAKE_SOURCE_DIR}/doxygen_global.cfg
+ ${CMAKE_BINARY_DIR}/doxygen_global.cfg
+ )
+ configure_file(
+ ${CMAKE_SOURCE_DIR}/ui/qt/doxygen.cfg.in
+ ${CMAKE_BINARY_DIR}/ui/qt/doxygen.cfg
+ )
+ configure_file(
+ ${CMAKE_SOURCE_DIR}/ui/gtk/doxygen.cfg.in
+ ${CMAKE_BINARY_DIR}/ui/gtk/doxygen.cfg
+ )
+ configure_file(
+ ${CMAKE_SOURCE_DIR}/ui/doxygen.cfg.in
+ ${CMAKE_BINARY_DIR}/ui/doxygen.cfg
+ )
+ configure_file(
+ ${CMAKE_SOURCE_DIR}/epan/doxygen.cfg.in
+ ${CMAKE_BINARY_DIR}/epan/doxygen.cfg
+ )
+ configure_file(
+ ${CMAKE_SOURCE_DIR}/doxygen.cfg.in
+ ${CMAKE_BINARY_DIR}/doxygen.cfg
+ )
+endif()
set( configure_input "Built with CMake ${CMAKE_VERSION}" )
set( VERSION ${PROJECT_VERSION} )
configure_file(
${CMAKE_SOURCE_DIR}/packaging/macosx/Info.plist.in
- ${CMAKE_SOURCE_DIR}/packaging/macosx/Info.plist
+ ${CMAKE_BINARY_DIR}/packaging/macosx/Info.plist
@ONLY)
include(FeatureSummary)
${CMAKE_BINARY_DIR}/ui/qt
${CMAKE_BINARY_DIR}/codecs
${CMAKE_BINARY_DIR}/epan
+ ${CMAKE_BINARY_DIR}/filetap
${CMAKE_BINARY_DIR}/wiretap
${CMAKE_BINARY_DIR}/wsutil
)
ADD_CUSTOM_TARGET(
- svnversion ALL
+ gitversion ALL
COMMAND ${PERL_EXECUTABLE}
${CMAKE_CURRENT_SOURCE_DIR}/make-version.pl
${CMAKE_CURRENT_SOURCE_DIR}
DEPENDS
${CMAKE_CURRENT_SOURCE_DIR}/make-version.pl
)
-set_target_properties(svnversion PROPERTIES FOLDER "Auxiliary")
+set_target_properties(gitversion PROPERTIES FOLDER "Auxiliary")
ADD_CUSTOM_COMMAND(
- OUTPUT svnversion.h
+ OUTPUT version.h
COMMAND ${PERL_EXECUTABLE}
${CMAKE_CURRENT_SOURCE_DIR}/make-version.pl
${CMAKE_CURRENT_SOURCE_DIR}
)
if(UNIX)
- set(PLATFORM_CAPTURE_SRC
+ set(PLATFORM_PCAP_SRC
capture-pcap-util-unix.c
)
endif()
if(WIN32)
- set(PLATFORM_CAPTURE_SRC
+ set(PLATFORM_PCAP_SRC
capture_win_ifnames.c
capture-wpcap.c
capture_wpcap_packet.c
)
endif()
-set(WTAP_PLUGIN_SOURCES
- epan/plugins.c
-)
-
-set(SHARK_COMMON_CAPTURE_SRC
- capture_ifinfo.c
- capture_ui_utils.c
-)
-
-set(WIRESHARK_COMMON_SRC
- ${PLATFORM_CAPTURE_SRC}
+# sources common for wireshark, tshark, and rawshark
+set(SHARK_COMMON_SRC
+ ${PLATFORM_PCAP_SRC}
capture-pcap-util.c
cfile.c
cfutils.c
clopts_common.c
frame_tvbuff.c
- svnversion.h
+ version.h
sync_pipe_write.c
version_info.c
)
+# sources common for wireshark and tshark, but not rawshark;
+# these are for programs that capture traffic by running dumpcap
+set(SHARK_COMMON_CAPTURE_SRC
+ capture_ifinfo.c
+ capture_sync.c
+ capture_ui_utils.c
+)
+
set(TSHARK_TAP_SRC
ui/cli/tap-afpstat.c
ui/cli/tap-ansi_astat.c
${CMAKE_BINARY_DIR}/AUTHORS-SHORT
COPYING
${CMAKE_BINARY_DIR}/capinfos.html
+ ${CMAKE_BINARY_DIR}/captype.html
cfilters
colorfilters
dfilters
${SMI_LIBRARIES}
${ZLIB_LIBRARIES}
${M_LIBRARIES}
+ ${SBC_LIBRARIES}
)
if( (BUILD_wireshark AND GTK_FOUND) OR (BUILD_qtshark AND QT_FOUND) )
capture.c
capture_info.c
capture_opts.c
- capture_sync.c
color_filters.c
file.c
fileset.c
summary.c
ws80211_utils.c
${SHARK_COMMON_CAPTURE_SRC}
- ${WIRESHARK_COMMON_SRC}
+ ${SHARK_COMMON_SRC}
${PLATFORM_UI_SRC}
)
endif()
# qtshark and wireshark share wireshark_FILES
add_executable(wireshark ${wireshark_FILES})
- add_dependencies(wireshark svnversion)
+ add_dependencies(wireshark gitversion)
set_target_properties(wireshark PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(wireshark PROPERTIES FOLDER "Executables")
target_link_libraries(wireshark ${wireshark_LIBS})
# qtshark and wireshark share wireshark_FILES
add_executable(qtshark ${wireshark_FILES})
- add_dependencies(qtshark svnversion)
+ add_dependencies(qtshark gitversion)
set_target_properties(qtshark PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(qtshark PROPERTIES FOLDER "Executables")
target_link_libraries(qtshark ${qtshark_LIBS})
)
set(tshark_FILES
capture_opts.c
- capture_sync.c
tshark-tap-register.c
tshark.c
${TSHARK_TAP_SRC}
${SHARK_COMMON_CAPTURE_SRC}
- ${WIRESHARK_COMMON_SRC}
+ ${SHARK_COMMON_SRC}
)
add_executable(tshark ${tshark_FILES})
- add_dependencies(tshark svnversion)
+ add_dependencies(tshark gitversion)
set_target_properties(tshark PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(tshark PROPERTIES FOLDER "Executables")
target_link_libraries(tshark ${tshark_LIBS})
install(TARGETS tshark RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
+if(BUILD_tfshark)
+ set(tfshark_LIBS
+ filetap
+ ui
+ ${LIBEPAN_LIBS}
+ ${APPLE_CORE_FOUNDATION_LIBRARY}
+ ${APPLE_SYSTEM_CONFIGURATION_LIBRARY}
+ )
+ set(tfshark_FILES
+ tfshark.c
+ ${TSHARK_TAP_SRC}
+ ${SHARK_COMMON_SRC}
+ )
+ add_executable(tfshark ${tfshark_FILES})
+ add_dependencies(tfshark gitversion)
+ set_target_properties(tfshark PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
+ set_target_properties(tfshark PROPERTIES FOLDER "Executables")
+ target_link_libraries(tfshark ${tfshark_LIBS})
+ install(TARGETS tfshark RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
+endif()
+
if(BUILD_rawshark AND PCAP_FOUND)
set(rawshark_LIBS
${LIBEPAN_LIBS}
${APPLE_SYSTEM_CONFIGURATION_LIBRARY}
)
set(rawshark_FILES
- ${WIRESHARK_COMMON_SRC}
+ ${SHARK_COMMON_SRC}
rawshark.c
ui/util.c
)
add_executable(rawshark ${rawshark_FILES})
- add_dependencies(rawshark svnversion)
+ add_dependencies(rawshark gitversion)
set_target_properties(rawshark PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(rawshark PROPERTIES FOLDER "Executables")
target_link_libraries(rawshark ${rawshark_LIBS})
text2pcap-scanner.l
)
add_executable(text2pcap ${text2pcap_FILES})
- add_dependencies(text2pcap svnversion)
+ add_dependencies(text2pcap gitversion)
set_target_properties(text2pcap PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(text2pcap PROPERTIES FOLDER "Executables")
target_link_libraries(text2pcap ${text2pcap_LIBS})
)
set(mergecap_FILES
mergecap.c
- svnversion.h
- ${WTAP_PLUGIN_SOURCES}
+ version.h
)
add_executable(mergecap ${mergecap_FILES})
- add_dependencies(mergecap svnversion)
+ add_dependencies(mergecap gitversion)
set_target_properties(mergecap PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(mergecap PROPERTIES FOLDER "Executables")
target_link_libraries(mergecap ${mergecap_LIBS})
)
set(reordercap_FILES
reordercap.c
- svnversion.h
- ${WTAP_PLUGIN_SOURCES}
+ version.h
)
add_executable(reordercap ${reordercap_FILES})
- add_dependencies(reordercap svnversion)
+ add_dependencies(reordercap gitversion)
set_target_properties(reordercap PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(reordercap PROPERTIES FOLDER "Executables")
target_link_libraries(reordercap ${reordercap_LIBS})
)
set(capinfos_FILES
capinfos.c
- ${WTAP_PLUGIN_SOURCES}
)
add_executable(capinfos ${capinfos_FILES})
- add_dependencies(capinfos svnversion)
+ add_dependencies(capinfos gitversion)
set_target_properties(capinfos PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(capinfos PROPERTIES FOLDER "Executables")
target_link_libraries(capinfos ${capinfos_LIBS})
install(TARGETS capinfos RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
+if(BUILD_captype)
+ set(captype_LIBS
+ wiretap
+ wsutil
+ ${ZLIB_LIBRARIES}
+ ${CMAKE_DL_LIBS}
+ )
+ set(captype_FILES
+ captype.c
+ )
+ add_executable(captype ${captype_FILES})
+ add_dependencies(captype gitversion)
+ set_target_properties(captype PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
+ set_target_properties(captype PROPERTIES FOLDER "Executables")
+ target_link_libraries(captype ${captype_LIBS})
+ install(TARGETS captype RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
+endif()
+
if(BUILD_editcap)
set(editcap_LIBS
wiretap
)
set(editcap_FILES
editcap.c
- ${WTAP_PLUGIN_SOURCES}
)
add_executable(editcap ${editcap_FILES})
- add_dependencies(editcap svnversion)
+ add_dependencies(editcap gitversion)
set_target_properties(editcap PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(editcap PROPERTIES FOLDER "Executables")
target_link_libraries(editcap ${editcap_LIBS})
${NL_LIBRARIES}
)
set(dumpcap_FILES
- svnversion.h
+ version.h
capture_opts.c
capture-pcap-util.c
capture_stop_conditions.c
sync_pipe_write.c
version_info.c
ws80211_utils.c
- ${PLATFORM_CAPTURE_SRC}
+ ${PLATFORM_PCAP_SRC}
)
add_executable(dumpcap ${dumpcap_FILES})
- add_dependencies(dumpcap svnversion)
+ add_dependencies(dumpcap gitversion)
set_target_properties(dumpcap PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
set_target_properties(dumpcap PROPERTIES FOLDER "Executables")
target_link_libraries(dumpcap ${dumpcap_LIBS})
- install(TARGETS dumpcap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
+ install(TARGETS dumpcap
+ RUNTIME
+ DESTINATION ${CMAKE_INSTALL_BINDIR}
+ PERMISSIONS ${DUMPCAP_SETUID}
+ OWNER_READ OWNER_WRITE OWNER_EXECUTE
+ GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
+ )
+ if(DUMPCAP_INSTALL_OPTION STREQUAL "capabilities")
+ install( CODE "execute_process(
+ COMMAND
+ ${SETCAP_EXECUTABLE}
+ cap_net_raw,cap_net_admin+ep
+ ${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_BINDIR}/dumpcap${CMAKE_EXECUTABLE_SUFFIX}
+ RESULT_VARIABLE
+ _SETCAP_RESULT
+ )
+ if( _SETCAP_RESULT )
+ message( WARNING \"setcap failed (${_SETCAP_RESULT}).\")
+ endif()"
+ )
+ endif()
endif()
ADD_CUSTOM_COMMAND(
)
pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/capinfos 1 )
+pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/captype 1 )
pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/dftest 1 )
pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/dumpcap 1 )
pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/editcap 1 )
DEPENDS
AUTHORS-SHORT
capinfos.html
+ captype.html
dftest.html
dumpcap.html
editcap.html
set(MAN1_FILES
${CMAKE_BINARY_DIR}/capinfos.1
+ ${CMAKE_BINARY_DIR}/captype.1
${CMAKE_BINARY_DIR}/dftest.1
${CMAKE_BINARY_DIR}/dumpcap.1
${CMAKE_BINARY_DIR}/editcap.1
${text2pcap_CLEAN_FILES}
${mergecap_FILES}
${capinfos_FILES}
+ ${captype_FILES}
${editcap_FILES}
${dumpcap_FILES}
)
${CMAKE_INSTALL_MANDIR}/man4
)
+install(
+ FILES
+ "${CMAKE_BINARY_DIR}/wireshark.pc"
+ DESTINATION
+ ${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_LIBDIR}/pkgconfig
+)
+
install(
DIRECTORY
${INSTALL_DIRS}
WORLD_EXECUTE WORLD_READ
DESTINATION
${CMAKE_INSTALL_DATADIR}/${CPACK_PACKAGE_NAME}
+ PATTERN ".git" EXCLUDE
PATTERN ".svn" EXCLUDE
PATTERN "Makefile.*" EXCLUDE
PATTERN "faq.py" EXCLUDE