Further IRC linting/formatting
This commit is contained in:
parent
1157e49d9e
commit
9040ad0419
3 changed files with 23 additions and 45 deletions
50
irc.py
50
irc.py
|
@ -5,11 +5,11 @@ References for the IRC protocol:
|
||||||
- Updated IRC Client specification: https://www.rfc-editor.org/rfc/rfc2812
|
- Updated IRC Client specification: https://www.rfc-editor.org/rfc/rfc2812
|
||||||
- Modern IRC client protocol writeup: https://modern.ircdocs.horse
|
- Modern IRC client protocol writeup: https://modern.ircdocs.horse
|
||||||
- IRCv3 protocol additions: https://ircv3.net/irc/
|
- IRCv3 protocol additions: https://ircv3.net/irc/
|
||||||
- Draft of metadata specification: https://gist.github.com/k4bek4be/92c2937cefd49990fbebd001faf2b237
|
- Draft of metadata spec: https://gist.github.com/k4bek4be/92c2937cefd49990fbebd001faf2b237
|
||||||
|
|
||||||
Some code in this file may be based on the oyoyo IRC library,
|
Some code in this file may be based on the oyoyo IRC library,
|
||||||
the license notice included with oyoyo source files is indented here:
|
the license notice included with oyoyo source files is indented here:
|
||||||
|
|
||||||
# Copyright (c) 2008 Duncan Fordyce
|
# Copyright (c) 2008 Duncan Fordyce
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
# of this software and associated documentation files (the "Software"), to deal
|
# of this software and associated documentation files (the "Software"), to deal
|
||||||
|
@ -26,7 +26,6 @@ the license notice included with oyoyo source files is indented here:
|
||||||
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
# THE SOFTWARE.
|
# THE SOFTWARE.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
import socket
|
import socket
|
||||||
import random
|
import random
|
||||||
|
@ -77,9 +76,9 @@ class PesterIRC(QtCore.QThread):
|
||||||
self._send_irc = SendIRC()
|
self._send_irc = SendIRC()
|
||||||
|
|
||||||
self.unresponsive = False
|
self.unresponsive = False
|
||||||
self.registeredIRC = False
|
self.registered_irc = False
|
||||||
self.metadata_supported = False
|
self.metadata_supported = False
|
||||||
self.stopIRC = None
|
self.stop_irc = None
|
||||||
self._conn = None
|
self._conn = None
|
||||||
self._end = False # Set to True when ending connection.
|
self._end = False # Set to True when ending connection.
|
||||||
self.joined = False
|
self.joined = False
|
||||||
|
@ -130,8 +129,8 @@ class PesterIRC(QtCore.QThread):
|
||||||
is called on the main thread. Returning from this method ends the thread."""
|
is called on the main thread. Returning from this method ends the thread."""
|
||||||
try:
|
try:
|
||||||
self.irc_connect()
|
self.irc_connect()
|
||||||
except OSError as se:
|
except OSError as socket_exception:
|
||||||
self.stopIRC = se
|
self.stop_irc = socket_exception
|
||||||
return
|
return
|
||||||
while True:
|
while True:
|
||||||
res = True
|
res = True
|
||||||
|
@ -139,13 +138,13 @@ class PesterIRC(QtCore.QThread):
|
||||||
PchumLog.debug("update_irc()")
|
PchumLog.debug("update_irc()")
|
||||||
self.mainwindow.sincerecv = 0
|
self.mainwindow.sincerecv = 0
|
||||||
res = self.update_irc()
|
res = self.update_irc()
|
||||||
except socket.timeout as se:
|
except socket.timeout as timeout:
|
||||||
PchumLog.debug("timeout in thread %s", self)
|
PchumLog.debug("timeout in thread %s", self)
|
||||||
self._close()
|
self._close()
|
||||||
self.stopIRC = "{}, {}".format(type(se), se)
|
self.stop_irc = f"{type(timeout)}, {timeout}"
|
||||||
return
|
return
|
||||||
except (OSError, IndexError, ValueError) as se:
|
except (OSError, IndexError, ValueError) as exception:
|
||||||
self.stopIRC = "{}, {}".format(type(se), se)
|
self.stop_irc = f"{type(exception)}, {exception}"
|
||||||
PchumLog.debug("Socket error, exiting thread.")
|
PchumLog.debug("Socket error, exiting thread.")
|
||||||
return
|
return
|
||||||
else:
|
else:
|
||||||
|
@ -198,13 +197,11 @@ class PesterIRC(QtCore.QThread):
|
||||||
else:
|
else:
|
||||||
if self._end:
|
if self._end:
|
||||||
break
|
break
|
||||||
|
|
||||||
split_buffer = buffer.split(b"\r\n")
|
split_buffer = buffer.split(b"\r\n")
|
||||||
buffer = b""
|
buffer = b""
|
||||||
if split_buffer[-1]:
|
if split_buffer[-1]:
|
||||||
# Incomplete line, add it back to the buffer.
|
# Incomplete line, add it back to the buffer.
|
||||||
buffer = split_buffer.pop()
|
buffer = split_buffer.pop()
|
||||||
|
|
||||||
for line in split_buffer:
|
for line in split_buffer:
|
||||||
line = line.decode(encoding="utf-8", errors="replace")
|
line = line.decode(encoding="utf-8", errors="replace")
|
||||||
tags, prefix, command, args = parse_irc_line(line)
|
tags, prefix, command, args = parse_irc_line(line)
|
||||||
|
@ -214,7 +211,6 @@ class PesterIRC(QtCore.QThread):
|
||||||
self._run_command(command, prefix, tags, *args)
|
self._run_command(command, prefix, tags, *args)
|
||||||
else:
|
else:
|
||||||
self._run_command(command, prefix, *args)
|
self._run_command(command, prefix, *args)
|
||||||
|
|
||||||
yield True
|
yield True
|
||||||
except OSError as socket_exception:
|
except OSError as socket_exception:
|
||||||
PchumLog.warning(
|
PchumLog.warning(
|
||||||
|
@ -271,9 +267,9 @@ class PesterIRC(QtCore.QThread):
|
||||||
raise e
|
raise e
|
||||||
self._conn = self._conn_generator()
|
self._conn = self._conn_generator()
|
||||||
|
|
||||||
def setConnectionBroken(self):
|
def set_connection_broken(self):
|
||||||
"""Called when the connection is broken."""
|
"""Called when the connection is broken."""
|
||||||
PchumLog.critical("setConnectionBroken() got called, disconnecting.")
|
PchumLog.critical("set_connection_broken() got called, disconnecting.")
|
||||||
self.disconnectIRC()
|
self.disconnectIRC()
|
||||||
|
|
||||||
@QtCore.pyqtSlot()
|
@QtCore.pyqtSlot()
|
||||||
|
@ -281,11 +277,10 @@ class PesterIRC(QtCore.QThread):
|
||||||
"""Get a silly scrunkler from the generator!!"""
|
"""Get a silly scrunkler from the generator!!"""
|
||||||
try:
|
try:
|
||||||
res = next(self._conn)
|
res = next(self._conn)
|
||||||
except socket.timeout as se:
|
except socket.timeout as socket_exception:
|
||||||
if self.registeredIRC:
|
if self.registered_irc:
|
||||||
return True
|
return True
|
||||||
else:
|
raise socket_exception
|
||||||
raise se
|
|
||||||
except StopIteration:
|
except StopIteration:
|
||||||
self._conn = self.conn_generator()
|
self._conn = self.conn_generator()
|
||||||
return True
|
return True
|
||||||
|
@ -304,7 +299,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
self._send_irc.metadata(chum.handle, "get", "mood")
|
self._send_irc.metadata(chum.handle, "get", "mood")
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
PchumLog.warning(e)
|
PchumLog.warning(e)
|
||||||
self.setConnectionBroken()
|
self.set_connection_broken()
|
||||||
else:
|
else:
|
||||||
# Legacy
|
# Legacy
|
||||||
PchumLog.warning(
|
PchumLog.warning(
|
||||||
|
@ -317,7 +312,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
self._send_irc.privmsg("#pesterchum", chumglub)
|
self._send_irc.privmsg("#pesterchum", chumglub)
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
PchumLog.warning(e)
|
PchumLog.warning(e)
|
||||||
self.setConnectionBroken()
|
self.set_connection_broken()
|
||||||
chumglub = "get_mood "
|
chumglub = "get_mood "
|
||||||
# No point in get_mood-ing services
|
# No point in get_mood-ing services
|
||||||
if chum.handle.casefold() not in SERVICES:
|
if chum.handle.casefold() not in SERVICES:
|
||||||
|
@ -327,7 +322,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
self._send_irc.privmsg("#pesterchum", chumglub)
|
self._send_irc.privmsg("#pesterchum", chumglub)
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
PchumLog.warning(e)
|
PchumLog.warning(e)
|
||||||
self.setConnectionBroken()
|
self.set_connection_broken()
|
||||||
|
|
||||||
@QtCore.pyqtSlot(PesterList)
|
@QtCore.pyqtSlot(PesterList)
|
||||||
def get_moods(self, chums):
|
def get_moods(self, chums):
|
||||||
|
@ -378,8 +373,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
if b: # len > 0
|
if b: # len > 0
|
||||||
return [a] + splittext([b])
|
return [a] + splittext([b])
|
||||||
return [a]
|
return [a]
|
||||||
else:
|
return l
|
||||||
return l
|
|
||||||
|
|
||||||
textl = splittext(textl)
|
textl = splittext(textl)
|
||||||
for t in textl:
|
for t in textl:
|
||||||
|
@ -593,7 +587,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
|
|
||||||
def _error(self, *params):
|
def _error(self, *params):
|
||||||
"""'ERROR' message from server, the server is terminating our connection."""
|
"""'ERROR' message from server, the server is terminating our connection."""
|
||||||
self.stopIRC = " ".join(params).strip()
|
self.stop_irc = " ".join(params).strip()
|
||||||
self.disconnectIRC()
|
self.disconnectIRC()
|
||||||
|
|
||||||
def __ctcp(self, nick: str, chan: str, msg: str):
|
def __ctcp(self, nick: str, chan: str, msg: str):
|
||||||
|
@ -805,7 +799,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
|
|
||||||
def _welcome(self, _server, _nick, _msg):
|
def _welcome(self, _server, _nick, _msg):
|
||||||
"""Numeric reply 001 RPL_WELCOME, send when we've connected to the server."""
|
"""Numeric reply 001 RPL_WELCOME, send when we've connected to the server."""
|
||||||
self.registeredIRC = (
|
self.registered_irc = (
|
||||||
True # Registered as in, the server has accepted our nick & user.
|
True # Registered as in, the server has accepted our nick & user.
|
||||||
)
|
)
|
||||||
self.connected.emit() # Alert main thread that we've connected.
|
self.connected.emit() # Alert main thread that we've connected.
|
||||||
|
@ -922,7 +916,7 @@ class PesterIRC(QtCore.QThread):
|
||||||
"""Numeric reply 432 ERR_ERRONEUSNICKNAME, we have a forbidden or protocol-breaking nick."""
|
"""Numeric reply 432 ERR_ERRONEUSNICKNAME, we have a forbidden or protocol-breaking nick."""
|
||||||
# Server is not allowing us to connect.
|
# Server is not allowing us to connect.
|
||||||
reason = "Handle is not allowed on this server.\n" + " ".join(args)
|
reason = "Handle is not allowed on this server.\n" + " ".join(args)
|
||||||
self.stopIRC = reason.strip()
|
self.stop_irc = reason.strip()
|
||||||
self.disconnectIRC()
|
self.disconnectIRC()
|
||||||
|
|
||||||
def _nicknameinuse(self, _server, _cmd, nick, _msg):
|
def _nicknameinuse(self, _server, _cmd, nick, _msg):
|
||||||
|
|
|
@ -4462,7 +4462,7 @@ class MainProgram(QtCore.QObject):
|
||||||
self.widget.loadingscreen.tryAgain.connect(self.tryAgain)
|
self.widget.loadingscreen.tryAgain.connect(self.tryAgain)
|
||||||
if (
|
if (
|
||||||
hasattr(self, "irc")
|
hasattr(self, "irc")
|
||||||
and self.irc.registeredIRC
|
and self.irc.registered_irc
|
||||||
and not self.irc.unresponsive
|
and not self.irc.unresponsive
|
||||||
):
|
):
|
||||||
return
|
return
|
||||||
|
|
|
@ -53,19 +53,3 @@ def is_valid_rgb_color(value: str):
|
||||||
if int(component) > 255:
|
if int(component) > 255:
|
||||||
return False
|
return False
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
"""
|
|
||||||
def is_valid_rgb_color(value: str):
|
|
||||||
"Returns True if an unparsed value (str) is a valid rgb color."
|
|
||||||
if re.search(_color_rgb, value):
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
def is_valid_hex_color(value: str):
|
|
||||||
"Returns True if an unparsed value (str) is a valid hex color."
|
|
||||||
if re.search(_color_hex, value):
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
"""
|
|
||||||
|
|
Loading…
Reference in a new issue