Package org.infinispan.schematic.internal.schema

Source Code of org.infinispan.schematic.internal.schema.ValidationResult

/*
* ModeShape (http://www.modeshape.org)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*       http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.infinispan.schematic.internal.schema;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import org.infinispan.schematic.SchemaLibrary.MismatchedTypeProblem;
import org.infinispan.schematic.SchemaLibrary.Problem;
import org.infinispan.schematic.SchemaLibrary.ProblemType;
import org.infinispan.schematic.SchemaLibrary.Results;
import org.infinispan.schematic.document.JsonSchema.Type;
import org.infinispan.schematic.document.NotThreadSafe;
import org.infinispan.schematic.document.Path;

/**
* Basic implementation of {@link Results} to which problems can be added.
*
* @author Randall Hauch <rhauch@redhat.com> (C) 2011 Red Hat Inc.
* @since 5.1
*/
@NotThreadSafe
public class ValidationResult implements Results, Problems {

    private final List<Problem> problems = new ArrayList<Problem>();
    private int successes;

    @Override
    public Iterator<Problem> iterator() {
        return Collections.unmodifiableList(problems).iterator();
    }

    @Override
    public boolean hasProblems() {
        return !problems.isEmpty();
    }

    @Override
    public boolean hasErrors() {
        for (Problem problem : problems) {
            if (problem.getType() == ProblemType.ERROR) return true;
        }
        return false;
    }

    @Override
    public boolean hasWarnings() {
        for (Problem problem : problems) {
            if (problem.getType() == ProblemType.WARNING) return true;
        }
        return false;
    }

    @Override
    public boolean hasOnlyTypeMismatchErrors() {
        boolean foundMismatch = false;
        for (Problem problem : problems) {
            if (problem.getType() == ProblemType.ERROR) {
                if (problem instanceof MismatchedTypeProblem) foundMismatch = true;
                else return false;
            }
        }
        return foundMismatch;
    }

    @Override
    public int errorCount() {
        int result = 0;
        for (Problem problem : problems) {
            if (problem.getType() == ProblemType.ERROR) ++result;
        }
        return result;
    }

    @Override
    public int warningCount() {
        int result = 0;
        for (Problem problem : problems) {
            if (problem.getType() == ProblemType.WARNING) ++result;
        }
        return result;
    }

    @Override
    public int problemCount() {
        return problems.size();
    }

    public int successCount() {
        return successes;
    }

    @Override
    public void recordSuccess() {
        ++successes;
    }

    @Override
    public void recordError( Path path,
                             String reason ) {
        problems.add(new ValidationProblem(ProblemType.ERROR, path, reason, null));
    }

    @Override
    public void recordError( Path path,
                             String reason,
                             Throwable cause ) {
        problems.add(new ValidationProblem(ProblemType.ERROR, path, reason, cause));
    }

    @Override
    public void recordWarning( Path path,
                               String reason ) {
        problems.add(new ValidationProblem(ProblemType.WARNING, path, reason, null));
    }

    @Override
    public void recordTypeMismatch( Path path,
                                    String reason,
                                    Type actualType,
                                    Object actualValue,
                                    Type requiredType,
                                    Object convertedValue ) {
        problems.add(new ValidationTypeMismatchProblem(ProblemType.ERROR, path, actualValue, actualType, requiredType,
                                                       convertedValue, reason, null));
    }

    public void recordIn( Problems otherProblems ) {
        if (successes == 0 && problems.isEmpty()) return;

        for (Problem problem : problems) {
            for (int i = 0; i != successes; ++i) {
                otherProblems.recordSuccess();
            }
            switch (problem.getType()) {
                case ERROR:
                    if (problem instanceof MismatchedTypeProblem) {
                        MismatchedTypeProblem mismatch = (MismatchedTypeProblem)problem;
                        otherProblems.recordTypeMismatch(mismatch.getPath(),
                                                         mismatch.getReason(),
                                                         mismatch.getActualType(),
                                                         mismatch.getActualValue(),
                                                         mismatch.getExpectedType(),
                                                         mismatch.getConvertedValue());
                    } else {
                        otherProblems.recordError(problem.getPath(), problem.getReason(), problem.getCause());
                    }
                    break;
                case WARNING:
                    otherProblems.recordWarning(problem.getPath(), problem.getReason());
                    break;
            }
        }
    }

    public void add( Problem problem ) {
        if (problem != null) {
            problems.add(problem);
        }
    }

    public void addAll( Iterable<Problem> results ) {
        if (results != null) {
            for (Problem problem : results) {
                problems.add(problem);
            }
        }
    }

    public void addAll( Iterator<Results> iter ) {
        if (iter != null) {
            while (iter.hasNext()) {
                addAll(iter.next());
            }
        }
    }

    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        for (Problem problem : problems) {
            sb.append(problem);
            sb.append('\n');
        }
        return sb.toString();
    }

}
TOP

Related Classes of org.infinispan.schematic.internal.schema.ValidationResult

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.