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

ch.powerunit.extensions.matchers.provideprocessor.ProvidesMatchersAnnotatedElementGenericMirror Maven / Gradle / Ivy

Go to download

This is a test framework for the JDK 1.8 - Extension to provide matchers based on annotation. - Factory Support

There is a newer version: 0.1.6
Show newest version
/**
 * Powerunit - A JDK1.8 test framework
 * Copyright (C) 2014 Mathieu Boretti.
 *
 * This file is part of Powerunit
 *
 * Powerunit is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * Powerunit is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Powerunit. If not, see .
 */
package ch.powerunit.extensions.matchers.provideprocessor;

import static java.util.stream.Collectors.collectingAndThen;
import static java.util.stream.Collectors.joining;

import javax.lang.model.element.TypeElement;

public abstract class ProvidesMatchersAnnotatedElementGenericMirror
		extends ProvidesMatchersAnnotatedElementJavadocMirror {

	protected final String generic;
	protected final String fullGeneric;
	protected final String simpleNameOfGeneratedInterfaceMatcher;
	protected final String genericForChaining;

	public ProvidesMatchersAnnotatedElementGenericMirror(TypeElement typeElement, RoundMirror roundMirror) {
		super(typeElement, roundMirror);
		this.generic = parseGeneric(typeElement);
		this.fullGeneric = parseFullGeneric(typeElement);
		this.simpleNameOfGeneratedInterfaceMatcher = simpleNameOfClassAnnotatedWithProvideMatcher + "Matcher";
		this.genericForChaining = getGenericParent().replaceAll("^<_PARENT",
				"<" + getFullyQualifiedNameOfGeneratedClass() + "." + simpleNameOfGeneratedInterfaceMatcher
						+ getGenericNoParent());
	}

	private static String parseFullGeneric(TypeElement typeElement) {
		return typeElement.getTypeParameters().stream()
				.map(t -> t.toString() + " extends "
						+ t.getBounds().stream().map(b -> b.toString()).collect(joining("&")))
				.collect(collectingAndThen(joining(","), r -> r.isEmpty() ? "" : ("<" + r + ">")));
	}

	private static String parseGeneric(TypeElement typeElement) {
		return typeElement.getTypeParameters().stream().map(t -> t.toString())
				.collect(collectingAndThen(joining(","), r -> r.isEmpty() ? "" : ("<" + r + ">")));
	}

	public String getSimpleNameOfGeneratedInterfaceMatcherWithGenericParent() {
		return simpleNameOfGeneratedInterfaceMatcher + " " + getGenericParent();
	}

	public String getSimpleNameOfGeneratedInterfaceMatcherWithGenericNoParent() {
		return simpleNameOfGeneratedInterfaceMatcher + " " + getGenericNoParent();
	}

	public String getFullyQualifiedNameOfClassAnnotatedWithProvideMatcherWithGeneric() {
		return fullyQualifiedNameOfClassAnnotatedWithProvideMatcher + " " + generic;
	}

	public static String getAddParentToGeneric(String generic) {
		if ("".equals(generic)) {
			return "<_PARENT>";
		} else {
			return generic.replaceFirst("<", "<_PARENT,");
		}
	}

	public static String getAddNoParentToGeneric(String generic) {
		if ("".equals(generic)) {
			return "";
		} else {
			return generic.replaceFirst("<", "




© 2015 - 2024 Weber Informatics LLC | Privacy Policy