/* * FileTypeMap.java * Copyright (C) 2004 The Free Software Foundation * * This file is part of GNU Java Activation Framework (JAF), a library. * * GNU JAF 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 2 of the License, or * (at your option) any later version. * * GNU JAF 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 this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * As a special exception, if you link this library with other files to * produce an executable, this library does not by itself cause the * resulting executable to be covered by the GNU General Public License. * This exception does not however invalidate any other reasons why the * executable file might be covered by the GNU General Public License. */ package javax.activation; import java.io.File; /** * Classifier for the MIME content type of files. * * @author <a href='mailto:dog@gnu.org'>Chris Burdess</a> * @version 1.1 */ public abstract class FileTypeMap { /* Class scope */ private static FileTypeMap defaultMap; /** * Returns the system default file type map. * If one has not been set, this returns a MimetypesFileTypeMap. */ public static FileTypeMap getDefaultFileTypeMap() { if (defaultMap == null) { defaultMap = new MimetypesFileTypeMap(); } return defaultMap; } /** * Sets the default file type map. * @param map the new file type map */ public static void setDefaultFileTypeMap(FileTypeMap map) { SecurityManager security = System.getSecurityManager(); if (security != null) { try { security.checkSetFactory(); } catch (SecurityException e) { if (map != null && FileTypeMap.class.getClassLoader() != map.getClass().getClassLoader()) { throw e; } } } defaultMap = map; } /* Instance scope */ /** * Returns the content type of the specified file. * @param file the file to classify */ public abstract String getContentType(File file); /** * Returns the content type of the specified file path. * @param filename the path of the file to classify */ public abstract String getContentType(String filename); }