Different in getitem depending on whether assignment, or lookup; fixed from_struct on BaseRef
This commit is contained in:
parent
7224bda047
commit
6528044b1c
@ -80,7 +80,7 @@ class RefBase(object):
|
|||||||
|
|
||||||
:returns: Returns a serialized object
|
:returns: Returns a serialized object
|
||||||
"""
|
"""
|
||||||
return struct
|
return str(struct)
|
||||||
|
|
||||||
def unserialize(self, data):
|
def unserialize(self, data):
|
||||||
"""
|
"""
|
||||||
|
@ -343,7 +343,7 @@ def from_struct(struct):
|
|||||||
return Note.create(Note.from_struct(struct))
|
return Note.create(Note.from_struct(struct))
|
||||||
elif struct["_class"] == "Tag":
|
elif struct["_class"] == "Tag":
|
||||||
return Tag.create(Tag.from_struct(struct))
|
return Tag.create(Tag.from_struct(struct))
|
||||||
raise AttributeError("invalid struct")
|
raise AttributeError("invalid struct: %s" % struct)
|
||||||
|
|
||||||
def get_dependencies(struct):
|
def get_dependencies(struct):
|
||||||
"""
|
"""
|
||||||
@ -475,16 +475,18 @@ class Struct(object):
|
|||||||
"""
|
"""
|
||||||
If the item is a handle, look up reference object.
|
If the item is a handle, look up reference object.
|
||||||
"""
|
"""
|
||||||
if hasattr(item, "classname") and self.db:
|
if hasattr(item, "classname") and self.db: # HandleClass
|
||||||
obj = self.db.get_from_name_and_handle(item.classname, str(item))
|
obj = self.db.get_from_name_and_handle(item.classname, str(item))
|
||||||
if obj:
|
if obj:
|
||||||
return Struct(obj.to_struct(), self.db)
|
return Struct(obj.to_struct(), self.db)
|
||||||
else:
|
else:
|
||||||
return None
|
return None
|
||||||
|
elif isinstance(item, dict):
|
||||||
|
return Struct(item, self.db)
|
||||||
else:
|
else:
|
||||||
return item
|
return item
|
||||||
|
|
||||||
def getitem(self, item, struct=None):
|
def getitem(self, item, struct=None, ref_struct=True):
|
||||||
"""
|
"""
|
||||||
>>> Struct(struct).getitem("primary_name")
|
>>> Struct(struct).getitem("primary_name")
|
||||||
{...}
|
{...}
|
||||||
@ -500,7 +502,10 @@ class Struct(object):
|
|||||||
return None
|
return None
|
||||||
elif isinstance(struct, dict):
|
elif isinstance(struct, dict):
|
||||||
if item in struct.keys():
|
if item in struct.keys():
|
||||||
|
if ref_struct:
|
||||||
return self.get_ref_struct(struct[item])
|
return self.get_ref_struct(struct[item])
|
||||||
|
else:
|
||||||
|
return struct[item]
|
||||||
else:
|
else:
|
||||||
return None
|
return None
|
||||||
elif hasattr(struct, item):
|
elif hasattr(struct, item):
|
||||||
@ -524,7 +529,7 @@ class Struct(object):
|
|||||||
struct = self.struct
|
struct = self.struct
|
||||||
for p in range(len(path)):
|
for p in range(len(path)):
|
||||||
part = path[p]
|
part = path[p]
|
||||||
struct = self.getitem(part, struct)
|
struct = self.getitem(part, struct, ref_struct=False) # just get dicts, no Struct
|
||||||
if isinstance(struct, Struct):
|
if isinstance(struct, Struct):
|
||||||
return struct.setitem_from_path(path[p+1:] + [item], value, trans)
|
return struct.setitem_from_path(path[p+1:] + [item], value, trans)
|
||||||
if struct is None:
|
if struct is None:
|
||||||
|
Loading…
Reference in New Issue
Block a user