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

org.thymeleaf.util.ProcessorComparators Maven / Gradle / Ivy

Go to download

Modern server-side Java template engine for both web and standalone environments

There is a newer version: 3.1.3.RELEASE
Show newest version
/*
 * =============================================================================
 *
 *   Copyright (c) 2011-2018, The THYMELEAF team (http://www.thymeleaf.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.thymeleaf.util;

import java.util.Comparator;

import org.thymeleaf.postprocessor.IPostProcessor;
import org.thymeleaf.preprocessor.IPreProcessor;
import org.thymeleaf.processor.IProcessor;

/**
 *
 * @author Daniel Fernández
 * @since 3.0.0
 *
 */
public final class ProcessorComparators {


    public static final Comparator PROCESSOR_COMPARATOR = new ProcessorPrecedenceComparator();
    public static final Comparator PRE_PROCESSOR_COMPARATOR = new PreProcessorPrecedenceComparator();
    public static final Comparator POST_PROCESSOR_COMPARATOR = new PostProcessorPrecedenceComparator();




    private ProcessorComparators() {
        super();
    }



    private static final class ProcessorPrecedenceComparator implements Comparator {


        ProcessorPrecedenceComparator() {
            super();
        }


        public int compare(final IProcessor o1, final IProcessor o2) {
            if (o1 == o2) {
                // This is the only case in which the comparison of two processors will return 0
                return 0;
            }
            if (o1 instanceof ProcessorConfigurationUtils.AbstractProcessorWrapper && o2 instanceof ProcessorConfigurationUtils.AbstractProcessorWrapper) {
                return compareWrapped((ProcessorConfigurationUtils.AbstractProcessorWrapper)o1, (ProcessorConfigurationUtils.AbstractProcessorWrapper)o2);
            }
            final int processorPrecedenceComp = compareInts(o1.getPrecedence(), o2.getPrecedence());
            if (processorPrecedenceComp != 0) {
                return processorPrecedenceComp;
            }
            final int classNameComp = o1.getClass().getName().compareTo(o2.getClass().getName());
            if (classNameComp != 0) {
                return classNameComp;
            }
            return compareInts(System.identityHashCode(o1), System.identityHashCode(o2)); // Cannot be 0
        }


        /*
         * Processors are wrapped and therefore we can apply dialect precedence
         */
        private int compareWrapped(final ProcessorConfigurationUtils.AbstractProcessorWrapper o1w, final ProcessorConfigurationUtils.AbstractProcessorWrapper o2w) {

            final int dialectPrecedenceComp = compareInts(o1w.getDialectPrecedence(), o2w.getDialectPrecedence());
            if (dialectPrecedenceComp != 0) {
                return dialectPrecedenceComp;
            }

            final IProcessor o1 = o1w.unwrap();
            final IProcessor o2 = o2w.unwrap();

            final int processorPrecedenceComp = compareInts(o1.getPrecedence(), o2.getPrecedence());
            if (processorPrecedenceComp != 0) {
                return processorPrecedenceComp;
            }
            final int classNameComp = o1.getClass().getName().compareTo(o2.getClass().getName());
            if (classNameComp != 0) {
                return classNameComp;
            }
            return compareInts(System.identityHashCode(o1), System.identityHashCode(o2)); // Cannot be 0

        }


        private static int compareInts(int x, int y) {
            return (x < y) ? -1 : ((x == y) ? 0 : 1);
        }

    }




    private static final class PreProcessorPrecedenceComparator implements Comparator {


        PreProcessorPrecedenceComparator() {
            super();
        }


        public int compare(final IPreProcessor o1, final IPreProcessor o2) {
            if (o1 == o2) {
                // This is the only case in which the comparison of two processors will return 0
                return 0;
            }
            if (o1 instanceof ProcessorConfigurationUtils.PreProcessorWrapper && o2 instanceof ProcessorConfigurationUtils.PreProcessorWrapper) {
                return compareWrapped((ProcessorConfigurationUtils.PreProcessorWrapper)o1, (ProcessorConfigurationUtils.PreProcessorWrapper)o2);
            }
            final int preProcessorPrecedenceComp = compareInts(o1.getPrecedence(), o2.getPrecedence());
            if (preProcessorPrecedenceComp != 0) {
                return preProcessorPrecedenceComp;
            }
            final int classNameComp = o1.getClass().getName().compareTo(o2.getClass().getName());
            if (classNameComp != 0) {
                return classNameComp;
            }
            return compareInts(System.identityHashCode(o1), System.identityHashCode(o2)); // Cannot be 0
        }


        /*
         * Processors are wrapped and therefore we can apply dialect precedence
         */
        private int compareWrapped(final ProcessorConfigurationUtils.PreProcessorWrapper o1w, final ProcessorConfigurationUtils.PreProcessorWrapper o2w) {

            final int dialectPrecedenceComp = compareInts(o1w.getDialect().getDialectProcessorPrecedence(), o2w.getDialect().getDialectProcessorPrecedence());
            if (dialectPrecedenceComp != 0) {
                return dialectPrecedenceComp;
            }

            final IPreProcessor o1 = o1w.unwrap();
            final IPreProcessor o2 = o2w.unwrap();

            final int processorPrecedenceComp = compareInts(o1.getPrecedence(), o2.getPrecedence());
            if (processorPrecedenceComp != 0) {
                return processorPrecedenceComp;
            }
            final int classNameComp = o1.getClass().getName().compareTo(o2.getClass().getName());
            if (classNameComp != 0) {
                return classNameComp;
            }
            return compareInts(System.identityHashCode(o1), System.identityHashCode(o2)); // Cannot be 0

        }


        private static int compareInts(int x, int y) {
            return (x < y) ? -1 : ((x == y) ? 0 : 1);
        }

    }




    private static final class PostProcessorPrecedenceComparator implements Comparator {


        PostProcessorPrecedenceComparator() {
            super();
        }


        public int compare(final IPostProcessor o1, final IPostProcessor o2) {
            if (o1 == o2) {
                // This is the only case in which the comparison of two processors will return 0
                return 0;
            }
            if (o1 instanceof ProcessorConfigurationUtils.PostProcessorWrapper && o2 instanceof ProcessorConfigurationUtils.PostProcessorWrapper) {
                return compareWrapped((ProcessorConfigurationUtils.PostProcessorWrapper)o1, (ProcessorConfigurationUtils.PostProcessorWrapper)o2);
            }
            final int postProcessorPrecedenceComp = compareInts(o1.getPrecedence(), o2.getPrecedence());
            if (postProcessorPrecedenceComp != 0) {
                return postProcessorPrecedenceComp;
            }
            final int classNameComp = o1.getClass().getName().compareTo(o2.getClass().getName());
            if (classNameComp != 0) {
                return classNameComp;
            }
            return compareInts(System.identityHashCode(o1), System.identityHashCode(o2)); // Cannot be 0
        }


        /*
         * Processors are wrapped and therefore we can apply dialect precedence
         */
        private int compareWrapped(final ProcessorConfigurationUtils.PostProcessorWrapper o1w, final ProcessorConfigurationUtils.PostProcessorWrapper o2w) {

            final int dialectPrecedenceComp = compareInts(o1w.getDialect().getDialectProcessorPrecedence(), o2w.getDialect().getDialectProcessorPrecedence());
            if (dialectPrecedenceComp != 0) {
                return dialectPrecedenceComp;
            }

            final IPostProcessor o1 = o1w.unwrap();
            final IPostProcessor o2 = o2w.unwrap();

            final int processorPrecedenceComp = compareInts(o1.getPrecedence(), o2.getPrecedence());
            if (processorPrecedenceComp != 0) {
                return processorPrecedenceComp;
            }
            final int classNameComp = o1.getClass().getName().compareTo(o2.getClass().getName());
            if (classNameComp != 0) {
                return classNameComp;
            }
            return compareInts(System.identityHashCode(o1), System.identityHashCode(o2)); // Cannot be 0

        }


        private static int compareInts(int x, int y) {
            return (x < y) ? -1 : ((x == y) ? 0 : 1);
        }

    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy