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

org.mapfish.print.parser.RequiresTracker Maven / Gradle / Ivy

package org.mapfish.print.parser;

import com.google.common.collect.HashMultimap;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.google.common.collect.Multimap;
import com.vividsolutions.jts.util.Assert;

import java.lang.reflect.Field;
import java.util.Collection;
import java.util.Map;

/**
 * Keeps track of the attributes that require other dependencies and verifies they are all satisfied at the end
 * of the json parsing.
 *
 * @author Jesse on 4/10/2014.
 */
class RequiresTracker {
    private Multimap dependantToRequirementsMap = HashMultimap.create();
    private Map requirementToDependantMap = Maps.newHashMap();
    private Collection dependantsInJson = Lists.newArrayList();
    /**
     * Check if field has the {@link org.mapfish.print.parser.Requires} annotation and registers it and its requirement.
     * @param field the field to inspect
     */
    public void register(final Field field) {
        Requires requires = field.getAnnotation(Requires.class);
        if (requires != null) {
            final String[] requirements = requires.value();
            for (String requirement : requirements) {
                this.dependantToRequirementsMap.put(field, requirement);
                this.requirementToDependantMap.put(requirement, field);
            }

        }
    }


    /**
     * Check if a field is part of a {@link org.mapfish.print.parser.Requires} relationship and mark the requirement as satisfied
     * for the given field.
     *
     * @param field the field that is done.
     */
    public void markAsVisited(final Field field) {
        if (field.getAnnotation(Requires.class) != null) {
            this.dependantsInJson.add(field);
        }

        final Field dependant = this.requirementToDependantMap.get(field.getName());
        if (dependant != null) {
            this.dependantToRequirementsMap.remove(dependant, field.getName());
        }
    }


    /**
     * Check that each requirement is satisfied.
     * @param currentPath the json path to the element being checked
     */
    public void checkAllRequirementsSatisfied(final String currentPath) {
        StringBuilder errors = new StringBuilder();

        for (Field field : this.dependantsInJson) {
            final Collection requirements = this.dependantToRequirementsMap.get(field);
            if (!requirements.isEmpty()) {
                errors.append("\n");
                String type = field.getType().getName();
                if (field.getType().isArray()) {
                    type = field.getType().getComponentType().getName() + "[]";
                }
                errors.append("\t* ").append(type).append(' ').append(field.getName()).append(" depends on ").append(requirements);
            }
        }
        Assert.equals(0, errors.length(), "\nErrors were detected when analysing the @Requires dependencies of '" +
                                          currentPath + "': " + errors);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy