From 1e604f2408861120d8168a3f88c29f9da3ddf7df Mon Sep 17 00:00:00 2001 From: makefu Date: Tue, 19 Jul 2011 20:52:28 +0200 Subject: added initial version of cholerab-live --- cholerab/cholerab-live/README | 6 ++++ cholerab/cholerab-live/cholerab.py | 10 ++++++ cholerab/cholerab-live/view.py | 71 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 87 insertions(+) create mode 100644 cholerab/cholerab-live/README create mode 100644 cholerab/cholerab-live/cholerab.py create mode 100644 cholerab/cholerab-live/view.py (limited to 'cholerab/cholerab-live') diff --git a/cholerab/cholerab-live/README b/cholerab/cholerab-live/README new file mode 100644 index 00000000..b778b98c --- /dev/null +++ b/cholerab/cholerab-live/README @@ -0,0 +1,6 @@ + +view.py: contains view classes for cholerab +cholerab.py: main file + +start with : +python cholerab.py diff --git a/cholerab/cholerab-live/cholerab.py b/cholerab/cholerab-live/cholerab.py new file mode 100644 index 00000000..4739d9cf --- /dev/null +++ b/cholerab/cholerab-live/cholerab.py @@ -0,0 +1,10 @@ +from view import CursesView + +a = CursesView() +a.start() +a.write_char(5,5,'p') +a.write_char(6,5,'e') +a.write_char(7,5,'n') +a.write_char(8,5,'i') +a.write_char(9,5,'s') +a.join() diff --git a/cholerab/cholerab-live/view.py b/cholerab/cholerab-live/view.py new file mode 100644 index 00000000..34891e5c --- /dev/null +++ b/cholerab/cholerab-live/view.py @@ -0,0 +1,71 @@ +#!/usr/bin/python2 + +from curses import * +import socket +import threading + +class CursesView(threading.Thread): + def stop(self): + self.running = False + nocbreak(); self.scr.keypad(0); echo() + endwin() + + def run(self): + self.running = True + def try_move(x,y): + if x >= self.width: x = 0;y = y+1 + if x < 0 : x = self.width-1; y= y-1 + if y >= self.height : x = x+1;y = 0 + if y < 0 : x = x-1; y = self.height-1 + self.win.move(y,x); return x,y + + while self.running: + c = self.scr.getch() + if c == KEY_LEFT : self.x -=1 + elif c == KEY_RIGHT : self.x +=1 + elif c == KEY_UP : self.y -=1 + elif c == KEY_DOWN : self.y +=1 + elif c == ord('q') : self.stop() + else : + try: + self.win.addch(c) #TODO UTF8 here + #self.cholerab.write_char(self.x,self.y,c) + except: + pass + self.x +=1 + self.x,self.y = try_move(self.x,self.y) + self.refresh() + + def write_char(self,x,y,char): + self.win.addch(y,x,char) + self.win.move(self.y,self.x) + self.refresh() + def refresh(self): + self.scr.refresh() + self.win.refresh() + def clear(self): + pass + def write_field(self,ar): + """ + writes the whole field with given 2-dimensional array + """ + self.clear() + pass + + + def __init__(self,height=24,width=80,cholerab=None): + self.cholerab = cholerab + threading.Thread.__init__(self) + self.scr = initscr() + noecho() + cbreak() + self.scr.keypad(1) + curs_set(2) + + begin_x = 0;begin_y = 0 + self.height = height + self.width = width + self.x = 0 ; self.y = 0 + + self.win = newwin(height,width,begin_y,begin_x) + -- cgit v1.2.3 From 82fda4544b2d3a04a2c67d8af2e11ddce0c61195 Mon Sep 17 00:00:00 2001 From: makefu Date: Thu, 21 Jul 2011 00:37:13 +0200 Subject: fixed cur_set bug/added todo --- cholerab/cholerab-live/view.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'cholerab/cholerab-live') diff --git a/cholerab/cholerab-live/view.py b/cholerab/cholerab-live/view.py index 34891e5c..b798e712 100644 --- a/cholerab/cholerab-live/view.py +++ b/cholerab/cholerab-live/view.py @@ -26,6 +26,7 @@ class CursesView(threading.Thread): elif c == KEY_UP : self.y -=1 elif c == KEY_DOWN : self.y +=1 elif c == ord('q') : self.stop() + #TODO handle backspace correctly else : try: self.win.addch(c) #TODO UTF8 here @@ -57,10 +58,13 @@ class CursesView(threading.Thread): self.cholerab = cholerab threading.Thread.__init__(self) self.scr = initscr() - noecho() + noecho() cbreak() self.scr.keypad(1) - curs_set(2) + try: + curs_set(2) + except: # go home with your non-standard terminals! + pass begin_x = 0;begin_y = 0 self.height = height -- cgit v1.2.3 From 531d9d4309fa09e893a19fdcf8165dc7bf1b3731 Mon Sep 17 00:00:00 2001 From: makefu Date: Sun, 24 Jul 2011 02:41:13 +0200 Subject: added curses stuff cholerab-live/view.py: now able to write basic utf-8 on the plane, handles some rudimentary colors handles backspace correctly --- cholerab/cholerab-live/cholerab.py | 31 +++++--- cholerab/cholerab-live/here.log | 149 +++++++++++++++++++++++++++++++++++++ cholerab/cholerab-live/view.py | 142 ++++++++++++++++++++--------------- cholerab/cholerab-live/view.pyc | Bin 0 -> 3949 bytes 4 files changed, 253 insertions(+), 69 deletions(-) mode change 100644 => 100755 cholerab/cholerab-live/cholerab.py create mode 100644 cholerab/cholerab-live/here.log create mode 100644 cholerab/cholerab-live/view.pyc (limited to 'cholerab/cholerab-live') diff --git a/cholerab/cholerab-live/cholerab.py b/cholerab/cholerab-live/cholerab.py old mode 100644 new mode 100755 index 4739d9cf..0ac44e09 --- a/cholerab/cholerab-live/cholerab.py +++ b/cholerab/cholerab-live/cholerab.py @@ -1,10 +1,23 @@ +#!/usr/bin/python2 +# -*- coding: utf-8 -*- +import curses,time from view import CursesView - -a = CursesView() -a.start() -a.write_char(5,5,'p') -a.write_char(6,5,'e') -a.write_char(7,5,'n') -a.write_char(8,5,'i') -a.write_char(9,5,'s') -a.join() +import logging +logging.basicConfig(filename='here.log',level=logging.DEBUG) +log = logging.getLogger('main') +def main(scr): + log.debug('started main') + a = CursesView(scr=scr) + a.start() + log.debug + a.write_char(5,5,'p') + a.write_char(6,5,'e') + a.write_char(7,5,'n') + a.write_char(8,5,'i') + a.write_char(9,5,'s') + a.write_str(5,6,'¯\(°_o)/¯',user=2) + for i in range(7,11): + time.sleep(2) + a.write_str(5,i,'¯\(°_o)/¯',user=3) + a.join() +curses.wrapper(main) diff --git a/cholerab/cholerab-live/here.log b/cholerab/cholerab-live/here.log new file mode 100644 index 00000000..80e02d4c --- /dev/null +++ b/cholerab/cholerab-live/here.log @@ -0,0 +1,149 @@ +DEBUG:main:started main +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:127 +DEBUG:cholerab-curses:113 +DEBUG:main:started main +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:100 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:100 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:100 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:113 +DEBUG:main:started main +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:260 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:259 +DEBUG:cholerab-curses:259 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:113 diff --git a/cholerab/cholerab-live/view.py b/cholerab/cholerab-live/view.py index b798e712..fe90b926 100644 --- a/cholerab/cholerab-live/view.py +++ b/cholerab/cholerab-live/view.py @@ -3,73 +3,95 @@ from curses import * import socket import threading +import logging +log = logging.getLogger('cholerab-curses') class CursesView(threading.Thread): - def stop(self): - self.running = False - nocbreak(); self.scr.keypad(0); echo() - endwin() + def stop(self): + self.running = False + nocbreak(); self.scr.keypad(0); echo() + endwin() - def run(self): - self.running = True - def try_move(x,y): - if x >= self.width: x = 0;y = y+1 - if x < 0 : x = self.width-1; y= y-1 - if y >= self.height : x = x+1;y = 0 - if y < 0 : x = x-1; y = self.height-1 - self.win.move(y,x); return x,y + def run(self): + """ + input loop - while self.running: - c = self.scr.getch() - if c == KEY_LEFT : self.x -=1 - elif c == KEY_RIGHT : self.x +=1 - elif c == KEY_UP : self.y -=1 - elif c == KEY_DOWN : self.y +=1 - elif c == ord('q') : self.stop() - #TODO handle backspace correctly - else : - try: - self.win.addch(c) #TODO UTF8 here - #self.cholerab.write_char(self.x,self.y,c) - except: - pass - self.x +=1 - self.x,self.y = try_move(self.x,self.y) - self.refresh() + TODO add Unicode Input Support + """ + self.running = True + def try_move(x,y): + if x >= self.width: x = 0;y = y+1 + if x < 0 : x = self.width-1; y= y-1 + if y >= self.height : x = x+1;y = 0 + if y < 0 : x = x-1; y = self.height-1 + self.win.move(y,x); return x,y - def write_char(self,x,y,char): - self.win.addch(y,x,char) - self.win.move(self.y,self.x) - self.refresh() - def refresh(self): - self.scr.refresh() - self.win.refresh() - def clear(self): - pass - def write_field(self,ar): - """ - writes the whole field with given 2-dimensional array - """ - self.clear() - pass + while self.running: + c = self.scr.getch() #get_char(self.scr) + log.debug(str(c)) + if c == KEY_LEFT : self.x -=1 + elif c == KEY_RIGHT : self.x +=1 + elif c == KEY_UP : self.y -=1 + elif c == KEY_DOWN : self.y +=1 + elif c == ord('q') : self.stop() + elif c == 127: + log.info('backspace pressed') + self.x -=1; + self.x,self.y = try_move(self.x,self.y) + self.win.addch(' ') + #TODO handle backspace correctly + else : + try: + self.win.addch(c) #TODO UTF8 here + #self.cholerab.write_char(self.x,self.y,c) + except: + pass + self.x +=1 + self.x,self.y = try_move(self.x,self.y) + self.refresh() - def __init__(self,height=24,width=80,cholerab=None): - self.cholerab = cholerab - threading.Thread.__init__(self) - self.scr = initscr() - noecho() - cbreak() - self.scr.keypad(1) - try: - curs_set(2) - except: # go home with your non-standard terminals! - pass + def write_char(self,x,y,char): + self.win.addch(y,x,char) + self.win.move(self.y,self.x) + self.refresh() + def write_str(self,x,y,string,user=1): + self.win.addstr(y,x,string,color_pair(user)) + self.win.move(self.y,self.x) + self.refresh() + def refresh(self): + self.scr.refresh() + self.win.refresh() + def clear(self): + pass + def write_field(self,ar): + """ + writes the whole field with given 2-dimensional array + """ + self.clear() + pass - begin_x = 0;begin_y = 0 - self.height = height - self.width = width - self.x = 0 ; self.y = 0 - self.win = newwin(height,width,begin_y,begin_x) + def __init__(self,height=24,width=80,cholerab=None,scr=None): + init_pair(1,COLOR_WHITE,COLOR_BLACK) + init_pair(2,COLOR_RED,COLOR_BLACK) + init_pair(3,COLOR_GREEN,COLOR_BLACK) + self.cholerab = cholerab + threading.Thread.__init__(self) + if scr: + self.scr = scr + else: + self.scr = initscr() + noecho() + cbreak() + self.scr.keypad(1) + try: curs_set(2) + except: pass # go home with your non-standard terminals! + + begin_x = 0;begin_y = 0 + self.height = height + self.width = width + self.x = 0 ; self.y = 0 + + self.win = newwin(height,width,begin_y,begin_x) diff --git a/cholerab/cholerab-live/view.pyc b/cholerab/cholerab-live/view.pyc new file mode 100644 index 00000000..5516ae2f Binary files /dev/null and b/cholerab/cholerab-live/view.pyc differ -- cgit v1.2.3 From f1f12489514f47f9154f8e4b6232399e747cfcd8 Mon Sep 17 00:00:00 2001 From: makefu Date: Sun, 24 Jul 2011 04:13:44 +0200 Subject: emergency commit --- cholerab/cholerab-live/chol_net.py | 81 +++ cholerab/cholerab-live/chol_net.pyc | Bin 0 -> 4364 bytes cholerab/cholerab-live/cholerab.py | 43 +- cholerab/cholerab-live/here.log | 1296 +++++++++++++++++++++++++++++++++++ cholerab/cholerab-live/view.py | 42 +- cholerab/cholerab-live/view.pyc | Bin 3949 -> 4409 bytes 6 files changed, 1431 insertions(+), 31 deletions(-) create mode 100644 cholerab/cholerab-live/chol_net.py create mode 100644 cholerab/cholerab-live/chol_net.pyc (limited to 'cholerab/cholerab-live') diff --git a/cholerab/cholerab-live/chol_net.py b/cholerab/cholerab-live/chol_net.py new file mode 100644 index 00000000..b5820973 --- /dev/null +++ b/cholerab/cholerab-live/chol_net.py @@ -0,0 +1,81 @@ +from socket import socket, AF_INET,SOCK_DGRAM,IPPROTO_UDP,SOL_SOCKET,SO_REUSEADDR,IP_MULTICAST_TTL,IP_MULTICAST_LOOP,INADDR_ANY,inet_aton,IP_ADD_MEMBERSHIP,IPPROTO_IP +import struct +import threading +import logging +log = None +from select import select +GROUP = '224.110.42.23' +PORT = 42023 +log = logging.getLogger('CholerabNet') +class CholerabMulicastNet(threading.Thread): + def __init__(self,cholerab,group=GROUP,port=PORT): + threading.Thread.__init__(self) + self.cholerab=cholerab + self.group=group + self.port=port + self.initSocket() + def send_char(self,x,y,char): + """ translates given params into network message """ + self.send_mc("%s %d %d" %(str(char),x,y)) + def send_mc(self,arg): + """ Sends message via multicast""" + + try: + log.debug("Sending '%s' to %s:%d" % (arg,self.group,self.port)) + self.s.sendto("%s" % arg,0,(self.group,self.port)) + except Exception ,e: + log.error("IN send_mc:%s"%str(e)) + + def initSocket (self,rcv=1): + ''' Initializes a Multicast socket ''' + host = '' + log.debug("Setting up Multicast Socket") + self.s = socket(AF_INET,SOCK_DGRAM, IPPROTO_UDP) + self.s.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1) + self.s.setsockopt(IPPROTO_IP, IP_MULTICAST_TTL, 32) + self.s.setsockopt(IPPROTO_IP,IP_MULTICAST_LOOP,1) # we do not want our own packets to be replayed + if rcv==1: + log.debug("Configuring for Read AND Write") + self.s.bind((host,PORT)) + mreq = struct.pack("4sl", inet_aton(GROUP), INADDR_ANY) + self.s.setsockopt(IPPROTO_IP,IP_ADD_MEMBERSHIP,mreq) + def run(self): + self.running = 1 + while self.running: + # break if we do not want to loop on + ready,output,exception = select([self.s],[],[],1) # try every second + for r in ready: + if r == self.s: + (data,addr) = self.s.recvfrom(1024) + log.debug("Received Data from %s, data %s"%(str(addr),str(data))) + self.receive_net(addr,data) + + def send_stupid(self,addr): + """ sends YOU ARE MADE OF STUPID to the right host """ + #TODO implement me + pass + + def receive_net(self,addr,data): + """ resolves which nick sent the message + TODO handle user resolution in mulicast """ + def decode(): + pass #TODO implement me + + #FIXME TODO using port as host identification is probably just plain wrong, fix me for real net! + try: + address,port = addr + user = port + arr = str(data).split() + char = arr[0] + x = arr[1] + y = arr[2] + self.cholerab.write_char(int(x),int(y),char,user) + except Exception, e: + log.error("Triggered YOU ARE MADE OF STUPID: %s" % str(e)) + self.send_stupid(addr) + + def stop(self): + ''' + stops the whole treading stuff gracefully + ''' + self.running=0 diff --git a/cholerab/cholerab-live/chol_net.pyc b/cholerab/cholerab-live/chol_net.pyc new file mode 100644 index 00000000..573bc413 Binary files /dev/null and b/cholerab/cholerab-live/chol_net.pyc differ diff --git a/cholerab/cholerab-live/cholerab.py b/cholerab/cholerab-live/cholerab.py index 0ac44e09..b6b3f84f 100755 --- a/cholerab/cholerab-live/cholerab.py +++ b/cholerab/cholerab-live/cholerab.py @@ -2,22 +2,35 @@ # -*- coding: utf-8 -*- import curses,time from view import CursesView +from chol_net import CholerabMulicastNet import logging logging.basicConfig(filename='here.log',level=logging.DEBUG) log = logging.getLogger('main') -def main(scr): +class Cholerab: + def __init__(self): + self.view = CursesView(cholerab=self) + self.transport = CholerabMulicastNet(cholerab=self) + def send_char(self,x,y,char): + log.info("Sending %s at (%d,%d) to connected peers" %(char,x,y)) + self.transport.send_char(x,y,char) + + def write_char(self,x,y,char,user): + log.info("Writing %s at (%d,%d) from %d to view" %(char,x,y,user)) + self.view.write_char(x,y,char,user) + def stop(self): + self.view.stop() + self.transport.stop() + def main(self): + self.view.start() + self.transport.start() + self.view.join() + #after view dies, kill the transport as well + self.transport.stop() + self.transport.join() +def main(): log.debug('started main') - a = CursesView(scr=scr) - a.start() - log.debug - a.write_char(5,5,'p') - a.write_char(6,5,'e') - a.write_char(7,5,'n') - a.write_char(8,5,'i') - a.write_char(9,5,'s') - a.write_str(5,6,'¯\(°_o)/¯',user=2) - for i in range(7,11): - time.sleep(2) - a.write_str(5,i,'¯\(°_o)/¯',user=3) - a.join() -curses.wrapper(main) + chol = Cholerab() + chol.main() + +if __name__ == "__main__": + main() diff --git a/cholerab/cholerab-live/here.log b/cholerab/cholerab-live/here.log index 80e02d4c..bc128175 100644 --- a/cholerab/cholerab-live/here.log +++ b/cholerab/cholerab-live/here.log @@ -147,3 +147,1299 @@ DEBUG:cholerab-curses:261 DEBUG:cholerab-curses:261 DEBUG:cholerab-curses:261 DEBUG:cholerab-curses:113 +DEBUG:main:started main +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:259 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:261 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:118 +DEBUG:cholerab-curses:120 +DEBUG:cholerab-curses:106 +DEBUG:cholerab-curses:108 +DEBUG:cholerab-curses:107 +DEBUG:cholerab-curses:106 +DEBUG:cholerab-curses:100 +DEBUG:cholerab-curses:102 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:115 +DEBUG:cholerab-curses:258 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:97 +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:127 +INFO:cholerab-curses:backspace pressed +DEBUG:cholerab-curses:113 +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +INFO:main:Sending 97 at (2,1) to connected peers +INFO:main:Sending 115 at (3,1) to connected peers +INFO:main:Sending 100 at (4,1) to connected peers +INFO:main:Sending 100 at (5,1) to connected peers +INFO:main:Sending 97 at (6,1) to connected peers +INFO:main:Sending 115 at (7,1) to connected peers +INFO:main:Sending 115 at (8,1) to connected peers +INFO:main:Sending 100 at (9,1) to connected peers +DEBUG:main:started main +INFO:main:Sending a at (6,4) to connected peers +INFO:main:Sending a at (8,4) to connected peers +INFO:main:Sending s at (9,5) to connected peers +INFO:main:Sending d at (10,6) to connected peers +INFO:main:Sending f at (11,6) to connected peers +INFO:main:Sending d at (12,6) to connected peers +DEBUG:main:started main +INFO:main:Sending a at (5,4) to connected peers +INFO:main:Sending a at (6,4) to connected peers +INFO:main:Sending s at (7,4) to connected peers +INFO:main:Sending d at (8,4) to connected peers +INFO:main:Sending s at (9,4) to connected peers +INFO:main:Sending f at (10,4) to connected peers +INFO:main:Sending d at (11,4) to connected peers +INFO:main:Sending a at (12,4) to connected peers +INFO:main:Sending d at (13,4) to connected peers +INFO:main:Sending f at (14,4) to connected peers +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +DEBUG:main:started main +INFO:main:Sending a at (5,5) to connected peers +INFO:main:Sending a at (6,5) to connected peers +INFO:main:Sending a at (7,5) to connected peers +INFO:main:Sending a at (8,5) to connected peers +INFO:main:Sending a at (9,5) to connected peers +INFO:main:Sending a at (10,5) to connected peers +INFO:main:Sending a at (11,5) to connected peers +INFO:main:Sending a at (12,5) to connected peers +INFO:main:Sending a at (13,5) to connected peers +INFO:main:Sending a at (14,5) to connected peers +INFO:main:Sending a at (15,5) to connected peers +INFO:main:Sending a at (16,5) to connected peers +INFO:main:Sending a at (17,5) to connected peers +INFO:main:Sending a at (18,5) to connected peers +INFO:main:Sending a at (19,5) to connected peers +INFO:main:Sending a at (20,5) to connected peers +INFO:main:Sending a at (21,5) to connected peers +INFO:main:Sending a at (22,5) to connected peers +INFO:main:Sending a at (23,5) to connected peers +INFO:main:Sending a at (24,5) to connected peers +INFO:main:Sending a at (25,5) to connected peers +INFO:main:Sending a at (26,5) to connected peers +INFO:main:Sending a at (27,5) to connected peers +INFO:main:Sending a at (28,5) to connected peers +INFO:main:Sending a at (29,5) to connected peers +INFO:main:Sending a at (30,5) to connected peers +INFO:main:Sending a at (31,5) to connected peers +INFO:main:Sending a at (32,5) to connected peers +INFO:main:Sending a at (33,5) to connected peers +INFO:main:Sending a at (34,5) to connected peers +INFO:main:Sending a at (35,5) to connected peers +INFO:main:Sending a at (36,5) to connected peers +INFO:main:Sending a at (37,5) to connected peers +INFO:main:Sending a at (38,5) to connected peers +INFO:main:Sending a at (39,5) to connected peers +INFO:main:Sending a at (40,5) to connected peers +INFO:main:Sending a at (41,5) to connected peers +INFO:main:Sending a at (42,5) to connected peers +INFO:main:Sending a at (43,5) to connected peers +INFO:main:Sending a at (44,5) to connected peers +INFO:main:Sending a at (45,5) to connected peers +INFO:main:Sending a at (46,5) to connected peers +INFO:main:Sending a at (47,5) to connected peers +INFO:main:Sending a at (48,5) to connected peers +INFO:main:Sending a at (49,5) to connected peers +INFO:main:Sending a at (50,5) to connected peers +INFO:main:Sending a at (51,5) to connected peers +INFO:main:Sending a at (52,5) to connected peers +INFO:main:Sending a at (53,5) to connected peers +INFO:main:Sending a at (54,5) to connected peers +INFO:main:Sending a at (55,5) to connected peers +INFO:main:Sending a at (56,5) to connected peers +INFO:main:Sending a at (57,5) to connected peers +INFO:main:Sending a at (58,5) to connected peers +INFO:main:Sending a at (59,5) to connected peers +INFO:main:Sending a at (60,5) to connected peers +INFO:main:Sending a at (61,5) to connected peers +INFO:main:Sending a at (62,5) to connected peers +INFO:main:Sending a at (63,5) to connected peers +INFO:main:Sending a at (64,5) to connected peers +INFO:main:Sending a at (65,5) to connected peers +INFO:main:Sending a at (66,5) to connected peers +INFO:main:Sending a at (67,5) to connected peers +INFO:main:Sending a at (68,5) to connected peers +DEBUG:main:started main +INFO:main:Sending a at (7,7) to connected peers +INFO:main:Sending a at (8,7) to connected peers +INFO:main:Sending a at (9,7) to connected peers +INFO:main:Sending a at (10,7) to connected peers +INFO:main:Sending a at (11,7) to connected peers +INFO:main:Sending a at (12,7) to connected peers +INFO:main:Sending a at (13,7) to connected peers +INFO:main:Sending a at (14,7) to connected peers +INFO:main:Sending a at (15,7) to connected peers +INFO:main:Sending a at (16,7) to connected peers +INFO:main:Sending a at (17,7) to connected peers +INFO:main:Sending a at (18,7) to connected peers +INFO:main:Sending a at (19,7) to connected peers +INFO:main:Sending a at (20,7) to connected peers +INFO:main:Sending a at (21,7) to connected peers +INFO:main:Sending a at (22,7) to connected peers +INFO:main:Sending a at (23,7) to connected peers +INFO:main:Sending a at (24,7) to connected peers +INFO:main:Sending a at (25,7) to connected peers +INFO:main:Sending d at (26,7) to connected peers +INFO:main:Sending d at (27,7) to connected peers +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:cholerab-curses:backspace pressed +INFO:main:Sending d at (6,11) to connected peers +INFO:main:Sending s at (7,11) to connected peers +INFO:main:Sending f at (8,10) to connected peers +INFO:main:Sending s at (10,10) to connected peers +INFO:main:Sending d at (11,10) to connected peers +INFO:main:Sending f at (13,10) to connected peers +INFO:main:Sending d at (14,9) to connected peers +INFO:main:Sending s at (15,9) to connected peers +INFO:main:Sending s at (17,8) to connected peers +INFO:main:Sending f at (18,8) to connected peers +INFO:main:Sending d at (19,8) to connected peers +INFO:main:Sending s at (20,8) to connected peers +INFO:main:Sending f at (22,8) to connected peers +INFO:main:Sending s at (23,7) to connected peers +INFO:main:Sending d at (25,7) to connected peers +INFO:main:Sending s at (27,6) to connected peers +INFO:main:Sending d at (28,6) to connected peers +INFO:main:Sending d at (29,5) to connected peers +INFO:main:Sending s at (31,4) to connected peers +INFO:main:Sending f at (32,4) to connected peers +INFO:main:Sending d at (34,3) to connected peers +INFO:main:Sending s at (35,3) to connected peers +INFO:main:Sending d at (38,2) to connected peers +INFO:main:Sending s at (39,2) to connected peers +INFO:main:Sending f at (40,2) to connected peers +INFO:main:Sending f at (41,2) to connected peers +INFO:main:Sending d at (44,0) to connected peers +INFO:main:Sending s at (45,0) to connected peers +INFO:main:Sending f at (46,0) to connected peers +INFO:main:Sending d at (47,23) to connected peers +INFO:main:Sending d at (49,22) to connected peers +INFO:main:Sending s at (50,22) to connected peers +INFO:main:Sending f at (51,22) to connected peers +INFO:main:Sending d at (53,21) to connected peers +INFO:main:Sending s at (54,21) to connected peers +INFO:main:Sending d at (56,20) to connected peers +INFO:main:Sending s at (57,20) to connected peers +INFO:main:Sending f at (58,20) to connected peers +INFO:main:Sending d at (60,19) to connected peers +INFO:main:Sending s at (61,19) to connected peers +INFO:main:Sending f at (62,19) to connected peers +INFO:main:Sending f at (64,18) to connected peers +INFO:main:Sending s at (65,18) to connected peers +INFO:main:Sending d at (66,18) to connected peers +INFO:main:Sending s at (68,17) to connected peers +INFO:main:Sending f at (69,17) to connected peers +INFO:main:Sending d at (70,17) to connected peers +INFO:main:Sending s at (72,16) to connected peers +INFO:main:Sending d at (73,16) to connected peers +INFO:main:Sending f at (74,16) to connected peers +INFO:main:Sending s at (76,16) to connected peers +INFO:main:Sending f at (78,15) to connected peers +INFO:main:Sending s at (0,15) to connected peers +INFO:main:Sending f at (1,15) to connected peers +INFO:main:Sending f at (3,14) to connected peers +INFO:main:Sending s at (4,14) to connected peers +INFO:main:Sending d at (5,14) to connected peers +INFO:main:Sending s at (7,13) to connected peers +INFO:main:Sending d at (8,13) to connected peers +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (1,1) to connected peers +INFO:main:Sending a at (2,1) to connected peers +INFO:main:Sending d at (4,1) to connected peers +INFO:main:Sending s at (5,1) to connected peers +INFO:main:Sending f at (6,1) to connected peers +INFO:main:Sending a at (7,1) to connected peers +INFO:main:Sending a at (8,1) to connected peers +INFO:main:Sending a at (9,1) to connected peers +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (10,1) to connected peers +INFO:main:Sending a at (0,0) to connected peers +INFO:main:Sending s at (1,0) to connected peers +INFO:main:Sending s at (2,0) to connected peers +INFO:main:Sending d at (3,0) to connected peers +INFO:main:Sending a at (4,0) to connected peers +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (11,1) to connected peers +INFO:main:Sending a at (12,1) to connected peers +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +INFO:main:Sending s at (1,0) to connected peers +INFO:main:Sending d at (2,0) to connected peers +INFO:main:Sending a at (13,1) to connected peers +INFO:main:Sending a at (14,1) to connected peers +INFO:main:Sending a at (15,1) to connected peers +INFO:main:Sending s at (16,1) to connected peers +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +INFO:main:Sending s at (1,0) to connected peers +INFO:main:Sending a at (3,0) to connected peers +INFO:main:Sending s at (4,0) to connected peers +INFO:main:Sending s at (5,0) to connected peers +INFO:main:Sending d at (6,0) to connected peers +INFO:main:Sending s at (7,0) to connected peers +INFO:main:Sending a at (8,4) to connected peers +INFO:main:Sending s at (9,4) to connected peers +INFO:main:Sending d at (10,4) to connected peers +INFO:main:Sending s at (11,4) to connected peers +INFO:main:Sending d at (12,4) to connected peers +INFO:main:Sending a at (2,0) to connected peers +INFO:main:Sending s at (3,0) to connected peers +INFO:main:Sending s at (4,0) to connected peers +INFO:main:Sending a at (13,4) to connected peers +INFO:main:Sending a at (14,4) to connected peers +INFO:main:Sending a at (15,4) to connected peers +INFO:main:Sending s at (16,4) to connected peers +INFO:main:Sending d at (17,4) to connected peers +INFO:main:Sending a at (18,4) to connected peers +INFO:main:Sending s at (19,4) to connected peers +INFO:main:Sending d at (20,4) to connected peers +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending s at (0,0) to connected peers +INFO:main:Sending a at (1,0) to connected peers +INFO:main:Sending d at (2,0) to connected peers +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +INFO:main:Sending a at (1,3) to connected peers +DEBUG:CholerabNet:Sending 'a 1 3' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 1 3 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 1 3 +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +INFO:main:Sending s at (4,1) to connected peers +DEBUG:CholerabNet:Sending 's 4 1' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 4 1 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 4 1 +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: %d format: a number is required, not str +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: %d format: a number is required, not str +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: %d format: a number is required, not str +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: not enough arguments for format string +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +INFO:main:Writing a at (0,0) from 42023 to view +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: %d format: a number is required, not str +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: write_char() takes exactly 4 arguments (5 given) +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (0,0) to connected peers +DEBUG:CholerabNet:Sending 'a 0 0' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +ERROR:CholerabNet:Triggered YOU ARE MADE OF STUPID: %d format: a number is required, not str +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 0 0 +INFO:main:Writing a at (0,0) from 42023 to view +DEBUG:main:started main +DEBUG:CholerabNet:Setting up Multicast Socket +DEBUG:CholerabNet:Configuring for Read AND Write +INFO:main:Sending a at (3,3) to connected peers +DEBUG:CholerabNet:Sending 'a 3 3' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 3 3 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 3 3 +INFO:main:Writing a at (3,3) from 42023 to view +INFO:main:Writing a at (3,3) from 42023 to view +INFO:main:Sending a at (4,4) to connected peers +DEBUG:CholerabNet:Sending 'a 4 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 4 4 +INFO:main:Writing a at (4,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 4 4 +INFO:main:Writing a at (4,4) from 42023 to view +INFO:main:Sending d at (5,4) to connected peers +DEBUG:CholerabNet:Sending 'd 5 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 5 4 +INFO:main:Writing d at (5,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 5 4 +INFO:main:Writing d at (5,4) from 42023 to view +INFO:main:Sending f at (6,4) to connected peers +DEBUG:CholerabNet:Sending 'f 6 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 6 4 +INFO:main:Writing f at (6,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 6 4 +INFO:main:Writing f at (6,4) from 42023 to view +INFO:main:Sending j at (7,4) to connected peers +DEBUG:CholerabNet:Sending 'j 7 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data j 7 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data j 7 4 +INFO:main:Writing j at (7,4) from 42023 to view +INFO:main:Writing j at (7,4) from 42023 to view +INFO:main:Sending l at (8,4) to connected peers +DEBUG:CholerabNet:Sending 'l 8 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data l 8 4 +INFO:main:Writing l at (8,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data l 8 4 +INFO:main:Writing l at (8,4) from 42023 to view +INFO:main:Sending s at (9,4) to connected peers +DEBUG:CholerabNet:Sending 's 9 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 9 4 +INFO:main:Writing s at (9,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 9 4 +INFO:main:Writing s at (9,4) from 42023 to view +INFO:main:Sending k at (10,4) to connected peers +DEBUG:CholerabNet:Sending 'k 10 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data k 10 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data k 10 4 +INFO:main:Writing k at (10,4) from 42023 to view +INFO:main:Writing k at (10,4) from 42023 to view +INFO:main:Sending a at (2,2) to connected peers +DEBUG:CholerabNet:Sending 'a 2 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 2 2 +INFO:main:Writing a at (2,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 2 2 +INFO:main:Writing a at (2,2) from 42023 to view +INFO:main:Sending d at (3,2) to connected peers +DEBUG:CholerabNet:Sending 'd 3 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 3 2 +INFO:main:Writing d at (3,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 3 2 +INFO:main:Writing d at (3,2) from 42023 to view +INFO:main:Sending s at (4,2) to connected peers +DEBUG:CholerabNet:Sending 's 4 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 4 2 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 4 2 +INFO:main:Writing s at (4,2) from 42023 to view +INFO:main:Writing s at (4,2) from 42023 to view +INFO:main:Sending f at (5,2) to connected peers +DEBUG:CholerabNet:Sending 'f 5 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 5 2 +INFO:main:Writing f at (5,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 5 2 +INFO:main:Writing f at (5,2) from 42023 to view +INFO:main:Sending d at (6,2) to connected peers +DEBUG:CholerabNet:Sending 'd 6 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 6 2 +INFO:main:Writing d at (6,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 6 2 +INFO:main:Writing d at (6,2) from 42023 to view +INFO:main:Sending s at (7,2) to connected peers +DEBUG:CholerabNet:Sending 's 7 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 7 2 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 7 2 +INFO:main:Writing s at (7,2) from 42023 to view +INFO:main:Writing s at (7,2) from 42023 to view +INFO:main:Sending a at (8,2) to connected peers +DEBUG:CholerabNet:Sending 'a 8 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 8 2 +INFO:main:Writing a at (8,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 8 2 +INFO:main:Writing a at (8,2) from 42023 to view +INFO:main:Sending s at (9,2) to connected peers +DEBUG:CholerabNet:Sending 's 9 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 9 2 +INFO:main:Writing s at (9,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 9 2 +INFO:main:Writing s at (9,2) from 42023 to view +INFO:main:Sending d at (10,2) to connected peers +DEBUG:CholerabNet:Sending 'd 10 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 10 2 +INFO:main:Writing d at (10,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 10 2 +INFO:main:Writing d at (10,2) from 42023 to view +INFO:main:Sending s at (11,2) to connected peers +DEBUG:CholerabNet:Sending 's 11 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 11 2 +INFO:main:Writing s at (11,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 11 2 +INFO:main:Writing s at (11,2) from 42023 to view +INFO:main:Sending f at (12,2) to connected peers +DEBUG:CholerabNet:Sending 'f 12 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 12 2 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 12 2 +INFO:main:Writing f at (12,2) from 42023 to view +INFO:main:Writing f at (12,2) from 42023 to view +INFO:main:Sending s at (13,2) to connected peers +DEBUG:CholerabNet:Sending 's 13 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 13 2 +INFO:main:Writing s at (13,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 13 2 +INFO:main:Writing s at (13,2) from 42023 to view +INFO:main:Sending f at (14,2) to connected peers +DEBUG:CholerabNet:Sending 'f 14 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 14 2 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 14 2 +INFO:main:Writing f at (14,2) from 42023 to view +INFO:main:Writing f at (14,2) from 42023 to view +INFO:main:Sending s at (15,2) to connected peers +DEBUG:CholerabNet:Sending 's 15 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 15 2 +INFO:main:Writing s at (15,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 15 2 +INFO:main:Writing s at (15,2) from 42023 to view +INFO:main:Sending d at (16,2) to connected peers +DEBUG:CholerabNet:Sending 'd 16 2' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 16 2 +INFO:main:Writing d at (16,2) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 16 2 +INFO:main:Writing d at (16,2) from 42023 to view +INFO:main:Sending s at (11,4) to connected peers +DEBUG:CholerabNet:Sending 's 11 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 11 4 +INFO:main:Writing s at (11,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 11 4 +INFO:main:Writing s at (11,4) from 42023 to view +INFO:main:Sending a at (12,4) to connected peers +DEBUG:CholerabNet:Sending 'a 12 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 12 4 +INFO:main:Writing a at (12,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 12 4 +INFO:main:Writing a at (12,4) from 42023 to view +INFO:main:Sending f at (13,4) to connected peers +DEBUG:CholerabNet:Sending 'f 13 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 13 4 +INFO:main:Writing f at (13,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 13 4 +INFO:main:Writing f at (13,4) from 42023 to view +INFO:main:Sending d at (14,4) to connected peers +DEBUG:CholerabNet:Sending 'd 14 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 14 4 +INFO:main:Writing d at (14,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 14 4 +INFO:main:Writing d at (14,4) from 42023 to view +INFO:main:Sending s at (15,4) to connected peers +DEBUG:CholerabNet:Sending 's 15 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 15 4 +INFO:main:Writing s at (15,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 15 4 +INFO:main:Writing s at (15,4) from 42023 to view +INFO:main:Sending a at (16,4) to connected peers +DEBUG:CholerabNet:Sending 'a 16 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 16 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data a 16 4 +INFO:main:Writing a at (16,4) from 42023 to view +INFO:main:Writing a at (16,4) from 42023 to view +INFO:main:Sending s at (17,4) to connected peers +DEBUG:CholerabNet:Sending 's 17 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 17 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 17 4 +INFO:main:Writing s at (17,4) from 42023 to view +INFO:main:Writing s at (17,4) from 42023 to view +INFO:main:Sending f at (18,4) to connected peers +DEBUG:CholerabNet:Sending 'f 18 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 18 4 +INFO:main:Writing f at (18,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 18 4 +INFO:main:Writing f at (18,4) from 42023 to view +INFO:main:Sending d at (19,4) to connected peers +DEBUG:CholerabNet:Sending 'd 19 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 19 4 +INFO:main:Writing d at (19,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 19 4 +INFO:main:Writing d at (19,4) from 42023 to view +INFO:main:Sending d at (20,4) to connected peers +DEBUG:CholerabNet:Sending 'd 20 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 20 4 +INFO:main:Writing d at (20,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 20 4 +INFO:main:Writing d at (20,4) from 42023 to view +INFO:main:Sending s at (21,4) to connected peers +DEBUG:CholerabNet:Sending 's 21 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 21 4 +INFO:main:Writing s at (21,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 21 4 +INFO:main:Writing s at (21,4) from 42023 to view +INFO:main:Sending k at (22,4) to connected peers +DEBUG:CholerabNet:Sending 'k 22 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data k 22 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data k 22 4 +INFO:main:Writing k at (22,4) from 42023 to view +INFO:main:Writing k at (22,4) from 42023 to view +INFO:main:Sending f at (23,4) to connected peers +DEBUG:CholerabNet:Sending 'f 23 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 23 4 +INFO:main:Writing f at (23,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 23 4 +INFO:main:Writing f at (23,4) from 42023 to view +INFO:main:Sending j at (24,4) to connected peers +DEBUG:CholerabNet:Sending 'j 24 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data j 24 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data j 24 4 +INFO:main:Writing j at (24,4) from 42023 to view +INFO:main:Writing j at (24,4) from 42023 to view +INFO:main:Sending s at (25,4) to connected peers +DEBUG:CholerabNet:Sending 's 25 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 25 4 +INFO:main:Writing s at (25,4) from 42023 to view +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data s 25 4 +INFO:main:Writing s at (25,4) from 42023 to view +INFO:main:Sending f at (26,4) to connected peers +DEBUG:CholerabNet:Sending 'f 26 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 26 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data f 26 4 +INFO:main:Writing f at (26,4) from 42023 to view +INFO:main:Writing f at (26,4) from 42023 to view +INFO:main:Sending d at (27,4) to connected peers +DEBUG:CholerabNet:Sending 'd 27 4' to 224.110.42.23:42023 +DEBUG:CholerabNet:Received Data from ('10.42.1.21', 42023), data d 27 4 +DEBUG:CholerabNet:Received Data from ('10.42.1.