jdk/src/share/classes/java/util/spi/CalendarNameProvider.java
author okutsu
Mon, 10 Dec 2012 10:52:11 +0900
changeset 14765 0987999ed367
parent 14502 d63fed06fed4
child 15281 dd43cb9be0e1
permissions -rw-r--r--
8000983: Support narrow display names for calendar fields 8003267: Support generic time zone names in TimeZoneNameProvider (SPI) Reviewed-by: naoto
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14502
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     1
/*
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     2
 * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     4
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    10
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    15
 * accompanied this code).
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    16
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    20
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    23
 * questions.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    24
 */
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    25
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    26
package java.util.spi;
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    27
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    28
import java.util.Calendar;
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    29
import java.util.Locale;
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    30
import java.util.Map;
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    31
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    32
/**
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    33
 * An abstract class for service providers that provide localized string
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    34
 * representations (display names) of {@code Calendar} field values.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    35
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    36
 * <p><a name="calendartypes"><b>Calendar Types</b></a>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    37
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    38
 * <p>Calendar types are used to specify calendar systems for which the {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    39
 * #getDisplayName(String, int, int, int, Locale) getDisplayName} and {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    40
 * #getDisplayNames(String, int, int, Locale) getDisplayNames} methods provide
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    41
 * calendar field value names. See {@link Calendar#getCalendarType()} for details.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    42
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    43
 * <p><b>Calendar Fields</b>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    44
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    45
 * <p>Calendar fields are specified with the constants defined in {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    46
 * Calendar}. The following are calendar-common fields and their values to be
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    47
 * supported for each calendar system.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    48
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    49
 * <table style="border-bottom:1px solid" border="1" cellpadding="3" cellspacing="0" summary="Field values">
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    50
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    51
 *     <th>Field</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    52
 *     <th>Value</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    53
 *     <th>Description</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    54
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    55
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    56
 *     <td valign="top">{@link Calendar#MONTH}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    57
 *     <td valign="top">{@link Calendar#JANUARY} to {@link Calendar#UNDECIMBER}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    58
 *     <td>Month numbering is 0-based (e.g., 0 - January, ..., 11 -
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    59
 *         December). Some calendar systems have 13 months. Month
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    60
 *         names need to be supported in both the formatting and
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    61
 *         stand-alone forms if required by the supported locales. If there's
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    62
 *         no distinction in the two forms, the same names should be returned
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    63
 *         in both of the forms.</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    64
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    65
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    66
 *     <td valign="top">{@link Calendar#DAY_OF_WEEK}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    67
 *     <td valign="top">{@link Calendar#SUNDAY} to {@link Calendar#SATURDAY}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    68
 *     <td>Day-of-week numbering is 1-based starting from Sunday (i.e., 1 - Sunday,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    69
 *         ..., 7 - Saturday).</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    70
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    71
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    72
 *     <td valign="top">{@link Calendar#AM_PM}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    73
 *     <td valign="top">{@link Calendar#AM} to {@link Calendar#PM}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    74
 *     <td>0 - AM, 1 - PM</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    75
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    76
 * </table>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    77
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    78
 * <p style="margin-top:20px">The following are calendar-specific fields and their values to be supported.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    79
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    80
 * <table style="border-bottom:1px solid" border="1" cellpadding="3" cellspacing="0" summary="Calendar type and field values">
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    81
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    82
 *     <th>Calendar Type</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    83
 *     <th>Field</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    84
 *     <th>Value</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    85
 *     <th>Description</th>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    86
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    87
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    88
 *     <td rowspan="2" valign="top">{@code "gregory"}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    89
 *     <td rowspan="2" valign="top">{@link Calendar#ERA}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    90
 *     <td>0</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    91
 *     <td>{@link java.util.GregorianCalendar#BC} (BCE)</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    92
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    93
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    94
 *     <td>1</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    95
 *     <td>{@link java.util.GregorianCalendar#AD} (CE)</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    96
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    97
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    98
 *     <td rowspan="2" valign="top">{@code "buddhist"}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
    99
 *     <td rowspan="2" valign="top">{@link Calendar#ERA}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   100
 *     <td>0</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   101
 *     <td>BC (BCE)</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   102
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   103
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   104
 *     <td>1</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   105
 *     <td>B.E. (Buddhist Era)</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   106
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   107
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   108
 *     <td rowspan="6" valign="top">{@code "japanese"}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   109
 *     <td rowspan="5" valign="top">{@link Calendar#ERA}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   110
 *     <td>0</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   111
 *     <td>Seireki (Before Meiji)</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   112
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   113
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   114
 *     <td>1</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   115
 *     <td>Meiji</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   116
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   117
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   118
 *     <td>2</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   119
 *     <td>Taisho</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   120
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   121
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   122
 *     <td>3</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   123
 *     <td>Showa</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   124
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   125
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   126
 *     <td>4</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   127
 *     <td >Heisei</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   128
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   129
 *   <tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   130
 *     <td>{@link Calendar#YEAR}</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   131
 *     <td>1</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   132
 *     <td>the first year in each era. It should be returned when a long
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   133
 *     style ({@link Calendar#LONG_FORMAT} or {@link Calendar#LONG_STANDALONE}) is
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   134
 *     specified. See also the <a href="../../text/SimpleDateFormat.html#year">
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   135
 *     Year representation in {@code SimpleDateFormat}</a>.</td>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   136
 *   </tr>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   137
 * </table>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   138
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   139
 * <p>Calendar field value names for {@code "gregory"} must be consistent with
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   140
 * the date-time symbols provided by {@link java.text.spi.DateFormatSymbolsProvider}.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   141
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   142
 * <p>Time zone names are supported by {@link TimeZoneNameProvider}.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   143
 *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   144
 * @author Masayoshi Okutsu
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   145
 * @since 1.8
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   146
 * @see CalendarDataProvider
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   147
 * @see Locale#getUnicodeLocaleType(String)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   148
 */
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   149
public abstract class CalendarNameProvider extends LocaleServiceProvider {
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   150
    /**
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   151
     * Sole constructor. (For invocation by subclass constructors, typically
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   152
     * implicit.)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   153
     */
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   154
    protected CalendarNameProvider() {
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   155
    }
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   156
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   157
    /**
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   158
     * Returns the string representation (display name) of the calendar
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   159
     * <code>field value</code> in the given <code>style</code> and
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   160
     * <code>locale</code>.  If no string representation is
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   161
     * applicable, <code>null</code> is returned.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   162
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   163
     * <p>{@code field} is a {@code Calendar} field index, such as {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   164
     * Calendar#MONTH}. The time zone fields, {@link Calendar#ZONE_OFFSET} and
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   165
     * {@link Calendar#DST_OFFSET}, are <em>not</em> supported by this
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   166
     * method. {@code null} must be returned if any time zone fields are
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   167
     * specified.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   168
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   169
     * <p>{@code value} is the numeric representation of the {@code field} value.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   170
     * For example, if {@code field} is {@link Calendar#DAY_OF_WEEK}, the valid
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   171
     * values are {@link Calendar#SUNDAY} to {@link Calendar#SATURDAY}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   172
     * (inclusive).
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   173
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   174
     * <p>{@code style} gives the style of the string representation. It is one
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   175
     * of {@link Calendar#SHORT_FORMAT} ({@link Calendar#SHORT SHORT}),
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   176
     * {@link Calendar#SHORT_STANDALONE}, {@link Calendar#LONG_FORMAT}
14765
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   177
     * ({@link Calendar#LONG LONG}), {@link Calendar#LONG_STANDALONE},
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   178
     * {@link Calendar#NARROW_FORMAT}, or {@link Calendar#NARROW_STANDALONE}.
14502
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   179
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   180
     * <p>For example, the following call will return {@code "Sunday"}.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   181
     * <pre>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   182
     * getDisplayName("gregory", Calendar.DAY_OF_WEEK, Calendar.SUNDAY,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   183
     *                Calendar.LONG_STANDALONE, Locale.ENGLISH);
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   184
     * </pre>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   185
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   186
     * @param calendarType
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   187
     *              the calendar type. (Any calendar type given by {@code locale}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   188
     *              is ignored.)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   189
     * @param field
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   190
     *              the {@code Calendar} field index,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   191
     *              such as {@link Calendar#DAY_OF_WEEK}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   192
     * @param value
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   193
     *              the value of the {@code Calendar field},
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   194
     *              such as {@link Calendar#MONDAY}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   195
     * @param style
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   196
     *              the string representation style: one of {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   197
     *              Calendar#SHORT_FORMAT} ({@link Calendar#SHORT SHORT}),
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   198
     *              {@link Calendar#SHORT_STANDALONE}, {@link
14765
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   199
     *              Calendar#LONG_FORMAT} ({@link Calendar#LONG LONG}),
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   200
     *              {@link Calendar#LONG_STANDALONE},
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   201
     *              {@link Calendar#NARROW_FORMAT},
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   202
     *              or {@link Calendar#NARROW_STANDALONE}
14502
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   203
     * @param locale
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   204
     *              the desired locale
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   205
     * @return the string representation of the {@code field value}, or {@code
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   206
     *         null} if the string representation is not applicable or
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   207
     *         the given calendar type is unknown
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   208
     * @throws IllegalArgumentException
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   209
     *         if {@code field} or {@code style} is invalid
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   210
     * @throws NullPointerException if {@code locale} is {@code null}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   211
     * @see TimeZoneNameProvider
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   212
     * @see java.util.Calendar#get(int)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   213
     * @see java.util.Calendar#getDisplayName(int, int, Locale)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   214
     */
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   215
    public abstract String getDisplayName(String calendarType,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   216
                                          int field, int value,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   217
                                          int style, Locale locale);
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   218
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   219
    /**
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   220
     * Returns a {@code Map} containing all string representations (display
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   221
     * names) of the {@code Calendar} {@code field} in the given {@code style}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   222
     * and {@code locale} and their corresponding field values.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   223
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   224
     * <p>{@code field} is a {@code Calendar} field index, such as {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   225
     * Calendar#MONTH}. The time zone fields, {@link Calendar#ZONE_OFFSET} and
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   226
     * {@link Calendar#DST_OFFSET}, are <em>not</em> supported by this
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   227
     * method. {@code null} must be returned if any time zone fields are specified.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   228
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   229
     * <p>{@code style} gives the style of the string representation. It must be
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   230
     * one of {@link Calendar#ALL_STYLES}, {@link Calendar#SHORT_FORMAT} ({@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   231
     * Calendar#SHORT SHORT}), {@link Calendar#SHORT_STANDALONE}, {@link
14765
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   232
     * Calendar#LONG_FORMAT} ({@link Calendar#LONG LONG}), {@link
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   233
     * Calendar#LONG_STANDALONE}, {@link Calendar#NARROW_FORMAT}, or
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   234
     * {@link Calendar#NARROW_STANDALONE}. Note that narrow names may
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   235
     * not be unique due to use of single characters, such as "S" for Sunday
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   236
     * and Saturday, and that no narrow names are included in that case.
14502
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   237
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   238
     * <p>For example, the following call will return a {@code Map} containing
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   239
     * {@code "January"} to {@link Calendar#JANUARY}, {@code "Jan"} to {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   240
     * Calendar#JANUARY}, {@code "February"} to {@link Calendar#FEBRUARY},
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   241
     * {@code "Feb"} to {@link Calendar#FEBRUARY}, and so on.
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   242
     * <pre>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   243
     * getDisplayNames("gregory", Calendar.MONTH, Calendar.ALL_STYLES, Locale.ENGLISH);
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   244
     * </pre>
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   245
     *
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   246
     * @param calendarType
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   247
     *              the calendar type. (Any calendar type given by {@code locale}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   248
     *              is ignored.)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   249
     * @param field
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   250
     *              the calendar field for which the display names are returned
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   251
     * @param style
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   252
     *              the style applied to the display names; one of
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   253
     *              {@link Calendar#ALL_STYLES}, {@link Calendar#SHORT_FORMAT}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   254
     *              ({@link Calendar#SHORT SHORT}), {@link
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   255
     *              Calendar#SHORT_STANDALONE}, {@link Calendar#LONG_FORMAT}
14765
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   256
     *              ({@link Calendar#LONG LONG}), {@link Calendar#LONG_STANDALONE},
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   257
     *              {@link Calendar#NARROW_FORMAT},
0987999ed367 8000983: Support narrow display names for calendar fields
okutsu
parents: 14502
diff changeset
   258
     *              or {@link Calendar#NARROW_STANDALONE}
14502
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   259
     * @param locale
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   260
     *              the desired locale
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   261
     * @return a {@code Map} containing all display names of {@code field} in
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   262
     *         {@code style} and {@code locale} and their {@code field} values,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   263
     *         or {@code null} if no display names are defined for {@code field}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   264
     * @throws NullPointerException
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   265
     *         if {@code locale} is {@code null}
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   266
     * @see Calendar#getDisplayNames(int, int, Locale)
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   267
     */
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   268
    public abstract Map<String, Integer> getDisplayNames(String calendarType,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   269
                                                         int field, int style,
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   270
                                                         Locale locale);
d63fed06fed4 8000986: Split java.util.spi.CalendarDataProvider into week parameters and field names portions
okutsu
parents:
diff changeset
   271
}