xbt_assert(nullptr == xbt_lib_get_or_null(as_router_lib, name, ROUTING_ASR_LEVEL),
"Refusing to create a second AS called '%s'.", name);
- netcard_ = new NetCardImpl(name, NetCard::Type::As, static_cast<AsImpl*>(father));
+ netcard_ = new NetCard(name, NetCard::Type::As, static_cast<AsImpl*>(father));
xbt_lib_set(as_router_lib, name, ROUTING_ASR_LEVEL, static_cast<void*>(netcard_));
XBT_DEBUG("AS '%s' created with the id '%d'", name, netcard_->id());
}
if (hierarchy_ == RoutingMode::unset)
hierarchy_ = RoutingMode::base;
- res->pimpl_netcard = new NetCardImpl(name, NetCard::Type::Host, this);
+ res->pimpl_netcard = new NetCard(name, NetCard::Type::Host, this);
surf_cpu_model_pm->createCpu(res, speedPerPstate, coreAmount);
"Refusing to create a router named '%s': this name already describes a node.", router->id);
simgrid::kernel::routing::NetCard* netcard =
- new simgrid::kernel::routing::NetCardImpl(router->id, simgrid::kernel::routing::NetCard::Type::Router, current_routing);
+ new simgrid::kernel::routing::NetCard(router->id, simgrid::kernel::routing::NetCard::Type::Router, current_routing);
xbt_lib_set(as_router_lib, router->id, ROUTING_ASR_LEVEL, netcard);
XBT_DEBUG("Router '%s' has the id %d", router->id, netcard->id());
*/
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 const char* cname() = 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)
+ NetCard(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;
+ ~NetCard() = default;
+
+ // Our rank in the vertices_ array of our containing AS.
+ unsigned int id() {return id_;}
+ std::string name() { return name_; }
+ const char* cname() { return name_.c_str(); }
+ // This is the AS in which I am
+ AsImpl *containingAS() {return containingAS_;}
- unsigned int id() override {return id_;}
- std::string name() override { return name_; }
- const char* cname() override { return name_.c_str(); }
- AsImpl *containingAS() override {return containingAS_;}
+ bool isAS() {return componentType_ == Type::As;}
+ bool isHost() {return componentType_ == Type::Host;}
+ bool isRouter() {return componentType_ == Type::Router;}
- 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_;