@@ -1,10 +1,11 @@ | |||||
| Q | A | | Q | A | ||||
| -------------- | --- | | -------------- | --- | ||||
| Bug fix? | yes/no | | Bug fix? | yes/no | ||||
| New feature? | yes/no | | New feature? | yes/no | ||||
| Related issues | Fix #... <!-- prefix each issue number with "Fix #", if any --> | | Related issues | Fix #... <!-- prefix each issue number with "Fix #" --> | ||||
| Has BC-break | yes/no | | Documentation PR | Kosmorrolib/libdoc#... <!-- if you implement a new feature, a PR in the documentation is required --> | ||||
| License | GNU AGPL-v3 | | Has BC-break | yes/no | ||||
| License | GNU AGPL-v3 | |||||
<!-- | <!-- | ||||
Replace this notice with a short README for your feature/bugfix. | Replace this notice with a short README for your feature/bugfix. | ||||
@@ -16,6 +16,7 @@ | |||||
# You should have received a copy of the GNU Affero General Public License | # You should have received a copy of the GNU Affero General Public License | ||||
# along with this program. If not, see <https://www.gnu.org/licenses/>. | # along with this program. If not, see <https://www.gnu.org/licenses/>. | ||||
from warnings import warn | |||||
from skyfield.api import Loader | from skyfield.api import Loader | ||||
from skyfield.timelib import Time | from skyfield.timelib import Time | ||||
from skyfield.nutationlib import iau2000b | from skyfield.nutationlib import iau2000b | ||||
@@ -48,3 +49,14 @@ def flatten_list(the_list: list): | |||||
new_list.append(item) | new_list.append(item) | ||||
return new_list | return new_list | ||||
def deprecated(message): | |||||
def inner(decorated): | |||||
def f(*args, **kwargs): | |||||
warn(message, DeprecationWarning, stacklevel=2) | |||||
return decorated(*args, **kwargs) | |||||
return f | |||||
return inner |
@@ -25,7 +25,7 @@ import numpy | |||||
from skyfield.api import Topos, Time, Angle | from skyfield.api import Topos, Time, Angle | ||||
from skyfield.vectorlib import VectorSum as SkfPlanet | from skyfield.vectorlib import VectorSum as SkfPlanet | ||||
from .core import get_skf_objects, get_timescale | from .core import get_skf_objects, get_timescale, deprecated | ||||
from .enum import MoonPhaseType, EventType, ObjectIdentifier, ObjectType | from .enum import MoonPhaseType, EventType, ObjectIdentifier, ObjectType | ||||
@@ -240,17 +240,27 @@ class Event(Serializable): | |||||
self.details, | self.details, | ||||
) | ) | ||||
@deprecated( | |||||
"kosmorrolib.Event.get_description method is deprecated since version 1.1 " | |||||
"and will be removed in version 2.0. " | |||||
"It should be reimplemented it in your own code." | |||||
) | |||||
def get_description(self, show_details: bool = True) -> str: | def get_description(self, show_details: bool = True) -> str: | ||||
description = self.event_type.value % self._get_objects_name() | """Return a textual description for the given details | ||||
if show_details and self.details is not None: | *Deprecated* since version 1.1 | ||||
description += " ({:s})".format(self.details) | """ | ||||
return description | description = f"Event of type {str(self.event_type)}" | ||||
if show_details and len(self.details) > 0: | |||||
details = "" | |||||
for key in self.details: | |||||
if details != "": | |||||
details += ", " | |||||
details += f"{key}: {self.details[key]}" | |||||
def _get_objects_name(self): | description += f" ({details})" | ||||
if len(self.objects) == 1: | |||||
return self.objects[0].name | |||||
return tuple(object.name for object in self.objects) | return description | ||||
def serialize(self) -> dict: | def serialize(self) -> dict: | ||||
return { | return { | ||||