From 1ff6b40e200cbfa9417707d83b036c49a4805cca Mon Sep 17 00:00:00 2001 From: Eijebong Date: Tue, 21 Oct 2014 01:05:11 +0200 Subject: [PATCH] The quote plugin now uses full messages instead of timestamps. --- plugins/quote.py | 72 +++++++++++++++++------------------------------- 1 file changed, 25 insertions(+), 47 deletions(-) diff --git a/plugins/quote.py b/plugins/quote.py index 8a4fd95c..ab503dc1 100644 --- a/plugins/quote.py +++ b/plugins/quote.py @@ -7,18 +7,19 @@ Usage .. glossary:: /quote - **Usage:** ``/quote `` + **Usage:** ``/quote `` - Timestamp is in ``HH:MM:SS`` format, and can be completed with [tab]. + The message must exist. You can use autocompletion to get the message + you want to quote easily. Example: .. code-block:: none - /quote 21:12:23 + /quote "Pouet" - If there is a message at 21:12:23, it will be put in the input. If there - isn’t, you will get a warning. + If the message "Pouet" exists, it will be put in the input. If not you + will get a warning. Options ------- @@ -42,14 +43,11 @@ Options be used to insert the nick of the user who sent the message or the time of the message. """ + from plugin import BasePlugin from xhtml import clean_text import common import tabs -import re - -timestamp_re = re.compile(r'^(\d\d\d\d-\d\d-\d\d )?\d\d:\d\d:\d\d$') -seconds_re = re.compile(r'^:\d\d$') import logging log = logging.getLogger(__name__) @@ -58,20 +56,18 @@ class Plugin(BasePlugin): def init(self): for _class in (tabs.MucTab, tabs.ConversationTab, tabs.PrivateTab): self.api.add_tab_command(_class, 'quote', self.command_quote, - usage='', - help='Takes the message received at and insert it in the input, to quote it.', - short='Quote a message from a timestamp', + usage='', + help='Quote the message you typed if it exists.', + short='Quote a message.', completion=self.completion_quote) def command_quote(self, args): args = common.shell_split(args) - if len(args) in (1, 2): - timestamp = args[-1] + if len(args) == 1: + message = args[-1] else: return self.api.run_command('/help quote') - if re.match(timestamp_re, timestamp) is None: - return self.api.information('Timestamp has a wrong format.', 'Warning') - message = self.find_message_with_timestamp(timestamp) + message = self.find_message(message) if message: before = self.config.get('before_quote', '') % {'nick': message.nickname or '', 'time': message.str_time} @@ -81,47 +77,29 @@ class Plugin(BasePlugin): 'quote': clean_text(message.txt), 'after': after.replace('\\n', '\n').replace('[SP]', ' ')}) else: - self.api.information('No message found for timestamp %s.' % timestamp, 'Warning') + self.api.information('No message found', 'Warning') - def find_message_with_timestamp(self, timestamp): - # TODO: handle messages with the same - # timestamp but not the same day + def find_message(self, txt): messages = self.api.get_conversation_messages() if not messages: return None for message in messages[::-1]: - if message.str_time == timestamp: + if clean_text(message.txt) == txt: return message return None def completion_quote(self, the_input): - def nick_match(msg): - if not msg.nickname: - return nick == '' - return msg.nickname.lower().startswith(nick.lower()) - def time_match(msg): - return msg.str_time.endswith(time) + def message_match(msg): + return input_message.lower() in clean_text(msg.txt).lower() messages = self.api.get_conversation_messages() if not messages: return text = the_input.get_text() args = common.shell_split(text) - n = len(args) - if text.endswith(' '): - n += 1 - time = args[-1] - if re.match(seconds_re, time) is not None: - messages = list(filter(time_match, messages)) - for i in range(3): - the_input.key_backspace(False) - elif n == 2: - try: - if args[1][0] not in ('1', '2', '3', '4', '5', '6', '7', '8', '9', '0'): - return False - except: - pass - nick = '' - if n == 3: - nick = args[1] - messages = list(filter(nick_match, messages)) - return the_input.auto_completion([msg.str_time for msg in messages[::-1]], '') + if not text.endswith(' '): + input_message = args[-1] + messages = list(filter(message_match, messages)) + elif len(args) > 1: + return False + return the_input.auto_completion([clean_text(msg.txt) for msg in messages[::-1]], '') +