mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-12 05:02:32 +01:00
Try to make network stuff case-insensitive.
This commit is contained in:
parent
570b3024c2
commit
1c737a4c8f
44
src/Owner.py
44
src/Owner.py
@ -220,6 +220,13 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
continue
|
continue
|
||||||
registerDefaultPlugin(name, s)
|
registerDefaultPlugin(name, s)
|
||||||
|
|
||||||
|
def _getIrc(self, network):
|
||||||
|
network = network.lower()
|
||||||
|
for irc in world.ircs:
|
||||||
|
if irc.network.lower() == network:
|
||||||
|
return irc
|
||||||
|
return None
|
||||||
|
|
||||||
def outFilter(self, irc, msg):
|
def outFilter(self, irc, msg):
|
||||||
if msg.command == 'PRIVMSG' and not world.testing:
|
if msg.command == 'PRIVMSG' and not world.testing:
|
||||||
if ircutils.strEqual(msg.args[0], irc.nick):
|
if ircutils.strEqual(msg.args[0], irc.nick):
|
||||||
@ -652,12 +659,23 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
irc.error('There was no plugin %s.' % name)
|
irc.error('There was no plugin %s.' % name)
|
||||||
|
|
||||||
def reconnect(self, irc, msg, args):
|
def reconnect(self, irc, msg, args):
|
||||||
"""takes no arguments
|
"""[<network>]
|
||||||
|
|
||||||
Disconnects and then reconnects to the current network.
|
Disconnects and then reconnects to <network>. If no network is given,
|
||||||
|
disconnects and then reconnects to the network the command was given
|
||||||
|
on.
|
||||||
"""
|
"""
|
||||||
|
network = privmsgs.getArgs(args, required=0, optional=1)
|
||||||
|
if network:
|
||||||
|
badIrc = self._getIrc(network)
|
||||||
|
if badIrc is None:
|
||||||
|
irc.error('I\'m not currently connected on %s.' % network)
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
badIrc = irc
|
||||||
try:
|
try:
|
||||||
irc.driver.reconnect()
|
badIrc.driver.reconnect()
|
||||||
|
if badIrc != irc:
|
||||||
irc.replySuccess()
|
irc.replySuccess()
|
||||||
except AttributeError: # There's a cleaner way to do this, but I'm lazy.
|
except AttributeError: # There's a cleaner way to do this, but I'm lazy.
|
||||||
irc.error('I couldn\'t reconnect. You should restart me instead.')
|
irc.error('I couldn\'t reconnect. You should restart me instead.')
|
||||||
@ -786,8 +804,8 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
defaults to 6667, the default port for IRC.
|
defaults to 6667, the default port for IRC.
|
||||||
"""
|
"""
|
||||||
(network, server) = privmsgs.getArgs(args, optional=1)
|
(network, server) = privmsgs.getArgs(args, optional=1)
|
||||||
for otherIrc in world.ircs:
|
otherIrc = self._getIrc(network)
|
||||||
if otherIrc.network == network:
|
if otherIrc is not None:
|
||||||
irc.error('I\'m already connected to %s.' % network)
|
irc.error('I\'m already connected to %s.' % network)
|
||||||
return
|
return
|
||||||
if server:
|
if server:
|
||||||
@ -806,7 +824,7 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
return
|
return
|
||||||
newIrc = self._connect(network, serverPort=serverPort)
|
newIrc = self._connect(network, serverPort=serverPort)
|
||||||
conf.supybot.networks().add(network)
|
conf.supybot.networks().add(network)
|
||||||
assert newIrc.callbacks == irc.callbacks, 'callbacks list is different'
|
assert newIrc.callbacks is irc.callbacks, 'callbacks list is different'
|
||||||
irc.replySuccess()
|
irc.replySuccess()
|
||||||
|
|
||||||
def disconnect(self, irc, msg, args):
|
def disconnect(self, irc, msg, args):
|
||||||
@ -819,23 +837,19 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
(network, quitMsg) = privmsgs.getArgs(args, optional=1)
|
(network, quitMsg) = privmsgs.getArgs(args, optional=1)
|
||||||
if not quitMsg:
|
if not quitMsg:
|
||||||
quitMsg = msg.nick
|
quitMsg = msg.nick
|
||||||
for otherIrc in world.ircs:
|
otherIrc = self._getIrc(network)
|
||||||
if otherIrc.network == network:
|
if otherIrc is not None:
|
||||||
# Here, rather than lower, in case we're being told to
|
# replySuccess here, rather than lower, in case we're being
|
||||||
# disconnect from the network we received the command on.
|
# told to disconnect from the network we received the command on.
|
||||||
irc.replySuccess()
|
irc.replySuccess()
|
||||||
otherIrc.queueMsg(ircmsgs.quit(quitMsg))
|
otherIrc.queueMsg(ircmsgs.quit(quitMsg))
|
||||||
otherIrc.die()
|
otherIrc.die()
|
||||||
break
|
|
||||||
else:
|
else:
|
||||||
irc.error('I\'m not connected to %s.' % network, Raise=True)
|
irc.error('I\'m not connected to %s.' % network, Raise=True)
|
||||||
conf.supybot.networks().remove(network)
|
conf.supybot.networks().discard(network)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Class = Owner
|
Class = Owner
|
||||||
|
|
||||||
|
|
||||||
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user