remove last quote if none is provided in !qdel
This commit is contained in:
parent
ab45c65fb4
commit
d3f09c5618
1 changed files with 23 additions and 13 deletions
|
@ -62,23 +62,33 @@ class Module(ModuleManager.BaseModule):
|
|||
:usage: <category> = <quote>
|
||||
"""
|
||||
category, remove_quote = self.category_and_quote(event["args"])
|
||||
remove_quote_lower = remove_quote.lower()
|
||||
if category and remove_quote:
|
||||
category = category or event["args"].strip()
|
||||
|
||||
message = None
|
||||
setting = "quotes-%s" % category
|
||||
quotes = event["server"].get_setting(setting, [])
|
||||
removed = False
|
||||
|
||||
if not quotes:
|
||||
raise utils.EventError("Quote category '%s' not found" %
|
||||
category)
|
||||
|
||||
if not remove_quote == None:
|
||||
remove_quote_lower = remove_quote.lower()
|
||||
for nickname, time_added, quote in quotes[:]:
|
||||
if quote.lower() == remove_quote_lower:
|
||||
quotes.remove([nickname, time_added, quote])
|
||||
removed = True
|
||||
if removed:
|
||||
message = "Removed quote from '%s'"
|
||||
break
|
||||
else:
|
||||
if quotes:
|
||||
quotes.pop(-1)
|
||||
message = "Removed last '%s' quote"
|
||||
|
||||
if not message == None:
|
||||
event["server"].set_setting(setting, quotes)
|
||||
event["stdout"].write("Removed quote")
|
||||
event["stdout"].write(message % category)
|
||||
else:
|
||||
event["stderr"].write("Quote not found")
|
||||
else:
|
||||
event["stderr"].write("Please provide a category and a quote "
|
||||
"to remove")
|
||||
|
||||
@utils.hook("received.command.q", alias_of="quote")
|
||||
@utils.hook("received.command.quote", min_args=1)
|
||||
|
|
Loading…
Reference in a new issue