From 9966418b86fb867d980f7284c80917b0672baa30 Mon Sep 17 00:00:00 2001 From: Nick Burch Date: Mon, 7 Jan 2008 14:51:37 +0000 Subject: [PATCH] Fix bug #44070 - patch from Gian Carlo Pace git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@609620 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/poi/hssf/usermodel/HSSFSheet.java | 22 +++++- .../org/apache/poi/hssf/data/comments.xls | Bin 0 -> 14336 bytes .../hssf/usermodel/TestSheetShiftRows.java | 67 ++++++++++++++++++ 3 files changed, 88 insertions(+), 1 deletion(-) create mode 100644 src/testcases/org/apache/poi/hssf/data/comments.xls diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFSheet.java b/src/java/org/apache/poi/hssf/usermodel/HSSFSheet.java index b52fa1e5b..ba9ff72a7 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFSheet.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFSheet.java @@ -1202,6 +1202,12 @@ public class HSSFSheet row2Replace.createCellFromRecord( cellRecord ); sheet.addValueRecord( rowNum + n, cellRecord ); } + + // move comments if exist (can exist even if cell is null) + HSSFComment comment = getCellComment(rowNum, col); + if (comment != null) { + comment.setRow(rowNum + n); + } } } if ( endRow == lastrow || endRow + n > lastrow ) lastrow = Math.min( endRow + n, 65535 ); @@ -1671,7 +1677,21 @@ public class HSSFSheet * @return cell comment or null if not found */ public HSSFComment getCellComment(int row, int column){ - return HSSFCell.findCellComment(sheet, row, column); + // Don't call findCellComment directly, otherwise + // two calls to this method will result in two + // new HSSFComment instances, which is bad + HSSFRow r = getRow(row); + if(r != null) { + HSSFCell c = r.getCell((short)column); + if(c != null) { + return c.getCellComment(); + } else { + // No cell, so you will get new + // objects every time, sorry... + return HSSFCell.findCellComment(sheet, row, column); + } + } + return null; } } diff --git a/src/testcases/org/apache/poi/hssf/data/comments.xls b/src/testcases/org/apache/poi/hssf/data/comments.xls new file mode 100644 index 0000000000000000000000000000000000000000..9eb0329b0e5471a09570b37a710cc55771fae476 GIT binary patch literal 14336 zcmeHOeT-aH75}}N+3DJM$_9{W+pYp4qA5yX4bjR=>~9hN)1>nO;d zp4O$8FJ_q}Kl~pd&=}!Bh8ys5*GuzWoMbTwyoLat3!P>P{DpBCccU5D{H4t9_|0Q` z_GHH6A9%RYY`D{r4U=@dbxs%#X+b=~v;~XJx^_z!TKcTXp0sow+OdznuE8x!*Rln$ z?$$usPVvrq z)o#NkWH5@`=V%~>d00~3z)I?#OM5jx78*i?mX?`bEi#CDmQ+i|LieB#*TETKkNb!~ ztzL`gVluac*G7W!i84Ih`byJK8Vl`2FOv0?j&Km%DjJ5_DocDxiCpZEt){NUQyh{isjAkBqHAyj ztAG)i(iitED_#!w7-6_~ut-R(NYL()p7aQ{ti(}z5v!Kh>x-9H>Wf#@NZ}YhRjJJF zL8U%3txRPqRZ@B#j&p4(DfQ~l==Ca_>Qc>fxXMkTt zB8)(Ot%JYgR@sbsn;0x^vDh{)AC_Mcr4JF7neO}-VVTi+658iy|b33BPza7D{Yfrq|Puio5^BBcXGirhRETb0IEsT2J+QF#DqdX&@ zu1y22>1y22>1y22>1y22>1y22>1y22>1w8BQV$gKk&*+ zuROByn&{z&x&L4O&NJHo|Cv$8(AxiRWYp>XRz@A~jWY6>j_*mh=g~T)*S>#0<08g` zjNW;G_WM6&taTosz5K7cnyoDs>*g^Y5J*<%5$?ZArQ)hmF^TyUlp-B8$lx0$wq?e0 zd$x_gp37w>tPTJCfVlXr=y>FKCYe0z0wI?ATc@eo1A10W_muc3e^=3N2}KB^$6Ad-;WpzOhl?hls*mW|Js6zF(Im rrGDt4e$64xpG(zmuW@SfFf`!P)Ue%b$k+&6o;_>-js9ELi~9csD~?XJ literal 0 HcmV?d00001 diff --git a/src/testcases/org/apache/poi/hssf/usermodel/TestSheetShiftRows.java b/src/testcases/org/apache/poi/hssf/usermodel/TestSheetShiftRows.java index d07a3eea5..91876fff2 100755 --- a/src/testcases/org/apache/poi/hssf/usermodel/TestSheetShiftRows.java +++ b/src/testcases/org/apache/poi/hssf/usermodel/TestSheetShiftRows.java @@ -25,6 +25,8 @@ import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.util.TempFile; import java.io.File; +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; import java.io.FileInputStream; import java.io.FileOutputStream; @@ -170,5 +172,70 @@ public class TestSheetShiftRows extends TestCase { assertTrue("Row number 6 should have a pagebreak", s.isRowBroken(6)); } + + + public void testShiftWithComments() throws Exception { + String filename = System.getProperty( "HSSF.testdata.path" ); + filename = filename + "/comments.xls"; + FileInputStream fin = new FileInputStream( filename ); + HSSFWorkbook wb = new HSSFWorkbook( fin ); + fin.close(); + + HSSFSheet sheet = wb.getSheet("Sheet1"); + assertEquals(3, sheet.getLastRowNum()); + + // Verify comments are in the position expected + assertNotNull(sheet.getCellComment(0,0)); + assertNull(sheet.getCellComment(1,0)); + assertNotNull(sheet.getCellComment(2,0)); + assertNotNull(sheet.getCellComment(3,0)); + + String comment1 = sheet.getCellComment(0,0).getString().getString(); + assertEquals(comment1,"comment top row1 (index0)\n"); + String comment3 = sheet.getCellComment(2,0).getString().getString(); + assertEquals(comment3,"comment top row3 (index2)\n"); + String comment4 = sheet.getCellComment(3,0).getString().getString(); + assertEquals(comment4,"comment top row4 (index3)\n"); + + // Shifting all but first line down to test comments shifting + sheet.shiftRows(1, sheet.getLastRowNum(), 1, true, true); + ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); + wb.write(outputStream); + + // Test that comments were shifted as expected + assertEquals(4, sheet.getLastRowNum()); + assertNotNull(sheet.getCellComment(0,0)); + assertNull(sheet.getCellComment(1,0)); + assertNull(sheet.getCellComment(2,0)); + assertNotNull(sheet.getCellComment(3,0)); + assertNotNull(sheet.getCellComment(4,0)); + + String comment1_shifted = sheet.getCellComment(0,0).getString().getString(); + assertEquals(comment1,comment1_shifted); + String comment3_shifted = sheet.getCellComment(3,0).getString().getString(); + assertEquals(comment3,comment3_shifted); + String comment4_shifted = sheet.getCellComment(4,0).getString().getString(); + assertEquals(comment4,comment4_shifted); + + // Write out and read back in again + // Ensure that the changes were persisted + wb = new HSSFWorkbook( new ByteArrayInputStream(outputStream.toByteArray()) ); + sheet = wb.getSheet("Sheet1"); + assertEquals(4, sheet.getLastRowNum()); + + // Verify comments are in the position expected after the shift + assertNotNull(sheet.getCellComment(0,0)); + assertNull(sheet.getCellComment(1,0)); + assertNull(sheet.getCellComment(2,0)); + assertNotNull(sheet.getCellComment(3,0)); + assertNotNull(sheet.getCellComment(4,0)); + + comment1_shifted = sheet.getCellComment(0,0).getString().getString(); + assertEquals(comment1,comment1_shifted); + comment3_shifted = sheet.getCellComment(3,0).getString().getString(); + assertEquals(comment3,comment3_shifted); + comment4_shifted = sheet.getCellComment(4,0).getString().getString(); + assertEquals(comment4,comment4_shifted); + } }