packetlogger2.hh

来自「COPE the first practical network coding 」· HH 代码 · 共 76 行

HH
76
字号
#ifndef CLICK_PACKETLOGGER2_HH#define CLICK_PACKETLOGGER2_HH#include <click/element.hh>#include <click/glue.hh>#include <click/dequeue.hh>CLICK_DECLS/* * =c * PacketLogger2(I<KEYWORKDS>) *  * =s Grid * Log packets for later dumping/analysis. *  * =d  * PacketLogger2 records the size, timestamp, user annotations, and * the first few bytes of every packet to pass through.  The list of * recorded data can be dumped (and cleared) by repeated calls to the * read handler 'log'. * * Keyword arguments are: * * =over 8 *  * =item NBYTES * Unsigned integer.  Number of bytes of each packet to record. * Defaults to 34 bytes. * * =back * * =h log read-only * Print as much of the list of logged packets as possible, clearing  * printed packets from the log. * */class PacketLogger2 : public Element { public:    PacketLogger2();  ~PacketLogger2();    const char *class_name() const		{ return "PacketLogger2"; }  const char *processing() const		{ return AGNOSTIC; }  const char *flow_code() const			{ return "#/#"; }    int configure(Vector<String> &, ErrorHandler *);  bool can_live_reconfigure() const		{ return true; }  Packet *simple_action(Packet *);  void add_handlers();  static String print_log(Element *, void *);  static int clear(const String &foo, Element *e, void *vparam, ErrorHandler *errh);  static String left(Element *, void *);  enum { NBYTES = 18 };    struct log_entry {    Timestamp timestamp;    unsigned length;    uint8_t anno[Packet::USER_ANNO_SIZE];    uint8_t bytes[NBYTES];  }; private:  unsigned int _nb;    DEQueue<log_entry> _p;};CLICK_ENDDECLS#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?