forked from msgpack/msgpack-cli
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMessagePackObjectDictionary.ValueCollection.Enumerator.cs
More file actions
110 lines (101 loc) · 3.51 KB
/
MessagePackObjectDictionary.ValueCollection.Enumerator.cs
File metadata and controls
110 lines (101 loc) · 3.51 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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#region -- License Terms --
//
// MessagePack for CLI
//
// Copyright (C) 2010-2012 FUJIWARA, Yusuke
//
// Licensed under the Apache License, Version 2.0 (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.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#endregion -- License Terms --
using System;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics.Contracts;
namespace MsgPack
{
partial class MessagePackObjectDictionary
{
partial class ValueCollection
{
/// <summary>
/// Enumerates the elements of a <see cref="MessagePackObjectDictionary.ValueCollection"/>.
/// </summary>
public struct Enumerator : IEnumerator<MessagePackObject>
{
// This field must not be readonly because it will cause infinite loop to the user of this type
// due to C# compiler emit ldfld instead of ldflda and state of this field will never change.
private MessagePackObjectDictionary.Enumerator _underlying;
/// <summary>
/// Gets the element at the current position of the enumerator.
/// </summary>
/// <value>
/// The element in the underlying collection at the current position of the enumerator.
/// </value>
public MessagePackObject Current
{
get { return this._underlying.Current.Value; }
}
/// <summary>
/// Gets the element at the current position of the enumerator.
/// </summary>
/// <value>
/// The element in the collection at the current position of the enumerator, as an <see cref="Object"/>.
/// </value>
/// <exception cref="InvalidOperationException">
/// The enumerator is positioned before the first element of the collection or after the last element.
/// </exception>
object IEnumerator.Current
{
get { return this._underlying.GetCurrentStrict().Value; }
}
internal Enumerator( MessagePackObjectDictionary dictionary )
{
Contract.Assert( dictionary != null );
this._underlying = dictionary.GetEnumerator();
}
/// <summary>
/// Releases all resources used by the this instance.
/// </summary>
public void Dispose()
{
this._underlying.Dispose();
}
/// <summary>
/// Advances the enumerator to the next element of the underlying collection.
/// </summary>
/// <returns>
/// <c>true</c> if the enumerator was successfully advanced to the next element;
/// <c>false</c> if the enumerator has passed the end of the collection.
/// </returns>
/// <exception cref="T:System.InvalidOperationException">
/// The collection was modified after the enumerator was created.
/// </exception>
public bool MoveNext()
{
this._underlying.VerifyVersion();
return this._underlying.MoveNext();
}
/// <summary>
/// Sets the enumerator to its initial position, which is before the first element in the collection.
/// </summary>
/// <exception cref="T:System.InvalidOperationException">
/// The collection was modified after the enumerator was created.
/// </exception>
void IEnumerator.Reset()
{
this._underlying.ResetCore();
}
}
}
}
}