listen.py
来自「无线通信的主要编程软件,是无线通信工作人员的必备工具,关天相关教程我会在后续传上」· Python 代码 · 共 236 行
PY
236 行
#!/usr/bin/python#$Id: Listen.py,v 1.3 2005/09/29 02:19:14 kaminw Exp $# "Copyright (c) 2000-2003 The Regents of the University of California. # All rights reserved.## Permission to use, copy, modify, and distribute this software and its# documentation for any purpose, without fee, and without written agreement# is hereby granted, provided that the above copyright notice, the following# two paragraphs and the author appear in all copies of this software.# # IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR# DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT# OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY# OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.# # THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY# AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS# ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO# PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS."## @author Kamin Whitehouse #import sys, threading, time, osimport pytos.util.NescApp as NescAppimport pytos.util.ParseArgs as ParseArgsimport pytos.util.MessageSnooper as MessageSnooperimport pytos.util.MessageFilter as MessageFilterimport pytos.util.KeyPress as KeyPressimport pytos.Comm as Commdef noReturn(msg) : sys.stdout.write("%25s" % "(am=%3d) %s " % (msg.amType, msg.nescType)) sys.stdout.flush() def nameAndType(msg) : print "(am=%3d) %s" % (msg.amType, msg.nescType)def printNamesOnly(msg, maxLevel=3, myLevel=0) : if myLevel==0 : print "%s%s" % (printNamesOnly(msg.parentMsg, maxLevel, 1), "%25s" % "(am=%3d) %s" % (msg.amType, msg.nescType)) else : if type(maxLevel) == int and maxLevel < myLevel: return "" elif msg == None: return "%s%28s" % (printNamesOnly(msg, maxLevel, myLevel+1), "") else : return "%s%s => " % (printNamesOnly(msg.parentMsg, maxLevel, myLevel+1), "(am=%3d) %13s" % (msg.amType, msg.nescType))def printNormal(msg) : print msg def printParentNames(msg, maxLevel=3, myLevel=0) : if myLevel==0 : print "%s%s" % (printParentNames(msg.parentMsg, maxLevel, 1), str(msg)) else : if type(maxLevel) == int and maxLevel < myLevel: return "" elif msg == None: return "%s%30s" % (printParentNames(msg, maxLevel, myLevel+1), "") else : return "%s%s => " % (printParentNames(msg.parentMsg, maxLevel, myLevel+1), "(am=%3d) %15s" % (msg.amType, msg.nescType))def printParents(msg, maxLevel='all', myLevel=0) : if myLevel==0 : print "%s%s" % (printParents(msg.parentMsg, maxLevel, 1), str(msg)) else : if msg == None or (type(maxLevel) == int and maxLevel < myLevel) : return "" else: return "%s%s" % (printParents(msg.parentMsg, maxLevel, myLevel+1), str(msg))class Listen( object ) : """This application prints incoming packets to the screen. Unlike other versions of listen, this one automatically parses the byte stream. The format of the output can be modified by typing letters while the data is flowing by (similar to 'top'). For a help, type the letter 'h'. Some of the current commands are: h: toggle help q: quit c: toggle colors usage: Listen.py telosb sf@localhost:9001 """ def __init__( self , snooper ) : self.usage = """ h : help p : pause q : quit 1-9 : verbosity f : manage filters l : draw line now c : toggle colors """ print "\nType \"h\" for help\n" msgQueue = Comm.MessageQueue(10) self.keyPress = KeyPress.KeyPress() self.filter = MessageFilter.MessageFilter(app,snooper) self.filter.register(msgQueue) self.running = True self.pausing = False self.verbosity = '4' self.numLostPackets = 0 self.numPrintedChars = 0 #start a thread to process the messages (make daemon so it dies when main thread stops) self.msgThread = threading.Thread(target=self.processMessages, args=(msgQueue,)) self.msgThread.setDaemon(True) self.msgThread.start() self.readKeys() def processMessages(self, msgQueue) : while True : (addr,msg) = msgQueue.get() if self.running == True: self.printMsg(msg) else : self.numLostPackets += 1 def readKeys(self) : self.reading = True while self.reading : try : key = self.keyPress.getChar(blocking=True) { 'q': self.stopReading, #sys.exit, '': self.stopReading, #sys.exit, 'h': self.help, '1': lambda : self.setVerbosity(key), '2': lambda : self.setVerbosity(key), '3': lambda : self.setVerbosity(key), '4': lambda : self.setVerbosity(key), '5': lambda : self.setVerbosity(key), '6': lambda : self.setVerbosity(key), '7': lambda : self.setVerbosity(key), '8': lambda : self.setVerbosity(key), '9': lambda : self.setVerbosity(key), 'f': self.createFilter, 'l': self.drawLine, 'c': self.colors, 'p': self.pause }[key]() except Exception, e: if len(e.args)>0: print e.args[0] else : raise print "key %s not understood. Press \"h\" for help" % key def createFilter(self) : self.stop() self.filter.userMenu() self.start() def drawLine(self) : print " --------------- " def stopReading(self) : self.reading = False def setVerbosity(self, verbosity) : self.verbosity = verbosity print "Verbosity is now %s" % self.verbosity def printMsg(self, msg) : { '1' : noReturn, '2' : nameAndType, '3' : lambda msg: printNamesOnly(msg), '4' : printNormal, '5' : lambda msg: printParentNames(msg), '6' : lambda msg: printParents(msg,1), '7' : lambda msg: printParents(msg,2), '8' : lambda msg: printParents(msg,3), '9' : lambda msg: printParents(msg,'all') }[self.verbosity](msg) def printLostPackets(self): banner = "\nHit any key to resume. Messages lost: 0" sys.stdout.write(banner) sys.stdout.flush() self.numPrintedChars=1 while True: time.sleep(1) c= self.keyPress.getChar(blocking=False) if c == "": strg = "" for i in range(self.numPrintedChars) : strg += "\b" strg = "%s%d" % (strg,self.numLostPackets) self.numPrintedChars = len(strg)-self.numPrintedChars sys.stdout.write(strg) sys.stdout.flush() else: print break def help(self) : self.stop() print " Current verbosity: %s" % self.verbosity print self.usage self.printLostPackets() self.start() def pause(self) : self.stop() self.printLostPackets() self.start() def colors(self) : print "Sorry, no colors yet\n" def stop(self) : self.running = False self.numLostPackets = 0 self.numPrintedChars = 0 def start(self) : self.running = True if __name__ == "__main__": args = ParseArgs.ParseArgs(sys.argv) app = NescApp.NescApp(args.buildDir, args.motecom, tosbase=True, localCommOnly=True) snooper = MessageSnooper.MessageSnooper(app) listen = Listen(snooper)# os.system('reset')
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?