From dd2c3d1c22bbe2280203c3cf700129cae48a48c7 Mon Sep 17 00:00:00 2001
From: Joe Darcy
Date: Thu, 23 Apr 2015 18:51:18 -0700
Subject: [PATCH 01/29] 8078468: Update security libraries to use diamond with
anonymous classes
Reviewed-by: weijun
---
.../com/sun/crypto/provider/JceKeyStore.java | 2 +-
.../sun/crypto/provider/PBEKeyFactory.java | 2 +-
.../com/sun/crypto/provider/SunJCE.java | 2 +-
.../com/sun/net/ssl/KeyManagerFactory.java | 2 +-
.../com/sun/net/ssl/TrustManagerFactory.java | 2 +-
.../java/security/AccessControlContext.java | 2 +-
.../java/security/AccessController.java | 2 +-
.../classes/java/security/AllPermission.java | 2 +-
.../java/security/BasicPermission.java | 4 +--
.../classes/java/security/CodeSource.java | 2 +-
.../share/classes/java/security/Identity.java | 4 +--
.../classes/java/security/IdentityScope.java | 2 +-
.../share/classes/java/security/KeyStore.java | 2 +-
.../classes/java/security/Permissions.java | 8 ++---
.../share/classes/java/security/Policy.java | 6 ++--
.../java/security/ProtectionDomain.java | 2 +-
.../share/classes/java/security/Provider.java | 20 ++++++------
.../classes/java/security/SecureRandom.java | 2 +-
.../share/classes/java/security/Security.java | 4 +--
.../classes/java/security/Signature.java | 2 +-
.../share/classes/java/security/Signer.java | 2 +-
.../java/security/UnresolvedPermission.java | 2 +-
.../UnresolvedPermissionCollection.java | 6 ++--
.../java/security/cert/CertPathBuilder.java | 2 +-
.../java/security/cert/CertPathValidator.java | 2 +-
.../classes/java/security/cert/CertStore.java | 2 +-
.../cert/CertificateRevokedException.java | 2 +-
.../java/security/cert/PKIXParameters.java | 31 +++++++++---------
.../security/cert/PKIXRevocationChecker.java | 4 +--
.../java/security/cert/X509CRLSelector.java | 16 +++++-----
.../java/security/cert/X509CertSelector.java | 28 ++++++++--------
.../classes/javax/crypto/JceSecurity.java | 4 +--
.../javax/crypto/JceSecurityManager.java | 2 +-
.../javax/net/ssl/KeyManagerFactory.java | 2 +-
.../javax/net/ssl/SSLSocketFactory.java | 2 +-
.../javax/net/ssl/TrustManagerFactory.java | 2 +-
.../classes/javax/security/auth/Subject.java | 32 +++++++++----------
.../security/auth/login/Configuration.java | 6 ++--
.../javax/security/cert/X509Certificate.java | 2 +-
.../classes/sun/security/pkcs/PKCS7.java | 4 +--
.../sun/security/pkcs/PKCS9Attributes.java | 3 +-
.../classes/sun/security/pkcs/SignerInfo.java | 2 +-
.../sun/security/provider/SeedGenerator.java | 6 ++--
.../classes/sun/security/ssl/SunJSSE.java | 2 +-
.../sun/security/util/DerInputStream.java | 2 +-
.../sun/security/util/ManifestDigester.java | 2 +-
.../security/util/ManifestEntryVerifier.java | 6 ++--
.../security/util/SignatureFileVerifier.java | 4 +--
.../share/classes/sun/security/x509/AVA.java | 2 +-
.../sun/security/x509/AlgorithmId.java | 6 ++--
.../security/x509/CertificatePolicySet.java | 2 +-
.../sun/security/x509/GeneralSubtrees.java | 4 +--
.../share/classes/sun/security/x509/RDN.java | 6 ++--
.../classes/sun/security/x509/X500Name.java | 4 +--
.../sun/security/provider/NativePRNG.java | 4 +--
55 files changed, 140 insertions(+), 142 deletions(-)
diff --git a/jdk/src/java.base/share/classes/com/sun/crypto/provider/JceKeyStore.java b/jdk/src/java.base/share/classes/com/sun/crypto/provider/JceKeyStore.java
index a364881d88a..0e3f1ed0566 100644
--- a/jdk/src/java.base/share/classes/com/sun/crypto/provider/JceKeyStore.java
+++ b/jdk/src/java.base/share/classes/com/sun/crypto/provider/JceKeyStore.java
@@ -711,7 +711,7 @@ public final class JceKeyStore extends KeyStoreSpi {
cf = CertificateFactory.getInstance("X509");
} else {
// version 2
- cfs = new Hashtable(3);
+ cfs = new Hashtable<>(3);
}
entries.clear();
diff --git a/jdk/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java b/jdk/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java
index 0c87971876f..3fd312f8737 100644
--- a/jdk/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java
+++ b/jdk/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java
@@ -56,7 +56,7 @@ abstract class PBEKeyFactory extends SecretKeyFactorySpi {
}
static {
- validTypes = new HashSet(17);
+ validTypes = new HashSet<>(17);
validTypes.add("PBEWithMD5AndDES".toUpperCase(Locale.ENGLISH));
validTypes.add("PBEWithSHA1AndDESede".toUpperCase(Locale.ENGLISH));
validTypes.add("PBEWithSHA1AndRC2_40".toUpperCase(Locale.ENGLISH));
diff --git a/jdk/src/java.base/share/classes/com/sun/crypto/provider/SunJCE.java b/jdk/src/java.base/share/classes/com/sun/crypto/provider/SunJCE.java
index 439acb94f47..3d588bf8a2e 100644
--- a/jdk/src/java.base/share/classes/com/sun/crypto/provider/SunJCE.java
+++ b/jdk/src/java.base/share/classes/com/sun/crypto/provider/SunJCE.java
@@ -115,7 +115,7 @@ public final class SunJCE extends Provider {
final String BLOCK_PADS = "NOPADDING|PKCS5PADDING|ISO10126PADDING";
AccessController.doPrivileged(
- new java.security.PrivilegedAction() {
+ new java.security.PrivilegedAction<>() {
public Object run() {
/*
diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java
index 30e941a89d5..6ddf6bf6917 100644
--- a/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java
+++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/KeyManagerFactory.java
@@ -63,7 +63,7 @@ public class KeyManagerFactory {
*/
public final static String getDefaultAlgorithm() {
String type;
- type = AccessController.doPrivileged(new PrivilegedAction() {
+ type = AccessController.doPrivileged(new PrivilegedAction<>() {
public String run() {
return Security.getProperty("sun.ssl.keymanager.type");
}
diff --git a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java
index b9ef566a0e7..8b0701c0a29 100644
--- a/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java
+++ b/jdk/src/java.base/share/classes/com/sun/net/ssl/TrustManagerFactory.java
@@ -63,7 +63,7 @@ public class TrustManagerFactory {
*/
public final static String getDefaultAlgorithm() {
String type;
- type = AccessController.doPrivileged(new PrivilegedAction() {
+ type = AccessController.doPrivileged(new PrivilegedAction<>() {
public String run() {
return Security.getProperty("sun.ssl.trustmanager.type");
}
diff --git a/jdk/src/java.base/share/classes/java/security/AccessControlContext.java b/jdk/src/java.base/share/classes/java/security/AccessControlContext.java
index feed0cf11e1..5e588602c97 100644
--- a/jdk/src/java.base/share/classes/java/security/AccessControlContext.java
+++ b/jdk/src/java.base/share/classes/java/security/AccessControlContext.java
@@ -458,7 +458,7 @@ public final class AccessControlContext {
Thread.dumpStack();
final ProtectionDomain pd = context[i];
final Debug db = debug;
- AccessController.doPrivileged (new PrivilegedAction() {
+ AccessController.doPrivileged (new PrivilegedAction<>() {
public Void run() {
db.println("domain that failed "+pd);
return null;
diff --git a/jdk/src/java.base/share/classes/java/security/AccessController.java b/jdk/src/java.base/share/classes/java/security/AccessController.java
index e2b8e584560..90503d29cf8 100644
--- a/jdk/src/java.base/share/classes/java/security/AccessController.java
+++ b/jdk/src/java.base/share/classes/java/security/AccessController.java
@@ -612,7 +612,7 @@ public final class AccessController {
private static ProtectionDomain getCallerPD(final Class > caller) {
ProtectionDomain callerPd = doPrivileged
- (new PrivilegedAction() {
+ (new PrivilegedAction<>() {
public ProtectionDomain run() {
return caller.getProtectionDomain();
}
diff --git a/jdk/src/java.base/share/classes/java/security/AllPermission.java b/jdk/src/java.base/share/classes/java/security/AllPermission.java
index b830b884c59..fcda7ce0bc1 100644
--- a/jdk/src/java.base/share/classes/java/security/AllPermission.java
+++ b/jdk/src/java.base/share/classes/java/security/AllPermission.java
@@ -212,7 +212,7 @@ final class AllPermissionCollection
* @return an enumeration of all the AllPermission objects.
*/
public Enumeration elements() {
- return new Enumeration() {
+ return new Enumeration<>() {
private boolean hasMore = all_allowed;
public boolean hasMoreElements() {
diff --git a/jdk/src/java.base/share/classes/java/security/BasicPermission.java b/jdk/src/java.base/share/classes/java/security/BasicPermission.java
index 7e0f4fb85b4..92dbe345b26 100644
--- a/jdk/src/java.base/share/classes/java/security/BasicPermission.java
+++ b/jdk/src/java.base/share/classes/java/security/BasicPermission.java
@@ -332,7 +332,7 @@ final class BasicPermissionCollection
*/
public BasicPermissionCollection(Class> clazz) {
- perms = new HashMap(11);
+ perms = new HashMap<>(11);
all_allowed = false;
permClass = clazz;
}
@@ -533,7 +533,7 @@ final class BasicPermissionCollection
@SuppressWarnings("unchecked")
Hashtable permissions =
(Hashtable)gfields.get("permissions", null);
- perms = new HashMap(permissions.size()*2);
+ perms = new HashMap<>(permissions.size()*2);
perms.putAll(permissions);
// Get all_allowed
diff --git a/jdk/src/java.base/share/classes/java/security/CodeSource.java b/jdk/src/java.base/share/classes/java/security/CodeSource.java
index 62a5959ecd8..e05c68f9e49 100644
--- a/jdk/src/java.base/share/classes/java/security/CodeSource.java
+++ b/jdk/src/java.base/share/classes/java/security/CodeSource.java
@@ -543,7 +543,7 @@ public class CodeSource implements java.io.Serializable {
if (size > 0) {
// we know of 3 different cert types: X.509, PGP, SDSI, which
// could all be present in the stream at the same time
- cfs = new Hashtable(3);
+ cfs = new Hashtable<>(3);
this.certs = new java.security.cert.Certificate[size];
}
diff --git a/jdk/src/java.base/share/classes/java/security/Identity.java b/jdk/src/java.base/share/classes/java/security/Identity.java
index 6a5e87e20fa..467e18d1b84 100644
--- a/jdk/src/java.base/share/classes/java/security/Identity.java
+++ b/jdk/src/java.base/share/classes/java/security/Identity.java
@@ -185,7 +185,7 @@ public abstract class Identity implements Principal, Serializable {
check("setIdentityPublicKey");
this.publicKey = key;
- certificates = new Vector();
+ certificates = new Vector<>();
}
/**
@@ -248,7 +248,7 @@ public abstract class Identity implements Principal, Serializable {
check("addIdentityCertificate");
if (certificates == null) {
- certificates = new Vector();
+ certificates = new Vector<>();
}
if (publicKey != null) {
if (!keyEquals(publicKey, certificate.getPublicKey())) {
diff --git a/jdk/src/java.base/share/classes/java/security/IdentityScope.java b/jdk/src/java.base/share/classes/java/security/IdentityScope.java
index 64c4a634374..763f8308c53 100644
--- a/jdk/src/java.base/share/classes/java/security/IdentityScope.java
+++ b/jdk/src/java.base/share/classes/java/security/IdentityScope.java
@@ -74,7 +74,7 @@ class IdentityScope extends Identity {
private static void initializeSystemScope() {
String classname = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
public String run() {
return Security.getProperty("system.scope");
}
diff --git a/jdk/src/java.base/share/classes/java/security/KeyStore.java b/jdk/src/java.base/share/classes/java/security/KeyStore.java
index 8fde796e041..75b64ab337a 100644
--- a/jdk/src/java.base/share/classes/java/security/KeyStore.java
+++ b/jdk/src/java.base/share/classes/java/security/KeyStore.java
@@ -976,7 +976,7 @@ public class KeyStore {
*/
public final static String getDefaultType() {
String kstype;
- kstype = AccessController.doPrivileged(new PrivilegedAction() {
+ kstype = AccessController.doPrivileged(new PrivilegedAction<>() {
public String run() {
return Security.getProperty(KEYSTORE_TYPE);
}
diff --git a/jdk/src/java.base/share/classes/java/security/Permissions.java b/jdk/src/java.base/share/classes/java/security/Permissions.java
index cc9c69358ee..56a5059351b 100644
--- a/jdk/src/java.base/share/classes/java/security/Permissions.java
+++ b/jdk/src/java.base/share/classes/java/security/Permissions.java
@@ -99,7 +99,7 @@ implements Serializable
* Creates a new Permissions object containing no PermissionCollections.
*/
public Permissions() {
- permsMap = new HashMap, PermissionCollection>(11);
+ permsMap = new HashMap<>(11);
allPermission = null;
}
@@ -394,7 +394,7 @@ implements Serializable
@SuppressWarnings("unchecked")
Hashtable, PermissionCollection> perms =
(Hashtable, PermissionCollection>)gfields.get("perms", null);
- permsMap = new HashMap, PermissionCollection>(perms.size()*2);
+ permsMap = new HashMap<>(perms.size()*2);
permsMap.putAll(perms);
// Set hasUnresolved
@@ -488,7 +488,7 @@ implements Serializable
*/
PermissionsHash() {
- permsMap = new HashMap(11);
+ permsMap = new HashMap<>(11);
}
/**
@@ -597,7 +597,7 @@ implements Serializable
@SuppressWarnings("unchecked")
Hashtable perms =
(Hashtable)gfields.get("perms", null);
- permsMap = new HashMap(perms.size()*2);
+ permsMap = new HashMap<>(perms.size()*2);
permsMap.putAll(perms);
}
}
diff --git a/jdk/src/java.base/share/classes/java/security/Policy.java b/jdk/src/java.base/share/classes/java/security/Policy.java
index ffbcb44cf3f..0864f10d188 100644
--- a/jdk/src/java.base/share/classes/java/security/Policy.java
+++ b/jdk/src/java.base/share/classes/java/security/Policy.java
@@ -170,7 +170,7 @@ public abstract class Policy {
PolicyInfo pinfo = policy.get();
if (pinfo.policy == null) {
String policy_class = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
public String run() {
return Security.getProperty("policy.provider");
}
@@ -199,7 +199,7 @@ public abstract class Policy {
final String pc = policy_class;
Policy pol = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
public Policy run() {
try {
ClassLoader cl =
@@ -303,7 +303,7 @@ public abstract class Policy {
*/
ProtectionDomain policyDomain =
- AccessController.doPrivileged(new PrivilegedAction() {
+ AccessController.doPrivileged(new PrivilegedAction<>() {
public ProtectionDomain run() {
return p.getClass().getProtectionDomain();
}
diff --git a/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java b/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java
index 6e7056ddc92..3dd5933fb06 100644
--- a/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java
+++ b/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java
@@ -367,7 +367,7 @@ public class ProtectionDomain {
PermissionCollection perms =
java.security.AccessController.doPrivileged
- (new java.security.PrivilegedAction() {
+ (new java.security.PrivilegedAction<>() {
public PermissionCollection run() {
Policy p = Policy.getPolicyNoCheck();
return p.getPermissions(ProtectionDomain.this);
diff --git a/jdk/src/java.base/share/classes/java/security/Provider.java b/jdk/src/java.base/share/classes/java/security/Provider.java
index fa20e072d5f..80e510f7fba 100644
--- a/jdk/src/java.base/share/classes/java/security/Provider.java
+++ b/jdk/src/java.base/share/classes/java/security/Provider.java
@@ -711,7 +711,7 @@ public abstract class Provider extends Properties {
legacyChanged = true;
if (legacyStrings == null) {
- legacyStrings = new LinkedHashMap();
+ legacyStrings = new LinkedHashMap<>();
}
return true;
}
@@ -773,7 +773,7 @@ public abstract class Provider extends Properties {
private void implReplaceAll(BiFunction super Object, ? super Object, ? extends Object> function) {
legacyChanged = true;
if (legacyStrings == null) {
- legacyStrings = new LinkedHashMap();
+ legacyStrings = new LinkedHashMap<>();
} else {
legacyStrings.replaceAll((BiFunction super String, ? super String, ? extends String>) function);
}
@@ -905,7 +905,7 @@ public abstract class Provider extends Properties {
}
serviceSet = null;
if (legacyMap == null) {
- legacyMap = new LinkedHashMap();
+ legacyMap = new LinkedHashMap<>();
} else {
legacyMap.clear();
}
@@ -1133,7 +1133,7 @@ public abstract class Provider extends Properties {
("service.getProvider() must match this Provider object");
}
if (serviceMap == null) {
- serviceMap = new LinkedHashMap();
+ serviceMap = new LinkedHashMap<>();
}
servicesChanged = true;
String type = s.getType();
@@ -1305,7 +1305,7 @@ public abstract class Provider extends Properties {
}
static {
- knownEngines = new HashMap();
+ knownEngines = new HashMap<>();
// JCA
addEngine("AlgorithmParameterGenerator", false, null);
addEngine("AlgorithmParameters", false, null);
@@ -1431,14 +1431,14 @@ public abstract class Provider extends Properties {
private void addAlias(String alias) {
if (aliases.isEmpty()) {
- aliases = new ArrayList(2);
+ aliases = new ArrayList<>(2);
}
aliases.add(alias);
}
void addAttribute(String type, String value) {
if (attributes.isEmpty()) {
- attributes = new HashMap(8);
+ attributes = new HashMap<>(8);
}
attributes.put(new UString(type), value);
}
@@ -1471,12 +1471,12 @@ public abstract class Provider extends Properties {
if (aliases == null) {
this.aliases = Collections.emptyList();
} else {
- this.aliases = new ArrayList(aliases);
+ this.aliases = new ArrayList<>(aliases);
}
if (attributes == null) {
this.attributes = Collections.emptyMap();
} else {
- this.attributes = new HashMap();
+ this.attributes = new HashMap<>();
for (Map.Entry entry : attributes.entrySet()) {
this.attributes.put(new UString(entry.getKey()), entry.getValue());
}
@@ -1644,7 +1644,7 @@ public abstract class Provider extends Properties {
("class configured for " + type + " (provider: " +
provider.getName() + ") is not public.");
}
- classRef = new WeakReference>(clazz);
+ classRef = new WeakReference<>(clazz);
}
return clazz;
} catch (ClassNotFoundException e) {
diff --git a/jdk/src/java.base/share/classes/java/security/SecureRandom.java b/jdk/src/java.base/share/classes/java/security/SecureRandom.java
index a9c4469e8e1..f1531de25f7 100644
--- a/jdk/src/java.base/share/classes/java/security/SecureRandom.java
+++ b/jdk/src/java.base/share/classes/java/security/SecureRandom.java
@@ -616,7 +616,7 @@ public class SecureRandom extends java.util.Random {
throws NoSuchAlgorithmException {
String property = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
@Override
public String run() {
return Security.getProperty(
diff --git a/jdk/src/java.base/share/classes/java/security/Security.java b/jdk/src/java.base/share/classes/java/security/Security.java
index 11e1a997639..5b7be62ca67 100644
--- a/jdk/src/java.base/share/classes/java/security/Security.java
+++ b/jdk/src/java.base/share/classes/java/security/Security.java
@@ -66,7 +66,7 @@ public final class Security {
// things in initialize that might require privs.
// (the FileInputStream call and the File.exists call,
// the securityPropFile call, etc)
- AccessController.doPrivileged(new PrivilegedAction() {
+ AccessController.doPrivileged(new PrivilegedAction<>() {
public Void run() {
initialize();
return null;
@@ -810,7 +810,7 @@ public final class Security {
final boolean pd = key.equals("package.definition");
if (pa || pd) {
- AccessController.doPrivileged(new PrivilegedAction() {
+ AccessController.doPrivileged(new PrivilegedAction<>() {
public Void run() {
try {
/* Get the class via the bootstrap class loader. */
diff --git a/jdk/src/java.base/share/classes/java/security/Signature.java b/jdk/src/java.base/share/classes/java/security/Signature.java
index bb2e75dd1ac..e23b0dde121 100644
--- a/jdk/src/java.base/share/classes/java/security/Signature.java
+++ b/jdk/src/java.base/share/classes/java/security/Signature.java
@@ -265,7 +265,7 @@ public abstract class Signature extends SignatureSpi {
private final static Map signatureInfo;
static {
- signatureInfo = new ConcurrentHashMap();
+ signatureInfo = new ConcurrentHashMap<>();
Boolean TRUE = Boolean.TRUE;
// pre-initialize with values for our SignatureSpi implementations
signatureInfo.put("sun.security.provider.DSA$RawDSA", TRUE);
diff --git a/jdk/src/java.base/share/classes/java/security/Signer.java b/jdk/src/java.base/share/classes/java/security/Signer.java
index 077538da979..2edf668b530 100644
--- a/jdk/src/java.base/share/classes/java/security/Signer.java
+++ b/jdk/src/java.base/share/classes/java/security/Signer.java
@@ -140,7 +140,7 @@ public abstract class Signer extends Identity {
}
try {
AccessController.doPrivileged(
- new PrivilegedExceptionAction() {
+ new PrivilegedExceptionAction<>() {
public Void run() throws KeyManagementException {
setPublicKey(pub);
return null;
diff --git a/jdk/src/java.base/share/classes/java/security/UnresolvedPermission.java b/jdk/src/java.base/share/classes/java/security/UnresolvedPermission.java
index 9dff324920e..e5b0d3047aa 100644
--- a/jdk/src/java.base/share/classes/java/security/UnresolvedPermission.java
+++ b/jdk/src/java.base/share/classes/java/security/UnresolvedPermission.java
@@ -560,7 +560,7 @@ implements java.io.Serializable
if (size > 0) {
// we know of 3 different cert types: X.509, PGP, SDSI, which
// could all be present in the stream at the same time
- cfs = new Hashtable(3);
+ cfs = new Hashtable<>(3);
this.certs = new java.security.cert.Certificate[size];
}
diff --git a/jdk/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java b/jdk/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java
index 76336485842..87ab32d54f9 100644
--- a/jdk/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java
+++ b/jdk/src/java.base/share/classes/java/security/UnresolvedPermissionCollection.java
@@ -61,7 +61,7 @@ implements java.io.Serializable
*
*/
public UnresolvedPermissionCollection() {
- perms = new HashMap>(11);
+ perms = new HashMap<>(11);
}
/**
@@ -82,7 +82,7 @@ implements java.io.Serializable
synchronized (this) {
v = perms.get(up.getName());
if (v == null) {
- v = new ArrayList();
+ v = new ArrayList<>();
perms.put(up.getName(), v);
}
}
@@ -203,7 +203,7 @@ implements java.io.Serializable
Hashtable> permissions =
(Hashtable>)
gfields.get("permissions", null);
- perms = new HashMap>(permissions.size()*2);
+ perms = new HashMap<>(permissions.size()*2);
// Convert each entry (Vector) into a List
Set>> set = permissions.entrySet();
diff --git a/jdk/src/java.base/share/classes/java/security/cert/CertPathBuilder.java b/jdk/src/java.base/share/classes/java/security/cert/CertPathBuilder.java
index 6008e9ec180..06c0d04fefa 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/CertPathBuilder.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/CertPathBuilder.java
@@ -301,7 +301,7 @@ public class CertPathBuilder {
*/
public final static String getDefaultType() {
String cpbtype =
- AccessController.doPrivileged(new PrivilegedAction() {
+ AccessController.doPrivileged(new PrivilegedAction<>() {
public String run() {
return Security.getProperty(CPB_TYPE);
}
diff --git a/jdk/src/java.base/share/classes/java/security/cert/CertPathValidator.java b/jdk/src/java.base/share/classes/java/security/cert/CertPathValidator.java
index bd2ff56dd0c..ce9d38d1800 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/CertPathValidator.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/CertPathValidator.java
@@ -313,7 +313,7 @@ public class CertPathValidator {
*/
public final static String getDefaultType() {
String cpvtype =
- AccessController.doPrivileged(new PrivilegedAction() {
+ AccessController.doPrivileged(new PrivilegedAction<>() {
public String run() {
return Security.getProperty(CPV_TYPE);
}
diff --git a/jdk/src/java.base/share/classes/java/security/cert/CertStore.java b/jdk/src/java.base/share/classes/java/security/cert/CertStore.java
index 1a8ed628c13..d39d6703b9a 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/CertStore.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/CertStore.java
@@ -409,7 +409,7 @@ public class CertStore {
*/
public final static String getDefaultType() {
String cstype;
- cstype = AccessController.doPrivileged(new PrivilegedAction() {
+ cstype = AccessController.doPrivileged(new PrivilegedAction<>() {
public String run() {
return Security.getProperty(CERTSTORE_TYPE);
}
diff --git a/jdk/src/java.base/share/classes/java/security/cert/CertificateRevokedException.java b/jdk/src/java.base/share/classes/java/security/cert/CertificateRevokedException.java
index 8c1f0664023..0fce92f0ef7 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/CertificateRevokedException.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/CertificateRevokedException.java
@@ -231,7 +231,7 @@ public class CertificateRevokedException extends CertificateException {
if (size == 0) {
extensions = Collections.emptyMap();
} else {
- extensions = new HashMap(size);
+ extensions = new HashMap<>(size);
}
// Read in the extensions and put the mappings in the extensions map
diff --git a/jdk/src/java.base/share/classes/java/security/cert/PKIXParameters.java b/jdk/src/java.base/share/classes/java/security/cert/PKIXParameters.java
index a411f6e2aec..4bc453ca956 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/PKIXParameters.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/PKIXParameters.java
@@ -120,8 +120,8 @@ public class PKIXParameters implements CertPathParameters {
setTrustAnchors(trustAnchors);
this.unmodInitialPolicies = Collections.emptySet();
- this.certPathCheckers = new ArrayList();
- this.certStores = new ArrayList();
+ this.certPathCheckers = new ArrayList<>();
+ this.certStores = new ArrayList<>();
}
/**
@@ -144,7 +144,7 @@ public class PKIXParameters implements CertPathParameters {
if (keystore == null)
throw new NullPointerException("the keystore parameter must be " +
"non-null");
- Set hashSet = new HashSet();
+ Set hashSet = new HashSet<>();
Enumeration aliases = keystore.aliases();
while (aliases.hasMoreElements()) {
String alias = aliases.nextElement();
@@ -156,8 +156,8 @@ public class PKIXParameters implements CertPathParameters {
}
setTrustAnchors(hashSet);
this.unmodInitialPolicies = Collections.emptySet();
- this.certPathCheckers = new ArrayList();
- this.certStores = new ArrayList();
+ this.certPathCheckers = new ArrayList<>();
+ this.certStores = new ArrayList<>();
}
/**
@@ -207,7 +207,7 @@ public class PKIXParameters implements CertPathParameters {
}
}
this.unmodTrustAnchors = Collections.unmodifiableSet
- (new HashSet(trustAnchors));
+ (new HashSet<>(trustAnchors));
}
/**
@@ -256,7 +256,7 @@ public class PKIXParameters implements CertPathParameters {
+ "of type java.lang.String");
}
this.unmodInitialPolicies =
- Collections.unmodifiableSet(new HashSet(initialPolicies));
+ Collections.unmodifiableSet(new HashSet<>(initialPolicies));
} else
this.unmodInitialPolicies = Collections.emptySet();
}
@@ -280,7 +280,7 @@ public class PKIXParameters implements CertPathParameters {
*/
public void setCertStores(List stores) {
if (stores == null) {
- this.certStores = new ArrayList();
+ this.certStores = new ArrayList<>();
} else {
for (Iterator i = stores.iterator(); i.hasNext();) {
if (!(i.next() instanceof CertStore)) {
@@ -288,7 +288,7 @@ public class PKIXParameters implements CertPathParameters {
+ "of type java.security.cert.CertStore");
}
}
- this.certStores = new ArrayList(stores);
+ this.certStores = new ArrayList<>(stores);
}
}
@@ -316,7 +316,7 @@ public class PKIXParameters implements CertPathParameters {
*/
public List getCertStores() {
return Collections.unmodifiableList
- (new ArrayList(this.certStores));
+ (new ArrayList<>(this.certStores));
}
/**
@@ -544,14 +544,13 @@ public class PKIXParameters implements CertPathParameters {
*/
public void setCertPathCheckers(List checkers) {
if (checkers != null) {
- List tmpList =
- new ArrayList();
+ List tmpList = new ArrayList<>();
for (PKIXCertPathChecker checker : checkers) {
tmpList.add((PKIXCertPathChecker)checker.clone());
}
this.certPathCheckers = tmpList;
} else {
- this.certPathCheckers = new ArrayList();
+ this.certPathCheckers = new ArrayList<>();
}
}
@@ -567,7 +566,7 @@ public class PKIXParameters implements CertPathParameters {
* @see #setCertPathCheckers
*/
public List getCertPathCheckers() {
- List tmpList = new ArrayList();
+ List tmpList = new ArrayList<>();
for (PKIXCertPathChecker ck : certPathCheckers) {
tmpList.add((PKIXCertPathChecker)ck.clone());
}
@@ -667,11 +666,11 @@ public class PKIXParameters implements CertPathParameters {
// must clone these because addCertStore, et al. modify them
if (certStores != null) {
- copy.certStores = new ArrayList(certStores);
+ copy.certStores = new ArrayList<>(certStores);
}
if (certPathCheckers != null) {
copy.certPathCheckers =
- new ArrayList(certPathCheckers.size());
+ new ArrayList<>(certPathCheckers.size());
for (PKIXCertPathChecker checker : certPathCheckers) {
copy.certPathCheckers.add(
(PKIXCertPathChecker)checker.clone());
diff --git a/jdk/src/java.base/share/classes/java/security/cert/PKIXRevocationChecker.java b/jdk/src/java.base/share/classes/java/security/cert/PKIXRevocationChecker.java
index a345c96cac8..14e17cccb2d 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/PKIXRevocationChecker.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/PKIXRevocationChecker.java
@@ -170,7 +170,7 @@ public abstract class PKIXRevocationChecker extends PKIXCertPathChecker {
{
this.ocspExtensions = (extensions == null)
? Collections.emptyList()
- : new ArrayList(extensions);
+ : new ArrayList<>(extensions);
}
/**
@@ -232,7 +232,7 @@ public abstract class PKIXRevocationChecker extends PKIXCertPathChecker {
public void setOptions(Set options) {
this.options = (options == null)
? Collections. emptySet()
- : new HashSet (options);
+ : new HashSet<>(options);
}
/**
diff --git a/jdk/src/java.base/share/classes/java/security/cert/X509CRLSelector.java b/jdk/src/java.base/share/classes/java/security/cert/X509CRLSelector.java
index f761721007a..056d36ab298 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/X509CRLSelector.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/X509CRLSelector.java
@@ -124,8 +124,8 @@ public class X509CRLSelector implements CRLSelector {
issuerX500Principals = null;
} else {
// clone
- issuerX500Principals = new HashSet(issuers);
- issuerNames = new HashSet();
+ issuerX500Principals = new HashSet<>(issuers);
+ issuerNames = new HashSet<>();
for (X500Principal p : issuerX500Principals) {
issuerNames.add(p.getEncoded());
}
@@ -288,10 +288,10 @@ public class X509CRLSelector implements CRLSelector {
*/
private void addIssuerNameInternal(Object name, X500Principal principal) {
if (issuerNames == null) {
- issuerNames = new HashSet();
+ issuerNames = new HashSet<>();
}
if (issuerX500Principals == null) {
- issuerX500Principals = new HashSet();
+ issuerX500Principals = new HashSet<>();
}
issuerNames.add(name);
issuerX500Principals.add(principal);
@@ -311,7 +311,7 @@ public class X509CRLSelector implements CRLSelector {
private static HashSet cloneAndCheckIssuerNames(Collection> names)
throws IOException
{
- HashSet namesCopy = new HashSet();
+ HashSet namesCopy = new HashSet<>();
Iterator> i = names.iterator();
while (i.hasNext()) {
Object nameObject = i.next();
@@ -363,7 +363,7 @@ public class X509CRLSelector implements CRLSelector {
*/
private static HashSet parseIssuerNames(Collection names)
throws IOException {
- HashSet x500Principals = new HashSet();
+ HashSet x500Principals = new HashSet<>();
for (Iterator t = names.iterator(); t.hasNext(); ) {
Object nameObject = t.next();
if (nameObject instanceof String) {
@@ -701,9 +701,9 @@ public class X509CRLSelector implements CRLSelector {
X509CRLSelector copy = (X509CRLSelector)super.clone();
if (issuerNames != null) {
copy.issuerNames =
- new HashSet(issuerNames);
+ new HashSet<>(issuerNames);
copy.issuerX500Principals =
- new HashSet(issuerX500Principals);
+ new HashSet<>(issuerX500Principals);
}
return copy;
} catch (CloneNotSupportedException e) {
diff --git a/jdk/src/java.base/share/classes/java/security/cert/X509CertSelector.java b/jdk/src/java.base/share/classes/java/security/cert/X509CertSelector.java
index 49d7e3da1a4..a498bbefc5f 100644
--- a/jdk/src/java.base/share/classes/java/security/cert/X509CertSelector.java
+++ b/jdk/src/java.base/share/classes/java/security/cert/X509CertSelector.java
@@ -619,8 +619,8 @@ public class X509CertSelector implements CertSelector {
keyPurposeOIDSet = null;
} else {
this.keyPurposeSet =
- Collections.unmodifiableSet(new HashSet(keyPurposeSet));
- keyPurposeOIDSet = new HashSet();
+ Collections.unmodifiableSet(new HashSet<>(keyPurposeSet));
+ keyPurposeOIDSet = new HashSet<>();
for (String s : this.keyPurposeSet) {
keyPurposeOIDSet.add(new ObjectIdentifier(s));
}
@@ -815,12 +815,12 @@ public class X509CertSelector implements CertSelector {
// First, ensure that the name parses
GeneralNameInterface tempName = makeGeneralNameInterface(type, name);
if (subjectAlternativeNames == null) {
- subjectAlternativeNames = new HashSet>();
+ subjectAlternativeNames = new HashSet<>();
}
if (subjectAlternativeGeneralNames == null) {
- subjectAlternativeGeneralNames = new HashSet();
+ subjectAlternativeGeneralNames = new HashSet<>();
}
- List list = new ArrayList(2);
+ List list = new ArrayList<>(2);
list.add(Integer.valueOf(type));
list.add(name);
subjectAlternativeNames.add(list);
@@ -845,7 +845,7 @@ public class X509CertSelector implements CertSelector {
* @throws IOException if a parsing error occurs
*/
private static Set parseNames(Collection> names) throws IOException {
- Set genNames = new HashSet();
+ Set genNames = new HashSet<>();
for (List> nameList : names) {
if (nameList.size() != 2) {
throw new IOException("name list size not 2");
@@ -1096,10 +1096,10 @@ public class X509CertSelector implements CertSelector {
} else {
// Snapshot set and parse it
Set tempSet = Collections.unmodifiableSet
- (new HashSet(certPolicySet));
+ (new HashSet<>(certPolicySet));
/* Convert to Vector of ObjectIdentifiers */
Iterator i = tempSet.iterator();
- Vector polIdVector = new Vector();
+ Vector polIdVector = new Vector<>();
while (i.hasNext()) {
Object o = i.next();
if (!(o instanceof String)) {
@@ -1267,10 +1267,10 @@ public class X509CertSelector implements CertSelector {
// First, ensure that the name parses
GeneralNameInterface tempName = makeGeneralNameInterface(type, name);
if (pathToGeneralNames == null) {
- pathToNames = new HashSet>();
- pathToGeneralNames = new HashSet();
+ pathToNames = new HashSet<>();
+ pathToGeneralNames = new HashSet<>();
}
- List list = new ArrayList(2);
+ List list = new ArrayList<>(2);
list.add(Integer.valueOf(type));
list.add(name);
pathToNames.add(list);
@@ -1671,10 +1671,10 @@ public class X509CertSelector implements CertSelector {
*/
private static Set> cloneAndCheckNames(Collection> names) throws IOException {
// Copy the Lists and Collection
- Set> namesCopy = new HashSet>();
+ Set> namesCopy = new HashSet<>();
for (List> o : names)
{
- namesCopy.add(new ArrayList(o));
+ namesCopy.add(new ArrayList<>(o));
}
// Check the contents of the Lists and clone any byte arrays
@@ -2397,7 +2397,7 @@ public class X509CertSelector implements CertSelector {
* Convert the Vector of PolicyInformation to a Vector
* of CertificatePolicyIds for easier comparison.
*/
- List policyIDs = new ArrayList(policies.size());
+ List policyIDs = new ArrayList<>(policies.size());
for (PolicyInformation info : policies) {
policyIDs.add(info.getPolicyIdentifier());
}
diff --git a/jdk/src/java.base/share/classes/javax/crypto/JceSecurity.java b/jdk/src/java.base/share/classes/javax/crypto/JceSecurity.java
index 2aaff7217ec..65fce38f6ca 100644
--- a/jdk/src/java.base/share/classes/javax/crypto/JceSecurity.java
+++ b/jdk/src/java.base/share/classes/javax/crypto/JceSecurity.java
@@ -76,7 +76,7 @@ final class JceSecurity {
static {
try {
AccessController.doPrivileged(
- new PrivilegedExceptionAction () {
+ new PrivilegedExceptionAction<> () {
@Override
public Void run() throws Exception {
setupJurisdictionPolicies();
@@ -225,7 +225,7 @@ final class JceSecurity {
URL url = codeBaseCacheRef.get(clazz);
if (url == null) {
url = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
@Override
public URL run() {
ProtectionDomain pd = clazz.getProtectionDomain();
diff --git a/jdk/src/java.base/share/classes/javax/crypto/JceSecurityManager.java b/jdk/src/java.base/share/classes/javax/crypto/JceSecurityManager.java
index 83f003b4838..a01cf7b29a3 100644
--- a/jdk/src/java.base/share/classes/javax/crypto/JceSecurityManager.java
+++ b/jdk/src/java.base/share/classes/javax/crypto/JceSecurityManager.java
@@ -66,7 +66,7 @@ final class JceSecurityManager extends SecurityManager {
exemptPolicy = JceSecurity.getExemptPolicy();
allPerm = CryptoAllPermission.INSTANCE;
INSTANCE = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
public JceSecurityManager run() {
return new JceSecurityManager();
}
diff --git a/jdk/src/java.base/share/classes/javax/net/ssl/KeyManagerFactory.java b/jdk/src/java.base/share/classes/javax/net/ssl/KeyManagerFactory.java
index 31149108c8f..cff1b133cc2 100644
--- a/jdk/src/java.base/share/classes/javax/net/ssl/KeyManagerFactory.java
+++ b/jdk/src/java.base/share/classes/javax/net/ssl/KeyManagerFactory.java
@@ -63,7 +63,7 @@ public class KeyManagerFactory {
*/
public final static String getDefaultAlgorithm() {
String type;
- type = AccessController.doPrivileged(new PrivilegedAction() {
+ type = AccessController.doPrivileged(new PrivilegedAction<>() {
@Override
public String run() {
return Security.getProperty(
diff --git a/jdk/src/java.base/share/classes/javax/net/ssl/SSLSocketFactory.java b/jdk/src/java.base/share/classes/javax/net/ssl/SSLSocketFactory.java
index 5c6fdc0faf8..316016aac35 100644
--- a/jdk/src/java.base/share/classes/javax/net/ssl/SSLSocketFactory.java
+++ b/jdk/src/java.base/share/classes/javax/net/ssl/SSLSocketFactory.java
@@ -126,7 +126,7 @@ public abstract class SSLSocketFactory extends SocketFactory
}
static String getSecurityProperty(final String name) {
- return AccessController.doPrivileged(new PrivilegedAction() {
+ return AccessController.doPrivileged(new PrivilegedAction<>() {
@Override
public String run() {
String s = java.security.Security.getProperty(name);
diff --git a/jdk/src/java.base/share/classes/javax/net/ssl/TrustManagerFactory.java b/jdk/src/java.base/share/classes/javax/net/ssl/TrustManagerFactory.java
index a8a5008cc55..36803cd5578 100644
--- a/jdk/src/java.base/share/classes/javax/net/ssl/TrustManagerFactory.java
+++ b/jdk/src/java.base/share/classes/javax/net/ssl/TrustManagerFactory.java
@@ -63,7 +63,7 @@ public class TrustManagerFactory {
*/
public final static String getDefaultAlgorithm() {
String type;
- type = AccessController.doPrivileged(new PrivilegedAction() {
+ type = AccessController.doPrivileged(new PrivilegedAction<>() {
@Override
public String run() {
return Security.getProperty(
diff --git a/jdk/src/java.base/share/classes/javax/security/auth/Subject.java b/jdk/src/java.base/share/classes/javax/security/auth/Subject.java
index f0ec16ced8f..4e4e61cc0ed 100644
--- a/jdk/src/java.base/share/classes/javax/security/auth/Subject.java
+++ b/jdk/src/java.base/share/classes/javax/security/auth/Subject.java
@@ -154,11 +154,11 @@ public final class Subject implements java.io.Serializable {
public Subject() {
this.principals = Collections.synchronizedSet
- (new SecureSet(this, PRINCIPAL_SET));
+ (new SecureSet<>(this, PRINCIPAL_SET));
this.pubCredentials = Collections.synchronizedSet
- (new SecureSet(this, PUB_CREDENTIAL_SET));
+ (new SecureSet<>(this, PUB_CREDENTIAL_SET));
this.privCredentials = Collections.synchronizedSet
- (new SecureSet(this, PRIV_CREDENTIAL_SET));
+ (new SecureSet<>(this, PRIV_CREDENTIAL_SET));
}
/**
@@ -206,11 +206,11 @@ public final class Subject implements java.io.Serializable {
collectionNullClean(pubCredentials);
collectionNullClean(privCredentials);
- this.principals = Collections.synchronizedSet(new SecureSet
+ this.principals = Collections.synchronizedSet(new SecureSet<>
(this, PRINCIPAL_SET, principals));
- this.pubCredentials = Collections.synchronizedSet(new SecureSet
+ this.pubCredentials = Collections.synchronizedSet(new SecureSet<>
(this, PUB_CREDENTIAL_SET, pubCredentials));
- this.privCredentials = Collections.synchronizedSet(new SecureSet
+ this.privCredentials = Collections.synchronizedSet(new SecureSet<>
(this, PRIV_CREDENTIAL_SET, privCredentials));
this.readOnly = readOnly;
}
@@ -292,7 +292,7 @@ public final class Subject implements java.io.Serializable {
// return the Subject from the DomainCombiner of the provided context
return AccessController.doPrivileged
- (new java.security.PrivilegedAction() {
+ (new java.security.PrivilegedAction<>() {
public Subject run() {
DomainCombiner dc = acc.getDomainCombiner();
if (!(dc instanceof SubjectDomainCombiner)) {
@@ -555,7 +555,7 @@ public final class Subject implements java.io.Serializable {
return java.security.AccessController.doPrivileged
- (new java.security.PrivilegedAction() {
+ (new java.security.PrivilegedAction<>() {
public AccessControlContext run() {
if (subject == null) {
return new AccessControlContext(acc, null);
@@ -801,7 +801,7 @@ public final class Subject implements java.io.Serializable {
Set thatPrincipals;
synchronized(that.principals) {
// avoid deadlock from dual locks
- thatPrincipals = new HashSet(that.principals);
+ thatPrincipals = new HashSet<>(that.principals);
}
if (!principals.equals(thatPrincipals)) {
return false;
@@ -810,7 +810,7 @@ public final class Subject implements java.io.Serializable {
Set thatPubCredentials;
synchronized(that.pubCredentials) {
// avoid deadlock from dual locks
- thatPubCredentials = new HashSet(that.pubCredentials);
+ thatPubCredentials = new HashSet<>(that.pubCredentials);
}
if (!pubCredentials.equals(thatPubCredentials)) {
return false;
@@ -819,7 +819,7 @@ public final class Subject implements java.io.Serializable {
Set thatPrivCredentials;
synchronized(that.privCredentials) {
// avoid deadlock from dual locks
- thatPrivCredentials = new HashSet(that.privCredentials);
+ thatPrivCredentials = new HashSet<>(that.privCredentials);
}
if (!privCredentials.equals(thatPrivCredentials)) {
return false;
@@ -970,21 +970,21 @@ public final class Subject implements java.io.Serializable {
// Rewrap the principals into a SecureSet
try {
- principals = Collections.synchronizedSet(new SecureSet
+ principals = Collections.synchronizedSet(new SecureSet<>
(this, PRINCIPAL_SET, inputPrincs));
} catch (NullPointerException npe) {
// Sometimes people deserialize the principals set only.
// Subject is not accessible, so just don't fail.
principals = Collections.synchronizedSet
- (new SecureSet(this, PRINCIPAL_SET));
+ (new SecureSet<>(this, PRINCIPAL_SET));
}
// The Credential {@code Set} is not serialized, but we do not
// want the default deserialization routine to set it to null.
this.pubCredentials = Collections.synchronizedSet
- (new SecureSet(this, PUB_CREDENTIAL_SET));
+ (new SecureSet<>(this, PUB_CREDENTIAL_SET));
this.privCredentials = Collections.synchronizedSet
- (new SecureSet(this, PRIV_CREDENTIAL_SET));
+ (new SecureSet<>(this, PRIV_CREDENTIAL_SET));
}
/**
@@ -1497,7 +1497,7 @@ public final class Subject implements java.io.Serializable {
Object next;
if (which == Subject.PRIV_CREDENTIAL_SET) {
next = java.security.AccessController.doPrivileged
- (new java.security.PrivilegedAction() {
+ (new java.security.PrivilegedAction<>() {
public Object run() {
return iterator.next();
}
diff --git a/jdk/src/java.base/share/classes/javax/security/auth/login/Configuration.java b/jdk/src/java.base/share/classes/javax/security/auth/login/Configuration.java
index ac8e301d7e0..c0b1865ee0b 100644
--- a/jdk/src/java.base/share/classes/javax/security/auth/login/Configuration.java
+++ b/jdk/src/java.base/share/classes/javax/security/auth/login/Configuration.java
@@ -229,7 +229,7 @@ public abstract class Configuration {
if (configuration == null) {
String config_class = null;
config_class = AccessController.doPrivileged
- (new PrivilegedAction() {
+ (new PrivilegedAction<>() {
public String run() {
return java.security.Security.getProperty
("login.configuration.provider");
@@ -242,7 +242,7 @@ public abstract class Configuration {
try {
final String finalClass = config_class;
Configuration untrustedImpl = AccessController.doPrivileged(
- new PrivilegedExceptionAction() {
+ new PrivilegedExceptionAction<>() {
public Configuration run() throws ClassNotFoundException,
InstantiationException,
IllegalAccessException {
@@ -254,7 +254,7 @@ public abstract class Configuration {
}
});
AccessController.doPrivileged(
- new PrivilegedExceptionAction() {
+ new PrivilegedExceptionAction<>() {
public Void run() {
setConfiguration(untrustedImpl);
return null;
diff --git a/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java b/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java
index 666524a084c..511d6ef601b 100644
--- a/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java
+++ b/jdk/src/java.base/share/classes/javax/security/cert/X509Certificate.java
@@ -142,7 +142,7 @@ public abstract class X509Certificate extends Certificate {
static {
X509Provider = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
public String run() {
return Security.getProperty(X509_PROVIDER);
}
diff --git a/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS7.java b/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS7.java
index 19211ae7b0e..52d7b18bcc4 100644
--- a/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS7.java
+++ b/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS7.java
@@ -530,7 +530,7 @@ public class PKCS7 {
// CRLs (optional)
if (crls != null && crls.length != 0) {
// cast to X509CRLImpl[] since X509CRLImpl implements DerEncoder
- Set implCRLs = new HashSet(crls.length);
+ Set implCRLs = new HashSet<>(crls.length);
for (X509CRL crl: crls) {
if (crl instanceof X509CRLImpl)
implCRLs.add((X509CRLImpl) crl);
@@ -590,7 +590,7 @@ public class PKCS7 {
public SignerInfo[] verify(byte[] bytes)
throws NoSuchAlgorithmException, SignatureException {
- Vector intResult = new Vector();
+ Vector intResult = new Vector<>();
for (int i = 0; i < signerInfos.length; i++) {
SignerInfo signerInfo = verify(signerInfos[i], bytes);
diff --git a/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS9Attributes.java b/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS9Attributes.java
index 9adcbd8b34e..d8a7ba7ffa8 100644
--- a/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS9Attributes.java
+++ b/jdk/src/java.base/share/classes/sun/security/pkcs/PKCS9Attributes.java
@@ -85,8 +85,7 @@ public class PKCS9Attributes {
DerInputStream in) throws IOException {
if (permittedAttributes != null) {
this.permittedAttributes =
- new Hashtable(
- permittedAttributes.length);
+ new Hashtable<>(permittedAttributes.length);
for (int i = 0; i < permittedAttributes.length; i++)
this.permittedAttributes.put(permittedAttributes[i],
diff --git a/jdk/src/java.base/share/classes/sun/security/pkcs/SignerInfo.java b/jdk/src/java.base/share/classes/sun/security/pkcs/SignerInfo.java
index 8650474f1ca..1f310a2d32f 100644
--- a/jdk/src/java.base/share/classes/sun/security/pkcs/SignerInfo.java
+++ b/jdk/src/java.base/share/classes/sun/security/pkcs/SignerInfo.java
@@ -237,7 +237,7 @@ public class SignerInfo implements DerEncoder {
if (userCert == null)
return null;
- ArrayList certList = new ArrayList();
+ ArrayList certList = new ArrayList<>();
certList.add(userCert);
X509Certificate[] pkcsCerts = block.getCertificates();
diff --git a/jdk/src/java.base/share/classes/sun/security/provider/SeedGenerator.java b/jdk/src/java.base/share/classes/sun/security/provider/SeedGenerator.java
index fd08fa3f8ee..acf8b645b62 100644
--- a/jdk/src/java.base/share/classes/sun/security/provider/SeedGenerator.java
+++ b/jdk/src/java.base/share/classes/sun/security/provider/SeedGenerator.java
@@ -165,7 +165,7 @@ abstract class SeedGenerator {
md.update(b);
java.security.AccessController.doPrivileged
- (new java.security.PrivilegedAction() {
+ (new java.security.PrivilegedAction<>() {
@Override
public Void run() {
try {
@@ -295,7 +295,7 @@ abstract class SeedGenerator {
final ThreadGroup[] finalsg = new ThreadGroup[1];
Thread t = java.security.AccessController.doPrivileged
- (new java.security.PrivilegedAction() {
+ (new java.security.PrivilegedAction<>() {
@Override
public Thread run() {
ThreadGroup parent, group =
@@ -501,7 +501,7 @@ abstract class SeedGenerator {
final URL device = new URL(deviceName);
try {
seedStream = java.security.AccessController.doPrivileged
- (new java.security.PrivilegedExceptionAction() {
+ (new java.security.PrivilegedExceptionAction<>() {
@Override
public InputStream run() throws IOException {
/*
diff --git a/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java b/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java
index cfd8e609ae4..7b1a67b4d7d 100644
--- a/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java
+++ b/jdk/src/java.base/share/classes/sun/security/ssl/SunJSSE.java
@@ -148,7 +148,7 @@ public abstract class SunJSSE extends java.security.Provider {
}
private void registerAlgorithms(final boolean isfips) {
- AccessController.doPrivileged(new PrivilegedAction() {
+ AccessController.doPrivileged(new PrivilegedAction<>() {
@Override
public Object run() {
doRegister(isfips);
diff --git a/jdk/src/java.base/share/classes/sun/security/util/DerInputStream.java b/jdk/src/java.base/share/classes/sun/security/util/DerInputStream.java
index 8d04d5ab9ed..264bfd0e9c7 100644
--- a/jdk/src/java.base/share/classes/sun/security/util/DerInputStream.java
+++ b/jdk/src/java.base/share/classes/sun/security/util/DerInputStream.java
@@ -394,7 +394,7 @@ public class DerInputStream {
/*
* Pull values out of the stream.
*/
- Vector vec = new Vector(startLen);
+ Vector vec = new Vector<>(startLen);
DerValue value;
do {
diff --git a/jdk/src/java.base/share/classes/sun/security/util/ManifestDigester.java b/jdk/src/java.base/share/classes/sun/security/util/ManifestDigester.java
index fc9ccd3d552..5314e69a14e 100644
--- a/jdk/src/java.base/share/classes/sun/security/util/ManifestDigester.java
+++ b/jdk/src/java.base/share/classes/sun/security/util/ManifestDigester.java
@@ -110,7 +110,7 @@ public class ManifestDigester {
public ManifestDigester(byte bytes[])
{
rawBytes = bytes;
- entries = new HashMap();
+ entries = new HashMap<>();
ByteArrayOutputStream baos = new ByteArrayOutputStream();
diff --git a/jdk/src/java.base/share/classes/sun/security/util/ManifestEntryVerifier.java b/jdk/src/java.base/share/classes/sun/security/util/ManifestEntryVerifier.java
index 39f356eec0f..6fcc26143e2 100644
--- a/jdk/src/java.base/share/classes/sun/security/util/ManifestEntryVerifier.java
+++ b/jdk/src/java.base/share/classes/sun/security/util/ManifestEntryVerifier.java
@@ -77,9 +77,9 @@ public class ManifestEntryVerifier {
*/
public ManifestEntryVerifier(Manifest man)
{
- createdDigests = new HashMap(11);
- digests = new ArrayList();
- manifestHashes = new ArrayList();
+ createdDigests = new HashMap<>(11);
+ digests = new ArrayList<>();
+ manifestHashes = new ArrayList<>();
this.man = man;
}
diff --git a/jdk/src/java.base/share/classes/sun/security/util/SignatureFileVerifier.java b/jdk/src/java.base/share/classes/sun/security/util/SignatureFileVerifier.java
index 0d1e66287c9..51b296544b2 100644
--- a/jdk/src/java.base/share/classes/sun/security/util/SignatureFileVerifier.java
+++ b/jdk/src/java.base/share/classes/sun/security/util/SignatureFileVerifier.java
@@ -203,7 +203,7 @@ public class SignatureFileVerifier {
private MessageDigest getDigest(String algorithm)
{
if (createdDigests == null)
- createdDigests = new HashMap();
+ createdDigests = new HashMap<>();
MessageDigest digest = createdDigests.get(algorithm);
@@ -523,7 +523,7 @@ public class SignatureFileVerifier {
ArrayList chain = info.getCertificateChain(block);
CertPath certChain = certificateFactory.generateCertPath(chain);
if (signers == null) {
- signers = new ArrayList();
+ signers = new ArrayList<>();
}
// Append the new code signer
signers.add(new CodeSigner(certChain, info.getTimestamp()));
diff --git a/jdk/src/java.base/share/classes/sun/security/x509/AVA.java b/jdk/src/java.base/share/classes/sun/security/x509/AVA.java
index fd3a3544592..d1f94fb23a4 100644
--- a/jdk/src/java.base/share/classes/sun/security/x509/AVA.java
+++ b/jdk/src/java.base/share/classes/sun/security/x509/AVA.java
@@ -307,7 +307,7 @@ public class AVA implements DerEncoder {
// doublequote.
int c = readChar(in, "Quoted string did not end in quote");
- List embeddedHex = new ArrayList();
+ List embeddedHex = new ArrayList<>();
boolean isPrintableString = true;
while (c != '"') {
if (c == '\\') {
diff --git a/jdk/src/java.base/share/classes/sun/security/x509/AlgorithmId.java b/jdk/src/java.base/share/classes/sun/security/x509/AlgorithmId.java
index 68068e6f3f1..294888bfaf4 100644
--- a/jdk/src/java.base/share/classes/sun/security/x509/AlgorithmId.java
+++ b/jdk/src/java.base/share/classes/sun/security/x509/AlgorithmId.java
@@ -571,7 +571,7 @@ public class AlgorithmId implements Serializable, DerEncoder {
break;
}
if (oidTable == null) {
- oidTable = new HashMap();
+ oidTable = new HashMap<>();
}
oidString = alias.substring(index);
String stdAlgName = provs[i].getProperty(alias);
@@ -588,7 +588,7 @@ public class AlgorithmId implements Serializable, DerEncoder {
}
if (oidTable == null) {
- oidTable = new HashMap(1);
+ oidTable = new HashMap<>(1);
}
initOidTable = true;
}
@@ -887,7 +887,7 @@ public class AlgorithmId implements Serializable, DerEncoder {
*/
sha1WithDSA_oid = ObjectIdentifier.newInternal(dsaWithSHA1_PKIX_data);
- nameTable = new HashMap();
+ nameTable = new HashMap<>();
nameTable.put(MD5_oid, "MD5");
nameTable.put(MD2_oid, "MD2");
nameTable.put(SHA_oid, "SHA-1");
diff --git a/jdk/src/java.base/share/classes/sun/security/x509/CertificatePolicySet.java b/jdk/src/java.base/share/classes/sun/security/x509/CertificatePolicySet.java
index 1bb3aa8de0d..89527d657bd 100644
--- a/jdk/src/java.base/share/classes/sun/security/x509/CertificatePolicySet.java
+++ b/jdk/src/java.base/share/classes/sun/security/x509/CertificatePolicySet.java
@@ -58,7 +58,7 @@ public class CertificatePolicySet {
* @exception IOException on decoding errors.
*/
public CertificatePolicySet(DerInputStream in) throws IOException {
- ids = new Vector();
+ ids = new Vector<>();
DerValue[] seq = in.getSequence(5);
for (int i = 0; i < seq.length; i++) {
diff --git a/jdk/src/java.base/share/classes/sun/security/x509/GeneralSubtrees.java b/jdk/src/java.base/share/classes/sun/security/x509/GeneralSubtrees.java
index 9c5e6212c1a..2d6e3a1df21 100644
--- a/jdk/src/java.base/share/classes/sun/security/x509/GeneralSubtrees.java
+++ b/jdk/src/java.base/share/classes/sun/security/x509/GeneralSubtrees.java
@@ -59,11 +59,11 @@ public class GeneralSubtrees implements Cloneable {
* The default constructor for the class.
*/
public GeneralSubtrees() {
- trees = new ArrayList();
+ trees = new ArrayList<>();
}
private GeneralSubtrees(GeneralSubtrees source) {
- trees = new ArrayList(source.trees);
+ trees = new ArrayList<>(source.trees);
}
/**
diff --git a/jdk/src/java.base/share/classes/sun/security/x509/RDN.java b/jdk/src/java.base/share/classes/sun/security/x509/RDN.java
index 940c977cc1d..4a59176c3e1 100644
--- a/jdk/src/java.base/share/classes/sun/security/x509/RDN.java
+++ b/jdk/src/java.base/share/classes/sun/security/x509/RDN.java
@@ -102,7 +102,7 @@ public class RDN {
int quoteCount = 0;
int searchOffset = 0;
int avaOffset = 0;
- List avaVec = new ArrayList(3);
+ List avaVec = new ArrayList<>(3);
int nextPlus = name.indexOf('+');
while (nextPlus >= 0) {
quoteCount += X500Name.countQuotes(name, searchOffset, nextPlus);
@@ -182,7 +182,7 @@ public class RDN {
}
int searchOffset = 0;
int avaOffset = 0;
- List avaVec = new ArrayList(3);
+ List avaVec = new ArrayList<>(3);
int nextPlus = name.indexOf('+');
while (nextPlus >= 0) {
/*
@@ -453,7 +453,7 @@ public class RDN {
} else {
// order the string type AVA's alphabetically,
// followed by the oid type AVA's numerically
- List avaList = new ArrayList(assertion.length);
+ List avaList = new ArrayList<>(assertion.length);
for (int i = 0; i < assertion.length; i++) {
avaList.add(assertion[i]);
}
diff --git a/jdk/src/java.base/share/classes/sun/security/x509/X500Name.java b/jdk/src/java.base/share/classes/sun/security/x509/X500Name.java
index 1b786063172..2b35f7a63af 100644
--- a/jdk/src/java.base/share/classes/sun/security/x509/X500Name.java
+++ b/jdk/src/java.base/share/classes/sun/security/x509/X500Name.java
@@ -342,7 +342,7 @@ public class X500Name implements GeneralNameInterface, Principal {
public List allAvas() {
List list = allAvaList;
if (list == null) {
- list = new ArrayList();
+ list = new ArrayList<>();
for (int i = 0; i < names.length; i++) {
list.addAll(names[i].avas());
}
@@ -1382,7 +1382,7 @@ public class X500Name implements GeneralNameInterface, Principal {
*/
static {
PrivilegedExceptionAction pa =
- new PrivilegedExceptionAction() {
+ new PrivilegedExceptionAction<>() {
public Object[] run() throws Exception {
Class pClass = X500Principal.class;
Class>[] args = new Class>[] { X500Name.class };
diff --git a/jdk/src/java.base/unix/classes/sun/security/provider/NativePRNG.java b/jdk/src/java.base/unix/classes/sun/security/provider/NativePRNG.java
index ef728aa78eb..200ca9a56b6 100644
--- a/jdk/src/java.base/unix/classes/sun/security/provider/NativePRNG.java
+++ b/jdk/src/java.base/unix/classes/sun/security/provider/NativePRNG.java
@@ -125,7 +125,7 @@ public final class NativePRNG extends SecureRandomSpi {
*/
private static RandomIO initIO(final Variant v) {
return AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
@Override
public RandomIO run() {
@@ -440,7 +440,7 @@ public final class NativePRNG extends SecureRandomSpi {
if (seedOutInitialized == false) {
seedOutInitialized = true;
seedOut = AccessController.doPrivileged(
- new PrivilegedAction() {
+ new PrivilegedAction<>() {
@Override
public OutputStream run() {
try {
From 476d962701ee5ef3cac5deae09a3f81d82211732 Mon Sep 17 00:00:00 2001
From: Volker Simonis
Date: Fri, 24 Apr 2015 09:37:06 +0200
Subject: [PATCH 02/29] 8078520: [TESTBUG] fix
'test/tools/launcher/ExecutionEnvironment.java' to run on arbitrary *nix
systems
Reviewed-by: ksrini
---
.../tools/launcher/ExecutionEnvironment.java | 20 +++++++++----------
1 file changed, 10 insertions(+), 10 deletions(-)
diff --git a/jdk/test/tools/launcher/ExecutionEnvironment.java b/jdk/test/tools/launcher/ExecutionEnvironment.java
index 894c9a252fa..58acf380b0e 100644
--- a/jdk/test/tools/launcher/ExecutionEnvironment.java
+++ b/jdk/test/tools/launcher/ExecutionEnvironment.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -184,15 +184,7 @@ public class ExecutionEnvironment extends TestHelper {
Map env = new HashMap<>();
- if (TestHelper.isLinux || TestHelper.isMacOSX || TestHelper.isAIX) {
- for (String x : LD_PATH_STRINGS) {
- String pairs[] = x.split("=");
- env.put(pairs[0], pairs[1]);
- }
-
- tr = doExec(env, javaCmd, "-jar", testJarFile.getAbsolutePath());
- verifyJavaLibraryPathGeneric(tr);
- } else { // Solaris
+ if (TestHelper.isSolaris) {
// no override
env.clear();
env.put(LD_LIBRARY_PATH, LD_LIBRARY_PATH_VALUE);
@@ -208,6 +200,14 @@ public class ExecutionEnvironment extends TestHelper {
// verify the override occurs for 64-bit system
tr = doExec(env, javaCmd, "-jar", testJarFile.getAbsolutePath());
verifyJavaLibraryPathOverride(tr, false);
+ } else {
+ for (String x : LD_PATH_STRINGS) {
+ String pairs[] = x.split("=");
+ env.put(pairs[0], pairs[1]);
+ }
+
+ tr = doExec(env, javaCmd, "-jar", testJarFile.getAbsolutePath());
+ verifyJavaLibraryPathGeneric(tr);
}
}
From 7840b0e7c1e7e269b803a929cf62fbcff6ac54fe Mon Sep 17 00:00:00 2001
From: Vladimir Ivanov
Date: Thu, 23 Apr 2015 18:01:38 +0300
Subject: [PATCH 03/29] 8059455: LambdaForm.prepare() does unnecessary work for
cached LambdaForms
Reviewed-by: psandoz
---
.../share/classes/java/lang/invoke/LambdaForm.java | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java
index 5c441071b92..09a742f55ec 100644
--- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java
+++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java
@@ -631,7 +631,7 @@ class LambdaForm {
* as a sort of pre-invocation linkage step.)
*/
public void prepare() {
- if (COMPILE_THRESHOLD == 0) {
+ if (COMPILE_THRESHOLD == 0 && !isCompiled) {
compileToBytecode();
}
if (this.vmentry != null) {
@@ -645,11 +645,11 @@ class LambdaForm {
/** Generate optimizable bytecode for this form. */
MemberName compileToBytecode() {
- MethodType invokerType = methodType();
- assert(vmentry == null || vmentry.getMethodType().basicType().equals(invokerType));
if (vmentry != null && isCompiled) {
return vmentry; // already compiled somehow
}
+ MethodType invokerType = methodType();
+ assert(vmentry == null || vmentry.getMethodType().basicType().equals(invokerType));
try {
vmentry = InvokerBytecodeGenerator.generateCustomizedCode(this, invokerType);
if (TRACE_INTERPRETER)
From 650d8b7cb65259a7fc719b5a7ba223bbbfc023fa Mon Sep 17 00:00:00 2001
From: Ed Nevill
Date: Fri, 24 Apr 2015 11:01:37 +0000
Subject: [PATCH 04/29] 8075930: AARCH64: Use FP Register in C2
Modify to allow C2 to allocate FP (R29) as a general register
Reviewed-by: aph, kvn, dlong
---
hotspot/src/cpu/aarch64/vm/aarch64.ad | 6 +++---
hotspot/src/cpu/aarch64/vm/frame_aarch64.inline.hpp | 12 ------------
2 files changed, 3 insertions(+), 15 deletions(-)
diff --git a/hotspot/src/cpu/aarch64/vm/aarch64.ad b/hotspot/src/cpu/aarch64/vm/aarch64.ad
index 9df5db4fb84..fd92690312f 100644
--- a/hotspot/src/cpu/aarch64/vm/aarch64.ad
+++ b/hotspot/src/cpu/aarch64/vm/aarch64.ad
@@ -449,7 +449,7 @@ reg_class no_special_reg32(
R26
/* R27, */ // heapbase
/* R28, */ // thread
- /* R29, */ // fp
+ R29, // fp
/* R30, */ // lr
/* R31 */ // sp
);
@@ -483,7 +483,7 @@ reg_class no_special_reg(
R26, R26_H,
/* R27, R27_H, */ // heapbase
/* R28, R28_H, */ // thread
- /* R29, R29_H, */ // fp
+ R29, R29_H, // fp
/* R30, R30_H, */ // lr
/* R31, R31_H */ // sp
);
@@ -2538,7 +2538,7 @@ RegMask Matcher::modL_proj_mask() {
}
const RegMask Matcher::method_handle_invoke_SP_save_mask() {
- return RegMask();
+ return FP_REG_mask();
}
// helper for encoding java_to_runtime calls on sim
diff --git a/hotspot/src/cpu/aarch64/vm/frame_aarch64.inline.hpp b/hotspot/src/cpu/aarch64/vm/frame_aarch64.inline.hpp
index eb0c9a1f20c..5a9ae786638 100644
--- a/hotspot/src/cpu/aarch64/vm/frame_aarch64.inline.hpp
+++ b/hotspot/src/cpu/aarch64/vm/frame_aarch64.inline.hpp
@@ -77,12 +77,6 @@ inline frame::frame(intptr_t* sp, intptr_t* fp, address pc) {
inline frame::frame(intptr_t* sp, intptr_t* unextended_sp, intptr_t* fp, address pc) {
intptr_t a = intptr_t(sp);
intptr_t b = intptr_t(fp);
-#ifndef PRODUCT
- if (fp)
- if (sp > fp || (fp - sp > 0x100000))
- for(;;)
- asm("nop");
-#endif
_sp = sp;
_unextended_sp = unextended_sp;
_fp = fp;
@@ -104,12 +98,6 @@ inline frame::frame(intptr_t* sp, intptr_t* unextended_sp, intptr_t* fp, address
inline frame::frame(intptr_t* sp, intptr_t* fp) {
intptr_t a = intptr_t(sp);
intptr_t b = intptr_t(fp);
-#ifndef PRODUCT
- if (fp)
- if (sp > fp || (fp - sp > 0x100000))
- for(;;)
- asm("nop");
-#endif
_sp = sp;
_unextended_sp = sp;
_fp = fp;
From 37fbfc1a3dddf4a0398838f2618f3fb20c25d616 Mon Sep 17 00:00:00 2001
From: Doug Lea
Date: Fri, 24 Apr 2015 15:39:41 +0200
Subject: [PATCH 05/29] 8078490: Missed submissions in ForkJoinPool
Reviewed-by: psandoz, shade, martin, chegar
---
.../java/util/concurrent/ForkJoinPool.java | 2 +-
.../concurrent/forkjoin/SubmissionTest.java | 49 +++++++++++++++++++
2 files changed, 50 insertions(+), 1 deletion(-)
create mode 100644 jdk/test/java/util/concurrent/forkjoin/SubmissionTest.java
diff --git a/jdk/src/java.base/share/classes/java/util/concurrent/ForkJoinPool.java b/jdk/src/java.base/share/classes/java/util/concurrent/ForkJoinPool.java
index c3ebf04d343..0029322cfc2 100644
--- a/jdk/src/java.base/share/classes/java/util/concurrent/ForkJoinPool.java
+++ b/jdk/src/java.base/share/classes/java/util/concurrent/ForkJoinPool.java
@@ -2411,7 +2411,7 @@ public class ForkJoinPool extends AbstractExecutorService {
int j = ((am & s) << ASHIFT) + ABASE;
U.putOrderedObject(a, j, task);
U.putOrderedInt(q, QTOP, s + 1);
- U.putOrderedInt(q, QLOCK, 0);
+ U.putIntVolatile(q, QLOCK, 0);
if (n <= 1)
signalWork(ws, q);
return;
diff --git a/jdk/test/java/util/concurrent/forkjoin/SubmissionTest.java b/jdk/test/java/util/concurrent/forkjoin/SubmissionTest.java
new file mode 100644
index 00000000000..5a3db577ddd
--- /dev/null
+++ b/jdk/test/java/util/concurrent/forkjoin/SubmissionTest.java
@@ -0,0 +1,49 @@
+/*
+ * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ *
+ * You should have received a copy of the GNU General Public License version
+ * 2 along with this work; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+ * or visit www.oracle.com if you need additional information or have any
+ * questions.
+ */
+
+import java.util.concurrent.ForkJoinPool;
+import java.util.concurrent.TimeUnit;
+import java.util.concurrent.atomic.AtomicBoolean;
+
+/*
+ * @test
+ * @bug 8078490
+ * @summary Test submission and execution of task without joining
+ */
+public class SubmissionTest {
+ public static void main(String[] args) throws Throwable {
+ final ForkJoinPool e = new ForkJoinPool(1);
+ final AtomicBoolean b = new AtomicBoolean();
+ final Runnable setFalse = () -> b.set(false);
+ for (int i = 0; i < 100000; i++) {
+ b.set(true);
+ e.execute(setFalse);
+ long st = System.nanoTime();
+ while (b.get()) {
+ if (System.nanoTime() - st >= TimeUnit.SECONDS.toNanos(10)) {
+ throw new RuntimeException("Submitted task failed to execute");
+ }
+ }
+ }
+ }
+}
From a4c5e8666b4f45c9365aa7fd77fe5b9134b6d790 Mon Sep 17 00:00:00 2001
From: Andrew Haley
Date: Fri, 24 Apr 2015 16:28:29 +0100
Subject: [PATCH 06/29] 8078621: AARCH64: Fails to build without precompiled
headers
Fix #includes.
Reviewed-by: kvn
---
hotspot/src/cpu/aarch64/vm/aarch64.ad | 2 ++
.../src/cpu/aarch64/vm/macroAssembler_aarch64.cpp | 14 +++-----------
2 files changed, 5 insertions(+), 11 deletions(-)
diff --git a/hotspot/src/cpu/aarch64/vm/aarch64.ad b/hotspot/src/cpu/aarch64/vm/aarch64.ad
index fd92690312f..956a4ac3fd0 100644
--- a/hotspot/src/cpu/aarch64/vm/aarch64.ad
+++ b/hotspot/src/cpu/aarch64/vm/aarch64.ad
@@ -758,6 +758,8 @@ definitions %{
source_hpp %{
+#include "memory/cardTableModRefBS.hpp"
+
class CallStubImpl {
//--------------------------------------------------------------
diff --git a/hotspot/src/cpu/aarch64/vm/macroAssembler_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/macroAssembler_aarch64.cpp
index 080d25b89f8..5653e44affd 100644
--- a/hotspot/src/cpu/aarch64/vm/macroAssembler_aarch64.cpp
+++ b/hotspot/src/cpu/aarch64/vm/macroAssembler_aarch64.cpp
@@ -32,22 +32,14 @@
#include "compiler/disassembler.hpp"
#include "memory/resourceArea.hpp"
+#include "nativeInst_aarch64.hpp"
+#include "opto/compile.hpp"
+#include "opto/node.hpp"
#include "runtime/biasedLocking.hpp"
#include "runtime/icache.hpp"
#include "runtime/interfaceSupport.hpp"
#include "runtime/sharedRuntime.hpp"
-// #include "gc_interface/collectedHeap.inline.hpp"
-// #include "interpreter/interpreter.hpp"
-// #include "memory/cardTableModRefBS.hpp"
-// #include "prims/methodHandles.hpp"
-// #include "runtime/biasedLocking.hpp"
-// #include "runtime/interfaceSupport.hpp"
-// #include "runtime/objectMonitor.hpp"
-// #include "runtime/os.hpp"
-// #include "runtime/sharedRuntime.hpp"
-// #include "runtime/stubRoutines.hpp"
-
#if INCLUDE_ALL_GCS
#include "gc_implementation/g1/g1CollectedHeap.inline.hpp"
#include "gc_implementation/g1/g1SATBCardTableModRefBS.hpp"
From a4a28312150a979141a97a60632b2f2e807132fb Mon Sep 17 00:00:00 2001
From: Alexander Stepanov
Date: Fri, 24 Apr 2015 20:51:41 +0400
Subject: [PATCH 07/29] 8078622: remove tidy warnings from JPDA docs
Minor HTML markup fix
Reviewed-by: lancea
---
.../share/classes/com/sun/jdi/Bootstrap.java | 7 +--
.../share/classes/com/sun/jdi/Field.java | 26 ++++----
.../classes/com/sun/jdi/JDIPermission.java | 16 ++---
.../share/classes/com/sun/jdi/Method.java | 61 +++++++++----------
.../share/classes/com/sun/jdi/Value.java | 46 +++++++-------
.../com/sun/jdi/VirtualMachineManager.java | 16 +++--
.../com/sun/jdi/connect/spi/Connection.java | 38 ++++++------
.../com/sun/jdi/doc-files/signature.html | 6 +-
.../classes/com/sun/jdi/event/EventSet.java | 1 -
.../jdi/event/MonitorContendedEnterEvent.java | 6 +-
.../event/MonitorContendedEnteredEvent.java | 2 -
.../com/sun/jdi/event/MonitorWaitEvent.java | 4 +-
.../com/sun/jdi/event/MonitorWaitedEvent.java | 4 +-
.../com/sun/jdi/request/EventRequest.java | 28 ++++-----
.../sun/jdi/request/EventRequestManager.java | 18 +++---
.../jdk.jdi/share/classes/jdi-overview.html | 1 -
16 files changed, 135 insertions(+), 145 deletions(-)
diff --git a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Bootstrap.java b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Bootstrap.java
index 8ab09545e0d..623a7a4d5a9 100644
--- a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Bootstrap.java
+++ b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Bootstrap.java
@@ -43,13 +43,12 @@ public class Bootstrap extends Object {
* May throw an unspecified error if initialization of the
* {@link com.sun.jdi.VirtualMachineManager} fails or if
* the virtual machine manager is unable to locate or create
- * any {@link com.sun.jdi.connect.Connector Connectors}.
- *
+ * any {@link com.sun.jdi.connect.Connector Connectors}.
+ *
* @throws java.lang.SecurityException if a security manager has been
* installed and it denies {@link JDIPermission}
- * ("virtualMachineManager") or other unspecified
+ * ("{@code virtualMachineManager}") or other unspecified
* permissions required by the implementation.
- *
*/
static public synchronized VirtualMachineManager virtualMachineManager() {
return com.sun.tools.jdi.VirtualMachineManagerImpl.virtualMachineManager();
diff --git a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Field.java b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Field.java
index 00e2b75a196..6842a81fa78 100644
--- a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Field.java
+++ b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Field.java
@@ -65,22 +65,22 @@ public interface Field extends TypeComponent, Comparable {
* short s;
* Date d;
* byte[] ba;
- * And the JDI client defines these Field
objects:
+ * And the JDI client defines these {@code Field} objects:
*
* Field sField = targetClass.fieldByName("s");
* Field dField = targetClass.fieldByName("d");
* Field baField = targetClass.fieldByName("ba");
- * to mirror the corresponding fields, then sField.type()
- * is a {@link ShortType}, dField.type()
is the
- * {@link ReferenceType} for java.util.Date
and
- * ((ArrayType)(baField.type())).componentType()
is a
+ * to mirror the corresponding fields, then {@code sField.type()}
+ * is a {@link ShortType}, {@code dField.type()} is the
+ * {@link ReferenceType} for {@code java.util.Date} and
+ * {@code ((ArrayType)(baField.type())).componentType()} is a
* {@link ByteType}.
*
* Note: if the type of this field is a reference type (class,
* interface, or array) and it has not been created or loaded
* by the declaring type's class loader - that is,
- * {@link TypeComponent#declaringType declaringType()
}
- * .classLoader()
,
+ * {@link TypeComponent#declaringType declaringType()}
+ * {@code .classLoader()},
* then ClassNotLoadedException will be thrown.
* Also, a reference type may have been loaded but not yet prepared,
* in which case the type will be returned
@@ -100,28 +100,28 @@ public interface Field extends TypeComponent, Comparable {
/**
* Determine if this is a transient field.
*
- * @return true
if this field is transient; false otherwise.
+ * @return {@code true} if this field is transient; {@code false} otherwise.
*/
boolean isTransient();
/**
* Determine if this is a volatile field.
*
- * @return true
if this field is volatile; false otherwise.
+ * @return {@code true} if this field is volatile; {@code false} otherwise.
*/
boolean isVolatile();
/**
* Determine if this is a field that represents an enum constant.
- * @return true
if this field represents an enum constant;
- * false otherwise.
+ * @return {@code true} if this field represents an enum constant;
+ * {@code false} otherwise.
*/
boolean isEnumConstant();
/**
* Compares the specified Object with this field for equality.
*
- * @return true if the Object is a Field and if both
+ * @return {@code true} if the Object is a Field and if both
* mirror the same field (declared in the same class or interface, in
* the same VM).
*/
@@ -130,7 +130,7 @@ public interface Field extends TypeComponent, Comparable {
/**
* Returns the hash code value for this Field.
*
- * @return the integer hash code
+ * @return the integer hash code.
*/
int hashCode();
}
diff --git a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/JDIPermission.java b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/JDIPermission.java
index 7c3fad78845..0f4abb258a8 100644
--- a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/JDIPermission.java
+++ b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/JDIPermission.java
@@ -26,20 +26,20 @@
package com.sun.jdi;
/**
- * The JDIPermission
class represents access rights to
- * the VirtualMachineManager
. This is the permission
+ * The {@code JDIPermission} class represents access rights to
+ * the {@code VirtualMachineManager}. This is the permission
* which the SecurityManager will check when code that is running with
* a SecurityManager requests access to the VirtualMachineManager, as
* defined in the Java Debug Interface (JDI) for the Java platform.
*
- * A JDIPermission
object contains a name (also referred
+ * A {@code JDIPermission} object contains a name (also referred
* to as a "target name") but no actions list; you either have the
* named permission or you don't.
*
* The following table provides a summary description of what the
* permission allows, and discusses the risks of granting code the
* permission.
- *
+ *
*
*
@@ -51,10 +51,10 @@ package com.sun.jdi;
*
* virtualMachineManager
* Ability to inspect and modify the JDI objects in the
- * VirtualMachineManager
+ * {@code VirtualMachineManager}
*
* This allows an attacker to control the
- * VirtualMachineManager
and cause the system to
+ * {@code VirtualMachineManager} and cause the system to
* misbehave.
*
*
@@ -82,8 +82,8 @@ package com.sun.jdi;
public final class JDIPermission extends java.security.BasicPermission {
private static final long serialVersionUID = -6988461416938786271L;
/**
- * The JDIPermission
class represents access rights to the
- * VirtualMachineManager
+ * The {@code JDIPermission} class represents access rights to the
+ * {@code VirtualMachineManager}
* @param name Permission name. Must be "virtualMachineManager".
* @throws IllegalArgumentException if the name argument is invalid.
*/
diff --git a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Method.java b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Method.java
index eb81b058c89..39cde3ea73c 100644
--- a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Method.java
+++ b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Method.java
@@ -49,7 +49,7 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* This type name is always available even if
* the type has not yet been created or loaded.
*
- * @return a String containing the return type name.
+ * @return a {@code String} containing the return type name.
*/
String returnTypeName();
@@ -60,8 +60,8 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* Note: if the return type of this method is a reference type (class,
* interface, or array) and it has not been created or loaded
* by the declaring type's class loader - that is,
- * {@link TypeComponent#declaringType declaringType()
}
- * .classLoader()
,
+ * {@link TypeComponent#declaringType declaringType()}
+ * {@code .classLoader()},
* then ClassNotLoadedException will be thrown.
* Also, a reference type may have been loaded but not yet prepared,
* in which case the type will be returned
@@ -93,7 +93,6 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* as specified at compile-time.
* If the formal parameter was declared with an ellipsis, then
* it is represented as an array of the type before the ellipsis.
- *
*/
List argumentTypeNames();
@@ -105,8 +104,8 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* is a reference type (class, interface, or array)
* and it has not been created or loaded
* by the declaring type's class loader - that is,
- * {@link TypeComponent#declaringType declaringType()
}
- * .classLoader()
,
+ * {@link TypeComponent#declaringType declaringType()}
+ * {@code .classLoader()},
* then ClassNotLoadedException will be thrown.
* Also, a reference type may have been loaded but not yet prepared,
* in which case the list will be returned
@@ -132,16 +131,16 @@ public interface Method extends TypeComponent, Locatable, Comparable {
/**
* Determine if this method is abstract.
*
- * @return true
if the method is declared abstract;
- * false otherwise.
+ * @return {@code true} if the method is declared abstract;
+ * {@code false} otherwise.
*/
boolean isAbstract();
/**
* Determine if this method is a default method
*
- * @return true
if the method is declared default;
- * false otherwise
+ * @return {@code true} if the method is declared default;
+ * {@code false} otherwise.
*
* @since 1.8
*/
@@ -152,24 +151,24 @@ public interface Method extends TypeComponent, Locatable, Comparable {
/**
* Determine if this method is synchronized.
*
- * @return true
if the method is declared synchronized;
- * false otherwise.
+ * @return {@code true} if the method is declared synchronized;
+ * {@code false} otherwise.
*/
boolean isSynchronized();
/**
* Determine if this method is native.
*
- * @return true
if the method is declared native;
- * false otherwise.
+ * @return {@code true} if the method is declared native;
+ * {@code false} otherwise.
*/
boolean isNative();
/**
* Determine if this method accepts a variable number of arguments.
*
- * @return true
if the method accepts a variable number
- * of arguments, false otherwise.
+ * @return {@code true} if the method accepts a variable number
+ * of arguments, {@code false} otherwise.
*
* @since 1.5
*/
@@ -180,8 +179,8 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* methods are defined in
* The Java™ Language Specification .
*
- * @return true
if the method is a bridge method,
- * false otherwise.
+ * @return {@code true} if the method is a bridge method,
+ * {@code false} otherwise.
*
* @since 1.5
*/
@@ -190,23 +189,23 @@ public interface Method extends TypeComponent, Locatable, Comparable {
/**
* Determine if this method is a constructor.
*
- * @return true
if the method is a constructor;
- * false otherwise.
+ * @return {@code true} if the method is a constructor;
+ * {@code false} otherwise.
*/
boolean isConstructor();
/**
* Determine if this method is a static initializer.
*
- * @return true
if the method is a static initializer;
- * false otherwise.
+ * @return {@code true} if the method is a static initializer;
+ * {@code false} otherwise.
*/
boolean isStaticInitializer();
/**
* Determine if this method is obsolete.
*
- * @return true
if this method has been made obsolete by a
+ * @return {@code true} if this method has been made obsolete by a
* {@link VirtualMachine#redefineClasses} operation.
*
* @since 1.4
@@ -218,7 +217,7 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* each executable source line in this method.
*
* This method is equivalent to
- * allLineLocations(vm.getDefaultStratum(),null)
-
+ * {@code allLineLocations(vm.getDefaultStratum(),null)} -
* see {@link #allLineLocations(String,String)}
* for more information.
*
@@ -252,16 +251,16 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* (see {@link Location} for a description of strata).
*
* @param stratum The stratum to retrieve information from
- * or null
for the {@link ReferenceType#defaultStratum()}
+ * or {@code null} for the {@link ReferenceType#defaultStratum()}
*
* @param sourceName Return locations only within this
- * source file or null
to return locations.
+ * source file or {@code null} to return locations.
*
* @return a List of all source line {@link Location} objects.
*
* @throws AbsentInformationException if there is no line
* number information for this (non-native, non-abstract)
- * method. Or if sourceName is non-null
+ * method. Or if sourceName is non-{@code null}
* and source name information is not present.
*
* @since 1.4
@@ -274,8 +273,8 @@ public interface Method extends TypeComponent, Locatable, Comparable {
* that map to the given line number.
*
* This method is equivalent to
- * locationsOfLine(vm.getDefaultStratum(), null,
- * lineNumber)
-
+ * {@code locationsOfLine(vm.getDefaultStratum(), null,
+ * lineNumber)} -
* see {@link
* #locationsOfLine(java.lang.String,java.lang.String,int)}
* for more information.
@@ -320,7 +319,7 @@ public interface Method extends TypeComponent, Locatable, Comparable {
*
* @throws AbsentInformationException if there is no line
* number information for this method.
- * Or if sourceName is non-null
+ * Or if sourceName is non-{@code null}
* and source name information is not present.
*
* @since 1.4
@@ -436,7 +435,7 @@ public interface Method extends TypeComponent, Locatable, Comparable {
/**
* Returns the hash code value for this Method.
*
- * @return the integer hash code
+ * @return the integer hash code.
*/
int hashCode();
}
diff --git a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Value.java b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Value.java
index 4957b02407b..01d869b2ce3 100644
--- a/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Value.java
+++ b/jdk/src/jdk.jdi/share/classes/com/sun/jdi/Value.java
@@ -63,47 +63,47 @@ package com.sun.jdi;
* {@link Type} of value {@link #type() Value.type()}
*
* a boolean
- * true
+ * {@code true}
* {@link BooleanValue}
* {@link BooleanType}
*
* a byte
- * (byte)4
+ * {@code (byte)4}
* {@link ByteValue}
* {@link ByteType}
*
* a char
- * 'a'
+ * {@code 'a'}
* {@link CharValue}
* {@link CharType}
*
* a double
- * 3.1415926
+ * {@code 3.1415926}
* {@link DoubleValue}
* {@link DoubleType}
*
* a float
- * 2.5f
+ * {@code 2.5f}
* {@link FloatValue}
* {@link FloatType}
*
* an int
- * 22
+ * {@code 22}
* {@link IntegerValue}
* {@link IntegerType}
*
* a long
- * 1024L
+ * {@code 1024L}
* {@link LongValue}
* {@link LongType}
*
* a short
- * (short)12
+ * {@code (short)12}
* {@link ShortValue}
* {@link ShortType}
*
* a void
- *
+ *
* {@link VoidValue}
* {@link VoidType}
*
@@ -115,50 +115,50 @@ package com.sun.jdi;
* {@link Type} of value {@link #type() Value.type()}
*
* a class instance
- * this
+ * {@code this}
* {@link ObjectReference}
* {@link ClassType}
*
* an array
- * new int[5]
+ * {@code new int[5]}
* {@link ArrayReference}
* {@link ArrayType}
*
* a string
- * "hello"
+ * {@code "hello"}
* {@link StringReference}
* {@link ClassType}
*
* a thread
- * Thread.currentThread()
+ * {@code Thread.currentThread()}
* {@link ThreadReference}
* {@link ClassType}
*
* a thread group
- * Thread.currentThread()