~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/registry.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2011-01-14 23:41:14 UTC
  • mfrom: (5611.1.3 bzr.dev)
  • Revision ID: pqm@pqm.ubuntu.com-20110114234114-r4hdusue691ekeg6
(jelmer) Cope with IPv6 addresses in ``bzr serve`` (Jelmer Vernooij)

Show diffs side-by-side

added added

removed removed

Lines of Context:
16
16
 
17
17
"""Classes to provide name-to-object registry-like support."""
18
18
 
19
 
from __future__ import absolute_import
20
19
 
21
20
from bzrlib.pyutils import get_named_object
22
21
 
36
35
    def __init__(self, obj):
37
36
        self._obj = obj
38
37
 
39
 
    def get_module(self):
40
 
        """Get the module the object was loaded from."""
41
 
        return self._obj.__module__
42
 
 
43
38
    def get_obj(self):
44
39
        """Get the object that was saved at creation time"""
45
40
        return self._obj
59
54
        self._imported = False
60
55
        super(_LazyObjectGetter, self).__init__(None)
61
56
 
62
 
    def get_module(self):
63
 
        """Get the module the referenced object will be loaded from.
64
 
        """
65
 
        return self._module_name
66
 
 
67
57
    def get_obj(self):
68
58
        """Get the referenced object.
69
59
 
133
123
                      override_existing=False):
134
124
        """Register a new object to be loaded on request.
135
125
 
136
 
        :param key: This is the key to use to request the object later.
137
126
        :param module_name: The python path to the module. Such as 'os.path'.
138
127
        :param member_name: The member of the module to return.  If empty or
139
128
                None, get() will return the module itself.
140
129
        :param help: Help text for this entry. This may be a string or
141
130
                a callable.
142
 
        :param info: More information for this entry. Registry.get_info()
143
 
                can be used to get this information. Registry treats this as an
144
 
                opaque storage location (it is defined by the caller).
 
131
        :param info: More information for this entry. Registry
145
132
        :param override_existing: If True, replace the existing object
146
133
                with the new one. If False, if there is already something
147
134
                registered with the same key, raise a KeyError
176
163
        """
177
164
        return self._dict[self._get_key_or_default(key)].get_obj()
178
165
 
179
 
    def _get_module(self, key):
180
 
        """Return the module the object will be or was loaded from.
181
 
 
182
 
        :param key: The key to obtain the module for.
183
 
        :return: The name of the module
184
 
        """
185
 
        return self._dict[key].get_module()
186
 
 
187
166
    def get_prefix(self, fullname):
188
167
        """Return an object whose key is a prefix of the supplied value.
189
168
 
260
239
        Registry.__init__(self)
261
240
        self._other_registry = other_registry
262
241
 
263
 
    def register(self, key, obj, help=None, info=None,
264
 
                 override_existing=False):
265
 
        Registry.register(self, key, obj, help=help, info=info,
266
 
            override_existing=override_existing)
267
 
        if self._other_registry is not None:
268
 
            self._other_registry.register(key, obj, help=help,
269
 
                info=info, override_existing=override_existing)
270
 
 
271
242
    def register_lazy(self, key, module_name, member_name,
272
243
                      help=None, info=None,
273
244
                      override_existing=False):
279
250
            self._other_registry.register_lazy(key, module_name, member_name,
280
251
                help=help, info=info, override_existing=override_existing)
281
252
 
282
 
    def remove(self, key):
283
 
        Registry.remove(self, key)
284
 
        if self._other_registry is not None:
285
 
            self._other_registry.remove(key)
286
 
 
287
253
    def get(self, format_string):
288
254
        r = Registry.get(self, format_string)
289
255
        if callable(r):
290
256
            r = r()
291
257
        return r
 
258
 
 
259