diff options
author | Haoyi Li <haoyi@haoyi-mbp.corp.dropbox.com> | 2014-11-26 00:45:31 -0800 |
---|---|---|
committer | Haoyi Li <haoyi@haoyi-mbp.corp.dropbox.com> | 2014-11-26 00:45:31 -0800 |
commit | 2c4b142503bd2d871e6818b5cab8c38627d9e4a0 (patch) | |
tree | 6ba33d2980a1a7a1286100202a695c6631bd240e /ir/src/main/scala/scala/scalajs/ir/ClassKind.scala | |
download | hands-on-scala-js-2c4b142503bd2d871e6818b5cab8c38627d9e4a0.tar.gz hands-on-scala-js-2c4b142503bd2d871e6818b5cab8c38627d9e4a0.tar.bz2 hands-on-scala-js-2c4b142503bd2d871e6818b5cab8c38627d9e4a0.zip |
Squashed 'examples/scala-js/' content from commit 47311ba
git-subtree-dir: examples/scala-js
git-subtree-split: 47311ba693f949f204f27ea9475bb63425fbd4f3
Diffstat (limited to 'ir/src/main/scala/scala/scalajs/ir/ClassKind.scala')
-rw-r--r-- | ir/src/main/scala/scala/scalajs/ir/ClassKind.scala | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/ir/src/main/scala/scala/scalajs/ir/ClassKind.scala b/ir/src/main/scala/scala/scalajs/ir/ClassKind.scala new file mode 100644 index 0000000..5092d2c --- /dev/null +++ b/ir/src/main/scala/scala/scalajs/ir/ClassKind.scala @@ -0,0 +1,53 @@ +/* __ *\ +** ________ ___ / / ___ __ ____ Scala.js IR ** +** / __/ __// _ | / / / _ | __ / // __/ (c) 2014, LAMP/EPFL ** +** __\ \/ /__/ __ |/ /__/ __ |/_// /_\ \ http://scala-js.org/ ** +** /____/\___/_/ |_/____/_/ | |__/ /____/ ** +** |/____/ ** +\* */ + + +package scala.scalajs.ir + +import scala.annotation.switch + +sealed abstract class ClassKind { + import ClassKind._ + + def isClass = this match { + case Class | ModuleClass => true + case _ => false + } + + def isType = this match { + case TraitImpl => false + case _ => true + } +} + +object ClassKind { + case object Class extends ClassKind + case object ModuleClass extends ClassKind + case object Interface extends ClassKind + case object RawJSType extends ClassKind + case object HijackedClass extends ClassKind + case object TraitImpl extends ClassKind + + private[ir] def toByte(kind: ClassKind): Byte = kind match { + case ClassKind.Class => 1 + case ClassKind.ModuleClass => 2 + case ClassKind.Interface => 3 + case ClassKind.RawJSType => 4 + case ClassKind.HijackedClass => 5 + case ClassKind.TraitImpl => 6 + } + + private[ir] def fromByte(b: Byte): ClassKind = (b: @switch) match { + case 1 => ClassKind.Class + case 2 => ClassKind.ModuleClass + case 3 => ClassKind.Interface + case 4 => ClassKind.RawJSType + case 5 => ClassKind.HijackedClass + case 6 => ClassKind.TraitImpl + } +} |