X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fcommands%2FTrimRegionCommand.java;h=655657e9aec76574971ee98fc867ade01dd57b34;hb=e1aa3fdd1ca82abf5acc0cd3c2b86a5ca1083941;hp=1159ecf242deaa33f01617dfb10153088d35f659;hpb=59d682209891099d46b960509907c79e3fb276fe;p=jalview.git diff --git a/src/jalview/commands/TrimRegionCommand.java b/src/jalview/commands/TrimRegionCommand.java index 1159ecf..655657e 100644 --- a/src/jalview/commands/TrimRegionCommand.java +++ b/src/jalview/commands/TrimRegionCommand.java @@ -1,53 +1,50 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8) - * Copyright (C) 2012 J Procter, AM Waterhouse, LM Lui, J Engelhardt, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * * Jalview is free software: you can redistribute it and/or * modify it under the terms of the GNU General Public License - * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. + * as published by the Free Software Foundation, either version 3 + * of the License, or (at your option) any later version. * * Jalview is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. * - * You should have received a copy of the GNU General Public License along with Jalview. If not, see . + * You should have received a copy of the GNU General Public License + * along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. */ package jalview.commands; -import java.util.*; - -import jalview.datamodel.*; -import jalview.util.*; +import jalview.datamodel.AlignmentI; +import jalview.datamodel.SequenceI; 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; - - Vector 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) { @@ -56,113 +53,25 @@ public class TrimRegionCommand extends EditCommand columnsDeleted = column; - edits = new Edit[] - { new Edit(CUT, seqs, 0, column, al) }; + 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; - - edits = new Edit[] - { new Edit(CUT, seqs, column + 1, width, al) }; - } + columnsDeleted = width; - // We need to keep a record of the sequence start - // in order to restore the state after a redo - int i, isize = edits[0].seqs.length; - start = new int[isize]; - for (i = 0; i < isize; i++) - { - start[i] = edits[0].seqs[i].getStart(); + setEdit(new Edit(Action.CUT, seqs, column + 1, width, al)); } 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 = (int[]) deletedHiddenColumns.elementAt(i); - colSel.hideColumns(region[0], region[1]); - } - } - } - + @Override public int getSize() { return columnsDeleted;