X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fdatamodel%2FColumnSelection.java;h=e51afd041569e75f35083707253061e153e672b9;hb=55c2e38285277f647543cc936f2fc80a9c4d0359;hp=60d7aea2f2ab9c4408d574875e2a077ee53f29c6;hpb=ddea0f030b4a1dc0cdb249345973ce59da9a0072;p=jalview.git diff --git a/src/jalview/datamodel/ColumnSelection.java b/src/jalview/datamodel/ColumnSelection.java index 60d7aea..e51afd0 100644 --- a/src/jalview/datamodel/ColumnSelection.java +++ b/src/jalview/datamodel/ColumnSelection.java @@ -175,8 +175,9 @@ public class ColumnSelection * @param start beginning of edit * @param left shift in edit (+ve for removal, or -ve for inserts) */ - public void compensateForEdit(int start, int change) + public Vector compensateForEdit(int start, int change) { + Vector deletedHiddenColumns = null; for (int i = 0; i < size(); i++) { int temp = columnAt(i); @@ -189,20 +190,37 @@ public class ColumnSelection if(hiddenColumns!=null) { - for(int i=0; i start) + if ( region[0]>start && start+change>region[1] ) + { + deletedHiddenColumns.addElement( + hiddenColumns.elementAt(i)); + + hiddenColumns.removeElementAt(i); + i--; + hSize--; + continue; + } + + if(region[0]>start) { region[0] -= change; region[1] -= change; } + if(region[0]<0) region[0] = 0; - if(region[1] <0) - region[1] = 0; + } + + this.revealHiddenColumns(0); } + + return deletedHiddenColumns; } /** * propagate shift in alignment columns to column selection @@ -582,6 +600,8 @@ public class ColumnSelection { removeElement(max); max ++; } min++; max--; + if(min>max) + min = max; hideColumns(min, max); } @@ -717,7 +737,7 @@ public class ColumnSelection { for(i=0; i