From 3e7481519e35c670cbf75320e6a1bd4485e42400 Mon Sep 17 00:00:00 2001 From: Grissess Date: Mon, 15 Jun 2015 01:37:37 -0400 Subject: Major functionality enhancements and bugfixes --- broadcast.py | 49 +++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 45 insertions(+), 4 deletions(-) (limited to 'broadcast.py') diff --git a/broadcast.py b/broadcast.py index aaf1276..7bd7bd0 100644 --- a/broadcast.py +++ b/broadcast.py @@ -4,9 +4,35 @@ import struct import time import xml.etree.ElementTree as ET import threading +import optparse from packet import Packet, CMD, itos +parser = optparse.OptionParser() +parser.add_option('-t', '--test', dest='test', action='store_true', help='Play a test tone (440, 880) on all clients in sequence (the last overlaps with the first of the next)') +parser.add_option('-q', '--quit', dest='quit', action='store_true', help='Instruct all clients to quit') +parser.add_option('-f', '--factor', dest='factor', type='int', help='Rescale time by this factor (0 2: factor = float(sys.argv[2]) @@ -19,6 +45,8 @@ s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1) clients = [] +uid_groups = {} +type_groups = {} s.sendto(str(Packet(CMD.PING)), ('255.255.255.255', PORT)) s.settimeout(0.5) @@ -37,15 +65,26 @@ for cl in clients: data, _ = s.recvfrom(4096) pkt = Packet.FromStr(data) print 'ports', pkt.data[0], - print 'type', itos(pkt.data[1]), - print 'uid', ''.join([itos(i) for i in pkt.data[2:]]).rstrip('\x00') - if sys.argv[1] == '-t': + tp = itos(pkt.data[1]) + print 'type', tp, + uid = ''.join([itos(i) for i in pkt.data[2:]]).rstrip('\x00') + print 'uid', uid + if uid == '': + uid = None + uid_groups.setdefault(uid, []).append(cl) + type_groups.setdefault(tp, []).append(cl) + if options.test: s.sendto(str(Packet(CMD.PLAY, 0, 250000, 440, 255)), cl) time.sleep(0.25) s.sendto(str(Packet(CMD.PLAY, 0, 250000, 880, 255)), cl) - if sys.argv[1] == '-q': + if options.quit: s.sendto(str(Packet(CMD.QUIT)), cl) +if options.test or options.quit: + print uid_groups + print type_groups + exit() + try: iv = ET.parse(sys.argv[1]).getroot() except IOError: @@ -53,8 +92,10 @@ except IOError: exit() notestreams = iv.findall("./streams/stream[@type='ns']") +groups = set([ns.get('group') for ns in notestreams if 'group' in ns.keys()]) print len(notestreams), 'notestreams' print len(clients), 'clients' +print len(groups), 'groups' class NSThread(threading.Thread): def run(self): -- cgit v1.2.3-70-g09d2