📄 rmst_source.cc
字号:
//// rmst_source.cc : RmstSource Class Methods// authors : Fred Stann//// Copyright (C) 2003 by the University of Southern California// $Id: rmst_source.cc,v 1.2 2003/07/10 21:18:56 haldar 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 "rmst_source.hh"#include <unistd.h>#ifdef NS_DIFFUSIONstatic class RmstSrcClass : public TclClass {public: RmstSrcClass() : TclClass("Application/DiffApp/RmstSource") {} TclObject* create(int , const char*const* ) { return(new RmstSource()); }} class_rmst_source;void RmstSendDataTimer::expire(Event *e) { a_->send();}void RmstSource::send(){ int sleep_interval; bool sent_first_blob = false; if (num_subscriptions_ > 0){ if (!sent_first_blob){ sendBlob(); sent_first_blob = true; sleep_interval = 100; } else printf("RMST-SRC::sees subscriptions\n"); } else{ printf("RMST-SRC::sees no subscriptions\n"); sleep_interval = 10; } // re-schedule the timer sdt_.resched(sleep_interval);}int RmstSource::command(int argc, const char*const* argv) { if (argc == 2) { if (strcmp(argv[1], "subscribe") == 0) { run(); return TCL_OK; } } return DiffApp::command(argc, argv);}#endif // NS_DIFFUSIONvoid RmstSrcReceive::recv(NRAttrVec *data, NR::handle my_handle){ NRSimpleAttribute<char*> *rmst_target_attr = NULL; NRSimpleAttribute<int> *nr_class = NULL; NRSimpleAttribute<int> *tsprt_ctl_attr = NULL; int class_type; int tsprt_ctl_type; timeval cur_time; printf("RMST-SRC::recv got an attr vector."); GetTime(&cur_time); printf(" time: sec = %d\n", (unsigned int) cur_time.tv_sec); nr_class = NRClassAttr.find(data); if (nr_class) class_type = nr_class->getVal(); tsprt_ctl_attr = RmstTsprtCtlAttr.find(data); if (tsprt_ctl_attr) tsprt_ctl_type = tsprt_ctl_attr->getVal(); if (nr_class){ switch (class_type){ case NRAttribute::INTEREST_CLASS: if (tsprt_ctl_attr && (tsprt_ctl_type == RMST_RESP)){ printf(" Source received an INTEREST message\n"); src_->num_subscriptions_++; } break; case NRAttribute::DISINTEREST_CLASS: src_->num_subscriptions_--; rmst_target_attr = RmstTargetAttr.find(data); if (rmst_target_attr){ printf(" Source received a DISINTEREST for %s\n", rmst_target_attr->getVal()); } else printf(" Source received a Disinterest message for unknown Interest!\n"); break; default: printf(" Source received an unknown or inappropriate class!(%d)!\n", nr_class->getVal()); break; } } if (tsprt_ctl_attr){ switch (tsprt_ctl_type){ case RMST_RESP: break; case RMST_CONT: printf(" Source received a RMST_CONT message\n"); if(src_->blobs_to_send_ > 0){ printf (" Source sending another blob\n"); src_->sendBlob(); } else printf (" Source done sending blobs\n"); break; default: printf(" Source received an unexpected RmstTsprtCtlAttr (%d)!\n", tsprt_ctl_attr->getVal()); break; } }}#ifdef NS_DIFFUSIONRmstSource::RmstSource() : blobs_to_send_(4), sdt_(this)#elseRmstSource::RmstSource(int argc, char **argv) : blobs_to_send_(4)#endif // NS_DIFFUSION{ mr = new RmstSrcReceive(this);#ifndef NS_DIFFUSION parseCommandLine(argc, argv); dr_ = NR::createNR(diffusion_port_);#endif // NS_DIFFUSION ck_val_ = 100;}#ifndef NS_DIFFUSIONint main(int argc, char **argv){ RmstSource *app; app = new RmstSource(argc, argv); app->run(); return 0;}#endif // NS_DIFFUSIONvoid RmstSource::run(){#ifndef NS_DIFFUSION int sleep_interval; bool sent_first_blob = false;#endif // !NS_DIFFUSION // Let diffusion know what kinds of interests we "latch." subscribe_handle_ = setupRmstInterest(); // Let diffusion know what we intend to publish. send_handle_ = setupRmstPublication();#ifndef NS_DIFFUSION while(1){ if (num_subscriptions_ > 0){ if (!sent_first_blob){ sendBlob(); sent_first_blob = true; sleep_interval = 100; } else printf("RMST-SRC::sees subscriptions\n"); } else{ printf("RMST-SRC::sees no subscriptions\n"); sleep_interval = 10; } sleep(sleep_interval); } //while loop#else send();#endif // !NS_DIFFUSION}handle RmstSource::setupRmstInterest(){ NRAttrVec attrs; printf("RMST-SRC::sets up local subscription for PCM_SAMPLEs\n"); attrs.push_back(NRClassAttr.make(NRAttribute::NE, NRAttribute::DATA_CLASS)); attrs.push_back(NRScopeAttr.make(NRAttribute::IS, NRAttribute::NODE_LOCAL_SCOPE)); attrs.push_back(RmstTargetAttr.make(NRAttribute::IS, "PCM_SAMPLE")); attrs.push_back(RmstTsprtCtlAttr.make(NRAttribute::IS, RMST_RESP)); attrs.push_back(RmstTsprtCtlAttr.make(NRAttribute::IS, RMST_CONT)); handle h = dr_->subscribe(&attrs, mr); ClearAttrs(&attrs); return h;}handle RmstSource::setupRmstPublication(){ NRAttrVec attrs; printf("RMST-SRC::publishes PCM_SAMPLE\n"); attrs.push_back(NRClassAttr.make(NRAttribute::IS, NRAttribute::DATA_CLASS)); attrs.push_back(RmstTargetAttr.make(NRAttribute::IS, "PCM_SAMPLE")); handle h = dr_->publish(&attrs); ClearAttrs(&attrs); return h;}char* RmstSource::createBlob (int ck_val){ char *tmpPtr = new char[2500]; for (int i = 0; i < 50; i++){ sprintf(&tmpPtr[i*50], "PCM FragNo: %d of ck_val %d", i, ck_val); } return tmpPtr;}void RmstSource::sendBlob() { char *blob; int retval; NRAttrVec src_attrs; // Retrieve rmsb from the local cache to get pointer to it. blob = createBlob(ck_val_); ck_val_++; src_attrs.push_back(RmstDataAttr.make(NRAttribute::IS, blob, 2500)); retval = ((DiffusionRouting *)dr_)->sendRmst(send_handle_, &src_attrs, PAYLOAD_SIZE); blobs_to_send_--; delete blob;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -