summaryrefslogtreecommitdiff
path: root/examples/scala-js/javalib/src/main/scala/java/util/concurrent
diff options
context:
space:
mode:
Diffstat (limited to 'examples/scala-js/javalib/src/main/scala/java/util/concurrent')
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/ExecutionException.scala9
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/Executor.scala5
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/TimeUnit.scala133
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicBoolean.scala33
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicInteger.scala63
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicLong.scala61
-rw-r--r--examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicReference.scala34
7 files changed, 338 insertions, 0 deletions
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/ExecutionException.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/ExecutionException.scala
new file mode 100644
index 0000000..6d04889
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/ExecutionException.scala
@@ -0,0 +1,9 @@
+package java.util.concurrent
+
+class ExecutionException(message: String, cause: Throwable)
+ extends Exception(message, cause) {
+
+ protected def this() = this(null, null)
+ protected def this(message: String) = this(message, null)
+ def this(cause: Throwable) = this(null, cause)
+}
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/Executor.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/Executor.scala
new file mode 100644
index 0000000..d030551
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/Executor.scala
@@ -0,0 +1,5 @@
+package java.util.concurrent
+
+trait Executor {
+ def execute(command: Runnable): Unit
+}
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/TimeUnit.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/TimeUnit.scala
new file mode 100644
index 0000000..a77dbfc
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/TimeUnit.scala
@@ -0,0 +1,133 @@
+package java.util.concurrent
+
+abstract class TimeUnit private (_index: Int,
+ _name: String) extends java.io.Serializable {
+
+ def convert(a: Long, u: TimeUnit): Long
+
+ def toNanos(a: Long): Long
+ def toMicros(a: Long): Long
+ def toMillis(a: Long): Long
+ def toSeconds(a: Long): Long
+ def toMinutes(a: Long): Long
+ def toHours(a: Long): Long
+ def toDays(a: Long): Long
+
+ // not used
+ //private[concurrent] def excessNanos(a: Long, b: Long): Int
+
+ def name(): String = _name
+ def ordinal(): Int = _index
+
+ // methods that cannot be implemented
+ //def timedWait(arg1: AnyRef, arg2: Long): Unit
+ //def timedJoin(arg1: Thread, arg2: Long): Unit
+ //def sleep(arg1: Long): Unit
+
+ override def toString() = name()
+}
+
+object TimeUnit {
+ final val NANOSECONDS: TimeUnit = new TimeUnit(0, "NANOSECONDS") {
+ def convert(a: Long, u: TimeUnit): Long = u.toNanos(a)
+ def toNanos(a: Long): Long = a
+ def toMicros(a: Long): Long = a / (C1/C0)
+ def toMillis(a: Long): Long = a / (C2/C0)
+ def toSeconds(a: Long): Long = a / (C3/C0)
+ def toMinutes(a: Long): Long = a / (C4/C0)
+ def toHours(a: Long): Long = a / (C5/C0)
+ def toDays(a: Long): Long = a / (C6/C0)
+ }
+
+ final val MICROSECONDS: TimeUnit = new TimeUnit(1, "MICROSECONDS") {
+ def convert(a: Long, u: TimeUnit): Long = u.toMicros(a)
+ def toNanos(a: Long): Long = x(a, C1/C0, MAX/(C1/C0))
+ def toMicros(a: Long): Long = a
+ def toMillis(a: Long): Long = a / (C2/C1)
+ def toSeconds(a: Long): Long = a / (C3/C1)
+ def toMinutes(a: Long): Long = a / (C4/C1)
+ def toHours(a: Long): Long = a / (C5/C1)
+ def toDays(a: Long): Long = a / (C6/C1)
+ }
+
+ final val MILLISECONDS: TimeUnit = new TimeUnit(2, "MILLISECONDS") {
+ def convert(a: Long, u: TimeUnit): Long = u.toMillis(a)
+ def toNanos(a: Long): Long = x(a, C2/C0, MAX/(C2/C0))
+ def toMicros(a: Long): Long = x(a, C2/C1, MAX/(C2/C1))
+ def toMillis(a: Long): Long = a
+ def toSeconds(a: Long): Long = a / (C3/C2)
+ def toMinutes(a: Long): Long = a / (C4/C2)
+ def toHours(a: Long): Long = a / (C5/C2)
+ def toDays(a: Long): Long = a / (C6/C2)
+ }
+
+ final val SECONDS: TimeUnit = new TimeUnit(3, "SECONDS") {
+ def convert(a: Long, u: TimeUnit): Long = u.toSeconds(a)
+ def toNanos(a: Long): Long = x(a, C3/C0, MAX/(C3/C0))
+ def toMicros(a: Long): Long = x(a, C3/C1, MAX/(C3/C1))
+ def toMillis(a: Long): Long = x(a, C3/C2, MAX/(C3/C2))
+ def toSeconds(a: Long): Long = a
+ def toMinutes(a: Long): Long = a / (C4/C3)
+ def toHours(a: Long): Long = a / (C5/C3)
+ def toDays(a: Long): Long = a / (C6/C3)
+ }
+
+ final val MINUTES: TimeUnit = new TimeUnit(4, "MINUTES") {
+ def convert(a: Long, u: TimeUnit): Long = u.toMinutes(a)
+ def toNanos(a: Long): Long = x(a, C4/C0, MAX/(C4/C0))
+ def toMicros(a: Long): Long = x(a, C4/C1, MAX/(C4/C1))
+ def toMillis(a: Long): Long = x(a, C4/C2, MAX/(C4/C2))
+ def toSeconds(a: Long): Long = x(a, C4/C3, MAX/(C4/C3))
+ def toMinutes(a: Long): Long = a
+ def toHours(a: Long): Long = a / (C5/C4)
+ def toDays(a: Long): Long = a / (C6/C4)
+ }
+
+ final val HOURS: TimeUnit = new TimeUnit(5, "HOURS") {
+ def convert(a: Long, u: TimeUnit): Long = u.toHours(a)
+ def toNanos(a: Long): Long = x(a, C5/C0, MAX/(C5/C0))
+ def toMicros(a: Long): Long = x(a, C5/C1, MAX/(C5/C1))
+ def toMillis(a: Long): Long = x(a, C5/C2, MAX/(C5/C2))
+ def toSeconds(a: Long): Long = x(a, C5/C3, MAX/(C5/C3))
+ def toMinutes(a: Long): Long = x(a, C5/C4, MAX/(C5/C4))
+ def toHours(a: Long): Long = a
+ def toDays(a: Long): Long = a / (C6/C5)
+ }
+
+ final val DAYS: TimeUnit = new TimeUnit(6, "DAYS") {
+ def convert(a: Long, u: TimeUnit): Long = u.toDays(a)
+ def toNanos(a: Long): Long = x(a, C6/C0, MAX/(C6/C0))
+ def toMicros(a: Long): Long = x(a, C6/C1, MAX/(C6/C1))
+ def toMillis(a: Long): Long = x(a, C6/C2, MAX/(C6/C2))
+ def toSeconds(a: Long): Long = x(a, C6/C3, MAX/(C6/C3))
+ def toMinutes(a: Long): Long = x(a, C6/C4, MAX/(C6/C4))
+ def toHours(a: Long): Long = x(a, C6/C5, MAX/(C6/C5))
+ def toDays(a: Long): Long = a
+ }
+
+ private[this] val _values: Array[TimeUnit] =
+ Array(NANOSECONDS, MICROSECONDS, MILLISECONDS, SECONDS, MINUTES, HOURS, DAYS)
+
+ // deliberately without type ascription to make them compile-time constants
+ private final val C0 = 1L
+ private final val C1 = C0 * 1000L
+ private final val C2 = C1 * 1000L
+ private final val C3 = C2 * 1000L
+ private final val C4 = C3 * 60L
+ private final val C5 = C4 * 60L
+ private final val C6 = C5 * 24L
+ private final val MAX = Long.MaxValue
+
+ def values(): Array[TimeUnit] = _values.clone()
+
+ def valueOf(name: String): TimeUnit = {
+ _values.find(_.name == name).getOrElse(
+ throw new IllegalArgumentException("No enum const TimeUnit." + name))
+ }
+
+ private def x(a: Long, b: Long, max: Long): Long = {
+ if (a > max) MAX
+ else if (a < -max) -MAX
+ else a * b
+ }
+}
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicBoolean.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicBoolean.scala
new file mode 100644
index 0000000..5675c31
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicBoolean.scala
@@ -0,0 +1,33 @@
+package java.util.concurrent.atomic
+
+class AtomicBoolean(private[this] var value: Boolean) extends Serializable {
+ def this() = this(false)
+
+ final def get(): Boolean = value
+
+ final def compareAndSet(expect: Boolean, update: Boolean): Boolean = {
+ if (expect != value) false else {
+ value = update
+ true
+ }
+ }
+
+ // For some reason, this method is not final
+ def weakCompareAndSet(expect: Boolean, update: Boolean): Boolean =
+ compareAndSet(expect, update)
+
+ final def set(newValue: Boolean): Unit =
+ value = newValue
+
+ final def lazySet(newValue: Boolean): Unit =
+ set(newValue)
+
+ final def getAndSet(newValue: Boolean): Boolean = {
+ val old = value
+ value = newValue
+ old
+ }
+
+ override def toString(): String =
+ value.toString()
+}
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicInteger.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicInteger.scala
new file mode 100644
index 0000000..1f24b7b
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicInteger.scala
@@ -0,0 +1,63 @@
+package java.util.concurrent.atomic
+
+class AtomicInteger(private[this] var value: Int)
+ extends Number with Serializable {
+
+ def this() = this(0)
+
+ final def get(): Int = value
+
+ final def set(newValue: Int): Unit =
+ value = newValue
+
+ final def lazySet(newValue: Int): Unit =
+ set(newValue)
+
+ final def getAndSet(newValue: Int): Int = {
+ val old = value
+ value = newValue
+ old
+ }
+
+ final def compareAndSet(expect: Int, update: Int): Boolean = {
+ if (expect != value) false else {
+ value = update
+ true
+ }
+ }
+
+ final def weakCompareAndSet(expect: Int, update: Int): Boolean =
+ compareAndSet(expect, update)
+
+ final def getAndIncrement(): Int =
+ getAndAdd(1)
+
+ final def getAndDecrement(): Int =
+ getAndAdd(-1)
+
+ @inline final def getAndAdd(delta: Int): Int = {
+ val old = value
+ value = old + delta
+ old
+ }
+
+ final def incrementAndGet(): Int =
+ addAndGet(1)
+
+ final def decrementAndGet(): Int =
+ addAndGet(-1)
+
+ @inline final def addAndGet(delta: Int): Int = {
+ val newValue = value + delta
+ value = newValue
+ newValue
+ }
+
+ override def toString(): String =
+ value.toString()
+
+ def intValue(): Int = value
+ def longValue(): Long = value.toLong
+ def floatValue(): Float = value.toFloat
+ def doubleValue(): Double = value.toDouble
+}
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicLong.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicLong.scala
new file mode 100644
index 0000000..5bfecf2
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicLong.scala
@@ -0,0 +1,61 @@
+package java.util.concurrent.atomic
+
+class AtomicLong(private[this] var value: Long) extends Number with Serializable {
+ def this() = this(0L)
+
+ final def get(): Long = value
+
+ final def set(newValue: Long): Unit =
+ value = newValue
+
+ final def lazySet(newValue: Long): Unit =
+ set(newValue)
+
+ final def getAndSet(newValue: Long): Long = {
+ val old = value
+ value = newValue
+ old
+ }
+
+ final def compareAndSet(expect: Long, update: Long): Boolean = {
+ if (expect != value) false else {
+ value = update
+ true
+ }
+ }
+
+ final def weakCompareAndSet(expect: Long, update: Long): Boolean =
+ compareAndSet(expect, update)
+
+ final def getAndIncrement(): Long =
+ getAndAdd(1L)
+
+ final def getAndDecrement(): Long =
+ getAndAdd(-1L)
+
+ @inline final def getAndAdd(delta: Long): Long = {
+ val old = value
+ value = old + delta
+ old
+ }
+
+ final def incrementAndGet(): Long =
+ addAndGet(1L)
+
+ final def decrementAndGet(): Long =
+ addAndGet(-1L)
+
+ @inline final def addAndGet(delta: Long): Long = {
+ val newValue = value + delta
+ value = newValue
+ newValue
+ }
+
+ override def toString(): String =
+ value.toString()
+
+ def intValue(): Int = value.toInt
+ def longValue(): Long = value
+ def floatValue(): Float = value.toFloat
+ def doubleValue(): Double = value.toDouble
+}
diff --git a/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicReference.scala b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicReference.scala
new file mode 100644
index 0000000..650b1e0
--- /dev/null
+++ b/examples/scala-js/javalib/src/main/scala/java/util/concurrent/atomic/AtomicReference.scala
@@ -0,0 +1,34 @@
+package java.util.concurrent.atomic
+
+class AtomicReference[T <: AnyRef](
+ private[this] var value: T) extends Serializable {
+
+ def this() = this(null.asInstanceOf[T])
+
+ final def get(): T = value
+
+ final def set(newValue: T): Unit =
+ value = newValue
+
+ final def lazySet(newValue: T): Unit =
+ set(newValue)
+
+ final def compareAndSet(expect: T, update: T): Boolean = {
+ if (expect ne value) false else {
+ value = update
+ true
+ }
+ }
+
+ final def weakCompareAndSet(expect: T, update: T): Boolean =
+ compareAndSet(expect, update)
+
+ final def getAndSet(newValue: T): T = {
+ val old = value
+ value = newValue
+ old
+ }
+
+ override def toString(): String =
+ String.valueOf(value)
+}