From 15e1aa8b8b34afdfb883ff8ee4b4e327851b2843 Mon Sep 17 00:00:00 2001 From: PJ Fanning Date: Wed, 31 Jan 2018 05:31:31 +0000 Subject: [PATCH] fix use of forbidden apis in row shift code git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1822743 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/poi/hssf/usermodel/HSSFRow.java | 21 ++++++++++--------- .../apache/poi/xssf/usermodel/XSSFRow.java | 21 +++++++++++-------- 2 files changed, 23 insertions(+), 19 deletions(-) diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFRow.java b/src/java/org/apache/poi/hssf/usermodel/HSSFRow.java index 3a33a75cdd..845b58a009 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFRow.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFRow.java @@ -24,13 +24,12 @@ import org.apache.poi.hssf.record.CellValueRecordInterface; import org.apache.poi.hssf.record.ExtendedFormatRecord; import org.apache.poi.hssf.record.RowRecord; import org.apache.poi.ss.SpreadsheetVersion; -import org.apache.poi.ss.formula.eval.NotImplementedException; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellStyle; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.util.Configurator; -import org.apache.poi.util.NotImplemented; +import org.apache.poi.util.LocaleUtil; /** * High level representation of a row of a spreadsheet. @@ -720,16 +719,17 @@ public final class HSSFRow implements Row, Comparable { /** * Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right. - * @param startColumn the column to start shifting - * @param endColumn the column to end shifting + * @param firstShiftColumnIndex the column to start shifting + * @param lastShiftColumnIndex the column to end shifting * @param step length of the shifting step */ @Override - public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){ + public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) { if(step < 0) throw new IllegalArgumentException("Shifting step may not be negative "); if(firstShiftColumnIndex > lastShiftColumnIndex) - throw new IllegalArgumentException(String.format("Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); + throw new IllegalArgumentException(String.format(LocaleUtil.getUserLocale(), + "Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); if(lastShiftColumnIndex + step + 1> cells.length) extend(lastShiftColumnIndex + step + 1); for (int columnIndex = lastShiftColumnIndex; columnIndex >= firstShiftColumnIndex; columnIndex--){ // process cells backwards, because of shifting @@ -748,16 +748,17 @@ public final class HSSFRow implements Row, Comparable { } /** * Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left. - * @param startColumn the column to start shifting - * @param endColumn the column to end shifting + * @param firstShiftColumnIndex the column to start shifting + * @param lastShiftColumnIndex the column to end shifting * @param step length of the shifting step */ @Override - public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){ + public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) { if(step < 0) throw new IllegalArgumentException("Shifting step may not be negative "); if(firstShiftColumnIndex > lastShiftColumnIndex) - throw new IllegalArgumentException(String.format("Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); + throw new IllegalArgumentException(String.format(LocaleUtil.getUserLocale(), + "Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); if(firstShiftColumnIndex - step < 0) throw new IllegalStateException("Column index less than zero : " + (Integer.valueOf(firstShiftColumnIndex + step)).toString()); for (int columnIndex = firstShiftColumnIndex; columnIndex <= lastShiftColumnIndex; columnIndex++){ diff --git a/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFRow.java b/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFRow.java index 311faacde0..78a92dac6c 100644 --- a/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFRow.java +++ b/src/ooxml/java/org/apache/poi/xssf/usermodel/XSSFRow.java @@ -32,6 +32,7 @@ import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.util.CellRangeAddress; import org.apache.poi.util.Beta; import org.apache.poi.util.Internal; +import org.apache.poi.util.LocaleUtil; import org.apache.poi.xssf.model.StylesTable; import org.apache.poi.xssf.usermodel.helpers.XSSFRowShifter; import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCell; @@ -551,7 +552,7 @@ public class XSSFRow implements Row, Comparable { */ protected void shift(int n) { int rownum = getRowNum() + n; - String msg = "Row[rownum="+getRowNum()+"] contains cell(s) included in a multi-cell array formula. " + + String msg = "Row[rownum=" + getRowNum() + "] contains cell(s) included in a multi-cell array formula. " + "You cannot change part of an array."; for(Cell c : this){ ((XSSFCell)c).updateCellReferencesForShifting(msg); @@ -641,16 +642,17 @@ public class XSSFRow implements Row, Comparable { /** * Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right. - * @param startColumn the column to start shifting - * @param endColumn the column to end shifting + * @param firstShiftColumnIndex the column to start shifting + * @param lastShiftColumnIndex the column to end shifting * @param step length of the shifting step */ @Override - public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){ + public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) { if(step < 0) throw new IllegalArgumentException("Shifting step may not be negative "); if(firstShiftColumnIndex > lastShiftColumnIndex) - throw new IllegalArgumentException(String.format("Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); + throw new IllegalArgumentException(String.format(LocaleUtil.getUserLocale(), + "Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); for (int columnIndex = lastShiftColumnIndex; columnIndex >= firstShiftColumnIndex; columnIndex--){ // process cells backwards, because of shifting shiftCell(columnIndex, step); } @@ -664,16 +666,17 @@ public class XSSFRow implements Row, Comparable { } /** * Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left. - * @param startColumn the column to start shifting - * @param endColumn the column to end shifting + * @param firstShiftColumnIndex the column to start shifting + * @param lastShiftColumnIndex the column to end shifting * @param step length of the shifting step */ @Override - public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){ + public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) { if(step < 0) throw new IllegalArgumentException("Shifting step may not be negative "); if(firstShiftColumnIndex > lastShiftColumnIndex) - throw new IllegalArgumentException(String.format("Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); + throw new IllegalArgumentException(String.format(LocaleUtil.getUserLocale(), + "Incorrect shifting range : %d-%d", firstShiftColumnIndex, lastShiftColumnIndex)); if(firstShiftColumnIndex - step < 0) throw new IllegalStateException("Column index less than zero : " + (Integer.valueOf(firstShiftColumnIndex + step)).toString()); for (int columnIndex = firstShiftColumnIndex; columnIndex <= lastShiftColumnIndex; columnIndex++){