comparison src/parpg/grease/component/base.py @ 27:09b581087d68

Added base files for grease
author KarstenBock@gmx.net
date Tue, 12 Jul 2011 10:16:48 +0200
parents
children
comparison
equal deleted inserted replaced
26:5529dd5644b8 27:09b581087d68
1 class ComponentBase(object):
2 """Component abstract base class
3
4 Strictly speaking you do not need to derive from this class to create your
5 own components, but it does serve to document the full interface that a
6 component implements and it provides some basic implementations for
7 certain methods
8 """
9
10 ## Optional attributes and methods ##
11
12 def set_manager(self, manager):
13 """Set the manager of this component. If this method exists it will be
14 automatically called when the component is added to a manager.
15
16 This method stores the manager and allows the component to be added
17 only once to a single manager.
18 """
19 assert getattr(self, 'manager', None) is None, 'Component cannot be added to multiple managers'
20 self.manager = manager
21
22 def __del__(self):
23 """Break circrefs to allow faster collection"""
24 if hasattr(self, 'manager'):
25 del self.manager
26
27 ## Mandatory methods ##
28
29 def add(self, entity_id, data=None, **data_kw):
30 """Add a data entry in the component for the given entity. Additional
31 data (if any) for the entry can be provided in the data argument or as
32 keyword arguments. Additional data is optional and if omitted then
33 suitable defaults will be used. Return an entity data object
34 for the new entity entry.
35
36 The semantics of the data arguments is up to the component.
37
38 An entity_id is a unique key, thus multiple separate data entries for
39 a given entity are not allowed. Components can indivdually decide
40 what to do if an entity_id is added multiple times to the component.
41 Potential options include, raising an exception, replacing the
42 existing data or coalescing it somehow.
43 """
44
45 def remove(self, entity_id):
46 """Remove the entity data entry from the component. If the
47 entity is not in the component, raise KeyError
48 """
49
50 def __delitem_(self, entity_id):
51 """Same as remove()"""
52
53 def __len__(self):
54 """Return the number of entities in the component"""
55 raise NotImplementedError()
56
57 def __iter__(self):
58 """Return an iterator of entity data objects in this component
59
60 No order is defined for these data objects
61 """
62 raise NotImplementedError()
63
64 def __contains__(self, entity_id):
65 """Return True if the entity is contained in the component"""
66 raise NotImplementedError()
67
68 def __getitem__(self, entity_id):
69 """Return the entity data object for the given entity.
70 The entity data object returned may be mutable, immutable or a
71 mutable copy of the data at the discretion of the component
72 """
73 raise NotImplementedError()
74