From 0c6aae8d1334176994291f30966ddb6ab911ceb5 Mon Sep 17 00:00:00 2001 From: Rainer Klute Date: Fri, 28 Jan 2005 17:23:00 +0000 Subject: [PATCH] Bug 33263 fixed: Patch provided by Der-Johng Sun . git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@353627 13f79535-47bb-0310-9956-ffa450edef68 --- .../org/apache/poi/hwpf/model/ListLevel.java | 26 +++++++++++++------ 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/src/scratchpad/src/org/apache/poi/hwpf/model/ListLevel.java b/src/scratchpad/src/org/apache/poi/hwpf/model/ListLevel.java index 5aa1761e2b..069e1d5236 100644 --- a/src/scratchpad/src/org/apache/poi/hwpf/model/ListLevel.java +++ b/src/scratchpad/src/org/apache/poi/hwpf/model/ListLevel.java @@ -49,7 +49,7 @@ public class ListLevel private short _reserved; private byte[] _grpprlPapx; private byte[] _grpprlChpx; - private char[] _numberText; + private char[] _numberText=null; public ListLevel(int startAt, int numberFormatCode, int alignment, byte[] numberProperties, byte[] entryProperties, @@ -111,13 +111,18 @@ public class ListLevel System.arraycopy(buf, offset, _grpprlChpx, 0, _cbGrpprlChpx); offset += _cbGrpprlChpx; - int numberTextLength = LittleEndian.getShort(buf, offset); - _numberText = new char[numberTextLength]; - offset += LittleEndian.SHORT_SIZE; - for (int x = 0; x < numberTextLength; x++) + int numberTextLength = LittleEndian.getShort(buf, offset); + /* sometimes numberTextLength<0 */ + /* by derjohng */ + if (numberTextLength>0) { - _numberText[x] = (char)LittleEndian.getShort(buf, offset); - offset += LittleEndian.SHORT_SIZE; + _numberText = new char[numberTextLength]; + offset += LittleEndian.SHORT_SIZE; + for (int x = 0; x < numberTextLength; x++) + { + _numberText[x] = (char)LittleEndian.getShort(buf, offset); + offset += LittleEndian.SHORT_SIZE; + } } } @@ -230,7 +235,12 @@ public class ListLevel } public int getSizeInBytes() { - return 28 + _cbGrpprlChpx + _cbGrpprlPapx + (_numberText.length * LittleEndian.SHORT_SIZE) + 2; + if (_numberText!=null) + { + return 28 + _cbGrpprlChpx + _cbGrpprlPapx + (_numberText.length * LittleEndian.SHORT_SIZE) + 2; + } else { + return 28 + _cbGrpprlChpx + _cbGrpprlPapx + 2; + } } }