X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fio%2FFormatAdapter.java;h=1dbfdefeb8d2e92e58dd734fc16541522a9278fd;hb=18a91cf8bf71500b0bfa020c8348227cce2fc279;hp=6d94616f12ccbcbd2a2ba5d0140ee5f47e1bf730;hpb=37de9310bec3501cbc6381e0c3dcb282fcaad812;p=jalview.git diff --git a/src/jalview/io/FormatAdapter.java b/src/jalview/io/FormatAdapter.java index 6d94616..1dbfdef 100755 --- a/src/jalview/io/FormatAdapter.java +++ b/src/jalview/io/FormatAdapter.java @@ -22,6 +22,7 @@ package jalview.io; import jalview.api.AlignExportSettingI; import jalview.api.AlignmentViewPanel; +import jalview.bin.Cache; import jalview.datamodel.Alignment; import jalview.datamodel.AlignmentAnnotation; import jalview.datamodel.AlignmentI; @@ -29,6 +30,9 @@ import jalview.datamodel.ColumnSelection; import jalview.datamodel.Sequence; import jalview.datamodel.SequenceGroup; import jalview.datamodel.SequenceI; +import jalview.util.Comparison; + +import java.io.IOException; /** * Additional formatting methods used by the application in a number of places. @@ -76,7 +80,7 @@ public class FormatAdapter extends AppletFormatAdapter } } - public String formatSequences(String format, SequenceI[] seqs, + public String formatSequences(FileFormatI format, SequenceI[] seqs, String[] omitHiddenColumns, int[] exportRange) { @@ -112,14 +116,14 @@ public class FormatAdapter extends AppletFormatAdapter startIndex = startEnd[0]; endIndex = startEnd[1]; // get first non-gaped residue start position - while (jalview.util.Comparison.isGap(seqs[i] + while (Comparison.isGap(seqs[i] .getCharAt(startIndex)) && startIndex < endIndex) { startIndex++; } // get last non-gaped residue end position - while (jalview.util.Comparison.isGap(seqs[i].getCharAt(endIndex)) + while (Comparison.isGap(seqs[i].getCharAt(endIndex)) && endIndex > startIndex) { endIndex--; @@ -144,112 +148,100 @@ public class FormatAdapter extends AppletFormatAdapter * * * @param format - * Format string as givien in the AppletFormatAdaptor list (exact - * match to name of class implementing file io for that format) * @param seqs * vector of sequences to write * * @return String containing sequences in desired format */ - public String formatSequences(String format, SequenceI[] seqs) + public String formatSequences(FileFormatI format, SequenceI[] seqs) { + // + // try + // { + boolean withSuffix = getCacheSuffixDefault(format); + return format.getAlignmentFile().print(seqs, withSuffix); + // null; + // + // if (format.equalsIgnoreCase("FASTA")) + // { + // afile = new FastaFile(); + // afile.addJVSuffix(jalview.bin.Cache.getDefault("FASTA_JVSUFFIX", + // true)); + // } + // else if (format.equalsIgnoreCase("MSF")) + // { + // afile = new MSFfile(); + // afile.addJVSuffix(jalview.bin.Cache + // .getDefault("MSF_JVSUFFIX", true)); + // } + // else if (format.equalsIgnoreCase("PileUp")) + // { + // afile = new PileUpfile(); + // afile.addJVSuffix(jalview.bin.Cache.getDefault("PILEUP_JVSUFFIX", + // true)); + // } + // else if (format.equalsIgnoreCase("CLUSTAL")) + // { + // afile = new ClustalFile(); + // afile.addJVSuffix(jalview.bin.Cache.getDefault("CLUSTAL_JVSUFFIX", + // true)); + // } + // else if (format.equalsIgnoreCase("BLC")) + // { + // afile = new BLCFile(); + // afile.addJVSuffix(jalview.bin.Cache + // .getDefault("BLC_JVSUFFIX", true)); + // } + // else if (format.equalsIgnoreCase("PIR")) + // { + // afile = new PIRFile(); + // afile.addJVSuffix(jalview.bin.Cache + // .getDefault("PIR_JVSUFFIX", true)); + // } + // else if (format.equalsIgnoreCase("PFAM")) + // { + // afile = new PfamFile(); + // afile.addJVSuffix(jalview.bin.Cache.getDefault("PFAM_JVSUFFIX", + // true)); + // } + // /* + // * amsa is not supported by this function - it requires an alignment + // * rather than a sequence vector else if + // (format.equalsIgnoreCase("AMSA")) + // * { afile = new AMSAFile(); afile.addJVSuffix( + // * jalview.bin.Cache.getDefault("AMSA_JVSUFFIX", true)); } + // */ - try - { - AlignFile afile = null; - - if (format.equalsIgnoreCase("FASTA")) - { - afile = new FastaFile(); - afile.addJVSuffix(jalview.bin.Cache.getDefault("FASTA_JVSUFFIX", - true)); - } - else if (format.equalsIgnoreCase("MSF")) - { - afile = new MSFfile(); - afile.addJVSuffix(jalview.bin.Cache - .getDefault("MSF_JVSUFFIX", true)); - } - else if (format.equalsIgnoreCase("PileUp")) - { - afile = new PileUpfile(); - afile.addJVSuffix(jalview.bin.Cache.getDefault("PILEUP_JVSUFFIX", - true)); - } - else if (format.equalsIgnoreCase("CLUSTAL")) - { - afile = new ClustalFile(); - afile.addJVSuffix(jalview.bin.Cache.getDefault("CLUSTAL_JVSUFFIX", - true)); - } - else if (format.equalsIgnoreCase("BLC")) - { - afile = new BLCFile(); - afile.addJVSuffix(jalview.bin.Cache - .getDefault("BLC_JVSUFFIX", true)); - } - else if (format.equalsIgnoreCase("PIR")) - { - afile = new PIRFile(); - afile.addJVSuffix(jalview.bin.Cache - .getDefault("PIR_JVSUFFIX", true)); - } - else if (format.equalsIgnoreCase("PFAM")) - { - afile = new PfamFile(); - afile.addJVSuffix(jalview.bin.Cache.getDefault("PFAM_JVSUFFIX", - true)); - } - /* - * amsa is not supported by this function - it requires an alignment - * rather than a sequence vector else if (format.equalsIgnoreCase("AMSA")) - * { afile = new AMSAFile(); afile.addJVSuffix( - * jalview.bin.Cache.getDefault("AMSA_JVSUFFIX", true)); } - */ - - afile.setSeqs(seqs); - String afileresp = afile.print(); - if (afile.hasWarningMessage()) - { - System.err.println("Warning raised when writing as " + format - + " : " + afile.getWarningMessage()); - } - return afileresp; - } catch (Exception e) - { - System.err.println("Failed to write alignment as a '" + format - + "' file\n"); - e.printStackTrace(); - } - - return null; +// afile.setSeqs(seqs); +// String afileresp = afile.print(); +// if (afile.hasWarningMessage()) +// { +// System.err.println("Warning raised when writing as " + format +// + " : " + afile.getWarningMessage()); +// } +// return afileresp; +// } catch (Exception e) +// { +// System.err.println("Failed to write alignment as a '" + format +// + "' file\n"); +// e.printStackTrace(); +// } +// +// return null; } - public boolean getCacheSuffixDefault(String format) + public boolean getCacheSuffixDefault(FileFormatI format) { - if (isValidFormat(format)) - { - return jalview.bin.Cache.getDefault(format.toUpperCase() - + "_JVSUFFIX", true); - } - return false; + return Cache.getDefault(format.toString() + "_JVSUFFIX", true); } - public String formatSequences(String format, AlignmentI alignment, + public String formatSequences(FileFormatI format, AlignmentI alignment, String[] omitHidden, int[] exportRange, ColumnSelection colSel) { return formatSequences(format, alignment, omitHidden, exportRange, getCacheSuffixDefault(format), colSel, null); } - public String formatSequences(String format, AlignmentI alignment, - String[] omitHidden, int[] exportRange, ColumnSelection colSel, - SequenceGroup sgp) - { - return formatSequences(format, alignment, omitHidden, exportRange, - getCacheSuffixDefault(format), colSel, sgp); - } - /** * hack function to replace seuqences with visible sequence strings before * generating a string of the alignment in the given format. @@ -262,7 +254,7 @@ public class FormatAdapter extends AppletFormatAdapter * defines hidden columns that are edited out of annotation * @return string representation of the alignment formatted as format */ - public String formatSequences(String format, AlignmentI alignment, + public String formatSequences(FileFormatI format, AlignmentI alignment, String[] omitHidden, int[] exportRange, boolean suffix, ColumnSelection colSel) { @@ -270,9 +262,9 @@ public class FormatAdapter extends AppletFormatAdapter suffix, colSel, null); } - public String formatSequences(String format, AlignmentI alignment, + public String formatSequences(FileFormatI format, AlignmentI alignment, String[] omitHidden, int[] exportRange, boolean suffix, - ColumnSelection colSel, jalview.datamodel.SequenceGroup selgp) + ColumnSelection colSel, SequenceGroup selgp) { if (omitHidden != null) { @@ -305,26 +297,20 @@ public class FormatAdapter extends AppletFormatAdapter return this.formatSequences(format, alignment, suffix); } - /** - * validate format is valid for IO in Application. This is basically the - * AppletFormatAdapter.isValidFormat call with additional checks for - * Application only formats like 'Jalview'. - * - * @param format - * a format string to be compared with list of readable or writable - * formats (READABLE_FORMATS or WRITABLE_FORMATS) - * @param forwriting - * when true, format is checked against list of writable formats. - * @return true if format is valid - */ - public static final boolean isValidIOFormat(String format, - boolean forwriting) + @Override + public AlignmentI readFile(String file, DataSourceType sourceType, + FileFormatI fileFormat) throws IOException { - if (format.equalsIgnoreCase("jalview")) - { - return true; - } - return AppletFormatAdapter.isValidFormat(format, forwriting); + AlignmentI al = super.readFile(file, sourceType, fileFormat); + return al; + } + + @Override + public AlignmentI readFromFile(FileParse source, FileFormatI format) + throws IOException + { + AlignmentI al = super.readFromFile(source, format); + return al; } /** @@ -336,11 +322,19 @@ public class FormatAdapter extends AppletFormatAdapter * alignment panel originating the view * @return String containing flat file */ - public String formatSequences(String format, AlignmentViewPanel ap, + public String formatSequences(FileFormatI format, AlignmentViewPanel ap, boolean selectedOnly) { return formatSequences(format, getCacheSuffixDefault(format), ap, selectedOnly); } + public AlignmentI readFromFile(AlignmentFileI source, FileFormatI format) + throws IOException + { + FileParse fp = new FileParse(source.getInFile(), + source.getDataSourceType()); + return readFromFile(fp, format); + } + }