mirror of https://github.com/apache/poi.git
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
This commit is contained in:
parent
aae614424e
commit
15e1aa8b8b
|
@ -24,13 +24,12 @@ import org.apache.poi.hssf.record.CellValueRecordInterface;
|
||||||
import org.apache.poi.hssf.record.ExtendedFormatRecord;
|
import org.apache.poi.hssf.record.ExtendedFormatRecord;
|
||||||
import org.apache.poi.hssf.record.RowRecord;
|
import org.apache.poi.hssf.record.RowRecord;
|
||||||
import org.apache.poi.ss.SpreadsheetVersion;
|
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.Cell;
|
||||||
import org.apache.poi.ss.usermodel.CellStyle;
|
import org.apache.poi.ss.usermodel.CellStyle;
|
||||||
import org.apache.poi.ss.usermodel.CellType;
|
import org.apache.poi.ss.usermodel.CellType;
|
||||||
import org.apache.poi.ss.usermodel.Row;
|
import org.apache.poi.ss.usermodel.Row;
|
||||||
import org.apache.poi.util.Configurator;
|
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.
|
* High level representation of a row of a spreadsheet.
|
||||||
|
@ -720,16 +719,17 @@ public final class HSSFRow implements Row, Comparable<HSSFRow> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right.
|
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right.
|
||||||
* @param startColumn the column to start shifting
|
* @param firstShiftColumnIndex the column to start shifting
|
||||||
* @param endColumn the column to end shifting
|
* @param lastShiftColumnIndex the column to end shifting
|
||||||
* @param step length of the shifting step
|
* @param step length of the shifting step
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){
|
public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) {
|
||||||
if(step < 0)
|
if(step < 0)
|
||||||
throw new IllegalArgumentException("Shifting step may not be negative ");
|
throw new IllegalArgumentException("Shifting step may not be negative ");
|
||||||
if(firstShiftColumnIndex > lastShiftColumnIndex)
|
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)
|
if(lastShiftColumnIndex + step + 1> cells.length)
|
||||||
extend(lastShiftColumnIndex + step + 1);
|
extend(lastShiftColumnIndex + step + 1);
|
||||||
for (int columnIndex = lastShiftColumnIndex; columnIndex >= firstShiftColumnIndex; columnIndex--){ // process cells backwards, because of shifting
|
for (int columnIndex = lastShiftColumnIndex; columnIndex >= firstShiftColumnIndex; columnIndex--){ // process cells backwards, because of shifting
|
||||||
|
@ -748,16 +748,17 @@ public final class HSSFRow implements Row, Comparable<HSSFRow> {
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left.
|
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left.
|
||||||
* @param startColumn the column to start shifting
|
* @param firstShiftColumnIndex the column to start shifting
|
||||||
* @param endColumn the column to end shifting
|
* @param lastShiftColumnIndex the column to end shifting
|
||||||
* @param step length of the shifting step
|
* @param step length of the shifting step
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){
|
public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) {
|
||||||
if(step < 0)
|
if(step < 0)
|
||||||
throw new IllegalArgumentException("Shifting step may not be negative ");
|
throw new IllegalArgumentException("Shifting step may not be negative ");
|
||||||
if(firstShiftColumnIndex > lastShiftColumnIndex)
|
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)
|
if(firstShiftColumnIndex - step < 0)
|
||||||
throw new IllegalStateException("Column index less than zero : " + (Integer.valueOf(firstShiftColumnIndex + step)).toString());
|
throw new IllegalStateException("Column index less than zero : " + (Integer.valueOf(firstShiftColumnIndex + step)).toString());
|
||||||
for (int columnIndex = firstShiftColumnIndex; columnIndex <= lastShiftColumnIndex; columnIndex++){
|
for (int columnIndex = firstShiftColumnIndex; columnIndex <= lastShiftColumnIndex; columnIndex++){
|
||||||
|
|
|
@ -32,6 +32,7 @@ import org.apache.poi.ss.usermodel.Row;
|
||||||
import org.apache.poi.ss.util.CellRangeAddress;
|
import org.apache.poi.ss.util.CellRangeAddress;
|
||||||
import org.apache.poi.util.Beta;
|
import org.apache.poi.util.Beta;
|
||||||
import org.apache.poi.util.Internal;
|
import org.apache.poi.util.Internal;
|
||||||
|
import org.apache.poi.util.LocaleUtil;
|
||||||
import org.apache.poi.xssf.model.StylesTable;
|
import org.apache.poi.xssf.model.StylesTable;
|
||||||
import org.apache.poi.xssf.usermodel.helpers.XSSFRowShifter;
|
import org.apache.poi.xssf.usermodel.helpers.XSSFRowShifter;
|
||||||
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCell;
|
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCell;
|
||||||
|
@ -551,7 +552,7 @@ public class XSSFRow implements Row, Comparable<XSSFRow> {
|
||||||
*/
|
*/
|
||||||
protected void shift(int n) {
|
protected void shift(int n) {
|
||||||
int rownum = getRowNum() + 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.";
|
"You cannot change part of an array.";
|
||||||
for(Cell c : this){
|
for(Cell c : this){
|
||||||
((XSSFCell)c).updateCellReferencesForShifting(msg);
|
((XSSFCell)c).updateCellReferencesForShifting(msg);
|
||||||
|
@ -641,16 +642,17 @@ public class XSSFRow implements Row, Comparable<XSSFRow> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right.
|
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right.
|
||||||
* @param startColumn the column to start shifting
|
* @param firstShiftColumnIndex the column to start shifting
|
||||||
* @param endColumn the column to end shifting
|
* @param lastShiftColumnIndex the column to end shifting
|
||||||
* @param step length of the shifting step
|
* @param step length of the shifting step
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){
|
public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) {
|
||||||
if(step < 0)
|
if(step < 0)
|
||||||
throw new IllegalArgumentException("Shifting step may not be negative ");
|
throw new IllegalArgumentException("Shifting step may not be negative ");
|
||||||
if(firstShiftColumnIndex > lastShiftColumnIndex)
|
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
|
for (int columnIndex = lastShiftColumnIndex; columnIndex >= firstShiftColumnIndex; columnIndex--){ // process cells backwards, because of shifting
|
||||||
shiftCell(columnIndex, step);
|
shiftCell(columnIndex, step);
|
||||||
}
|
}
|
||||||
|
@ -664,16 +666,17 @@ public class XSSFRow implements Row, Comparable<XSSFRow> {
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left.
|
* Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left.
|
||||||
* @param startColumn the column to start shifting
|
* @param firstShiftColumnIndex the column to start shifting
|
||||||
* @param endColumn the column to end shifting
|
* @param lastShiftColumnIndex the column to end shifting
|
||||||
* @param step length of the shifting step
|
* @param step length of the shifting step
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step){
|
public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step) {
|
||||||
if(step < 0)
|
if(step < 0)
|
||||||
throw new IllegalArgumentException("Shifting step may not be negative ");
|
throw new IllegalArgumentException("Shifting step may not be negative ");
|
||||||
if(firstShiftColumnIndex > lastShiftColumnIndex)
|
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)
|
if(firstShiftColumnIndex - step < 0)
|
||||||
throw new IllegalStateException("Column index less than zero : " + (Integer.valueOf(firstShiftColumnIndex + step)).toString());
|
throw new IllegalStateException("Column index less than zero : " + (Integer.valueOf(firstShiftColumnIndex + step)).toString());
|
||||||
for (int columnIndex = firstShiftColumnIndex; columnIndex <= lastShiftColumnIndex; columnIndex++){
|
for (int columnIndex = firstShiftColumnIndex; columnIndex <= lastShiftColumnIndex; columnIndex++){
|
||||||
|
|
Loading…
Reference in New Issue