| /* |
| * Copyright (c) 2007, 2012, Oracle and/or its affiliates. All rights reserved. |
| * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
| * |
| * This code is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License version 2 only, as |
| * published by the Free Software Foundation. |
| * |
| * This code 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 |
| * version 2 for more details (a copy is included in the LICENSE file that |
| * accompanied this code). |
| * |
| * You should have received a copy of the GNU General Public License version |
| * 2 along with this work; if not, write to the Free Software Foundation, |
| * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
| * |
| * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
| * or visit www.oracle.com if you need additional information or have any |
| * questions. |
| */ |
| /* |
| * |
| */ |
| |
| package com.foo; |
| |
| import java.text.*; |
| import java.text.spi.*; |
| import java.util.*; |
| |
| import com.foobar.Utils; |
| |
| public class DateFormatSymbolsProviderImpl extends DateFormatSymbolsProvider { |
| |
| static Locale[] avail = { |
| new Locale("ja", "JP", "osaka"), |
| new Locale("ja", "JP", "kyoto"), |
| Locale.JAPAN, |
| new Locale("yy", "ZZ") |
| }; |
| static List<Locale> availList = Arrays.asList(avail); |
| |
| static String[] dialect = { |
| "\u3084\u3002", |
| "\u3069\u3059\u3002", |
| "\u3067\u3059\u3002", |
| "-yy-ZZ" |
| }; |
| |
| static Map<Locale, FooDateFormatSymbols> symbols = new HashMap<Locale, FooDateFormatSymbols>(4); |
| |
| public Locale[] getAvailableLocales() { |
| return avail; |
| } |
| |
| public DateFormatSymbols getInstance(Locale locale) { |
| if (!Utils.supportsLocale(availList, locale)) { |
| throw new IllegalArgumentException("locale is not supported: "+locale); |
| } |
| |
| FooDateFormatSymbols fdfs = symbols.get(locale); |
| if (fdfs == null) { |
| for (int index = 0; index < avail.length; index ++) { |
| if (Utils.supportsLocale(avail[index], locale)) { |
| fdfs = new FooDateFormatSymbols(index); |
| symbols.put(locale, fdfs); |
| break; |
| } |
| } |
| } |
| return fdfs; |
| } |
| |
| class FooDateFormatSymbols extends DateFormatSymbols { |
| String dialect = ""; |
| |
| String[] eras = null; |
| String[] months = null; |
| String[] shortMonths = null; |
| String[] weekdays = null; |
| String[] shortWeekdays = null; |
| String[] ampms = null; |
| |
| public FooDateFormatSymbols(int index) { |
| super(DateFormatSymbolsProviderImpl.this.avail[index]); |
| dialect = DateFormatSymbolsProviderImpl.this.dialect[index]; |
| } |
| |
| public String[] getEras() { |
| if (eras == null) { |
| eras = super.getEras(); |
| for (int i = 0; i < eras.length; i++) { |
| eras[i] = eras[i]+dialect; |
| } |
| } |
| return eras; |
| } |
| |
| /** |
| * Sets era strings. For example: "AD" and "BC". |
| * @param newEras the new era strings. |
| */ |
| public void setEras(String[] newEras) { |
| eras = newEras; |
| } |
| |
| /** |
| * Gets month strings. For example: "January", "February", etc. |
| * @return the month strings. |
| */ |
| public String[] getMonths() { |
| if (months == null) { |
| months = super.getMonths(); |
| for (int i = 0; i < months.length; i++) { |
| months[i] = months[i]+dialect; |
| } |
| } |
| return months; |
| } |
| |
| /** |
| * Sets month strings. For example: "January", "February", etc. |
| * @param newMonths the new month strings. |
| */ |
| public void setMonths(String[] newMonths) { |
| months = newMonths; |
| } |
| |
| /** |
| * Gets short month strings. For example: "Jan", "Feb", etc. |
| * @return the short month strings. |
| */ |
| public String[] getShortMonths() { |
| if (shortMonths == null) { |
| shortMonths = super.getShortMonths(); |
| for (int i = 0; i < shortMonths.length; i++) { |
| shortMonths[i] = shortMonths[i]+dialect; |
| } |
| } |
| return shortMonths; |
| } |
| |
| /** |
| * Sets short month strings. For example: "Jan", "Feb", etc. |
| * @param newShortMonths the new short month strings. |
| */ |
| public void setShortMonths(String[] newShortMonths) { |
| shortMonths = newShortMonths; |
| } |
| |
| /** |
| * Gets weekday strings. For example: "Sunday", "Monday", etc. |
| * @return the weekday strings. Use <code>Calendar.SUNDAY</code>, |
| * <code>Calendar.MONDAY</code>, etc. to index the result array. |
| */ |
| public String[] getWeekdays() { |
| if (weekdays == null) { |
| weekdays = super.getWeekdays(); |
| for (int i = 0; i < weekdays.length; i++) { |
| weekdays[i] = weekdays[i]+dialect; |
| } |
| } |
| return weekdays; |
| } |
| |
| /** |
| * Sets weekday strings. For example: "Sunday", "Monday", etc. |
| * @param newWeekdays the new weekday strings. The array should |
| * be indexed by <code>Calendar.SUNDAY</code>, |
| * <code>Calendar.MONDAY</code>, etc. |
| */ |
| public void setWeekdays(String[] newWeekdays) { |
| weekdays = newWeekdays; |
| } |
| |
| /** |
| * Gets short weekday strings. For example: "Sun", "Mon", etc. |
| * @return the short weekday strings. Use <code>Calendar.SUNDAY</code>, |
| * <code>Calendar.MONDAY</code>, etc. to index the result array. |
| */ |
| public String[] getShortWeekdays() { |
| if (shortWeekdays == null) { |
| shortWeekdays = super.getShortWeekdays(); |
| for (int i = 0; i < shortWeekdays.length; i++) { |
| shortWeekdays[i] = shortWeekdays[i]+dialect; |
| } |
| } |
| return shortWeekdays; |
| } |
| |
| /** |
| * Sets short weekday strings. For example: "Sun", "Mon", etc. |
| * @param newShortWeekdays the new short weekday strings. The array should |
| * be indexed by <code>Calendar.SUNDAY</code>, |
| * <code>Calendar.MONDAY</code>, etc. |
| */ |
| public void setShortWeekdays(String[] newShortWeekdays) { |
| shortWeekdays = newShortWeekdays; |
| } |
| |
| /** |
| * Gets ampm strings. For example: "AM" and "PM". |
| * @return the ampm strings. |
| */ |
| public String[] getAmPmStrings() { |
| if (ampms == null) { |
| ampms = super.getAmPmStrings(); |
| for (int i = 0; i < ampms.length; i++) { |
| ampms[i] = ampms[i]+dialect; |
| } |
| } |
| return ampms; |
| } |
| |
| /** |
| * Sets ampm strings. For example: "AM" and "PM". |
| * @param newAmpms the new ampm strings. |
| */ |
| public void setAmPmStrings(String[] newAmpms) { |
| ampms = newAmpms; |
| } |
| |
| @Override |
| public String[][] getZoneStrings() { |
| return new String[0][0]; |
| } |
| } |
| } |