From d079fc7b201c7f5855c05acc80955e3b16c4ef6d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A9r=C3=B4me=20Deuchnord?= Date: Sun, 1 Dec 2019 10:04:19 +0100 Subject: [PATCH 1/2] fix(position): remove useless altitude argument BREAKING CHANGE: invoking kosmorro command with the --altitude argument will now fail with an "unrecognized arguments" error. --- kosmorro | 6 ++---- kosmorrolib/data.py | 3 +-- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/kosmorro b/kosmorro index 1020db2..a08442f 100644 --- a/kosmorro +++ b/kosmorro @@ -40,7 +40,7 @@ def main(): if day is not None and month is None: month = date.today().month - ephemeris = EphemeridesComputer(Position(args.latitude, args.longitude, altitude=args.altitude)) + ephemeris = EphemeridesComputer(Position(args.latitude, args.longitude)) ephemerides = ephemeris.compute_ephemerides(year, month, day) dump = output_formats[args.format](ephemerides, date(year, month, day)) @@ -84,7 +84,7 @@ def get_args(output_formats: [str]): parser = argparse.ArgumentParser(description='Compute the ephemerides for a given date, at a given position' ' on Earth.', epilog='By default, the ephemerides will be computed for today (%s) for an' - ' observer positioned at coordinates (0,0), with an altitude of 0.' + ' observer positioned at coordinates (0,0).' % today.strftime('%a %b %d, %Y')) parser.add_argument('--version', '-v', dest='special_action', action='store_const', const=output_version, @@ -97,8 +97,6 @@ def get_args(output_formats: [str]): help="The observer's latitude on Earth") parser.add_argument('--longitude', '-lon', type=float, default=0., help="The observer's longitude on Earth") - parser.add_argument('--altitude', '-alt', type=float, default=0., - help="The observer's altitude on Earth") parser.add_argument('--day', '-d', type=int, default=today.day, help='A number between 1 and 28, 29, 30 or 31 (depending on the month). The day you want to ' ' compute the ephemerides for. Defaults to %d (the current day).' % today.day) diff --git a/kosmorrolib/data.py b/kosmorrolib/data.py index 58b5eb7..e37cd0e 100644 --- a/kosmorrolib/data.py +++ b/kosmorrolib/data.py @@ -61,10 +61,9 @@ class MoonPhase: class Position: - def __init__(self, latitude: float, longitude: float, altitude: float = 0): + def __init__(self, latitude: float, longitude: float): self.latitude = latitude self.longitude = longitude - self.altitude = altitude self.observation_planet = None def get_planet_topos(self) -> Topos: From 61536da9df4e742e9f7046fb177ecd09fb711b38 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A9r=C3=B4me=20Deuchnord?= Date: Sun, 1 Dec 2019 10:16:53 +0100 Subject: [PATCH 2/2] perf(position): enhance the position performing --- kosmorrolib/data.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/kosmorrolib/data.py b/kosmorrolib/data.py index e37cd0e..d7e931b 100644 --- a/kosmorrolib/data.py +++ b/kosmorrolib/data.py @@ -65,12 +65,17 @@ class Position: self.latitude = latitude self.longitude = longitude self.observation_planet = None + self._topos = None def get_planet_topos(self) -> Topos: if self.observation_planet is None: raise TypeError('Observation planet must be set.') - return self.observation_planet + Topos(latitude_degrees=self.latitude, longitude_degrees=self.longitude) + if self._topos is None: + self._topos = self.observation_planet + Topos(latitude_degrees=self.latitude, + longitude_degrees=self.longitude) + + return self._topos class AsterEphemerides: