Use ws_printf routines everywhere in column-utils.c.
[gd/wireshark/.git] / CMakeLists.txt
index 90fde1e1a274c5745f9df12658ca146ec4f42ded..488e451e72fb039dd0df0e41c69021882abae3ce 100644 (file)
@@ -28,7 +28,7 @@ if(WIN32)
        # 3.1.3 is the currently supported version
        cmake_minimum_required(VERSION 3.1.3)
 else()
-       cmake_minimum_required(VERSION 2.8.3)
+       cmake_minimum_required(VERSION 2.8.8)
 endif()
 
 # Needs to be set after cmake_minimum_required or cmake_policy(VERSION)
@@ -177,10 +177,15 @@ include(CMakeInstallDirs)
 # Updated by make-version.pl
 set(GIT_REVISION 0)
 set(PROJECT_MAJOR_VERSION 2)
-set(PROJECT_MINOR_VERSION 1)
+set(PROJECT_MINOR_VERSION 3)
 set(PROJECT_PATCH_VERSION 0)
 set(PROJECT_BUILD_VERSION ${GIT_REVISION})
-set(PROJECT_VERSION_EXTENSION "$ENV{WIRESHARK_VERSION_EXTRA}")
+set(PROJECT_VERSION_EXTENSION "")
+
+if(DEFINED ENV{WIRESHARK_VERSION_EXTRA})
+       set(PROJECT_VERSION_EXTENSION "$ENV{WIRESHARK_VERSION_EXTRA}")
+endif()
+
 set(PROJECT_VERSION "${PROJECT_MAJOR_VERSION}.${PROJECT_MINOR_VERSION}.${PROJECT_PATCH_VERSION}${PROJECT_VERSION_EXTENSION}")
 
 # Banner shown at top right of Qt welcome screen.
@@ -209,7 +214,6 @@ include_directories(
        ${CMAKE_SOURCE_DIR}
        ${CMAKE_SOURCE_DIR}/epan
        ${CMAKE_SOURCE_DIR}/tools/lemon
-       ${CMAKE_SOURCE_DIR}/wiretap
 )
 
 include( CMakeOptions.txt )
@@ -250,7 +254,6 @@ if( CMAKE_C_COMPILER_ID MATCHES "MSVC")
                /DWIN32_LEAN_AND_MEAN
                "/DMSC_VER_REQUIRED=${MSC_VER_REQUIRED}"
                /D_CRT_SECURE_NO_DEPRECATE
-               /D_CRT_NONSTDC_NO_DEPRECATE
                # NOMINMAX keeps windows.h from defining "min" and "max" via windef.h.
                # This avoids conflicts with the C++ standard library.
                /DNOMINMAX
@@ -267,7 +270,7 @@ if( CMAKE_C_COMPILER_ID MATCHES "MSVC")
                # -D_ALLOW_KEYWORD_MACROS           For VS2012 onwards the, C++ STL does not permit macro redefinitions of keywords
                #                                   (see http://msdn.microsoft.com/en-us/library/bb531344(v=vs.110).aspx)
                #                                   This definition prevents the complaint about the redefinition of inline by WinPCap
-               #                                   in pcap-stdinc.h when compiling CPP files, e.g. the Qt UI
+               #                                   in pcap-stdinc.h when compiling C++ files, e.g. the Qt UI
                /DPSAPI_VERSION=1
                /DBUILD_WINDOWS
                /D_ALLOW_KEYWORD_MACROS
@@ -292,8 +295,9 @@ if( CMAKE_C_COMPILER_ID MATCHES "MSVC")
                set(LOCAL_CFLAGS ${LOCAL_CFLAGS} "/Zo")
        elseif(MSVC14)
                # /Zo                               Enhanced debugging of optimised code
+               # /utf-8                            Set Source and Executable character sets to UTF-8
                #                                   VS2015(MSVC14): On by default when /Zi or /Z7 used.
-               set(LOCAL_CFLAGS ${LOCAL_CFLAGS} "/Zo")
+               set(LOCAL_CFLAGS ${LOCAL_CFLAGS} "/Zo" "/utf-8")
        endif()
 
        if(ENABLE_CODE_ANALYSIS)
@@ -311,7 +315,6 @@ if( CMAKE_C_COMPILER_ID MATCHES "MSVC")
                ${WARNINGS_CFLAGS}
        )
 
-       # Set in Makefile.nmake
        set(WS_LINK_FLAGS "/LARGEADDRESSAWARE /MANIFEST:NO /INCREMENTAL:NO /RELEASE")
 
 else()
@@ -344,11 +347,9 @@ else()
                # The following are for C and C++
                # -O<X> and -g get set by the CMAKE_BUILD_TYPE
                -Wall
-               -W
                -Wextra
                -Wendif-labels
                -Wpointer-arith
-               -Warray-bounds
                -Wformat-security
                -fwrapv
                -fno-strict-overflow
@@ -361,7 +362,6 @@ else()
                -Wno-overlength-strings
                -Wno-long-long
                -Wheader-guard
-               -Wunused-const-variable
        )
 
        set(WIRESHARK_C_ONLY_FLAGS
@@ -374,12 +374,15 @@ else()
                -Wstrict-prototypes
                -Wlogical-op
                -Wjump-misses-init
+               -Wunused-const-variable
                # 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
+               # Clang only
+               -Wc99-extensions
        )
 
-       set(WIRESHARK_CPP_ONLY_FLAGS
+       set(WIRESHARK_CXX_ONLY_FLAGS
        )
 
        set(WIRESHARK_EXTRA_COMPILER_COMMON_FLAGS
@@ -447,7 +450,7 @@ else()
                -Wbad-function-cast
        )
 
-       set(WIRESHARK_EXTRA_COMPILER_CPP_ONLY_FLAGS
+       set(WIRESHARK_EXTRA_COMPILER_CXX_ONLY_FLAGS
        )
 
        if(CMAKE_C_COMPILER_ID MATCHES "Clang")
@@ -458,7 +461,7 @@ else()
                        -Qunused-arguments
                )
 
-               set(WIRESHARK_CPP_ONLY_FLAGS ${WIRESHARK_CPP_ONLY_FLAGS}
+               set(WIRESHARK_CXX_ONLY_FLAGS ${WIRESHARK_CXX_ONLY_FLAGS}
                )
        else()
                set(WIRESHARK_COMMON_FLAGS ${WIRESHARK_COMMON_FLAGS}
@@ -469,25 +472,10 @@ else()
                )
        endif()
 
-       set(WIRESHARK_ASAN_FLAGS
-               # With Clang >= 3.5 Leak detection is enable by default
-               # and no yet all leak is fixed...
-               # use ASAN_OPTIONS=detect_leaks=0 to disable detect_leaks
-               -fsanitize=address
-               -fsanitize=undefined # compile and runtime checks
-               # -fsanitize=float-divide-by-zero
-               # -fsanitize=float-cast-overflow
-               # -fno-sanitize-recover # Abort during runtime
-       )
-
-       if(ENABLE_ASAN)
-               set(WIRESHARK_COMMON_FLAGS ${WIRESHARK_COMMON_FLAGS} ${WIRESHARK_ASAN_FLAGS})
-       endif()
-
        if(ENABLE_EXTRA_COMPILER_WARNINGS)   # This overrides -Werror
                set(WIRESHARK_COMMON_FLAGS ${WIRESHARK_COMMON_FLAGS} ${WIRESHARK_EXTRA_COMPILER_COMMON_FLAGS})
                set(WIRESHARK_C_ONLY_FLAGS ${WIRESHARK_C_ONLY_FLAGS} ${WIRESHARK_EXTRA_COMPILER_C_ONLY_FLAGS})
-               set(WIRESHARK_CPP_ONLY_FLAGS ${WIRESHARK_CPP_ONLY_FLAGS} ${WIRESHARK_EXTRA_COMPILER_CPP_ONLY_FLAGS})
+               set(WIRESHARK_CXX_ONLY_FLAGS ${WIRESHARK_CXX_ONLY_FLAGS} ${WIRESHARK_EXTRA_COMPILER_CXX_ONLY_FLAGS})
        endif()
 
        add_definitions(
@@ -497,7 +485,7 @@ else()
 endif()
 
 set( C_FLAG_TESTS ${WIRESHARK_COMMON_FLAGS} ${WIRESHARK_C_ONLY_FLAGS} )
-set( CPP_FLAG_TESTS ${WIRESHARK_COMMON_FLAGS} ${WIRESHARK_CPP_ONLY_FLAGS} )
+set( CXX_FLAG_TESTS ${WIRESHARK_COMMON_FLAGS} ${WIRESHARK_CXX_ONLY_FLAGS} )
 
 # Counterhack to work around some cache magic in CHECK_C_SOURCE_COMPILES
 include(CheckCCompilerFlag)
@@ -526,10 +514,10 @@ foreach(THIS_FLAG ${C_FLAG_TESTS})
 endforeach()
 set(CMAKE_C_FLAGS "${ADDED_CMAKE_C_FLAGS} ${CMAKE_C_FLAGS}")
 
-foreach(THIS_FLAG ${CPP_FLAG_TESTS})
+foreach(THIS_FLAG ${CXX_FLAG_TESTS})
        string( REGEX REPLACE "[^a-zA-Z0-9_]+" "_" F ${THIS_FLAG} )
        set(${F} ${THIS_FLAG})
-       set(V CPP_${F}_VALID)
+       set(V CXX_${F}_VALID)
        message(STATUS "Checking for c++-compiler flag: ${THIS_FLAG}")
        check_cxx_compiler_flag("${ADDED_CMAKE_CXX_FLAGS} ${${F}}" ${V})
        if (${${V}})
@@ -538,6 +526,18 @@ foreach(THIS_FLAG ${CPP_FLAG_TESTS})
 endforeach()
 set(CMAKE_CXX_FLAGS "${ADDED_CMAKE_CXX_FLAGS} ${CMAKE_CXX_FLAGS}")
 
+if(ENABLE_ASAN)
+       set(CMAKE_REQUIRED_LIBRARIES "-fsanitize=address")
+       check_c_compiler_flag(-fsanitize=address C__fsanitize_address_VALID)
+       check_cxx_compiler_flag(-fsanitize=address CXX__fsanitize_address_VALID)
+       set(CMAKE_REQUIRED_LIBRARIES "")
+       if(NOT C__fsanitize_address_VALID OR NOT CXX__fsanitize_address_VALID)
+               message(FATAL_ERROR "ENABLE_ASAN was requested, but not supported!")
+       endif()
+       set(CMAKE_C_FLAGS "-fsanitize=address ${CMAKE_C_FLAGS}")
+       set(CMAKE_CXX_FLAGS "-fsanitize=address ${CMAKE_CXX_FLAGS}")
+endif()
+
 if(NOT DISABLE_WERROR AND NOT ENABLE_EXTRA_COMPILER_WARNINGS)
        if(CMAKE_C_COMPILER_ID MATCHES "MSVC")
                set(WERROR_COMMON_FLAGS "/WX")
@@ -590,9 +590,14 @@ if( NOT CMAKE_C_COMPILER_ID MATCHES "MSVC")
 endif()
 
 if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_C_COMPILER_ID MATCHES "Clang")
-       set (C_UNUSED "__attribute__((unused))" )
+       set (C_UNUSED       "__attribute__((unused))" )
+       set (WS_NORETURN    "__attribute__((noreturn))")
+elseif(MSVC)
+       set (C_UNUSED       "")
+       set (WS_NORETURN    "__declspec(noreturn)")
 else()
-       set (C_UNUSED "" )
+       set (C_UNUSED       "")
+       set (WS_NORETURN    "")
 endif()
 
 set(WIRESHARK_LD_FLAGS
@@ -656,8 +661,6 @@ if (NOT WIN32)
        set(M_REQUIRED TRUE)
 endif()
 
-set(PACKAGELIST ${PACKAGELIST} HtmlViewer)
-
 set(PACKAGELIST ${PACKAGELIST} LIBSSH)
 set(LIBSSH_OPTIONS "0.6")
 
@@ -742,11 +745,9 @@ if(ENABLE_PORTAUDIO AND BUILD_wireshark_gtk)
 endif()
 
 
-# Prefer c-ares over adns
-if(ENABLE_CARES) # C Asynchronouse resolver
+# C Asynchronous resolver
+if(ENABLE_CARES)
        set(PACKAGELIST ${PACKAGELIST} CARES)
-elseif(ENABLE_ADNS) # Gnu asynchronous DNS
-       set(PACKAGELIST ${PACKAGELIST} ADNS)
 endif()
 
 # Zlib compression
@@ -816,8 +817,6 @@ foreach(PACKAGE ${PACKAGELIST})
                set(PACKAGE_VAR "PYTHONINTERP")
        elseif(${PACKAGE} STREQUAL "Gettext")
                set(PACKAGE_VAR "GETTEXT")
-       elseif(${PACKAGE} STREQUAL "HtmlViewer")
-               set(PACKAGE_VAR "HTML_VIEWER")
        elseif(${PACKAGE} STREQUAL "Perl")
                set(PACKAGE_VAR "PERL")
        else()
@@ -882,8 +881,9 @@ endif()
 if(HAVE_LIBCARES)
        set(HAVE_C_ARES 1)
 endif()
-if(HAVE_LIBADNS)
-       set(HAVE_GNU_ADNS 1)
+if(NOT HAVE_LIBCARES)
+       message(WARNING "Not using c-ares.")
+       message(WARNING "DNS name resolution for captures will be disabled.")
 endif()
 if(HAVE_LIBNL AND HAVE_AIRPCAP)
        message(ERROR "Airpcap and Libnl support are mutually exclusive")
@@ -903,9 +903,9 @@ endif()
 if(GTK2_FOUND OR GTK3_FOUND)
        set(GTK_FOUND ON)
 endif()
-# That's the name autofoo uses
+
 if(HAVE_LIBZLIB)
-       set(HAVE_LIBZ 1)
+       set(HAVE_ZLIB 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})
@@ -938,6 +938,17 @@ if (Qt5Widgets_FOUND)
                #
                list(REMOVE_ITEM Qt5Widgets_EXECUTABLE_COMPILE_FLAGS "-fPIC")
        endif()
+       if (Qt5Widgets_VERSION VERSION_GREATER 5.6
+           AND (CMAKE_COMPILER_IS_GNUCC OR CMAKE_C_COMPILER_ID MATCHES "Clang"))
+               # Qt 5.7 and later require C++ 11. If our minmimu required CMake version
+               # is ever >= 3.1 we can use CXX_STANDARD + CXX_STANDARD_REQUIRED.
+               message(STATUS "Checking for C++ 11 support (Required by Qt 5.7 and later)")
+               check_cxx_compiler_flag(-std=c++11 CXX__std_c__11_VALID)
+               if(NOT CXX__std_c__11_VALID)
+                       message(FATAL_ERROR "Qt ${Qt5Widgets_VERSION} requires C++ 11")
+               endif()
+               set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
+       endif()
        set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${Qt5Widgets_EXECUTABLE_COMPILE_FLAGS}")
        set (QT_FOUND ON)
        set (QT_LIBRARIES ${Qt5Widgets_LIBRARIES} ${Qt5PrintSupport_LIBRARIES})
@@ -960,6 +971,10 @@ if (Qt5Widgets_FOUND)
                set (QT_LIBRARIES ${QT_LIBRARIES} ${Qt5WinExtras_LIBRARIES})
                # set(QT_WINEXTRAS_LIB 1) # Not needed?
        endif()
+       if(NOT DEFINED MOC_OPTIONS)
+               # Squelch moc verbose "nothing to do" output
+               set(MOC_OPTIONS -nn)
+       endif()
 # If Qt4: QT_LIBRARIES and QT_INCLUDES are not set above. They require extra magic
 elseif(QT_FOUND)
        include(${QT_USE_FILE})
@@ -974,6 +989,15 @@ elseif(QT_FOUND)
                # That's the name autofoo uses
                set(QT_MULTIMEDIA_LIB 1)
        endif()
+       if(NOT DEFINED MOC_OPTIONS)
+               if(QT_VERSION_MAJOR EQUAL 4 AND QT_VERSION_MINOR GREATER 7)
+                       set(MOC_OPTIONS -nn)
+               endif()
+       endif()
+endif()
+
+if(ENABLE_CHECKHF_CONFLICT)
+       set(ENABLE_CHECK_FILTER 1)
 endif()
 
 message(STATUS "C-Flags: ${CMAKE_C_FLAGS}")
@@ -999,15 +1023,26 @@ test_big_endian(WORDS_BIGENDIAN)
 
 set_property(GLOBAL PROPERTY USE_FOLDERS ON)
 
-add_subdirectory( asn1 EXCLUDE_FROM_ALL )
+# The top level checkAPIs target, add before subdirectory calls so it's avaiable to all
+add_custom_target(checkAPI)
+set_target_properties(checkAPI
+       PROPERTIES
+               FOLDER "Auxiliary"
+               EXCLUDE_FROM_ALL True
+               EXCLUDE_FROM_DEFAULT_BUILD True
+)
+
 add_subdirectory( capchild )
 add_subdirectory( caputils )
 add_subdirectory( codecs )
+add_subdirectory( doc )
 add_subdirectory( docbook )
 add_subdirectory( epan )
+add_subdirectory( randpkt_core )
 add_subdirectory( tools/lemon )
 add_subdirectory( ui )
 add_subdirectory( wiretap )
+add_subdirectory( writecap )
 add_subdirectory( wsutil )
 
 if(NOT WIN32)
@@ -1132,31 +1167,26 @@ gmx_test_large_files(GMX_LARGEFILES)
 add_definitions( -DTOP_SRCDIR=\"${CMAKE_SOURCE_DIR}\" )
 
 if(WIN32)
-       set(WS_MSVC_NORETURN "__declspec(noreturn)")
-
        # Disable deprecation
        if(MSVC80 OR MSVC90)
                add_definitions(-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE)
        endif()
-else()
-       set(WS_MSVC_NORETURN " ")
 endif()
 
 if (${GIT_EXECUTABLE})
        set(GIT_BIN_PARAM "--git-bin ${GIT_EXECUTABLE}")
 endif()
 set( VERSION ${PROJECT_VERSION} )
-execute_process(
+add_custom_target(version
        COMMAND ${PERL_EXECUTABLE}
-               ${CMAKE_CURRENT_SOURCE_DIR}/make-version.pl
-               --print-vcs ${GIT_BIN_PARAM}
-               ${CMAKE_CURRENT_SOURCE_DIR}
-       OUTPUT_VARIABLE VERSION_H_CONTENT
+               ${CMAKE_SOURCE_DIR}/make-version.pl
+               --set-vcs ${GIT_BIN_PARAM}
+               ${CMAKE_SOURCE_DIR}
 )
+set_target_properties(version PROPERTIES FOLDER "Auxiliary")
+
 set( configure_input "Built with CMake ${CMAKE_VERSION}" )
 configure_file(${CMAKE_SOURCE_DIR}/cmakeconfig.h.in ${CMAKE_BINARY_DIR}/config.h)
-configure_file(${CMAKE_SOURCE_DIR}/version.h.in ${CMAKE_BINARY_DIR}/version.h)
-#set_target_properties(${CMAKE_BINARY_DIR}/version.h PROPERTIES FOLDER "Auxiliary")
 
 set( prefix "${CMAKE_INSTALL_PREFIX}" )
 set( exec_prefix "\${prefix}" )
@@ -1166,7 +1196,6 @@ set( plugindir "\${libdir}/wireshark/plugins/${CPACK_PACKAGE_VERSION}" )
 
 set(ICON_PATH "${CMAKE_SOURCE_DIR}/image/")
 set( IN_FILES
-       adns_dll.rc
        capchild/doxygen.cfg.in
        caputils/doxygen.cfg.in
        doxygen.cfg.in
@@ -1192,10 +1221,12 @@ set( IN_FILES
        packaging/macosx/Info.plist.in
        packaging/macosx/osx-dmg.sh.in
        packaging/macosx/Wireshark_package.pmdoc/index.xml.in
+       randpkt_core/doxygen.cfg.in
        ui/doxygen.cfg.in
        ui/gtk/doxygen.cfg.in
        ui/qt/doxygen.cfg.in
        wireshark.pc.in
+       writecap/doxygen.cfg.in
 )
 foreach( _in_file ${IN_FILES} )
        get_filename_component( _path ${_in_file} PATH )
@@ -1206,7 +1237,7 @@ endforeach()
 include(FeatureSummary)
 #SET_FEATURE_INFO(NAME DESCRIPTION [URL [COMMENT] ])
 SET_FEATURE_INFO(SBC "SBC Codec for Bluetooth A2DP stream playing" "www: http://git.kernel.org/cgit/bluetooth/sbc.git" )
-SET_FEATURE_INFO(LIBSSH "libssh is library for ssh connections and it is needed to build sshdump" "www: https://www.libssh.org/get-it/" )
+SET_FEATURE_INFO(LIBSSH "libssh is library for ssh connections and it is needed to build sshdump/ciscodump" "www: https://www.libssh.org/get-it/" )
 
 FEATURE_SUMMARY(WHAT ALL)
 
@@ -1218,7 +1249,9 @@ link_directories(
        ${CMAKE_BINARY_DIR}/caputils
        ${CMAKE_BINARY_DIR}/codecs
        ${CMAKE_BINARY_DIR}/epan
+       ${CMAKE_BINARY_DIR}/randpkt_core
        ${CMAKE_BINARY_DIR}/wiretap
+       ${CMAKE_BINARY_DIR}/writecap
        ${CMAKE_BINARY_DIR}/wsutil
 )
 
@@ -1238,6 +1271,7 @@ set(SHARK_COMMON_SRC
        cfile.c
        frame_tvbuff.c
        sync_pipe_write.c
+       ws_version_info.c
 )
 
 # sources for external capture interfaces
@@ -1246,6 +1280,7 @@ if(ENABLE_EXTCAP)
                ${SHARK_COMMON_SRC}
                extcap.c
                extcap_parser.c
+               extcap_spawn.c
        )
 endif()
 
@@ -1292,36 +1327,37 @@ set(INSTALL_DIRS
 )
 
 set(INSTALL_FILES
-       ${CMAKE_BINARY_DIR}/androiddump.html
-       ${CMAKE_BINARY_DIR}/sshdump.html
-       ${CMAKE_BINARY_DIR}/AUTHORS-SHORT
-       ${CMAKE_BINARY_DIR}/capinfos.html
-       ${CMAKE_BINARY_DIR}/captype.html
        cfilters
        colorfilters
        dfilters
-       ${CMAKE_BINARY_DIR}/dftest.html
-       ${CMAKE_BINARY_DIR}/dumpcap.html
-       ${CMAKE_BINARY_DIR}/editcap.html
-       ${CMAKE_BINARY_DIR}/extcap.html
-       ${CMAKE_BINARY_DIR}/asn2deb.html
-       ${CMAKE_BINARY_DIR}/idl2deb.html
-       ${CMAKE_BINARY_DIR}/idl2wrs.html
        ipmap.html
        manuf
-       ${CMAKE_BINARY_DIR}/mergecap.html
        pdml2html.xsl
-       ${CMAKE_BINARY_DIR}/randpkt.html
-       ${CMAKE_BINARY_DIR}/randpktdump.html
-       ${CMAKE_BINARY_DIR}/rawshark.html
-       ${CMAKE_BINARY_DIR}/reordercap.html
        services
        smi_modules
-       ${CMAKE_BINARY_DIR}/text2pcap.html
-       ${CMAKE_BINARY_DIR}/tshark.html
-       ${CMAKE_BINARY_DIR}/wireshark-filter.html
-       ${CMAKE_BINARY_DIR}/wireshark.html
        docbook/ws.css
+       ${CMAKE_BINARY_DIR}/doc/AUTHORS-SHORT
+       ${CMAKE_BINARY_DIR}/doc/asn2deb.html
+       ${CMAKE_BINARY_DIR}/doc/androiddump.html
+       ${CMAKE_BINARY_DIR}/doc/capinfos.html
+       ${CMAKE_BINARY_DIR}/doc/captype.html
+       ${CMAKE_BINARY_DIR}/doc/ciscodump.html
+       ${CMAKE_BINARY_DIR}/doc/dftest.html
+       ${CMAKE_BINARY_DIR}/doc/dumpcap.html
+       ${CMAKE_BINARY_DIR}/doc/editcap.html
+       ${CMAKE_BINARY_DIR}/doc/extcap.html
+       ${CMAKE_BINARY_DIR}/doc/idl2deb.html
+       ${CMAKE_BINARY_DIR}/doc/idl2wrs.html
+       ${CMAKE_BINARY_DIR}/doc/mergecap.html
+       ${CMAKE_BINARY_DIR}/doc/randpkt.html
+       ${CMAKE_BINARY_DIR}/doc/randpktdump.html
+       ${CMAKE_BINARY_DIR}/doc/rawshark.html
+       ${CMAKE_BINARY_DIR}/doc/reordercap.html
+       ${CMAKE_BINARY_DIR}/doc/sshdump.html
+       ${CMAKE_BINARY_DIR}/doc/text2pcap.html
+       ${CMAKE_BINARY_DIR}/doc/tshark.html
+       ${CMAKE_BINARY_DIR}/doc/wireshark.html
+       ${CMAKE_BINARY_DIR}/doc/wireshark-filter.html
 )
 
 if(WIN32)
@@ -1333,40 +1369,13 @@ else()
        set(INSTALL_FILES COPYING ${INSTALL_FILES})
 endif()
 
-set(MAN1_FILES
-       ${CMAKE_BINARY_DIR}/androiddump.1
-       ${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
-       ${CMAKE_BINARY_DIR}/extcap.4
-       ${CMAKE_BINARY_DIR}/idl2wrs.1
-       ${CMAKE_BINARY_DIR}/mergecap.1
-       ${CMAKE_BINARY_DIR}/randpkt.1
-       ${CMAKE_BINARY_DIR}/androiddump.1
-       ${CMAKE_BINARY_DIR}/rawshark.1
-       ${CMAKE_BINARY_DIR}/reordercap.1
-       ${CMAKE_BINARY_DIR}/sshdump.1
-       ${CMAKE_BINARY_DIR}/text2pcap.1
-       ${CMAKE_BINARY_DIR}/tshark.1
-       ${CMAKE_BINARY_DIR}/wireshark.1
-)
-
-set(MAN4_FILES
-       ${CMAKE_BINARY_DIR}/wireshark-filter.4
-)
-
 set(LIBEPAN_LIBS
-#              @NSL_LIBS@      # -lnsl
-#              @SOCKET_LIBS@   # -lsocket
 #              @SSL_LIBS@      # -lcrypto
                epan
 #              $(plugin_ldadd) # in case of static
                ${AIRPCAP_LIBRARIES}
                ${PCAP_LIBRARIES}
                ${CARES_LIBRARIES}
-               ${ADNS_LIBRARIES}
                ${KERBEROS_LIBRARIES}
                ${LUA_LIBRARIES}
                ${PYTHON_LIBRARIES}
@@ -1376,7 +1385,6 @@ set(LIBEPAN_LIBS
                ${SMI_LIBRARIES}
                ${ZLIB_LIBRARIES}
                ${M_LIBRARIES}
-               ${SBC_LIBRARIES}
                ${WINSPARKLE_LIBRARIES}
 )
 
@@ -1412,20 +1420,6 @@ if(WIN32)
                )
        endforeach(_dll)
 
-
-       # Don't overwrite an exe if it's already there. We don't want to
-       # clobber any previous code signing.
-       file(GLOB _gspawn_helpers
-               RELATIVE "${GLIB2_DLL_DIR}"
-               "${GLIB2_DLL_DIR}/gspawn*.exe"
-       )
-       foreach(_gspawn_helper ${_gspawn_helpers})
-               add_custom_command(TARGET copy_cli_dlls PRE_BUILD
-                       COMMAND if not exist \"${_dll_output_dir_win}\\${_gspawn_helper}\" xcopy ${_gspawn_helper} "${_dll_output_dir_win}" /D /Y
-                       WORKING_DIRECTORY "${GLIB2_DLL_DIR}"
-               )
-       endforeach()
-
        # Optional
        if (AIRPCAP_FOUND)
                add_custom_command(TARGET copy_cli_dlls PRE_BUILD
@@ -1501,26 +1495,35 @@ if(WIN32)
                        COMMAND ${CMAKE_COMMAND} -E make_directory
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/mibs/iana"
+                               "${SMI_SHARE_DIR}/mibs/iana"
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/mibs/ietf"
+                               "${SMI_SHARE_DIR}/mibs/ietf"
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/mibs/irtf"
+                               "${SMI_SHARE_DIR}/mibs/irtf"
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/mibs/site"
+                               "${SMI_SHARE_DIR}/mibs/site"
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/mibs/tubs"
+                               "${SMI_SHARE_DIR}/mibs/tubs"
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/pibs"
+                               "${SMI_SHARE_DIR}/pibs"
                                "${_dll_output_dir}/snmp/mibs"
                        COMMAND ${CMAKE_COMMAND} -E copy_directory
-                               "${SMI_SHARE_DIR}/${SMI_DLL}/yang"
+                               "${SMI_SHARE_DIR}/yang"
                                "${_dll_output_dir}/snmp/mibs"
+                       #remove the extra directories copied (shallow copying the above would remove the need for this)
+                       COMMAND ${CMAKE_COMMAND} -E remove_directory
+                               "${_dll_output_dir}/snmp/mibs/iana"
+                       COMMAND ${CMAKE_COMMAND} -E remove_directory
+                               "${_dll_output_dir}/snmp/mibs/ietf"
+                       COMMAND ${CMAKE_COMMAND} -E remove_directory
+                               "${_dll_output_dir}/snmp/mibs/site"
+                       COMMAND ${CMAKE_COMMAND} -E remove_directory
+                               "${_dll_output_dir}/snmp/mibs/tubs"
                )
        endif(SMI_FOUND)
        if (WINSPARKLE_FOUND)
@@ -1592,7 +1595,7 @@ foreach(_install_file ${INSTALL_FILES})
                        "${_output_file}"
                WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
                DEPENDS
-                       html_docs
+                       docs
                        "${_install_file}"
        )
        list(APPEND copy_data_files_depends "${_output_file}")
@@ -1758,8 +1761,8 @@ if(ENABLE_APPLICATION_BUNDLE)
 
        # Wireshark.app/Contents/Resources
        set(BUNDLE_RESOURCE_FILES
-               ${CMAKE_SOURCE_DIR}/packaging/macosx/Resources/Wireshark.icns
-               ${CMAKE_SOURCE_DIR}/packaging/macosx/Resources/Wiresharkdoc.icns
+               ${CMAKE_SOURCE_DIR}/packaging/macosx/Wireshark.icns
+               ${CMAKE_SOURCE_DIR}/packaging/macosx/Wiresharkdoc.icns
        )
        set_source_files_properties(${BUNDLE_RESOURCE_FILES} PROPERTIES
                MACOSX_PACKAGE_LOCATION Resources
@@ -1811,6 +1814,7 @@ if(BUILD_wireshark AND QT_FOUND)
        endif()
 
        add_executable(wireshark WIN32 MACOSX_BUNDLE wireshark-qt.cpp ${wireshark_FILES} ${EXTRA_BUNDLE_FILES})
+       add_dependencies(wireshark version)
        set(PROGLIST ${PROGLIST} wireshark)
        set_target_properties(wireshark PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
        set_target_properties(wireshark PROPERTIES FOLDER "Executables")
@@ -1827,7 +1831,8 @@ if(BUILD_wireshark AND QT_FOUND)
                # convenience but makes debugging more difficult.
                file(REMOVE ${CMAKE_BINARY_DIR}/run/wireshark)
                file(WRITE ${CMAKE_BINARY_DIR}/run/wireshark "#!/bin/sh\n")
-               file(APPEND ${CMAKE_BINARY_DIR}/run/wireshark "open ${CMAKE_BINARY_DIR}/run/Wireshark.app --args \"\$\@\"\n")
+               file(APPEND ${CMAKE_BINARY_DIR}/run/wireshark "# Generated by ${CMAKE_CURRENT_LIST_FILE}\n")
+               file(APPEND ${CMAKE_BINARY_DIR}/run/wireshark "exec ${CMAKE_BINARY_DIR}/run/Wireshark.app/Contents/MacOS/Wireshark \"\$\@\"\n")
                execute_process(COMMAND chmod a+x ${CMAKE_BINARY_DIR}/run/wireshark)
        endif()
 
@@ -1964,6 +1969,7 @@ if(BUILD_wireshark_gtk AND GTK_FOUND)
        # wireshark and wireshark-gtk share wireshark_FILES
 
        add_executable(wireshark-gtk WIN32 ${wireshark_FILES})
+       add_dependencies(wireshark-gtk version)
        set(PROGLIST ${PROGLIST} wireshark-gtk)
        set_target_properties(wireshark-gtk PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
        set_target_properties(wireshark-gtk PROPERTIES FOLDER "Executables")
@@ -2075,6 +2081,7 @@ if(BUILD_tshark)
                ${CMAKE_BINARY_DIR}/image/tshark.rc
        )
        add_executable(tshark ${tshark_FILES})
+       add_dependencies(tshark version)
        set_extra_executable_properties(tshark "Executables")
        target_link_libraries(tshark ${tshark_LIBS})
        install(TARGETS tshark RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2094,6 +2101,7 @@ if(BUILD_tfshark)
                ${CMAKE_BINARY_DIR}/image/tfshark.rc
        )
        add_executable(tfshark ${tfshark_FILES})
+       add_dependencies(tfshark version)
        set_extra_executable_properties(tfshark "Executables")
        target_link_libraries(tfshark ${tfshark_LIBS})
        install(TARGETS tfshark RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2113,6 +2121,7 @@ if(BUILD_rawshark AND PCAP_FOUND)
                ${CMAKE_BINARY_DIR}/image/rawshark.rc
        )
        add_executable(rawshark ${rawshark_FILES})
+       add_dependencies(rawshark version)
        set_extra_executable_properties(rawshark "Executables")
        target_link_libraries(rawshark ${rawshark_LIBS})
        install(TARGETS rawshark RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2127,6 +2136,7 @@ if(BUILD_dftest)
                ui/util.c
        )
        add_executable(dftest ${dftest_FILES})
+       add_dependencies(dftest version)
        set_extra_executable_properties(dftest "Tests")
        target_link_libraries(dftest ${dftest_LIBS})
        install(TARGETS dftest RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2134,21 +2144,20 @@ endif()
 
 if(BUILD_randpkt)
        set(randpkt_LIBS
+               randpkt_core
                wiretap
                wsutil
                ${M_LIBRARIES}
                ${PCAP_LIBRARIES}
-#              @SOCKET_LIBS@
-#              @NSL_LIBS@
                ${CARES_LIBRARIES}
-               ${ADNS_LIBRARIES}
                ${ZLIB_LIBRARIES}
        )
        set(randpkt_FILES
                randpkt.c
-               randpkt-core.c
+               ws_version_info.c
        )
        add_executable(randpkt ${randpkt_FILES})
+       add_dependencies(randpkt version)
        set_extra_executable_properties(randpkt "Executables")
        target_link_libraries(randpkt ${randpkt_LIBS})
        install(TARGETS randpkt RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2156,22 +2165,24 @@ endif()
 
 if(BUILD_text2pcap)
        set(text2pcap_LIBS
+               writecap
                wsutil
                ${M_LIBRARIES}
                ${ZLIB_LIBRARIES}
        )
        set(text2pcap_CLEAN_FILES
                text2pcap.c
-               pcapio.c
+               ws_version_info.c
        )
        set(text2pcap_FILES
                ${text2pcap_CLEAN_FILES}
                ${CMAKE_BINARY_DIR}/image/text2pcap.rc
        )
-       add_lex_files(text2pcap_FILES
+       add_lex_files(text2pcap_LEX_FILES text2pcap_GENERATED_FILES
                text2pcap-scanner.l
        )
-       add_executable(text2pcap ${text2pcap_FILES})
+       add_executable(text2pcap ${text2pcap_FILES} ${text2pcap_GENERATED_FILES})
+       add_dependencies(text2pcap version)
        set_extra_executable_properties(text2pcap "Executables")
        target_link_libraries(text2pcap ${text2pcap_LIBS})
        install(TARGETS text2pcap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2185,9 +2196,11 @@ if(BUILD_mergecap)
        )
        set(mergecap_FILES
                mergecap.c
+               ws_version_info.c
                ${CMAKE_BINARY_DIR}/image/mergecap.rc
        )
        add_executable(mergecap ${mergecap_FILES})
+       add_dependencies(mergecap version)
        set_extra_executable_properties(mergecap "Executables")
        target_link_libraries(mergecap ${mergecap_LIBS})
        install(TARGETS mergecap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2201,9 +2214,11 @@ if(BUILD_reordercap)
        )
        set(reordercap_FILES
                reordercap.c
+               ws_version_info.c
                ${CMAKE_BINARY_DIR}/image/reordercap.rc
        )
        add_executable(reordercap ${reordercap_FILES})
+       add_dependencies(reordercap version)
        set_extra_executable_properties(reordercap "Executables")
        target_link_libraries(reordercap ${reordercap_LIBS})
        install(TARGETS reordercap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2219,9 +2234,11 @@ if(BUILD_capinfos)
        )
        set(capinfos_FILES
                capinfos.c
+               ws_version_info.c
                ${CMAKE_BINARY_DIR}/image/capinfos.rc
        )
        add_executable(capinfos ${capinfos_FILES})
+       add_dependencies(capinfos version)
        set_extra_executable_properties(capinfos "Executables")
        target_link_libraries(capinfos ${capinfos_LIBS})
        install(TARGETS capinfos RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2236,9 +2253,11 @@ if(BUILD_captype)
        )
        set(captype_FILES
                captype.c
+               ws_version_info.c
                ${CMAKE_BINARY_DIR}/image/captype.rc
        )
        add_executable(captype ${captype_FILES})
+       add_dependencies(captype version)
        set_extra_executable_properties(captype "Executables")
        target_link_libraries(captype ${captype_LIBS})
        install(TARGETS captype RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2252,9 +2271,11 @@ if(BUILD_editcap)
        )
        set(editcap_FILES
                editcap.c
+               ws_version_info.c
                ${CMAKE_BINARY_DIR}/image/editcap.rc
        )
        add_executable(editcap ${editcap_FILES})
+       add_dependencies(editcap version)
        set_extra_executable_properties(editcap "Executables")
        target_link_libraries(editcap ${editcap_LIBS})
        install(TARGETS editcap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
@@ -2262,12 +2283,11 @@ endif()
 
 if(BUILD_dumpcap AND PCAP_FOUND)
        set(dumpcap_LIBS
+               writecap
                wsutil
                caputils
                ${PCAP_LIBRARIES}
                ${CAP_LIBRARIES}
-#              @SOCKET_LIBS@
-#              @NSL_LIBS@
                ${GLIB2_LIBRARIES}
                ${GTHREAD2_LIBRARIES}
                ${ZLIB_LIBRARIES}
@@ -2281,12 +2301,13 @@ if(BUILD_dumpcap AND PCAP_FOUND)
                conditions.c
                dumpcap.c
                filter_files.c
-               pcapio.c
                ringbuffer.c
                sync_pipe_write.c
+               ws_version_info.c
                ${CMAKE_BINARY_DIR}/image/dumpcap.rc
        )
        add_executable(dumpcap ${dumpcap_FILES})
+       add_dependencies(dumpcap version)
        set_extra_executable_properties(dumpcap "Executables")
        target_link_libraries(dumpcap ${dumpcap_LIBS})
        install(TARGETS dumpcap
@@ -2323,6 +2344,13 @@ if (WIN32)
                ADD_NSIS_PACKAGE_TARGET()
        endif()
 
+       find_package( WiX )
+
+       if (NOT "${WIX_CANDLE_EXECUTABLE}" STREQUAL "WIX_CANDLE_EXECUTABLE-NOTFOUND")
+               add_subdirectory( packaging/wix EXCLUDE_FROM_ALL )
+               ADD_WIX_PACKAGE_TARGET()
+       endif()
+
        find_package( PortableApps )
        if (
                NOT "${PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE}" STREQUAL "PORTABLEAPPS_LAUNCHER_GENERATOR_EXECUTABLE-NOTFOUND"
@@ -2334,7 +2362,7 @@ if (WIN32)
        endif()
 endif()
 
-if(BUILD_androiddump)
+if(ENABLE_EXTCAP AND BUILD_androiddump)
        if(EXTCAP_ANDROIDDUMP_LIBPCAP)
                if(HAVE_LIBPCAP)
                        set(androiddump_LIBS
@@ -2353,6 +2381,7 @@ if(BUILD_androiddump)
        endif()
        set(androiddump_FILES
                extcap/androiddump.c
+               extcap/extcap-base.c
        )
 
        add_executable(androiddump WIN32 ${androiddump_FILES})
@@ -2362,17 +2391,20 @@ if(BUILD_androiddump)
        install(TARGETS androiddump RUNTIME DESTINATION ${EXTCAP_DIR})
 endif()
 
-if(BUILD_sshdump AND LIBSSH_FOUND)
+if(ENABLE_EXTCAP AND BUILD_sshdump AND LIBSSH_FOUND)
        set(sshdump_LIBS
+               wsutil
                ${GLIB2_LIBRARIES}
                ${CMAKE_DL_LIBS}
                ${LIBSSH_LIBRARIES}
        )
        if (WIN32)
-               set(sshdump_LIBS wsutil ${sshdump_LIBS})
+               set(sshdump_LIBS wsutil ${sshdump_LIBS})
        endif()
        set(sshdump_FILES
                extcap/sshdump.c
+               extcap/extcap-base.c
+               extcap/ssh-base.c
        )
 
        add_executable(sshdump WIN32 ${sshdump_FILES})
@@ -2384,15 +2416,42 @@ elseif (BUILD_sshdump)
        #message( WARNING "Cannot find libssh, cannot build sshdump" )
 endif()
 
-if(BUILD_randpktdump)
+if(ENABLE_EXTCAP AND BUILD_ciscodump AND LIBSSH_FOUND)
+       set(ciscodump_LIBS
+               writecap
+               wsutil
+               ${GLIB2_LIBRARIES}
+               ${CMAKE_DL_LIBS}
+               ${LIBSSH_LIBRARIES}
+       )
+       if (WIN32)
+               set(ciscodump_LIBS wsutil ${ciscodump_LIBS})
+       endif()
+       set(ciscodump_FILES
+               extcap/ciscodump.c
+               extcap/extcap-base.c
+               extcap/ssh-base.c
+       )
+
+       add_executable(ciscodump WIN32 ${ciscodump_FILES})
+       set_extcap_executable_properties(ciscodump)
+       target_link_libraries(ciscodump ${ciscodump_LIBS})
+       target_include_directories(ciscodump PUBLIC ${LIBSSH_INCLUDE_DIR})
+       install(TARGETS ciscodump RUNTIME DESTINATION ${EXTCAP_DIR})
+elseif (BUILD_ciscodump)
+       #message( WARNING "Cannot find libssh, cannot build ciscodump" )
+endif()
+
+if(ENABLE_EXTCAP AND BUILD_randpktdump)
        set(randpktdump_LIBS
+               randpkt_core
                wiretap
                ${GLIB2_LIBRARIES}
                ${CMAKE_DL_LIBS}
        )
        set(randpktdump_FILES
+               extcap/extcap-base.c
                extcap/randpktdump.c
-               randpkt-core.c
        )
 
        add_executable(randpktdump WIN32 ${randpktdump_FILES})
@@ -2402,57 +2461,6 @@ if(BUILD_randpktdump)
        install(TARGETS randpktdump RUNTIME DESTINATION ${EXTCAP_DIR})
 endif()
 
-ADD_CUSTOM_COMMAND(
-       OUTPUT  ${CMAKE_BINARY_DIR}/AUTHORS-SHORT
-       COMMAND ${PERL_EXECUTABLE}
-               ${CMAKE_SOURCE_DIR}/doc/perlnoutf.pl
-               ${CMAKE_SOURCE_DIR}/doc/make-authors-short.pl
-               < ${CMAKE_SOURCE_DIR}/AUTHORS
-               > ${CMAKE_BINARY_DIR}/AUTHORS-SHORT
-       DEPENDS
-               ${CMAKE_SOURCE_DIR}/doc/perlnoutf.pl
-               ${CMAKE_SOURCE_DIR}/doc/make-authors-short.pl
-               ${CMAKE_SOURCE_DIR}/AUTHORS
-)
-
-ADD_CUSTOM_COMMAND(
-       OUTPUT  ${CMAKE_BINARY_DIR}/AUTHORS-SHORT-FORMAT
-       COMMAND ${PERL_EXECUTABLE}
-               ${CMAKE_SOURCE_DIR}/doc/perlnoutf.pl
-               ${CMAKE_SOURCE_DIR}/doc/make-authors-format.pl
-               < ${CMAKE_BINARY_DIR}/AUTHORS-SHORT
-               > ${CMAKE_BINARY_DIR}/AUTHORS-SHORT-FORMAT
-       DEPENDS
-               ${CMAKE_SOURCE_DIR}/doc/perlnoutf.pl
-               ${CMAKE_SOURCE_DIR}/doc/make-authors-format.pl
-               ${CMAKE_BINARY_DIR}/AUTHORS-SHORT
-)
-
-if(WIN32)
-FILE(TO_NATIVE_PATH ${CMAKE_SOURCE_DIR}/doc/wireshark.pod.template WPT_WIN_PATH)
-FILE(TO_NATIVE_PATH ${CMAKE_BINARY_DIR}/AUTHORS-SHORT-FORMAT ASF_WIN_PATH)
-FILE(TO_NATIVE_PATH ${CMAKE_BINARY_DIR}/wireshark.pod WP_WIN_PATH)
-ADD_CUSTOM_COMMAND(
-       OUTPUT  ${CMAKE_BINARY_DIR}/wireshark.pod
-       COMMAND copy /B ${WPT_WIN_PATH} + ${ASF_WIN_PATH} ${WP_WIN_PATH}
-       DEPENDS
-               ${CMAKE_SOURCE_DIR}/doc/wireshark.pod.template
-               ${CMAKE_BINARY_DIR}/AUTHORS-SHORT-FORMAT
-)
-else()
-
-ADD_CUSTOM_COMMAND(
-       OUTPUT  ${CMAKE_BINARY_DIR}/wireshark.pod
-       COMMAND cat
-               ${CMAKE_SOURCE_DIR}/doc/wireshark.pod.template
-               ${CMAKE_BINARY_DIR}/AUTHORS-SHORT-FORMAT
-               > ${CMAKE_BINARY_DIR}/wireshark.pod
-       DEPENDS
-               ${CMAKE_SOURCE_DIR}/doc/wireshark.pod.template
-               ${CMAKE_BINARY_DIR}/AUTHORS-SHORT-FORMAT
-)
-endif()
-
 if(ENABLE_APPLICATION_BUNDLE)
        add_custom_target(app_bundle)
        set_target_properties(app_bundle PROPERTIES FOLDER "Copy Tasks")
@@ -2509,53 +2517,6 @@ if(ENABLE_APPLICATION_BUNDLE)
 
 endif()
 
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/androiddump 1 )
-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 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/extcap 4 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/asn2deb 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/idl2deb 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/idl2wrs 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/mergecap 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/randpkt 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/randpktdump 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/rawshark 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/reordercap 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/sshdump 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/text2pcap 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/tshark 1 )
-pod2manhtml( ${CMAKE_BINARY_DIR}/wireshark 1 )
-pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/wireshark-filter 4 )
-
-add_custom_target(
-       html_docs ALL
-       DEPENDS
-               ${CMAKE_BINARY_DIR}/AUTHORS-SHORT
-               androiddump.html
-               capinfos.html
-               captype.html
-               dftest.html
-               dumpcap.html
-               editcap.html
-               asn2deb.html
-               idl2deb.html
-               idl2wrs.html
-               mergecap.html
-               randpkt.html
-               randpktdump.html
-               rawshark.html
-               reordercap.html
-               sshdump.html
-               text2pcap.html
-               tshark.html
-               wireshark.html
-               wireshark-filter.html
-)
-set_target_properties(html_docs PROPERTIES FOLDER "Docs")
-
 set(CLEAN_FILES
        ${wireshark_FILES}
        ${tshark_FILES}
@@ -2571,6 +2532,7 @@ set(CLEAN_FILES
        ${dumpcap_FILES}
        ${androiddump_FILES}
        ${sshdump_FILES}
+       ${ciscodump_FILES}
 )
 
 if (WERROR_COMMON_FLAGS)
@@ -2588,20 +2550,6 @@ install(
                ${CMAKE_INSTALL_DATADIR}/${CPACK_PACKAGE_NAME}
 )
 
-install(
-       FILES
-               ${MAN1_FILES}
-       DESTINATION
-               ${CMAKE_INSTALL_MANDIR}/man1
-)
-
-install(
-       FILES
-               ${MAN4_FILES}
-       DESTINATION
-               ${CMAKE_INSTALL_MANDIR}/man4
-)
-
 install(
        FILES
                "${CMAKE_BINARY_DIR}/wireshark.pc"
@@ -2624,12 +2572,6 @@ install(
        PATTERN "faq.py" EXCLUDE
 )
 
-include( UseCheckAPI )
-CHECKAPI(
-       ${TSHARK_TAP_SRC}
-       ${WIRESHARK_SRC}
-)
-
 set(CMAKE_INSTALL_MODULES_DIR ${CMAKE_INSTALL_LIBDIR}/${CPACK_PACKAGE_NAME})
 configure_file("${CMAKE_MODULE_PATH}/WiresharkConfig.cmake.in" "${CMAKE_BINARY_DIR}/WiresharkConfig.cmake" @ONLY)
 configure_file("${CMAKE_MODULE_PATH}/WiresharkConfigVersion.cmake.in" "${CMAKE_BINARY_DIR}/WiresharkConfigVersion.cmake" @ONLY)
@@ -2680,6 +2622,18 @@ add_custom_target(test-sh
 )
 set_target_properties(test-sh PROPERTIES FOLDER "Tests")
 
+if (GIT_EXECUTABLE)
+       # Update AUTHORS file with entries from git shortlog
+       add_custom_target(
+               gen-authors
+               COMMAND ${PERL_EXECUTABLE} tools/generate_authors.pl AUTHORS.src > AUTHORS
+               WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
+       )
+else (GIT_EXECUTABLE)
+       add_custom_target( gen-authors COMMAND ${CMAKE_COMMAND} -E echo "Git not found." )
+endif (GIT_EXECUTABLE)
+set_target_properties(gen-authors PROPERTIES FOLDER "Docs")
+
 add_custom_target(test-programs
        DEPENDS test-sh
                exntest
@@ -2719,6 +2673,17 @@ else ()
        endif()
 endif()
 
+include( UseCheckAPI )
+CHECKAPI(
+       NAME
+         main
+       SWITCHES
+         -build
+       SOURCES
+         ${WIRESHARK_SRC}
+         ${TSHARK_TAP_SRC}
+)
+
 #
 # Editor modelines  -  http://www.wireshark.org/tools/modelines.html
 #