diff options
| author | Jenkins <jenkins@review.openstack.org> | 2012-12-05 21:16:32 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2012-12-05 21:16:32 +0000 |
| commit | ea7ced276d2f080718cd89f3a77378cdf24fabf5 (patch) | |
| tree | 8af04e6b8fb4a8fe952df20ab4dd0fa25a0454ae /openstack | |
| parent | 2f7a7edc41d0e7b663877592aeda14e766a64241 (diff) | |
| parent | c67f2881a4bbe5958048610458180c3f9d914964 (diff) | |
| download | oslo-ea7ced276d2f080718cd89f3a77378cdf24fabf5.tar.gz oslo-ea7ced276d2f080718cd89f3a77378cdf24fabf5.tar.xz oslo-ea7ced276d2f080718cd89f3a77378cdf24fabf5.zip | |
Merge "Fix broken --version command"
Diffstat (limited to 'openstack')
| -rw-r--r-- | openstack/common/version.py | 32 |
1 files changed, 26 insertions, 6 deletions
diff --git a/openstack/common/version.py b/openstack/common/version.py index a19e422..dae88e3 100644 --- a/openstack/common/version.py +++ b/openstack/common/version.py @@ -24,17 +24,37 @@ import pkg_resources import setup -class _deferred_version_string(object): +class _deferred_version_string(str): """Internal helper class which provides delayed version calculation.""" - def __init__(self, version_info, prefix): - self.version_info = version_info - self.prefix = prefix + + def __new__(cls, version_info, prefix): + new_obj = str.__new__(cls, "") + new_obj._version_info = version_info + new_obj._prefix = prefix + new_obj._cached_version = None + return new_obj + + def _get_cached_version(self): + if not self._cached_version: + self._cached_version = \ + "%s%s" % (self._prefix, + self._version_info.version_string()) + return self._cached_version + + def __len__(self): + return self._get_cached_version().__len__() + + def __contains__(self, item): + return self._get_cached_version().__contains__(item) + + def __getslice__(self, i, j): + return self._get_cached_version().__getslice__(i, j) def __str__(self): - return "%s%s" % (self.prefix, self.version_info.version_string()) + return self._get_cached_version() def __repr__(self): - return "%s%s" % (self.prefix, self.version_info.version_string()) + return self._get_cached_version() class VersionInfo(object): |
