183 lines
4.4 KiB
C#
183 lines
4.4 KiB
C#
|
//
|
||
|
// ConstructorCollection.cs
|
||
|
//
|
||
|
// Author:
|
||
|
// Jb Evain (jbevain@gmail.com)
|
||
|
//
|
||
|
// Generated by /CodeGen/cecil-gen.rb do not edit
|
||
|
// Fri Mar 30 18:43:56 +0200 2007
|
||
|
//
|
||
|
// (C) 2005 Jb Evain
|
||
|
//
|
||
|
// Permission is hereby granted, free of charge, to any person obtaining
|
||
|
// a copy of this software and associated documentation files (the
|
||
|
// "Software"), to deal in the Software without restriction, including
|
||
|
// without limitation the rights to use, copy, modify, merge, publish,
|
||
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
||
|
// permit persons to whom the Software is furnished to do so, subject to
|
||
|
// the following conditions:
|
||
|
//
|
||
|
// The above copyright notice and this permission notice shall be
|
||
|
// included in all copies or substantial portions of the Software.
|
||
|
//
|
||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
//
|
||
|
|
||
|
namespace Mono.Cecil {
|
||
|
|
||
|
using System;
|
||
|
using System.Collections;
|
||
|
|
||
|
using Mono.Cecil.Cil;
|
||
|
|
||
|
internal sealed class ConstructorCollection : CollectionBase, IReflectionVisitable {
|
||
|
|
||
|
TypeDefinition m_container;
|
||
|
|
||
|
public MethodDefinition this [int index] {
|
||
|
get { return List [index] as MethodDefinition; }
|
||
|
set { List [index] = value; }
|
||
|
}
|
||
|
|
||
|
public TypeDefinition Container {
|
||
|
get { return m_container; }
|
||
|
}
|
||
|
|
||
|
public ConstructorCollection (TypeDefinition container)
|
||
|
{
|
||
|
m_container = container;
|
||
|
}
|
||
|
|
||
|
public void Add (MethodDefinition value)
|
||
|
{
|
||
|
Attach (value);
|
||
|
|
||
|
List.Add (value);
|
||
|
}
|
||
|
|
||
|
|
||
|
public new void Clear ()
|
||
|
{
|
||
|
foreach (MethodDefinition item in this)
|
||
|
Detach (item);
|
||
|
|
||
|
base.Clear ();
|
||
|
}
|
||
|
|
||
|
public bool Contains (MethodDefinition value)
|
||
|
{
|
||
|
return List.Contains (value);
|
||
|
}
|
||
|
|
||
|
public int IndexOf (MethodDefinition value)
|
||
|
{
|
||
|
return List.IndexOf (value);
|
||
|
}
|
||
|
|
||
|
public void Insert (int index, MethodDefinition value)
|
||
|
{
|
||
|
Attach (value);
|
||
|
|
||
|
List.Insert (index, value);
|
||
|
}
|
||
|
|
||
|
public void Remove (MethodDefinition value)
|
||
|
{
|
||
|
List.Remove (value);
|
||
|
|
||
|
Detach (value);
|
||
|
}
|
||
|
|
||
|
|
||
|
public new void RemoveAt (int index)
|
||
|
{
|
||
|
MethodDefinition item = this [index];
|
||
|
Remove (item);
|
||
|
}
|
||
|
|
||
|
protected override void OnValidate (object o)
|
||
|
{
|
||
|
if (! (o is MethodDefinition))
|
||
|
throw new ArgumentException ("Must be of type " + typeof (MethodDefinition).FullName);
|
||
|
}
|
||
|
|
||
|
internal MethodDefinition GetConstructorInternal (bool isStatic, IList parameters)
|
||
|
{
|
||
|
if (parameters == null)
|
||
|
#if CF_2_0 || CF_1_0
|
||
|
parameters = new Type[0];
|
||
|
#else
|
||
|
parameters = Type.EmptyTypes;
|
||
|
#endif
|
||
|
|
||
|
foreach (MethodDefinition ctor in this) {
|
||
|
if (ctor.IsStatic != isStatic || ctor.Parameters.Count != parameters.Count)
|
||
|
continue;
|
||
|
|
||
|
bool match = true;
|
||
|
for (int i = 0; i < parameters.Count; i++) {
|
||
|
string pname;
|
||
|
object param = parameters [i];
|
||
|
if (param is Type)
|
||
|
pname = ReflectionHelper.GetTypeSignature (param as Type);
|
||
|
else if (param is TypeReference)
|
||
|
pname = (param as TypeReference).FullName;
|
||
|
else if (param is ParameterDefinition)
|
||
|
pname = (param as ParameterDefinition).ParameterType.FullName;
|
||
|
else
|
||
|
throw new NotSupportedException ();
|
||
|
|
||
|
if (ctor.Parameters [i].ParameterType.FullName != pname) {
|
||
|
match = false;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (match)
|
||
|
return ctor;
|
||
|
}
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
public MethodDefinition GetConstructor (bool isStatic, Type [] parameters)
|
||
|
{
|
||
|
return GetConstructorInternal (isStatic, parameters);
|
||
|
}
|
||
|
|
||
|
public MethodDefinition GetConstructor (bool isStatic, TypeReference [] parameters)
|
||
|
{
|
||
|
return GetConstructorInternal (isStatic, parameters);
|
||
|
}
|
||
|
|
||
|
public MethodDefinition GetConstructor (bool isStatic, ParameterDefinitionCollection parameters)
|
||
|
{
|
||
|
return GetConstructorInternal (isStatic, parameters);
|
||
|
}
|
||
|
|
||
|
void Attach (MemberReference member)
|
||
|
{
|
||
|
if (member.DeclaringType != null)
|
||
|
throw new ReflectionException ("Member already attached, clone it instead");
|
||
|
|
||
|
member.DeclaringType = m_container;
|
||
|
}
|
||
|
|
||
|
void Detach (MemberReference member)
|
||
|
{
|
||
|
member.DeclaringType = null;
|
||
|
}
|
||
|
|
||
|
public void Accept (IReflectionVisitor visitor)
|
||
|
{
|
||
|
visitor.VisitConstructorCollection (this);
|
||
|
}
|
||
|
}
|
||
|
}
|