diff options
author | Florent Le Coz <louiz@louiz.org> | 2011-11-09 01:23:35 +0100 |
---|---|---|
committer | Florent Le Coz <louiz@louiz.org> | 2011-11-09 01:23:35 +0100 |
commit | ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f (patch) | |
tree | 3f2bbf1be7f753f1c7495f0a60833f469e7f10a7 /plugins/link.py | |
parent | 7fadb35fe2e7932a0a4aa6a8184ab6b186669edc (diff) | |
parent | 03999f1ef08036b7ea25e2239cf7b6bcdb4d76cc (diff) | |
download | poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.tar.gz poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.tar.bz2 poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.tar.xz poezio-ad0b3b41ecc0003f3d5b4fdb9799b6e325127e1f.zip |
Merge branch 'plugins'
Conflicts:
README
src/core.py
src/tabs.py
Diffstat (limited to 'plugins/link.py')
-rw-r--r-- | plugins/link.py | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/plugins/link.py b/plugins/link.py new file mode 100644 index 00000000..8ef52982 --- /dev/null +++ b/plugins/link.py @@ -0,0 +1,47 @@ +# A plugin that adds the /link command, letting you open links that are pasted +# in the conversation, without having to click them. + +import os +import re + +from plugin import BasePlugin, PluginConfig +from xhtml import clean_text +import common + +url_pattern = re.compile(r'\b(http[s]?://(?:\S+))\b', re.I|re.U) + +class Plugin(BasePlugin): + def init(self): + self.add_command('link', self.command_link, "Usage: /link\nLink: opens the last link from the conversation into a browser.") + + def find_link(self, nb): + messages = self.core.get_conversation_messages() + if not messages: + return None + for message in messages[::-1]: + matches = url_pattern.findall(clean_text(message.txt)) + if matches: + for url in matches[::-1]: + if nb == 1: + return url + else: + nb -= 1 + return None + + def command_link(self, args): + args = common.shell_split(args) + if len(args) == 1: + try: + nb = int(args[0]) + except: + return self.core.command_help('link') + else: + nb = 1 + link = self.find_link(nb) + if link: + self.core.exec_command('%s %s' % (self.config.get('browser', 'firefox'), link)) + else: + self.core.information('No URL found.', 'Warning') + + def cleanup(self): + del self.config |