aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/org/apache
diff options
context:
space:
mode:
Diffstat (limited to 'src/java/org/apache')
-rw-r--r--src/java/org/apache/poi/extractor/ExtractorFactory.java3
-rw-r--r--src/java/org/apache/poi/extractor/MainExtractorFactory.java1
-rw-r--r--src/java/org/apache/poi/hssf/dev/ReSave.java26
-rw-r--r--src/java/org/apache/poi/hssf/model/InternalWorkbook.java2
-rw-r--r--src/java/org/apache/poi/hssf/record/GridsetRecord.java2
-rw-r--r--src/java/org/apache/poi/hssf/record/PageBreakRecord.java18
-rw-r--r--src/java/org/apache/poi/hssf/record/PrecisionRecord.java2
-rw-r--r--src/java/org/apache/poi/hssf/record/TabIdRecord.java10
-rw-r--r--src/java/org/apache/poi/hssf/record/aggregates/PageSettingsBlock.java24
-rw-r--r--src/java/org/apache/poi/hssf/record/common/PhRun.java10
-rw-r--r--src/java/org/apache/poi/poifs/common/POIFSConstants.java9
-rw-r--r--src/java/org/apache/poi/poifs/crypt/agile/AgileDecryptor.java1
-rw-r--r--src/java/org/apache/poi/poifs/crypt/binaryrc4/BinaryRC4Decryptor.java2
-rw-r--r--src/java/org/apache/poi/poifs/filesystem/FileMagic.java41
-rw-r--r--src/java/org/apache/poi/poifs/filesystem/POIFSFileSystem.java1
-rw-r--r--src/java/org/apache/poi/sl/draw/DrawTextParagraph.java2
-rw-r--r--src/java/org/apache/poi/sl/usermodel/SlideShowFactory.java4
-rw-r--r--src/java/org/apache/poi/ss/formula/SheetIdentifier.java4
-rw-r--r--src/java/org/apache/poi/ss/formula/SheetRangeIdentifier.java2
-rw-r--r--src/java/org/apache/poi/ss/formula/atp/YearFracCalculator.java2
-rw-r--r--src/java/org/apache/poi/ss/formula/functions/LinearRegressionFunction.java2
-rw-r--r--src/java/org/apache/poi/ss/formula/functions/Trend.java11
-rw-r--r--src/java/org/apache/poi/ss/usermodel/WorkbookFactory.java2
-rw-r--r--src/java/org/apache/poi/ss/util/cellwalk/CellWalk.java27
-rw-r--r--src/java/org/apache/poi/util/DrawingDump.java17
-rw-r--r--src/java/org/apache/poi/util/IOUtils.java8
26 files changed, 123 insertions, 110 deletions
diff --git a/src/java/org/apache/poi/extractor/ExtractorFactory.java b/src/java/org/apache/poi/extractor/ExtractorFactory.java
index 0833535189..b45b5e29e2 100644
--- a/src/java/org/apache/poi/extractor/ExtractorFactory.java
+++ b/src/java/org/apache/poi/extractor/ExtractorFactory.java
@@ -178,6 +178,7 @@ public final class ExtractorFactory {
return createExtractor(file, getCurrentUserPassword());
}
+ @SuppressWarnings({"java:S2095"})
public static POITextExtractor createExtractor(File file, String password) throws IOException {
if (file.length() == 0) {
throw new EmptyFileException();
@@ -318,6 +319,6 @@ public final class ExtractorFactory {
}
public static void removeProvider(Class<? extends ExtractorProvider> provider){
- Singleton.INSTANCE.provider.removeIf(p -> p.getClass().getName().equals(provider.getName()));
+ Singleton.INSTANCE.provider.removeIf(p -> p.getClass().isAssignableFrom(provider));
}
}
diff --git a/src/java/org/apache/poi/extractor/MainExtractorFactory.java b/src/java/org/apache/poi/extractor/MainExtractorFactory.java
index 7f8733eecf..d485f864ff 100644
--- a/src/java/org/apache/poi/extractor/MainExtractorFactory.java
+++ b/src/java/org/apache/poi/extractor/MainExtractorFactory.java
@@ -41,6 +41,7 @@ public class MainExtractorFactory implements ExtractorProvider {
return FileMagic.OLE2 == fm;
}
+ @SuppressWarnings({"java:S2095"})
@Override
public POITextExtractor create(File file, String password) throws IOException {
return create(new POIFSFileSystem(file, true).getRoot(), password);
diff --git a/src/java/org/apache/poi/hssf/dev/ReSave.java b/src/java/org/apache/poi/hssf/dev/ReSave.java
index 7f19888973..2f31eb48d8 100644
--- a/src/java/org/apache/poi/hssf/dev/ReSave.java
+++ b/src/java/org/apache/poi/hssf/dev/ReSave.java
@@ -37,7 +37,6 @@ public class ReSave {
public static void main(String[] args) throws Exception {
boolean initDrawing = false;
boolean saveToMemory = false;
- ByteArrayOutputStream bos = new ByteArrayOutputStream();
for(String filename : args) {
if(filename.equals("-dg")) {
initDrawing = true;
@@ -45,11 +44,10 @@ public class ReSave {
saveToMemory = true;
} else {
System.out.print("reading " + filename + "...");
- FileInputStream is = new FileInputStream(filename);
- HSSFWorkbook wb = new HSSFWorkbook(is);
- try {
+ try (FileInputStream is = new FileInputStream(filename);
+ HSSFWorkbook wb = new HSSFWorkbook(is)) {
System.out.println("done");
-
+
for(int i = 0; i < wb.getNumberOfSheets(); i++){
HSSFSheet sheet = wb.getSheetAt(i);
if(initDrawing) {
@@ -57,25 +55,15 @@ public class ReSave {
}
}
- OutputStream os;
- if (saveToMemory) {
- bos.reset();
- os = bos;
- } else {
- String outputFile = filename.replace(".xls", "-saved.xls");
+ String outputFile = filename.replace(".xls", "-saved.xls");
+ if (!saveToMemory) {
System.out.print("saving to " + outputFile + "...");
- os = new FileOutputStream(outputFile);
}
-
- try {
+
+ try (OutputStream os = saveToMemory ? new ByteArrayOutputStream() : new FileOutputStream(outputFile)) {
wb.write(os);
- } finally {
- os.close();
}
System.out.println("done");
- } finally {
- wb.close();
- is.close();
}
}
}
diff --git a/src/java/org/apache/poi/hssf/model/InternalWorkbook.java b/src/java/org/apache/poi/hssf/model/InternalWorkbook.java
index 8ddb368e0a..e1d4f85718 100644
--- a/src/java/org/apache/poi/hssf/model/InternalWorkbook.java
+++ b/src/java/org/apache/poi/hssf/model/InternalWorkbook.java
@@ -1052,7 +1052,7 @@ public final class InternalWorkbook {
// Can be a few short if new sheets were added
if(records.getTabpos() > 0) {
TabIdRecord tir = ( TabIdRecord ) records.get(records.getTabpos());
- if(tir._tabids.length < boundsheets.size()) {
+ if(tir.getTabIdSize() < boundsheets.size()) {
fixTabIdRecord();
}
}
diff --git a/src/java/org/apache/poi/hssf/record/GridsetRecord.java b/src/java/org/apache/poi/hssf/record/GridsetRecord.java
index d5f705071f..b5cfd92055 100644
--- a/src/java/org/apache/poi/hssf/record/GridsetRecord.java
+++ b/src/java/org/apache/poi/hssf/record/GridsetRecord.java
@@ -30,7 +30,7 @@ import org.apache.poi.util.LittleEndianOutput;
*/
public final class GridsetRecord extends StandardRecord {
public static final short sid = 0x82;
- public short field_1_gridset_flag;
+ private short field_1_gridset_flag;
public GridsetRecord() {}
diff --git a/src/java/org/apache/poi/hssf/record/PageBreakRecord.java b/src/java/org/apache/poi/hssf/record/PageBreakRecord.java
index 99369d9ae3..402c04d02c 100644
--- a/src/java/org/apache/poi/hssf/record/PageBreakRecord.java
+++ b/src/java/org/apache/poi/hssf/record/PageBreakRecord.java
@@ -53,9 +53,9 @@ public abstract class PageBreakRecord extends StandardRecord {
public static final class Break implements GenericRecord {
public static final int ENCODED_SIZE = 6;
- public int main;
- public int subFrom;
- public int subTo;
+ private int main;
+ private int subFrom;
+ private int subTo;
public Break(Break other) {
main = other.main;
@@ -75,6 +75,18 @@ public abstract class PageBreakRecord extends StandardRecord {
subTo = in.readUShort();
}
+ public int getMain() {
+ return main;
+ }
+
+ public int getSubFrom() {
+ return subFrom;
+ }
+
+ public int getSubTo() {
+ return subTo;
+ }
+
public void serialize(LittleEndianOutput out) {
out.writeShort(main + 1);
out.writeShort(subFrom);
diff --git a/src/java/org/apache/poi/hssf/record/PrecisionRecord.java b/src/java/org/apache/poi/hssf/record/PrecisionRecord.java
index 49cbf31de5..27471b935f 100644
--- a/src/java/org/apache/poi/hssf/record/PrecisionRecord.java
+++ b/src/java/org/apache/poi/hssf/record/PrecisionRecord.java
@@ -32,7 +32,7 @@ import org.apache.poi.util.LittleEndianOutput;
public final class PrecisionRecord extends StandardRecord {
public static final short sid = 0xE;
- public short field_1_precision;
+ private short field_1_precision;
public PrecisionRecord() {}
diff --git a/src/java/org/apache/poi/hssf/record/TabIdRecord.java b/src/java/org/apache/poi/hssf/record/TabIdRecord.java
index 2fc905bb9e..c76a396bd7 100644
--- a/src/java/org/apache/poi/hssf/record/TabIdRecord.java
+++ b/src/java/org/apache/poi/hssf/record/TabIdRecord.java
@@ -30,7 +30,7 @@ public final class TabIdRecord extends StandardRecord {
public static final short sid = 0x013D;
private static final short[] EMPTY_SHORT_ARRAY = { };
- public short[] _tabids;
+ private short[] _tabids;
public TabIdRecord() {
_tabids = EMPTY_SHORT_ARRAY;
@@ -63,6 +63,14 @@ public final class TabIdRecord extends StandardRecord {
}
}
+ public int getTabIdSize() {
+ return _tabids.length;
+ }
+
+ public short getTabIdAt(int index) {
+ return _tabids[index];
+ }
+
protected int getDataSize() {
return _tabids.length * 2;
}
diff --git a/src/java/org/apache/poi/hssf/record/aggregates/PageSettingsBlock.java b/src/java/org/apache/poi/hssf/record/aggregates/PageSettingsBlock.java
index 78b93a0e41..c8d931f349 100644
--- a/src/java/org/apache/poi/hssf/record/aggregates/PageSettingsBlock.java
+++ b/src/java/org/apache/poi/hssf/record/aggregates/PageSettingsBlock.java
@@ -121,7 +121,7 @@ public final class PageSettingsBlock extends RecordAggregate {
/**
* @param sid the record sid
- *
+ *
* @return <code>true</code> if the specified Record sid is one belonging to the
* 'Page Settings Block'.
*/
@@ -486,7 +486,7 @@ public final class PageSettingsBlock extends RecordAggregate {
while(iterator.hasNext())
{
PageBreakRecord.Break breakItem = iterator.next();
- int breakLocation = breakItem.main;
+ int breakLocation = breakItem.getMain();
boolean inStart = (breakLocation >= start);
boolean inEnd = (breakLocation <= stop);
if(inStart && inEnd) {
@@ -497,8 +497,8 @@ public final class PageSettingsBlock extends RecordAggregate {
iterator = shiftedBreak.iterator();
while (iterator.hasNext()) {
PageBreakRecord.Break breakItem = iterator.next();
- breaks.removeBreak(breakItem.main);
- breaks.addBreak((short)(breakItem.main+count), breakItem.subFrom, breakItem.subTo);
+ breaks.removeBreak(breakItem.getMain());
+ breaks.addBreak((short)(breakItem.getMain()+count), breakItem.getSubFrom(), breakItem.getSubTo());
}
}
@@ -526,9 +526,9 @@ public final class PageSettingsBlock extends RecordAggregate {
/**
* Queries if the specified row has a page break
- *
+ *
* @param row the row to check for
- *
+ *
* @return true if the specified row has a page break
*/
public boolean isRowBroken(int row) {
@@ -538,7 +538,7 @@ public final class PageSettingsBlock extends RecordAggregate {
/**
* Queries if the specified column has a page break
- *
+ *
* @param column the column to check for
*
* @return <code>true</code> if the specified column has a page break
@@ -606,7 +606,7 @@ public final class PageSettingsBlock extends RecordAggregate {
/**
* HEADERFOOTER is new in 2007. Some apps seem to have scattered this record long after
* the {@link PageSettingsBlock} where it belongs.
- *
+ *
* @param rec the HeaderFooterRecord to set
*/
public void addLateHeaderFooter(HeaderFooterRecord rec) {
@@ -623,10 +623,10 @@ public final class PageSettingsBlock extends RecordAggregate {
* This method reads PageSettingsBlock records from the supplied RecordStream until the first
* non-PageSettingsBlock record is encountered. As each record is read, it is incorporated
* into this PageSettingsBlock.<p>
- *
+ *
* The latest Excel version seems to write the PageSettingsBlock uninterrupted. However there
* are several examples (that Excel reads OK) where these records are not written together:
- *
+ *
* <ul>
* <li><b>HEADER_FOOTER(0x089C) after WINDOW2</b> - This record is new in 2007. Some apps
* seem to have scattered this record long after the PageSettingsBlock where it belongs
@@ -635,7 +635,7 @@ public final class PageSettingsBlock extends RecordAggregate {
* This happens in the test sample file "NoGutsRecords.xls" and "WORKBOOK_in_capitals.xls"</li>
* <li><b>Margins after DIMENSION</b> - All of PSB should be before DIMENSION. (Bug-47199)</li>
* </ul>
- *
+ *
* These were probably written by other applications (or earlier versions of Excel). It was
* decided to not write specific code for detecting each of these cases. POI now tolerates
* PageSettingsBlock records scattered all over the sheet record stream, and in any order, but
@@ -646,7 +646,7 @@ public final class PageSettingsBlock extends RecordAggregate {
* were when they were originally read.
*
* @param rs the RecordStream to read from
- *
+ *
* @throws org.apache.poi.util.RecordFormatException if any PSB record encountered has the same type (sid) as
* a record that is already part of this PageSettingsBlock
*/
diff --git a/src/java/org/apache/poi/hssf/record/common/PhRun.java b/src/java/org/apache/poi/hssf/record/common/PhRun.java
index 2f5a9229da..404efb0bd0 100644
--- a/src/java/org/apache/poi/hssf/record/common/PhRun.java
+++ b/src/java/org/apache/poi/hssf/record/common/PhRun.java
@@ -59,4 +59,14 @@ public class PhRun {
public int hashCode() {
return Objects.hash(phoneticTextFirstCharacterOffset, realTextFirstCharacterOffset, realTextLength);
}
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ PhRun phRun = (PhRun) o;
+ return phoneticTextFirstCharacterOffset == phRun.phoneticTextFirstCharacterOffset
+ && realTextFirstCharacterOffset == phRun.realTextFirstCharacterOffset
+ && realTextLength == phRun.realTextLength;
+ }
}
diff --git a/src/java/org/apache/poi/poifs/common/POIFSConstants.java b/src/java/org/apache/poi/poifs/common/POIFSConstants.java
index 7cacb68fe8..f3804a90be 100644
--- a/src/java/org/apache/poi/poifs/common/POIFSConstants.java
+++ b/src/java/org/apache/poi/poifs/common/POIFSConstants.java
@@ -57,11 +57,4 @@ public interface POIFSConstants
int END_OF_CHAIN = -2;
/** Indicates the sector is not used (0xFFFFFFFF) */
int UNUSED_BLOCK = -1;
-
- /** The first 4 bytes of an OOXML file, used in detection */
- byte[] OOXML_FILE_HEADER =
- new byte[] { 0x50, 0x4b, 0x03, 0x04 };
- /** The first 5 bytes of a raw XML file, used in detection */
- byte[] RAW_XML_FILE_HEADER =
- new byte[] { 0x3c, 0x3f, 0x78, 0x6d, 0x6c };
-} // end public interface POIFSConstants;
+}
diff --git a/src/java/org/apache/poi/poifs/crypt/agile/AgileDecryptor.java b/src/java/org/apache/poi/poifs/crypt/agile/AgileDecryptor.java
index f8efe0d201..898670eaba 100644
--- a/src/java/org/apache/poi/poifs/crypt/agile/AgileDecryptor.java
+++ b/src/java/org/apache/poi/poifs/crypt/agile/AgileDecryptor.java
@@ -205,6 +205,7 @@ public class AgileDecryptor extends Decryptor {
}
}
+ @SuppressWarnings({"java:S2095"})
@Override
public InputStream getDataStream(DirectoryNode dir) throws IOException, GeneralSecurityException {
DocumentInputStream dis = dir.createDocumentInputStream(DEFAULT_POIFS_ENTRY);
diff --git a/src/java/org/apache/poi/poifs/crypt/binaryrc4/BinaryRC4Decryptor.java b/src/java/org/apache/poi/poifs/crypt/binaryrc4/BinaryRC4Decryptor.java
index 3aec22e55f..ff14f19ab3 100644
--- a/src/java/org/apache/poi/poifs/crypt/binaryrc4/BinaryRC4Decryptor.java
+++ b/src/java/org/apache/poi/poifs/crypt/binaryrc4/BinaryRC4Decryptor.java
@@ -140,7 +140,7 @@ public class BinaryRC4Decryptor extends Decryptor {
}
@Override
- @SuppressWarnings("resource")
+ @SuppressWarnings({"java:S2095","resource"})
public ChunkedCipherInputStream getDataStream(DirectoryNode dir) throws IOException,
GeneralSecurityException {
DocumentInputStream dis = dir.createDocumentInputStream(DEFAULT_POIFS_ENTRY);
diff --git a/src/java/org/apache/poi/poifs/filesystem/FileMagic.java b/src/java/org/apache/poi/poifs/filesystem/FileMagic.java
index 501db481a6..60667f88a5 100644
--- a/src/java/org/apache/poi/poifs/filesystem/FileMagic.java
+++ b/src/java/org/apache/poi/poifs/filesystem/FileMagic.java
@@ -17,9 +17,6 @@
package org.apache.poi.poifs.filesystem;
-import static org.apache.poi.poifs.common.POIFSConstants.OOXML_FILE_HEADER;
-import static org.apache.poi.poifs.common.POIFSConstants.RAW_XML_FILE_HEADER;
-
import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
@@ -39,24 +36,24 @@ import org.apache.poi.util.LocaleUtil;
public enum FileMagic {
/** OLE2 / BIFF8+ stream used for Office 97 and higher documents */
OLE2(HeaderBlockConstants._signature),
- /** OOXML / ZIP stream */
- OOXML(OOXML_FILE_HEADER),
- /** XML file */
- XML(RAW_XML_FILE_HEADER),
+ /** OOXML / ZIP stream - The first 4 bytes of an OOXML file, used in detection */
+ OOXML(0x50, 0x4b, 0x03, 0x04),
+ /** XML file - The first 5 bytes of a raw XML file, used in detection */
+ XML(0x3c, 0x3f, 0x78, 0x6d, 0x6c),
/** BIFF2 raw stream - for Excel 2 */
- BIFF2(new byte[]{
+ BIFF2(
0x09, 0x00, // sid=0x0009
0x04, 0x00, // size=0x0004
0x00, 0x00, // unused
'?', 0x00 // '?' = multiple values
- }),
+ ),
/** BIFF3 raw stream - for Excel 3 */
- BIFF3(new byte[]{
+ BIFF3(
0x09, 0x02, // sid=0x0209
0x06, 0x00, // size=0x0006
0x00, 0x00, // unused
'?', 0x00 // '?' = multiple values
- }),
+ ),
/** BIFF4 raw stream - for Excel 4 */
BIFF4(new byte[]{
0x09, 0x04, // sid=0x0409
@@ -81,7 +78,7 @@ public enum FileMagic {
HTML("<!DOCTYP",
"<html","\n\r<html","\r\n<html","\r<html","\n<html",
"<HTML","\r\n<HTML","\n\r<HTML","\r<HTML","\n<HTML"),
- WORD2(new byte[]{ (byte)0xdb, (byte)0xa5, 0x2d, 0x00}),
+ WORD2(0xdb, 0xa5, 0x2d, 0x00),
/** JPEG image */
JPEG(
new byte[]{ (byte)0xFF, (byte)0xD8, (byte)0xFF, (byte)0xDB },
@@ -91,20 +88,18 @@ public enum FileMagic {
/** GIF image */
GIF("GIF87a","GIF89a"),
/** PNG Image */
- PNG(new byte[]{ (byte)0x89, 'P', 'N', 'G', 0x0D, 0x0A, 0x1A, 0x0A }),
+ PNG(0x89, 'P', 'N', 'G', 0x0D, 0x0A, 0x1A, 0x0A),
/** TIFF Image */
TIFF("II*\u0000", "MM\u0000*" ),
/** WMF image with a placeable header */
- WMF(new byte[]{ (byte)0xD7, (byte)0xCD, (byte)0xC6, (byte)0x9A }),
+ WMF(0xD7, 0xCD, 0xC6, 0x9A),
/** EMF image */
- EMF(new byte[]{
- 1, 0, 0, 0,
+ EMF(1, 0, 0, 0,
'?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?',
'?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?', '?',
- ' ', 'E', 'M', 'F'
- }),
+ ' ', 'E', 'M', 'F'),
/** BMP image */
- BMP(new byte[]{'B','M'}),
+ BMP('B','M'),
// keep UNKNOWN always as last enum!
/** UNKNOWN magic */
UNKNOWN(new byte[0]);
@@ -119,6 +114,14 @@ public enum FileMagic {
LittleEndian.putLong(this.magic[0], 0, magic);
}
+ FileMagic(int... magic) {
+ byte[] one = new byte[magic.length];
+ for (int i=0; i<magic.length; i++) {
+ one[i] = (byte)(magic[i] & 0xFF);
+ }
+ this.magic = new byte[][]{ one };
+ }
+
FileMagic(byte[]... magic) {
this.magic = magic;
}
diff --git a/src/java/org/apache/poi/poifs/filesystem/POIFSFileSystem.java b/src/java/org/apache/poi/poifs/filesystem/POIFSFileSystem.java
index 22577980a3..20fc398e27 100644
--- a/src/java/org/apache/poi/poifs/filesystem/POIFSFileSystem.java
+++ b/src/java/org/apache/poi/poifs/filesystem/POIFSFileSystem.java
@@ -204,6 +204,7 @@ public class POIFSFileSystem extends BlockStore
this(channel, null, readOnly, false);
}
+ @SuppressWarnings("java:S2095")
private POIFSFileSystem(FileChannel channel, File srcFile, boolean readOnly, boolean closeChannelOnError)
throws IOException {
this(false);
diff --git a/src/java/org/apache/poi/sl/draw/DrawTextParagraph.java b/src/java/org/apache/poi/sl/draw/DrawTextParagraph.java
index b3d70fff26..e047b3468d 100644
--- a/src/java/org/apache/poi/sl/draw/DrawTextParagraph.java
+++ b/src/java/org/apache/poi/sl/draw/DrawTextParagraph.java
@@ -177,7 +177,7 @@ public class DrawTextParagraph implements Drawable {
penY -= line.getLayout().getAscent();
}
- penX = x + (isHSLF ? leftMargin : leftMargin);
+ penX = x + leftMargin;
if (lastLine == null) {
if (!isEmptyParagraph()) {
// TODO: find out character style for empty, but bulleted/numbered lines
diff --git a/src/java/org/apache/poi/sl/usermodel/SlideShowFactory.java b/src/java/org/apache/poi/sl/usermodel/SlideShowFactory.java
index a69efaf8f8..cb0607de61 100644
--- a/src/java/org/apache/poi/sl/usermodel/SlideShowFactory.java
+++ b/src/java/org/apache/poi/sl/usermodel/SlideShowFactory.java
@@ -298,7 +298,7 @@ public final class SlideShowFactory {
Singleton.INSTANCE.provider.add(provider);
}
- public static void removeProvider(Class<? extends SlideShowProvider> provider){
- Singleton.INSTANCE.provider.removeIf(p -> p.getClass().getName().equals(provider.getName()));
+ public static void removeProvider(Class<? extends SlideShowProvider<?,?>> provider){
+ Singleton.INSTANCE.provider.removeIf(p -> p.getClass().isAssignableFrom(provider));
}
}
diff --git a/src/java/org/apache/poi/ss/formula/SheetIdentifier.java b/src/java/org/apache/poi/ss/formula/SheetIdentifier.java
index 51c0852b30..69f6f99501 100644
--- a/src/java/org/apache/poi/ss/formula/SheetIdentifier.java
+++ b/src/java/org/apache/poi/ss/formula/SheetIdentifier.java
@@ -18,8 +18,8 @@
package org.apache.poi.ss.formula;
public class SheetIdentifier {
- public String _bookName;
- public NameIdentifier _sheetIdentifier;
+ private final String _bookName;
+ private final NameIdentifier _sheetIdentifier;
public SheetIdentifier(String bookName, NameIdentifier sheetIdentifier) {
_bookName = bookName;
diff --git a/src/java/org/apache/poi/ss/formula/SheetRangeIdentifier.java b/src/java/org/apache/poi/ss/formula/SheetRangeIdentifier.java
index 8cb5b3201a..88c91991b9 100644
--- a/src/java/org/apache/poi/ss/formula/SheetRangeIdentifier.java
+++ b/src/java/org/apache/poi/ss/formula/SheetRangeIdentifier.java
@@ -18,7 +18,7 @@
package org.apache.poi.ss.formula;
public class SheetRangeIdentifier extends SheetIdentifier {
- public NameIdentifier _lastSheetIdentifier;
+ private final NameIdentifier _lastSheetIdentifier;
public SheetRangeIdentifier(String bookName, NameIdentifier firstSheetIdentifier, NameIdentifier lastSheetIdentifier) {
super(bookName, firstSheetIdentifier);
diff --git a/src/java/org/apache/poi/ss/formula/atp/YearFracCalculator.java b/src/java/org/apache/poi/ss/formula/atp/YearFracCalculator.java
index 77ed481481..aba00e7f6b 100644
--- a/src/java/org/apache/poi/ss/formula/atp/YearFracCalculator.java
+++ b/src/java/org/apache/poi/ss/formula/atp/YearFracCalculator.java
@@ -324,7 +324,7 @@ final class YearFracCalculator {
/** day of month */
public final int day;
/** milliseconds since 1970 */
- public long tsMilliseconds;
+ public final long tsMilliseconds;
public SimpleDate(Calendar cal) {
year = cal.get(Calendar.YEAR);
diff --git a/src/java/org/apache/poi/ss/formula/functions/LinearRegressionFunction.java b/src/java/org/apache/poi/ss/formula/functions/LinearRegressionFunction.java
index aee79ab274..513daa3a1b 100644
--- a/src/java/org/apache/poi/ss/formula/functions/LinearRegressionFunction.java
+++ b/src/java/org/apache/poi/ss/formula/functions/LinearRegressionFunction.java
@@ -107,7 +107,7 @@ public final class LinearRegressionFunction extends Fixed2ArgFunction {
}
public enum FUNCTION {INTERCEPT, SLOPE}
- public FUNCTION function;
+ private final FUNCTION function;
public LinearRegressionFunction(FUNCTION function) {
this.function = function;
diff --git a/src/java/org/apache/poi/ss/formula/functions/Trend.java b/src/java/org/apache/poi/ss/formula/functions/Trend.java
index 2a1227e2db..62eb545670 100644
--- a/src/java/org/apache/poi/ss/formula/functions/Trend.java
+++ b/src/java/org/apache/poi/ss/formula/functions/Trend.java
@@ -60,11 +60,10 @@ import org.apache.poi.ss.formula.eval.ValueEval;
*/
public final class Trend implements Function {
- MatrixFunction.MutableValueCollector collector = new MatrixFunction.MutableValueCollector(false, false);
private static final class TrendResults {
- public double[] vals;
- public int resultWidth;
- public int resultHeight;
+ private final double[] vals;
+ private final int resultWidth;
+ private final int resultHeight;
public TrendResults(double[] vals, int resultWidth, int resultHeight) {
this.vals = vals;
@@ -149,7 +148,7 @@ public final class Trend implements Function {
}
double[] oneD = new double[twoD.length * twoD[0].length];
for (int i = 0; i < twoD.length; i++) {
- System.arraycopy(twoD[i], 0, oneD, i * twoD[0].length + 0, twoD[0].length);
+ System.arraycopy(twoD[i], 0, oneD, i * twoD[0].length, twoD[0].length);
}
return oneD;
}
@@ -335,7 +334,7 @@ public final class Trend implements Function {
if(isAllColumnsSame(x)){
double[] result = new double[newX.length];
double avg = Arrays.stream(y).average().orElse(0);
- for(int i = 0; i < result.length; i++) result[i] = avg;
+ Arrays.fill(result, avg);
return new TrendResults(result, resultWidth, resultHeight);
}
diff --git a/src/java/org/apache/poi/ss/usermodel/WorkbookFactory.java b/src/java/org/apache/poi/ss/usermodel/WorkbookFactory.java
index b730731f7c..c2b6e6936f 100644
--- a/src/java/org/apache/poi/ss/usermodel/WorkbookFactory.java
+++ b/src/java/org/apache/poi/ss/usermodel/WorkbookFactory.java
@@ -305,6 +305,6 @@ public final class WorkbookFactory {
}
public static void removeProvider(Class<? extends WorkbookProvider> provider){
- Singleton.INSTANCE.provider.removeIf(p -> p.getClass().getName().equals(provider.getName()));
+ Singleton.INSTANCE.provider.removeIf(p -> p.getClass().isAssignableFrom(provider));
}
}
diff --git a/src/java/org/apache/poi/ss/util/cellwalk/CellWalk.java b/src/java/org/apache/poi/ss/util/cellwalk/CellWalk.java
index 2826cc3323..d26d7a9864 100644
--- a/src/java/org/apache/poi/ss/util/cellwalk/CellWalk.java
+++ b/src/java/org/apache/poi/ss/util/cellwalk/CellWalk.java
@@ -17,6 +17,10 @@
package org.apache.poi.ss.util.cellwalk;
+import static org.apache.commons.math3.util.ArithmeticUtils.addAndCheck;
+import static org.apache.commons.math3.util.ArithmeticUtils.mulAndCheck;
+import static org.apache.commons.math3.util.ArithmeticUtils.subAndCheck;
+
import org.apache.commons.math3.util.ArithmeticUtils;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellType;
@@ -26,13 +30,11 @@ import org.apache.poi.ss.util.CellRangeAddress;
/**
* Traverse cell range.
- *
- * @author Roman Kashitsyn
*/
public class CellWalk {
- private Sheet sheet;
- private CellRangeAddress range;
+ private final Sheet sheet;
+ private final CellRangeAddress range;
private boolean traverseEmptyCells;
@@ -74,8 +76,8 @@ public class CellWalk {
int lastColumn = range.getLastColumn();
final int width = lastColumn - firstColumn + 1;
SimpleCellWalkContext ctx = new SimpleCellWalkContext();
- Row currentRow = null;
- Cell currentCell = null;
+ Row currentRow;
+ Cell currentCell;
for (ctx.rowNumber = firstRow; ctx.rowNumber <= lastRow; ++ctx.rowNumber) {
currentRow = sheet.getRow(ctx.rowNumber);
@@ -92,10 +94,9 @@ public class CellWalk {
continue;
}
- long rowSize = ArithmeticUtils.mulAndCheck(
- (long)ArithmeticUtils.subAndCheck(ctx.rowNumber, firstRow), (long)width);
+ long rowSize = mulAndCheck(subAndCheck(ctx.rowNumber, firstRow), (long)width);
- ctx.ordinalNumber = ArithmeticUtils.addAndCheck(rowSize, (ctx.colNumber - firstColumn + 1));
+ ctx.ordinalNumber = addAndCheck(rowSize, (ctx.colNumber - firstColumn + 1));
handler.onCell(currentCell, ctx);
}
@@ -108,13 +109,11 @@ public class CellWalk {
/**
* Inner class to hold walk context.
- *
- * @author Roman Kashitsyn
*/
private static class SimpleCellWalkContext implements CellWalkContext {
- public long ordinalNumber;
- public int rowNumber;
- public int colNumber;
+ private long ordinalNumber;
+ private int rowNumber;
+ private int colNumber;
@Override
public long getOrdinalNumber() {
diff --git a/src/java/org/apache/poi/util/DrawingDump.java b/src/java/org/apache/poi/util/DrawingDump.java
index ef7b2d29ac..72d9580b65 100644
--- a/src/java/org/apache/poi/util/DrawingDump.java
+++ b/src/java/org/apache/poi/util/DrawingDump.java
@@ -15,7 +15,7 @@
See the License for the specific language governing permissions and
limitations under the License.
==================================================================== */
-
+
package org.apache.poi.util;
import java.io.File;
@@ -37,23 +37,20 @@ public final class DrawingDump {
}
public static void main( String[] args ) throws IOException {
- OutputStreamWriter osw = new OutputStreamWriter(System.out, Charset.defaultCharset());
- PrintWriter pw = new PrintWriter(osw);
- POIFSFileSystem fs = new POIFSFileSystem(new File(args[0]));
- HSSFWorkbook wb = new HSSFWorkbook(fs);
- try {
+ try (OutputStreamWriter osw = new OutputStreamWriter(System.out, Charset.defaultCharset());
+ PrintWriter pw = new PrintWriter(osw);
+ POIFSFileSystem fs = new POIFSFileSystem(new File(args[0]));
+ HSSFWorkbook wb = new HSSFWorkbook(fs)) {
+
pw.println( "Drawing group:" );
wb.dumpDrawingGroupRecords(true);
-
+
int i = 1;
for (Sheet sheet : wb)
{
pw.println( "Sheet " + i + "(" + sheet.getSheetName() + "):" );
((HSSFSheet) sheet).dumpDrawingRecords(true, pw);
}
- } finally {
- wb.close();
- fs.close();
}
}
}
diff --git a/src/java/org/apache/poi/util/IOUtils.java b/src/java/org/apache/poi/util/IOUtils.java
index 1a53cdd0b0..f1532b75e2 100644
--- a/src/java/org/apache/poi/util/IOUtils.java
+++ b/src/java/org/apache/poi/util/IOUtils.java
@@ -162,13 +162,13 @@ public final class IOUtils {
* @return A byte array with the read bytes.
* @throws IOException If reading data fails or EOF is encountered too early for the given length.
*/
- public static byte[] toByteArray(InputStream stream, final long length, final int maxLength) throws IOException {
+ public static byte[] toByteArray(InputStream stream, final int length, final int maxLength) throws IOException {
if (length < 0L || maxLength < 0L) {
throw new RecordFormatException("Can't allocate an array of length < 0");
}
- if (length > (long)Integer.MAX_VALUE) {
- throw new RecordFormatException("Can't allocate an array > "+Integer.MAX_VALUE);
- }
+ // if (length > (long)Integer.MAX_VALUE) {
+ // throw new RecordFormatException("Can't allocate an array > "+Integer.MAX_VALUE);
+ // }
if ((length != Integer.MAX_VALUE) || (maxLength != Integer.MAX_VALUE)) {
checkLength(length, maxLength);
}