⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 filterbyrange.cc

📁 COPE the first practical network coding scheme which is developped on click
💻 CC
字号:
/* * filterbyrange.{cc,hh} -- Grid packet filtering element * Douglas S. J. De Couto * * Copyright (c) 2000 Massachusetts Institute of Technology * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, subject to the conditions * listed in the Click LICENSE file. These conditions include: you must * preserve this copyright notice, and you cannot mention the copyright * holders in advertising related to the Software without their permission. * The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This * notice is a summary of the Click LICENSE file; the license in that file is * legally binding. */#include <click/config.h>#include <stddef.h>#include "filterbyrange.hh"#include <click/confparse.hh>#include <click/error.hh>#include <click/router.hh>#include <clicknet/ether.h>#include <click/glue.hh>CLICK_DECLSFilterByRange::FilterByRange() : Element(1, 2), _locinfo(0){}FilterByRange::~FilterByRange(){}intFilterByRange::configure(Vector<String> &conf, ErrorHandler *errh){  int res = cp_va_parse(conf, this, errh,			cpInteger, "range (metres)", &_range,                        cpElement, "GridLocationInfo element", &_locinfo,			cpEnd);  return res;}intFilterByRange::initialize(ErrorHandler *errh){  if(_locinfo && _locinfo->cast("GridLocationInfo") == 0){    errh->warning("%s: GridLocationInfo argument %s has the wrong type",                  id().cc(),                  _locinfo->id().cc());    _locinfo = 0;  } else if(_locinfo == 0){    return errh->error("no GridLocationInfo argument");  }  return 0;}voidFilterByRange::push(int, Packet *p){  assert(p);  if (_range < 0) { // negative range means: don't filter    output(0).push(p);    return;  }  grid_hdr *gh = (grid_hdr *) (p->data() + sizeof(click_ether));  grid_location remote_loc(gh->tx_loc);  assert(_locinfo);  grid_location our_loc = _locinfo->get_current_location();  double dist = grid_location::calc_range(our_loc, remote_loc);#if 0  IPAddress tx(gh->tx_ip);  click_chatter("XXXXX range %s %f", tx.s().cc(), dist);#endif  if (dist < 0) {    click_chatter("bogus location info in grid header");    output(1).push(p);    return;  }  if (dist < _range)    output(0).push(p);  else // ``out of range''    output(1).push(p);}CLICK_ENDDECLSELEMENT_REQUIRES(userlevel GridLocationInfo)EXPORT_ELEMENT(FilterByRange)

⌨️ 快捷键说明

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