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