GNU Classpath (0.95) | |
Frames | No Frames |
1: /* PropertyResourceBundle -- a resource bundle built from a Property file 2: Copyright (C) 1998, 1999, 2001, 2002 Free Software Foundation, Inc. 3: 4: This file is part of GNU Classpath. 5: 6: GNU Classpath is free software; you can redistribute it and/or modify 7: it under the terms of the GNU General Public License as published by 8: the Free Software Foundation; either version 2, or (at your option) 9: any later version. 10: 11: GNU Classpath is distributed in the hope that it will be useful, but 12: WITHOUT ANY WARRANTY; without even the implied warranty of 13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14: General Public License for more details. 15: 16: You should have received a copy of the GNU General Public License 17: along with GNU Classpath; see the file COPYING. If not, write to the 18: Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 19: 02110-1301 USA. 20: 21: Linking this library statically or dynamically with other modules is 22: making a combined work based on this library. Thus, the terms and 23: conditions of the GNU General Public License cover the whole 24: combination. 25: 26: As a special exception, the copyright holders of this library give you 27: permission to link this library with independent modules to produce an 28: executable, regardless of the license terms of these independent 29: modules, and to copy and distribute the resulting executable under 30: terms of your choice, provided that you also meet, for each linked 31: independent module, the terms and conditions of the license of that 32: module. An independent module is a module which is not derived from 33: or based on this library. If you modify this library, you may extend 34: this exception to your version of the library, but you are not 35: obligated to do so. If you do not wish to do so, delete this 36: exception statement from your version. */ 37: 38: 39: package java.util; 40: 41: import java.io.IOException; 42: import java.io.InputStream; 43: 44: /** 45: * This class is a concrete <code>ResourceBundle</code> that gets it 46: * resources from a property file. This implies that the resources are 47: * strings. For more information about resource bundles see the class 48: * <code>ResourceBundle</code>. 49: * 50: * You should not use this class directly, or subclass it, but you get 51: * an object of this class automatically when you call 52: * <code>ResourceBundle.getBundle()</code> and there is a properties 53: * file. 54: * 55: * If there is also a class for this resource and the same locale, the 56: * class will be chosen. The properties file should have the name of the 57: * resource bundle, appended with the locale (e.g. <code>_de</code> and the 58: * extension <code>.properties</code>. The file should have the same format 59: * as for <code>Properties.load()</code> 60: * 61: * An example of a properties file for the german language is given 62: * here. This extends the example given in ListResourceBundle. 63: * Create a file MyResource_de.properties with the following contents 64: * and put it in the CLASSPATH. (The char <code>\u00e4</code> is the 65: * german umlaut) 66: * 67: * 68: <pre> 69: s1=3 70: s2=MeineDisk 71: s3=3. M\u00e4rz 96 72: s4=Die Diskette ''{1}'' enth\u00e4lt {0} in {2}. 73: s5=0 74: s6=keine Dateien 75: s7=1 76: s8=eine Datei 77: s9=2 78: s10={0,number} Dateien 79: s11=Die Formatierung warf eine Exception: {0} 80: s12=FEHLER 81: s13=Ergebnis 82: s14=Dialog 83: s15=Auswahlkriterium 84: s16=1,3 85: </pre> 86: * 87: * @author Jochen Hoenicke 88: * @see ResourceBundle 89: * @see ListResourceBundle 90: * @see Properties#load(InputStream) 91: * @since 1.1 92: * @status updated to 1.4 93: */ 94: public class PropertyResourceBundle extends ResourceBundle 95: { 96: /** The properties file this bundle is based on. */ 97: private Properties properties; 98: 99: /** 100: * Creates a new property resource bundle. 101: * 102: * @param stream an input stream, where the resources are read from 103: * @throws NullPointerException if stream is null 104: * @throws IOException if reading the stream fails 105: */ 106: public PropertyResourceBundle(InputStream stream) throws IOException 107: { 108: properties = new Properties(); 109: properties.load(stream); 110: } 111: 112: /** 113: * Called by <code>getObject</code> when a resource is needed. This 114: * returns the resource given by the key. 115: * 116: * @param key the key of the resource 117: * @return the resource for the key, or null if it doesn't exist 118: */ 119: public Object handleGetObject(String key) 120: { 121: return properties.getProperty(key); 122: } 123: 124: /** 125: * This method should return all keys for which a resource exists. 126: * 127: * @return an enumeration of the keys 128: */ 129: public Enumeration<String> getKeys() 130: { 131: if (parent == null) 132: // FIXME: bogus cast. 133: return (Enumeration<String>) properties.propertyNames(); 134: // We make a new Set that holds all the keys, then return an enumeration 135: // for that. This prevents modifications from ruining the enumeration, 136: // as well as ignoring duplicates. 137: Set<String> s = new HashSet<String>(); 138: // FIXME: bogus cast. 139: Enumeration<String> e = (Enumeration<String>) properties.propertyNames(); 140: while (e.hasMoreElements()) 141: s.add(e.nextElement()); 142: ResourceBundle bundle = parent; 143: // Eliminate tail recursion. 144: do 145: { 146: e = bundle.getKeys(); 147: while (e.hasMoreElements()) 148: s.add(e.nextElement()); 149: bundle = bundle.parent; 150: } 151: while (bundle != null); 152: return Collections.enumeration(s); 153: } 154: } // class PropertyResourceBundle
GNU Classpath (0.95) |