X-Git-Url: https://code.grnet.gr/git/snf-image-creator/blobdiff_plain/e77e66a923367afd618cb5d7b977095cac119b75..1d413d1e60951a5a65f39971cbfc67501420761d:/image_creator/os_type/__init__.py diff --git a/image_creator/os_type/__init__.py b/image_creator/os_type/__init__.py index 98d570d..5bb8226 100644 --- a/image_creator/os_type/__init__.py +++ b/image_creator/os_type/__init__.py @@ -37,16 +37,16 @@ import textwrap import re -def get_os_class(distro, osfamily): +def os_cls(distro, osfamily): module = None classname = None try: - module = __import__("image_creator.os_type.%s" - % distro, fromlist=['image_creator.os_type']) + module = __import__("image_creator.os_type.%s" % distro, + fromlist=['image_creator.os_type']) classname = distro.capitalize() except ImportError: - module = __import__("image_creator.os_type.%s" - % osfamily, fromlist=['image_creator.os_type']) + module = __import__("image_creator.os_type.%s" % osfamily, + fromlist=['image_creator.os_type']) classname = osfamily.capitalize() return getattr(module, classname) @@ -87,18 +87,20 @@ class OSBase(object): def list_syspreps(self): - objs = [getattr(self, name) for name in dir(self) \ - if not name.startswith('_')] + objs = [getattr(self, name) for name in dir(self) + if not name.startswith('_')] - enabled = [x for x in objs if self._is_sysprep(x) and x.enabled] - disabled = [x for x in objs if self._is_sysprep(x) and not x.enabled] + return [x for x in objs if self._is_sysprep(x)] - return enabled, disabled + def sysprep_info(self, obj): + assert self._is_sysprep(obj), "Object is not a sysprep" - def _sysprep_change_status(self, name, status): + return (obj.__name__.replace('_', '-'), textwrap.dedent(obj.__doc__)) + def get_sysprep_by_name(self, name): + """Returns the sysprep object with the given name""" error_msg = "Syprep operation %s does not exist for %s" % \ - (name, self.__class__.__name__) + (name, self.__class__.__name__) method_name = name.replace('-', '_') method = None @@ -110,20 +112,22 @@ class OSBase(object): if not self._is_sysprep(method): raise FatalError(error_msg) - setattr(method.im_func, 'enabled', status) + return method - def enable_sysprep(self, name): + def enable_sysprep(self, obj): """Enable a system preperation operation""" - self._sysprep_change_status(name, True) + setattr(obj.im_func, 'enabled', True) - def disable_sysprep(self, name): + def disable_sysprep(self, obj): """Disable a system preperation operation""" - self._sysprep_change_status(name, False) + setattr(obj.im_func, 'enabled', False) def print_syspreps(self): """Print enabled and disabled system preperation operations.""" - enabled, disabled = self.list_syspreps() + syspreps = self.list_syspreps() + enabled = filter(lambda x: x.enabled, syspreps) + disabled = filter(lambda x: not x.enabled, syspreps) wrapper = textwrap.TextWrapper() wrapper.subsequent_indent = '\t' @@ -205,10 +209,12 @@ class OSBase(object): self.out.output('Preparing system for image creation:') - tasks, _ = self.list_syspreps() - size = len(tasks) + tasks = self.list_syspreps() + enabled = filter(lambda x: x.enabled, tasks) + + size = len(enabled) cnt = 0 - for task in tasks: + for task in enabled: cnt += 1 self.out.output(('(%d/%d)' % (cnt, size)).ljust(7), False) task()