qubes/vm/qubesvm: do not clone VM-specific properties

This is reworked
    core: do not clone VM-unique identifiers in clone_properties
by Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
This commit is contained in:
Wojtek Porczyk 2016-02-24 01:08:32 +01:00
parent 2cbbe0bdb6
commit 88a63cbe3a
2 changed files with 11 additions and 3 deletions

View File

@ -550,6 +550,8 @@ class property(object): # pylint: disable=redefined-builtin,invalid-name
:param int load_stage: stage when property should be loaded (see \ :param int load_stage: stage when property should be loaded (see \
:py:class:`Qubes` for description of stages) :py:class:`Qubes` for description of stages)
:param int order: order of evaluation (bigger order values are later) :param int order: order of evaluation (bigger order values are later)
:param bool clone: :py:meth:`PropertyHolder.clone_properties` will not \
include this property by default if :py:obj:`False`
:param str ls_head: column head for :program:`qvm-ls` :param str ls_head: column head for :program:`qvm-ls`
:param int ls_width: column width in :program:`qvm-ls` :param int ls_width: column width in :program:`qvm-ls`
:param str doc: docstring; this should be one paragraph of plain RST, no \ :param str doc: docstring; this should be one paragraph of plain RST, no \
@ -584,7 +586,7 @@ class property(object): # pylint: disable=redefined-builtin,invalid-name
def __init__(self, name, setter=None, saver=None, type=None, def __init__(self, name, setter=None, saver=None, type=None,
default=_NO_DEFAULT, write_once=False, load_stage=2, order=0, default=_NO_DEFAULT, write_once=False, load_stage=2, order=0,
save_via_ref=False, save_via_ref=False, clone=True,
ls_head=None, ls_width=None, doc=None): ls_head=None, ls_width=None, doc=None):
# pylint: disable=redefined-builtin # pylint: disable=redefined-builtin
self.__name__ = name self.__name__ = name
@ -597,6 +599,7 @@ class property(object): # pylint: disable=redefined-builtin,invalid-name
self.order = order self.order = order
self.load_stage = load_stage self.load_stage = load_stage
self.save_via_ref = save_via_ref self.save_via_ref = save_via_ref
self.clone = clone
self.__doc__ = doc self.__doc__ = doc
self._attr_name = '_qubesprop_' + name self._attr_name = '_qubesprop_' + name
@ -969,11 +972,13 @@ class PropertyHolder(qubes.events.Emitter):
:param PropertyHolder src: source object :param PropertyHolder src: source object
:param list proplist: list of properties \ :param list proplist: list of properties \
(:py:obj:`None` for all properties) (:py:obj:`None` or omit for all properties except those with \
:py:attr:`property.clone` set to :py:obj:`False`)
''' '''
if proplist is None: if proplist is None:
proplist = self.property_list() proplist = [prop for prop in self.property_list()
if prop.clone]
else: else:
proplist = [prop for prop in self.property_list() proplist = [prop for prop in self.property_list()
if prop.__name__ in proplist or prop in proplist] if prop.__name__ in proplist or prop in proplist]

View File

@ -151,15 +151,18 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
qid = qubes.property('qid', type=int, write_once=True, qid = qubes.property('qid', type=int, write_once=True,
setter=_setter_qid, setter=_setter_qid,
clone=False,
ls_width=3, ls_width=3,
doc='''Internal, persistent identificator of particular domain. Note doc='''Internal, persistent identificator of particular domain. Note
this is different from Xen domid.''') this is different from Xen domid.''')
name = qubes.property('name', type=str, name = qubes.property('name', type=str,
clone=False,
ls_width=31, ls_width=31,
doc='User-specified name of the domain.') doc='User-specified name of the domain.')
uuid = qubes.property('uuid', type=uuid.UUID, write_once=True, uuid = qubes.property('uuid', type=uuid.UUID, write_once=True,
clone=False,
ls_width=36, ls_width=36,
doc='UUID from libvirt.') doc='UUID from libvirt.')