chiark / gitweb /
some more messages to process
[ypp-sc-tools.web-live.git] / yoweb-scrape
index 7db7afac44400fe17ae3ae0e4b3a904d994c2c40..3c42f7e6bfcb4ca16ffdec44463c2cab40722e49 100755 (executable)
@@ -41,6 +41,11 @@ def debug(m):
        if opts.debug > 0:
                print >>opts.debug_file, m
 
+def sleep(seconds):
+       if opts.debug > 0:
+               opts.debug_file.flush()
+       time.sleep(seconds)
+
 def format_time_interval(ti):
        if ti < 120: return '%d:%02d' % (ti / 60, ti % 60)
        if ti < 7200: return '%2dm' % (ti / 60)
@@ -103,7 +108,7 @@ class Fetcher:
                need_wait = self.need_wait(now)
                if need_wait > 0:
                        debug('Fetcher   wait %d' % need_wait)
-                       time.sleep(need_wait)
+                       sleep(need_wait)
 
        def fetch(self, url, max_age):
                debug('Fetcher fetch %s' % url)
@@ -557,26 +562,30 @@ class ChatLogTracker:
                m = rm('(\\w+) abandoned a (\\S.*\\S) station\\.$')
                if m: oba('stopped'); return d("end")
 
-               def chat(what):
-                       who = m.group(1)
-                       try: pa = self._pl[who]
-                       except KeyError: return d('chat mystery')
-                       if pa.v is self._v:
-                               pa.last_chat_time = timestamp
-                               pa.last_chat_chan = what
-                               self.force_redisplay()
-                               return d('chat '+what)
-
-               def chat_metacmd(what):
+               def chat_core(speaker, chan):
+                       try: pa = self._pl[speaker]
+                       except KeyError: return 'mystery'
+                       if pa.v is not self._v: return 'elsewhere'
+                       pa.last_chat_time = timestamp
+                       pa.last_chat_chan = chan
+                       self.force_redisplay()
+                       return 'here'
+
+               def chat(chan):
+                       speaker = m.group(1)
+                       dm = chat_core(speaker, chan)
+                       return d('chat %s %s' % (chan, dm))
+
+               def chat_metacmd(chan):
                        (cmdr, metacmd) = m.groups()
                        metacmd = regexp.sub('\\s+', ' ', metacmd).strip()
                        m2 = regexp.match(
                                '/([ad]) (?:([A-Za-z ]+)\\s*:)?([A-Za-z ]+)$',
                                metacmd)
-                       if not m2: return chat(what)
+                       if not m2: return chat(chan)
 
                        (cmd, vn, targets) = m2.groups()
-                       dml = ['metachat', cmd]
+                       dml = ['cmd', chan, cmd]
 
                        if cmd == 'a': each = self._onboard_event
                        else: each = disembark
@@ -604,15 +613,15 @@ class ChatLogTracker:
                        else:
                                dml.append('unk-abbrev')
 
-                       if v is None:
-                               return d(' '.join(dml))
-
-                       targets = targets.strip().split(' ')
-                       dml.append(`len(targets)`)
-                       for target in targets:
-                               each(v, timestamp, target.title(), how)
+                       if v is not None:
+                               targets = targets.strip().split(' ')
+                               dml.append(`len(targets)`)
+                               for target in targets:
+                                       each(v, timestamp, target.title(), how)
 
-                       return d(' '.join(dml))
+                       dm = ' '.join(dml)
+                       chat_core(cmdr, 'cmd '+chan)
+                       return d(dm)
 
                m = rm('(\\w+) (?:issued an order|ordered everyone) "')
                if m: return ob1('general order');
@@ -799,7 +808,7 @@ def do_track_chat_log(args, bu):
                track.catchup()
                if track.changed():
                        print track
-               time.sleep(1)
+               sleep(1)
 
 #----- ship management aid -----
 
@@ -910,7 +919,7 @@ def do_ship_aid(args, bu):
                s += tbl.results()
 
                displayer.show(s)
-               time.sleep(1)
+               sleep(1)
                rotate_nya = rotate_nya[1:3] + rotate_nya[0]
 
 #---------- main program ----------