import re from datetime import timedelta from PyQt4 import QtGui _ctag_begin = re.compile(r'') _ctag_rgb = re.compile(r'\d+,\d+,\d+') _urlre = re.compile(r"(?i)(http://[^\s<]+)") _memore = re.compile(r" (#[A-Za-z0-9_]+)") def convertTags(string, format="html"): if format not in ["html", "bbcode", "ctag"]: raise ValueError("Color format not recognized") def colorrepfunc(matchobj): color = matchobj.group(1) if _ctag_rgb.match(color) is not None: if format=='ctag': return "" % (color) try: qc = QtGui.QColor(*[int(c) for c in color.split(",")]) except ValueError: qc = QtGui.QColor("black") else: qc = QtGui.QColor(color) if not qc.isValid(): qc = QtGui.QColor("black") if format == "html": return '' % (qc.name()) elif format == "bbcode": return '[color=%s]' % (qc.name()) elif format == "ctag": (r,g,b,a) = qc.getRgb() return '' % (r,g,b) string = _ctag_begin.sub(colorrepfunc, string) endtag = {"html": "", "bbcode": "[/color]", "ctag": ""} string = string.replace("", endtag[format]) def urlrep(matchobj): if format=="html": return "%s" % (matchobj.group(1).replace("&", "&"), matchobj.group(1)) elif format=="bbcode": return "[url]%s[/url]" % (matchobj.group(1).replace("&", "&")) elif format=="ctag": return matchobj.group(1) string = _urlre.sub(urlrep, string) if format == "html": string = _memore.sub(r" \1", string) string = string.replace(" :trollcool:", " " % ("themes/pesterchum/trollcool.gif")) # ugh hardcoded, gross i know. but its just 1 smiley elif format == "bbcode": string = string.replace(" :trollcool:", " [img]http://www.mspaintadventures.com/storyfiles/hs2/scraps/trollcool.gif[/img]") return string def escapeBrackets(string): class beginTag(object): def __init__(self, tag): self.tag = tag class endTag(object): pass newlist = [] begintagpos = [(m.start(), m.end()) for m in _ctag_begin.finditer(string)] lasti = 0 for (s, e) in begintagpos: newlist.append(string[lasti:s]) newlist.append(beginTag(string[s:e])) lasti = e if lasti < len(string): newlist.append(string[lasti:]) tmp = [] for o in newlist: if type(o) is not beginTag: l = o.split("") tmp.append(l[0]) l = l[1:] for item in l: tmp.append(endTag()) tmp.append(item) else: tmp.append(o) btlen = 0 etlen = 0 retval = "" newlist = tmp for o in newlist: if type(o) is beginTag: retval += o.tag.replace("&", "&") btlen +=1 elif type(o) is endTag: if etlen >= btlen: continue else: retval += "" etlen += 1 else: retval += o.replace("&", "&").replace("<", "<").replace(">", ">") if btlen > etlen: for i in range(0, btlen-etlen): retval += "" return retval def addTimeInitial(string, grammar): endofi = string.find(":") endoftag = string.find(">") if endoftag < 0 or endoftag > 16 or endofi > 17: return string return string[0:endoftag+1]+grammar.pcf+string[endoftag+1:endofi]+grammar.number+string[endofi:] def timeProtocol(cmd): dir = cmd[0] cmd = cmd[1:] cmd = re.sub("[^0-9:]", "", cmd) try: l = [int(x) for x in cmd.split(":")] except ValueError: l = [0,0] timed = timedelta(0, l[0]*3600+l[1]*60) if dir == "P": timed = timed*-1 return timed def timeDifference(td): if td < timedelta(0): when = "AGO" else: when = "FROM NOW" atd = abs(td) minutes = (atd.days*86400 + atd.seconds) // 60 hours = minutes // 60 leftoverminutes = minutes % 60 if atd == timedelta(0): timetext = "RIGHT NOW" elif atd < timedelta(0,3600): if minutes == 1: timetext = "%d MINUTE %s" % (minutes, when) else: timetext = "%d MINUTES %s" % (minutes, when) elif atd < timedelta(0,3600*100): if hours == 1 and leftoverminutes == 0: timetext = "%d:%02d HOUR %s" % (hours, leftoverminutes, when) else: timetext = "%d:%02d HOURS %s" % (hours, leftoverminutes, when) else: timetext = "%d HOURS %s" % (hours, when) return timetext