mirror of https://github.com/apache/poi.git
Merged revisions 638786-638802,638805-638811,638813-638814,638816-639230,639233-639241,639243-639253,639255-639486,639488-639601,639603-639835,639837-639917,639919-640056,640058-640710,640712-641156,641158-641184,641186-641795,641797-641798,641800-641933,641935-641963,641965-641966,641968-641995,641997-642230,642232-642562,642564-642565,642568-642570,642572-642573,642576-642736,642739-642877,642879,642881-642890,642892-642903,642905-642945,642947-643624,643626-643653,643655-643669,643671,643673-643830,643832-643833,643835-644342,644344-644472,644474-644508,644510-645347,645349-645351,645353-645559,645561-645565,645568-645951,645953-646193,646195-646311,646313-646404,646406-646665,646667-646853,646855-646869,646871-647151,647153-647185,647187-647277,647279-647566,647568-647573,647575,647578-647711,647714-647737,647739-647823,647825-648155,648157-648202,648204-648273,648275,648277-648302,648304-648333,648335-648588,648590-648622,648625-648673,648675-649141,649144,649146-649556,649558-649795,649799,649801-649910,649912-649913,649915-650128,650131-650132,650134-650137,650140-650914,650916-651991,651993-652284,652286-652287,652289,652291,652293-652297,652299-652328,652330-652425,652427-652445,652447-652560,652562-652933,652935,652937-652993,652995-653116,653118-653124,653126-653483,653487-653519,653522-653550,653552-653607,653609-653667,653669-653674,653676-653814,653817-653830,653832-653891,653893-653944,653946-654055,654057-654355,654357-654365,654367-654648,654651-655215,655217-655277,655279-655281,655283-655911,655913-656212,656214,656216-656251,656253-656698,656700-656756,656758-656892,656894-657135,657137-657165,657168-657179,657181-657354,657356-657357,657359-657701,657703-657874,657876-658032,658034-658284,658286,658288-658301,658303-658307,658309-658321,658323-658335,658337-658348,658351,658353-658832,658834-658983,658985,658987-659066,659068-659402,659404-659428,659430-659451,659453-659454,659456-659461,659463-659477,659479-659524,659526-659571,659574,659576-660255,660257-660262,660264-660279,660281-660343,660345-660473,660475-660827,660829-660833,660835-660888,660890-663321,663323-663435,663437-663764,663766-663854,663856-664219,664221-664489,664494-664514,664516-668143 via svnmerge from
https://svn.apache.org:443/repos/asf/poi/trunk ........ r668014 | josh | 2008-06-15 23:26:06 +0100 (Sun, 15 Jun 2008) | 1 line added extra RVA test case (for bug 45206) ........ r668143 | nick | 2008-06-16 13:49:55 +0100 (Mon, 16 Jun 2008) | 1 line Unit test from bug #45001, and new replaceText method (no test yet) ........ git-svn-id: https://svn.apache.org/repos/asf/poi/branches/ooxml@668144 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6bede3197f
commit
bc2efc3111
|
@ -15,12 +15,11 @@
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
==================================================================== */
|
==================================================================== */
|
||||||
|
|
||||||
|
|
||||||
package org.apache.poi.hssf.record.formula;
|
package org.apache.poi.hssf.record.formula;
|
||||||
|
|
||||||
import org.apache.poi.ss.usermodel.Workbook;
|
|
||||||
import org.apache.poi.hssf.record.RecordInputStream;
|
import org.apache.poi.hssf.record.RecordInputStream;
|
||||||
import org.apache.poi.hssf.util.RangeAddress;
|
import org.apache.poi.hssf.util.RangeAddress;
|
||||||
|
import org.apache.poi.ss.usermodel.Workbook;
|
||||||
import org.apache.poi.ss.util.CellReference;
|
import org.apache.poi.ss.util.CellReference;
|
||||||
import org.apache.poi.ss.util.SheetReferences;
|
import org.apache.poi.ss.util.SheetReferences;
|
||||||
import org.apache.poi.util.BitField;
|
import org.apache.poi.util.BitField;
|
||||||
|
@ -69,16 +68,15 @@ public class Ref3DPtg extends OperandPtg {
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
StringBuffer buffer = new StringBuffer();
|
CellReference cr = new CellReference(getRow(), getColumn(), !isRowRelative(),!isColRelative());
|
||||||
|
StringBuffer sb = new StringBuffer();
|
||||||
buffer.append("Ref3dPtg\n");
|
sb.append(getClass().getName());
|
||||||
buffer.append("Index to Extern Sheet = " + getExternSheetIndex()).append("\n");
|
sb.append(" [");
|
||||||
buffer.append("Row = " + getRow()).append("\n");
|
sb.append("sheetIx=").append(getExternSheetIndex());
|
||||||
buffer.append("Col = " + getColumn()).append("\n");
|
sb.append(" ! ");
|
||||||
buffer.append("ColRowRel= "
|
sb.append(cr.formatAsString());
|
||||||
+ isRowRelative()).append("\n");
|
sb.append("]");
|
||||||
buffer.append("ColRel = " + isColRelative()).append("\n");
|
return sb.toString();
|
||||||
return buffer.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeBytes(byte [] array, int offset) {
|
public void writeBytes(byte [] array, int offset) {
|
||||||
|
|
|
@ -632,6 +632,50 @@ public class Range
|
||||||
return (ListEntry)insertAfter(props, styleIndex);
|
return (ListEntry)insertAfter(props, styleIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Replace (one instance of) a piece of text with another...
|
||||||
|
*
|
||||||
|
* @param pPlaceHolder The text to be replaced (e.g., "${company}")
|
||||||
|
* @param pValue The replacement text (e.g., "Cognocys, Inc.")
|
||||||
|
* @param pDocument The <code>HWPFDocument</code> in which the placeholder was found
|
||||||
|
* @param pStartOffset The offset or index where the <code>CharacterRun</code> begins
|
||||||
|
* @param pPlaceHolderIndex The offset or index of the placeholder,
|
||||||
|
* relative to the <code>CharacterRun</code> where
|
||||||
|
* <code>pPlaceHolder</code> was found
|
||||||
|
*/
|
||||||
|
protected void replaceText(String pPlaceHolder, String pValue,
|
||||||
|
int pStartOffset, int pPlaceHolderIndex, HWPFDocument pDocument) {
|
||||||
|
int absPlaceHolderIndex = pStartOffset + pPlaceHolderIndex;
|
||||||
|
Range subRange = new Range(
|
||||||
|
absPlaceHolderIndex,
|
||||||
|
(absPlaceHolderIndex + pPlaceHolder.length()), pDocument
|
||||||
|
);
|
||||||
|
if (subRange.usesUnicode()) {
|
||||||
|
absPlaceHolderIndex = pStartOffset + (pPlaceHolderIndex * 2);
|
||||||
|
subRange = new Range(
|
||||||
|
absPlaceHolderIndex,
|
||||||
|
(absPlaceHolderIndex + (pPlaceHolder.length() * 2)),
|
||||||
|
pDocument
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
subRange.insertBefore(pValue);
|
||||||
|
|
||||||
|
// re-create the sub-range so we can delete it
|
||||||
|
subRange = new Range(
|
||||||
|
(absPlaceHolderIndex + pValue.length()),
|
||||||
|
(absPlaceHolderIndex + pPlaceHolder.length() + pValue.length()),
|
||||||
|
pDocument
|
||||||
|
);
|
||||||
|
if (subRange.usesUnicode())
|
||||||
|
subRange = new Range(
|
||||||
|
(absPlaceHolderIndex + (pValue.length() * 2)),
|
||||||
|
(absPlaceHolderIndex + (pPlaceHolder.length() * 2) +
|
||||||
|
(pValue.length() * 2)), pDocument
|
||||||
|
);
|
||||||
|
|
||||||
|
subRange.delete();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the character run at index. The index is relative to this range.
|
* Gets the character run at index. The index is relative to this range.
|
||||||
|
|
Binary file not shown.
|
@ -0,0 +1,120 @@
|
||||||
|
|
||||||
|
/* ====================================================================
|
||||||
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
contributor license agreements. See the NOTICE file distributed with
|
||||||
|
this work for additional information regarding copyright ownership.
|
||||||
|
The ASF licenses this file to You 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.apache.poi.hwpf.usermodel;
|
||||||
|
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.poi.hwpf.HWPFDocument;
|
||||||
|
import org.apache.poi.hwpf.model.PicturesTable;
|
||||||
|
import org.apache.poi.hwpf.usermodel.Picture;
|
||||||
|
|
||||||
|
import junit.framework.TestCase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test to see if Range.insertBefore() works even if the Range contains a
|
||||||
|
* CharacterRun that uses Unicode characters.
|
||||||
|
*/
|
||||||
|
public class TestRangeInsertion extends TestCase {
|
||||||
|
|
||||||
|
// u201c and u201d are "smart-quotes"
|
||||||
|
private String originalText =
|
||||||
|
"It is used to confirm that text insertion works even if Unicode characters (such as \u201c\u2014\u201d (U+2014), \u201c\u2e8e\u201d (U+2E8E), or \u201c\u2714\u201d (U+2714)) are present.\r";
|
||||||
|
private String textToInsert = "Look at me! I'm cool! ";
|
||||||
|
private int insertionPoint = 244;
|
||||||
|
|
||||||
|
private String illustrativeDocFile;
|
||||||
|
|
||||||
|
protected void setUp() throws Exception {
|
||||||
|
|
||||||
|
String dirname = System.getProperty("HWPF.testdata.path");
|
||||||
|
|
||||||
|
illustrativeDocFile = dirname + "/testRangeInsertion.doc";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test just opening the files
|
||||||
|
*/
|
||||||
|
public void testOpen() throws Exception {
|
||||||
|
|
||||||
|
HWPFDocument docA = new HWPFDocument(new FileInputStream(illustrativeDocFile));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test (more "confirm" than test) that we have the general structure that we expect to have.
|
||||||
|
*/
|
||||||
|
public void testDocStructure() throws Exception {
|
||||||
|
|
||||||
|
HWPFDocument daDoc = new HWPFDocument(new FileInputStream(illustrativeDocFile));
|
||||||
|
|
||||||
|
Range range = daDoc.getRange();
|
||||||
|
|
||||||
|
assertEquals(1, range.numSections());
|
||||||
|
Section section = range.getSection(0);
|
||||||
|
|
||||||
|
assertEquals(3, section.numParagraphs());
|
||||||
|
Paragraph para = section.getParagraph(2);
|
||||||
|
|
||||||
|
assertEquals(3, para.numCharacterRuns());
|
||||||
|
String text = para.getCharacterRun(0).text() + para.getCharacterRun(1).text() +
|
||||||
|
para.getCharacterRun(2).text();
|
||||||
|
|
||||||
|
assertEquals(originalText, text);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that we can insert text in our CharacterRun with Unicode text.
|
||||||
|
*/
|
||||||
|
public void testRangeInsertion() throws Exception {
|
||||||
|
|
||||||
|
HWPFDocument daDoc = new HWPFDocument(new FileInputStream(illustrativeDocFile));
|
||||||
|
|
||||||
|
/*
|
||||||
|
Range range = daDoc.getRange();
|
||||||
|
Section section = range.getSection(0);
|
||||||
|
Paragraph para = section.getParagraph(2);
|
||||||
|
String text = para.getCharacterRun(0).text() + para.getCharacterRun(1).text() +
|
||||||
|
para.getCharacterRun(2).text();
|
||||||
|
|
||||||
|
System.out.println(text);
|
||||||
|
*/
|
||||||
|
|
||||||
|
Range range = new Range(insertionPoint, (insertionPoint + 2), daDoc);
|
||||||
|
range.insertBefore(textToInsert);
|
||||||
|
|
||||||
|
// we need to let the model re-calculate the Range before we evaluate it
|
||||||
|
range = daDoc.getRange();
|
||||||
|
|
||||||
|
assertEquals(1, range.numSections());
|
||||||
|
Section section = range.getSection(0);
|
||||||
|
|
||||||
|
assertEquals(3, section.numParagraphs());
|
||||||
|
Paragraph para = section.getParagraph(2);
|
||||||
|
|
||||||
|
assertEquals(3, para.numCharacterRuns());
|
||||||
|
String text = para.getCharacterRun(0).text() + para.getCharacterRun(1).text() +
|
||||||
|
para.getCharacterRun(2).text();
|
||||||
|
|
||||||
|
// System.out.println(text);
|
||||||
|
|
||||||
|
assertEquals((textToInsert + originalText), text);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Binary file not shown.
|
@ -23,7 +23,6 @@ import junit.framework.TestCase;
|
||||||
import org.apache.poi.hssf.HSSFTestDataSamples;
|
import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||||
import org.apache.poi.hssf.record.formula.AttrPtg;
|
import org.apache.poi.hssf.record.formula.AttrPtg;
|
||||||
import org.apache.poi.hssf.record.formula.Ptg;
|
import org.apache.poi.hssf.record.formula.Ptg;
|
||||||
import org.apache.poi.hssf.record.formula.RefPtgBase;
|
|
||||||
import org.apache.poi.hssf.usermodel.FormulaExtractor;
|
import org.apache.poi.hssf.usermodel.FormulaExtractor;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFCell;
|
import org.apache.poi.hssf.usermodel.HSSFCell;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFRow;
|
import org.apache.poi.hssf.usermodel.HSSFRow;
|
||||||
|
@ -60,7 +59,7 @@ public final class TestRVA extends TestCase {
|
||||||
}
|
}
|
||||||
String formula = cell.getCellFormula();
|
String formula = cell.getCellFormula();
|
||||||
try {
|
try {
|
||||||
confirmCell(cell, formula);
|
confirmCell(cell, formula, wb);
|
||||||
} catch (AssertionFailedError e) {
|
} catch (AssertionFailedError e) {
|
||||||
System.err.println("Problem with row[" + rowIx + "] formula '" + formula + "'");
|
System.err.println("Problem with row[" + rowIx + "] formula '" + formula + "'");
|
||||||
System.err.println(e.getMessage());
|
System.err.println(e.getMessage());
|
||||||
|
@ -79,9 +78,9 @@ public final class TestRVA extends TestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void confirmCell(HSSFCell formulaCell, String formula) {
|
private void confirmCell(HSSFCell formulaCell, String formula, HSSFWorkbook wb) {
|
||||||
Ptg[] excelPtgs = FormulaExtractor.getPtgs(formulaCell);
|
Ptg[] excelPtgs = FormulaExtractor.getPtgs(formulaCell);
|
||||||
Ptg[] poiPtgs = FormulaParser.parse(formula, null);
|
Ptg[] poiPtgs = FormulaParser.parse(formula, wb);
|
||||||
int nExcelTokens = excelPtgs.length;
|
int nExcelTokens = excelPtgs.length;
|
||||||
int nPoiTokens = poiPtgs.length;
|
int nPoiTokens = poiPtgs.length;
|
||||||
if (nExcelTokens != nPoiTokens) {
|
if (nExcelTokens != nPoiTokens) {
|
||||||
|
@ -122,6 +121,10 @@ public final class TestRVA extends TestCase {
|
||||||
}
|
}
|
||||||
sb.append(NEW_LINE);
|
sb.append(NEW_LINE);
|
||||||
}
|
}
|
||||||
|
if (false) { // set 'true' to see trace of RVA values
|
||||||
|
System.out.println(formula);
|
||||||
|
System.out.println(sb.toString());
|
||||||
|
}
|
||||||
if (hasMismatch) {
|
if (hasMismatch) {
|
||||||
throw new AssertionFailedError(sb.toString());
|
throw new AssertionFailedError(sb.toString());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue