aboutsummaryrefslogtreecommitdiffstats
path: root/src/scratchpad
diff options
context:
space:
mode:
Diffstat (limited to 'src/scratchpad')
-rw-r--r--src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkFactory.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkSeparator.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkTrailer.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hdgf/streams/CompressedStreamStore.java12
-rw-r--r--src/scratchpad/src/org/apache/poi/hdgf/streams/StreamStore.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hmef/CompressedRTF.java22
-rw-r--r--src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIAttribute.java32
-rw-r--r--src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIRtfAttribute.java19
-rw-r--r--src/scratchpad/src/org/apache/poi/hmef/dev/HMEFDumper.java41
-rw-r--r--src/scratchpad/src/org/apache/poi/hpbf/model/QuillContents.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/blip/Bitmap.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/blip/DIB.java15
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/blip/PICT.java16
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/dev/PPTXMLDump.java11
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/dev/SlideShowDumper.java9
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfo.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfoAtom.java9
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/BinaryTagDataBlob.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/CString.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ColorSchemeAtom.java6
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Comment2000.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Comment2000Atom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/CurrentUserAtom.java11
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/DocInfoListContainer.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Document.java16
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/DocumentEncryptionAtom.java18
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/DummyPositionSensitiveRecordWithChildren.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/DummyRecordWithChildren.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Environment.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExControlAtom.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExEmbed.java22
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExEmbedAtom.java9
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlink.java26
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlinkAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExMCIMovie.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExMediaAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExObjList.java26
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExObjListAtom.java17
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExObjRefAtom.java10
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjAtom.java11
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjStg.java11
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/ExVideoContainer.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/FontCollection.java18
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/FontEmbeddedData.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/FontEntityAtom.java8
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/HSLFEscherClientDataRecord.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersContainer.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfo.java24
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfoAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/MainMaster.java26
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/MasterTextPropAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Notes.java20
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/NotesAtom.java25
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/OEPlaceholderAtom.java11
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/OutlineTextRefAtom.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/PPDrawing.java11
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/PPDrawingGroup.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/PersistPtrHolder.java27
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/RecordContainer.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/RoundTripHFPlaceholder12.java6
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SSSlideInfoAtom.java51
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Slide.java21
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SlideAtom.java28
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SlideAtomLayout.java8
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SlideListWithText.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SlidePersistAtom.java9
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/Sound.java10
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SoundCollection.java6
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/SoundData.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/StyleTextProp9Atom.java21
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/StyleTextPropAtom.java10
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/TextBytesAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/TextCharsAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/TextHeaderAtom.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/TextSpecInfoAtom.java16
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/TxInteractiveInfoAtom.java8
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/TxMasterStyleAtom.java7
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/UnknownRecordPlaceholder.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java8
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoAtom.java10
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoContainer.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFPictureData.java5
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShowImpl.java20
-rw-r--r--src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFTextParagraph.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hssf/converter/ExcelToHtmlUtils.java18
-rw-r--r--src/scratchpad/src/org/apache/poi/hwmf/record/HwmfText.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/HWPFOldDocument.java23
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/CHPFormattedDiskPage.java12
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/ComplexFileTable.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/DocumentProperties.java6
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/FileInformationBlock.java8
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/OldSectionTable.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPiece.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPieceTable.java6
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/PICFAndOfficeArtData.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/PlexOfCps.java4
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/SectionTable.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/Sttb.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/StyleDescription.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/TextPieceTable.java3
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/types/DOPAbstractType.java376
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/types/LVLFAbstractType.java2
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/model/types/PICFAbstractType.java17
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/sprm/ParagraphSprmUncompressor.java9
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/sprm/SectionSprmUncompressor.java9
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmBuffer.java5
-rw-r--r--src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmOperation.java6
-rw-r--r--src/scratchpad/testcases/org/apache/poi/hmef/TestCompressedRTF.java3
-rw-r--r--src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestPictures.java49
110 files changed, 724 insertions, 839 deletions
diff --git a/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkFactory.java b/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkFactory.java
index ca78a48edd..5ebda3841d 100644
--- a/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkFactory.java
+++ b/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkFactory.java
@@ -188,8 +188,7 @@ public final class ChunkFactory {
}
// Now, create the chunk
- byte[] contents = IOUtils.safelyAllocate(header.getLength(), MAX_RECORD_LENGTH);
- System.arraycopy(data, offset+header.getSizeInBytes(), contents, 0, contents.length);
+ byte[] contents = IOUtils.safelyClone(data, offset+header.getSizeInBytes(), header.getLength(), MAX_RECORD_LENGTH);
Chunk chunk = new Chunk(header, trailer, separator, contents);
// Feed in the stuff from chunks_parse_cmds.tbl
diff --git a/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkSeparator.java b/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkSeparator.java
index bf49ceac48..ee009db15e 100644
--- a/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkSeparator.java
+++ b/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkSeparator.java
@@ -17,16 +17,17 @@
package org.apache.poi.hdgf.chunks;
+import java.util.Arrays;
+
/**
* A separator between the trailer of one chunk, and the
* header of the next one
*/
public final class ChunkSeparator {
- protected byte[] separatorData;
+ final byte[] separatorData;
public ChunkSeparator(byte[] data, int offset) {
- separatorData = new byte[4];
- System.arraycopy(data, offset, separatorData, 0, 4);
+ separatorData = Arrays.copyOfRange(data, offset, offset+4);
}
public String toString() {
diff --git a/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkTrailer.java b/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkTrailer.java
index a4c9e178c2..92160abb8e 100644
--- a/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkTrailer.java
+++ b/src/scratchpad/src/org/apache/poi/hdgf/chunks/ChunkTrailer.java
@@ -17,15 +17,16 @@
package org.apache.poi.hdgf.chunks;
+import java.util.Arrays;
+
/**
* A trailer that follows a chunk
*/
public final class ChunkTrailer {
- private byte[] trailerData;
+ private final byte[] trailerData;
public ChunkTrailer(byte[] data, int offset) {
- trailerData = new byte[8];
- System.arraycopy(data, offset, trailerData, 0, 8);
+ trailerData = Arrays.copyOfRange(data, offset, offset+8);
}
public String toString() {
diff --git a/src/scratchpad/src/org/apache/poi/hdgf/streams/CompressedStreamStore.java b/src/scratchpad/src/org/apache/poi/hdgf/streams/CompressedStreamStore.java
index 0ed5540b5e..a8bea5ccd8 100644
--- a/src/scratchpad/src/org/apache/poi/hdgf/streams/CompressedStreamStore.java
+++ b/src/scratchpad/src/org/apache/poi/hdgf/streams/CompressedStreamStore.java
@@ -38,21 +38,19 @@ public final class CompressedStreamStore extends StreamStore {
* We're not sure what this is, but it comes before the
* real contents in the de-compressed data
*/
- private byte[] blockHeader = new byte[4];
+ private final byte[] blockHeader;
private boolean blockHeaderInContents;
- protected byte[] _getCompressedContents() { return compressedContents; }
- protected byte[] _getBlockHeader() { return blockHeader; }
+ byte[] _getCompressedContents() { return compressedContents; }
+ byte[] _getBlockHeader() { return blockHeader; }
/**
* Creates a new compressed StreamStore, which will handle
* the decompression.
*/
- protected CompressedStreamStore(byte[] data, int offset, int length) throws IOException {
+ CompressedStreamStore(byte[] data, int offset, int length) throws IOException {
this(decompress(data,offset,length));
-
- compressedContents = IOUtils.safelyAllocate(length, MAX_RECORD_LENGTH);
- System.arraycopy(data, offset, compressedContents, 0, length);
+ compressedContents = IOUtils.safelyClone(data, offset, length, MAX_RECORD_LENGTH);
}
/**
* Handles passing the de-compressed data onto our superclass.
diff --git a/src/scratchpad/src/org/apache/poi/hdgf/streams/StreamStore.java b/src/scratchpad/src/org/apache/poi/hdgf/streams/StreamStore.java
index 30dead90a3..ad8e13cd56 100644
--- a/src/scratchpad/src/org/apache/poi/hdgf/streams/StreamStore.java
+++ b/src/scratchpad/src/org/apache/poi/hdgf/streams/StreamStore.java
@@ -34,8 +34,7 @@ public class StreamStore { // TODO - instantiable superclass
* Creates a new, non compressed Stream Store
*/
protected StreamStore(byte[] data, int offset, int length) {
- contents = IOUtils.safelyAllocate(length, MAX_RECORD_LENGTH);
- System.arraycopy(data, offset, contents, 0, length);
+ contents = IOUtils.safelyClone(data, offset, length, MAX_RECORD_LENGTH);
}
protected void prependContentsWith(byte[] b) {
diff --git a/src/scratchpad/src/org/apache/poi/hmef/CompressedRTF.java b/src/scratchpad/src/org/apache/poi/hmef/CompressedRTF.java
index b9f4cc4ee6..c3e2ab0c38 100644
--- a/src/scratchpad/src/org/apache/poi/hmef/CompressedRTF.java
+++ b/src/scratchpad/src/org/apache/poi/hmef/CompressedRTF.java
@@ -20,7 +20,7 @@ package org.apache.poi.hmef;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
-import java.nio.charset.Charset;
+import java.nio.charset.StandardCharsets;
import org.apache.poi.util.IOUtils;
import org.apache.poi.util.LZWDecompresser;
@@ -43,18 +43,18 @@ public final class CompressedRTF extends LZWDecompresser {
LittleEndian.getInt(COMPRESSED_SIGNATURE);
public static final int UNCOMPRESSED_SIGNATURE_INT =
LittleEndian.getInt(UNCOMPRESSED_SIGNATURE);
-
+
// The 4096 byte LZW dictionary is pre-loaded with some common
// RTF fragments. These come from RTFLIB32.LIB, which ships
// with older versions of Visual Studio or the EDK
- public static final String LZW_RTF_PRELOAD =
+ public static final String LZW_RTF_PRELOAD =
"{\\rtf1\\ansi\\mac\\deff0\\deftab720{\\fonttbl;}{\\f0\\fnil \\froman \\fswiss " +
"\\fmodern \\fscript \\fdecor MS Sans SerifSymbolArialTimes New RomanCourier" +
"{\\colortbl\\red0\\green0\\blue0\n\r\\par \\pard\\plain\\f0\\fs20\\b\\i\\u\\tab\\tx";
private int compressedSize;
private int decompressedSize;
-
+
public CompressedRTF() {
// Out flag has the normal meaning
// Length wise, we're 2 longer than we say, so the max len is 18
@@ -76,9 +76,9 @@ public final class CompressedRTF extends LZWDecompresser {
decompressedSize = LittleEndian.readInt(src);
int compressionType = LittleEndian.readInt(src);
/* int dataCRC = */ LittleEndian.readInt(src);
-
+
// TODO - Handle CRC checking on the output side
-
+
// Do we need to do anything?
if(compressionType == UNCOMPRESSED_SIGNATURE_INT) {
// Nope, nothing fancy to do
@@ -92,7 +92,7 @@ public final class CompressedRTF extends LZWDecompresser {
// Have it processed
super.decompress(src, res);
}
-
+
/**
* Returns how big the compressed version was.
*/
@@ -100,7 +100,7 @@ public final class CompressedRTF extends LZWDecompresser {
// Return the size less the header
return compressedSize - 12;
}
-
+
/**
* Returns how big the decompressed version was.
*/
@@ -119,10 +119,10 @@ public final class CompressedRTF extends LZWDecompresser {
@Override
protected int populateDictionary(byte[] dict) {
- // Copy in the RTF constants
- byte[] preload = LZW_RTF_PRELOAD.getBytes(Charset.forName("US-ASCII"));
+ // Copy in the RTF constants
+ byte[] preload = LZW_RTF_PRELOAD.getBytes(StandardCharsets.US_ASCII);
System.arraycopy(preload, 0, dict, 0, preload.length);
-
+
// Start adding new codes after the constants
return preload.length;
}
diff --git a/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIAttribute.java b/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIAttribute.java
index 159328fe70..695822909a 100644
--- a/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIAttribute.java
+++ b/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIAttribute.java
@@ -21,6 +21,7 @@ import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import org.apache.poi.hmef.Attachment;
@@ -45,7 +46,7 @@ public class MAPIAttribute {
private final MAPIProperty property;
private final int type;
private final byte[] data;
-
+
/**
* Constructs a single new attribute from
* the contents of the stream
@@ -67,21 +68,20 @@ public class MAPIAttribute {
public byte[] getData() {
return data;
}
-
+
public String toString() {
String hex;
if(data.length <= 16) {
hex = HexDump.toHex(data);
} else {
- byte[] d = new byte[16];
- System.arraycopy(data, 0, d, 0, 16);
+ byte[] d = Arrays.copyOf(data, 16);
hex = HexDump.toHex(d);
hex = hex.substring(0, hex.length()-1) + ", ....]";
}
-
+
return property + " " + hex;
}
-
+
/**
* Parses a MAPI Properties TNEF Attribute, and returns
* the list of MAPI Attributes contained within it
@@ -101,16 +101,16 @@ public class MAPIAttribute {
);
}
ByteArrayInputStream inp = new ByteArrayInputStream(parent.getData());
-
+
// First up, get the number of attributes
int count = LittleEndian.readInt(inp);
List<MAPIAttribute> attrs = new ArrayList<>();
-
+
// Now, read each one in in turn
for(int i=0; i<count; i++) {
int typeAndMV = LittleEndian.readUShort(inp);
int id = LittleEndian.readUShort(inp);
-
+
// Is it either Multi-Valued or Variable-Length?
boolean isMV = false;
boolean isVL = false;
@@ -123,13 +123,13 @@ public class MAPIAttribute {
typeId == Types.BINARY.getId() || typeId == Types.DIRECTORY.getId()) {
isVL = true;
}
-
+
// Turn the type ID into a strongly typed thing
MAPIType type = Types.getById(typeId);
if (type == null) {
type = Types.createCustom(typeId);
}
-
+
// If it's a named property, rather than a standard
// MAPI property, grab the details of it
MAPIProperty prop = MAPIProperty.get(id);
@@ -137,7 +137,7 @@ public class MAPIAttribute {
byte[] guid = new byte[16];
IOUtils.readFully(inp, guid);
int mptype = LittleEndian.readInt(inp);
-
+
// Get the name of it
String name;
if(mptype == 0) {
@@ -153,14 +153,14 @@ public class MAPIAttribute {
name = StringUtil.getFromUnicodeLE(mpdata, 0, (mplen/2)-1);
skipToBoundary(mplen, inp);
}
-
+
// Now create
prop = MAPIProperty.createCustom(id, type, name);
}
if(prop == MAPIProperty.UNKNOWN) {
prop = MAPIProperty.createCustom(id, type, "(unknown " + Integer.toHexString(id) + ")");
}
-
+
// Now read in the value(s)
int values = 1;
if(isMV || isVL) {
@@ -171,7 +171,7 @@ public class MAPIAttribute {
byte[] data = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
IOUtils.readFully(inp, data);
skipToBoundary(len, inp);
-
+
// Create
MAPIAttribute attr;
if(type == Types.UNICODE_STRING || type == Types.ASCII_STRING) {
@@ -186,7 +186,7 @@ public class MAPIAttribute {
attrs.add(attr);
}
}
-
+
// All done
return attrs;
}
diff --git a/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIRtfAttribute.java b/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIRtfAttribute.java
index 744fc2b7df..c5d1cec826 100644
--- a/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIRtfAttribute.java
+++ b/src/scratchpad/src/org/apache/poi/hmef/attribute/MAPIRtfAttribute.java
@@ -28,7 +28,7 @@ import org.apache.poi.util.IOUtils;
import org.apache.poi.util.StringUtil;
/**
- * A pure-MAPI attribute holding RTF (compressed or not), which applies
+ * A pure-MAPI attribute holding RTF (compressed or not), which applies
* to a {@link HMEFMessage} or one of its {@link Attachment}s.
*/
public final class MAPIRtfAttribute extends MAPIAttribute {
@@ -38,45 +38,44 @@ public final class MAPIRtfAttribute extends MAPIAttribute {
private final byte[] decompressed;
private final String data;
-
+
public MAPIRtfAttribute(MAPIProperty property, int type, byte[] data) throws IOException {
super(property, type, data);
-
+
// Decompress it, removing any trailing padding as needed
CompressedRTF rtf = new CompressedRTF();
byte[] tmp = rtf.decompress(new ByteArrayInputStream(data));
if(tmp.length > rtf.getDeCompressedSize()) {
- this.decompressed = IOUtils.safelyAllocate(rtf.getDeCompressedSize(), MAX_RECORD_LENGTH);
- System.arraycopy(tmp, 0, decompressed, 0, decompressed.length);
+ this.decompressed = IOUtils.safelyClone(tmp, 0, rtf.getDeCompressedSize(), MAX_RECORD_LENGTH);
} else {
this.decompressed = tmp;
}
-
+
// Turn the RTF data into a more useful string
this.data = StringUtil.getFromCompressedUnicode(decompressed, 0, decompressed.length);
}
-
+
/**
* Returns the original, compressed RTF
*/
public byte[] getRawData() {
return super.getData();
}
-
+
/**
* Returns the raw uncompressed RTF data
*/
public byte[] getData() {
return decompressed;
}
-
+
/**
* Returns the uncompressed RTF as a string
*/
public String getDataString() {
return data;
}
-
+
public String toString() {
return getProperty() + " " + data;
}
diff --git a/src/scratchpad/src/org/apache/poi/hmef/dev/HMEFDumper.java b/src/scratchpad/src/org/apache/poi/hmef/dev/HMEFDumper.java
index e969952648..d0019cebf4 100644
--- a/src/scratchpad/src/org/apache/poi/hmef/dev/HMEFDumper.java
+++ b/src/scratchpad/src/org/apache/poi/hmef/dev/HMEFDumper.java
@@ -44,7 +44,7 @@ public final class HMEFDumper {
if(args.length < 1) {
throw new IllegalArgumentException("Filename must be given");
}
-
+
boolean truncatePropData = true;
for (String arg : args) {
if (arg.equalsIgnoreCase("--full")) {
@@ -62,77 +62,77 @@ public final class HMEFDumper {
private InputStream inp;
private boolean truncatePropertyData;
-
+
public HMEFDumper(InputStream inp) throws IOException {
this.inp = inp;
-
+
// Check the signature matches
int sig = LittleEndian.readInt(inp);
if(sig != HMEFMessage.HEADER_SIGNATURE) {
throw new IllegalArgumentException(
"TNEF signature not detected in file, " +
- "expected " + HMEFMessage.HEADER_SIGNATURE +
+ "expected " + HMEFMessage.HEADER_SIGNATURE +
" but got " + sig
);
}
-
+
// Skip over the File ID
LittleEndian.readUShort(inp);
}
-
+
public void setTruncatePropertyData(boolean truncate) {
truncatePropertyData = truncate;
}
-
+
private void dump() throws IOException {
int level;
int attachments = 0;
-
+
while(true) {
// Fetch the level
level = inp.read();
if(level == TNEFProperty.LEVEL_END_OF_FILE) {
break;
}
-
+
// Build the attribute
TNEFAttribute attr = TNEFAttribute.create(inp);
-
+
// Is it a new attachment?
- if(level == TNEFProperty.LEVEL_ATTACHMENT &&
+ if(level == TNEFProperty.LEVEL_ATTACHMENT &&
attr.getProperty() == TNEFProperty.ID_ATTACHRENDERDATA) {
attachments++;
System.out.println();
System.out.println("Attachment # " + attachments);
System.out.println();
}
-
+
// Print the attribute into
System.out.println(
"Level " + level + " : Type " + attr.getType() +
" : ID " + attr.getProperty()
);
-
+
// Print the contents
String indent = " ";
-
+
if(attr instanceof TNEFStringAttribute) {
System.out.println(indent + indent + indent + ((TNEFStringAttribute)attr).getString());
}
if(attr instanceof TNEFDateAttribute) {
System.out.println(indent + indent + indent + ((TNEFDateAttribute)attr).getDate());
}
-
+
System.out.println(indent + "Data of length " + attr.getData().length);
if(attr.getData().length > 0) {
int len = attr.getData().length;
if(truncatePropertyData) {
len = Math.min( attr.getData().length, 48 );
}
-
+
int loops = len/16;
if(loops == 0) loops = 1;
-
+
for(int i=0; i<loops; i++) {
int thisLen = 16;
int offset = i*16;
@@ -140,16 +140,15 @@ public final class HMEFDumper {
thisLen = len - offset;
}
- byte[] data = IOUtils.safelyAllocate(thisLen, MAX_RECORD_LENGTH);
- System.arraycopy(attr.getData(), offset, data, 0, thisLen);
-
+ byte[] data = IOUtils.safelyClone(attr.getData(), offset, thisLen, MAX_RECORD_LENGTH);
+
System.out.print(
indent + HexDump.dump(data, 0, 0)
);
}
}
System.out.println();
-
+
if(attr.getProperty() == TNEFProperty.ID_MAPIPROPERTIES ||
attr.getProperty() == TNEFProperty.ID_ATTACHMENT) {
List<MAPIAttribute> attrs = MAPIAttribute.create(attr);
diff --git a/src/scratchpad/src/org/apache/poi/hpbf/model/QuillContents.java b/src/scratchpad/src/org/apache/poi/hpbf/model/QuillContents.java
index 8db0e5b7d2..ab5b5d09e9 100644
--- a/src/scratchpad/src/org/apache/poi/hpbf/model/QuillContents.java
+++ b/src/scratchpad/src/org/apache/poi/hpbf/model/QuillContents.java
@@ -69,8 +69,7 @@ public final class QuillContents extends HPBFPart {
int from = (int)LittleEndian.getUInt(data, offset+16);
int len = (int)LittleEndian.getUInt(data, offset+20);
- byte[] bitData = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
- System.arraycopy(data, from, bitData, 0, len);
+ byte[] bitData = IOUtils.safelyClone(data, from, len, MAX_RECORD_LENGTH);
// Create
if(bitType.equals("TEXT")) {
diff --git a/src/scratchpad/src/org/apache/poi/hslf/blip/Bitmap.java b/src/scratchpad/src/org/apache/poi/hslf/blip/Bitmap.java
index 1e944d48ed..afc8cd5481 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/blip/Bitmap.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/blip/Bitmap.java
@@ -39,9 +39,7 @@ public abstract class Bitmap extends HSLFPictureData {
public byte[] getData(){
byte[] rawdata = getRawData();
int prefixLen = 16*getUIDInstanceCount()+1;
- byte[] imgdata = IOUtils.safelyAllocate(rawdata.length-prefixLen, rawdata.length);
- System.arraycopy(rawdata, prefixLen, imgdata, 0, imgdata.length);
- return imgdata;
+ return IOUtils.safelyClone(rawdata, prefixLen, rawdata.length-prefixLen, rawdata.length);
}
@Override
diff --git a/src/scratchpad/src/org/apache/poi/hslf/blip/DIB.java b/src/scratchpad/src/org/apache/poi/hslf/blip/DIB.java
index 5699bbfeff..1c2d3dc07f 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/blip/DIB.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/blip/DIB.java
@@ -62,9 +62,9 @@ public final class DIB extends Bitmap {
break;
default:
throw new IllegalArgumentException(signature+" is not a valid instance/signature value for DIB");
- }
- }
-
+ }
+ }
+
@Override
public byte[] getData(){
return addBMPHeader ( super.getData() );
@@ -83,14 +83,14 @@ public final class DIB extends Bitmap {
int imageSize = LittleEndian.getInt(data, 0x22 - HEADER_SIZE);
int fileSize = data.length + HEADER_SIZE;
int offset = fileSize - imageSize;
-
+
// specifies the size, in bytes, of the bitmap file - must add the length of the header
- LittleEndian.putInt(header, 2, fileSize);
+ LittleEndian.putInt(header, 2, fileSize);
// Reserved; set to zero
LittleEndian.putInt(header, 6, 0);
// the offset, i.e. starting address, of the byte where the bitmap data can be found
LittleEndian.putInt(header, 10, offset);
-
+
//DIB data is the header + dib bytes
byte[] dib = IOUtils.safelyAllocate(header.length + data.length, MAX_RECORD_LENGTH);
System.arraycopy(header, 0, dib, 0, header.length);
@@ -102,8 +102,7 @@ public final class DIB extends Bitmap {
@Override
public void setData(byte[] data) throws IOException {
//cut off the bitmap file-header
- byte[] dib = IOUtils.safelyAllocate(data.length-HEADER_SIZE, data.length);
- System.arraycopy(data, HEADER_SIZE, dib, 0, dib.length);
+ byte[] dib = IOUtils.safelyClone(data, HEADER_SIZE, data.length-HEADER_SIZE, data.length);
super.setData(dib);
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/blip/PICT.java b/src/scratchpad/src/org/apache/poi/hslf/blip/PICT.java
index e4fedb4d98..201f98e603 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/blip/PICT.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/blip/PICT.java
@@ -36,8 +36,8 @@ import org.apache.poi.util.Units;
*/
public final class PICT extends Metafile {
private static final POILogger LOG = POILogFactory.getLogger(PICT.class);
-
-
+
+
@Override
public byte[] getData(){
byte[] rawdata = getRawData();
@@ -95,7 +95,7 @@ public final class PICT extends Metafile {
// skip the first 512 bytes - they are MAC specific crap
final int nOffset = ImageHeaderPICT.PICT_HEADER_OFFSET;
ImageHeaderPICT nHeader = new ImageHeaderPICT(data, nOffset);
-
+
Header header = new Header();
int wmfSize = data.length - nOffset;
header.setWmfSize(wmfSize);
@@ -144,12 +144,12 @@ public final class PICT extends Metafile {
break;
default:
throw new IllegalArgumentException(signature+" is not a valid instance/signature value for PICT");
- }
+ }
}
-
-
+
+
/*
- * initialize a smaller piece of the array and use the System.arraycopy
+ * initialize a smaller piece of the array and use the System.arraycopy
* call to fill in the rest of the array in an expanding binary fashion
*/
private static void bytefill(byte[] array, byte value) {
@@ -161,7 +161,7 @@ public final class PICT extends Metafile {
}
for (int i = 1; i < len; i += i) {
- System.arraycopy(array, 0, array, i, ((len - i) < i) ? (len - i) : i);
+ System.arraycopy(array, 0, array, i, Math.min(len - i, i));
}
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/dev/PPTXMLDump.java b/src/scratchpad/src/org/apache/poi/hslf/dev/PPTXMLDump.java
index fc0afe7ece..6b13a07920 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/dev/PPTXMLDump.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/dev/PPTXMLDump.java
@@ -26,6 +26,7 @@ import java.io.OutputStreamWriter;
import java.io.StringWriter;
import java.io.Writer;
import java.nio.charset.StandardCharsets;
+import java.util.Arrays;
import org.apache.poi.hslf.record.RecordTypes;
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
@@ -161,20 +162,18 @@ public final class PPTXMLDump {
public void dumpPictures(byte[] data, int padding) throws IOException {
int pos = 0;
while (pos < data.length) {
- byte[] header = new byte[PICT_HEADER_SIZE];
-
- if(data.length - pos < header.length) {
+ if(data.length - pos < PICT_HEADER_SIZE) {
// corrupt file, cannot read header
return;
}
- System.arraycopy(data, pos, header, 0, header.length);
+ byte[] header = Arrays.copyOfRange(data, pos, pos + PICT_HEADER_SIZE);
int size = LittleEndian.getInt(header, 4) - 17;
if(size < 0) {
// corrupt file, negative image size
return;
}
- byte[] pictdata = IOUtils.safelyAllocate(size, MAX_RECORD_LENGTH);
- System.arraycopy(data, pos + PICT_HEADER_SIZE, pictdata, 0, pictdata.length);
+
+ byte[] pictdata = IOUtils.safelyClone(data, pos + PICT_HEADER_SIZE, size, MAX_RECORD_LENGTH);
pos += PICT_HEADER_SIZE + size;
padding++;
diff --git a/src/scratchpad/src/org/apache/poi/hslf/dev/SlideShowDumper.java b/src/scratchpad/src/org/apache/poi/hslf/dev/SlideShowDumper.java
index 7fbed19e0e..230892e61f 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/dev/SlideShowDumper.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/dev/SlideShowDumper.java
@@ -58,7 +58,7 @@ public final class SlideShowDumper {
private boolean ddfEscher;
/** Do we use our own built-in basic escher groker to understand the escher objects? */
private boolean basicEscher;
-
+
private PrintStream out;
/**
@@ -213,8 +213,7 @@ public void walkTree(int depth, int startPos, int maxLen) throws IOException {
final String ind = (indent == 0) ? "%1$s" : "%1$"+indent+"s";
- byte[] contents = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
- System.arraycopy(docstream,pos,contents,0,len);
+ byte[] contents = IOUtils.safelyClone(docstream, pos, len, MAX_RECORD_LENGTH);
DefaultEscherRecordFactory erf = new HSLFEscherRecordFactory();
EscherRecord record = erf.createRecord(contents,0);
@@ -229,8 +228,8 @@ public void walkTree(int depth, int startPos, int maxLen) throws IOException {
String fmt = ind+"At position %2$d (%2$04x): type is %3$d (%3$04x), len is %4$d (%4$04x) (%5$d) - record claims %6$d";
out.println(String.format(Locale.ROOT, fmt, "", pos, atomType, atomLen, atomLen+8, recordLen));
-
-
+
+
// Check for corrupt / lying ones
if(recordLen != 8 && (recordLen != (atomLen+8))) {
out.println(String.format(Locale.ROOT, ind+"** Atom length of $2d ($3d) doesn't match record length of %4d", "", atomLen, atomLen+8, recordLen));
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfo.java b/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfo.java
index 01f641d303..baa17a08ea 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfo.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfo.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -39,8 +40,7 @@ public final class AnimationInfo extends RecordContainer {
*/
protected AnimationInfo(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfoAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfoAtom.java
index 2f1306a3f8..f89e188f14 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfoAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/AnimationInfoAtom.java
@@ -21,6 +21,7 @@ import static org.apache.poi.util.GenericRecordUtil.getBitsAsString;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -101,7 +102,7 @@ public final class AnimationInfoAtom extends RecordAtom {
/**
* record data
*/
- private byte[] _recdata;
+ private final byte[] _recdata;
/**
* Constructs a brand new link related atom record.
@@ -125,12 +126,10 @@ public final class AnimationInfoAtom extends RecordAtom {
*/
protected AnimationInfoAtom(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the record data
- _recdata = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_recdata,0,len-8);
+ _recdata = IOUtils.safelyClone(source,start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/BinaryTagDataBlob.java b/src/scratchpad/src/org/apache/poi/hslf/record/BinaryTagDataBlob.java
index 160e2bdbdf..79d8d9da7d 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/BinaryTagDataBlob.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/BinaryTagDataBlob.java
@@ -17,9 +17,11 @@
package org.apache.poi.hslf.record;
-import org.apache.poi.util.LittleEndian;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
+
+import org.apache.poi.util.LittleEndian;
/**
* If we come across a record we know has children of (potential)
@@ -44,8 +46,7 @@ public final class BinaryTagDataBlob extends PositionDependentRecordContainer
*/
protected BinaryTagDataBlob(byte[] source, int start, int len) {
// Just grab the header, not the whole contents
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
_type = LittleEndian.getUShort(_header,2);
// Find our children
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/CString.java b/src/scratchpad/src/org/apache/poi/hslf/record/CString.java
index 5f98cc8a8c..329915f93e 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/CString.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/CString.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -86,12 +87,10 @@ public final class CString extends RecordAtom {
if(len < 8) { len = 8; }
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the text
- _text = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_text,0,len-8);
+ _text = IOUtils.safelyClone(source,start+8, len-8, MAX_RECORD_LENGTH);
}
/**
* Create an empty CString
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ColorSchemeAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ColorSchemeAtom.java
index 9bd51ed8ad..8625245844 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ColorSchemeAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ColorSchemeAtom.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.Map;
@@ -108,11 +109,10 @@ public final class ColorSchemeAtom extends RecordAtom {
}
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the rgb values
- backgroundColourRGB = LittleEndian.getInt(source,start+8+0);
+ backgroundColourRGB = LittleEndian.getInt(source, start+8);
textAndLinesColourRGB = LittleEndian.getInt(source,start+8+4);
shadowsColourRGB = LittleEndian.getInt(source,start+8+8);
titleTextColourRGB = LittleEndian.getInt(source,start+8+12);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000.java b/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000.java
index ed8237b38f..fbf0d3086a 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -101,8 +102,7 @@ public final class Comment2000 extends RecordContainer {
*/
protected Comment2000(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = org.apache.poi.hslf.record.Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000Atom.java b/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000Atom.java
index de01e4f9aa..00c3cdef01 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000Atom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Comment2000Atom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Date;
import java.util.Map;
import java.util.function.Supplier;
@@ -72,12 +73,10 @@ public final class Comment2000Atom extends RecordAtom
*/
protected Comment2000Atom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/CurrentUserAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/CurrentUserAtom.java
index 99b991fa11..680d97c242 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/CurrentUserAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/CurrentUserAtom.java
@@ -192,17 +192,12 @@ public class CurrentUserAtom
// Grab the unicode username, if stored
int start = 28+(int)usernameLen+4;
- int len = 2*(int)usernameLen;
- if(_contents.length >= start+len) {
- byte[] textBytes = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
- System.arraycopy(_contents,start,textBytes,0,len);
- lastEditUser = StringUtil.getFromUnicodeLE(textBytes);
+ if(_contents.length >= start+2*usernameLen) {
+ lastEditUser = StringUtil.getFromUnicodeLE(_contents, start, (int)usernameLen);
} else {
// Fake from the 8 bit version
- byte[] textBytes = IOUtils.safelyAllocate(usernameLen, MAX_RECORD_LENGTH);
- System.arraycopy(_contents,28,textBytes,0,(int)usernameLen);
- lastEditUser = StringUtil.getFromCompressedUnicode(textBytes,0,(int)usernameLen);
+ lastEditUser = StringUtil.getFromCompressedUnicode(_contents, 28, (int)usernameLen);
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/DocInfoListContainer.java b/src/scratchpad/src/org/apache/poi/hslf/record/DocInfoListContainer.java
index e10e864724..a43e475034 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/DocInfoListContainer.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/DocInfoListContainer.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -38,8 +39,7 @@ public final class DocInfoListContainer extends RecordContainer {
*/
protected DocInfoListContainer(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source,start,start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Document.java b/src/scratchpad/src/org/apache/poi/hslf/record/Document.java
index 4fd37a9b35..114f5b3bb6 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Document.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Document.java
@@ -17,11 +17,12 @@
package org.apache.poi.hslf.record;
-import org.apache.poi.util.POILogger;
-
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
+
+import org.apache.poi.util.POILogger;
/**
* Master container for Document. There is one of these for every
@@ -46,24 +47,24 @@ public final class Document extends PositionDependentRecordContainer
* Returns the DocumentAtom of this Document
*/
public DocumentAtom getDocumentAtom() { return documentAtom; }
-
+
/**
* Returns the Environment of this Notes, which lots of
* settings for the document in it
*/
public Environment getEnvironment() { return environment; }
-
+
/**
* Returns the PPDrawingGroup, which holds an Escher Structure
* that contains information on pictures in the slides.
*/
public PPDrawingGroup getPPDrawingGroup() { return ppDrawing; }
-
+
/**
* Returns the ExObjList, which holds the references to
* external objects used in the slides. This may be null, if
* there are no external references.
- *
+ *
* @param create if true, create an ExObjList if it doesn't exist
*/
public ExObjList getExObjList(boolean create) {
@@ -126,8 +127,7 @@ public final class Document extends PositionDependentRecordContainer
*/
/* package */ Document(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/DocumentEncryptionAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/DocumentEncryptionAtom.java
index abcf03628e..bb498f2088 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/DocumentEncryptionAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/DocumentEncryptionAtom.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -51,8 +52,7 @@ public final class DocumentEncryptionAtom extends PositionDependentRecordAtom {
*/
protected DocumentEncryptionAtom(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source,start,start+8);
ByteArrayInputStream bis = new ByteArrayInputStream(source, start+8, len-8);
try (LittleEndianInputStream leis = new LittleEndianInputStream(bis)) {
@@ -67,10 +67,10 @@ public final class DocumentEncryptionAtom extends PositionDependentRecordAtom {
LittleEndian.putShort(_header, 0, (short)0x000F);
LittleEndian.putShort(_header, 2, (short)_type);
// record length not yet known ...
-
+
ei = new EncryptionInfo(EncryptionMode.cryptoAPI);
}
-
+
/**
* Initializes the encryption settings
*
@@ -79,7 +79,7 @@ public final class DocumentEncryptionAtom extends PositionDependentRecordAtom {
public void initializeEncryptionInfo(int keyBits) {
ei = new EncryptionInfo(EncryptionMode.cryptoAPI, CipherAlgorithm.rc4, HashAlgorithm.sha1, keyBits, -1, null);
}
-
+
/**
* Return the length of the encryption key, in bits
*/
@@ -100,8 +100,8 @@ public final class DocumentEncryptionAtom extends PositionDependentRecordAtom {
public EncryptionInfo getEncryptionInfo() {
return ei;
}
-
-
+
+
/**
* We are of type 12052
*/
@@ -119,10 +119,10 @@ public final class DocumentEncryptionAtom extends PositionDependentRecordAtom {
bos.writeShort(ei.getVersionMajor());
bos.writeShort(ei.getVersionMinor());
bos.writeInt(ei.getEncryptionFlags());
-
+
((CryptoAPIEncryptionHeader)ei.getHeader()).write(bos);
((CryptoAPIEncryptionVerifier)ei.getVerifier()).write(bos);
-
+
// Header
LittleEndian.putInt(_header, 4, bos.getWriteIndex());
out.write(_header);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/DummyPositionSensitiveRecordWithChildren.java b/src/scratchpad/src/org/apache/poi/hslf/record/DummyPositionSensitiveRecordWithChildren.java
index 285f824b43..db7a0cb943 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/DummyPositionSensitiveRecordWithChildren.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/DummyPositionSensitiveRecordWithChildren.java
@@ -17,9 +17,11 @@
package org.apache.poi.hslf.record;
-import org.apache.poi.util.LittleEndian;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
+
+import org.apache.poi.util.LittleEndian;
/**
* If we come across a record we know has children of (potential)
@@ -44,8 +46,7 @@ public final class DummyPositionSensitiveRecordWithChildren extends PositionDepe
*/
protected DummyPositionSensitiveRecordWithChildren(byte[] source, int start, int len) {
// Just grab the header, not the whole contents
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source,start,start+8);
_type = LittleEndian.getUShort(_header,2);
// Find our children
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/DummyRecordWithChildren.java b/src/scratchpad/src/org/apache/poi/hslf/record/DummyRecordWithChildren.java
index 18dea58923..cc99aa2f98 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/DummyRecordWithChildren.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/DummyRecordWithChildren.java
@@ -17,9 +17,11 @@
package org.apache.poi.hslf.record;
-import org.apache.poi.util.LittleEndian;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
+
+import org.apache.poi.util.LittleEndian;
/**
* If we come across a record we know has children of (potential)
@@ -39,8 +41,7 @@ public final class DummyRecordWithChildren extends RecordContainer
*/
protected DummyRecordWithChildren(byte[] source, int start, int len) {
// Just grab the header, not the whole contents
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
_type = LittleEndian.getUShort(_header,2);
// Find our children
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Environment.java b/src/scratchpad/src/org/apache/poi/hslf/record/Environment.java
index eb66f2a288..a8bebeaeaa 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Environment.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Environment.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
/**
* Environment, which contains lots of settings for the document.
@@ -47,8 +48,7 @@ public final class Environment extends PositionDependentRecordContainer
*/
protected Environment(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExControlAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExControlAtom.java
index 93942674af..58d27ef340 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExControlAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExControlAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -63,8 +64,7 @@ public final class ExControlAtom extends RecordAtom {
*/
protected ExControlAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source, start, _header, 0, 8);
+ _header = Arrays.copyOfRange(source, start, start+8);
_id = LittleEndian.getInt(source, start + 8);
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbed.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbed.java
index 099aeb854b..486a9bf235 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbed.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbed.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -49,8 +50,7 @@ public class ExEmbed extends RecordContainer {
*/
protected ExEmbed(final byte[] source, final int start, final int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
@@ -66,9 +66,9 @@ public class ExEmbed extends RecordContainer {
this();
_children[0] = this.embedAtom = embedAtom;
}
-
-
-
+
+
+
/**
* Create a new ExEmbed, with blank fields
*/
@@ -163,7 +163,7 @@ public class ExEmbed extends RecordContainer {
/**
* Gets the OLE Programmatic Identifier.
- *
+ *
* @return the OLE Programmatic Identifier.
*/
public String getProgId() {
@@ -175,8 +175,8 @@ public class ExEmbed extends RecordContainer {
this.progId.setText(progId);
}
-
-
+
+
/**
* Gets the name that appears in the paste special dialog.
*
@@ -190,7 +190,7 @@ public class ExEmbed extends RecordContainer {
this.clipboardName = safeCString(this.clipboardName, 0x3);
this.clipboardName.setText(clipboardName);
}
-
+
/**
* Returns the type (held as a little endian in bytes 3 and 4)
* that this class handles.
@@ -213,7 +213,7 @@ public class ExEmbed extends RecordContainer {
public void writeOut(final OutputStream out) throws IOException {
writeOut(_header[0],_header[1],getRecordType(),_children,out);
}
-
+
private CString safeCString(CString oldStr, int optionsId) {
CString newStr = oldStr;
if (newStr == null) {
@@ -233,7 +233,7 @@ public class ExEmbed extends RecordContainer {
if (!found) {
appendChildRecord(newStr);
}
-
+
return newStr;
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbedAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbedAtom.java
index e72f052347..f3c3a48f43 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbedAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExEmbedAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -94,12 +95,10 @@ public class ExEmbedAtom extends RecordAtom {
*/
protected ExEmbedAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source,start+8,len-8, MAX_RECORD_LENGTH);
// Must be at least 8 bytes long
if(_data.length < 8) {
@@ -130,7 +129,7 @@ public class ExEmbedAtom extends RecordAtom {
public void setCantLockServerB(boolean cantBeLocked) {
_data[4] = (byte)(cantBeLocked ? 1 : 0);
}
-
+
/**
* Gets whether it is not required to send the dimensions to the embedded object.
*
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlink.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlink.java
index 37c47824e4..4dabe4cc82 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlink.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlink.java
@@ -18,12 +18,13 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
/**
- * This class represents the data of a link in the document.
+ * This class represents the data of a link in the document.
* @author Nick Burch
*/
public class ExHyperlink extends RecordContainer {
@@ -35,12 +36,12 @@ public class ExHyperlink extends RecordContainer {
private ExHyperlinkAtom linkAtom;
private CString linkDetailsA;
private CString linkDetailsB;
-
- /**
+
+ /**
* Returns the ExHyperlinkAtom of this link
- */
+ */
public ExHyperlinkAtom getExHyperlinkAtom() { return linkAtom; }
-
+
/**
* Returns the URL of the link.
*
@@ -68,7 +69,7 @@ public class ExHyperlink extends RecordContainer {
linkDetailsB.setText(url);
}
}
-
+
public void setLinkOptions(int options) {
if(linkDetailsB != null) {
linkDetailsB.setOptions(options);
@@ -80,7 +81,7 @@ public class ExHyperlink extends RecordContainer {
linkDetailsA.setText(title);
}
}
-
+
/**
* Get the link details (field A)
*/
@@ -94,13 +95,12 @@ public class ExHyperlink extends RecordContainer {
return linkDetailsB == null ? null : linkDetailsB.getText();
}
- /**
+ /**
* Set things up, and find our more interesting children
*/
protected ExHyperlink(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
@@ -111,7 +111,7 @@ public class ExHyperlink extends RecordContainer {
* Go through our child records, picking out the ones that are
* interesting, and saving those for use by the easy helper
* methods.
- */
+ */
private void findInterestingChildren() {
// First child should be the ExHyperlinkAtom
@@ -138,11 +138,11 @@ public class ExHyperlink extends RecordContainer {
public ExHyperlink() {
_header = new byte[8];
_children = new org.apache.poi.hslf.record.Record[3];
-
+
// Setup our header block
_header[0] = 0x0f; // We are a container record
LittleEndian.putShort(_header, 2, (short)_type);
-
+
// Setup our child records
CString csa = new CString();
CString csb = new CString();
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlinkAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlinkAtom.java
index bc99430998..ba63ac5da6 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlinkAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExHyperlinkAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -70,12 +71,10 @@ public final class ExHyperlinkAtom extends RecordAtom {
*/
protected ExHyperlinkAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
// Must be at least 4 bytes long
if(_data.length < 4) {
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExMCIMovie.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExMCIMovie.java
index b83e0f8184..37b60ca9e2 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExMCIMovie.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExMCIMovie.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -39,8 +40,7 @@ public class ExMCIMovie extends RecordContainer { // TODO - instantiable supercl
*/
protected ExMCIMovie(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source, start, _header, 0, 8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source, start + 8, len - 8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExMediaAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExMediaAtom.java
index b8db11ad78..486b976f66 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExMediaAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExMediaAtom.java
@@ -21,6 +21,7 @@ import static org.apache.poi.util.GenericRecordUtil.getBitsAsString;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -89,12 +90,10 @@ public final class ExMediaAtom extends RecordAtom
*/
protected ExMediaAtom(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the record data
- _recdata = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_recdata,0,len-8);
+ _recdata = IOUtils.safelyClone(source,start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExObjList.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExObjList.java
index f57461cf18..bee803a21b 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExObjList.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExObjList.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
@@ -30,15 +31,15 @@ import org.apache.poi.util.LittleEndian;
public class ExObjList extends RecordContainer {
private byte[] _header;
private static final long _type = RecordTypes.ExObjList.typeID;
-
+
// Links to our more interesting children
- private ExObjListAtom exObjListAtom;
-
- /**
+ private ExObjListAtom exObjListAtom;
+
+ /**
* Returns the ExObjListAtom of this list
- */
+ */
public ExObjListAtom getExObjListAtom() { return exObjListAtom; }
-
+
/**
* Returns all the ExHyperlinks
*/
@@ -53,13 +54,12 @@ public class ExObjList extends RecordContainer {
return links.toArray(new ExHyperlink[0]);
}
- /**
+ /**
* Set things up, and find our more interesting children
*/
protected ExObjList(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
@@ -70,7 +70,7 @@ public class ExObjList extends RecordContainer {
* Go through our child records, picking out the ones that are
* interesting, and saving those for use by the easy helper
* methods.
- */
+ */
private void findInterestingChildren() {
// First child should be the atom
if(_children[0] instanceof ExObjListAtom) {
@@ -79,18 +79,18 @@ public class ExObjList extends RecordContainer {
throw new IllegalStateException("First child record wasn't a ExObjListAtom, was of type " + _children[0].getRecordType());
}
}
-
+
/**
* Create a new ExObjList, with blank fields
*/
public ExObjList() {
_header = new byte[8];
_children = new org.apache.poi.hslf.record.Record[1];
-
+
// Setup our header block
_header[0] = 0x0f; // We are a container record
LittleEndian.putShort(_header, 2, (short)_type);
-
+
// Setup our child records
_children[0] = new ExObjListAtom();
findInterestingChildren();
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExObjListAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExObjListAtom.java
index 0c345a286b..5fab662c42 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExObjListAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExObjListAtom.java
@@ -14,12 +14,13 @@
See the License for the specific language governing permissions and
limitations under the License.
==================================================================== */
-
+
package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -58,7 +59,7 @@ public class ExObjListAtom extends RecordAtom
LittleEndian.putShort(_header, 2, (short)getRecordType());
LittleEndian.putInt(_header, 4, _data.length);
-
+
// It is fine for the other values to be zero
}
@@ -72,13 +73,11 @@ public class ExObjListAtom extends RecordAtom
*/
protected ExObjListAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
-
+ _header = Arrays.copyOfRange(source, start, start+8);
+
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
-
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
+
// Must be at least 4 bytes long
if(_data.length < 4) {
throw new IllegalArgumentException("The length of the data for a ExObjListAtom must be at least 4 bytes, but was only " + _data.length);
@@ -101,7 +100,7 @@ public class ExObjListAtom extends RecordAtom
public void setObjectIDSeed(int seed) {
LittleEndian.putInt(_data,0,seed);
}
-
+
/**
* Gets the record type.
* @return the record type.
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExObjRefAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExObjRefAtom.java
index 930f54c380..a1e3d168c8 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExObjRefAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExObjRefAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -55,17 +56,14 @@ public final class ExObjRefAtom extends RecordAtom {
/**
* Build an instance of <code>ExObjRefAtom</code> from on-disk data
- *
+ *
* @param source the source data as a byte array.
* @param start the start offset into the byte array.
* @param len the length of the slice in the byte array.
*/
protected ExObjRefAtom(byte[] source, int start, int len) {
- _header = new byte[8];
- int offset = start;
- System.arraycopy(source,start,_header,0,8);
- offset += _header.length;
- exObjIdRef = (int)LittleEndian.getUInt(source, offset);
+ _header = Arrays.copyOfRange(source, start, start+8);
+ exObjIdRef = (int)LittleEndian.getUInt(source, start+8);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjAtom.java
index b8c77a747c..321f09cb41 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjAtom.java
@@ -22,6 +22,7 @@ import static org.apache.poi.util.GenericRecordUtil.safeEnum;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -187,12 +188,10 @@ public class ExOleObjAtom extends RecordAtom {
*/
protected ExOleObjAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
// Must be at least 24 bytes long
if(_data.length < 24) {
@@ -258,7 +257,7 @@ public class ExOleObjAtom extends RecordAtom {
/**
* Gets the type of OLE object.
- *
+ *
* @return the sub-type, one of the {@code SUBTYPE_*} constants.
*/
public int getSubType() {
@@ -303,7 +302,7 @@ public class ExOleObjAtom extends RecordAtom {
// Even though this is a mere boolean, KOffice's code says it's an int.
return LittleEndian.getInt(_data, 20) != 0;
}
-
+
/**
* Gets misc options (the last four bytes in the atom).
*
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjStg.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjStg.java
index 3fdfa04ecd..4fc8a838e0 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjStg.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExOleObjStg.java
@@ -22,6 +22,7 @@ import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
import java.util.zip.DeflaterOutputStream;
@@ -51,7 +52,7 @@ public class ExOleObjStg extends PositionDependentRecordAtom implements PersistR
* Record data.
*/
private byte[] _data;
-
+
/**
* Constructs a new empty storage container.
*/
@@ -74,12 +75,10 @@ public class ExOleObjStg extends PositionDependentRecordAtom implements PersistR
*/
protected ExOleObjStg(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
public boolean isCompressed() {
@@ -155,7 +154,7 @@ public class ExOleObjStg extends PositionDependentRecordAtom implements PersistR
public int getRecordInstance() {
return (LittleEndian.getUShort(_header, 0) >>> 4);
}
-
+
/**
* Write the contents of the record back, so it can be written
* to disk.
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/ExVideoContainer.java b/src/scratchpad/src/org/apache/poi/hslf/record/ExVideoContainer.java
index 1e9031cba2..bebb2aecfe 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/ExVideoContainer.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/ExVideoContainer.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -41,8 +42,7 @@ public final class ExVideoContainer extends RecordContainer {
*/
protected ExVideoContainer(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/FontCollection.java b/src/scratchpad/src/org/apache/poi/hslf/record/FontCollection.java
index 4bd0b0547c..aef98a81c1 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/FontCollection.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/FontCollection.java
@@ -21,6 +21,7 @@ import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
@@ -47,8 +48,7 @@ public final class FontCollection extends RecordContainer {
private byte[] _header;
/* package */ FontCollection(byte[] source, int start, int len) {
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
_children = Record.findChildRecords(source,start+8,len-8);
@@ -86,10 +86,10 @@ public final class FontCollection extends RecordContainer {
/**
* Add font with the given FontInfo configuration to the font collection.
- * The returned FontInfo contains the HSLF specific details and the collection
+ * The returned FontInfo contains the HSLF specific details and the collection
* uniquely contains fonts based on their typeface, i.e. calling the method with FontInfo
* objects having the same name results in the same HSLFFontInfo reference.
- *
+ *
* @param fontInfo the FontInfo configuration, can be a instance of {@link HSLFFontInfo},
* {@link HSLFFontInfoPredefined} or a custom implementation
* @return the register HSLFFontInfo object
@@ -168,9 +168,9 @@ public final class FontCollection extends RecordContainer {
/**
* Lookup a FontInfo object by its typeface
- *
+ *
* @param typeface the full font name
- *
+ *
* @return the HSLFFontInfo for the given name or {@code null} if not found
*/
public HSLFFontInfo getFontInfo(String typeface) {
@@ -195,9 +195,9 @@ public final class FontCollection extends RecordContainer {
/**
* Lookup a FontInfo object by its internal font index
- *
+ *
* @param index the internal font index
- *
+ *
* @return the HSLFFontInfo for the given index or {@code null} if not found
*/
public HSLFFontInfo getFontInfo(int index) {
@@ -208,7 +208,7 @@ public final class FontCollection extends RecordContainer {
}
return null;
}
-
+
/**
* @return the number of registered fonts
*/
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/FontEmbeddedData.java b/src/scratchpad/src/org/apache/poi/hslf/record/FontEmbeddedData.java
index f28bb3f990..b9acb2e3bf 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/FontEmbeddedData.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/FontEmbeddedData.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -63,12 +64,10 @@ public class FontEmbeddedData extends RecordAtom implements FontFacet {
*/
/* package */ FontEmbeddedData(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
// Must be at least 4 bytes long
if(_data.length < 4) {
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/FontEntityAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/FontEntityAtom.java
index 0e9f732833..0d576f6a6a 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/FontEntityAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/FontEntityAtom.java
@@ -62,7 +62,7 @@ public final class FontEntityAtom extends RecordAtom {
/**
* record header
*/
- private final byte[] _header = new byte[8];
+ private final byte[] _header;
/**
* record data
@@ -74,11 +74,10 @@ public final class FontEntityAtom extends RecordAtom {
*/
/* package */ FontEntityAtom(byte[] source, int start, int len) {
// Get the header
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the record data
- _recdata = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_recdata,0,len-8);
+ _recdata = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
@@ -86,6 +85,7 @@ public final class FontEntityAtom extends RecordAtom {
*/
public FontEntityAtom() {
_recdata = new byte[68];
+ _header = new byte[8];
LittleEndian.putShort(_header, 2, (short)getRecordType());
LittleEndian.putInt(_header, 4, _recdata.length);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/HSLFEscherClientDataRecord.java b/src/scratchpad/src/org/apache/poi/hslf/record/HSLFEscherClientDataRecord.java
index 3f1b0fbe3d..af0e0a5ec5 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/HSLFEscherClientDataRecord.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/HSLFEscherClientDataRecord.java
@@ -68,8 +68,7 @@ public class HSLFEscherClientDataRecord extends EscherClientDataRecord {
@Override
public int fillFields(byte[] data, int offset, EscherRecordFactory recordFactory) {
int bytesRemaining = readHeader( data, offset );
- byte[] remainingData = IOUtils.safelyAllocate(bytesRemaining, MAX_RECORD_LENGTH);
- System.arraycopy(data, offset+8, remainingData, 0, bytesRemaining);
+ byte[] remainingData = IOUtils.safelyClone(data, offset+8, bytesRemaining, MAX_RECORD_LENGTH);
setRemainingData(remainingData);
return bytesRemaining + 8;
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersAtom.java
index f175848ff1..42f8d017ca 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersAtom.java
@@ -22,6 +22,7 @@ import static org.apache.poi.util.GenericRecordUtil.safeEnum;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -142,12 +143,10 @@ public final class HeadersFootersAtom extends RecordAtom {
*/
protected HeadersFootersAtom(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the record data
- _recdata = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_recdata,0,len-8);
+ _recdata = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersContainer.java b/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersContainer.java
index b974bb35bb..492933be48 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersContainer.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/HeadersFootersContainer.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -59,8 +60,7 @@ public final class HeadersFootersContainer extends RecordContainer {
protected HeadersFootersContainer(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
_children = Record.findChildRecords(source,start+8,len-8);
findInterestingChildren();
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfo.java b/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfo.java
index 440005b479..76b84c554a 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfo.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfo.java
@@ -18,6 +18,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogger;
@@ -31,22 +32,21 @@ import org.apache.poi.util.POILogger;
public class InteractiveInfo extends RecordContainer {
private byte[] _header;
private static final long _type = RecordTypes.InteractiveInfo.typeID;
-
+
// Links to our more interesting children
private InteractiveInfoAtom infoAtom;
-
- /**
+
+ /**
* Returns the InteractiveInfoAtom of this InteractiveInfo
- */
+ */
public InteractiveInfoAtom getInteractiveInfoAtom() { return infoAtom; }
-
- /**
+
+ /**
* Set things up, and find our more interesting children
*/
protected InteractiveInfo(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
@@ -57,7 +57,7 @@ public class InteractiveInfo extends RecordContainer {
* Go through our child records, picking out the ones that are
* interesting, and saving those for use by the easy helper
* methods.
- */
+ */
private void findInterestingChildren() {
// First child should be the InteractiveInfoAtom
if (_children == null || _children.length == 0 || !(_children[0] instanceof InteractiveInfoAtom)) {
@@ -67,18 +67,18 @@ public class InteractiveInfo extends RecordContainer {
infoAtom = (InteractiveInfoAtom)_children[0];
}
-
+
/**
* Create a new InteractiveInfo, with blank fields
*/
public InteractiveInfo() {
_header = new byte[8];
_children = new org.apache.poi.hslf.record.Record[1];
-
+
// Setup our header block
_header[0] = 0x0f; // We are a container record
LittleEndian.putShort(_header, 2, (short)_type);
-
+
// Setup our child records
infoAtom = new InteractiveInfoAtom();
_children[0] = infoAtom;
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfoAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfoAtom.java
index 71a5adc123..3543010612 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfoAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/InteractiveInfoAtom.java
@@ -22,6 +22,7 @@ import static org.apache.poi.util.GenericRecordUtil.safeEnum;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -153,12 +154,10 @@ public class InteractiveInfoAtom extends RecordAtom {
*/
protected InteractiveInfoAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
// Must be at least 16 bytes long
if(_data.length < 16) {
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/MainMaster.java b/src/scratchpad/src/org/apache/poi/hslf/record/MainMaster.java
index 8451193c33..e771fcf57d 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/MainMaster.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/MainMaster.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
/**
* Master slide
@@ -57,8 +58,7 @@ public final class MainMaster extends SheetContainer {
*/
protected MainMaster(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
@@ -66,19 +66,19 @@ public final class MainMaster extends SheetContainer {
ArrayList<TxMasterStyleAtom> tx = new ArrayList<>();
ArrayList<ColorSchemeAtom> clr = new ArrayList<>();
// Find the interesting ones in there
- for(int i=0; i<_children.length; i++) {
- if(_children[i] instanceof SlideAtom) {
- slideAtom = (SlideAtom)_children[i];
- } else if(_children[i] instanceof PPDrawing) {
- ppDrawing = (PPDrawing)_children[i];
- } else if(_children[i] instanceof TxMasterStyleAtom) {
- tx.add( (TxMasterStyleAtom)_children[i] );
- } else if(_children[i] instanceof ColorSchemeAtom) {
- clr.add( (ColorSchemeAtom)_children[i] );
+ for (Record child : _children) {
+ if (child instanceof SlideAtom) {
+ slideAtom = (SlideAtom) child;
+ } else if (child instanceof PPDrawing) {
+ ppDrawing = (PPDrawing) child;
+ } else if (child instanceof TxMasterStyleAtom) {
+ tx.add((TxMasterStyleAtom) child);
+ } else if (child instanceof ColorSchemeAtom) {
+ clr.add((ColorSchemeAtom) child);
}
- if(ppDrawing != null && _children[i] instanceof ColorSchemeAtom) {
- _colorScheme = (ColorSchemeAtom)_children[i];
+ if (ppDrawing != null && child instanceof ColorSchemeAtom) {
+ _colorScheme = (ColorSchemeAtom) child;
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/MasterTextPropAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/MasterTextPropAtom.java
index 0e1b4dcab1..8da3d439b6 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/MasterTextPropAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/MasterTextPropAtom.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Map;
@@ -76,12 +77,10 @@ public final class MasterTextPropAtom extends RecordAtom {
*/
protected MasterTextPropAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
try {
read();
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Notes.java b/src/scratchpad/src/org/apache/poi/hslf/record/Notes.java
index 8695b25f0b..4854426283 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Notes.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Notes.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
/**
* Master container for Notes. There is one of these for every page of
@@ -53,23 +54,22 @@ public final class Notes extends SheetContainer
*/
protected Notes(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
// Find the interesting ones in there
- for(int i=0; i<_children.length; i++) {
- if(_children[i] instanceof NotesAtom) {
- notesAtom = (NotesAtom)_children[i];
+ for (Record child : _children) {
+ if (child instanceof NotesAtom) {
+ notesAtom = (NotesAtom) child;
}
- if(_children[i] instanceof PPDrawing) {
- ppDrawing = (PPDrawing)_children[i];
+ if (child instanceof PPDrawing) {
+ ppDrawing = (PPDrawing) child;
+ }
+ if (ppDrawing != null && child instanceof ColorSchemeAtom) {
+ _colorScheme = (ColorSchemeAtom) child;
}
- if(ppDrawing != null && _children[i] instanceof ColorSchemeAtom) {
- _colorScheme = (ColorSchemeAtom)_children[i];
- }
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/NotesAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/NotesAtom.java
index 40b4554955..655898adb8 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/NotesAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/NotesAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -70,33 +71,19 @@ public final class NotesAtom extends RecordAtom
if(len < 8) { len = 8; }
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the slide ID
slideID = LittleEndian.getInt(source,start+8);
// Grok the flags, stored as bits
int flags = LittleEndian.getUShort(source,start+12);
- if((flags&4) == 4) {
- followMasterBackground = true;
- } else {
- followMasterBackground = false;
- }
- if((flags&2) == 2) {
- followMasterScheme = true;
- } else {
- followMasterScheme = false;
- }
- if((flags&1) == 1) {
- followMasterObjects = true;
- } else {
- followMasterObjects = false;
- }
+ followMasterBackground = (flags & 4) == 4;
+ followMasterScheme = (flags & 2) == 2;
+ followMasterObjects = (flags & 1) == 1;
// There might be 2 more bytes, which are a reserved field
- reserved = IOUtils.safelyAllocate(len-14, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+14,reserved,0,reserved.length);
+ reserved = IOUtils.safelyClone(source, start+14, len-14, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/OEPlaceholderAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/OEPlaceholderAtom.java
index f25164d2a2..af3595fecb 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/OEPlaceholderAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/OEPlaceholderAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -28,7 +29,7 @@ import org.apache.poi.util.LittleEndian;
/**
* OEPlaceholderAtom (3011).<p>
- *
+ *
* An atom record that specifies whether a shape is a placeholder shape.
*
* @see Placeholder
@@ -77,10 +78,8 @@ public final class OEPlaceholderAtom extends RecordAtom{
* Build an instance of {@code OEPlaceholderAtom} from on-disk data
*/
protected OEPlaceholderAtom(byte[] source, int start, int len) {
- _header = new byte[8];
- int offset = start;
- System.arraycopy(source,start,_header,0,8);
- offset += _header.length;
+ _header = Arrays.copyOfRange(source, start, start+8);
+ int offset = start+8;
placementId = LittleEndian.getInt(source, offset); offset += 4;
placeholderId = LittleEndian.getUByte(source, offset); offset++;
@@ -96,7 +95,7 @@ public final class OEPlaceholderAtom extends RecordAtom{
/**
* Returns the placement Id.<p>
- *
+ *
* The placement Id is a number assigned to the placeholder. It goes from -1 to the number of placeholders.
* It SHOULD be unique among all PlacholderAtom records contained in the corresponding slide.
* The value 0xFFFFFFFF specifies that the corresponding shape is not a placeholder shape.
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/OutlineTextRefAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/OutlineTextRefAtom.java
index e0c368825b..e521c74383 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/OutlineTextRefAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/OutlineTextRefAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -55,8 +56,7 @@ public final class OutlineTextRefAtom extends RecordAtom {
*/
protected OutlineTextRefAtom(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the record data
_index = LittleEndian.getInt(source, start+8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawing.java b/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawing.java
index 2bb40a812a..77af5d467f 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawing.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawing.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
@@ -114,15 +115,13 @@ public final class PPDrawing extends RecordAtom implements Iterable<EscherRecord
*/
PPDrawing(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the type
_type = LittleEndian.getUShort(_header,2);
// Get the contents for now
- final byte[] contents = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
- System.arraycopy(source,start,contents,0,len);
+ final byte[] contents = IOUtils.safelyClone(source, start, len, MAX_RECORD_LENGTH);
// Build up a tree of Escher records contained within
final DefaultEscherRecordFactory erf = new HSLFEscherRecordFactory();
@@ -342,7 +341,7 @@ public final class PPDrawing extends RecordAtom implements Iterable<EscherRecord
spContainer.addChildRecord(opt);
dgContainer.addChildRecord(spContainer);
-
+
childRecords.add(dgContainer);
}
@@ -364,7 +363,7 @@ public final class PPDrawing extends RecordAtom implements Iterable<EscherRecord
public EscherContainerRecord getDgContainer() {
return (EscherContainerRecord)firstEscherRecord(this, EscherRecordTypes.DG_CONTAINER).orElse(null);
}
-
+
/**
* Return EscherDgRecord which keeps track of the number of shapes and shapeId in this drawing group
*
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawingGroup.java b/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawingGroup.java
index 672be6c0cf..6ff8b4577f 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawingGroup.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/PPDrawingGroup.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -50,12 +51,10 @@ public final class PPDrawingGroup extends RecordAtom {
protected PPDrawingGroup(byte[] source, int start, int len) {
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the contents for now
- byte[] contents = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
- System.arraycopy(source,start,contents,0,len);
+ byte[] contents = IOUtils.safelyClone(source, start, len, MAX_RECORD_LENGTH);
DefaultEscherRecordFactory erf = new HSLFEscherRecordFactory();
EscherRecord child = erf.createRecord(contents, 0);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/PersistPtrHolder.java b/src/scratchpad/src/org/apache/poi/hslf/record/PersistPtrHolder.java
index 841d49d9e1..0084d9020b 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/PersistPtrHolder.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/PersistPtrHolder.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
@@ -65,7 +66,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
private static final BitField persistIdFld = BitFieldFactory.getInstance(0X000FFFFF);
private static final BitField cntPersistFld = BitFieldFactory.getInstance(0XFFF00000);
-
+
/**
* Return the value we were given at creation, be it 6001 or 6002
*/
@@ -93,7 +94,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
public Map<Integer,Integer> getSlideLocationsLookup() {
return Collections.unmodifiableMap(_slideLocations);
}
-
+
/**
* Create a new holder for a PersistPtr record
*/
@@ -103,8 +104,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
if(len < 8) { len = 8; }
// Treat as an atom, grab and hold everything
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
_type = LittleEndian.getUShort(_header,2);
// Try to make sense of the data part:
@@ -115,8 +115,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
// count * 32 bit offsets
// Repeat as many times as you have data
_slideLocations = new HashMap<>();
- _ptrData = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_ptrData,0,_ptrData.length);
+ _ptrData = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
int pos = 0;
while(pos < _ptrData.length) {
@@ -127,7 +126,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
// Remaining 12 bits = offset count
int offset_no = persistIdFld.getValue(info);
int offset_count = cntPersistFld.getValue(info);
-
+
// Wind on by the 4 byte info header
pos += 4;
@@ -145,13 +144,13 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
/**
* remove all slide references
- *
+ *
* Convenience method provided, for easier reviewing of invocations
*/
public void clear() {
_slideLocations.clear();
}
-
+
/**
* Adds a new slide, notes or similar, to be looked up by this.
*/
@@ -187,7 +186,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
private void normalizePersistDirectory() {
TreeMap<Integer,Integer> orderedSlideLocations = new TreeMap<>(_slideLocations);
-
+
@SuppressWarnings("resource")
BufAccessBAOS bos = new BufAccessBAOS(); // NOSONAR
byte[] intbuf = new byte[4];
@@ -200,7 +199,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
// Building the info block
// First 20 bits = offset number = slide ID (persistIdFld, i.e. first slide ID of a continuous group)
// Remaining 12 bits = offset count = 1 (cntPersistFld, i.e. continuous entries in a group)
-
+
if (lastSlideId+1 == nextSlideId) {
// use existing PersistDirectoryEntry, need to increase entry count
assert(lastPersistEntry != -1);
@@ -225,14 +224,14 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
throw new HSLFException(e);
}
}
-
+
// Save the new ptr data
_ptrData = bos.toByteArray();
// Update the atom header
LittleEndian.putInt(_header,4,bos.size());
}
-
+
/**
* Write the contents of the record back, so it can be written
* to disk
@@ -243,7 +242,7 @@ public final class PersistPtrHolder extends PositionDependentRecordAtom
out.write(_header);
out.write(_ptrData);
}
-
+
private static class BufAccessBAOS extends ByteArrayOutputStream {
public byte[] getBuf() {
return buf;
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/RecordContainer.java b/src/scratchpad/src/org/apache/poi/hslf/record/RecordContainer.java
index dafc3972fe..4e738a7601 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/RecordContainer.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/RecordContainer.java
@@ -21,6 +21,7 @@ import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -76,8 +77,7 @@ public abstract class RecordContainer extends Record
*/
private int appendChild(Record newChild) {
// Copy over, and pop the child in at the end
- Record[] nc = new org.apache.poi.hslf.record.Record[(_children.length + 1)];
- System.arraycopy(_children, 0, nc, 0, _children.length);
+ Record[] nc = Arrays.copyOf(_children, _children.length+1, org.apache.poi.hslf.record.Record[].class);
// Switch the arrays
nc[_children.length] = newChild;
_children = nc;
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/RoundTripHFPlaceholder12.java b/src/scratchpad/src/org/apache/poi/hslf/record/RoundTripHFPlaceholder12.java
index f2c8f03b82..283c65ba43 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/RoundTripHFPlaceholder12.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/RoundTripHFPlaceholder12.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -55,7 +56,7 @@ public final class RoundTripHFPlaceholder12 extends RecordAtom {
LittleEndian.putInt(_header, 4, 8);
_placeholderId = 0;
}
-
+
/**
* Constructs the comment atom record from its source data.
*
@@ -65,8 +66,7 @@ public final class RoundTripHFPlaceholder12 extends RecordAtom {
*/
protected RoundTripHFPlaceholder12(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
_placeholderId = source[start+8];
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SSSlideInfoAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/SSSlideInfoAtom.java
index e0d28e5dfa..7bd098f92b 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SSSlideInfoAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SSSlideInfoAtom.java
@@ -21,6 +21,7 @@ import static org.apache.poi.util.GenericRecordUtil.getBitsAsString;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -31,7 +32,7 @@ import org.apache.poi.util.LittleEndianConsts;
/**
* A SlideShowSlideInfo Atom (type 1017).<br>
* <br>
- *
+ *
* An atom record that specifies which transition effects to perform
* during a slide show, and how to advance to the next presentation slide.<br>
* <br>
@@ -70,30 +71,30 @@ public class SSSlideInfoAtom extends RecordAtom {
* manually advanced by the user during the slide show.
*/
public static final int MANUAL_ADVANCE_BIT = 1 << 0;
-
+
/**
- * A bit that specifies whether the corresponding slide is
+ * A bit that specifies whether the corresponding slide is
* hidden and is not displayed during the slide show.
*/
public static final int HIDDEN_BIT = 1 << 2;
-
+
/**
* A bit that specifies whether to play the sound specified by soundIfRef.
*/
public static final int SOUND_BIT = 1 << 4;
-
+
/**
* A bit that specifies whether the sound specified by soundIdRef is
* looped continuously when playing until the next sound plays.
*/
public static final int LOOP_SOUND_BIT = 1 << 6;
-
+
/**
- * A bit that specifies whether to stop any currently playing
+ * A bit that specifies whether to stop any currently playing
* sound when the transition starts.
*/
public static final int STOP_SOUND_BIT = 1 << 8;
-
+
/**
* A bit that specifies whether the slide will automatically
* advance after slideTime milliseconds during the slide show.
@@ -102,10 +103,10 @@ public class SSSlideInfoAtom extends RecordAtom {
/**
* A bit that specifies whether to display the cursor during
- * the slide show.
+ * the slide show.
*/
public static final int CURSOR_VISIBLE_BIT = 1 << 12;
-
+
// public static int RESERVED1_BIT = 1 << 1;
// public static int RESERVED2_BIT = 1 << 3;
// public static int RESERVED3_BIT = 1 << 5;
@@ -144,9 +145,9 @@ public class SSSlideInfoAtom extends RecordAtom {
* less than or equal to 86399000. It MUST be ignored unless AUTO_ADVANCE_BIT is TRUE.
*/
private int _slideTime;
-
+
/**
- * A SoundIdRef that specifies which sound to play when the transition starts.
+ * A SoundIdRef that specifies which sound to play when the transition starts.
*/
private int _soundIdRef;
@@ -155,23 +156,23 @@ public class SSSlideInfoAtom extends RecordAtom {
* there are further restriction and specification of this field.
*/
private short _effectDirection; // byte
-
+
/**
* A byte that specifies which transition is used when transitioning to the
- * next presentation slide during a slide show. Exact rendering of any transition is
+ * next presentation slide during a slide show. Exact rendering of any transition is
* determined by the rendering application. As such, the same transition can have
* many variations depending on the implementation.
*/
private short _effectType; // byte
-
+
/**
* Various flags - see bitmask for more details
*/
private short _effectTransitionFlags;
-
+
/**
* A byte value that specifies how long the transition takes to run.
- * (0x00 = 0.75 seconds, 0x01 = 0.5 seconds, 0x02 = 0.25 seconds)
+ * (0x00 = 0.75 seconds, 0x01 = 0.5 seconds, 0x02 = 0.25 seconds)
*/
private short _speed; // byte
private byte[] _unused; // 3-byte
@@ -184,18 +185,18 @@ public class SSSlideInfoAtom extends RecordAtom {
LittleEndian.putShort(_header, 6, (short)0);
_unused = new byte[3];
}
-
+
public SSSlideInfoAtom(byte[] source, int offset, int len) {
int ofs = offset;
// Sanity Checking
if(len != 24) len = 24;
assert(source.length >= offset+len);
-
+
// Get the header
- _header = LittleEndian.getByteArray(source,ofs,8);
+ _header = Arrays.copyOfRange(source, ofs, ofs+8);
ofs += _header.length;
-
+
assert(LittleEndian.getShort(_header, 0) == 0);
assert(LittleEndian.getShort(_header, 2) == RecordTypes.SSSlideInfoAtom.typeID);
assert(LittleEndian.getShort(_header, 4) == 0x10);
@@ -214,7 +215,7 @@ public class SSSlideInfoAtom extends RecordAtom {
ofs += LittleEndianConsts.SHORT_SIZE;
_speed = LittleEndian.getUByte(source, ofs);
ofs += LittleEndianConsts.BYTE_SIZE;
- _unused = LittleEndian.getByteArray(source,ofs,3);
+ _unused = Arrays.copyOfRange(source,ofs,ofs+3);
}
/**
@@ -232,7 +233,7 @@ public class SSSlideInfoAtom extends RecordAtom {
out.write(byteBuf);
LittleEndian.putUByte(byteBuf, 0, _effectType);
out.write(byteBuf);
-
+
writeLittleEndian(_effectTransitionFlags, out);
LittleEndian.putUByte(byteBuf, 0, _speed);
out.write(byteBuf);
@@ -240,7 +241,7 @@ public class SSSlideInfoAtom extends RecordAtom {
assert(_unused.length == 3);
out.write(_unused);
}
-
+
/**
* We are of type 1017
*/
@@ -303,7 +304,7 @@ public class SSSlideInfoAtom extends RecordAtom {
public boolean getEffectTransitionFlagByBit(int bitmask) {
return ((_effectTransitionFlags & bitmask) != 0);
}
-
+
public short getSpeed() {
return _speed;
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Slide.java b/src/scratchpad/src/org/apache/poi/hslf/record/Slide.java
index 4534de034a..cf8d2466c0 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Slide.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Slide.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
@@ -56,24 +57,22 @@ public final class Slide extends SheetContainer
*/
protected Slide(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
// Find the interesting ones in there
- for(int i=0; i<_children.length; i++) {
- if(_children[i] instanceof SlideAtom) {
- slideAtom = (SlideAtom)_children[i];
- }
- else if(_children[i] instanceof PPDrawing) {
- ppDrawing = (PPDrawing)_children[i];
+ for (Record child : _children) {
+ if (child instanceof SlideAtom) {
+ slideAtom = (SlideAtom) child;
+ } else if (child instanceof PPDrawing) {
+ ppDrawing = (PPDrawing) child;
}
- if(ppDrawing != null && _children[i] instanceof ColorSchemeAtom) {
- _colorScheme = (ColorSchemeAtom)_children[i];
- }
+ if (ppDrawing != null && child instanceof ColorSchemeAtom) {
+ _colorScheme = (ColorSchemeAtom) child;
+ }
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtom.java
index e5b85a7e00..5728bacf4c 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -83,12 +84,10 @@ public final class SlideAtom extends RecordAtom {
if(len < 30) { len = 30; }
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the 12 bytes that is "SSlideLayoutAtom"
- byte[] SSlideLayoutAtomData = new byte[12];
- System.arraycopy(source,start+8,SSlideLayoutAtomData,0,12);
+ byte[] SSlideLayoutAtomData = Arrays.copyOfRange(source,start+8, start+12+8);
// Use them to build up the SSlideLayoutAtom
layoutAtom = new SlideAtomLayout(SSlideLayoutAtomData);
@@ -98,26 +97,13 @@ public final class SlideAtom extends RecordAtom {
// Grok the flags, stored as bits
int flags = LittleEndian.getUShort(source,start+20+8);
- if((flags&4) == 4) {
- followMasterBackground = true;
- } else {
- followMasterBackground = false;
- }
- if((flags&2) == 2) {
- followMasterScheme = true;
- } else {
- followMasterScheme = false;
- }
- if((flags&1) == 1) {
- followMasterObjects = true;
- } else {
- followMasterObjects = false;
- }
+ followMasterBackground = (flags & 4) == 4;
+ followMasterScheme = (flags & 2) == 2;
+ followMasterObjects = (flags & 1) == 1;
// If there's any other bits of data, keep them about
// 8 bytes header + 20 bytes to flags + 2 bytes flags = 30 bytes
- reserved = IOUtils.safelyAllocate(len-30, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+30,reserved,0,reserved.length);
+ reserved = IOUtils.safelyClone(source,start+30, len-30, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtomLayout.java b/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtomLayout.java
index 9b27fe2282..e91bc7ddb4 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtomLayout.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SlideAtomLayout.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -32,7 +33,7 @@ import org.apache.poi.util.LittleEndian;
* Holds the geometry of the Slide, and the ID of the placeholders on the slide.
* Embedded inside a SlideAtom is a SlideAtomLayout, without the usual record header.
* Since it's a fixed size and tied to the SlideAtom, we'll hold it here.<p>
- *
+ *
* This might eventually merged with the XSLF counterpart
*/
@Internal
@@ -82,7 +83,7 @@ public class SlideAtomLayout implements GenericRecord {
SlideLayoutType(int nativeId) {
this.nativeId = nativeId;
}
-
+
public int getNativeId() {
return nativeId;
}
@@ -117,8 +118,7 @@ public class SlideAtomLayout implements GenericRecord {
// Grab out our data
geometry = SlideLayoutType.forNativeID(LittleEndian.getInt(data,0));
- placeholderIDs = new byte[8];
- System.arraycopy(data,4,placeholderIDs,0,8);
+ placeholderIDs = Arrays.copyOfRange(data,4, 4+8);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SlideListWithText.java b/src/scratchpad/src/org/apache/poi/hslf/record/SlideListWithText.java
index 516bbda7b0..d0298a5be2 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SlideListWithText.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SlideListWithText.java
@@ -20,6 +20,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import org.apache.poi.util.LittleEndian;
@@ -74,8 +75,7 @@ public final class SlideListWithText extends RecordContainer {
*/
protected SlideListWithText(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
@@ -96,8 +96,7 @@ public final class SlideListWithText extends RecordContainer {
// Create a SlideAtomsSets, not caring if they're empty
//if(emptySet) { continue; }
- org.apache.poi.hslf.record.Record[] spaChildren = new org.apache.poi.hslf.record.Record[clen];
- System.arraycopy(_children,i+1,spaChildren,0,clen);
+ org.apache.poi.hslf.record.Record[] spaChildren = Arrays.copyOfRange(_children,i+1, i+1+clen, org.apache.poi.hslf.record.Record[].class);
SlideAtomsSet set = new SlideAtomsSet((SlidePersistAtom)_children[i],spaChildren);
sets.add(set);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SlidePersistAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/SlidePersistAtom.java
index 34a5560253..d52552ab7b 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SlidePersistAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SlidePersistAtom.java
@@ -21,6 +21,7 @@ import static org.apache.poi.util.GenericRecordUtil.getBitsAsString;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -44,7 +45,7 @@ public final class SlidePersistAtom extends RecordAtom {
private static final String[] FLAGS_NAMES = { "HAS_SHAPES_OTHER_THAN_PLACEHOLDERS" };
- private final byte[] _header = new byte[8];
+ private final byte[] _header;
/** Slide reference ID. Should correspond to the PersistPtr "sheet ID" of the matching slide/notes record */
private int refID;
@@ -91,7 +92,7 @@ public final class SlidePersistAtom extends RecordAtom {
if(len < 8) { len = 8; }
// Get the header
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the reference ID
refID = LittleEndian.getInt(source,start+8);
@@ -107,14 +108,14 @@ public final class SlidePersistAtom extends RecordAtom {
// Finally you have typically 4 or 8 bytes of reserved fields,
// all zero running from 24 bytes in to the end
- reservedFields = IOUtils.safelyAllocate(len-24, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+24,reservedFields,0,reservedFields.length);
+ reservedFields = IOUtils.safelyClone(source,start+24, len-24, MAX_RECORD_LENGTH);
}
/**
* Create a new SlidePersistAtom, for use with a new Slide
*/
public SlidePersistAtom() {
+ _header = new byte[8];
LittleEndian.putUShort(_header, 0, 0);
LittleEndian.putUShort(_header, 2, (int)_type);
LittleEndian.putInt(_header, 4, 20);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/Sound.java b/src/scratchpad/src/org/apache/poi/hslf/record/Sound.java
index f454e4d208..27a2c1b8cf 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/Sound.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/Sound.java
@@ -17,10 +17,11 @@
package org.apache.poi.hslf.record;
-import org.apache.poi.util.POILogger;
-
-import java.io.OutputStream;
import java.io.IOException;
+import java.io.OutputStream;
+import java.util.Arrays;
+
+import org.apache.poi.util.POILogger;
/**
* A container holding information about a sound. It contains:
@@ -55,8 +56,7 @@ public final class Sound extends RecordContainer {
*/
protected Sound(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SoundCollection.java b/src/scratchpad/src/org/apache/poi/hslf/record/SoundCollection.java
index abea3887f0..3fda587c6e 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SoundCollection.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SoundCollection.java
@@ -17,8 +17,9 @@
package org.apache.poi.hslf.record;
-import java.io.OutputStream;
import java.io.IOException;
+import java.io.OutputStream;
+import java.util.Arrays;
/**
* Is a container for all sound related atoms and containers. It contains:
@@ -42,8 +43,7 @@ public final class SoundCollection extends RecordContainer {
*/
protected SoundCollection(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source,start+8,len-8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/SoundData.java b/src/scratchpad/src/org/apache/poi/hslf/record/SoundData.java
index 09f9d5c1a7..0989052c56 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/SoundData.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/SoundData.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -68,12 +69,10 @@ public final class SoundData extends RecordAtom {
*/
protected SoundData(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextProp9Atom.java b/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextProp9Atom.java
index cedea7f646..20317e3074 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextProp9Atom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextProp9Atom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
@@ -45,7 +46,7 @@ public final class StyleTextProp9Atom extends RecordAtom {
private short version;
private short recordId;
private int length;
-
+
/**
* Constructs the link related atom record from its
* source data.
@@ -57,35 +58,33 @@ public final class StyleTextProp9Atom extends RecordAtom {
protected StyleTextProp9Atom(byte[] source, int start, int len) {
// Get the header.
final List<TextPFException9> schemes = new LinkedList<>();
- header = new byte[8];
- System.arraycopy(source,start, header,0,8);
+ header = Arrays.copyOfRange(source, start, start+8);
this.version = LittleEndian.getShort(header, 0);
this.recordId = LittleEndian.getShort(header, 2);
this.length = LittleEndian.getInt(header, 4);
-
+
// Get the record data.
- data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source, start+8, data, 0, len-8);
+ data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
for (int i = 0; i < data.length; ) {
final TextPFException9 item = new TextPFException9(data, i);
schemes.add(item);
i += item.getRecordLength();
-
+
if (i+4 >= data.length) {
break;
}
int textCfException9 = LittleEndian.getInt(data, i );
i += 4;
//TODO analyze textCfException when have some test data
-
+
if (i+4 >= data.length) {
break;
}
int textSiException = LittleEndian.getInt(data, i );
i += 4;//TextCFException9 + SIException
-
- if (0 != (textSiException & 0x40)) {
- i += 2; //skip fBidi
+
+ if (0 != (textSiException & 0x40)) {
+ i += 2; //skip fBidi
}
if (i+4 >= data.length) {
break;
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextPropAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextPropAtom.java
index 0d2a23ba60..2e0084e323 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextPropAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/StyleTextPropAtom.java
@@ -21,6 +21,7 @@ import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
@@ -130,13 +131,11 @@ public final class StyleTextPropAtom extends RecordAtom {
}
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Save the contents of the atom, until we're asked to go and
// decode them (via a call to setParentTextSize(int)
- rawContents = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,rawContents,0,rawContents.length);
+ rawContents = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
reserved = new byte[0];
// Set empty lists, ready for when they call setParentTextSize
@@ -289,8 +288,7 @@ public final class StyleTextPropAtom extends RecordAtom {
// Handle anything left over
if(pos < rawContents.length) {
- reserved = IOUtils.safelyAllocate(rawContents.length-pos, rawContents.length);
- System.arraycopy(rawContents,pos,reserved,0,reserved.length);
+ reserved = IOUtils.safelyClone(rawContents, pos, rawContents.length-pos, rawContents.length);
}
initialised = true;
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/TextBytesAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/TextBytesAtom.java
index cd84b7b8da..81a503b95c 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/TextBytesAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/TextBytesAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -69,12 +70,10 @@ public final class TextBytesAtom extends RecordAtom {
if(len < 8) { len = 8; }
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the text
- _text = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_text,0,len-8);
+ _text = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/TextCharsAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/TextCharsAtom.java
index 078f1d9ef7..768aaba6ef 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/TextCharsAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/TextCharsAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -68,12 +69,10 @@ public final class TextCharsAtom extends RecordAtom {
if(len < 8) { len = 8; }
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the text
- _text = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_text,0,len-8);
+ _text = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
* Create an empty TextCharsAtom
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/TextHeaderAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/TextHeaderAtom.java
index 3a2d01adfb..99ac049994 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/TextHeaderAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/TextHeaderAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -84,8 +85,7 @@ public final class TextHeaderAtom extends RecordAtom implements ParentAwareRecor
}
// Get the header
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Grab the type
textType = LittleEndian.getInt(source,start+8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/TextSpecInfoAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/TextSpecInfoAtom.java
index d572290657..b26e9cb04b 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/TextSpecInfoAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/TextSpecInfoAtom.java
@@ -21,6 +21,7 @@ import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
@@ -43,7 +44,7 @@ public final class TextSpecInfoAtom extends RecordAtom {
private static final int MAX_RECORD_LENGTH = 100_000;
private static final long _type = RecordTypes.TextSpecInfoAtom.typeID;
-
+
/**
* Record header.
*/
@@ -55,14 +56,14 @@ public final class TextSpecInfoAtom extends RecordAtom {
private byte[] _data;
/**
- * Constructs an empty atom, with a default run of size 1
+ * Constructs an empty atom, with a default run of size 1
*/
public TextSpecInfoAtom() {
_header = new byte[8];
LittleEndian.putUInt(_header, 4, _type);
reset(1);
}
-
+
/**
* Constructs the link related atom record from its
* source data.
@@ -73,13 +74,10 @@ public final class TextSpecInfoAtom extends RecordAtom {
*/
public TextSpecInfoAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
-
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
* Gets the record type.
@@ -157,7 +155,7 @@ public final class TextSpecInfoAtom extends RecordAtom {
// Update the size (header bytes 5-8)
LittleEndian.putInt(_header, 4, _data.length);
}
-
+
/**
* Get the number of characters covered by this records
*
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/TxInteractiveInfoAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/TxInteractiveInfoAtom.java
index 469de32a56..f5896aa817 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/TxInteractiveInfoAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/TxInteractiveInfoAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -67,13 +68,10 @@ public final class TxInteractiveInfoAtom extends RecordAtom {
*/
protected TxInteractiveInfoAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,len-8);
-
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/TxMasterStyleAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/TxMasterStyleAtom.java
index 2597ccbe67..40a85fab1c 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/TxMasterStyleAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/TxMasterStyleAtom.java
@@ -21,6 +21,7 @@ import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
@@ -70,11 +71,9 @@ public final class TxMasterStyleAtom extends RecordAtom {
private List<TextPropCollection> charStyles;
protected TxMasterStyleAtom(byte[] source, int start, int len) {
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
- _data = IOUtils.safelyAllocate(len-8, MAX_RECORD_LENGTH);
- System.arraycopy(source,start+8,_data,0,_data.length);
+ _data = IOUtils.safelyClone(source, start+8, len-8, MAX_RECORD_LENGTH);
//read available styles
try {
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/UnknownRecordPlaceholder.java b/src/scratchpad/src/org/apache/poi/hslf/record/UnknownRecordPlaceholder.java
index e483ce7424..886a0dd20f 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/UnknownRecordPlaceholder.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/UnknownRecordPlaceholder.java
@@ -53,8 +53,7 @@ public final class UnknownRecordPlaceholder extends RecordAtom
if(len < 0) { len = 0; }
// Treat as an atom, grab and hold everything
- _contents = IOUtils.safelyAllocate(len, MAX_RECORD_LENGTH);
- System.arraycopy(source,start,_contents,0,len);
+ _contents = IOUtils.safelyClone(source, start, len, MAX_RECORD_LENGTH);
_type = LittleEndian.getUShort(_contents,2);
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java
index 287da27798..b89da4a98c 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/UserEditAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.Map;
@@ -89,8 +90,7 @@ public final class UserEditAtom extends PositionDependentRecordAtom
int offset = start;
// Get the header
- _header = new byte[8];
- System.arraycopy(source,offset,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
offset += 8;
// Get the last viewed slide ID
@@ -125,7 +125,7 @@ public final class UserEditAtom extends PositionDependentRecordAtom
// Last view type
lastViewType = LittleEndian.getShort(source,offset);
offset += LittleEndianConsts.SHORT_SIZE;
-
+
// unused
unused = LittleEndian.getShort(source,offset);
offset += LittleEndianConsts.SHORT_SIZE;
@@ -135,7 +135,7 @@ public final class UserEditAtom extends PositionDependentRecordAtom
encryptSessionPersistIdRef = LittleEndian.getInt(source,offset);
offset += LittleEndianConsts.INT_SIZE;
}
-
+
assert(offset-start == len);
}
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoAtom.java b/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoAtom.java
index eb4d337383..4607bb6141 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoAtom.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoAtom.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
@@ -30,7 +31,7 @@ import org.apache.poi.util.LittleEndian;
*/
public final class VBAInfoAtom extends RecordAtom {
private static final long _type = RecordTypes.VBAInfoAtom.typeID;
-
+
/**
* Record header.
*/
@@ -44,7 +45,7 @@ public final class VBAInfoAtom extends RecordAtom {
private long version;
/**
- * Constructs an empty atom - not yet supported
+ * Constructs an empty atom - not yet supported
*/
private VBAInfoAtom() {
_header = new byte[8];
@@ -54,7 +55,7 @@ public final class VBAInfoAtom extends RecordAtom {
hasMacros = true;
version = 2;
}
-
+
/**
* Constructs the vba atom record from its source data.
*
@@ -64,8 +65,7 @@ public final class VBAInfoAtom extends RecordAtom {
*/
public VBAInfoAtom(byte[] source, int start, int len) {
// Get the header.
- _header = new byte[8];
- System.arraycopy(source,start,_header,0,8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Get the record data.
persistIdRef = LittleEndian.getUInt(source, start+8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoContainer.java b/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoContainer.java
index cf9f6159cc..043cea2286 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoContainer.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/record/VBAInfoContainer.java
@@ -19,6 +19,7 @@ package org.apache.poi.hslf.record;
import java.io.IOException;
import java.io.OutputStream;
+import java.util.Arrays;
import org.apache.poi.util.LittleEndian;
@@ -36,8 +37,7 @@ public final class VBAInfoContainer extends RecordContainer {
*/
protected VBAInfoContainer(byte[] source, int start, int len) {
// Grab the header
- _header = new byte[8];
- System.arraycopy(source, start, _header, 0, 8);
+ _header = Arrays.copyOfRange(source, start, start+8);
// Find our children
_children = Record.findChildRecords(source, start + 8, len - 8);
diff --git a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFPictureData.java b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFPictureData.java
index e7f92a4a9f..f5b2eaa1ce 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFPictureData.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFPictureData.java
@@ -21,6 +21,7 @@ import java.awt.Dimension;
import java.io.IOException;
import java.io.OutputStream;
import java.security.MessageDigest;
+import java.util.Arrays;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.Map;
@@ -129,9 +130,7 @@ public abstract class HSLFPictureData implements PictureData, GenericRecord {
* Returns 16-byte checksum of this picture
*/
public byte[] getUID(){
- byte[] uid = new byte[16];
- System.arraycopy(rawdata, 0, uid, 0, uid.length);
- return uid;
+ return Arrays.copyOf(rawdata, 16);
}
@Override
diff --git a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShowImpl.java b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShowImpl.java
index 9ad2c7ccde..6f1c633ea3 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShowImpl.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFSlideShowImpl.java
@@ -301,7 +301,7 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
// check for corrupted user edit atom and try to repair it
// if the next user edit atom offset is already known, we would go into an endless loop
if (usrOffset > 0 && recordMap.containsKey(usrOffset)) {
- // a user edit atom is usually located 36 byte before the smallest known record offset
+ // a user edit atom is usually located 36 byte before the smallest known record offset
usrOffset = recordMap.firstKey() - 36;
// check that we really are located on a user edit atom
int ver_inst = LittleEndian.getUShort(docstream, usrOffset);
@@ -415,8 +415,7 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
pict.setSignature(signature);
// Copy the data, ready to pass to PictureData
- byte[] imgdata = IOUtils.safelyAllocate(imgsize, MAX_RECORD_LENGTH);
- System.arraycopy(pictstream, pos, imgdata, 0, imgdata.length);
+ byte[] imgdata = IOUtils.safelyClone(pictstream, pos, imgsize, MAX_RECORD_LENGTH);
pict.setRawData(imgdata);
pict.setOffset(offset);
@@ -563,7 +562,7 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
validateInPlaceWritePossible();
// Write the PowerPoint streams to the current FileSystem
- // No need to do anything to other streams, already there!
+ // No need to do anything to other streams, already there!
write(getDirectory().getFileSystem(), false);
// Sync with the File on disk
@@ -649,7 +648,7 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
}
private void write(POIFSFileSystem outFS, boolean copyAllOtherNodes) throws IOException {
- // read properties and pictures, with old encryption settings where appropriate
+ // read properties and pictures, with old encryption settings where appropriate
if (_pictures == null) {
readPictures();
}
@@ -673,8 +672,7 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
updateAndWriteDependantRecords(baos, null);
// Update our cached copy of the bytes that make up the PPT stream
- _docstream = new byte[baos.size()];
- System.arraycopy(baos.getBuf(), 0, _docstream, 0, baos.size());
+ _docstream = baos.toByteArray();
baos.close();
// Write the PPT stream into the POIFS layer
@@ -701,7 +699,7 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
}
}
-
+
// If requested, copy over any other streams we spot, eg Macros
if (copyAllOtherNodes) {
EntryUtils.copyNodes(getDirectory().getFileSystem(), outFS, writtenEntries);
@@ -715,9 +713,9 @@ public final class HSLFSlideShowImpl extends POIDocument implements Closeable {
return (dea != null) ? dea.getEncryptionInfo() : null;
}
-
-
-
+
+
+
/* ******************* adding methods follow ********************* */
/**
diff --git a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFTextParagraph.java b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFTextParagraph.java
index ba9d1495bc..6e1b7611d1 100644
--- a/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFTextParagraph.java
+++ b/src/scratchpad/src/org/apache/poi/hslf/usermodel/HSLFTextParagraph.java
@@ -22,6 +22,7 @@ import static org.apache.poi.hslf.record.RecordTypes.OutlineTextRefAtom;
import java.awt.Color;
import java.io.IOException;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.function.Consumer;
@@ -333,8 +334,7 @@ public final class HSLFTextParagraph implements TextParagraph<HSLFShape,HSLFText
}
}
- org.apache.poi.hslf.record.Record[] result = new org.apache.poi.hslf.record.Record[length];
- System.arraycopy(records, startIdx[0], result, 0, length);
+ org.apache.poi.hslf.record.Record[] result = Arrays.copyOfRange(records, startIdx[0], startIdx[0]+length, org.apache.poi.hslf.record.Record[].class);
startIdx[0] += length;
return result;
diff --git a/src/scratchpad/src/org/apache/poi/hssf/converter/ExcelToHtmlUtils.java b/src/scratchpad/src/org/apache/poi/hssf/converter/ExcelToHtmlUtils.java
index 651d1f0dda..63e71d9b98 100644
--- a/src/scratchpad/src/org/apache/poi/hssf/converter/ExcelToHtmlUtils.java
+++ b/src/scratchpad/src/org/apache/poi/hssf/converter/ExcelToHtmlUtils.java
@@ -39,7 +39,7 @@ public class ExcelToHtmlUtils extends AbstractExcelUtils {
* Creates a map (i.e. two-dimensional array) filled with ranges. Allow fast
* retrieving {@link CellRangeAddress} of any cell, if cell is contained in
* range.
- *
+ *
* @see #getMergedRange(CellRangeAddress[][], int, int)
*/
public static CellRangeAddress[][] buildMergedRangesMap( Sheet sheet ) {
@@ -47,10 +47,7 @@ public class ExcelToHtmlUtils extends AbstractExcelUtils {
for ( final CellRangeAddress cellRangeAddress : sheet.getMergedRegions() ) {
final int requiredHeight = cellRangeAddress.getLastRow() + 1;
if ( mergedRanges.length < requiredHeight ) {
- CellRangeAddress[][] newArray = new CellRangeAddress[requiredHeight][];
- System.arraycopy( mergedRanges, 0, newArray, 0,
- mergedRanges.length );
- mergedRanges = newArray;
+ mergedRanges = Arrays.copyOf(mergedRanges, requiredHeight, CellRangeAddress[][].class);
}
for ( int r = cellRangeAddress.getFirstRow(); r <= cellRangeAddress
@@ -63,14 +60,9 @@ public class ExcelToHtmlUtils extends AbstractExcelUtils {
mergedRanges[r] = rowMerged;
} else {
final int rowMergedLength = rowMerged.length;
- if ( rowMergedLength < requiredWidth )
- {
- final CellRangeAddress[] newRow = new CellRangeAddress[requiredWidth];
- System.arraycopy( rowMerged, 0, newRow, 0,
- rowMergedLength );
-
- mergedRanges[r] = newRow;
- rowMerged = newRow;
+ if ( rowMergedLength < requiredWidth ) {
+ rowMerged = mergedRanges[r] =
+ Arrays.copyOf(rowMerged, requiredWidth, CellRangeAddress[].class);
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hwmf/record/HwmfText.java b/src/scratchpad/src/org/apache/poi/hwmf/record/HwmfText.java
index bbeb4ac98b..5229b34c18 100644
--- a/src/scratchpad/src/org/apache/poi/hwmf/record/HwmfText.java
+++ b/src/scratchpad/src/org/apache/poi/hwmf/record/HwmfText.java
@@ -225,9 +225,7 @@ public class HwmfText {
* This does not include the extra optional padding on the byte array.
*/
private byte[] getTextBytes() {
- byte[] ret = IOUtils.safelyAllocate(stringLength, MAX_RECORD_LENGTH);
- System.arraycopy(rawTextBytes, 0, ret, 0, stringLength);
- return ret;
+ return IOUtils.safelyClone(rawTextBytes, 0, stringLength, MAX_RECORD_LENGTH);
}
@Override
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/HWPFOldDocument.java b/src/scratchpad/src/org/apache/poi/hwpf/HWPFOldDocument.java
index 230174637e..6cf4027cad 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/HWPFOldDocument.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/HWPFOldDocument.java
@@ -60,12 +60,12 @@ public class HWPFOldDocument extends HWPFDocumentCore {
private final static Charset DEFAULT_CHARSET = StringUtil.WIN_1252;
private OldTextPieceTable tpt;
-
+
private StringBuilder _text;
private final OldFontTable fontTable;
private final Charset guessedCharset;
-
+
public HWPFOldDocument(POIFSFileSystem fs) throws IOException {
this(fs.getRoot());
}
@@ -73,7 +73,7 @@ public class HWPFOldDocument extends HWPFDocumentCore {
public HWPFOldDocument(DirectoryNode directory)
throws IOException {
super(directory);
-
+
// Where are things?
int sedTableOffset = LittleEndian.getInt(_mainStream, 0x88);
int sedTableSize = LittleEndian.getInt(_mainStream, 0x8c);
@@ -91,7 +91,7 @@ public class HWPFOldDocument extends HWPFDocumentCore {
guessedCharset = guessCodePage(fontTable);
int complexTableOffset = LittleEndian.getInt(_mainStream, 0x160);
-
+
// We need to get hold of the text that makes up the
// document, which might be regular or fast-saved
ComplexFileTable cft = null;
@@ -101,7 +101,7 @@ public class HWPFOldDocument extends HWPFDocumentCore {
complexTableOffset, _fib.getFibBase().getFcMin(), guessedCharset
);
tpt = (OldTextPieceTable)cft.getTextPieceTable();
-
+
} else {
// TODO Discover if these older documents can ever hold Unicode Strings?
// (We think not, because they seem to lack a Piece table)
@@ -118,7 +118,7 @@ public class HWPFOldDocument extends HWPFDocumentCore {
logger.log(POILogger.WARN, "Error with "+guessedCharset +". Backing off to Windows-1252");
}
tpt.add(tp);
-
+
}
_text = tpt.getText();
@@ -171,19 +171,16 @@ public class HWPFOldDocument extends HWPFDocumentCore {
// Generate a single Text Piece Table, with a single Text Piece
// which covers all the (8 bit only) text in the file
tpt = new OldTextPieceTable();
- byte[] textData = IOUtils.safelyAllocate(
- _fib.getFibBase().getFcMac()-_fib.getFibBase().getFcMin(), MAX_RECORD_LENGTH);
- System.arraycopy(_mainStream, _fib.getFibBase().getFcMin(), textData, 0, textData.length);
+
+ byte[] textData = IOUtils.safelyClone(_mainStream, _fib.getFibBase().getFcMin(),
+ _fib.getFibBase().getFcMac()-_fib.getFibBase().getFcMin(), MAX_RECORD_LENGTH);
int numChars = textData.length;
if (CodePageUtil.DOUBLE_BYTE_CHARSETS.contains(guessedCharset)) {
numChars /= 2;
}
- return new TextPiece(
- 0, numChars, textData, pd
- );
-
+ return new TextPiece(0, numChars, textData, pd);
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/CHPFormattedDiskPage.java b/src/scratchpad/src/org/apache/poi/hwpf/model/CHPFormattedDiskPage.java
index 5191342c14..349f39b634 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/CHPFormattedDiskPage.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/CHPFormattedDiskPage.java
@@ -62,7 +62,7 @@ public final class CHPFormattedDiskPage extends FormattedDiskPage
/**
* This constructs a CHPFormattedDiskPage from a raw fkp (512 byte array
* read from a Word file).
- *
+ *
* @deprecated Use
* {@link #CHPFormattedDiskPage(byte[], int, CharIndexTranslator)}
* instead
@@ -134,17 +134,13 @@ public final class CHPFormattedDiskPage extends FormattedDiskPage
int chpxOffset = 2 * LittleEndian.getUByte(_fkp, _offset + (((_crun + 1) * 4) + index));
//optimization if offset == 0 use "Normal" style
- if(chpxOffset == 0)
- {
+ if(chpxOffset == 0) {
return new byte[0];
}
int size = LittleEndian.getUByte(_fkp, _offset + chpxOffset);
- byte[] chpx = IOUtils.safelyAllocate(size, MAX_RECORD_LENGTH);
-
- System.arraycopy(_fkp, _offset + ++chpxOffset, chpx, 0, size);
- return chpx;
+ return IOUtils.safelyClone(_fkp, _offset + chpxOffset + 1, size, MAX_RECORD_LENGTH);
}
protected byte[] toByteArray( CharIndexTranslator translator )
@@ -184,7 +180,7 @@ public final class CHPFormattedDiskPage extends FormattedDiskPage
if (index == 0) {
throw new RecordFormatException("empty grpprl entry.");
}
-
+
// see if we couldn't fit some
if ( index != size )
{
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/ComplexFileTable.java b/src/scratchpad/src/org/apache/poi/hwpf/model/ComplexFileTable.java
index 9d6b631e4c..7dc6081cc5 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/ComplexFileTable.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/ComplexFileTable.java
@@ -25,6 +25,7 @@ import java.util.List;
import org.apache.poi.hwpf.model.io.HWPFFileSystem;
import org.apache.poi.hwpf.sprm.SprmBuffer;
+import org.apache.poi.util.IOUtils;
import org.apache.poi.util.Internal;
import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.LittleEndianConsts;
@@ -56,7 +57,7 @@ public class ComplexFileTable {
offset++;
int size = LittleEndian.getShort(tableStream, offset);
offset += LittleEndianConsts.SHORT_SIZE;
- byte[] bs = LittleEndian.getByteArray(tableStream, offset, size, MAX_RECORD_LENGTH);
+ byte[] bs = IOUtils.safelyClone(tableStream, offset, size, MAX_RECORD_LENGTH);
offset += size;
SprmBuffer sprmBuffer = new SprmBuffer(bs, false, 0);
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/DocumentProperties.java b/src/scratchpad/src/org/apache/poi/hwpf/model/DocumentProperties.java
index c9aa4326ad..f292643fb1 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/DocumentProperties.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/DocumentProperties.java
@@ -23,11 +23,10 @@ import java.io.IOException;
import org.apache.poi.hwpf.model.types.DOPAbstractType;
import org.apache.poi.util.IOUtils;
import org.apache.poi.util.Internal;
-import org.apache.poi.util.LittleEndian;
/**
* Comment me
- *
+ *
* @author Ryan Ackley
*/
@Internal
@@ -54,8 +53,7 @@ public final class DocumentProperties extends DOPAbstractType
final int supportedSize = DOPAbstractType.getSize();
if ( length != supportedSize )
{
- this._preserved = LittleEndian.getByteArray( tableStream, offset
- + supportedSize, length - supportedSize, MAX_RECORD_LENGTH );
+ this._preserved = IOUtils.safelyClone( tableStream, offset + supportedSize, length - supportedSize, MAX_RECORD_LENGTH );
}
else
{
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/FileInformationBlock.java b/src/scratchpad/src/org/apache/poi/hwpf/model/FileInformationBlock.java
index 15dca2fb16..6e055f186d 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/FileInformationBlock.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/FileInformationBlock.java
@@ -111,7 +111,6 @@ public final class FileInformationBlock
_cbRgFcLcb = LittleEndian.getUShort( mainDocument, offset );
offset += LittleEndianConsts.SHORT_SIZE;
- assert offset == 154;
// skip fibRgFcLcbBlob (read later at fillVariableFields)
offset += _cbRgFcLcb * LittleEndianConsts.INT_SIZE * 2;
@@ -125,11 +124,8 @@ public final class FileInformationBlock
offset += LittleEndianConsts.SHORT_SIZE;
// first short is already read as _nFibNew
- final int fibRgCswNewLength = ( _cswNew - 1 )
- * LittleEndianConsts.SHORT_SIZE;
- _fibRgCswNew = IOUtils.safelyAllocate(fibRgCswNewLength, MAX_RECORD_LENGTH);
- LittleEndian.getByteArray( mainDocument, offset, fibRgCswNewLength, MAX_RECORD_LENGTH );
- offset += fibRgCswNewLength;
+ final int fibRgCswNewLength = ( _cswNew - 1 ) * LittleEndianConsts.SHORT_SIZE;
+ _fibRgCswNew = IOUtils.safelyClone(mainDocument, offset, fibRgCswNewLength, MAX_RECORD_LENGTH);
}
else
{
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/OldSectionTable.java b/src/scratchpad/src/org/apache/poi/hwpf/model/OldSectionTable.java
index f93604fffd..684d3bd8b5 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/OldSectionTable.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/OldSectionTable.java
@@ -72,9 +72,8 @@ public final class OldSectionTable extends SectionTable
// section properties, and we're trying to decode them as if they
// were the new ones, we sometimes "need" more data than we have.
// As a workaround, have a few extra 0 bytes on the end!
- byte[] buf = IOUtils.safelyAllocate(sepxSize+2, Short.MAX_VALUE+2);
fileOffset += LittleEndianConsts.SHORT_SIZE;
- System.arraycopy(documentStream, fileOffset, buf, 0, buf.length);
+ byte[] buf = IOUtils.safelyClone(documentStream, fileOffset, sepxSize+2, Short.MAX_VALUE+2);
sepx = new SEPX(sed, startAt, endAt, buf);
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPiece.java b/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPiece.java
index 1386b0af65..b14c38223d 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPiece.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPiece.java
@@ -68,9 +68,7 @@ public class OldTextPiece extends TextPiece {
@Override
public byte[] getRawBytes() {
- byte[] buf = new byte[rawBytes.length];
- System.arraycopy(rawBytes, 0, buf, 0, rawBytes.length);
- return buf;
+ return rawBytes.clone();
}
/**
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPieceTable.java b/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPieceTable.java
index 701c793996..e3cb94c868 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPieceTable.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/OldTextPieceTable.java
@@ -82,12 +82,10 @@ public class OldTextPieceTable extends TextPieceTable {
int textSizeBytes = textSizeChars * multiple;
// Grab the data that makes up the piece
- byte[] buf = IOUtils.safelyAllocate(textSizeBytes, MAX_RECORD_LENGTH);
- System.arraycopy(documentStream, start, buf, 0, textSizeBytes);
+ byte[] buf = IOUtils.safelyClone(documentStream, start, textSizeBytes, MAX_RECORD_LENGTH);
// And now build the piece
- final TextPiece newTextPiece = newTextPiece(nodeStartChars, nodeEndChars, buf,
- pieces[x]);
+ final TextPiece newTextPiece = newTextPiece(nodeStartChars, nodeEndChars, buf, pieces[x]);
_textPieces.add(newTextPiece);
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/PICFAndOfficeArtData.java b/src/scratchpad/src/org/apache/poi/hwpf/model/PICFAndOfficeArtData.java
index f75de37920..85205b7bb1 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/PICFAndOfficeArtData.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/PICFAndOfficeArtData.java
@@ -23,6 +23,7 @@ import org.apache.poi.ddf.DefaultEscherRecordFactory;
import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.hwpf.model.types.PICFAbstractType;
+import org.apache.poi.util.IOUtils;
import org.apache.poi.util.Internal;
import org.apache.poi.util.LittleEndian;
@@ -55,8 +56,7 @@ public class PICFAndOfficeArtData
_cchPicName = LittleEndian.getUByte( dataStream, offset );
offset += 1;
- _stPicName = LittleEndian.getByteArray( dataStream, offset,
- _cchPicName, MAX_RECORD_LENGTH);
+ _stPicName = IOUtils.safelyClone(dataStream, offset, _cchPicName, MAX_RECORD_LENGTH);
offset += _cchPicName;
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/PlexOfCps.java b/src/scratchpad/src/org/apache/poi/hwpf/model/PlexOfCps.java
index 579ec187c7..658cb60c9e 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/PlexOfCps.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/PlexOfCps.java
@@ -128,9 +128,7 @@ public final class PlexOfCps {
int start = LittleEndian.getInt(buf, offset + getIntOffset(index));
int end = LittleEndian.getInt(buf, offset + getIntOffset(index + 1));
- byte[] struct = IOUtils.safelyAllocate(_cbStruct, MAX_RECORD_LENGTH);
- System.arraycopy(buf, offset + getStructOffset(index), struct, 0,
- _cbStruct);
+ byte[] struct = IOUtils.safelyClone(buf, offset + getStructOffset(index), _cbStruct, MAX_RECORD_LENGTH);
return new GenericPropertyNode(start, end, struct);
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/SectionTable.java b/src/scratchpad/src/org/apache/poi/hwpf/model/SectionTable.java
index 5e7186b920..eb2292a6e0 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/SectionTable.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/SectionTable.java
@@ -81,9 +81,8 @@ public class SectionTable
{
// The first short at the offset is the size of the grpprl.
int sepxSize = LittleEndian.getShort(documentStream, fileOffset);
- byte[] buf = IOUtils.safelyAllocate(sepxSize, MAX_RECORD_LENGTH);
fileOffset += LittleEndianConsts.SHORT_SIZE;
- System.arraycopy(documentStream, fileOffset, buf, 0, buf.length);
+ byte[] buf = IOUtils.safelyClone(documentStream, fileOffset, sepxSize, MAX_RECORD_LENGTH);
_sections.add(new SEPX(sed, startAt, endAt, buf));
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/Sttb.java b/src/scratchpad/src/org/apache/poi/hwpf/model/Sttb.java
index 92378e8fed..f81c97880e 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/Sttb.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/Sttb.java
@@ -116,8 +116,7 @@ public class Sttb
_data[i] = StringUtil.getFromUnicodeLE( buffer, offset, cchData );
offset += cchData * 2;
- _extraData[i] = LittleEndian
- .getByteArray( buffer, offset, _cbExtra );
+ _extraData[i] = Arrays.copyOfRange( buffer, offset, offset+_cbExtra );
offset += _cbExtra;
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/StyleDescription.java b/src/scratchpad/src/org/apache/poi/hwpf/model/StyleDescription.java
index 60de580d80..d96d66da33 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/StyleDescription.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/StyleDescription.java
@@ -110,8 +110,7 @@ public final class StyleDescription {
int upxSize = LittleEndian.getShort(std, varOffset);
varOffset += LittleEndianConsts.SHORT_SIZE;
- byte[] upx = IOUtils.safelyAllocate(upxSize, Short.MAX_VALUE);
- System.arraycopy(std, varOffset, upx, 0, upxSize);
+ byte[] upx = IOUtils.safelyClone(std, varOffset, upxSize, Short.MAX_VALUE);
_upxs[x] = new UPX(upx);
varOffset += upxSize;
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/TextPieceTable.java b/src/scratchpad/src/org/apache/poi/hwpf/model/TextPieceTable.java
index fe79951db2..8649f06a3f 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/TextPieceTable.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/TextPieceTable.java
@@ -101,8 +101,7 @@ public class TextPieceTable implements CharIndexTranslator {
int textSizeBytes = textSizeChars * multiple;
// Grab the data that makes up the piece
- byte[] buf = IOUtils.safelyAllocate(textSizeBytes, MAX_RECORD_LENGTH);
- System.arraycopy(documentStream, start, buf, 0, textSizeBytes);
+ byte[] buf = IOUtils.safelyClone(documentStream, start, textSizeBytes, MAX_RECORD_LENGTH);
// And now build the piece
final TextPiece newTextPiece = newTextPiece(nodeStartChars, nodeEndChars, buf,
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/types/DOPAbstractType.java b/src/scratchpad/src/org/apache/poi/hwpf/model/types/DOPAbstractType.java
index 773f731d47..6ba7a30183 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/types/DOPAbstractType.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/types/DOPAbstractType.java
@@ -224,16 +224,16 @@ public abstract class DOPAbstractType {
field_32_view = LittleEndian.getShort(data, 0x52 + offset);
field_33_docinfo4 = LittleEndian.getInt(data, 0x54 + offset);
field_34_adt = LittleEndian.getShort(data, 0x58 + offset);
- field_35_doptypography = LittleEndian.getByteArray(data, 0x5a + offset,310);
- field_36_dogrid = LittleEndian.getByteArray(data, 0x190 + offset,10);
+ field_35_doptypography = Arrays.copyOfRange(data, 0x5a + offset, 0x5a + offset+ 310);
+ field_36_dogrid = Arrays.copyOfRange(data, 0x190 + offset,0x190 + offset + 10);
field_37_docinfo5 = LittleEndian.getShort(data, 0x19a + offset);
field_38_docinfo6 = LittleEndian.getShort(data, 0x19c + offset);
- field_39_asumyi = LittleEndian.getByteArray(data, 0x19e + offset,12);
+ field_39_asumyi = Arrays.copyOfRange(data, 0x19e + offset, 0x19e + offset + 12);
field_40_cChWS = LittleEndian.getInt(data, 0x1aa + offset);
field_41_cChWSFtnEdn = LittleEndian.getInt(data, 0x1ae + offset);
field_42_grfDocEvents = LittleEndian.getInt(data, 0x1b2 + offset);
field_43_virusinfo = LittleEndian.getInt(data, 0x1b6 + offset);
- field_44_Spare = LittleEndian.getByteArray(data, 0x1ba + offset,30);
+ field_44_Spare = Arrays.copyOfRange(data, 0x1ba + offset, 0x1ba + offset + 30);
field_45_reserved1 = LittleEndian.getInt(data, 0x1d8 + offset);
field_46_reserved2 = LittleEndian.getInt(data, 0x1dc + offset);
field_47_cDBC = LittleEndian.getInt(data, 0x1e0 + offset);
@@ -1473,7 +1473,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fFacingPages field value.
- *
+ *
*/
@Internal
public void setFFacingPages( boolean value )
@@ -1482,7 +1482,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fFacingPages field value.
*/
@Internal
@@ -1493,7 +1493,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fWidowControl field value.
- *
+ *
*/
@Internal
public void setFWidowControl( boolean value )
@@ -1502,7 +1502,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fWidowControl field value.
*/
@Internal
@@ -1513,7 +1513,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fPMHMainDoc field value.
- *
+ *
*/
@Internal
public void setFPMHMainDoc( boolean value )
@@ -1522,7 +1522,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fPMHMainDoc field value.
*/
@Internal
@@ -1533,7 +1533,7 @@ public abstract class DOPAbstractType {
/**
* Sets the grfSupression field value.
- *
+ *
*/
@Internal
public void setGrfSupression( byte value )
@@ -1542,7 +1542,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the grfSupression field value.
*/
@Internal
@@ -1553,7 +1553,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fpc field value.
- *
+ *
*/
@Internal
public void setFpc( byte value )
@@ -1562,7 +1562,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fpc field value.
*/
@Internal
@@ -1573,7 +1573,7 @@ public abstract class DOPAbstractType {
/**
* Sets the unused1 field value.
- *
+ *
*/
@Internal
public void setUnused1( boolean value )
@@ -1582,7 +1582,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the unused1 field value.
*/
@Internal
@@ -1593,7 +1593,7 @@ public abstract class DOPAbstractType {
/**
* Sets the rncFtn field value.
- *
+ *
*/
@Internal
public void setRncFtn( byte value )
@@ -1602,7 +1602,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the rncFtn field value.
*/
@Internal
@@ -1613,7 +1613,7 @@ public abstract class DOPAbstractType {
/**
* Sets the nFtn field value.
- *
+ *
*/
@Internal
public void setNFtn( short value )
@@ -1622,7 +1622,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the nFtn field value.
*/
@Internal
@@ -1633,7 +1633,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fOnlyMacPics field value.
- *
+ *
*/
@Internal
public void setFOnlyMacPics( boolean value )
@@ -1642,7 +1642,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fOnlyMacPics field value.
*/
@Internal
@@ -1653,7 +1653,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fOnlyWinPics field value.
- *
+ *
*/
@Internal
public void setFOnlyWinPics( boolean value )
@@ -1662,7 +1662,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fOnlyWinPics field value.
*/
@Internal
@@ -1673,7 +1673,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fLabelDoc field value.
- *
+ *
*/
@Internal
public void setFLabelDoc( boolean value )
@@ -1682,7 +1682,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fLabelDoc field value.
*/
@Internal
@@ -1693,7 +1693,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fHyphCapitals field value.
- *
+ *
*/
@Internal
public void setFHyphCapitals( boolean value )
@@ -1702,7 +1702,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fHyphCapitals field value.
*/
@Internal
@@ -1713,7 +1713,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fAutoHyphen field value.
- *
+ *
*/
@Internal
public void setFAutoHyphen( boolean value )
@@ -1722,7 +1722,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fAutoHyphen field value.
*/
@Internal
@@ -1733,7 +1733,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fFormNoFields field value.
- *
+ *
*/
@Internal
public void setFFormNoFields( boolean value )
@@ -1742,7 +1742,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fFormNoFields field value.
*/
@Internal
@@ -1753,7 +1753,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fLinkStyles field value.
- *
+ *
*/
@Internal
public void setFLinkStyles( boolean value )
@@ -1762,7 +1762,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fLinkStyles field value.
*/
@Internal
@@ -1773,7 +1773,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fRevMarking field value.
- *
+ *
*/
@Internal
public void setFRevMarking( boolean value )
@@ -1782,7 +1782,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fRevMarking field value.
*/
@Internal
@@ -1793,7 +1793,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fBackup field value.
- *
+ *
*/
@Internal
public void setFBackup( boolean value )
@@ -1802,7 +1802,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fBackup field value.
*/
@Internal
@@ -1813,7 +1813,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fExactCWords field value.
- *
+ *
*/
@Internal
public void setFExactCWords( boolean value )
@@ -1822,7 +1822,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fExactCWords field value.
*/
@Internal
@@ -1833,7 +1833,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fPagHidden field value.
- *
+ *
*/
@Internal
public void setFPagHidden( boolean value )
@@ -1842,7 +1842,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fPagHidden field value.
*/
@Internal
@@ -1853,7 +1853,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fPagResults field value.
- *
+ *
*/
@Internal
public void setFPagResults( boolean value )
@@ -1862,7 +1862,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fPagResults field value.
*/
@Internal
@@ -1873,7 +1873,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fLockAtn field value.
- *
+ *
*/
@Internal
public void setFLockAtn( boolean value )
@@ -1882,7 +1882,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fLockAtn field value.
*/
@Internal
@@ -1893,7 +1893,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fMirrorMargins field value.
- *
+ *
*/
@Internal
public void setFMirrorMargins( boolean value )
@@ -1902,7 +1902,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fMirrorMargins field value.
*/
@Internal
@@ -1913,7 +1913,7 @@ public abstract class DOPAbstractType {
/**
* Sets the unused3 field value.
- *
+ *
*/
@Internal
public void setUnused3( boolean value )
@@ -1922,7 +1922,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the unused3 field value.
*/
@Internal
@@ -1933,7 +1933,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fDfltTrueType field value.
- *
+ *
*/
@Internal
public void setFDfltTrueType( boolean value )
@@ -1942,7 +1942,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fDfltTrueType field value.
*/
@Internal
@@ -1953,7 +1953,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fPagSupressTopSpacing field value.
- *
+ *
*/
@Internal
public void setFPagSupressTopSpacing( boolean value )
@@ -1962,7 +1962,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fPagSupressTopSpacing field value.
*/
@Internal
@@ -1973,7 +1973,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fProtEnabled field value.
- *
+ *
*/
@Internal
public void setFProtEnabled( boolean value )
@@ -1982,7 +1982,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fProtEnabled field value.
*/
@Internal
@@ -1993,7 +1993,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fDispFormFldSel field value.
- *
+ *
*/
@Internal
public void setFDispFormFldSel( boolean value )
@@ -2002,7 +2002,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fDispFormFldSel field value.
*/
@Internal
@@ -2013,7 +2013,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fRMView field value.
- *
+ *
*/
@Internal
public void setFRMView( boolean value )
@@ -2022,7 +2022,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fRMView field value.
*/
@Internal
@@ -2033,7 +2033,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fRMPrint field value.
- *
+ *
*/
@Internal
public void setFRMPrint( boolean value )
@@ -2042,7 +2042,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fRMPrint field value.
*/
@Internal
@@ -2053,7 +2053,7 @@ public abstract class DOPAbstractType {
/**
* Sets the unused4 field value.
- *
+ *
*/
@Internal
public void setUnused4( boolean value )
@@ -2062,7 +2062,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the unused4 field value.
*/
@Internal
@@ -2073,7 +2073,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fLockRev field value.
- *
+ *
*/
@Internal
public void setFLockRev( boolean value )
@@ -2082,7 +2082,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fLockRev field value.
*/
@Internal
@@ -2093,7 +2093,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fEmbedFonts field value.
- *
+ *
*/
@Internal
public void setFEmbedFonts( boolean value )
@@ -2102,7 +2102,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fEmbedFonts field value.
*/
@Internal
@@ -2113,7 +2113,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfNoTabForInd field value.
- *
+ *
*/
@Internal
public void setOldfNoTabForInd( boolean value )
@@ -2122,7 +2122,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfNoTabForInd field value.
*/
@Internal
@@ -2133,7 +2133,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfNoSpaceRaiseLower field value.
- *
+ *
*/
@Internal
public void setOldfNoSpaceRaiseLower( boolean value )
@@ -2142,7 +2142,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfNoSpaceRaiseLower field value.
*/
@Internal
@@ -2153,7 +2153,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfSuppressSpbfAfterPageBreak field value.
- *
+ *
*/
@Internal
public void setOldfSuppressSpbfAfterPageBreak( boolean value )
@@ -2162,7 +2162,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfSuppressSpbfAfterPageBreak field value.
*/
@Internal
@@ -2173,7 +2173,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfWrapTrailSpaces field value.
- *
+ *
*/
@Internal
public void setOldfWrapTrailSpaces( boolean value )
@@ -2182,7 +2182,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfWrapTrailSpaces field value.
*/
@Internal
@@ -2193,7 +2193,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfMapPrintTextColor field value.
- *
+ *
*/
@Internal
public void setOldfMapPrintTextColor( boolean value )
@@ -2202,7 +2202,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfMapPrintTextColor field value.
*/
@Internal
@@ -2213,7 +2213,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfNoColumnBalance field value.
- *
+ *
*/
@Internal
public void setOldfNoColumnBalance( boolean value )
@@ -2222,7 +2222,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfNoColumnBalance field value.
*/
@Internal
@@ -2233,7 +2233,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfConvMailMergeEsc field value.
- *
+ *
*/
@Internal
public void setOldfConvMailMergeEsc( boolean value )
@@ -2242,7 +2242,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfConvMailMergeEsc field value.
*/
@Internal
@@ -2253,7 +2253,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfSupressTopSpacing field value.
- *
+ *
*/
@Internal
public void setOldfSupressTopSpacing( boolean value )
@@ -2262,7 +2262,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfSupressTopSpacing field value.
*/
@Internal
@@ -2273,7 +2273,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfOrigWordTableRules field value.
- *
+ *
*/
@Internal
public void setOldfOrigWordTableRules( boolean value )
@@ -2282,7 +2282,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfOrigWordTableRules field value.
*/
@Internal
@@ -2293,7 +2293,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfTransparentMetafiles field value.
- *
+ *
*/
@Internal
public void setOldfTransparentMetafiles( boolean value )
@@ -2302,7 +2302,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfTransparentMetafiles field value.
*/
@Internal
@@ -2313,7 +2313,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfShowBreaksInFrames field value.
- *
+ *
*/
@Internal
public void setOldfShowBreaksInFrames( boolean value )
@@ -2322,7 +2322,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfShowBreaksInFrames field value.
*/
@Internal
@@ -2333,7 +2333,7 @@ public abstract class DOPAbstractType {
/**
* Sets the oldfSwapBordersFacingPgs field value.
- *
+ *
*/
@Internal
public void setOldfSwapBordersFacingPgs( boolean value )
@@ -2342,7 +2342,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the oldfSwapBordersFacingPgs field value.
*/
@Internal
@@ -2353,7 +2353,7 @@ public abstract class DOPAbstractType {
/**
* Sets the unused5 field value.
- *
+ *
*/
@Internal
public void setUnused5( byte value )
@@ -2362,7 +2362,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the unused5 field value.
*/
@Internal
@@ -2373,7 +2373,7 @@ public abstract class DOPAbstractType {
/**
* Sets the rncEdn field value.
- *
+ *
*/
@Internal
public void setRncEdn( byte value )
@@ -2382,7 +2382,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the rncEdn field value.
*/
@Internal
@@ -2393,7 +2393,7 @@ public abstract class DOPAbstractType {
/**
* Sets the nEdn field value.
- *
+ *
*/
@Internal
public void setNEdn( short value )
@@ -2402,7 +2402,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the nEdn field value.
*/
@Internal
@@ -2413,7 +2413,7 @@ public abstract class DOPAbstractType {
/**
* Sets the epc field value.
- *
+ *
*/
@Internal
public void setEpc( byte value )
@@ -2422,7 +2422,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the epc field value.
*/
@Internal
@@ -2433,7 +2433,7 @@ public abstract class DOPAbstractType {
/**
* Sets the nfcFtnRef1 field value.
- *
+ *
*/
@Internal
public void setNfcFtnRef1( byte value )
@@ -2442,7 +2442,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the nfcFtnRef1 field value.
*/
@Internal
@@ -2453,7 +2453,7 @@ public abstract class DOPAbstractType {
/**
* Sets the nfcEdnRef1 field value.
- *
+ *
*/
@Internal
public void setNfcEdnRef1( byte value )
@@ -2462,7 +2462,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the nfcEdnRef1 field value.
*/
@Internal
@@ -2473,7 +2473,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fPrintFormData field value.
- *
+ *
*/
@Internal
public void setFPrintFormData( boolean value )
@@ -2482,7 +2482,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fPrintFormData field value.
*/
@Internal
@@ -2493,7 +2493,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSaveFormData field value.
- *
+ *
*/
@Internal
public void setFSaveFormData( boolean value )
@@ -2502,7 +2502,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSaveFormData field value.
*/
@Internal
@@ -2513,7 +2513,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fShadeFormData field value.
- *
+ *
*/
@Internal
public void setFShadeFormData( boolean value )
@@ -2522,7 +2522,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fShadeFormData field value.
*/
@Internal
@@ -2533,7 +2533,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fWCFtnEdn field value.
- *
+ *
*/
@Internal
public void setFWCFtnEdn( boolean value )
@@ -2542,7 +2542,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fWCFtnEdn field value.
*/
@Internal
@@ -2553,7 +2553,7 @@ public abstract class DOPAbstractType {
/**
* Sets the wvkSaved field value.
- *
+ *
*/
@Internal
public void setWvkSaved( byte value )
@@ -2562,7 +2562,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the wvkSaved field value.
*/
@Internal
@@ -2573,7 +2573,7 @@ public abstract class DOPAbstractType {
/**
* Sets the wScaleSaved field value.
- *
+ *
*/
@Internal
public void setWScaleSaved( short value )
@@ -2582,7 +2582,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the wScaleSaved field value.
*/
@Internal
@@ -2593,7 +2593,7 @@ public abstract class DOPAbstractType {
/**
* Sets the zkSaved field value.
- *
+ *
*/
@Internal
public void setZkSaved( byte value )
@@ -2602,7 +2602,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the zkSaved field value.
*/
@Internal
@@ -2613,7 +2613,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fRotateFontW6 field value.
- *
+ *
*/
@Internal
public void setFRotateFontW6( boolean value )
@@ -2622,7 +2622,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fRotateFontW6 field value.
*/
@Internal
@@ -2633,7 +2633,7 @@ public abstract class DOPAbstractType {
/**
* Sets the iGutterPos field value.
- *
+ *
*/
@Internal
public void setIGutterPos( boolean value )
@@ -2642,7 +2642,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the iGutterPos field value.
*/
@Internal
@@ -2653,7 +2653,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fNoTabForInd field value.
- *
+ *
*/
@Internal
public void setFNoTabForInd( boolean value )
@@ -2662,7 +2662,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fNoTabForInd field value.
*/
@Internal
@@ -2673,7 +2673,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fNoSpaceRaiseLower field value.
- *
+ *
*/
@Internal
public void setFNoSpaceRaiseLower( boolean value )
@@ -2682,7 +2682,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fNoSpaceRaiseLower field value.
*/
@Internal
@@ -2693,7 +2693,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSupressSpdfAfterPageBreak field value.
- *
+ *
*/
@Internal
public void setFSupressSpdfAfterPageBreak( boolean value )
@@ -2702,7 +2702,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSupressSpdfAfterPageBreak field value.
*/
@Internal
@@ -2713,7 +2713,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fWrapTrailSpaces field value.
- *
+ *
*/
@Internal
public void setFWrapTrailSpaces( boolean value )
@@ -2722,7 +2722,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fWrapTrailSpaces field value.
*/
@Internal
@@ -2733,7 +2733,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fMapPrintTextColor field value.
- *
+ *
*/
@Internal
public void setFMapPrintTextColor( boolean value )
@@ -2742,7 +2742,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fMapPrintTextColor field value.
*/
@Internal
@@ -2753,7 +2753,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fNoColumnBalance field value.
- *
+ *
*/
@Internal
public void setFNoColumnBalance( boolean value )
@@ -2762,7 +2762,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fNoColumnBalance field value.
*/
@Internal
@@ -2773,7 +2773,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fConvMailMergeEsc field value.
- *
+ *
*/
@Internal
public void setFConvMailMergeEsc( boolean value )
@@ -2782,7 +2782,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fConvMailMergeEsc field value.
*/
@Internal
@@ -2793,7 +2793,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSupressTopSpacing field value.
- *
+ *
*/
@Internal
public void setFSupressTopSpacing( boolean value )
@@ -2802,7 +2802,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSupressTopSpacing field value.
*/
@Internal
@@ -2813,7 +2813,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fOrigWordTableRules field value.
- *
+ *
*/
@Internal
public void setFOrigWordTableRules( boolean value )
@@ -2822,7 +2822,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fOrigWordTableRules field value.
*/
@Internal
@@ -2833,7 +2833,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fTransparentMetafiles field value.
- *
+ *
*/
@Internal
public void setFTransparentMetafiles( boolean value )
@@ -2842,7 +2842,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fTransparentMetafiles field value.
*/
@Internal
@@ -2853,7 +2853,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fShowBreaksInFrames field value.
- *
+ *
*/
@Internal
public void setFShowBreaksInFrames( boolean value )
@@ -2862,7 +2862,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fShowBreaksInFrames field value.
*/
@Internal
@@ -2873,7 +2873,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSwapBordersFacingPgs field value.
- *
+ *
*/
@Internal
public void setFSwapBordersFacingPgs( boolean value )
@@ -2882,7 +2882,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSwapBordersFacingPgs field value.
*/
@Internal
@@ -2893,7 +2893,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSuppressTopSPacingMac5 field value.
- *
+ *
*/
@Internal
public void setFSuppressTopSPacingMac5( boolean value )
@@ -2902,7 +2902,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSuppressTopSPacingMac5 field value.
*/
@Internal
@@ -2913,7 +2913,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fTruncDxaExpand field value.
- *
+ *
*/
@Internal
public void setFTruncDxaExpand( boolean value )
@@ -2922,7 +2922,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fTruncDxaExpand field value.
*/
@Internal
@@ -2933,7 +2933,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fPrintBodyBeforeHdr field value.
- *
+ *
*/
@Internal
public void setFPrintBodyBeforeHdr( boolean value )
@@ -2942,7 +2942,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fPrintBodyBeforeHdr field value.
*/
@Internal
@@ -2953,7 +2953,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fNoLeading field value.
- *
+ *
*/
@Internal
public void setFNoLeading( boolean value )
@@ -2962,7 +2962,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fNoLeading field value.
*/
@Internal
@@ -2973,7 +2973,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fMWSmallCaps field value.
- *
+ *
*/
@Internal
public void setFMWSmallCaps( boolean value )
@@ -2982,7 +2982,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fMWSmallCaps field value.
*/
@Internal
@@ -2993,7 +2993,7 @@ public abstract class DOPAbstractType {
/**
* Sets the lvl field value.
- *
+ *
*/
@Internal
public void setLvl( byte value )
@@ -3002,7 +3002,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the lvl field value.
*/
@Internal
@@ -3013,7 +3013,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fGramAllDone field value.
- *
+ *
*/
@Internal
public void setFGramAllDone( boolean value )
@@ -3022,7 +3022,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fGramAllDone field value.
*/
@Internal
@@ -3033,7 +3033,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fGramAllClean field value.
- *
+ *
*/
@Internal
public void setFGramAllClean( boolean value )
@@ -3042,7 +3042,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fGramAllClean field value.
*/
@Internal
@@ -3053,7 +3053,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSubsetFonts field value.
- *
+ *
*/
@Internal
public void setFSubsetFonts( boolean value )
@@ -3062,7 +3062,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSubsetFonts field value.
*/
@Internal
@@ -3073,7 +3073,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fHideLastVersion field value.
- *
+ *
*/
@Internal
public void setFHideLastVersion( boolean value )
@@ -3082,7 +3082,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fHideLastVersion field value.
*/
@Internal
@@ -3093,7 +3093,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fHtmlDoc field value.
- *
+ *
*/
@Internal
public void setFHtmlDoc( boolean value )
@@ -3102,7 +3102,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fHtmlDoc field value.
*/
@Internal
@@ -3113,7 +3113,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fSnapBorder field value.
- *
+ *
*/
@Internal
public void setFSnapBorder( boolean value )
@@ -3122,7 +3122,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fSnapBorder field value.
*/
@Internal
@@ -3133,7 +3133,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fIncludeHeader field value.
- *
+ *
*/
@Internal
public void setFIncludeHeader( boolean value )
@@ -3142,7 +3142,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fIncludeHeader field value.
*/
@Internal
@@ -3153,7 +3153,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fIncludeFooter field value.
- *
+ *
*/
@Internal
public void setFIncludeFooter( boolean value )
@@ -3162,7 +3162,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fIncludeFooter field value.
*/
@Internal
@@ -3173,7 +3173,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fForcePageSizePag field value.
- *
+ *
*/
@Internal
public void setFForcePageSizePag( boolean value )
@@ -3182,7 +3182,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fForcePageSizePag field value.
*/
@Internal
@@ -3193,7 +3193,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fMinFontSizePag field value.
- *
+ *
*/
@Internal
public void setFMinFontSizePag( boolean value )
@@ -3202,7 +3202,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fMinFontSizePag field value.
*/
@Internal
@@ -3213,7 +3213,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fHaveVersions field value.
- *
+ *
*/
@Internal
public void setFHaveVersions( boolean value )
@@ -3222,7 +3222,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fHaveVersions field value.
*/
@Internal
@@ -3233,7 +3233,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fAutoVersions field value.
- *
+ *
*/
@Internal
public void setFAutoVersions( boolean value )
@@ -3242,7 +3242,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fAutoVersions field value.
*/
@Internal
@@ -3253,7 +3253,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fVirusPrompted field value.
- *
+ *
*/
@Internal
public void setFVirusPrompted( boolean value )
@@ -3262,7 +3262,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fVirusPrompted field value.
*/
@Internal
@@ -3273,7 +3273,7 @@ public abstract class DOPAbstractType {
/**
* Sets the fVirusLoadSafe field value.
- *
+ *
*/
@Internal
public void setFVirusLoadSafe( boolean value )
@@ -3282,7 +3282,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the fVirusLoadSafe field value.
*/
@Internal
@@ -3293,7 +3293,7 @@ public abstract class DOPAbstractType {
/**
* Sets the KeyVirusSession30 field value.
- *
+ *
*/
@Internal
public void setKeyVirusSession30( int value )
@@ -3302,7 +3302,7 @@ public abstract class DOPAbstractType {
}
/**
- *
+ *
* @return the KeyVirusSession30 field value.
*/
@Internal
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/types/LVLFAbstractType.java b/src/scratchpad/src/org/apache/poi/hwpf/model/types/LVLFAbstractType.java
index e101fe9e2e..79ade79b26 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/types/LVLFAbstractType.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/types/LVLFAbstractType.java
@@ -74,7 +74,7 @@ public abstract class LVLFAbstractType
field_1_iStartAt = LittleEndian.getInt( data, 0x0 + offset );
field_2_nfc = data[ 0x4 + offset ];
field_3_info = data[ 0x5 + offset ];
- field_4_rgbxchNums = LittleEndian.getByteArray( data, 0x6 + offset,9 );
+ field_4_rgbxchNums = Arrays.copyOfRange( data, 0x6 + offset, 0x6 + offset + 9 );
field_5_ixchFollow = data[ 0xf + offset ];
field_6_dxaIndentSav = LittleEndian.getInt( data, 0x10 + offset );
field_7_unused2 = LittleEndian.getInt( data, 0x14 + offset );
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/types/PICFAbstractType.java b/src/scratchpad/src/org/apache/poi/hwpf/model/types/PICFAbstractType.java
index b41b2ba837..22d4b22dbe 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/model/types/PICFAbstractType.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/model/types/PICFAbstractType.java
@@ -21,7 +21,8 @@ package org.apache.poi.hwpf.model.types;
import java.util.Arrays;
-import org.apache.poi.util.*;
+import org.apache.poi.util.Internal;
+import org.apache.poi.util.LittleEndian;
/**
* The PICF structure specifies the type of a picture, as well as the size of the
@@ -29,17 +30,17 @@ import org.apache.poi.util.*;
from Microsoft Office Word 97-2007
Binary File Format and [MS-DOC] - v20110608 Word (.doc)
Binary File Format
-
+
* <p>
* NOTE: This source is automatically generated please do not modify this file. Either subclass or
* remove the record in src/types/definitions.
* <p>
- * This class is internal. It content or properties may change without notice
+ * This class is internal. It content or properties may change without notice
* due to changes in our knowledge of internal Microsoft Word binary structures.
* @author Sergey Vladimirov; according to Microsoft Office Word 97-2007 Binary File Format
Specification [*.doc] and [MS-DOC] - v20110608 Word (.doc) Binary File Format
-
+
*/
@Internal
public abstract class PICFAbstractType
@@ -103,10 +104,10 @@ public abstract class PICFAbstractType
field_18_dyaReserved2 = LittleEndian.getShort( data, 0x2a + offset );
field_19_fReserved = data[ 0x2c + offset ];
field_20_bpp = data[ 0x2d + offset ];
- field_21_brcTop80 = LittleEndian.getByteArray( data, 0x2e + offset,4 );
- field_22_brcLeft80 = LittleEndian.getByteArray( data, 0x32 + offset,4 );
- field_23_brcBottom80 = LittleEndian.getByteArray( data, 0x36 + offset,4 );
- field_24_brcRight80 = LittleEndian.getByteArray( data, 0x3a + offset,4 );
+ field_21_brcTop80 = Arrays.copyOfRange( data, 0x2e + offset, 0x2e + offset + 4 );
+ field_22_brcLeft80 = Arrays.copyOfRange( data, 0x32 + offset, 0x32 + offset + 4 );
+ field_23_brcBottom80 = Arrays.copyOfRange( data, 0x36 + offset, 0x36 + offset + 4 );
+ field_24_brcRight80 = Arrays.copyOfRange( data, 0x3a + offset, 0x3a + offset + 4 );
field_25_dxaReserved3 = LittleEndian.getShort( data, 0x3e + offset );
field_26_dyaReserved3 = LittleEndian.getShort( data, 0x40 + offset );
field_27_cProps = LittleEndian.getShort( data, 0x42 + offset );
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/sprm/ParagraphSprmUncompressor.java b/src/scratchpad/src/org/apache/poi/hwpf/sprm/ParagraphSprmUncompressor.java
index ddd7b52aa2..c89661cd99 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/sprm/ParagraphSprmUncompressor.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/sprm/ParagraphSprmUncompressor.java
@@ -18,6 +18,7 @@
package org.apache.poi.hwpf.sprm;
import java.util.ArrayList;
+import java.util.Arrays;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
@@ -314,11 +315,9 @@ public final class ParagraphSprmUncompressor
case 0x3b:
//obsolete
break;
- case 0x3e:
- {
- byte[] buf = new byte[sprm.size() - 3];
- System.arraycopy(buf, 0, sprm.getGrpprl(), sprm.getGrpprlOffset(),
- buf.length);
+ case 0x3e: {
+ // TODO: REMOVEME
+ byte[] buf = Arrays.copyOfRange(sprm.getGrpprl(), sprm.getGrpprlOffset(), sprm.getGrpprlOffset() + (sprm.size() - 3));
newPAP.setAnld(buf);
break;
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/sprm/SectionSprmUncompressor.java b/src/scratchpad/src/org/apache/poi/hwpf/sprm/SectionSprmUncompressor.java
index 7f64b01047..11072bc334 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/sprm/SectionSprmUncompressor.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/sprm/SectionSprmUncompressor.java
@@ -17,6 +17,8 @@
package org.apache.poi.hwpf.sprm;
+import java.util.Arrays;
+
import org.apache.poi.hwpf.usermodel.BorderCode;
import org.apache.poi.hwpf.usermodel.SectionProperties;
import org.apache.poi.util.HexDump;
@@ -69,8 +71,7 @@ public final class SectionSprmUncompressor extends SprmUncompressor
newSEP.setIHeadingPgn ((byte) sprm.getOperand());
break;
case 0x2:
- byte[] buf = new byte[sprm.size() - 3];
- System.arraycopy(sprm.getGrpprl(), sprm.getGrpprlOffset(), buf, 0, buf.length);
+ byte[] buf = Arrays.copyOfRange(sprm.getGrpprl(), sprm.getGrpprlOffset(), sprm.getGrpprlOffset() + (sprm.size() - 3));
newSEP.setOlstAnm (buf);
break;
case 0x3:
@@ -216,11 +217,11 @@ public final class SectionSprmUncompressor extends SprmUncompressor
newSEP.setWTextFlow ((short) sprm.getOperand());
break;
case 0x3C:
- // [MS-DOC], v20140721, 2.6.4, sprmSRncFtn
+ // [MS-DOC], v20140721, 2.6.4, sprmSRncFtn
newSEP.setRncFtn((short) sprm.getOperand());
break;
case 0x3E:
- // [MS-DOC], v20140721, 2.6.4, sprmSRncEdn
+ // [MS-DOC], v20140721, 2.6.4, sprmSRncEdn
newSEP.setRncEdn((short) sprm.getOperand());
break;
case 0x3F:
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmBuffer.java b/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmBuffer.java
index 1bcee335e8..af937e6465 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmBuffer.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmBuffer.java
@@ -127,9 +127,8 @@ public final class SprmBuffer implements Duplicatable {
// commented - buffer shall not contain any additional bytes --
// sergey
// byte[] newBuf = new byte[_offset + addition + 6];
- byte[] newBuf = IOUtils.safelyAllocate(_offset + addition, MAX_RECORD_LENGTH);
- System.arraycopy(_buf, 0, newBuf, 0, _buf.length);
- _buf = newBuf;
+ IOUtils.safelyAllocateCheck(_offset + addition, MAX_RECORD_LENGTH);
+ _buf = Arrays.copyOf(_buf, _offset + addition);
}
}
diff --git a/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmOperation.java b/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmOperation.java
index 287063c22d..3fc26d0712 100644
--- a/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmOperation.java
+++ b/src/scratchpad/src/org/apache/poi/hwpf/sprm/SprmOperation.java
@@ -17,6 +17,8 @@
package org.apache.poi.hwpf.sprm;
+import java.util.Arrays;
+
import org.apache.poi.util.BitField;
import org.apache.poi.util.BitFieldFactory;
import org.apache.poi.util.Internal;
@@ -75,9 +77,7 @@ public final class SprmOperation
public byte[] toByteArray()
{
- byte[] result = new byte[size()];
- System.arraycopy( _grpprl, _offset, result, 0, size() );
- return result;
+ return Arrays.copyOfRange(_grpprl, _offset, _offset + size());
}
public byte[] getGrpprl()
diff --git a/src/scratchpad/testcases/org/apache/poi/hmef/TestCompressedRTF.java b/src/scratchpad/testcases/org/apache/poi/hmef/TestCompressedRTF.java
index 04fa813732..3b5b1ec0b6 100644
--- a/src/scratchpad/testcases/org/apache/poi/hmef/TestCompressedRTF.java
+++ b/src/scratchpad/testcases/org/apache/poi/hmef/TestCompressedRTF.java
@@ -119,8 +119,7 @@ public final class TestCompressedRTF {
MAPIRtfAttribute rtfAttr = (MAPIRtfAttribute) attr;
// Truncate to header + flag + data for flag
- byte[] data = new byte[16 + 12];
- System.arraycopy(rtfAttr.getRawData(), 0, data, 0, data.length);
+ byte[] data = Arrays.copyOf(rtfAttr.getRawData(), 16 + 12);
// Decompress it
CompressedRTF comp = new CompressedRTF();
diff --git a/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestPictures.java b/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestPictures.java
index 40e20429ed..299a71e7fc 100644
--- a/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestPictures.java
+++ b/src/scratchpad/testcases/org/apache/poi/hslf/usermodel/TestPictures.java
@@ -26,6 +26,7 @@ import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.net.URL;
+import java.util.Arrays;
import java.util.List;
import org.apache.poi.POIDataSamples;
@@ -49,7 +50,7 @@ import org.junit.Test;
* @author Yegor Kozlov
*/
public final class TestPictures {
- private static POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
+ private static final POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
/**
* Test read/write Macintosh PICT
@@ -66,11 +67,11 @@ public final class TestPictures {
Dimension nDim = nHeader.getSize();
assertEquals(expWidth, nDim.getWidth(), 0);
assertEquals(expHeight, nDim.getHeight(), 0);
-
+
Dimension dim = data.getImageDimensionInPixels();
assertEquals(Units.pointsToPixel(expWidth), dim.getWidth(), 0);
assertEquals(Units.pointsToPixel(expHeight), dim.getHeight(), 0);
-
+
HSLFPictureShape pict = new HSLFPictureShape(data);
assertEquals(data.getIndex(), pict.getPictureIndex());
slide.addShape(pict);
@@ -91,12 +92,12 @@ public final class TestPictures {
//check picture data
List<HSLFPictureData> pictures = ppt.getPictureData();
assertEquals(1, pictures.size());
-
+
HSLFPictureData pd = pictures.get(0);
dim = pd.getImageDimension();
assertEquals(expWidth, dim.width);
assertEquals(expHeight, dim.height);
-
+
//the Picture shape refers to the PictureData object in the Presentation
assertEquals(pict.getPictureData(), pd);
@@ -107,10 +108,8 @@ public final class TestPictures {
byte[] ppt_bytes = pd.getData();
assertEquals(src_bytes.length, ppt_bytes.length);
//in PICT the first 512 bytes are MAC specific and may not be preserved, ignore them
- byte[] b1 = new byte[src_bytes.length-512];
- System.arraycopy(src_bytes, 512, b1, 0, b1.length);
- byte[] b2 = new byte[ppt_bytes.length-512];
- System.arraycopy(ppt_bytes, 512, b2, 0, b2.length);
+ byte[] b1 = Arrays.copyOfRange(src_bytes, 512, src_bytes.length);
+ byte[] b2 = Arrays.copyOfRange(ppt_bytes, 512, ppt_bytes.length);
assertArrayEquals(b1, b2);
}
@@ -133,7 +132,7 @@ public final class TestPictures {
Dimension dim = data.getImageDimensionInPixels();
assertEquals(Units.pointsToPixel(expWidth), dim.getWidth(), 0);
assertEquals(Units.pointsToPixel(expHeight), dim.getHeight(), 0);
-
+
HSLFPictureShape pict = new HSLFPictureShape(data);
assertEquals(data.getIndex(), pict.getPictureIndex());
slide.addShape(pict);
@@ -159,20 +158,18 @@ public final class TestPictures {
dim = pd.getImageDimension();
assertEquals(expWidth, dim.width);
assertEquals(expHeight, dim.height);
-
+
//the Picture shape refers to the PictureData object in the Presentation
assertEquals(pict.getPictureData(), pd);
-
+
assertEquals(PictureType.WMF, pd.getType());
assertTrue(pd instanceof WMF);
//compare the content of the initial file with what is stored in the PictureData
byte[] ppt_bytes = pd.getData();
assertEquals(src_bytes.length, ppt_bytes.length);
//in WMF the first 22 bytes - is a metafile header
- byte[] b1 = new byte[src_bytes.length-22];
- System.arraycopy(src_bytes, 22, b1, 0, b1.length);
- byte[] b2 = new byte[ppt_bytes.length-22];
- System.arraycopy(ppt_bytes, 22, b2, 0, b2.length);
+ byte[] b1 = Arrays.copyOfRange(src_bytes, 22, src_bytes.length);
+ byte[] b2 = Arrays.copyOfRange(ppt_bytes, 22, ppt_bytes.length);
assertArrayEquals(b1, b2);
}
@@ -195,7 +192,7 @@ public final class TestPictures {
Dimension dim = data.getImageDimensionInPixels();
assertEquals(Units.pointsToPixel(expWidth), dim.getWidth(), 0);
assertEquals(Units.pointsToPixel(expHeight), dim.getHeight(), 0);
-
+
HSLFPictureShape pict = new HSLFPictureShape(data);
assertEquals(data.getIndex(), pict.getPictureIndex());
slide.addShape(pict);
@@ -216,12 +213,12 @@ public final class TestPictures {
//check picture data
List<HSLFPictureData> pictures = ppt.getPictureData();
assertEquals(1, pictures.size());
-
+
HSLFPictureData pd = pictures.get(0);
dim = pd.getImageDimension();
assertEquals(expWidth, dim.width);
assertEquals(expHeight, dim.height);
-
+
//the Picture shape refers to the PictureData object in the Presentation
assertEquals(pict.getPictureData(), pd);
@@ -393,10 +390,8 @@ public final class TestPictures {
ppt_bytes = slTests.readFile("santa.wmf");
assertEquals(src_bytes.length, ppt_bytes.length);
//ignore the first 22 bytes - it is a WMF metafile header
- b1 = new byte[src_bytes.length-22];
- System.arraycopy(src_bytes, 22, b1, 0, b1.length);
- b2 = new byte[ppt_bytes.length-22];
- System.arraycopy(ppt_bytes, 22, b2, 0, b2.length);
+ b1 = Arrays.copyOfRange(src_bytes, 22, src_bytes.length);
+ b2 = Arrays.copyOfRange(ppt_bytes, 22, ppt_bytes.length);
assertArrayEquals(b1, b2);
pict = (HSLFPictureShape)slides.get(3).getShapes().get(0); //the forth slide contains PICT
@@ -407,10 +402,8 @@ public final class TestPictures {
ppt_bytes = slTests.readFile("cow.pict");
assertEquals(src_bytes.length, ppt_bytes.length);
//ignore the first 512 bytes - it is a MAC specific crap
- b1 = new byte[src_bytes.length-512];
- System.arraycopy(src_bytes, 512, b1, 0, b1.length);
- b2 = new byte[ppt_bytes.length-512];
- System.arraycopy(ppt_bytes, 512, b2, 0, b2.length);
+ b1 = Arrays.copyOfRange(src_bytes, 512, src_bytes.length);
+ b2 = Arrays.copyOfRange(ppt_bytes, 512, ppt_bytes.length);
assertArrayEquals(b1, b2);
pict = (HSLFPictureShape)slides.get(4).getShapes().get(0); //the fifth slide contains EMF
@@ -457,7 +450,7 @@ public final class TestPictures {
pdata = pict.getPictureData();
assertTrue(pdata instanceof WMF);
assertEquals(PictureType.WMF, pdata.getType());
-
+
ppt.close();
}