diff options
author | Markus Holtermann <info@markusholtermann.eu> | 2013-01-30 20:00:14 +0100 |
---|---|---|
committer | Markus Holtermann <info@markusholtermann.eu> | 2013-01-30 20:00:14 +0100 |
commit | 41af0a769e8896b6df5baccfff31d5ccea3f7da8 (patch) | |
tree | 7f08d9b42f7dcf670cf523a73a1bab4ccaa6013b /bvggrabber | |
parent | a259ff6b63839e178b7ed652a08ab1c64858120c (diff) | |
download | bvg-grabber-41af0a769e8896b6df5baccfff31d5ccea3f7da8.tar.gz bvg-grabber-41af0a769e8896b6df5baccfff31d5ccea3f7da8.tar.bz2 bvg-grabber-41af0a769e8896b6df5baccfff31d5ccea3f7da8.zip |
Add total order for ``bvggrabber.api.Departure``. Fixes #1
Diffstat (limited to 'bvggrabber')
-rw-r--r-- | bvggrabber/api/__init__.py | 33 |
1 files changed, 28 insertions, 5 deletions
diff --git a/bvggrabber/api/__init__.py b/bvggrabber/api/__init__.py index ed5ca3f..8568d00 100644 --- a/bvggrabber/api/__init__.py +++ b/bvggrabber/api/__init__.py @@ -3,7 +3,9 @@ import datetime import json import re +from functools import total_ordering from math import ceil, floor + from dateutil.parser import parse @@ -30,6 +32,7 @@ class QueryApi(object): "the call() method!") +@total_ordering class Departure(object): def __init__(self, start, end, when, line, since=None): @@ -54,11 +57,6 @@ class Departure(object): raise TypeError("when must be a valid datetime, timestamp or " "string!") - def __str__(self): - return "Start: %s, End: %s, when: %s, now: %s, line: %s" % ( - self.start, self.end, hourformat(self.when), - hourformat(self.now), self.line) - @property def remaining(self): return compute_remaining(self.now, self.when) @@ -73,3 +71,28 @@ class Departure(object): 'when_full': fullformat(self.when), 'when_hour': hourformat(self.when), 'remaining': round(self.remaining)}) + + def __eq__(self, other): + """Two departures are assumed to be equal iff their remaining time + and their destination are equal. + + Right now we do **not** considering the start or line, since that would + require some kind of geo location in order to define a *total order*. + """ + return ((self.remaining, self.end.lower()) == + (other.remaining, other.end.lower())) + + def __lt__(self, other): + """A departure is assumed to be less than another iff its remaining + time is less than the remaining time of the other departure. + + Right now we do **not** considering the start, end or line, since that + would require some kind of geo location in order to define a *total + order*. + """ + return (remaining < other.remaining) + + def __str__(self): + return "Start: %s, End: %s, when: %s, now: %s, line: %s" % ( + self.start, self.end, hourformat(self.when), + hourformat(self.now), self.line) |