Final Commit
[progcomp2013.git] / qchess / qchess.py
index 092a121..1279ec1 100755 (executable)
@@ -651,6 +651,8 @@ class Player():
 
        def base_player(self):
                return self
+
+
        
 
 
@@ -722,11 +724,17 @@ class FifoPlayer(Player):
                Player.__init__(self, name, colour)
                os.mkfifo(self.name+".in")
                os.mkfifo(self.name+".out")
-               
-               
-               
-               
-               
+                       
+
+               try:
+                       self.fifo_out = open_fifo(self.name+".out","w", FifoPlayer.timeout)
+               except:
+                       raise Exception("FIFO_TIMEOUT")
+               else:
+                       self.fifo_out.write("START "+colour+"\n")
+                       self.fifo_out.close()
+
+                               
        def update(self, result):
                sys.stderr.write("update fifo called\n")
                try:
@@ -772,15 +780,16 @@ class FifoPlayer(Player):
                try:
                        self.fifo_out = open_fifo(self.name+".out", "w", FifoPlayer.timeout)
                except:
-                       os.remove(self.name+".in")
-                       os.remove(self.name+".out")
-                       #raise Exception("FIFO_TIMEOUT")
-                       
+                       pass
                else:
                        self.fifo_out.write(result + "\n")
                        self.fifo_out.close()
+
+               try:
                        os.remove(self.name+".in")
                        os.remove(self.name+".out")
+               except OSError:
+                       pass
 
 # Player that runs from another process
 class ExternalAgent(Player):
@@ -788,6 +797,7 @@ class ExternalAgent(Player):
 
        def __init__(self, name, colour):
                Player.__init__(self, name, colour)
+               #raise Exception("waht")
                self.p = subprocess.Popen(name,bufsize=0,stdin=subprocess.PIPE, stdout=subprocess.PIPE, shell=True,universal_newlines=True)
                
                self.send_message(colour)
@@ -869,6 +879,7 @@ class HumanPlayer(Player):
        def __init__(self, name, colour):
                Player.__init__(self, name, colour)
                
+
        # Select your preferred account
        def select(self):
                if isinstance(graphics, GraphicsThread):
@@ -890,9 +901,11 @@ class HumanPlayer(Player):
                                sys.stdout.write("SELECTION?\n")
                                try:
                                        p = map(int, sys.stdin.readline().strip("\r\n ").split(" "))
+                                       return p
                                except:
                                        sys.stderr.write("ILLEGAL GIBBERISH\n")
                                        continue
+
        # It's your move captain
        def get_move(self):
                if isinstance(graphics, GraphicsThread):
@@ -908,6 +921,7 @@ class HumanPlayer(Player):
                                sys.stdout.write("MOVE?\n")
                                try:
                                        p = map(int, sys.stdin.readline().strip("\r\n ").split(" "))
+                                       return p
                                except:
                                        sys.stderr.write("ILLEGAL GIBBERISH\n")
                                        continue
@@ -934,7 +948,8 @@ class InternalAgent(Player):
 
                self.board = Board(style = "agent")
 
-
+       def argForm(self):
+               return "@internal:"+self.name
 
        def update(self, result):
                
@@ -1423,9 +1438,11 @@ class Network():
                if self.src in ready:
                        s = self.src.recv(1)
                else:
-                       raise Exception("UNRESPONSIVE")
+                       raise Exception("NET_UNRESPONSIVE")
 
 
+               debug("Network get_response s = " + str(s))
+
                while s[len(s)-1] != '\n':
                        # Timeout on each character in the message
                        if network_timeout_delay > 0.0:
@@ -1435,7 +1452,7 @@ class Network():
                        if self.src in ready:
                                s += self.src.recv(1) 
                        else:
-                               raise Exception("UNRESPONSIVE")
+                               raise Exception("NET_UNRESPONSIVE")
 
                
                return s.strip(" \r\n")
@@ -1449,7 +1466,7 @@ class Network():
                if self.src in ready:
                        self.src.send(s + "\n")
                else:
-                       raise Exception("UNRESPONSIVE")
+                       raise Exception("NET_UNRESPONSIVE")
                
                
 
@@ -1673,11 +1690,10 @@ class GameThread(StoppableThread):
                self.cond = threading.Condition() # conditional for some reason, I forgot
                self.final_result = ""
                self.server = server
+               self.retry_illegal = False
                
                
-                       
-               
-               
+       
 
        # Run the game (run in new thread with start(), run in current thread with run())
        def run(self):
@@ -1804,14 +1820,17 @@ class GameThread(StoppableThread):
                                                break
                                except Exception,e:
                                #if False:
-                                       result = e.message
-                                       sys.stderr.write("qchess.py exception: "+result + "\n")
-                                       
-                                       self.stop()
+
                                        
-                                       with self.lock:
-                                               self.final_result = self.state["turn"].colour + " " + e.message
-                                       break
+                                       result = e.message
+                                       if self.retry_illegal:
+                                               self.state["turn"].update(result);
+                                       else:
+                                               sys.stderr.write("qchess.py exception: "+result + "\n")
+                                               self.stop()
+                                               with self.lock:
+                                                       self.final_result = self.state["turn"].colour + " " + e.message
+                                               break
 
 
 
@@ -2594,13 +2613,13 @@ def dedicated_server():
 def client(addr, player="@human"):
        
        
-       
+       debug("Client " + player + " starts")
        s = socket.socket()
        s.connect((addr, 4562))
        
        [colour,port] = s.recv(1024).strip(" \r\n").split(" ")
        
-       #debug("Colour: " + colour + ", port: " + port)
+       debug("Colour: " + colour + ", port: " + port)
        
        s.shutdown(socket.SHUT_RDWR)
        s.close()
@@ -2610,7 +2629,8 @@ def client(addr, player="@human"):
        else:
                p = subprocess.Popen(["python", "qchess.py", "@network:"+addr+":"+port, player])
        p.wait()
-       return 0# --- server.py --- #
+       return 0
+# --- server.py --- #
 #!/usr/bin/python -u
 
 # Do you know what the -u does? It unbuffers stdin and stdout
@@ -2633,6 +2653,7 @@ sleep_timeout = None
 [game, graphics] = [None, None]
 
 def make_player(name, colour):
+       debug(name)
        if name[0] == '@':
                if name[1:] == "human":
                        return HumanPlayer(name, colour)
@@ -2701,6 +2722,7 @@ def main(argv):
        global sleep_timeout
 
 
+       retry_illegal = False
        server_addr = None
 
        max_moves = None
@@ -2722,17 +2744,7 @@ def main(argv):
                i += 1
                arg = argv[i]
                if arg[0] != '-':
-                       p = make_player(arg, colour)
-                       if not isinstance(p, Player):
-                               sys.stderr.write(sys.argv[0] + " : Fatal error creating " + colour + " player\n")
-                               return 100
-                       players.append(p)
-                       if colour == "white":
-                               colour = "black"
-                       elif colour == "black":
-                               pass
-                       else:
-                               sys.stderr.write(sys.argv[0] + " : Too many players (max 2)\n")
+                       players.append(arg)
                        continue
 
                # Option parsing goes here
@@ -2798,7 +2810,8 @@ def main(argv):
                                sleep_timeout = -1
                        else:
                                sleep_timeout = float(arg[2:].split("=")[1])
-                               
+               elif (arg[1] == '-' and arg[2:] == "retry-illegal"):
+                       retry_illegal = not retry_illegal
                elif (arg[1] == '-' and arg[2:] == "help"):
                        # Help
                        os.system("less data/help.txt") # The best help function
@@ -2816,11 +2829,23 @@ def main(argv):
                                sys.stderr.write("Only a single player may be provided when --server is used\n")
                                return 1
                        if len(players) == 1:
-                               return client(server_addr, players[0].name)
+                               return client(server_addr, players[0])
                        else:
                                return client(server_addr)
                
-
+       for i in xrange(len(players)):
+               p = make_player(players[i], colour)
+               if not isinstance(p, Player):
+                       sys.stderr.write(sys.argv[0] + " : Fatal error creating " + colour + " player\n")
+                       return 100
+               players[i] = p
+               if colour == "white":
+                       colour = "black"
+               elif colour == "black":
+                       pass
+               else:
+                       sys.stderr.write(sys.argv[0] + " : Too many players (max 2)\n")
+               
        # Create the board
        
        # Construct a GameThread! Make it global! Damn the consequences!
@@ -2845,6 +2870,7 @@ def main(argv):
                board = Board(style)
                board.max_moves = max_moves
                game = GameThread(board, players) 
+               game.retry_illegal = retry_illegal
 
 
 
@@ -2987,4 +3013,4 @@ if __name__ == "__main__":
                
 
 # --- main.py --- #
-# EOF - created from make on Sun May 19 12:36:10 WST 2013
+# EOF - created from make on Monday 24 June  23:55:46 WST 2013

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