У меня есть абстрактный класс Java с именем ImmutableEntity
и несколько подклассов, которые содержат аннотацию на уровне класса с именем @DBTable
.Я пытаюсь найти иерархию классов для аннотации, используя хвостовой рекурсивный метод Scala:
def getDbTableForClass[A <: ImmutableEntity](cls: Class[A]): String = {
@tailrec
def getDbTableAnnotation[B >: A](cls: Class[B]): DBTable = {
if (cls == null) {
null
} else {
val dbTable = cls.getAnnotation(classOf[DBTable])
if (dbTable != null) {
dbTable
} else {
getDbTableAnnotation(cls.getSuperclass)
}
}
}
val dbTable = getDbTableAnnotation(cls)
if (dbTable == null) {
throw new
IllegalArgumentException("No DBTable annotation on class " + cls.getName)
} else {
val value = dbTable.value
if (value != null) {
value
} else {
throw new
IllegalArgumentException("No DBTable.value annotation on class " + cls.getName)
}
}
}
Когда я компилирую этот код, я получаю сообщение об ошибке: «не удалось оптимизировать аннотированный метод @tailrec: этовызывается рекурсивно с аргументами разных типов ".Что не так с моим внутренним методом?
Спасибо.