Collections Data Structure C#

#region License
/*
 * Copyright 2002-2005 the original author or authors.
 * 
 * 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
#region Imports
using System;
using System.Collections;
using System.Reflection;
#endregion
namespace Spring.Util
{
    /// 
    /// Miscellaneous collection utility methods.
    /// 

    /// 
    /// Mainly for internal use within the framework.
    /// 

    /// Mark Pollack (.NET)
    public sealed class CollectionUtils
    {
        /// 
        /// Finds a value of the given type in the given collection.
        /// 

        /// The collection to search.
        /// The type to look for.
        /// a value of the given type found, or null if none.
        /// If more than one value of the given type is found
        public static object FindValueOfType(ICollection collection, Type type)
        {
            Type typeToUse = (type != null ? type : typeof(object));
            object val = null;
            foreach (object obj in collection)
            {
                if (typeToUse.IsAssignableFrom(obj.GetType()))
                {
                    if (val != null)
                    {
                        throw new ArgumentException("More than one value of type[" + typeToUse.Name + "] found.");
                    }
                    val = obj;
                }
            }
            return val;
        }
    }
}