X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fio%2FJalviewFileView.java;h=18114f34b747c6fc44b02fa42b4fc49ab5b020fa;hb=5b9fcd4e9349485a0be84260b3199c746adfbe92;hp=6df223a27f85ee2c5c82897b2b0c074bac418d65;hpb=47168f025aefdaa044802bd5f8f510ffe43a4808;p=jalview.git diff --git a/src/jalview/io/JalviewFileView.java b/src/jalview/io/JalviewFileView.java index 6df223a..18114f3 100755 --- a/src/jalview/io/JalviewFileView.java +++ b/src/jalview/io/JalviewFileView.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2) - * Copyright (C) 2014 The Jalview Authors + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * @@ -20,71 +20,82 @@ */ package jalview.io; -import java.io.*; -import java.util.*; +import java.io.File; +import java.net.URL; +import java.util.HashMap; +import java.util.Map; -import javax.swing.*; -import javax.swing.filechooser.*; +import javax.swing.Icon; +import javax.swing.ImageIcon; +import javax.swing.filechooser.FileView; public class JalviewFileView extends FileView { - static Hashtable alignSuffix = new Hashtable(); + private static Map extensions; - static + private static Map icons; + + private void loadExtensions() { - // TODO: these names should come from the FormatAdapter lists for readable/writable extensions - alignSuffix.put("amsa", "AMSA file"); - alignSuffix.put("fasta", "Fasta file"); - alignSuffix.put("fa", "Fasta file"); - alignSuffix.put("fastq", "Fasta file"); - alignSuffix.put("mfa", "Fasta file"); - alignSuffix.put("blc", "BLC file"); - alignSuffix.put("msf", "MSF file"); - alignSuffix.put("pfam", "PFAM file"); - alignSuffix.put("aln", "Clustal file"); - alignSuffix.put("pir", "PIR file"); - alignSuffix.put("jar", "Jalview Project file (old)"); - alignSuffix.put("jvp", "Jalview Project file"); - alignSuffix.put("amsa", "AMSA file"); - alignSuffix.put("sto", "Stockholm File"); - alignSuffix.put("stk", "Stockholm File"); - alignSuffix.put("sto", "Stockholm File"); + extensions = new HashMap<>(); + for (FileFormatI ff : FileFormats.getInstance().getFormats()) + { + String desc = ff.getName() + " file"; + String exts = ff.getExtensions(); + for (String ext : exts.split(",")) + { + ext = ext.trim().toLowerCase(); + extensions.put(ext, + desc + ("jar".equals(ext) ? " (old)" : "")); + } + } } + @Override public String getTypeDescription(File f) { String extension = getExtension(f); - String type = null; - + String type = getDescriptionForExtension(extension); if (extension != null) { - if (alignSuffix.containsKey(extension)) + if (extensions.containsKey(extension)) { - type = alignSuffix.get(extension).toString(); + type = extensions.get(extension).toString(); } } return type; } + private String getDescriptionForExtension(String extension) + { + synchronized (this) + { + if (extensions == null) + { + loadExtensions(); + } + } + return extensions.get(extension); + } + + @Override public Icon getIcon(File f) { String extension = getExtension(f); Icon icon = null; - if (extension != null) + if (getDescriptionForExtension(extension) != null) { - if (alignSuffix.containsKey(extension)) - { - icon = createImageIcon("/images/file.png"); - } + icon = getImageIcon("/images/file.png"); } return icon; } - /* - * Get the extension of a file. + /** + * Returns the extension of a file (part of the name after the last period), + * in lower case, or null if the name ends in or does not include a period. */ public static String getExtension(File f) { @@ -100,22 +111,44 @@ public class JalviewFileView extends FileView return ext; } - /** Returns an ImageIcon, or null if the path was invalid. */ - protected static ImageIcon createImageIcon(String path) + /** + * Returns an ImageIcon, or null if the file was not found + * + * @param filePath + */ + protected ImageIcon getImageIcon(String filePath) { - java.net.URL imgURL = JalviewFileView.class.getResource(path); - - if (imgURL != null) + /* + * we reuse a single icon object per path here + */ + synchronized (this) { - return new ImageIcon(imgURL); + if (icons == null) + { + icons = new HashMap<>(); + } + if (!icons.containsKey(filePath)) + { + ImageIcon icon = null; + URL imgURL = JalviewFileView.class.getResource(filePath); + if (imgURL != null) + { + icon = new ImageIcon(imgURL); + } + else + { + System.err.println( + "JalviewFileView.createImageIcon: Couldn't find file: " + + filePath); + } + icons.put(filePath, icon); + } } - else - { - System.err - .println("JalviewFileView.createImageIcon: Couldn't find file: " - + path); - return null; - } + /* + * return the image from the table (which may be null if + * icon creation failed) + */ + return icons.get(filePath); } }