diff --git a/src/java.base/share/classes/java/security/AccessControlContext.java b/src/java.base/share/classes/java/security/AccessControlContext.java index fac9b32d7b9..1ca97a08962 100644 --- a/src/java.base/share/classes/java/security/AccessControlContext.java +++ b/src/java.base/share/classes/java/security/AccessControlContext.java @@ -750,18 +750,9 @@ public final class AccessControlContext { if (obj == this) return true; - if (! (obj instanceof AccessControlContext)) - return false; - - AccessControlContext that = (AccessControlContext) obj; - - if (!equalContext(that)) - return false; - - if (!equalLimitedContext(that)) - return false; - - return true; + return obj instanceof AccessControlContext that + && equalContext(that) + && equalLimitedContext(that); } /* diff --git a/src/java.base/share/classes/java/security/BasicPermission.java b/src/java.base/share/classes/java/security/BasicPermission.java index 12218dfabe2..4651ea146d3 100644 --- a/src/java.base/share/classes/java/security/BasicPermission.java +++ b/src/java.base/share/classes/java/security/BasicPermission.java @@ -364,27 +364,25 @@ final class BasicPermissionCollection */ @Override public void add(Permission permission) { - if (! (permission instanceof BasicPermission)) + if (!(permission instanceof BasicPermission basicPermission)) throw new IllegalArgumentException("invalid permission: "+ permission); if (isReadOnly()) throw new SecurityException("attempt to add a Permission to a readonly PermissionCollection"); - BasicPermission bp = (BasicPermission) permission; - // make sure we only add new BasicPermissions of the same class // Also check null for compatibility with deserialized form from // previous versions. if (permClass == null) { // adding first permission - permClass = bp.getClass(); + permClass = basicPermission.getClass(); } else { - if (bp.getClass() != permClass) + if (basicPermission.getClass() != permClass) throw new IllegalArgumentException("invalid permission: " + permission); } - String canonName = bp.getCanonicalName(); + String canonName = basicPermission.getCanonicalName(); perms.put(canonName, permission); // No sync on all_allowed; staleness OK @@ -405,13 +403,11 @@ final class BasicPermissionCollection */ @Override public boolean implies(Permission permission) { - if (! (permission instanceof BasicPermission)) + if (!(permission instanceof BasicPermission basicPermission)) return false; - BasicPermission bp = (BasicPermission) permission; - // random subclasses of BasicPermission do not imply each other - if (bp.getClass() != permClass) + if (basicPermission.getClass() != permClass) return false; // short circuit if the "*" Permission was added @@ -422,7 +418,7 @@ final class BasicPermissionCollection // Check for full match first. Then work our way up the // path looking for matches on a.b..* - String path = bp.getCanonicalName(); + String path = basicPermission.getCanonicalName(); //System.out.println("check "+path); Permission x = perms.get(path); diff --git a/src/java.base/share/classes/java/security/CodeSigner.java b/src/java.base/share/classes/java/security/CodeSigner.java index bc7bc391fe0..99748210d79 100644 --- a/src/java.base/share/classes/java/security/CodeSigner.java +++ b/src/java.base/share/classes/java/security/CodeSigner.java @@ -126,10 +126,9 @@ public final class CodeSigner implements Serializable { * @return true if the objects are considered equal, false otherwise. */ public boolean equals(Object obj) { - if (obj == null || (!(obj instanceof CodeSigner))) { + if (obj == null || (!(obj instanceof CodeSigner that))) { return false; } - CodeSigner that = (CodeSigner)obj; if (this == that) { return true; diff --git a/src/java.base/share/classes/java/security/CodeSource.java b/src/java.base/share/classes/java/security/CodeSource.java index 16199394f1c..e0df104f367 100644 --- a/src/java.base/share/classes/java/security/CodeSource.java +++ b/src/java.base/share/classes/java/security/CodeSource.java @@ -34,6 +34,8 @@ import java.util.Hashtable; import java.io.ByteArrayInputStream; import java.io.IOException; import java.security.cert.*; +import java.util.Objects; + import sun.net.util.URLUtil; import sun.security.util.IOUtils; @@ -157,22 +159,9 @@ public class CodeSource implements java.io.Serializable { return true; // objects types must be equal - if (!(obj instanceof CodeSource)) - return false; - - CodeSource cs = (CodeSource) obj; - - // URLs must match - if (location == null) { - // if location is null, then cs.location must be null as well - if (cs.location != null) return false; - } else { - // if location is not null, then it must equal cs.location - if (!location.equals(cs.location)) return false; - } - - // certs must match - return matchCerts(cs, true); + return (obj instanceof CodeSource other) + && Objects.equals(location, other.location) + && matchCerts(other, true); } /** diff --git a/src/java.base/share/classes/java/security/Identity.java b/src/java.base/share/classes/java/security/Identity.java index 787d9b41626..0d2aa84db7a 100644 --- a/src/java.base/share/classes/java/security/Identity.java +++ b/src/java.base/share/classes/java/security/Identity.java @@ -334,20 +334,12 @@ public abstract class Identity implements Principal, Serializable { * @see #identityEquals */ public final boolean equals(Object identity) { - if (identity == this) { return true; } - if (identity instanceof Identity) { - Identity i = (Identity)identity; - if (this.fullName().equals(i.fullName())) { - return true; - } else { - return identityEquals(i); - } - } - return false; + return identity instanceof Identity other + && (this.fullName().equals(other.fullName()) || identityEquals(other)); } /** diff --git a/src/java.base/share/classes/java/security/KeyFactory.java b/src/java.base/share/classes/java/security/KeyFactory.java index b2f8bcdb0f7..48c542786b5 100644 --- a/src/java.base/share/classes/java/security/KeyFactory.java +++ b/src/java.base/share/classes/java/security/KeyFactory.java @@ -313,10 +313,9 @@ public class KeyFactory { Service s = serviceIterator.next(); try { Object obj = s.newInstance(null); - if (obj instanceof KeyFactorySpi == false) { + if (!(obj instanceof KeyFactorySpi spi)) { continue; } - KeyFactorySpi spi = (KeyFactorySpi)obj; provider = s.getProvider(); this.spi = spi; return spi; diff --git a/src/java.base/share/classes/java/security/KeyPairGenerator.java b/src/java.base/share/classes/java/security/KeyPairGenerator.java index 79f57c08a94..182e730b9d2 100644 --- a/src/java.base/share/classes/java/security/KeyPairGenerator.java +++ b/src/java.base/share/classes/java/security/KeyPairGenerator.java @@ -623,13 +623,12 @@ public abstract class KeyPairGenerator extends KeyPairGeneratorSpi { try { Object inst = s.newInstance(null); // ignore non-spis - if (inst instanceof KeyPairGeneratorSpi == false) { + if (!(inst instanceof KeyPairGeneratorSpi spi)) { continue; } if (inst instanceof KeyPairGenerator) { continue; } - KeyPairGeneratorSpi spi = (KeyPairGeneratorSpi)inst; if (reinit) { if (initType == I_SIZE) { spi.initialize(initKeySize, initRandom); diff --git a/src/java.base/share/classes/java/security/KeyStore.java b/src/java.base/share/classes/java/security/KeyStore.java index 63c90d7e3e9..a6ed591c887 100644 --- a/src/java.base/share/classes/java/security/KeyStore.java +++ b/src/java.base/share/classes/java/security/KeyStore.java @@ -1961,13 +1961,13 @@ public class KeyStore { if ((type == null) || (file == null) || (protection == null)) { throw new NullPointerException(); } - if ((protection instanceof PasswordProtection == false) && - (protection instanceof CallbackHandlerProtection == false)) { + if (!(protection instanceof PasswordProtection) && + !(protection instanceof CallbackHandlerProtection)) { throw new IllegalArgumentException ("Protection must be PasswordProtection or " + "CallbackHandlerProtection"); } - if (file.isFile() == false) { + if (!file.isFile()) { throw new IllegalArgumentException ("File does not exist or it does not refer " + "to a normal file: " + file); @@ -2056,7 +2056,7 @@ public class KeyStore { PrivilegedExceptionAction action = new PrivilegedExceptionAction() { public KeyStore run() throws Exception { - if (protection instanceof CallbackHandlerProtection == false) { + if (!(protection instanceof CallbackHandlerProtection)) { return run0(); } // when using a CallbackHandler, @@ -2190,7 +2190,7 @@ public class KeyStore { ks = KeyStore.getInstance(type, provider); } LoadStoreParameter param = new SimpleLoadStoreParameter(protection); - if (protection instanceof CallbackHandlerProtection == false) { + if (!(protection instanceof CallbackHandlerProtection)) { ks.load(param); } else { // when using a CallbackHandler, diff --git a/src/java.base/share/classes/java/security/MessageDigest.java b/src/java.base/share/classes/java/security/MessageDigest.java index be96b0f6953..5898ec30e1e 100644 --- a/src/java.base/share/classes/java/security/MessageDigest.java +++ b/src/java.base/share/classes/java/security/MessageDigest.java @@ -298,8 +298,7 @@ public abstract class MessageDigest extends MessageDigestSpi { if (provider == null) throw new IllegalArgumentException("missing provider"); Object[] objs = Security.getImpl(algorithm, "MessageDigest", provider); - if (objs[0] instanceof MessageDigest) { - MessageDigest md = (MessageDigest)objs[0]; + if (objs[0] instanceof MessageDigest md) { md.provider = (Provider)objs[1]; return md; } else { diff --git a/src/java.base/share/classes/java/security/Provider.java b/src/java.base/share/classes/java/security/Provider.java index 0eca1dc809f..1ed0eae62a8 100644 --- a/src/java.base/share/classes/java/security/Provider.java +++ b/src/java.base/share/classes/java/security/Provider.java @@ -1077,10 +1077,8 @@ public abstract class Provider extends Properties { if (this == obj) { return true; } - if (!(obj instanceof ServiceKey other)) { - return false; - } - return this.type.equals(other.type) + return obj instanceof ServiceKey other + && this.type.equals(other.type) && this.algorithm.equals(other.algorithm); } boolean matches(String type, String algorithm) { @@ -1500,11 +1498,8 @@ public abstract class Provider extends Properties { if (this == obj) { return true; } - if (obj instanceof UString == false) { - return false; - } - UString other = (UString)obj; - return lowerString.equals(other.lowerString); + return obj instanceof UString other + && lowerString.equals(other.lowerString); } public String toString() { @@ -2005,16 +2000,16 @@ public abstract class Provider extends Properties { // unknown engine type, return true by default return true; } - if (cap.supportsParameter == false) { + if (!cap.supportsParameter) { throw new InvalidParameterException("supportsParameter() not " + "used with " + type + " engines"); } // allow null for keys without attributes for compatibility - if ((parameter != null) && (parameter instanceof Key == false)) { + if ((parameter != null) && (!(parameter instanceof Key))) { throw new InvalidParameterException ("Parameter must be instanceof Key for engine " + type); } - if (hasKeyAttributes() == false) { + if (!hasKeyAttributes()) { return true; } if (parameter == null) { diff --git a/src/java.base/share/classes/java/security/SecureClassLoader.java b/src/java.base/share/classes/java/security/SecureClassLoader.java index 83f48d662a2..9ea5e3e503b 100644 --- a/src/java.base/share/classes/java/security/SecureClassLoader.java +++ b/src/java.base/share/classes/java/security/SecureClassLoader.java @@ -254,18 +254,10 @@ public class SecureClassLoader extends ClassLoader { return true; } - if (!(obj instanceof CodeSourceKey)) { - return false; - } - - CodeSourceKey csk = (CodeSourceKey) obj; - - if (!Objects.equals(cs.getLocationNoFragString(), - csk.cs.getLocationNoFragString())) { - return false; - } - - return cs.matchCerts(csk.cs, true); + return obj instanceof CodeSourceKey other + && Objects.equals(cs.getLocationNoFragString(), + other.cs.getLocationNoFragString()) + && cs.matchCerts(other.cs, true); } } diff --git a/src/java.base/share/classes/java/security/Signature.java b/src/java.base/share/classes/java/security/Signature.java index d493d8d40b7..02fc234bd58 100644 --- a/src/java.base/share/classes/java/security/Signature.java +++ b/src/java.base/share/classes/java/security/Signature.java @@ -333,7 +333,7 @@ public abstract class Signature extends SignatureSpi { // so it is a "real" Spi if it is an // instance of SignatureSpi but not Signature boolean r = (instance instanceof SignatureSpi) - && (instance instanceof Signature == false); + && (!(instance instanceof Signature)); if ((debug != null) && (r == false)) { debug.println("Not a SignatureSpi " + className); debug.println("Delayed provider selection may not be " @@ -541,16 +541,15 @@ public abstract class Signature extends SignatureSpi { // we should check whether it has a Key Usage // extension marked as critical. //if (cert instanceof java.security.cert.X509Certificate) { - if (cert instanceof X509Certificate) { + if (cert instanceof X509Certificate xcert) { // Check whether the cert has a key usage extension // marked as a critical extension. // The OID for KeyUsage extension is 2.5.29.15. - X509Certificate c = (X509Certificate)cert; - Set critSet = c.getCriticalExtensionOIDs(); + Set critSet = xcert.getCriticalExtensionOIDs(); if (critSet != null && !critSet.isEmpty() && critSet.contains(KnownOIDs.KeyUsage.value())) { - boolean[] keyUsageInfo = c.getKeyUsage(); + boolean[] keyUsageInfo = xcert.getKeyUsage(); // keyUsageInfo[0] is for digitalSignature. if ((keyUsageInfo != null) && (keyUsageInfo[0] == false)) throw new InvalidKeyException("Wrong key usage"); @@ -1178,7 +1177,7 @@ public abstract class Signature extends SignatureSpi { } } else { Object o = s.newInstance(null); - if (o instanceof SignatureSpi == false) { + if (!(o instanceof SignatureSpi)) { throw new NoSuchAlgorithmException ("Not a SignatureSpi: " + o.getClass().getName()); } diff --git a/src/java.base/share/classes/java/security/Timestamp.java b/src/java.base/share/classes/java/security/Timestamp.java index 771627494cf..e3994ca0565 100644 --- a/src/java.base/share/classes/java/security/Timestamp.java +++ b/src/java.base/share/classes/java/security/Timestamp.java @@ -123,16 +123,12 @@ public final class Timestamp implements Serializable { * @return true if the timestamp are considered equal, false otherwise. */ public boolean equals(Object obj) { - if (obj == null || (!(obj instanceof Timestamp))) { - return false; - } - Timestamp that = (Timestamp)obj; - - if (this == that) { + if (this == obj) { return true; } - return (timestamp.equals(that.getTimestamp()) && - signerCertPath.equals(that.getSignerCertPath())); + return obj instanceof Timestamp other + && (timestamp.equals(other.getTimestamp()) && + signerCertPath.equals(other.getSignerCertPath())); } /** diff --git a/src/java.base/share/classes/java/security/UnresolvedPermission.java b/src/java.base/share/classes/java/security/UnresolvedPermission.java index 72a70f19dcc..d05d81879e0 100644 --- a/src/java.base/share/classes/java/security/UnresolvedPermission.java +++ b/src/java.base/share/classes/java/security/UnresolvedPermission.java @@ -334,9 +334,8 @@ implements java.io.Serializable if (obj == this) return true; - if (! (obj instanceof UnresolvedPermission)) + if (!(obj instanceof UnresolvedPermission that)) return false; - UnresolvedPermission that = (UnresolvedPermission) obj; // check type if (!this.type.equals(that.type)) { diff --git a/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java b/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java index 220850b6251..61d2e7ce1ef 100644 --- a/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java +++ b/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java @@ -75,14 +75,13 @@ implements java.io.Serializable */ @Override public void add(Permission permission) { - if (! (permission instanceof UnresolvedPermission)) + if (!(permission instanceof UnresolvedPermission unresolvedPermission)) throw new IllegalArgumentException("invalid permission: "+ permission); - UnresolvedPermission up = (UnresolvedPermission) permission; // Add permission to map. NOTE: cannot use lambda for // remappingFunction parameter until JDK-8076596 is fixed. - perms.compute(up.getName(), + perms.compute(unresolvedPermission.getName(), new java.util.function.BiFunction<>() { @Override public List apply(String key, @@ -90,10 +89,10 @@ implements java.io.Serializable if (oldValue == null) { List v = new CopyOnWriteArrayList<>(); - v.add(up); + v.add(unresolvedPermission); return v; } else { - oldValue.add(up); + oldValue.add(unresolvedPermission); return oldValue; } } diff --git a/src/java.base/share/classes/java/security/cert/CertPath.java b/src/java.base/share/classes/java/security/cert/CertPath.java index 733df32594c..28000591c00 100644 --- a/src/java.base/share/classes/java/security/cert/CertPath.java +++ b/src/java.base/share/classes/java/security/cert/CertPath.java @@ -181,16 +181,9 @@ public abstract class CertPath implements Serializable { if (this == other) return true; - if (! (other instanceof CertPath)) - return false; - - CertPath otherCP = (CertPath) other; - if (! otherCP.getType().equals(type)) - return false; - - List thisCertList = this.getCertificates(); - List otherCertList = otherCP.getCertificates(); - return(thisCertList.equals(otherCertList)); + return other instanceof CertPath that + && that.getType().equals(this.type) + && this.getCertificates().equals(that.getCertificates()); } /** diff --git a/src/java.base/share/classes/java/security/cert/URICertStoreParameters.java b/src/java.base/share/classes/java/security/cert/URICertStoreParameters.java index d8b05485d2d..d4d5d686015 100644 --- a/src/java.base/share/classes/java/security/cert/URICertStoreParameters.java +++ b/src/java.base/share/classes/java/security/cert/URICertStoreParameters.java @@ -124,16 +124,11 @@ public final class URICertStoreParameters implements CertStoreParameters { */ @Override public boolean equals(Object p) { - if (p == null || (!(p instanceof URICertStoreParameters))) { - return false; - } - if (p == this) { return true; } - - URICertStoreParameters other = (URICertStoreParameters)p; - return uri.equals(other.getURI()); + return p instanceof URICertStoreParameters other + && uri.equals(other.getURI()); } /** diff --git a/src/java.base/share/classes/java/security/cert/X509CRLSelector.java b/src/java.base/share/classes/java/security/cert/X509CRLSelector.java index 43fce1adba0..f91cde5b411 100644 --- a/src/java.base/share/classes/java/security/cert/X509CRLSelector.java +++ b/src/java.base/share/classes/java/security/cert/X509CRLSelector.java @@ -597,10 +597,9 @@ public class X509CRLSelector implements CRLSelector { * {@code false} otherwise */ public boolean match(CRL crl) { - if (!(crl instanceof X509CRL)) { + if (!(crl instanceof X509CRL xcrl)) { return false; } - X509CRL xcrl = (X509CRL)crl; /* match on issuer name */ if (issuerNames != null) { diff --git a/src/java.base/share/classes/java/security/cert/X509CertSelector.java b/src/java.base/share/classes/java/security/cert/X509CertSelector.java index 6168404b8b0..356e53e21fa 100644 --- a/src/java.base/share/classes/java/security/cert/X509CertSelector.java +++ b/src/java.base/share/classes/java/security/cert/X509CertSelector.java @@ -834,10 +834,9 @@ public class X509CertSelector implements CertSelector { throw new IOException("name list size not 2"); } Object o = nameList.get(0); - if (!(o instanceof Integer)) { + if (!(o instanceof Integer nameType)) { throw new IOException("expected an Integer"); } - int nameType = ((Integer)o).intValue(); o = nameList.get(1); genNames.add(makeGeneralNameInterface(nameType, o)); } @@ -885,29 +884,29 @@ public class X509CertSelector implements CertSelector { + type + ")..."); } - if (name instanceof String) { + if (name instanceof String nameAsString) { if (debug != null) { debug.println("X509CertSelector.makeGeneralNameInterface() " - + "name is String: " + name); + + "name is String: " + nameAsString); } switch (type) { case NAME_RFC822: - result = new RFC822Name((String)name); + result = new RFC822Name(nameAsString); break; case NAME_DNS: - result = new DNSName((String)name); + result = new DNSName(nameAsString); break; case NAME_DIRECTORY: - result = new X500Name((String)name); + result = new X500Name(nameAsString); break; case NAME_URI: - result = new URIName((String)name); + result = new URIName(nameAsString); break; case NAME_IP: - result = new IPAddressName((String)name); + result = new IPAddressName(nameAsString); break; case NAME_OID: - result = new OIDName((String)name); + result = new OIDName(nameAsString); break; default: throw new IOException("unable to parse String names of type " @@ -1668,10 +1667,9 @@ public class X509CertSelector implements CertSelector { throw new IOException("name list size not 2"); } Object o = nameList.get(0); - if (!(o instanceof Integer)) { + if (!(o instanceof Integer nameType)) { throw new IOException("expected an Integer"); } - int nameType = ((Integer)o).intValue(); if ((nameType < 0) || (nameType > 8)) { throw new IOException("name type not 0-8"); } @@ -1929,8 +1927,7 @@ public class X509CertSelector implements CertSelector { */ private static Extension getExtensionObject(X509Certificate cert, KnownOIDs extId) throws IOException { - if (cert instanceof X509CertImpl) { - X509CertImpl impl = (X509CertImpl) cert; + if (cert instanceof X509CertImpl impl) { switch (extId) { case PrivateKeyUsage: return impl.getPrivateKeyUsageExtension(); @@ -1980,10 +1977,9 @@ public class X509CertSelector implements CertSelector { * selected, {@code false} otherwise */ public boolean match(Certificate cert) { - if (!(cert instanceof X509Certificate)) { + if (!(cert instanceof X509Certificate xcert)) { return false; } - X509Certificate xcert = (X509Certificate)cert; if (debug != null) { debug.println("X509CertSelector.match(SN: " diff --git a/src/java.base/share/classes/java/security/spec/ECFieldF2m.java b/src/java.base/share/classes/java/security/spec/ECFieldF2m.java index e3cbf7e9596..1e0c0d26904 100644 --- a/src/java.base/share/classes/java/security/spec/ECFieldF2m.java +++ b/src/java.base/share/classes/java/security/spec/ECFieldF2m.java @@ -217,13 +217,12 @@ public class ECFieldF2m implements ECField { */ public boolean equals(Object obj) { if (this == obj) return true; - if (obj instanceof ECFieldF2m) { + + return obj instanceof ECFieldF2m other // no need to compare rp here since ks and rp // should be equivalent - return ((m == ((ECFieldF2m)obj).m) && - (Arrays.equals(ks, ((ECFieldF2m) obj).ks))); - } - return false; + && (m == other.m) + && (Arrays.equals(ks, other.ks)); } /** diff --git a/src/java.base/share/classes/java/security/spec/ECFieldFp.java b/src/java.base/share/classes/java/security/spec/ECFieldFp.java index 6d3290a6bb0..572f4742a17 100644 --- a/src/java.base/share/classes/java/security/spec/ECFieldFp.java +++ b/src/java.base/share/classes/java/security/spec/ECFieldFp.java @@ -82,10 +82,9 @@ public class ECFieldFp implements ECField { */ public boolean equals(Object obj) { if (this == obj) return true; - if (obj instanceof ECFieldFp) { - return (p.equals(((ECFieldFp)obj).p)); - } - return false; + + return obj instanceof ECFieldFp other + && p.equals(other.p); } /** diff --git a/src/java.base/share/classes/java/security/spec/ECPoint.java b/src/java.base/share/classes/java/security/spec/ECPoint.java index 3a89236fc65..86a4264ad6c 100644 --- a/src/java.base/share/classes/java/security/spec/ECPoint.java +++ b/src/java.base/share/classes/java/security/spec/ECPoint.java @@ -96,11 +96,10 @@ public class ECPoint { public boolean equals(Object obj) { if (this == obj) return true; if (this == POINT_INFINITY) return false; - if (obj instanceof ECPoint) { - return ((x.equals(((ECPoint)obj).x)) && - (y.equals(((ECPoint)obj).y))); - } - return false; + + return obj instanceof ECPoint other + && ((x.equals(other.x)) + && (y.equals(other.y))); } /** diff --git a/src/java.base/share/classes/java/security/spec/EllipticCurve.java b/src/java.base/share/classes/java/security/spec/EllipticCurve.java index 8672db6025f..4a43977fd4c 100644 --- a/src/java.base/share/classes/java/security/spec/EllipticCurve.java +++ b/src/java.base/share/classes/java/security/spec/EllipticCurve.java @@ -169,15 +169,11 @@ public class EllipticCurve { */ public boolean equals(Object obj) { if (this == obj) return true; - if (obj instanceof EllipticCurve) { - EllipticCurve curve = (EllipticCurve) obj; - if ((field.equals(curve.field)) && - (a.equals(curve.a)) && - (b.equals(curve.b))) { - return true; - } - } - return false; + + return obj instanceof EllipticCurve other + && field.equals(other.field) + && a.equals(other.a) + && b.equals(other.b); } /**