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

📄 log.cc

📁 定向扩散路由协议
💻 CC
字号:
//// log.cc         : Log Filter// author         : Fabio Silva//// Copyright (C) 2000-2002 by the University of Southern California// $Id: log.cc,v 1.11 2002/05/29 00:00:39 fabio Exp $//// This program is free software; you can redistribute it and/or// modify it under the terms of the GNU General Public License,// version 2, as published by the Free Software Foundation.//// This program is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License along// with this program; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.////#include "log.hh"char *msg_types[] = {"INTEREST", "POSITIVE REINFORCEMENT",		     "NEGATIVE REINFORCEMENT", "DATA",		     "EXPLORATORY DATA", "PUSH EXPLORATORY DATA",		     "CONTROL", "REDIRECT"};#ifdef NS_DIFFUSIONstatic class LogFilterClass : public TclClass {public:  LogFilterClass() : TclClass("Application/DiffApp/LogFilter") {}  TclObject * create(int argc, const char*const* argv) {    return(new LogFilter());  }} class_log_filter;int LogFilter::command(int argc, const char*const* argv) {  if (argc == 2) {    if (strcmp(argv[1], "start") == 0) {      run();      return TCL_OK;    }  }  return DiffApp::command(argc, argv);}#endif // NS_DIFFUSIONvoid LogFilterReceive::recv(Message *msg, handle h){  app_->recv(msg, h);}void LogFilter::recv(Message *msg, handle h){  if (h != filter_handle_){    DiffPrint(DEBUG_ALWAYS,	      "Error: recv received message for handle %d when subscribing to handle %d !\n", h, filter_handle_);    return;  }  ProcessMessage(msg);  ((DiffusionRouting *)dr_)->sendMessage(msg, h);}void LogFilter::ProcessMessage(Message *msg){  DiffPrint(DEBUG_ALWAYS, "Received a");  if (msg->new_message_)    DiffPrint(DEBUG_ALWAYS, " new ");  else    DiffPrint(DEBUG_ALWAYS, "n old ");  if (msg->last_hop_ != LOCALHOST_ADDR)    DiffPrint(DEBUG_ALWAYS, "%s message from node %d, %d bytes\n",	      msg_types[msg->msg_type_], msg->last_hop_,	      CalculateSize(msg->msg_attr_vec_));  else    DiffPrint(DEBUG_ALWAYS, "%s message from agent %d, %d bytes\n",	      msg_types[msg->msg_type_], msg->source_port_,	      CalculateSize(msg->msg_attr_vec_));}handle LogFilter::setupFilter(){  NRAttrVec attrs;  handle h;  // This is a dummy attribute for filtering that matches everything  attrs.push_back(NRClassAttr.make(NRAttribute::IS, NRAttribute::INTEREST_CLASS));  h = ((DiffusionRouting *)dr_)->addFilter(&attrs, LOG_FILTER_PRIORITY,					   filter_callback_);  ClearAttrs(&attrs);  return h;}void LogFilter::run(){#ifdef NS_DIFFUSION  filter_handle_ = setupFilter();  DiffPrint(DEBUG_ALWAYS, "Log filter subscribed to *, received handle %d\n",	    filter_handle_);  DiffPrint(DEBUG_ALWAYS, "Log filter initialized !\n");#else  // Doesn't do anything  while (1){    sleep(1000);  }#endif // NS_DIFFUSION}#ifdef NS_DIFFUSIONLogFilter::LogFilter()#elseLogFilter::LogFilter(int argc, char **argv)#endif // NS_DIFFUSION{  // Create Diffusion Routing class#ifndef NS_DIFFUSION  parseCommandLine(argc, argv);  dr_ = NR::createNR(diffusion_port_);#endif // !NS_DIFFUSION  filter_callback_ = new LogFilterReceive(this);#ifndef NS_DIFFUSION  // Set up the filter  filter_handle_ = setupFilter();  DiffPrint(DEBUG_ALWAYS, "Log filter subscribed to *, received handle %d\n", filter_handle_);  DiffPrint(DEBUG_ALWAYS, "Log filter initialized !\n");#endif // !NS_DIFFUSION}#ifndef NS_DIFFUSIONint main(int argc, char **argv){  LogFilter *app;  // Initialize and run the Log Filter  app = new LogFilter(argc, argv);  app->run();  return 0;}#endif // !NS_DIFFUSION

⌨️ 快捷键说明

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