-
Notifications
You must be signed in to change notification settings - Fork 342
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PBEM fails due to save game compression change from .xz to .zst #484
Comments
Thanks for reporting, pull requests welcome. |
diff --git a/pbem/pbem.py b/pbem/pbem.py
index 12fd92b..a4ef18a 100644
--- a/pbem/pbem.py
+++ b/pbem/pbem.py
@@ -20,7 +20,10 @@
import os, os.path
import time
-import lzma
+#import lzma
+import zstandard as zstd
+import tempfile
import mysql.connector
from mailsender import MailSender
from mailstatus import *
@@ -94,14 +97,20 @@ def handle_savegame(root, file):
print("Handling savegame: " + filename);
txt = None;
try:
- with lzma.open(filename, mode="rt") as f:
- txt = f.read().split("\n");
- status.savegames_read += 1;
+ with open(filename, 'rb') as compressed:
+ decomp = zstd.ZstdDecompressor()
+ output_path = tempfile.NamedTemporaryFile().name
+ with open(output_path, 'wb') as destination:
+ decomp.copy_stream(compressed, destination)
+ with open(output_path, "rt") as f:
+ txt = f.read().split("\n");
+ status.savegames_read += 1;
except Exception as inst:
print("Error loading savegame: " + str(inst));
return;
- new_filename = "pbem_processed_" + str(random.randint(0,10000000000)) + ".xz";
+ new_filename = "pbem_processed_" + str(random.randint(0,10000000000)) + ".zst";
f.close();
if not testmode: shutil.move(filename, os.path.join(root,new_filename))
print("New filename will be: " + new_filename);
@@ -220,7 +229,7 @@ def save_game_result(winner, playerOne, playerTwo):
def process_savegames():
for root, subFolders, files in os.walk(savedir):
for file in files:
- if (file.endswith(".xz") and file.startswith("pbem") and not file.startswith("pbem_processed")):
+ if (file.endswith(".zst") and file.startswith("pbem") and not file.startswith("pbem_processed")):
handle_savegame(root, file); Here is a very trivial patch in that it does not handle any migrations, and creates a temp file - zstandard does not have the same read() like lzma does. It appears the entire file is loaded into memory anyways and I'd think they are small so this may be OK. Any guidance would be appreciated - more of a Java dev then python. |
Unfortunately this only partially works - while the game saves after the first turn to a |
https://github.com/freeciv/freeciv-web/blob/develop/pbem/pbem.py#L125 Please submit a propser GitHub pull request. |
Or revert to using .xz compression format in Freeciv-web. The differences between the various compession formats is usually minimal these days. |
I'm trying to trace how this all works and as someone unfamiliar with the codebase, it's quite complex. So the pbem.js script is sending a websocket message to a python proxy, which is sending that save game name to an actual freeciv instance. It seems like I could recompile with |
I've meant to work on implementing the zstd support, but thought that all game types currently hardcode .xz to use in their .serv files (compresstype server setting). That might not be the case for pbem games? |
Hmm... publite2/pubscript_pbem.serv has "set compresstype xz" - isn't that one currently used for pbem games? |
Ahh, so that was the issue - I was switching the rule set as I thought (maybe incorrectly) that for web games I should be using I guess the fix is to ensure any rulesets used by the web save in the correct compresstype. Though, looking at the rulesets/.serv files - I'm not sure the correct way to go. Edit: Would adding |
This seems to be a bigger problem than just the compresstype then. Freeciv-web (publite) seems to be designed with the assumption that settings set in the .serv file it initially feeds to the server remain in effect. But that's not the case if user changes ruleset, causing settings to reset to server's defaults. Maybe we should have some feature in the server for it to reread the initial .serv file when ever the settings get resetted. |
Some of those "game type" .serv files under publite also want to set specific rulesetdir, so in those cases changing the ruleset should not be allowed at all. |
|
Using develop branch at 583adba
... Configure email
vagrant up
.. provision succeeds
Start a PBEM game - welcome email sent.
Take first turn - the savegame/pbem/ dir contains a file ending in
.zst
Currently the pbem.py script only handles
.xz
compressed files and fails to send next turn email to playerfreeciv-web/pbem/pbem.py
Line 97 in c5930c2
The text was updated successfully, but these errors were encountered: