Only put a ":" on trailing args when it's required
This commit is contained in:
parent
01a7c05687
commit
86bc49a0a1
2 changed files with 27 additions and 13 deletions
|
@ -257,7 +257,8 @@ class Server(IRCObject.Object):
|
||||||
self.events.on("raw.send").call_unsafe(server=self, line=line)
|
self.events.on("raw.send").call_unsafe(server=self, line=line)
|
||||||
|
|
||||||
def send_user(self, username: str, realname: str) -> IRCLine.Line:
|
def send_user(self, username: str, realname: str) -> IRCLine.Line:
|
||||||
return self.send("USER %s 0 * :%s" % (username, realname))
|
return self.send("USER %s 0 * %s" %
|
||||||
|
(username, utils.irc.trailing(realname)))
|
||||||
def send_nick(self, nickname: str) -> IRCLine.Line:
|
def send_nick(self, nickname: str) -> IRCLine.Line:
|
||||||
return self.send("NICK %s" % nickname)
|
return self.send("NICK %s" % nickname)
|
||||||
|
|
||||||
|
@ -276,7 +277,7 @@ class Server(IRCObject.Object):
|
||||||
def has_capability_queue(self):
|
def has_capability_queue(self):
|
||||||
return bool(len(self._capability_queue))
|
return bool(len(self._capability_queue))
|
||||||
def send_capability_request(self, capability: str) -> IRCLine.Line:
|
def send_capability_request(self, capability: str) -> IRCLine.Line:
|
||||||
return self.send("CAP REQ :%s" % capability)
|
return self.send("CAP REQ %s" % utils.irc.trailing(capability))
|
||||||
def send_capability_end(self) -> IRCLine.Line:
|
def send_capability_end(self) -> IRCLine.Line:
|
||||||
return self.send("CAP END")
|
return self.send("CAP END")
|
||||||
def send_authenticate(self, text: str) -> IRCLine.Line:
|
def send_authenticate(self, text: str) -> IRCLine.Line:
|
||||||
|
@ -295,9 +296,9 @@ class Server(IRCObject.Object):
|
||||||
return self.send("PASS %s" % password)
|
return self.send("PASS %s" % password)
|
||||||
|
|
||||||
def send_ping(self, nonce: str="hello") -> IRCLine.Line:
|
def send_ping(self, nonce: str="hello") -> IRCLine.Line:
|
||||||
return self.send("PING :%s" % nonce)
|
return self.send("PING %s" % utils.irc.trailing(nonce))
|
||||||
def send_pong(self, nonce: str="hello") -> IRCLine.Line:
|
def send_pong(self, nonce: str="hello") -> IRCLine.Line:
|
||||||
return self.send("PONG :%s" % nonce)
|
return self.send("PONG %s" % utils.irc.trailing(nonce))
|
||||||
|
|
||||||
def try_rejoin(self, event: EventManager.Event):
|
def try_rejoin(self, event: EventManager.Event):
|
||||||
if event["server_id"] == self.id and event["channel_name"
|
if event["server_id"] == self.id and event["channel_name"
|
||||||
|
@ -310,7 +311,7 @@ class Server(IRCObject.Object):
|
||||||
return self.send("PART %s%s" % (channel_name,
|
return self.send("PART %s%s" % (channel_name,
|
||||||
"" if reason == None else " %s" % reason))
|
"" if reason == None else " %s" % reason))
|
||||||
def send_quit(self, reason: str="Leaving") -> IRCLine.Line:
|
def send_quit(self, reason: str="Leaving") -> IRCLine.Line:
|
||||||
return self.send("QUIT :%s" % reason)
|
return self.send("QUIT %s" % utils.irc.trailing(reason))
|
||||||
|
|
||||||
def _tag_str(self, tags: dict) -> str:
|
def _tag_str(self, tags: dict) -> str:
|
||||||
tag_str = ""
|
tag_str = ""
|
||||||
|
@ -327,14 +328,14 @@ class Server(IRCObject.Object):
|
||||||
def send_message(self, target: str, message: str, prefix: str=None,
|
def send_message(self, target: str, message: str, prefix: str=None,
|
||||||
tags: dict={}) -> IRCLine.Line:
|
tags: dict={}) -> IRCLine.Line:
|
||||||
full_message = message if not prefix else prefix+message
|
full_message = message if not prefix else prefix+message
|
||||||
return self.send("%sPRIVMSG %s :%s" % (self._tag_str(tags), target,
|
return self.send("%sPRIVMSG %s %s" %
|
||||||
full_message))
|
(self._tag_str(tags), target, utils.irc.trailing(full_message)))
|
||||||
|
|
||||||
def send_notice(self, target: str, message: str, prefix: str=None,
|
def send_notice(self, target: str, message: str, prefix: str=None,
|
||||||
tags: dict={}) -> IRCLine.Line:
|
tags: dict={}) -> IRCLine.Line:
|
||||||
full_message = message if not prefix else prefix+message
|
full_message = message if not prefix else prefix+message
|
||||||
return self.send("%sNOTICE %s :%s" % (self._tag_str(tags), target,
|
return self.send("%sNOTICE %s %s" %
|
||||||
full_message))
|
(self._tag_str(tags), target, utils.irc.trailing(full_message)))
|
||||||
|
|
||||||
def send_mode(self, target: str, mode: str=None, args: str=None
|
def send_mode(self, target: str, mode: str=None, args: str=None
|
||||||
) -> IRCLine.Line:
|
) -> IRCLine.Line:
|
||||||
|
@ -343,11 +344,14 @@ class Server(IRCObject.Object):
|
||||||
"" if args == None else " %s" % args))
|
"" if args == None else " %s" % args))
|
||||||
|
|
||||||
def send_topic(self, channel_name: str, topic: str) -> IRCLine.Line:
|
def send_topic(self, channel_name: str, topic: str) -> IRCLine.Line:
|
||||||
return self.send("TOPIC %s :%s" % (channel_name, topic))
|
return self.send("TOPIC %s %s" %
|
||||||
|
(channel_name, utils.irc.trailing(topic)))
|
||||||
def send_kick(self, channel_name: str, target: str, reason: str=None
|
def send_kick(self, channel_name: str, target: str, reason: str=None
|
||||||
) -> IRCLine.Line:
|
) -> IRCLine.Line:
|
||||||
return self.send("KICK %s %s%s" % (channel_name, target,
|
reason = ""
|
||||||
"" if reason == None else " :%s" % reason))
|
if not reason == None:
|
||||||
|
reason = " %s" % utils.irc.trailing(typing.cast(str, reason))
|
||||||
|
return self.send("KICK %s %s%s" % (channel_name, target, reason))
|
||||||
def send_names(self, channel_name: str) -> IRCLine.Line:
|
def send_names(self, channel_name: str) -> IRCLine.Line:
|
||||||
return self.send("NAMES %s" % channel_name)
|
return self.send("NAMES %s" % channel_name)
|
||||||
def send_list(self, search_for: str=None) -> IRCLine.Line:
|
def send_list(self, search_for: str=None) -> IRCLine.Line:
|
||||||
|
@ -360,9 +364,13 @@ class Server(IRCObject.Object):
|
||||||
return self.send("WHOIS %s" % target)
|
return self.send("WHOIS %s" % target)
|
||||||
def send_whowas(self, target: str, amount: int=None, server: str=None
|
def send_whowas(self, target: str, amount: int=None, server: str=None
|
||||||
) -> IRCLine.Line:
|
) -> IRCLine.Line:
|
||||||
|
server = ""
|
||||||
|
if not server == None:
|
||||||
|
server = " %s" % utils.irc.trailing(typing.cast(str, server))
|
||||||
|
|
||||||
return self.send("WHOWAS %s%s%s" % (target,
|
return self.send("WHOWAS %s%s%s" % (target,
|
||||||
"" if amount == None else " %s" % amount,
|
"" if amount == None else " %s" % amount,
|
||||||
"" if server == None else " :%s" % server))
|
"" if server == None else " %s" % utils.irc.trailing(server)))
|
||||||
def send_who(self, filter: str=None) -> IRCLine.Line:
|
def send_who(self, filter: str=None) -> IRCLine.Line:
|
||||||
return self.send("WHO%s" % ("" if filter == None else " %s" % filter))
|
return self.send("WHO%s" % ("" if filter == None else " %s" % filter))
|
||||||
def send_whox(self, mask: str, filter: str, fields: str, label: str=None
|
def send_whox(self, mask: str, filter: str, fields: str, label: str=None
|
||||||
|
|
|
@ -293,3 +293,9 @@ class IRCBatch(object):
|
||||||
self.type = batch_type
|
self.type = batch_type
|
||||||
self.tags = tags
|
self.tags = tags
|
||||||
self.lines = [] # type: typing.List[IRCParsedLine]
|
self.lines = [] # type: typing.List[IRCParsedLine]
|
||||||
|
|
||||||
|
def trailing(s: str) -> str:
|
||||||
|
if s[0] == ":" or " " in s:
|
||||||
|
return ":%s" % s
|
||||||
|
else:
|
||||||
|
return s
|
||||||
|
|
Loading…
Reference in a new issue