X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Examples%2FSniffer%2FSniffer.cc;h=5c81ddafe82ff4672da82598f9ebdca89c0b043f;hb=834416e1c5669c1687d63e29b8055afe3b44ad63;hp=7e60a23623b354575d055483e09fe7de3decb0b4;hpb=a1a6c76a214ad1935032826713cabaf9ac57bf07;p=senf.git diff --git a/Examples/Sniffer/Sniffer.cc b/Examples/Sniffer/Sniffer.cc index 7e60a23..5c81dda 100644 --- a/Examples/Sniffer/Sniffer.cc +++ b/Examples/Sniffer/Sniffer.cc @@ -30,10 +30,10 @@ #include #include #include -#include #include #include #include +#include //#include "Sniffer.mpp" #define prefix_ @@ -67,22 +67,23 @@ int loop_main (int argc, char const * argv[]) class Sniffer { senf::PacketSocketHandle sock; + senf::scheduler::FdEvent event; public: Sniffer(std::string const & interface) + : event ("Sniffer", senf::membind(&Sniffer::dumpPacket, this), + sock, senf::scheduler::FdEvent::EV_READ) { sock.bind(senf::LLSocketAddress(interface)); } void run() { - senf::Scheduler::instance().add( - sock, senf::membind(&Sniffer::dumpPacket, this)); - senf::Scheduler::instance().process(); + senf::scheduler::process(); } private: - void dumpPacket(senf::Scheduler::EventId event) + void dumpPacket(int event) { senf::EthernetPacket packet ( senf::EthernetPacket::create(senf::noinit)); @@ -110,11 +111,15 @@ int scheduler_main(int argc, char const * argv[]) int main(int argc, char const * argv[]) { - if (argc >= 3) + std::cout << "Registered packets:\n\n"; + senf::dumpPacketRegistries(std::cout); + + if (argc >= 3) { if (std::string(argv[1]) == "loop") return loop_main(argc,argv); else if (std::string(argv[1]) == "scheduler") return scheduler_main(argc,argv); + } std::cerr << "Usage: sniffer { loop | scheduler } [interface]" << std::endl; return 1;