gnome-games r7648 - branches/gnome-2-22/glchess/src/lib
- From: rancell svn gnome org
- To: svn-commits-list gnome org
- Subject: gnome-games r7648 - branches/gnome-2-22/glchess/src/lib
- Date: Sun, 11 May 2008 10:29:50 +0100 (BST)
Author: rancell
Date: Sun May 11 09:29:50 2008
New Revision: 7648
URL: http://svn.gnome.org/viewvc/gnome-games?rev=7648&view=rev
Log:
Ignore autoloded games that have completed. Don't autosave autoloaded games that are not in the history directory
Modified:
branches/gnome-2-22/glchess/src/lib/history.py
branches/gnome-2-22/glchess/src/lib/main.py
Modified: branches/gnome-2-22/glchess/src/lib/history.py
==============================================================================
--- branches/gnome-2-22/glchess/src/lib/history.py (original)
+++ branches/gnome-2-22/glchess/src/lib/history.py Sun May 11 09:29:50 2008
@@ -20,7 +20,7 @@
def getUnfinishedGame(self):
"""Get the last game that is unfinished.
- Returns the (PGN game, fileName) or (None, None) if no unfinished games.
+ Returns the (PGN game, fileName, inHistory) or (None, None, False) if no unfinished games.
"""
g = None
fileName = None
@@ -29,41 +29,40 @@
lines = f.readlines()
f.close()
- lines.reverse()
index = 0
- for line in lines:
- fileName = line.strip()
+ while len(lines) > 0:
+ fileName = lines[0].strip()
+
try:
p = chess.pgn.PGN(fileName, 1)
except chess.pgn.Error, e:
print e.description
- continue
except IOError, e:
print e.strerror
- continue
else:
- g = p[0]
- break
- index += 1
+ result = p[0].getTag(chess.pgn.TAG_RESULT)
+ if result == chess.pgn.RESULT_INCOMPLETE:
+ g = p[0]
+ break
+ lines = lines[1:]
+
except IOError, e:
if e.errno != errno.ENOENT:
print e.errno
print 'Failed to read unfinished list'
- return (None, None)
+ return (None, None, False)
lines = []
- else:
- lines = lines[index:]
# Write the list back
try:
f = file(UNFINISHED_FILE, 'w')
- lines.reverse()
f.writelines(lines)
f.close()
except IOError:
print 'Failed to write unfinished list'
- return (g, fileName)
+ inHistory = fileName.startswith(HISTORY_DIR)
+ return (g, fileName, inHistory)
def load(self, date):
return
@@ -147,13 +146,13 @@
f.close()
f = file(UNFINISHED_FILE, 'w')
+ if result == chess.pgn.RESULT_INCOMPLETE:
+ f.write(fileName + '\n')
for line in lines:
l = line.strip()
if l == fileName and result == chess.pgn.RESULT_INCOMPLETE:
continue
f.write(l + '\n')
- if result == chess.pgn.RESULT_INCOMPLETE:
- f.write(fileName + '\n')
f.close()
except IOError:
print 'Failed to update unfinished list'
Modified: branches/gnome-2-22/glchess/src/lib/main.py
==============================================================================
--- branches/gnome-2-22/glchess/src/lib/main.py (original)
+++ branches/gnome-2-22/glchess/src/lib/main.py Sun May 11 09:29:50 2008
@@ -743,11 +743,11 @@
def __autoload(self):
"""Restore games from the autosave file"""
- (pgnGame, fileName) = self.history.getUnfinishedGame()
+ (pgnGame, fileName, inHistory) = self.history.getUnfinishedGame()
if pgnGame is not None:
g = self.addPGNGame(pgnGame, fileName)
if g is not None:
- g.inHistory = True
+ g.inHistory = inHistory
if __name__ == '__main__':
app = Application()
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]