diff --git a/ircbot/modules/TextTransform.py b/ircbot/modules/TextTransform.py deleted file mode 100644 index e9cda19..0000000 --- a/ircbot/modules/TextTransform.py +++ /dev/null @@ -1,137 +0,0 @@ -""" -TextTransform - assorted text transformations (e.g. rot13) -Copyright (C) 2010 Brian S. Stephan - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation, either version 3 of the License, or -(at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with this program. If not, see . -""" - -import base64 -import re - -from Module import Module - -class TextTransform(Module): - """ - Do a number of text transformations, like rot13. - """ - - def do(self, connection, event, nick, userhost, what, admin_unlocked): - """ - Pass the real work on to one of our methods and see if any bite. - """ - - # if the caller replied, this will be the reply and they'll have returned true - reply = [''] - - if self.rot13(what, reply): - return self.irc.reply(event, reply[0]) - elif self.base64(what, reply): - return self.irc.reply(event, reply[0]) - elif self.upper(what, reply): - return self.irc.reply(event, reply[0]) - elif self.lower(what, reply): - return self.irc.reply(event, reply[0]) - elif self.al_bhed(what, reply): - return self.irc.reply(event, reply[0]) - - def rot13(self, what, reply): - """ - Apply a rot13 method to the text if first word is 'rot13'. - """ - - match = re.search('^!rot13\s+(.*)$', what) - if match: - text = match.group(1) - reply[0] = text.encode('rot13', 'ignore') - return True - - def base64(self, what, reply): - """ - Encode/decode base64 string. - """ - - match = re.search('^!base64\s+encode\s+(.*)$', what) - if match: - text = match.group(1) - reply[0] = base64.encodestring(text).replace('\n','') - return True - - match = re.search('^!base64\s+decode\s+(.*)$', what) - if match: - text = match.group(1) - reply[0] = base64.decodestring(text).replace('\n','') - return True - - def upper(self, what, reply): - """ - Convert a string to uppercase. - """ - - match = re.search('^!upper\s+(.*)$', what) - if match: - text = match.group(1) - reply[0] = text.upper() - return True - - def lower(self, what, reply): - """ - Convert a string to lowercase. - """ - - match = re.search('^!lower\s+(.*)$', what) - if match: - text = match.group(1) - reply[0] = text.lower() - return True - - def al_bhed(self, what, reply): - """ - Convert a string to al bhed. - """ - - cipher = {'A':'Y','B':'P','C':'L','D':'T','E':'A','F':'V','G':'K','H':'R','I':'E','J':'Z','K':'G','L':'M','M':'S','N':'H','O':'U','P':'B','Q':'X','R':'N','S':'C','T':'D','U':'I','V':'J','W':'F','X':'Q','Y':'O','Z':'W'} - decipher = dict([(v,k) for (k,v) in cipher.iteritems()]) - - match = re.search('^!al-bhed\s+(.*)$', what) - if match: - text = match.group(1) - trans = [] - for i in range(len(text)): - if text[i] in cipher: - trans.append(cipher[text[i]]) - elif text[i].upper() in cipher: - trans.append(cipher[text[i].upper()].lower()) - else: - trans.append(text[i]) - - reply[0] = "".join(trans) - return True - - match = re.search('^!deal-bhed\s+(.*)$', what) - if match: - text = match.group(1) - trans = [] - for i in range(len(text)): - if text[i] in decipher: - trans.append(decipher[text[i]]) - elif text[i].upper() in cipher: - trans.append(decipher[text[i].upper()].lower()) - else: - trans.append(text[i]) - - reply[0] = "".join(trans) - return True - -# vi:tabstop=4:expandtab:autoindent -# kate: indent-mode python;indent-width 4;replace-tabs on;