Merge branch 'master' into siteneutral
Conflicts: pyfpdb/fpdb_import.py pyfpdb/fpdb_parse_logic.py pyfpdb/fpdb_simple.py
This commit is contained in:
		
						commit
						444e780f29
					
				
							
								
								
									
										122
									
								
								pyfpdb/Configuration.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										122
									
								
								pyfpdb/Configuration.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							|  | @ -32,6 +32,13 @@ import shutil | ||||||
| import xml.dom.minidom | import xml.dom.minidom | ||||||
| from xml.dom.minidom import Node | from xml.dom.minidom import Node | ||||||
| 
 | 
 | ||||||
|  | def fix_tf(x): | ||||||
|  |     if x == "1" or x == 1 or string.lower(x) == "true"  or string.lower(x) == "t": | ||||||
|  |         return True | ||||||
|  |     if x == "0" or x == 0 or string.lower(x) == "false" or string.lower(x) == "f": | ||||||
|  |         return False | ||||||
|  |     return False | ||||||
|  | 
 | ||||||
| class Layout: | class Layout: | ||||||
|     def __init__(self, node): |     def __init__(self, node): | ||||||
| 
 | 
 | ||||||
|  | @ -205,9 +212,18 @@ class Import: | ||||||
|         self.interval      = node.getAttribute("interval") |         self.interval      = node.getAttribute("interval") | ||||||
|         self.callFpdbHud   = node.getAttribute("callFpdbHud") |         self.callFpdbHud   = node.getAttribute("callFpdbHud") | ||||||
|         self.hhArchiveBase = node.getAttribute("hhArchiveBase") |         self.hhArchiveBase = node.getAttribute("hhArchiveBase") | ||||||
|  |         if node.hasAttribute("saveActions"): | ||||||
|  |             self.saveActions = fix_tf(node.getAttribute("saveActions")) | ||||||
|  |         else: | ||||||
|  |             self.saveActions = True | ||||||
|  |         if node.hasAttribute("fastStoreHudCache"): | ||||||
|  |             self.fastStoreHudCache = fix_tf(node.getAttribute("fastStoreHudCache")) | ||||||
|  |         else: | ||||||
|  |             self.fastStoreHudCache = False | ||||||
| 
 | 
 | ||||||
|     def __str__(self): |     def __str__(self): | ||||||
|         return "    interval = %s\n    callFpdbHud = %s\n    hhArchiveBase = %s" % (self.interval, self.callFpdbHud, self.hhArchiveBase) |         return "    interval = %s\n    callFpdbHud = %s\n    hhArchiveBase = %s\n    saveActions = %s\n    fastStoreHudCache = %s\n" \ | ||||||
|  |              % (self.interval, self.callFpdbHud, self.hhArchiveBase, self.saveActions, self.saveActions) | ||||||
| 
 | 
 | ||||||
| class Tv: | class Tv: | ||||||
|     def __init__(self, node): |     def __init__(self, node): | ||||||
|  | @ -391,9 +407,14 @@ class Config: | ||||||
|                 return layout_node |                 return layout_node | ||||||
| 
 | 
 | ||||||
|     def get_location_node(self, layout_node, seat): |     def get_location_node(self, layout_node, seat): | ||||||
|         for location_node in layout_node.getElementsByTagName("location"): |         if seat == "common": | ||||||
|             if int( location_node.getAttribute("seat") ) == int( seat ): |             for location_node in layout_node.getElementsByTagName("location"): | ||||||
|                 return location_node |                 if location_node.hasAttribute("common"): | ||||||
|  |                     return location_node | ||||||
|  |         else: | ||||||
|  |             for location_node in layout_node.getElementsByTagName("location"): | ||||||
|  |                 if int( location_node.getAttribute("seat") ) == int( seat ): | ||||||
|  |                     return location_node | ||||||
| 
 | 
 | ||||||
|     def save(self, file = None): |     def save(self, file = None): | ||||||
|         if not file == None: |         if not file == None: | ||||||
|  | @ -420,29 +441,42 @@ class Config: | ||||||
|     def edit_aux_layout(self, aux_name, max, width = None, height = None, locations = None): |     def edit_aux_layout(self, aux_name, max, width = None, height = None, locations = None): | ||||||
|         aux_node   = self.get_aux_node(aux_name) |         aux_node   = self.get_aux_node(aux_name) | ||||||
|         layout_node = self.get_layout_node(aux_node, max) |         layout_node = self.get_layout_node(aux_node, max) | ||||||
|         if layout_node == None: return |         if layout_node == None: | ||||||
|         for i in range(1, max + 1): |             print "aux node not found" | ||||||
|  |             return | ||||||
|  |         print "editing locations =", locations | ||||||
|  |         for (i, pos) in locations.iteritems(): | ||||||
|             location_node = self.get_location_node(layout_node, i) |             location_node = self.get_location_node(layout_node, i) | ||||||
|             location_node.setAttribute("x", str( locations[i-1][0] )) |             location_node.setAttribute("x", str( locations[i][0] )) | ||||||
|             location_node.setAttribute("y", str( locations[i-1][1] )) |             location_node.setAttribute("y", str( locations[i][1] )) | ||||||
|             self.aux_windows[aux_name].layout[max].location[i] = ( locations[i-1][0], locations[i-1][1] ) |             if i == "common": | ||||||
|  |                 self.aux_windows[aux_name].layout[max].common = ( locations[i][0], locations[i][1] ) | ||||||
|  |             else: | ||||||
|  |                 self.aux_windows[aux_name].layout[max].location[i] = ( locations[i][0], locations[i][1] ) | ||||||
| 
 | 
 | ||||||
|     def get_db_parameters(self, name = None): |     def get_db_parameters(self, name = None): | ||||||
|         if name == None: name = 'fpdb' |         if name == None: name = 'fpdb' | ||||||
|         db = {} |         db = {} | ||||||
|         try: |         try:    db['db-databaseName'] = name | ||||||
|             db['db-databaseName'] = name |         except: pass | ||||||
|             db['db-host'] = self.supported_databases[name].db_ip | 
 | ||||||
|             db['db-user'] = self.supported_databases[name].db_user |         try:    db['db-host'] = self.supported_databases[name].db_ip | ||||||
|             db['db-password'] = self.supported_databases[name].db_pass |         except: pass | ||||||
|             db['db-server'] = self.supported_databases[name].db_server | 
 | ||||||
|             if   string.lower(self.supported_databases[name].db_server) == 'mysql': |         try:    db['db-user'] = self.supported_databases[name].db_user | ||||||
|                 db['db-backend'] = 2 |         except: pass | ||||||
|             elif string.lower(self.supported_databases[name].db_server) == 'postgresql': | 
 | ||||||
|                 db['db-backend'] = 3 |         try:    db['db-password'] = self.supported_databases[name].db_pass | ||||||
|             else: db['db-backend'] = None # this is big trouble |         except: pass | ||||||
|         except: | 
 | ||||||
|             pass |         try:    db['db-server'] = self.supported_databases[name].db_server | ||||||
|  |         except: pass | ||||||
|  | 
 | ||||||
|  |         if   string.lower(self.supported_databases[name].db_server) == 'mysql': | ||||||
|  |             db['db-backend'] = 2 | ||||||
|  |         elif string.lower(self.supported_databases[name].db_server) == 'postgresql': | ||||||
|  |             db['db-backend'] = 3 | ||||||
|  |         else: db['db-backend'] = None # this is big trouble | ||||||
|         return db |         return db | ||||||
| 
 | 
 | ||||||
|     def set_db_parameters(self, db_name = 'fpdb', db_ip = None, db_user = None, |     def set_db_parameters(self, db_name = 'fpdb', db_ip = None, db_user = None, | ||||||
|  | @ -464,26 +498,32 @@ class Config: | ||||||
| 
 | 
 | ||||||
|     def get_tv_parameters(self): |     def get_tv_parameters(self): | ||||||
|         tv = {} |         tv = {} | ||||||
|         try: |         try:    tv['combinedStealFold'] = self.tv.combinedStealFold | ||||||
|             tv['combinedStealFold'] = self.tv.combinedStealFold |         except: tv['combinedStealFold'] = True | ||||||
|             tv['combined2B3B']      = self.tv.combined2B3B | 
 | ||||||
|             tv['combinedPostflop']  = self.tv.combinedPostflop |         try:    tv['combined2B3B']      = self.tv.combined2B3B | ||||||
|         except: # Default tv parameters |         except: tv['combined2B3B']      = True | ||||||
|             tv['combinedStealFold'] = True | 
 | ||||||
|             tv['combined2B3B']      = True |         try:    tv['combinedPostflop']  = self.tv.combinedPostflop | ||||||
|             tv['combinedPostflop']  = True |         except: tv['combinedPostflop']  = True | ||||||
|         return tv |         return tv | ||||||
|      |      | ||||||
|     def get_import_parameters(self): |     def get_import_parameters(self): | ||||||
|         imp = {} |         imp = {} | ||||||
|         try: |         try:     imp['callFpdbHud']       = self.imp.callFpdbHud | ||||||
|             imp['callFpdbHud']   = self.imp.callFpdbHud |         except:  imp['callFpdbHud']       = True | ||||||
|             imp['interval']      = self.imp.interval | 
 | ||||||
|             imp['hhArchiveBase'] = self.imp.hhArchiveBase |         try:     imp['interval']          = self.imp.interval | ||||||
|         except: # Default params |         except:  imp['interval']          = 10 | ||||||
|             imp['callFpdbHud']   = True | 
 | ||||||
|             imp['interval']      = 10 |         try:     imp['hhArchiveBase']     = self.imp.hhArchiveBase | ||||||
|             imp['hhArchiveBase'] = "~/.fpdb/HandHistories/" |         except:  imp['hhArchiveBase']     = "~/.fpdb/HandHistories/" | ||||||
|  | 
 | ||||||
|  |         try:     imp['saveActions']       = self.imp.saveActions | ||||||
|  |         except:  imp['saveActions']       = True | ||||||
|  | 
 | ||||||
|  |         try:     imp['fastStoreHudCache'] = self.imp.fastStoreHudCache | ||||||
|  |         except:  imp['fastStoreHudCache'] = True | ||||||
|         return imp |         return imp | ||||||
| 
 | 
 | ||||||
|     def get_default_paths(self, site = "PokerStars"): |     def get_default_paths(self, site = "PokerStars"): | ||||||
|  | @ -689,9 +729,9 @@ if __name__== "__main__": | ||||||
|         print c.get_aux_parameters(mw) |         print c.get_aux_parameters(mw) | ||||||
| 
 | 
 | ||||||
|     print "mucked locations =", c.get_aux_locations('mucked', 9) |     print "mucked locations =", c.get_aux_locations('mucked', 9) | ||||||
|     c.edit_aux_layout('mucked', 9, locations = [(487, 113), (555, 469), (572, 276), (522, 345),  | #    c.edit_aux_layout('mucked', 9, locations = [(487, 113), (555, 469), (572, 276), (522, 345),  | ||||||
|                                                 (333, 354), (217, 341), (150, 273), (150, 169), (230, 115)]) | #                                                (333, 354), (217, 341), (150, 273), (150, 169), (230, 115)]) | ||||||
|     print "mucked locations =", c.get_aux_locations('mucked', 9) | #    print "mucked locations =", c.get_aux_locations('mucked', 9) | ||||||
| 
 | 
 | ||||||
|     for site in c.supported_sites.keys(): |     for site in c.supported_sites.keys(): | ||||||
|         print "site = ", site, |         print "site = ", site, | ||||||
|  |  | ||||||
|  | @ -213,7 +213,7 @@ if __name__ == '__main__': | ||||||
|     parser = OptionParser() |     parser = OptionParser() | ||||||
|     parser.add_option("-f", "--file", dest="filename", help="Input file in quiet mode", metavar="FILE") |     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("-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() |     (options, sys.argv) = parser.parse_args() | ||||||
| 
 | 
 | ||||||
|     config = Configuration.Config() |     config = Configuration.Config() | ||||||
|  | @ -240,7 +240,7 @@ if __name__ == '__main__': | ||||||
|         importer = fpdb_import.Importer(False,settings, config)  |         importer = fpdb_import.Importer(False,settings, config)  | ||||||
|         importer.setDropIndexes("auto") |         importer.setDropIndexes("auto") | ||||||
|         importer.setFailOnError(True) |         importer.setFailOnError(True) | ||||||
|         importer.addImportFile(options.filename) |         importer.addImportFile(options.filename, filter=options.filtername) | ||||||
|         importer.setCallHud(False) |         importer.setCallHud(False) | ||||||
|         importer.runImport() |         importer.runImport() | ||||||
|         importer.clearFileList() |         importer.clearFileList() | ||||||
|  |  | ||||||
|  | @ -123,7 +123,7 @@ class HUD_main(object): | ||||||
|             gtk.gdk.threads_enter() |             gtk.gdk.threads_enter() | ||||||
|             try: |             try: | ||||||
|                 self.hud_dict[table_name].update(new_hand_id, config) |                 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 |                 return False | ||||||
|             finally: |             finally: | ||||||
|                 gtk.gdk.threads_leave() |                 gtk.gdk.threads_leave() | ||||||
|  | @ -172,8 +172,7 @@ class HUD_main(object): | ||||||
|             if temp_key in self.hud_dict: |             if temp_key in self.hud_dict: | ||||||
|                 self.hud_dict[temp_key].stat_dict = stat_dict |                 self.hud_dict[temp_key].stat_dict = stat_dict | ||||||
|                 self.hud_dict[temp_key].cards = cards |                 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) for aw in self.hud_dict[temp_key].aux_windows] | ||||||
|                     aw.update_data(new_hand_id, self.db_connection) |  | ||||||
|                 self.update_HUD(new_hand_id, temp_key, self.config) |                 self.update_HUD(new_hand_id, temp_key, self.config) | ||||||
|      |      | ||||||
| #    Or create a new HUD | #    Or create a new HUD | ||||||
|  |  | ||||||
|  | @ -504,7 +504,15 @@ Card ranks will be uppercased | ||||||
|         if self.shown: |         if self.shown: | ||||||
|             print >>fh, _("*** SHOW DOWN ***") |             print >>fh, _("*** SHOW DOWN ***") | ||||||
|             for name in self.shown: |             for name in self.shown: | ||||||
|                 print >>fh, _("%s shows [%s] (a hand...)" % (name, " ".join(self.holecards[name]['PREFLOP']))) |                 # 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: |         # Current PS format has the lines: | ||||||
|         # Uncalled bet ($111.25) returned to s0rrow |         # Uncalled bet ($111.25) returned to s0rrow | ||||||
|  |  | ||||||
|  | @ -196,12 +196,12 @@ class Hud: | ||||||
|             s.window.destroy()     |             s.window.destroy()     | ||||||
|         self.stat_windows = {} |         self.stat_windows = {} | ||||||
| #    also kill any aux 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 = [] |         self.aux_windows = [] | ||||||
| 
 | 
 | ||||||
|     def reposition_windows(self, *args): |     def reposition_windows(self, *args): | ||||||
|         if self.stat_windows and len(self.stat_windows > 0): |         if self.stat_windows != {} and len(self.stat_windows) > 0: | ||||||
|             map(lambda x: x.window.move(x.x, x.y), self.stat_windows) |             map(lambda x: x.window.move(x.x, x.y), self.stat_windows.itervalues()) | ||||||
|         return True |         return True | ||||||
| 
 | 
 | ||||||
|     def debug_stat_windows(self, *args): |     def debug_stat_windows(self, *args): | ||||||
|  | @ -216,6 +216,10 @@ class Hud: | ||||||
|             new_loc = (loc[0] - self.table.x, loc[1] - self.table.y) |             new_loc = (loc[0] - self.table.x, loc[1] - self.table.y) | ||||||
|             new_layout[self.stat_windows[sw].adj - 1] = new_loc |             new_layout[self.stat_windows[sw].adj - 1] = new_loc | ||||||
|         self.config.edit_layout(self.table.site, self.max, locations = new_layout) |         self.config.edit_layout(self.table.site, self.max, locations = new_layout) | ||||||
|  | #    ask each aux to save its layout back to the config object | ||||||
|  |         [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() |         self.config.save() | ||||||
| 
 | 
 | ||||||
|     def adj_seats(self, hand, config): |     def adj_seats(self, hand, config): | ||||||
|  | @ -346,6 +350,8 @@ class Hud: | ||||||
|                 style = win32gui.GetWindowLong(self.table.number, win32con.GWL_EXSTYLE) |                 style = win32gui.GetWindowLong(self.table.number, win32con.GWL_EXSTYLE) | ||||||
|                 style |= win32con.WS_CLIPCHILDREN |                 style |= win32con.WS_CLIPCHILDREN | ||||||
|                 win32gui.SetWindowLong(self.table.number, win32con.GWL_EXSTYLE, style) |                 win32gui.SetWindowLong(self.table.number, win32con.GWL_EXSTYLE, style) | ||||||
|  |                 break | ||||||
|  |              | ||||||
|         window.set_title(real_name) |         window.set_title(real_name) | ||||||
| 
 | 
 | ||||||
| class Stat_Window: | class Stat_Window: | ||||||
|  | @ -570,6 +576,7 @@ class Popup_window: | ||||||
|                 style = win32gui.GetWindowLong(self.table.number, win32con.GWL_EXSTYLE) |                 style = win32gui.GetWindowLong(self.table.number, win32con.GWL_EXSTYLE) | ||||||
|                 style |= win32con.WS_CLIPCHILDREN |                 style |= win32con.WS_CLIPCHILDREN | ||||||
|                 win32gui.SetWindowLong(self.table.number, win32con.GWL_EXSTYLE, style) |                 win32gui.SetWindowLong(self.table.number, win32con.GWL_EXSTYLE, style) | ||||||
|  |                 break | ||||||
|                  |                  | ||||||
|         window.set_title(real_name) |         window.set_title(real_name) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -49,6 +49,9 @@ class Aux_Window: | ||||||
|     def create(self, *parms): |     def create(self, *parms): | ||||||
|         pass |         pass | ||||||
| 
 | 
 | ||||||
|  |     def save_layout(self, *args): | ||||||
|  |         pass | ||||||
|  | 
 | ||||||
|     def destroy(self): |     def destroy(self): | ||||||
|         self.container.destroy() |         self.container.destroy() | ||||||
| 
 | 
 | ||||||
|  | @ -312,12 +315,13 @@ class Flop_Mucked(Aux_Window): | ||||||
|     def __init__(self, hud, config, params): |     def __init__(self, hud, config, params): | ||||||
|         self.hud     = hud       # hud object that this aux window supports |         self.hud     = hud       # hud object that this aux window supports | ||||||
|         self.config  = config    # configuration object for this aux window to use |         self.config  = config    # configuration object for this aux window to use | ||||||
|         self.params  = params    # hash aux params from config |         self.params  = params    # dict aux params from config | ||||||
|  |         self.positions = {}      # dict of window positions | ||||||
|  |         self.displayed_cards = False | ||||||
|         self.card_images = self.get_card_images() |         self.card_images = self.get_card_images() | ||||||
| 
 | 
 | ||||||
|     def create(self): |     def create(self): | ||||||
| 
 |         self.adj = self.hud.adj_seats(0, self.config) | ||||||
|         adj = self.hud.adj_seats(0, self.config) |  | ||||||
|         loc = self.config.get_aux_locations(self.params['name'], int(self.hud.max)) |         loc = self.config.get_aux_locations(self.params['name'], int(self.hud.max)) | ||||||
|          |          | ||||||
|         self.m_windows = {}      # windows to put the card images in |         self.m_windows = {}      # windows to put the card images in | ||||||
|  | @ -328,7 +332,7 @@ class Flop_Mucked(Aux_Window): | ||||||
|             if i == 'common': |             if i == 'common': | ||||||
|                 (x, y) = self.params['layout'][self.hud.max].common |                 (x, y) = self.params['layout'][self.hud.max].common | ||||||
|             else: |             else: | ||||||
|                 (x, y) = loc[adj[i]] |                 (x, y) = loc[self.adj[i]] | ||||||
|             self.m_windows[i] = gtk.Window() |             self.m_windows[i] = gtk.Window() | ||||||
|             self.m_windows[i].set_decorated(False) |             self.m_windows[i].set_decorated(False) | ||||||
|             self.m_windows[i].set_property("skip-taskbar-hint", True) |             self.m_windows[i].set_property("skip-taskbar-hint", True) | ||||||
|  | @ -340,6 +344,7 @@ class Flop_Mucked(Aux_Window): | ||||||
|             self.seen_cards[i] = gtk.image_new_from_pixbuf(self.card_images[('B', 'H')]) |             self.seen_cards[i] = gtk.image_new_from_pixbuf(self.card_images[('B', 'H')]) | ||||||
|             self.eb[i].add(self.seen_cards[i]) |             self.eb[i].add(self.seen_cards[i]) | ||||||
|             self.m_windows[i].move(int(x) + self.hud.table.x, int(y) + self.hud.table.y) |             self.m_windows[i].move(int(x) + self.hud.table.x, int(y) + self.hud.table.y) | ||||||
|  |             self.positions[i] = (int(x) + self.hud.table.x, int(y) + self.hud.table.y) | ||||||
|             self.m_windows[i].set_opacity(float(self.params['opacity'])) |             self.m_windows[i].set_opacity(float(self.params['opacity'])) | ||||||
|             self.m_windows[i].show_all() |             self.m_windows[i].show_all() | ||||||
|             self.m_windows[i].hide() |             self.m_windows[i].hide() | ||||||
|  | @ -350,11 +355,9 @@ class Flop_Mucked(Aux_Window): | ||||||
| 
 | 
 | ||||||
|     def update_gui(self, new_hand_id): |     def update_gui(self, new_hand_id): | ||||||
|         """Prepare and show the mucked cards.""" |         """Prepare and show the mucked cards.""" | ||||||
|         pos = {} |         if self.displayed_cards: | ||||||
|         for i, w in self.m_windows.iteritems(): |             self.hide_mucked_cards() | ||||||
|             pos[i] = w.get_position()  # I hate this. I don't know why I have to save position and then move back |             self.displayed_cards = False | ||||||
|         self.hide_mucked_cards() |  | ||||||
|         displayed_cards = False |  | ||||||
|         for (i, cards) in self.hud.cards.iteritems(): |         for (i, cards) in self.hud.cards.iteritems(): | ||||||
|             if self.has_cards(cards): |             if self.has_cards(cards): | ||||||
| #    scratch is a working pixbuf, used to assemble the image | #    scratch is a working pixbuf, used to assemble the image | ||||||
|  | @ -370,11 +373,12 @@ class Flop_Mucked(Aux_Window): | ||||||
|                     x = x + int(self.params['card_wd']) |                     x = x + int(self.params['card_wd']) | ||||||
|                 self.seen_cards[i].set_from_pixbuf(scratch) |                 self.seen_cards[i].set_from_pixbuf(scratch) | ||||||
| #                self.m_windows[i].show_all() | #                self.m_windows[i].show_all() | ||||||
|                 self.m_windows[i].move(pos[i][0], pos[i][1])   # here is where I move back |                 self.m_windows[i].resize(1,1) | ||||||
|                 self.m_windows[i].present() |                 self.m_windows[i].present() | ||||||
|                 displayed_cards = True |                 self.m_windows[i].move(self.positions[i][0], self.positions[i][1])   # here is where I move back | ||||||
|  |                 self.displayed_cards = True | ||||||
| 
 | 
 | ||||||
|         if displayed_cards and float(self.params['timeout']) > 0: |         if self.displayed_cards and float(self.params['timeout']) > 0: | ||||||
|             gobject.timeout_add(int(1000*float(self.params['timeout'])), self.hide_mucked_cards) |             gobject.timeout_add(int(1000*float(self.params['timeout'])), self.hide_mucked_cards) | ||||||
| 
 | 
 | ||||||
|     def destroy(self): |     def destroy(self): | ||||||
|  | @ -385,8 +389,10 @@ class Flop_Mucked(Aux_Window): | ||||||
|     def hide_mucked_cards(self): |     def hide_mucked_cards(self): | ||||||
|         """Hide the mucked card windows.""" |         """Hide the mucked card windows.""" | ||||||
| #    this is the callback from the timeout | #    this is the callback from the timeout | ||||||
|         for w in self.m_windows.values(): |         for (i, w) in self.m_windows.iteritems(): | ||||||
|  |             self.positions[i] = w.get_position() | ||||||
|             w.hide() |             w.hide() | ||||||
|  |             self.displayed_cards = False | ||||||
|         return False  # this tells the system to NOT run this timeout again |         return False  # this tells the system to NOT run this timeout again | ||||||
| 
 | 
 | ||||||
|     def button_press_cb(self, widget, event, *args): |     def button_press_cb(self, widget, event, *args): | ||||||
|  | @ -403,17 +409,16 @@ class Flop_Mucked(Aux_Window): | ||||||
| 
 | 
 | ||||||
|     def save_layout(self, *args): |     def save_layout(self, *args): | ||||||
|         """Save new layout back to the aux element in the config file.""" |         """Save new layout back to the aux element in the config file.""" | ||||||
| #    similar to same method in stat_windows |         new_locs = {} | ||||||
|         new_layout = [(0, 0)] * self.hud.max |         print "adj =", self.adj | ||||||
|         for (i, w) in self.m_windows.iteritems(): |         for (i, pos) in self.positions.iteritems(): | ||||||
|             (x, y) = w.get_position() |             if i != 'common': | ||||||
|             new_loc = (x - self.hud.table.x, y - self.hud.table.y) |                 new_locs[self.adj[int(i)]] = (pos[0] - self.hud.table.x, pos[1] - self.hud.table.y) | ||||||
|             if i != "common": |  | ||||||
|                 new_layout[self.hud.stat_windows[int(i)].adj - 1] = new_loc |  | ||||||
|             else: |             else: | ||||||
|                 pass |                 new_locs[i] = (pos[0] - self.hud.table.x, pos[1] - self.hud.table.y) | ||||||
|         self.config.edit_layout(self.table.site, self.max, locations = new_layout) |         print "old locations =", self.params['layout'][self.hud.max] | ||||||
|         self.config.save() |         print "saving locations =", new_locs | ||||||
|  |         self.config.edit_aux_layout(self.params['name'], self.hud.max, locations = new_locs) | ||||||
| 
 | 
 | ||||||
| if __name__== "__main__": | if __name__== "__main__": | ||||||
|      |      | ||||||
|  |  | ||||||
|  | @ -26,7 +26,7 @@ from HandHistoryConverter import * | ||||||
| class PokerStars(HandHistoryConverter): | class PokerStars(HandHistoryConverter): | ||||||
| 
 | 
 | ||||||
|     # Static regexes |     # Static regexes | ||||||
|     re_GameInfo     = re.compile("PokerStars Game #(?P<HID>[0-9]+):\s+(HORSE)? \(?(?P<GAME>Hold\'em|Razz|7 Card Stud|Omaha Hi/Lo|Badugi) (?P<LIMIT>No Limit|Limit|Pot Limit),? \(?(?P<CURRENCY>\$|)?(?P<SB>[.0-9]+)/\$?(?P<BB>[.0-9]+)\) - (?P<DATETIME>.*$)", re.MULTILINE) |     re_GameInfo     = re.compile("PokerStars Game #(?P<HID>[0-9]+):\s+(HORSE)? \(?(?P<GAME>Hold\'em|Razz|7 Card Stud|Omaha|Omaha Hi/Lo|Badugi) (?P<LIMIT>No Limit|Limit|Pot Limit),? \(?(?P<CURRENCY>\$|)?(?P<SB>[.0-9]+)/\$?(?P<BB>[.0-9]+)\) - (?P<DATETIME>.*$)", re.MULTILINE) | ||||||
|     re_SplitHands   = re.compile('\n\n+') |     re_SplitHands   = re.compile('\n\n+') | ||||||
|     re_HandInfo     = re.compile("^Table \'(?P<TABLE>[- a-zA-Z]+)\'(?P<TABLEATTRIBUTES>.+?$)?", re.MULTILINE) |     re_HandInfo     = re.compile("^Table \'(?P<TABLE>[- a-zA-Z]+)\'(?P<TABLEATTRIBUTES>.+?$)?", re.MULTILINE) | ||||||
|     re_Button       = re.compile('Seat #(?P<BUTTON>\d+) is the button', re.MULTILINE) |     re_Button       = re.compile('Seat #(?P<BUTTON>\d+) is the button', re.MULTILINE) | ||||||
|  | @ -89,7 +89,7 @@ follow :  whether to tail -f the input""" | ||||||
|         limits = { 'No Limit':'nl', 'Pot Limit':'pl', 'Limit':'fl' } |         limits = { 'No Limit':'nl', 'Pot Limit':'pl', 'Limit':'fl' } | ||||||
|         games = {              # base, category |         games = {              # base, category | ||||||
|                   "Hold'em" : ('hold','holdem'),  |                   "Hold'em" : ('hold','holdem'),  | ||||||
|                  'Omaha Hi' : ('hold','omahahi'), |                     'Omaha' : ('hold','omahahi'), | ||||||
|               'Omaha Hi/Lo' : ('hold','omahahilo'), |               'Omaha Hi/Lo' : ('hold','omahahilo'), | ||||||
|                      'Razz' : ('stud','razz'),  |                      'Razz' : ('stud','razz'),  | ||||||
|               '7 Card Stud' : ('stud','studhi'), |               '7 Card Stud' : ('stud','studhi'), | ||||||
|  |  | ||||||
|  | @ -81,23 +81,13 @@ class fpdb: | ||||||
|     def display_tab(self, new_tab_name): |     def display_tab(self, new_tab_name): | ||||||
|         """displays the indicated tab""" |         """displays the indicated tab""" | ||||||
|         #print "start of display_tab, len(self.tab_names):",len(self.tab_names) |         #print "start of display_tab, len(self.tab_names):",len(self.tab_names) | ||||||
|         tab_no=-1 |         tab_no = -1 | ||||||
|         #if len(self.tab_names)>1: |         for i, name in enumerate(self.tab_names): | ||||||
|         for i in range(len(self.tab_names)): |             if name == new_tab_name: | ||||||
|             #print "display_tab, new_tab_name:",new_tab_name,"  self.tab_names[i]:", self.tab_names[i] |                 tab_no = i | ||||||
|             if (new_tab_name==self.tab_names[i]): |                 break | ||||||
|                 tab_no=i |  | ||||||
|                 #self.tab_buttons[i].set_active(False) |  | ||||||
|         #else: |  | ||||||
|         #    tab_no=0 |  | ||||||
| 
 | 
 | ||||||
|         #current_tab_no=-1 |         if 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: |  | ||||||
|             raise fpdb_simple.FpdbError("invalid tab_no") |             raise fpdb_simple.FpdbError("invalid tab_no") | ||||||
|         else: |         else: | ||||||
|             self.main_vbox.remove(self.current_tab) |             self.main_vbox.remove(self.current_tab) | ||||||
|  | @ -199,12 +189,13 @@ class fpdb: | ||||||
|     def dia_recreate_tables(self, widget, data): |     def dia_recreate_tables(self, widget, data): | ||||||
|         """Dialogue that asks user to confirm that he wants to delete and recreate the tables""" |         """Dialogue that asks user to confirm that he wants to delete and recreate the tables""" | ||||||
|         self.obtain_global_lock() |         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") |                 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 |         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() |         dia_confirm.destroy() | ||||||
|         if response == gtk.RESPONSE_YES: |         if response == gtk.RESPONSE_YES: | ||||||
|             self.db.recreate_tables() |             self.db.recreate_tables() | ||||||
|  |  | ||||||
|  | @ -23,12 +23,12 @@ import FpdbSQLQueries | ||||||
| class fpdb_db: | class fpdb_db: | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         """Simple constructor, doesnt really do anything""" |         """Simple constructor, doesnt really do anything""" | ||||||
|         self.db=None |         self.db             = None | ||||||
|         self.cursor=None |         self.cursor         = None | ||||||
|         self.sql = {} |         self.sql            = {} | ||||||
|         self.MYSQL_INNODB=2 |         self.MYSQL_INNODB   = 2 | ||||||
|         self.PGSQL=3 |         self.PGSQL          = 3 | ||||||
|         self.SQLITE=4 |         self.SQLITE         = 4 | ||||||
|     #end def __init__ |     #end def __init__ | ||||||
| 
 | 
 | ||||||
|     def do_connect(self, config=None): |     def do_connect(self, config=None): | ||||||
|  | @ -37,10 +37,7 @@ class fpdb_db: | ||||||
|             raise FpdbError('Configuration not defined') |             raise FpdbError('Configuration not defined') | ||||||
| 
 | 
 | ||||||
|         self.settings = {} |         self.settings = {} | ||||||
|         if (os.sep=="/"): |         self.settings['os'] = "linuxmac" if os.name != "nt" else "windows" | ||||||
|             self.settings['os']="linuxmac" |  | ||||||
|         else: |  | ||||||
|             self.settings['os']="windows" |  | ||||||
| 
 | 
 | ||||||
|         self.settings.update(config.get_db_parameters()) |         self.settings.update(config.get_db_parameters()) | ||||||
|         self.connect(self.settings['db-backend'], |         self.connect(self.settings['db-backend'], | ||||||
|  |  | ||||||
|  | @ -51,22 +51,22 @@ class Importer: | ||||||
| 
 | 
 | ||||||
|     def __init__(self, caller, settings, config): |     def __init__(self, caller, settings, config): | ||||||
|         """Constructor""" |         """Constructor""" | ||||||
|         self.settings=settings |         self.settings   = settings | ||||||
|         self.caller=caller |         self.caller     = caller | ||||||
|         self.config = config |         self.config     = config | ||||||
|         self.fdb = None |         self.fdb        = None | ||||||
|         self.cursor = None |         self.cursor     = None | ||||||
|         self.filelist = {} |         self.filelist   = {} | ||||||
|         self.dirlist = {} |         self.dirlist    = {} | ||||||
|         self.addToDirList = {} |         self.addToDirList = {} | ||||||
|         self.removeFromFileList = {} # to remove deleted files |         self.removeFromFileList = {} # to remove deleted files | ||||||
|         self.monitor = False |         self.monitor    = False | ||||||
|         self.updated = {}       #Time last import was run {file:mtime} |         self.updated    = {}       #Time last import was run {file:mtime} | ||||||
|         self.lines = None |         self.lines      = None | ||||||
|         self.faobs = None       #File as one big string |         self.faobs      = None       #File as one big string | ||||||
|         self.pos_in_file = {} # dict to remember how far we have read in the file |         self.pos_in_file = {} # dict to remember how far we have read in the file | ||||||
|         #Set defaults |         #Set defaults | ||||||
|         self.callHud = self.config.get_import_parameters().get("callFpdbHud") |         self.callHud    = self.config.get_import_parameters().get("callFpdbHud") | ||||||
|         if 'minPrint' not in self.settings: |         if 'minPrint' not in self.settings: | ||||||
|             #TODO: Is this value in the xml file? |             #TODO: Is this value in the xml file? | ||||||
|             self.settings['minPrint'] = 30 |             self.settings['minPrint'] = 30 | ||||||
|  | @ -188,24 +188,26 @@ class Importer: | ||||||
|             self.addImportDirectory(self.dirlist[site][0], False, site, self.dirlist[site][1]) |             self.addImportDirectory(self.dirlist[site][0], False, site, self.dirlist[site][1]) | ||||||
| 
 | 
 | ||||||
|         for file in self.filelist: |         for file in self.filelist: | ||||||
|             stat_info = os.stat(file) |             if os.path.exists(file): | ||||||
|             try:  |                 stat_info = os.stat(file) | ||||||
|                 lastupdate = self.updated[file] |                 try:  | ||||||
|                 if stat_info.st_mtime > lastupdate: |                     lastupdate = self.updated[file] | ||||||
|                     self.import_file_dict(file, self.filelist[file][0], self.filelist[file][1]) |                     if stat_info.st_mtime > lastupdate: | ||||||
|  |                         self.import_file_dict(file, self.filelist[file][0], self.filelist[file][1]) | ||||||
|  |                         self.updated[file] = time() | ||||||
|  |                 except: | ||||||
|                     self.updated[file] = time() |                     self.updated[file] = time() | ||||||
|             except: |                     # If modified in the last minute run an immediate import. | ||||||
|                 self.updated[file] = time() |                     # This codepath only runs first time the file is found. | ||||||
|                 # If modified in the last minute run an immediate import. |                     if os.path.isdir(file) or (time() - stat_info.st_mtime) < 60: | ||||||
|                 # This codepath only runs first time the file is found. |                         # TODO attach a HHC thread to the file | ||||||
|                 if os.path.isdir(file) or (time() - stat_info.st_mtime) < 60: |                         # TODO import the output of the HHC thread  -- this needs to wait for the HHC to block? | ||||||
|                     # TODO attach a HHC thread to the file |                         self.import_file_dict(file, self.filelist[file][0], self.filelist[file][1]) | ||||||
|                     # TODO import the output of the HHC thread  -- this needs to wait for the HHC to block? |  | ||||||
|                     self.import_file_dict(file, self.filelist[file][0], self.filelist[file][1]) |  | ||||||
|                 # TODO we also test if directory, why? |                 # TODO we also test if directory, why? | ||||||
|                 #if os.path.isdir(file): |                 #if os.path.isdir(file): | ||||||
|                     #self.import_file_dict(file, self.filelist[file][0], self.filelist[file][1]) |                     #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) |         self.addToDirList = filter(lambda x: self.addImportDirectory(x, True, self.addToDirList[x][0], self.addToDirList[x][1]), self.addToDirList) | ||||||
|              |              | ||||||
|         for file in self.removeFromFileList: |         for file in self.removeFromFileList: | ||||||
|  | @ -251,7 +253,6 @@ class Importer: | ||||||
|                 print "Unknown filter filter_name:'%s' in filter:'%s'" %(filter_name, filter) |                 print "Unknown filter filter_name:'%s' in filter:'%s'" %(filter_name, filter) | ||||||
|                 return |                 return | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         #This will barf if conv.getStatus != True |         #This will barf if conv.getStatus != True | ||||||
|         return (stored, duplicates, partial, errors, ttime) |         return (stored, duplicates, partial, errors, ttime) | ||||||
| 
 | 
 | ||||||
|  | @ -284,7 +285,13 @@ class Importer: | ||||||
|             print "DEBUG: import_fpdb_file: failed on self.lines[0]: '%s' '%s' '%s' '%s' " %( file, site, self.lines, loc) |             print "DEBUG: import_fpdb_file: failed on self.lines[0]: '%s' '%s' '%s' '%s' " %( file, site, self.lines, loc) | ||||||
|             return (0,0,0,1,0) |             return (0,0,0,1,0) | ||||||
| 
 | 
 | ||||||
|         # site=fpdb_simple.recogniseSite(firstline) |         if firstline.find("Tournament Summary")!=-1: | ||||||
|  |             print "TODO: implement importing tournament summaries" | ||||||
|  |             #self.faobs = readfile(inputFile) | ||||||
|  |             #self.parseTourneyHistory() | ||||||
|  |             return 0 | ||||||
|  | 
 | ||||||
|  |         site=fpdb_simple.recogniseSite(firstline) | ||||||
|         category=fpdb_simple.recogniseCategory(firstline) |         category=fpdb_simple.recogniseCategory(firstline) | ||||||
| 
 | 
 | ||||||
|         startpos=0 |         startpos=0 | ||||||
|  | @ -315,7 +322,7 @@ class Importer: | ||||||
| 
 | 
 | ||||||
|                     try: |                     try: | ||||||
|                         handsId=fpdb_parse_logic.mainParser(self.settings['db-backend'], self.fdb.db |                         handsId=fpdb_parse_logic.mainParser(self.settings['db-backend'], self.fdb.db | ||||||
|                                                                    ,self.fdb.cursor, category, hand) |                                                            ,self.fdb.cursor, site, category, hand, self.config) | ||||||
|                         self.fdb.db.commit() |                         self.fdb.db.commit() | ||||||
| 
 | 
 | ||||||
|                         stored+=1 |                         stored+=1 | ||||||
|  |  | ||||||
|  | @ -21,46 +21,45 @@ import fpdb_simple | ||||||
| import fpdb_save_to_db | import fpdb_save_to_db | ||||||
| 
 | 
 | ||||||
| #parses a holdem hand | #parses a holdem hand | ||||||
| def mainParser(backend, db, cursor, category, hand): | def mainParser(backend, db, cursor, category, hand, config): | ||||||
|     category=fpdb_simple.recogniseCategory(hand[0]) |     category = fpdb_simple.recogniseCategory(hand[0]) | ||||||
|     if (category=="holdem" or category=="omahahi" or category=="omahahilo"): | 
 | ||||||
|         base="hold" |     base = "hold" if category == "holdem" or category == "omahahi" or category == "omahahilo" else "stud" | ||||||
|     else: | 
 | ||||||
|         base="stud" |  | ||||||
|     #part 0: create the empty arrays |     #part 0: create the empty arrays | ||||||
|     lineTypes=[] #char, valid values: header, name, cards, action, win, rake, ignore |     lineTypes   = [] #char, valid values: header, name, cards, action, win, rake, ignore | ||||||
|     lineStreets=[] #char, valid values: (predeal, preflop, flop, turn, river) |     lineStreets = [] #char, valid values: (predeal, preflop, flop, turn, river) | ||||||
| 
 | 
 | ||||||
|     cardValues, cardSuits, boardValues, boardSuits, antes, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo, seatLines, winnings, rakes=[],[],[],[],[],[],[],[],[],[],[],[],[] |     cardValues, cardSuits, boardValues, boardSuits, antes, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo, seatLines, winnings, rakes=[],[],[],[],[],[],[],[],[],[],[],[],[] | ||||||
| 
 | 
 | ||||||
|     #part 1: read hand no and check for duplicate |     #part 1: read hand no and check for duplicate | ||||||
|     siteHandNo=fpdb_simple.parseSiteHandNo(hand[0]) |     siteHandNo      = fpdb_simple.parseSiteHandNo(hand[0]) | ||||||
|     handStartTime=fpdb_simple.parseHandStartTime(hand[0]) |     handStartTime   = fpdb_simple.parseHandStartTime(hand[0]) | ||||||
|     siteID=fpdb_simple.recogniseSiteID() |     siteID          = fpdb_simple.recogniseSiteID() | ||||||
|     #print "parse logic, siteID:",siteID,"site:",site |     #print "parse logic, siteID:",siteID,"site:",site | ||||||
|      |      | ||||||
|     isTourney=fpdb_simple.isTourney(hand[0]) |     isTourney       = fpdb_simple.isTourney(hand[0]) | ||||||
|     smallBlindLine=0 |     smallBlindLine  = 0 | ||||||
|     for i in range(len(hand)): |     for i, line in enumerate(hand): | ||||||
|         if 'posts small blind' in hand[i] or 'posts the small blind' in hand[i]: |         if 'posts small blind' in line or 'posts the small blind' in line: | ||||||
|             if hand[i][-2:] == "$0": |             if line[-2:] == "$0": continue | ||||||
|                 continue |             smallBlindLine = i | ||||||
|             smallBlindLine=i |  | ||||||
|             #print "found small blind line:",smallBlindLine |  | ||||||
|             break |             break | ||||||
|     #print "small blind line:",smallBlindLine |     #print "small blind line:",smallBlindLine | ||||||
|     gametypeID=fpdb_simple.recogniseGametypeID(backend, db, cursor, hand[0], hand[smallBlindLine], siteID, category, isTourney) |  | ||||||
|     if isTourney: |  | ||||||
|         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: | ||||||
|  |         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) |     fpdb_simple.isAlreadyInDB(cursor, gametypeID, siteHandNo) | ||||||
|      |      | ||||||
|     #part 2: classify lines by type (e.g. cards, action, win, sectionchange) and street |     #part 2: classify lines by type (e.g. cards, action, win, sectionchange) and street | ||||||
|  | @ -68,94 +67,90 @@ def mainParser(backend, db, cursor, category, hand): | ||||||
|          |          | ||||||
|     #part 3: read basic player info     |     #part 3: read basic player info     | ||||||
|     #3a read player names, startcashes |     #3a read player names, startcashes | ||||||
|     for i in range (len(hand)): #todo: use maxseats+1 here. |     for i, line in enumerate(hand): | ||||||
|         if (lineTypes[i]=="name"): |         if lineTypes[i] == "name": | ||||||
|             seatLines.append(hand[i]) |             seatLines.append(line) | ||||||
|     names=fpdb_simple.parseNames(seatLines) | 
 | ||||||
|     playerIDs = fpdb_simple.recognisePlayerIDs(cursor, names, siteID) |     names       = fpdb_simple.parseNames(seatLines) | ||||||
|     tmp=fpdb_simple.parseCashesAndSeatNos(seatLines) |     playerIDs   = fpdb_simple.recognisePlayerIDs(cursor, names, siteID) | ||||||
|     startCashes=tmp['startCashes'] |     tmp         = fpdb_simple.parseCashesAndSeatNos(seatLines) | ||||||
|     seatNos=tmp['seatNos'] |     startCashes = tmp['startCashes'] | ||||||
|  |     seatNos     = tmp['seatNos'] | ||||||
|      |      | ||||||
|     fpdb_simple.createArrays(category, len(names), cardValues, cardSuits, antes, winnings, rakes, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) |     fpdb_simple.createArrays(category, len(names), cardValues, cardSuits, antes, winnings, rakes, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) | ||||||
|      |      | ||||||
|     #3b read positions |     #3b read positions | ||||||
|     if base=="hold": |     if base == "hold": | ||||||
|         positions = fpdb_simple.parsePositions (hand, names) |         positions = fpdb_simple.parsePositions(hand, names) | ||||||
|      |      | ||||||
|     #part 4: take appropriate action for each line based on linetype |     #part 4: take appropriate action for each line based on linetype | ||||||
|     for i in range(len(hand)): |     for i, line in enumerate(hand): | ||||||
|         if (lineTypes[i]=="cards"): |         if lineTypes[i] == "cards": | ||||||
|             fpdb_simple.parseCardLine (category, lineStreets[i], hand[i], names, cardValues, cardSuits, boardValues, boardSuits) |             fpdb_simple.parseCardLine(category, lineStreets[i], line, names, cardValues, cardSuits, boardValues, boardSuits) | ||||||
|             #if category=="studhilo": |             #if category=="studhilo": | ||||||
|             #    print "hand[i]:", hand[i] |             #    print "hand[i]:", hand[i] | ||||||
|             #    print "cardValues:", cardValues |             #    print "cardValues:", cardValues | ||||||
|             #    print "cardSuits:", cardSuits |             #    print "cardSuits:", cardSuits | ||||||
|         elif (lineTypes[i]=="action"): |         elif lineTypes[i] == "action": | ||||||
|             fpdb_simple.parseActionLine (base, isTourney, hand[i], lineStreets[i], playerIDs, names, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) |             fpdb_simple.parseActionLine(base, isTourney, line, lineStreets[i], playerIDs, names, actionTypes, allIns, actionAmounts, actionNos, actionTypeByNo) | ||||||
|         elif (lineTypes[i]=="win"): |         elif lineTypes[i] == "win": | ||||||
|             fpdb_simple.parseWinLine (hand[i], names, winnings, isTourney) |             fpdb_simple.parseWinLine(line, names, winnings, isTourney) | ||||||
|         elif (lineTypes[i]=="rake"): |         elif lineTypes[i] == "rake": | ||||||
|             if isTourney: |             totalRake = 0 if isTourney else fpdb_simple.parseRake(line) | ||||||
|                 totalRake=0 |  | ||||||
|             else: |  | ||||||
|                 totalRake=fpdb_simple.parseRake(hand[i]) |  | ||||||
|             fpdb_simple.splitRake(winnings, rakes, totalRake) |             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 |             pass | ||||||
|         elif (lineTypes[i]=="ante"): |         elif lineTypes[i]=="ante": | ||||||
|             fpdb_simple.parseAnteLine(hand[i], isTourney, names, antes) |             fpdb_simple.parseAnteLine(line, isTourney, names, antes) | ||||||
|         elif (lineTypes[i]=="table"): |         elif lineTypes[i]=="table": | ||||||
|             tableResult=fpdb_simple.parseTableLine(base, hand[i]) |             tableResult=fpdb_simple.parseTableLine(base, line) | ||||||
|         else: |         else: | ||||||
|             raise fpdb_simple.FpdbError("unrecognised lineType:"+lineTypes[i]) |             raise fpdb_simple.FpdbError("unrecognised lineType:"+lineTypes[i]) | ||||||
|     maxSeats=tableResult['maxSeats'] | 
 | ||||||
|     tableName=tableResult['tableName'] |     maxSeats    = tableResult['maxSeats'] | ||||||
|  |     tableName   = tableResult['tableName'] | ||||||
|     #print "before part5, antes:", antes |     #print "before part5, antes:", antes | ||||||
|      |      | ||||||
|     #part 5: final preparations, then call fpdb_save_to_db.* with |     #part 5: final preparations, then call fpdb_save_to_db.* with | ||||||
|     #         the arrays as they are - that file will fill them. |     #         the arrays as they are - that file will fill them. | ||||||
|     fpdb_simple.convertCardValues(cardValues) |     fpdb_simple.convertCardValues(cardValues) | ||||||
|     if base=="hold": |     if base == "hold": | ||||||
|         fpdb_simple.convertCardValuesBoard(boardValues) |         fpdb_simple.convertCardValuesBoard(boardValues) | ||||||
|         fpdb_simple.convertBlindBet(actionTypes, actionAmounts) |         fpdb_simple.convertBlindBet(actionTypes, actionAmounts) | ||||||
|         fpdb_simple.checkPositions(positions) |         fpdb_simple.checkPositions(positions) | ||||||
|          |          | ||||||
|     cursor.execute("SELECT limitType FROM Gametypes WHERE id=%s",(gametypeID, )) |     cursor.execute("SELECT limitType FROM Gametypes WHERE id=%s",(gametypeID, )) | ||||||
|     limit_type=cursor.fetchone()[0] |     limit_type = cursor.fetchone()[0] | ||||||
|     fpdb_simple.convert3B4B(category, limit_type, actionTypes, actionAmounts) |     fpdb_simple.convert3B4B(category, limit_type, actionTypes, actionAmounts) | ||||||
|      |      | ||||||
|     totalWinnings=0 |     totalWinnings = sum(winnings) | ||||||
|     for i in range(len(winnings)): |  | ||||||
|         totalWinnings+=winnings[i] |  | ||||||
|      |      | ||||||
|     if base=="hold": |     # if hold'em, use positions and not antes, if stud do not use positions, use antes | ||||||
|         hudImportData=fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes |     if base == "hold": | ||||||
|  |         hudImportData = fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes | ||||||
|                                      , allIns, actionTypeByNo, winnings, totalWinnings, positions |                                      , allIns, actionTypeByNo, winnings, totalWinnings, positions | ||||||
|                                      , actionTypes, actionAmounts, None) |                                      , actionTypes, actionAmounts, None) | ||||||
|     else: |     else: | ||||||
|         hudImportData=fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes |         hudImportData = fpdb_simple.generateHudCacheData(playerIDs, base, category, actionTypes | ||||||
|                                      , allIns, actionTypeByNo, winnings, totalWinnings, None |                                      , allIns, actionTypeByNo, winnings, totalWinnings, None | ||||||
|                                      , actionTypes, actionAmounts, antes) |                                      , actionTypes, actionAmounts, antes) | ||||||
| 
 | 
 | ||||||
|     if isTourney: |     if isTourney: | ||||||
|         ranks=[] |         ranks = map(lambda x: 0, names) # create an array of 0's equal to the length of names | ||||||
|         for i in range (len(names)): |         payin_amounts = fpdb_simple.calcPayin(len(names), buyin, fee) | ||||||
|             ranks.append(0) |  | ||||||
|         payin_amounts=fpdb_simple.calcPayin(len(names), buyin, fee) |  | ||||||
|          |          | ||||||
|         if base=="hold": |         if base == "hold": | ||||||
|             result = fpdb_save_to_db.tourney_holdem_omaha( |             result = fpdb_save_to_db.tourney_holdem_omaha( | ||||||
|                                        backend, db, cursor, base, category, siteTourneyNo, buyin |                                        config, backend, db, cursor, base, category, siteTourneyNo, buyin | ||||||
|                                      , fee, knockout, entries, prizepool, tourneyStartTime |                                      , fee, knockout, entries, prizepool, tourneyStartTime | ||||||
|                                      , payin_amounts, ranks, tourneyTypeId, siteID, siteHandNo |                                      , payin_amounts, ranks, tourneyTypeId, siteID, siteHandNo | ||||||
|                                      , gametypeID, handStartTime, names, playerIDs, startCashes |                                      , gametypeID, handStartTime, names, playerIDs, startCashes | ||||||
|                                      , positions, cardValues, cardSuits, boardValues, boardSuits |                                      , positions, cardValues, cardSuits, boardValues, boardSuits | ||||||
|                                      , winnings, rakes, actionTypes, allIns, actionAmounts |                                      , winnings, rakes, actionTypes, allIns, actionAmounts | ||||||
|                                      , actionNos, hudImportData, maxSeats, tableName, seatNos) |                                      , actionNos, hudImportData, maxSeats, tableName, seatNos) | ||||||
|         elif base=="stud": |         elif base == "stud": | ||||||
|             result = fpdb_save_to_db.tourney_stud( |             result = fpdb_save_to_db.tourney_stud( | ||||||
|                                        backend, db, cursor, base, category, siteTourneyNo |                                        config, backend, db, cursor, base, category, siteTourneyNo | ||||||
|                                      , buyin, fee, knockout, entries, prizepool, tourneyStartTime |                                      , buyin, fee, knockout, entries, prizepool, tourneyStartTime | ||||||
|                                      , payin_amounts, ranks, tourneyTypeId, siteID, siteHandNo |                                      , payin_amounts, ranks, tourneyTypeId, siteID, siteHandNo | ||||||
|                                      , gametypeID, handStartTime, names, playerIDs, startCashes |                                      , gametypeID, handStartTime, names, playerIDs, startCashes | ||||||
|  | @ -163,19 +158,19 @@ def mainParser(backend, db, cursor, category, hand): | ||||||
|                                      , allIns, actionAmounts, actionNos, hudImportData, maxSeats |                                      , allIns, actionAmounts, actionNos, hudImportData, maxSeats | ||||||
|                                      , tableName, seatNos) |                                      , tableName, seatNos) | ||||||
|         else: |         else: | ||||||
|             raise fpdb_simple.FpdbError ("unrecognised category") |             raise fpdb_simple.FpdbError("unrecognised category") | ||||||
|     else: |     else: | ||||||
|         if base=="hold": |         if base == "hold": | ||||||
|             result = fpdb_save_to_db.ring_holdem_omaha( |             result = fpdb_save_to_db.ring_holdem_omaha( | ||||||
|                                        backend, db, cursor, base, category, siteHandNo |                                        config, backend, db, cursor, base, category, siteHandNo | ||||||
|                                      , gametypeID, handStartTime, names, playerIDs |                                      , gametypeID, handStartTime, names, playerIDs | ||||||
|                                      , startCashes, positions, cardValues, cardSuits |                                      , startCashes, positions, cardValues, cardSuits | ||||||
|                                      , boardValues, boardSuits, winnings, rakes |                                      , boardValues, boardSuits, winnings, rakes | ||||||
|                                      , actionTypes, allIns, actionAmounts, actionNos |                                      , actionTypes, allIns, actionAmounts, actionNos | ||||||
|                                      , hudImportData, maxSeats, tableName, seatNos) |                                      , hudImportData, maxSeats, tableName, seatNos) | ||||||
|         elif base=="stud": |         elif base == "stud": | ||||||
|             result = fpdb_save_to_db.ring_stud( |             result = fpdb_save_to_db.ring_stud( | ||||||
|                                        backend, db, cursor, base, category, siteHandNo, gametypeID |                                        config, backend, db, cursor, base, category, siteHandNo, gametypeID | ||||||
|                                      , handStartTime, names, playerIDs, startCashes, antes |                                      , handStartTime, names, playerIDs, startCashes, antes | ||||||
|                                      , cardValues, cardSuits, winnings, rakes, actionTypes, allIns |                                      , cardValues, cardSuits, winnings, rakes, actionTypes, allIns | ||||||
|                                      , actionAmounts, actionNos, hudImportData, maxSeats, tableName |                                      , actionAmounts, actionNos, hudImportData, maxSeats, tableName | ||||||
|  |  | ||||||
|  | @ -22,29 +22,35 @@ from time import time | ||||||
| 
 | 
 | ||||||
| import fpdb_simple | import fpdb_simple | ||||||
| 
 | 
 | ||||||
| MYSQL_INNODB=2 | MYSQL_INNODB    = 2 | ||||||
| PGSQL=3 | PGSQL           = 3 | ||||||
| SQLITE=4 | SQLITE          = 4 | ||||||
| 
 | 
 | ||||||
| fastStoreHudCache=False   # set this to True to test the new storeHudCache routine | fastStoreHudCache = True   # set this to True to test the new storeHudCache routine | ||||||
| 
 | 
 | ||||||
| saveActions=True    # set this to False to avoid storing action data | saveActions = False    # set this to False to avoid storing action data | ||||||
|                     # Pros: speeds up imports |                     # Pros: speeds up imports | ||||||
|                     # Cons: no action data is saved, so you need to keep the hand histories |                     # Cons: no action data is saved, so you need to keep the hand histories | ||||||
|                     #       variance not available on stats page |                     #       variance not available on stats page | ||||||
| 
 | 
 | ||||||
| #stores a stud/razz hand into the database | #stores a stud/razz hand into the database | ||||||
| def ring_stud(backend, db, cursor, base, category, site_hand_no, gametype_id, hand_start_time | def ring_stud(config, backend, db, cursor, base, category, site_hand_no, gametype_id, hand_start_time | ||||||
|              ,names, player_ids, start_cashes, antes, card_values, card_suits, winnings, rakes |              ,names, player_ids, start_cashes, antes, card_values, card_suits, winnings, rakes | ||||||
|              ,action_types, allIns, action_amounts, actionNos, hudImportData, maxSeats, tableName |              ,action_types, allIns, action_amounts, actionNos, hudImportData, maxSeats, tableName | ||||||
|              ,seatNos): |              ,seatNos): | ||||||
|  | 
 | ||||||
|  |     import_options = config.get_import_parameters() | ||||||
|  |      | ||||||
|  |     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.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) |                                    ,hand_start_time, names, tableName, maxSeats) | ||||||
|      |      | ||||||
|     #print "before calling store_hands_players_stud, antes:", antes |     #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 |                                                           ,start_cashes, antes, card_values | ||||||
|                                                           ,card_suits, winnings, rakes, seatNos) |                                                           ,card_suits, winnings, rakes, seatNos) | ||||||
|      |      | ||||||
|  | @ -56,21 +62,26 @@ def ring_stud(backend, db, cursor, base, category, site_hand_no, gametype_id, ha | ||||||
|     return hands_id |     return hands_id | ||||||
| #end def ring_stud | #end def ring_stud | ||||||
| 
 | 
 | ||||||
| def ring_holdem_omaha(backend, db, cursor, base, category, site_hand_no, gametype_id | def ring_holdem_omaha(config, backend, db, cursor, base, category, site_hand_no, gametype_id | ||||||
|                      ,hand_start_time, names, player_ids, start_cashes, positions, card_values |                      ,hand_start_time, names, player_ids, start_cashes, positions, card_values | ||||||
|                      ,card_suits, board_values, board_suits, winnings, rakes, action_types, allIns |                      ,card_suits, board_values, board_suits, winnings, rakes, action_types, allIns | ||||||
|                      ,action_amounts, actionNos, hudImportData, maxSeats, tableName, seatNos): |                      ,action_amounts, actionNos, hudImportData, maxSeats, tableName, seatNos): | ||||||
|     """stores a holdem/omaha hand into the database""" |     """stores a holdem/omaha hand into the database""" | ||||||
|  | 
 | ||||||
|  |     import_options = config.get_import_parameters() | ||||||
|  |     saveActions = True if import_options['saveActions'] == 'True' else False | ||||||
|  |     fastStoreHudCache = True if import_options['fastStoreHudCache'] == 'True' else False | ||||||
|  | 
 | ||||||
|     t0 = time() |     t0 = time() | ||||||
|     fpdb_simple.fillCardArrays(len(names), base, category, card_values, card_suits) |     fpdb_simple.fillCardArrays(len(names), base, category, card_values, card_suits) | ||||||
|     t1 = time() |     t1 = time() | ||||||
|     fpdb_simple.fill_board_cards(board_values, board_suits) |     fpdb_simple.fill_board_cards(board_values, board_suits) | ||||||
|     t2 = time() |     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) |                                    ,hand_start_time, names, tableName, maxSeats) | ||||||
|     t3 = time() |     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 |                                backend, db, cursor, category, hands_id, player_ids, start_cashes | ||||||
|                              , positions, card_values, card_suits, winnings, rakes, seatNos) |                              , positions, card_values, card_suits, winnings, rakes, seatNos) | ||||||
|     t4 = time()             |     t4 = time()             | ||||||
|  | @ -89,7 +100,7 @@ def ring_holdem_omaha(backend, db, cursor, base, category, site_hand_no, gametyp | ||||||
|     return hands_id |     return hands_id | ||||||
| #end def ring_holdem_omaha | #end def ring_holdem_omaha | ||||||
| 
 | 
 | ||||||
| def tourney_holdem_omaha(backend, db, cursor, base, category, siteTourneyNo, buyin, fee, knockout | def tourney_holdem_omaha(config, backend, db, cursor, base, category, siteTourneyNo, buyin, fee, knockout | ||||||
|                         ,entries, prizepool, tourney_start, payin_amounts, ranks, tourneyTypeId |                         ,entries, prizepool, tourney_start, payin_amounts, ranks, tourneyTypeId | ||||||
|                         ,siteId #end of tourney specific params |                         ,siteId #end of tourney specific params | ||||||
|                         ,site_hand_no, gametype_id, hand_start_time, names, player_ids |                         ,site_hand_no, gametype_id, hand_start_time, names, player_ids | ||||||
|  | @ -97,16 +108,21 @@ def tourney_holdem_omaha(backend, db, cursor, base, category, siteTourneyNo, buy | ||||||
|                         ,board_suits, winnings, rakes, action_types, allIns, action_amounts |                         ,board_suits, winnings, rakes, action_types, allIns, action_amounts | ||||||
|                         ,actionNos, hudImportData, maxSeats, tableName, seatNos): |                         ,actionNos, hudImportData, maxSeats, tableName, seatNos): | ||||||
|     """stores a tourney holdem/omaha hand into the database""" |     """stores a tourney holdem/omaha hand into the database""" | ||||||
|  | 
 | ||||||
|  |     import_options = config.get_import_parameters() | ||||||
|  |     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.fillCardArrays(len(names), base, category, card_values, card_suits) | ||||||
|     fpdb_simple.fill_board_cards(board_values, board_suits) |     fpdb_simple.fill_board_cards(board_values, board_suits) | ||||||
|      |      | ||||||
|     tourney_id=fpdb_simple.store_tourneys(cursor, tourneyTypeId, siteTourneyNo, entries, prizepool, tourney_start) |     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) |     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) |                                    ,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 |                       backend, db, cursor, category, hands_id, player_ids, start_cashes, positions | ||||||
|                     , card_values, card_suits, winnings, rakes, seatNos, tourneys_players_ids) |                     , card_values, card_suits, winnings, rakes, seatNos, tourneys_players_ids) | ||||||
|      |      | ||||||
|  | @ -123,21 +139,26 @@ def tourney_holdem_omaha(backend, db, cursor, base, category, siteTourneyNo, buy | ||||||
|     return hands_id |     return hands_id | ||||||
| #end def tourney_holdem_omaha | #end def tourney_holdem_omaha | ||||||
| 
 | 
 | ||||||
| def tourney_stud(backend, db, cursor, base, category, siteTourneyNo, buyin, fee, knockout, entries | def tourney_stud(config, backend, db, cursor, base, category, siteTourneyNo, buyin, fee, knockout, entries | ||||||
|                 ,prizepool, tourneyStartTime, payin_amounts, ranks, tourneyTypeId, siteId |                 ,prizepool, tourneyStartTime, payin_amounts, ranks, tourneyTypeId, siteId | ||||||
|                 ,siteHandNo, gametypeId, handStartTime, names, playerIds, startCashes, antes |                 ,siteHandNo, gametypeId, handStartTime, names, playerIds, startCashes, antes | ||||||
|                 ,cardValues, cardSuits, winnings, rakes, actionTypes, allIns, actionAmounts |                 ,cardValues, cardSuits, winnings, rakes, actionTypes, allIns, actionAmounts | ||||||
|                 ,actionNos, hudImportData, maxSeats, tableName, seatNos): |                 ,actionNos, hudImportData, maxSeats, tableName, seatNos): | ||||||
| #stores a tourney stud/razz hand into the database | #stores a tourney stud/razz hand into the database | ||||||
|  | 
 | ||||||
|  |     import_options = config.get_import_parameters() | ||||||
|  |     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) |     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 |                                              , playerIds, startCashes, antes, cardValues, cardSuits | ||||||
|                                              , winnings, rakes, seatNos, tourneys_players_ids) |                                              , winnings, rakes, seatNos, tourneys_players_ids) | ||||||
|      |      | ||||||
|  |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -4,7 +4,10 @@ from Hand import * | ||||||
| import py | import py | ||||||
| 
 | 
 | ||||||
| #regression-test-files/stars/badugi/ring-fl-badugi.txt | #regression-test-files/stars/badugi/ring-fl-badugi.txt | ||||||
| #   s0rrow: start $30.00 end: $22.65 total: ($7.35) | #   s0rrow: input: $30.00 end: $22.65 total: ($7.35) | ||||||
|  | #regression-test-files/stars/plo/PLO-6max.txt | ||||||
|  | #   s0rrow: input: $18.35 end: $0 total: ($18.35) | ||||||
|  | #   Notes: last hand #25975302416 s0rrow aifp against 2 players | ||||||
| 
 | 
 | ||||||
| gametype = {'type':'ring', 'base':'draw', 'category':'badugi', 'limitType':'fl', 'sb':'0.25', 'bb':'0.50','currency':'USD'} | gametype = {'type':'ring', 'base':'draw', 'category':'badugi', 'limitType':'fl', 'sb':'0.25', 'bb':'0.50','currency':'USD'} | ||||||
| text = "" | text = "" | ||||||
|  | @ -30,7 +33,10 @@ def testGameInfo(): | ||||||
|     {'type':'ring', 'base':'hold', 'category':'omahahilo', 'limitType':'fl', 'sb':'2', 'bb':'4','currency':'USD'}), |     {'type':'ring', 'base':'hold', 'category':'omahahilo', 'limitType':'fl', 'sb':'2', 'bb':'4','currency':'USD'}), | ||||||
| 
 | 
 | ||||||
|     (u"PokerStars Game #25923772706:  Badugi Limit ($0.25/$0.50) - 2009/03/13 16:40:58 ET", |     (u"PokerStars Game #25923772706:  Badugi Limit ($0.25/$0.50) - 2009/03/13 16:40:58 ET", | ||||||
|     {'type':'ring', 'base':'draw', 'category':'badugi', 'limitType':'fl', 'sb':'0.25', 'bb':'0.50','currency':'USD'}) |     {'type':'ring', 'base':'draw', 'category':'badugi', 'limitType':'fl', 'sb':'0.25', 'bb':'0.50','currency':'USD'}), | ||||||
|  | 
 | ||||||
|  |     (u"PokerStars Game #25974627364:  Omaha Pot Limit ($0.05/$0.10) - 2009/03/15 0:29:00 ET", | ||||||
|  |     {'type':'ring', 'base':'hold', 'category':'omahahi', 'limitType':'pl', 'sb':'0.05', 'bb':'0.10','currency':'USD'}) | ||||||
|     ) |     ) | ||||||
|     for (header, info) in pairs: |     for (header, info) in pairs: | ||||||
|         yield checkGameInfo, hhc, header, info |         yield checkGameInfo, hhc, header, info | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user