//
// Copyright (c) 2004,2005 Jaroslaw Kowalski <jkowalski@users.sourceforge.net>
//
//
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
//
// * Neither the name of the Jaroslaw Kowalski nor the names of its
// contributors may be used to endorse or promote products derived from this
// software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
// THE POSSIBILITY OF SUCH DAMAGE.
//
using System;
using System.Collections;
using System.Text;
namespace NLog
{
/// <summary>
/// A collection of elements of type LayoutRenderer
/// </summary>
public class LayoutRendererCollection: System.Collections.CollectionBase
{
/// <summary>
/// Initializes a new empty instance of the LayoutRendererCollection class.
/// </summary>
public LayoutRendererCollection()
{
// empty
}
/// <summary>
/// Initializes a new instance of the LayoutRendererCollection class, containing elements
/// copied from an array.
/// </summary>
/// <param name="items">
/// The array whose elements are to be added to the new LayoutRendererCollection.
/// </param>
public LayoutRendererCollection(LayoutRenderer[]items)
{
this.AddRange(items);
}
/// <summary>
/// Initializes a new instance of the LayoutRendererCollection class, containing elements
/// copied from another instance of LayoutRendererCollection
/// </summary>
/// <param name="items">
/// The LayoutRendererCollection whose elements are to be added to the new LayoutRendererCollection.
/// </param>
public LayoutRendererCollection(LayoutRendererCollection items)
{
this.AddRange(items);
}
/// <summary>
/// Adds the elements of an array to the end of this LayoutRendererCollection.
/// </summary>
/// <param name="items">
/// The array whose elements are to be added to the end of this LayoutRendererCollection.
/// </param>
public virtual void AddRange(LayoutRenderer[]items)
{
foreach (LayoutRenderer item in items)
{
this.List.Add(item);
}
}
/// <summary>
/// Adds the elements of another LayoutRendererCollection to the end of this LayoutRendererCollection.
/// </summary>
/// <param name="items">
/// The LayoutRendererCollection whose elements are to be added to the end of this LayoutRendererCollection.
/// </param>
public virtual void AddRange(LayoutRendererCollection items)
{
foreach (LayoutRenderer item in items)
{
this.List.Add(item);
}
}
/// <summary>
/// Adds an instance of type LayoutRenderer to the end of this LayoutRendererCollection.
/// </summary>
/// <param name="value">
/// The LayoutRenderer to be added to the end of this LayoutRendererCollection.
/// </param>
public virtual void Add(LayoutRenderer value)
{
this.List.Add(value);
}
/// <summary>
/// Determines whether a specfic LayoutRenderer value is in this LayoutRendererCollection.
/// </summary>
/// <param name="value">
/// The LayoutRenderer value to locate in this LayoutRendererCollection.
/// </param>
/// <returns>
/// true if value is found in this LayoutRendererCollection;
/// false otherwise.
/// </returns>
public virtual bool Contains(LayoutRenderer value)
{
return this.List.Contains(value);
}
/// <summary>
/// Return the zero-based index of the first occurrence of a specific value
/// in this LayoutRendererCollection
/// </summary>
/// <param name="value">
/// The LayoutRenderer value to locate in the LayoutRendererCollection.
/// </param>
/// <returns>
/// The zero-based index of the first occurrence of the _ELEMENT value if found;
/// -1 otherwise.
/// </returns>
public virtual int IndexOf(LayoutRenderer value)
{
return this.List.IndexOf(value);
}
/// <summary>
/// Inserts an element into the LayoutRendererCollection at the specified index
/// </summary>
/// <param name="index">
/// The index at which the LayoutRenderer is to be inserted.
/// </param>
/// <param name="value">
/// The LayoutRenderer to insert.
/// </param>
public virtual void Insert(int index, LayoutRenderer value)
{
this.List.Insert(index, value);
}
/// <summary>
/// Gets or sets the LayoutRenderer at the given index in this LayoutRendererCollection.
/// </summary>
public virtual LayoutRenderer this[int index]
{
get
{
return (LayoutRenderer)this.List[index];
}
set
{
this.List[index] = value;
}
}
/// <summary>
/// Removes the first occurrence of a specific LayoutRenderer from this LayoutRendererCollection.
/// </summary>
/// <param name="value">
/// The LayoutRenderer value to remove from this LayoutRendererCollection.
/// </param>
public virtual void Remove(LayoutRenderer value)
{
this.List.Remove(value);
}
/// <summary>
/// Type-specific enumeration class, used by LayoutRendererCollection.GetEnumerator.
/// </summary>
public class Enumerator: System.Collections.IEnumerator
{
private System.Collections.IEnumerator wrapped;
/// <summary>
///
/// </summary>
/// <param name="collection"></param>
public Enumerator(LayoutRendererCollection collection)
{
this.wrapped = ((System.Collections.CollectionBase)collection).GetEnumerator();
}
/// <summary>
///
/// </summary>
public LayoutRenderer Current
{
get
{
return (LayoutRenderer)(this.wrapped.Current);
}
}
/// <summary>
///
/// </summary>
object System.Collections.IEnumerator.Current
{
get
{
return (LayoutRenderer)(this.wrapped.Current);
}
}
/// <summary>
///
/// </summary>
/// <returns></returns>
public bool MoveNext()
{
return this.wrapped.MoveNext();
}
/// <summary>
///
/// </summary>
public void Reset()
{
this.wrapped.Reset();
}
}
/// <summary>
/// Returns an enumerator that can iterate through the elements of this LayoutRendererCollection.
/// </summary>
/// <returns>
/// An object that implements System.Collections.IEnumerator.
/// </returns>
public new virtual LayoutRendererCollection.Enumerator GetEnumerator()
{
return new LayoutRendererCollection.Enumerator(this);
}
}
}