Merge branch 'master' of git://git.assembla.com/fpdb-eric
This commit is contained in:
		
						commit
						e99ec0cd71
					
				|  | @ -213,7 +213,7 @@ if __name__ == '__main__': | |||
|     parser = OptionParser() | ||||
|     parser.add_option("-f", "--file", dest="filename", help="Input file in quiet mode", metavar="FILE") | ||||
|     parser.add_option("-q", "--quiet", action="store_false", dest="gui", default=True, help="don't start gui") | ||||
| 
 | ||||
|     parser.add_option("-x", "--convert", dest="filtername", help="Conversion filter", default="passthrough") | ||||
|     (options, sys.argv) = parser.parse_args() | ||||
| 
 | ||||
|     config = Configuration.Config() | ||||
|  | @ -240,7 +240,7 @@ if __name__ == '__main__': | |||
|         importer = fpdb_import.Importer(False,settings, config)  | ||||
|         importer.setDropIndexes("auto") | ||||
|         importer.setFailOnError(True) | ||||
|         importer.addImportFile(options.filename) | ||||
|         importer.addImportFile(options.filename, filter=options.filtername) | ||||
|         importer.setCallHud(False) | ||||
|         importer.runImport() | ||||
|         importer.clearFileList() | ||||
|  |  | |||
|  | @ -123,7 +123,7 @@ class HUD_main(object): | |||
|             gtk.gdk.threads_enter() | ||||
|             try: | ||||
|                 self.hud_dict[table_name].update(new_hand_id, config) | ||||
|                 map(lambda aw: aw.update_gui(new_hand_id), self.hud_dict[table_name].aux_windows) | ||||
|                 [aw.update_gui(new_hand_id) for aw in self.hud_dict[table_name].aux_windows] | ||||
|                 return False | ||||
|             finally: | ||||
|                 gtk.gdk.threads_leave() | ||||
|  | @ -174,8 +174,7 @@ class HUD_main(object): | |||
|             if temp_key in self.hud_dict: | ||||
|                 self.hud_dict[temp_key].stat_dict = stat_dict | ||||
|                 self.hud_dict[temp_key].cards = cards | ||||
|                 for aw in self.hud_dict[temp_key].aux_windows: | ||||
|                     aw.update_data(new_hand_id, self.db_connection) | ||||
|                 [aw.update_data(new_hand_id, self.db_connection) for aw in self.hud_dict[temp_key].aux_windows] | ||||
|                 self.update_HUD(new_hand_id, temp_key, self.config) | ||||
|      | ||||
| #    Or create a new HUD | ||||
|  |  | |||
|  | @ -328,7 +328,7 @@ Map the tuple self.gametype onto the pokerstars string describing it | |||
|         # currently it appears to be something like ["ring", "hold", "nl", sb, bb]: | ||||
|         gs = {"holdem"       : "Hold'em", | ||||
|               "omahahi"    : "Omaha", | ||||
|               "omahahilo"  : "FIXME", | ||||
|               "omahahilo"  : "Omaha Hi/Lo", | ||||
|               "razz"       : "Razz", | ||||
|               "studhi"     : "7 Card Stud", | ||||
|               "studhilo"   : "FIXME", | ||||
|  | @ -371,11 +371,11 @@ Map the tuple self.gametype onto the pokerstars string describing it | |||
|             print >>fh, _("%s: completes to $%s%s" %(act[0], act[2], ' and is all-in' if act[3] else '')) | ||||
|         elif act[1] == 'posts': | ||||
|             if(act[2] == "small blind"): | ||||
|                 print >>fh, _("%s: posts small blind $%s" %(act[0], act[3])) | ||||
|                 print >>fh, _("%s: posts small blind $%s%s" %(act[0], act[3], ' and is all-in' if act[4] else '')) | ||||
|             elif(act[2] == "big blind"): | ||||
|                 print >>fh, _("%s: posts big blind $%s" %(act[0], act[3])) | ||||
|                 print >>fh, _("%s: posts big blind $%s%s" %(act[0], act[3], ' and is all-in' if act[4] else '')) | ||||
|             elif(act[2] == "both"): | ||||
|                 print >>fh, _("%s: posts small & big blinds $%s" %(act[0], act[3])) | ||||
|                 print >>fh, _("%s: posts small & big blinds $%s%s" %(act[0], act[3], ' and is all-in' if act[4] else '')) | ||||
|         elif act[1] == 'bringin': | ||||
|             print >>fh, _("%s: brings in for $%s%s" %(act[0], act[2], ' and is all-in' if act[3] else '')) | ||||
|         elif act[1] == 'discards': | ||||
|  | @ -458,7 +458,7 @@ Card ranks will be uppercased | |||
| 
 | ||||
|     def writeHand(self, fh=sys.__stdout__): | ||||
|         # PokerStars format. | ||||
|         print >>fh, _("%s Game #%s: %s ($%s/$%s) - %s" %("PokerStars", self.handid, self.getGameTypeAsString(), self.sb, self.bb, time.strftime('%Y/%m/%d - %H:%M:%S (ET)', self.starttime))) | ||||
|         print >>fh, _("%s Game #%s: %s ($%s/$%s) - %s" %("PokerStars", self.handid, self.getGameTypeAsString(), self.sb, self.bb, time.strftime('%Y/%m/%d - %H:%M:%S ET', self.starttime))) | ||||
|         print >>fh, _("Table '%s' %d-max Seat #%s is the button" %(self.tablename, self.maxseats, self.buttonpos)) | ||||
|          | ||||
|         players_who_act_preflop = set(([x[0] for x in self.actions['PREFLOP']]+[x[0] for x in self.actions['BLINDSANTES']])) | ||||
|  | @ -501,9 +501,18 @@ Card ranks will be uppercased | |||
|         #Some sites don't have a showdown section so we have to figure out if there should be one | ||||
|         # The logic for a showdown is: at the end of river action there are at least two players in the hand | ||||
|         # we probably don't need a showdown section in pseudo stars format for our filtering purposes | ||||
|         if 'SHOWDOWN' in self.actions: | ||||
|         if self.shown: | ||||
|             print >>fh, _("*** SHOW DOWN ***") | ||||
|             #TODO: Complete SHOWDOWN | ||||
|             for name in self.shown: | ||||
|                 # TODO: legacy importer can't handle only one holecard here, make sure there are 2 for holdem, 4 for omaha | ||||
|                 # TOOD: If HoldHand subclass supports more than omahahi, omahahilo, holdem, add them here | ||||
|                 numOfHoleCardsNeeded = None | ||||
|                 if self.gametype['category'] in ('omahahi','omahahilo'): | ||||
|                     numOfHoleCardsNeeded = 4 | ||||
|                 elif self.gametype['category'] in ('holdem'): | ||||
|                     numOfHoleCardsNeeded = 2 | ||||
|                 if len(self.holecards[name]['PREFLOP']) == numOfHoleCardsNeeded: | ||||
|                     print >>fh, _("%s shows [%s] (a hand...)" % (name, " ".join(self.holecards[name]['PREFLOP']))) | ||||
|                  | ||||
|         # Current PS format has the lines: | ||||
|         # Uncalled bet ($111.25) returned to s0rrow | ||||
|  | @ -652,14 +661,14 @@ Card ranks will be uppercased | |||
| 
 | ||||
|     def writeHand(self, fh=sys.__stdout__): | ||||
|         # PokerStars format. | ||||
|         print >>fh, _("%s Game #%s: %s ($%s/$%s) - %s" %("PokerStars", self.handid, self.getGameTypeAsString(), self.sb, self.bb, time.strftime('%Y/%m/%d - %H:%M:%S (ET)', self.starttime))) | ||||
|         print >>fh, _("%s Game #%s:  %s ($%s/$%s) - %s" %("PokerStars", self.handid, self.getGameTypeAsString(), self.sb, self.bb, time.strftime('%Y/%m/%d %H:%M:%S ET', self.starttime))) | ||||
|         print >>fh, _("Table '%s' %d-max Seat #%s is the button" %(self.tablename, self.maxseats, self.buttonpos)) | ||||
| 
 | ||||
|         players_who_act_ondeal = set(([x[0] for x in self.actions['DEAL']]+[x[0] for x in self.actions['BLINDSANTES']])) | ||||
| 
 | ||||
|         for player in [x for x in self.players if x[1] in players_who_act_ondeal]: | ||||
|             #Only print stacks of players who do something on deal | ||||
|             print >>fh, _("Seat %s: %s ($%s)" %(player[0], player[1], player[2])) | ||||
|             print >>fh, _("Seat %s: %s ($%s in chips) " %(player[0], player[1], player[2])) | ||||
| 
 | ||||
|         if 'BLINDSANTES' in self.actions: | ||||
|             for act in self.actions['BLINDSANTES']: | ||||
|  |  | |||
|  | @ -204,7 +204,12 @@ Tail the in_path file and yield handTexts separated by re_SplitHands""" | |||
|     def processHand(self, handText): | ||||
|         gametype = self.determineGameType(handText) | ||||
|         logging.debug("gametype %s" % gametype) | ||||
| 
 | ||||
|         if gametype is None:  | ||||
|             l = None | ||||
|             gametype = "unmatched" | ||||
|             # TODO: not ideal, just trying to not error. | ||||
|             # TODO: Need to count failed hands. | ||||
|         else: | ||||
|             # See if gametype is supported. | ||||
|             type = gametype['type'] | ||||
|             base = gametype['base'] | ||||
|  |  | |||
|  | @ -196,7 +196,7 @@ class Hud: | |||
|             s.window.destroy()     | ||||
|         self.stat_windows = {} | ||||
| #    also kill any aux windows | ||||
|         map(lambda m: m.destroy(), self.aux_windows) | ||||
|         [aux.destroy() for aux in self.aux_windows] | ||||
|         self.aux_windows = [] | ||||
| 
 | ||||
|     def reposition_windows(self, *args): | ||||
|  | @ -217,8 +217,7 @@ class Hud: | |||
|             new_layout[self.stat_windows[sw].adj - 1] = new_loc | ||||
|         self.config.edit_layout(self.table.site, self.max, locations = new_layout) | ||||
| #    ask each aux to save its layout back to the config object | ||||
|         for aux in self.aux_windows: | ||||
|             aux.save_layout() | ||||
|         [aux.save_layout() for aux in self.aux_windows] | ||||
| #    save the config object back to the file | ||||
|         print "saving new xml file" | ||||
|         self.config.save() | ||||
|  | @ -351,6 +350,8 @@ class Hud: | |||
|                 style = win32gui.GetWindowLong(self.table.number, win32con.GWL_EXSTYLE) | ||||
|                 style |= win32con.WS_CLIPCHILDREN | ||||
|                 win32gui.SetWindowLong(self.table.number, win32con.GWL_EXSTYLE, style) | ||||
|                 break | ||||
|              | ||||
|         window.set_title(real_name) | ||||
| 
 | ||||
| class Stat_Window: | ||||
|  | @ -575,6 +576,7 @@ class Popup_window: | |||
|                 style = win32gui.GetWindowLong(self.table.number, win32con.GWL_EXSTYLE) | ||||
|                 style |= win32con.WS_CLIPCHILDREN | ||||
|                 win32gui.SetWindowLong(self.table.number, win32con.GWL_EXSTYLE, style) | ||||
|                 break | ||||
|                  | ||||
|         window.set_title(real_name) | ||||
| 
 | ||||
|  |  | |||
|  | @ -81,23 +81,13 @@ class fpdb: | |||
|     def display_tab(self, new_tab_name): | ||||
|         """displays the indicated tab""" | ||||
|         #print "start of display_tab, len(self.tab_names):",len(self.tab_names) | ||||
|         tab_no=-1 | ||||
|         #if len(self.tab_names)>1: | ||||
|         for i in range(len(self.tab_names)): | ||||
|             #print "display_tab, new_tab_name:",new_tab_name,"  self.tab_names[i]:", self.tab_names[i] | ||||
|             if (new_tab_name==self.tab_names[i]): | ||||
|                 tab_no=i | ||||
|                 #self.tab_buttons[i].set_active(False) | ||||
|         #else: | ||||
|         #    tab_no=0 | ||||
|         tab_no = -1 | ||||
|         for i, name in enumerate(self.tab_names): | ||||
|             if name == new_tab_name: | ||||
|                 tab_no = i | ||||
|                 break | ||||
| 
 | ||||
|         #current_tab_no=-1 | ||||
|         for i in range(len(self.tab_names)): | ||||
|             if self.current_tab==self.tabs[i]: | ||||
|                 #self.tab_buttons[i].set_active(False) | ||||
|                 pass | ||||
| 
 | ||||
|         if tab_no==-1: | ||||
|         if tab_no == -1: | ||||
|             raise fpdb_simple.FpdbError("invalid tab_no") | ||||
|         else: | ||||
|             self.main_vbox.remove(self.current_tab) | ||||
|  | @ -199,12 +189,13 @@ class fpdb: | |||
|     def dia_recreate_tables(self, widget, data): | ||||
|         """Dialogue that asks user to confirm that he wants to delete and recreate the tables""" | ||||
|         self.obtain_global_lock() | ||||
|         dia_confirm=gtk.MessageDialog(parent=None, flags=0, type=gtk.MESSAGE_WARNING, | ||||
|          | ||||
|         dia_confirm = gtk.MessageDialog(parent=None, flags=0, type=gtk.MESSAGE_WARNING, | ||||
|                 buttons=(gtk.BUTTONS_YES_NO), message_format="Confirm deleting and recreating tables") | ||||
|         diastring=("Please confirm that you want to (re-)create the tables. If there already are tables in the database "+self.db.database+" on "+self.db.host+" they will be deleted.") | ||||
|         diastring = "Please confirm that you want to (re-)create the tables. If there already are tables in the database "+self.db.database+" on "+self.db.host+" they will be deleted." | ||||
|         dia_confirm.format_secondary_text(diastring)#todo: make above string with bold for db, host and deleted | ||||
| 
 | ||||
|         response=dia_confirm.run() | ||||
|         response = dia_confirm.run() | ||||
|         dia_confirm.destroy() | ||||
|         if response == gtk.RESPONSE_YES: | ||||
|             self.db.recreate_tables() | ||||
|  |  | |||
|  | @ -23,12 +23,12 @@ import FpdbSQLQueries | |||
| class fpdb_db: | ||||
|     def __init__(self): | ||||
|         """Simple constructor, doesnt really do anything""" | ||||
|         self.db=None | ||||
|         self.cursor=None | ||||
|         self.db             = None | ||||
|         self.cursor         = None | ||||
|         self.sql            = {} | ||||
|         self.MYSQL_INNODB=2 | ||||
|         self.PGSQL=3 | ||||
|         self.SQLITE=4 | ||||
|         self.MYSQL_INNODB   = 2 | ||||
|         self.PGSQL          = 3 | ||||
|         self.SQLITE         = 4 | ||||
|     #end def __init__ | ||||
| 
 | ||||
|     def do_connect(self, config=None): | ||||
|  | @ -37,10 +37,7 @@ class fpdb_db: | |||
|             raise FpdbError('Configuration not defined') | ||||
| 
 | ||||
|         self.settings = {} | ||||
|         if (os.sep=="/"): | ||||
|             self.settings['os']="linuxmac" | ||||
|         else: | ||||
|             self.settings['os']="windows" | ||||
|         self.settings['os'] = "linuxmac" if os.name != "nt" else "windows" | ||||
| 
 | ||||
|         self.settings.update(config.get_db_parameters()) | ||||
|         self.connect(self.settings['db-backend'], | ||||
|  |  | |||
|  | @ -51,8 +51,8 @@ class Importer: | |||
| 
 | ||||
|     def __init__(self, caller, settings, config): | ||||
|         """Constructor""" | ||||
|         self.settings=settings | ||||
|         self.caller=caller | ||||
|         self.settings   = settings | ||||
|         self.caller     = caller | ||||
|         self.config     = config | ||||
|         self.fdb        = None | ||||
|         self.cursor     = None | ||||
|  | @ -188,6 +188,7 @@ class Importer: | |||
|             self.addImportDirectory(self.dirlist[site][0], False, site, self.dirlist[site][1]) | ||||
| 
 | ||||
|         for file in self.filelist: | ||||
|             if os.path.exists(file):             | ||||
|                 stat_info = os.stat(file) | ||||
|                 try:  | ||||
|                     lastupdate = self.updated[file] | ||||
|  | @ -205,7 +206,8 @@ class Importer: | |||
|                 # TODO we also test if directory, why? | ||||
|                 #if os.path.isdir(file): | ||||
|                     #self.import_file_dict(file, self.filelist[file][0], self.filelist[file][1]) | ||||
|                      | ||||
|             else: | ||||
|                 removeFromFileList[file] = True | ||||
|         self.addToDirList = filter(lambda x: self.addImportDirectory(x, True, self.addToDirList[x][0], self.addToDirList[x][1]), self.addToDirList)                        | ||||
|              | ||||
|         for file in self.removeFromFileList: | ||||
|  | @ -251,7 +253,6 @@ class Importer: | |||
|                 print "Unknown filter filter_name:'%s' in filter:'%s'" %(filter_name, filter) | ||||
|                 return | ||||
| 
 | ||||
| 
 | ||||
|         #This will barf if conv.getStatus != True | ||||
|         return (stored, duplicates, partial, errors, ttime) | ||||
| 
 | ||||
|  |  | |||
|  | @ -22,47 +22,46 @@ import fpdb_save_to_db | |||
| 
 | ||||
| #parses a holdem hand | ||||
| def mainParser(backend, db, cursor, site, category, hand, config): | ||||
|     category=fpdb_simple.recogniseCategory(hand[0]) | ||||
|     if (category=="holdem" or category=="omahahi" or category=="omahahilo"): | ||||
|         base="hold" | ||||
|     else: | ||||
|         base="stud" | ||||
|     category = fpdb_simple.recogniseCategory(hand[0]) | ||||
|      | ||||
|     base = "hold" if category == "holdem" or category == "omahahi" or category == "omahahilo" else "stud" | ||||
|      | ||||
|     #part 0: create the empty arrays | ||||
|     lineTypes=[] #char, valid values: header, name, cards, action, win, rake, ignore | ||||
|     lineStreets=[] #char, valid values: (predeal, preflop, flop, turn, river) | ||||
|     lineTypes   = [] #char, valid values: header, name, cards, action, win, rake, ignore | ||||
|     lineStreets = [] #char, valid values: (predeal, preflop, flop, turn, river) | ||||
| 
 | ||||
|     cardValues, cardSuits, boardValues, boardSuits, antes, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo, seatLines, winnings, rakes=[],[],[],[],[],[],[],[],[],[],[],[],[] | ||||
| 
 | ||||
|     #part 1: read hand no and check for duplicate | ||||
|     siteHandNo=fpdb_simple.parseSiteHandNo(hand[0]) | ||||
|     handStartTime=fpdb_simple.parseHandStartTime(hand[0], site) | ||||
|     siteID=fpdb_simple.recogniseSiteID(cursor, site) | ||||
|     siteHandNo      = fpdb_simple.parseSiteHandNo(hand[0]) | ||||
|     handStartTime   = fpdb_simple.parseHandStartTime(hand[0], site) | ||||
|     siteID          = fpdb_simple.recogniseSiteID(cursor, site) | ||||
|     #print "parse logic, siteID:",siteID,"site:",site | ||||
|      | ||||
|     isTourney=fpdb_simple.isTourney(hand[0]) | ||||
|     smallBlindLine=0 | ||||
|     for i in range(len(hand)): | ||||
|         if 'posts small blind' in hand[i] or 'posts the small blind' in hand[i]: | ||||
|             if hand[i][-2:] == "$0": | ||||
|                 continue | ||||
|             smallBlindLine=i | ||||
|             #print "found small blind line:",smallBlindLine | ||||
|     isTourney       = fpdb_simple.isTourney(hand[0]) | ||||
|     smallBlindLine  = 0 | ||||
|     for i, line in enumerate(hand): | ||||
|         if 'posts small blind' in line or 'posts the small blind' in line: | ||||
|             if line[-2:] == "$0": continue | ||||
|             smallBlindLine = i | ||||
|             break | ||||
|     #print "small blind line:",smallBlindLine | ||||
|     gametypeID=fpdb_simple.recogniseGametypeID(backend, db, cursor, hand[0], hand[smallBlindLine], siteID, category, isTourney) | ||||
|     if isTourney: | ||||
|         if site!="ps": | ||||
|             raise fpdb_simple.FpdbError("tourneys are only supported on PS right now") | ||||
|         siteTourneyNo=fpdb_simple.parseTourneyNo(hand[0]) | ||||
|         buyin=fpdb_simple.parseBuyin(hand[0]) | ||||
|         fee=fpdb_simple.parseFee(hand[0]) | ||||
|         entries=-1 #todo: parse this | ||||
|         prizepool=-1 #todo: parse this | ||||
|         knockout=0 | ||||
|         tourneyStartTime=handStartTime #todo: read tourney start time | ||||
|         rebuyOrAddon=fpdb_simple.isRebuyOrAddon(hand[0]) | ||||
|      | ||||
|         tourneyTypeId=fpdb_simple.recogniseTourneyTypeId(cursor, siteID, buyin, fee, knockout, rebuyOrAddon)         | ||||
|     gametypeID = fpdb_simple.recogniseGametypeID(backend, db, cursor, hand[0], hand[smallBlindLine], siteID, category, isTourney) | ||||
|     if isTourney: | ||||
|         if site != "ps": | ||||
|             raise fpdb_simple.FpdbError("tourneys are only supported on PS right now") | ||||
|         siteTourneyNo   = fpdb_simple.parseTourneyNo(hand[0]) | ||||
|         buyin           = fpdb_simple.parseBuyin(hand[0]) | ||||
|         fee             = fpdb_simple.parseFee(hand[0]) | ||||
|         entries         = -1 #todo: parse this | ||||
|         prizepool       = -1 #todo: parse this | ||||
|         knockout        = 0 | ||||
|         tourneyStartTime= handStartTime #todo: read tourney start time | ||||
|         rebuyOrAddon    = fpdb_simple.isRebuyOrAddon(hand[0]) | ||||
| 
 | ||||
|         tourneyTypeId   = fpdb_simple.recogniseTourneyTypeId(cursor, siteID, buyin, fee, knockout, rebuyOrAddon) | ||||
|          | ||||
|     fpdb_simple.isAlreadyInDB(cursor, gametypeID, siteHandNo) | ||||
|      | ||||
|     #part 2: classify lines by type (e.g. cards, action, win, sectionchange) and street | ||||
|  | @ -70,85 +69,82 @@ def mainParser(backend, db, cursor, site, category, hand, config): | |||
|          | ||||
|     #part 3: read basic player info     | ||||
|     #3a read player names, startcashes | ||||
|     for i in range (len(hand)): #todo: use maxseats+1 here. | ||||
|         if (lineTypes[i]=="name"): | ||||
|             seatLines.append(hand[i]) | ||||
|     names=fpdb_simple.parseNames(seatLines) | ||||
|     for i, line in enumerate(hand): | ||||
|         if lineTypes[i] == "name": | ||||
|             seatLines.append(line) | ||||
|              | ||||
|     names       = fpdb_simple.parseNames(seatLines) | ||||
|     playerIDs   = fpdb_simple.recognisePlayerIDs(cursor, names, siteID) | ||||
|     tmp=fpdb_simple.parseCashesAndSeatNos(seatLines, site) | ||||
|     startCashes=tmp['startCashes'] | ||||
|     seatNos=tmp['seatNos'] | ||||
|     tmp         = fpdb_simple.parseCashesAndSeatNos(seatLines, site) | ||||
|     startCashes = tmp['startCashes'] | ||||
|     seatNos     = tmp['seatNos'] | ||||
|      | ||||
|     fpdb_simple.createArrays(category, len(names), cardValues, cardSuits, antes, winnings, rakes, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) | ||||
|      | ||||
|     #3b read positions | ||||
|     if base=="hold": | ||||
|         positions = fpdb_simple.parsePositions (hand, names) | ||||
|     if base == "hold": | ||||
|         positions = fpdb_simple.parsePositions(hand, names) | ||||
|      | ||||
|     #part 4: take appropriate action for each line based on linetype | ||||
|     for i in range(len(hand)): | ||||
|         if (lineTypes[i]=="cards"): | ||||
|             fpdb_simple.parseCardLine (site, category, lineStreets[i], hand[i], names, cardValues, cardSuits, boardValues, boardSuits) | ||||
|     for i, line in enumerate(hand): | ||||
|         if lineTypes[i] == "cards": | ||||
|             fpdb_simple.parseCardLine(site, category, lineStreets[i], line, names, cardValues, cardSuits, boardValues, boardSuits) | ||||
|             #if category=="studhilo": | ||||
|             #    print "hand[i]:", hand[i] | ||||
|             #    print "cardValues:", cardValues | ||||
|             #    print "cardSuits:", cardSuits | ||||
|         elif (lineTypes[i]=="action"): | ||||
|             fpdb_simple.parseActionLine (site, base, isTourney, hand[i], lineStreets[i], playerIDs, names, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) | ||||
|         elif (lineTypes[i]=="win"): | ||||
|             fpdb_simple.parseWinLine (hand[i], site, names, winnings, isTourney) | ||||
|         elif (lineTypes[i]=="rake"): | ||||
|             if isTourney: | ||||
|                 totalRake=0 | ||||
|             else: | ||||
|                 totalRake=fpdb_simple.parseRake(hand[i]) | ||||
|         elif lineTypes[i] == "action": | ||||
|             fpdb_simple.parseActionLine(site, base, isTourney, line, lineStreets[i], playerIDs, names, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) | ||||
|         elif lineTypes[i] == "win": | ||||
|             fpdb_simple.parseWinLine(line, site, names, winnings, isTourney) | ||||
|         elif lineTypes[i] == "rake": | ||||
|             totalRake = 0 if isTourney else fpdb_simple.parseRake(line) | ||||
|             fpdb_simple.splitRake(winnings, rakes, totalRake) | ||||
|         elif (lineTypes[i]=="header" or lineTypes[i]=="rake" or lineTypes[i]=="name" or lineTypes[i]=="ignore"): | ||||
|         elif lineTypes[i]=="header" or lineTypes[i]=="rake" or lineTypes[i]=="name" or lineTypes[i]=="ignore": | ||||
|             pass | ||||
|         elif (lineTypes[i]=="ante"): | ||||
|             fpdb_simple.parseAnteLine(hand[i], site, isTourney, names, antes) | ||||
|         elif (lineTypes[i]=="table"): | ||||
|             tableResult=fpdb_simple.parseTableLine(site, base, hand[i]) | ||||
|         elif lineTypes[i]=="ante": | ||||
|             fpdb_simple.parseAnteLine(line, site, isTourney, names, antes) | ||||
|         elif lineTypes[i]=="table": | ||||
|             tableResult=fpdb_simple.parseTableLine(site, base, line) | ||||
|         else: | ||||
|             raise fpdb_simple.FpdbError("unrecognised lineType:"+lineTypes[i]) | ||||
|     if site=="ftp": | ||||
|         tableResult=fpdb_simple.parseTableLine(site, base, hand[0]) | ||||
|     maxSeats=tableResult['maxSeats'] | ||||
|     tableName=tableResult['tableName'] | ||||
|          | ||||
|     if site == "ftp": | ||||
|         tableResult = fpdb_simple.parseTableLine(site, base, hand[0]) | ||||
|          | ||||
|     maxSeats    = tableResult['maxSeats'] | ||||
|     tableName   = tableResult['tableName'] | ||||
|     #print "before part5, antes:", antes | ||||
|      | ||||
|     #part 5: final preparations, then call fpdb_save_to_db.* with | ||||
|     #         the arrays as they are - that file will fill them. | ||||
|     fpdb_simple.convertCardValues(cardValues) | ||||
|     if base=="hold": | ||||
|     if base == "hold": | ||||
|         fpdb_simple.convertCardValuesBoard(boardValues) | ||||
|         fpdb_simple.convertBlindBet(actionTypes, actionAmounts) | ||||
|         fpdb_simple.checkPositions(positions) | ||||
|          | ||||
|     cursor.execute("SELECT limitType FROM Gametypes WHERE id=%s",(gametypeID, )) | ||||
|     limit_type=cursor.fetchone()[0] | ||||
|     limit_type = cursor.fetchone()[0] | ||||
|     fpdb_simple.convert3B4B(site, category, limit_type, actionTypes, actionAmounts) | ||||
|      | ||||
|     totalWinnings=0 | ||||
|     for i in range(len(winnings)): | ||||
|         totalWinnings+=winnings[i] | ||||
|     totalWinnings = sum(winnings) | ||||
|      | ||||
|     if base=="hold": | ||||
|         hudImportData=fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes | ||||
|     # if hold'em, use positions and not antes, if stud do not use positions, use antes | ||||
|     if base == "hold": | ||||
|         hudImportData = fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes | ||||
|                                      , allIns, actionTypeByNo, winnings, totalWinnings, positions | ||||
|                                      , actionTypes, actionAmounts, None) | ||||
|     else: | ||||
|         hudImportData=fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes | ||||
|         hudImportData = fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes | ||||
|                                      , allIns, actionTypeByNo, winnings, totalWinnings, None | ||||
|                                      , actionTypes, actionAmounts, antes) | ||||
|      | ||||
|     if isTourney: | ||||
|         ranks=[] | ||||
|         for i in range (len(names)): | ||||
|             ranks.append(0) | ||||
|         payin_amounts=fpdb_simple.calcPayin(len(names), buyin, fee) | ||||
|         ranks = map(lambda x: 0, names) # create an array of 0's equal to the length of names | ||||
|         payin_amounts = fpdb_simple.calcPayin(len(names), buyin, fee) | ||||
|          | ||||
|         if base=="hold": | ||||
|         if base == "hold": | ||||
|             result = fpdb_save_to_db.tourney_holdem_omaha( | ||||
|                                        config, backend, db, cursor, base, category, siteTourneyNo, buyin | ||||
|                                      , fee, knockout, entries, prizepool, tourneyStartTime | ||||
|  | @ -157,7 +153,7 @@ def mainParser(backend, db, cursor, site, category, hand, config): | |||
|                                      , positions, cardValues, cardSuits, boardValues, boardSuits | ||||
|                                      , winnings, rakes, actionTypes, allIns, actionAmounts | ||||
|                                      , actionNos, hudImportData, maxSeats, tableName, seatNos) | ||||
|         elif base=="stud": | ||||
|         elif base == "stud": | ||||
|             result = fpdb_save_to_db.tourney_stud( | ||||
|                                        config, backend, db, cursor, base, category, siteTourneyNo | ||||
|                                      , buyin, fee, knockout, entries, prizepool, tourneyStartTime | ||||
|  | @ -167,9 +163,9 @@ def mainParser(backend, db, cursor, site, category, hand, config): | |||
|                                      , allIns, actionAmounts, actionNos, hudImportData, maxSeats | ||||
|                                      , tableName, seatNos) | ||||
|         else: | ||||
|             raise fpdb_simple.FpdbError ("unrecognised category") | ||||
|             raise fpdb_simple.FpdbError("unrecognised category") # it's impossible to get here, but w/e | ||||
|     else: | ||||
|         if base=="hold": | ||||
|         if base == "hold": | ||||
|             result = fpdb_save_to_db.ring_holdem_omaha( | ||||
|                                        config, backend, db, cursor, base, category, siteHandNo | ||||
|                                      , gametypeID, handStartTime, names, playerIDs | ||||
|  | @ -177,7 +173,7 @@ def mainParser(backend, db, cursor, site, category, hand, config): | |||
|                                      , boardValues, boardSuits, winnings, rakes | ||||
|                                      , actionTypes, allIns, actionAmounts, actionNos | ||||
|                                      , hudImportData, maxSeats, tableName, seatNos) | ||||
|         elif base=="stud": | ||||
|         elif base == "stud": | ||||
|             result = fpdb_save_to_db.ring_stud( | ||||
|                                        config, backend, db, cursor, base, category, siteHandNo, gametypeID | ||||
|                                      , handStartTime, names, playerIDs, startCashes, antes | ||||
|  | @ -185,7 +181,7 @@ def mainParser(backend, db, cursor, site, category, hand, config): | |||
|                                      , actionAmounts, actionNos, hudImportData, maxSeats, tableName | ||||
|                                      , seatNos) | ||||
|         else: | ||||
|             raise fpdb_simple.FpdbError ("unrecognised category") | ||||
|             raise fpdb_simple.FpdbError ("unrecognised category") # also impossible to get here | ||||
|     db.commit() | ||||
|     return result | ||||
| #end def mainParser | ||||
|  |  | |||
|  | @ -22,13 +22,13 @@ from time import time | |||
| 
 | ||||
| import fpdb_simple | ||||
| 
 | ||||
| MYSQL_INNODB=2 | ||||
| PGSQL=3 | ||||
| SQLITE=4 | ||||
| MYSQL_INNODB    = 2 | ||||
| PGSQL           = 3 | ||||
| SQLITE          = 4 | ||||
| 
 | ||||
| fastStoreHudCache=True   # set this to True to test the new storeHudCache routine | ||||
| fastStoreHudCache = True   # set this to True to test the new storeHudCache routine | ||||
| 
 | ||||
| saveActions=False    # set this to False to avoid storing action data | ||||
| saveActions = False    # set this to False to avoid storing action data | ||||
|                     # Pros: speeds up imports | ||||
|                     # Cons: no action data is saved, so you need to keep the hand histories | ||||
|                     #       variance not available on stats page | ||||
|  | @ -40,16 +40,17 @@ def ring_stud(config, backend, db, cursor, base, category, site_hand_no, gametyp | |||
|              ,seatNos): | ||||
| 
 | ||||
|     import_options = config.get_import_parameters() | ||||
|     saveActions = import_options['saveActions'] | ||||
|     fastStoreHudCache = import_options['fastStoreHudCache'] | ||||
|      | ||||
|     saveActions = True if import_options['saveActions'] == 'True' else False | ||||
|     fastStoreHudCache = True if import_options['fastStoreHudCache'] == 'True' else False | ||||
| 
 | ||||
|     fpdb_simple.fillCardArrays(len(names), base, category, card_values, card_suits) | ||||
|      | ||||
|     hands_id=fpdb_simple.storeHands(backend, db, cursor, site_hand_no, gametype_id | ||||
|     hands_id = fpdb_simple.storeHands(backend, db, cursor, site_hand_no, gametype_id | ||||
|                                    ,hand_start_time, names, tableName, maxSeats) | ||||
|      | ||||
|     #print "before calling store_hands_players_stud, antes:", antes | ||||
|     hands_players_ids=fpdb_simple.store_hands_players_stud(backend, db, cursor, hands_id, player_ids | ||||
|     hands_players_ids = fpdb_simple.store_hands_players_stud(backend, db, cursor, hands_id, player_ids | ||||
|                                                           ,start_cashes, antes, card_values | ||||
|                                                           ,card_suits, winnings, rakes, seatNos) | ||||
|      | ||||
|  | @ -68,8 +69,8 @@ def ring_holdem_omaha(config, backend, db, cursor, base, category, site_hand_no, | |||
|     """stores a holdem/omaha hand into the database""" | ||||
| 
 | ||||
|     import_options = config.get_import_parameters() | ||||
|     saveActions = import_options['saveActions'] | ||||
|     fastStoreHudCache = import_options['fastStoreHudCache'] | ||||
|     saveActions = True if import_options['saveActions'] == 'True' else False | ||||
|     fastStoreHudCache = True if import_options['fastStoreHudCache'] == 'True' else False | ||||
| 
 | ||||
|     t0 = time() | ||||
|     fpdb_simple.fillCardArrays(len(names), base, category, card_values, card_suits) | ||||
|  | @ -77,10 +78,10 @@ def ring_holdem_omaha(config, backend, db, cursor, base, category, site_hand_no, | |||
|     fpdb_simple.fill_board_cards(board_values, board_suits) | ||||
|     t2 = time() | ||||
| 
 | ||||
|     hands_id=fpdb_simple.storeHands(backend, db, cursor, site_hand_no, gametype_id | ||||
|     hands_id = fpdb_simple.storeHands(backend, db, cursor, site_hand_no, gametype_id | ||||
|                                    ,hand_start_time, names, tableName, maxSeats) | ||||
|     t3 = time() | ||||
|     hands_players_ids=fpdb_simple.store_hands_players_holdem_omaha( | ||||
|     hands_players_ids = fpdb_simple.store_hands_players_holdem_omaha( | ||||
|                                backend, db, cursor, category, hands_id, player_ids, start_cashes | ||||
|                              , positions, card_values, card_suits, winnings, rakes, seatNos) | ||||
|     t4 = time()             | ||||
|  | @ -109,19 +110,19 @@ def tourney_holdem_omaha(config, backend, db, cursor, base, category, siteTourne | |||
|     """stores a tourney holdem/omaha hand into the database""" | ||||
| 
 | ||||
|     import_options = config.get_import_parameters() | ||||
|     saveActions = import_options['saveActions'] | ||||
|     fastStoreHudCache = import_options['fastStoreHudCache'] | ||||
|     saveActions = True if import_options['saveActions'] == 'True' else False | ||||
|     fastStoreHudCache = True if import_options['fastStoreHudCache'] == 'True' else False | ||||
| 
 | ||||
|     fpdb_simple.fillCardArrays(len(names), base, category, card_values, card_suits) | ||||
|     fpdb_simple.fill_board_cards(board_values, board_suits) | ||||
|      | ||||
|     tourney_id=fpdb_simple.store_tourneys(cursor, tourneyTypeId, siteTourneyNo, entries, prizepool, tourney_start) | ||||
|     tourneys_players_ids=fpdb_simple.store_tourneys_players(cursor, tourney_id, player_ids, payin_amounts, ranks, winnings) | ||||
|     tourney_id = fpdb_simple.store_tourneys(cursor, tourneyTypeId, siteTourneyNo, entries, prizepool, tourney_start) | ||||
|     tourneys_players_ids = fpdb_simple.store_tourneys_players(cursor, tourney_id, player_ids, payin_amounts, ranks, winnings) | ||||
|      | ||||
|     hands_id=fpdb_simple.storeHands(backend, db, cursor, site_hand_no, gametype_id | ||||
|     hands_id = fpdb_simple.storeHands(backend, db, cursor, site_hand_no, gametype_id | ||||
|                                    ,hand_start_time, names, tableName, maxSeats) | ||||
|      | ||||
|     hands_players_ids=fpdb_simple.store_hands_players_holdem_omaha_tourney( | ||||
|     hands_players_ids = fpdb_simple.store_hands_players_holdem_omaha_tourney( | ||||
|                       backend, db, cursor, category, hands_id, player_ids, start_cashes, positions | ||||
|                     , card_values, card_suits, winnings, rakes, seatNos, tourneys_players_ids) | ||||
|      | ||||
|  | @ -146,18 +147,18 @@ def tourney_stud(config, backend, db, cursor, base, category, siteTourneyNo, buy | |||
| #stores a tourney stud/razz hand into the database | ||||
| 
 | ||||
|     import_options = config.get_import_parameters() | ||||
|     saveActions = import_options['saveActions'] | ||||
|     fastStoreHudCache = import_options['fastStoreHudCache'] | ||||
|     saveActions = True if import_options['saveActions'] == 'True' else False | ||||
|     fastStoreHudCache = True if import_options['fastStoreHudCache'] == 'True' else False | ||||
|      | ||||
|     fpdb_simple.fillCardArrays(len(names), base, category, cardValues, cardSuits) | ||||
|      | ||||
|     tourney_id=fpdb_simple.store_tourneys(cursor, tourneyTypeId, siteTourneyNo, entries, prizepool, tourneyStartTime) | ||||
|     tourney_id = fpdb_simple.store_tourneys(cursor, tourneyTypeId, siteTourneyNo, entries, prizepool, tourneyStartTime) | ||||
|      | ||||
|     tourneys_players_ids=fpdb_simple.store_tourneys_players(cursor, tourney_id, playerIds, payin_amounts, ranks, winnings) | ||||
|     tourneys_players_ids = fpdb_simple.store_tourneys_players(cursor, tourney_id, playerIds, payin_amounts, ranks, winnings) | ||||
|      | ||||
|     hands_id=fpdb_simple.storeHands(backend, db, cursor, siteHandNo, gametypeId, handStartTime, names, tableName, maxSeats) | ||||
|     hands_id = fpdb_simple.storeHands(backend, db, cursor, siteHandNo, gametypeId, handStartTime, names, tableName, maxSeats) | ||||
|      | ||||
|     hands_players_ids=fpdb_simple.store_hands_players_stud_tourney(backend, db, cursor, hands_id | ||||
|     hands_players_ids = fpdb_simple.store_hands_players_stud_tourney(backend, db, cursor, hands_id | ||||
|                                              , playerIds, startCashes, antes, cardValues, cardSuits | ||||
|                                              , winnings, rakes, seatNos, tourneys_players_ids) | ||||
|      | ||||
|  |  | |||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user