# # NEPI, a framework to manage network experiments # Copyright (C) 2014 INRIA # # 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, see . # from nepi.execution.attribute import Attribute, Flags, Types from nepi.execution.trace import Trace, TraceAttr from nepi.execution.resource import ResourceManager, clsinit_copy, \ ResourceState from nepi.resources.ns3.ns3node import NS3BaseNode @clsinit_copy class NS3Node(NS3BaseNode): _rtype = "ns3::Node" @classmethod def _register_attributes(cls): attr_id = Attribute("Id", "The id (unique integer) of this Node.", type = Types.Integer, default = "0", allowed = None, range = None, flags = Flags.Reserved | Flags.NoWrite) cls._register_attribute(attr_id) attr_systemid = Attribute("SystemId", "The systemId of this node: a unique integer used for parallel simulations.", type = Types.Integer, default = "0", allowed = None, range = None, flags = Flags.Reserved) cls._register_attribute(attr_systemid) @classmethod def _register_traces(cls): pass def __init__(self, ec, guid): super(NS3Node, self).__init__(ec, guid) self._home = "ns3-node-%s" % self.guid