-def ping_test(server_answered):
- half_wait_time = 5
- if server_answered:
- ping_test.sent = False
- elif ping_test.wait_start + half_wait_time < time.time():
- if not ping_test.sent:
- io["file_out"].write("PING\n")
- io["file_out"].flush()
- ping_test.sent = True
- ping_test.wait_start = time.time()
- elif ping_test.sent:
- raise SystemExit("Server not answering anymore.")
-ping_test.wait_start = 0
-
-
-def read_into_message_queue(string):
- if string == "":
- return
- new_open_end = False
- if string[-1] is not "\n":
- new_open_end = True
- new_messages = string.splitlines()
- logfile = open("log", "a")
- logfile.write(str(new_messages) + "\n")
- logfile.flush()
- logfile.close()
- if message_queue["open_end"]:
- message_queue["messages"][-1] = message_queue["messages"][-1] + new_messages[0]
- del new_messages[0]
- message_queue["messages"] = message_queue["messages"] + new_messages
- if new_open_end:
- message_queue["open_end"] = True
+def read_worldstate():
+ if not os.access(io["path_worldstate"], os.F_OK):
+ msg = "No world state file found at " + io["path_worldstate"] + "."
+ raise SystemExit(msg)
+ read_anew = False
+ worldstate_file = open(io["path_worldstate"], "r")
+ turn_string = worldstate_file.readline()
+ if int(turn_string) != world_data["turn"]:
+ read_anew = True
+ if not read_anew: # In rare cases, world may change, but not turn number.
+ mtime = os.stat(io["path_worldstate"])
+ if mtime != read_worldstate.last_checked_mtime:
+ read_worldstate.last_checked_mtime = mtime
+ read_anew = True
+ if read_anew:
+ cursed_main.redraw = True
+ world_data["turn"] = int(turn_string)
+ world_data["lifepoints"] = int(worldstate_file.readline())
+ world_data["satiation"] = int(worldstate_file.readline())
+ worldstate_file.close()
+read_worldstate.last_checked_mtime = -1
+
+
+def read_message_queue():
+ while (len(message_queue["messages"]) > 1
+ or (len(message_queue["messages"]) == 0
+ and not message_queue["open_end"])):
+ message = message_queue["messages"].pop(0)
+ if message[0:4] == "LOG ":
+ world_data["log"] += [message[4:]]
+ cursed_main.redraw = True