| /* |
| * Copyright (C) 2019 The Dagger Authors. |
| * |
| * 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 dagger.internal.codegen.kotlin; |
| |
| import static com.google.auto.common.MoreElements.isAnnotationPresent; |
| import static dagger.internal.codegen.langmodel.DaggerElements.closestEnclosingTypeElement; |
| |
| import dagger.internal.codegen.base.ClearableCache; |
| import java.util.HashMap; |
| import java.util.Map; |
| import javax.inject.Inject; |
| import javax.inject.Singleton; |
| import javax.lang.model.element.Element; |
| import javax.lang.model.element.TypeElement; |
| import kotlin.Metadata; |
| |
| /** |
| * Factory creating Kotlin metadata data objects. |
| * |
| * <p>The metadata is cache since it can be expensive to parse the information stored in a proto |
| * binary string format in the metadata annotation values. |
| */ |
| @Singleton |
| public final class KotlinMetadataFactory implements ClearableCache { |
| private final Map<TypeElement, KotlinMetadata> metadataCache = new HashMap<>(); |
| |
| @Inject |
| KotlinMetadataFactory() {} |
| |
| /** |
| * Parses and returns the {@link KotlinMetadata} out of a given element. |
| * |
| * @throws IllegalStateException if the element has no metadata or is not enclosed in a type |
| * element with metadata. To check if an element has metadata use {@link |
| * KotlinMetadataUtil#hasMetadata(Element)} |
| */ |
| public KotlinMetadata create(Element element) { |
| TypeElement enclosingElement = closestEnclosingTypeElement(element); |
| if (!isAnnotationPresent(enclosingElement, Metadata.class)) { |
| throw new IllegalStateException("Missing @Metadata for: " + enclosingElement); |
| } |
| return metadataCache.computeIfAbsent(enclosingElement, KotlinMetadata::from); |
| } |
| |
| @Override |
| public void clearCache() { |
| metadataCache.clear(); |
| } |
| } |