summaryrefslogtreecommitdiff
path: root/examples/scala-js/scalalib/overrides-2.10/scala
diff options
context:
space:
mode:
Diffstat (limited to 'examples/scala-js/scalalib/overrides-2.10/scala')
-rw-r--r--examples/scala-js/scalalib/overrides-2.10/scala/Console.scala468
-rw-r--r--examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/NumericRange.scala285
-rw-r--r--examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/Range.scala424
-rw-r--r--examples/scala-js/scalalib/overrides-2.10/scala/collection/mutable/Buffer.scala50
-rw-r--r--examples/scala-js/scalalib/overrides-2.10/scala/compat/Platform.scala133
-rw-r--r--examples/scala-js/scalalib/overrides-2.10/scala/package.scala138
6 files changed, 0 insertions, 1498 deletions
diff --git a/examples/scala-js/scalalib/overrides-2.10/scala/Console.scala b/examples/scala-js/scalalib/overrides-2.10/scala/Console.scala
deleted file mode 100644
index 7fc2d50..0000000
--- a/examples/scala-js/scalalib/overrides-2.10/scala/Console.scala
+++ /dev/null
@@ -1,468 +0,0 @@
-/* __ *\
-** ________ ___ / / ___ Scala API **
-** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
-** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
-** /____/\___/_/ |_/____/_/ | | **
-** |/ **
-\* */
-
-
-
-package scala
-
-import java.io.{BufferedReader, InputStream, InputStreamReader,
- IOException, OutputStream, PrintStream, Reader}
-import java.text.MessageFormat
-import scala.util.DynamicVariable
-
-
-/** Implements functionality for
- * printing Scala values on the terminal as well as reading specific values.
- * Also defines constants for marking up text on ANSI terminals.
- *
- * @author Matthias Zenger
- * @version 1.0, 03/09/2003
- */
-object Console {
-
- /** Foreground color for ANSI black */
- final val BLACK = "\033[30m"
- /** Foreground color for ANSI red */
- final val RED = "\033[31m"
- /** Foreground color for ANSI green */
- final val GREEN = "\033[32m"
- /** Foreground color for ANSI yellow */
- final val YELLOW = "\033[33m"
- /** Foreground color for ANSI blue */
- final val BLUE = "\033[34m"
- /** Foreground color for ANSI magenta */
- final val MAGENTA = "\033[35m"
- /** Foreground color for ANSI cyan */
- final val CYAN = "\033[36m"
- /** Foreground color for ANSI white */
- final val WHITE = "\033[37m"
-
- /** Background color for ANSI black */
- final val BLACK_B = "\033[40m"
- /** Background color for ANSI red */
- final val RED_B = "\033[41m"
- /** Background color for ANSI green */
- final val GREEN_B = "\033[42m"
- /** Background color for ANSI yellow */
- final val YELLOW_B = "\033[43m"
- /** Background color for ANSI blue */
- final val BLUE_B = "\033[44m"
- /** Background color for ANSI magenta */
- final val MAGENTA_B = "\033[45m"
- /** Background color for ANSI cyan */
- final val CYAN_B = "\033[46m"
- /** Background color for ANSI white */
- final val WHITE_B = "\033[47m"
-
- /** Reset ANSI styles */
- final val RESET = "\033[0m"
- /** ANSI bold */
- final val BOLD = "\033[1m"
- /** ANSI underlines */
- final val UNDERLINED = "\033[4m"
- /** ANSI blink */
- final val BLINK = "\033[5m"
- /** ANSI reversed */
- final val REVERSED = "\033[7m"
- /** ANSI invisible */
- final val INVISIBLE = "\033[8m"
-
- private val outVar = new DynamicVariable[PrintStream](java.lang.System.out)
- private val errVar = new DynamicVariable[PrintStream](java.lang.System.err)
- private val inVar = new DynamicVariable[BufferedReader](null)
- //new BufferedReader(new InputStreamReader(java.lang.System.in)))
-
- /** The default output, can be overridden by `setOut` */
- def out = outVar.value
- /** The default error, can be overridden by `setErr` */
- def err = errVar.value
- /** The default input, can be overridden by `setIn` */
- def in = inVar.value
-
- /** Sets the default output stream.
- *
- * @param out the new output stream.
- */
- def setOut(out: PrintStream) { outVar.value = out }
-
- /** Sets the default output stream for the duration
- * of execution of one thunk.
- *
- * @example {{{
- * withOut(Console.err) { println("This goes to default _error_") }
- * }}}
- *
- * @param out the new output stream.
- * @param thunk the code to execute with
- * the new output stream active
- * @return the results of `thunk`
- * @see `withOut[T](out:OutputStream)(thunk: => T)`
- */
- def withOut[T](out: PrintStream)(thunk: =>T): T =
- outVar.withValue(out)(thunk)
-
- /** Sets the default output stream.
- *
- * @param out the new output stream.
- */
- def setOut(out: OutputStream): Unit =
- setOut(new PrintStream(out))
-
- /** Sets the default output stream for the duration
- * of execution of one thunk.
- *
- * @param out the new output stream.
- * @param thunk the code to execute with
- * the new output stream active
- * @return the results of `thunk`
- * @see `withOut[T](out:PrintStream)(thunk: => T)`
- */
- def withOut[T](out: OutputStream)(thunk: =>T): T =
- withOut(new PrintStream(out))(thunk)
-
-
- /** Sets the default error stream.
- *
- * @param err the new error stream.
- */
- def setErr(err: PrintStream) { errVar.value = err }
-
- /** Set the default error stream for the duration
- * of execution of one thunk.
- * @example {{{
- * withErr(Console.out) { println("This goes to default _out_") }
- * }}}
- *
- * @param err the new error stream.
- * @param thunk the code to execute with
- * the new error stream active
- * @return the results of `thunk`
- * @see `withErr[T](err:OutputStream)(thunk: =>T)`
- */
- def withErr[T](err: PrintStream)(thunk: =>T): T =
- errVar.withValue(err)(thunk)
-
- /** Sets the default error stream.
- *
- * @param err the new error stream.
- */
- def setErr(err: OutputStream): Unit =
- setErr(new PrintStream(err))
-
- /** Sets the default error stream for the duration
- * of execution of one thunk.
- *
- * @param err the new error stream.
- * @param thunk the code to execute with
- * the new error stream active
- * @return the results of `thunk`
- * @see `withErr[T](err:PrintStream)(thunk: =>T)`
- */
- def withErr[T](err: OutputStream)(thunk: =>T): T =
- withErr(new PrintStream(err))(thunk)
-
-
- /** Sets the default input stream.
- *
- * @param reader specifies the new input stream.
- */
- def setIn(reader: Reader) {
- inVar.value = new BufferedReader(reader)
- }
-
- /** Sets the default input stream for the duration
- * of execution of one thunk.
- *
- * @example {{{
- * val someFile:Reader = openFile("file.txt")
- * withIn(someFile) {
- * // Reads a line from file.txt instead of default input
- * println(readLine)
- * }
- * }}}
- *
- * @param thunk the code to execute with
- * the new input stream active
- *
- * @return the results of `thunk`
- * @see `withIn[T](in:InputStream)(thunk: =>T)`
- */
- def withIn[T](reader: Reader)(thunk: =>T): T =
- inVar.withValue(new BufferedReader(reader))(thunk)
-
- /** Sets the default input stream.
- *
- * @param in the new input stream.
- */
- def setIn(in: InputStream) {
- setIn(new InputStreamReader(in))
- }
-
- /** Sets the default input stream for the duration
- * of execution of one thunk.
- *
- * @param in the new input stream.
- * @param thunk the code to execute with
- * the new input stream active
- * @return the results of `thunk`
- * @see `withIn[T](reader:Reader)(thunk: =>T)`
- */
- def withIn[T](in: InputStream)(thunk: =>T): T =
- withIn(new InputStreamReader(in))(thunk)
-
- /** Prints an object to `out` using its `toString` method.
- *
- * @param obj the object to print; may be null.
- */
- def print(obj: Any) {
- out.print(if (null == obj) "null" else obj.toString())
- }
-
- /** Flushes the output stream. This function is required when partial
- * output (i.e. output not terminated by a newline character) has
- * to be made visible on the terminal.
- */
- def flush() { out.flush() }
-
- /** Prints a newline character on the default output.
- */
- def println() { out.println() }
-
- /** Prints out an object to the default output, followed by a newline character.
- *
- * @param x the object to print.
- */
- def println(x: Any) { out.println(x) }
-
- /** Prints its arguments as a formatted string to the default output,
- * based on a string pattern (in a fashion similar to printf in C).
- *
- * The interpretation of the formatting patterns is described in
- * <a href="" target="contentFrame" class="java/util/Formatter">
- * `java.util.Formatter`</a>.
- *
- * @param text the pattern for formatting the arguments.
- * @param args the arguments used to instantiating the pattern.
- * @throws java.lang.IllegalArgumentException if there was a problem with the format string or arguments
- */
- def printf(text: String, args: Any*) { out.print(text format (args : _*)) }
-
- /** Read a full line from the default input. Returns `null` if the end of the
- * input stream has been reached.
- *
- * @return the string read from the terminal or null if the end of stream was reached.
- */
- def readLine(): String = in.readLine()
-
- /** Print formatted text to the default output and read a full line from the default input.
- * Returns `null` if the end of the input stream has been reached.
- *
- * @param text the format of the text to print out, as in `printf`.
- * @param args the parameters used to instantiate the format, as in `printf`.
- * @return the string read from the default input
- */
- def readLine(text: String, args: Any*): String = {
- printf(text, args: _*)
- readLine()
- }
-
- /** Reads a boolean value from an entire line of the default input.
- * Has a fairly liberal interpretation of the input.
- *
- * @return the boolean value read, or false if it couldn't be converted to a boolean
- * @throws java.io.EOFException if the end of the input stream has been reached.
- */
- def readBoolean(): Boolean = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toLowerCase() match {
- case "true" => true
- case "t" => true
- case "yes" => true
- case "y" => true
- case _ => false
- }
- }
-
- /** Reads a byte value from an entire line of the default input.
- *
- * @return the Byte that was read
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.NumberFormatException if the value couldn't be converted to a Byte
- */
- def readByte(): Byte = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toByte
- }
-
- /** Reads a short value from an entire line of the default input.
- *
- * @return the short that was read
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.NumberFormatException if the value couldn't be converted to a Short
- */
- def readShort(): Short = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toShort
- }
-
- /** Reads a char value from an entire line of the default input.
- *
- * @return the Char that was read
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.StringIndexOutOfBoundsException if the line read from default input was empty
- */
- def readChar(): Char = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s charAt 0
- }
-
- /** Reads an int value from an entire line of the default input.
- *
- * @return the Int that was read
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.NumberFormatException if the value couldn't be converted to an Int
- */
- def readInt(): Int = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toInt
- }
-
- /** Reads an long value from an entire line of the default input.
- *
- * @return the Long that was read
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.NumberFormatException if the value couldn't be converted to a Long
- */
- def readLong(): Long = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toLong
- }
-
- /** Reads a float value from an entire line of the default input.
- * @return the Float that was read.
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.NumberFormatException if the value couldn't be converted to a Float
- *
- */
- def readFloat(): Float = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toFloat
- }
-
- /** Reads a double value from an entire line of the default input.
- *
- * @return the Double that was read.
- * @throws java.io.EOFException if the end of the
- * input stream has been reached.
- * @throws java.lang.NumberFormatException if the value couldn't be converted to a Float
- */
- def readDouble(): Double = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- s.toDouble
- }
-
- /** Reads in some structured input (from the default input), specified by
- * a format specifier. See class `java.text.MessageFormat` for details of
- * the format specification.
- *
- * @param format the format of the input.
- * @return a list of all extracted values.
- * @throws java.io.EOFException if the end of the input stream has been
- * reached.
- */
- def readf(format: String): List[Any] = {
- val s = readLine()
- if (s == null)
- throw new java.io.EOFException("Console has reached end of input")
- else
- textComponents(new MessageFormat(format).parse(s))
- }
-
- /** Reads in some structured input (from the default input), specified by
- * a format specifier, returning only the first value extracted, according
- * to the format specification.
- *
- * @param format format string, as accepted by `readf`.
- * @return The first value that was extracted from the input
- */
- def readf1(format: String): Any = readf(format).head
-
- /** Reads in some structured input (from the default input), specified
- * by a format specifier, returning only the first two values extracted,
- * according to the format specification.
- *
- * @param format format string, as accepted by `readf`.
- * @return A [[scala.Tuple2]] containing the first two values extracted
- */
- def readf2(format: String): (Any, Any) = {
- val res = readf(format)
- (res.head, res.tail.head)
- }
-
- /** Reads in some structured input (from the default input), specified
- * by a format specifier, returning only the first three values extracted,
- * according to the format specification.
- *
- * @param format format string, as accepted by `readf`.
- * @return A [[scala.Tuple3]] containing the first three values extracted
- */
- def readf3(format: String): (Any, Any, Any) = {
- val res = readf(format)
- (res.head, res.tail.head, res.tail.tail.head)
- }
-
- private def textComponents(a: Array[AnyRef]): List[Any] = {
- var i: Int = a.length - 1
- var res: List[Any] = Nil
- while (i >= 0) {
- res = (a(i) match {
- case x: java.lang.Boolean => x.booleanValue()
- case x: java.lang.Byte => x.byteValue()
- case x: java.lang.Short => x.shortValue()
- case x: java.lang.Character => x.charValue()
- case x: java.lang.Integer => x.intValue()
- case x: java.lang.Long => x.longValue()
- case x: java.lang.Float => x.floatValue()
- case x: java.lang.Double => x.doubleValue()
- case x => x
- }) :: res;
- i -= 1
- }
- res
- }
-}
diff --git a/examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/NumericRange.scala b/examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/NumericRange.scala
deleted file mode 100644
index d3971ee..0000000
--- a/examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/NumericRange.scala
+++ /dev/null
@@ -1,285 +0,0 @@
-/* __ *\
-** ________ ___ / / ___ Scala API **
-** / __/ __// _ | / / / _ | (c) 2006-2013, LAMP/EPFL **
-** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
-** /____/\___/_/ |_/____/_/ | | **
-** |/ **
-\* */
-
-
-package scala.collection
-package immutable
-
-import mutable.{ Builder, ListBuffer }
-import generic._
-
-/** `NumericRange` is a more generic version of the
- * `Range` class which works with arbitrary types.
- * It must be supplied with an `Integral` implementation of the
- * range type.
- *
- * Factories for likely types include `Range.BigInt`, `Range.Long`,
- * and `Range.BigDecimal`. `Range.Int` exists for completeness, but
- * the `Int`-based `scala.Range` should be more performant.
- *
- * {{{
- * val r1 = new Range(0, 100, 1)
- * val veryBig = Int.MaxValue.toLong + 1
- * val r2 = Range.Long(veryBig, veryBig + 100, 1)
- * assert(r1 sameElements r2.map(_ - veryBig))
- * }}}
- *
- * TODO: Now the specialization exists there is no clear reason to have
- * separate classes for Range/NumericRange. Investigate and consolidate.
- *
- * @author Paul Phillips
- * @version 2.8
- * @define Coll `NumericRange`
- * @define coll numeric range
- * @define mayNotTerminateInf
- * @define willNotTerminateInf
- */
-abstract class NumericRange[T]
- (val start: T, val end: T, val step: T, val isInclusive: Boolean)
- (implicit num: Integral[T])
-extends AbstractSeq[T] with IndexedSeq[T] with Serializable {
- /** Note that NumericRange must be invariant so that constructs
- * such as "1L to 10 by 5" do not infer the range type as AnyVal.
- */
- import num._
-
- // See comment in Range for why this must be lazy.
- private lazy val numRangeElements: Int =
- NumericRange.count(start, end, step, isInclusive)
-
- override def length = numRangeElements
- override def isEmpty = length == 0
- override lazy val last: T =
- if (length == 0) Nil.last
- else locationAfterN(length - 1)
-
- /** Create a new range with the start and end values of this range and
- * a new `step`.
- */
- def by(newStep: T): NumericRange[T] = copy(start, end, newStep)
-
- /** Create a copy of this range.
- */
- def copy(start: T, end: T, step: T): NumericRange[T]
-
- override def foreach[U](f: T => U) {
- var count = 0
- var current = start
- while (count < length) {
- f(current)
- current += step
- count += 1
- }
- }
-
- // TODO: these private methods are straight copies from Range, duplicated
- // to guard against any (most likely illusory) performance drop. They should
- // be eliminated one way or another.
-
- // Counts how many elements from the start meet the given test.
- private def skipCount(p: T => Boolean): Int = {
- var current = start
- var counted = 0
-
- while (counted < length && p(current)) {
- counted += 1
- current += step
- }
- counted
- }
- // Tests whether a number is within the endpoints, without testing
- // whether it is a member of the sequence (i.e. when step > 1.)
- private def isWithinBoundaries(elem: T) = !isEmpty && (
- (step > zero && start <= elem && elem <= last ) ||
- (step < zero && last <= elem && elem <= start)
- )
- // Methods like apply throw exceptions on invalid n, but methods like take/drop
- // are forgiving: therefore the checks are with the methods.
- private def locationAfterN(n: Int): T = start + (step * fromInt(n))
-
- // When one drops everything. Can't ever have unchecked operations
- // like "end + 1" or "end - 1" because ranges involving Int.{ MinValue, MaxValue }
- // will overflow. This creates an exclusive range where start == end
- // based on the given value.
- private def newEmptyRange(value: T) = NumericRange(value, value, step)
-
- final override def take(n: Int): NumericRange[T] = (
- if (n <= 0 || length == 0) newEmptyRange(start)
- else if (n >= length) this
- else new NumericRange.Inclusive(start, locationAfterN(n - 1), step)
- )
-
- final override def drop(n: Int): NumericRange[T] = (
- if (n <= 0 || length == 0) this
- else if (n >= length) newEmptyRange(end)
- else copy(locationAfterN(n), end, step)
- )
-
- def apply(idx: Int): T = {
- if (idx < 0 || idx >= length) throw new IndexOutOfBoundsException(idx.toString)
- else locationAfterN(idx)
- }
-
- import NumericRange.defaultOrdering
-
- override def min[T1 >: T](implicit ord: Ordering[T1]): T =
- if (ord eq defaultOrdering(num)) {
- if (num.signum(step) > 0) start
- else last
- } else super.min(ord)
-
- override def max[T1 >: T](implicit ord: Ordering[T1]): T =
- if (ord eq defaultOrdering(num)) {
- if (num.signum(step) > 0) last
- else start
- } else super.max(ord)
-
- // Motivated by the desire for Double ranges with BigDecimal precision,
- // we need some way to map a Range and get another Range. This can't be
- // done in any fully general way because Ranges are not arbitrary
- // sequences but step-valued, so we have a custom method only we can call
- // which we promise to use responsibly.
- //
- // The point of it all is that
- //
- // 0.0 to 1.0 by 0.1
- //
- // should result in
- //
- // NumericRange[Double](0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0)
- //
- // and not
- //
- // NumericRange[Double](0.0, 0.1, 0.2, 0.30000000000000004, 0.4, 0.5, 0.6000000000000001, 0.7000000000000001, 0.8, 0.9)
- //
- // or perhaps more importantly,
- //
- // (0.1 to 0.3 by 0.1 contains 0.3) == true
- //
- private[immutable] def mapRange[A](fm: T => A)(implicit unum: Integral[A]): NumericRange[A] = {
- val self = this
-
- // XXX This may be incomplete.
- new NumericRange[A](fm(start), fm(end), fm(step), isInclusive) {
- def copy(start: A, end: A, step: A): NumericRange[A] =
- if (isInclusive) NumericRange.inclusive(start, end, step)
- else NumericRange(start, end, step)
-
- private lazy val underlyingRange: NumericRange[T] = self
- override def foreach[U](f: A => U) { underlyingRange foreach (x => f(fm(x))) }
- override def isEmpty = underlyingRange.isEmpty
- override def apply(idx: Int): A = fm(underlyingRange(idx))
- override def containsTyped(el: A) = underlyingRange exists (x => fm(x) == el)
- }
- }
-
- // a well-typed contains method.
- def containsTyped(x: T): Boolean =
- isWithinBoundaries(x) && (((x - start) % step) == zero)
-
- override def contains(x: Any): Boolean =
- try containsTyped(x.asInstanceOf[T])
- catch { case _: ClassCastException => false }
-
- final override def sum[B >: T](implicit num: Numeric[B]): B = {
- import num.Ops
- if (isEmpty) this.num fromInt 0
- else if (numRangeElements == 1) head
- else ((this.num fromInt numRangeElements) * (head + last) / (this.num fromInt 2))
- }
-
- override lazy val hashCode = super.hashCode()
- override def equals(other: Any) = other match {
- case x: NumericRange[_] =>
- (x canEqual this) && (length == x.length) && (
- (length == 0) || // all empty sequences are equal
- (start == x.start && last == x.last) // same length and same endpoints implies equality
- )
- case _ =>
- super.equals(other)
- }
-
- override def toString() = {
- val endStr = if (length > Range.MAX_PRINT) ", ... )" else ")"
- take(Range.MAX_PRINT).mkString("NumericRange(", ", ", endStr)
- }
-}
-
-/** A companion object for numeric ranges.
- */
-object NumericRange {
-
- /** Calculates the number of elements in a range given start, end, step, and
- * whether or not it is inclusive. Throws an exception if step == 0 or
- * the number of elements exceeds the maximum Int.
- */
- def count[T](start: T, end: T, step: T, isInclusive: Boolean)(implicit num: Integral[T]): Int = {
- val zero = num.zero
- val upward = num.lt(start, end)
- val posStep = num.gt(step, zero)
-
- if (step == zero) throw new IllegalArgumentException("step cannot be 0.")
- else if (start == end) if (isInclusive) 1 else 0
- else if (upward != posStep) 0
- else {
- val diff = num.minus(end, start)
- val jumps = num.toLong(num.quot(diff, step))
- val remainder = num.rem(diff, step)
- val longCount = jumps + (
- if (!isInclusive && zero == remainder) 0 else 1
- )
-
- /** The edge cases keep coming. Since e.g.
- * Long.MaxValue + 1 == Long.MinValue
- * we do some more improbable seeming checks lest
- * overflow turn up as an empty range.
- */
- // The second condition contradicts an empty result.
- val isOverflow = longCount == 0 && num.lt(num.plus(start, step), end) == upward
-
- if (longCount > scala.Int.MaxValue || longCount < 0L || isOverflow) {
- val word = if (isInclusive) "to" else "until"
- val descr = List(start, word, end, "by", step) mkString " "
-
- throw new IllegalArgumentException(descr + ": seqs cannot contain more than Int.MaxValue elements.")
- }
- longCount.toInt
- }
- }
-
- class Inclusive[T](start: T, end: T, step: T)(implicit num: Integral[T])
- extends NumericRange(start, end, step, true) {
- def copy(start: T, end: T, step: T): Inclusive[T] =
- NumericRange.inclusive(start, end, step)
-
- def exclusive: Exclusive[T] = NumericRange(start, end, step)
- }
-
- class Exclusive[T](start: T, end: T, step: T)(implicit num: Integral[T])
- extends NumericRange(start, end, step, false) {
- def copy(start: T, end: T, step: T): Exclusive[T] =
- NumericRange(start, end, step)
-
- def inclusive: Inclusive[T] = NumericRange.inclusive(start, end, step)
- }
-
- def apply[T](start: T, end: T, step: T)(implicit num: Integral[T]): Exclusive[T] =
- new Exclusive(start, end, step)
- def inclusive[T](start: T, end: T, step: T)(implicit num: Integral[T]): Inclusive[T] =
- new Inclusive(start, end, step)
-
- private[collection] val defaultOrdering = Map[Numeric[_], Ordering[_]](
- Numeric.IntIsIntegral -> Ordering.Int,
- Numeric.ShortIsIntegral -> Ordering.Short,
- Numeric.ByteIsIntegral -> Ordering.Byte,
- Numeric.CharIsIntegral -> Ordering.Char,
- Numeric.LongIsIntegral -> Ordering.Long
- )
-
-}
-
diff --git a/examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/Range.scala b/examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/Range.scala
deleted file mode 100644
index 5c8758d..0000000
--- a/examples/scala-js/scalalib/overrides-2.10/scala/collection/immutable/Range.scala
+++ /dev/null
@@ -1,424 +0,0 @@
-/* __ *\
-** ________ ___ / / ___ Scala API **
-** / __/ __// _ | / / / _ | (c) 2006-2013, LAMP/EPFL **
-** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
-** /____/\___/_/ |_/____/_/ | | **
-** |/ **
-\* */
-
-
-package scala.collection.immutable
-
-import scala.collection.parallel.immutable.ParRange
-
-/** The `Range` class represents integer values in range
- * ''[start;end)'' with non-zero step value `step`.
- * It's a special case of an indexed sequence.
- * For example:
- *
- * {{{
- * val r1 = 0 until 10
- * val r2 = r1.start until r1.end by r1.step + 1
- * println(r2.length) // = 5
- * }}}
- *
- * @param start the start of this range.
- * @param end the exclusive end of the range.
- * @param step the step for the range.
- *
- * @author Martin Odersky
- * @author Paul Phillips
- * @version 2.8
- * @since 2.5
- * @see [[http://docs.scala-lang.org/overviews/collections/concrete-immutable-collection-classes.html#ranges "Scala's Collection Library overview"]]
- * section on `Ranges` for more information.
- *
- * @define coll range
- * @define mayNotTerminateInf
- * @define willNotTerminateInf
- * @define doesNotUseBuilders
- * '''Note:''' this method does not use builders to construct a new range,
- * and its complexity is O(1).
- */
-@SerialVersionUID(7618862778670199309L)
-@inline
-class Range(val start: Int, val end: Int, val step: Int)
-extends scala.collection.AbstractSeq[Int]
- with IndexedSeq[Int]
- with scala.collection.CustomParallelizable[Int, ParRange]
- with Serializable
-{
- override def par = new ParRange(this)
-
- private def gap = end.toLong - start.toLong
- private def isExact = gap % step == 0
- private def hasStub = isInclusive || !isExact
- private def longLength = gap / step + ( if (hasStub) 1 else 0 )
-
- // Check cannot be evaluated eagerly because we have a pattern where
- // ranges are constructed like: "x to y by z" The "x to y" piece
- // should not trigger an exception. So the calculation is delayed,
- // which means it will not fail fast for those cases where failing was
- // correct.
- override final val isEmpty = (
- (start > end && step > 0)
- || (start < end && step < 0)
- || (start == end && !isInclusive)
- )
- final val numRangeElements: Int = {
- if (step == 0) throw new IllegalArgumentException("step cannot be 0.")
- else if (isEmpty) 0
- else {
- val len = longLength
- if (len > scala.Int.MaxValue) -1
- else len.toInt
- }
- }
- final val lastElement = start + (numRangeElements - 1) * step
- final val terminalElement = start + numRangeElements * step
-
- override def last = if (isEmpty) Nil.last else lastElement
-
- override def min[A1 >: Int](implicit ord: Ordering[A1]): Int =
- if (ord eq Ordering.Int) {
- if (step > 0) start
- else last
- } else super.min(ord)
-
- override def max[A1 >: Int](implicit ord: Ordering[A1]): Int =
- if (ord eq Ordering.Int) {
- if (step > 0) last
- else start
- } else super.max(ord)
-
- protected def copy(start: Int, end: Int, step: Int): Range = new Range(start, end, step)
-
- /** Create a new range with the `start` and `end` values of this range and
- * a new `step`.
- *
- * @return a new range with a different step
- */
- def by(step: Int): Range = copy(start, end, step)
-
- def isInclusive = false
-
- override def size = length
- override def length = if (numRangeElements < 0) fail() else numRangeElements
-
- private def fail() = Range.fail(start, end, step, isInclusive)
- private def validateMaxLength() {
- if (numRangeElements < 0)
- fail()
- }
-
- def validateRangeBoundaries(f: Int => Any): Boolean = {
- validateMaxLength()
-
- start != Int.MinValue || end != Int.MinValue || {
- var count = 0
- var num = start
- while (count < numRangeElements) {
- f(num)
- count += 1
- num += step
- }
- false
- }
- }
-
- final def apply(idx: Int): Int = {
- validateMaxLength()
- if (idx < 0 || idx >= numRangeElements) throw new IndexOutOfBoundsException(idx.toString)
- else start + (step * idx)
- }
-
- @inline final override def foreach[@specialized(Unit) U](f: Int => U) {
- validateMaxLength()
- val isCommonCase = (start != Int.MinValue || end != Int.MinValue)
- var i = start
- var count = 0
- val terminal = terminalElement
- val step = this.step
- while(
- if(isCommonCase) { i != terminal }
- else { count < numRangeElements }
- ) {
- f(i)
- count += 1
- i += step
- }
- }
-
- /** Creates a new range containing the first `n` elements of this range.
- *
- * $doesNotUseBuilders
- *
- * @param n the number of elements to take.
- * @return a new range consisting of `n` first elements.
- */
- final override def take(n: Int): Range = (
- if (n <= 0 || isEmpty) newEmptyRange(start)
- else if (n >= numRangeElements) this
- else new Range.Inclusive(start, locationAfterN(n - 1), step)
- )
-
- /** Creates a new range containing all the elements of this range except the first `n` elements.
- *
- * $doesNotUseBuilders
- *
- * @param n the number of elements to drop.
- * @return a new range consisting of all the elements of this range except `n` first elements.
- */
- final override def drop(n: Int): Range = (
- if (n <= 0 || isEmpty) this
- else if (n >= numRangeElements) newEmptyRange(end)
- else copy(locationAfterN(n), end, step)
- )
-
- /** Creates a new range containing all the elements of this range except the last one.
- *
- * $doesNotUseBuilders
- *
- * @return a new range consisting of all the elements of this range except the last one.
- */
- final override def init: Range = {
- if (isEmpty)
- Nil.init
-
- dropRight(1)
- }
-
- /** Creates a new range containing all the elements of this range except the first one.
- *
- * $doesNotUseBuilders
- *
- * @return a new range consisting of all the elements of this range except the first one.
- */
- final override def tail: Range = {
- if (isEmpty)
- Nil.tail
-
- drop(1)
- }
-
- // Counts how many elements from the start meet the given test.
- private def skipCount(p: Int => Boolean): Int = {
- var current = start
- var counted = 0
-
- while (counted < numRangeElements && p(current)) {
- counted += 1
- current += step
- }
- counted
- }
- // Tests whether a number is within the endpoints, without testing
- // whether it is a member of the sequence (i.e. when step > 1.)
- private def isWithinBoundaries(elem: Int) = !isEmpty && (
- (step > 0 && start <= elem && elem <= last ) ||
- (step < 0 && last <= elem && elem <= start)
- )
- // Methods like apply throw exceptions on invalid n, but methods like take/drop
- // are forgiving: therefore the checks are with the methods.
- private def locationAfterN(n: Int) = start + (step * n)
-
- // When one drops everything. Can't ever have unchecked operations
- // like "end + 1" or "end - 1" because ranges involving Int.{ MinValue, MaxValue }
- // will overflow. This creates an exclusive range where start == end
- // based on the given value.
- private def newEmptyRange(value: Int) = new Range(value, value, step)
-
- final override def takeWhile(p: Int => Boolean): Range = take(skipCount(p))
- final override def dropWhile(p: Int => Boolean): Range = drop(skipCount(p))
- final override def span(p: Int => Boolean): (Range, Range) = splitAt(skipCount(p))
-
- /** Creates a pair of new ranges, first consisting of elements before `n`, and the second
- * of elements after `n`.
- *
- * $doesNotUseBuilders
- */
- final override def splitAt(n: Int) = (take(n), drop(n))
-
- /** Creates a new range consisting of the `length - n` last elements of the range.
- *
- * $doesNotUseBuilders
- */
- final override def takeRight(n: Int): Range = drop(numRangeElements - n)
-
- /** Creates a new range consisting of the initial `length - n` elements of the range.
- *
- * $doesNotUseBuilders
- */
- final override def dropRight(n: Int): Range = take(numRangeElements - n)
-
- /** Returns the reverse of this range.
- *
- * $doesNotUseBuilders
- */
- final override def reverse: Range =
- if (isEmpty) this
- else new Range.Inclusive(last, start, -step)
-
- /** Make range inclusive.
- */
- def inclusive =
- if (isInclusive) this
- else new Range.Inclusive(start, end, step)
-
- final def contains(x: Int) = isWithinBoundaries(x) && ((x - start) % step == 0)
-
- final override def sum[B >: Int](implicit num: Numeric[B]): Int = {
- if (isEmpty) 0
- else if (numRangeElements == 1) head
- else (numRangeElements.toLong * (head + last) / 2).toInt
- }
-
- override def toIterable = this
-
- override def toSeq = this
-
- override def equals(other: Any) = other match {
- case x: Range =>
- (x canEqual this) && (length == x.length) && (
- isEmpty || // all empty sequences are equal
- (start == x.start && last == x.last) // same length and same endpoints implies equality
- )
- case _ =>
- super.equals(other)
- }
- /** Note: hashCode can't be overridden without breaking Seq's
- * equals contract.
- */
-
- override def toString() = {
- val endStr = if (numRangeElements > Range.MAX_PRINT) ", ... )" else ")"
- take(Range.MAX_PRINT).mkString("Range(", ", ", endStr)
- }
-}
-
-/** A companion object for the `Range` class.
- */
-object Range {
- private[immutable] val MAX_PRINT = 512 // some arbitrary value
-
- private def description(start: Int, end: Int, step: Int, isInclusive: Boolean) =
- "%d %s %d by %s".format(start, if (isInclusive) "to" else "until", end, step)
-
- private def fail(start: Int, end: Int, step: Int, isInclusive: Boolean) =
- throw new IllegalArgumentException(description(start, end, step, isInclusive) +
- ": seqs cannot contain more than Int.MaxValue elements.")
-
- /** Counts the number of range elements.
- * @pre step != 0
- * If the size of the range exceeds Int.MaxValue, the
- * result will be negative.
- */
- def count(start: Int, end: Int, step: Int, isInclusive: Boolean): Int = {
- if (step == 0)
- throw new IllegalArgumentException("step cannot be 0.")
-
- val isEmpty = (
- if (start == end) !isInclusive
- else if (start < end) step < 0
- else step > 0
- )
- if (isEmpty) 0
- else {
- // Counts with Longs so we can recognize too-large ranges.
- val gap: Long = end.toLong - start.toLong
- val jumps: Long = gap / step
- // Whether the size of this range is one larger than the
- // number of full-sized jumps.
- val hasStub = isInclusive || (gap % step != 0)
- val result: Long = jumps + ( if (hasStub) 1 else 0 )
-
- if (result > scala.Int.MaxValue) -1
- else result.toInt
- }
- }
- def count(start: Int, end: Int, step: Int): Int =
- count(start, end, step, false)
-
- @inline
- class Inclusive(start: Int, end: Int, step: Int) extends Range(start, end, step) {
-// override def par = new ParRange(this)
- override def isInclusive = true
- override protected def copy(start: Int, end: Int, step: Int): Range = new Inclusive(start, end, step)
- }
-
- /** Make a range from `start` until `end` (exclusive) with given step value.
- * @note step != 0
- */
- def apply(start: Int, end: Int, step: Int): Range = new Range(start, end, step)
-
- /** Make a range from `start` until `end` (exclusive) with step value 1.
- */
- def apply(start: Int, end: Int): Range = new Range(start, end, 1)
-
- /** Make an inclusive range from `start` to `end` with given step value.
- * @note step != 0
- */
- def inclusive(start: Int, end: Int, step: Int): Range.Inclusive = new Inclusive(start, end, step)
-
- /** Make an inclusive range from `start` to `end` with step value 1.
- */
- def inclusive(start: Int, end: Int): Range.Inclusive = new Inclusive(start, end, 1)
-
- // BigInt and Long are straightforward generic ranges.
- object BigInt {
- def apply(start: BigInt, end: BigInt, step: BigInt) = NumericRange(start, end, step)
- def inclusive(start: BigInt, end: BigInt, step: BigInt) = NumericRange.inclusive(start, end, step)
- }
-
- object Long {
- def apply(start: Long, end: Long, step: Long) = NumericRange(start, end, step)
- def inclusive(start: Long, end: Long, step: Long) = NumericRange.inclusive(start, end, step)
- }
-
- // BigDecimal uses an alternative implementation of Numeric in which
- // it pretends to be Integral[T] instead of Fractional[T]. See Numeric for
- // details. The intention is for it to throw an exception anytime
- // imprecision or surprises might result from anything, although this may
- // not yet be fully implemented.
- object BigDecimal {
- implicit val bigDecAsIntegral = scala.math.Numeric.BigDecimalAsIfIntegral
-
- def apply(start: BigDecimal, end: BigDecimal, step: BigDecimal) =
- NumericRange(start, end, step)
- def inclusive(start: BigDecimal, end: BigDecimal, step: BigDecimal) =
- NumericRange.inclusive(start, end, step)
- }
-
- // Double works by using a BigDecimal under the hood for precise
- // stepping, but mapping the sequence values back to doubles with
- // .doubleValue. This constructs the BigDecimals by way of the
- // String constructor (valueOf) instead of the Double one, which
- // is necessary to keep 0.3d at 0.3 as opposed to
- // 0.299999999999999988897769753748434595763683319091796875 or so.
- object Double {
- implicit val bigDecAsIntegral = scala.math.Numeric.BigDecimalAsIfIntegral
- implicit val doubleAsIntegral = scala.math.Numeric.DoubleAsIfIntegral
- def toBD(x: Double): BigDecimal = scala.math.BigDecimal valueOf x
-
- def apply(start: Double, end: Double, step: Double) =
- BigDecimal(toBD(start), toBD(end), toBD(step)) mapRange (_.doubleValue)
-
- def inclusive(start: Double, end: Double, step: Double) =
- BigDecimal.inclusive(toBD(start), toBD(end), toBD(step)) mapRange (_.doubleValue)
- }
-
- // As there is no appealing default step size for not-really-integral ranges,
- // we offer a partially constructed object.
- class Partial[T, U](f: T => U) {
- def by(x: T): U = f(x)
- }
-
- // Illustrating genericity with Int Range, which should have the same behavior
- // as the original Range class. However we leave the original Range
- // indefinitely, for performance and because the compiler seems to bootstrap
- // off it and won't do so with our parameterized version without modifications.
- object Int {
- def apply(start: Int, end: Int, step: Int) = NumericRange(start, end, step)
- def inclusive(start: Int, end: Int, step: Int) = NumericRange.inclusive(start, end, step)
- }
-}
diff --git a/examples/scala-js/scalalib/overrides-2.10/scala/collection/mutable/Buffer.scala b/examples/scala-js/scalalib/overrides-2.10/scala/collection/mutable/Buffer.scala
deleted file mode 100644
index ec7763b..0000000
--- a/examples/scala-js/scalalib/overrides-2.10/scala/collection/mutable/Buffer.scala
+++ /dev/null
@@ -1,50 +0,0 @@
-/* __ *\
-** ________ ___ / / ___ Scala API **
-** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
-** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
-** /____/\___/_/ |_/____/_/ | | **
-** |/ **
-\* */
-
-
-
-package scala.collection
-package mutable
-
-import generic._
-
-import scala.scalajs.js
-
-/** Buffers are used to create sequences of elements incrementally by
- * appending, prepending, or inserting new elements. It is also
- * possible to access and modify elements in a random access fashion
- * via the index of the element in the current sequence.
- *
- * @author Matthias Zenger
- * @author Martin Odersky
- * @version 2.8
- * @since 1
- *
- * @tparam A type of the elements contained in this buffer.
- *
- * @define Coll `Buffer`
- * @define coll buffer
- */
-trait Buffer[A] extends Seq[A]
- with GenericTraversableTemplate[A, Buffer]
- with BufferLike[A, Buffer[A]]
- with scala.Cloneable {
- override def companion: GenericCompanion[Buffer] = Buffer
-}
-
-/** $factoryInfo
- * @define coll buffer
- * @define Coll `Buffer`
- */
-object Buffer extends SeqFactory[Buffer] {
- implicit def canBuildFrom[A]: CanBuildFrom[Coll, A, Buffer[A]] = ReusableCBF.asInstanceOf[GenericCanBuildFrom[A]]
- def newBuilder[A]: Builder[A, Buffer[A]] = new js.WrappedArray
-}
-
-/** Explicit instantiation of the `Buffer` trait to reduce class file size in subclasses. */
-private[scala] abstract class AbstractBuffer[A] extends AbstractSeq[A] with Buffer[A]
diff --git a/examples/scala-js/scalalib/overrides-2.10/scala/compat/Platform.scala b/examples/scala-js/scalalib/overrides-2.10/scala/compat/Platform.scala
deleted file mode 100644
index 77bf7de..0000000
--- a/examples/scala-js/scalalib/overrides-2.10/scala/compat/Platform.scala
+++ /dev/null
@@ -1,133 +0,0 @@
-/* __ *\
-** ________ ___ / / ___ Scala API **
-** / __/ __// _ | / / / _ | (c) 2002-2013, LAMP/EPFL **
-** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
-** /____/\___/_/ |_/____/_/ | | **
-** |/ **
-\* */
-
-
-
-package scala.compat
-
-import java.lang.System
-
-object Platform {
-
- /** Thrown when a stack overflow occurs because a method or function recurses too deeply.
- *
- * On the JVM, this is a type alias for `java.lang.StackOverflowError`, which itself extends `java.lang.Error`.
- * The same rules apply to catching a `java.lang.Error` as for Java, that it indicates a serious problem that a reasonable application should not try and catch.
- */
- type StackOverflowError = java.lang.StackOverflowError
-
- /** This is a type alias for `java.util.ConcurrentModificationException`,
- * which may be thrown by methods that detect an invalid modification of an object.
- * For example, many common collection types do not allow modifying a collection
- * while it is being iterated over.
- */
- type ConcurrentModificationException = java.util.ConcurrentModificationException
-
- /** Copies `length` elements of array `src` starting at position `srcPos` to the
- * array `dest` starting at position `destPos`. If `src`==`dest`, the copying will
- * behave as if the elements copied from `src` were first copied to a temporary
- * array before being copied back into the array at the destination positions.
- *
- * @param src A non-null array as source for the copy.
- * @param srcPos The starting index in the source array.
- * @param dest A non-null array as destination for the copy.
- * @param destPos The starting index in the destination array.
- * @param length The number of elements to be copied.
- * @throws java.lang.NullPointerException If either `src` or `dest` are `null`.
- * @throws java.lang.ArrayStoreException If either `src` or `dest` are not of type
- * [java.lang.Array]; or if the element type of `src` is not
- * compatible with that of `dest`.
- * @throws java.lang.IndexOutOfBoundsException If either srcPos` or `destPos` are
- * outside of the bounds of their respective arrays; or if `length`
- * is negative; or if there are less than `length` elements available
- * after `srcPos` or `destPos` in `src` and `dest` respectively.
- */
- @inline
- def arraycopy(src: AnyRef, srcPos: Int, dest: AnyRef, destPos: Int, length: Int) {
- System.arraycopy(src, srcPos, dest, destPos, length)
- }
-
- /** Creates a new array of the specified type and given length.
- *
- * Note that if `elemClass` is a subclass of [[scala.AnyVal]] then the returned value is an Array of the corresponding java primitive type.
- * For example, the following code `scala.compat.Platform.createArray(classOf[Int], 4)` returns an array of the java primitive type `int`.
- *
- * For a [[scala.AnyVal]] array, the values of the array are set to 0 for ''numeric value types'' ([[scala.Double]], [[scala.Float]], [[scala.Long]], [[scala.Int]], [[scala.Char]],
- * [[scala.Short]], and [[scala.Byte]]), and `false` for [[scala.Boolean]]. Creation of an array of type [[scala.Unit]] is not possible.
- *
- * For subclasses of [[scala.AnyRef]], the values of the array are set to `null`.
- *
- * The caller must cast the returned value to the correct type.
- *
- * @example {{{
- * val a = scala.compat.Platform.createArray(classOf[Int], 4).asInstanceOf[Array[Int]] // returns Array[Int](0, 0, 0, 0)
- * }}}
- *
- * @param elemClass the `Class` object of the component type of the array
- * @param length the length of the new array.
- * @return an array of the given component type as an `AnyRef`.
- * @throws `java.lang.NullPointerException` If `elemClass` is `null`.
- * @throws `java.lang.IllegalArgumentException` if componentType is [[scala.Unit]] or `java.lang.Void.TYPE`
- * @throws `java.lang.NegativeArraySizeException` if the specified length is negative
- */
- @inline
- def createArray(elemClass: Class[_], length: Int): AnyRef =
- java.lang.reflect.Array.newInstance(elemClass, length)
-
- /** Assigns the value of 0 to each element in the array.
- * @param arr A non-null Array[Int].
- * @throws `java.lang.NullPointerException` If `arr` is `null`.
- */
- @inline
- def arrayclear(arr: Array[Int]) { java.util.Arrays.fill(arr, 0) }
-
- /** Returns the `Class` object associated with the class or interface with the given string name using the current `ClassLoader`.
- * On the JVM, invoking this method is equivalent to: `java.lang.Class.forName(name)`
- *
- * For more information, please see the Java documentation for [[java.lang.Class]].
- *
- * @param name the fully qualified name of the desired class.
- * @return the `Class` object for the class with the specified name.
- * @throws `java.lang.LinkageError` if the linkage fails
- * @throws `java.lang.ExceptionInInitializerError` if the initialization provoked by this method fails
- * @throws `java.lang.ClassNotFoundException` if the class cannot be located
- * @example {{{
- * val a = scala.compat.Platform.getClassForName("java.lang.Integer") // returns the Class[_] for java.lang.Integer
- * }}}
- */
- @inline
- def getClassForName(name: String): Class[_] = java.lang.Class.forName(name)
-
- /** The default line separator.
- *
- * On the JavaScript backend, this is always "\n".
- */
- val EOL = "\n"
-
- /** The current time in milliseconds. The time is counted since 1 January 1970
- * UTC.
- *
- * Note that the operating system timer used to obtain this value may be less
- * precise than a millisecond.
- */
- @inline
- def currentTime: Long = System.currentTimeMillis()
-
- /** Runs the garbage collector.
- *
- * This is a request that the underlying JVM runs the garbage collector.
- * The results of this call depends heavily on the JVM used.
- * The underlying JVM is free to ignore this request.
- */
- @inline
- def collectGarbage(): Unit = System.gc()
-
- /** The name of the default character set encoding as a string */
- @inline
- def defaultCharsetName: String = java.nio.charset.Charset.defaultCharset.name
-}
diff --git a/examples/scala-js/scalalib/overrides-2.10/scala/package.scala b/examples/scala-js/scalalib/overrides-2.10/scala/package.scala
deleted file mode 100644
index 5aad9a9..0000000
--- a/examples/scala-js/scalalib/overrides-2.10/scala/package.scala
+++ /dev/null
@@ -1,138 +0,0 @@
-/* __ *\
-** ________ ___ / / ___ Scala API **
-** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
-** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
-** /____/\___/_/ |_/____/_/ | | **
-** |/ **
-\* */
-
-
-/**
- * Core Scala types. They are always available without an explicit import.
- * @contentDiagram hideNodes "scala.Serializable"
- */
-package object scala {
- type Throwable = java.lang.Throwable
- type Exception = java.lang.Exception
- type Error = java.lang.Error
-
- type RuntimeException = java.lang.RuntimeException
- type NullPointerException = java.lang.NullPointerException
- type ClassCastException = java.lang.ClassCastException
- type IndexOutOfBoundsException = java.lang.IndexOutOfBoundsException
- type ArrayIndexOutOfBoundsException = java.lang.ArrayIndexOutOfBoundsException
- type StringIndexOutOfBoundsException = java.lang.StringIndexOutOfBoundsException
- type UnsupportedOperationException = java.lang.UnsupportedOperationException
- type IllegalArgumentException = java.lang.IllegalArgumentException
- type NoSuchElementException = java.util.NoSuchElementException
- type NumberFormatException = java.lang.NumberFormatException
- type AbstractMethodError = java.lang.AbstractMethodError
- type InterruptedException = java.lang.InterruptedException
-
- // A dummy used by the specialization annotation.
- val AnyRef = new Specializable {
- override def toString = "object AnyRef"
- }
-
- @deprecated("instead of `@serializable class C`, use `class C extends Serializable`", "2.9.0")
- type serializable = annotation.serializable
-
- @deprecated("instead of `@cloneable class C`, use `class C extends Cloneable`", "2.10.0")
- type cloneable = annotation.cloneable
-
- type TraversableOnce[+A] = scala.collection.TraversableOnce[A]
-
- type Traversable[+A] = scala.collection.Traversable[A]
- val Traversable = scala.collection.Traversable
-
- type Iterable[+A] = scala.collection.Iterable[A]
- val Iterable = scala.collection.Iterable
-
- type Seq[+A] = scala.collection.Seq[A]
- val Seq = scala.collection.Seq
-
- type IndexedSeq[+A] = scala.collection.IndexedSeq[A]
- val IndexedSeq = scala.collection.IndexedSeq
-
- type Iterator[+A] = scala.collection.Iterator[A]
- val Iterator = scala.collection.Iterator
-
- type BufferedIterator[+A] = scala.collection.BufferedIterator[A]
-
- type List[+A] = scala.collection.immutable.List[A]
- val List = scala.collection.immutable.List
-
- val Nil = scala.collection.immutable.Nil
-
- type ::[A] = scala.collection.immutable.::[A]
- val :: = scala.collection.immutable.::
-
- val +: = scala.collection.+:
- val :+ = scala.collection.:+
-
- type Stream[+A] = scala.collection.immutable.Stream[A]
- val Stream = scala.collection.immutable.Stream
- val #:: = scala.collection.immutable.Stream.#::
-
- type Vector[+A] = scala.collection.immutable.Vector[A]
- val Vector = scala.collection.immutable.Vector
-
- type StringBuilder = scala.collection.mutable.StringBuilder
- val StringBuilder = scala.collection.mutable.StringBuilder
-
- type Range = scala.collection.immutable.Range
- val Range = scala.collection.immutable.Range
-
- // Numeric types which were moved into scala.math.*
-
- type BigDecimal = scala.math.BigDecimal
- lazy val BigDecimal = scala.math.BigDecimal
-
- type BigInt = scala.math.BigInt
- lazy val BigInt = scala.math.BigInt
-
- type Equiv[T] = scala.math.Equiv[T]
- val Equiv = scala.math.Equiv
-
- type Fractional[T] = scala.math.Fractional[T]
- type Integral[T] = scala.math.Integral[T]
-
- type Numeric[T] = scala.math.Numeric[T]
- val Numeric = scala.math.Numeric
-
- type Ordered[T] = scala.math.Ordered[T]
- val Ordered = scala.math.Ordered
-
- type Ordering[T] = scala.math.Ordering[T]
- val Ordering = scala.math.Ordering
-
- type PartialOrdering[T] = scala.math.PartialOrdering[T]
- type PartiallyOrdered[T] = scala.math.PartiallyOrdered[T]
-
- type Either[+A, +B] = scala.util.Either[A, B]
- val Either = scala.util.Either
-
- type Left[+A, +B] = scala.util.Left[A, B]
- val Left = scala.util.Left
-
- type Right[+A, +B] = scala.util.Right[A, B]
- val Right = scala.util.Right
-
- // Annotations which we might move to annotation.*
-/*
- type SerialVersionUID = annotation.SerialVersionUID
- type cloneable = annotation.cloneable
- type deprecated = annotation.deprecated
- type deprecatedName = annotation.deprecatedName
- type inline = annotation.inline
- type native = annotation.native
- type noinline = noannotation.inline
- type remote = annotation.remote
- type serializable = annotation.serializable
- type specialized = annotation.specialized
- type transient = annotation.transient
- type throws = annotation.throws
- type unchecked = annotation.unchecked.unchecked
- type volatile = annotation.volatile
- */
-}