Merge branch 'cecil-light'
[mono.git] / mcs / tools / cil-strip / Mono.Cecil / MethodDefinitionCollection.cs
1 //
2 // MethodDefinitionCollection.cs
3 //
4 // Author:
5 //   Jb Evain (jbevain@gmail.com)
6 //
7 // Generated by /CodeGen/cecil-gen.rb do not edit
8 // Fri Mar 30 18:43:56 +0200 2007
9 //
10 // (C) 2005 Jb Evain
11 //
12 // Permission is hereby granted, free of charge, to any person obtaining
13 // a copy of this software and associated documentation files (the
14 // "Software"), to deal in the Software without restriction, including
15 // without limitation the rights to use, copy, modify, merge, publish,
16 // distribute, sublicense, and/or sell copies of the Software, and to
17 // permit persons to whom the Software is furnished to do so, subject to
18 // the following conditions:
19 //
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
22 //
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
27 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
28 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
29 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 //
31
32 namespace Mono.Cecil {
33
34         using System;
35         using System.Collections;
36
37         using Mono.Cecil.Cil;
38
39         internal sealed class MethodDefinitionCollection : CollectionBase, IReflectionVisitable {
40
41                 TypeDefinition m_container;
42
43                 public MethodDefinition this [int index] {
44                         get { return List [index] as MethodDefinition; }
45                         set { List [index] = value; }
46                 }
47
48                 public TypeDefinition Container {
49                         get { return m_container; }
50                 }
51
52                 public MethodDefinitionCollection (TypeDefinition container)
53                 {
54                         m_container = container;
55                 }
56
57                 public void Add (MethodDefinition value)
58                 {
59                         Attach (value);
60
61                         List.Add (value);
62                 }
63
64
65                 public new void Clear ()
66                 {
67                         foreach (MethodDefinition item in this)
68                                 Detach (item);
69
70                         base.Clear ();
71                 }
72
73                 public bool Contains (MethodDefinition value)
74                 {
75                         return List.Contains (value);
76                 }
77
78                 public int IndexOf (MethodDefinition value)
79                 {
80                         return List.IndexOf (value);
81                 }
82
83                 public void Insert (int index, MethodDefinition value)
84                 {
85                         Attach (value);
86
87                         List.Insert (index, value);
88                 }
89
90                 public void Remove (MethodDefinition value)
91                 {
92                         List.Remove (value);
93
94                         Detach (value);
95                 }
96
97
98                 public new void RemoveAt (int index)
99                 {
100                         MethodDefinition item = this [index];
101                         Remove (item);
102                 }
103
104                 protected override void OnValidate (object o)
105                 {
106                         if (! (o is MethodDefinition))
107                                 throw new ArgumentException ("Must be of type " + typeof (MethodDefinition).FullName);
108                 }
109
110                 public MethodDefinition [] GetMethod (string name)
111                 {
112                         ArrayList ret = new ArrayList ();
113                         foreach (MethodDefinition meth in this)
114                                 if (meth.Name == name)
115                                         ret.Add (meth);
116
117                         return ret.ToArray (typeof (MethodDefinition)) as MethodDefinition [];
118                 }
119
120                 internal MethodDefinition GetMethodInternal (string name, IList parameters)
121                 {
122                         foreach (MethodDefinition meth in this) {
123                                 if (meth.Name != name || meth.Parameters.Count != parameters.Count)
124                                         continue;
125
126                                 bool match = true;
127                                 for (int i = 0; i < parameters.Count; i++) {
128                                         string pname;
129                                         object param = parameters [i];
130                                         if (param is Type)
131                                                 pname = ReflectionHelper.GetTypeSignature (param as Type);
132                                         else if (param is TypeReference)
133                                                 pname = (param as TypeReference).FullName;
134                                         else if (param is ParameterDefinition)
135                                                 pname = (param as ParameterDefinition).ParameterType.FullName;
136                                         else
137                                                 throw new NotSupportedException ();
138
139                                         if (meth.Parameters [i].ParameterType.FullName != pname) {
140                                                 match = false;
141                                                 break;
142                                         }
143                                 }
144
145                                 if (match)
146                                         return meth;
147                         }
148
149                         return null;
150                 }
151
152                 public MethodDefinition GetMethod (string name, Type [] parameters)
153                 {
154                         return GetMethodInternal (name, parameters);
155                 }
156
157                 public MethodDefinition GetMethod (string name, TypeReference [] parameters)
158                 {
159                         return GetMethodInternal (name, parameters);
160                 }
161
162                 public MethodDefinition GetMethod (string name, ParameterDefinitionCollection parameters)
163                 {
164                         return GetMethodInternal (name, parameters);
165                 }
166
167                 void Attach (MemberReference member)
168                 {
169                         if (member.DeclaringType != null)
170                                 throw new ReflectionException ("Member already attached, clone it instead");
171
172                         member.DeclaringType = m_container;
173                 }
174
175                 void Detach (MemberReference member)
176                 {
177                         member.DeclaringType = null;
178                 }
179
180                 public void Accept (IReflectionVisitor visitor)
181                 {
182                         visitor.VisitMethodDefinitionCollection (this);
183                 }
184         }
185 }