Skip to content

Instantly share code, notes, and snippets.

@PJUllrich
Created January 14, 2018 20:13
Show Gist options
  • Save PJUllrich/71fed6e2fe29b0a4f3f4725892423329 to your computer and use it in GitHub Desktop.
Save PJUllrich/71fed6e2fe29b0a4f3f4725892423329 to your computer and use it in GitHub Desktop.
from observer.observer_pattern import Observable, Observer
class Elf:
name = 'Galadriel'
def nall_nin(self):
print('Elf says: Calling the Overlord ...')
class Dwarf:
def estver_narho(self):
print('Dwarf says: Calling the Overlord ...')
class Human:
def ring_mig(self):
print('Human says: Calling the Overlord ...')
class MinionAdapter(Observable):
_initialised = False
def __init__(self, minion, **adapted_methods):
super().__init__()
self.minion = minion
for key, value in adapted_methods.items():
func = getattr(self.minion, value)
self.__setattr__(key, func)
self._initialised = True
def __getattr__(self, attr):
return getattr(self.minion, attr)
def __setattr__(self, key, value):
if not self._initialised:
super().__setattr__(key, value)
else:
setattr(self.minion, key, value)
self.notify_observer(key=key, value=value)
class MinionFacade:
minion_adapters = None
@classmethod
def create_minions(cls):
print('Creating minions ...')
cls.minion_adapters = [
MinionAdapter(Elf(), call_me='nall_nin'),
MinionAdapter(Dwarf(), call_me='estver_narho'),
MinionAdapter(Human(), call_me='ring_mig')
]
@classmethod
def summon_minions(cls):
print('Summoning minions ...')
for adapter in cls.minion_adapters:
adapter.call_me()
@classmethod
def monitor_elves(cls, observer):
cls.minion_adapters[0].add_observer(observer)
print('Added an observer to the Elves!')
@classmethod
def change_elves_name(cls, new_name):
print('Changing the Elves name ...')
cls.minion_adapters[0].name = new_name
print('Elves name changed!')
class EvilOverlord(Observer):
def update(self, obj, *args, **kwargs):
print('The Evil Overlord received a message!')
print(f'Object: {obj}, Args: {args}, Kwargs: {kwargs}')
class Observer:
def update(self, obj, *args, **kwargs):
raise NotImplementedError
class Observable:
def __init__(self):
self._observers = []
def add_observer(self, observer):
self._observers.append(observer)
def remove_observer(self, observer):
self._observers.remove(observer)
def notify_observer(self, *args, **kwargs):
for observer in self._observers:
observer.update(self, *args, **kwargs)
if __name__ == '__main__':
overlord = EvilOverlord()
MinionFacade.create_minions()
MinionFacade.monitor_elves(overlord)
MinionFacade.change_elves_name('Elrond')
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment