All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dagger.internal.codegen.binding.DependencyRequestFormatter Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2014 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.binding;

import static androidx.room.compiler.processing.XElementKt.isMethod;
import static androidx.room.compiler.processing.XElementKt.isTypeElement;
import static androidx.room.compiler.processing.XElementKt.isVariableElement;
import static dagger.internal.codegen.base.ElementFormatter.elementToString;
import static dagger.internal.codegen.base.RequestKinds.requestType;

import androidx.room.compiler.processing.XElement;
import androidx.room.compiler.processing.XProcessingEnv;
import com.google.errorprone.annotations.CanIgnoreReturnValue;
import dagger.internal.codegen.base.Formatter;
import dagger.internal.codegen.model.DaggerAnnotation;
import dagger.internal.codegen.model.DependencyRequest;
import dagger.internal.codegen.xprocessing.XTypes;
import java.util.Optional;
import javax.inject.Inject;

/**
 * Formats a {@link DependencyRequest} into a {@link String} suitable for an error message listing a
 * chain of dependencies.
 *
 * 
*
For component provision methods *
{@code @Qualifier SomeType is provided at\n ComponentType.method()} *
For component injection methods *
{@code SomeType is injected at\n ComponentType.method(foo)} *
For parameters to {@code @Provides}, {@code @Produces}, or {@code @Inject} methods: *
{@code @Qualified ResolvedType is injected at\n EnclosingType.method([…, ]param[, …])} *
For parameters to {@link Inject @Inject} constructors: *
{@code @Qualified ResolvedType is injected at\n EnclosingType([…, ]param[, …])} *
For {@link Inject @Inject} fields: *
{@code @Qualified ResolvedType is injected at\n EnclosingType.field} *
*/ public final class DependencyRequestFormatter extends Formatter { private final XProcessingEnv processingEnv; @Inject DependencyRequestFormatter(XProcessingEnv processingEnv) { this.processingEnv = processingEnv; } @Override public String format(DependencyRequest request) { if (!request.requestElement().isPresent()) { return ""; } XElement requestElement = request.requestElement().get().xprocessing(); if (isMethod(requestElement)) { return INDENT + request.key() + " is " + componentMethodRequestVerb(request) + " at\n" + DOUBLE_INDENT + elementToString(requestElement); } else if (isVariableElement(requestElement)) { return INDENT + formatQualifier(request.key().qualifier()) + XTypes.toStableString( requestType(request.kind(), request.key().type().xprocessing(), processingEnv)) + " is injected at\n" + DOUBLE_INDENT + elementToString(requestElement); } else if (isTypeElement(requestElement)) { return ""; // types by themselves provide no useful information. } else { throw new IllegalStateException("Invalid request element " + requestElement); } } /** * Appends a newline and the formatted dependency request unless {@link * #format(DependencyRequest)} returns the empty string. */ @CanIgnoreReturnValue public StringBuilder appendFormatLine( StringBuilder builder, DependencyRequest dependencyRequest) { String formatted = format(dependencyRequest); if (!formatted.isEmpty()) { builder.append('\n').append(formatted); } return builder; } private String formatQualifier(Optional maybeQualifier) { return maybeQualifier.map(qualifier -> qualifier + " ").orElse(""); } /** * Returns the verb for a component method dependency request. Returns "produced", "provided", or * "injected", depending on the kind of request. */ private String componentMethodRequestVerb(DependencyRequest request) { switch (request.kind()) { case FUTURE: case PRODUCER: case INSTANCE: case LAZY: case PROVIDER: case PROVIDER_OF_LAZY: return "requested"; case MEMBERS_INJECTION: return "injected"; case PRODUCED: break; } throw new AssertionError("illegal request kind for method: " + request); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy