aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/tcpflow/files/patch-src__be13_api__plugin.cpp48
-rw-r--r--net/tcpflow/files/patch-src__tcpdemux.h39
2 files changed, 87 insertions, 0 deletions
diff --git a/net/tcpflow/files/patch-src__be13_api__plugin.cpp b/net/tcpflow/files/patch-src__be13_api__plugin.cpp
new file mode 100644
index 000000000000..cc2a9d695bf9
--- /dev/null
+++ b/net/tcpflow/files/patch-src__be13_api__plugin.cpp
@@ -0,0 +1,48 @@
+--- ./src/be13_api/plugin.cpp.orig 2013-08-03 16:58:46.000000000 +0000
++++ ./src/be13_api/plugin.cpp 2013-09-07 22:32:02.000000000 +0000
+@@ -9,7 +9,16 @@
+ #include <sys/stat.h>
+ #include <dirent.h>
+ #include <algorithm>
++#ifdef __clang__
++#if __has_include(<unordered_set>)
++#define HAVE_CXX11_UNORDERED_SET 1
++#endif
++#endif
++#ifdef HAVE_CXX11_UNORDERED_SET
++#include <unordered_set>
++#else
+ #include <tr1/unordered_set>
++#endif
+ #ifdef HAVE_ERR_H
+ #include <err.h>
+ #endif
+@@ -23,20 +32,28 @@
+ #include "../dfxml/src/hash_t.h"
+
+ namespace std {
++#ifndef HAVE_CXX11_UNORDERED_SET
+ namespace tr1 {
++#endif
+ template<>
+ struct hash<md5_t> {
+ size_t operator()(const md5_t &key) const {
+ return *(size_t *)(key.final());
+ }
+ };
++#ifndef HAVE_CXX11_UNORDERED_SET
+ }
++#endif
+ }
+
+ class atomic_hash_set
+ {
+ cppmutex M;
++#ifdef HAVE_CXX11_UNORDERED_SET
++ std::unordered_set<md5_t>myset;
++#else
+ std::tr1::unordered_set<md5_t>myset;
++#endif
+ public:
+ atomic_hash_set():M(),myset(){}
+ bool in(const md5_t &s){
diff --git a/net/tcpflow/files/patch-src__tcpdemux.h b/net/tcpflow/files/patch-src__tcpdemux.h
new file mode 100644
index 000000000000..d967b5a9191d
--- /dev/null
+++ b/net/tcpflow/files/patch-src__tcpdemux.h
@@ -0,0 +1,39 @@
+--- ./src/tcpdemux.h.orig 2013-05-27 22:28:50.000000000 +0000
++++ ./src/tcpdemux.h 2013-09-07 22:32:29.000000000 +0000
+@@ -20,8 +20,18 @@
+ #include "pcap_writer.h"
+ #include "dfxml/src/dfxml_writer.h"
+ #include "dfxml/src/hash_t.h"
++#ifdef __clang__
++#if __has_include(<unordered_set>)
++#define HAVE_CXX11_UNORDERED_SET 1
++#endif
++#endif
++#ifdef HAVE_CXX11_UNORDERED_SET
++#include <unordered_map>
++#include <unordered_set>
++#else
+ #include <tr1/unordered_map>
+ #include <tr1/unordered_set>
++#endif
+ #include <queue>
+
+
+@@ -53,10 +63,17 @@
+ bool operator() (const flow_addr &x, const flow_addr &y) const { return x==y;}
+ } flow_addr_key_eq;
+
++#ifdef HAVE_CXX11_UNORDERED_SET
++ typedef std::unordered_set<class tcpip *> tcpset;
++ typedef std::vector<class saved_flow *> saved_flows_t; // needs to be ordered
++ typedef std::unordered_map<flow_addr,tcpip *,flow_addr_hash,flow_addr_key_eq> flow_map_t; // active flows
++ typedef std::unordered_map<flow_addr,saved_flow *,flow_addr_hash,flow_addr_key_eq> saved_flow_map_t; // flows that have been saved
++#else
+ typedef std::tr1::unordered_set<class tcpip *> tcpset;
+ typedef std::vector<class saved_flow *> saved_flows_t; // needs to be ordered
+ typedef std::tr1::unordered_map<flow_addr,tcpip *,flow_addr_hash,flow_addr_key_eq> flow_map_t; // active flows
+ typedef std::tr1::unordered_map<flow_addr,saved_flow *,flow_addr_hash,flow_addr_key_eq> saved_flow_map_t; // flows that have been saved
++#endif
+ tcpdemux();
+ public:
+ static uint32_t tcp_timeout;