blob: 66541446ded08e4b7d11e23fdff0b60d46646287 [file] [log] [blame]
/*
* Copyright 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package androidx.room.processor
import androidx.room.parser.ParsedQuery
import androidx.room.parser.QueryType
import androidx.room.parser.SqlParser
import androidx.room.compiler.processing.XTypeElement
import androidx.room.vo.DatabaseView
class DatabaseViewProcessor(
baseContext: Context,
val element: XTypeElement,
private val referenceStack: LinkedHashSet<String> = LinkedHashSet()
) : EntityOrViewProcessor {
val context = baseContext.fork(element)
override fun process(): DatabaseView {
context.checker.hasAnnotation(element, androidx.room.DatabaseView::class,
ProcessorErrors.VIEW_MUST_BE_ANNOTATED_WITH_DATABASE_VIEW)
val annotationBox = element.toAnnotationBox(androidx.room.DatabaseView::class)
val viewName: String = if (annotationBox != null) {
extractViewName(element, annotationBox.value)
} else {
element.name
}
val query: ParsedQuery = if (annotationBox != null) {
SqlParser.parse(annotationBox.value.value).also {
context.checker.check(it.errors.isEmpty(), element,
it.errors.joinToString("\n"))
context.checker.check(it.type == QueryType.SELECT, element,
ProcessorErrors.VIEW_QUERY_MUST_BE_SELECT)
context.checker.check(it.bindSections.isEmpty(), element,
ProcessorErrors.VIEW_QUERY_CANNOT_TAKE_ARGUMENTS)
}
} else {
ParsedQuery.MISSING
}
context.checker.notBlank(viewName, element,
ProcessorErrors.VIEW_NAME_CANNOT_BE_EMPTY)
context.checker.check(!viewName.startsWith("sqlite_", true), element,
ProcessorErrors.VIEW_NAME_CANNOT_START_WITH_SQLITE)
val pojo = PojoProcessor.createFor(
context = context,
element = element,
bindingScope = FieldProcessor.BindingScope.READ_FROM_CURSOR,
parent = null,
referenceStack = referenceStack).process()
return DatabaseView(
element = element,
viewName = viewName,
query = query,
type = pojo.type,
fields = pojo.fields,
embeddedFields = pojo.embeddedFields,
constructor = pojo.constructor)
}
companion object {
fun extractViewName(
element: XTypeElement,
annotation: androidx.room.DatabaseView
): String {
return if (annotation.viewName == "") {
element.name
} else {
annotation.viewName
}
}
}
}