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