Проблема компилятора Scala 2.8.0.RC2 в операторе сопоставления с образцом? - PullRequest
4 голосов
/ 24 мая 2010

Почему следующий модуль не компилируется в Scala 2.8.RC [1,2]?

object Test {

import util.matching.Regex._

val pVoid = """\s*void\s*""".r
val pVoidPtr = """\s*(const\s+)?void\s*\*\s*""".r
val pCharPtr = """\s*(const\s+)GLchar\s*\*\s*""".r
val pIntPtr = """\s*(const\s+)?GLint\s*\*\s*""".r
val pUintPtr = """\s*(const\s+)?GLuint\s*\*\s*""".r
val pFloatPtr = """\s*(const\s+)?GLfloat\s*\*\s*""".r
val pDoublePtr = """\s*(const\s+)?GLdouble\s*\*\s*""".r
val pShortPtr = """\s*(const\s+)?GLshort\s*\*\s*""".r
val pUshortPtr = """\s*(const\s+)?GLushort\s*\*\s*""".r
val pInt64Ptr = """\s*(const\s+)?GLint64\s*\*\s*""".r
val pUint64Ptr = """\s*(const\s+)?GLuint64\s*\*\s*""".r

def mapType(t: String): String = t.trim match {
  case pVoid() => "Unit"
  case pVoidPtr() => "ByteBuffer"
  case pCharPtr() => "CharBuffer"
  case pIntPtr() | pUintPtr() => "IntBuffer"
  case pFloatPtr() => "FloatBuffer"
  case pShortPtr() | pUshortPtr() => "ShortBuffer"
  case pDoublePtr() => "DoubleBuffer"
  case pInt64Ptr() | pUint64Ptr() => "LongBuffer"
  case x => x
}
}

ОБНОВЛЕНИЕ 1

После следования советам вответ, следующая проблема заключается в том, что компиляция длится слишком долго.Интересно, что если я удаляю 2 из приведенных выше операторов case, я получаю следующую ошибку компилятора:

object Test {

    import util.matching.Regex._

    val PVoid = """\s*void\s*""".r
    val PVoidPtr = """\s*(const\s+)?void\s*\*\s*""".r
    val PCharPtr = """\s*(const\s+)GLchar\s*\*\s*""".r
    val PIntPtr = """\s*(const\s+)?GLint\s*\*\s*""".r
    val PUintPtr = """\s*(const\s+)?GLuint\s*\*\s*""".r
    val PFloatPtr = """\s*(const\s+)?GLfloat\s*\*\s*""".r
    val PDoublePtr = """\s*(const\s+)?GLdouble\s*\*\s*""".r
    val PShortPtr = """\s*(const\s+)?GLshort\s*\*\s*""".r
    val PUshortPtr = """\s*(const\s+)?GLushort\s*\*\s*""".r
    val PInt64Ptr = """\s*(const\s+)?GLint64\s*\*\s*""".r
    val PUint64Ptr = """\s*(const\s+)?GLuint64\s*\*\s*""".r

    def mapType(t: String): String = t.trim match {
      case PVoid() => "Unit"
      case PVoidPtr() => "ByteBuffer"
      case PCharPtr() => "CharBuffer"
      case PIntPtr() | PUintPtr() => "IntBuffer"
      case PFloatPtr() => "FloatBuffer"
      case PShortPtr() | PUshortPtr() => "ShortBuffer"
      case PDoublePtr() => "DoubleBuffer"
      case PInt64Ptr() | PUint64Ptr() => "LongBuffer"
      case x => x
    }
}


Exception in thread "main" java.lang.Error:ch.epfl.lamp.fjbg.JCode$OffsetTooBigException: offset too big to fit in 16 bits: 43772
at ch.epfl.lamp.fjbg.JFieldOrMethod.writeTo(JFieldOrMethod.java:114)
at ch.epfl.lamp.fjbg.JClass.writeTo(JClass.java:315)

1 Ответ

3 голосов
/ 24 мая 2010

Вы пытаетесь использовать util.matching.Regex в качестве шаблона экстрактора. Вы можете сделать это, потому что этот класс определяет метод unapplySeq. При сопоставлении с образцом ссылки на шаблоны извлечения должны начинаться с заглавной буквы.

val PVoid = """\s*void\s*""".r

def mapType(t: String): String = t.trim match {
  case PVoid() => "Unit"
  case x => x
}

UPDATE

Вот полная скомпилированная версия вашего кода:

object Test {

    import util.matching.Regex._

    val PVoid = """\s*void\s*""".r
    val PVoidPtr = """\s*(const\s+)?void\s*\*\s*""".r
    val PCharPtr = """\s*(const\s+)GLchar\s*\*\s*""".r
    val PIntPtr = """\s*(const\s+)?GLint\s*\*\s*""".r
    val PUintPtr = """\s*(const\s+)?GLuint\s*\*\s*""".r
    val PFloatPtr = """\s*(const\s+)?GLfloat\s*\*\s*""".r
    val PDoublePtr = """\s*(const\s+)?GLdouble\s*\*\s*""".r
    val PShortPtr = """\s*(const\s+)?GLshort\s*\*\s*""".r
    val PUshortPtr = """\s*(const\s+)?GLushort\s*\*\s*""".r
    val PInt64Ptr = """\s*(const\s+)?GLint64\s*\*\s*""".r
    val PUint64Ptr = """\s*(const\s+)?GLuint64\s*\*\s*""".r

    def mapType(t: String): String = t.trim match {
      case PVoid() => "Unit"
      case PVoidPtr() => "ByteBuffer"
      case PCharPtr() => "CharBuffer"
      case PIntPtr() | PUintPtr() => "IntBuffer"
      case x => x match {
        case PFloatPtr() => "FloatBuffer"
        case PShortPtr() | PUshortPtr() => "ShortBuffer"
        case PDoublePtr() => "DoubleBuffer"
        case PInt64Ptr() | PUint64Ptr() => "LongBuffer"
        case x => x
      }
    }
}

Сопоставление шаблона разбито на полпути к ошибке обхода # 1113 .

...