summaryrefslogtreecommitdiff
path: root/java/openjdk6/files/patch-security
diff options
context:
space:
mode:
Diffstat (limited to 'java/openjdk6/files/patch-security')
-rw-r--r--java/openjdk6/files/patch-security6905
1 files changed, 0 insertions, 6905 deletions
diff --git a/java/openjdk6/files/patch-security b/java/openjdk6/files/patch-security
deleted file mode 100644
index 99daf6f5b42a..000000000000
--- a/java/openjdk6/files/patch-security
+++ /dev/null
@@ -1,6905 +0,0 @@
---- corba/src/share/classes/com/sun/corba/se/impl/interceptors/ClientRequestInfoImpl.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/interceptors/ClientRequestInfoImpl.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -215,7 +215,7 @@
-
- // ClientRequestInfo validity table (see ptc/00-08-06 table 21-1).
- // Note: These must be in the same order as specified in contants.
-- protected static final boolean validCall[][] = {
-+ private static final boolean validCall[][] = {
- // LEGEND:
- // s_req = send_request r_rep = receive_reply
- // s_pol = send_poll r_exc = receive_exception
---- corba/src/share/classes/com/sun/corba/se/impl/interceptors/ServerRequestInfoImpl.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/interceptors/ServerRequestInfoImpl.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -195,7 +195,7 @@
-
- // ServerRequestInfo validity table (see ptc/00-08-06 table 21-2).
- // Note: These must be in the same order as specified in contants.
-- protected static final boolean validCall[][] = {
-+ private static final boolean validCall[][] = {
- // LEGEND:
- // r_rsc = receive_request_service_contexts
- // r_req = receive_request
---- corba/src/share/classes/com/sun/corba/se/impl/javax/rmi/CORBA/Util.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/javax/rmi/CORBA/Util.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1999, 2004, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1999, 2012, 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
-@@ -130,10 +130,23 @@
- private UtilSystemException utilWrapper = UtilSystemException.get(
- CORBALogDomains.RPC_ENCODING);
-
-- public static Util instance = null;
-+ private static Util instance = null;
-
- public Util() {
-- instance = this;
-+ setInstance(this);
-+ }
-+
-+ private static void setInstance( Util util ) {
-+ assert instance == null : "Instance already defined";
-+ instance = util;
-+ }
-+
-+ public static Util getInstance() {
-+ return instance;
-+ }
-+
-+ public static boolean isInstanceDefined() {
-+ return instance != null;
- }
-
- // Used by TOAFactory.shutdown to unexport all targets for this
---- corba/src/share/classes/com/sun/corba/se/impl/oa/poa/POAPolicyMediatorBase_R.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/oa/poa/POAPolicyMediatorBase_R.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2002, 2004, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2002, 2012, 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
-@@ -93,7 +93,7 @@
-
- activeObjectMap.putServant( servant, entry ) ;
-
-- if (Util.instance != null) {
-+ if (Util.isInstanceDefined()) {
- POAManagerImpl pm = (POAManagerImpl)poa.the_POAManager() ;
- POAFactory factory = pm.getFactory() ;
- factory.registerPOAForServant(poa, servant);
-@@ -133,7 +133,7 @@
-
- activeObjectMap.remove(key);
-
-- if (Util.instance != null) {
-+ if (Util.isInstanceDefined()) {
- POAManagerImpl pm = (POAManagerImpl)poa.the_POAManager() ;
- POAFactory factory = pm.getFactory() ;
- factory.unregisterPOAForServant(poa, s);
---- corba/src/share/classes/com/sun/corba/se/impl/oa/toa/TOAFactory.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/oa/toa/TOAFactory.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2002, 2012, 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
-@@ -78,8 +78,8 @@
-
- public void shutdown( boolean waitForCompletion )
- {
-- if (Util.instance != null) {
-- Util.instance.unregisterTargetsForORB(orb);
-+ if (Util.isInstanceDefined()) {
-+ Util.getInstance().unregisterTargetsForORB(orb);
- }
- }
-
---- corba/src/share/classes/com/sun/corba/se/impl/orb/ParserTable.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/orb/ParserTable.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2002, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2002, 2012, 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
-@@ -106,7 +106,9 @@
-
- public ParserData[] getParserData()
- {
-- return parserData ;
-+ ParserData[] parserArray = new ParserData[parserData.length];
-+ System.arraycopy(parserData, 0, parserArray, 0, parserData.length);
-+ return parserArray;
- }
-
- private ParserTable() {
---- corba/src/share/classes/com/sun/corba/se/impl/orbutil/RepositoryId_1_3.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/orbutil/RepositoryId_1_3.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2002, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -62,7 +62,7 @@
- // legal use of '.' in a Java name.
-
- public static final RepositoryIdCache_1_3 cache = new RepositoryIdCache_1_3();
-- public static final byte[] IDL_IDENTIFIER_CHARS = {
-+ private static final byte[] IDL_IDENTIFIER_CHARS = {
-
- // 0 1 2 3 4 5 6 7 8 9 a b c d e f
- 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 00-0f
-@@ -180,7 +180,7 @@
- public static final String kRemoteTypeStr = "";
- public static final String kRemoteValueRepID = "";
-
-- public static final Hashtable kSpecialArrayTypeStrings = new Hashtable();
-+ private static final Hashtable kSpecialArrayTypeStrings = new Hashtable();
-
- static {
- kSpecialArrayTypeStrings.put("CORBA.WStringValue", new StringBuffer(java.lang.String.class.getName()));
-@@ -189,7 +189,7 @@
-
- }
-
-- public static final Hashtable kSpecialCasesRepIDs = new Hashtable();
-+ private static final Hashtable kSpecialCasesRepIDs = new Hashtable();
-
- static {
- kSpecialCasesRepIDs.put(java.lang.String.class, kWStringValueRepID);
-@@ -197,7 +197,7 @@
- kSpecialCasesRepIDs.put(java.rmi.Remote.class, kRemoteValueRepID);
- }
-
-- public static final Hashtable kSpecialCasesStubValues = new Hashtable();
-+ private static final Hashtable kSpecialCasesStubValues = new Hashtable();
-
- static {
- kSpecialCasesStubValues.put(java.lang.String.class, kWStringStubValue);
-@@ -209,7 +209,7 @@
- }
-
-
-- public static final Hashtable kSpecialCasesVersions = new Hashtable();
-+ private static final Hashtable kSpecialCasesVersions = new Hashtable();
-
- static {
- kSpecialCasesVersions.put(java.lang.String.class, kWStringValueHash);
-@@ -220,7 +220,7 @@
- kSpecialCasesVersions.put(java.rmi.Remote.class, kRemoteValueHash);
- }
-
-- public static final Hashtable kSpecialCasesClasses = new Hashtable();
-+ private static final Hashtable kSpecialCasesClasses = new Hashtable();
-
- static {
- kSpecialCasesClasses.put(kWStringTypeStr, java.lang.String.class);
-@@ -232,7 +232,7 @@
- //kSpecialCasesClasses.put(kRemoteTypeStr, java.rmi.Remote.class);
- }
-
-- public static final Hashtable kSpecialCasesArrayPrefix = new Hashtable();
-+ private static final Hashtable kSpecialCasesArrayPrefix = new Hashtable();
-
- static {
- kSpecialCasesArrayPrefix.put(java.lang.String.class, kValuePrefix + kSequencePrefix + kCORBAPrefix);
-@@ -243,7 +243,7 @@
- kSpecialCasesArrayPrefix.put(java.rmi.Remote.class, kValuePrefix + kSequencePrefix + kCORBAPrefix);
- }
-
-- public static final Hashtable kSpecialPrimitives = new Hashtable();
-+ private static final Hashtable kSpecialPrimitives = new Hashtable();
-
- static {
- kSpecialPrimitives.put("int","long");
---- corba/src/share/classes/com/sun/corba/se/impl/orbutil/RepositoryId_1_3_1.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/orbutil/RepositoryId_1_3_1.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2001, 2002, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2001, 2012, 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
-@@ -63,7 +63,7 @@
- // uniformly, and is safe because that is the only
- // legal use of '.' in a Java name.
-
-- public static final byte[] IDL_IDENTIFIER_CHARS = {
-+ private static final byte[] IDL_IDENTIFIER_CHARS = {
-
- // 0 1 2 3 4 5 6 7 8 9 a b c d e f
- 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 00-0f
-@@ -198,7 +198,7 @@
- public static final String kRemoteTypeStr = "";
- public static final String kRemoteValueRepID = "";
-
-- public static final Hashtable kSpecialArrayTypeStrings = new Hashtable();
-+ private static final Hashtable kSpecialArrayTypeStrings = new Hashtable();
-
- static {
- kSpecialArrayTypeStrings.put("CORBA.WStringValue", new StringBuffer(java.lang.String.class.getName()));
-@@ -207,7 +207,7 @@
-
- }
-
-- public static final Hashtable kSpecialCasesRepIDs = new Hashtable();
-+ private static final Hashtable kSpecialCasesRepIDs = new Hashtable();
-
- static {
- kSpecialCasesRepIDs.put(java.lang.String.class, kWStringValueRepID);
-@@ -215,7 +215,7 @@
- kSpecialCasesRepIDs.put(java.rmi.Remote.class, kRemoteValueRepID);
- }
-
-- public static final Hashtable kSpecialCasesStubValues = new Hashtable();
-+ private static final Hashtable kSpecialCasesStubValues = new Hashtable();
-
- static {
- kSpecialCasesStubValues.put(java.lang.String.class, kWStringStubValue);
-@@ -227,7 +227,7 @@
- }
-
-
-- public static final Hashtable kSpecialCasesVersions = new Hashtable();
-+ private static final Hashtable kSpecialCasesVersions = new Hashtable();
-
- static {
- kSpecialCasesVersions.put(java.lang.String.class, kWStringValueHash);
-@@ -238,7 +238,7 @@
- kSpecialCasesVersions.put(java.rmi.Remote.class, kRemoteValueHash);
- }
-
-- public static final Hashtable kSpecialCasesClasses = new Hashtable();
-+ private static final Hashtable kSpecialCasesClasses = new Hashtable();
-
- static {
- kSpecialCasesClasses.put(kWStringTypeStr, java.lang.String.class);
-@@ -250,7 +250,7 @@
- //kSpecialCasesClasses.put(kRemoteTypeStr, java.rmi.Remote.class);
- }
-
-- public static final Hashtable kSpecialCasesArrayPrefix = new Hashtable();
-+ private static final Hashtable kSpecialCasesArrayPrefix = new Hashtable();
-
- static {
- kSpecialCasesArrayPrefix.put(java.lang.String.class, kValuePrefix + kSequencePrefix + kCORBAPrefix);
-@@ -261,7 +261,7 @@
- kSpecialCasesArrayPrefix.put(java.rmi.Remote.class, kValuePrefix + kSequencePrefix + kCORBAPrefix);
- }
-
-- public static final Hashtable kSpecialPrimitives = new Hashtable();
-+ private static final Hashtable kSpecialPrimitives = new Hashtable();
-
- static {
- kSpecialPrimitives.put("int","long");
---- corba/src/share/classes/com/sun/corba/se/impl/protocol/LocalClientRequestDispatcherBase.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/protocol/LocalClientRequestDispatcherBase.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2002, 2012, 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
-@@ -52,7 +52,7 @@
-
- // If isNextIsLocalValid.get() == Boolean.TRUE,
- // the next call to isLocal should be valid
-- protected static ThreadLocal isNextCallValid = new ThreadLocal() {
-+ private static final ThreadLocal isNextCallValid = new ThreadLocal() {
- protected synchronized Object initialValue() {
- return Boolean.TRUE;
- }
---- corba/src/share/classes/com/sun/corba/se/impl/util/RepositoryId.java 2012-05-01 17:14:05.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/impl/util/RepositoryId.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2004, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -57,7 +57,7 @@
- // uniformly, and is safe because that is the only
- // legal use of '.' in a Java name.
-
-- public static final byte[] IDL_IDENTIFIER_CHARS = {
-+ private static final byte[] IDL_IDENTIFIER_CHARS = {
-
- // 0 1 2 3 4 5 6 7 8 9 a b c d e f
- 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 00-0f
-@@ -95,7 +95,7 @@
- private static IdentityHashtable classIDLToRepStr = new IdentityHashtable();
- private static IdentityHashtable classSeqToRepStr = new IdentityHashtable();
-
-- private static IdentityHashtable repStrToByteArray = new IdentityHashtable();
-+ private static final IdentityHashtable repStrToByteArray = new IdentityHashtable();
- private static Hashtable repStrToClass = new Hashtable();
-
- private String repId = null;
-@@ -192,7 +192,7 @@
- public static final String kRemoteTypeStr = "";
- public static final String kRemoteValueRepID = "";
-
-- public static final Hashtable kSpecialArrayTypeStrings = new Hashtable();
-+ private static final Hashtable kSpecialArrayTypeStrings = new Hashtable();
-
- static {
- kSpecialArrayTypeStrings.put("CORBA.WStringValue", new StringBuffer(java.lang.String.class.getName()));
-@@ -201,7 +201,7 @@
-
- }
-
-- public static final Hashtable kSpecialCasesRepIDs = new Hashtable();
-+ private static final Hashtable kSpecialCasesRepIDs = new Hashtable();
-
- static {
- kSpecialCasesRepIDs.put(java.lang.String.class, kWStringValueRepID);
-@@ -209,7 +209,7 @@
- kSpecialCasesRepIDs.put(java.rmi.Remote.class, kRemoteValueRepID);
- }
-
-- public static final Hashtable kSpecialCasesStubValues = new Hashtable();
-+ private static final Hashtable kSpecialCasesStubValues = new Hashtable();
-
- static {
- kSpecialCasesStubValues.put(java.lang.String.class, kWStringStubValue);
-@@ -221,7 +221,7 @@
- }
-
-
-- public static final Hashtable kSpecialCasesVersions = new Hashtable();
-+ private static final Hashtable kSpecialCasesVersions = new Hashtable();
-
- static {
- kSpecialCasesVersions.put(java.lang.String.class, kWStringValueHash);
-@@ -232,7 +232,7 @@
- kSpecialCasesVersions.put(java.rmi.Remote.class, kRemoteValueHash);
- }
-
-- public static final Hashtable kSpecialCasesClasses = new Hashtable();
-+ private static final Hashtable kSpecialCasesClasses = new Hashtable();
-
- static {
- kSpecialCasesClasses.put(kWStringTypeStr, java.lang.String.class);
-@@ -244,7 +244,7 @@
- //kSpecialCasesClasses.put(kRemoteTypeStr, java.rmi.Remote.class);
- }
-
-- public static final Hashtable kSpecialCasesArrayPrefix = new Hashtable();
-+ private static final Hashtable kSpecialCasesArrayPrefix = new Hashtable();
-
- static {
- kSpecialCasesArrayPrefix.put(java.lang.String.class, kValuePrefix + kSequencePrefix + kCORBAPrefix);
-@@ -255,7 +255,7 @@
- kSpecialCasesArrayPrefix.put(java.rmi.Remote.class, kValuePrefix + kSequencePrefix + kCORBAPrefix);
- }
-
-- public static final Hashtable kSpecialPrimitives = new Hashtable();
-+ private static final Hashtable kSpecialPrimitives = new Hashtable();
-
- static {
- kSpecialPrimitives.put("int","long");
---- corba/src/share/classes/com/sun/corba/se/spi/logging/CORBALogDomains.java 2012-05-01 17:14:06.000000000 -0400
-+++ corba/src/share/classes/com/sun/corba/se/spi/logging/CORBALogDomains.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2003, 2012, 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
-@@ -58,7 +58,7 @@
- private CORBALogDomains() {}
-
- // Top level log domain for CORBA
-- public static String TOP_LEVEL_DOMAIN = "javax.enterprise.resource.corba";
-+ public static final String TOP_LEVEL_DOMAIN = "javax.enterprise.resource.corba";
-
- public static final String RPC = "rpc" ;
-
---- corba/src/share/classes/sun/rmi/rmic/iiop/IDLNames.java 2012-05-01 17:14:07.000000000 -0400
-+++ corba/src/share/classes/sun/rmi/rmic/iiop/IDLNames.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -71,6 +71,34 @@
- (byte)'F',
- };
-
-+ // Legal IDL Identifier characters (1 = legal). Note
-+ // that '.' (2E) is marked as legal even though it is
-+ // not legal in IDL. This allows us to treat a fully
-+ // qualified Java name with '.' package separators
-+ // uniformly, and is safe because that is the only
-+ // legal use of '.' in a Java name.
-+
-+ private static final byte[] IDL_IDENTIFIER_CHARS = {
-+
-+ // 0 1 2 3 4 5 6 7 8 9 a b c d e f
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 00-0f
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 10-1f
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,1,0, // 20-2f
-+ 1,1,1,1, 1,1,1,1, 1,1,0,0, 0,0,0,0, // 30-3f
-+ 0,1,1,1, 1,1,1,1, 1,1,1,1, 1,1,1,1, // 40-4f
-+ 1,1,1,1, 1,1,1,1, 1,1,1,0, 0,0,0,1, // 50-5f
-+ 0,1,1,1, 1,1,1,1, 1,1,1,1, 1,1,1,1, // 60-6f
-+ 1,1,1,1, 1,1,1,1, 1,1,1,0, 0,0,0,0, // 70-7f
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 80-8f
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // 90-9f
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // a0-af
-+ 0,0,0,0, 0,0,0,0, 0,0,0,0, 0,0,0,0, // b0-bf
-+ 1,1,1,1, 1,1,1,1, 1,1,1,1, 1,1,1,1, // c0-cf
-+ 0,1,1,1, 1,1,1,0, 1,1,1,1, 1,0,0,1, // d0-df
-+ 1,1,1,1, 1,1,1,1, 1,1,1,1, 1,1,1,1, // e0-ef
-+ 0,1,1,1, 1,1,1,0, 1,1,1,1, 1,0,0,1, // f0-ff
-+ };
-+
- //_____________________________________________________________________
- // Public Interfaces
- //_____________________________________________________________________
-@@ -139,7 +167,7 @@
- result = replace(result,"x\\U","U");
-
- // Now see if we have any remaining illegal characters (see
-- // RepositoryId.IDL_IDENTIFIER_CHARS array)...
-+ // IDL_IDENTIFIER_CHARS array)...
-
- int length = result.length();
- StringBuffer buffer = null;
-@@ -148,7 +176,7 @@
-
- char c = result.charAt(i);
-
-- if (c > 255 || RepositoryId.IDL_IDENTIFIER_CHARS[c] == 0) {
-+ if (c > 255 || IDL_IDENTIFIER_CHARS[c] == 0) {
-
- // We gotta convert. Have we already started?
-
---- corba/src/share/classes/sun/rmi/rmic/iiop/StubGenerator.java 2012-05-01 17:14:07.000000000 -0400
-+++ corba/src/share/classes/sun/rmi/rmic/iiop/StubGenerator.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -425,7 +425,7 @@
- // Write the _ids() method...
-
- p.plnI("public String[] _ids() { ");
-- p.pln("return _type_ids;");
-+ p.pln("return (String[]) _type_ids.clone();");
- p.pOln("}");
-
- // Get all the methods and write each stub method...
-@@ -1860,11 +1860,11 @@
- {
- if(POATie){
- p.plnI("public String[] _all_interfaces(org.omg.PortableServer.POA poa, byte[] objectId){");
-- p.pln("return _type_ids;");
-+ p.pln("return (String[]) _type_ids.clone();");
- p.pOln("}");
- } else {
- p.plnI("public String[] _ids() { ");
-- p.pln("return _type_ids;");
-+ p.pln("return (String[]) _type_ids.clone();");
- p.pOln("}");
- }
- }
---- hotspot/src/share/vm/ci/ciField.cpp 2012-05-01 17:15:10.000000000 -0400
-+++ hotspot/src/share/vm/ci/ciField.cpp 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1999, 2012, 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
-@@ -67,7 +67,7 @@
-
- // ------------------------------------------------------------------
- // ciField::ciField
--ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with(NULL) {
-+ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with_put(NULL), _known_to_link_with_get(NULL) {
- ASSERT_IN_VM;
- CompilerThread *thread = CompilerThread::current();
-
-@@ -143,7 +143,7 @@
- initialize_from(&field_desc);
- }
-
--ciField::ciField(fieldDescriptor *fd): _known_to_link_with(NULL) {
-+ciField::ciField(fieldDescriptor *fd): _known_to_link_with_put(NULL), _known_to_link_with_get(NULL) {
- ASSERT_IN_VM;
-
- _cp_index = -1;
-@@ -312,6 +312,10 @@
- bool ciField::will_link(ciInstanceKlass* accessing_klass,
- Bytecodes::Code bc) {
- VM_ENTRY_MARK;
-+ assert(bc == Bytecodes::_getstatic || bc == Bytecodes::_putstatic ||
-+ bc == Bytecodes::_getfield || bc == Bytecodes::_putfield,
-+ "unexpected bytecode");
-+
- if (_offset == -1) {
- // at creation we couldn't link to our holder so we need to
- // maintain that stance, otherwise there's no safe way to use this
-@@ -319,8 +323,22 @@
- return false;
- }
-
-- if (_known_to_link_with == accessing_klass) {
-- return true;
-+ // Check for static/nonstatic mismatch
-+ bool is_static = (bc == Bytecodes::_getstatic || bc == Bytecodes::_putstatic);
-+ if (is_static != this->is_static()) {
-+ return false;
-+ }
-+
-+ // Get and put can have different accessibility rules
-+ bool is_put = (bc == Bytecodes::_putfield || bc == Bytecodes::_putstatic);
-+ if (is_put) {
-+ if (_known_to_link_with_put == accessing_klass) {
-+ return true;
-+ }
-+ } else {
-+ if (_known_to_link_with_get == accessing_klass) {
-+ return true;
-+ }
- }
-
- FieldAccessInfo result;
-@@ -331,8 +349,13 @@
- true, false, KILL_COMPILE_ON_FATAL_(false));
-
- // update the hit-cache, unless there is a problem with memory scoping:
-- if (accessing_klass->is_shared() || !is_shared())
-- _known_to_link_with = accessing_klass;
-+ if (accessing_klass->is_shared() || !is_shared()) {
-+ if (is_put) {
-+ _known_to_link_with_put = accessing_klass;
-+ } else {
-+ _known_to_link_with_get = accessing_klass;
-+ }
-+ }
-
- return true;
- }
---- hotspot/src/share/vm/ci/ciField.hpp 2012-05-01 17:15:10.000000000 -0400
-+++ hotspot/src/share/vm/ci/ciField.hpp 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1999, 2012, 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
-@@ -49,7 +49,8 @@
- ciType* _type;
- int _offset;
- bool _is_constant;
-- ciInstanceKlass* _known_to_link_with;
-+ ciInstanceKlass* _known_to_link_with_put;
-+ ciInstanceKlass* _known_to_link_with_get;
- ciConstant _constant_value;
-
- // Used for will_link
---- hotspot/src/share/vm/classfile/verifier.cpp 2012-05-01 17:15:10.000000000 -0400
-+++ hotspot/src/share/vm/classfile/verifier.cpp 2012-09-05 19:34:26.000000000 -0400
-@@ -1871,10 +1871,10 @@
- VerificationType type = current_frame->pop_stack(
- VerificationType::reference_check(), CHECK_VERIFY(this));
- if (type == VerificationType::uninitialized_this_type()) {
-- // The method must be an <init> method of either this class, or one of its
-- // superclasses
-+ // The method must be an <init> method of this class or its superclass
-+ klassOop superk = current_class()->super();
- if (ref_class_type.name() != current_class()->name() &&
-- !name_in_supers(ref_class_type.name(), current_class())) {
-+ ref_class_type.name() != superk->klass_part()->name()) {
- verify_error(bci, "Bad <init> method call");
- return;
- }
---- hotspot/src/share/vm/compiler/compilerOracle.cpp 2012-05-01 17:15:10.000000000 -0400
-+++ hotspot/src/share/vm/compiler/compilerOracle.cpp 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2010, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -551,13 +551,22 @@
- }
-
- static const char* cc_file() {
-- if (CompileCommandFile == NULL)
-+#ifdef ASSERT
-+ if (CompileCommandFile == NULL) {
- return ".hotspot_compiler";
-+ }
-+#endif
- return CompileCommandFile;
- }
-+
-+bool CompilerOracle::has_command_file() {
-+ return cc_file() != NULL;
-+}
-+
- bool CompilerOracle::_quiet = false;
-
- void CompilerOracle::parse_from_file() {
-+ assert(has_command_file(), "command file must be specified");
- FILE* stream = fopen(cc_file(), "rt");
- if (stream == NULL) return;
-
-@@ -600,6 +609,7 @@
- }
-
- void CompilerOracle::append_comment_to_file(const char* message) {
-+ assert(has_command_file(), "command file must be specified");
- fileStream stream(fopen(cc_file(), "at"));
- stream.print("# ");
- for (int index = 0; message[index] != '\0'; index++) {
-@@ -610,6 +620,7 @@
- }
-
- void CompilerOracle::append_exclude_to_file(methodHandle method) {
-+ assert(has_command_file(), "command file must be specified");
- fileStream stream(fopen(cc_file(), "at"));
- stream.print("exclude ");
- Klass::cast(method->method_holder())->name()->print_symbol_on(&stream);
-@@ -624,7 +635,9 @@
- void compilerOracle_init() {
- CompilerOracle::parse_from_string(CompileCommand, CompilerOracle::parse_from_line);
- CompilerOracle::parse_from_string(CompileOnly, CompilerOracle::parse_compile_only);
-- CompilerOracle::parse_from_file();
-+ if (CompilerOracle::has_command_file()) {
-+ CompilerOracle::parse_from_file();
-+ }
- if (lists[PrintCommand] != NULL) {
- if (PrintAssembly) {
- warning("CompileCommand and/or .hotspot_compiler file contains 'print' commands, but PrintAssembly is also enabled");
---- hotspot/src/share/vm/compiler/compilerOracle.hpp 2012-05-01 17:15:10.000000000 -0400
-+++ hotspot/src/share/vm/compiler/compilerOracle.hpp 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2010, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -38,6 +38,10 @@
- static bool _quiet;
-
- public:
-+
-+ // True if the command file has been specified or is implicit
-+ static bool has_command_file();
-+
- // Reads from file and adds to lists
- static void parse_from_file();
-
---- hotspot/src/share/vm/opto/runtime.cpp 2012-05-01 17:15:13.000000000 -0400
-+++ hotspot/src/share/vm/opto/runtime.cpp 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2010, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -804,7 +804,8 @@
- methodOop method = ((nmethod*)n)->method();
- tty->print_cr("# Method where it happened %s.%s ", Klass::cast(method->method_holder())->name()->as_C_string(), method->name()->as_C_string());
- tty->print_cr("#");
-- if (ShowMessageBoxOnError && UpdateHotSpotCompilerFileOnError) {
-+ if (ShowMessageBoxOnError && UpdateHotSpotCompilerFileOnError &&
-+ CompilerOracle::has_command_file()) {
- const char* title = "HotSpot Runtime Error";
- const char* question = "Do you want to exclude compilation of this method in future runs?";
- if (os::message_box(title, question)) {
---- hotspot/src/share/vm/runtime/arguments.cpp 2012-05-01 17:15:13.000000000 -0400
-+++ hotspot/src/share/vm/runtime/arguments.cpp 2012-09-05 19:34:26.000000000 -0400
-@@ -2956,12 +2956,14 @@
- }
- }
-
-+#ifdef ASSERT
- // Parse default .hotspotrc settings file
- if (!settings_file_specified) {
- if (!process_settings_file(".hotspotrc", false, args->ignoreUnrecognized)) {
- return JNI_EINVAL;
- }
- }
-+#endif
-
- if (PrintVMOptions) {
- for (index = 0; index < args->nOptions; index++) {
---- jaxp/build.properties 2012-05-01 17:15:26.000000000 -0400
-+++ jaxp/build.properties 2012-09-05 19:34:26.000000000 -0400
-@@ -77,6 +77,9 @@
- # Where patches to drop bundle sources live
- patches.dir=patches
-
-+# Patches to apply
-+jaxp_src.patch.list=7157609.patch
-+
- # Sanity information
- sanity.info= Sanity Settings:${line.separator}\
- ant.home=${ant.home}${line.separator}\
---- jaxp/patches/jaxp_src/7157609.patch 1969-12-31 19:00:00.000000000 -0500
-+++ jaxp/patches/jaxp_src/7157609.patch 2012-09-05 19:34:26.000000000 -0400
-@@ -0,0 +1,38 @@
-+# HG changeset patch
-+# User joehw
-+# Date 1333729977 25200
-+# Node ID abc9f6855a61c74ca11183ec49fcbbb9e4fa29b1
-+# Parent 3f8b55667a6f9d093fcaf4a70c784c426b00685b
-+7157609: Issues with loop
-+Reviewed-by: hawtin, lancea
-+
-+diff --git a/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java b/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java
-+--- src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java
-++++ src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java
-+@@ -402,6 +402,16 @@ public abstract class XMLScanner
-+
-+ boolean dataFoundForTarget = false;
-+ boolean sawSpace = fEntityScanner.skipSpaces();
-++ // since pseudoattributes are *not* attributes,
-++ // their quotes don't need to be preserved in external parameter entities.
-++ // the XMLEntityScanner#scanLiteral method will continue to
-++ // emit -1 in such cases when it finds a quote; this is
-++ // fine for other methods that parse scanned entities,
-++ // but not for the scanning of pseudoattributes. So,
-++ // temporarily, we must mark the current entity as not being "literal"
-++ Entity.ScannedEntity currEnt = fEntityManager.getCurrentEntity();
-++ boolean currLiteral = currEnt.literal;
-++ currEnt.literal = false;
-+ while (fEntityScanner.peekChar() != '?') {
-+ dataFoundForTarget = true;
-+ String name = scanPseudoAttribute(scanningTextDecl, fString);
-+@@ -499,6 +509,9 @@ public abstract class XMLScanner
-+ }
-+ sawSpace = fEntityScanner.skipSpaces();
-+ }
-++ // restore original literal value
-++ if(currLiteral)
-++ currEnt.literal = true;
-+ // REVISIT: should we remove this error reporting?
-+ if (scanningTextDecl && state != STATE_DONE) {
-+ reportFatalError("MorePseudoAttributes", null);
---- jdk/make/com/sun/jmx/Makefile 2012-05-01 17:17:59.000000000 -0400
-+++ jdk/make/com/sun/jmx/Makefile 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- #
--# Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
-+# Copyright (c) 2003, 2012, 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
-@@ -98,6 +98,21 @@
- # so that *_tie classes are generated in package without the prefix
- # org.omg.stub (6375696)
- #
-+# To ensure the latest stub generator files are picked up from corba repo
-+# when available, we need to run with latest rmic version available. rmic
-+# launch tool not built at this stage but we can invoke via rmi class.
-+
-+RMIC_JAVA = $(OUTPUTDIR)/bin/java
-+# need to treat 64bit solaris differently
-+ifeq ($(PLATFORM)-$(LIBARCH), solaris-amd64)
-+RMIC_JAVA = $(OUTPUTDIR)/bin/amd64/java
-+endif
-+ifeq ($(PLATFORM)-$(LIBARCH), solaris-sparcv9)
-+RMIC_JAVA = $(OUTPUTDIR)/bin/sparcv9/java
-+endif
-+
-+RMIC = $(RMIC_JAVA) $(JAVA_TOOLS_FLAGS) -cp $(OUTPUTDIR)/classes sun.rmi.rmic.Main
-+
- $(CLASSDESTDIR)/%_Stub.class: $(CLASSDESTDIR)/%.class
- $(prep-target)
- $(RMIC) -classpath "$(CLASSDESTDIR)" \
---- jdk/make/sun/Makefile 2012-05-01 17:18:00.000000000 -0400
-+++ jdk/make/sun/Makefile 2012-09-05 19:35:34.000000000 -0400
-@@ -64,7 +64,7 @@
- SUBDIRS = jar security javazic misc net audio $(RENDER_SUBDIR) image \
- awt splashscreen $(XAWT_SUBDIR) $(MOTIF_SUBDIRS) \
- $(HEADLESS_SUBDIR) $(DGA_SUBDIR) \
-- font jpeg cmm applet rmi beans $(JDBC_SUBDIR) \
-+ font jpeg cmm applet rmi $(JDBC_SUBDIR) \
- jawt text nio launcher management $(ORG_SUBDIR) \
- native2ascii serialver tools jconsole
-
---- jdk/make/sun/beans/Makefile 2012-05-01 17:18:00.000000000 -0400
-+++ jdk/make/sun/beans/Makefile 2012-09-05 19:35:34.000000000 -0400
-@@ -1,43 +0,0 @@
--#
--# Copyright (c) 1997, 2005, 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. Oracle designates this
--# particular file as subject to the "Classpath" exception as provided
--# by Oracle in the LICENSE file that accompanied this code.
--#
--# 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.
--#
--
--#
--# Makefile for building sun.beans.*
--#
--
--BUILDDIR = ../..
--PACKAGE = sun.beans
--PRODUCT = sun
--include $(BUILDDIR)/common/Defs.gmk
--
--#
--# Files
--#
--AUTO_FILES_JAVA_DIRS = sun/beans
--
--#
--# Rules
--#
--include $(BUILDDIR)/common/Classes.gmk
---- jdk/src/share/classes/com/sun/beans/editors/BooleanEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/BooleanEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,76 @@
-+/*
-+ * Copyright (c) 2006, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "boolean" type.
-+ */
-+
-+import java.beans.*;
-+
-+public class BooleanEditor extends PropertyEditorSupport {
-+
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ return (value != null)
-+ ? value.toString()
-+ : "null";
-+ }
-+
-+ public String getAsText() {
-+ Object value = getValue();
-+ return (value instanceof Boolean)
-+ ? getValidName((Boolean) value)
-+ : "null";
-+ }
-+
-+ public void setAsText(String text) throws java.lang.IllegalArgumentException {
-+ if (text == null) {
-+ setValue(null);
-+ } else if (isValidName(true, text)) {
-+ setValue(Boolean.TRUE);
-+ } else if (isValidName(false, text)) {
-+ setValue(Boolean.FALSE);
-+ } else {
-+ throw new java.lang.IllegalArgumentException(text);
-+ }
-+ }
-+
-+ public String[] getTags() {
-+ return new String[] {getValidName(true), getValidName(false)};
-+ }
-+
-+ // the following method should be localized (4890258)
-+
-+ private String getValidName(boolean value) {
-+ return value ? "True" : "False";
-+ }
-+
-+ private boolean isValidName(boolean value, String name) {
-+ return getValidName(value).equalsIgnoreCase(name);
-+ }
-+}
---- jdk/src/share/classes/com/sun/beans/editors/ByteEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/ByteEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,48 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "byte" type.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+public class ByteEditor extends NumberEditor {
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ return (value != null)
-+ ? "((byte)" + value + ")"
-+ : "null";
-+ }
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Byte.decode(text));
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/ColorEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/ColorEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,212 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+import java.awt.*;
-+import java.beans.*;
-+
-+public class ColorEditor extends Panel implements PropertyEditor {
-+ public ColorEditor() {
-+ setLayout(null);
-+
-+ ourWidth = hPad;
-+
-+ // Create a sample color block bordered in black
-+ Panel p = new Panel();
-+ p.setLayout(null);
-+ p.setBackground(Color.black);
-+ sample = new Canvas();
-+ p.add(sample);
-+ sample.reshape(2, 2, sampleWidth, sampleHeight);
-+ add(p);
-+ p.reshape(ourWidth, 2, sampleWidth+4, sampleHeight+4);
-+ ourWidth += sampleWidth + 4 + hPad;
-+
-+ text = new TextField("", 14);
-+ add(text);
-+ text.reshape(ourWidth,0,100,30);
-+ ourWidth += 100 + hPad;
-+
-+ choser = new Choice();
-+ int active = 0;
-+ for (int i = 0; i < colorNames.length; i++) {
-+ choser.addItem(colorNames[i]);
-+ }
-+ add(choser);
-+ choser.reshape(ourWidth,0,100,30);
-+ ourWidth += 100 + hPad;
-+
-+ resize(ourWidth,40);
-+ }
-+
-+ public void setValue(Object o) {
-+ Color c = (Color)o;
-+ changeColor(c);
-+ }
-+
-+ public Dimension preferredSize() {
-+ return new Dimension(ourWidth, 40);
-+ }
-+
-+ public boolean keyUp(Event e, int key) {
-+ if (e.target == text) {
-+ try {
-+ setAsText(text.getText());
-+ } catch (IllegalArgumentException ex) {
-+ // Quietly ignore.
-+ }
-+ }
-+ return (false);
-+ }
-+
-+ public void setAsText(String s) throws java.lang.IllegalArgumentException {
-+ if (s == null) {
-+ changeColor(null);
-+ return;
-+ }
-+ int c1 = s.indexOf(',');
-+ int c2 = s.indexOf(',', c1+1);
-+ if (c1 < 0 || c2 < 0) {
-+ // Invalid string.
-+ throw new IllegalArgumentException(s);
-+ }
-+ try {
-+ int r = Integer.parseInt(s.substring(0,c1));
-+ int g = Integer.parseInt(s.substring(c1+1, c2));
-+ int b = Integer.parseInt(s.substring(c2+1));
-+ Color c = new Color(r,g,b);
-+ changeColor(c);
-+ } catch (Exception ex) {
-+ throw new IllegalArgumentException(s);
-+ }
-+
-+ }
-+
-+ public boolean action(Event e, Object arg) {
-+ if (e.target == choser) {
-+ changeColor(colors[choser.getSelectedIndex()]);
-+ }
-+ return false;
-+ }
-+
-+ public String getJavaInitializationString() {
-+ return (this.color != null)
-+ ? "new java.awt.Color(" + this.color.getRGB() + ",true)"
-+ : "null";
-+ }
-+
-+
-+ private void changeColor(Color c) {
-+
-+ if (c == null) {
-+ this.color = null;
-+ this.text.setText("");
-+ return;
-+ }
-+
-+ color = c;
-+
-+ text.setText("" + c.getRed() + "," + c.getGreen() + "," + c.getBlue());
-+
-+ int active = 0;
-+ for (int i = 0; i < colorNames.length; i++) {
-+ if (color.equals(colors[i])) {
-+ active = i;
-+ }
-+ }
-+ choser.select(active);
-+
-+ sample.setBackground(color);
-+ sample.repaint();
-+
-+ support.firePropertyChange("", null, null);
-+ }
-+
-+ public Object getValue() {
-+ return color;
-+ }
-+
-+ public boolean isPaintable() {
-+ return true;
-+ }
-+
-+ public void paintValue(java.awt.Graphics gfx, java.awt.Rectangle box) {
-+ Color oldColor = gfx.getColor();
-+ gfx.setColor(Color.black);
-+ gfx.drawRect(box.x, box.y, box.width-3, box.height-3);
-+ gfx.setColor(color);
-+ gfx.fillRect(box.x+1, box.y+1, box.width-4, box.height-4);
-+ gfx.setColor(oldColor);
-+ }
-+
-+ public String getAsText() {
-+ return (this.color != null)
-+ ? this.color.getRed() + "," + this.color.getGreen() + "," + this.color.getBlue()
-+ : "null";
-+ }
-+
-+ public String[] getTags() {
-+ return null;
-+ }
-+
-+ public java.awt.Component getCustomEditor() {
-+ return this;
-+ }
-+
-+ public boolean supportsCustomEditor() {
-+ return true;
-+ }
-+
-+ public void addPropertyChangeListener(PropertyChangeListener l) {
-+ support.addPropertyChangeListener(l);
-+ }
-+
-+ public void removePropertyChangeListener(PropertyChangeListener l) {
-+ support.removePropertyChangeListener(l);
-+ }
-+
-+
-+ private String colorNames[] = { " ", "white", "lightGray", "gray", "darkGray",
-+ "black", "red", "pink", "orange",
-+ "yellow", "green", "magenta", "cyan",
-+ "blue"};
-+ private Color colors[] = { null, Color.white, Color.lightGray, Color.gray, Color.darkGray,
-+ Color.black, Color.red, Color.pink, Color.orange,
-+ Color.yellow, Color.green, Color.magenta, Color.cyan,
-+ Color.blue};
-+
-+ private Canvas sample;
-+ private int sampleHeight = 20;
-+ private int sampleWidth = 40;
-+ private int hPad = 5;
-+ private int ourWidth;
-+
-+ private Color color;
-+ private TextField text;
-+ private Choice choser;
-+
-+ private PropertyChangeSupport support = new PropertyChangeSupport(this);
-+}
---- jdk/src/share/classes/com/sun/beans/editors/DoubleEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/DoubleEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,41 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "double" type.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+public class DoubleEditor extends NumberEditor {
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Double.valueOf(text));
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/EnumEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/EnumEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,142 @@
-+/*
-+ * Copyright (c) 2006, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+package com.sun.beans.editors;
-+
-+import java.awt.Component;
-+import java.awt.Graphics;
-+import java.awt.Rectangle;
-+import java.beans.PropertyChangeEvent;
-+import java.beans.PropertyChangeListener;
-+import java.beans.PropertyEditor;
-+import java.util.ArrayList;
-+import java.util.List;
-+
-+/**
-+ * Property editor for java.lang.Enum subclasses.
-+ *
-+ * @see PropertyEditor
-+ *
-+ * @since 1.7
-+ *
-+ * @author Sergey A. Malenkov
-+ */
-+public final class EnumEditor implements PropertyEditor {
-+ private final List<PropertyChangeListener> listeners = new ArrayList<PropertyChangeListener>();
-+
-+ private final Class type;
-+ private final String[] tags;
-+
-+ private Object value;
-+
-+ public EnumEditor( Class type ) {
-+ Object[] values = type.getEnumConstants();
-+ if ( values == null ) {
-+ throw new IllegalArgumentException( "Unsupported " + type );
-+ }
-+ this.type = type;
-+ this.tags = new String[values.length];
-+ for ( int i = 0; i < values.length; i++ ) {
-+ this.tags[i] = ( ( Enum )values[i] ).name();
-+ }
-+ }
-+
-+ public Object getValue() {
-+ return this.value;
-+ }
-+
-+ public void setValue( Object value ) {
-+ if ( ( value != null ) && !this.type.isInstance( value ) ) {
-+ throw new IllegalArgumentException( "Unsupported value: " + value );
-+ }
-+ Object oldValue;
-+ PropertyChangeListener[] listeners;
-+ synchronized ( this.listeners ) {
-+ oldValue = this.value;
-+ this.value = value;
-+
-+ if ( ( value == null ) ? oldValue == null : value.equals( oldValue ) ) {
-+ return; // do not fire event if value is not changed
-+ }
-+ int size = this.listeners.size();
-+ if ( size == 0 ) {
-+ return; // do not fire event if there are no any listener
-+ }
-+ listeners = this.listeners.toArray( new PropertyChangeListener[size] );
-+ }
-+ PropertyChangeEvent event = new PropertyChangeEvent( this, null, oldValue, value );
-+ for ( PropertyChangeListener listener : listeners ) {
-+ listener.propertyChange( event );
-+ }
-+ }
-+
-+ public String getAsText() {
-+ return ( this.value != null )
-+ ? ( ( Enum )this.value ).name()
-+ : "null";
-+ }
-+
-+ public void setAsText( String text ) {
-+ setValue( ( text != null )
-+ ? Enum.valueOf( this.type, text )
-+ : null );
-+ }
-+
-+ public String[] getTags() {
-+ return this.tags.clone();
-+ }
-+
-+ public String getJavaInitializationString() {
-+ return ( this.value != null )
-+ ? this.type.getName() + '.' + ( ( Enum )this.value ).name()
-+ : "null";
-+ }
-+
-+ public boolean isPaintable() {
-+ return false;
-+ }
-+
-+ public void paintValue( Graphics gfx, Rectangle box ) {
-+ }
-+
-+ public boolean supportsCustomEditor() {
-+ return false;
-+ }
-+
-+ public Component getCustomEditor() {
-+ return null;
-+ }
-+
-+ public void addPropertyChangeListener( PropertyChangeListener listener ) {
-+ synchronized ( this.listeners ) {
-+ this.listeners.add( listener );
-+ }
-+ }
-+
-+ public void removePropertyChangeListener( PropertyChangeListener listener ) {
-+ synchronized ( this.listeners ) {
-+ this.listeners.remove( listener );
-+ }
-+ }
-+}
---- jdk/src/share/classes/com/sun/beans/editors/FloatEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/FloatEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,48 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "float" type.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+public class FloatEditor extends NumberEditor {
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ return (value != null)
-+ ? value + "F"
-+ : "null";
-+ }
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Float.valueOf(text));
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/FontEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/FontEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,218 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+import java.awt.*;
-+import java.beans.*;
-+
-+public class FontEditor extends Panel implements java.beans.PropertyEditor {
-+
-+ public FontEditor() {
-+ setLayout(null);
-+
-+ toolkit = Toolkit.getDefaultToolkit();
-+ fonts = toolkit.getFontList();
-+
-+ familyChoser = new Choice();
-+ for (int i = 0; i < fonts.length; i++) {
-+ familyChoser.addItem(fonts[i]);
-+ }
-+ add(familyChoser);
-+ familyChoser.reshape(20, 5, 100, 30);
-+
-+ styleChoser = new Choice();
-+ for (int i = 0; i < styleNames.length; i++) {
-+ styleChoser.addItem(styleNames[i]);
-+ }
-+ add(styleChoser);
-+ styleChoser.reshape(145, 5, 70, 30);
-+
-+ sizeChoser = new Choice();
-+ for (int i = 0; i < pointSizes.length; i++) {
-+ sizeChoser.addItem("" + pointSizes[i]);
-+ }
-+ add(sizeChoser);
-+ sizeChoser.reshape(220, 5, 70, 30);
-+
-+ resize(300,40);
-+ }
-+
-+
-+ public Dimension preferredSize() {
-+ return new Dimension(300, 40);
-+ }
-+
-+ public void setValue(Object o) {
-+ font = (Font) o;
-+ if (this.font == null)
-+ return;
-+
-+ changeFont(font);
-+ // Update the current GUI choices.
-+ for (int i = 0; i < fonts.length; i++) {
-+ if (fonts[i].equals(font.getFamily())) {
-+ familyChoser.select(i);
-+ break;
-+ }
-+ }
-+ for (int i = 0; i < styleNames.length; i++) {
-+ if (font.getStyle() == styles[i]) {
-+ styleChoser.select(i);
-+ break;
-+ }
-+ }
-+ for (int i = 0; i < pointSizes.length; i++) {
-+ if (font.getSize() <= pointSizes[i]) {
-+ sizeChoser.select(i);
-+ break;
-+ }
-+ }
-+ }
-+
-+ private void changeFont(Font f) {
-+ font = f;
-+ if (sample != null) {
-+ remove(sample);
-+ }
-+ sample = new Label(sampleText);
-+ sample.setFont(font);
-+ add(sample);
-+ Component p = getParent();
-+ if (p != null) {
-+ p.invalidate();
-+ p.layout();
-+ }
-+ invalidate();
-+ layout();
-+ repaint();
-+ support.firePropertyChange("", null, null);
-+ }
-+
-+ public Object getValue() {
-+ return (font);
-+ }
-+
-+ public String getJavaInitializationString() {
-+ if (this.font == null)
-+ return "null";
-+
-+ return "new java.awt.Font(\"" + font.getName() + "\", " +
-+ font.getStyle() + ", " + font.getSize() + ")";
-+ }
-+
-+ public boolean action(Event e, Object arg) {
-+ String family = familyChoser.getSelectedItem();
-+ int style = styles[styleChoser.getSelectedIndex()];
-+ int size = pointSizes[sizeChoser.getSelectedIndex()];
-+ try {
-+ Font f = new Font(family, style, size);
-+ changeFont(f);
-+ } catch (Exception ex) {
-+ System.err.println("Couldn't create font " + family + "-" +
-+ styleNames[style] + "-" + size);
-+ }
-+ return (false);
-+ }
-+
-+
-+ public boolean isPaintable() {
-+ return true;
-+ }
-+
-+ public void paintValue(java.awt.Graphics gfx, java.awt.Rectangle box) {
-+ // Silent noop.
-+ Font oldFont = gfx.getFont();
-+ gfx.setFont(font);
-+ FontMetrics fm = gfx.getFontMetrics();
-+ int vpad = (box.height - fm.getAscent())/2;
-+ gfx.drawString(sampleText, 0, box.height-vpad);
-+ gfx.setFont(oldFont);
-+ }
-+
-+ public String getAsText() {
-+ if (this.font == null) {
-+ return "null";
-+ }
-+ StringBuilder sb = new StringBuilder();
-+ sb.append(this.font.getName());
-+ sb.append(' ');
-+
-+ boolean b = this.font.isBold();
-+ if (b) {
-+ sb.append("BOLD");
-+ }
-+ boolean i = this.font.isItalic();
-+ if (i) {
-+ sb.append("ITALIC");
-+ }
-+ if (b || i) {
-+ sb.append(' ');
-+ }
-+ sb.append(this.font.getSize());
-+ return sb.toString();
-+ }
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Font.decode(text));
-+ }
-+
-+ public String[] getTags() {
-+ return null;
-+ }
-+
-+ public java.awt.Component getCustomEditor() {
-+ return this;
-+ }
-+
-+ public boolean supportsCustomEditor() {
-+ return true;
-+ }
-+
-+ public void addPropertyChangeListener(PropertyChangeListener l) {
-+ support.addPropertyChangeListener(l);
-+ }
-+
-+ public void removePropertyChangeListener(PropertyChangeListener l) {
-+ support.removePropertyChangeListener(l);
-+ }
-+
-+ private Font font;
-+ private Toolkit toolkit;
-+ private String sampleText = "Abcde...";
-+
-+ private Label sample;
-+ private Choice familyChoser;
-+ private Choice styleChoser;
-+ private Choice sizeChoser;
-+
-+ private String fonts[];
-+ private String[] styleNames = { "plain", "bold", "italic" };
-+ private int[] styles = { Font.PLAIN, Font.BOLD, Font.ITALIC };
-+ private int[] pointSizes = { 3, 5, 8, 10, 12, 14, 18, 24, 36, 48 };
-+
-+ private PropertyChangeSupport support = new PropertyChangeSupport(this);
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/IntegerEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/IntegerEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,42 @@
-+/*
-+ * Copyright (c) 2006, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "int" type.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+public class IntegerEditor extends NumberEditor {
-+
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Integer.decode(text));
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/LongEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/LongEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,48 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "long" type.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+public class LongEditor extends NumberEditor {
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ return (value != null)
-+ ? value + "L"
-+ : "null";
-+ }
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Long.decode(text));
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/NumberEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/NumberEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,44 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Abstract Property editor for a java builtin number types.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+abstract public class NumberEditor extends PropertyEditorSupport {
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ return (value != null)
-+ ? value.toString()
-+ : "null";
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/ShortEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/ShortEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,49 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+
-+package com.sun.beans.editors;
-+
-+/**
-+ * Property editor for a java builtin "short" type.
-+ *
-+ */
-+
-+import java.beans.*;
-+
-+public class ShortEditor extends NumberEditor {
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ return (value != null)
-+ ? "((short)" + value + ")"
-+ : "null";
-+ }
-+
-+ public void setAsText(String text) throws IllegalArgumentException {
-+ setValue((text == null) ? null : Short.decode(text));
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/editors/StringEditor.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/editors/StringEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,74 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+
-+package com.sun.beans.editors;
-+
-+import java.beans.*;
-+
-+public class StringEditor extends PropertyEditorSupport {
-+
-+ public String getJavaInitializationString() {
-+ Object value = getValue();
-+ if (value == null)
-+ return "null";
-+
-+ String str = value.toString();
-+ int length = str.length();
-+ StringBuilder sb = new StringBuilder(length + 2);
-+ sb.append('"');
-+ for (int i = 0; i < length; i++) {
-+ char ch = str.charAt(i);
-+ switch (ch) {
-+ case '\b': sb.append("\\b"); break;
-+ case '\t': sb.append("\\t"); break;
-+ case '\n': sb.append("\\n"); break;
-+ case '\f': sb.append("\\f"); break;
-+ case '\r': sb.append("\\r"); break;
-+ case '\"': sb.append("\\\""); break;
-+ case '\\': sb.append("\\\\"); break;
-+ default:
-+ if ((ch < ' ') || (ch > '~')) {
-+ sb.append("\\u");
-+ String hex = Integer.toHexString((int) ch);
-+ for (int len = hex.length(); len < 4; len++) {
-+ sb.append('0');
-+ }
-+ sb.append(hex);
-+ } else {
-+ sb.append(ch);
-+ }
-+ break;
-+ }
-+ }
-+ sb.append('"');
-+ return sb.toString();
-+ }
-+
-+ public void setAsText(String text) {
-+ setValue(text);
-+ }
-+
-+}
---- jdk/src/share/classes/com/sun/beans/finder/ClassFinder.java 2012-05-01 17:18:02.000000000 -0400
-+++ jdk/src/share/classes/com/sun/beans/finder/ClassFinder.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2006, 2012, 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
-@@ -24,6 +24,8 @@
- */
- package com.sun.beans.finder;
-
-+import static sun.reflect.misc.ReflectUtil.checkPackageAccess;
-+
- /**
- * This is utility class that provides <code>static</code> methods
- * to find a class with the specified name using the specified class loader.
-@@ -53,6 +55,7 @@
- * @see Thread#getContextClassLoader()
- */
- public static Class findClass( String name ) throws ClassNotFoundException {
-+ checkPackageAccess(name);
- try {
- ClassLoader loader = Thread.currentThread().getContextClassLoader();
- if ( loader == null ) {
-@@ -93,6 +96,7 @@
- * @see Class#forName(String,boolean,ClassLoader)
- */
- public static Class findClass( String name, ClassLoader loader ) throws ClassNotFoundException {
-+ checkPackageAccess(name);
- if ( loader != null ) {
- try {
- return Class.forName( name, false, loader );
---- jdk/src/share/classes/com/sun/beans/infos/ComponentBeanInfo.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/com/sun/beans/infos/ComponentBeanInfo.java 2012-09-05 19:35:34.000000000 -0400
-@@ -0,0 +1,62 @@
-+/*
-+ * Copyright (c) 1996, 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package com.sun.beans.infos;
-+
-+import java.beans.*;
-+
-+/**
-+ * BeanInfo descriptor for a standard AWT component.
-+ */
-+
-+public class ComponentBeanInfo extends SimpleBeanInfo {
-+ private static final Class beanClass = java.awt.Component.class;
-+
-+ public PropertyDescriptor[] getPropertyDescriptors() {
-+ try {
-+ PropertyDescriptor
-+ name = new PropertyDescriptor("name", beanClass),
-+ background = new PropertyDescriptor("background", beanClass),
-+ foreground = new PropertyDescriptor("foreground", beanClass),
-+ font = new PropertyDescriptor("font", beanClass),
-+ enabled = new PropertyDescriptor("enabled", beanClass),
-+ visible = new PropertyDescriptor("visible", beanClass),
-+ focusable = new PropertyDescriptor("focusable", beanClass);
-+
-+ enabled.setExpert(true);
-+ visible.setHidden(true);
-+
-+ background.setBound(true);
-+ foreground.setBound(true);
-+ font.setBound(true);
-+ focusable.setBound(true);
-+
-+ PropertyDescriptor[] rv = {name, background, foreground, font, enabled, visible, focusable };
-+ return rv;
-+ } catch (IntrospectionException e) {
-+ throw new Error(e.toString());
-+ }
-+ }
-+}
---- jdk/src/share/classes/com/sun/java/util/jar/pack/Driver.java 2012-05-01 17:18:04.000000000 -0400
-+++ jdk/src/share/classes/com/sun/java/util/jar/pack/Driver.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2003, 2005, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2003, 2012, 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
-@@ -354,8 +354,7 @@
- where = new File(".").getAbsoluteFile();
-
-
-- File f = File.createTempFile(prefix, suffix, where);
-- return f;
-+ return sun.misc.IOUtils.createTempFile(prefix, suffix, where);
- }
-
- static private
---- jdk/src/share/classes/java/awt/AWTEvent.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/AWTEvent.java 2012-09-05 19:35:40.000000000 -0400
-@@ -268,9 +268,21 @@
- return ev.isSystemGenerated;
- }
-
-+ public void setPosted(AWTEvent ev) {
-+ ev.isPosted = true;
-+ }
-+
- public AccessControlContext getAccessControlContext(AWTEvent ev) {
- return ev.getAccessControlContext();
- }
-+
-+ public byte[] getBData(AWTEvent ev) {
-+ return ev.bdata;
-+ }
-+
-+ public void setBData(AWTEvent ev, byte[] bdata) {
-+ ev.bdata = bdata;
-+ }
- });
- }
-
---- jdk/src/share/classes/java/awt/CheckboxMenuItem.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/CheckboxMenuItem.java 2012-09-05 19:35:40.000000000 -0400
-@@ -31,6 +31,7 @@
- import java.io.ObjectInputStream;
- import java.io.IOException;
- import javax.accessibility.*;
-+import sun.awt.AWTAccessor;
-
-
- /**
-@@ -68,6 +69,13 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+
-+ AWTAccessor.setCheckboxMenuItemAccessor(
-+ new AWTAccessor.CheckboxMenuItemAccessor() {
-+ public boolean getState(CheckboxMenuItem cmi) {
-+ return cmi.state;
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/awt/Component.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/Component.java 2012-09-05 19:35:40.000000000 -0400
-@@ -798,10 +798,25 @@
-
- static {
- AWTAccessor.setComponentAccessor(new AWTAccessor.ComponentAccessor() {
-+ public AppContext getAppContext(Component comp) {
-+ return comp.appContext;
-+ }
-+
-+ public void setAppContext(Component comp, AppContext appContext) {
-+ comp.appContext = appContext;
-+ }
-+
- public AccessControlContext getAccessControlContext(Component comp) {
- return comp.getAccessControlContext();
- }
-
-+ public boolean requestFocusInWindow(Component comp, CausedFocusEvent.Cause cause) {
-+ return comp.requestFocusInWindow(cause);
-+ }
-+
-+ public void requestFocus(Component comp, CausedFocusEvent.Cause cause) {
-+ comp.requestFocus(cause);
-+ }
- });
- }
-
---- jdk/src/share/classes/java/awt/Cursor.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/Cursor.java 2012-09-05 19:35:40.000000000 -0400
-@@ -38,6 +38,7 @@
- import java.util.logging.*;
-
- import java.security.AccessController;
-+import sun.awt.AWTAccessor;
-
- /**
- * A class to encapsulate the bitmap representation of the mouse cursor.
-@@ -193,6 +194,21 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+
-+ AWTAccessor.setCursorAccessor(
-+ new AWTAccessor.CursorAccessor() {
-+ public long getPData(Cursor cursor) {
-+ return cursor.pData;
-+ }
-+
-+ public void setPData(Cursor cursor, long pData) {
-+ cursor.pData = pData;
-+ }
-+
-+ public int getType(Cursor cursor) {
-+ return cursor.type;
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/awt/DefaultKeyboardFocusManager.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/DefaultKeyboardFocusManager.java 2012-09-05 19:35:40.000000000 -0400
-@@ -40,6 +40,7 @@
-
- import sun.awt.AppContext;
- import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
- import sun.awt.CausedFocusEvent;
-
- /**
-@@ -76,6 +77,16 @@
- typeAheadMarkers = new LinkedList();
- private boolean consumeNextKeyTyped;
-
-+ static {
-+ AWTAccessor.setDefaultKeyboardFocusManagerAccessor(
-+ new AWTAccessor.DefaultKeyboardFocusManagerAccessor() {
-+ public void consumeNextKeyTyped(DefaultKeyboardFocusManager dkfm,
-+ KeyEvent e) {
-+ dkfm.consumeNextKeyTyped(e);
-+ }
-+ });
-+ }
-+
- private static class TypeAheadMarker {
- long after;
- Component untilFocused;
---- jdk/src/share/classes/java/awt/EventQueue.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/EventQueue.java 2012-09-05 19:35:40.000000000 -0400
-@@ -42,9 +42,9 @@
- import sun.awt.AWTAutoShutdown;
- import sun.awt.PeerEvent;
- import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- import java.security.AccessControlContext;
--import java.security.ProtectionDomain;
-
- import sun.misc.SharedSecrets;
- import sun.misc.JavaSecurityAccess;
-@@ -159,6 +159,26 @@
-
- private static final Logger eventLog = Logger.getLogger("java.awt.event.EventQueue");
-
-+ static {
-+ AWTAccessor.setEventQueueAccessor(
-+ new AWTAccessor.EventQueueAccessor() {
-+ public boolean noEvents(EventQueue eventQueue) {
-+ return eventQueue.noEvents();
-+ }
-+ public Thread getDispatchThread(EventQueue eventQueue) {
-+ return eventQueue.dispatchThread;
-+ }
-+ public EventQueue getNextQueue(EventQueue eventQueue) {
-+ return eventQueue.nextQueue;
-+ }
-+ public void removeSourceEvents(EventQueue eventQueue,
-+ Object source,
-+ boolean removeAllEvents) {
-+ eventQueue.removeSourceEvents(source, removeAllEvents);
-+ }
-+ });
-+ }
-+
- public EventQueue() {
- for (int i = 0; i < NUM_PRIORITIES; i++) {
- queues[i] = new Queue();
---- jdk/src/share/classes/java/awt/Font.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/Font.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1995, 2010, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1995, 2012, 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
-@@ -809,7 +809,7 @@
- File f = null;
- boolean hasPerm = false;
- try {
-- f = File.createTempFile("+~JT", ".tmp", null);
-+ f = sun.misc.IOUtils.createTempFile("+~JT", ".tmp", null);
- f.delete();
- f = null;
- hasPerm = true;
-@@ -860,7 +860,7 @@
- final File tFile = AccessController.doPrivileged(
- new PrivilegedExceptionAction<File>() {
- public File run() throws IOException {
-- return File.createTempFile("+~JF", ".tmp", null);
-+ return sun.misc.IOUtils.createTempFile("+~JF", ".tmp", null);
- }
- }
- );
---- jdk/src/share/classes/java/awt/KeyboardFocusManager.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/KeyboardFocusManager.java 2012-09-05 19:35:40.000000000 -0400
-@@ -60,6 +60,7 @@
- import sun.awt.HeadlessToolkit;
- import sun.awt.SunToolkit;
- import sun.awt.CausedFocusEvent;
-+import sun.awt.AWTAccessor;
-
- /**
- * The KeyboardFocusManager is responsible for managing the active and focused
-@@ -117,6 +118,24 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+ AWTAccessor.setKeyboardFocusManagerAccessor(
-+ new AWTAccessor.KeyboardFocusManagerAccessor() {
-+ public int shouldNativelyFocusHeavyweight(Component heavyweight,
-+ Component descendant,
-+ boolean temporary,
-+ boolean focusedWindowChangeAllowed,
-+ long time,
-+ CausedFocusEvent.Cause cause)
-+ {
-+ return KeyboardFocusManager.shouldNativelyFocusHeavyweight(
-+ heavyweight, descendant, temporary, focusedWindowChangeAllowed, time, cause);
-+ }
-+
-+ public void removeLastFocusRequest(Component heavyweight) {
-+ KeyboardFocusManager.removeLastFocusRequest(heavyweight);
-+ }
-+ }
-+ );
- }
-
- transient KeyboardFocusManagerPeer peer;
---- jdk/src/share/classes/java/awt/Menu.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/Menu.java 2012-09-05 19:35:40.000000000 -0400
-@@ -31,6 +31,7 @@
- import java.awt.peer.MenuPeer;
- import java.awt.event.KeyEvent;
- import javax.accessibility.*;
-+import sun.awt.AWTAccessor;
-
- /**
- * A <code>Menu</code> object is a pull-down menu component
-@@ -62,6 +63,12 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+ AWTAccessor.setMenuAccessor(
-+ new AWTAccessor.MenuAccessor() {
-+ public Vector getItems(Menu menu) {
-+ return menu.items;
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/awt/MenuBar.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/MenuBar.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,6 +28,7 @@
- import java.io.ObjectInputStream;
- import java.util.Vector;
- import java.util.Enumeration;
-+import sun.awt.AWTAccessor;
- import java.awt.peer.MenuBarPeer;
- import java.awt.event.KeyEvent;
- import javax.accessibility.*;
-@@ -74,6 +75,16 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+ AWTAccessor.setMenuBarAccessor(
-+ new AWTAccessor.MenuBarAccessor() {
-+ public Menu getHelpMenu(MenuBar menuBar) {
-+ return menuBar.helpMenu;
-+ }
-+
-+ public Vector getMenus(MenuBar menuBar) {
-+ return menuBar.menus;
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/awt/MenuComponent.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/MenuComponent.java 2012-09-05 19:35:40.000000000 -0400
-@@ -29,7 +29,7 @@
- import java.io.IOException;
- import java.io.ObjectInputStream;
- import sun.awt.AppContext;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
- import javax.accessibility.*;
-
- import java.security.AccessControlContext;
-@@ -55,6 +55,22 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+ AWTAccessor.setMenuComponentAccessor(
-+ new AWTAccessor.MenuComponentAccessor() {
-+ public AppContext getAppContext(MenuComponent menuComp) {
-+ return menuComp.appContext;
-+ }
-+ public void setAppContext(MenuComponent menuComp,
-+ AppContext appContext) {
-+ menuComp.appContext = appContext;
-+ }
-+ public MenuContainer getParent(MenuComponent menuComp) {
-+ return menuComp.parent;
-+ }
-+ public Font getFont_NoClientCode(MenuComponent menuComp) {
-+ return menuComp.getFont_NoClientCode();
-+ }
-+ });
- }
-
- transient MenuComponentPeer peer;
---- jdk/src/share/classes/java/awt/MenuItem.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/MenuItem.java 2012-09-05 19:35:40.000000000 -0400
-@@ -31,7 +31,7 @@
- import java.io.ObjectInputStream;
- import java.io.IOException;
- import javax.accessibility.*;
--
-+import sun.awt.AWTAccessor;
-
- /**
- * All items in a menu must belong to the class
-@@ -76,6 +76,29 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+
-+ AWTAccessor.setMenuItemAccessor(
-+ new AWTAccessor.MenuItemAccessor() {
-+ public boolean isEnabled(MenuItem item) {
-+ return item.enabled;
-+ }
-+
-+ public String getLabel(MenuItem item) {
-+ return item.label;
-+ }
-+
-+ public MenuShortcut getShortcut(MenuItem item) {
-+ return item.shortcut;
-+ }
-+
-+ public String getActionCommandImpl(MenuItem item) {
-+ return item.getActionCommandImpl();
-+ }
-+
-+ public boolean isItemEnabled(MenuItem item) {
-+ return item.isItemEnabled();
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/awt/PopupMenu.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/PopupMenu.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,6 +28,7 @@
- import java.awt.peer.PopupMenuPeer;
- import javax.accessibility.*;
-
-+import sun.awt.AWTAccessor;
-
- /**
- * A class that implements a menu which can be dynamically popped up
-@@ -48,6 +49,15 @@
-
- transient boolean isTrayIconPopup = false;
-
-+ static {
-+ AWTAccessor.setPopupMenuAccessor(
-+ new AWTAccessor.PopupMenuAccessor() {
-+ public boolean isTrayIconPopup(PopupMenu popupMenu) {
-+ return popupMenu.isTrayIconPopup;
-+ }
-+ });
-+ }
-+
- /*
- * JDK 1.1 serialVersionUID
- */
---- jdk/src/share/classes/java/awt/ScrollPaneAdjustable.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/ScrollPaneAdjustable.java 2012-09-05 19:35:40.000000000 -0400
-@@ -24,6 +24,8 @@
- */
- package java.awt;
-
-+import sun.awt.AWTAccessor;
-+
- import java.awt.event.AdjustmentEvent;
- import java.awt.event.AdjustmentListener;
- import java.awt.peer.ScrollPanePeer;
-@@ -156,6 +158,12 @@
- if (!GraphicsEnvironment.isHeadless()) {
- initIDs();
- }
-+ AWTAccessor.setScrollPaneAdjustableAccessor(new AWTAccessor.ScrollPaneAdjustableAccessor() {
-+ public void setTypedValue(final ScrollPaneAdjustable adj,
-+ final int v, final int type) {
-+ adj.setTypedValue(v, type);
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/awt/Window.java 2012-05-01 17:18:08.000000000 -0400
-+++ jdk/src/share/classes/java/awt/Window.java 2012-09-05 19:35:40.000000000 -0400
-@@ -50,6 +50,7 @@
- import java.util.logging.Logger;
- import java.util.concurrent.atomic.AtomicBoolean;
- import javax.accessibility.*;
-+import sun.awt.AWTAccessor;
- import sun.awt.AppContext;
- import sun.awt.CausedFocusEvent;
- import sun.awt.SunToolkit;
-@@ -318,6 +319,12 @@
- s = (String) java.security.AccessController.doPrivileged(
- new GetPropertyAction("java.awt.Window.locationByPlatform"));
- locationByPlatformProp = (s != null && s.equals("true"));
-+
-+ AWTAccessor.setWindowAccessor(new AWTAccessor.WindowAccessor() {
-+ public void setLWRequestStatus(Window changed, boolean status) {
-+ changed.syncLWRequests = status;
-+ }
-+ });
- }
-
- /**
---- jdk/src/share/classes/java/beans/Introspector.java 2012-05-01 17:18:09.000000000 -0400
-+++ jdk/src/share/classes/java/beans/Introspector.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1996, 2009, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1996, 2012, 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
-@@ -139,6 +139,7 @@
- private Map events;
-
- private final static String DEFAULT_INFO_PATH = "sun.beans.infos";
-+ private final static String DEFAULT_INFO_PATH_NEW = "com.sun.beans.infos";
-
- private static String[] searchPath = { DEFAULT_INFO_PATH };
-
-@@ -460,12 +461,15 @@
- name = name.substring(name.lastIndexOf('.')+1);
-
- for (int i = 0; i < searchPath.length; i++) {
-+ String path = searchPath[i];
-+ if (DEFAULT_INFO_PATH.equals(path)) {
-+ path = DEFAULT_INFO_PATH_NEW;
-+ }
- // This optimization will only use the BeanInfo search path if is has changed
- // from the original or trying to get the ComponentBeanInfo.
-- if (!DEFAULT_INFO_PATH.equals(searchPath[i]) ||
-- DEFAULT_INFO_PATH.equals(searchPath[i]) && "ComponentBeanInfo".equals(name)) {
-+ if (!DEFAULT_INFO_PATH_NEW.equals(path) || "ComponentBeanInfo".equals(name)) {
- try {
-- String fullName = searchPath[i] + "." + name;
-+ String fullName = path + "." + name;
- java.beans.BeanInfo bi = (java.beans.BeanInfo)instantiate(beanClass, fullName);
-
- // Make sure that the returned BeanInfo matches the class.
---- jdk/src/share/classes/java/beans/PropertyEditorManager.java 2012-05-01 17:18:09.000000000 -0400
-+++ jdk/src/share/classes/java/beans/PropertyEditorManager.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1996, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1996, 2012, 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
-@@ -25,7 +25,7 @@
-
- package java.beans;
-
--import sun.beans.editors.*;
-+import com.sun.beans.editors.*;
-
- /**
- * The PropertyEditorManager can be used to locate a property editor for
-@@ -54,6 +54,9 @@
-
- public class PropertyEditorManager {
-
-+ private static final String DEFAULT_SEARCH_PATH = "sun.beans.editors";
-+ private static final String DEFAULT_SEARCH_PATH_NEW = "com.sun.beans.editors";
-+
- /**
- * Register an editor class to be used to edit values of
- * a given target class.
-@@ -119,7 +122,7 @@
- editorName = editorName.substring(index);
- }
- for (String path : searchPath) {
-- String name = path + '.' + editorName;
-+ String name = (DEFAULT_SEARCH_PATH.equals(path) ? DEFAULT_SEARCH_PATH_NEW : path) + '.' + editorName;
- try {
- return (PropertyEditor) Introspector.instantiate(targetType, name);
- } catch (Exception ex) {
-@@ -188,6 +191,6 @@
- registry.put(Double.TYPE, DoubleEditor.class);
- }
-
-- private static String[] searchPath = { "sun.beans.editors" };
-+ private static String[] searchPath = { DEFAULT_SEARCH_PATH };
- private static java.util.Hashtable registry;
- }
---- jdk/src/share/classes/java/io/File.java 2012-05-01 17:18:09.000000000 -0400
-+++ jdk/src/share/classes/java/io/File.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1994, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1994, 2012, 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
-@@ -897,7 +897,7 @@
- public boolean createNewFile() throws IOException {
- SecurityManager security = System.getSecurityManager();
- if (security != null) security.checkWrite(path);
-- return fs.createFileExclusively(path);
-+ return fs.createFileExclusively(path, false);
- }
-
- /**
-@@ -1700,7 +1700,8 @@
- return new File(dir, prefix + Long.toString(n) + suffix);
- }
-
-- private static boolean checkAndCreate(String filename, SecurityManager sm)
-+ private static boolean checkAndCreate(String filename, SecurityManager sm,
-+ boolean restrictive)
- throws IOException
- {
- if (sm != null) {
-@@ -1713,7 +1714,29 @@
- throw new SecurityException("Unable to create temporary file");
- }
- }
-- return fs.createFileExclusively(filename);
-+ return fs.createFileExclusively(filename, restrictive);
-+ }
-+
-+ // The resulting temporary file may have more restrictive access permission
-+ // on some platforms, if restrictive is true.
-+ private static File createTempFile0(String prefix, String suffix,
-+ File directory, boolean restrictive)
-+ throws IOException
-+ {
-+ if (prefix == null) throw new NullPointerException();
-+ if (prefix.length() < 3)
-+ throw new IllegalArgumentException("Prefix string too short");
-+ String s = (suffix == null) ? ".tmp" : suffix;
-+ if (directory == null) {
-+ String tmpDir = LazyInitialization.temporaryDirectory();
-+ directory = new File(tmpDir, fs.prefixLength(tmpDir));
-+ }
-+ SecurityManager sm = System.getSecurityManager();
-+ File f;
-+ do {
-+ f = generateFile(prefix, s, directory);
-+ } while (!checkAndCreate(f.getPath(), sm, restrictive));
-+ return f;
- }
-
- /**
-@@ -1789,20 +1812,7 @@
- File directory)
- throws IOException
- {
-- if (prefix == null) throw new NullPointerException();
-- if (prefix.length() < 3)
-- throw new IllegalArgumentException("Prefix string too short");
-- String s = (suffix == null) ? ".tmp" : suffix;
-- if (directory == null) {
-- String tmpDir = LazyInitialization.temporaryDirectory();
-- directory = new File(tmpDir, fs.prefixLength(tmpDir));
-- }
-- SecurityManager sm = System.getSecurityManager();
-- File f;
-- do {
-- f = generateFile(prefix, s, directory);
-- } while (!checkAndCreate(f.getPath(), sm));
-- return f;
-+ return createTempFile0(prefix, suffix, directory, false);
- }
-
- /**
-@@ -1837,7 +1847,7 @@
- public static File createTempFile(String prefix, String suffix)
- throws IOException
- {
-- return createTempFile(prefix, suffix, null);
-+ return createTempFile0(prefix, suffix, null, false);
- }
-
-
-@@ -1959,6 +1969,15 @@
- }
- );
- }
--
--
-+
-+ // Set up JavaIOAccess in SharedSecrets
-+ static {
-+ sun.misc.SharedSecrets.setJavaIOFileAccess(new sun.misc.JavaIOFileAccess() {
-+ public File createTempFile(String prefix, String suffix, File directory)
-+ throws IOException
-+ {
-+ return createTempFile0(prefix, suffix, directory, true);
-+ }
-+ });
-+ }
- }
---- jdk/src/share/classes/java/io/FileSystem.java 2012-05-01 17:18:09.000000000 -0400
-+++ jdk/src/share/classes/java/io/FileSystem.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2005, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -157,8 +157,13 @@
- * <code>true</code> if the file was created and <code>false</code> if a
- * file or directory with the given pathname already exists. Throw an
- * IOException if an I/O error occurs.
-+ *
-+ * <p>
-+ * The resulting file may have more restrictive access permission
-+ * on some platforms, if restrictive is true.
- */
-- public abstract boolean createFileExclusively(String pathname)
-+ public abstract boolean createFileExclusively(String pathname,
-+ boolean restrictive)
- throws IOException;
-
- /**
---- jdk/src/share/classes/javax/imageio/stream/FileCacheImageInputStream.java 2012-05-01 17:18:13.000000000 -0400
-+++ jdk/src/share/classes/javax/imageio/stream/FileCacheImageInputStream.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -98,7 +98,7 @@
- }
- this.stream = stream;
- this.cacheFile =
-- File.createTempFile("imageio", ".tmp", cacheDir);
-+ sun.misc.IOUtils.createTempFile("imageio", ".tmp", cacheDir);
- this.cache = new RandomAccessFile(cacheFile, "rw");
-
- this.closeAction = StreamCloser.createCloseAction(this);
---- jdk/src/share/classes/javax/imageio/stream/FileCacheImageOutputStream.java 2012-05-01 17:18:13.000000000 -0400
-+++ jdk/src/share/classes/javax/imageio/stream/FileCacheImageOutputStream.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -84,7 +84,7 @@
- }
- this.stream = stream;
- this.cacheFile =
-- File.createTempFile("imageio", ".tmp", cacheDir);
-+ sun.misc.IOUtils.createTempFile("imageio", ".tmp", cacheDir);
- this.cache = new RandomAccessFile(cacheFile, "rw");
-
- this.closeAction = StreamCloser.createCloseAction(this);
---- jdk/src/share/classes/javax/management/loading/MLet.java 2012-05-01 17:18:13.000000000 -0400
-+++ jdk/src/share/classes/javax/management/loading/MLet.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1999, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1999, 2012, 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
-@@ -1152,7 +1152,7 @@
- if (is != null) {
- File directory = new File(libraryDirectory);
- directory.mkdirs();
-- File file = File.createTempFile(libname + ".", null, directory);
-+ File file = sun.misc.IOUtils.createTempFile(libname + ".", null, directory);
- file.deleteOnExit();
- FileOutputStream fileOutput = new FileOutputStream(file);
- int c;
---- jdk/src/share/classes/javax/swing/ClientPropertyKey.java 2012-05-01 17:18:15.000000000 -0400
-+++ jdk/src/share/classes/javax/swing/ClientPropertyKey.java 2012-09-05 19:35:40.000000000 -0400
-@@ -25,6 +25,8 @@
-
- package javax.swing;
-
-+import sun.awt.AWTAccessor;
-+
- /**
- * An enumeration for keys used as client properties within the Swing
- * implementation.
-@@ -86,6 +88,15 @@
- */
- private final boolean reportValueNotSerializable;
-
-+ static {
-+ AWTAccessor.setClientPropertyKeyAccessor(
-+ new AWTAccessor.ClientPropertyKeyAccessor() {
-+ public Object getJComponent_TRANSFER_HANDLER() {
-+ return JComponent_TRANSFER_HANDLER;
-+ }
-+ });
-+ }
-+
- /**
- * Constructs a key with the {@code reportValueNotSerializable} property
- * set to {@code false}.
---- jdk/src/share/classes/javax/swing/plaf/synth/SynthButtonUI.java 2012-05-01 17:18:17.000000000 -0400
-+++ jdk/src/share/classes/javax/swing/plaf/synth/SynthButtonUI.java 2012-09-05 19:34:26.000000000 -0400
-@@ -135,8 +135,8 @@
- if (!c.isEnabled()) {
- state = DISABLED;
- }
-- if (SynthLookAndFeel.selectedUI == this) {
-- return SynthLookAndFeel.selectedUIState | SynthConstants.ENABLED;
-+ if (SynthLookAndFeel.getSelectedUI() == this) {
-+ return SynthLookAndFeel.getSelectedUIState() | SynthConstants.ENABLED;
- }
- AbstractButton button = (AbstractButton) c;
- ButtonModel model = button.getModel();
---- jdk/src/share/classes/javax/swing/plaf/synth/SynthLabelUI.java 2012-05-01 17:18:17.000000000 -0400
-+++ jdk/src/share/classes/javax/swing/plaf/synth/SynthLabelUI.java 2012-09-05 19:34:26.000000000 -0400
-@@ -94,9 +94,9 @@
-
- private int getComponentState(JComponent c) {
- int state = SynthLookAndFeel.getComponentState(c);
-- if (SynthLookAndFeel.selectedUI == this &&
-+ if (SynthLookAndFeel.getSelectedUI() == this &&
- state == SynthConstants.ENABLED) {
-- state = SynthLookAndFeel.selectedUIState | SynthConstants.ENABLED;
-+ state = SynthLookAndFeel.getSelectedUIState() | SynthConstants.ENABLED;
- }
- return state;
- }
---- jdk/src/share/classes/javax/swing/plaf/synth/SynthLookAndFeel.java 2012-05-01 17:18:17.000000000 -0400
-+++ jdk/src/share/classes/javax/swing/plaf/synth/SynthLookAndFeel.java 2012-09-05 19:34:26.000000000 -0400
-@@ -78,27 +78,25 @@
- private static final Object STYLE_FACTORY_KEY = new Object(); // com.sun.java.swing.plaf.gtk.StyleCache
-
- /**
-+ * AppContext key to get selectedUI.
-+ */
-+ private static final Object SELECTED_UI_KEY = new StringBuilder("selectedUI");
-+
-+ /**
-+ * AppContext key to get selectedUIState.
-+ */
-+ private static final Object SELECTED_UI_STATE_KEY = new StringBuilder("selectedUIState");
-+
-+ /**
- * The last SynthStyleFactory that was asked for from AppContext
- * <code>lastContext</code>.
- */
- private static SynthStyleFactory lastFactory;
- /**
-- * If this is true it indicates there is more than one AppContext active
-- * and that we need to make sure in getStyleCache the requesting
-- * AppContext matches that of <code>lastContext</code> before returning
-- * it.
-- */
-- private static boolean multipleApps;
-- /**
- * AppContext lastLAF came from.
- */
- private static AppContext lastContext;
-
-- // Refer to setSelectedUI
-- static ComponentUI selectedUI;
-- // Refer to setSelectedUI
-- static int selectedUIState;
--
- /**
- * SynthStyleFactory for the this SynthLookAndFeel.
- */
-@@ -112,6 +110,10 @@
-
- private Handler _handler;
-
-+ static ComponentUI getSelectedUI() {
-+ return (ComponentUI) AppContext.getAppContext().get(SELECTED_UI_KEY);
-+ }
-+
- /**
- * Used by the renderers. For the most part the renderers are implemented
- * as Labels, which is problematic in so far as they are never selected.
-@@ -123,8 +125,8 @@
- static void setSelectedUI(ComponentUI uix, boolean selected,
- boolean focused, boolean enabled,
- boolean rollover) {
-- selectedUI = uix;
-- selectedUIState = 0;
-+ int selectedUIState = 0;
-+
- if (selected) {
- selectedUIState = SynthConstants.SELECTED;
- if (focused) {
-@@ -141,19 +143,32 @@
- else {
- if (enabled) {
- selectedUIState |= SynthConstants.ENABLED;
-- selectedUIState = SynthConstants.FOCUSED;
-+ if (focused) {
-+ selectedUIState |= SynthConstants.FOCUSED;
-+ }
- }
- else {
- selectedUIState |= SynthConstants.DISABLED;
- }
- }
-+
-+ AppContext context = AppContext.getAppContext();
-+
-+ context.put(SELECTED_UI_KEY, uix);
-+ context.put(SELECTED_UI_STATE_KEY, Integer.valueOf(selectedUIState));
-+ }
-+
-+ static int getSelectedUIState() {
-+ Integer result = (Integer) AppContext.getAppContext().get(SELECTED_UI_STATE_KEY);
-+
-+ return result == null ? 0 : result.intValue();
- }
-
- /**
- * Clears out the selected UI that was last set in setSelectedUI.
- */
- static void resetSelectedUI() {
-- selectedUI = null;
-+ AppContext.getAppContext().remove(SELECTED_UI_KEY);
- }
-
-
-@@ -168,10 +183,6 @@
- // for a particular AppContext.
- synchronized(SynthLookAndFeel.class) {
- AppContext context = AppContext.getAppContext();
-- if (!multipleApps && context != lastContext &&
-- lastContext != null) {
-- multipleApps = true;
-- }
- lastFactory = cache;
- lastContext = context;
- context.put(STYLE_FACTORY_KEY, cache);
-@@ -185,17 +196,13 @@
- */
- public static SynthStyleFactory getStyleFactory() {
- synchronized(SynthLookAndFeel.class) {
-- if (!multipleApps) {
-- return lastFactory;
-- }
- AppContext context = AppContext.getAppContext();
-
- if (lastContext == context) {
- return lastFactory;
- }
- lastContext = context;
-- lastFactory = (SynthStyleFactory)AppContext.getAppContext().get
-- (STYLE_FACTORY_KEY);
-+ lastFactory = (SynthStyleFactory) context.get(STYLE_FACTORY_KEY);
- return lastFactory;
- }
- }
---- jdk/src/share/classes/sun/awt/AWTAccessor.java 2012-05-01 17:18:18.000000000 -0400
-+++ jdk/src/share/classes/sun/awt/AWTAccessor.java 2012-09-05 19:35:40.000000000 -0400
-@@ -26,16 +26,15 @@
- package sun.awt;
-
- import java.awt.*;
--import java.awt.event.InputEvent;
--import java.awt.geom.Point2D;
--import java.awt.image.BufferedImage;
-
- import sun.misc.Unsafe;
--import java.awt.peer.ComponentPeer;
-
--import java.security.AccessController;
- import java.security.AccessControlContext;
-
-+import java.util.Vector;
-+
-+import java.awt.event.KeyEvent;
-+
- /**
- * The AWTAccessor utility class.
- * The main purpose of this class is to enable accessing
-@@ -55,14 +54,64 @@
- private AWTAccessor() {
- }
-
-+ /**
-+ * An interface of an accessor for java.awt.Window class.
-+ */
-+ public interface WindowAccessor {
-+ /**
-+ * Sets the synchronous status of focus requests on lightweight
-+ * components in the specified window to the specified value.
-+ */
-+ void setLWRequestStatus(Window changed, boolean status);
-+ }
-+
- /*
- * An interface of accessor for the java.awt.Component class.
- */
- public interface ComponentAccessor {
-+ /**
-+ * Returns the appContext of the component.
-+ */
-+ AppContext getAppContext(Component comp);
-+
-+ /**
-+ * Sets the appContext of the component.
-+ */
-+ void setAppContext(Component comp, AppContext appContext);
-+
- /*
- * Returns the acc this component was constructed with.
- */
- AccessControlContext getAccessControlContext(Component comp);
-+
-+ /**
-+ * Requests that this Component get the input focus, if this
-+ * Component's top-level ancestor is already the focused Window
-+ */
-+ boolean requestFocusInWindow(Component comp, CausedFocusEvent.Cause cause);
-+
-+ /**
-+ * Requests that this Component get the input focus, providing the cause
-+ */
-+ void requestFocus(Component comp, CausedFocusEvent.Cause cause);
-+ }
-+
-+ /**
-+ * An interface of accessor for the KeyboardFocusManager class.
-+ */
-+ public interface KeyboardFocusManagerAccessor {
-+ /**
-+ * Indicates whether the native implementation should
-+ * proceed with a pending focus request for the heavyweight.
-+ */
-+ int shouldNativelyFocusHeavyweight(Component heavyweight,
-+ Component descendant,
-+ boolean temporary,
-+ boolean focusedWindowChangeAllowed,
-+ long time,
-+ CausedFocusEvent.Cause cause);
-+
-+ void removeLastFocusRequest(Component heavyweight);
- }
-
- /*
-@@ -70,6 +119,11 @@
- */
- public interface AWTEventAccessor {
- /**
-+ * Marks the event as posted.
-+ */
-+ void setPosted(AWTEvent ev);
-+
-+ /**
- * Sets the flag on this AWTEvent indicating that it was
- * generated by the system.
- */
-@@ -80,20 +134,234 @@
- */
- boolean isSystemGenerated(AWTEvent ev);
-
--
- /*
- * Returns the acc this event was constructed with.
- */
- AccessControlContext getAccessControlContext(AWTEvent ev);
-
-+ /**
-+ * Returns binary data associated with this event;
-+ */
-+ byte[] getBData(AWTEvent ev);
-+
-+ /**
-+ * Associates binary data with this event;
-+ */
-+ void setBData(AWTEvent ev, byte[] bdata);
-+}
-+
-+ /**
-+ * An accessor for the MenuComponent class.
-+ */
-+ public interface MenuComponentAccessor {
-+ /**
-+ * Returns the appContext of the menu component.
-+ */
-+ AppContext getAppContext(MenuComponent menuComp);
-+
-+ /**
-+ * Sets the appContext of the menu component.
-+ */
-+ void setAppContext(MenuComponent menuComp, AppContext appContext);
-+
-+ /**
-+ * Returns the parent container for this menu component.
-+ */
-+ MenuContainer getParent(MenuComponent menuComp);
-+
-+ /**
-+ * Gets the font used for this menu component.
-+ */
-+ Font getFont_NoClientCode(MenuComponent menuComp);
-+ }
-+
-+ /** An accessor for the EventQueue class
-+ */
-+ public interface EventQueueAccessor {
-+ /**
-+ * Returns whether an event is pending on any of the separate Queues.
-+ */
-+ boolean noEvents(EventQueue eventQueue);
-+
-+ /**
-+ * Returns dispatch thread for the given EventQueue which has private access
-+ */
-+ Thread getDispatchThread(EventQueue eventQueue);
-+
-+ /**
-+ * Returns next queue for the given EventQueue which has private access
-+ */
-+ EventQueue getNextQueue(EventQueue eventQueue);
-+
-+ /**
-+ * Removes any pending events for the specified source object.
-+ */
-+ void removeSourceEvents(EventQueue eventQueue, Object source,
-+ boolean removeAllEvents);
-+ }
-+
-+ /**
-+ * An accessor for the PopupMenu class
-+ */
-+ public interface PopupMenuAccessor {
-+ /**
-+ * Returns whether the popup menu is attached to a tray
-+ */
-+ boolean isTrayIconPopup(PopupMenu popupMenu);
-+ }
-+
-+ /**
-+ * An accessor for the ScrollPaneAdjustable class.
-+ */
-+ public interface ScrollPaneAdjustableAccessor {
-+ /**
-+ * Sets the value of this scrollbar to the specified value.
-+ */
-+ void setTypedValue(final ScrollPaneAdjustable adj, final int v,
-+ final int type);
-+ }
-+
-+ /**
-+ * An accessor for the CheckboxMenuItem class
-+ */
-+ public interface CheckboxMenuItemAccessor {
-+ /**
-+ * Returns whether menu item is checked
-+ */
-+ boolean getState(CheckboxMenuItem cmi);
-+ }
-+
-+ /**
-+ * An accessor for the Cursor class
-+ */
-+ public interface CursorAccessor {
-+ /**
-+ * Returns pData of the Cursor class
-+ */
-+ long getPData(Cursor cursor);
-+
-+ /**
-+ * Sets pData to the Cursor class
-+ */
-+ void setPData(Cursor cursor, long pData);
-+
-+ /**
-+ * Return type of the Cursor class
-+ */
-+ int getType(Cursor cursor);
-+ }
-+
-+ /**
-+ * An accessor for the MenuBar class
-+ */
-+ public interface MenuBarAccessor {
-+ /**
-+ * Returns help menu
-+ */
-+ Menu getHelpMenu(MenuBar menuBar);
-+
-+ /**
-+ * Returns menus
-+ */
-+ Vector getMenus(MenuBar menuBar);
-+ }
-+
-+ /**
-+ * An accessor for the MenuItem class
-+ */
-+ public interface MenuItemAccessor {
-+ /**
-+ * Returns whether menu item is enabled
-+ */
-+ boolean isEnabled(MenuItem item);
-+
-+ /**
-+ * Gets the command name of the action event that is fired
-+ * by this menu item.
-+ */
-+ String getActionCommandImpl(MenuItem item);
-+
-+ /**
-+ * Returns true if the item and all its ancestors are
-+ * enabled, false otherwise
-+ */
-+ boolean isItemEnabled(MenuItem item);
-+
-+ /**
-+ * Returns label
-+ */
-+ String getLabel(MenuItem item);
-+
-+ /**
-+ * Returns shortcut
-+ */
-+ MenuShortcut getShortcut(MenuItem item);
-+ }
-+
-+ /**
-+ * An accessor for the Menu class
-+ */
-+ public interface MenuAccessor {
-+ /**
-+ * Returns vector of the items that are part of the Menu
-+ */
-+ Vector getItems(Menu menu);
-+ }
-+
-+ /**
-+ * An accessor for the ClientPropertyKey class
-+ */
-+ public interface ClientPropertyKeyAccessor {
-+ /**
-+ * Retrieves JComponent_TRANSFER_HANDLER enum object
-+ */
-+ Object getJComponent_TRANSFER_HANDLER();
-+ }
-+
-+ /**
-+ * An accessor for the DefaultKeyboardFocusManager class
-+ */
-+ public interface DefaultKeyboardFocusManagerAccessor {
-+ void consumeNextKeyTyped(DefaultKeyboardFocusManager dkfm, KeyEvent e);
- }
-
- /*
- * Accessor instances are initialized in the static initializers of
- * corresponding AWT classes by using setters defined below.
- */
-+ private static WindowAccessor windowAccessor;
- private static ComponentAccessor componentAccessor;
-+ private static KeyboardFocusManagerAccessor kfmAccessor;
- private static AWTEventAccessor awtEventAccessor;
-+ private static MenuComponentAccessor menuComponentAccessor;
-+ private static EventQueueAccessor eventQueueAccessor;
-+ private static PopupMenuAccessor popupMenuAccessor;
-+ private static ScrollPaneAdjustableAccessor scrollPaneAdjustableAccessor;
-+ private static CheckboxMenuItemAccessor checkboxMenuItemAccessor;
-+ private static CursorAccessor cursorAccessor;
-+ private static MenuBarAccessor menuBarAccessor;
-+ private static MenuItemAccessor menuItemAccessor;
-+ private static MenuAccessor menuAccessor;
-+ private static ClientPropertyKeyAccessor clientPropertyKeyAccessor;
-+ private static DefaultKeyboardFocusManagerAccessor defaultKeyboardFocusManagerAccessor;
-+
-+ /**
-+ * Set an accessor object for the java.awt.Window class.
-+ */
-+ public static void setWindowAccessor(WindowAccessor wa) {
-+ windowAccessor = wa;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.Window class.
-+ */
-+ public static WindowAccessor getWindowAccessor() {
-+ if (windowAccessor == null) {
-+ unsafe.ensureClassInitialized(Window.class);
-+ }
-+
-+ return windowAccessor;
-+ }
-
- /*
- * Set an accessor object for the java.awt.Component class.
-@@ -113,6 +381,23 @@
- return componentAccessor;
- }
-
-+ /**
-+ * Set an accessor object for the java.awt.KeyboardFocusManager class.
-+ */
-+ public static void setKeyboardFocusManagerAccessor(KeyboardFocusManagerAccessor kfma) {
-+ kfmAccessor = kfma;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.KeyboardFocusManager class.
-+ */
-+ public static KeyboardFocusManagerAccessor getKeyboardFocusManagerAccessor() {
-+ if (kfmAccessor == null) {
-+ unsafe.ensureClassInitialized(KeyboardFocusManager.class);
-+ }
-+ return kfmAccessor;
-+ }
-+
- /*
- * Set an accessor object for the java.awt.AWTEvent class.
- */
-@@ -129,4 +414,194 @@
- }
- return awtEventAccessor;
- }
-+
-+ /**
-+ * Set an accessor object for the java.awt.MenuComponent class.
-+ */
-+ public static void setMenuComponentAccessor(MenuComponentAccessor mca) {
-+ menuComponentAccessor = mca;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.MenuComponent class.
-+ */
-+ public static MenuComponentAccessor getMenuComponentAccessor() {
-+ if (menuComponentAccessor == null) {
-+ unsafe.ensureClassInitialized(MenuComponent.class);
-+ }
-+
-+ return menuComponentAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.EventQueue class.
-+ */
-+ public static void setEventQueueAccessor(EventQueueAccessor eqa) {
-+ eventQueueAccessor = eqa;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.EventQueue class.
-+ */
-+ public static EventQueueAccessor getEventQueueAccessor() {
-+ if (eventQueueAccessor == null) {
-+ unsafe.ensureClassInitialized(EventQueue.class);
-+ }
-+ return eventQueueAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.PopupMenu class.
-+ */
-+ public static void setPopupMenuAccessor(PopupMenuAccessor pma) {
-+ popupMenuAccessor = pma;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.PopupMenu class.
-+ */
-+ public static PopupMenuAccessor getPopupMenuAccessor() {
-+ if (popupMenuAccessor == null) {
-+ unsafe.ensureClassInitialized(PopupMenu.class);
-+ }
-+ return popupMenuAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.ScrollPaneAdjustable class.
-+ */
-+ public static void setScrollPaneAdjustableAccessor(ScrollPaneAdjustableAccessor adj) {
-+ scrollPaneAdjustableAccessor = adj;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.ScrollPaneAdjustable
-+ * class.
-+ */
-+ public static ScrollPaneAdjustableAccessor getScrollPaneAdjustableAccessor() {
-+ if (scrollPaneAdjustableAccessor == null) {
-+ unsafe.ensureClassInitialized(ScrollPaneAdjustable.class);
-+ }
-+ return scrollPaneAdjustableAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.CheckboxMenuItem class.
-+ */
-+ public static void setCheckboxMenuItemAccessor(CheckboxMenuItemAccessor cmia) {
-+ checkboxMenuItemAccessor = cmia;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.CheckboxMenuItem class.
-+ */
-+ public static CheckboxMenuItemAccessor getCheckboxMenuItemAccessor() {
-+ if (checkboxMenuItemAccessor == null) {
-+ unsafe.ensureClassInitialized(CheckboxMenuItemAccessor.class);
-+ }
-+ return checkboxMenuItemAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.Cursor class.
-+ */
-+ public static void setCursorAccessor(CursorAccessor ca) {
-+ cursorAccessor = ca;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.Cursor class.
-+ */
-+ public static CursorAccessor getCursorAccessor() {
-+ if (cursorAccessor == null) {
-+ unsafe.ensureClassInitialized(CursorAccessor.class);
-+ }
-+ return cursorAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.MenuBar class.
-+ */
-+ public static void setMenuBarAccessor(MenuBarAccessor mba) {
-+ menuBarAccessor = mba;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.MenuBar class.
-+ */
-+ public static MenuBarAccessor getMenuBarAccessor() {
-+ if (menuBarAccessor == null) {
-+ unsafe.ensureClassInitialized(MenuBarAccessor.class);
-+ }
-+ return menuBarAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.MenuItem class.
-+ */
-+ public static void setMenuItemAccessor(MenuItemAccessor mia) {
-+ menuItemAccessor = mia;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.MenuItem class.
-+ */
-+ public static MenuItemAccessor getMenuItemAccessor() {
-+ if (menuItemAccessor == null) {
-+ unsafe.ensureClassInitialized(MenuItemAccessor.class);
-+ }
-+ return menuItemAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.Menu class.
-+ */
-+ public static void setMenuAccessor(MenuAccessor ma) {
-+ menuAccessor = ma;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.Menu class.
-+ */
-+ public static MenuAccessor getMenuAccessor() {
-+ if (menuAccessor == null) {
-+ unsafe.ensureClassInitialized(MenuAccessor.class);
-+ }
-+ return menuAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the javax.swing.ClientPropertyKey class.
-+ */
-+ public static void setClientPropertyKeyAccessor(ClientPropertyKeyAccessor cpka) {
-+ clientPropertyKeyAccessor = cpka;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the javax.swing.ClientPropertyKey class.
-+ */
-+ public static ClientPropertyKeyAccessor getClientPropertyKeyAccessor() {
-+ if (clientPropertyKeyAccessor == null) {
-+ unsafe.ensureClassInitialized(ClientPropertyKeyAccessor.class);
-+ }
-+ return clientPropertyKeyAccessor;
-+ }
-+
-+ /**
-+ * Set an accessor object for the java.awt.DefaultKeyboardFocusManager class.
-+ */
-+ public static void setDefaultKeyboardFocusManagerAccessor(
-+ DefaultKeyboardFocusManagerAccessor dkfma) {
-+ defaultKeyboardFocusManagerAccessor = dkfma;
-+ }
-+
-+ /**
-+ * Retrieve the accessor object for the java.awt.DefaultKeyboardFocusManager class.
-+ */
-+ public static DefaultKeyboardFocusManagerAccessor getDefaultKeyboardFocusManagerAccessor() {
-+ if (defaultKeyboardFocusManagerAccessor == null) {
-+ unsafe.ensureClassInitialized(DefaultKeyboardFocusManagerAccessor.class);
-+ }
-+ return defaultKeyboardFocusManagerAccessor;
-+ }
- }
---- jdk/src/share/classes/sun/awt/KeyboardFocusManagerPeerImpl.java 2012-05-01 17:18:18.000000000 -0400
-+++ jdk/src/share/classes/sun/awt/KeyboardFocusManagerPeerImpl.java 2012-09-05 19:35:40.000000000 -0400
-@@ -30,10 +30,6 @@
-
- import java.awt.peer.KeyboardFocusManagerPeer;
-
--import java.lang.reflect.InvocationTargetException;
--import java.lang.reflect.Method;
--
--
- public class KeyboardFocusManagerPeerImpl implements KeyboardFocusManagerPeer {
- static native Window getNativeFocusedWindow();
- static native Component getNativeFocusOwner();
-@@ -56,18 +52,7 @@
- clearNativeGlobalFocusOwner(activeWindow);
- }
-
-- static Method m_removeLastFocusRequest = null;
- public static void removeLastFocusRequest(Component heavyweight) {
-- try {
-- if (m_removeLastFocusRequest == null) {
-- m_removeLastFocusRequest = SunToolkit.getMethod(KeyboardFocusManager.class, "removeLastFocusRequest",
-- new Class[] {Component.class});
-- }
-- m_removeLastFocusRequest.invoke(null, new Object[]{heavyweight});
-- } catch (InvocationTargetException ite) {
-- ite.printStackTrace();
-- } catch (IllegalAccessException ex) {
-- ex.printStackTrace();
-- }
-+ AWTAccessor.getKeyboardFocusManagerAccessor().removeLastFocusRequest(heavyweight);
- }
- }
---- jdk/src/share/classes/sun/awt/SunToolkit.java 2012-05-01 17:18:18.000000000 -0400
-+++ jdk/src/share/classes/sun/awt/SunToolkit.java 2012-09-05 19:35:40.000000000 -0400
-@@ -32,14 +32,10 @@
- import java.awt.peer.*;
- import java.awt.event.WindowEvent;
- import java.awt.event.KeyEvent;
--import java.awt.im.spi.InputMethodDescriptor;
- import java.awt.image.*;
--import java.awt.geom.AffineTransform;
- import java.awt.TrayIcon;
- import java.awt.SystemTray;
--import java.io.*;
- import java.net.URL;
--import java.net.JarURLConnection;
- import java.util.*;
- import java.util.concurrent.TimeUnit;
- import java.util.concurrent.locks.Condition;
-@@ -49,18 +45,14 @@
- import sun.misc.SoftCache;
- import sun.font.FontDesignMetrics;
- import sun.awt.im.InputContext;
--import sun.awt.im.SimpleInputMethodWindow;
- import sun.awt.image.*;
- import sun.security.action.GetPropertyAction;
- import sun.security.action.GetBooleanAction;
--import java.lang.reflect.Field;
- import java.lang.reflect.Method;
- import java.lang.reflect.Constructor;
- import java.lang.reflect.InvocationTargetException;
- import java.security.AccessController;
- import java.security.PrivilegedAction;
--import java.security.PrivilegedActionException;
--import java.security.PrivilegedExceptionAction;
-
- public abstract class SunToolkit extends Toolkit
- implements WindowClosingSupport, WindowClosingListener,
-@@ -82,14 +74,7 @@
- */
- public static final int GRAB_EVENT_MASK = 0x80000000;
-
-- private static Field syncLWRequestsField;
- private static Method wakeupMethod;
-- private static Field componentKeyField;
-- private static Field menuComponentKeyField;
-- private static Field trayIconKeyField;
-- private static Field componentAppContextField;
-- private static Field menuComponentAppContextField;
-- private static Field isPostedField;
- /* The key to put()/get() the PostEventQueue into/from the AppContext.
- */
- private static final String POST_EVENT_QUEUE_KEY = "PostEventQueue";
-@@ -326,24 +311,6 @@
- return appContext;
- }
-
-- public static Field getField(final Class klass, final String fieldName) {
-- return AccessController.doPrivileged(new PrivilegedAction<Field>() {
-- public Field run() {
-- try {
-- Field field = klass.getDeclaredField(fieldName);
-- assert (field != null);
-- field.setAccessible(true);
-- return field;
-- } catch (SecurityException e) {
-- assert false;
-- } catch (NoSuchFieldException e) {
-- assert false;
-- }
-- return null;
-- }//run
-- });
-- }
--
- static void wakeupEventQueue(EventQueue q, boolean isShutdown){
- if (wakeupMethod == null){
- wakeupMethod = (Method)AccessController.doPrivileged(new PrivilegedAction(){
-@@ -417,25 +384,15 @@
- */
- private static boolean setAppContext(Object target, AppContext context)
- {
-- if (!(target instanceof Component) && !(target instanceof MenuComponent)) {
-+ if (target instanceof Component) {
-+ AWTAccessor.getComponentAccessor().
-+ setAppContext((Component)target, context);
-+ } else if (target instanceof MenuComponent) {
-+ AWTAccessor.getMenuComponentAccessor().
-+ setAppContext((MenuComponent)target, context);
-+ } else {
- return false;
- }
-- try{
-- if (target instanceof Component){
-- if (componentAppContextField == null) {
-- componentAppContextField = getField(Component.class, "appContext");
-- }
-- componentAppContextField.set(target, context);
-- } else if (target instanceof MenuComponent) {
-- if (menuComponentAppContextField == null) {
-- menuComponentAppContextField = getField(MenuComponent.class, "appContext");
-- }
-- menuComponentAppContextField.set(target, context);
-- }
-- } catch( IllegalAccessException e){
-- assert false;
-- }
--
- return true;
- }
-
-@@ -444,23 +401,15 @@
- * Component or MenuComponent this returns null.
- */
- private static AppContext getAppContext(Object target) {
-- AppContext retObj = null;
-- try{
-- if (target instanceof Component){
-- if (componentAppContextField == null) {
-- componentAppContextField = getField(Component.class, "appContext");
-- }
-- retObj = (AppContext) componentAppContextField.get(target);
-- } else if (target instanceof MenuComponent) {
-- if (menuComponentAppContextField == null) {
-- menuComponentAppContextField = getField(MenuComponent.class, "appContext");
-- }
-- retObj = (AppContext) menuComponentAppContextField.get(target);
-- }
-- } catch( IllegalAccessException e){
-- assert false;
-+ if (target instanceof Component) {
-+ return AWTAccessor.getComponentAccessor().
-+ getAppContext((Component)target);
-+ } else if (target instanceof MenuComponent) {
-+ return AWTAccessor.getMenuComponentAccessor().
-+ getAppContext((MenuComponent)target);
-+ } else {
-+ return null;
- }
-- return retObj;
- }
-
- /*
-@@ -508,16 +457,7 @@
- */
-
- public static void setLWRequestStatus(Window changed,boolean status){
-- if (syncLWRequestsField == null){
-- syncLWRequestsField = getField(Window.class, "syncLWRequests");
-- }
-- try{
-- if (syncLWRequestsField != null){
-- syncLWRequestsField.setBoolean(changed, status);
-- }
-- } catch( IllegalAccessException e){
-- assert false;
-- }
-+ AWTAccessor.getWindowAccessor().setLWRequestStatus(changed, status);
- };
-
- public static void checkAndSetPolicy(Container cont, boolean isSwingCont)
-@@ -625,18 +565,9 @@
- * Post AWTEvent of high priority.
- */
- public static void postPriorityEvent(final AWTEvent e) {
-- if (isPostedField == null) {
-- isPostedField = getField(AWTEvent.class, "isPosted");
-- }
- PeerEvent pe = new PeerEvent(Toolkit.getDefaultToolkit(), new Runnable() {
- public void run() {
-- try {
-- isPostedField.setBoolean(e, true);
-- } catch (IllegalArgumentException e) {
-- assert(false);
-- } catch (IllegalAccessException e) {
-- assert(false);
-- }
-+ AWTAccessor.getAWTEventAccessor().setPosted(e);
- ((Component)e.getSource()).dispatchEvent(e);
- }
- }, PeerEvent.ULTIMATE_PRIORITY_EVENT);
-@@ -745,36 +676,6 @@
- }
-
- /*
-- * Returns next queue for the given EventQueue which has private access
-- */
-- private static EventQueue getNextQueue(final Object o) {
-- EventQueue result = null;
-- try{
-- Field nextQueueField = getField(EventQueue.class,
-- "nextQueue");
-- result = (EventQueue)nextQueueField.get(o);
-- } catch( IllegalAccessException e){
-- assert false;
-- }
-- return result;
-- }
--
-- /*
-- * Returns dispatch thread for the given EventQueue which has private access
-- */
-- private static Thread getDispatchThread(final Object o) {
-- Thread result = null;
-- try{
-- Field dispatchThreadField = getField(EventQueue.class,
-- "dispatchThread");
-- result = (Thread)dispatchThreadField.get(o);
-- } catch( IllegalAccessException e){
-- assert false;
-- }
-- return result;
-- }
--
-- /*
- * Returns true if the calling thread is the event dispatch thread
- * contained within AppContext which associated with the given target.
- * Use this call to ensure that a given task is being executed
-@@ -784,13 +685,14 @@
- AppContext appContext = targetToAppContext(target);
- EventQueue eq = (EventQueue)appContext.get(AppContext.EVENT_QUEUE_KEY);
-
-- EventQueue next = getNextQueue(eq);
-+ EventQueue next = AWTAccessor.getEventQueueAccessor().getNextQueue(eq);
- while (next != null) {
- eq = next;
-- next = getNextQueue(eq);
-+ next = AWTAccessor.getEventQueueAccessor().getNextQueue(eq);
- }
-
-- return (Thread.currentThread() == getDispatchThread(eq));
-+ return (Thread.currentThread() == AWTAccessor.getEventQueueAccessor()
-+ .getDispatchThread(eq));
- }
-
- public Dimension getScreenSize() {
-@@ -1524,22 +1426,6 @@
- || comp instanceof Window);
- }
-
-- public static Method getMethod(final Class clz, final String methodName, final Class[] params) {
-- Method res = null;
-- try {
-- res = AccessController.doPrivileged(new PrivilegedExceptionAction<Method>() {
-- public Method run() throws Exception {
-- Method m = clz.getDeclaredMethod(methodName, params);
-- m.setAccessible(true);
-- return m;
-- }
-- });
-- } catch (PrivilegedActionException ex) {
-- ex.printStackTrace();
-- }
-- return res;
-- }
--
- public static class OperationTimedOut extends RuntimeException {
- public OperationTimedOut(String msg) {
- super(msg);
-@@ -1682,21 +1568,9 @@
- private boolean queueEmpty = false;
- private final Object waitLock = "Wait Lock";
-
-- static Method eqNoEvents;
--
- private boolean isEQEmpty() {
- EventQueue queue = getSystemEventQueueImpl();
-- synchronized(SunToolkit.class) {
-- if (eqNoEvents == null) {
-- eqNoEvents = getMethod(java.awt.EventQueue.class, "noEvents", null);
-- }
-- }
-- try {
-- return (Boolean)eqNoEvents.invoke(queue);
-- } catch (Exception e) {
-- e.printStackTrace();
-- return false;
-- }
-+ return AWTAccessor.getEventQueueAccessor().noEvents(queue);
- }
-
- /**
-@@ -1951,20 +1825,14 @@
- * consumeNextKeyTyped() method is not currently used,
- * however Swing could use it in the future.
- */
-- private static Method consumeNextKeyTypedMethod = null;
- public static synchronized void consumeNextKeyTyped(KeyEvent keyEvent) {
-- if (consumeNextKeyTypedMethod == null) {
-- consumeNextKeyTypedMethod = getMethod(DefaultKeyboardFocusManager.class,
-- "consumeNextKeyTyped",
-- new Class[] {KeyEvent.class});
-- }
- try {
-- consumeNextKeyTypedMethod.invoke(KeyboardFocusManager.getCurrentKeyboardFocusManager(),
-- keyEvent);
-- } catch (IllegalAccessException iae) {
-- iae.printStackTrace();
-- } catch (InvocationTargetException ite) {
-- ite.printStackTrace();
-+ AWTAccessor.getDefaultKeyboardFocusManagerAccessor().consumeNextKeyTyped(
-+ (DefaultKeyboardFocusManager)KeyboardFocusManager.
-+ getCurrentKeyboardFocusManager(),
-+ keyEvent);
-+ } catch (ClassCastException cce) {
-+ cce.printStackTrace();
- }
- }
-
---- jdk/src/share/classes/sun/beans/editors/BooleanEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/BooleanEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,76 +0,0 @@
--/*
-- * Copyright (c) 2006, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "boolean" type.
-- */
--
--import java.beans.*;
--
--public class BooleanEditor extends PropertyEditorSupport {
--
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- return (value != null)
-- ? value.toString()
-- : "null";
-- }
--
-- public String getAsText() {
-- Object value = getValue();
-- return (value instanceof Boolean)
-- ? getValidName((Boolean) value)
-- : "null";
-- }
--
-- public void setAsText(String text) throws java.lang.IllegalArgumentException {
-- if (text == null) {
-- setValue(null);
-- } else if (isValidName(true, text)) {
-- setValue(Boolean.TRUE);
-- } else if (isValidName(false, text)) {
-- setValue(Boolean.FALSE);
-- } else {
-- throw new java.lang.IllegalArgumentException(text);
-- }
-- }
--
-- public String[] getTags() {
-- return new String[] {getValidName(true), getValidName(false)};
-- }
--
-- // the following method should be localized (4890258)
--
-- private String getValidName(boolean value) {
-- return value ? "True" : "False";
-- }
--
-- private boolean isValidName(boolean value, String name) {
-- return getValidName(value).equalsIgnoreCase(name);
-- }
--}
---- jdk/src/share/classes/sun/beans/editors/ByteEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/ByteEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,48 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "byte" type.
-- *
-- */
--
--import java.beans.*;
--
--public class ByteEditor extends NumberEditor {
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- return (value != null)
-- ? "((byte)" + value + ")"
-- : "null";
-- }
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Byte.decode(text));
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/ColorEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/ColorEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,212 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--import java.awt.*;
--import java.beans.*;
--
--public class ColorEditor extends Panel implements PropertyEditor {
-- public ColorEditor() {
-- setLayout(null);
--
-- ourWidth = hPad;
--
-- // Create a sample color block bordered in black
-- Panel p = new Panel();
-- p.setLayout(null);
-- p.setBackground(Color.black);
-- sample = new Canvas();
-- p.add(sample);
-- sample.reshape(2, 2, sampleWidth, sampleHeight);
-- add(p);
-- p.reshape(ourWidth, 2, sampleWidth+4, sampleHeight+4);
-- ourWidth += sampleWidth + 4 + hPad;
--
-- text = new TextField("", 14);
-- add(text);
-- text.reshape(ourWidth,0,100,30);
-- ourWidth += 100 + hPad;
--
-- choser = new Choice();
-- int active = 0;
-- for (int i = 0; i < colorNames.length; i++) {
-- choser.addItem(colorNames[i]);
-- }
-- add(choser);
-- choser.reshape(ourWidth,0,100,30);
-- ourWidth += 100 + hPad;
--
-- resize(ourWidth,40);
-- }
--
-- public void setValue(Object o) {
-- Color c = (Color)o;
-- changeColor(c);
-- }
--
-- public Dimension preferredSize() {
-- return new Dimension(ourWidth, 40);
-- }
--
-- public boolean keyUp(Event e, int key) {
-- if (e.target == text) {
-- try {
-- setAsText(text.getText());
-- } catch (IllegalArgumentException ex) {
-- // Quietly ignore.
-- }
-- }
-- return (false);
-- }
--
-- public void setAsText(String s) throws java.lang.IllegalArgumentException {
-- if (s == null) {
-- changeColor(null);
-- return;
-- }
-- int c1 = s.indexOf(',');
-- int c2 = s.indexOf(',', c1+1);
-- if (c1 < 0 || c2 < 0) {
-- // Invalid string.
-- throw new IllegalArgumentException(s);
-- }
-- try {
-- int r = Integer.parseInt(s.substring(0,c1));
-- int g = Integer.parseInt(s.substring(c1+1, c2));
-- int b = Integer.parseInt(s.substring(c2+1));
-- Color c = new Color(r,g,b);
-- changeColor(c);
-- } catch (Exception ex) {
-- throw new IllegalArgumentException(s);
-- }
--
-- }
--
-- public boolean action(Event e, Object arg) {
-- if (e.target == choser) {
-- changeColor(colors[choser.getSelectedIndex()]);
-- }
-- return false;
-- }
--
-- public String getJavaInitializationString() {
-- return (this.color != null)
-- ? "new java.awt.Color(" + this.color.getRGB() + ",true)"
-- : "null";
-- }
--
--
-- private void changeColor(Color c) {
--
-- if (c == null) {
-- this.color = null;
-- this.text.setText("");
-- return;
-- }
--
-- color = c;
--
-- text.setText("" + c.getRed() + "," + c.getGreen() + "," + c.getBlue());
--
-- int active = 0;
-- for (int i = 0; i < colorNames.length; i++) {
-- if (color.equals(colors[i])) {
-- active = i;
-- }
-- }
-- choser.select(active);
--
-- sample.setBackground(color);
-- sample.repaint();
--
-- support.firePropertyChange("", null, null);
-- }
--
-- public Object getValue() {
-- return color;
-- }
--
-- public boolean isPaintable() {
-- return true;
-- }
--
-- public void paintValue(java.awt.Graphics gfx, java.awt.Rectangle box) {
-- Color oldColor = gfx.getColor();
-- gfx.setColor(Color.black);
-- gfx.drawRect(box.x, box.y, box.width-3, box.height-3);
-- gfx.setColor(color);
-- gfx.fillRect(box.x+1, box.y+1, box.width-4, box.height-4);
-- gfx.setColor(oldColor);
-- }
--
-- public String getAsText() {
-- return (this.color != null)
-- ? this.color.getRed() + "," + this.color.getGreen() + "," + this.color.getBlue()
-- : "null";
-- }
--
-- public String[] getTags() {
-- return null;
-- }
--
-- public java.awt.Component getCustomEditor() {
-- return this;
-- }
--
-- public boolean supportsCustomEditor() {
-- return true;
-- }
--
-- public void addPropertyChangeListener(PropertyChangeListener l) {
-- support.addPropertyChangeListener(l);
-- }
--
-- public void removePropertyChangeListener(PropertyChangeListener l) {
-- support.removePropertyChangeListener(l);
-- }
--
--
-- private String colorNames[] = { " ", "white", "lightGray", "gray", "darkGray",
-- "black", "red", "pink", "orange",
-- "yellow", "green", "magenta", "cyan",
-- "blue"};
-- private Color colors[] = { null, Color.white, Color.lightGray, Color.gray, Color.darkGray,
-- Color.black, Color.red, Color.pink, Color.orange,
-- Color.yellow, Color.green, Color.magenta, Color.cyan,
-- Color.blue};
--
-- private Canvas sample;
-- private int sampleHeight = 20;
-- private int sampleWidth = 40;
-- private int hPad = 5;
-- private int ourWidth;
--
-- private Color color;
-- private TextField text;
-- private Choice choser;
--
-- private PropertyChangeSupport support = new PropertyChangeSupport(this);
--}
---- jdk/src/share/classes/sun/beans/editors/DoubleEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/DoubleEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,41 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "double" type.
-- *
-- */
--
--import java.beans.*;
--
--public class DoubleEditor extends NumberEditor {
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Double.valueOf(text));
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/EnumEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/EnumEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,142 +0,0 @@
--/*
-- * Copyright (c) 2006, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--package sun.beans.editors;
--
--import java.awt.Component;
--import java.awt.Graphics;
--import java.awt.Rectangle;
--import java.beans.PropertyChangeEvent;
--import java.beans.PropertyChangeListener;
--import java.beans.PropertyEditor;
--import java.util.ArrayList;
--import java.util.List;
--
--/**
-- * Property editor for java.lang.Enum subclasses.
-- *
-- * @see PropertyEditor
-- *
-- * @since 1.7
-- *
-- * @author Sergey A. Malenkov
-- */
--public final class EnumEditor implements PropertyEditor {
-- private final List<PropertyChangeListener> listeners = new ArrayList<PropertyChangeListener>();
--
-- private final Class type;
-- private final String[] tags;
--
-- private Object value;
--
-- public EnumEditor( Class type ) {
-- Object[] values = type.getEnumConstants();
-- if ( values == null ) {
-- throw new IllegalArgumentException( "Unsupported " + type );
-- }
-- this.type = type;
-- this.tags = new String[values.length];
-- for ( int i = 0; i < values.length; i++ ) {
-- this.tags[i] = ( ( Enum )values[i] ).name();
-- }
-- }
--
-- public Object getValue() {
-- return this.value;
-- }
--
-- public void setValue( Object value ) {
-- if ( ( value != null ) && !this.type.isInstance( value ) ) {
-- throw new IllegalArgumentException( "Unsupported value: " + value );
-- }
-- Object oldValue;
-- PropertyChangeListener[] listeners;
-- synchronized ( this.listeners ) {
-- oldValue = this.value;
-- this.value = value;
--
-- if ( ( value == null ) ? oldValue == null : value.equals( oldValue ) ) {
-- return; // do not fire event if value is not changed
-- }
-- int size = this.listeners.size();
-- if ( size == 0 ) {
-- return; // do not fire event if there are no any listener
-- }
-- listeners = this.listeners.toArray( new PropertyChangeListener[size] );
-- }
-- PropertyChangeEvent event = new PropertyChangeEvent( this, null, oldValue, value );
-- for ( PropertyChangeListener listener : listeners ) {
-- listener.propertyChange( event );
-- }
-- }
--
-- public String getAsText() {
-- return ( this.value != null )
-- ? ( ( Enum )this.value ).name()
-- : "null";
-- }
--
-- public void setAsText( String text ) {
-- setValue( ( text != null )
-- ? Enum.valueOf( this.type, text )
-- : null );
-- }
--
-- public String[] getTags() {
-- return this.tags.clone();
-- }
--
-- public String getJavaInitializationString() {
-- return ( this.value != null )
-- ? this.type.getName() + '.' + ( ( Enum )this.value ).name()
-- : "null";
-- }
--
-- public boolean isPaintable() {
-- return false;
-- }
--
-- public void paintValue( Graphics gfx, Rectangle box ) {
-- }
--
-- public boolean supportsCustomEditor() {
-- return false;
-- }
--
-- public Component getCustomEditor() {
-- return null;
-- }
--
-- public void addPropertyChangeListener( PropertyChangeListener listener ) {
-- synchronized ( this.listeners ) {
-- this.listeners.add( listener );
-- }
-- }
--
-- public void removePropertyChangeListener( PropertyChangeListener listener ) {
-- synchronized ( this.listeners ) {
-- this.listeners.remove( listener );
-- }
-- }
--}
---- jdk/src/share/classes/sun/beans/editors/FloatEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/FloatEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,48 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "float" type.
-- *
-- */
--
--import java.beans.*;
--
--public class FloatEditor extends NumberEditor {
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- return (value != null)
-- ? value + "F"
-- : "null";
-- }
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Float.valueOf(text));
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/FontEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/FontEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,218 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--import java.awt.*;
--import java.beans.*;
--
--public class FontEditor extends Panel implements java.beans.PropertyEditor {
--
-- public FontEditor() {
-- setLayout(null);
--
-- toolkit = Toolkit.getDefaultToolkit();
-- fonts = toolkit.getFontList();
--
-- familyChoser = new Choice();
-- for (int i = 0; i < fonts.length; i++) {
-- familyChoser.addItem(fonts[i]);
-- }
-- add(familyChoser);
-- familyChoser.reshape(20, 5, 100, 30);
--
-- styleChoser = new Choice();
-- for (int i = 0; i < styleNames.length; i++) {
-- styleChoser.addItem(styleNames[i]);
-- }
-- add(styleChoser);
-- styleChoser.reshape(145, 5, 70, 30);
--
-- sizeChoser = new Choice();
-- for (int i = 0; i < pointSizes.length; i++) {
-- sizeChoser.addItem("" + pointSizes[i]);
-- }
-- add(sizeChoser);
-- sizeChoser.reshape(220, 5, 70, 30);
--
-- resize(300,40);
-- }
--
--
-- public Dimension preferredSize() {
-- return new Dimension(300, 40);
-- }
--
-- public void setValue(Object o) {
-- font = (Font) o;
-- if (this.font == null)
-- return;
--
-- changeFont(font);
-- // Update the current GUI choices.
-- for (int i = 0; i < fonts.length; i++) {
-- if (fonts[i].equals(font.getFamily())) {
-- familyChoser.select(i);
-- break;
-- }
-- }
-- for (int i = 0; i < styleNames.length; i++) {
-- if (font.getStyle() == styles[i]) {
-- styleChoser.select(i);
-- break;
-- }
-- }
-- for (int i = 0; i < pointSizes.length; i++) {
-- if (font.getSize() <= pointSizes[i]) {
-- sizeChoser.select(i);
-- break;
-- }
-- }
-- }
--
-- private void changeFont(Font f) {
-- font = f;
-- if (sample != null) {
-- remove(sample);
-- }
-- sample = new Label(sampleText);
-- sample.setFont(font);
-- add(sample);
-- Component p = getParent();
-- if (p != null) {
-- p.invalidate();
-- p.layout();
-- }
-- invalidate();
-- layout();
-- repaint();
-- support.firePropertyChange("", null, null);
-- }
--
-- public Object getValue() {
-- return (font);
-- }
--
-- public String getJavaInitializationString() {
-- if (this.font == null)
-- return "null";
--
-- return "new java.awt.Font(\"" + font.getName() + "\", " +
-- font.getStyle() + ", " + font.getSize() + ")";
-- }
--
-- public boolean action(Event e, Object arg) {
-- String family = familyChoser.getSelectedItem();
-- int style = styles[styleChoser.getSelectedIndex()];
-- int size = pointSizes[sizeChoser.getSelectedIndex()];
-- try {
-- Font f = new Font(family, style, size);
-- changeFont(f);
-- } catch (Exception ex) {
-- System.err.println("Couldn't create font " + family + "-" +
-- styleNames[style] + "-" + size);
-- }
-- return (false);
-- }
--
--
-- public boolean isPaintable() {
-- return true;
-- }
--
-- public void paintValue(java.awt.Graphics gfx, java.awt.Rectangle box) {
-- // Silent noop.
-- Font oldFont = gfx.getFont();
-- gfx.setFont(font);
-- FontMetrics fm = gfx.getFontMetrics();
-- int vpad = (box.height - fm.getAscent())/2;
-- gfx.drawString(sampleText, 0, box.height-vpad);
-- gfx.setFont(oldFont);
-- }
--
-- public String getAsText() {
-- if (this.font == null) {
-- return "null";
-- }
-- StringBuilder sb = new StringBuilder();
-- sb.append(this.font.getName());
-- sb.append(' ');
--
-- boolean b = this.font.isBold();
-- if (b) {
-- sb.append("BOLD");
-- }
-- boolean i = this.font.isItalic();
-- if (i) {
-- sb.append("ITALIC");
-- }
-- if (b || i) {
-- sb.append(' ');
-- }
-- sb.append(this.font.getSize());
-- return sb.toString();
-- }
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Font.decode(text));
-- }
--
-- public String[] getTags() {
-- return null;
-- }
--
-- public java.awt.Component getCustomEditor() {
-- return this;
-- }
--
-- public boolean supportsCustomEditor() {
-- return true;
-- }
--
-- public void addPropertyChangeListener(PropertyChangeListener l) {
-- support.addPropertyChangeListener(l);
-- }
--
-- public void removePropertyChangeListener(PropertyChangeListener l) {
-- support.removePropertyChangeListener(l);
-- }
--
-- private Font font;
-- private Toolkit toolkit;
-- private String sampleText = "Abcde...";
--
-- private Label sample;
-- private Choice familyChoser;
-- private Choice styleChoser;
-- private Choice sizeChoser;
--
-- private String fonts[];
-- private String[] styleNames = { "plain", "bold", "italic" };
-- private int[] styles = { Font.PLAIN, Font.BOLD, Font.ITALIC };
-- private int[] pointSizes = { 3, 5, 8, 10, 12, 14, 18, 24, 36, 48 };
--
-- private PropertyChangeSupport support = new PropertyChangeSupport(this);
--
--}
---- jdk/src/share/classes/sun/beans/editors/IntegerEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/IntegerEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,42 +0,0 @@
--/*
-- * Copyright (c) 2006, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "int" type.
-- *
-- */
--
--import java.beans.*;
--
--public class IntegerEditor extends NumberEditor {
--
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Integer.decode(text));
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/LongEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/LongEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,48 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "long" type.
-- *
-- */
--
--import java.beans.*;
--
--public class LongEditor extends NumberEditor {
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- return (value != null)
-- ? value + "L"
-- : "null";
-- }
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Long.decode(text));
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/NumberEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/NumberEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,44 +0,0 @@
--/*
-- * Copyright (c) 1996, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.editors;
--
--/**
-- * Abstract Property editor for a java builtin number types.
-- *
-- */
--
--import java.beans.*;
--
--abstract public class NumberEditor extends PropertyEditorSupport {
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- return (value != null)
-- ? value.toString()
-- : "null";
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/ShortEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/ShortEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,49 +0,0 @@
--/*
-- * Copyright (c) 1996, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--
--package sun.beans.editors;
--
--/**
-- * Property editor for a java builtin "short" type.
-- *
-- */
--
--import java.beans.*;
--
--public class ShortEditor extends NumberEditor {
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- return (value != null)
-- ? "((short)" + value + ")"
-- : "null";
-- }
--
-- public void setAsText(String text) throws IllegalArgumentException {
-- setValue((text == null) ? null : Short.decode(text));
-- }
--
--}
---- jdk/src/share/classes/sun/beans/editors/StringEditor.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/editors/StringEditor.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,74 +0,0 @@
--/*
-- * Copyright (c) 1996, 2006, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--
--package sun.beans.editors;
--
--import java.beans.*;
--
--public class StringEditor extends PropertyEditorSupport {
--
-- public String getJavaInitializationString() {
-- Object value = getValue();
-- if (value == null)
-- return "null";
--
-- String str = value.toString();
-- int length = str.length();
-- StringBuilder sb = new StringBuilder(length + 2);
-- sb.append('"');
-- for (int i = 0; i < length; i++) {
-- char ch = str.charAt(i);
-- switch (ch) {
-- case '\b': sb.append("\\b"); break;
-- case '\t': sb.append("\\t"); break;
-- case '\n': sb.append("\\n"); break;
-- case '\f': sb.append("\\f"); break;
-- case '\r': sb.append("\\r"); break;
-- case '\"': sb.append("\\\""); break;
-- case '\\': sb.append("\\\\"); break;
-- default:
-- if ((ch < ' ') || (ch > '~')) {
-- sb.append("\\u");
-- String hex = Integer.toHexString((int) ch);
-- for (int len = hex.length(); len < 4; len++) {
-- sb.append('0');
-- }
-- sb.append(hex);
-- } else {
-- sb.append(ch);
-- }
-- break;
-- }
-- }
-- sb.append('"');
-- return sb.toString();
-- }
--
-- public void setAsText(String text) {
-- setValue(text);
-- }
--
--}
---- jdk/src/share/classes/sun/beans/infos/ComponentBeanInfo.java 2012-05-01 17:18:19.000000000 -0400
-+++ jdk/src/share/classes/sun/beans/infos/ComponentBeanInfo.java 2012-09-05 19:35:34.000000000 -0400
-@@ -1,62 +0,0 @@
--/*
-- * Copyright (c) 1996, 2002, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.beans.infos;
--
--import java.beans.*;
--
--/**
-- * BeanInfo descriptor for a standard AWT component.
-- */
--
--public class ComponentBeanInfo extends SimpleBeanInfo {
-- private static final Class beanClass = java.awt.Component.class;
--
-- public PropertyDescriptor[] getPropertyDescriptors() {
-- try {
-- PropertyDescriptor
-- name = new PropertyDescriptor("name", beanClass),
-- background = new PropertyDescriptor("background", beanClass),
-- foreground = new PropertyDescriptor("foreground", beanClass),
-- font = new PropertyDescriptor("font", beanClass),
-- enabled = new PropertyDescriptor("enabled", beanClass),
-- visible = new PropertyDescriptor("visible", beanClass),
-- focusable = new PropertyDescriptor("focusable", beanClass);
--
-- enabled.setExpert(true);
-- visible.setHidden(true);
--
-- background.setBound(true);
-- foreground.setBound(true);
-- font.setBound(true);
-- focusable.setBound(true);
--
-- PropertyDescriptor[] rv = {name, background, foreground, font, enabled, visible, focusable };
-- return rv;
-- } catch (IntrospectionException e) {
-- throw new Error(e.toString());
-- }
-- }
--}
---- jdk/src/share/classes/sun/misc/IOUtils.java 2012-05-01 17:18:21.000000000 -0400
-+++ jdk/src/share/classes/sun/misc/IOUtils.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2009, 2012, 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
-@@ -30,6 +30,7 @@
- package sun.misc;
-
- import java.io.EOFException;
-+import java.io.File;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.Arrays;
-@@ -77,4 +78,37 @@
- }
- return output;
- }
-+
-+ /*
-+ * <p> Creates a new empty file in the specified directory, using the
-+ * given prefix and suffix strings to generate its name. The resulting
-+ * temporary file may have more restrictive access permission on some
-+ * platforms.
-+ *
-+ * @param prefix The prefix string to be used in generating the file's
-+ * name; must be at least three characters long
-+ *
-+ * @param suffix The suffix string to be used in generating the file's
-+ * name; may be <code>null</code>, in which case the
-+ * suffix <code>".tmp"</code> will be used
-+ *
-+ * @param directory The directory in which the file is to be created, or
-+ * <code>null</code> if the default temporary-file
-+ * directory is to be used
-+ *
-+ * @return An abstract pathname denoting a newly-created empty file
-+ *
-+ * @see java.io.File#createTempFile(String,String,java.io.File)
-+ */
-+ public static File createTempFile(String prefix, String suffix, File directory)
-+ throws IOException
-+ {
-+ return SharedSecrets.getJavaIOFileAccess().createTempFile(prefix, suffix, directory);
-+ }
-+
-+ public static File createTempFile(String prefix, String suffix)
-+ throws IOException
-+ {
-+ return SharedSecrets.getJavaIOFileAccess().createTempFile(prefix, suffix, null);
-+ }
- }
---- jdk/src/share/classes/sun/misc/JavaIOFileAccess.java 1969-12-31 19:00:00.000000000 -0500
-+++ jdk/src/share/classes/sun/misc/JavaIOFileAccess.java 2012-09-05 19:34:26.000000000 -0400
-@@ -0,0 +1,35 @@
-+/*
-+ * Copyright (c) 2012, 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. Oracle designates this
-+ * particular file as subject to the "Classpath" exception as provided
-+ * by Oracle in the LICENSE file that accompanied this code.
-+ *
-+ * 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.
-+ */
-+
-+package sun.misc;
-+
-+import java.io.File;
-+import java.io.IOException;
-+
-+public interface JavaIOFileAccess {
-+ public File createTempFile(String prefix, String suffix, File directory)
-+ throws IOException;
-+}
-+
---- jdk/src/share/classes/sun/misc/SharedSecrets.java 2012-05-01 17:18:21.000000000 -0400
-+++ jdk/src/share/classes/sun/misc/SharedSecrets.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2002, 2012, 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
-@@ -53,6 +53,7 @@
- private static JavaSecurityProtectionDomainAccess javaSecurityProtectionDomainAccess;
- private static JavaSecurityAccess javaSecurityAccess;
- private static JavaAWTAccess javaAWTAccess;
-+ private static JavaIOFileAccess javaIOFileAccess;
-
- public static JavaUtilJarAccess javaUtilJarAccess() {
- if (javaUtilJarAccess == null) {
-@@ -149,4 +150,12 @@
- // provision for.
- return javaAWTAccess;
- }
-+
-+ public static void setJavaIOFileAccess(JavaIOFileAccess access) {
-+ javaIOFileAccess = access;
-+ }
-+
-+ public static JavaIOFileAccess getJavaIOFileAccess() {
-+ return javaIOFileAccess;
-+ }
- }
---- jdk/src/share/classes/sun/net/www/protocol/jar/URLJarFile.java 2012-05-01 17:18:22.000000000 -0400
-+++ jdk/src/share/classes/sun/net/www/protocol/jar/URLJarFile.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2001, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2001, 2012, 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
-@@ -219,7 +219,7 @@
- OutputStream out = null;
- File tmpFile = null;
- try {
-- tmpFile = File.createTempFile("jar_cache", null);
-+ tmpFile = sun.misc.IOUtils.createTempFile("jar_cache", null);
- tmpFile.deleteOnExit();
- out = new FileOutputStream(tmpFile);
- int read = 0;
---- jdk/src/share/classes/sun/print/PSPrinterJob.java 2012-05-01 17:18:24.000000000 -0400
-+++ jdk/src/share/classes/sun/print/PSPrinterJob.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -652,7 +652,7 @@
- * is not removed for some reason, request that it is
- * removed when the VM exits.
- */
-- spoolFile = File.createTempFile("javaprint", ".ps", null);
-+ spoolFile = sun.misc.IOUtils.createTempFile("javaprint", ".ps", null);
- spoolFile.deleteOnExit();
-
- result = new FileOutputStream(spoolFile);
---- jdk/src/share/classes/sun/rmi/server/Activation.java 2012-05-01 17:18:25.000000000 -0400
-+++ jdk/src/share/classes/sun/rmi/server/Activation.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1997, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1997, 2012, 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
-@@ -1916,7 +1916,7 @@
- new PrivilegedExceptionAction<Void>() {
- public Void run() throws IOException {
- File file =
-- File.createTempFile("rmid-err", null, null);
-+ sun.misc.IOUtils.createTempFile("rmid-err", null, null);
- PrintStream errStream =
- new PrintStream(new FileOutputStream(file));
- System.setErr(errStream);
---- jdk/src/share/classes/sun/security/x509/CRLExtensions.java 2012-05-01 17:18:27.000000000 -0400
-+++ jdk/src/share/classes/sun/security/x509/CRLExtensions.java 2012-09-05 19:34:26.000000000 -0400
-@@ -32,8 +32,10 @@
- import java.security.cert.CRLException;
- import java.security.cert.CertificateException;
- import java.util.Collection;
-+import java.util.Collections;
- import java.util.Enumeration;
--import java.util.Hashtable;
-+import java.util.Map;
-+import java.util.TreeMap;
-
- import sun.security.util.*;
- import sun.misc.HexDumpEncoder;
-@@ -62,7 +64,8 @@
- */
- public class CRLExtensions {
-
-- private Hashtable<String,Extension> map = new Hashtable<String,Extension>();
-+ private Map<String,Extension> map = Collections.synchronizedMap(
-+ new TreeMap<String,Extension>());
- private boolean unsupportedCritExt = false;
-
- /**
-@@ -215,7 +218,7 @@
- * @return an enumeration of the extensions in this CRL.
- */
- public Enumeration<Extension> getElements() {
-- return map.elements();
-+ return Collections.enumeration(map.values());
- }
-
- /**
---- jdk/src/share/classes/sun/security/x509/CertificateExtensions.java 2012-05-01 17:18:27.000000000 -0400
-+++ jdk/src/share/classes/sun/security/x509/CertificateExtensions.java 2012-09-05 19:34:26.000000000 -0400
-@@ -57,7 +57,8 @@
-
- private static final Debug debug = Debug.getInstance("x509");
-
-- private Hashtable<String,Extension> map = new Hashtable<String,Extension>();
-+ private Map<String,Extension> map = Collections.synchronizedMap(
-+ new TreeMap<String,Extension>());
- private boolean unsupportedCritExt = false;
-
- private Map<String,Extension> unparseableExtensions;
-@@ -117,7 +118,7 @@
- if (ext.isCritical() == false) {
- // ignore errors parsing non-critical extensions
- if (unparseableExtensions == null) {
-- unparseableExtensions = new HashMap<String,Extension>();
-+ unparseableExtensions = new TreeMap<String,Extension>();
- }
- unparseableExtensions.put(ext.getExtensionId().toString(),
- new UnparseableExtension(ext, e));
-@@ -218,6 +219,12 @@
- return (obj);
- }
-
-+ // Similar to get(String), but throw no exception, might return null.
-+ // Used in X509CertImpl::getExtension(OID).
-+ Extension getExtension(String name) {
-+ return map.get(name);
-+ }
-+
- /**
- * Delete the attribute value.
- * @param name the extension name used in the lookup.
-@@ -236,7 +243,7 @@
- * attribute.
- */
- public Enumeration<Extension> getElements() {
-- return map.elements();
-+ return Collections.enumeration(map.values());
- }
-
- /**
---- jdk/src/share/classes/sun/security/x509/X509CRLEntryImpl.java 2012-05-01 17:18:27.000000000 -0400
-+++ jdk/src/share/classes/sun/security/x509/X509CRLEntryImpl.java 2012-09-05 19:34:26.000000000 -0400
-@@ -31,11 +31,7 @@
- import java.security.cert.CertificateException;
- import java.security.cert.X509CRLEntry;
- import java.math.BigInteger;
--import java.util.Collection;
--import java.util.Date;
--import java.util.Enumeration;
--import java.util.Set;
--import java.util.HashSet;
-+import java.util.*;
-
- import javax.security.auth.x500.X500Principal;
-
-@@ -72,7 +68,8 @@
- * @author Hemma Prafullchandra
- */
-
--public class X509CRLEntryImpl extends X509CRLEntry {
-+public class X509CRLEntryImpl extends X509CRLEntry
-+ implements Comparable<X509CRLEntryImpl> {
-
- private SerialNumber serialNumber = null;
- private Date revocationDate = null;
-@@ -193,9 +190,14 @@
- * @exception CRLException if an encoding error occurs.
- */
- public byte[] getEncoded() throws CRLException {
-+ return getEncoded0().clone();
-+ }
-+
-+ // Called internally to avoid clone
-+ private byte[] getEncoded0() throws CRLException {
- if (revokedCert == null)
- this.encode(new DerOutputStream());
-- return revokedCert.clone();
-+ return revokedCert;
- }
-
- @Override
-@@ -313,7 +315,7 @@
- if (extensions == null) {
- return null;
- }
-- Set<String> extSet = new HashSet<String>();
-+ Set<String> extSet = new TreeSet<String>();
- for (Extension ex : extensions.getAllExtensions()) {
- if (ex.isCritical()) {
- extSet.add(ex.getExtensionId().toString());
-@@ -334,7 +336,7 @@
- if (extensions == null) {
- return null;
- }
-- Set<String> extSet = new HashSet<String>();
-+ Set<String> extSet = new TreeSet<String>();
- for (Extension ex : extensions.getAllExtensions()) {
- if (!ex.isCritical()) {
- extSet.add(ex.getExtensionId().toString());
-@@ -461,4 +463,24 @@
- return (CertificateIssuerExtension)
- getExtension(PKIXExtensions.CertificateIssuer_Id);
- }
-+
-+ @Override
-+ public int compareTo(X509CRLEntryImpl that) {
-+ int compSerial = getSerialNumber().compareTo(that.getSerialNumber());
-+ if (compSerial != 0) {
-+ return compSerial;
-+ }
-+ try {
-+ byte[] thisEncoded = this.getEncoded0();
-+ byte[] thatEncoded = that.getEncoded0();
-+ for (int i=0; i<thisEncoded.length && i<thatEncoded.length; i++) {
-+ int a = thisEncoded[i] & 0xff;
-+ int b = thatEncoded[i] & 0xff;
-+ if (a != b) return a-b;
-+ }
-+ return thisEncoded.length -thatEncoded.length;
-+ } catch (CRLException ce) {
-+ return -1;
-+ }
-+ }
- }
---- jdk/src/share/classes/sun/security/x509/X509CRLImpl.java 2012-05-01 17:18:27.000000000 -0400
-+++ jdk/src/share/classes/sun/security/x509/X509CRLImpl.java 2012-09-05 19:34:26.000000000 -0400
-@@ -53,7 +53,7 @@
-
- /**
- * <p>
-- * An implmentation for X509 CRL (Certificate Revocation List).
-+ * An implementation for X509 CRL (Certificate Revocation List).
- * <p>
- * The X.509 v2 CRL format is described below in ASN.1:
- * <pre>
-@@ -104,7 +104,8 @@
- private X500Principal issuerPrincipal = null;
- private Date thisUpdate = null;
- private Date nextUpdate = null;
-- private Map<X509IssuerSerial,X509CRLEntry> revokedCerts = new LinkedHashMap<X509IssuerSerial,X509CRLEntry>();
-+ private Map<X509IssuerSerial,X509CRLEntry> revokedMap = new TreeMap<X509IssuerSerial,X509CRLEntry>();
-+ private List<X509CRLEntry> revokedList = new LinkedList<X509CRLEntry>();
- private CRLExtensions extensions = null;
- private final static boolean isExplicit = true;
- private static final long YR_2050 = 2524636800000L;
-@@ -223,7 +224,8 @@
- badCert.setCertificateIssuer(crlIssuer, badCertIssuer);
- X509IssuerSerial issuerSerial = new X509IssuerSerial
- (badCertIssuer, badCert.getSerialNumber());
-- this.revokedCerts.put(issuerSerial, badCert);
-+ this.revokedMap.put(issuerSerial, badCert);
-+ this.revokedList.add(badCert);
- if (badCert.hasExtensions()) {
- this.version = 1;
- }
-@@ -305,8 +307,8 @@
- tmp.putGeneralizedTime(nextUpdate);
- }
-
-- if (!revokedCerts.isEmpty()) {
-- for (X509CRLEntry entry : revokedCerts.values()) {
-+ if (!revokedList.isEmpty()) {
-+ for (X509CRLEntry entry : revokedList) {
- ((X509CRLEntryImpl)entry).encode(rCerts);
- }
- tmp.write(DerValue.tag_Sequence, rCerts);
-@@ -490,14 +492,14 @@
- sb.append("\nThis Update: " + thisUpdate.toString() + "\n");
- if (nextUpdate != null)
- sb.append("Next Update: " + nextUpdate.toString() + "\n");
-- if (revokedCerts.isEmpty())
-+ if (revokedList.isEmpty())
- sb.append("\nNO certificates have been revoked\n");
- else {
-- sb.append("\nRevoked Certificates: " + revokedCerts.size());
-+ sb.append("\nRevoked Certificates: " + revokedList.size());
- int i = 1;
-- for (Iterator<X509CRLEntry> iter = revokedCerts.values().iterator();
-- iter.hasNext(); i++)
-- sb.append("\n[" + i + "] " + iter.next().toString());
-+ for (X509CRLEntry entry: revokedList) {
-+ sb.append("\n[" + i++ + "] " + entry.toString());
-+ }
- }
- if (extensions != null) {
- Collection<Extension> allExts = extensions.getAllExtensions();
-@@ -543,12 +545,12 @@
- * false otherwise.
- */
- public boolean isRevoked(Certificate cert) {
-- if (revokedCerts.isEmpty() || (!(cert instanceof X509Certificate))) {
-+ if (revokedMap.isEmpty() || (!(cert instanceof X509Certificate))) {
- return false;
- }
- X509Certificate xcert = (X509Certificate) cert;
- X509IssuerSerial issuerSerial = new X509IssuerSerial(xcert);
-- return revokedCerts.containsKey(issuerSerial);
-+ return revokedMap.containsKey(issuerSerial);
- }
-
- /**
-@@ -638,24 +640,24 @@
- * @see X509CRLEntry
- */
- public X509CRLEntry getRevokedCertificate(BigInteger serialNumber) {
-- if (revokedCerts.isEmpty()) {
-+ if (revokedMap.isEmpty()) {
- return null;
- }
- // assume this is a direct CRL entry (cert and CRL issuer are the same)
- X509IssuerSerial issuerSerial = new X509IssuerSerial
- (getIssuerX500Principal(), serialNumber);
-- return revokedCerts.get(issuerSerial);
-+ return revokedMap.get(issuerSerial);
- }
-
- /**
- * Gets the CRL entry for the given certificate.
- */
- public X509CRLEntry getRevokedCertificate(X509Certificate cert) {
-- if (revokedCerts.isEmpty()) {
-+ if (revokedMap.isEmpty()) {
- return null;
- }
- X509IssuerSerial issuerSerial = new X509IssuerSerial(cert);
-- return revokedCerts.get(issuerSerial);
-+ return revokedMap.get(issuerSerial);
- }
-
- /**
-@@ -667,10 +669,10 @@
- * @see X509CRLEntry
- */
- public Set<X509CRLEntry> getRevokedCertificates() {
-- if (revokedCerts.isEmpty()) {
-+ if (revokedList.isEmpty()) {
- return null;
- } else {
-- return new HashSet<X509CRLEntry>(revokedCerts.values());
-+ return new TreeSet<X509CRLEntry>(revokedList);
- }
- }
-
-@@ -896,7 +898,7 @@
- if (extensions == null) {
- return null;
- }
-- Set<String> extSet = new HashSet<String>();
-+ Set<String> extSet = new TreeSet<String>();
- for (Extension ex : extensions.getAllExtensions()) {
- if (ex.isCritical()) {
- extSet.add(ex.getExtensionId().toString());
-@@ -917,7 +919,7 @@
- if (extensions == null) {
- return null;
- }
-- Set<String> extSet = new HashSet<String>();
-+ Set<String> extSet = new TreeSet<String>();
- for (Extension ex : extensions.getAllExtensions()) {
- if (!ex.isCritical()) {
- extSet.add(ex.getExtensionId().toString());
-@@ -1094,7 +1096,8 @@
- entry.setCertificateIssuer(crlIssuer, badCertIssuer);
- X509IssuerSerial issuerSerial = new X509IssuerSerial
- (badCertIssuer, entry.getSerialNumber());
-- revokedCerts.put(issuerSerial, entry);
-+ revokedMap.put(issuerSerial, entry);
-+ revokedList.add(entry);
- }
- }
-
-@@ -1192,7 +1195,8 @@
- /**
- * Immutable X.509 Certificate Issuer DN and serial number pair
- */
-- private final static class X509IssuerSerial {
-+ private final static class X509IssuerSerial
-+ implements Comparable<X509IssuerSerial> {
- final X500Principal issuer;
- final BigInteger serial;
- volatile int hashcode = 0;
-@@ -1271,5 +1275,13 @@
- }
- return hashcode;
- }
-+
-+ @Override
-+ public int compareTo(X509IssuerSerial another) {
-+ int cissuer = issuer.toString()
-+ .compareTo(another.issuer.toString());
-+ if (cissuer != 0) return cissuer;
-+ return this.serial.compareTo(another.serial);
-+ }
- }
- }
---- jdk/src/share/classes/sun/security/x509/X509CertImpl.java 2012-05-01 17:18:27.000000000 -0400
-+++ jdk/src/share/classes/sun/security/x509/X509CertImpl.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1214,7 +1214,7 @@
- if (exts == null) {
- return null;
- }
-- Set<String> extSet = new HashSet<String>();
-+ Set<String> extSet = new TreeSet<String>();
- for (Extension ex : exts.getAllExtensions()) {
- if (ex.isCritical()) {
- extSet.add(ex.getExtensionId().toString());
-@@ -1244,7 +1244,7 @@
- if (exts == null) {
- return null;
- }
-- Set<String> extSet = new HashSet<String>();
-+ Set<String> extSet = new TreeSet<String>();
- for (Extension ex : exts.getAllExtensions()) {
- if (!ex.isCritical()) {
- extSet.add(ex.getExtensionId().toString());
-@@ -1278,10 +1278,14 @@
- if (extensions == null) {
- return null;
- } else {
-- for (Extension ex : extensions.getAllExtensions()) {
-- if (ex.getExtensionId().equals(oid)) {
-+ Extension ex = extensions.getExtension(oid.toString());
-+ if (ex != null) {
-+ return ex;
-+ }
-+ for (Extension ex2: extensions.getAllExtensions()) {
-+ if (ex2.getExtensionId().equals((Object)oid)) {
- //XXXX May want to consider cloning this
-- return ex;
-+ return ex2;
- }
- }
- /* no such extension in this certificate */
-@@ -1480,7 +1484,7 @@
- if (names.isEmpty()) {
- return Collections.<List<?>>emptySet();
- }
-- Set<List<?>> newNames = new HashSet<List<?>>();
-+ List<List<?>> newNames = new ArrayList<List<?>>();
- for (GeneralName gname : names.names()) {
- GeneralNameInterface name = gname.getName();
- List<Object> nameEntry = new ArrayList<Object>(2);
-@@ -1541,7 +1545,7 @@
- }
- }
- if (mustClone) {
-- Set<List<?>> namesCopy = new HashSet<List<?>>();
-+ List<List<?>> namesCopy = new ArrayList<List<?>>();
- for (List<?> nameEntry : altNames) {
- Object nameObject = nameEntry.get(1);
- if (nameObject instanceof byte[]) {
---- jdk/src/share/classes/sun/tools/jar/Main.java 2012-05-01 17:18:28.000000000 -0400
-+++ jdk/src/share/classes/sun/tools/jar/Main.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1996, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1996, 2012, 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
-@@ -127,14 +127,14 @@
-
- /**
- * Creates a new empty temporary file in the same directory as the
-- * specified file. A variant of File.createTempFile.
-+ * specified file. A variant of sun.misc.IOUtils.createTempFile.
- */
- private static File createTempFileInSameDirectoryAs(File file)
- throws IOException {
- File dir = file.getParentFile();
- if (dir == null)
- dir = new File(".");
-- return File.createTempFile("jartmp", null, dir);
-+ return sun.misc.IOUtils.createTempFile("jartmp", null, dir);
- }
-
- private boolean ok;
---- jdk/src/share/classes/sun/tools/native2ascii/Main.java 2012-05-01 17:18:28.000000000 -0400
-+++ jdk/src/share/classes/sun/tools/native2ascii/Main.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1996, 2007, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1996, 2012, 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
-@@ -237,9 +237,7 @@
- if (tempDir == null)
- tempDir = new File(System.getProperty("user.dir"));
-
-- tempFile = File.createTempFile("_N2A",
-- ".TMP",
-- tempDir);
-+ tempFile = sun.misc.IOUtils.createTempFile("_N2A", ".TMP", tempDir);
- tempFile.deleteOnExit();
-
- try {
---- jdk/src/share/lib/security/java.security 2012-05-01 17:18:31.000000000 -0400
-+++ jdk/src/share/lib/security/java.security 2012-09-05 19:34:26.000000000 -0400
-@@ -127,7 +127,7 @@
- # passed to checkPackageAccess unless the
- # corresponding RuntimePermission ("accessClassInPackage."+package) has
- # been granted.
--package.access=sun.,com.sun.xml.internal.ws.,com.sun.xml.internal.bind.,com.sun.imageio.
-+package.access=sun.,com.sun.xml.internal.ws.,com.sun.xml.internal.bind.,com.sun.imageio.,com.sun.org.apache.xerces.internal.utils.,com.sun.org.apache.xalan.internal.utils.
-
- #
- # List of comma-separated packages that start with or equal this string
-@@ -136,10 +136,10 @@
- # corresponding RuntimePermission ("defineClassInPackage."+package) has
- # been granted.
- #
--# by default, no packages are restricted for definition, and none of
--# the class loaders supplied with the JDK call checkPackageDefinition.
-+# by default, none of the class loaders supplied with the JDK call
-+# checkPackageDefinition.
- #
--#package.definition=
-+package.definition=sun.,com.sun.xml.internal.ws.,com.sun.xml.internal.bind.,com.sun.imageio.,com.sun.org.apache.xerces.internal.utils.,com.sun.org.apache.xalan.internal.utils.
-
- #
- # Determines whether this properties file can be appended to
---- jdk/src/share/lib/security/java.security-solaris 2012-05-01 17:18:31.000000000 -0400
-+++ jdk/src/share/lib/security/java.security-solaris 2012-09-05 19:34:26.000000000 -0400
-@@ -137,10 +137,10 @@
- # corresponding RuntimePermission ("defineClassInPackage."+package) has
- # been granted.
- #
--# by default, no packages are restricted for definition, and none of
--# the class loaders supplied with the JDK call checkPackageDefinition.
-+# by default, none of the class loaders supplied with the JDK call
-+# checkPackageDefinition.
- #
--#package.definition=
-+package.definition=sun.,com.sun.xml.internal.ws.,com.sun.xml.internal.bind.,com.sun.imageio.,com.sun.org.apache.xerces.internal.utils.,com.sun.org.apache.xalan.internal.utils.
-
- #
- # Determines whether this properties file can be appended to
---- jdk/src/share/lib/security/java.security-windows 2012-05-01 17:18:31.000000000 -0400
-+++ jdk/src/share/lib/security/java.security-windows 2012-09-05 19:34:26.000000000 -0400
-@@ -137,10 +137,10 @@
- # corresponding RuntimePermission ("defineClassInPackage."+package) has
- # been granted.
- #
--# by default, no packages are restricted for definition, and none of
--# the class loaders supplied with the JDK call checkPackageDefinition.
-+# by default, none of the class loaders supplied with the JDK call
-+# checkPackageDefinition.
- #
--#package.definition=
-+package.definition=sun.,com.sun.xml.internal.ws.,com.sun.xml.internal.bind.,com.sun.imageio.,com.sun.org.apache.xerces.internal.utils.,com.sun.org.apache.xalan.internal.utils.
-
- #
- # Determines whether this properties file can be appended to
---- jdk/src/share/native/sun/font/layout/LookupProcessor.cpp 2012-05-01 17:18:33.000000000 -0400
-+++ jdk/src/share/native/sun/font/layout/LookupProcessor.cpp 2012-09-05 19:34:26.000000000 -0400
-@@ -86,6 +86,10 @@
-
- if (selectMask != 0) {
- const LookupTable *lookupTable = lookupListTable->getLookupTable(lookup);
-+
-+ if (!lookupTable)
-+ continue;
-+
- le_uint16 lookupFlags = SWAPW(lookupTable->lookupFlags);
-
- glyphIterator.reset(lookupFlags, selectMask);
-@@ -124,6 +128,9 @@
- for (le_uint16 lookup = 0; lookup < lookupCount; lookup += 1) {
- le_uint16 lookupListIndex = SWAPW(featureTable->lookupListIndexArray[lookup]);
-
-+ if (lookupListIndex >= lookupSelectCount)
-+ continue;
-+
- lookupSelectArray[lookupListIndex] |= featureMask;
- lookupOrderArray[store++] = lookupListIndex;
- }
-@@ -135,7 +142,7 @@
- Offset scriptListOffset, Offset featureListOffset, Offset lookupListOffset,
- LETag scriptTag, LETag languageTag, const FeatureMap *featureMap,
- le_int32 featureMapCount, le_bool orderFeatures)
-- : lookupListTable(NULL), featureListTable(NULL), lookupSelectArray(NULL),
-+ : lookupListTable(NULL), featureListTable(NULL), lookupSelectArray(NULL), lookupSelectCount(0),
- lookupOrderArray(NULL), lookupOrderCount(0)
- {
- const ScriptListTable *scriptListTable = NULL;
-@@ -175,6 +182,8 @@
- lookupSelectArray[i] = 0;
- }
-
-+ lookupSelectCount = lookupListCount;
-+
- le_int32 count, order = 0;
- le_int32 featureReferences = 0;
- const FeatureTable *featureTable = NULL;
-@@ -191,6 +200,10 @@
- le_uint16 featureIndex = SWAPW(langSysTable->featureIndexArray[feature]);
-
- featureTable = featureListTable->getFeatureTable(featureIndex, &featureTag);
-+
-+ if (!featureTable)
-+ continue;
-+
- featureReferences += SWAPW(featureTable->lookupCount);
- }
-
---- jdk/src/share/native/sun/font/layout/LookupProcessor.h 2012-05-01 17:18:33.000000000 -0400
-+++ jdk/src/share/native/sun/font/layout/LookupProcessor.h 2012-09-05 19:34:26.000000000 -0400
-@@ -77,6 +77,7 @@
- const FeatureListTable *featureListTable;
-
- FeatureMask *lookupSelectArray;
-+ le_uint32 lookupSelectCount;
-
- le_uint16 *lookupOrderArray;
- le_uint32 lookupOrderCount;
---- jdk/src/solaris/classes/java/io/UnixFileSystem.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/java/io/UnixFileSystem.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2005, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -253,7 +253,7 @@
-
- /* -- File operations -- */
-
-- public native boolean createFileExclusively(String path)
-+ public native boolean createFileExclusively(String path, boolean restrictive)
- throws IOException;
- public boolean delete(File f) {
- // Keep canonicalization caches in sync after file deletion
---- jdk/src/solaris/classes/sun/awt/X11/XCheckboxMenuItemPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XCheckboxMenuItemPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -29,27 +29,12 @@
- import java.awt.peer.*;
- import java.awt.event.*;
-
--import java.lang.reflect.Field;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- class XCheckboxMenuItemPeer extends XMenuItemPeer implements CheckboxMenuItemPeer {
-
- /************************************************
- *
-- * Data members
-- *
-- ************************************************/
--
-- /*
-- * CheckboxMenuItem's fields
-- */
-- private final static Field f_state;
-- static {
-- f_state = SunToolkit.getField(CheckboxMenuItem.class, "state");
-- }
--
-- /************************************************
-- *
- * Construction
- *
- ************************************************/
-@@ -74,16 +59,8 @@
- *
- ************************************************/
- boolean getTargetState() {
-- MenuItem target = getTarget();
-- if (target == null) {
-- return false;
-- }
-- try {
-- return f_state.getBoolean(target);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- }
-- return false;
-+ return AWTAccessor.getCheckboxMenuItemAccessor()
-+ .getState((CheckboxMenuItem)getTarget());
- }
-
- /************************************************
---- jdk/src/solaris/classes/sun/awt/X11/XComponentPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XComponentPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -31,17 +31,13 @@
- import java.awt.Component;
- import java.awt.Container;
- import java.awt.Cursor;
--import java.awt.DefaultKeyboardFocusManager;
- import java.awt.Dimension;
--import java.awt.Event;
- import java.awt.Font;
- import java.awt.FontMetrics;
- import java.awt.Graphics;
- import java.awt.Image;
- import java.awt.Insets;
- import java.awt.KeyboardFocusManager;
--import java.awt.MenuBar;
--import java.awt.Point;
- import java.awt.Rectangle;
- import java.awt.SystemColor;
- import java.awt.Toolkit;
-@@ -60,12 +56,9 @@
- import java.awt.image.ImageObserver;
- import java.awt.image.ImageProducer;
- import java.awt.image.VolatileImage;
--import java.awt.peer.CanvasPeer;
- import java.awt.peer.ComponentPeer;
- import java.awt.peer.ContainerPeer;
- import java.awt.peer.LightweightPeer;
--import java.awt.peer.PanelPeer;
--import java.awt.peer.WindowPeer;
- import java.lang.reflect.*;
- import java.security.*;
- import java.util.Collection;
-@@ -397,19 +390,8 @@
- }
- }
-
-- static Method requestFocusWithCause;
--
- static void callRequestFocus(Component target, CausedFocusEvent.Cause cause) {
-- if (requestFocusWithCause == null) {
-- requestFocusWithCause = SunToolkit.getMethod(Component.class, "requestFocus", new Class[] {CausedFocusEvent.Cause.class});
-- }
-- if (requestFocusWithCause != null) {
-- try {
-- requestFocusWithCause.invoke(target, new Object[] {cause});
-- } catch (Exception e) {
-- e.printStackTrace();
-- }
-- }
-+ AWTAccessor.getComponentAccessor().requestFocus(target, cause);
- }
-
- final public boolean requestFocus(Component lightweightChild, boolean temporary,
---- jdk/src/solaris/classes/sun/awt/X11/XEmbedCanvasPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XEmbedCanvasPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -29,14 +29,7 @@
- import java.awt.dnd.DropTarget;
- import java.awt.dnd.DropTargetListener;
- import java.awt.event.*;
--import java.awt.image.ColorModel;
--import java.awt.image.ImageObserver;
--import java.awt.image.ImageProducer;
--import java.awt.image.VolatileImage;
--import java.awt.peer.*;
- import sun.awt.*;
--import sun.awt.motif.X11FontMetrics;
--import java.lang.reflect.*;
- import java.util.logging.*;
- import java.util.*;
- import static sun.awt.X11.XEmbedHelper.*;
-@@ -455,16 +448,8 @@
- }
- }
-
-- static Field bdataField;
- static byte[] getBData(KeyEvent e) {
-- try {
-- if (bdataField == null) {
-- bdataField = SunToolkit.getField(java.awt.AWTEvent.class, "bdata");
-- }
-- return (byte[])bdataField.get(e);
-- } catch (IllegalAccessException ex) {
-- return null;
-- }
-+ return AWTAccessor.getAWTEventAccessor().getBData(e);
- }
-
- void forwardKeyEvent(KeyEvent e) {
---- jdk/src/solaris/classes/sun/awt/X11/XEmbeddingContainer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XEmbeddingContainer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,8 +28,7 @@
- import java.awt.*;
- import java.util.HashMap;
- import java.awt.event.KeyEvent;
--import java.lang.reflect.*;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public class XEmbeddingContainer extends XEmbedHelper implements XEventDispatcher {
- HashMap children = new HashMap();
-@@ -127,20 +126,8 @@
- }
- }
-
-- static Field bdata;
-- byte[] getBData(KeyEvent e) {
-- try {
-- if (bdata == null) {
-- bdata = SunToolkit.getField(java.awt.AWTEvent.class, "bdata");
-- }
-- return (byte[])bdata.get(e);
-- } catch (IllegalAccessException ex) {
-- return null;
-- }
-- }
--
- void forwardKeyEvent(long child, KeyEvent e) {
-- byte[] bdata = getBData(e);
-+ byte[] bdata = AWTAccessor.getAWTEventAccessor().getBData(e);
- long data = Native.toData(bdata);
- if (data == 0) {
- return;
---- jdk/src/solaris/classes/sun/awt/X11/XGlobalCursorManager.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XGlobalCursorManager.java 2012-09-05 19:35:40.000000000 -0400
-@@ -29,32 +29,13 @@
- import java.awt.peer.ComponentPeer;
- import java.awt.peer.LightweightPeer;
- import java.lang.ref.WeakReference;
--import java.lang.reflect.Field;
--import java.lang.reflect.Method;
- import sun.awt.ComponentAccessor;
-
- import sun.awt.GlobalCursorManager;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public final class XGlobalCursorManager extends GlobalCursorManager {
-
-- private static Field field_pData;
-- private static Field field_type;
-- private static Class cursorClass;
-- private static Method method_setPData;
-- static {
-- cursorClass = java.awt.Cursor.class;
-- field_pData = SunToolkit.getField(cursorClass, "pData");
-- field_type = SunToolkit.getField(cursorClass, "type");
-- method_setPData = SunToolkit.getMethod(cursorClass, "setPData", new Class[] {long.class});
-- if (field_pData == null || field_type == null || method_setPData == null) {
-- System.out.println("Unable to initialize XGlobalCursorManager: ");
-- Thread.dumpStack();
--
-- }
-- }
--
--
- // cached nativeContainer
- private WeakReference<Component> nativeContainer;
-
-@@ -216,8 +197,8 @@
- long pData = 0;
- int type = 0;
- try {
-- pData = field_pData.getLong(c);
-- type = field_type.getInt(c);
-+ pData = AWTAccessor.getCursorAccessor().getPData(c);
-+ type = AWTAccessor.getCursorAccessor().getType(c);
- }
- catch (Exception e)
- {
-@@ -287,7 +268,7 @@
-
- static void setPData(Cursor c, long pData) {
- try {
-- method_setPData.invoke(c, pData);
-+ AWTAccessor.getCursorAccessor().setPData(c, pData);
- }
- catch (Exception e)
- {
---- jdk/src/solaris/classes/sun/awt/X11/XKeyboardFocusManagerPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XKeyboardFocusManagerPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -32,14 +32,11 @@
-
- import java.awt.peer.KeyboardFocusManagerPeer;
-
--import java.lang.reflect.InvocationTargetException;
--import java.lang.reflect.Method;
--
- import java.util.logging.Level;
- import java.util.logging.Logger;
-
- import sun.awt.CausedFocusEvent;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public class XKeyboardFocusManagerPeer implements KeyboardFocusManagerPeer {
- private static final Logger focusLog = Logger.getLogger("sun.awt.X11.focus.XKeyboardFocusManagerPeer");
-@@ -130,46 +127,16 @@
- return true;
- }
-
-- static Method shouldNativelyFocusHeavyweightMethod;
--
- static int shouldNativelyFocusHeavyweight(Component heavyweight,
- Component descendant, boolean temporary,
- boolean focusedWindowChangeAllowed, long time, CausedFocusEvent.Cause cause)
- {
-- if (shouldNativelyFocusHeavyweightMethod == null) {
-- Class[] arg_types =
-- new Class[] { Component.class,
-- Component.class,
-- Boolean.TYPE,
-- Boolean.TYPE,
-- Long.TYPE,
-- CausedFocusEvent.Cause.class
-- };
--
-- shouldNativelyFocusHeavyweightMethod =
-- SunToolkit.getMethod(KeyboardFocusManager.class,
-- "shouldNativelyFocusHeavyweight",
-- arg_types);
-- }
-- Object[] args = new Object[] { heavyweight,
-- descendant,
-- Boolean.valueOf(temporary),
-- Boolean.valueOf(focusedWindowChangeAllowed),
-- Long.valueOf(time), cause};
--
-- int result = XComponentPeer.SNFH_FAILURE;
-- if (shouldNativelyFocusHeavyweightMethod != null) {
-- try {
-- result = ((Integer) shouldNativelyFocusHeavyweightMethod.invoke(null, args)).intValue();
-- }
-- catch (IllegalAccessException e) {
-- assert false;
-- }
-- catch (InvocationTargetException e) {
-- assert false;
-- }
-- }
--
-- return result;
-+ return AWTAccessor.getKeyboardFocusManagerAccessor()
-+ .shouldNativelyFocusHeavyweight(heavyweight,
-+ descendant,
-+ temporary,
-+ focusedWindowChangeAllowed,
-+ time,
-+ cause);
- }
- }
---- jdk/src/solaris/classes/sun/awt/X11/XMenuBarPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XMenuBarPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,10 +28,9 @@
- import java.awt.peer.*;
- import java.awt.event.*;
-
--import java.lang.reflect.Field;
- import java.util.Vector;
- import java.util.logging.*;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public class XMenuBarPeer extends XBaseMenuWindow implements MenuBarPeer {
-
-@@ -67,15 +66,6 @@
- private final static int BAR_ITEM_MARGIN_TOP = 2;
- private final static int BAR_ITEM_MARGIN_BOTTOM = 2;
-
-- //fields
-- private static Field f_helpMenu;
-- private static Field f_menus;
--
-- static {
-- f_helpMenu = SunToolkit.getField(MenuBar.class, "helpMenu");
-- f_menus = SunToolkit.getField(MenuBar.class, "menus");
-- }
--
- /************************************************
- *
- * Mapping data
-@@ -204,19 +194,12 @@
- */
- void postInit(XCreateWindowParams params) {
- super.postInit(params);
-- Vector targetMenuVector = null;
-- Menu targetHelpMenu = null;
-- try {
-- // Get menus from the target.
-- targetMenuVector = (Vector)f_menus.get(menuBarTarget);
-- targetHelpMenu = (Menu)f_helpMenu.get(menuBarTarget);
-- reloadItems(targetMenuVector);
-- } catch (IllegalAccessException iae) {
-- iae.printStackTrace();
-- }
-- if (targetHelpMenu != null) {
-- addHelpMenu(targetHelpMenu);
-- }
-+ // Get menus from the target.
-+ Vector targetMenuVector = AWTAccessor.getMenuBarAccessor()
-+ .getMenus(menuBarTarget);
-+ Menu targetHelpMenu = AWTAccessor.getMenuBarAccessor()
-+ .getHelpMenu(menuBarTarget);
-+ reloadItems(targetMenuVector);
- xSetVisible(true);
- toFront();
- }
---- jdk/src/solaris/classes/sun/awt/X11/XMenuItemPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XMenuItemPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,12 +28,7 @@
- import java.awt.peer.*;
- import java.awt.event.*;
-
--import java.util.logging.*;
--
--import java.lang.reflect.Field;
--import java.lang.reflect.Method;
--import java.lang.reflect.InvocationTargetException;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public class XMenuItemPeer implements MenuItemPeer {
-
-@@ -83,24 +78,6 @@
- private final static int SEPARATOR_WIDTH = 20;
- private final static int SEPARATOR_HEIGHT = 5;
-
-- /*
-- * MenuItem's fields & methods
-- */
-- private final static Field f_enabled;
-- private final static Field f_label;
-- private final static Field f_shortcut;
-- private final static Method m_getFont;
-- private final static Method m_isItemEnabled;
-- private final static Method m_getActionCommand;
-- static {
-- f_enabled = SunToolkit.getField(MenuItem.class, "enabled");
-- f_label = SunToolkit.getField(MenuItem.class, "label");
-- f_shortcut = SunToolkit.getField(MenuItem.class, "shortcut");
--
-- m_getFont = SunToolkit.getMethod(MenuComponent.class, "getFont_NoClientCode", null);
-- m_getActionCommand = SunToolkit.getMethod(MenuItem.class, "getActionCommandImpl", null);
-- m_isItemEnabled = SunToolkit.getMethod(MenuItem.class, "isItemEnabled", null);
-- }
- /************************************************
- *
- * Text Metrics
-@@ -218,39 +195,21 @@
- if (target == null) {
- return XWindow.defaultFont;
- }
-- try {
-- return (Font)m_getFont.invoke(target, new Object[0]);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- } catch (InvocationTargetException e) {
-- e.printStackTrace();
-- }
-- return XWindow.defaultFont;
-+ return AWTAccessor.getMenuComponentAccessor().getFont_NoClientCode(target);
- }
-
- String getTargetLabel() {
- if (target == null) {
- return "";
- }
-- try {
-- String label = (String)f_label.get(target);
-- return (label == null) ? "" : label;
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- }
-- return "";
-+ return AWTAccessor.getMenuItemAccessor().getLabel(target);
- }
-
- boolean isTargetEnabled() {
- if (target == null) {
- return false;
- }
-- try {
-- return f_enabled.getBoolean(target);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- }
-- return false;
-+ return AWTAccessor.getMenuItemAccessor().isEnabled(target);
- }
-
- /**
-@@ -262,40 +221,21 @@
- if (target == null) {
- return false;
- }
-- try {
-- return ((Boolean)m_isItemEnabled.invoke(target, new Object[0])).booleanValue();
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- } catch (InvocationTargetException e) {
-- e.printStackTrace();
-- }
-- return false;
-+ return AWTAccessor.getMenuItemAccessor().isItemEnabled(target);
- }
-
- String getTargetActionCommand() {
- if (target == null) {
- return "";
- }
-- try {
-- return (String) m_getActionCommand.invoke(target,(Object[]) null);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- } catch (InvocationTargetException e) {
-- e.printStackTrace();
-- }
-- return "";
-+ return AWTAccessor.getMenuItemAccessor().getActionCommandImpl(target);
- }
-
- MenuShortcut getTargetShortcut() {
- if (target == null) {
- return null;
- }
-- try {
-- return (MenuShortcut)f_shortcut.get(target);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- }
-- return null;
-+ return AWTAccessor.getMenuItemAccessor().getShortcut(target);
- }
-
- String getShortcutText() {
---- jdk/src/solaris/classes/sun/awt/X11/XMenuPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XMenuPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -27,10 +27,9 @@
- import java.awt.*;
- import java.awt.peer.*;
-
--import java.lang.reflect.Field;
- import java.util.Vector;
- import java.util.logging.*;
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public class XMenuPeer extends XMenuItemPeer implements MenuPeer {
-
-@@ -46,16 +45,6 @@
- */
- XMenuWindow menuWindow;
-
--
-- /*
-- * Menu's fields & methods
-- */
-- private final static Field f_items;
--
-- static {
-- f_items = SunToolkit.getField(Menu.class, "items");
-- }
--
- /************************************************
- *
- * Construction
-@@ -153,12 +142,7 @@
- *
- ************************************************/
- Vector getTargetItems() {
-- try {
-- return (Vector)f_items.get(getTarget());
-- } catch (IllegalAccessException iae) {
-- iae.printStackTrace();
-- return null;
-- }
-+ return AWTAccessor.getMenuAccessor().getItems((Menu)getTarget());
- }
-
- /************************************************
---- jdk/src/solaris/classes/sun/awt/X11/XPopupMenuPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XPopupMenuPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,15 +28,10 @@
- import java.awt.peer.*;
- import java.awt.event.*;
-
--import java.lang.reflect.Field;
--import java.lang.reflect.Method;
--import java.lang.reflect.InvocationTargetException;
--
- import java.util.Vector;
-+import sun.awt.AWTAccessor;
- import java.util.logging.*;
-
--import sun.awt.SunToolkit;
--
- public class XPopupMenuPeer extends XMenuWindow implements PopupMenuPeer {
-
- /************************************************
-@@ -66,24 +61,6 @@
- private final static int CAPTION_MARGIN_TOP = 4;
- private final static int CAPTION_SEPARATOR_HEIGHT = 6;
-
-- /*
-- * Menu's fields & methods
-- */
-- //Fix for 6184485: Popup menu is not disabled on XToolkit even when calling setEnabled (false)
-- private final static Field f_enabled;
-- //Fix for 6267144: PIT: Popup menu label is not shown, XToolkit
-- private final static Field f_label;
-- private final static Method m_getFont;
-- private final static Field f_items;
--
-- static {
-- f_enabled = SunToolkit.getField(MenuItem.class, "enabled");
-- f_label = SunToolkit.getField(MenuItem.class, "label");
-- f_items = SunToolkit.getField(Menu.class, "items");
-- m_getFont = SunToolkit.getMethod(MenuComponent.class, "getFont_NoClientCode", null);
-- }
--
--
- /************************************************
- *
- * Construction
-@@ -189,27 +166,16 @@
- if (popupMenuTarget == null) {
- return XWindow.defaultFont;
- }
-- try {
-- return (Font)m_getFont.invoke(popupMenuTarget, new Object[0]);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- } catch (InvocationTargetException e) {
-- e.printStackTrace();
-- }
-- return XWindow.defaultFont;
-+ return AWTAccessor.getMenuComponentAccessor()
-+ .getFont_NoClientCode(popupMenuTarget);
- }
-
-+ //Fix for 6267144: PIT: Popup menu label is not shown, XToolkit
- String getTargetLabel() {
- if (target == null) {
- return "";
- }
-- try {
-- String label = (String)f_label.get(popupMenuTarget);
-- return (label == null) ? "" : label;
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- }
-- return "";
-+ return AWTAccessor.getMenuItemAccessor().getLabel(popupMenuTarget);
- }
-
- //Fix for 6184485: Popup menu is not disabled on XToolkit even when calling setEnabled (false)
-@@ -217,21 +183,14 @@
- if (popupMenuTarget == null) {
- return false;
- }
-- try {
-- return f_enabled.getBoolean(popupMenuTarget);
-- } catch (IllegalAccessException e) {
-- e.printStackTrace();
-- }
-- return false;
-+ return AWTAccessor.getMenuItemAccessor().isEnabled(popupMenuTarget);
- }
-
- Vector getMenuTargetItems() {
-- try {
-- return (Vector)f_items.get(popupMenuTarget);
-- } catch (IllegalAccessException iae) {
-- iae.printStackTrace();
-+ if (popupMenuTarget == null) {
- return null;
- }
-+ return AWTAccessor.getMenuAccessor().getItems(popupMenuTarget);
- }
-
- /************************************************
---- jdk/src/solaris/classes/sun/awt/X11/XScrollPanePeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XScrollPanePeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -28,8 +28,8 @@
- import java.awt.*;
- import java.awt.event.*;
- import java.awt.peer.*;
--import java.lang.reflect.*;
--import sun.awt.SunToolkit;
-+
-+import sun.awt.AWTAccessor;
-
- class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollbarClient {
-
-@@ -41,9 +41,7 @@
- public final static int VERTICAL = 1 << 0;
- public final static int HORIZONTAL = 1 << 1;
-
-- private static Method m_setValue;
- static {
-- m_setValue = SunToolkit.getMethod(ScrollPaneAdjustable.class, "setTypedValue", new Class[] {Integer.TYPE, Integer.TYPE});
- SCROLLBAR = XToolkit.getUIDefaults().getInt("ScrollBar.defaultWidth");
- }
-
-@@ -316,16 +314,8 @@
- }
-
- void setAdjustableValue(ScrollPaneAdjustable adj, int value, int type) {
-- try {
-- m_setValue.invoke(adj, new Object[] {Integer.valueOf(value), Integer.valueOf(type)});
-- } catch (IllegalAccessException iae) {
-- adj.setValue(value);
-- } catch (IllegalArgumentException iae2) {
-- adj.setValue(value);
-- } catch (InvocationTargetException ite) {
-- adj.setValue(value);
-- ite.getCause().printStackTrace();
-- }
-+ AWTAccessor.getScrollPaneAdjustableAccessor().setTypedValue(adj, value,
-+ type);
- }
-
-
---- jdk/src/solaris/classes/sun/awt/X11/XTextAreaPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XTextAreaPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -61,6 +61,7 @@
- import java.awt.im.InputMethodRequests;
- import sun.awt.CausedFocusEvent;
- import sun.awt.ComponentAccessor;
-+import sun.awt.AWTAccessor;
-
-
- class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
-@@ -985,8 +986,10 @@
- // loading SystemFlavorMap and associated classes.
- public void setTransferHandler(TransferHandler newHandler) {
- TransferHandler oldHandler = (TransferHandler)
-- getClientProperty(XTextTransferHelper.getTransferHandlerKey());
-- putClientProperty(XTextTransferHelper.getTransferHandlerKey(),
-+ getClientProperty(AWTAccessor.getClientPropertyKeyAccessor()
-+ .getJComponent_TRANSFER_HANDLER());
-+ putClientProperty(AWTAccessor.getClientPropertyKeyAccessor()
-+ .getJComponent_TRANSFER_HANDLER(),
- newHandler);
-
- firePropertyChange("transferHandler", oldHandler, newHandler);
---- jdk/src/solaris/classes/sun/awt/X11/XTextFieldPeer.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XTextFieldPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -55,6 +55,7 @@
- import java.util.logging.*;
- import sun.awt.CausedFocusEvent;
- import sun.awt.ComponentAccessor;
-+import sun.awt.AWTAccessor;
-
- public class XTextFieldPeer extends XComponentPeer implements TextFieldPeer {
- private static final Logger log = Logger.getLogger("sun.awt.X11.XTextField");
-@@ -714,8 +715,10 @@
- // loading SystemFlavorMap and associated classes.
- public void setTransferHandler(TransferHandler newHandler) {
- TransferHandler oldHandler = (TransferHandler)
-- getClientProperty(XTextTransferHelper.getTransferHandlerKey());
-- putClientProperty(XTextTransferHelper.getTransferHandlerKey(),
-+ getClientProperty(AWTAccessor.getClientPropertyKeyAccessor()
-+ .getJComponent_TRANSFER_HANDLER());
-+ putClientProperty(AWTAccessor.getClientPropertyKeyAccessor()
-+ .getJComponent_TRANSFER_HANDLER(),
- newHandler);
-
- firePropertyChange("transferHandler", oldHandler, newHandler);
---- jdk/src/solaris/classes/sun/awt/X11/XTextTransferHelper.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XTextTransferHelper.java 2012-09-05 19:35:40.000000000 -0400
-@@ -1,47 +0,0 @@
--/*
-- * Copyright (c) 2003, 2007, 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. Oracle designates this
-- * particular file as subject to the "Classpath" exception as provided
-- * by Oracle in the LICENSE file that accompanied this code.
-- *
-- * 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.
-- */
--
--package sun.awt.X11;
--
--import java.lang.reflect.Field;
--import sun.awt.SunToolkit;
--
--class XTextTransferHelper {
-- private static Object transferHandlerKey = null;
-- static Object getTransferHandlerKey() {
-- if (transferHandlerKey == null) {
-- try {
-- Class clazz = Class.forName("javax.swing.ClientPropertyKey");
-- Field field = SunToolkit.getField(clazz, "JComponent_TRANSFER_HANDLER");
-- transferHandlerKey = field.get(null);
-- } catch (IllegalAccessException ex) {
-- return null;
-- } catch (ClassNotFoundException cnfe) {
-- cnfe.printStackTrace();
-- }
-- }
-- return transferHandlerKey;
-- }
--}
---- jdk/src/solaris/classes/sun/awt/X11/XToolkit.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XToolkit.java 2012-09-05 19:35:40.000000000 -0400
-@@ -49,7 +49,7 @@
- import sun.misc.PerformanceLogger;
- import sun.print.PrintJob2D;
- import sun.security.action.GetBooleanAction;
--import java.lang.reflect.*;
-+import sun.security.action.GetPropertyAction;
-
- public class XToolkit extends UNIXToolkit implements Runnable, XConstants {
- private static Logger log = Logger.getLogger("sun.awt.X11.XToolkit");
-@@ -102,7 +102,6 @@
- private static int screenWidth = -1, screenHeight = -1; // Dimensions of default screen
- static long awt_defaultFg; // Pixel
- private static XMouseInfoPeer xPeer;
-- private static Method m_removeSourceEvents;
-
- static {
- initSecurityWarning();
-@@ -120,9 +119,9 @@
- initIDs();
- setBackingStoreType();
- }
-- m_removeSourceEvents = SunToolkit.getMethod(EventQueue.class, "removeSourceEvents", new Class[] {Object.class, Boolean.TYPE}) ;
-
-- noisyAwtHandler = AccessController.doPrivileged(new GetBooleanAction("sun.awt.noisyerrorhandler"));
-+ noisyAwtHandler = AccessController.doPrivileged(
-+ new GetBooleanAction("sun.awt.noisyerrorhandler"));
- }
-
- //---- ERROR HANDLER CODE ----//
-@@ -203,7 +202,8 @@
-
- static void initSecurityWarning() {
- // Enable warning only for internal builds
-- String runtime = getSystemProperty("java.runtime.version");
-+ String runtime = AccessController.doPrivileged(
-+ new GetPropertyAction("java.runtime.version"));
- securityWarningEnabled = (runtime != null && runtime.contains("internal"));
- }
-
-@@ -1126,14 +1126,6 @@
- }
- }
-
-- static String getSystemProperty(final String name) {
-- return (String)AccessController.doPrivileged(new PrivilegedAction() {
-- public Object run() {
-- return System.getProperty(name);
-- }
-- });
-- }
--
- public PrintJob getPrintJob(final Frame frame, final String doctitle,
- final Properties props) {
-
-@@ -1894,16 +1886,7 @@
- }
-
- static void removeSourceEvents(EventQueue queue, Object source, boolean removeAllEvents) {
-- try {
-- m_removeSourceEvents.invoke(queue, source, removeAllEvents);
-- }
-- catch (IllegalAccessException e)
-- {
-- e.printStackTrace();
-- }
-- catch (InvocationTargetException e) {
-- e.printStackTrace();
-- }
-+ AWTAccessor.getEventQueueAccessor().removeSourceEvents(queue, source, removeAllEvents);
- }
-
- public boolean isAlwaysOnTopSupported() {
-@@ -1937,8 +1920,8 @@
- }
-
- private static void setBackingStoreType() {
-- String prop = (String)AccessController.doPrivileged(
-- new sun.security.action.GetPropertyAction("sun.awt.backingStore"));
-+ String prop = AccessController.doPrivileged(
-+ new GetPropertyAction("sun.awt.backingStore"));
-
- if (prop == null) {
- backingStoreType = XConstants.NotUseful;
---- jdk/src/solaris/classes/sun/awt/X11/XWindow.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XWindow.java 2012-09-05 19:35:40.000000000 -0400
-@@ -33,7 +33,6 @@
- import java.lang.ref.WeakReference;
-
- import java.lang.reflect.Field;
--import java.lang.reflect.Method;
-
- import java.util.logging.Level;
- import java.util.logging.Logger;
-@@ -108,7 +107,6 @@
- native void getWindowBounds(long window, long x, long y, long width, long height);
- private native static void initIDs();
-
-- private static Field isPostedField;
- static {
- initIDs();
- }
-@@ -361,20 +359,10 @@
- return false;
- }
-
-- static Method m_sendMessage;
- static void sendEvent(final AWTEvent e) {
-- if (isPostedField == null) {
-- isPostedField = SunToolkit.getField(AWTEvent.class, "isPosted");
-- }
- PeerEvent pe = new PeerEvent(Toolkit.getDefaultToolkit(), new Runnable() {
- public void run() {
-- try {
-- isPostedField.setBoolean(e, true);
-- } catch (IllegalArgumentException e) {
-- assert(false);
-- } catch (IllegalAccessException e) {
-- assert(false);
-- }
-+ AWTAccessor.getAWTEventAccessor().setPosted(e);
- ((Component)e.getSource()).dispatchEvent(e);
- }
- }, PeerEvent.ULTIMATE_PRIORITY_EVENT);
-@@ -1250,16 +1238,8 @@
- }
-
-
-- static Field bdata;
- static void setBData(KeyEvent e, byte[] data) {
-- try {
-- if (bdata == null) {
-- bdata = SunToolkit.getField(java.awt.AWTEvent.class, "bdata");
-- }
-- bdata.set(e, data);
-- } catch (IllegalAccessException ex) {
-- assert false;
-- }
-+ AWTAccessor.getAWTEventAccessor().setBData(e, data);
- }
-
- public void postKeyEvent(int id, long when, int keyCode, char keyChar,
---- jdk/src/solaris/classes/sun/awt/X11/XlibWrapper.java 2012-05-01 17:18:34.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/X11/XlibWrapper.java 2012-09-05 19:35:40.000000000 -0400
-@@ -26,7 +26,7 @@
- package sun.awt.X11;
-
- import java.security.AccessController;
--import java.security.PrivilegedAction;
-+import sun.security.action.GetPropertyAction;
- import sun.misc.*;
-
- public class XlibWrapper implements XConstants, XUtilConstants, XProtocolConstants,
-@@ -562,12 +562,7 @@
- static final boolean isBuildInternal;
-
- static {
-- String dataModelProp = (String)AccessController.doPrivileged(
-- new PrivilegedAction() {
-- public Object run() {
-- return System.getProperty("sun.arch.data.model");
-- }
-- });
-+ String dataModelProp = AccessController.doPrivileged(new GetPropertyAction("sun.arch.data.model"));
- try {
- dataModel = Integer.parseInt(dataModelProp);
- } catch (Exception e) {
-@@ -610,7 +605,7 @@
- }
-
- private static boolean getBuildInternal() {
-- String javaVersion = XToolkit.getSystemProperty("java.version");
-+ String javaVersion = AccessController.doPrivileged(new GetPropertyAction("java.version"));
- return javaVersion != null && javaVersion.contains("internal");
- }
-
---- jdk/src/solaris/classes/sun/awt/motif/MComponentPeer.java 2012-05-01 17:18:35.000000000 -0400
-+++ jdk/src/solaris/classes/sun/awt/motif/MComponentPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -400,16 +400,7 @@
- static Method requestFocusWithCause;
-
- static void callRequestFocusInWindow(Component target, CausedFocusEvent.Cause cause) {
-- if (requestFocusWithCause == null) {
-- requestFocusWithCause = SunToolkit.getMethod(Component.class, "requestFocusInWindow", new Class[] {CausedFocusEvent.Cause.class});
-- }
-- if (requestFocusWithCause != null) {
-- try {
-- requestFocusWithCause.invoke(target, new Object[] {cause});
-- } catch (Exception e) {
-- e.printStackTrace();
-- }
-- }
-+ AWTAccessor.getComponentAccessor().requestFocusInWindow(target, cause);
- }
-
- public void handleEvent(AWTEvent e) {
---- jdk/src/solaris/classes/sun/print/UnixPrintJob.java 2012-05-01 17:18:35.000000000 -0400
-+++ jdk/src/solaris/classes/sun/print/UnixPrintJob.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -937,7 +937,7 @@
- * is not removed for some reason, request that it is
- * removed when the VM exits.
- */
-- spoolFile = File.createTempFile("javaprint", ".ps", null);
-+ spoolFile = sun.misc.IOUtils.createTempFile("javaprint", ".ps", null);
- spoolFile.deleteOnExit();
- }
- result = new FileOutputStream(spoolFile);
---- jdk/src/solaris/classes/sun/print/UnixPrintServiceLookup.java 2012-05-01 17:18:35.000000000 -0400
-+++ jdk/src/solaris/classes/sun/print/UnixPrintServiceLookup.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2000, 2012, 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
-@@ -712,7 +712,7 @@
-
- Process proc;
- BufferedReader bufferedReader = null;
-- File f = File.createTempFile("prn","xc");
-+ File f = sun.misc.IOUtils.createTempFile("prn","xc");
- cmd[2] = cmd[2]+">"+f.getAbsolutePath();
-
- proc = Runtime.getRuntime().exec(cmd);
---- jdk/src/solaris/native/java/io/UnixFileSystem_md.c 2012-05-01 17:18:35.000000000 -0400
-+++ jdk/src/solaris/native/java/io/UnixFileSystem_md.c 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -310,7 +310,8 @@
-
- JNIEXPORT jboolean JNICALL
- Java_java_io_UnixFileSystem_createFileExclusively(JNIEnv *env, jclass cls,
-- jstring pathname)
-+ jstring pathname,
-+ jboolean restrictive)
- {
- jboolean rv = JNI_FALSE;
-
-@@ -319,7 +320,8 @@
- if (!strcmp (path, "/")) {
- fd = JVM_EEXIST; /* The root directory always exists */
- } else {
-- fd = JVM_Open(path, JVM_O_RDWR | JVM_O_CREAT | JVM_O_EXCL, 0666);
-+ jint mode = (restrictive == JNI_TRUE) ? 0600 : 0666;
-+ fd = JVM_Open(path, JVM_O_RDWR | JVM_O_CREAT | JVM_O_EXCL, mode);
- }
- if (fd < 0) {
- if (fd != JVM_EEXIST) {
---- jdk/src/windows/classes/java/io/Win32FileSystem.java 2012-05-01 17:18:37.000000000 -0400
-+++ jdk/src/windows/classes/java/io/Win32FileSystem.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2005, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -510,7 +510,7 @@
-
- /* -- File operations -- */
-
-- public native boolean createFileExclusively(String path)
-+ public native boolean createFileExclusively(String path, boolean restrictive)
- throws IOException;
- public boolean delete(File f) {
- // Keep canonicalization caches in sync after file deletion
---- jdk/src/windows/classes/java/io/WinNTFileSystem.java 2012-05-01 17:18:37.000000000 -0400
-+++ jdk/src/windows/classes/java/io/WinNTFileSystem.java 2012-09-05 19:34:26.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2001, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2001, 2012, 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
-@@ -61,7 +61,7 @@
-
- /* -- File operations -- */
-
-- public native boolean createFileExclusively(String path)
-+ public native boolean createFileExclusively(String path, boolean restrictive)
- throws IOException;
- protected native boolean delete0(File f);
- public native String[] list(File f);
---- jdk/src/windows/classes/sun/awt/windows/WPopupMenuPeer.java 2012-05-01 17:18:37.000000000 -0400
-+++ jdk/src/windows/classes/sun/awt/windows/WPopupMenuPeer.java 2012-09-05 19:35:40.000000000 -0400
-@@ -26,36 +26,23 @@
-
- import java.awt.*;
- import java.awt.peer.*;
--import java.lang.reflect.Field;
-
--import sun.awt.SunToolkit;
-+import sun.awt.AWTAccessor;
-
- public class WPopupMenuPeer extends WMenuPeer implements PopupMenuPeer {
- // We can't use target.getParent() for TrayIcon popup
- // because this method should return null for the TrayIcon
- // popup regardless of that whether it has parent or not.
-- private static Field f_parent;
-- private static Field f_isTrayIconPopup;
--
-- static {
-- f_parent = SunToolkit.getField(MenuComponent.class, "parent");
-- f_isTrayIconPopup = SunToolkit.getField(PopupMenu.class, "isTrayIconPopup");
-- }
-
- public WPopupMenuPeer(PopupMenu target) {
- this.target = target;
- MenuContainer parent = null;
- boolean isTrayIconPopup = false;
-- try {
-- isTrayIconPopup = ((Boolean)f_isTrayIconPopup.get(target)).booleanValue();
-- if (isTrayIconPopup) {
-- parent = (MenuContainer)f_parent.get(target);
-- } else {
-- parent = target.getParent();
-- }
-- } catch (IllegalAccessException iae) {
-- iae.printStackTrace();
-- return;
-+ isTrayIconPopup = AWTAccessor.getPopupMenuAccessor().isTrayIconPopup(target);
-+ if (isTrayIconPopup) {
-+ parent = AWTAccessor.getMenuComponentAccessor().getParent(target);
-+ } else {
-+ parent = target.getParent();
- }
-
- if (parent instanceof Component) {
---- jdk/src/windows/native/java/io/Win32FileSystem_md.c 2012-05-01 17:18:37.000000000 -0400
-+++ jdk/src/windows/native/java/io/Win32FileSystem_md.c 2012-09-05 19:34:27.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 1998, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 1998, 2012, 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
-@@ -262,7 +262,8 @@
-
- JNIEXPORT jboolean JNICALL
- Java_java_io_Win32FileSystem_createFileExclusively(JNIEnv *env, jclass cls,
-- jstring pathname)
-+ jstring pathname,
-+ jboolean restrictive)
- {
- jboolean rv = JNI_FALSE;
- DWORD a;
---- jdk/src/windows/native/java/io/WinNTFileSystem_md.c 2012-05-01 17:18:37.000000000 -0400
-+++ jdk/src/windows/native/java/io/WinNTFileSystem_md.c 2012-09-05 19:34:27.000000000 -0400
-@@ -1,5 +1,5 @@
- /*
-- * Copyright (c) 2001, 2006, Oracle and/or its affiliates. All rights reserved.
-+ * Copyright (c) 2001, 2012, 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
-@@ -349,7 +349,8 @@
-
- JNIEXPORT jboolean JNICALL
- Java_java_io_WinNTFileSystem_createFileExclusively(JNIEnv *env, jclass cls,
-- jstring path)
-+ jstring path,
-+ jboolean restrictive)
- {
- HANDLE h = NULL;
- WCHAR *pathbuf = pathToNTPath(env, path, JNI_FALSE);