Dissect additional information parameters for Result object
[metze/wireshark/wip.git] / CMakeLists.txt
index 29269b80f28c94e17ff6cfca2a542b2e5366bca1..e493ded9ce2533e402b3efcccdbfb6de04623dd0 100644 (file)
@@ -18,7 +18,7 @@
 #
 # You should have received a copy of the GNU General Public License
 # along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 #
 
 project(Wireshark C CXX)
@@ -33,42 +33,53 @@ if(COMMAND cmake_policy)
 #      cmake_policy(SET CMP0015 NEW)
 endif(COMMAND cmake_policy)
 
-# set(PROJECT_VERSION "1.3.4-rc5")
-# set(PROJECT_VERSION "1.3.4rc5")
-# set(PROJECT_VERSION "1.3.4")
-# If not set, copy over Wireshark version from configure.in AC_INIT
-if(NOT PROJECT_VERSION)
+# set(PROJECT_MAJOR_VERSION 1)
+# set(PROJECT_MINOR_VERSION 9)
+# set(PROJECT_PATCH_VERSION 0)
+# set(PROJECT_VERSION_EXTENSION "-rc5")
+# If not set, copy over Wireshark version from configure.ac
+if(NOT PROJECT_MAJOR_VERSION)
        file(STRINGS
-               ${CMAKE_SOURCE_DIR}/configure.in
-               VERSIONLINE
-               REGEX "\\(wireshark, .*\\)"
+               ${CMAKE_SOURCE_DIR}/configure.ac
+               PROJECT_MAJOR_VERSION_TMP
+               REGEX "^m4_define\\(\\[?version_major\\]?, *\\[?[0-9]+\\]?\\)"
        )
-       string(REGEX REPLACE ".*\\(wireshark, (.*)\\).*"
+       file(STRINGS
+               ${CMAKE_SOURCE_DIR}/configure.ac
+               PROJECT_MINOR_VERSION_TMP
+               REGEX "^m4_define\\(\\[?version_minor\\]?, *\\[?[0-9]+\\]?\\)"
+       )
+       file(STRINGS
+               ${CMAKE_SOURCE_DIR}/configure.ac
+               PROJECT_PATCH_VERSION_TMP
+               REGEX "^m4_define\\(\\[?version_micro\\]?, *\\[?[0-9]+\\]?\\)"
+       )
+       # XXX pull VERSION_EXTENSION out of configure.ac ?
+
+       string(REGEX REPLACE "m4_define\\(\\[?version_major\\]?, *\\[?([0-9]+)\\]?\\)"
+               "\\1"
+               PROJECT_MAJOR_VERSION
+               ${PROJECT_MAJOR_VERSION_TMP}
+       )
+       string(REGEX REPLACE "m4_define\\(\\[?version_minor\\]?, *\\[?([0-9]+)\\]?\\)"
+               "\\1"
+               PROJECT_MINOR_VERSION
+               ${PROJECT_MINOR_VERSION_TMP}
+       )
+       string(REGEX REPLACE "m4_define\\(\\[?version_micro\\]?, *\\[?([0-9]+)\\]?\\)"
                "\\1"
-               PROJECT_VERSION
-               ${VERSIONLINE}
+               PROJECT_PATCH_VERSION
+               ${PROJECT_PATCH_VERSION_TMP}
        )
 endif()
-string(REGEX REPLACE "([0-9]+)\\..*"
-       "\\1"
-       PROJECT_MAJOR_VERSION
-       ${PROJECT_VERSION}
-)
-string(REGEX REPLACE ".*\\.([0-9]+)\\..*"
-       "\\1"
-       PROJECT_MINOR_VERSION
-       ${PROJECT_VERSION}
-)
-string(REGEX REPLACE ".*\\..*\\.([0-9]+).*"
-       "\\1"
-       PROJECT_PATCH_VERSION
-       ${PROJECT_VERSION}
-)
-string(REGEX REPLACE ".*\\..*\\.[0-9]+(.*)"
-       "\\1"
-       PROJECT_VERSION_EXTENSION
-       ${PROJECT_VERSION}
-)
+
+
+if(PROJECT_VERSION_EXTENSION)
+       set(PROJECT_VERSION ${PROJECT_MAJOR_VERSION}.${PROJECT_MINOR_VERSION}.${PROJECT_PATCH_VERSION}${PROJECT_VERSION_EXTENSION})
+else()
+       set(PROJECT_VERSION ${PROJECT_MAJOR_VERSION}.${PROJECT_MINOR_VERSION}.${PROJECT_PATCH_VERSION})
+endif()
+
 message(STATUS "V: ${PROJECT_VERSION}, MaV: ${PROJECT_MAJOR_VERSION}, MiV: ${PROJECT_MINOR_VERSION}, PL: ${PROJECT_PATCH_VERSION}, EV: ${PROJECT_VERSION_EXTENSION}.")
 
 #Where to find local cmake scripts
@@ -105,20 +116,25 @@ include(CMakeOptions.txt)
 
 set(WIRESHARK_C_FLAGS
        -O2
+       -g
        -Wall
        -W
        -Wextra
-       -Wdeclaration-after-statement
        -Wendif-labels
        -Wpointer-arith
-       -Wno-pointer-sign
        -Warray-bounds
        -Wcast-align
        -Wformat-security
-       -Wold-style-definition
        -fexcess-precision=fast
 )
 
+set(WIRESHARK_C_ONLY_FLAGS
+       # The following are C only, not C++
+       -Wdeclaration-after-statement
+       -Wno-pointer-sign
+       -Wold-style-definition
+)
+
 set(WIRESHARK_EXTRA_C_FLAGS
        -pedantic
        -Woverflow
@@ -128,7 +144,6 @@ set(WIRESHARK_EXTRA_C_FLAGS
        -Wunreachable-code
        -Wunsafe-loop-optimizations
        -Wno-long-long
-       -Wbad-function-cast
        -Wcast-qual
        -Waddress
        -Warray-bounds
@@ -139,27 +154,34 @@ set(WIRESHARK_EXTRA_C_FLAGS
        -Wpragmas
        -Wredundant-decls
        -Wvla
-       -Wc++-compat
-       -Wjump-misses-init
        # packet-ncp2222.inc prevents this from going into all warnings
        -Wwrite-strings
-       # GLib blocks this for now.
-       -Wstrict-prototypes
        # All the registration functions block these for now.
-       -Wmissing-prototypes
        -Wmissing-declarations
        # Problem with packet-afs.c
        -Wshadow
        # More cleanup needed for this on LP64
        -Wshorten-64-to-32
+
+)
+
+set(WIRESHARK_EXTRA_C_ONLY_FLAGS
+       # The following are C only, not C++
+       -Wbad-function-cast
+       -Wc++-compat
+       -Wjump-misses-init
+       # GLib blocks this for now.
+       -Wstrict-prototypes
+       # All the registration functions block these for now.
+       -Wmissing-prototypes
 )
 
 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})
 endif()
 
 add_definitions(
-       -DHAVE_CONFIG_H
        -DG_DISABLE_DEPRECATED
        -DG_DISABLE_SINGLE_INCLUDES
 )
@@ -174,10 +196,23 @@ foreach(THIS_FLAG ${WIRESHARK_C_FLAGS})
        set(V WS_C_FLAG_VALID${C})
        check_c_compiler_flag(${${F}} ${V})
        if (${${V}})
-               add_definitions(${${F}})
+               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})
+       set(${F} ${THIS_FLAG})
+       set(V WS_C_FLAG_VALID${C})
+       check_c_compiler_flag(${${F}} ${V})
+       if (${${V}})
+               set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${${F}}")
+       endif()
+       math(EXPR C "${C} + 1")
+endforeach()
+message(STATUS "C-Flags: ${CMAKE_C_FLAGS}\nCXX-Flags: ${CMAKE_CXX_FLAGS}")
 
 if(NOT DISABLE_WERROR AND NOT ENABLE_EXTRA_GCC_CHECKS)
        check_c_compiler_flag(-Werror WERROR)
@@ -307,6 +342,10 @@ if(ENABLE_GEOIP)
        set(PACKAGELIST ${PACKAGELIST} GEOIP)
 endif()
 
+if(ENABLE_NETLINK)
+       set(PACKAGELIST ${PACKAGELIST} NL)
+endif()
+
 # Capabilities
 if(ENABLE_CAP)
        set(PACKAGELIST ${PACKAGELIST} CAP)
@@ -321,7 +360,7 @@ set(PACKAGELIST ${PACKAGELIST} YAPP)
 set(PACKAGELIST ${PACKAGELIST} POD)
 
 
-set(PROGLIST text2pcap mergecap capinfos editcap dumpcap)
+set(PROGLIST text2pcap mergecap capinfos editcap reordercap dumpcap)
 
 #Let's loop the package list
 foreach(PACKAGE ${PACKAGELIST})
@@ -355,7 +394,7 @@ if(HAVE_LIBPYTHON)
 endif()
 if(HAVE_LIBLUA)
        set(HAVE_LUA_H 1)
-       set(HAVE_LUA_5_1 1)
+       set(HAVE_LUA 1)
 endif()
 if(HAVE_LIBKERBEROS)
        set(HAVE_KERBEROS 1)
@@ -375,6 +414,9 @@ endif()
 if(ENABLE_AIRPCAP)
        set(HAVE_AIRPCAP 1)
 endif()
+if(HAVE_LIBNL AND ENABLE_AIRPCAP)
+       message(ERROR "Airpcap and Libnl support are mutually exclusive")
+endif()
 # No matter which version of GTK is present
 if(GTK2_FOUND OR GTK3_FOUND)
        set(GTK_FOUND ON)
@@ -406,7 +448,6 @@ if(ENABLE_PLUGINS)
                plugins/asn1
                plugins/docsis
                plugins/ethercat
-               plugins/giop
                plugins/gryphon
                plugins/irda
                plugins/m2m
@@ -417,6 +458,7 @@ if(ENABLE_PLUGINS)
                plugins/unistim
                plugins/wimax
                plugins/wimaxasncp
+               plugins/wimaxmacphy
        )
 # It seems this stuff doesn't build with autofoo either...
 #      if(YAPP_FOUND)
@@ -439,6 +481,10 @@ add_subdirectory( tools/lemon )
 add_subdirectory( wiretap )
 add_subdirectory( wsutil )
 
+if((BUILD_wireshark AND GTK_FOUND) OR (BUILD_qtshark AND QT_FOUND))
+       add_subdirectory( ui )
+endif()
+
 if(BUILD_wireshark AND GTK_FOUND)
        add_subdirectory( ui/gtk )
 endif()
@@ -494,6 +540,7 @@ PRINT_ENABLED_FEATURES()
 PRINT_DISABLED_FEATURES()
 
 link_directories(
+       ${CMAKE_BINARY_DIR}/ui
        ${CMAKE_BINARY_DIR}/ui/gtk
        ${CMAKE_BINARY_DIR}/ui/qt
        ${CMAKE_BINARY_DIR}/codecs
@@ -640,6 +687,7 @@ set(INSTALL_FILES
        pdml2html.xsl
        ${CMAKE_BINARY_DIR}/randpkt.html
        ${CMAKE_BINARY_DIR}/rawshark.html
+       ${CMAKE_BINARY_DIR}/reordercap.html
        services
        smi_modules
        ${CMAKE_BINARY_DIR}/text2pcap.html
@@ -672,7 +720,6 @@ set(LIBEPAN_LIBS
 if( (BUILD_wireshark AND GTK_FOUND) OR (BUILD_qtshark AND QT_FOUND) )
        set(wireshark_FILES
                airpcap_loader.c
-               alert_box.c
                capture.c
                capture_info.c
                capture_opts.c
@@ -682,13 +729,14 @@ if( (BUILD_wireshark AND GTK_FOUND) OR (BUILD_qtshark AND QT_FOUND) )
                fileset.c
                filters.c
                g711.c
+               iface_monitor.c
                merge.c
                proto_hier_stats.c
                recent.c
                summary.c
                tempfile.c
                u3.c
-               ui/util.c
+               ws80211_utils.c
                ${SHARK_COMMON_CAPTURE_SRC}
                ${WIRESHARK_COMMON_SRC}
        )
@@ -697,6 +745,7 @@ endif()
 if(BUILD_wireshark AND GTK_FOUND)
        set(wireshark_LIBS
                gtkui
+               ui
                ${GTK2_LIBRARIES}
                ${GTK3_LIBRARIES}
                ${GTHREAD2_LIBRARIES}
@@ -705,6 +754,7 @@ if(BUILD_wireshark AND GTK_FOUND)
                ${LIBEPAN_LIBS}
                ${APPLE_CORE_SERVICES_LIBRARY}
                ${APPLE_COCOA_LIBRARY}
+               ${NL_LIBRARIES}
        )
        # qtshark and wireshark share wireshark_FILES
 
@@ -718,6 +768,7 @@ endif()
 if(BUILD_qtshark AND QT_FOUND)
        set(qtshark_LIBS
                qtui
+               ui
                ${QT_LIBRARIES}
                ${GTHREAD2_LIBRARIES}
                codecs
@@ -725,6 +776,7 @@ if(BUILD_qtshark AND QT_FOUND)
                ${LIBEPAN_LIBS}
                ${APPLE_CORE_SERVICES_LIBRARY}
                ${APPLE_COCOA_LIBRARY}
+               ${NL_LIBRARIES}
        )
        # qtshark and wireshark share wireshark_FILES
 
@@ -784,7 +836,7 @@ if(BUILD_dftest)
                ${LIBEPAN_LIBS}
        )
        set(dftest_FILES
-               ui/cli/dftest.c
+               dftest.c
                ui/util.c
        )
        add_executable(dftest ${dftest_FILES})
@@ -844,6 +896,7 @@ if(BUILD_mergecap)
                mergecap.c
                merge.c
                svnversion.h
+               ${WTAP_PLUGIN_SOURCES}
        )
        add_executable(mergecap ${mergecap_FILES})
        add_dependencies(mergecap svnversion)
@@ -852,9 +905,27 @@ if(BUILD_mergecap)
        install(TARGETS mergecap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
 endif()
 
+if(BUILD_reordercap)
+       set(reordercap_LIBS
+               wiretap
+               ${ZLIB_LIBRARIES}
+       )
+       set(reordercap_FILES
+               reordercap.c
+               svnversion.h
+               ${WTAP_PLUGIN_SOURCES}
+       )
+       add_executable(reordercap ${reordercap_FILES})
+       add_dependencies(reordercap svnversion)
+       set_target_properties(reordercap PROPERTIES LINK_FLAGS "${WS_LINK_FLAGS}")
+       target_link_libraries(reordercap ${reordercap_LIBS})
+       install(TARGETS reordercap RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
+endif()
+
 if(BUILD_capinfos)
        set(capinfos_LIBS
                wiretap
+               wsutil
                ${ZLIB_LIBRARIES}
                ${GCRYPT_LIBRARIES}
                ${APPLE_COCOA_LIBRARY}
@@ -900,6 +971,7 @@ if(BUILD_dumpcap AND PCAP_FOUND)
                ${GTHREAD2_LIBRARIES}
                ${ZLIB_LIBRARIES}
                ${APPLE_COCOA_LIBRARY}
+               ${NL_LIBRARIES}
        )
        set(dumpcap_FILES
                svnversion.h
@@ -914,6 +986,7 @@ if(BUILD_dumpcap AND PCAP_FOUND)
                sync_pipe_write.c
                tempfile.c
                version_info.c
+               ws80211_utils.c
                ${PLATFORM_SRC}
        )
        add_executable(dumpcap ${dumpcap_FILES})
@@ -963,6 +1036,7 @@ 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/rawshark 1 )
+pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/reordercap 1 )
 pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/text2pcap 1 )
 pod2manhtml( ${CMAKE_SOURCE_DIR}/doc/tshark 1 )
 pod2manhtml( wireshark 1 )
@@ -980,6 +1054,7 @@ add_custom_target(
                mergecap.html
                randpkt.html
                rawshark.html
+               reordercap.html
                text2pcap.html
                tshark.html
                wireshark.html
@@ -995,6 +1070,7 @@ set(MAN1_FILES
        ${CMAKE_BINARY_DIR}/mergecap.1
        ${CMAKE_BINARY_DIR}/randpkt.1
        ${CMAKE_BINARY_DIR}/rawshark.1
+       ${CMAKE_BINARY_DIR}/reordercap.1
        ${CMAKE_BINARY_DIR}/text2pcap.1
        ${CMAKE_BINARY_DIR}/tshark.1
        ${CMAKE_BINARY_DIR}/wireshark.1
@@ -1076,4 +1152,3 @@ if(DOC_DIR)
                PATTERN "*.pdf"
        )
 endif()
-