mirror of
https://github.com/apache/poi.git
synced 2026-02-27 20:40:08 +08:00
tag r1873869 as 4.1.2
git-svn-id: https://svn.apache.org/repos/asf/poi/tags/REL_4_1_2@1873870 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
commit
30388294ec
@ -10,7 +10,7 @@ def triggerSundays = '''
|
||||
H H * * 0
|
||||
'''
|
||||
|
||||
def xercesUrl = 'http://repo1.maven.org/maven2/xerces/xercesImpl/2.6.1/xercesImpl-2.6.1.jar'
|
||||
def xercesUrl = 'https://repo1.maven.org/maven2/xerces/xercesImpl/2.6.1/xercesImpl-2.6.1.jar'
|
||||
def xercesLib = './xercesImpl-2.6.1.jar'
|
||||
|
||||
def poijobs = [
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
Apache POI
|
||||
Copyright 2003-2019 The Apache Software Foundation
|
||||
Copyright 2003-2020 The Apache Software Foundation
|
||||
|
||||
This product includes software developed at
|
||||
The Apache Software Foundation (https://www.apache.org/).
|
||||
@ -17,7 +17,7 @@ Research Consortium for Informatics and Mathematics, Keio University)
|
||||
This product contains the chunks_parse_cmds.tbl file from the vsdump program.
|
||||
Copyright (C) 2006-2007 Valek Filippov (frob@df.ru)
|
||||
|
||||
This product contains parts of the eID Applet project
|
||||
This product contains parts of the eID Applet project
|
||||
<http://eid-applet.googlecode.com> and <https://github.com/e-Contract/eid-applet>.
|
||||
Copyright (c) 2009-2014
|
||||
FedICT (federal ICT department of Belgium), e-Contract.be BVBA (https://www.e-contract.be),
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
<?xml version="1.0"?>
|
||||
<!--
|
||||
<!--
|
||||
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
|
||||
@ -25,7 +25,7 @@ under the License.
|
||||
<property name="bundle.lib" location="osgi/lib"/>
|
||||
|
||||
<!-- TODO Import these from the parent build file -->
|
||||
<property name="repository.m2" value="http://repo1.maven.org"/>
|
||||
<property name="repository.m2" value="https://repo1.maven.org"/>
|
||||
<property name="version.id" value="4.1.2-SNAPSHOT"/>
|
||||
<property name="dist.dir" value="build/dist"/>
|
||||
|
||||
@ -54,13 +54,13 @@ under the License.
|
||||
<target name="bundle" depends="init, check-bundle-jars, fetch-bundle-jars">
|
||||
<taskdef resource="aQute/bnd/ant/taskdef.properties" classpath="${bundle.bnd.jar}"/>
|
||||
<mkdir dir="build/osgi"/>
|
||||
<bnd
|
||||
<bnd
|
||||
classpath="${dist.dir}/poi-${version.id}-${DSTAMP}.jar,${dist.dir}/poi-scratchpad-${version.id}-${DSTAMP}.jar,${dist.dir}/poi-ooxml-${version.id}-${DSTAMP}.jar"
|
||||
eclipse="false"
|
||||
failok="false"
|
||||
exceptions="true"
|
||||
eclipse="false"
|
||||
failok="false"
|
||||
exceptions="true"
|
||||
output="build/osgi"
|
||||
files="test.bnd"/>
|
||||
files="test.bnd"/>
|
||||
<!-- TODO Include the settings from http://svn.apache.org/repos/asf/servicemix/smx4/bundles/trunk/poi-3.9/pom.xml -->
|
||||
<!-- TODO Make this actually spit out an OSGi Jar -->
|
||||
</target>
|
||||
|
||||
@ -327,6 +327,7 @@ public class TestAllFiles {
|
||||
"spreadsheet/testEXCEL_95.xls",
|
||||
"spreadsheet/59074.xls",
|
||||
"spreadsheet/60284.xls",
|
||||
"spreadsheet/64130.xls",
|
||||
|
||||
// OOXML Strict is not yet supported, see bug #57699
|
||||
"spreadsheet/SampleSS.strict.xlsx",
|
||||
|
||||
@ -47,15 +47,17 @@ public final class OldSheetRecord {
|
||||
field_2_visibility = in.readUByte();
|
||||
field_3_type = in.readUByte();
|
||||
int field_4_sheetname_length = in.readUByte();
|
||||
in.mark(1);
|
||||
byte b = in.readByte();
|
||||
// if the sheet name starts with a 0, we need to skip one byte, otherwise the following records will
|
||||
// fail with a LeftOverDataException
|
||||
if (b != 0) {
|
||||
try {
|
||||
in.reset();
|
||||
} catch (IOException e) {
|
||||
throw new RecordFormatException(e);
|
||||
if (field_4_sheetname_length > 0) {
|
||||
in.mark(1);
|
||||
byte b = in.readByte();
|
||||
// if the sheet name starts with a 0, we need to skip one byte, otherwise the following records will
|
||||
// fail with a LeftOverDataException
|
||||
if (b != 0) {
|
||||
try {
|
||||
in.reset();
|
||||
} catch (IOException e) {
|
||||
throw new RecordFormatException(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
field_5_sheetname = IOUtils.safelyAllocate(field_4_sheetname_length, MAX_RECORD_LENGTH);
|
||||
|
||||
@ -45,6 +45,7 @@ public class TestBiffDrawingToXml extends BaseXLSIteratingTest {
|
||||
EXCLUDED.put("43493.xls", RecordInputStream.LeftoverDataException.class); // HSSFWorkbook cannot open it as well
|
||||
EXCLUDED.put("44958_1.xls", RecordInputStream.LeftoverDataException.class);
|
||||
EXCLUDED.put("61300.xls", RecordFormatException.class);
|
||||
EXCLUDED.put("64130.xls", OldExcelFormatException.class); // BIFF 5
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@ -54,6 +54,7 @@ public class TestBiffViewer extends BaseXLSIteratingTest {
|
||||
EXCLUDED.put("50833.xls", IllegalArgumentException.class); // "Name is too long" when setting username
|
||||
EXCLUDED.put("XRefCalc.xls", RuntimeException.class); // "Buffer overrun"
|
||||
EXCLUDED.put("61300.xls", RecordFormatException.class);
|
||||
EXCLUDED.put("64130.xls", OldExcelFormatException.class); //Biff 5
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@ -47,6 +47,7 @@ public class TestEFBiffViewer extends BaseXLSIteratingTest {
|
||||
EXCLUDED.put("44958_1.xls", RecordInputStream.LeftoverDataException.class);
|
||||
EXCLUDED.put("XRefCalc.xls", RuntimeException.class); // "Buffer overrun"
|
||||
EXCLUDED.put("61300.xls", RecordFormatException.class);
|
||||
EXCLUDED.put("64130.xls", OldExcelFormatException.class); //Biff 5
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@ -47,6 +47,7 @@ public class TestFormulaViewer extends BaseXLSIteratingTest {
|
||||
EXCLUDED.put("43493.xls", RecordInputStream.LeftoverDataException.class); // HSSFWorkbook cannot open it as well
|
||||
EXCLUDED.put("44958_1.xls", RecordInputStream.LeftoverDataException.class);
|
||||
EXCLUDED.put("61300.xls", RecordFormatException.class);
|
||||
EXCLUDED.put("64130.xls", OldExcelFormatException.class); //Biff 5
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@ -51,6 +51,7 @@ public class TestReSave extends BaseXLSIteratingTest {
|
||||
EXCLUDED.put("44958_1.xls", RecordInputStream.LeftoverDataException.class);
|
||||
EXCLUDED.put("XRefCalc.xls", RuntimeException.class); // "Buffer overrun"
|
||||
EXCLUDED.put("61300.xls", RecordFormatException.class);
|
||||
EXCLUDED.put("64130.xls", OldExcelFormatException.class); //Biff 5
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@ -38,7 +38,7 @@ public class TestRecordLister extends BaseXLSIteratingTest {
|
||||
EXCLUDED.put("60284.xls", OldExcelFormatException.class); // Biff 5 / Excel 5
|
||||
EXCLUDED.put("testEXCEL_95.xls", OldExcelFormatException.class); // Biff 5 / Excel 95
|
||||
EXCLUDED.put("61300.xls", RecordFormatException.class);
|
||||
|
||||
EXCLUDED.put("64130.xls", OldExcelFormatException.class); //Biff 5
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@ -267,6 +267,10 @@ public final class TestOldExcelExtractor {
|
||||
|
||||
@Test
|
||||
public void testInputStreamNPOIHeader() throws IOException {
|
||||
//TODO: the worksheet names are currently mangled. They're treated
|
||||
//as if UTF-16, but they're just ascii. Need to fix this.
|
||||
//Is it possible that the leading 0 byte in the worksheet name is a signal
|
||||
//that these worksheet names should be interpreted as ascii/1252?
|
||||
File file = HSSFTestDataSamples.getSampleFile("FormulaRefs.xls");
|
||||
try (InputStream stream = new FileInputStream(file);
|
||||
OldExcelExtractor extractor = new OldExcelExtractor(stream)) {
|
||||
@ -350,6 +354,17 @@ public final class TestOldExcelExtractor {
|
||||
}
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSheetWithNoName() throws IOException {
|
||||
File file = HSSFTestDataSamples.getSampleFile("64130.xls");
|
||||
|
||||
try (OldExcelExtractor ex = new OldExcelExtractor(file)) {
|
||||
assertEquals(5, ex.getBiffVersion());
|
||||
assertEquals(5, ex.getFileType());
|
||||
assertContains(ex.getText(), "Dawn");
|
||||
}
|
||||
}
|
||||
|
||||
private static class NoExitSecurityManager extends SecurityManager {
|
||||
@Override
|
||||
public void checkPermission(Permission perm) {
|
||||
|
||||
BIN
test-data/spreadsheet/64130.xls
Normal file
BIN
test-data/spreadsheet/64130.xls
Normal file
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user