2008-12-06 11:08:07 +01:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
#Copyright 2008 Steffen Jobbagy-Felso
|
|
|
|
#This program is free software: you can redistribute it and/or modify
|
|
|
|
#it under the terms of the GNU Affero General Public License as published by
|
|
|
|
#the Free Software Foundation, version 3 of the License.
|
|
|
|
#
|
|
|
|
#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 Affero General Public License
|
|
|
|
#along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#In the "official" distribution you can find the license in
|
|
|
|
#agpl-3.0.txt in the docs folder of the package.
|
|
|
|
|
|
|
|
import threading
|
|
|
|
import pygtk
|
|
|
|
pygtk.require('2.0')
|
|
|
|
import gtk
|
|
|
|
import os
|
|
|
|
|
|
|
|
import fpdb_import
|
|
|
|
import fpdb_db
|
2009-04-11 14:07:50 +02:00
|
|
|
import Filters
|
2008-12-06 11:08:07 +01:00
|
|
|
import FpdbSQLQueries
|
|
|
|
|
|
|
|
class GuiPlayerStats (threading.Thread):
|
2009-05-02 22:39:48 +02:00
|
|
|
def __init__(self, config, querylist, debug=True):
|
2008-12-06 11:08:07 +01:00
|
|
|
self.debug=debug
|
|
|
|
self.conf=config
|
2009-05-05 00:14:33 +02:00
|
|
|
self.MYSQL_INNODB = 2
|
|
|
|
self.PGSQL = 3
|
|
|
|
self.SQLITE = 4
|
2008-12-18 00:03:17 +01:00
|
|
|
|
|
|
|
# create new db connection to avoid conflicts with other threads
|
2009-04-11 14:07:50 +02:00
|
|
|
self.db = fpdb_db.fpdb_db()
|
|
|
|
self.db.do_connect(self.conf)
|
|
|
|
self.cursor=self.db.cursor
|
2008-12-06 11:08:07 +01:00
|
|
|
self.sql = querylist
|
|
|
|
|
2009-04-11 14:07:50 +02:00
|
|
|
settings = {}
|
|
|
|
settings.update(config.get_db_parameters())
|
|
|
|
settings.update(config.get_tv_parameters())
|
|
|
|
settings.update(config.get_import_parameters())
|
|
|
|
settings.update(config.get_default_paths())
|
|
|
|
|
2009-05-05 00:14:33 +02:00
|
|
|
filters_display = { "Heroes" : True,
|
|
|
|
"Sites" : True,
|
|
|
|
"Games" : False,
|
|
|
|
"Limits" : True,
|
|
|
|
"LimitSep" : True,
|
|
|
|
"Dates" : False,
|
|
|
|
"Button1" : True,
|
|
|
|
"Button2" : False
|
2009-04-17 06:44:43 +02:00
|
|
|
}
|
|
|
|
|
2009-05-02 22:39:48 +02:00
|
|
|
self.filters = Filters.Filters(self.db, settings, config, querylist, display = filters_display)
|
2009-05-05 00:14:33 +02:00
|
|
|
self.filters.registerButton1Name("Refresh")
|
|
|
|
self.filters.registerButton1Callback(self.refreshStats)
|
2008-12-07 09:06:01 +01:00
|
|
|
|
2008-12-06 12:50:06 +01:00
|
|
|
self.stat_table = None
|
|
|
|
self.stats_frame = None
|
2008-12-06 11:08:07 +01:00
|
|
|
|
|
|
|
self.main_hbox = gtk.HBox(False, 0)
|
|
|
|
self.main_hbox.show()
|
|
|
|
|
|
|
|
statsFrame = gtk.Frame("Stats:")
|
|
|
|
statsFrame.set_label_align(0.0, 0.0)
|
|
|
|
statsFrame.show()
|
2008-12-07 09:06:01 +01:00
|
|
|
self.stats_frame = gtk.VBox(False, 0)
|
|
|
|
self.stats_frame.show()
|
2008-12-06 11:08:07 +01:00
|
|
|
|
2008-12-07 09:06:01 +01:00
|
|
|
self.fillStatsFrame(self.stats_frame)
|
|
|
|
statsFrame.add(self.stats_frame)
|
2008-12-06 11:08:07 +01:00
|
|
|
|
2009-04-11 14:07:50 +02:00
|
|
|
self.main_hbox.pack_start(self.filters.get_vbox())
|
2008-12-06 11:08:07 +01:00
|
|
|
self.main_hbox.pack_start(statsFrame)
|
|
|
|
|
2009-04-11 14:07:50 +02:00
|
|
|
def get_vbox(self):
|
|
|
|
"""returns the vbox of this thread"""
|
|
|
|
return self.main_hbox
|
|
|
|
|
|
|
|
def refreshStats(self, widget, data):
|
|
|
|
try: self.stats_table.destroy()
|
|
|
|
except AttributeError: pass
|
|
|
|
self.fillStatsFrame(self.stats_frame)
|
|
|
|
|
|
|
|
def fillStatsFrame(self, vbox):
|
|
|
|
sites = self.filters.getSites()
|
|
|
|
heroes = self.filters.getHeroes()
|
|
|
|
siteids = self.filters.getSiteIds()
|
2009-05-05 00:14:33 +02:00
|
|
|
limits = self.filters.getLimits()
|
2009-04-11 14:07:50 +02:00
|
|
|
sitenos = []
|
|
|
|
playerids = []
|
|
|
|
|
|
|
|
# Which sites are selected?
|
|
|
|
for site in sites:
|
|
|
|
if sites[site] == True:
|
|
|
|
sitenos.append(siteids[site])
|
|
|
|
self.cursor.execute(self.sql.query['getPlayerId'], (heroes[site],))
|
|
|
|
result = self.db.cursor.fetchall()
|
|
|
|
if len(result) == 1:
|
|
|
|
playerids.append(result[0][0])
|
|
|
|
|
|
|
|
if not sitenos:
|
|
|
|
#Should probably pop up here.
|
|
|
|
print "No sites selected - defaulting to PokerStars"
|
|
|
|
sitenos = [2]
|
|
|
|
if not playerids:
|
|
|
|
print "No player ids found"
|
|
|
|
return
|
2009-05-05 00:14:33 +02:00
|
|
|
if not limits:
|
|
|
|
print "No limits found"
|
|
|
|
return
|
2009-04-11 14:07:50 +02:00
|
|
|
|
2009-05-05 00:14:33 +02:00
|
|
|
self.createStatsTable(vbox, playerids, sitenos, limits)
|
2009-04-11 14:07:50 +02:00
|
|
|
|
2009-05-05 00:14:33 +02:00
|
|
|
def createStatsTable(self, vbox, playerids, sitenos, limits):
|
2009-04-11 14:07:50 +02:00
|
|
|
tmp = self.sql.query['playerStats']
|
2009-05-05 00:14:33 +02:00
|
|
|
tmp = self.refineQuery(tmp, playerids, sitenos, limits)
|
2009-04-11 14:07:50 +02:00
|
|
|
self.cursor.execute(tmp)
|
|
|
|
result = self.cursor.fetchall()
|
2009-05-04 03:10:05 +02:00
|
|
|
cols = 18
|
2009-04-11 14:07:50 +02:00
|
|
|
rows = len(result)+1 # +1 for title row
|
|
|
|
self.stats_table = gtk.Table(rows, cols, False)
|
|
|
|
self.stats_table.set_col_spacings(4)
|
|
|
|
self.stats_table.show()
|
|
|
|
vbox.add(self.stats_table)
|
|
|
|
|
|
|
|
# Create header row
|
2009-05-04 03:10:05 +02:00
|
|
|
titles = ("Game", "Hands", "VPIP", "PFR", "PF3", "Steals", "Saw_F", "SawSD", "WtSDwsF", "W$SD", "FlAFq", "TuAFq", "RvAFq", "PoFAFq", "Net($)", "BB/100", "$/hand", "Variance")
|
2009-04-11 14:07:50 +02:00
|
|
|
|
|
|
|
col = 0
|
|
|
|
row = 0
|
|
|
|
for t in titles:
|
|
|
|
l = gtk.Label(titles[col])
|
|
|
|
l.show()
|
|
|
|
self.stats_table.attach(l, col, col+1, row, row+1, yoptions=gtk.SHRINK)
|
|
|
|
col +=1
|
|
|
|
|
|
|
|
for row in range(rows-1):
|
|
|
|
if(row%2 == 0):
|
|
|
|
bgcolor = "white"
|
|
|
|
else:
|
|
|
|
bgcolor = "lightgrey"
|
|
|
|
for col in range(cols):
|
|
|
|
eb = gtk.EventBox()
|
|
|
|
eb.modify_bg(gtk.STATE_NORMAL, gtk.gdk.color_parse(bgcolor))
|
|
|
|
if result[row][col]:
|
|
|
|
l = gtk.Label(result[row][col])
|
|
|
|
else:
|
|
|
|
l = gtk.Label(' ')
|
|
|
|
if col == 0:
|
|
|
|
l.set_alignment(xalign=0.0, yalign=0.5)
|
|
|
|
else:
|
|
|
|
l.set_alignment(xalign=1.0, yalign=0.5)
|
|
|
|
eb.add(l)
|
|
|
|
self.stats_table.attach(eb, col, col+1, row+1, row+2, yoptions=gtk.SHRINK)
|
|
|
|
l.show()
|
|
|
|
eb.show()
|
|
|
|
self.db.db.commit()
|
|
|
|
#end def fillStatsFrame(self, vbox):
|
2009-05-05 00:14:33 +02:00
|
|
|
|
|
|
|
def refineQuery(self, query, playerids, sitenos, limits):
|
|
|
|
if playerids:
|
|
|
|
nametest = str(tuple(playerids))
|
|
|
|
nametest = nametest.replace("L", "")
|
|
|
|
nametest = nametest.replace(",)",")")
|
|
|
|
query = query.replace("<player_test>", nametest)
|
|
|
|
else:
|
|
|
|
query = query.replace("<player_test>", "1 = 2")
|
|
|
|
|
|
|
|
if [x for x in limits if str(x).isdigit()]:
|
|
|
|
blindtest = str(tuple([x for x in limits if str(x).isdigit()]))
|
|
|
|
blindtest = blindtest.replace("L", "")
|
|
|
|
blindtest = blindtest.replace(",)",")")
|
|
|
|
query = query.replace("<gtbigBlind_test>", "gt.bigBlind in " + blindtest)
|
|
|
|
else:
|
|
|
|
query = query.replace("<gtbigBlind_test>", "gt.bigBlind = -1 ")
|
|
|
|
|
|
|
|
groupLevels = "Separate" not in str(limits)
|
|
|
|
if groupLevels:
|
|
|
|
if self.db.backend == self.MYSQL_INNODB:
|
|
|
|
bigblindselect = """concat(trim(leading ' ' from
|
|
|
|
case when min(gt.bigBlind) < 100
|
|
|
|
then format(min(gt.bigBlind)/100.0, 2)
|
|
|
|
else format(min(gt.bigBlind)/100.0, 0)
|
|
|
|
end)
|
|
|
|
,' - '
|
|
|
|
,trim(leading ' ' from
|
|
|
|
case when max(gt.bigBlind) < 100
|
|
|
|
then format(max(gt.bigBlind)/100.0, 2)
|
|
|
|
else format(max(gt.bigBlind)/100.0, 0)
|
|
|
|
end)
|
|
|
|
) """
|
|
|
|
else:
|
|
|
|
bigblindselect = """trim(leading ' ' from
|
|
|
|
case when min(gt.bigBlind) < 100
|
|
|
|
then to_char(min(gt.bigBlind)/100.0,'90D00')
|
|
|
|
else to_char(min(gt.bigBlind)/100.0,'999990')
|
|
|
|
end)
|
|
|
|
|| ' - ' ||
|
|
|
|
trim(leading ' ' from
|
|
|
|
case when max(gt.bigBlind) < 100
|
|
|
|
then to_char(max(gt.bigBlind)/100.0,'90D00')
|
|
|
|
else to_char(max(gt.bigBlind)/100.0,'999990')
|
|
|
|
end) """
|
|
|
|
query = query.replace("<selectgt.bigBlind>", bigblindselect)
|
|
|
|
query = query.replace("<groupbygt.bigBlind>", "")
|
|
|
|
query = query.replace("<hcgametypeId>", "-1")
|
|
|
|
query = query.replace("<hgameTypeId>", "-1")
|
|
|
|
else:
|
|
|
|
if self.db.backend == self.MYSQL_INNODB:
|
|
|
|
bigblindselect = """trim(leading ' ' from
|
|
|
|
case when gt.bigBlind < 100
|
|
|
|
then format(gt.bigBlind/100.0, 2)
|
|
|
|
else format(gt.bigBlind/100.0, 0)
|
|
|
|
end
|
|
|
|
) """
|
|
|
|
else:
|
|
|
|
bigblindselect = """trim(leading ' ' from
|
|
|
|
case when gt.bigBlind < 100
|
|
|
|
then to_char(gt.bigBlind/100.0,'90D00')
|
|
|
|
else to_char(gt.bigBlind/100.0,'999990')
|
|
|
|
end
|
|
|
|
) """
|
|
|
|
query = query.replace("<selectgt.bigBlind>", bigblindselect)
|
|
|
|
query = query.replace("<groupbygt.bigBlind>", ",gt.bigBlind")
|
|
|
|
query = query.replace("<hcgametypeId>", "hc.gametypeId")
|
|
|
|
query = query.replace("<hgameTypeId>", "h.gameTypeId")
|
|
|
|
#print "query =\n", query
|
|
|
|
return(query)
|
|
|
|
#end def refineQuery(self, query, playerids, sitenos, limits):
|