X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/8a5a52c31203af9e7eb66dc1c1c8f4e6b14d0b70..77163c152598f613abd0a938a967fcbd7a95fc8b:/src/surf/ns3/ns3_simulator.h diff --git a/src/surf/ns3/ns3_simulator.h b/src/surf/ns3/ns3_simulator.h index 484a49fb66..c69c1a8d41 100644 --- a/src/surf/ns3/ns3_simulator.h +++ b/src/surf/ns3/ns3_simulator.h @@ -1,59 +1,46 @@ -/* Copyright (c) 2007, 2008, 2009, 2010. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2007-2017. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ -#ifndef _NS3_SIM_H -#define _NS3_SIM_H - -#ifdef __cplusplus - -#include "ns3/core-module.h" -#include "ns3/helper-module.h" -#include "ns3/simulator-module.h" -#include "ns3/node-module.h" -#include "ns3/helper-module.h" -#include "ns3/global-routing-module.h" -#include "ns3/tcp-socket-factory.h" - -using namespace ns3; -using namespace std; - -struct MySocket{ - uint32_t bufferedBytes; - uint32_t sentBytes; - uint32_t remaining; - uint32_t TotalBytes; - uint32_t last_amount_sent; - char finished; - void* action; -}; +#ifndef NS3_SIM_H +#define NS3_SIM_H + +#include -//Simulator s; -class NS3Sim { +#include "ns3_interface.h" -private: +#include +#include +#include +#include +#include +#include +#include +class SgFlow { public: - NS3Sim(); - ~NS3Sim(); - void create_flow_NS3(Ptr src, - Ptr dst, - uint16_t port_number, - double start, - const char *addr, - uint32_t TotalBytes, - void * action); - void simulator_stop(double min); - void simulator_start(void); - void* get_action_from_socket(void *socket); - double get_remains_from_socket(void *socket); - double get_last_amount_sent_from_socket(void *socket); - void reset_last_amount_sent_from_socket(void *socket); - char get_finished(void *socket); + SgFlow(uint32_t totalBytes, simgrid::surf::NetworkNS3Action* action); + + // private: + std::uint32_t bufferedBytes_ = 0; + std::uint32_t sentBytes_ = 0; + std::uint32_t remaining_; + std::uint32_t totalBytes_; + bool finished_ = false; + simgrid::surf::NetworkNS3Action* action_; }; -#endif /* __cplusplus */ +void StartFlow(ns3::Ptr sock, const char* to, uint16_t port_number); + +static inline const char* transformSocketPtr(ns3::Ptr localSocket) +{ + static char key[24]; + std::stringstream sstream; + sstream << localSocket; + snprintf(key, 24, "%s", sstream.str().c_str()); + + return key; +} #endif