summaryrefslogtreecommitdiff
path: root/xmerge/java/org/openoffice/xmerge/merger/diff/CharArrayLCSAlgorithm.java
diff options
context:
space:
mode:
Diffstat (limited to 'xmerge/java/org/openoffice/xmerge/merger/diff/CharArrayLCSAlgorithm.java')
-rw-r--r--xmerge/java/org/openoffice/xmerge/merger/diff/CharArrayLCSAlgorithm.java235
1 files changed, 0 insertions, 235 deletions
diff --git a/xmerge/java/org/openoffice/xmerge/merger/diff/CharArrayLCSAlgorithm.java b/xmerge/java/org/openoffice/xmerge/merger/diff/CharArrayLCSAlgorithm.java
deleted file mode 100644
index b54f0ee8a8da..000000000000
--- a/xmerge/java/org/openoffice/xmerge/merger/diff/CharArrayLCSAlgorithm.java
+++ /dev/null
@@ -1,235 +0,0 @@
-/************************************************************************
- *
- * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
- *
- * Copyright 2000, 2010 Oracle and/or its affiliates.
- *
- * OpenOffice.org - a multi-platform office productivity suite
- *
- * This file is part of OpenOffice.org.
- *
- * OpenOffice.org is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License version 3
- * only, as published by the Free Software Foundation.
- *
- * OpenOffice.org 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 version 3 for more details
- * (a copy is included in the LICENSE file that accompanied this code).
- *
- * You should have received a copy of the GNU Lesser General Public License
- * version 3 along with OpenOffice.org. If not, see
- * <http://www.openoffice.org/license.html>
- * for a copy of the LGPLv3 License.
- *
- ************************************************************************/
-
-package org.openoffice.xmerge.merger.diff;
-
-import java.util.Vector;
-import org.openoffice.xmerge.merger.DiffAlgorithm;
-import org.openoffice.xmerge.merger.Difference;
-
-/**
- * <p>This is an implementations of <code>DiffAlgorithm</code> interface
- * which will difference char arrays.</p>
- *
- * <p>It also use Longest Common Subsequence (LCS). The algorithm is based
- * on the book "Introduction to Algorithms" by Thomas H.Cormen,
- * Charles E.Leiserson, and Ronald L.Riverst (MIT Press 1990) page 314.</p>
- *
- * @author smak
- */
-public class CharArrayLCSAlgorithm {
-
- /**
- * Return an <code>Difference</code> array. This method finds out
- * the difference between two sequences.
- *
- * @param orgSeq The original sequence.
- * @param modSeq The modified (or changed) sequence to
- * compare against the origial.
- *
- * @return A <code>Difference</code> array.
- */
- public Difference[] computeDiffs(char[] orgSeq, char[] modSeq) {
-
- int orgSeqlen = orgSeq.length;
- int modSeqlen = modSeq.length;
-
- int[][] diffTable;
-
- // Diff table is used to keep track which element is the same or not
- // in those 2 sequences
- diffTable = createDiffTable(orgSeq, modSeq);
-
- // debug purpose...
- // printDiffTable(diffTable);
-
- Vector diffResult = new Vector();
-
- generateResult(diffTable, orgSeqlen, modSeqlen, diffResult);
-
- // don't need anymore if Difference do not contain content information
- /* fillInDiffContent(diffResult, orgSeq, modSeq); */
-
- Difference[] diffArray = new Difference[0];
-
- // convert the vector to array, it has to do in here as
- // generateResult is called recursively
- if (diffResult.size() > 0) {
- diffArray = new Difference[diffResult.size()];
- diffResult.copyInto(diffArray);
- }
-
- diffTable = null;
- diffResult = null;
-
- return diffArray;
- }
-
-
- /**
- * Debug function Used to print out the nicely formatted
- * difference table.
- *
- * @param diffTable The difference table to display.
- */
- private void printDiffTable(int[][] diffTable) {
-
- for (int i = 0; i < diffTable.length; i++) {
- for (int j = 0; j < diffTable[i].length; j++) {
- System.out.print(" " + diffTable[i][j] + " ");
- }
- System.out.println();
- }
- }
-
-
- /**
- * Create the difference table.
- * The difference table is used internal to keep track what
- * elements are common or different in the two sequences.
- *
- * @param orgSeq The original sequence to be used as a base.
- * @param modSeq The modified sequence to compare.
- *
- * @return A difference table as a two-dimensional array of
- * integers.
- */
- private int[][] createDiffTable(char[] orgSeq, char[] modSeq) {
- int orgSeqlen = orgSeq.length + 1;
- int modSeqlen = modSeq.length + 1;
- int[][] diffTable;
-
- // initialize the diffTable (it need to be 1 row/col bigger
- // than the original str)
- diffTable = new int[orgSeqlen][];
- for (int i = 0; i < orgSeqlen; i++) {
- diffTable[i] = new int[modSeqlen];
- }
-
- // compute the diff Table using LCS algorithm, refer to the book
- // mentioned at the top of the program
- for (int i = 1; i < orgSeqlen; i++) {
- for (int j = 1; j < modSeqlen; j++) {
-
- if (orgSeq[i-1] == modSeq[j-1]) {
- diffTable[i][j] = diffTable[i-1][j-1]+1;
- } else {
- if (diffTable[i-1][j] >= diffTable[i][j-1]) {
- diffTable[i][j] = diffTable[i-1][j];
- } else {
- diffTable[i][j] = diffTable[i][j-1];
- }
- }
- }
- }
-
- return diffTable;
- }
-
-
- /**
- * Generate the <code>Difference</code> result vector.
- * This method will be called recursively to backtrack the difference
- * table to get the difference result (and also the LCS).
- *
- * @param diffTable The difference table containing the
- * <code>Difference</code> result.
- * @param i The nth element in original sequence to
- * compare. This method is called recursively
- * with i and j decreased until 0.
- * @param j The nth element in modified sequence to
- * compare.
- * @param diffVector A vector to output the <code>Difference</code>
- * result. Can not use a return variable as it
- * is a recursive method. The vector will contain
- * <code>Difference</code> objects with operation
- * and positions filled in.
- */
- private void generateResult(int[][] diffTable,
- int i, int j, Vector diffVector) {
-
- // handle the first element
- if (i == 0 || j == 0) {
- if (i == 0 && j == 0) {
- // return
- } else if (j == 0) {
- for (int cnt = 0; cnt < i; cnt++) {
- Difference diff =
- new Difference(Difference.DELETE, cnt, j);
- diffVector.add(diff);
- }
- } else {
- for (int cnt = 0; cnt < j; cnt++) {
- Difference diff =
- new Difference(Difference.ADD, i, cnt);
- diffVector.add(diff);
- }
- }
- return;
- }
-
- // for the detail of this algorithm, refer to the book mentioned on
- // the top and page 317 and 318.
- if ((diffTable[i-1][j-1] == diffTable[i][j] -1) &&
- (diffTable[i-1][j-1] == diffTable[i-1][j]) &&
- (diffTable[i-1][j-1] == diffTable[i][j-1])) {
-
- // the element of ith and jth in org and mod sequence is the same
- generateResult(diffTable, i-1, j-1, diffVector);
- } else {
- if (diffTable[i-1][j] > diffTable[i][j-1]) {
-
- // recursively call first, then add the result so that
- // the beginning of the diffs will be stored first
- generateResult(diffTable, i-1, j, diffVector);
-
- Difference diff =
- new Difference(Difference.DELETE, i-1, j);
- diffVector.add(diff);
- } else if (diffTable[i-1][j] < diffTable[i][j-1]) {
-
- // recursively call first, then add the result so that
- // the beginning of the diffs will be stored first
- generateResult(diffTable, i, j-1, diffVector);
-
- Difference diff =
- new Difference(Difference.ADD, i, j-1);
- diffVector.add(diff);
- } else { // diffTable[i-1][j] == diffTable[i][j-1]
- // recursively call first, then add the result so that
- // the beginning of the diffs will be stored first
- generateResult(diffTable, i-1, j-1, diffVector);
-
- Difference diff =
- new Difference(Difference.CHANGE, i-1, j-1);
- diffVector.add(diff);
-
- }
- }
- }
-}
-