- redid part of the media handling
[mir.git] / source / mircoders / media / MediaHelper.java
1 /*\r
2  * Copyright (C) 2001, 2002 The Mir-coders group\r
3  *\r
4  * This file is part of Mir.\r
5  *\r
6  * Mir is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 2 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Mir is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with Mir; if not, write to the Free Software\r
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
19  *\r
20  * In addition, as a special exception, The Mir-coders gives permission to link\r
21  * the code of this program with  any library licensed under the Apache Software License,\r
22  * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library\r
23  * (or with modified versions of the above that use the same license as the above),\r
24  * and distribute linked combinations including the two.  You must obey the\r
25  * GNU General Public License in all respects for all of the code used other than\r
26  * the above mentioned libraries.  If you modify this file, you may extend this\r
27  * exception to your version of the file, but you are not obligated to do so.\r
28  * If you do not wish to do so, delete this exception statement from your version.\r
29  */\r
30 package mircoders.media;\r
31 \r
32 import mir.entity.Entity;\r
33 import mir.storage.Database;\r
34 import java.util.Map;\r
35 import java.util.HashMap;\r
36 import mircoders.global.*;\r
37 import mircoders.storage.*;\r
38 import mir.media.*;\r
39 import mircoders.localizer.MirLocalizerExc;\r
40 \r
41 /**\r
42  * helper class to resolve media handlers using reflection\r
43  *\r
44  * @author mh\r
45  * @author Zapata\r
46  * @version 2003\r
47  */\r
48 \r
49 public final class MediaHelper {\r
50   private static Map nameToMediaHandler = new HashMap();\r
51   private static String defaultMediaHandler = null;\r
52 \r
53   public static void addHandler(String aName, MediaHandler aHandler) {\r
54     synchronized (nameToMediaHandler) {\r
55       nameToMediaHandler.put(aName, aHandler);\r
56     }\r
57   }\r
58 \r
59   public static MediaHandler getHandler(Entity aMediaType) throws MediaExc, MediaFailure {\r
60     String handlerName = aMediaType.getValue("classname");\r
61 \r
62     try {\r
63       return MirGlobal.localizer().media().getHandler(handlerName);\r
64     }\r
65     catch (MirLocalizerExc e) {\r
66       throw new MediaFailure(e);\r
67     }\r
68   }\r
69 \r
70   public static Database getStorage(Entity mediaType, String aTable) throws MediaExc, MediaFailure {\r
71     if (aTable.equals("Images"))\r
72       return DatabaseImages.getInstance();\r
73     else if (aTable.equals("Audio"))\r
74       return DatabaseAudio.getInstance();\r
75     if (aTable.equals("Video"))\r
76       return DatabaseVideo.getInstance();\r
77     if (aTable.equals("Other"))\r
78       return DatabaseOther.getInstance();\r
79 \r
80     throw new MediaExc("Unknown storage specification: " + aTable);\r
81   }\r
82 }\r
83 \r
84 \r
85 \r