Meshroom/meshroom/common/core.py
Yann Lanthony 6ac4a9d712 [desc][qt] use QVariantList for list-type properties
* required for PySide2 > 5.11.1 (and compatible with 5.11.1)
* AttributeItemDelegate: test for list length to determine whether to create a slider component (if range is set to None on Python side, it will be an empty list on the QML/JS side)
2019-01-04 17:30:38 +01:00

148 lines
3.3 KiB
Python

class CoreDictModel:
def __init__(self, keyAttrName, **kwargs):
self._objects = {}
self._keyAttrName = keyAttrName
def __len__(self):
return len(self._objects)
def __iter__(self):
""" Enables iteration over the list of objects. """
return iter(self._objects.values())
def keys(self):
return self._objects.keys()
def items(self):
return self._objects.items()
def values(self):
return self._objects.values()
@property
def objects(self):
return self._objects
# TODO: operator[]
def get(self, key):
"""
Raises a KeyError if key is not in the map.
:param key:
:return:
"""
return self._objects[key]
def add(self, obj):
key = getattr(obj, self._keyAttrName, None)
assert key is not None
assert key not in self._objects
self._objects[key] = obj
def pop(self, key):
assert key in self._objects
return self._objects.pop(key)
def remove(self, obj):
assert obj in self._objects.values()
del self._objects[getattr(obj, self._keyAttrName)]
def clear(self):
self._objects.clear()
def update(self, objects):
for obj in objects:
self.add(obj)
def reset(self, objects):
self.clear()
self.update(objects)
class CoreListModel:
def __init__(self, parent=None):
self._objects = []
def __iter__(self):
return self._objects.__iter__()
def __len__(self):
return len(self._objects)
def __getitem__(self, idx):
return self._objects[idx]
def setObjectList(self, iterable):
self.clear()
self._objects = iterable
def at(self, idx):
return self._objects[idx]
def append(self, obj):
self._objects.append(obj)
def extend(self, iterable):
self._objects.extend(iterable)
def indexOf(self, obj):
return self._objects.index(obj)
def removeAt(self, idx, count=1):
del self._objects[idx:idx+count]
def remove(self, obj):
self._objects.remove(obj)
def clear(self):
self._objects = []
def insert(self, index, iterable):
self._objects[index:index] = iterable
class CoreSignal:
""" Simple signal/callback implementation """
def __init__(self):
self._callbacks = set()
def emit(self, *args):
# TODO: check if we really need this in non-UI mode
# [cb(*args) for cb in self._callbacks]
pass
def connect(self, func):
self._callbacks.add(func)
def CoreSlot(*args, **kwargs):
def slot_decorator(func):
def func_wrapper(*f_args, **f_kwargs):
return func(*f_args, **f_kwargs)
return func_wrapper
return slot_decorator
class CoreProperty(property):
def __init__(self, ptype, fget=None, fset=None, **kwargs):
super(CoreProperty, self).__init__(fget, fset)
class CoreObject(object):
def __init__(self, parent=None, *args, **kwargs):
super(CoreObject, self).__init__()
self._parent = parent
def parent(self):
return self._parent
DictModel = CoreDictModel
ListModel = CoreListModel
Slot = CoreSlot
Signal = CoreSignal
Property = CoreProperty
BaseObject = CoreObject
Variant = object
VariantList = object