X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fio%2FJalviewFileFilter.java;h=0d2d4bfe90ed80d04d4e436c7b5f09a1696fd1f6;hb=ab43013b7e357b84b4abade0dba949668dfb2a0e;hp=f19e5ea071d50b782002eaf382f659f674a5ddd5;hpb=2c012a6c95ee7a4017b9896a4cdcfe0dd280fcd2;p=jalview.git diff --git a/src/jalview/io/JalviewFileFilter.java b/src/jalview/io/JalviewFileFilter.java index f19e5ea..0d2d4bf 100755 --- a/src/jalview/io/JalviewFileFilter.java +++ b/src/jalview/io/JalviewFileFilter.java @@ -1,119 +1,175 @@ -package jalview.io; - -import javax.swing.filechooser.*; -import java.io.File; -import java.util.*; - -public class JalviewFileFilter extends FileFilter -{ - private static String TYPE_UNKNOWN = "Type Unknown"; - private static String HIDDEN_FILE = "Hidden File"; - public static Hashtable suffixHash = new Hashtable(); - - private Hashtable filters = null; - private String description = "no description"; - private String fullDescription = "full description"; - private boolean useExtensionsInDescription = true; - - - public JalviewFileFilter(String extension, String description) { - - StringTokenizer st = new StringTokenizer(extension, ","); - while(st.hasMoreElements()) - { - addExtension(st.nextToken().trim()); - } - setDescription(description); - } - - public JalviewFileFilter(String[] filts) { - this(filts, null); - } - - public String getAcceptableExtension() - { - return filters.keys().nextElement().toString(); - } - - public JalviewFileFilter(String[] filts, String description) { - for (int i = 0; i < filts.length; i++) { - // add filters one by one - addExtension(filts[i]); - } - if(description!=null) setDescription(description); - } - - // takes account of the fact that database is a directory - public boolean accept(File f) { - if(f != null) { - String extension = getExtension(f); - if(f.isDirectory()) { - if(extension == null || extension.equals("")) { - return true; - } else { - if(filters.get(getExtension(f)) != null) { - return true; - } - } - } - if(extension != null && filters.get(getExtension(f)) != null) { - return true; - } - } - return false; - } - - public String getExtension(File f) { - if(f != null) { - String filename = f.getName(); - int i = filename.lastIndexOf('.'); - if(i>0 && i. + * The Jalview Authors are detailed in the 'AUTHORS' file. + */ +package jalview.io; + +import java.io.*; +import java.util.*; + +import javax.swing.filechooser.FileFilter; + +public class JalviewFileFilter extends FileFilter +{ + public static Hashtable suffixHash = new Hashtable(); + + private Hashtable filters = null; + + private String description = "no description"; + + private String fullDescription = "full description"; + + private boolean useExtensionsInDescription = true; + + public JalviewFileFilter(String extension, String description) + { + StringTokenizer st = new StringTokenizer(extension, ","); + + while (st.hasMoreElements()) + { + addExtension(st.nextToken().trim()); + } + + setDescription(description); + } + + public JalviewFileFilter(String[] filts) + { + this(filts, null); + } + + public JalviewFileFilter(String[] filts, String description) + { + for (int i = 0; i < filts.length; i++) + { + // add filters one by one + addExtension(filts[i]); + } + + if (description != null) + { + setDescription(description); + } + } + + public String getAcceptableExtension() + { + return filters.keys().nextElement().toString(); + } + + // takes account of the fact that database is a directory + public boolean accept(File f) + { + if (f != null) + { + String extension = getExtension(f); + + if (f.isDirectory()) + { + return true; + } + + if ((extension != null) && (filters.get(getExtension(f)) != null)) + { + return true; + } + } + + return false; + } + + public String getExtension(File f) + { + if (f != null) + { + String filename = f.getName(); + int i = filename.lastIndexOf('.'); + + if ((i > 0) && (i < (filename.length() - 1))) + { + return filename.substring(i + 1).toLowerCase(); + } + + ; + } + + return ""; + } + + public void addExtension(String extension) + { + if (filters == null) + { + filters = new Hashtable(5); + } + + filters.put(extension.toLowerCase(), this); + fullDescription = null; + } + + public String getDescription() + { + if (fullDescription == null) + { + if ((description == null) || isExtensionListInDescription()) + { + fullDescription = (description == null) ? "(" + : (description + " ("); + + // build the description from the extension list + Enumeration extensions = filters.keys(); + + if (extensions != null) + { + fullDescription += ("." + (String) extensions.nextElement()); + + while (extensions.hasMoreElements()) + { + fullDescription += (", " + (String) extensions.nextElement()); + } + } + + fullDescription += ")"; + } + else + { + fullDescription = description; + } + } + + return fullDescription; + } + + public void setDescription(String description) + { + this.description = description; + fullDescription = null; + } + + public void setExtensionListInDescription(boolean b) + { + useExtensionsInDescription = b; + fullDescription = null; + } + + public boolean isExtensionListInDescription() + { + return useExtensionsInDescription; + } +}