-/* Copyright (c) 2013-2015. The SimGrid Team.
- * All rights reserved. */
+/* Copyright (c) 2013-2016. 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. */
#include <xbt/signal.hpp>
#include "surf_interface.hpp"
-#include "src/surf/xml/platf_private.hpp" // FIXME: including this here is pure madness. KILKILKIL XML.
#include "src/kernel/routing/AsImpl.hpp"
#include <float.h>
namespace routing {
XBT_PUBLIC_DATA(simgrid::xbt::signal<void(s4u::As*)>) asCreatedCallbacks;
- XBT_PUBLIC_DATA(simgrid::xbt::signal<void(NetCard*)>) netcardCreatedCallbacks;
/***********
* Classes *
class XBT_PRIVATE Onelink;
class RoutingPlatf;
-/** @ingroup SURF_routing_interface
- * @brief Network cards are the vertices in the graph representing the network, used to compute paths between nodes.
- *
- * @details This represents a position in the network. One can route information between two netcards
- */
-class NetCard {
-public:
- virtual ~NetCard() = default;
- virtual unsigned int id()=0; // Our rank in the vertices_ array of our containing AS.
- virtual std::string name() = 0;
- virtual AsImpl *containingAS()=0; // This is the AS in which I am
- virtual bool isAS()=0;
- virtual bool isHost()=0;
- virtual bool isRouter()=0;
- enum class Type {
- Host, Router, As
- };
-};
-
-struct XBT_PRIVATE NetCardImpl : public NetCard {
-public:
- NetCardImpl(std::string name, NetCard::Type componentType, AsImpl* containingAS)
- : name_(name), componentType_(componentType), containingAS_(containingAS)
- {
- if (containingAS != nullptr)
- id_ = containingAS->addComponent(this);
- simgrid::kernel::routing::netcardCreatedCallbacks(this);
- }
- ~NetCardImpl() = default;
-
- unsigned int id() override {return id_;}
- std::string name() override { return name_; }
- AsImpl *containingAS() override {return containingAS_;}
-
- bool isAS() override {return componentType_ == Type::As;}
- bool isHost() override {return componentType_ == Type::Host;}
- bool isRouter() override {return componentType_ == Type::Router;}
-
-private:
- unsigned int id_;
- std::string name_;
- NetCard::Type componentType_;
- AsImpl *containingAS_;
-};
-
class AsRoute {
public:
explicit AsRoute(NetCard* gwSrc, NetCard* gwDst) : gw_src(gwSrc), gw_dst(gwDst) {}
*/
class Onelink {
public:
- Onelink(Link* link, NetCard* src, NetCard* dst) : src_(src), dst_(dst), link_(link){};
+ Onelink(Link* link, NetCard* src, NetCard* dst) : src_(src), dst_(dst), link_(link) {}
NetCard* src_;
NetCard* dst_;
Link* link_;
};
-/** @ingroup SURF_routing_interface
- * @brief The class representing a whole routing platform
- */
-XBT_PUBLIC_CLASS RoutingPlatf {
-public:
- explicit RoutingPlatf();
- ~RoutingPlatf();
- AsImpl *root_ = nullptr;
- void getRouteAndLatency(NetCard *src, NetCard *dst, std::vector<Link*> * links, double *latency);
-};
-
}}}
#endif /* NETWORK_ROUTING_HPP_ */