+# Look up a currency conversion via xe.com
+def currencyq(bot, cmd, nick, conn, public):
+ args = ' '.join(cmd.split()[1:]).split(' as ')
+ if len(args) != 2 or len(args[0]) != 3 or len(args[1]) != 3:
+ conn.notice(nick, "syntax: currency arg1 as arg2")
+ return
+ targ = ("http://www.xe.com/ucc/convert.cgi?From=%s&To=%s" % (args[0], args[1]))
+ try:
+ currencypage = urllib.urlopen(targ).read()
+ match = re.search(r"(1 %s = [\d\.]+ %s)" % (args[0],args[1]),currencypage,re.MULTILINE)
+ if match == None:
+ bot.automsg(public,nick,"Dear Chief Secretary, there is no money.")
+ else:
+ conversion = match.group(1);
+ conversion = conversion.replace(' ',' ');
+ bot.automsg(public,nick,conversion + " (from xe.com)")
+ except IOError: # if the connection times out. This blocks. :(
+ bot.automsg(public,nick,"The web's broken. Waah!")
+
+
+### extract the commit message and timestamp for commit
+def __getcommitinfo(commit):
+ cmd=["git","log","-n","1","--pretty=format:%ct|%s",commit]
+ x=subprocess.Popen(cmd,
+ stdout=subprocess.PIPE,stderr=subprocess.PIPE)
+ out,err=x.communicate()
+
+ if len(err):
+ return(err)
+
+ ts,mes=out.split('|')
+ when=datetime.date.fromtimestamp(float(ts))
+ return mes.strip(), when
+
+###Return an array of commit messages and timestamps for lines in db that match what
+def __getcommits(db,keys,what):
+ ans=[]
+ for k in keys:
+ if what in k:
+ ret=__getcommitinfo(db[k])
+ if len(ret)==1: #error message
+ return ["Error message from git blame: %s" % ret]
+ else:
+ ans.append( (k,ret[0],ret[1]) )
+ return ans
+
+###search all three databases for what
+def __getall(tdb,tdbk,fdb,fdbk,sdb,sdbk,what):
+ if what.strip()=="":
+ return []
+ tans=__getcommits(tdb,tdbk,what)
+ fans=__getcommits(fdb,fdbk,what)
+ sans=__getcommits(sdb,sdbk,what)
+ return tans+fans+sans
+
+def blameq(bot,cmd,nick,conn,public,fish,tdb,tdbk,fdb,fdbk,sdb,sdbk):
+ clist=cmd.split()
+ if len(clist) < 2:
+ bot.automsg(public,nick,"Who or what do you want to blame?")
+ return
+ cwhat=' '.join(clist[2:])
+ if clist[1]=="#last":
+ ans=__getall(tdb,tdbk,fdb,fdbk,sdb,sdbk,fish.last)
+ elif clist[1]=="#trouts" or clist[1]=="#trout":
+ ans=__getcommits(tdb,tdbk,cwhat)
+ elif clist[1]=="#flirts" or clist[1]=="#flirt":
+ ans=__getcommits(fdb,fdbk,cwhat)
+ elif clist[1]=="#slashes" or clist[1]=="#slash":
+ ans=__getcommits(sdb,sdbk,cwhat)
+ else:
+ cwhat=' '.join(clist[1:])
+ ans=__getall(tdb,tdbk,fdb,fdbk,sdb,sdbk,cwhat)
+ if len(ans)==0:
+ bot.automsg(public,nick,"No match found")
+ elif len(ans)==1:
+ if len(ans[0])==1:
+ bot.automsg(public,nick,ans[0])
+ else:
+ bot.automsg(public,nick,"Added %s: %s" % (ans[0][2].isoformat(),ans[0][1]))
+ elif len(ans)>4:
+ bot.automsg(public,nick,"I found %d matches, which is too many. Please be more specific!" % (len(ans)) )
+ else:
+ for a in ans:
+ if len(a)==1:
+ bot.automsg(public,nick,a)
+ else:
+ bot.automsg(public,nick,"'%s' added on %s: %s" % (a[0],a[2].isoformat(),a[1]))
+