/* * Copyright 2001-2011 Stephen Colebourne * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.joda.time.tz; import java.text.DateFormatSymbols; import java.util.HashMap; import java.util.Locale; import java.util.Map; import org.joda.time.DateTimeUtils; /** * The default name provider acquires localized names from * {@link DateFormatSymbols java.text.DateFormatSymbols}. * <p> * DefaultNameProvider is thread-safe and immutable. * * @author Brian S O'Neill * @since 1.0 */ @SuppressWarnings("unchecked") public class DefaultNameProvider implements NameProvider { // locale -> (id -> (nameKey -> [shortName, name])) private HashMap<Locale, Map<String, Map<String, Object>>> iByLocaleCache = createCache(); public DefaultNameProvider() { } public String getShortName(Locale locale, String id, String nameKey) { String[] nameSet = getNameSet(locale, id, nameKey); return nameSet == null ? null : nameSet[0]; } public String getName(Locale locale, String id, String nameKey) { String[] nameSet = getNameSet(locale, id, nameKey); return nameSet == null ? null : nameSet[1]; } private synchronized String[] getNameSet(Locale locale, String id, String nameKey) { if (locale == null || id == null || nameKey == null) { return null; } Map<String, Map<String, Object>> byIdCache = iByLocaleCache.get(locale); if (byIdCache == null) { iByLocaleCache.put(locale, byIdCache = createCache()); } Map<String, Object> byNameKeyCache = byIdCache.get(id); if (byNameKeyCache == null) { byIdCache.put(id, byNameKeyCache = createCache()); String[][] zoneStringsEn = DateTimeUtils.getDateFormatSymbols(Locale.ENGLISH).getZoneStrings(); String[] setEn = null; for (String[] strings : zoneStringsEn) { if (strings != null && strings.length == 5 && id.equals(strings[0])) { setEn = strings; break; } } String[][] zoneStringsLoc = DateTimeUtils.getDateFormatSymbols(locale).getZoneStrings(); String[] setLoc = null; for (String[] strings : zoneStringsLoc) { if (strings != null && strings.length == 5 && id.equals(strings[0])) { setLoc = strings; break; } } if (setEn != null && setLoc != null) { byNameKeyCache.put(setEn[2], new String[] {setLoc[2], setLoc[1]}); // need to handle case where summer and winter have the same // abbreviation, such as EST in Australia [1716305] // we handle this by appending "-Summer", cf ZoneInfoCompiler if (setEn[2].equals(setEn[4])) { byNameKeyCache.put(setEn[4] + "-Summer", new String[] {setLoc[4], setLoc[3]}); } else { byNameKeyCache.put(setEn[4], new String[] {setLoc[4], setLoc[3]}); } } } return (String[]) byNameKeyCache.get(nameKey); } private HashMap createCache() { return new HashMap(7); } }