From 957d18e95b8a4e30f8e39ee39c9a2993f5f2feaa Mon Sep 17 00:00:00 2001 From: "Andrew C. Oliver" Date: Thu, 1 Aug 2002 18:18:16 +0000 Subject: [PATCH] get mad and throw a runtime error if users specify columns > 255 (more than Excel will allow) PR: Obtained from: Submitted by: Reviewed by: git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@352821 13f79535-47bb-0310-9956-ffa450edef68 --- src/java/org/apache/poi/hssf/usermodel/HSSFCell.java | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFCell.java b/src/java/org/apache/poi/hssf/usermodel/HSSFCell.java index 9d6298300b..6ba0c63f75 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFCell.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFCell.java @@ -182,6 +182,7 @@ public class HSSFCell //protected HSSFCell(Workbook book, Sheet sheet, short row, short col) protected HSSFCell(Workbook book, Sheet sheet, int row, short col) { + checkBounds(col); cellNum = col; this.row = row; cellStyle = null; @@ -221,6 +222,7 @@ public class HSSFCell protected HSSFCell(Workbook book, Sheet sheet, int row, short col, int type) { + checkBounds(col); cellNum = col; this.row = row; cellType = type; @@ -953,4 +955,14 @@ public class HSSFCell { return record; } + + /** + * @throws RuntimeException if the bounds are exceeded. + */ + private void checkBounds(int cellNum) { + if (cellNum > 255) { + throw new RuntimeException("You cannot have more than 255 columns "+ + "in a given row (IV). Because Excel can't handle it"); + } + } }