mirror of
https://github.com/Mikaela/Limnoria.git
synced 2024-12-24 03:33:11 +01:00
Changed to registry.
This commit is contained in:
parent
81009586fb
commit
215a2b3a76
@ -46,26 +46,23 @@ import ircdb
|
||||
import ircmsgs
|
||||
import plugins
|
||||
import privmsgs
|
||||
import registry
|
||||
import callbacks
|
||||
import configurable
|
||||
|
||||
class Topic(callbacks.Privmsg, configurable.Mixin):
|
||||
conf.registerPlugin('Topic')
|
||||
conf.registerChannelValue(conf.supybot.plugins.Topic, 'separator',
|
||||
registry.StringSurroundedBySpaces(' || ', """Determines what separator is
|
||||
used between individually added topics in the channel topic."""))
|
||||
|
||||
class Topic(callbacks.Privmsg):
|
||||
topicFormatter = '%s (%s)'
|
||||
topicUnformatter = re.compile('(.*) \((\S+)\)')
|
||||
configurables = configurable.Dictionary(
|
||||
[('separator', configurable.SpaceSurroundedStrType, ' || ',
|
||||
"The separator between individual topics in the channel topic.")]
|
||||
)
|
||||
def __init__(self):
|
||||
callbacks.Privmsg.__init__(self)
|
||||
configurable.Mixin.__init__(self)
|
||||
|
||||
def _splitTopic(self, topic, channel):
|
||||
separator = self.configurables.get('separator', channel)
|
||||
separator = self.registryValue('separator', channel)
|
||||
return filter(None, topic.split(separator))
|
||||
|
||||
def _joinTopic(self, topics, channel):
|
||||
separator = self.configurables.get('separator', channel)
|
||||
separator = self.registryValue('separator', channel)
|
||||
return separator.join(topics)
|
||||
|
||||
def _unformatTopic(self, topic, channel):
|
||||
@ -82,7 +79,7 @@ class Topic(callbacks.Privmsg, configurable.Mixin):
|
||||
if the message isn't sent in the channel itself.
|
||||
"""
|
||||
topic = privmsgs.getArgs(args)
|
||||
separator = self.configurables.get('separator', channel)
|
||||
separator = self.registryValue('separator', channel)
|
||||
if separator in topic:
|
||||
s = 'You can\'t have %s in your topic' % separator
|
||||
irc.error(s)
|
||||
|
@ -81,10 +81,14 @@ class TopicTestCase(ChannelPluginTestCase, PluginDocumentation):
|
||||
self.assertError('topic change 0 s/baz/biff/')
|
||||
|
||||
def testConfig(self):
|
||||
self.assertNotError('topic config separator <==>')
|
||||
_ = self.getMsg('topic add foo')
|
||||
m = self.getMsg('topic add bar')
|
||||
self.failUnless('<==>' in m.args[1])
|
||||
try:
|
||||
conf.supybot.plugins.Topic.separator.setValue(' <==> ')
|
||||
_ = self.getMsg('topic add foo')
|
||||
m = self.getMsg('topic add bar')
|
||||
self.failUnless('<==>' in m.args[1])
|
||||
finally:
|
||||
default = conf.supybot.plugins.Topic.separator.default
|
||||
conf.supybot.plugins.Topic.separator.setValue(default)
|
||||
|
||||
def testReorder(self):
|
||||
_ = self.getMsg('topic add foo')
|
||||
|
Loading…
Reference in New Issue
Block a user