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

graphql.schema.diffing.Mapping Maven / Gradle / Ivy

package graphql.schema.diffing;

import com.google.common.collect.BiMap;
import com.google.common.collect.HashBiMap;
import graphql.Internal;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.function.BiConsumer;
import java.util.function.Consumer;

/**
 * A mapping (in the math sense) from a list of vertices to another list of
 * vertices.
 * A mapping can semantically mean a change, but doesn't have to: a vertex
 * can be mapped to the same vertex (semantically the same, Java object wise they are different).
 */
@Internal
public class Mapping {


    private final Map fixedParentRestrictions;
    private final BiMap fixedMappings;
    private final List fixedSourceList;
    private final List fixedTargetList;

    private final BiMap map;
    private final List sourceList;
    private final List targetList;

    private Mapping(Map fixedParentRestrictions,
                    BiMap fixedMappings,
                    List fixedSourceList,
                    List fixedTargetList,
                    BiMap map,
                    List sourceList,
                    List targetList) {
        this.fixedParentRestrictions = fixedParentRestrictions;
        this.fixedMappings = fixedMappings;
        this.fixedSourceList = fixedSourceList;
        this.fixedTargetList = fixedTargetList;
        this.map = map;
        this.sourceList = sourceList;
        this.targetList = targetList;
    }

    public static Mapping newMapping(Map fixedParentRestrictions,
                                     BiMap fixedMappings,
                                     List fixedSourceList,
                                     List fixedTargetList) {
        return new Mapping(
                fixedParentRestrictions,
                fixedMappings,
                fixedSourceList,
                fixedTargetList,
                HashBiMap.create(),
                Collections.emptyList(),
                Collections.emptyList());
    }

    public boolean hasParentRestriction(Vertex v) {
        return fixedParentRestrictions.containsKey(v);
    }

    public Vertex getParentRestriction(Vertex v) {
        return fixedParentRestrictions.get(v);
    }

    public Vertex getSource(Vertex target) {
        if (fixedMappings.containsValue(target)) {
            return fixedMappings.inverse().get(target);
        }
        return map.inverse().get(target);
    }

    public Vertex getTarget(Vertex source) {
        if (fixedMappings.containsKey(source)) {
            return fixedMappings.get(source);
        }
        return map.get(source);
    }

    public Vertex getSource(int i) {
        if (i < fixedSourceList.size()) {
            return fixedSourceList.get(i);
        }
        return sourceList.get(i - fixedSourceList.size());
    }

    public Vertex getTarget(int i) {
        if (i < fixedTargetList.size()) {
            return fixedTargetList.get(i);
        }
        return targetList.get(i - fixedTargetList.size());
    }

    public boolean containsSource(Vertex sourceVertex) {
        if (fixedMappings.containsKey(sourceVertex)) {
            return true;
        }
        return map.containsKey(sourceVertex);
    }

    public boolean containsTarget(Vertex targetVertex) {
        if (fixedMappings.containsValue(targetVertex)) {
            return true;
        }
        return map.containsValue(targetVertex);
    }


    public boolean contains(Vertex vertex, boolean sourceOrTarget) {
        return sourceOrTarget ? containsSource(vertex) : containsTarget(vertex);
    }


    public int size() {
        return fixedMappings.size() + map.size();
    }

    public int fixedSize() {
        return fixedMappings.size();
    }

    public int nonFixedSize() {
        return map.size();
    }

    public void add(Vertex source, Vertex target) {
        this.map.put(source, target);
        this.sourceList.add(source);
        this.targetList.add(target);
    }

    public Mapping copyMappingWithLastElementRemoved() {
        HashBiMap newMap = HashBiMap.create(map);
        newMap.remove(this.sourceList.get(this.sourceList.size() - 1));
        List newSourceList = new ArrayList<>(this.sourceList.subList(0, this.sourceList.size() - 1));
        List newTargetList = new ArrayList<>(this.targetList.subList(0, this.targetList.size() - 1));
        return new Mapping(fixedParentRestrictions, fixedMappings, fixedSourceList, fixedTargetList, newMap, newSourceList, newTargetList);
    }

    public Mapping copy() {
        HashBiMap newMap = HashBiMap.create(map);
        List newSourceList = new ArrayList<>(this.sourceList);
        List newTargetList = new ArrayList<>(this.targetList);
        return new Mapping(fixedParentRestrictions, fixedMappings, fixedSourceList, fixedTargetList, newMap, newSourceList, newTargetList);
    }

    public Mapping extendMapping(Vertex source, Vertex target) {
        HashBiMap newMap = HashBiMap.create(map);
        newMap.put(source, target);
        List newSourceList = new ArrayList<>(this.sourceList);
        newSourceList.add(source);
        List newTargetList = new ArrayList<>(this.targetList);
        newTargetList.add(target);
        return new Mapping(fixedParentRestrictions, fixedMappings, fixedSourceList, fixedTargetList, newMap, newSourceList, newTargetList);
    }

    public void forEachTarget(Consumer action) {
        for (Vertex t : fixedTargetList) {
            action.accept(t);
        }
        for (Vertex t : targetList) {
            action.accept(t);
        }
    }

    public void forEachNonFixedTarget(Consumer action) {
        for (Vertex t : targetList) {
            action.accept(t);
        }
    }

    public void forEachNonFixedSourceAndTarget(BiConsumer consumer) {
        map.forEach(consumer);
    }

    public Mapping invert() {
        BiMap invertedFixedMappings = HashBiMap.create();
        for (Vertex s : fixedMappings.keySet()) {
            Vertex t = fixedMappings.get(s);
            invertedFixedMappings.put(t, s);
        }
        BiMap invertedMap = HashBiMap.create();
        for (Vertex s : map.keySet()) {
            Vertex t = map.get(s);
            invertedMap.put(t, s);
        }
        return new Mapping(fixedParentRestrictions, invertedFixedMappings, fixedTargetList, fixedSourceList, invertedMap, targetList, sourceList);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy