Index: third_party/pexpect/examples/chess3.py |
diff --git a/third_party/pexpect/examples/chess3.py b/third_party/pexpect/examples/chess3.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..dc02663abdcccf9cfe43444d31fb0144ed5917ba |
--- /dev/null |
+++ b/third_party/pexpect/examples/chess3.py |
@@ -0,0 +1,157 @@ |
+#!/usr/bin/env python |
+ |
+'''This demonstrates controlling a screen oriented application (curses). |
+It starts two instances of gnuchess and then pits them against each other. |
+ |
+PEXPECT LICENSE |
+ |
+ This license is approved by the OSI and FSF as GPL-compatible. |
+ http://opensource.org/licenses/isc-license.txt |
+ |
+ Copyright (c) 2012, Noah Spurrier <noah@noah.org> |
+ PERMISSION TO USE, COPY, MODIFY, AND/OR DISTRIBUTE THIS SOFTWARE FOR ANY |
+ PURPOSE WITH OR WITHOUT FEE IS HEREBY GRANTED, PROVIDED THAT THE ABOVE |
+ COPYRIGHT NOTICE AND THIS PERMISSION NOTICE APPEAR IN ALL COPIES. |
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
+ |
+''' |
+ |
+from __future__ import print_function |
+ |
+from __future__ import absolute_import |
+ |
+import pexpect |
+import ANSI |
+ |
+REGEX_MOVE = '(?:[a-z]|\x1b\[C)(?:[0-9]|\x1b\[C)(?:[a-z]|\x1b\[C)(?:[0-9]|\x1b\[C)' |
+REGEX_MOVE_PART = '(?:[0-9]|\x1b\[C)(?:[a-z]|\x1b\[C)(?:[0-9]|\x1b\[C)' |
+ |
+class Chess: |
+ |
+ def __init__(self, engine = "/usr/local/bin/gnuchess -a -h 1"): |
+ self.child = pexpect.spawn (engine) |
+ self.term = ANSI.ANSI () |
+ |
+# self.child.expect ('Chess') |
+ # if self.child.after != 'Chess': |
+ # raise IOError, 'incompatible chess program' |
+ # self.term.process_list (self.before) |
+ # self.term.process_list (self.after) |
+ self.last_computer_move = '' |
+ def read_until_cursor (self, r,c): |
+ fout = open ('log','a') |
+ while 1: |
+ k = self.child.read(1, 10) |
+ self.term.process (k) |
+ fout.write ('(r,c):(%d,%d)\n' %(self.term.cur_r, self.term.cur_c)) |
+ fout.flush() |
+ if self.term.cur_r == r and self.term.cur_c == c: |
+ fout.close() |
+ return 1 |
+ sys.stdout.write (k) |
+ sys.stdout.flush() |
+ |
+ def do_scan (self): |
+ fout = open ('log','a') |
+ while 1: |
+ c = self.child.read(1,10) |
+ self.term.process (c) |
+ fout.write ('(r,c):(%d,%d)\n' %(self.term.cur_r, self.term.cur_c)) |
+ fout.flush() |
+ sys.stdout.write (c) |
+ sys.stdout.flush() |
+ |
+ def do_move (self, move): |
+ self.read_until_cursor (19,60) |
+ self.child.sendline (move) |
+ return move |
+ |
+ def get_computer_move (self): |
+ print('Here') |
+ i = self.child.expect (['\[17;59H', '\[17;58H']) |
+ print(i) |
+ if i == 0: |
+ self.child.expect (REGEX_MOVE) |
+ if len(self.child.after) < 4: |
+ self.child.after = self.child.after + self.last_computer_move[3] |
+ if i == 1: |
+ self.child.expect (REGEX_MOVE_PART) |
+ self.child.after = self.last_computer_move[0] + self.child.after |
+ print('', self.child.after) |
+ self.last_computer_move = self.child.after |
+ return self.child.after |
+ |
+ def switch (self): |
+ self.child.sendline ('switch') |
+ |
+ def set_depth (self, depth): |
+ self.child.sendline ('depth') |
+ self.child.expect ('depth=') |
+ self.child.sendline ('%d' % depth) |
+ |
+ def quit(self): |
+ self.child.sendline ('quit') |
+import sys |
+print('Starting...') |
+white = Chess() |
+white.do_move('b2b4') |
+white.read_until_cursor (19,60) |
+c1 = white.term.get_abs(17,58) |
+c2 = white.term.get_abs(17,59) |
+c3 = white.term.get_abs(17,60) |
+c4 = white.term.get_abs(17,61) |
+fout = open ('log','a') |
+fout.write ('Computer:%s%s%s%s\n' %(c1,c2,c3,c4)) |
+fout.close() |
+white.do_move('c2c4') |
+white.read_until_cursor (19,60) |
+c1 = white.term.get_abs(17,58) |
+c2 = white.term.get_abs(17,59) |
+c3 = white.term.get_abs(17,60) |
+c4 = white.term.get_abs(17,61) |
+fout = open ('log','a') |
+fout.write ('Computer:%s%s%s%s\n' %(c1,c2,c3,c4)) |
+fout.close() |
+white.do_scan () |
+ |
+#white.do_move ('b8a6') |
+#move_white = white.get_computer_move() |
+#print 'move white:', move_white |
+ |
+sys.exit(1) |
+ |
+ |
+ |
+black = Chess() |
+white = Chess() |
+white.child.expect ('Your move is') |
+white.switch() |
+ |
+move_white = white.get_first_computer_move() |
+print('first move white:', move_white) |
+ |
+black.do_first_move (move_white) |
+move_black = black.get_first_computer_move() |
+print('first move black:', move_black) |
+ |
+white.do_move (move_black) |
+ |
+done = 0 |
+while not done: |
+ move_white = white.get_computer_move() |
+ print('move white:', move_white) |
+ |
+ black.do_move (move_white) |
+ move_black = black.get_computer_move() |
+ print('move black:', move_black) |
+ |
+ white.do_move (move_black) |
+ print('tail of loop') |
+ |
+g.quit() |