# -*- coding: utf-8 -*-
"""The events which can be bound to envs."""
from abc import ABC, abstractmethod
from typing import Any, Tuple
[docs]
class Event:
"""A class representing the information of an event.
It contains the name of the event, the arguments of the event,
and the returns of the event.
"""
def __init__(
self,
name: str,
args: dict = None,
returns: Any = None,
) -> None:
self._name = name
self._args = args
self._returns = returns
@property
def name(self) -> str:
"""Return the name of the event."""
return self._name
@property
def args(self) -> dict:
"""Return the arguments of the event."""
return self._args
@property
def returns(self) -> Any:
"""Return the returns of the event."""
return self._returns
[docs]
class Getable(ABC):
"""Representing an env whose value can be gotten."""
[docs]
@abstractmethod
def get(self) -> Any:
"""Get the value of the env.
Returns:
`Any`: The value of the env.
"""
[docs]
class Setable(ABC):
"""Representing an env whose value can be set."""
[docs]
@abstractmethod
def set(self, value: Any) -> bool:
"""Set the value of the env.
Args:
value (`Any`): The new value of the env.
Returns:
`bool`: Whether the value was set successfully.
"""
[docs]
class Movable2D(ABC):
"""A class representing an env can be moved in 2D."""
[docs]
@abstractmethod
def move_by(self, x: float, y: float) -> bool:
"""Move the env in 2D by the given vector.
Args:
x (`float`): The movement in x direction.
y (`float`): The movement in y direction.
Returns:
`bool`: Whether the movement was successful.
"""
[docs]
@abstractmethod
def move_to(self, x: float, y: float) -> bool:
"""Move the env to the given position.
Args:
x (`float`): The x coordinate of the new position.
y (`float`): The y coordinate of the new position.
Returns:
`bool`: Whether the movement was successful.
"""
[docs]
@abstractmethod
def get_position(self) -> Tuple[float, float]:
"""Get the position of the env.
Returns:
`Tuple[float, float]`: The position of the env.
"""
[docs]
class Holdable(ABC):
"""A class representing an env can be held,and during
the holding period, all access behaviors except the owner
are prohibited.
"""
[docs]
@abstractmethod
def acquire(self, owner: str) -> bool:
"""Acquire the env.
Args:
owner (`str`): The owner of the env.
Returns:
`bool`: Whether the env was acquired successfully.
"""
[docs]
@abstractmethod
def release(self, owner: str) -> bool:
"""Release the env.
Args:
owner (`str`): The owner of the env.
Returns:
`bool`: Whether the env was released successfully.
"""