fe008ae27a
Reviewed-by: darcy, weijun
226 lines
7.2 KiB
Java
226 lines
7.2 KiB
Java
/*
|
|
* Copyright (c) 2007, 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;
|
|
}
|
|
}
|
|
}
|