From 13243b22468aac58ff35758c0c6cd4a56b631e2a Mon Sep 17 00:00:00 2001 From: cidoku Date: Sun, 2 Mar 2025 16:10:58 -0300 Subject: [PATCH] handle disconnections better + more widgets focus on ic input after clicking --- AOsocket.py | 2 ++ gameview.py | 11 ++++++++++ mainmenu.py | 61 ++++++++++------------------------------------------- options.py | 2 +- 4 files changed, 25 insertions(+), 51 deletions(-) diff --git a/AOsocket.py b/AOsocket.py index 8407d57..939df86 100644 --- a/AOsocket.py +++ b/AOsocket.py @@ -80,6 +80,8 @@ class AOwebSocket(object): return -2, [] except websocket.WebSocketConnectionClosedException: return -1, [] + except Exception as e: + return -3, e totals = contents.split('%') del totals[-1] diff --git a/gameview.py b/gameview.py index a6a0524..1309b5d 100644 --- a/gameview.py +++ b/gameview.py @@ -1222,6 +1222,7 @@ class gui(QtGui.QWidget): self.slidebutton.setToolTip("Tell clients to play courtroom slide animations for your message") self.effectdropdown = QtGui.QComboBox(self) + self.effectdropdown.currentIndexChanged.connect(self.icchat_focus) self.effectdropdown.setToolTip('Show this effect on your next message') self.callmodbtn = QtGui.QPushButton(self) @@ -1460,6 +1461,7 @@ class gui(QtGui.QWidget): self.posdropdown.setCurrentIndex(ind) self.charside = str(self.posdropdown.itemText(ind)) self.setJudgeButtons() + self.icchat_focus() server_is_2_8 = "additive" in self.features and "looping_sfx" in self.features and "effects" in self.features if server_is_2_8: @@ -2049,6 +2051,8 @@ class gui(QtGui.QWidget): def changeEmote(self, dropdown, ind): if ind == -1: return + + self.icchat_focus() if not dropdown: self.selectedemote = ind + self.current_emote_page * self.max_emotes_on_page else: @@ -2067,6 +2071,7 @@ class gui(QtGui.QWidget): def setChatColor(self, ind): self.mychatcolor = ind + self.icchat_focus() def showMessage(self, type, *args, **kwargs): if type == 'critical': @@ -3604,6 +3609,7 @@ class PresentButton(QtGui.QLabel): self.setPixmap(self.button_on) else: self.setPixmap(self.button_off) + self.gamegui.icchat_focus() class EditEvidenceDialog(QtGui.QDialog): @@ -3882,6 +3888,11 @@ class TCP_Thread(QtCore.QThread): self.parent.willDisconnect = True self.quit() return + elif error == -3: + self.parent.emit(QtCore.SIGNAL('showMessage(QString, QString, QString)'), 'critical', 'Connection lost', "There was a critical connection failure. Please check your internet connection.\n\nDetails: %s." % total) + self.parent.willDisconnect = True + self.quit() + return else: self.send_attempts = 0 diff --git a/mainmenu.py b/mainmenu.py index d3191c9..4b14733 100644 --- a/mainmenu.py +++ b/mainmenu.py @@ -252,8 +252,9 @@ class lobby(QtGui.QWidget): if self.tab == 0: try: self.masterserver.start() - except: - self.lobbychatlog.append('failed to refresh server list') + except Exception as e: + print "[debug] Failed to refresh server list:", e + self.lobbychatlog.append('Failed to refresh server list.') elif self.tab == 1: if exists(AOpath+'serverlist.txt'): @@ -364,56 +365,16 @@ class MasterServer(QtCore.QThread): super(MasterServer, self).__init__() def run(self): - tempdata = "" - self.ms_http = requests.get("http://servers.aceattorneyonline.com/servers") - self.ms_motd = requests.get("http://servers.aceattorneyonline.com/motd") - - if self.ms_http.ok: self.gotServers.emit(json.loads(self.ms_http.content)) - if self.ms_motd.ok: self.gotOOCMsg.emit(self.ms_motd.content) - -""" try: - self.ms_tcp.connect(('master.aceattorneyonline.com', 27016)) - except: - return + tempdata = "" + self.ms_http = requests.get("http://servers.aceattorneyonline.com/servers") + self.ms_motd = requests.get("http://servers.aceattorneyonline.com/motd") - while True: - contents = self.ms_tcp.recv(16384) - if len(contents) == 0: - print 'masterserver failure' - return - - if not contents.endswith("%"): - tempdata += contents - continue - else: - if tempdata: - contents = tempdata + contents - tempdata = "" - - temp = contents.split('%') - for msg in temp: - network = msg.split('#') - header = network[0] - - if header == "servercheok": - self.ms_tcp.send("HI#AO2XP %s#%%ID#AO2XP by Headshot#%s#%%" % (hardware.get_hdid(), GAME_VERSION[1:])) - self.ms_tcp.send("ALL#%") - - elif header == 'DOOM': - print 'banned from masterserver' - self.msgbox_signal.emit(0, "WHEEZE", "You are exiled from AO") - self.ms_tcp.close() - return - - elif header == 'ALL': - self.gotServers.emit(network) - - elif header == 'CT': - name = decode_ao_str(network[1].decode("utf-8")) - chatmsg = decode_ao_str(network[2].decode("utf-8")) - self.gotOOCMsg.emit(name, chatmsg) - """ + if self.ms_http.ok: self.gotServers.emit(json.loads(self.ms_http.content)) + if self.ms_motd.ok: self.gotOOCMsg.emit(self.ms_motd.content) + except Exception as e: + print "[debug] Failed to load server list:", e + QtGui.QMessageBox.critical(None, "Error", "Failed to load the master server list. Please check your internet connection and try again.") class AOServerInfo(QtCore.QThread): moveToGameSignal = QtCore.pyqtSignal(list) diff --git a/options.py b/options.py index 562da0a..73f996f 100644 --- a/options.py +++ b/options.py @@ -240,7 +240,7 @@ class Settings(QtGui.QDialog): self.defaultshowname.setText(ini.read_ini(self.inifile, "General", "showname").decode("utf-8")) except: self.defaultshowname.setText(ini.read_ini(self.inifile, "General", "showname")) - self.enableslide.setChecked(ini.read_ini_bool(self.inifile, "General", "slide")) + self.enableslide.setChecked(ini.read_ini_bool(self.inifile, "General", "slide", False)) self.allowdownload_chars.setChecked(ini.read_ini_bool(self.inifile, "General", "download characters")) self.allowdownload_sounds.setChecked(ini.read_ini_bool(self.inifile, "General", "download sounds")) self.allowdownload_music.setChecked(ini.read_ini_bool(self.inifile, "General", "download music"))