rev 7998 : [mq]: 8024332
1 /* 2 * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. Oracle designates this 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26 #warn This file is preprocessed before being compiled 27 28 /* 29 * This class contains a map which records the locale list string for 30 * each resource in sun.util.resources & sun.text.resources. 31 * It is used to avoid loading non-existent localized resources so that 32 * jar files won't be opened unnecessary to look up them. 33 * 34 * @since 1.6 35 */ 36 package sun.util.locale.provider; 37 38 import java.util.HashMap; 39 40 41 public class LocaleDataMetaInfo { 42 43 private static final HashMap<String, String> resourceNameToLocales = 44 new HashMap<String, String>(7); 45 46 47 static { 48 /* During JDK build time, #XXX_YYY# will be replaced by a string contain all the locales 49 supported by the resource. 50 51 Don't remove the space character between " and #. That is put there purposely so that 52 look up locale string such as "en" could be based on if it contains " en ". 53 */ 54 resourceNameToLocales.put("FormatData", 55 " #FormatData_USLocales# | #FormatData_NonUSLocales# "); 56 57 resourceNameToLocales.put("CollationData", 58 " #CollationData_USLocales# | #CollationData_NonUSLocales# "); 59 60 resourceNameToLocales.put("TimeZoneNames", 61 " #TimeZoneNames_USLocales# | #TimeZoneNames_NonUSLocales# "); 62 63 resourceNameToLocales.put("LocaleNames", 64 " #LocaleNames_USLocales# | #LocaleNames_NonUSLocales# "); 65 66 resourceNameToLocales.put("CurrencyNames", 67 " #CurrencyNames_USLocales# | #CurrencyNames_NonUSLocales# "); 68 69 resourceNameToLocales.put("CalendarData", 70 " #CalendarData_USLocales# | #CalendarData_NonUSLocales# "); 71 72 resourceNameToLocales.put("AvailableLocales", 73 " #AvailableLocales_USLocales# | #AvailableLocales_NonUSLocales# "); 74 } 75 76 /* 77 * @param resourceName the resource name 78 * @return the supported locale string for the passed in resource. 79 */ 80 public static String getSupportedLocaleString(String resourceName) { 81 return resourceNameToLocales.get(resourceName); 82 } 83 } --- EOF ---