| #include "bej_tree.h" |
| |
| static void bejTreeInitParent(struct RedfishPropertyParent* node, |
| const char* name, enum BejPrincipalDataType type) |
| { |
| node->nodeAttr.name = name; |
| node->nodeAttr.format.principalDataType = type; |
| node->nodeAttr.format.deferredBinding = 0; |
| node->nodeAttr.format.readOnlyProperty = 0; |
| node->nodeAttr.format.nullableProperty = 0; |
| node->nodeAttr.format.reserved = 0; |
| node->nodeAttr.sibling = NULL; |
| node->nChildren = 0; |
| node->firstChild = NULL; |
| node->lastChild = NULL; |
| } |
| |
| void bejTreeInitSet(struct RedfishPropertyParent* node, const char* name) |
| { |
| bejTreeInitParent(node, name, bejSet); |
| } |
| |
| void bejTreeInitArray(struct RedfishPropertyParent* node, const char* name) |
| { |
| bejTreeInitParent(node, name, bejArray); |
| } |
| |
| void bejTreeInitPropertyAnnotated(struct RedfishPropertyParent* node, |
| const char* name) |
| { |
| bejTreeInitParent(node, name, bejPropertyAnnotation); |
| } |
| |
| bool bejTreeIsParentType(struct RedfishPropertyNode* node) |
| { |
| return node->format.principalDataType == bejSet || |
| node->format.principalDataType == bejArray || |
| node->format.principalDataType == bejPropertyAnnotation; |
| } |
| |
| static void bejTreeInitChildNode(struct RedfishPropertyLeaf* node, |
| const char* name, |
| enum BejPrincipalDataType type) |
| { |
| node->nodeAttr.name = name; |
| node->nodeAttr.format.principalDataType = type; |
| node->nodeAttr.format.deferredBinding = 0; |
| node->nodeAttr.format.readOnlyProperty = 0; |
| node->nodeAttr.format.nullableProperty = 0; |
| node->nodeAttr.format.reserved = 0; |
| node->nodeAttr.sibling = NULL; |
| } |
| |
| void bejTreeAddNull(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyLeafNull* child, const char* name) |
| { |
| bejTreeInitChildNode((struct RedfishPropertyLeaf*)child, name, bejNull); |
| bejTreeLinkChildToParent(parent, child); |
| } |
| |
| void bejTreeAddInteger(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyLeafInt* child, const char* name, |
| int64_t value) |
| { |
| bejTreeInitChildNode((struct RedfishPropertyLeaf*)child, name, bejInteger); |
| child->value = value; |
| bejTreeLinkChildToParent(parent, child); |
| } |
| |
| void bejTreeSetInteger(struct RedfishPropertyLeafInt* node, int64_t newValue) |
| { |
| node->value = newValue; |
| } |
| |
| void bejTreeAddEnum(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyLeafEnum* child, const char* name, |
| const char* value) |
| { |
| bejTreeInitChildNode((struct RedfishPropertyLeaf*)child, name, bejEnum); |
| child->value = value; |
| bejTreeLinkChildToParent(parent, child); |
| } |
| |
| void bejTreeAddString(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyLeafString* child, const char* name, |
| const char* value) |
| { |
| bejTreeInitChildNode((struct RedfishPropertyLeaf*)child, name, bejString); |
| child->value = value; |
| bejTreeLinkChildToParent(parent, child); |
| } |
| |
| void bejTreeAddReal(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyLeafReal* child, const char* name, |
| double value) |
| { |
| bejTreeInitChildNode((struct RedfishPropertyLeaf*)child, name, bejReal); |
| child->value = value; |
| bejTreeLinkChildToParent(parent, child); |
| } |
| |
| void bejTreeSetReal(struct RedfishPropertyLeafReal* node, double newValue) |
| { |
| node->value = newValue; |
| } |
| |
| void bejTreeAddBool(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyLeafBool* child, const char* name, |
| bool value) |
| { |
| bejTreeInitChildNode((struct RedfishPropertyLeaf*)child, name, bejBoolean); |
| child->value = value; |
| bejTreeLinkChildToParent(parent, child); |
| } |
| |
| void bejTreeLinkChildToParent(struct RedfishPropertyParent* parent, void* child) |
| { |
| // A new node is added at the end of the list. |
| if (parent->firstChild == NULL) |
| { |
| parent->firstChild = child; |
| } |
| else |
| { |
| struct RedfishPropertyNode* lastChild = parent->lastChild; |
| lastChild->sibling = child; |
| } |
| parent->lastChild = child; |
| parent->nChildren += 1; |
| } |
| |
| void bejTreeUpdateNodeFlags(struct RedfishPropertyNode* node, |
| bool deferredBinding, bool readOnlyProperty, |
| bool nullableProperty) |
| { |
| node->format.deferredBinding = deferredBinding; |
| node->format.readOnlyProperty = readOnlyProperty; |
| node->format.nullableProperty = nullableProperty; |
| } |
| |
| void* bejParentGoToNextChild(struct RedfishPropertyParent* parent, |
| struct RedfishPropertyNode* currentChild) |
| { |
| if (parent == NULL || currentChild == NULL) |
| { |
| return NULL; |
| } |
| |
| parent->metaData.nextChildIndex += 1; |
| parent->metaData.nextChild = currentChild->sibling; |
| return currentChild->sibling; |
| } |