Преглед на файлове

Fixed str/int in galaxy. Working(ish) PlanetUp!

bugz преди 5 години
родител
ревизия
b91b48b2ad
променени са 2 файла, в които са добавени 55 реда и са изтрити 2 реда
  1. 54 1
      flexible.py
  2. 1 1
      galaxy.py

+ 54 - 1
flexible.py

@@ -1975,6 +1975,7 @@ class PlanetUpScript(object):
         self.queue_game.put(Boxes.alert("Let me see what I can see here..."))  
 
     def game_prompt(self, prompt):
+        log.info("prompt {0} : {1}".format(self.state, prompt))
         if self.state == 2 and re.match(r"Command \[TL=.* \(\?=Help\)\? :", prompt):
             self.game.to_player = True
             # For now we output the information, and exit
@@ -2080,16 +2081,52 @@ class PlanetUpScript(object):
                     self.fetch = 'C'
                     self.queue_player.put("NTE")
                     self.state = 7
-                # elif
                 else:
+                    for i in ('F','O','E'):
+                        if self.need[i] > self.cargo[i]:
+                            self.fetch = i
+                            place = self.game.gamedata.find_nearest_selling(self.planet_sector, i)
+                            if place == 0:
+                                self.queue_game.put(self.nl + Boxes.alert("Find Nearest Failed!"))
+                                self.deactivate()
+                                return
+                            self.queue_player.put("{0}\rE".format(place))
+                            self.state = 7
+                            return
+                    # Ok, upgrade time!
                     self.queue_game.put("No, not yet!" + self.nl)
                     self.deactivate()
+
+                # for i in ['F', 'O', 'E']:
+                #     if self.need[i] > self.cargo[i]:
+                #         ready = False
+                #         self.queue_game.put( "Need: {0}".format(i) + self.nl)
+
         elif self.state == 7:
             if re.match(r"Command \[TL=.* \(\?=Help\)\? :", prompt):
                 if self.fetch == 'C':
                     # Colonist
                     # [How many groups of Colonists do you want to take ([125] empty holds) ? ]
                     self.queue_player.put("L")   # "LT\r")
+                elif self.fetch in ('F', 'O', 'E'):
+                    # Port, Trade
+                    self.queue_player.put("pt")
+            elif re.match(r"How many holds of .+ do you want to sell", prompt):
+                # This shouldn't occur...
+                self.queue_game.put("OH NOSE!" + self.nl)
+                self.deactivate()
+            elif prompt.startswith('Stop in this sector (Y,N,E,I,R,S,D,P,?) (?=Help) [N] ?'):
+                self.queue_game.put("N")
+            elif re.match(r"How many holds of .+ do you want to buy \[\d+\]\? ", prompt):
+                if prompt.startswith('How many holds of ' + self.fetch):
+                    _, _, holds = prompt.partition('[')
+                    holds, _, _ = holds.partition(']')
+                    self.fetch_amount = int(holds)
+                    self.queue_player.put("\r\r")
+                    self.state = 8
+                else:
+                    # We don't want to buy this one.  Skip it!
+                    self.queue_player.put("0\r")
             elif prompt.startswith('Land on which planet <Q to abort> ?'):
                 if self.fetch == 'C':
                     self.queue_player.put("1\r")
@@ -2112,7 +2149,22 @@ class PlanetUpScript(object):
                 if self.fetch == 'C':
                     # Colonist / No display Planet / Leave
                     self.queue_player.put("SNL")
+                elif self.fetch in ('F', 'O', 'E'):
+                    # Cargo, No display / Leave
+                    self.queue_player.put("TNL")
+            elif prompt.startswith('(1)Ore, (2)Org or (3)Equipment ?'):
+                if self.fetch == 'F':
+                    idx = 1
+                elif self.fetch == 'O':
+                    idx = 2
+                elif self.fetch == 'E':
+                    idx = 3
+                self.queue_player.put("{0}\r\rQ".format(idx))
+                self.cargo[self.fetch] += self.fetch_amount
+                self.state = 6
+
             elif prompt.startswith('(1)Ore, (2)Org or (3)Equipment Production?'):
+                # TO FIX:  Use self.place_people to decide.
                 # Ok, I'd choose, but for right now.
                 self.queue_player.put("1\r\rQ")
                 self.colonists += self.fetch_amount
@@ -2139,6 +2191,7 @@ class PlanetUpScript(object):
                 self.deactivate()
 
     def game_line(self, line):
+        log.info("line {0} : {1}".format(self.state, line))        
         if self.state == 1:
             if 'Personal Planet Scan' in line:
                 self.state = 2

+ 1 - 1
galaxy.py

@@ -415,7 +415,7 @@ class GameData(object):
                     if sp["port"][s_pos] == "S":
                         # Ok, they are selling!
                         if sell in sp:
-                            if sp[sell]["units"] >= at_least:
+                            if int(sp[sell]["units"]) >= at_least:
                                 log.warn(
                                     "find_nearest_selling( {0}, {1}): {2} {3} units".format(
                                         sector, selling, s, sp[sell]["units"]