AstComparator.java

package graphql.language;


import graphql.Internal;

import java.util.Iterator;
import java.util.List;

@Internal
public class AstComparator {

    private AstComparator() {

    }

    public static boolean sameValue(Value value1, Value value2) {
        if (value1 == null && value2 == null) {
            return true;
        }
        if (value1 == null) {
            return false;
        }
        if (value2 == null) {
            return false;
        }
        return isEqual(value1, value2);
    }


    public static boolean isEqual(Node node1, Node node2) {
        if (null == node1) {
            return null == node2;
        }
        if (!node1.isEqualTo(node2)) {
            return false;
        }
        List<Node> childs1 = node1.getChildren();
        List<Node> childs2 = node2.getChildren();
        if (childs1.size() != childs2.size()) {
            return false;
        }
        for (int i = 0; i < childs1.size(); i++) {
            if (!isEqual(childs1.get(i), childs2.get(i))) {
                return false;
            }
        }
        return true;
    }

    public static boolean isEqual(List<Node> nodes1, List<Node> nodes2) {
        if (nodes1.size() != nodes2.size()) {
            return false;
        }
        Iterator<Node> iter1 = nodes1.iterator();
        Iterator<Node> iter2 = nodes2.iterator();
        while (iter1.hasNext()) {
            if (!isEqual(iter1.next(), iter2.next())) {
                return false;
            }
        }
        return true;
    }
}