blob: 2d49adaef3c442db734b1c45931410c69dd42787 [file] [log] [blame]
#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;
}