Click here to Skip to main content
Click here to Skip to main content
Add your own
alternative version

NPerf, A Performance Benchmark Framework for .NET

, 25 Jan 2004
NPerf is a framework for benchmarking classes and methods, that tastes like NUnit.
nperf_bin.zip
Release
NPerf.Cons.exe
NPerf.Core.dll
NPerf.Framework.chm
NPerf.Framework.dll
NPerf.Report.dll
scpl.dll
System.Perf.dll
nperf_demo.zip
Releases
Unpackaged
nperf-1.1-Release
nperf
bin
Release
nperf-doc-1.1.chm
NPerf.Cons.exe
NPerf.Core.dll
NPerf.Framework.dll
NPerf.Report.dll
scpl.dll
System.Perf.dll
nperf_src.zip
src
build
NAnt
i18n.xsl
ICSharpCode.SharpCvsLib.dll
ICSharpCode.SharpZipLib.dll
log4net.dll
NAnt.Contrib.Tasks.dll
NAnt.Core.dll
NAnt.DotNetTasks.dll
NAnt.exe
NAnt.NUnit.dll
NAnt.NUnit1Tasks.dll
NAnt.NUnit2ReportTasks.dll
NAnt.NUnit2Tasks.dll
NAnt.SourceControlTasks.dll
NAnt.VisualCppTasks.dll
NAnt.VSNetTasks.dll
NAnt.Win32Tasks.dll
NAnt.ZipTasks.dll
NDoc.Core.dll
NDoc.Documenter.Msdn.dll
NDoc.Documenter.NAnt.dll
NUnit-Frame.xsl
NUnit-NoFrame.xsl
nunit.framework.dll
NUnitCore.dll
toolkit.xsl
NPerf.Cons
Collections
App.ico
NPerf.Cons.cmbx
NPerf.Cons.prjx
NPerf.Core
Collections
Monitoring
Tracers
NPerf.Core.cmbx
NPerf.Core.prjx
NPerf.Framework
NPerf.Framework.cmbx
NPerf.Framework.prjx
NPerf.Report
scpl
scpl.dll
System.Perf
NPerf.Framework.chm
nperf.ndoc
nperf.png
using System;
using System.Reflection;

namespace NPerf.Core.Collections
{
	/// <summary>
	/// A collection of elements of type MethodInfo
	/// </summary>
	public class MethodInfoCollection: System.Collections.CollectionBase
	{
		/// <summary>
		/// Initializes a new empty instance of the MethodInfoCollection class.
		/// </summary>
		public MethodInfoCollection()
		{
			// empty
		}

		/// <summary>
		/// Initializes a new instance of the MethodInfoCollection class, containing elements
		/// copied from an array.
		/// </summary>
		/// <param name="items">
		/// The array whose elements are to be added to the new MethodInfoCollection.
		/// </param>
		public MethodInfoCollection(MethodInfo[] items)
		{
			this.AddRange(items);
		}

		/// <summary>
		/// Initializes a new instance of the MethodInfoCollection class, containing elements
		/// copied from another instance of MethodInfoCollection
		/// </summary>
		/// <param name="items">
		/// The MethodInfoCollection whose elements are to be added to the new MethodInfoCollection.
		/// </param>
		public MethodInfoCollection(MethodInfoCollection items)
		{
			this.AddRange(items);
		}

		/// <summary>
		/// Adds the elements of an array to the end of this MethodInfoCollection.
		/// </summary>
		/// <param name="items">
		/// The array whose elements are to be added to the end of this MethodInfoCollection.
		/// </param>
		public virtual void AddRange(MethodInfo[] items)
		{
			foreach (MethodInfo item in items)
			{
				this.List.Add(item);
			}
		}

		/// <summary>
		/// Adds the elements of another MethodInfoCollection to the end of this MethodInfoCollection.
		/// </summary>
		/// <param name="items">
		/// The MethodInfoCollection whose elements are to be added to the end of this MethodInfoCollection.
		/// </param>
		public virtual void AddRange(MethodInfoCollection items)
		{
			foreach (MethodInfo item in items)
			{
				this.List.Add(item);
			}
		}

		/// <summary>
		/// Adds an instance of type MethodInfo to the end of this MethodInfoCollection.
		/// </summary>
		/// <param name="value">
		/// The MethodInfo to be added to the end of this MethodInfoCollection.
		/// </param>
		public virtual void Add(MethodInfo value)
		{
			this.List.Add(value);
		}

		/// <summary>
		/// Determines whether a specfic MethodInfo value is in this MethodInfoCollection.
		/// </summary>
		/// <param name="value">
		/// The MethodInfo value to locate in this MethodInfoCollection.
		/// </param>
		/// <returns>
		/// true if value is found in this MethodInfoCollection;
		/// false otherwise.
		/// </returns>
		public virtual bool Contains(MethodInfo value)
		{
			return this.List.Contains(value);
		}

		/// <summary>
		/// Return the zero-based index of the first occurrence of a specific value
		/// in this MethodInfoCollection
		/// </summary>
		/// <param name="value">
		/// The MethodInfo value to locate in the MethodInfoCollection.
		/// </param>
		/// <returns>
		/// The zero-based index of the first occurrence of the _ELEMENT value if found;
		/// -1 otherwise.
		/// </returns>
		public virtual int IndexOf(MethodInfo value)
		{
			return this.List.IndexOf(value);
		}

		/// <summary>
		/// Inserts an element into the MethodInfoCollection at the specified index
		/// </summary>
		/// <param name="index">
		/// The index at which the MethodInfo is to be inserted.
		/// </param>
		/// <param name="value">
		/// The MethodInfo to insert.
		/// </param>
		public virtual void Insert(int index, MethodInfo value)
		{
			this.List.Insert(index, value);
		}

		/// <summary>
		/// Gets or sets the MethodInfo at the given index in this MethodInfoCollection.
		/// </summary>
		public virtual MethodInfo this[int index]
		{
			get
			{
				return (MethodInfo) this.List[index];
			}
			set
			{
				this.List[index] = value;
			}
		}

		/// <summary>
		/// Removes the first occurrence of a specific MethodInfo from this MethodInfoCollection.
		/// </summary>
		/// <param name="value">
		/// The MethodInfo value to remove from this MethodInfoCollection.
		/// </param>
		public virtual void Remove(MethodInfo value)
		{
			this.List.Remove(value);
		}

		/// <summary>
		/// Type-specific enumeration class, used by MethodInfoCollection.GetEnumerator.
		/// </summary>
		public class Enumerator: System.Collections.IEnumerator
		{
			private System.Collections.IEnumerator wrapped;

			public Enumerator(MethodInfoCollection collection)
			{
				this.wrapped = ((System.Collections.CollectionBase)collection).GetEnumerator();
			}

			public MethodInfo Current
			{
				get
				{
					return (MethodInfo) (this.wrapped.Current);
				}
			}

			object System.Collections.IEnumerator.Current
			{
				get
				{
					return (MethodInfo) (this.wrapped.Current);
				}
			}

			public bool MoveNext()
			{
				return this.wrapped.MoveNext();
			}

			public void Reset()
			{
				this.wrapped.Reset();
			}
		}

		/// <summary>
		/// Returns an enumerator that can iterate through the elements of this MethodInfoCollection.
		/// </summary>
		/// <returns>
		/// An object that implements System.Collections.IEnumerator.
		/// </returns>        
		public new virtual MethodInfoCollection.Enumerator GetEnumerator()
		{
			return new MethodInfoCollection.Enumerator(this);
		}
	}

}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

Share

About the Author

Jonathan de Halleux
Engineer
United States United States
Jonathan de Halleux is Civil Engineer in Applied Mathematics. He finished his PhD in 2004 in the rainy country of Belgium. After 2 years in the Common Language Runtime (i.e. .net), he is now working at Microsoft Research on Pex (http://research.microsoft.com/pex).

| Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.1411019.1 | Last Updated 26 Jan 2004
Article Copyright 2004 by Jonathan de Halleux
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid