The SideEffect library provides a convenient way to manage state changes with optional synchronous or asynchronous side effects. This can be particularly useful in scenarios where you want to perform an action whenever a state changes, such as updating a user interface, logging, notifications, or other side effects.
You can install SideEffect using pip:
pip install sideeffectThe SideEffect class allows you to manage a state with an optional side effect that can be executed either synchronously or asynchronously when the state is changed. Additionally, you can specify if the side effect is dependent on the state or not.
from sideeffect import SideEffect
def drink_coffee():
print("Coffee consumed ☕️")
coffee_level = SideEffect(default="Full", side_effect=drink_coffee)
# Oh no, the coffee level is dropping!
coffee_level.setState("Half")The side_effect function is a convenience function that creates a SideEffect instance and returns accessor functions for getting and setting the state.
from sideeffect import side_effect
def drink_coffee():
print("Coffee consumed ☕️")
coffee_level, set_coffee_level = side_effect(default="Full", side_effect=drink_coffee)
# Oh no, the coffee level is dropping!
set_coffee_level("Half")-
__init__(self, default=0, side_effect=lambda: None, *, asynchronous=True, dependent=False) -> NoneInitializes the
SideEffectinstance.default(Any): The initial state (default is 0).side_effect(Callable[[], None]): A callable to be executed as a side effect (default is a no-op lambda).asynchronous(bool): If True, the side effect is executed asynchronously (default is True).dependent(bool): If True, the side effect is dependent on the state (default is False).
state(self) -> AnyReturns the current state.
setState(self, value: Any, *, asynchronous: Union[bool, None]=None, cancel_side_effect: bool=False) -> NoneSets the state to the given value and executes the side effect.
value(Any): The new state value.asynchronous(Union[bool, None]): If provided, overrides the instance's asynchronous setting for this call.cancel_side_effect(bool): If True, cancels the execution of the side effect.- Raises
TypeErrorif theasynchronousorcancel_side_effectparameter is not a boolean.
disable_side_effect(self) -> NoneDisables the execution of the side effect.
enable_side_effect(self) -> NoneEnables the execution of the side effect.
-
side_effect(default=0, side_effect=lambda: None, *, asynchronous=True, dependent=False) -> Tuple[SideEffect.state, SideEffect.setState]A convenience function to create a
SideEffectinstance and return accessor functions.default(Any): The initial state (default is 0).side_effect(Callable[[], None]): A callable to be executed as a side effect (default is a no-op lambda).asynchronous(bool): If True, the side effect is executed asynchronously (default is True).dependent(bool): If True, the side effect is dependent on the state (default is False).
Returns a tuple containing:
- A lambda to get the current state.
- A lambda to set the state and execute the side effect.
- Removed
_side_effect_on_actionattribute for improved side effect control and clarity inSideEffectclass. - Enhanced thread management for more efficient side effect execution handling.
Contributions are welcome! Please open an issue or submit a pull request on GitHub.
This project is licensed under the MIT License. See the LICENSE file for details.