DateFormat.java, [...]: New versions from classpath.
2003-06-21 Michael Koch <konqueror@gmx.de> * java/text/DateFormat.java, java/text/SimpleDateFormat.java, java/util/Locale.java: New versions from classpath. From-SVN: r68300
This commit is contained in:
parent
5ee8128f1b
commit
73c7dd50e8
4 changed files with 40 additions and 16 deletions
|
@ -1,3 +1,10 @@
|
|||
2003-06-21 Michael Koch <konqueror@gmx.de>
|
||||
|
||||
* java/text/DateFormat.java,
|
||||
java/text/SimpleDateFormat.java,
|
||||
java/util/Locale.java:
|
||||
New versions from classpath.
|
||||
|
||||
2003-06-21 Michael Koch <konqueror@gmx.de>
|
||||
|
||||
* javax/swing/SpinnerModel.java:
|
||||
|
|
|
@ -101,7 +101,7 @@ public abstract class DateFormat extends Format implements Cloneable
|
|||
* <ul>
|
||||
* <li>Is not <code>null</code>.
|
||||
* <li>Is an instance of <code>DateFormat</code>.
|
||||
* <li>Has the same calendar and numberFormat field values as this object.
|
||||
* <li>Has the same numberFormat field value as this object.
|
||||
* </ul>
|
||||
*
|
||||
* @param obj The object to test for equality against.
|
||||
|
@ -111,10 +111,12 @@ public abstract class DateFormat extends Format implements Cloneable
|
|||
*/
|
||||
public boolean equals (Object obj)
|
||||
{
|
||||
if (! (obj instanceof DateFormat))
|
||||
if (!(obj instanceof DateFormat))
|
||||
return false;
|
||||
|
||||
DateFormat d = (DateFormat) obj;
|
||||
return calendar.equals(d.calendar) && numberFormat.equals(d.numberFormat);
|
||||
|
||||
return numberFormat.equals(d.numberFormat);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -467,10 +469,10 @@ public abstract class DateFormat extends Format implements Cloneable
|
|||
*/
|
||||
public int hashCode ()
|
||||
{
|
||||
int hash = calendar.hashCode();
|
||||
if (numberFormat != null)
|
||||
hash ^= numberFormat.hashCode();
|
||||
return hash;
|
||||
return numberFormat.hashCode();
|
||||
else
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -384,10 +384,10 @@ public class SimpleDateFormat extends DateFormat
|
|||
|
||||
SimpleDateFormat sdf = (SimpleDateFormat)o;
|
||||
|
||||
if (!toPattern().equals(sdf.toPattern()))
|
||||
if (defaultCentury != sdf.defaultCentury)
|
||||
return false;
|
||||
|
||||
if (!get2DigitYearStart().equals(sdf.get2DigitYearStart()))
|
||||
if (!toPattern().equals(sdf.toPattern()))
|
||||
return false;
|
||||
|
||||
if (!getDateFormatSymbols().equals(sdf.getDateFormatSymbols()))
|
||||
|
@ -396,6 +396,17 @@ public class SimpleDateFormat extends DateFormat
|
|||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* This method returns a hash value for this object.
|
||||
*
|
||||
* @return A hash value for this object.
|
||||
*/
|
||||
public int hashCode()
|
||||
{
|
||||
return super.hashCode() ^ toPattern().hashCode() ^ defaultCentury ^
|
||||
getDateFormatSymbols().hashCode();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Formats the date input according to the format string in use,
|
||||
|
|
|
@ -231,9 +231,9 @@ public final class Locale implements Serializable, Cloneable
|
|||
// default locale.
|
||||
if (defaultLocale != null)
|
||||
{
|
||||
language = convertLanguage(language);
|
||||
country = country.toUpperCase();
|
||||
variant = variant.toUpperCase();
|
||||
language = convertLanguage(language).intern();
|
||||
country = country.toUpperCase().intern();
|
||||
variant = variant.toUpperCase().intern();
|
||||
}
|
||||
this.language = language;
|
||||
this.country = country;
|
||||
|
@ -436,7 +436,7 @@ public final class Locale implements Serializable, Cloneable
|
|||
*/
|
||||
public String getISO3Language()
|
||||
{
|
||||
if ("".equals(language))
|
||||
if (language == "")
|
||||
return "";
|
||||
int index
|
||||
= ("aa,ab,af,am,ar,as,ay,az,ba,be,bg,bh,bi,bn,bo,br,ca,co,cs,cy,da,"
|
||||
|
@ -472,7 +472,7 @@ public final class Locale implements Serializable, Cloneable
|
|||
*/
|
||||
public String getISO3Country()
|
||||
{
|
||||
if ("".equals(country))
|
||||
if (country == "")
|
||||
return "";
|
||||
int index
|
||||
= ("AD,AE,AF,AG,AI,AL,AM,AN,AO,AQ,AR,AS,AT,AU,AW,AZ,BA,BB,BD,BE,BF,"
|
||||
|
@ -729,9 +729,13 @@ public final class Locale implements Serializable, Cloneable
|
|||
return false;
|
||||
Locale l = (Locale) obj;
|
||||
|
||||
return (language.equals(l.language)
|
||||
&& country.equals(l.country)
|
||||
&& variant.equals(l.variant));
|
||||
// ??? We might also want to add:
|
||||
// hashCode() == l.hashCode()
|
||||
// But this is a synchronized method. Is the overhead worth it?
|
||||
// Measure this to make a decision.
|
||||
return (language == l.language
|
||||
&& country == l.country
|
||||
&& variant == l.variant);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Add table
Reference in a new issue