summaryrefslogtreecommitdiff
path: root/src/compiler/scala/tools/nsc/doc/SourcelessComments.scala
blob: 9216fa6f230c93ad095c0946487bb5d34be9c022 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
/* NSC -- new Scala compiler -- Copyright 2007-2010 LAMP/EPFL */

package scala.tools.nsc
package doc

import scala.collection._

/**
 * This class contains comments to all symbols which pre-exist in Scala, such as Any, Nothing, ...
 * It also contains a HashSet of the given symbols
 * The comments are to be added to a HashMap called comments, which resides in the Global.scala file
 *  @author Manohar Jonnalagedda, Stephane Micheloud, Sean McDirmid, Geoffrey Washburn
 *  @version 1.0
 */
abstract class SourcelessComments {

  val global: Global

  import global._
  import definitions._

  lazy val comments = {

    val comment = mutable.HashMap.empty[Symbol, DocComment]

    comment(NothingClass) = new DocComment("""
      /** <p>
        * Class <code>Nothing</code> is - together with class <a href="Null.html">
        * <code>Null</code></a> - at the bottom of the
        * <a href="http://scala-lang.org" target="_top">Scala</a> type
        * hierarchy.
        * </p>
        * <p>
        * Type <code>Nothing</code> is a subtype of every other type
        * (including <a href="Null.html"><code>Null</code></a>); there
        * exist <em>no instances</em> of this type. Even though type
        * <code>Nothing</code> is empty, it is nevertheless useful as a
        * type parameter. For instance, the <a href="http://scala-lang.org"
        * target="_top">Scala</a> library defines a value
        * <a href="Nil$object.html"><code>Nil</code></a> of type
        * <code><a href="List.html">List</a>[Nothing]</code>. Because lists
        * are covariant in <a href="http://scala-lang.org" target="_top">Scala</a>,
        * this makes <a href="Nil$object.html"><code>Nil</code></a> an
        * instance of <code><a href="List.html">List</a>[T]</code>, for
        * any element type <code>T</code>.
        * </p> */
      """)

     comment(NullClass) = new DocComment("""
       /** <p>
         * Class <code>Null</code> is - together with class <a href="Nothing.html">
         * <code>Nothing</code> - at the bottom of the
         * <a href="http://scala-lang.org" target="_top">Scala</a> type
         * hierarchy.
         * </p>
         * <p>
         * Type <code>Null</code> is a subtype of all reference types; its
         * only instance is the <code>null</code> reference.
         * Since <code>Null</code> is not a subtype of value types,
         * <code>null</code> is not a member of any such type. For instance,
         * it is not possible to assign <code>null</code> to a variable of
         * type <a href="Int.html"><code>Int</code></a>.
         * </p> */
       """)

     /*******************************************************************/
     /* Documentation for Any */

     comment(AnyClass) = new DocComment("""
      /** <p>
        * Class <code>Any</code> is the root of the <a
        * href="http://scala-lang.org/"
        * target="_top">Scala</a> class hierarchy. Every class in a
        * <a href="http://scala-lang.org/" target="_top">Scala</a> execution
        * environment inherits directly or indirectly from this class.
        * Class <code>Any</code> has two direct subclasses:
        * <a href="AnyRef.html"><code>AnyRef</code></a> and
        * <a href="AnyVal.html"><code>AnyVal</code></a>.
        * </p> */
      """)

    comment(Any_equals) = new DocComment("""
      /** This method is used to compare the receiver object (<code>this</code>)
        * with the argument object (<code>arg0</code>) for equivalence.
        *
        * <p>
        * The default implementations of this method is an <a
        * href="http://en.wikipedia.org/wiki/Equivalence_relation">equivalence
        * relation</a>:
        *   <ul>
        *  <li>It is reflexive: for any instance <code>x</code> of type <code>Any</code>,
        *  <code>x.equals(x)</code> should return <code>true</code>.</li>
        *  <li>It is symmetric: for any instances <code>x</code> and <code>y</code> of type
        *  <code>Any</code>, <code>x.equals(y)</code> should return <code>true</code> if and only
        *  if <code>y.equals(x)</code> returns <code>true</code>.</li>
        *  <li>It is transitive: for any instances
        *  <code>x</code>, <code>y</code>, and <code>z</code> of type <code>AnyRef</code>
        *  if <code>x.equals(y)</code> returns <code>true</code> and
        *  <code>y.equals(z)</code> returns
        *  <code>true</code>, then <code>x.equals(z)</code> should return <code>true</code>.</li>
        *</ul>
        *</p>
        *
        * <p>
        * If you override this method, you should verify that
        * your implementation remains an equivalence relation.
        * Additionally, when overriding this method it is often necessary to
        * override <code>hashCode</code> to ensure that objects that are
        * "equal" (<code>o1.equals(o2)</code> returns <code>true</code>)
        * hash to the same <a href="Int.html"><code>Int</code></a>
        * (<code>o1.hashCode.equals(o2.hashCode)</code>).
        *
        * @param arg0 the object to compare against this object for equality.
        * @return <code>true</code> if the receiver object is equivalent to the argument; <code>false</code> otherwise.
        * </p> */
      """)

    comment(Any_==) = new DocComment("""
      /** `o == arg0` is the same as `o.equals(arg0)`.
        * <p>
        * @param arg0 the object to compare against this object for equality.
        * @return `true` if the receiver object is equivalent to the argument; `false` otherwise.
        * </p> */
      """)

    comment(Any_!=) = new DocComment("""
      /** `o != arg0` is the same as `!(o == (arg0))`.
        * <p>
        * @param arg0 the object to compare against this object for dis-equality.
        * @return `false` if the receiver object is equivalent to the argument; `true` otherwise.
        * </p> */
      """)

    comment(Any_toString) = new DocComment("""
      /** Returns a string representation of the object.
        * <p>
        * The default representation is platform dependent.
        *
        * @return a string representation of the object.
        * </p>*/
      """)

    comment(Any_asInstanceOf) = new DocComment("""
      /**This method is used to cast the receiver object to be of type <code>T0</code>.
        *
        * <p>Note that the success of a cast at runtime is modulo Scala's
        * erasure semantics.  Therefore the expression
        * <code>1.asInstanceOf[String]</code> will throw a
        * <code>ClassCastException</code> at runtime, while the expression
        * <code>List(1).asInstanceOf[List[String]]</code> will not.  In the
        * latter example, because the type argument is erased as part of
        * compilation it is not possible to check whether the contents of
        * the list are of the requested typed.
        *
        * @throws ClassCastException if the receiver object is not an
        * instance of erasure of type <code>T0</code>.
        * @return the receiver object.
        * </p> */
      """)

    comment(Any_isInstanceOf) = new DocComment("""
      /** This method is used to test whether the dynamic type of the receiver object is <code>T0</code>.
        *
        * <p>Note that the test result of the test is modulo Scala's erasure
        * semantics.  Therefore the expression
        * <code>1.isInstanceOf[String]</code> will return
        * <code>false</code>, while the expression
        * <code>List(1).isInstanceOf[List[String]]</code> will return
        * <code>true</code>.  In the latter example, because the type
        * argument is erased as part of compilation it is not possible to
        * check whether the contents of the list are of the requested typed.
        *
        * @return <code>true</code> if the receiver object is an
        * instance of erasure of type <code>T0</code>; <code>false</code> otherwise. */
      """)

    comment(Any_hashCode) = new DocComment("""
      /** Returns a hash code value for the object.
        *
        * <p>
        * The default hashing algorithm is platform dependent.
        *
        * Note that it is allowed for two objects to have identical hash
        * codes (<code>o1.hashCode.equals(o2.hashCode)</code>) yet not be
        * equal (<code>o1.equals(o2)</code> returns <code>false</code>).  A
        * degenerate implementation could always return <code>0</code>.
        * However, it is required that if two objects are equal
        * (<code>o1.equals(o2)</code> returns <code>true</code>) that they
        * have identical hash codes
        * (<code>o1.hashCode.equals(o2.hashCode)</code>).  Therefore, when
        * overriding this method, be sure to verify that the behavior is
        * consistent with the <code>equals</code> method.
        * </p>
        *
        * <p>
        * @return the hash code value for the object.
        * </p> */
      """)

     /*******************************************************************/
     /* Documentation for AnyRef */

     comment(AnyRefClass) = new DocComment("""
       /** <p>
         * Class <code>AnyRef</code> is the root class of all
         * <em>reference types</em>.
         * </p> */
       """)

    comment(Object_==) = new DocComment("""
      /** <code>o == arg0</code> is the same as <code>if (o eq null) arg0 eq null else o.equals(arg0)</code>.
        * <p>
        * @param arg0 the object to compare against this object for equality.
        * @return <code>true</code> if the receiver object is equivalent to the argument; <code>false</code> otherwise.
        * </p> */
      """)

    comment(Object_ne) = new DocComment("""
      /** <code>o.ne(arg0)</code> is the same as <code>!(o.eq(arg0))</code>.
        * <p>
        * @param arg0 the object to compare against this object for reference dis-equality.
        * @return <code>false</code> if the argument is not a reference to the receiver object; <code>true</code> otherwise.
        * </p> */
      """)


    comment(Object_finalize) = new DocComment("""
      /** This method is called by the garbage collector on the receiver object when garbage
        * collection determines that there are no more references to the object.
        * <p>
        * The details of when and if the <code>finalize</code> method are
        * invoked, as well as the interaction between <code>finalize</code>
        * and non-local returns and exceptions, are all platform dependent.
        * </p> */
      """)

    comment(Object_clone) = new DocComment("""
      /** This method creates and returns a copy of the receiver object.
        *
        * <p>
        * The default implementation of the <code>clone</code> method is platform dependent.
        *
        * @return a copy of the receiver object.
        * </p> */
      """)

    comment(Object_getClass) = new DocComment("""
      /** Returns a representation that corresponds to the dynamic class of the receiver object.
        *
        * <p>
        * The nature of the representation is platform dependent.
        *
        * @return a representation that corresponds to the dynamic class of the receiver object.
        * </p> */
      """)

    comment(Object_notify) = new DocComment("""
      /** Wakes up a single thread that is waiting on the receiver object's monitor. */
      """)

    comment(Object_notifyAll) = new DocComment("""
      /** Wakes up all threads that are waiting on the receiver object's monitor. */
      """)

    comment(Object_eq) = new DocComment("""
      /** This method is used to test whether the argument (<code>arg0</code>) is a reference to the
        * receiver object (<code>this</code>).
        *
        * <p>
        * The <code>eq</code> method implements an
        * <a href="http://en.wikipedia.org/wiki/Equivalence_relation">equivalence relation</a> on non-null instances of
        * <code>AnyRef</code>:
        * <ul>
        * <li>It is reflexive: for any non-null instance <code>x</code> of type <code>AnyRef</code>,
        * <code>x.eq(x)</code> returns <code>true</code>.</li>
        * <li>It is symmetric: for any non-null instances <code>x</code> and <code>y</code> of type
        * <code>AnyRef</code>, <code>x.eq(y)</code> returns <code>true</code> if and only
        * if <code>y.eq(x)</code> returns <code>true</code>.</li>
        * <li>It is transitive: for any non-null instances
        * <code>x</code>, <code>y</code>, and <code>z</code> of type <code>AnyRef</code>
        * if <code>x.eq(y)</code> returns <code>true</code> and
        * <code>y.eq(z)</code> returns
        * <code>true</code>, then <code>x.eq(z)</code> returns <code>true</code>.</li>
        * </ul>
        * Additionally, the <code>eq</code> method has three other properties.
        * <ul>
        *  <li>It is consistent: for any non-null instances <code>x</code> and <code>y</code> of type <code>AnyRef</code>,
        *    multiple invocations of <code>x.eq(y)</code> consistently returns <code>true</code>
        *    or consistently returns <code>false</code>.</li>
        *  <li>For any non-null instance <code>x</code> of type <code>AnyRef</code>,
        *   <code>x.eq(null)</code> and <code>null.eq(x)</code> returns <code>false</code>.</li>
        *  <li><code>null.eq(null)</code> returns <code>true</code>.</li>
        *</ul>
        *</p>
        *
        * <p> When overriding the <code>equals</code> or
        * <code>hashCode</code> methods, it is important to ensure that
        * their behavior is consistent with reference equality.  Therefore,
        * if two objects are references to each other (<code>o1 eq
        * o2</code>), they should be equal to each other (<code>o1 ==
        * o2</code>) and they should hash to the same value
        * (<code>o1.hashCode == o2.hashCode</code>).</p>
        *
        * @param arg0 the object to compare against this object for reference equality.
        * @return <code>true</code> if the argument is a reference to the receiver object; <code>false</code> otherwise.
        * </p> */
      """)

    /*******************************************************************/

    comment(AnyValClass) = new DocComment("""
      /** <p>
        * Class <code>AnyVal</code> is the root class of all
        * <em>value types</em>.
        * </p>
        * <p>
        * <code>AnyVal</code> has a fixed number subclasses, which
        * describe values which are not implemented as objects in the
        * underlying host system.
        * </p>
        * <p>
        *  Classes <a href="Double.html"><code>Double</code></a>,
        * <a href="Float.html"><code>Float</code></a>,
        * <a href="Long.html"><code>Long</code></a>,
        * <a href="Int.html"><code>Int</code></a>,
        * <a href="Char.html"><code>Char</code></a>,
        * <a href="Short.html"><code>Short</code></a>, and
        * <a href="Byte.html"><code>Byte</code></a> are together called
        * <em>numeric value types</em>.
        * Classes <a href="Byte.html"><code>Byte</code></a>,
        * <a href="Short.html"><code>Short</code></a>, or
        * <a href="Char.html"><code>Char</code></a>
        * are called <em>subrange types</em>. Subrange types, as well as
        * <a href="Int.html"><code>Int</code></a> and
        * <a href="Long.html"><code>Long</code></a> are called
        * <em>integer types</em>, whereas
        * <a href="Float.html"><code>Float</code></a> and
        * <a href="Double.html"><code>Double</code></a> are called
        * <em>floating point types</em>.
        * </p> */
      """)

    comment(BooleanClass) = new DocComment("""
      /** <p>
        * Class <code>Boolean</code> has only two values: <code>true</code>
        * and <code>false</code>.
        * </p> */
      """)

    comment(UnitClass) = new DocComment("""
      /** <p>
        * Class <code>Unit</code> has only one value: <code>()</code>.
        * </p> */
      """)

    List(ByteClass, CharClass, DoubleClass, LongClass, FloatClass, IntClass, ShortClass) foreach { sym =>
      val maxValue = "MAX_" + sym.name.toString().toUpperCase()
      val minValue = "MIN_" + sym.name.toString().toUpperCase()
      comment(sym) = new DocComment("""
        /** <p>
          * Class <code>""" + sym.name + """</code> belongs to the value
          * classes whose instances are not represented as objects by the
          * underlying host system.  There is an implicit conversion from
          * instances of <code>""" + sym.name + """</code> to instances of
          * <a href="runtime/Rich""" + sym.name + """.html"><code>runtime.Rich""" + sym.name + """</code></a> which
          * provides useful non-primitive operations.  All value classes inherit
          * from class <a href="AnyVal.html"><code>AnyVal</code></a>.
          * </p>
          * <p>
          *  Values <code>""" + maxValue + """</code> and <code>""" + minValue + """</code>
          *  are in defined in object <a href="Math$object.html">scala.Math</a>.
          * </p> */
        """)
    }

    comment
  }

}