Skip to content
Snippets Groups Projects
Commit 7523c420 authored by Brian O'Connor's avatar Brian O'Connor
Browse files

Merge pull request #186 from mininet/devel/clifix

Replaced nodelist and nodemap in CLI with mn
parents 6df4371d 98cb3359
No related branches found
No related tags found
No related merge requests found
......@@ -43,13 +43,8 @@ class CLI( Cmd ):
def __init__( self, mininet, stdin=sys.stdin, script=None ):
self.mn = mininet
self.nodelist = self.mn.controllers + self.mn.switches + self.mn.hosts
self.nodemap = {} # map names to Node objects
for node in self.nodelist:
self.nodemap[ node.name ] = node
# Local variable bindings for py command
self.locals = { 'net': mininet }
self.locals.update( self.nodemap )
# Attempt to handle input
self.stdin = stdin
self.inPoller = poll()
......@@ -63,7 +58,7 @@ def __init__( self, mininet, stdin=sys.stdin, script=None ):
while True:
try:
# Make sure no nodes are still waiting
for node in self.nodelist:
for node in self.mn.values():
while node.waiting:
node.sendInt()
node.monitor()
......@@ -78,6 +73,11 @@ def emptyline( self ):
"Don't repeat last command when you hit return."
pass
def getLocals( self ):
"Local variable bindings for py command"
self.locals.update( self.mn )
return self.locals
# Disable pylint "Unused argument: 'arg's'" messages, as well as
# "method could be a function" warning, since each CLI function
# must have the same interface
......@@ -110,12 +110,12 @@ def do_help( self, line ):
def do_nodes( self, _line ):
"List all nodes."
nodes = ' '.join( [ node.name for node in sorted( self.nodelist ) ] )
nodes = ' '.join( sorted( self.mn ) )
output( 'available nodes are: \n%s\n' % nodes )
def do_net( self, _line ):
"List network connections."
dumpNodeConnections( self.nodelist )
dumpNodeConnections( self.mn.values() )
def do_sh( self, line ):
"Run an external shell command"
......@@ -128,7 +128,7 @@ def do_py( self, line ):
"""Evaluate a Python expression.
Node names may be used, e.g.: py h1.cmd('ls')"""
try:
result = eval( line, globals(), self.locals )
result = eval( line, globals(), self.getLocals() )
if not result:
return
elif isinstance( result, str ):
......@@ -145,7 +145,7 @@ def do_px( self, line ):
"""Execute a Python statement.
Node names may be used, e.g.: px print h1.cmd('ls')"""
try:
exec( line, globals(), self.locals )
exec( line, globals(), self.getLocals() )
except Exception, e:
output( str( e ) + '\n' )
......@@ -176,11 +176,11 @@ def do_iperf( self, line ):
hosts = []
err = False
for arg in args:
if arg not in self.nodemap:
if arg not in self.mn:
err = True
error( "node '%s' not in network\n" % arg )
else:
hosts.append( self.nodemap[ arg ] )
hosts.append( self.mn[ arg ] )
if not err:
self.mn.iperf( hosts )
else:
......@@ -196,11 +196,11 @@ def do_iperfudp( self, line ):
hosts = []
err = False
for arg in args[ 1:3 ]:
if arg not in self.nodemap:
if arg not in self.mn:
err = True
error( "node '%s' not in network\n" % arg )
else:
hosts.append( self.nodemap[ arg ] )
hosts.append( self.mn[ arg ] )
if not err:
self.mn.iperf( hosts, l4Type='UDP', udpBw=udpBw )
else:
......@@ -209,13 +209,13 @@ def do_iperfudp( self, line ):
def do_intfs( self, _line ):
"List interfaces."
for node in self.nodelist:
for node in self.mn.values():
output( '%s: %s\n' %
( node.name, ','.join( node.intfNames() ) ) )
def do_dump( self, _line ):
"Dump node info."
for node in self.nodelist:
for node in self.mn.values():
output( '%s\n' % repr( node ) )
def do_link( self, line ):
......@@ -235,10 +235,10 @@ def do_xterm( self, line, term='xterm' ):
error( 'usage: %s node1 node2 ...\n' % term )
else:
for arg in args:
if arg not in self.nodemap:
if arg not in self.mn:
error( "node '%s' not in network\n" % arg )
else:
node = self.nodemap[ arg ]
node = self.mn[ arg ]
self.mn.terms += makeTerms( [ node ], term = term )
def do_x( self, line ):
......@@ -329,11 +329,11 @@ def default( self, line ):
args = args[ :-1 ]
rest = args.split( ' ' )
if first in self.nodemap:
node = self.nodemap[ first ]
if first in self.mn:
node = self.mn[ first ]
# Substitute IP addresses for node names in command
rest = [ self.nodemap[ arg ].defaultIntf().updateIP()
if arg in self.nodemap else arg
rest = [ self.mn[ arg ].defaultIntf().updateIP()
if arg in self.mn else arg
for arg in rest ]
rest = ' '.join( rest )
# Run cmd on node:
......
......@@ -236,7 +236,29 @@ def __getitem__( self, *args ):
def __iter__( self ):
"return iterator over nodes"
return chain( self.hosts, self.switches, self.controllers )
#or dow we want to iterate of the keys i.e. node.name like a dict
for node in chain( self.hosts, self.switches, self.controllers ):
yield node.name
def __len__( self ):
"returns number of nodes in net"
return len( self.hosts ) + len( self.switches ) + len( self.controllers )
def __contains__( self, item ):
"returns True if net contains named node"
return item in self.keys()
def keys( self ):
"return a list of all node names or net's keys"
return list( self.__iter__() )
def values( self ):
"return a list of all nodes or net's values"
return [ self[name] for name in self.__iter__() ]
def items( self ):
"return (key,value) tuple list for every node in net"
return zip( self.keys(), self.values() )
def addLink( self, node1, node2, port1=None, port2=None,
cls=None, **params ):
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment