# HG changeset patch # User Teemu Piippo # Date 1497940782 -10800 # Node ID 3a495bc4b7b536f0e6a5a19f4a4ea1e1d0975658 # Parent 3d094a804af8f9c5af1c68741d754c30f36281de optimointia diff -r 3d094a804af8 -r 3a495bc4b7b5 buses.py --- a/buses.py Tue Jun 20 09:37:43 2017 +0300 +++ b/buses.py Tue Jun 20 09:39:42 2017 +0300 @@ -109,7 +109,7 @@ # ja jos tämä ajo pysähtyy tällä pysäkillä, ei kuitenkaan saapuen # päätepysäkille, stop = trip.pysäkkiReitillä(self) - if stop and not stop.isArrival(): # stop is not trip.reitti[-1]: + if stop and not stop.isArrival: # stop is not trip.reitti[-1]: # ja jos tämä pysähdys on tulevaisuudessa, stop_time = datetime.combine(date, time()) + stop.saapumisaika if stop_time >= nyt(): @@ -128,15 +128,21 @@ self.saapumisaika, self.lähtöaika, self.pysäkki, self.ajo = saapumisaika, lähtöaika, \ pysäkki, ajo self.ajettu_matka = ajettu_matka + self._isArrival = None + @property def isArrival(self): - iterator = iter(self.ajo.reitti) - stop = next(iterator) - while stop is not self: + if self._isArrival is None: + iterator = iter(self.ajo.reitti) stop = next(iterator) - for stop in iterator: - if stop.pysäkki.alue != self.pysäkki.alue: - return False - return True + while stop is not self: + stop = next(iterator) + for stop in iterator: + if stop.pysäkki.alue != self.pysäkki.alue: + self._isArrival = False + break + else: + self._isArrival = True + return self._isArrival def __repr__(self): return 'Pysähdys(%r, %r, %r, %r)' % (self.saapumisaika, self.lähtöaika, self.pysäkki, self.ajo)