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

org.xwiki.diff.display.InlineDiffChunk Maven / Gradle / Ivy

/*
 * See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 *
 * This 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 2.1 of
 * the License, or (at your option) any later version.
 *
 * This software 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 this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */
package org.xwiki.diff.display;

import java.util.List;

import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;

/**
 * A group of consecutive elements that are targeted by the same operation (add, remove, keep) in an in-line diff.
 *
 * @param  the type of elements that form a chunk
 * @version $Id: 470faae03c6b77f75c3cf1b31b513163eaa998de $
 * @since 4.1RC1
 */
public class InlineDiffChunk
{
    /**
     * The possible types of chunks you can find within an in-line diff.
     */
    public enum Type
    {
        /** A chunk that has been added. All the elements that form this chunk have been added. */
        ADDED,

        /** A chunk that has been removed. All the elements that form this chunk have been added. */
        DELETED,

        /**
         * A chunk that stays unmodified. The elements of this chunk are neither added nor removed. They indicate the
         * context where a change has been made.
         */
        UNMODIFIED;
    }

    /**
     * The chunk type. This specified the operation (add, remove, keep) that targets all the chunk elements.
     */
    private final Type type;

    /**
     * The list of elements that form this chunk.
     */
    private final List elements;

    /**
     * Creates a new chunk with the specified type and elements.
     *
     * @param type the chunk type
     * @param elements the list of elements that form the chunk
     */
    public InlineDiffChunk(Type type, List elements)
    {
        this.type = type;
        this.elements = elements;
    }

    /**
     * @return the chunk type
     */
    public Type getType()
    {
        return this.type;
    }

    /**
     * @return the list of element that form this chunk
     */
    public List getElements()
    {
        return this.elements;
    }

    /**
     * @return {@code true} if this chunk was added, {@code false} otherwise
     */
    public boolean isAdded()
    {
        return this.type == Type.ADDED;
    }

    /**
     * @return {@code true} if this chunk was deleted, {@code false} otherwise
     */
    public boolean isDeleted()
    {
        return this.type == Type.DELETED;
    }

    /**
     * @return {@code true} if this chunk was left unmodified, {@code false} otherwise
     */
    public boolean isUnmodified()
    {
        return this.type == Type.UNMODIFIED;
    }

    @Override
    public String toString()
    {
        StringBuilder stringBuilder = new StringBuilder(this.elements.size());
        for (E element : this.elements) {
            stringBuilder.append(element);
        }
        return stringBuilder.toString();
    }

    @Override
    public boolean equals(Object o)
    {
        if (this == o) {
            return true;
        }

        if (o == null || getClass() != o.getClass()) {
            return false;
        }

        InlineDiffChunk that = (InlineDiffChunk) o;

        return new EqualsBuilder()
            .append(type, that.type)
            .append(elements, that.elements)
            .isEquals();
    }

    @Override
    public int hashCode()
    {
        return new HashCodeBuilder(23, 63)
            .append(type)
            .append(elements)
            .toHashCode();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy