Skip to content

Commit

Permalink
Fixing issue #298# when deleting the middle of three rows having a co…
Browse files Browse the repository at this point in the history
…vered cell from row 2 to 3
  • Loading branch information
svanteschubert authored and mistmist committed Jul 8, 2024
1 parent 4a02da7 commit 8ee02cc
Show file tree
Hide file tree
Showing 6 changed files with 118 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -871,7 +871,6 @@ void removeAllCellsRelationship() {
if (coverCell != null) {
coverCell.setRowSpannedNumber(coverCell.getRowSpannedNumber() - getRowsRepeatedNumber());
}
getOdfElement().removeChild(cell.getOdfElement());
} else {
if (cell.getRowSpannedNumber() > 1) // cell is not a cover cell, and it span more rows
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,9 @@
*/
package org.odftoolkit.odfdom.doc.table;

import java.net.URISyntaxException;
import java.net.URL;
import java.nio.file.Path;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
Expand Down Expand Up @@ -221,6 +224,18 @@ public void testGetInstance() {
}
}

@Test
public void testRowDeletionText() {
try {
OdfTextDocument document = (OdfTextDocument) OdfTextDocument.loadDocument(
ResourceUtilities.getAbsoluteInputPath("tableRowDeletionTest.odt"));
OdfTable pTable = document.getTableList(true).get(0);
pTable.removeRowsByIndex(2, 1);
} catch (Throwable t) {
Assert.fail("No problem should occure during deletion of Row");
}
}

private void saveods(String name) {
try {
odsdoc.save(ResourceUtilities.getTestOutputFile(filename + name + ".ods"));
Expand Down
Binary file not shown.
Binary file not shown.
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
{"changes":[
{"name":"documentLayout","attrs":{"document":{"defaultTabStop":1251,"fileFormat":"odf"}}},
{"name":"addFontDecl","attrs":{"family":"'DejaVu Sans'","familyGeneric":"swiss","pitch":"variable"},"fontName":"DejaVu Sans"},
{"name":"addFontDecl","attrs":{"family":"'DejaVu Sans'","familyGeneric":"swiss","pitch":"variable"},"fontName":"DejaVu Sans1"},
{"name":"addFontDecl","attrs":{"family":"'Liberation Sans'","familyGeneric":"swiss","pitch":"variable"},"fontName":"Liberation Sans"},
{"name":"addFontDecl","attrs":{"family":"'Liberation Serif'","familyGeneric":"roman","pitch":"variable"},"fontName":"Liberation Serif"},
{"name":"addFontDecl","attrs":{"family":"'Lucida Sans'","familyGeneric":"swiss"},"fontName":"Lucida Sans"},
{"name":"addFontDecl","attrs":{"family":"'Lucida Sans'","familyGeneric":"system","pitch":"variable"},"fontName":"Lucida Sans1"},
{"name":"addFontDecl","attrs":{"family":"'Microsoft YaHei'","familyGeneric":"system","pitch":"variable"},"fontName":"Microsoft YaHei"},
{"name":"addFontDecl","attrs":{"family":"NSimSun","familyGeneric":"system","pitch":"variable"},"fontName":"NSimSun"},
{"name":"addFontDecl","attrs":{"family":"Verdana","familyGeneric":"swiss"},"fontName":"Verdana"},
{"name":"addStyle","type":"character","styleId":"Placeholder","attrs":{"character":{"color":{"type":"rgb","value":"008080"},"underline":true}},"parent":"default_character_style"},
{"name":"addStyle","type":"drawing","styleId":"default_drawing_style","attrs":{"character":{"color":{"type":"auto"},"fontName":"Liberation Serif","fontNameAsian":"NSimSun","fontNameComplex":"Lucida Sans1","fontSize":12,"fontSizeAsian":10.5,"language":"de-DE"},"fill":{"type":"solid","color":{"type":"rgb","value":"729fcf"}},"line":{"color":{"type":"rgb","value":"3465a4"}}},"default":true,"hidden":true,"styleName":"Default Graphic Style"},
{"name":"addStyle","type":"paragraph","styleId":"Caption","attrs":{"character":{"fontNameComplex":"Lucida Sans","fontSize":12,"fontSizeAsian":12,"italic":true,"italicAsian":true,"italicComplex":true},"paragraph":{"marginBottom":212,"marginTop":212}},"parent":"Standard"},
{"name":"addStyle","type":"paragraph","styleId":"default_paragraph_style","attrs":{"character":{"color":{"type":"auto"},"fontName":"Liberation Serif","fontNameAsian":"NSimSun","fontNameComplex":"Lucida Sans1","fontSize":12,"fontSizeAsian":10.5,"language":"de-DE"},"paragraph":{"document":{"defaultTabStop":1251}}},"default":true,"hidden":true,"styleName":"Default Paragraph Style"},
{"name":"addStyle","type":"paragraph","styleId":"Frame_20_contents","attrs":{"character":{"fontName":"DejaVu Sans1"}},"parent":"Text_20_body","styleName":"Frame contents"},
{"name":"addStyle","type":"paragraph","styleId":"Heading","attrs":{"character":{"fontName":"Liberation Sans","fontNameAsian":"Microsoft YaHei","fontNameComplex":"Lucida Sans1","fontSize":14,"fontSizeAsian":14},"paragraph":{"marginBottom":212,"marginTop":423,"nextStyleId":"Text_20_body"}},"parent":"Standard"},
{"name":"addStyle","type":"paragraph","styleId":"Index","attrs":{"character":{"fontNameComplex":"Lucida Sans","fontSizeAsian":12,"language":"zxx"}},"parent":"Standard"},
{"name":"addStyle","type":"paragraph","styleId":"List","attrs":{"character":{"fontNameComplex":"Lucida Sans","fontSizeAsian":12}},"parent":"Text_20_body"},
{"name":"addStyle","type":"paragraph","styleId":"Standard","attrs":{},"parent":"default_paragraph_style"},
{"name":"addStyle","type":"paragraph","styleId":"Table_20_Contents","attrs":{},"parent":"Standard","styleName":"Table Contents"},
{"name":"addStyle","type":"paragraph","styleId":"Text_20_body","attrs":{"paragraph":{"lineHeight":{"type":"percent","value":115},"marginBottom":247,"marginTop":0}},"parent":"Standard","styleName":"Text body"},
{"name":"addTable","start":[1],"attrs":{"table":{"tableGrid":[32766,16383,16383],"width":17000}}},
{"name":"addRows","start":[1,1]},
{"name":"addCells","start":[1,1,1],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderRight":{"style":"none"},"borderTop":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97,"rowSpan":3}}},
{"name":"addParagraph","start":[1,1,1,1],"attrs":{"styleId":"Frame_20_contents","character":{"bold":true,"boldAsian":true,"boldComplex":true,"fontSize":12,"fontSizeAsian":12}}},
{"name":"addField","start":[1,1,1,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<DOCUMENT.NAME>"},
{"name":"addText","start":[1,1,1,1,2],"text":" "},
{"name":"addCells","start":[1,1,2],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderRight":{"style":"none"},"borderTop":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,1,2,1],"attrs":{"styleId":"Table_20_Contents","paragraph":{"alignment":"right"}}},
{"name":"addText","start":[1,1,2,1,1],"text":"Zwischensumme:"},
{"name":"addCells","start":[1,1,3],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderTop":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,1,3,1],"attrs":{"styleId":"Table_20_Contents","character":{"fontSizeAsian":11},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,1,3,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<DOCUMENT.ITEMS.NET>"},
{"name":"addRows","start":[1,2]},
{"name":"addCells","start":[1,2,1],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderRight":{"style":"none"},"borderTop":{"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,2,1,1],"attrs":{"styleId":"Table_20_Contents","paragraph":{"alignment":"right"}}},
{"name":"addText","start":[1,2,1,1,1],"text":"Rabatt ("},
{"name":"addField","start":[1,2,1,1,9],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<ITEMS.DISCOUNT.PERCENT>"},
{"name":"addText","start":[1,2,1,1,10],"text":"):"},
{"name":"addCells","start":[1,2,2],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderRight":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderTop":{"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,2,2,1],"attrs":{"styleId":"Table_20_Contents","character":{"fontSizeAsian":11},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,2,2,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<ITEMS.DISCOUNT.GROSS>"},
{"name":"addRows","start":[1,3]},
{"name":"addCells","start":[1,3,1],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderRight":{"style":"none"},"borderTop":{"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,3,1,1],"attrs":{"styleId":"Text_20_body","character":{"bold":true,"boldAsian":true,"boldComplex":true,"color":{"type":"auto"},"fontName":"DejaVu Sans","fontNameAsian":"Verdana","fontNameComplex":"Verdana","fontSize":10,"fontSizeAsian":10,"letterSpacing":"normal"},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,3,1,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<VATLIST.DESCRIPTIONS>"},
{"name":"addCells","start":[1,3,2],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderRight":{"color":{"type":"rgb","value":"000000"},"style":"single","width":18},"borderTop":{"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,3,2,1],"attrs":{"styleId":"Table_20_Contents","character":{"color":{"type":"auto"},"fontName":"DejaVu Sans","fontNameAsian":"Verdana","fontNameComplex":"Verdana","fontSize":10,"fontSizeAsian":10,"letterSpacing":"normal"},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,3,2,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<VATLIST.VALUES>"},
{"name":"addParagraph","start":[2],"attrs":{"styleId":"Standard"}}
]}
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
{"changes":[
{"name":"documentLayout","attrs":{"document":{"fileFormat":"odf"}}},
{"name":"addFontDecl","attrs":{"family":"'DejaVu Sans'","familyGeneric":"swiss","pitch":"variable"},"fontName":"DejaVu Sans"},
{"name":"addFontDecl","attrs":{"family":"'DejaVu Sans'","familyGeneric":"swiss","pitch":"variable"},"fontName":"DejaVu Sans1"},
{"name":"addFontDecl","attrs":{"family":"'Liberation Sans'","familyGeneric":"swiss","pitch":"variable"},"fontName":"Liberation Sans"},
{"name":"addFontDecl","attrs":{"family":"'Liberation Serif'","familyGeneric":"roman","pitch":"variable"},"fontName":"Liberation Serif"},
{"name":"addFontDecl","attrs":{"family":"'Lucida Sans'","familyGeneric":"swiss"},"fontName":"Lucida Sans"},
{"name":"addFontDecl","attrs":{"family":"'Lucida Sans'","familyGeneric":"system","pitch":"variable"},"fontName":"Lucida Sans1"},
{"name":"addFontDecl","attrs":{"family":"'Microsoft YaHei'","familyGeneric":"system","pitch":"variable"},"fontName":"Microsoft YaHei"},
{"name":"addFontDecl","attrs":{"family":"NSimSun","familyGeneric":"system","pitch":"variable"},"fontName":"NSimSun"},
{"name":"addFontDecl","attrs":{"family":"Verdana","familyGeneric":"swiss"},"fontName":"Verdana"},
{"name":"addStyle","type":"character","styleId":"Placeholder","attrs":{"character":{"color":{"type":"rgb","value":"008080"},"underline":true}},"parent":"default_character_style"},
{"name":"addStyle","type":"drawing","styleId":"default_drawing_style","attrs":{"character":{"color":{"type":"auto"},"fontName":"Liberation Serif","fontNameAsian":"NSimSun","fontNameComplex":"Lucida Sans1","fontSize":12,"fontSizeAsian":10.5,"language":"de-DE"},"fill":{"type":"solid","color":{"type":"rgb","value":"729fcf"}}},"default":true,"hidden":true,"styleName":"Default Graphic Style"},
{"name":"addStyle","type":"paragraph","styleId":"Caption","attrs":{"character":{"fontNameComplex":"Lucida Sans","fontSize":12,"fontSizeAsian":12,"italic":true,"italicAsian":true,"italicComplex":true},"paragraph":{"marginBottom":212,"marginTop":212}},"parent":"Standard"},
{"name":"addStyle","type":"paragraph","styleId":"Frame_20_contents","attrs":{"character":{"fontName":"DejaVu Sans1"}},"parent":"Text_20_body","styleName":"Frame contents"},
{"name":"addStyle","type":"paragraph","styleId":"Heading","attrs":{"character":{"fontName":"Liberation Sans","fontNameAsian":"Microsoft YaHei","fontNameComplex":"Lucida Sans1","fontSize":14,"fontSizeAsian":14},"paragraph":{"marginBottom":212,"marginTop":423,"nextStyleId":"Text_20_body"}},"parent":"Standard"},
{"name":"addStyle","type":"paragraph","styleId":"Index","attrs":{"character":{"fontNameComplex":"Lucida Sans","fontSizeAsian":12,"language":"zxx"}},"parent":"Standard"},
{"name":"addStyle","type":"paragraph","styleId":"List","attrs":{"character":{"fontNameComplex":"Lucida Sans","fontSizeAsian":12}},"parent":"Text_20_body"},
{"name":"addStyle","type":"paragraph","styleId":"Standard","attrs":{},"parent":"default_paragraph_style"},
{"name":"addStyle","type":"paragraph","styleId":"Table_20_Contents","attrs":{},"parent":"Standard","styleName":"Table Contents"},
{"name":"addStyle","type":"paragraph","styleId":"Text_20_body","attrs":{"paragraph":{"lineHeight":{"type":"percent","value":115},"marginBottom":247,"marginTop":0}},"parent":"Standard","styleName":"Text body"},
{"name":"addTable","start":[1],"attrs":{"table":{"tableGrid":[32766,16383,16383],"width":17000}}},
{"name":"addRows","start":[1,1]},
{"name":"addCells","start":[1,1,1],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"space":97,"style":"none"},"borderTop":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,1,1,1],"attrs":{"styleId":"Frame_20_contents","character":{"bold":true,"boldAsian":true,"boldComplex":true,"fontSize":12,"fontSizeAsian":12}}},
{"name":"addField","start":[1,1,1,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<DOCUMENT.NAME>"},
{"name":"addText","start":[1,1,1,1,2],"text":" "},
{"name":"addCells","start":[1,1,2],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"space":97,"style":"none"},"borderTop":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,1,2,1],"attrs":{"styleId":"Table_20_Contents","paragraph":{"alignment":"right"}}},
{"name":"addText","start":[1,1,2,1,1],"text":"Zwischensumme:"},
{"name":"addCells","start":[1,1,3],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderTop":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,1,3,1],"attrs":{"styleId":"Table_20_Contents","character":{"fontSizeAsian":11},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,1,3,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<DOCUMENT.ITEMS.NET>"},
{"name":"addRows","start":[1,2]},
{"name":"addCells","start":[1,2,1],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"space":97,"style":"none"},"borderTop":{"space":97,"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,2,1,1],"attrs":{"styleId":"Table_20_Contents","paragraph":{"alignment":"right"}}},
{"name":"addText","start":[1,2,1,1,1],"text":"Rabatt ("},
{"name":"addField","start":[1,2,1,1,9],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<ITEMS.DISCOUNT.PERCENT>"},
{"name":"addText","start":[1,2,1,1,10],"text":"):"},
{"name":"addCells","start":[1,2,2],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderTop":{"space":97,"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,2,2,1],"attrs":{"styleId":"Table_20_Contents","character":{"fontSizeAsian":11},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,2,2,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<ITEMS.DISCOUNT.GROSS>"},
{"name":"addRows","start":[1,3]},
{"name":"addCells","start":[1,3,1],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"space":97,"style":"none"},"borderTop":{"space":97,"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,3,1,1],"attrs":{"styleId":"Text_20_body","character":{"bold":true,"boldAsian":true,"boldComplex":true,"color":{"type":"auto"},"fontName":"DejaVu Sans","fontNameAsian":"Verdana","fontNameComplex":"Verdana","fontSize":10,"fontSizeAsian":10,"letterSpacing":"normal"},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,3,1,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<VATLIST.DESCRIPTIONS>"},
{"name":"addCells","start":[1,3,2],"attrs":{"cell":{"borderBottom":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderLeft":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderRight":{"color":{"type":"rgb","value":"000000"},"space":97,"style":"single","width":18},"borderTop":{"space":97,"style":"none"},"paddingBottom":97,"paddingLeft":97,"paddingRight":97,"paddingTop":97}}},
{"name":"addParagraph","start":[1,3,2,1],"attrs":{"styleId":"Table_20_Contents","character":{"color":{"type":"auto"},"fontName":"DejaVu Sans","fontNameAsian":"Verdana","fontNameComplex":"Verdana","fontSize":10,"fontSizeAsian":10,"letterSpacing":"normal"},"paragraph":{"alignment":"right"}}},
{"name":"addField","start":[1,3,2,1,1],"type":"placeholder","attrs":{"field":{"placeHolderType":"text"}},"representation":"<VATLIST.VALUES>"},
{"name":"addParagraph","start":[2],"attrs":{"styleId":"Standard"}}
]}

0 comments on commit 8ee02cc

Please sign in to comment.