X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fcommands%2FTrimRegionCommand.java;h=dc6c424039b5fdf382034ceac55376a28bb0a7cd;hb=db098429f712e3cda729b937cd3f635482f96b52;hp=b4d92a03880ee6c5c028755cd9c57bb1a3dfa560;hpb=b4fa0a19d837656bea439fad05c007521fb68660;p=jalview.git diff --git a/src/jalview/commands/TrimRegionCommand.java b/src/jalview/commands/TrimRegionCommand.java index b4d92a0..dc6c424 100644 --- a/src/jalview/commands/TrimRegionCommand.java +++ b/src/jalview/commands/TrimRegionCommand.java @@ -21,39 +21,30 @@ package jalview.commands; import jalview.datamodel.AlignmentI; -import jalview.datamodel.ColumnSelection; -import jalview.datamodel.SequenceGroup; import jalview.datamodel.SequenceI; -import jalview.util.ShiftList; - -import java.util.List; public class TrimRegionCommand extends EditCommand { - public static String TRIM_LEFT = "TrimLeft"; - - public static String TRIM_RIGHT = "TrimRight"; - - public ColumnSelection colSel = null; - - int[] start; - - ShiftList shiftList; - - SequenceGroup selectionGroup; - - List deletedHiddenColumns; - int columnsDeleted; - public TrimRegionCommand(String description, String command, - SequenceI[] seqs, int column, AlignmentI al, - ColumnSelection colSel, SequenceGroup selectedRegion) + /** + * Constructs and performs a trim alignment command + * + * @param description + * (to show in Undo/Redo menu) + * @param trimLeft + * if true trim to left of column, else to right + * @param seqs + * the sequences to trim + * @param column + * the alignment column (base 0) from which to trim + * @param al + */ + public TrimRegionCommand(String description, boolean trimLeft, + SequenceI[] seqs, int column, AlignmentI al) { this.description = description; - this.selectionGroup = selectedRegion; - this.colSel = colSel; - if (command.equalsIgnoreCase(TRIM_LEFT)) + if (trimLeft) { if (column == 0) { @@ -64,109 +55,24 @@ public class TrimRegionCommand extends EditCommand setEdit(new Edit(Action.CUT, seqs, 0, column, al)); } - else if (command.equalsIgnoreCase(TRIM_RIGHT)) + else { int width = al.getWidth() - column - 1; - if (width < 2) + if (width < 1) { return; } - columnsDeleted = width - 1; + columnsDeleted = width; setEdit(new Edit(Action.CUT, seqs, column + 1, width, al)); } - // We need to keep a record of the sequence start - // in order to restore the state after a redo - int i, isize = getEdit(0).seqs.length; - start = new int[isize]; - for (i = 0; i < isize; i++) - { - start[i] = getEdit(0).seqs[i].getStart(); - } performEdit(0, null); } - void cut(Edit command) - { - int column, j, jSize = command.seqs.length; - for (j = 0; j < jSize; j++) - { - if (command.position == 0) - { - // This is a TRIM_LEFT command - column = command.seqs[j].findPosition(command.number); - command.seqs[j].setStart(column); - } - else - { - // This is a TRIM_RIGHT command - column = command.seqs[j].findPosition(command.position) - 1; - command.seqs[j].setEnd(column); - } - } - - super.cut(command, null); - - if (command.position == 0) - { - deletedHiddenColumns = colSel.compensateForEdit(0, command.number); - if (selectionGroup != null) - { - selectionGroup.adjustForRemoveLeft(command.number); - } - } - else - { - deletedHiddenColumns = colSel.compensateForEdit(command.position, - command.number); - if (selectionGroup != null) - { - selectionGroup.adjustForRemoveRight(command.position); - } - } - } - - void paste(Edit command) - { - super.paste(command, null); - int column, j, jSize = command.seqs.length; - for (j = 0; j < jSize; j++) - { - if (command.position == 0) - { - command.seqs[j].setStart(start[j]); - } - else - { - column = command.seqs[j].findPosition(command.number - + command.position) - 1; - command.seqs[j].setEnd(column); - } - } - - if (command.position == 0) - { - colSel.compensateForEdit(0, -command.number); - if (selectionGroup != null) - { - selectionGroup.adjustForRemoveLeft(-command.number); - } - } - - if (deletedHiddenColumns != null) - { - int[] region; - for (int i = 0; i < deletedHiddenColumns.size(); i++) - { - region = deletedHiddenColumns.get(i); - colSel.hideColumns(region[0], region[1]); - } - } - } - + @Override public int getSize() { return columnsDeleted;