151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski/*
22c87ad3a45cecf9e344487cad1abfdebe79f2c7cNarayan Kamath * Copyright (C) 2014 The Android Open Source Project
351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * Copyright (c) 1996, 2010, Oracle and/or its affiliates. All rights reserved.
451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski *
651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * This code is free software; you can redistribute it and/or modify it
751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * under the terms of the GNU General Public License version 2 only, as
851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * published by the Free Software Foundation.  Oracle designates this
951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * particular file as subject to the "Classpath" exception as provided
1051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * by Oracle in the LICENSE file that accompanied this code.
1151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski *
1251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * This code is distributed in the hope that it will be useful, but WITHOUT
1351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * version 2 for more details (a copy is included in the LICENSE file that
1651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * accompanied this code).
1751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski *
1851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * You should have received a copy of the GNU General Public License version
1951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * 2 along with this work; if not, write to the Free Software Foundation,
2051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
2151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski *
2251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
2351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * or visit www.oracle.com if you need additional information or have any
2451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * questions.
2551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski */
2651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
2751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebskipackage java.sql;
2851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
2951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski/**
3051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * <P>A thin wrapper around a millisecond value that allows
3151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * JDBC to identify this as an SQL <code>DATE</code> value.  A
3251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * milliseconds value represents the number of milliseconds that
3351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * have passed since January 1, 1970 00:00:00.000 GMT.
3451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * <p>
3551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * To conform with the definition of SQL <code>DATE</code>, the
3651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * millisecond values wrapped by a <code>java.sql.Date</code> instance
3751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * must be 'normalized' by setting the
3851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * hours, minutes, seconds, and milliseconds to zero in the particular
3951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski * time zone with which the instance is associated.
4051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski */
4151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebskipublic class Date extends java.util.Date {
4251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
4351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    /**
4451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * Constructs a <code>Date</code> object initialized with the given
4551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * year, month, and day.
4651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * <P>
4751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * The result is undefined if a given argument is out of bounds.
4851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *
4951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @param year the year minus 1900; must be 0 to 8099. (Note that
5051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        8099 is 9999 minus 1900.)
5151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @param month 0 to 11
5251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @param day 1 to 31
5351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @deprecated instead use the constructor <code>Date(long date)</code>
5451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     */
55f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added
5651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public Date(int year, int month, int day) {
5751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        super(year, month, day);
5851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
5951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
6051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    /**
6151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * Constructs a <code>Date</code> object using the given milliseconds
6251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * time value.  If the given milliseconds value contains time
6351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * information, the driver will set the time components to the
6451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * time in the default time zone (the time zone of the Java virtual
6551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * machine running the application) that corresponds to zero GMT.
6651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *
6751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @param date milliseconds since January 1, 1970, 00:00:00 GMT not
6851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        to exceed the milliseconds representation for the year 8099.
6951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        A negative number indicates the number of milliseconds
7051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        before January 1, 1970, 00:00:00 GMT.
7151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     */
7251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public Date(long date) {
7351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        // If the millisecond date value contains time info, mask it out.
7451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        super(date);
7551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
7651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
7751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
7851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    /**
7951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * Sets an existing <code>Date</code> object
8051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * using the given milliseconds time value.
8151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * If the given milliseconds value contains time information,
8251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * the driver will set the time components to the
8351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * time in the default time zone (the time zone of the Java virtual
8451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * machine running the application) that corresponds to zero GMT.
8551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *
8651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @param date milliseconds since January 1, 1970, 00:00:00 GMT not
8751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        to exceed the milliseconds representation for the year 8099.
8851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        A negative number indicates the number of milliseconds
8951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        before January 1, 1970, 00:00:00 GMT.
9051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     */
9151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public void setTime(long date) {
9251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        // If the millisecond date value contains time info, mask it out.
9351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        super.setTime(date);
9451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
9551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
9651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    /**
9751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * Converts a string in JDBC date escape format to
9851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * a <code>Date</code> value.
9951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *
10051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @param s a <code>String</code> object representing a date in
10151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *        in the format "yyyy-[m]m-[d]d". The leading zero for <code>mm</code>
10251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * and <code>dd</code> may also be omitted.
10351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @return a <code>java.sql.Date</code> object representing the
10451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *         given date
10551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @throws IllegalArgumentException if the date given is not in the
10651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     *         JDBC date escape format (yyyy-[m]m-[d]d)
10751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     */
10851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public static Date valueOf(String s) {
10951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        final int YEAR_LENGTH = 4;
11051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        final int MONTH_LENGTH = 2;
11151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        final int DAY_LENGTH = 2;
11251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        final int MAX_MONTH = 12;
11351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        final int MAX_DAY = 31;
11451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        int firstDash;
11551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        int secondDash;
11651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        Date d = null;
11751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
11851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        if (s == null) {
11951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            throw new java.lang.IllegalArgumentException();
12051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        }
12151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
12251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        firstDash = s.indexOf('-');
12351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        secondDash = s.indexOf('-', firstDash + 1);
12451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
12551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        if ((firstDash > 0) && (secondDash > 0) && (secondDash < s.length() - 1)) {
12651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            String yyyy = s.substring(0, firstDash);
12751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            String mm = s.substring(firstDash + 1, secondDash);
12851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            String dd = s.substring(secondDash + 1);
12951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            if (yyyy.length() == YEAR_LENGTH &&
13051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                    (mm.length() >= 1 && mm.length() <= MONTH_LENGTH) &&
13151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                    (dd.length() >= 1 && dd.length() <= DAY_LENGTH)) {
13251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                int year = Integer.parseInt(yyyy);
13351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                int month = Integer.parseInt(mm);
13451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                int day = Integer.parseInt(dd);
13551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
13651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                if ((month >= 1 && month <= MAX_MONTH) && (day >= 1 && day <= MAX_DAY)) {
13751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                    d = new Date(year - 1900, month - 1, day);
13851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski                }
13951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            }
14051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        }
14151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        if (d == null) {
14251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski            throw new java.lang.IllegalArgumentException();
14351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        }
14451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
14551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        return d;
14651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
14751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
14851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
14951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
15051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    /**
15151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * Formats a date in the date escape format yyyy-mm-dd.
15251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * <P>
15351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     * @return a String in yyyy-mm-dd format
15451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski     */
15551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public String toString () {
15651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        int year = super.getYear() + 1900;
15751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        int month = super.getMonth() + 1;
15851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        int day = super.getDate();
15951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
16051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        char buf[] = "2000-00-00".toCharArray();
16151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[0] = Character.forDigit(year/1000,10);
16251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[1] = Character.forDigit((year/100)%10,10);
16351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[2] = Character.forDigit((year/10)%10,10);
16451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[3] = Character.forDigit(year%10,10);
16551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[5] = Character.forDigit(month/10,10);
16651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[6] = Character.forDigit(month%10,10);
16751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[8] = Character.forDigit(day/10,10);
16851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        buf[9] = Character.forDigit(day%10,10);
16951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
17051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        return new String(buf);
17151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
17251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
17351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    // Override all the time operations inherited from java.util.Date;
17451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
17551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
176f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    * @deprecated This method is deprecated and should not be used because SQL Date
17751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * values do not have a time component.
17851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    *
17951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @exception java.lang.IllegalArgumentException if this method is invoked
18051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @see #setHours
18151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
182f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added - changed javadoc to include deprecation note.
18351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public int getHours() {
18451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        throw new java.lang.IllegalArgumentException();
18551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
18651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
18751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
188f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    * @deprecated This method is deprecated and should not be used because SQL Date
18951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * values do not have a time component.
19051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    *
19151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @exception java.lang.IllegalArgumentException if this method is invoked
19251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @see #setMinutes
19351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
194f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added - changed javadoc to include deprecation note.
19551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public int getMinutes() {
19651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        throw new java.lang.IllegalArgumentException();
19751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
19851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
19951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
200f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    * @deprecated This method is deprecated and should not be used because SQL Date
20151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * values do not have a time component.
20251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    *
20351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @exception java.lang.IllegalArgumentException if this method is invoked
20451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @see #setSeconds
20551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
206f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added - changed javadoc to include deprecation note.
20751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public int getSeconds() {
20851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        throw new java.lang.IllegalArgumentException();
20951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
21051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
21151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
212f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    * @deprecated This method is deprecated and should not be used because SQL Date
21351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * values do not have a time component.
21451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    *
21551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @exception java.lang.IllegalArgumentException if this method is invoked
21651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @see #getHours
21751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
218f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added - changed javadoc to include deprecation note.
21951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public void setHours(int i) {
22051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        throw new java.lang.IllegalArgumentException();
22151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
22251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
22351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
224f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    * @deprecated This method is deprecated and should not be used because SQL Date
22551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * values do not have a time component.
22651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    *
22751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @exception java.lang.IllegalArgumentException if this method is invoked
22851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @see #getMinutes
22951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
230f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added - changed javadoc to include deprecation note.
23151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public void setMinutes(int i) {
23251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        throw new java.lang.IllegalArgumentException();
23351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
23451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
23551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
236f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    * @deprecated This method is deprecated and should not be used because SQL Date
23751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * values do not have a time component.
23851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    *
23951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @exception java.lang.IllegalArgumentException if this method is invoked
24051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * @see #getSeconds
24151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
242f28e88eb0d34e13bdded8f37021bbf0e110f9b1dNarayan Kamath    @Deprecated // Android added - changed javadoc to include deprecation note.
24351b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    public void setSeconds(int i) {
24451b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski        throw new java.lang.IllegalArgumentException();
24551b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    }
24651b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski
24751b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski   /**
24851b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * Private serial version unique ID to ensure serialization
24951b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    * compatibility.
25051b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    */
25151b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski    static final long serialVersionUID = 1511598038487230103L;
25251b1b6997fd3f980076b8081f7f1165ccc2a4008Piotr Jastrzebski}
253