本文整理汇总了C#中Vertex.AddAttribute方法的典型用法代码示例。如果您正苦于以下问题:C# Vertex.AddAttribute方法的具体用法?C# Vertex.AddAttribute怎么用?C# Vertex.AddAttribute使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Vertex
的用法示例。
在下文中一共展示了Vertex.AddAttribute方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetVertexForType
/// <summary>
/// return the uuid, revision id and the editition for a new created type
/// </summary>
/// <param name="myGraphDBType">the created type</param>
/// <returns></returns>
private Exceptional<Vertex> GetVertexForType(GraphDBType myGraphDBType)
{
if (myGraphDBType == null)
return new Exceptional<Vertex>(new Error_ArgumentNullOrEmpty("The type should not be null."));
var _Vertex = new Vertex();
_Vertex.AddAttribute(DBConstants.DbGraphType, myGraphDBType.Name);
_Vertex.AddAttribute(SpecialTypeAttribute_UUID.AttributeName, myGraphDBType.ObjectUUID);
_Vertex.AddAttribute(SpecialTypeAttribute_REVISION.AttributeName, myGraphDBType.ObjectRevisionID);
_Vertex.AddAttribute(SpecialTypeAttribute_EDITION.AttributeName, myGraphDBType.ObjectEdition);
return new Exceptional<Vertex>(_Vertex);
}
示例2: GenerateOutput
/// <summary>
/// Generate an output for an type with the attributes of the types and all parent types
/// </summary>
/// <param name="myGraphDBType">The db type</param>
/// <param name="myDBContext">The db context</param>
/// <param name="myDepth">If depth == 0 only the type basic attributes will be returned</param>
private Vertex GenerateOutput(DBContext myDBContext, GraphDBType myGraphDBType, Int32 myDepth = 0)
{
var retVal = new Vertex();
if (myGraphDBType.ParentTypeUUID != null)
retVal.AddAttribute("UUID", myGraphDBType.UUID);
retVal.AddAttribute("TYPE", myGraphDBType.GetType().Name);
retVal.AddAttribute("Name", myGraphDBType.Name);
retVal.AddAttribute("Comment", myGraphDBType.Comment);
if (myDepth > 0)
{
retVal.AddAttribute("Properties", new Edge(retVal, GeneratePropertiesOutput(myGraphDBType, myDBContext,
myGraphDBType.Attributes.Where(a => !(a.Value.EdgeType is IReferenceEdge)).Select(kv => kv.Value)))
{
EdgeTypeName = "Property"
});
retVal.AddAttribute("Edges", new Edge(retVal, GenerateEdgesOutput(myGraphDBType, myDBContext, myGraphDBType.Attributes.Where(a => (a.Value.EdgeType is IReferenceEdge) && !a.Value.IsBackwardEdge).Select(kv => kv.Value)))
{
EdgeTypeName = "Edge"
});
retVal.AddAttribute("BackwardEdges", new Edge(retVal, GenerateEdgesOutput(myGraphDBType, myDBContext, myGraphDBType.Attributes.Where(a => (a.Value.EdgeType is IReferenceEdge) && a.Value.IsBackwardEdge).Select(kv => kv.Value)))
{
EdgeTypeName = "Edge"
});
retVal.AddAttribute("UniqueAttributes", new Edge(retVal, GeneratePropertiesOutput(myGraphDBType, myDBContext,
myGraphDBType.GetUniqueAttributes().Select(a => myGraphDBType.GetTypeAttributeByUUID(a))))
{
EdgeTypeName = "Unique"
});
retVal.AddAttribute("MandatoryAttributes", new Edge(retVal, GeneratePropertiesOutput(myGraphDBType, myDBContext,
myGraphDBType.GetMandatoryAttributes().Select(a => myGraphDBType.GetTypeAttributeByUUID(a))))
{
EdgeTypeName = "Mandatory"
});
retVal.AddAttribute("Indices", new Edge(retVal, GenerateIndicesOutput(myGraphDBType, myDBContext))
{
EdgeTypeName = "Index"
});
if (myGraphDBType.ParentTypeUUID != null)
{
var _ParentType = myDBContext.DBTypeManager.GetTypeByUUID(myGraphDBType.ParentTypeUUID);
retVal.AddAttribute("Extends", new Edge(retVal, GenerateOutput(myDBContext, _ParentType, myDepth - 1))
{
EdgeTypeName = "VertexType"
});
}
}
return retVal;
}