+### 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,"Modified %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' modified on %s: %s" % (a[0],a[2].isoformat(),a[1]))
+