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

com.fitbur.assertj.util.diff.myers.DiffNode Maven / Gradle / Ivy

There is a newer version: 1.0.0
Show newest version
/**
 * 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.
 *
 * Copyright 2012-2016 the original author or authors.
 */
package com.fitbur.assertj.util.diff.myers;

/**
 * Copy from https://code.google.com/p/java-diff-utils/.
 * 

* A diffnode in a diffpath. *

* A DiffNode and its previous node mark a delta between * two input sequences, that is, two differing subsequences * between (possibly zero length) matching sequences. * * {@link DiffNode DiffNodes} and {@link Snake Snakes} allow for compression * of diffpaths, as each snake is represented by a single {@link Snake Snake} * node and each contiguous series of insertions and deletions is represented * by a single {@link DiffNode DiffNodes}. * * @author Juanco Anez */ public final class DiffNode extends PathNode { /** * Constructs a DiffNode. *

* DiffNodes are compressed. That means that * the path pointed to by the prev parameter * will be followed using {@link PathNode#previousSnake} * until a non-diff node is found. * * @param i the position in the original sequence * @param j the position in the revised sequence * @param prev the previous node in the path. */ public DiffNode(int i, int j, PathNode prev) { super(i, j, (prev == null ? null : prev.previousSnake())); } /** * {@inheritDoc} * @return false, always */ public boolean isSnake() { return false; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy