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

com.github.gumtreediff.tree.TreeValidator Maven / Gradle / Ivy

The newest version!
/*
 * This file is part of GumTree.
 *
 * GumTree is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * GumTree 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 Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with GumTree.  If not, see .
 *
 * Copyright 2019 Jean-Rémy Falleri 
 */

package com.github.gumtreediff.tree;

/**
 * Class dedicated to check the constraints on the ASTs.
 * The checked constraints are:
 * 1. Only leaves may have a label
 * 2. A child node test position must be contained in the position of its parent
 * 3. The text position of a given node should be strictly greater than
 *    the position of its preceding sibling (if any).
 * An instantiated tree validator should be stateless and can then be reused
 * to validate several ASTs.
 */
public class TreeValidator {

    private TreeContext context;

    /**
     * Launch the validation on the tree contained in the provided context.
     * In case of violation of a constraint, an runtime exception is raised.
     * @see TreeException
     */
    public void validate(TreeContext context) {
        this.context = context;
        validate(context.getRoot());
    }

    private void validate(Tree root) {
        for (Tree t : root.preOrder()) {
            if (!t.isLeaf()) {
                if (!t.getLabel().equals(Tree.NO_LABEL))
                    throw new TreeException(String.format("%s : %s\n%s",
                            "Inner node with label",
                            t.toString(),
                            t.toTreeString()));

                if (t.getChildren().get(0).getPos() < t.getPos())
                    throw new TreeException(String.format("%s : %s\n%s",
                            "Children begin position before node begin position",
                            t.getChildren().get(0).toString(),
                            t.toTreeString()));

                if (t.getChildren().get(t.getChildren().size() - 1).getEndPos() > t.getEndPos())
                    throw new TreeException(String.format("%s : %s\n%s",
                            "Children end position after node end position",
                            t.getChildren().get(t.getChildren().size() - 1).toString(),
                            t.toTreeString()));

                if (t.getChildren().size() > 1) {
                    for (int i = 1; i < t.getChildren().size(); i++) {
                        Tree b = t.getChild(i -  1);
                        Tree c = t.getChild(i);
                        if (c.getPos() < b.getEndPos())
                            throw new TreeException(String.format("%s : %s\n%s",
                                    "Sibling begin position before node end position",
                                    c.toString(),
                                    t.toTreeString()));
                    }
                }
            }

        }

    }

    /**
     * Exception class for errors w.r.t. to AST constraints.
     */
    public static class TreeException extends RuntimeException {
        public TreeException(String message) {
            super(message);
        }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy