X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Examples%2FSniffer%2FSniffer.cc;h=53cba175a7617ae38a2e0ee5f7363b9d9f0cbbbc;hb=5b2e9a63a43027c71ac470ac9bdecb72e8974951;hp=fbeeab4c3e3398e0f3e88986859208037f44d2ab;hpb=f90ccec9262e178534bb86c0061ecf83e3df91b3;p=senf.git diff --git a/Examples/Sniffer/Sniffer.cc b/Examples/Sniffer/Sniffer.cc index fbeeab4..53cba17 100644 --- a/Examples/Sniffer/Sniffer.cc +++ b/Examples/Sniffer/Sniffer.cc @@ -37,7 +37,7 @@ //#include "Sniffer.mpp" #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// int loop_main (int argc, char const * argv[]) { @@ -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)); @@ -113,17 +114,18 @@ int main(int argc, char const * argv[]) std::cout << "Registered packets:\n\n"; senf::dumpPacketRegistries(std::cout); - if (argc >= 3) + 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; } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_ //#include "Sniffer.mpp"