-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathCsStructure.cs
More file actions
87 lines (80 loc) · 5.69 KB
/
CsStructure.cs
File metadata and controls
87 lines (80 loc) · 5.69 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
//*****************************************************************************
//* Code Factory SDK
//* Copyright (c) 2023 CodeFactory, LLC
//*****************************************************************************
using System.Collections.Generic;
using System.Collections.Immutable;
using System.Linq;
using CodeFactory.SourceCode;
namespace CodeFactory.DotNet.CSharp
{
/// <summary>
/// Data model that represents the definition of a structure.
/// </summary>
public abstract class CsStructure:CsContainerWithNestedContainers,ICsStructure
{
/// <summary>
/// Constructor for the <see cref="CsStructure"/>
/// </summary>
/// <param name="isLoaded">Flag that determines if the model was loaded.</param>
/// <param name="hasErrors">Flag that determine if errors were found creating the model.</param>
/// <param name="loadedFromSource">Flag that determines if the model was loaded from source code or from an existing library.</param>
/// <param name="language">The target language the model was generated from.</param>
/// <param name="members">The members assigned to this container.</param>
/// <param name="isNested">Flag that determines if the container type is nested in another type definition.</param>
/// <param name="nestedType">Enumeration of the type of nesting the container is.</param>
/// <param name="nestedModels">List of nested models assigned to this container. This is an optional parameter and can be null</param>
/// <param name="sourceDocument">The source document that was used to build this model. This is optional parameter and can be null.</param>
/// <param name="modelStore">Optional the lookup storage for models created during the compile or lookup of the model.</param>
/// <param name="modelErrors">Optional the error that occurred while creating the model.</param>
/// <param name="attributes">List of the attributes assigned to this model.</param>
/// <param name="isGeneric">Flag that determines if the container is a generic definition.</param>
/// <param name="hasStrongTypesInGenerics">Flag that determines if the generics use strong type definitions.</param>
/// <param name="genericParameters">Generic parameters assigned to the container.</param>
/// <param name="genericTypes">Target types for the generic parameters assigned to the container.</param>
/// <param name="modelSourceFile">The source file the model was generated from.</param>
/// <param name="sourceFiles">List of the fully qualified paths to the source code files this model is defined in.</param>
/// <param name="hasDocumentation">Flag that determines if the model has XML documentation assigned to it.</param>
/// <param name="documentation">The xml documentation assigned to the model.</param>
/// <param name="lookupPath">The fully qualified model lookup path for this model.</param>
/// <param name="name">The name of the model.</param>
/// <param name="ns">The namespace the container belongs to.</param>
/// <param name="parentPath">The fully qualified lookup path for the parent model to this one.</param>
/// <param name="security">The security scope assigned to this model.</param>
/// <param name="inheritedInterfaces">The interfaces that are inherited by this container.</param>
protected CsStructure(bool isLoaded, bool hasErrors, bool loadedFromSource, SourceCodeType language,
IReadOnlyList<CsAttribute> attributes, bool isGeneric, bool hasStrongTypesInGenerics,
IReadOnlyList<CsGenericParameter> genericParameters, IReadOnlyList<CsType> genericTypes, string modelSourceFile, IReadOnlyList<string> sourceFiles,
bool hasDocumentation, string documentation, string lookupPath, string name, string ns, string parentPath,
CsSecurity security, IReadOnlyList<CsInterface> inheritedInterfaces, IReadOnlyList<CsMember> members,bool isNested,CsNestedType nestedType,IReadOnlyList<ICsNestedModel> nestedModels = null,
string sourceDocument = null, ModelStore<ICsModel> modelStore = null, IReadOnlyList<ModelLoadException> modelErrors = null)
: base(isLoaded, hasErrors, loadedFromSource, language, CsModelType.Structure,
attributes, isGeneric, hasStrongTypesInGenerics, genericParameters, genericTypes, modelSourceFile, sourceFiles, hasDocumentation,
documentation, lookupPath, name, ns, parentPath, CsContainerType.Structure, security, inheritedInterfaces, members,isNested,nestedType,
nestedModels, sourceDocument, modelStore, modelErrors)
{
//Intentionally blank
}
/// <summary>
/// List of the constructors for this structure.
/// </summary>
IReadOnlyList<IDotNetMethod> IDotNetStructure.Constructors => Constructors;
/// <summary>
/// List of the fields for this structure.
/// </summary>
public IReadOnlyList<CsField> Fields =>
Members.Where(m => m.MemberType == CsMemberType.Field).Cast<CsField>().ToImmutableList() ??
ImmutableList<CsField>.Empty;
/// <summary>
/// List of the constructors for this structure.
/// </summary>
public IReadOnlyList<CsMethod> Constructors =>
Members.Where(m => m.MemberType == CsMemberType.Method).Cast<CsMethod>()
.Where(m => m.MethodType == CsMethodType.Constructor).ToImmutableList() ??
ImmutableList<CsMethod>.Empty;
/// <summary>
/// List of the fields for this structure.
/// </summary>
IReadOnlyList<IDotNetField> IDotNetStructure.Fields => Fields;
}
}