blob: 75bd80022a0b32e1e6aa8884f64d1a7ac76237c1 (
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
|
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2006-2009, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
// $Id$
package scala.runtime
import Predef.NoSuchElementException
/** <p>
* For example, in the following code
* </p>
* <pre>
* <b>object</b> test <b>extends</b> Application {
* Console.println(<chr>'\40'</chr>.isWhitespace)
* Console.println('\011'.isWhitespace)
* Console.println('1'.asDigit == 1)
* Console.println('A'.asDigit == 10)
* }</pre>
* <p>
* the implicit conversions are performed using the predefined view
* <a href="../Predef$object.html#charWrapper(scala.Char)"
* target="contentFrame"><code>Predef.charWrapper</code></a>.
* </p>
*/
final class RichChar(x: Char) extends Proxy with Ordered[Char] {
// Proxy.self
def self: Any = x
// Ordered[Char].compare
def compare (y: Char): Int = if (x < y) -1 else if (x > y) 1 else 0
def asDigit: Int = System.Char.GetNumericValue(x).toInt
def isControl: Boolean = System.Char.IsControl(x)
def isDigit: Boolean = System.Char.IsDigit(x)
def isLetter: Boolean = System.Char.IsLetter(x)
def isLetterOrDigit: Boolean = System.Char.IsLetterOrDigit(x)
def isLowerCase: Boolean = System.Char.IsLower(x)
def isUpperCase: Boolean = System.Char.IsUpper(x)
def isWhitespace: Boolean = System.Char.IsWhiteSpace(x)
def toLowerCase: Char = System.Char.ToLower(x)
def toUpperCase: Char = System.Char.ToUpper(x)
/** Create an Iterator[Char] over the characters from 'x' to 'y' - 1
*/
def until(limit: Char): Iterator[Char] = new Iterator[Char] {
private var ch = x
def hasNext: Boolean = ch < limit
def next: Char =
if (hasNext) { val j = ch; ch = (ch + 1).toChar; j }
else throw new NoSuchElementException("next on empty iterator")
}
//def until(y: Char): Iterator[Char] = to(y)
/** Create an Iterator[Char] over the characters from 'x' to 'y'
*/
def to(y: Char): Iterator[Char] = until((y + 1).toChar)
}
|