Bläddra i källkod

feat(deprecation): deprecate `Event.get_description()` function

pull/34/head
Jérôme Deuchnord 3 år sedan
förälder
incheckning
643ddacce8
3 ändrade filer med 39 tillägg och 16 borttagningar
  1. +8
    -7
      .github/PULL_REQUEST_TEMPLATE.md
  2. +12
    -0
      kosmorrolib/core.py
  3. +19
    -9
      kosmorrolib/model.py

+ 8
- 7
.github/PULL_REQUEST_TEMPLATE.md Visa fil

@@ -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.


+ 12
- 0
kosmorrolib/core.py Visa fil

@@ -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

+ 19
- 9
kosmorrolib/model.py Visa fil

@@ -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 {


||||||
x
 
000:0
Laddar…
Avbryt
Spara