add support for one shot Idlers
[zanchey/dispense2.git] / sql-edition / servers / Idler.py
index 4efb56f..a231d96 100755 (executable)
@@ -1,6 +1,10 @@
 #!/usr/bin/env python
 
-import string
+import string, time
+from random import random
+from MessageKeeper import MessageKeeper
+
+orderings = None
 
 class Idler:
        def __init__(self, v):
@@ -11,6 +15,9 @@ class Idler:
 
        def reset(self):
                pass
+       
+       def finished(self):
+               return False
 
 class TrainIdler(Idler):
        def __init__(self, v):
@@ -74,8 +81,34 @@ class TrainIdler(Idler):
        def reset(self):
                self.idle_state = 0
 
+class OrderMaker:
+       def __init__(self, n=8):
+               self.n = n
+               self.a = []
+               self.u = []
+               self.s = []
+               for x in range(0,n):
+                       self.u.append(False)
+               self.go()
+
+       def go(self):
+               from copy import deepcopy
+               if len(self.s) == self.n:
+                       self.a.append(deepcopy(self.s))
+               else:
+                       for x in range(0,self.n):
+                               if self.u[x]: continue
+                               self.s.append(x)
+                               self.u[x] = True
+                               self.go()
+                               self.u[x] = False
+                               self.s.pop()
+
+       def order(self):
+               return self.a
+
 class GrayIdler(Idler):
-       def __init__(self, v, one=None, zero=None):
+       def __init__(self, v, one=None, zero=None, reorder=0):
                self.bits = 8
                self.size = 1 << self.bits
                self.i = 0
@@ -83,6 +116,10 @@ class GrayIdler(Idler):
                self.v = v
                self.one = one
                self.zero = zero
+               self.reorder = reorder
+               global orderings
+               if not orderings:
+                       orderings = OrderMaker().order()
 
        def next(self):
                output = self.do_next_state()
@@ -91,6 +128,12 @@ class GrayIdler(Idler):
                        output = string.replace(output, "0", self.zero)
                if self.one:
                        output = string.replace(output, "1", self.one)
+               if self.reorder:
+                       global orderings
+                       newoutput = ""
+                       for i in range(0,8):
+                               newoutput += output[orderings[self.reorder][i]]
+                       output = newoutput
                self.v.display(" %8.8s " % (output))
                self.i = (self.i + 1) % self.size
 
@@ -138,3 +181,45 @@ class GrayIdler(Idler):
        def reset(self):
                self.i = 0
                self.grayCode = 0
+               if self.reorder:
+                       self.reorder = int(random()*40319)+1
+
+
+class StringIdler(Idler):
+       def __init__(self, v, text="Hello Cruel World!  "):
+               self.v = v
+               self.mk = MessageKeeper(v)
+               self.text = self.clean_text(text)
+               
+               msg = [("",False, None),(self.text, True, 0.8)]
+               self.mk.set_messages(msg)
+
+       def clean_text(self, text):
+               # nothing like a bit of good clean text :)
+               valid = string.digits \
+                       + string.letters \
+                       + string.punctuation \
+                       + " "
+               # uppercase it
+               text = string.upper(text)
+               clean = ""
+               for char in text:
+                       if char in valid:
+                               clean = clean + char
+                       else:
+                               clean = clean + " "
+               return clean
+
+       def next(self):
+               self.mk.update_display()
+
+class ClockIdler(Idler):
+       def __init__(self, v):
+               self.v = v
+               self.last = None
+
+       def next(self):
+               output = time.strftime("%H:%M:%S")
+               if output != self.last:
+                       self.v.display(" %8.8s " % (output))
+                       self.last = output

UCC git Repository :: git.ucc.asn.au