- virtual ~NetCard(){};
- virtual int id()=0; // Our rank in the vertices_ array of our containing AS.
- virtual char *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(const char *name, NetCard::Type componentType, AsImpl *containingAS)
- : name_(xbt_strdup(name)),
- componentType_(componentType),
- containingAS_(containingAS)
- {
- if (containingAS != nullptr)
- id_ = containingAS->addComponent(this);
- simgrid::kernel::routing::netcardCreatedCallbacks(this);
- }
- ~NetCardImpl() { xbt_free(name_);};
-
- int id() override {return id_;}
- char *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:
- int id_ = -1;
- char *name_;
- NetCard::Type componentType_;
- AsImpl *containingAS_;