jdk/src/java.base/share/classes/java/time/format/DateTimeFormatter.java
author jjg
Wed, 12 Jul 2017 12:48:01 -0700
changeset 45881 aaec0fbe17ae
parent 45124 144479e89cdb
child 46149 b515ebc3db98
permissions -rw-r--r--
8184208: update class="striped" tables for accessibility Reviewed-by: lancea, bpb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     1
/*
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
     2
 * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     4
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    10
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    15
 * accompanied this code).
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    16
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    20
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    23
 * questions.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    24
 */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    25
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    26
/*
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    27
 * This file is available under and governed by the GNU General Public
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    28
 * License version 2 only, as published by the Free Software Foundation.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    29
 * However, the following notice accompanied the original version of this
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    30
 * file:
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    31
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    32
 * Copyright (c) 2008-2012, Stephen Colebourne & Michael Nascimento Santos
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    33
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    34
 * All rights reserved.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    35
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    36
 * Redistribution and use in source and binary forms, with or without
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    37
 * modification, are permitted provided that the following conditions are met:
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    38
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    39
 *  * Redistributions of source code must retain the above copyright notice,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    40
 *    this list of conditions and the following disclaimer.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    41
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    42
 *  * Redistributions in binary form must reproduce the above copyright notice,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    43
 *    this list of conditions and the following disclaimer in the documentation
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    44
 *    and/or other materials provided with the distribution.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    45
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    46
 *  * Neither the name of JSR-310 nor the names of its contributors
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    47
 *    may be used to endorse or promote products derived from this software
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    48
 *    without specific prior written permission.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    49
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    50
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    51
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    52
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    53
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    54
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    55
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    56
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    57
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    58
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    59
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    60
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    61
 */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    62
package java.time.format;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    63
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    64
import static java.time.temporal.ChronoField.DAY_OF_MONTH;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    65
import static java.time.temporal.ChronoField.DAY_OF_WEEK;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    66
import static java.time.temporal.ChronoField.DAY_OF_YEAR;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    67
import static java.time.temporal.ChronoField.HOUR_OF_DAY;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    68
import static java.time.temporal.ChronoField.MINUTE_OF_HOUR;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    69
import static java.time.temporal.ChronoField.MONTH_OF_YEAR;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    70
import static java.time.temporal.ChronoField.NANO_OF_SECOND;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    71
import static java.time.temporal.ChronoField.SECOND_OF_MINUTE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    72
import static java.time.temporal.ChronoField.YEAR;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    73
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    74
import java.io.IOException;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    75
import java.text.FieldPosition;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    76
import java.text.Format;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    77
import java.text.ParseException;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    78
import java.text.ParsePosition;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    79
import java.time.DateTimeException;
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
    80
import java.time.Period;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    81
import java.time.ZoneId;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    82
import java.time.ZoneOffset;
34831
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
    83
import java.time.chrono.ChronoLocalDateTime;
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    84
import java.time.chrono.Chronology;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    85
import java.time.chrono.IsoChronology;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    86
import java.time.format.DateTimeFormatterBuilder.CompositePrinterParser;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    87
import java.time.temporal.ChronoField;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    88
import java.time.temporal.IsoFields;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    89
import java.time.temporal.TemporalAccessor;
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    90
import java.time.temporal.TemporalField;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    91
import java.time.temporal.TemporalQuery;
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    92
import java.util.Arrays;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    93
import java.util.Collections;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    94
import java.util.HashMap;
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    95
import java.util.HashSet;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    96
import java.util.Locale;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
    97
import java.util.Map;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
    98
import java.util.Objects;
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
    99
import java.util.Set;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   100
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   101
/**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   102
 * Formatter for printing and parsing date-time objects.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   103
 * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   104
 * This class provides the main application entry point for printing and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   105
 * and provides common implementations of {@code DateTimeFormatter}:
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   106
 * <ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   107
 * <li>Using predefined constants, such as {@link #ISO_LOCAL_DATE}</li>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   108
 * <li>Using pattern letters, such as {@code uuuu-MMM-dd}</li>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   109
 * <li>Using localized styles, such as {@code long} or {@code medium}</li>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   110
 * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   111
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   112
 * More complex formatters are provided by
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   113
 * {@link DateTimeFormatterBuilder DateTimeFormatterBuilder}.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   114
 *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   115
 * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   116
 * The main date-time classes provide two methods - one for formatting,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   117
 * {@code format(DateTimeFormatter formatter)}, and one for parsing,
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   118
 * {@code parse(CharSequence text, DateTimeFormatter formatter)}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   119
 * <p>For example:
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   120
 * <blockquote><pre>
28751
47403deaec44 8068284: Missing @throws in DateTimeFormatterBuilder.appendOffset
rriggs
parents: 28059
diff changeset
   121
 *  LocalDate date = LocalDate.now();
24256
da9a41004459 8034906: Fix typos, errors and Javadoc differences in java.time
scolebourne
parents: 23722
diff changeset
   122
 *  String text = date.format(formatter);
28751
47403deaec44 8068284: Missing @throws in DateTimeFormatterBuilder.appendOffset
rriggs
parents: 28059
diff changeset
   123
 *  LocalDate parsedDate = LocalDate.parse(text, formatter);
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   124
 * </pre></blockquote>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   125
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   126
 * In addition to the format, formatters can be created with desired Locale,
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   127
 * Chronology, ZoneId, and DecimalStyle.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   128
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   129
 * The {@link #withLocale withLocale} method returns a new formatter that
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   130
 * overrides the locale. The locale affects some aspects of formatting and
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   131
 * parsing. For example, the {@link #ofLocalizedDate ofLocalizedDate} provides a
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   132
 * formatter that uses the locale specific date format.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   133
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   134
 * The {@link #withChronology withChronology} method returns a new formatter
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   135
 * that overrides the chronology. If overridden, the date-time value is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   136
 * converted to the chronology before formatting. During parsing the date-time
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   137
 * value is converted to the chronology before it is returned.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   138
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   139
 * The {@link #withZone withZone} method returns a new formatter that overrides
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   140
 * the zone. If overridden, the date-time value is converted to a ZonedDateTime
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   141
 * with the requested ZoneId before formatting. During parsing the ZoneId is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   142
 * applied before the value is returned.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   143
 * <p>
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   144
 * The {@link #withDecimalStyle withDecimalStyle} method returns a new formatter that
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   145
 * overrides the {@link DecimalStyle}. The DecimalStyle symbols are used for
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   146
 * formatting and parsing.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   147
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   148
 * Some applications may need to use the older {@link Format java.text.Format}
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   149
 * class for formatting. The {@link #toFormat()} method returns an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   150
 * implementation of {@code java.text.Format}.
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   151
 *
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   152
 * <h3 id="predefined">Predefined Formatters</h3>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   153
 * <table class="striped">
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   154
 * <caption>Predefined Formatters</caption>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   155
 * <thead>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   156
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   157
 * <th scope="col" style="text-align:left">Formatter</th>
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   158
 * <th scope="col" style="text-align:left">Description</th>
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   159
 * <th scope="col" style="text-align:left">Example</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   160
 * </tr>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   161
 * </thead>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   162
 * <tbody>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   163
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   164
 * <th scope="row">{@link #ofLocalizedDate ofLocalizedDate(dateStyle)} </th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   165
 * <td> Formatter with date style from the locale </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   166
 * <td> '2011-12-03'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   167
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   168
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   169
 * <th scope="row"> {@link #ofLocalizedTime ofLocalizedTime(timeStyle)} </th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   170
 * <td> Formatter with time style from the locale </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   171
 * <td> '10:15:30'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   172
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   173
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   174
 * <th scope="row"> {@link #ofLocalizedDateTime ofLocalizedDateTime(dateTimeStyle)} </th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   175
 * <td> Formatter with a style for date and time from the locale</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   176
 * <td> '3 Jun 2008 11:05:30'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   177
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   178
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   179
 * <th scope="row"> {@link #ofLocalizedDateTime ofLocalizedDateTime(dateStyle,timeStyle)}
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   180
 * </th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   181
 * <td> Formatter with date and time styles from the locale </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   182
 * <td> '3 Jun 2008 11:05'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   183
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   184
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   185
 * <th scope="row"> {@link #BASIC_ISO_DATE}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   186
 * <td>Basic ISO date </td> <td>'20111203'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   187
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   188
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   189
 * <th scope="row"> {@link #ISO_LOCAL_DATE}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   190
 * <td> ISO Local Date </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   191
 * <td>'2011-12-03'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   192
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   193
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   194
 * <th scope="row"> {@link #ISO_OFFSET_DATE}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   195
 * <td> ISO Date with offset </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   196
 * <td>'2011-12-03+01:00'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   197
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   198
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   199
 * <th scope="row"> {@link #ISO_DATE}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   200
 * <td> ISO Date with or without offset </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   201
 * <td> '2011-12-03+01:00'; '2011-12-03'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   202
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   203
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   204
 * <th scope="row"> {@link #ISO_LOCAL_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   205
 * <td> Time without offset </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   206
 * <td>'10:15:30'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   207
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   208
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   209
 * <th scope="row"> {@link #ISO_OFFSET_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   210
 * <td> Time with offset </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   211
 * <td>'10:15:30+01:00'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   212
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   213
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   214
 * <th scope="row"> {@link #ISO_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   215
 * <td> Time with or without offset </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   216
 * <td>'10:15:30+01:00'; '10:15:30'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   217
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   218
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   219
 * <th scope="row"> {@link #ISO_LOCAL_DATE_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   220
 * <td> ISO Local Date and Time </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   221
 * <td>'2011-12-03T10:15:30'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   222
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   223
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   224
 * <th scope="row"> {@link #ISO_OFFSET_DATE_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   225
 * <td> Date Time with Offset
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   226
 * </td><td>2011-12-03T10:15:30+01:00'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   227
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   228
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   229
 * <th scope="row"> {@link #ISO_ZONED_DATE_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   230
 * <td> Zoned Date Time </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   231
 * <td>'2011-12-03T10:15:30+01:00[Europe/Paris]'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   232
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   233
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   234
 * <th scope="row"> {@link #ISO_DATE_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   235
 * <td> Date and time with ZoneId </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   236
 * <td>'2011-12-03T10:15:30+01:00[Europe/Paris]'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   237
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   238
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   239
 * <th scope="row"> {@link #ISO_ORDINAL_DATE}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   240
 * <td> Year and day of year </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   241
 * <td>'2012-337'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   242
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   243
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   244
 * <th scope="row"> {@link #ISO_WEEK_DATE}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   245
 * <td> Year and Week </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   246
 * <td>2012-W48-6'</td></tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   247
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   248
 * <th scope="row"> {@link #ISO_INSTANT}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   249
 * <td> Date and Time of an Instant </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   250
 * <td>'2011-12-03T10:15:30Z' </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   251
 * </tr>
45124
144479e89cdb 8179592: Update tables in java.base to be HTML 5-friendly.
jjg
parents: 44846
diff changeset
   252
 * <tr>
45881
aaec0fbe17ae 8184208: update class="striped" tables for accessibility
jjg
parents: 45124
diff changeset
   253
 * <th scope="row"> {@link #RFC_1123_DATE_TIME}</th>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   254
 * <td> RFC 1123 / RFC 822 </td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   255
 * <td>'Tue, 3 Jun 2008 11:05:30 GMT'</td>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   256
 * </tr>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   257
 * </tbody>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   258
 * </table>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   259
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   260
 * <h3 id="patterns">Patterns for Formatting and Parsing</h3>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   261
 * Patterns are based on a simple sequence of letters and symbols.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   262
 * A pattern is used to create a Formatter using the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   263
 * {@link #ofPattern(String)} and {@link #ofPattern(String, Locale)} methods.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   264
 * For example,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   265
 * {@code "d MMM uuuu"} will format 2011-12-03 as '3&nbsp;Dec&nbsp;2011'.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   266
 * A formatter created from a pattern can be used as many times as necessary,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   267
 * it is immutable and is thread-safe.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   268
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   269
 * For example:
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   270
 * <blockquote><pre>
28751
47403deaec44 8068284: Missing @throws in DateTimeFormatterBuilder.appendOffset
rriggs
parents: 28059
diff changeset
   271
 *  LocalDate date = LocalDate.now();
19030
32f129cb6351 8016025: JSR 310 DateTime API Updates IV
sherman
parents: 18591
diff changeset
   272
 *  DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy MM dd");
24256
da9a41004459 8034906: Fix typos, errors and Javadoc differences in java.time
scolebourne
parents: 23722
diff changeset
   273
 *  String text = date.format(formatter);
28751
47403deaec44 8068284: Missing @throws in DateTimeFormatterBuilder.appendOffset
rriggs
parents: 28059
diff changeset
   274
 *  LocalDate parsedDate = LocalDate.parse(text, formatter);
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   275
 * </pre></blockquote>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   276
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   277
 * All letters 'A' to 'Z' and 'a' to 'z' are reserved as pattern letters. The
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   278
 * following pattern letters are defined:
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   279
 * <pre>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   280
 *  Symbol  Meaning                     Presentation      Examples
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   281
 *  ------  -------                     ------------      -------
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   282
 *   G       era                         text              AD; Anno Domini; A
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   283
 *   u       year                        year              2004; 04
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   284
 *   y       year-of-era                 year              2004; 04
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   285
 *   D       day-of-year                 number            189
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   286
 *   M/L     month-of-year               number/text       7; 07; Jul; July; J
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   287
 *   d       day-of-month                number            10
37599
9ee25a0a2c01 8148947: DateTimeFormatter pattern letter 'g'
ntv
parents: 36646
diff changeset
   288
 *   g       modified-julian-day         number            2451334
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   289
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   290
 *   Q/q     quarter-of-year             number/text       3; 03; Q3; 3rd quarter
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   291
 *   Y       week-based-year             year              1996; 96
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   292
 *   w       week-of-week-based-year     number            27
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   293
 *   W       week-of-month               number            4
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   294
 *   E       day-of-week                 text              Tue; Tuesday; T
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   295
 *   e/c     localized day-of-week       number/text       2; 02; Tue; Tuesday; T
43004
54896b192cc7 8169482: java.time.DateTimeFormatter javadoc: F is not week-of-month
rriggs
parents: 41482
diff changeset
   296
 *   F       day-of-week-in-month        number            3
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   297
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   298
 *   a       am-pm-of-day                text              PM
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   299
 *   h       clock-hour-of-am-pm (1-12)  number            12
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   300
 *   K       hour-of-am-pm (0-11)        number            0
43007
4de62a95642c 8171348: Incorrect documentation for DateTimeFormatter letter 'k'
rriggs
parents: 43004
diff changeset
   301
 *   k       clock-hour-of-day (1-24)    number            24
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   302
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   303
 *   H       hour-of-day (0-23)          number            0
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   304
 *   m       minute-of-hour              number            30
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   305
 *   s       second-of-minute            number            55
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   306
 *   S       fraction-of-second          fraction          978
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   307
 *   A       milli-of-day                number            1234
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   308
 *   n       nano-of-second              number            987654321
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   309
 *   N       nano-of-day                 number            1234000000
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   310
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   311
 *   V       time-zone ID                zone-id           America/Los_Angeles; Z; -08:30
37907
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   312
 *   v       generic time-zone name      zone-name         Pacific Time; PT
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   313
 *   z       time-zone name              zone-name         Pacific Standard Time; PST
37599
9ee25a0a2c01 8148947: DateTimeFormatter pattern letter 'g'
ntv
parents: 36646
diff changeset
   314
 *   O       localized zone-offset       offset-O          GMT+8; GMT+08:00; UTC-08:00
9ee25a0a2c01 8148947: DateTimeFormatter pattern letter 'g'
ntv
parents: 36646
diff changeset
   315
 *   X       zone-offset 'Z' for zero    offset-X          Z; -08; -0830; -08:30; -083015; -08:30:15
9ee25a0a2c01 8148947: DateTimeFormatter pattern letter 'g'
ntv
parents: 36646
diff changeset
   316
 *   x       zone-offset                 offset-x          +0000; -08; -0830; -08:30; -083015; -08:30:15
9ee25a0a2c01 8148947: DateTimeFormatter pattern letter 'g'
ntv
parents: 36646
diff changeset
   317
 *   Z       zone-offset                 offset-Z          +0000; -0800; -08:00
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   318
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   319
 *   p       pad next                    pad modifier      1
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   320
 *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   321
 *   '       escape for text             delimiter
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   322
 *   ''      single quote                literal           '
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   323
 *   [       optional section start
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   324
 *   ]       optional section end
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   325
 *   #       reserved for future use
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   326
 *   {       reserved for future use
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   327
 *   }       reserved for future use
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   328
 * </pre>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   329
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   330
 * The count of pattern letters determines the format.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   331
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   332
 * <b>Text</b>: The text style is determined based on the number of pattern
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   333
 * letters used. Less than 4 pattern letters will use the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   334
 * {@link TextStyle#SHORT short form}. Exactly 4 pattern letters will use the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   335
 * {@link TextStyle#FULL full form}. Exactly 5 pattern letters will use the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   336
 * {@link TextStyle#NARROW narrow form}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   337
 * Pattern letters 'L', 'c', and 'q' specify the stand-alone form of the text styles.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   338
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   339
 * <b>Number</b>: If the count of letters is one, then the value is output using
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   340
 * the minimum number of digits and without padding. Otherwise, the count of digits
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   341
 * is used as the width of the output field, with the value zero-padded as necessary.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   342
 * The following pattern letters have constraints on the count of letters.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   343
 * Only one letter of 'c' and 'F' can be specified.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   344
 * Up to two letters of 'd', 'H', 'h', 'K', 'k', 'm', and 's' can be specified.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   345
 * Up to three letters of 'D' can be specified.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   346
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   347
 * <b>Number/Text</b>: If the count of pattern letters is 3 or greater, use the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   348
 * Text rules above. Otherwise use the Number rules above.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   349
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   350
 * <b>Fraction</b>: Outputs the nano-of-second field as a fraction-of-second.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   351
 * The nano-of-second value has nine digits, thus the count of pattern letters
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   352
 * is from 1 to 9. If it is less than 9, then the nano-of-second value is
22654
da81e0be094a 8032749: Typo in java.time.Clock
rriggs
parents: 20873
diff changeset
   353
 * truncated, with only the most significant digits being output.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   354
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   355
 * <b>Year</b>: The count of letters determines the minimum field width below
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   356
 * which padding is used. If the count of letters is two, then a
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   357
 * {@link DateTimeFormatterBuilder#appendValueReduced reduced} two digit form is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   358
 * used. For printing, this outputs the rightmost two digits. For parsing, this
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   359
 * will parse using the base value of 2000, resulting in a year within the range
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   360
 * 2000 to 2099 inclusive. If the count of letters is less than four (but not
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   361
 * two), then the sign is only output for negative years as per
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   362
 * {@link SignStyle#NORMAL}. Otherwise, the sign is output if the pad width is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   363
 * exceeded, as per {@link SignStyle#EXCEEDS_PAD}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   364
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   365
 * <b>ZoneId</b>: This outputs the time-zone ID, such as 'Europe/Paris'. If the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   366
 * count of letters is two, then the time-zone ID is output. Any other count of
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   367
 * letters throws {@code IllegalArgumentException}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   368
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   369
 * <b>Zone names</b>: This outputs the display name of the time-zone ID. If the
37907
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   370
 * pattern letter is 'z' the output is the daylight savings aware zone name.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   371
 * If there is insufficient information to determine whether DST applies,
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   372
 * the name ignoring daylight savings time will be used.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   373
 * If the count of letters is one, two or three, then the short name is output.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   374
 * If the count of letters is four, then the full name is output.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   375
 * Five or more letters throws {@code IllegalArgumentException}.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   376
 * <p>
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   377
 * If the pattern letter is 'v' the output provides the zone name ignoring
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   378
 * daylight savings time. If the count of letters is one, then the short name is output.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   379
 * If the count of letters is four, then the full name is output.
643c10927a1a 8155823: Add date-time patterns 'v' and 'vvvv'
ntv
parents: 37599
diff changeset
   380
 * Two, three and five or more letters throw {@code IllegalArgumentException}.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   381
 * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   382
 * <b>Offset X and x</b>: This formats the offset based on the number of pattern
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   383
 * letters. One letter outputs just the hour, such as '+01', unless the minute
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   384
 * is non-zero in which case the minute is also output, such as '+0130'. Two
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   385
 * letters outputs the hour and minute, without a colon, such as '+0130'. Three
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   386
 * letters outputs the hour and minute, with a colon, such as '+01:30'. Four
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   387
 * letters outputs the hour and minute and optional second, without a colon,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   388
 * such as '+013015'. Five letters outputs the hour and minute and optional
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   389
 * second, with a colon, such as '+01:30:15'. Six or more letters throws
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   390
 * {@code IllegalArgumentException}. Pattern letter 'X' (upper case) will output
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   391
 * 'Z' when the offset to be output would be zero, whereas pattern letter 'x'
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   392
 * (lower case) will output '+00', '+0000', or '+00:00'.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   393
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   394
 * <b>Offset O</b>: This formats the localized offset based on the number of
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   395
 * pattern letters. One letter outputs the {@linkplain TextStyle#SHORT short}
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   396
 * form of the localized offset, which is localized offset text, such as 'GMT',
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   397
 * with hour without leading zero, optional 2-digit minute and second if
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   398
 * non-zero, and colon, for example 'GMT+8'. Four letters outputs the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   399
 * {@linkplain TextStyle#FULL full} form, which is localized offset text,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   400
 * such as 'GMT, with 2-digit hour and minute field, optional second field
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   401
 * if non-zero, and colon, for example 'GMT+08:00'. Any other count of letters
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   402
 * throws {@code IllegalArgumentException}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   403
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   404
 * <b>Offset Z</b>: This formats the offset based on the number of pattern
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   405
 * letters. One, two or three letters outputs the hour and minute, without a
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   406
 * colon, such as '+0130'. The output will be '+0000' when the offset is zero.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   407
 * Four letters outputs the {@linkplain TextStyle#FULL full} form of localized
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   408
 * offset, equivalent to four letters of Offset-O. The output will be the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   409
 * corresponding localized offset text if the offset is zero. Five
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   410
 * letters outputs the hour, minute, with optional second if non-zero, with
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   411
 * colon. It outputs 'Z' if the offset is zero.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   412
 * Six or more letters throws {@code IllegalArgumentException}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   413
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   414
 * <b>Optional section</b>: The optional section markers work exactly like
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   415
 * calling {@link DateTimeFormatterBuilder#optionalStart()} and
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   416
 * {@link DateTimeFormatterBuilder#optionalEnd()}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   417
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   418
 * <b>Pad modifier</b>: Modifies the pattern that immediately follows to be
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   419
 * padded with spaces. The pad width is determined by the number of pattern
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   420
 * letters. This is the same as calling
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   421
 * {@link DateTimeFormatterBuilder#padNext(int)}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   422
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   423
 * For example, 'ppH' outputs the hour-of-day padded on the left with spaces to
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   424
 * a width of 2.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   425
 * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   426
 * Any unrecognized letter is an error. Any non-letter character, other than
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   427
 * '[', ']', '{', '}', '#' and the single quote will be output directly.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   428
 * Despite this, it is recommended to use single quotes around all characters
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   429
 * that you want to output directly to ensure that future changes do not break
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   430
 * your application.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   431
 *
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   432
 * <h3 id="resolving">Resolving</h3>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   433
 * Parsing is implemented as a two-phase operation.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   434
 * First, the text is parsed using the layout defined by the formatter, producing
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   435
 * a {@code Map} of field to value, a {@code ZoneId} and a {@code Chronology}.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   436
 * Second, the parsed data is <em>resolved</em>, by validating, combining and
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   437
 * simplifying the various fields into more useful ones.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   438
 * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   439
 * Five parsing methods are supplied by this class.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   440
 * Four of these perform both the parse and resolve phases.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   441
 * The fifth method, {@link #parseUnresolved(CharSequence, ParsePosition)},
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   442
 * only performs the first phase, leaving the result unresolved.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   443
 * As such, it is essentially a low-level operation.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   444
 * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   445
 * The resolve phase is controlled by two parameters, set on this class.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   446
 * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   447
 * The {@link ResolverStyle} is an enum that offers three different approaches,
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   448
 * strict, smart and lenient. The smart option is the default.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   449
 * It can be set using {@link #withResolverStyle(ResolverStyle)}.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   450
 * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   451
 * The {@link #withResolverFields(TemporalField...)} parameter allows the
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   452
 * set of fields that will be resolved to be filtered before resolving starts.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   453
 * For example, if the formatter has parsed a year, month, day-of-month
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   454
 * and day-of-year, then there are two approaches to resolve a date:
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   455
 * (year + month + day-of-month) and (year + day-of-year).
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   456
 * The resolver fields allows one of the two approaches to be selected.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   457
 * If no resolver fields are set then both approaches must result in the same date.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   458
 * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   459
 * Resolving separate fields to form a complete date and time is a complex
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   460
 * process with behaviour distributed across a number of classes.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   461
 * It follows these steps:
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   462
 * <ol>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   463
 * <li>The chronology is determined.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   464
 * The chronology of the result is either the chronology that was parsed,
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   465
 * or if no chronology was parsed, it is the chronology set on this class,
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   466
 * or if that is null, it is {@code IsoChronology}.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   467
 * <li>The {@code ChronoField} date fields are resolved.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   468
 * This is achieved using {@link Chronology#resolveDate(Map, ResolverStyle)}.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   469
 * Documentation about field resolution is located in the implementation
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   470
 * of {@code Chronology}.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   471
 * <li>The {@code ChronoField} time fields are resolved.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   472
 * This is documented on {@link ChronoField} and is the same for all chronologies.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   473
 * <li>Any fields that are not {@code ChronoField} are processed.
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   474
 * This is achieved using {@link TemporalField#resolve(Map, TemporalAccessor, ResolverStyle)}.
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   475
 * Documentation about field resolution is located in the implementation
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   476
 * of {@code TemporalField}.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   477
 * <li>The {@code ChronoField} date and time fields are re-resolved.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   478
 * This allows fields in step four to produce {@code ChronoField} values
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   479
 * and have them be processed into dates and times.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   480
 * <li>A {@code LocalTime} is formed if there is at least an hour-of-day available.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   481
 * This involves providing default values for minute, second and fraction of second.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   482
 * <li>Any remaining unresolved fields are cross-checked against any
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   483
 * date and/or time that was resolved. Thus, an earlier stage would resolve
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   484
 * (year + month + day-of-month) to a date, and this stage would check that
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   485
 * day-of-week was valid for the date.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   486
 * <li>If an {@linkplain #parsedExcessDays() excess number of days}
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   487
 * was parsed then it is added to the date if a date is available.
34831
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   488
 * <li> If a second-based field is present, but {@code LocalTime} was not parsed,
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   489
 * then the resolver ensures that milli, micro and nano second values are
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   490
 * available to meet the contract of {@link ChronoField}.
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   491
 * These will be set to zero if missing.
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   492
 * <li>If both date and time were parsed and either an offset or zone is present,
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   493
 * the field {@link ChronoField#INSTANT_SECONDS} is created.
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   494
 * If an offset was parsed then the offset will be combined with the
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   495
 * {@code LocalDateTime} to form the instant, with any zone ignored.
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   496
 * If a {@code ZoneId} was parsed without an offset then the zone will be
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   497
 * combined with the {@code LocalDateTime} to form the instant using the rules
dc7f444c7b85 8066982: ZonedDateTime.parse() returns wrong ZoneOffset around DST fall transition
igerasim
parents: 30821
diff changeset
   498
 * of {@link ChronoLocalDateTime#atZone(ZoneId)}.
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   499
 * </ol>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   500
 *
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   501
 * @implSpec
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   502
 * This class is immutable and thread-safe.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   503
 *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   504
 * @since 1.8
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   505
 */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   506
public final class DateTimeFormatter {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   507
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   508
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   509
     * The printer and/or parser to use, not null.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   510
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   511
    private final CompositePrinterParser printerParser;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   512
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   513
     * The locale to use for formatting, not null.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   514
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   515
    private final Locale locale;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   516
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   517
     * The symbols to use for formatting, not null.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   518
     */
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
   519
    private final DecimalStyle decimalStyle;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   520
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   521
     * The resolver style to use, not null.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   522
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   523
    private final ResolverStyle resolverStyle;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   524
    /**
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   525
     * The fields to use in resolving, null for all fields.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   526
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   527
    private final Set<TemporalField> resolverFields;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   528
    /**
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   529
     * The chronology to use for formatting, null for no override.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   530
     */
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   531
    private final Chronology chrono;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   532
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   533
     * The zone to use for formatting, null for no override.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   534
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   535
    private final ZoneId zone;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
   536
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   537
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   538
    /**
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   539
     * Creates a formatter using the specified pattern.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   540
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   541
     * This method will create a formatter based on a simple
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   542
     * <a href="#patterns">pattern of letters and symbols</a>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   543
     * as described in the class documentation.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   544
     * For example, {@code d MMM uuuu} will format 2011-12-03 as '3 Dec 2011'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   545
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   546
     * The formatter will use the {@link Locale#getDefault(Locale.Category) default FORMAT locale}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   547
     * This can be changed using {@link DateTimeFormatter#withLocale(Locale)} on the returned formatter
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   548
     * Alternatively use the {@link #ofPattern(String, Locale)} variant of this method.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   549
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   550
     * The returned formatter has no override chronology or zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   551
     * It uses {@link ResolverStyle#SMART SMART} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   552
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   553
     * @param pattern  the pattern to use, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   554
     * @return the formatter based on the pattern, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   555
     * @throws IllegalArgumentException if the pattern is invalid
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   556
     * @see DateTimeFormatterBuilder#appendPattern(String)
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   557
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   558
    public static DateTimeFormatter ofPattern(String pattern) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   559
        return new DateTimeFormatterBuilder().appendPattern(pattern).toFormatter();
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   560
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   561
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   562
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   563
     * Creates a formatter using the specified pattern and locale.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   564
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   565
     * This method will create a formatter based on a simple
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   566
     * <a href="#patterns">pattern of letters and symbols</a>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   567
     * as described in the class documentation.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   568
     * For example, {@code d MMM uuuu} will format 2011-12-03 as '3 Dec 2011'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   569
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   570
     * The formatter will use the specified locale.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   571
     * This can be changed using {@link DateTimeFormatter#withLocale(Locale)} on the returned formatter
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   572
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   573
     * The returned formatter has no override chronology or zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   574
     * It uses {@link ResolverStyle#SMART SMART} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   575
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   576
     * @param pattern  the pattern to use, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   577
     * @param locale  the locale to use, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   578
     * @return the formatter based on the pattern, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   579
     * @throws IllegalArgumentException if the pattern is invalid
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   580
     * @see DateTimeFormatterBuilder#appendPattern(String)
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   581
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   582
    public static DateTimeFormatter ofPattern(String pattern, Locale locale) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   583
        return new DateTimeFormatterBuilder().appendPattern(pattern).toFormatter(locale);
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   584
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   585
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   586
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   587
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   588
     * Returns a locale specific date format for the ISO chronology.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   589
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   590
     * This returns a formatter that will format or parse a date.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   591
     * The exact format pattern used varies by locale.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   592
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   593
     * The locale is determined from the formatter. The formatter returned directly by
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   594
     * this method will use the {@link Locale#getDefault(Locale.Category) default FORMAT locale}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   595
     * The locale can be controlled using {@link DateTimeFormatter#withLocale(Locale) withLocale(Locale)}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   596
     * on the result of this method.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   597
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   598
     * Note that the localized pattern is looked up lazily.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   599
     * This {@code DateTimeFormatter} holds the style required and the locale,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   600
     * looking up the pattern required on demand.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   601
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   602
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   603
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   604
     * It has no override zone and uses the {@link ResolverStyle#SMART SMART} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   605
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   606
     * @param dateStyle  the formatter style to obtain, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   607
     * @return the date formatter, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   608
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   609
    public static DateTimeFormatter ofLocalizedDate(FormatStyle dateStyle) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   610
        Objects.requireNonNull(dateStyle, "dateStyle");
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   611
        return new DateTimeFormatterBuilder().appendLocalized(dateStyle, null)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   612
                .toFormatter(ResolverStyle.SMART, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   613
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   614
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   615
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   616
     * Returns a locale specific time format for the ISO chronology.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   617
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   618
     * This returns a formatter that will format or parse a time.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   619
     * The exact format pattern used varies by locale.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   620
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   621
     * The locale is determined from the formatter. The formatter returned directly by
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   622
     * this method will use the {@link Locale#getDefault(Locale.Category) default FORMAT locale}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   623
     * The locale can be controlled using {@link DateTimeFormatter#withLocale(Locale) withLocale(Locale)}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   624
     * on the result of this method.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   625
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   626
     * Note that the localized pattern is looked up lazily.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   627
     * This {@code DateTimeFormatter} holds the style required and the locale,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   628
     * looking up the pattern required on demand.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   629
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   630
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   631
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   632
     * It has no override zone and uses the {@link ResolverStyle#SMART SMART} resolver style.
36638
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   633
     * The {@code FULL} and {@code LONG} styles typically require a time-zone.
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   634
     * When formatting using these styles, a {@code ZoneId} must be available,
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   635
     * either by using {@code ZonedDateTime} or {@link DateTimeFormatter#withZone}.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   636
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   637
     * @param timeStyle  the formatter style to obtain, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   638
     * @return the time formatter, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   639
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   640
    public static DateTimeFormatter ofLocalizedTime(FormatStyle timeStyle) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   641
        Objects.requireNonNull(timeStyle, "timeStyle");
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   642
        return new DateTimeFormatterBuilder().appendLocalized(null, timeStyle)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   643
                .toFormatter(ResolverStyle.SMART, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   644
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   645
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   646
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   647
     * Returns a locale specific date-time formatter for the ISO chronology.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   648
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   649
     * This returns a formatter that will format or parse a date-time.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   650
     * The exact format pattern used varies by locale.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   651
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   652
     * The locale is determined from the formatter. The formatter returned directly by
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   653
     * this method will use the {@link Locale#getDefault(Locale.Category) default FORMAT locale}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   654
     * The locale can be controlled using {@link DateTimeFormatter#withLocale(Locale) withLocale(Locale)}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   655
     * on the result of this method.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   656
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   657
     * Note that the localized pattern is looked up lazily.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   658
     * This {@code DateTimeFormatter} holds the style required and the locale,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   659
     * looking up the pattern required on demand.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   660
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   661
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   662
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   663
     * It has no override zone and uses the {@link ResolverStyle#SMART SMART} resolver style.
36638
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   664
     * The {@code FULL} and {@code LONG} styles typically require a time-zone.
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   665
     * When formatting using these styles, a {@code ZoneId} must be available,
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   666
     * either by using {@code ZonedDateTime} or {@link DateTimeFormatter#withZone}.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   667
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   668
     * @param dateTimeStyle  the formatter style to obtain, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   669
     * @return the date-time formatter, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   670
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   671
    public static DateTimeFormatter ofLocalizedDateTime(FormatStyle dateTimeStyle) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   672
        Objects.requireNonNull(dateTimeStyle, "dateTimeStyle");
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   673
        return new DateTimeFormatterBuilder().appendLocalized(dateTimeStyle, dateTimeStyle)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   674
                .toFormatter(ResolverStyle.SMART, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   675
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   676
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   677
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   678
     * Returns a locale specific date and time format for the ISO chronology.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   679
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   680
     * This returns a formatter that will format or parse a date-time.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   681
     * The exact format pattern used varies by locale.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   682
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   683
     * The locale is determined from the formatter. The formatter returned directly by
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   684
     * this method will use the {@link Locale#getDefault() default FORMAT locale}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   685
     * The locale can be controlled using {@link DateTimeFormatter#withLocale(Locale) withLocale(Locale)}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   686
     * on the result of this method.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   687
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   688
     * Note that the localized pattern is looked up lazily.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   689
     * This {@code DateTimeFormatter} holds the style required and the locale,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   690
     * looking up the pattern required on demand.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   691
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   692
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   693
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   694
     * It has no override zone and uses the {@link ResolverStyle#SMART SMART} resolver style.
36638
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   695
     * The {@code FULL} and {@code LONG} styles typically require a time-zone.
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   696
     * When formatting using these styles, a {@code ZoneId} must be available,
bc1438c48f1b 8085887: java.time.format.FormatStyle.LONG or FULL causes unchecked exception
rriggs
parents: 34831
diff changeset
   697
     * either by using {@code ZonedDateTime} or {@link DateTimeFormatter#withZone}.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   698
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   699
     * @param dateStyle  the date formatter style to obtain, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   700
     * @param timeStyle  the time formatter style to obtain, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   701
     * @return the date, time or date-time formatter, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   702
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   703
    public static DateTimeFormatter ofLocalizedDateTime(FormatStyle dateStyle, FormatStyle timeStyle) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   704
        Objects.requireNonNull(dateStyle, "dateStyle");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   705
        Objects.requireNonNull(timeStyle, "timeStyle");
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   706
        return new DateTimeFormatterBuilder().appendLocalized(dateStyle, timeStyle)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   707
                .toFormatter(ResolverStyle.SMART, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   708
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   709
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   710
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   711
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   712
     * The ISO date formatter that formats or parses a date without an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   713
     * offset, such as '2011-12-03'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   714
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   715
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   716
     * the ISO-8601 extended local date format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   717
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   718
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   719
     * <li>Four digits or more for the {@link ChronoField#YEAR year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   720
     * Years in the range 0000 to 9999 will be pre-padded by zero to ensure four digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   721
     * Years outside that range will have a prefixed positive or negative symbol.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   722
     * <li>A dash
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   723
     * <li>Two digits for the {@link ChronoField#MONTH_OF_YEAR month-of-year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   724
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   725
     * <li>A dash
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   726
     * <li>Two digits for the {@link ChronoField#DAY_OF_MONTH day-of-month}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   727
     *  This is pre-padded by zero to ensure two digits.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   728
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   729
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   730
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   731
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   732
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   733
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   734
    public static final DateTimeFormatter ISO_LOCAL_DATE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   735
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   736
        ISO_LOCAL_DATE = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   737
                .appendValue(YEAR, 4, 10, SignStyle.EXCEEDS_PAD)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   738
                .appendLiteral('-')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   739
                .appendValue(MONTH_OF_YEAR, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   740
                .appendLiteral('-')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   741
                .appendValue(DAY_OF_MONTH, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   742
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   743
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   744
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   745
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   746
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   747
     * The ISO date formatter that formats or parses a date with an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   748
     * offset, such as '2011-12-03+01:00'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   749
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   750
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   751
     * the ISO-8601 extended offset date format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   752
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   753
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   754
     * <li>The {@link #ISO_LOCAL_DATE}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   755
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   756
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   757
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   758
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   759
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   760
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   761
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   762
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   763
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   764
    public static final DateTimeFormatter ISO_OFFSET_DATE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   765
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   766
        ISO_OFFSET_DATE = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   767
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   768
                .append(ISO_LOCAL_DATE)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   769
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   770
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   771
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   772
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   773
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   774
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   775
     * The ISO date formatter that formats or parses a date with the
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   776
     * offset if available, such as '2011-12-03' or '2011-12-03+01:00'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   777
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   778
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   779
     * the ISO-8601 extended date format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   780
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   781
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   782
     * <li>The {@link #ISO_LOCAL_DATE}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   783
     * <li>If the offset is not available then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   784
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   785
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   786
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   787
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   788
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   789
     * As this formatter has an optional element, it may be necessary to parse using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   790
     * {@link DateTimeFormatter#parseBest}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   791
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   792
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   793
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   794
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   795
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   796
    public static final DateTimeFormatter ISO_DATE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   797
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   798
        ISO_DATE = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   799
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   800
                .append(ISO_LOCAL_DATE)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   801
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   802
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   803
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   804
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   805
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   806
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   807
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   808
     * The ISO time formatter that formats or parses a time without an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   809
     * offset, such as '10:15' or '10:15:30'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   810
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   811
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   812
     * the ISO-8601 extended local time format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   813
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   814
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   815
     * <li>Two digits for the {@link ChronoField#HOUR_OF_DAY hour-of-day}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   816
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   817
     * <li>A colon
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   818
     * <li>Two digits for the {@link ChronoField#MINUTE_OF_HOUR minute-of-hour}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   819
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   820
     * <li>If the second-of-minute is not available then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   821
     * <li>A colon
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   822
     * <li>Two digits for the {@link ChronoField#SECOND_OF_MINUTE second-of-minute}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   823
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   824
     * <li>If the nano-of-second is zero or not available then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   825
     * <li>A decimal point
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   826
     * <li>One to nine digits for the {@link ChronoField#NANO_OF_SECOND nano-of-second}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   827
     *  As many digits will be output as required.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   828
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   829
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   830
     * The returned formatter has no override chronology or zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   831
     * It uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   832
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   833
    public static final DateTimeFormatter ISO_LOCAL_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   834
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   835
        ISO_LOCAL_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   836
                .appendValue(HOUR_OF_DAY, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   837
                .appendLiteral(':')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   838
                .appendValue(MINUTE_OF_HOUR, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   839
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   840
                .appendLiteral(':')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   841
                .appendValue(SECOND_OF_MINUTE, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   842
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   843
                .appendFraction(NANO_OF_SECOND, 0, 9, true)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   844
                .toFormatter(ResolverStyle.STRICT, null);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   845
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   846
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   847
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   848
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   849
     * The ISO time formatter that formats or parses a time with an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   850
     * offset, such as '10:15+01:00' or '10:15:30+01:00'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   851
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   852
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   853
     * the ISO-8601 extended offset time format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   854
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   855
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   856
     * <li>The {@link #ISO_LOCAL_TIME}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   857
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   858
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   859
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   860
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   861
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   862
     * The returned formatter has no override chronology or zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   863
     * It uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   864
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   865
    public static final DateTimeFormatter ISO_OFFSET_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   866
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   867
        ISO_OFFSET_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   868
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   869
                .append(ISO_LOCAL_TIME)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   870
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   871
                .toFormatter(ResolverStyle.STRICT, null);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   872
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   873
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   874
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   875
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   876
     * The ISO time formatter that formats or parses a time, with the
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   877
     * offset if available, such as '10:15', '10:15:30' or '10:15:30+01:00'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   878
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   879
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   880
     * the ISO-8601 extended offset time format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   881
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   882
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   883
     * <li>The {@link #ISO_LOCAL_TIME}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   884
     * <li>If the offset is not available then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   885
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   886
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   887
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   888
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   889
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   890
     * As this formatter has an optional element, it may be necessary to parse using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   891
     * {@link DateTimeFormatter#parseBest}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   892
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   893
     * The returned formatter has no override chronology or zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   894
     * It uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   895
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   896
    public static final DateTimeFormatter ISO_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   897
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   898
        ISO_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   899
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   900
                .append(ISO_LOCAL_TIME)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   901
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   902
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   903
                .toFormatter(ResolverStyle.STRICT, null);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   904
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   905
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   906
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   907
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   908
     * The ISO date-time formatter that formats or parses a date-time without
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   909
     * an offset, such as '2011-12-03T10:15:30'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   910
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   911
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   912
     * the ISO-8601 extended offset date-time format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   913
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   914
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   915
     * <li>The {@link #ISO_LOCAL_DATE}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   916
     * <li>The letter 'T'. Parsing is case insensitive.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   917
     * <li>The {@link #ISO_LOCAL_TIME}
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   918
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   919
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   920
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   921
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   922
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   923
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   924
    public static final DateTimeFormatter ISO_LOCAL_DATE_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   925
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   926
        ISO_LOCAL_DATE_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   927
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   928
                .append(ISO_LOCAL_DATE)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   929
                .appendLiteral('T')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   930
                .append(ISO_LOCAL_TIME)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   931
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   932
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   933
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   934
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   935
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   936
     * The ISO date-time formatter that formats or parses a date-time with an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   937
     * offset, such as '2011-12-03T10:15:30+01:00'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   938
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   939
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   940
     * the ISO-8601 extended offset date-time format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   941
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   942
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   943
     * <li>The {@link #ISO_LOCAL_DATE_TIME}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   944
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   945
     *  they will be handled even though this is not part of the ISO-8601 standard.
36646
de0663d2d82e 8032051: "ZonedDateTime" class "parse" method fails with short time zone offset ("+01")
ntv
parents: 36638
diff changeset
   946
     *  The offset parsing is lenient, which allows the minutes and seconds to be optional.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   947
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   948
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   949
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   950
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   951
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   952
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   953
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   954
    public static final DateTimeFormatter ISO_OFFSET_DATE_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   955
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   956
        ISO_OFFSET_DATE_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   957
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   958
                .append(ISO_LOCAL_DATE_TIME)
36646
de0663d2d82e 8032051: "ZonedDateTime" class "parse" method fails with short time zone offset ("+01")
ntv
parents: 36638
diff changeset
   959
                .parseLenient()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   960
                .appendOffsetId()
36646
de0663d2d82e 8032051: "ZonedDateTime" class "parse" method fails with short time zone offset ("+01")
ntv
parents: 36638
diff changeset
   961
                .parseStrict()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   962
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   963
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   964
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   965
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   966
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   967
     * The ISO-like date-time formatter that formats or parses a date-time with
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   968
     * offset and zone, such as '2011-12-03T10:15:30+01:00[Europe/Paris]'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   969
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   970
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   971
     * a format that extends the ISO-8601 extended offset date-time format
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   972
     * to add the time-zone.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   973
     * The section in square brackets is not part of the ISO-8601 standard.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   974
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
   975
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   976
     * <li>The {@link #ISO_OFFSET_DATE_TIME}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   977
     * <li>If the zone ID is not available or is a {@code ZoneOffset} then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   978
     * <li>An open square bracket '['.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   979
     * <li>The {@link ZoneId#getId() zone ID}. This is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   980
     *  Parsing is case sensitive.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   981
     * <li>A close square bracket ']'.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   982
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   983
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   984
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   985
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   986
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   987
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   988
    public static final DateTimeFormatter ISO_ZONED_DATE_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   989
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   990
        ISO_ZONED_DATE_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   991
                .append(ISO_OFFSET_DATE_TIME)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   992
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   993
                .appendLiteral('[')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   994
                .parseCaseSensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   995
                .appendZoneRegionId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   996
                .appendLiteral(']')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
   997
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   998
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
   999
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1000
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1001
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1002
     * The ISO-like date-time formatter that formats or parses a date-time with
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1003
     * the offset and zone if available, such as '2011-12-03T10:15:30',
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1004
     * '2011-12-03T10:15:30+01:00' or '2011-12-03T10:15:30+01:00[Europe/Paris]'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1005
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1006
     * This returns an immutable formatter capable of formatting and parsing
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1007
     * the ISO-8601 extended local or offset date-time format, as well as the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1008
     * extended non-ISO form specifying the time-zone.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1009
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1010
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1011
     * <li>The {@link #ISO_LOCAL_DATE_TIME}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1012
     * <li>If the offset is not available to format or parse then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1013
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1014
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1015
     * <li>If the zone ID is not available or is a {@code ZoneOffset} then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1016
     * <li>An open square bracket '['.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1017
     * <li>The {@link ZoneId#getId() zone ID}. This is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1018
     *  Parsing is case sensitive.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1019
     * <li>A close square bracket ']'.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1020
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1021
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1022
     * As this formatter has an optional element, it may be necessary to parse using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1023
     * {@link DateTimeFormatter#parseBest}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1024
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1025
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1026
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1027
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1028
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1029
    public static final DateTimeFormatter ISO_DATE_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1030
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1031
        ISO_DATE_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1032
                .append(ISO_LOCAL_DATE_TIME)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1033
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1034
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1035
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1036
                .appendLiteral('[')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1037
                .parseCaseSensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1038
                .appendZoneRegionId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1039
                .appendLiteral(']')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1040
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1041
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1042
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1043
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1044
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1045
     * The ISO date formatter that formats or parses the ordinal date
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1046
     * without an offset, such as '2012-337'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1047
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1048
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1049
     * the ISO-8601 extended ordinal date format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1050
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1051
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1052
     * <li>Four digits or more for the {@link ChronoField#YEAR year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1053
     * Years in the range 0000 to 9999 will be pre-padded by zero to ensure four digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1054
     * Years outside that range will have a prefixed positive or negative symbol.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1055
     * <li>A dash
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1056
     * <li>Three digits for the {@link ChronoField#DAY_OF_YEAR day-of-year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1057
     *  This is pre-padded by zero to ensure three digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1058
     * <li>If the offset is not available to format or parse then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1059
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1060
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1061
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1062
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1063
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1064
     * As this formatter has an optional element, it may be necessary to parse using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1065
     * {@link DateTimeFormatter#parseBest}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1066
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1067
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1068
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1069
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1070
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1071
    public static final DateTimeFormatter ISO_ORDINAL_DATE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1072
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1073
        ISO_ORDINAL_DATE = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1074
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1075
                .appendValue(YEAR, 4, 10, SignStyle.EXCEEDS_PAD)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1076
                .appendLiteral('-')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1077
                .appendValue(DAY_OF_YEAR, 3)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1078
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1079
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1080
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1081
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1082
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1083
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1084
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1085
     * The ISO date formatter that formats or parses the week-based date
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1086
     * without an offset, such as '2012-W48-6'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1087
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1088
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1089
     * the ISO-8601 extended week-based date format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1090
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1091
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1092
     * <li>Four digits or more for the {@link IsoFields#WEEK_BASED_YEAR week-based-year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1093
     * Years in the range 0000 to 9999 will be pre-padded by zero to ensure four digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1094
     * Years outside that range will have a prefixed positive or negative symbol.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1095
     * <li>A dash
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1096
     * <li>The letter 'W'. Parsing is case insensitive.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1097
     * <li>Two digits for the {@link IsoFields#WEEK_OF_WEEK_BASED_YEAR week-of-week-based-year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1098
     *  This is pre-padded by zero to ensure three digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1099
     * <li>A dash
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1100
     * <li>One digit for the {@link ChronoField#DAY_OF_WEEK day-of-week}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1101
     *  The value run from Monday (1) to Sunday (7).
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1102
     * <li>If the offset is not available to format or parse then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1103
     * <li>The {@link ZoneOffset#getId() offset ID}. If the offset has seconds then
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1104
     *  they will be handled even though this is not part of the ISO-8601 standard.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1105
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1106
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1107
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1108
     * As this formatter has an optional element, it may be necessary to parse using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1109
     * {@link DateTimeFormatter#parseBest}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1110
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1111
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1112
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1113
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1114
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1115
    public static final DateTimeFormatter ISO_WEEK_DATE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1116
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1117
        ISO_WEEK_DATE = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1118
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1119
                .appendValue(IsoFields.WEEK_BASED_YEAR, 4, 10, SignStyle.EXCEEDS_PAD)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1120
                .appendLiteral("-W")
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1121
                .appendValue(IsoFields.WEEK_OF_WEEK_BASED_YEAR, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1122
                .appendLiteral('-')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1123
                .appendValue(DAY_OF_WEEK, 1)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1124
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1125
                .appendOffsetId()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1126
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1127
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1128
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1129
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1130
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1131
     * The ISO instant formatter that formats or parses an instant in UTC,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1132
     * such as '2011-12-03T10:15:30Z'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1133
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1134
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1135
     * the ISO-8601 instant format.
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1136
     * When formatting, the second-of-minute is always output.
28059
e576535359cc 8067377: My hobby: caning, then then canning, the the can-can
martin
parents: 25859
diff changeset
  1137
     * The nano-of-second outputs zero, three, six or nine digits as necessary.
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1138
     * When parsing, time to at least the seconds field is required.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1139
     * Fractional seconds from zero to nine are parsed.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1140
     * The localized decimal style is not used.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1141
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1142
     * This is a special case formatter intended to allow a human readable form
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1143
     * of an {@link java.time.Instant}. The {@code Instant} class is designed to
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1144
     * only represent a point in time and internally stores a value in nanoseconds
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1145
     * from a fixed epoch of 1970-01-01Z. As such, an {@code Instant} cannot be
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1146
     * formatted as a date or time without providing some form of time-zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1147
     * This formatter allows the {@code Instant} to be formatted, by providing
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1148
     * a suitable conversion using {@code ZoneOffset.UTC}.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1149
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1150
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1151
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1152
     * <li>The {@link #ISO_OFFSET_DATE_TIME} where the instant is converted from
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1153
     *  {@link ChronoField#INSTANT_SECONDS} and {@link ChronoField#NANO_OF_SECOND}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1154
     *  using the {@code UTC} offset. Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1155
     * </ul>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1156
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1157
     * The returned formatter has no override chronology or zone.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1158
     * It uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1159
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1160
    public static final DateTimeFormatter ISO_INSTANT;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1161
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1162
        ISO_INSTANT = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1163
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1164
                .appendInstant()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1165
                .toFormatter(ResolverStyle.STRICT, null);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1166
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1167
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1168
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1169
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1170
     * The ISO date formatter that formats or parses a date without an
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1171
     * offset, such as '20111203'.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1172
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1173
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1174
     * the ISO-8601 basic local date format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1175
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1176
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1177
     * <li>Four digits for the {@link ChronoField#YEAR year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1178
     *  Only years in the range 0000 to 9999 are supported.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1179
     * <li>Two digits for the {@link ChronoField#MONTH_OF_YEAR month-of-year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1180
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1181
     * <li>Two digits for the {@link ChronoField#DAY_OF_MONTH day-of-month}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1182
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1183
     * <li>If the offset is not available to format or parse then the format is complete.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1184
     * <li>The {@link ZoneOffset#getId() offset ID} without colons. If the offset has
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1185
     *  seconds then they will be handled even though this is not part of the ISO-8601 standard.
36646
de0663d2d82e 8032051: "ZonedDateTime" class "parse" method fails with short time zone offset ("+01")
ntv
parents: 36638
diff changeset
  1186
     *  The offset parsing is lenient, which allows the minutes and seconds to be optional.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1187
     *  Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1188
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1189
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1190
     * As this formatter has an optional element, it may be necessary to parse using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1191
     * {@link DateTimeFormatter#parseBest}.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1192
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1193
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1194
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1195
     * It has no override zone and uses the {@link ResolverStyle#STRICT STRICT} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1196
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1197
    public static final DateTimeFormatter BASIC_ISO_DATE;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1198
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1199
        BASIC_ISO_DATE = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1200
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1201
                .appendValue(YEAR, 4)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1202
                .appendValue(MONTH_OF_YEAR, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1203
                .appendValue(DAY_OF_MONTH, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1204
                .optionalStart()
36646
de0663d2d82e 8032051: "ZonedDateTime" class "parse" method fails with short time zone offset ("+01")
ntv
parents: 36638
diff changeset
  1205
                .parseLenient()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1206
                .appendOffset("+HHMMss", "Z")
36646
de0663d2d82e 8032051: "ZonedDateTime" class "parse" method fails with short time zone offset ("+01")
ntv
parents: 36638
diff changeset
  1207
                .parseStrict()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1208
                .toFormatter(ResolverStyle.STRICT, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1209
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1210
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1211
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1212
    /**
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1213
     * The RFC-1123 date-time formatter, such as 'Tue, 3 Jun 2008 11:05:30 GMT'.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1214
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1215
     * This returns an immutable formatter capable of formatting and parsing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1216
     * most of the RFC-1123 format.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1217
     * RFC-1123 updates RFC-822 changing the year from two digits to four.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1218
     * This implementation requires a four digit year.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1219
     * This implementation also does not handle North American or military zone
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1220
     * names, only 'GMT' and offset amounts.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1221
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1222
     * The format consists of:
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1223
     * <ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1224
     * <li>If the day-of-week is not available to format or parse then jump to day-of-month.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1225
     * <li>Three letter {@link ChronoField#DAY_OF_WEEK day-of-week} in English.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1226
     * <li>A comma
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1227
     * <li>A space
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1228
     * <li>One or two digits for the {@link ChronoField#DAY_OF_MONTH day-of-month}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1229
     * <li>A space
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1230
     * <li>Three letter {@link ChronoField#MONTH_OF_YEAR month-of-year} in English.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1231
     * <li>A space
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1232
     * <li>Four digits for the {@link ChronoField#YEAR year}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1233
     *  Only years in the range 0000 to 9999 are supported.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1234
     * <li>A space
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1235
     * <li>Two digits for the {@link ChronoField#HOUR_OF_DAY hour-of-day}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1236
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1237
     * <li>A colon
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1238
     * <li>Two digits for the {@link ChronoField#MINUTE_OF_HOUR minute-of-hour}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1239
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1240
     * <li>If the second-of-minute is not available then jump to the next space.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1241
     * <li>A colon
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1242
     * <li>Two digits for the {@link ChronoField#SECOND_OF_MINUTE second-of-minute}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1243
     *  This is pre-padded by zero to ensure two digits.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1244
     * <li>A space
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1245
     * <li>The {@link ZoneOffset#getId() offset ID} without colons or seconds.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1246
     *  An offset of zero uses "GMT". North American zone names and military zone names are not handled.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1247
     * </ul>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1248
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1249
     * Parsing is case insensitive.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1250
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1251
     * The returned formatter has a chronology of ISO set to ensure dates in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1252
     * other calendar systems are correctly converted.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1253
     * It has no override zone and uses the {@link ResolverStyle#SMART SMART} resolver style.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1254
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1255
    public static final DateTimeFormatter RFC_1123_DATE_TIME;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1256
    static {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1257
        // manually code maps to ensure correct data always used
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1258
        // (locale data can be changed by application code)
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1259
        Map<Long, String> dow = new HashMap<>();
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1260
        dow.put(1L, "Mon");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1261
        dow.put(2L, "Tue");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1262
        dow.put(3L, "Wed");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1263
        dow.put(4L, "Thu");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1264
        dow.put(5L, "Fri");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1265
        dow.put(6L, "Sat");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1266
        dow.put(7L, "Sun");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1267
        Map<Long, String> moy = new HashMap<>();
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1268
        moy.put(1L, "Jan");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1269
        moy.put(2L, "Feb");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1270
        moy.put(3L, "Mar");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1271
        moy.put(4L, "Apr");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1272
        moy.put(5L, "May");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1273
        moy.put(6L, "Jun");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1274
        moy.put(7L, "Jul");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1275
        moy.put(8L, "Aug");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1276
        moy.put(9L, "Sep");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1277
        moy.put(10L, "Oct");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1278
        moy.put(11L, "Nov");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1279
        moy.put(12L, "Dec");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1280
        RFC_1123_DATE_TIME = new DateTimeFormatterBuilder()
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1281
                .parseCaseInsensitive()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1282
                .parseLenient()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1283
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1284
                .appendText(DAY_OF_WEEK, dow)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1285
                .appendLiteral(", ")
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1286
                .optionalEnd()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1287
                .appendValue(DAY_OF_MONTH, 1, 2, SignStyle.NOT_NEGATIVE)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1288
                .appendLiteral(' ')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1289
                .appendText(MONTH_OF_YEAR, moy)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1290
                .appendLiteral(' ')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1291
                .appendValue(YEAR, 4)  // 2 digit year not handled
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1292
                .appendLiteral(' ')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1293
                .appendValue(HOUR_OF_DAY, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1294
                .appendLiteral(':')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1295
                .appendValue(MINUTE_OF_HOUR, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1296
                .optionalStart()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1297
                .appendLiteral(':')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1298
                .appendValue(SECOND_OF_MINUTE, 2)
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1299
                .optionalEnd()
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1300
                .appendLiteral(' ')
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1301
                .appendOffset("+HHMM", "GMT")  // should handle UT/Z/EST/EDT/CST/CDT/MST/MDT/PST/MDT
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1302
                .toFormatter(ResolverStyle.SMART, IsoChronology.INSTANCE);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1303
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1304
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1305
    //-----------------------------------------------------------------------
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1306
    /**
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1307
     * A query that provides access to the excess days that were parsed.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1308
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1309
     * This returns a singleton {@linkplain TemporalQuery query} that provides
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1310
     * access to additional information from the parse. The query always returns
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1311
     * a non-null period, with a zero period returned instead of null.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1312
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1313
     * There are two situations where this query may return a non-zero period.
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1314
     * <ul>
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1315
     * <li>If the {@code ResolverStyle} is {@code LENIENT} and a time is parsed
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1316
     *  without a date, then the complete result of the parse consists of a
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1317
     *  {@code LocalTime} and an excess {@code Period} in days.
20873
e91d5b1cb8e6 8026516: javadoc errors in java.time
rriggs
parents: 19030
diff changeset
  1318
     *
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1319
     * <li>If the {@code ResolverStyle} is {@code SMART} and a time is parsed
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1320
     *  without a date where the time is 24:00:00, then the complete result of
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1321
     *  the parse consists of a {@code LocalTime} of 00:00:00 and an excess
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1322
     *  {@code Period} of one day.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1323
     * </ul>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1324
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1325
     * In both cases, if a complete {@code ChronoLocalDateTime} or {@code Instant}
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1326
     * is parsed, then the excess days are added to the date part.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1327
     * As a result, this query will return a zero period.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1328
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1329
     * The {@code SMART} behaviour handles the common "end of day" 24:00 value.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1330
     * Processing in {@code LENIENT} mode also produces the same result:
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1331
     * <pre>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1332
     *  Text to parse        Parsed object                         Excess days
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1333
     *  "2012-12-03T00:00"   LocalDateTime.of(2012, 12, 3, 0, 0)   ZERO
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1334
     *  "2012-12-03T24:00"   LocalDateTime.of(2012, 12, 4, 0, 0)   ZERO
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1335
     *  "00:00"              LocalTime.of(0, 0)                    ZERO
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1336
     *  "24:00"              LocalTime.of(0, 0)                    Period.ofDays(1)
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1337
     * </pre>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1338
     * The query can be used as follows:
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1339
     * <pre>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1340
     *  TemporalAccessor parsed = formatter.parse(str);
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1341
     *  LocalTime time = parsed.query(LocalTime::from);
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1342
     *  Period extraDays = parsed.query(DateTimeFormatter.parsedExcessDays());
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1343
     * </pre>
18591
8202ea23bca7 8019535: Fix doclint issues in java.time.format
darcy
parents: 17474
diff changeset
  1344
     * @return a query that provides access to the excess days that were parsed
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1345
     */
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1346
    public static final TemporalQuery<Period> parsedExcessDays() {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1347
        return PARSED_EXCESS_DAYS;
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1348
    }
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1349
    private static final TemporalQuery<Period> PARSED_EXCESS_DAYS = t -> {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1350
        if (t instanceof Parsed) {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1351
            return ((Parsed) t).excessDays;
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1352
        } else {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1353
            return Period.ZERO;
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1354
        }
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1355
    };
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1356
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1357
    /**
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1358
     * A query that provides access to whether a leap-second was parsed.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1359
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1360
     * This returns a singleton {@linkplain TemporalQuery query} that provides
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1361
     * access to additional information from the parse. The query always returns
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1362
     * a non-null boolean, true if parsing saw a leap-second, false if not.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1363
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1364
     * Instant parsing handles the special "leap second" time of '23:59:60'.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1365
     * Leap seconds occur at '23:59:60' in the UTC time-zone, but at other
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1366
     * local times in different time-zones. To avoid this potential ambiguity,
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1367
     * the handling of leap-seconds is limited to
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1368
     * {@link DateTimeFormatterBuilder#appendInstant()}, as that method
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1369
     * always parses the instant with the UTC zone offset.
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1370
     * <p>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1371
     * If the time '23:59:60' is received, then a simple conversion is applied,
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1372
     * replacing the second-of-minute of 60 with 59. This query can be used
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1373
     * on the parse result to determine if the leap-second adjustment was made.
30821
9bc6f2e9966b 8075678: java.time javadoc error in DateTimeFormatter::parsedLeapSecond
rriggs
parents: 28751
diff changeset
  1374
     * The query will return {@code true} if it did adjust to remove the
9bc6f2e9966b 8075678: java.time javadoc error in DateTimeFormatter::parsedLeapSecond
rriggs
parents: 28751
diff changeset
  1375
     * leap-second, and {@code false} if not. Note that applying a leap-second
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1376
     * smoothing mechanism, such as UTC-SLS, is the responsibility of the
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1377
     * application, as follows:
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1378
     * <pre>
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1379
     *  TemporalAccessor parsed = formatter.parse(str);
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1380
     *  Instant instant = parsed.query(Instant::from);
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1381
     *  if (parsed.query(DateTimeFormatter.parsedLeapSecond())) {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1382
     *    // validate leap-second is correct and apply correct smoothing
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1383
     *  }
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1384
     * </pre>
18591
8202ea23bca7 8019535: Fix doclint issues in java.time.format
darcy
parents: 17474
diff changeset
  1385
     * @return a query that provides access to whether a leap-second was parsed
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1386
     */
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1387
    public static final TemporalQuery<Boolean> parsedLeapSecond() {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1388
        return PARSED_LEAP_SECOND;
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1389
    }
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1390
    private static final TemporalQuery<Boolean> PARSED_LEAP_SECOND = t -> {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1391
        if (t instanceof Parsed) {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1392
            return ((Parsed) t).leapSecond;
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1393
        } else {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1394
            return Boolean.FALSE;
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1395
        }
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1396
    };
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1397
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1398
    //-----------------------------------------------------------------------
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1399
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1400
     * Constructor.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1401
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1402
     * @param printerParser  the printer/parser to use, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1403
     * @param locale  the locale to use, not null
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1404
     * @param decimalStyle  the DecimalStyle to use, not null
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1405
     * @param resolverStyle  the resolver style to use, not null
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1406
     * @param resolverFields  the fields to use during resolving, null for all fields
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1407
     * @param chrono  the chronology to use, null for no override
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1408
     * @param zone  the zone to use, null for no override
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1409
     */
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1410
    DateTimeFormatter(CompositePrinterParser printerParser,
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1411
            Locale locale, DecimalStyle decimalStyle,
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1412
            ResolverStyle resolverStyle, Set<TemporalField> resolverFields,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1413
            Chronology chrono, ZoneId zone) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1414
        this.printerParser = Objects.requireNonNull(printerParser, "printerParser");
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1415
        this.resolverFields = resolverFields;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1416
        this.locale = Objects.requireNonNull(locale, "locale");
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1417
        this.decimalStyle = Objects.requireNonNull(decimalStyle, "decimalStyle");
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1418
        this.resolverStyle = Objects.requireNonNull(resolverStyle, "resolverStyle");
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1419
        this.chrono = chrono;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1420
        this.zone = zone;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1421
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1422
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1423
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1424
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1425
     * Gets the locale to be used during formatting.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1426
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1427
     * This is used to lookup any part of the formatter needing specific
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1428
     * localization, such as the text or localized pattern.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1429
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1430
     * @return the locale of this formatter, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1431
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1432
    public Locale getLocale() {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1433
        return locale;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1434
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1435
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1436
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1437
     * Returns a copy of this formatter with a new locale.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1438
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1439
     * This is used to lookup any part of the formatter needing specific
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1440
     * localization, such as the text or localized pattern.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1441
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1442
     * This instance is immutable and unaffected by this method call.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1443
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1444
     * @param locale  the new locale, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1445
     * @return a formatter based on this formatter with the requested locale, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1446
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1447
    public DateTimeFormatter withLocale(Locale locale) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1448
        if (this.locale.equals(locale)) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1449
            return this;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1450
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1451
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1452
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1453
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1454
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1455
    /**
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1456
     * Gets the DecimalStyle to be used during formatting.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1457
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1458
     * @return the locale of this formatter, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1459
     */
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1460
    public DecimalStyle getDecimalStyle() {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1461
        return decimalStyle;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1462
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1463
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1464
    /**
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1465
     * Returns a copy of this formatter with a new DecimalStyle.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1466
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1467
     * This instance is immutable and unaffected by this method call.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1468
     *
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1469
     * @param decimalStyle  the new DecimalStyle, not null
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1470
     * @return a formatter based on this formatter with the requested DecimalStyle, not null
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1471
     */
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1472
    public DateTimeFormatter withDecimalStyle(DecimalStyle decimalStyle) {
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1473
        if (this.decimalStyle.equals(decimalStyle)) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1474
            return this;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1475
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1476
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1477
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1478
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1479
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1480
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1481
     * Gets the overriding chronology to be used during formatting.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1482
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1483
     * This returns the override chronology, used to convert dates.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1484
     * By default, a formatter has no override chronology, returning null.
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1485
     * See {@link #withChronology(Chronology)} for more details on overriding.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1486
     *
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1487
     * @return the override chronology of this formatter, null if no override
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1488
     */
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1489
    public Chronology getChronology() {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1490
        return chrono;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1491
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1492
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1493
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1494
     * Returns a copy of this formatter with a new override chronology.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1495
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1496
     * This returns a formatter with similar state to this formatter but
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1497
     * with the override chronology set.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1498
     * By default, a formatter has no override chronology, returning null.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1499
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1500
     * If an override is added, then any date that is formatted or parsed will be affected.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1501
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1502
     * When formatting, if the temporal object contains a date, then it will
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1503
     * be converted to a date in the override chronology.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1504
     * Whether the temporal contains a date is determined by querying the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1505
     * {@link ChronoField#EPOCH_DAY EPOCH_DAY} field.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1506
     * Any time or zone will be retained unaltered unless overridden.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1507
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1508
     * If the temporal object does not contain a date, but does contain one
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1509
     * or more {@code ChronoField} date fields, then a {@code DateTimeException}
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1510
     * is thrown. In all other cases, the override chronology is added to the temporal,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1511
     * replacing any previous chronology, but without changing the date/time.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1512
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1513
     * When parsing, there are two distinct cases to consider.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1514
     * If a chronology has been parsed directly from the text, perhaps because
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1515
     * {@link DateTimeFormatterBuilder#appendChronologyId()} was used, then
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1516
     * this override chronology has no effect.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1517
     * If no zone has been parsed, then this override chronology will be used
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1518
     * to interpret the {@code ChronoField} values into a date according to the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1519
     * date resolving rules of the chronology.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1520
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1521
     * This instance is immutable and unaffected by this method call.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1522
     *
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1523
     * @param chrono  the new chronology, null if no override
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1524
     * @return a formatter based on this formatter with the requested override chronology, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1525
     */
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1526
    public DateTimeFormatter withChronology(Chronology chrono) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1527
        if (Objects.equals(this.chrono, chrono)) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1528
            return this;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1529
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1530
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1531
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1532
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1533
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1534
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1535
     * Gets the overriding zone to be used during formatting.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1536
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1537
     * This returns the override zone, used to convert instants.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1538
     * By default, a formatter has no override zone, returning null.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1539
     * See {@link #withZone(ZoneId)} for more details on overriding.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1540
     *
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1541
     * @return the override zone of this formatter, null if no override
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1542
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1543
    public ZoneId getZone() {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1544
        return zone;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1545
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1546
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1547
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1548
     * Returns a copy of this formatter with a new override zone.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1549
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1550
     * This returns a formatter with similar state to this formatter but
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1551
     * with the override zone set.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1552
     * By default, a formatter has no override zone, returning null.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1553
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1554
     * If an override is added, then any instant that is formatted or parsed will be affected.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1555
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1556
     * When formatting, if the temporal object contains an instant, then it will
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1557
     * be converted to a zoned date-time using the override zone.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1558
     * Whether the temporal is an instant is determined by querying the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1559
     * {@link ChronoField#INSTANT_SECONDS INSTANT_SECONDS} field.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1560
     * If the input has a chronology then it will be retained unless overridden.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1561
     * If the input does not have a chronology, such as {@code Instant}, then
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1562
     * the ISO chronology will be used.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1563
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1564
     * If the temporal object does not contain an instant, but does contain
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1565
     * an offset then an additional check is made. If the normalized override
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1566
     * zone is an offset that differs from the offset of the temporal, then
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1567
     * a {@code DateTimeException} is thrown. In all other cases, the override
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1568
     * zone is added to the temporal, replacing any previous zone, but without
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1569
     * changing the date/time.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1570
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1571
     * When parsing, there are two distinct cases to consider.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1572
     * If a zone has been parsed directly from the text, perhaps because
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1573
     * {@link DateTimeFormatterBuilder#appendZoneId()} was used, then
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1574
     * this override zone has no effect.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1575
     * If no zone has been parsed, then this override zone will be included in
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1576
     * the result of the parse where it can be used to build instants and date-times.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1577
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1578
     * This instance is immutable and unaffected by this method call.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1579
     *
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1580
     * @param zone  the new override zone, null if no override
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1581
     * @return a formatter based on this formatter with the requested override zone, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1582
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1583
    public DateTimeFormatter withZone(ZoneId zone) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1584
        if (Objects.equals(this.zone, zone)) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1585
            return this;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1586
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1587
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone);
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1588
    }
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1589
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1590
    //-----------------------------------------------------------------------
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1591
    /**
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1592
     * Gets the resolver style to use during parsing.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1593
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1594
     * This returns the resolver style, used during the second phase of parsing
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1595
     * when fields are resolved into dates and times.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1596
     * By default, a formatter has the {@link ResolverStyle#SMART SMART} resolver style.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1597
     * See {@link #withResolverStyle(ResolverStyle)} for more details.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1598
     *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1599
     * @return the resolver style of this formatter, not null
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1600
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1601
    public ResolverStyle getResolverStyle() {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1602
        return resolverStyle;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1603
    }
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1604
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1605
    /**
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1606
     * Returns a copy of this formatter with a new resolver style.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1607
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1608
     * This returns a formatter with similar state to this formatter but
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1609
     * with the resolver style set. By default, a formatter has the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1610
     * {@link ResolverStyle#SMART SMART} resolver style.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1611
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1612
     * Changing the resolver style only has an effect during parsing.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1613
     * Parsing a text string occurs in two phases.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1614
     * Phase 1 is a basic text parse according to the fields added to the builder.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1615
     * Phase 2 resolves the parsed field-value pairs into date and/or time objects.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1616
     * The resolver style is used to control how phase 2, resolving, happens.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1617
     * See {@code ResolverStyle} for more information on the options available.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1618
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1619
     * This instance is immutable and unaffected by this method call.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1620
     *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1621
     * @param resolverStyle  the new resolver style, not null
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1622
     * @return a formatter based on this formatter with the requested resolver style, not null
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1623
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1624
    public DateTimeFormatter withResolverStyle(ResolverStyle resolverStyle) {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1625
        Objects.requireNonNull(resolverStyle, "resolverStyle");
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1626
        if (Objects.equals(this.resolverStyle, resolverStyle)) {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1627
            return this;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1628
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1629
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone);
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1630
    }
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1631
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1632
    //-----------------------------------------------------------------------
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1633
    /**
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1634
     * Gets the resolver fields to use during parsing.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1635
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1636
     * This returns the resolver fields, used during the second phase of parsing
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1637
     * when fields are resolved into dates and times.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1638
     * By default, a formatter has no resolver fields, and thus returns null.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1639
     * See {@link #withResolverFields(Set)} for more details.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1640
     *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1641
     * @return the immutable set of resolver fields of this formatter, null if no fields
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1642
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1643
    public Set<TemporalField> getResolverFields() {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1644
        return resolverFields;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1645
    }
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1646
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1647
    /**
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1648
     * Returns a copy of this formatter with a new set of resolver fields.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1649
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1650
     * This returns a formatter with similar state to this formatter but with
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1651
     * the resolver fields set. By default, a formatter has no resolver fields.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1652
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1653
     * Changing the resolver fields only has an effect during parsing.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1654
     * Parsing a text string occurs in two phases.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1655
     * Phase 1 is a basic text parse according to the fields added to the builder.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1656
     * Phase 2 resolves the parsed field-value pairs into date and/or time objects.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1657
     * The resolver fields are used to filter the field-value pairs between phase 1 and 2.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1658
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1659
     * This can be used to select between two or more ways that a date or time might
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1660
     * be resolved. For example, if the formatter consists of year, month, day-of-month
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1661
     * and day-of-year, then there are two ways to resolve a date.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1662
     * Calling this method with the arguments {@link ChronoField#YEAR YEAR} and
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1663
     * {@link ChronoField#DAY_OF_YEAR DAY_OF_YEAR} will ensure that the date is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1664
     * resolved using the year and day-of-year, effectively meaning that the month
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1665
     * and day-of-month are ignored during the resolving phase.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1666
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1667
     * In a similar manner, this method can be used to ignore secondary fields that
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1668
     * would otherwise be cross-checked. For example, if the formatter consists of year,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1669
     * month, day-of-month and day-of-week, then there is only one way to resolve a
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1670
     * date, but the parsed value for day-of-week will be cross-checked against the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1671
     * resolved date. Calling this method with the arguments {@link ChronoField#YEAR YEAR},
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1672
     * {@link ChronoField#MONTH_OF_YEAR MONTH_OF_YEAR} and
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1673
     * {@link ChronoField#DAY_OF_MONTH DAY_OF_MONTH} will ensure that the date is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1674
     * resolved correctly, but without any cross-check for the day-of-week.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1675
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1676
     * In implementation terms, this method behaves as follows. The result of the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1677
     * parsing phase can be considered to be a map of field to value. The behavior
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1678
     * of this method is to cause that map to be filtered between phase 1 and 2,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1679
     * removing all fields other than those specified as arguments to this method.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1680
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1681
     * This instance is immutable and unaffected by this method call.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1682
     *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1683
     * @param resolverFields  the new set of resolver fields, null if no fields
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1684
     * @return a formatter based on this formatter with the requested resolver style, not null
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1685
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1686
    public DateTimeFormatter withResolverFields(TemporalField... resolverFields) {
23722
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1687
        Set<TemporalField> fields = null;
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1688
        if (resolverFields != null) {
41482
05e75e5f3afb 8134373: use collections convenience factories in the JDK
smarks
parents: 37907
diff changeset
  1689
            // Set.of cannot be used because it is hostile to nulls and duplicate elements
23722
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1690
            fields = Collections.unmodifiableSet(new HashSet<>(Arrays.asList(resolverFields)));
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1691
        }
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1692
        if (Objects.equals(this.resolverFields, fields)) {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1693
            return this;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1694
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1695
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, fields, chrono, zone);
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1696
    }
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1697
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1698
    /**
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1699
     * Returns a copy of this formatter with a new set of resolver fields.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1700
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1701
     * This returns a formatter with similar state to this formatter but with
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1702
     * the resolver fields set. By default, a formatter has no resolver fields.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1703
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1704
     * Changing the resolver fields only has an effect during parsing.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1705
     * Parsing a text string occurs in two phases.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1706
     * Phase 1 is a basic text parse according to the fields added to the builder.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1707
     * Phase 2 resolves the parsed field-value pairs into date and/or time objects.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1708
     * The resolver fields are used to filter the field-value pairs between phase 1 and 2.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1709
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1710
     * This can be used to select between two or more ways that a date or time might
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1711
     * be resolved. For example, if the formatter consists of year, month, day-of-month
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1712
     * and day-of-year, then there are two ways to resolve a date.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1713
     * Calling this method with the arguments {@link ChronoField#YEAR YEAR} and
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1714
     * {@link ChronoField#DAY_OF_YEAR DAY_OF_YEAR} will ensure that the date is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1715
     * resolved using the year and day-of-year, effectively meaning that the month
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1716
     * and day-of-month are ignored during the resolving phase.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1717
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1718
     * In a similar manner, this method can be used to ignore secondary fields that
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1719
     * would otherwise be cross-checked. For example, if the formatter consists of year,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1720
     * month, day-of-month and day-of-week, then there is only one way to resolve a
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1721
     * date, but the parsed value for day-of-week will be cross-checked against the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1722
     * resolved date. Calling this method with the arguments {@link ChronoField#YEAR YEAR},
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1723
     * {@link ChronoField#MONTH_OF_YEAR MONTH_OF_YEAR} and
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1724
     * {@link ChronoField#DAY_OF_MONTH DAY_OF_MONTH} will ensure that the date is
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1725
     * resolved correctly, but without any cross-check for the day-of-week.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1726
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1727
     * In implementation terms, this method behaves as follows. The result of the
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1728
     * parsing phase can be considered to be a map of field to value. The behavior
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1729
     * of this method is to cause that map to be filtered between phase 1 and 2,
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1730
     * removing all fields other than those specified as arguments to this method.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1731
     * <p>
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1732
     * This instance is immutable and unaffected by this method call.
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1733
     *
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1734
     * @param resolverFields  the new set of resolver fields, null if no fields
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1735
     * @return a formatter based on this formatter with the requested resolver style, not null
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1736
     */
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1737
    public DateTimeFormatter withResolverFields(Set<TemporalField> resolverFields) {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1738
        if (Objects.equals(this.resolverFields, resolverFields)) {
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1739
            return this;
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1740
        }
23722
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1741
        if (resolverFields != null) {
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1742
            resolverFields = Collections.unmodifiableSet(new HashSet<>(resolverFields));
877a047171bb 8036818: DateTimeFormatter withResolverFields() fails to accept null
scolebourne
parents: 23573
diff changeset
  1743
        }
17474
8c100beabcc0 8013730: JSR 310 DateTime API Updates III
sherman
parents: 16852
diff changeset
  1744
        return new DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1745
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1746
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1747
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1748
    /**
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1749
     * Formats a date-time object using this formatter.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1750
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1751
     * This formats the date-time to a String using the rules of the formatter.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1752
     *
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1753
     * @param temporal  the temporal object to format, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1754
     * @return the formatted string, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1755
     * @throws DateTimeException if an error occurs during formatting
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1756
     */
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1757
    public String format(TemporalAccessor temporal) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1758
        StringBuilder buf = new StringBuilder(32);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1759
        formatTo(temporal, buf);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1760
        return buf.toString();
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1761
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1762
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1763
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1764
    /**
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1765
     * Formats a date-time object to an {@code Appendable} using this formatter.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1766
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1767
     * This outputs the formatted date-time to the specified destination.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1768
     * {@link Appendable} is a general purpose interface that is implemented by all
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1769
     * key character output classes including {@code StringBuffer}, {@code StringBuilder},
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1770
     * {@code PrintStream} and {@code Writer}.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1771
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1772
     * Although {@code Appendable} methods throw an {@code IOException}, this method does not.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1773
     * Instead, any {@code IOException} is wrapped in a runtime exception.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1774
     *
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1775
     * @param temporal  the temporal object to format, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1776
     * @param appendable  the appendable to format to, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1777
     * @throws DateTimeException if an error occurs during formatting
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1778
     */
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1779
    public void formatTo(TemporalAccessor temporal, Appendable appendable) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1780
        Objects.requireNonNull(temporal, "temporal");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1781
        Objects.requireNonNull(appendable, "appendable");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1782
        try {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1783
            DateTimePrintContext context = new DateTimePrintContext(temporal, this);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1784
            if (appendable instanceof StringBuilder) {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1785
                printerParser.format(context, (StringBuilder) appendable);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1786
            } else {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1787
                // buffer output to avoid writing to appendable in case of error
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1788
                StringBuilder buf = new StringBuilder(32);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1789
                printerParser.format(context, buf);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1790
                appendable.append(buf);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1791
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1792
        } catch (IOException ex) {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1793
            throw new DateTimeException(ex.getMessage(), ex);
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1794
        }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1795
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1796
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1797
    //-----------------------------------------------------------------------
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1798
    /**
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1799
     * Fully parses the text producing a temporal object.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1800
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1801
     * This parses the entire text producing a temporal object.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1802
     * It is typically more useful to use {@link #parse(CharSequence, TemporalQuery)}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1803
     * The result of this method is {@code TemporalAccessor} which has been resolved,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1804
     * applying basic validation checks to help ensure a valid date-time.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1805
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1806
     * If the parse completes without reading the entire length of the text,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1807
     * or a problem occurs during parsing or merging, then an exception is thrown.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1808
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1809
     * @param text  the text to parse, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1810
     * @return the parsed temporal object, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1811
     * @throws DateTimeParseException if unable to parse the requested result
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1812
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1813
    public TemporalAccessor parse(CharSequence text) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1814
        Objects.requireNonNull(text, "text");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1815
        try {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1816
            return parseResolved0(text, null);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1817
        } catch (DateTimeParseException ex) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1818
            throw ex;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1819
        } catch (RuntimeException ex) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1820
            throw createError(text, ex);
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1821
        }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1822
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1823
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1824
    /**
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1825
     * Parses the text using this formatter, providing control over the text position.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1826
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1827
     * This parses the text without requiring the parse to start from the beginning
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1828
     * of the string or finish at the end.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1829
     * The result of this method is {@code TemporalAccessor} which has been resolved,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1830
     * applying basic validation checks to help ensure a valid date-time.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1831
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1832
     * The text will be parsed from the specified start {@code ParsePosition}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1833
     * The entire length of the text does not have to be parsed, the {@code ParsePosition}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1834
     * will be updated with the index at the end of parsing.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1835
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1836
     * The operation of this method is slightly different to similar methods using
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1837
     * {@code ParsePosition} on {@code java.text.Format}. That class will return
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1838
     * errors using the error index on the {@code ParsePosition}. By contrast, this
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1839
     * method will throw a {@link DateTimeParseException} if an error occurs, with
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1840
     * the exception containing the error index.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1841
     * This change in behavior is necessary due to the increased complexity of
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1842
     * parsing and resolving dates/times in this API.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1843
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1844
     * If the formatter parses the same field more than once with different values,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1845
     * the result will be an error.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1846
     *
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1847
     * @param text  the text to parse, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1848
     * @param position  the position to parse from, updated with length parsed
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1849
     *  and the index of any error, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1850
     * @return the parsed temporal object, not null
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1851
     * @throws DateTimeParseException if unable to parse the requested result
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1852
     * @throws IndexOutOfBoundsException if the position is invalid
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1853
     */
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1854
    public TemporalAccessor parse(CharSequence text, ParsePosition position) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1855
        Objects.requireNonNull(text, "text");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1856
        Objects.requireNonNull(position, "position");
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1857
        try {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1858
            return parseResolved0(text, position);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1859
        } catch (DateTimeParseException | IndexOutOfBoundsException ex) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1860
            throw ex;
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1861
        } catch (RuntimeException ex) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1862
            throw createError(text, ex);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1863
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1864
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1865
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1866
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1867
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1868
     * Fully parses the text producing an object of the specified type.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1869
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1870
     * Most applications should use this method for parsing.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1871
     * It parses the entire text to produce the required date-time.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1872
     * The query is typically a method reference to a {@code from(TemporalAccessor)} method.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1873
     * For example:
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1874
     * <pre>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1875
     *  LocalDateTime dt = parser.parse(str, LocalDateTime::from);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1876
     * </pre>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1877
     * If the parse completes without reading the entire length of the text,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1878
     * or a problem occurs during parsing or merging, then an exception is thrown.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1879
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1880
     * @param <T> the type of the parsed date-time
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1881
     * @param text  the text to parse, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1882
     * @param query  the query defining the type to parse to, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1883
     * @return the parsed date-time, not null
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1884
     * @throws DateTimeParseException if unable to parse the requested result
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1885
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1886
    public <T> T parse(CharSequence text, TemporalQuery<T> query) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1887
        Objects.requireNonNull(text, "text");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1888
        Objects.requireNonNull(query, "query");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1889
        try {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1890
            return parseResolved0(text, null).query(query);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1891
        } catch (DateTimeParseException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1892
            throw ex;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1893
        } catch (RuntimeException ex) {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1894
            throw createError(text, ex);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1895
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1896
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1897
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1898
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1899
     * Fully parses the text producing an object of one of the specified types.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1900
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1901
     * This parse method is convenient for use when the parser can handle optional elements.
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1902
     * For example, a pattern of 'uuuu-MM-dd HH.mm[ VV]' can be fully parsed to a {@code ZonedDateTime},
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1903
     * or partially parsed to a {@code LocalDateTime}.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1904
     * The queries must be specified in order, starting from the best matching full-parse option
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1905
     * and ending with the worst matching minimal parse option.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1906
     * The query is typically a method reference to a {@code from(TemporalAccessor)} method.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1907
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1908
     * The result is associated with the first type that successfully parses.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1909
     * Normally, applications will use {@code instanceof} to check the result.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1910
     * For example:
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1911
     * <pre>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1912
     *  TemporalAccessor dt = parser.parseBest(str, ZonedDateTime::from, LocalDateTime::from);
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1913
     *  if (dt instanceof ZonedDateTime) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1914
     *   ...
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1915
     *  } else {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1916
     *   ...
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1917
     *  }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1918
     * </pre>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1919
     * If the parse completes without reading the entire length of the text,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1920
     * or a problem occurs during parsing or merging, then an exception is thrown.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1921
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1922
     * @param text  the text to parse, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1923
     * @param queries  the queries defining the types to attempt to parse to,
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1924
     *  must implement {@code TemporalAccessor}, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1925
     * @return the parsed date-time, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1926
     * @throws IllegalArgumentException if less than 2 types are specified
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1927
     * @throws DateTimeParseException if unable to parse the requested result
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1928
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1929
    public TemporalAccessor parseBest(CharSequence text, TemporalQuery<?>... queries) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1930
        Objects.requireNonNull(text, "text");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1931
        Objects.requireNonNull(queries, "queries");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1932
        if (queries.length < 2) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1933
            throw new IllegalArgumentException("At least two queries must be specified");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1934
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1935
        try {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1936
            TemporalAccessor resolved = parseResolved0(text, null);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1937
            for (TemporalQuery<?> query : queries) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1938
                try {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1939
                    return (TemporalAccessor) resolved.query(query);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1940
                } catch (RuntimeException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1941
                    // continue
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1942
                }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1943
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1944
            throw new DateTimeException("Unable to convert parsed text using any of the specified queries");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1945
        } catch (DateTimeParseException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1946
            throw ex;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1947
        } catch (RuntimeException ex) {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1948
            throw createError(text, ex);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1949
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1950
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1951
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1952
    private DateTimeParseException createError(CharSequence text, RuntimeException ex) {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1953
        String abbr;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1954
        if (text.length() > 64) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1955
            abbr = text.subSequence(0, 64).toString() + "...";
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1956
        } else {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1957
            abbr = text.toString();
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1958
        }
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1959
        return new DateTimeParseException("Text '" + abbr + "' could not be parsed: " + ex.getMessage(), text, 0, ex);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1960
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1961
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1962
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1963
    /**
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1964
     * Parses and resolves the specified text.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1965
     * <p>
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1966
     * This parses to a {@code TemporalAccessor} ensuring that the text is fully parsed.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1967
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1968
     * @param text  the text to parse, not null
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1969
     * @param position  the position to parse from, updated with length parsed
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1970
     *  and the index of any error, null if parsing whole string
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1971
     * @return the resolved result of the parse, not null
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1972
     * @throws DateTimeParseException if the parse fails
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1973
     * @throws DateTimeException if an error occurs while resolving the date or time
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1974
     * @throws IndexOutOfBoundsException if the position is invalid
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1975
     */
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1976
    private TemporalAccessor parseResolved0(final CharSequence text, final ParsePosition position) {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1977
        ParsePosition pos = (position != null ? position : new ParsePosition(0));
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  1978
        DateTimeParseContext context = parseUnresolved0(text, pos);
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  1979
        if (context == null || pos.getErrorIndex() >= 0 || (position == null && pos.getIndex() < text.length())) {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  1980
            String abbr;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1981
            if (text.length() > 64) {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1982
                abbr = text.subSequence(0, 64).toString() + "...";
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1983
            } else {
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1984
                abbr = text.toString();
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1985
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1986
            if (pos.getErrorIndex() >= 0) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1987
                throw new DateTimeParseException("Text '" + abbr + "' could not be parsed at index " +
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1988
                        pos.getErrorIndex(), text, pos.getErrorIndex());
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1989
            } else {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1990
                throw new DateTimeParseException("Text '" + abbr + "' could not be parsed, unparsed text found at index " +
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1991
                        pos.getIndex(), text, pos.getIndex());
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1992
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1993
        }
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  1994
        return context.toResolved(resolverStyle, resolverFields);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1995
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1996
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  1997
    /**
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1998
     * Parses the text using this formatter, without resolving the result, intended
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  1999
     * for advanced use cases.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2000
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2001
     * Parsing is implemented as a two-phase operation.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2002
     * First, the text is parsed using the layout defined by the formatter, producing
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2003
     * a {@code Map} of field to value, a {@code ZoneId} and a {@code Chronology}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2004
     * Second, the parsed data is <em>resolved</em>, by validating, combining and
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2005
     * simplifying the various fields into more useful ones.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2006
     * This method performs the parsing stage but not the resolving stage.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2007
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2008
     * The result of this method is {@code TemporalAccessor} which represents the
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2009
     * data as seen in the input. Values are not validated, thus parsing a date string
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2010
     * of '2012-00-65' would result in a temporal with three fields - year of '2012',
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2011
     * month of '0' and day-of-month of '65'.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2012
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2013
     * The text will be parsed from the specified start {@code ParsePosition}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2014
     * The entire length of the text does not have to be parsed, the {@code ParsePosition}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2015
     * will be updated with the index at the end of parsing.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2016
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2017
     * Errors are returned using the error index field of the {@code ParsePosition}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2018
     * instead of {@code DateTimeParseException}.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2019
     * The returned error index will be set to an index indicative of the error.
24256
da9a41004459 8034906: Fix typos, errors and Javadoc differences in java.time
scolebourne
parents: 23722
diff changeset
  2020
     * Callers must check for errors before using the result.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2021
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2022
     * If the formatter parses the same field more than once with different values,
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2023
     * the result will be an error.
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2024
     * <p>
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2025
     * This method is intended for advanced use cases that need access to the
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2026
     * internal state during parsing. Typical application code should use
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2027
     * {@link #parse(CharSequence, TemporalQuery)} or the parse method on the target type.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2028
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2029
     * @param text  the text to parse, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2030
     * @param position  the position to parse from, updated with length parsed
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2031
     *  and the index of any error, not null
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2032
     * @return the parsed text, null if the parse results in an error
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2033
     * @throws DateTimeException if some problem occurs during parsing
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2034
     * @throws IndexOutOfBoundsException if the position is invalid
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2035
     */
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2036
    public TemporalAccessor parseUnresolved(CharSequence text, ParsePosition position) {
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2037
        DateTimeParseContext context = parseUnresolved0(text, position);
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2038
        if (context == null) {
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2039
            return null;
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2040
        }
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2041
        return context.toUnresolved();
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2042
    }
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2043
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2044
    private DateTimeParseContext parseUnresolved0(CharSequence text, ParsePosition position) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2045
        Objects.requireNonNull(text, "text");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2046
        Objects.requireNonNull(position, "position");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2047
        DateTimeParseContext context = new DateTimeParseContext(this);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2048
        int pos = position.getIndex();
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2049
        pos = printerParser.parse(context, text, pos);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2050
        if (pos < 0) {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2051
            position.setErrorIndex(~pos);  // index not updated from input
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2052
            return null;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2053
        }
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2054
        position.setIndex(pos);  // errorIndex not updated from input
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2055
        return context;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2056
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2057
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2058
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2059
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2060
     * Returns the formatter as a composite printer parser.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2061
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2062
     * @param optional  whether the printer/parser should be optional
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2063
     * @return the printer/parser, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2064
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2065
    CompositePrinterParser toPrinterParser(boolean optional) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2066
        return printerParser.withOptional(optional);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2067
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2068
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2069
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2070
     * Returns this formatter as a {@code java.text.Format} instance.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2071
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2072
     * The returned {@link Format} instance will format any {@link TemporalAccessor}
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2073
     * and parses to a resolved {@link TemporalAccessor}.
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2074
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2075
     * Exceptions will follow the definitions of {@code Format}, see those methods
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2076
     * for details about {@code IllegalArgumentException} during formatting and
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2077
     * {@code ParseException} or null during parsing.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2078
     * The format does not support attributing of the returned format string.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2079
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2080
     * @return this formatter as a classic format instance, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2081
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2082
    public Format toFormat() {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2083
        return new ClassicFormat(this, null);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2084
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2085
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2086
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2087
     * Returns this formatter as a {@code java.text.Format} instance that will
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2088
     * parse using the specified query.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2089
     * <p>
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2090
     * The returned {@link Format} instance will format any {@link TemporalAccessor}
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2091
     * and parses to the type specified.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2092
     * The type must be one that is supported by {@link #parse}.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2093
     * <p>
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2094
     * Exceptions will follow the definitions of {@code Format}, see those methods
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2095
     * for details about {@code IllegalArgumentException} during formatting and
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2096
     * {@code ParseException} or null during parsing.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2097
     * The format does not support attributing of the returned format string.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2098
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2099
     * @param parseQuery  the query defining the type to parse to, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2100
     * @return this formatter as a classic format instance, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2101
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2102
    public Format toFormat(TemporalQuery<?> parseQuery) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2103
        Objects.requireNonNull(parseQuery, "parseQuery");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2104
        return new ClassicFormat(this, parseQuery);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2105
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2106
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2107
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2108
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2109
     * Returns a description of the underlying formatters.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2110
     *
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2111
     * @return a description of this formatter, not null
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2112
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2113
    @Override
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2114
    public String toString() {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2115
        String pattern = printerParser.toString();
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2116
        pattern = pattern.startsWith("[") ? pattern : pattern.substring(1, pattern.length() - 1);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2117
        return pattern;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2118
        // TODO: Fix tests to not depend on toString()
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2119
//        return "DateTimeFormatter[" + locale +
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2120
//                (chrono != null ? "," + chrono : "") +
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2121
//                (zone != null ? "," + zone : "") +
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2122
//                pattern + "]";
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2123
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2124
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2125
    //-----------------------------------------------------------------------
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2126
    /**
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2127
     * Implements the classic Java Format API.
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2128
     * @serial exclude
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2129
     */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2130
    @SuppressWarnings("serial")  // not actually serializable
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2131
    static class ClassicFormat extends Format {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2132
        /** The formatter. */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2133
        private final DateTimeFormatter formatter;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2134
        /** The type to be parsed. */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2135
        private final TemporalQuery<?> parseType;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2136
        /** Constructor. */
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2137
        public ClassicFormat(DateTimeFormatter formatter, TemporalQuery<?> parseType) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2138
            this.formatter = formatter;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2139
            this.parseType = parseType;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2140
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2141
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2142
        @Override
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2143
        public StringBuffer format(Object obj, StringBuffer toAppendTo, FieldPosition pos) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2144
            Objects.requireNonNull(obj, "obj");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2145
            Objects.requireNonNull(toAppendTo, "toAppendTo");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2146
            Objects.requireNonNull(pos, "pos");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2147
            if (obj instanceof TemporalAccessor == false) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2148
                throw new IllegalArgumentException("Format target must implement TemporalAccessor");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2149
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2150
            pos.setBeginIndex(0);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2151
            pos.setEndIndex(0);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2152
            try {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2153
                formatter.formatTo((TemporalAccessor) obj, toAppendTo);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2154
            } catch (RuntimeException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2155
                throw new IllegalArgumentException(ex.getMessage(), ex);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2156
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2157
            return toAppendTo;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2158
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2159
        @Override
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2160
        public Object parseObject(String text) throws ParseException {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2161
            Objects.requireNonNull(text, "text");
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2162
            try {
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2163
                if (parseType == null) {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  2164
                    return formatter.parseResolved0(text, null);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2165
                }
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2166
                return formatter.parse(text, parseType);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2167
            } catch (DateTimeParseException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2168
                throw new ParseException(ex.getMessage(), ex.getErrorIndex());
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2169
            } catch (RuntimeException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2170
                throw (ParseException) new ParseException(ex.getMessage(), 0).initCause(ex);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2171
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2172
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2173
        @Override
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2174
        public Object parseObject(String text, ParsePosition pos) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2175
            Objects.requireNonNull(text, "text");
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2176
            DateTimeParseContext context;
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2177
            try {
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2178
                context = formatter.parseUnresolved0(text, pos);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2179
            } catch (IndexOutOfBoundsException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2180
                if (pos.getErrorIndex() < 0) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2181
                    pos.setErrorIndex(0);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2182
                }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2183
                return null;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2184
            }
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2185
            if (context == null) {
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2186
                if (pos.getErrorIndex() < 0) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2187
                    pos.setErrorIndex(0);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2188
                }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2189
                return null;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2190
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2191
            try {
23573
f42dcef4fb7f 8033662: DateTimeFormatter parsing ignores withZone()
sherman
parents: 22654
diff changeset
  2192
                TemporalAccessor resolved = context.toResolved(formatter.resolverStyle, formatter.resolverFields);
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2193
                if (parseType == null) {
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  2194
                    return resolved;
15658
55b829ca2334 8007392: JSR 310: DateTime API Updates
sherman
parents: 15289
diff changeset
  2195
                }
16852
60207b2b4b42 8011172: JSR 310 DateTime API Updates II
sherman
parents: 15658
diff changeset
  2196
                return resolved.query(parseType);
15289
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2197
            } catch (RuntimeException ex) {
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2198
                pos.setErrorIndex(0);
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2199
                return null;
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2200
            }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2201
        }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2202
    }
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2203
3ac550392e43 8003680: JSR 310 Date/Time API
sherman
parents:
diff changeset
  2204
}