2009-07-11 Michael Barker <mike@middlesoft.co.uk>
[mono.git] / mcs / tools / mdoc / Test / DocTest-v1.cs
1 using System;
2 using System.Collections;
3 using System.Collections.Generic;
4 using System.Linq;
5
6 public class NoNamespace {}
7
8 namespace System {
9         /* 
10          * The System namespace gets special treatment, e.g. instead of
11          * System.Environment C# declarations it's just Environment.
12          */
13         /// <remarks><c>T:System.Action`1</c></remarks>
14         public delegate void Action<T> (T obj);
15
16         /// <remarks><c>T:System.Environment</c></remarks>
17         public static class Environment {
18                 /// <remarks><c>T:System.Environment+SpecialFolder</c></remarks>
19                 public enum SpecialFolder {}
20
21                 /// <param name="folder">
22                 ///   A <see cref="T:System.Environment+SpecialFolder" /> instance.
23                 /// </param>
24                 /// <remarks>
25                 ///   <c>M:System.Environment.GetFolderPath(System.Environment+SpecialFolder)</c>
26                 /// </remarks>
27                 public static string GetFolderPath (SpecialFolder folder)
28                 {
29                         throw new NotSupportedException ();
30                 }
31         }
32
33         // to test ECMA doc importing...
34         public class Array {
35                 // the ECMA docs have a different return type than .NET -- skip.
36                 public static System.Collections.ObjectModel.ReadOnlyCollection<T> AsReadOnly<T> (T[] array)
37                 {
38                         throw new NotImplementedException ();
39                 }
40
41                 // ECMA docs use <T,U> instead of <TInput,TOutput> --> map them.
42                 public static TOutput[] ConvertAll<TInput, TOutput> (TInput[] array, Converter<TInput, TOutput> converter)
43                 {
44                         throw new InvalidOperationException ();
45                 }
46
47                 // ECMA docs *incorrectly* document parameter -- skip
48                 public static void Resize<T> (ref T[] array, int newSize)
49                 {
50                         throw new Exception ();
51                 }
52         }
53
54         // to test ECMA doc importing...
55         public delegate void AsyncCallback (IAsyncResult ar);
56 }
57
58 namespace Mono.DocTest {
59         internal class Internal {
60                 public class ShouldNotBeDocumented {
61                 }
62         }
63
64         internal class MonoTODOAttribute : Attribute {
65         }
66
67         /// <remarks>
68         ///  <para>
69         ///   cref=<c>T:Mono.DocTest.DocAttribute</c>.
70         ///  </para>
71         ///  <code lang="C#" src="../DocTest.cs#DocAttribute Example" />
72         /// </remarks>
73         [AttributeUsage (AttributeTargets.All)]
74         public class DocAttribute : Attribute {
75                 #region DocAttribute Example
76                 [Doc ("documented class")]
77                 class Example {
78                         [Doc ("documented field")] public string field;
79                 }
80                 #endregion
81                 /// <remarks><c>C:Mono.DocTest.DocAttribute(System.String)</c></remarks>
82                 public DocAttribute (string docs)
83                 {
84                         if (docs == null)
85                                 throw new ArgumentNullException ("docs");
86                 }
87
88                 /// <remarks><c>P:Mono.DocTest.DocAttribute.Property</c></remarks>
89                 public Type Property { get; set; }
90
91                 /// <remarks><c>F:Mono.DocTest.DocAttribute.Field</c></remarks>
92                 public bool Field;
93
94                 /// <remarks><c>F:Mono.DocTest.DocAttribute.FlagsEnum</c></remarks>
95                 public ConsoleModifiers FlagsEnum;
96
97                 /// <remarks><c>F:Mono.DocTest.DocAttribute.NonFlagsEnum</c></remarks>
98                 public Color NonFlagsEnum;
99         }
100
101         /// <summary>Possible colors</summary>
102         /// <remarks><see cref="T:Mono.DocTest.Color"/>.</remarks>
103         [MonoTODO]
104         public enum Color {
105                 /// <summary>Insert Red summary here</summary>
106                 /// <remarks><c>F:Mono.DocTest.Color.Red</c>.</remarks>
107                 Red, 
108                 /// <summary>Insert Blue summary here</summary>
109                 /// <remarks><c>F:Mono.DocTest.Color.Blue</c>.</remarks>
110                 Blue, 
111                 /// <summary>Insert Green summary here</summary>
112                 /// <remarks><c>F:Mono.DocTest.Color.Green</c>.</remarks>
113                 Green,
114
115                 AnotherGreen = Green,
116         }
117
118         /// <summary>Process interface</summary>
119         /// <remarks><c>T:Mono.DocTest.IProcess</c>.</remarks>
120         public interface IProcess {}
121
122         /// <summary>Process interface</summary>
123         /// <remarks><c>T:Mono.DocTest.DocValueType</c>.</remarks>
124         public struct DocValueType : IProcess {
125                 /// <remarks><c>F:Mono.DocTest.DocValueType.total</c>.</remarks>
126                 public int total;
127
128                 /// <param name="i">A <see cref="T:System.Int32" />.</param>
129                 /// <remarks><see cref="M:Mono.DocTest.DocValueType.M(System.Int32)"/>.</remarks>
130                 public void M (int i)
131                 {
132                         if ((new Random().Next() % 2) == 0)
133                                 throw new SystemException ();
134                         throw new ApplicationException ();
135                 }
136         }
137
138         /// <remarks><c>T:Mono.DocTest.Widget</c>.</remarks>
139         /// <seealso cref="P:Mono.DocTest.Widget.Item(System.Int32)" />
140         /// <extra>Some extra tag value</extra>
141         public unsafe class Widget : IProcess {
142                 /// <remarks><c>T:Mono.DocTest.Widget.NestedClass</c>.</remarks>
143                 public class NestedClass {
144                         /// <remarks><c>F:Mono.DocTest.Widget.NestedClass.value</c>.</remarks>
145                         public int value;
146
147                         /// <param name="i">Some <see cref="T:System.Int32" />.</param>
148                         /// <remarks><c>M:Mono.DocTest.Widget.NestedClass.M(System.Int32)</c>.</remarks>
149                         public void M (int i) {}
150
151                         /// <remarks><c>T:Mono.DocTest.Widget.NestedClass.Double</c>.</remarks>
152                         public class Double {
153                                 /// <remarks><c>T:Mono.DocTest.Widget.NestedClass.Double.Triple</c>.</remarks>
154                                 public class Triple {
155                                         /// <remarks><c>T:Mono.DocTest.Widget.NestedClass.Double.Triple.Quadruple</c>.</remarks>
156                                         public class Quadruple {} // for good measure
157                                 }
158                         }
159                 }
160
161                 /// <remarks><c>T:Mono.DocTest.Widget.NestedClass`1</c>.</remarks>
162                 public class NestedClass<T> {
163                         /// <remarks><c>F:Mono.DocTest.Widget.NestedClass`1.value</c>.</remarks>
164                         public int value;
165
166                         /// <param name="i">Another <see cref="T:System.Int32" />.</param>
167                         /// <remarks><c>M:Mono.DocTest.Widget.NestedClass`1.M(System.Int32)</c>.</remarks>
168                         public void M (int i) {}
169                 }
170
171                 /// <remarks><c>F:Mono.DocTest.Widget.classCtorError</c>.</remarks>
172                 public static readonly string[] classCtorError = CreateArray ();
173
174                 private static string[] CreateArray ()
175                 {
176                         throw new NotSupportedException ();
177                 }
178
179                 /// <remarks><c>F:Mono.DocTest.Widget.message</c>.</remarks>
180                 public string message;
181
182                 /// <remarks><c>F:Mono.DocTest.Widget.defaultColor</c>.</remarks>
183                 protected static Color defaultColor;
184
185                 /// <remarks><c>F:Mono.DocTest.Widget.PI</c>.</remarks>
186                 protected internal const double PI = 3.14159;
187
188                 /// <remarks><c>F:Mono.DocTest.Widget.monthlyAverage</c>.</remarks>
189                 internal protected readonly double monthlyAverage;
190
191                 /// <remarks><c>F:Mono.DocTest.Widget.array1</c>.</remarks>
192                 public long[] array1;
193
194                 /// <remarks><c>F:Mono.DocTest.Widget.array2</c>.</remarks>
195                 public Widget[,] array2;
196
197                 /// <remarks><c>F:Mono.DocTest.Widget.pCount</c>.</remarks>
198                 public unsafe int *pCount;
199
200                 /// <remarks><c>F:Mono.DocTest.Widget.ppValues</c>.</remarks>
201                 public unsafe float **ppValues;
202
203                 /// <remarks><c>T:Mono.DocTest.Widget.IMenuItem</c>.</remarks>
204                 public interface IMenuItem {
205                         /// <remarks><c>M:Mono.DocTest.Widget.IMenuItem.A</c>.</remarks>
206                         void A ();
207
208                         /// <remarks><c>P:Mono.DocTest.Widget.IMenuItem.P</c>.</remarks>
209                         int B {get; set;}
210                 }
211
212                 /// <remarks><c>T:Mono.DocTest.Widget.Del</c>.</remarks>
213                 public delegate void Del (int i);
214
215                 /// <remarks><c>T:Mono.DocTest.Widget.Direction</c>.</remarks>
216                 [Flags]
217                 public enum Direction {
218                         /// <remarks><c>T:Mono.DocTest.Widget.Direction.North</c>.</remarks>
219                         North,
220                         /// <remarks><c>T:Mono.DocTest.Widget.Direction.South</c>.</remarks>
221                         South,
222                         /// <remarks><c>T:Mono.DocTest.Widget.Direction.East</c>.</remarks>
223                         East,
224                         /// <remarks><c>T:Mono.DocTest.Widget.Direction.West</c>.</remarks>
225                         West,
226                 }
227
228                 /// <remarks>
229                 ///  <para><c>C:Mono.DocTest.Widget</c>.</para>
230                 ///  <para><c>M:Mono.DocTest.Widget.#ctor</c>.</para>
231                 ///  <para><see cref="C:Mono.DocTest.Widget(System.String)" /></para>
232                 ///  <para><see cref="C:Mono.DocTest.Widget(System.Converter{System.String,System.String})" /></para>
233                 /// </remarks>
234                 public Widget () {}
235
236                 /// <param name="s">A <see cref="T:System.String" />.</param>
237                 /// <remarks>
238                 ///  <para><c>C:Mono.DocTest.Widget(System.String)</c>.</para>
239                 ///  <para><c>M:Mono.DocTest.Widget.#ctor(System.String)</c>.</para>
240                 /// </remarks>
241                 public Widget (string s) {}
242
243                 /// <param name="c">A <see cref="T:System.Converter{System.String,System.String}" />.</param>
244                 /// <remarks>
245                 ///  <para><c>C:Mono.DocTest.Widget(System.Converter{System.String,System.String})</c>.</para>
246                 /// </remarks>
247                 public Widget (Converter<string,string> c) {}
248
249                 /// <remarks><c>M:Mono.DocTest.Widget.M0</c>.</remarks>
250                 public static void M0 () {}
251
252                 /// <param name="c">A <see cref="T:System.Char" />.</param>
253                 /// <param name="f">A <see cref="T:System.Single" />.</param>
254                 /// <param name="v">A <see cref="T:Mono.DocTest.DocValueType" />.</param>
255                 /// <remarks><c>M:Mono.DocTest.Widget.M1(System.Char,System.Signle@,Mono.DocTest.DocValueType@)</c>.</remarks>
256                 [return:Doc ("return:DocAttribute", Property=typeof(Widget))]
257                 [Doc("normal DocAttribute", Field=true)]
258                 public void M1 ([Doc ("c", FlagsEnum=ConsoleModifiers.Alt | ConsoleModifiers.Control)] char c, 
259                                 [Doc ("f", NonFlagsEnum=Color.Red)] out float f, 
260                                 [Doc ("v")] ref DocValueType v) {f=0;}
261
262                 /// <param name="x1">A <see cref="T:System.Int16" /> array.</param>
263                 /// <param name="x2">A <see cref="T:System.Int32" /> array.</param>
264                 /// <param name="x3">A <see cref="T:System.Int64" /> array.</param>
265                 /// <remarks><c>M:Mono.DocTest.Widget.M2(System.Int16[],System.Int32[0:,0:],System.Int64[][])</c>.</remarks>
266                 public void M2 (short[] x1, int[,] x2, long[][] x3) {}
267
268                 /// <param name="x3">Another <see cref="T:System.Int64" /> array.</param>
269                 /// <param name="x4">A <see cref="T:Mono.DocTest.Widget" /> array.</param>
270                 /// <remarks><c>M:Mono.DocTest.Widget.M3(System.Int64[][],Mono.DocTest.Widget[0:,0:,0:][])</c>.</remarks>
271                 protected void M3 (long[][] x3, Widget[][,,] x4) {}
272
273                 /// <param name="pc">A <see cref="T:System.Char" /> pointer.</param>
274                 /// <param name="ppf">A <see cref="T:Mono.DocTest.Color" /> pointer.</param>
275                 /// <remarks><c>M:Mono.DocTest.Widget.M4(System.Char*,Mono.DocTest.Color**)</c>.</remarks>
276                 protected unsafe void M4 (char *pc, Color **ppf) {}
277
278                 /// <param name="pv">A <see cref="T:System.Void" /> pointer.</param>
279                 /// <param name="pd">A <see cref="T:System.Double" /> array.</param>
280                 /// <remarks><c>M:Mono.DocTest.Widget.M5(System.Void*,System.Double*[0:,0:][])</c>.</remarks>
281                 protected unsafe void M5 (void *pv, double *[][,] pd) {}
282
283                 /// <param name="i">Yet another <see cref="T:System.Int32" />.</param>
284                 /// <param name="args">An <see cref="T:System.Object" /> array.</param>
285                 /// <remarks><c>M:Mono.DocTest.Widget.M6(System.Int32,System.Object[])</c>.</remarks>
286                 protected void M6 (int i, params object[] args) {}
287
288                 /// <remarks><c>M:Mono.DocTest.Widget.M7(Mono.DocTest.Widget.NestedClass.Double.Triple.Quadruple)</c>.</remarks>
289                 public void M7(Widget.NestedClass.Double.Triple.Quadruple a) {}
290
291                 /// <value>A <see cref="T:System.Int32" /> value...</value>
292                 /// <remarks><c>P:Mono.DocTest.Widget.Width</c>.</remarks>
293                 public int Width {get {return 0;} protected set {}}
294
295                 /// <value>A <see cref="T:System.Int64" /> value...</value>
296                 /// <remarks><c>P:Mono.DocTest.Widget.Height</c>.</remarks>
297                 protected long Height {get {return 0;}}
298
299                 /// <value>A <see cref="T:System.Int16" /> value...</value>
300                 /// <remarks><c>P:Mono.DocTest.Widget.X</c>.</remarks>
301                 protected internal short X {set {}}
302
303                 /// <value>A <see cref="T:System.Double" /> value...</value>
304                 /// <remarks><c>P:Mono.DocTest.Widget.Y</c>.</remarks>
305                 internal protected double Y {get {return 0;} set {}}
306
307
308                 /// <param name="i">TODO</param>
309                 /// <remarks><c>P:Mono.DocTest.Widget.Item(System.Int32)</c>.</remarks>
310                 /// <value>A <see cref="T:System.Int32" /> instance.</value>
311                 public int this [int i] {get {return 0;} set {}}
312
313                 /// <param name="s">Some <see cref="T:System.String" />.</param>
314                 /// <param name="i">I love <see cref="T:System.Int32" />s.</param>
315                 /// <remarks><c>P:Mono.DocTest.Widget.Item(System.String,System.Int32)</c>.</remarks>
316                 /// <value>A <see cref="T:System.Int32" /> instance.</value>
317                 public int this [string s, int i] {get {return 0;} set {}}
318
319                 /// <remarks><c>E:Mono.DocTest.Widget.AnEvent</c>.</remarks>
320                 public event Del AnEvent;
321
322                 /// <remarks><c>E:Mono.DocTest.Widget.AnotherEvent</c>.</remarks>
323                 protected event Del AnotherEvent;
324
325                 /// <param name="x">Another <see cref="T:Mono.DocTest.Widget" />.</param>
326                 /// <remarks><c>M:Mono.DocTest.Widget.op_UnaryPlus(Mono.DocTest.Widget)</c>.</remarks>
327                 /// <returns>A <see cref="T:Mono.DocTest.Widget" /> instance.</returns>
328                 public static Widget operator+ (Widget x) {return null;}
329
330                 /// <param name="x1">Yet Another <see cref="T:Mono.DocTest.Widget" />.</param>
331                 /// <param name="x2">Yay, <see cref="T:Mono.DocTest.Widget" />s.</param>
332                 /// <remarks><c>M:Mono.DocTest.Widget.op_Addition(Mono.DocTest.Widget,Mono.DocTest.Widget)</c>.</remarks>
333                 /// <returns>A <see cref="T:Mono.DocTest.Widget" /> instance (2).</returns>
334                 public static Widget operator+ (Widget x1, Widget x2) {return null;}
335
336                 /// <param name="x"><see cref="T:Mono.DocTest.Widget" />s are fun!.</param>
337                 /// <remarks><c>M:Mono.DocTest.Widget.op_Explicit(Mono.DocTest.Widget)~System.Int32</c>.</remarks>
338                 /// <returns>A <see cref="T:System.Int32" /> instance.</returns>
339                 public static explicit operator int (Widget x) {return 0;}
340
341                 /// <param name="x"><c>foo</c>; <see cref="T:Mono.DocTest.Widget" />.</param>
342                 /// <remarks><c>M:Mono.DocTest.Widget.op_Implicit(Mono.DocTest.Widget)~System.Int64</c>.</remarks>
343                 /// <returns>A <see cref="T:System.Int64" /> instance.</returns>
344                 public static implicit operator long (Widget x) {return 0;}
345         }
346
347         /// <remarks><c>T:Mono.DocTest.UseLists</c>.</remarks>
348         public class UseLists
349         {
350                 /// <param name="list">A <see cref="T:Mono.DocTest.Generic.MyList{System.Int32}" />.</param>
351                 /// <remarks><c>M:Mono.DocTest.UseLists.Process(Mono.DocTest.MyList{System.Int32})</c>.</remarks>
352                 public void Process (Generic.MyList<int> list) {}
353
354                 /// <param name="value">A <c>T</c>.</param>
355                 /// <typeparam name="T">Something</typeparam>
356                 /// <remarks><c>M:Mono.DocTest.UseLists.GetValues``1(``0)</c>.</remarks>
357                 /// <returns>A <see cref="T:Mono.DocTest.Generic.MyList`1" /> instance.</returns>
358                 public Generic.MyList<T> GetValues <T> (T value) where T : struct {return null;}
359
360                 /// <param name="list">Another <see cref="T:Mono.DocTest.Generic.MyList{System.Int32}" />.</param>
361                 /// <remarks>
362                 ///  <para><c>M:Mono.DocTest.UseLists.Process(System.Collections.Generic.List{System.Int32})</c>.</para>
363                 /// <para><see cref="M:System.Collections.Generic.List{System.Int32}.Remove(`0)" /></para>
364                 /// </remarks>
365                 /// <exception invalid="foo">text!</exception>
366                 public void Process (List<int> list)
367                 {
368                         // Bug: only creation is looked for, so this generates an <exception/>
369                         // node:
370                         new Exception ();
371
372                         // Bug? We only look at "static" types, so we can't follow
373                         // delegates/interface calls:
374                         Func<int, int> a = x => {throw new InvalidOperationException ();};
375                         a (1);
376
377                         // Multi-dimensional arrays have "phantom" methods that Cecil can't
378                         // resolve, as they're provided by the runtime.  These should be
379                         // ignored.
380                         int[,] array = new int[1,1];
381                         array[0,0] = 42;
382                 }
383
384                 /// <param name="list">A <see cref="T:Mono.DocTest.Generic.MyList{System.Predicate{System.Int32}}" />.</param>
385                 /// <remarks><c>M:Mono.DocTest.UseLists.Process(System.Collections.Generic.List{System.Predicate{System.Int32}})</c>.</remarks>
386                 public void Process (List<Predicate<int>> list)
387                 {
388                         if (list == null)
389                                 throw new ArgumentNullException ("list");
390                         Process<int> (list);
391                 }
392
393                 /// <param name="list">A <see cref="T:Mono.DocTest.Generic.MyList{System.Predicate{``0}}" />.</param>
394                 /// <typeparam name="T">Something Else</typeparam>
395                 /// <remarks><c>M:Mono.DocTest.UseLists.Process``1(System.Collections.Generic.List{System.Predicate{``0}})</c>.</remarks>
396                 public void Process<T> (List<Predicate<T>> list)
397                 {
398                         if (list.Any (p => p == null))
399                                 throw new ArgumentException ("predicate null");
400                 }
401
402                 /// <param name="helper">A <see cref="T:Mono.DocTest.Generic.MyList{``0}.Helper{``1,``2}" />.</param>
403                 /// <typeparam name="T"><c>T</c></typeparam>
404                 /// <typeparam name="U"><c>U</c></typeparam>
405                 /// <typeparam name="V"><c>V</c></typeparam>
406                 /// <remarks><c>M:Mono.DocTest.UseLists.UseHelper``3(Mono.DocTest.Generic.MyList{``0}.Helper{``1,``2})</c>.</remarks>
407                 public void UseHelper<T,U,V> (Generic.MyList<T>.Helper<U,V> helper) {}
408         }
409 }
410
411 namespace Mono.DocTest.Generic {
412         // Need to place this into a separate namespace to work around gmcs bug
413         // where XML docs for type *following* this one aren't extracted.
414
415         /// <typeparam name="TArg">argument type, with attributes!</typeparam>
416         /// <typeparam name="TRet">return type, with attributes!</typeparam>
417         /// <remarks><c>T:Mono.DocTest.Generic.Func`2</c>.</remarks>
418         [Doc ("method")]
419         [return:Doc ("return", Field=false)]
420         public delegate TRet Func<[Doc ("arg!")] TArg, [Doc ("ret!")] TRet> (
421                         [Doc ("arg-actual")] TArg a
422         ) where TArg : Exception;
423 }
424
425 namespace Mono.DocTest.Generic {
426         using Mono.DocTest;
427
428         /// <summary>extension methods!</summary>
429         /// <remarks><c>T:Mono.DocTest.Generic.Extensions</c></remarks>
430         public static class Extensions {
431                 /// <summary><c>System.Object</c> extension method</summary>
432                 /// <remarks><c>M:Mono.DocTest.Generic.Extensions.ToEnumerable``1</c></remarks>
433                 public static IEnumerable<T> ToEnumerable<T> (this T self)
434                 {
435                         yield return self;
436                 }
437
438                 /// <summary><see cref="T:System.Collections.Generic.IEnumerable`1" /> extension method</summary>
439                 /// <remarks><c>M:Mono.DocTest.Generic.Extensions.ForEach``1</c></remarks>
440                 public static void ForEach<T> (this IEnumerable<T> self, Action<T> a)
441                 {
442                 }
443
444                 /// <summary><see cref="T:Mono.DocTest.Generic.IFoo`1" /> extension method</summary>
445                 /// <remarks><c>M:Mono.DocTest.Generic.Extensions.Bar``1</c></remarks>
446                 public static void Bar <T> (this IFoo<T> self, string s)
447                 {
448                 }
449
450                 /// <summary>
451                 ///   <see cref="T:System.Collections.Generic.IEnumerable{System.Int32}" /> 
452                 ///   extension method.
453                 /// </summary>
454                 /// <remarks><c>M:Mono.DocTest.Generic.Extensions.ToDouble</c></remarks>
455                 public static IEnumerable<double> ToDouble (this IEnumerable<int> list)
456                 {
457                         return null;
458                 }
459
460                 /// <summary>
461                 ///   <see cref="T:Mono.DocTest.Generic.IFoo`1" /> extension method.
462                 /// </summary>
463                 /// <remarks><c>M:Mono.DocTest.Generic.Extensions.ToDouble</c></remarks>
464                 public static double ToDouble<T> (this T val) where T : IFoo<T>
465                 {
466                         // the target type is T:...IFoo<T>, NOT T:System.Object.
467                         return 0.0;
468                 }
469         }
470
471         /// <typeparam name="U">Insert <c>text</c> here.</typeparam>
472         /// <remarks><c>T:Mono.DocTest.Generic.GenericBase`1</c>.</remarks>
473         public class GenericBase<U> {
474         
475                 /// <param name="genericParameter">Something</param>
476                 /// <typeparam name="S">Insert more <c>text</c> here.</typeparam>
477                 /// <remarks><c>M:Mono.DocTest.GenericBase`1.BaseMethod``1(``0)</c>.</remarks>
478                 /// <returns>The default value.</returns>
479                 public U BaseMethod<[Doc ("S")] S> (S genericParameter) {
480                         return default(U);
481                 }
482
483                 /// <remarks><c>F:Mono.DocTest.GenericBase`1.StaticField1</c></remarks>
484                 public static readonly GenericBase<U> StaticField1 = new GenericBase<U> ();
485
486                 /// <remarks><c>F:Mono.DocTest.GenericBase`1.ConstField1</c></remarks>
487                 public const int ConstField1 = 1;
488
489                 /// <param name="list">Insert description here</param>
490                 /// <remarks><c>M:Mono.DocTest.GenericBase`1.op_Explicit(Mono.DocTest.GenericBase{`0})~`0</c></remarks>
491                 /// <returns>The default value for <typeparamref name="U"/>.</returns>
492                 public static explicit operator U (GenericBase<U> list) {return default(U);}
493
494                 /// <remarks>T:Mono.DocTest.Generic.GenericBase`1.FooEventArgs</remarks>
495                 public class FooEventArgs : EventArgs {
496                 }
497
498                 /// <remarks>E:Mono.DocTest.Generic.GenericBase`1.MyEvent</remarks>
499                 public event EventHandler<FooEventArgs> MyEvent;
500
501                 /// <remarks>T:Mono.DocTest.Generic.GenericBase`1.NestedCollection</remarks>
502                 public class NestedCollection {
503                         /// <remarks>T:Mono.DocTest.Generic.GenericBase`1.NestedCollection.Enumerator</remarks>
504                         public struct Enumerator {
505                         }
506                 }
507         }
508         
509         /// <typeparam name="T">I'm Dying Here!</typeparam>
510         /// <remarks><c>T:Mono.DocTest.Generic.MyList`1</c>.</remarks>
511         public class MyList<[Mono.DocTest.Doc("Type Parameter!")] T> : GenericBase <T>, IEnumerable<int[]>
512         {
513                 /// <typeparam name="U">Seriously!</typeparam>
514                 /// <typeparam name="V">Too <c>many</c> docs!</typeparam>
515                 /// <remarks><c>T:Mono.DocTest.MyList`1.Helper`2</c>.</remarks>
516                 public class Helper <U, V> {
517                         /// <param name="a">Ako</param>
518                         /// <param name="b">bko</param>
519                         /// <param name="c">cko</param>
520                         /// <remarks><c>M:Mono.DocTest.MyList`1.Helper`2.UseT(`0,`1,`2)</c>.</remarks>
521                         public void UseT(T a, U b, V c) { }
522                 }
523
524                 /// <param name="t">tko</param>
525                 /// <remarks><c>M:Mono.DocTest.MyList`1.Test(`0)</c>.</remarks>
526                 public void Test (T t) {}
527
528                 /// <param name="t">Class generic type</param>
529                 /// <param name="u">Method generic type</param>
530                 /// <typeparam name="U">Method generic parameter</typeparam>
531                 /// <remarks><c>M:Mono.DocTest.MyList`1.Method``1(`0,``0)</c>.</remarks>
532                 public void Method <U> (T t, U u) {}
533
534                 // mcs "crashes" (CS1569) on this method; exclude it for now.
535                 // <remarks><c>M:Mono.DocTest.MyList`1.RefMethod``1(`0@,``0@)</c>.</remarks>
536                 public void RefMethod<U> (ref T t, ref U u) {}
537
538                 /// <param name="helper">A <see cref="T:Mono.DocTest.Generic.MyList`1.Helper`2" />.</param>
539                 /// <typeparam name="U">Argh!</typeparam>
540                 /// <typeparam name="V">Foo Argh!</typeparam>
541                 /// <remarks><c>M:Mono.DocTest.Generic.MyList`1.UseHelper``2(Mono.DocTest.Generic.MyList{``0}.Helper{``1,``2})</c>.</remarks>
542                 public void UseHelper<U,V> (Helper<U,V> helper) {}
543
544                 /// <remarks><c>M:Mono.DocTest.Generic.MyList`1.GetHelper``2</c>.</remarks>
545                 /// <returns><see langword="null" />.</returns>
546                 public Helper<U,V> GetHelper<U,V> () {return null;}
547
548                 /// <remarks><c>M:Mono.DocTest.MyList`1.System#Collections#GetEnumerator</c>.</remarks>
549                 IEnumerator IEnumerable.GetEnumerator () {return null;}
550
551                 /// <remarks><c>M:Mono.DocTest.MyList`1.GetEnumerator</c>.</remarks>
552                 public IEnumerator<int[]> GetEnumerator () {return null;}
553         }
554
555         /// <typeparam name="T">T generic param</typeparam>
556         /// <remarks><c>T:Mono.DocTest.IFoo`1</c>.</remarks>
557         public interface IFoo<T> {
558                 /// <typeparam name="U">U generic param</typeparam>
559                 /// <remarks><c>T:Mono.DocTest.IFoo`1.Method``1(`0,``0)</c>.</remarks>
560                 T Method <U> (T t, U u);
561         }
562
563         /// <typeparam name="A">Ako generic param</typeparam>
564         /// <typeparam name="B">Bko generic param</typeparam>
565         /// <remarks><c>T:Mono.DocTest.MyList`2</c>.</remarks>
566         public class MyList<A,B> : GenericBase<Dictionary<A,B>>, IEnumerable<A>, 
567                                  IEnumerator<A>, ICollection<A>, IFoo<A>
568                 where A : class, IList<B>, new()
569                 where B : class, A
570         {
571                 // IEnumerator
572
573                 // shown?
574                 object IEnumerator.Current {get {return null;}}
575
576                 /// <remarks><c>M:Mono.DocTest.MyList`2.MoveNext</c>.</remarks>
577                 /// <returns><see cref="T:System.Boolean" /></returns>
578                 public bool MoveNext () {return false;}
579
580                 /// <remarks><c>M:Mono.DocTest.MyList`2.Reset</c>.</remarks>
581                 public void Reset () {}
582
583                 // IDisposable
584                 /// <remarks><c>M:Mono.DocTest.MyList`2.Dispose</c>.</remarks>
585                 public void Dispose () {}
586
587                 // IEnumerator<T>
588                 /// <remarks><c>P:Mono.DocTest.MyList`2.Current</c>.</remarks>
589                 /// <value>The current value.</value>
590                 public A Current {get {return default(A);}}
591                 /// <remarks><c>P:Mono.DocTest.MyList`2.Current</c>.</remarks>
592                 /// <value>The current value.</value>
593                 A IEnumerator<A>.Current {get {return default(A);}}
594
595                 // IEnumerable
596                 /// <remarks><c>M:Mono.DocTest.MyList`2.System#Collections#GetEnumerator</c>.</remarks>
597                 IEnumerator IEnumerable.GetEnumerator () {return this;}
598
599                 // IEnumerable<T>
600                 /// <remarks><c>M:Mono.DocTest.MyList`2.System#Collections#Generic#IEnumerable{A}#GetEnumerator</c>.</remarks>
601                 /// <returns>A <see cref="T:System.Collections.Generic.IEnumerator{`0}" />.</returns>
602                 IEnumerator<A> IEnumerable<A>.GetEnumerator () {return this;}
603                 /// <remarks><c>M:Mono.DocTest.MyList`2.GetEnumerator</c>.</remarks>
604                 /// <returns>A <see cref="T:System.Collections.Generic.List{`0}.Enumerator" />.</returns>
605                 public List<A>.Enumerator GetEnumerator () {return new List<A>.Enumerator ();}
606
607                 // ICollection<T>
608                 /// <remarks><c>P:Mono.DocTest.MyList`2.Count</c>.</remarks>
609                 /// <value>A <see cref="T:System.Int32" />.</value>
610                 public int Count {get {return 0;}}
611                 /// <remarks><c>P:Mono.DocTest.MyList`2.System#Collections#Generic#ICollection{A}#IsReadOnly</c>.</remarks>
612                 /// <value>A <see cref="T:System.Boolean" />.</value>
613                 bool ICollection<A>.IsReadOnly {get {return false;}}
614                 /// <param name="item">The item to add.</param>
615                 /// <remarks><c>M:Mono.DocTest.MyList`2.System#Collections#Generic#ICollection{A}#Add(`0)</c>.</remarks>
616                 void ICollection<A>.Add (A item) {}
617                 /// <remarks><c>M:Mono.DocTest.MyList`2.System#Collections#Generic#ICollection{A}#Clear</c>.</remarks>
618                 void ICollection<A>.Clear () {}
619                 /// <param name="item">The item to check for</param>
620                 /// <remarks><c>M:Mono.DocTest.MyList`2.System#Collections#Generic#ICollection{A}.Contains(`0)</c>.</remarks>
621                 /// <returns>A <see cref="T:System.Boolean" /> instance (<see langword="false" />).</returns>
622                 bool ICollection<A>.Contains (A item) {return false;}
623                 /// <param name="array">Where to copy elements to</param>
624                 /// <param name="arrayIndex">Where to start copyingto</param>
625                 /// <remarks><c>M:Mono.DocTest.MyList`2.CopyTo(`0[],System.Int32)</c>.</remarks>
626                 public void CopyTo (A[] array, int arrayIndex) {}
627                 /// <param name="item">the item to remove</param>
628                 /// <remarks><c>M:Mono.DocTest.MyList`2.System#Collections#Generic#ICollection{A}#Remove(`0)</c>.</remarks>
629                 /// <returns>Whether the item was removed.</returns>
630                 bool ICollection<A>.Remove (A item) {return false;}
631
632                 /// <remarks>M:Mono.DocTest.Generic.MyList`2.Foo</remarks>
633                 public KeyValuePair<IEnumerable<A>, IEnumerable<B>> Foo ()
634                 {
635                         return new KeyValuePair<IEnumerable<A>, IEnumerable<B>> ();
636                 }
637
638                 // IFoo members
639                 /// <typeparam name="U">U generic param on MyList`2</typeparam>
640                 /// <remarks><c>M:Mono.DocTest.Generic.MyList`2.Mono#DocTest#Generic#IFoo{A}#Method``1(`0,``0)</c>.</remarks>
641                 A IFoo<A>.Method <U> (A a, U u)
642                 {
643                         return default (A);
644                 }
645         }
646 }
647