generated from gemstone/gemtem
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ConfigurationCellCollection.cs
103 lines (90 loc) · 4.43 KB
/
ConfigurationCellCollection.cs
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
//******************************************************************************************************
// ConfigurationCellCollection.cs - Gbtc
//
// Copyright © 2012, Grid Protection Alliance. All Rights Reserved.
//
// Licensed to the Grid Protection Alliance (GPA) under one or more contributor license agreements. See
// the NOTICE file distributed with this work for additional information regarding copyright ownership.
// The GPA licenses this file to you under the MIT License (MIT), the "License"; you may
// not use this file except in compliance with the License. You may obtain a copy of the License at:
//
// http://www.opensource.org/licenses/MIT
//
// Unless agreed to in writing, the subject software distributed under the License is distributed on an
// "AS-IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. Refer to the
// License for the specific language governing permissions and limitations.
//
// Code Modification History:
// ----------------------------------------------------------------------------------------------------
// 11/12/2004 - J. Ritchie Carroll
// Generated original version of source code.
// 09/15/2009 - Stephen C. Wills
// Added new header and license agreement.
// 12/17/2012 - Starlynn Danyelle Gilliam
// Modified Header.
//
//******************************************************************************************************
using System;
using System.Runtime.Serialization;
namespace Gemstone.PhasorProtocols.BPAPDCstream
{
/// <summary>
/// Represents a BPA PDCstream implementation of a collection of <see cref="IConfigurationCell"/> objects.
/// </summary>
[Serializable]
public class ConfigurationCellCollection : PhasorProtocols.ConfigurationCellCollection
{
#region [ Constructors ]
/// <summary>
/// Creates a new <see cref="ConfigurationCellCollection"/>.
/// </summary>
public ConfigurationCellCollection()
: base(ushort.MaxValue, true)
{
// Although the number of configuration cells are not restricted in the
// INI file, the data stream limits the maximum number of associated
// data cells to 16-bits, so we limit the configurations cells to the same.
// Also, PDCstream configuration cells are constant length.
}
/// <summary>
/// Creates a new <see cref="ConfigurationCellCollection"/> from serialization parameters.
/// </summary>
/// <param name="info">The <see cref="SerializationInfo"/> with populated with data.</param>
/// <param name="context">The source <see cref="StreamingContext"/> for this deserialization.</param>
protected ConfigurationCellCollection(SerializationInfo info, StreamingContext context)
: base(info, context)
{
}
#endregion
#region [ Properties ]
/// <summary>
/// Gets or sets <see cref="ConfigurationCell"/> at specified <paramref name="index"/>.
/// </summary>
/// <param name="index">Index of value to get or set.</param>
public new ConfigurationCell this[int index]
{
get => base[index] as ConfigurationCell;
set => base[index] = value;
}
#endregion
#region [ Methods ]
/// <summary>
/// Attempts to retrieve a <see cref="ConfigurationCell"/> from this <see cref="ConfigurationCellCollection"/> with the specified <paramref name="sectionEntry"/>.
/// </summary>
/// <param name="sectionEntry"><see cref="ConfigurationCell.SectionEntry"/> value to try to find.</param>
/// <param name="configurationCell"><see cref="ConfigurationCell"/> with the specified <paramref name="sectionEntry"/> if found; otherwise <c>null</c>.</param>
/// <returns><c>true</c> if <see cref="ConfigurationCell"/> with the specified <paramref name="sectionEntry"/> is found; otherwise <c>false</c>.</returns>
public bool TryGetBySectionEntry(string sectionEntry, out ConfigurationCell configurationCell)
{
for (int i = 0; i < Count; i++)
{
configurationCell = this[i];
if (string.Equals(configurationCell.SectionEntry, sectionEntry, StringComparison.OrdinalIgnoreCase))
return true;
}
configurationCell = null;
return false;
}
#endregion
}
}