From 07b29f5f43b871780d49a66840e69ca17272e6fb Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Tue, 5 Feb 2019 14:54:06 -0800 Subject: [PATCH] 8216592: Removal of the class sun.awt.AWTSecurityManager Reviewed-by: prr --- .../share/classes/java/awt/Font.java | 10 +- .../classes/sun/awt/AWTSecurityManager.java | 65 ------ .../share/classes/sun/awt/AppContext.java | 33 +-- .../classes/sun/font/FontDesignMetrics.java | 18 +- .../share/classes/sun/font/FontManager.java | 15 +- .../classes/sun/font/SunFontManager.java | 194 +++--------------- 6 files changed, 39 insertions(+), 296 deletions(-) delete mode 100644 src/java.desktop/share/classes/sun/awt/AWTSecurityManager.java diff --git a/src/java.desktop/share/classes/java/awt/Font.java b/src/java.desktop/share/classes/java/awt/Font.java index 6ecbbf43436..99830337712 100644 --- a/src/java.desktop/share/classes/java/awt/Font.java +++ b/src/java.desktop/share/classes/java/awt/Font.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1995, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1995, 2019, 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 @@ -495,13 +495,7 @@ public class Font implements java.io.Serializable private Font2D getFont2D() { FontManager fm = FontManagerFactory.getInstance(); - if (fm.usingPerAppContextComposites() && - font2DHandle != null && - font2DHandle.font2D instanceof CompositeFont && - ((CompositeFont)(font2DHandle.font2D)).isStdComposite()) { - return fm.findFont2D(name, style, - FontManager.LOGICAL_FALLBACK); - } else if (font2DHandle == null) { + if (font2DHandle == null) { font2DHandle = fm.findFont2D(name, style, FontManager.LOGICAL_FALLBACK).handle; diff --git a/src/java.desktop/share/classes/sun/awt/AWTSecurityManager.java b/src/java.desktop/share/classes/sun/awt/AWTSecurityManager.java deleted file mode 100644 index 991a37ea24a..00000000000 --- a/src/java.desktop/share/classes/sun/awt/AWTSecurityManager.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - * Copyright (c) 1999, 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; - -/** - * The AWTSecurityManager class provides the ability to secondarily - * index AppContext objects through SecurityManager extensions. - * As noted in AppContext.java, AppContexts are primarily indexed by - * ThreadGroup. In the case where the ThreadGroup doesn't provide - * enough information to determine AppContext (e.g. system threads), - * if a SecurityManager is installed which derives from - * AWTSecurityManager, the AWTSecurityManager's getAppContext() - * method is called to determine the AppContext. - * - * A typical example of the use of this class is where an applet - * is called by a system thread, yet the system AppContext is - * inappropriate, because applet code is currently executing. - * In this case, the getAppContext() method can walk the call stack - * to determine the applet code being executed and return the applet's - * AppContext object. - * - * @author Fred Ecks - */ -public class AWTSecurityManager extends SecurityManager { - - /** - * Get the AppContext corresponding to the current context. - * The default implementation returns null, but this method - * may be overridden by various SecurityManagers - * (e.g. AppletSecurity) to index AppContext objects by the - * calling context. - * - * @return the AppContext corresponding to the current context. - * @see sun.awt.AppContext - * @see java.lang.SecurityManager - * @since 1.2.1 - */ - public AppContext getAppContext() { - return null; // Default implementation returns null - } - -} /* class AWTSecurityManager */ diff --git a/src/java.desktop/share/classes/sun/awt/AppContext.java b/src/java.desktop/share/classes/sun/awt/AppContext.java index d2fd17b08b7..cc4547ddc02 100644 --- a/src/java.desktop/share/classes/sun/awt/AppContext.java +++ b/src/java.desktop/share/classes/sun/awt/AppContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -123,17 +123,6 @@ import java.util.function.Supplier; * therefore safely invoke any of its methods without worry of being * blocked. * - * Note: If a SecurityManager is installed which derives from - * sun.awt.AWTSecurityManager, it may override the - * AWTSecurityManager.getAppContext() method to return the proper - * AppContext based on the execution context, in the case where - * the default ThreadGroup-based AppContext indexing would return - * the main "system" AppContext. For example, in an applet situation, - * if a system thread calls into an applet, rather than returning the - * main "system" AppContext (the one corresponding to the system thread), - * an installed AWTSecurityManager may return the applet's AppContext - * based on the execution context. - * * @author Thomas Ball * @author Fred Ecks */ @@ -287,10 +276,7 @@ public final class AppContext { /** * Returns the appropriate AppContext for the caller, - * as determined by its ThreadGroup. If the main "system" AppContext - * would be returned and there's an AWTSecurityManager installed, it - * is called to get the proper AppContext based on the execution - * context. + * as determined by its ThreadGroup. * * @return the AppContext for the caller. * @see java.lang.ThreadGroup @@ -384,18 +370,6 @@ public final class AppContext { return (ctx != null && ctx == mainAppContext); } - private static AppContext getExecutionAppContext() { - SecurityManager securityManager = System.getSecurityManager(); - if ((securityManager != null) && - (securityManager instanceof AWTSecurityManager)) - { - AWTSecurityManager awtSecMgr = (AWTSecurityManager) securityManager; - AppContext secAppContext = awtSecMgr.getAppContext(); - return secAppContext; // Return what we're told - } - return null; - } - private long DISPOSAL_TIMEOUT = 5000; // Default to 5-second timeout // for disposal of all Frames // (we wait for this time twice, @@ -872,8 +846,7 @@ public final class AppContext { // context since we don't need it. if (numAppContexts.get() == 0) return null; - // Get the context from the security manager - AppContext ecx = getExecutionAppContext(); + AppContext ecx = null; // Not sure we really need to re-check numAppContexts here. // If all applets have gone away then we could have a diff --git a/src/java.desktop/share/classes/sun/font/FontDesignMetrics.java b/src/java.desktop/share/classes/sun/font/FontDesignMetrics.java index 33b9f363a0f..932cfa44c04 100644 --- a/src/java.desktop/share/classes/sun/font/FontDesignMetrics.java +++ b/src/java.desktop/share/classes/sun/font/FontDesignMetrics.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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,22 +25,18 @@ package sun.font; -import java.lang.ref.ReferenceQueue; -import java.lang.ref.SoftReference; - -import java.awt.FontMetrics; import java.awt.Font; +import java.awt.FontMetrics; import java.awt.GraphicsEnvironment; -import java.awt.geom.AffineTransform; -import java.awt.geom.NoninvertibleTransformException; -import java.awt.geom.Rectangle2D; import java.awt.font.FontRenderContext; import java.awt.font.TextLayout; - +import java.awt.geom.AffineTransform; +import java.awt.geom.Rectangle2D; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; - +import java.lang.ref.ReferenceQueue; +import java.lang.ref.SoftReference; import java.util.concurrent.ConcurrentHashMap; import sun.java2d.Disposer; @@ -263,7 +259,7 @@ public final class FontDesignMetrics extends FontMetrics { * by this code as they use the metrics of the physical anyway. */ SunFontManager fm = SunFontManager.getInstance(); - if (fm.maybeUsingAlternateCompositeFonts() && + if (fm.usingAlternateCompositeFonts() && FontUtilities.getFont2D(font) instanceof CompositeFont) { return new FontDesignMetrics(font, frc); } diff --git a/src/java.desktop/share/classes/sun/font/FontManager.java b/src/java.desktop/share/classes/sun/font/FontManager.java index 455daf69cfa..6eb151177d8 100644 --- a/src/java.desktop/share/classes/sun/font/FontManager.java +++ b/src/java.desktop/share/classes/sun/font/FontManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -22,16 +22,12 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package sun.font; import java.awt.Font; import java.awt.FontFormatException; import java.io.File; -import java.util.Locale; -import java.util.TreeMap; - -import javax.swing.plaf.FontUIResource; - /** * Interface between Java Fonts (java.awt.Font) and the underlying @@ -92,13 +88,6 @@ public interface FontManager { boolean isCopy, CreatedFontTracker tracker) throws FontFormatException; - /** - * If usingPerAppContextComposites is true, we are in "applet" - * (eg browser) environment and at least one context has selected - * an alternate composite font behaviour. - */ - public boolean usingPerAppContextComposites(); - /** * Creates a derived composite font from the specified font (handle). * diff --git a/src/java.desktop/share/classes/sun/font/SunFontManager.java b/src/java.desktop/share/classes/sun/font/SunFontManager.java index e60cf939fc7..23f3adc841c 100644 --- a/src/java.desktop/share/classes/sun/font/SunFontManager.java +++ b/src/java.desktop/share/classes/sun/font/SunFontManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2019, 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 @@ -50,7 +50,7 @@ import java.util.Vector; import java.util.concurrent.ConcurrentHashMap; import javax.swing.plaf.FontUIResource; -import sun.awt.AppContext; + import sun.awt.FontConfiguration; import sun.awt.SunToolkit; import sun.awt.util.ThreadGroupUtils; @@ -256,11 +256,6 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { return t1Filter; } - @Override - public boolean usingPerAppContextComposites() { - return _usingPerAppContextComposites; - } - static { java.security.AccessController.doPrivileged( @@ -1936,7 +1931,6 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { public Font2D findFont2D(String name, int style, int fallback) { String lowerCaseName = name.toLowerCase(Locale.ENGLISH); String mapName = lowerCaseName + dotStyleStr(style); - Font2D font; /* If preferLocaleFonts() or preferProportionalFonts() has been * called we may be using an alternate set of composite fonts in this @@ -1944,19 +1938,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * this is so, and gives access to the alternate composite for the * name. */ - if (_usingPerAppContextComposites) { - @SuppressWarnings("unchecked") - ConcurrentHashMap altNameCache = - (ConcurrentHashMap) - AppContext.getAppContext().get(CompositeFont.class); - if (altNameCache != null) { - font = altNameCache.get(mapName); - } else { - font = null; - } - } else { - font = fontNameCache.get(mapName); - } + Font2D font = fontNameCache.get(mapName); if (font != null) { return font; } @@ -2161,25 +2143,9 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * cache for these. */ - if (fontsAreRegistered || fontsAreRegisteredPerAppContext) { - Hashtable familyTable = null; - Hashtable nameTable; - - if (fontsAreRegistered) { - familyTable = createdByFamilyName; - nameTable = createdByFullName; - } else { - AppContext appContext = AppContext.getAppContext(); - @SuppressWarnings("unchecked") - Hashtable tmp1 = - (Hashtable)appContext.get(regFamilyKey); - familyTable = tmp1; - - @SuppressWarnings("unchecked") - Hashtable tmp2 = - (Hashtable)appContext.get(regFullNameKey); - nameTable = tmp2; - } + if (fontsAreRegistered) { + Hashtable familyTable = createdByFamilyName; + Hashtable nameTable = createdByFullName; family = familyTable.get(lowerCaseName); if (family != null) { @@ -2684,9 +2650,6 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * Calling the methods below is "heavyweight" but it is expected that * these methods will be called very rarely. * - * If _usingPerAppContextComposites is true, we are in "applet" - * (eg browser) environment and at least one context has selected - * an alternate composite font behaviour. * If _usingAlternateComposites is true, we are not in an "applet" * environment and the (single) application has selected * an alternate composite font behaviour. @@ -2698,21 +2661,13 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * but that may have to wait. The results should be correct, just not * optimal. */ - private static final Object altJAFontKey = new Object(); - private static final Object localeFontKey = new Object(); - private static final Object proportionalFontKey = new Object(); - private boolean _usingPerAppContextComposites = false; private boolean _usingAlternateComposites = false; - /* These values are used only if we are running as a standalone - * application, as determined by maybeMultiAppContext(); - */ private static boolean gAltJAFont = false; private boolean gLocalePref = false; private boolean gPropPref = false; - /* This method doesn't check if alternates are selected in this app - * context. Its used by the FontMetrics caching code which in such + /* Its used by the FontMetrics caching code which in such * a case cannot retrieve a cached metrics solely on the basis of * the Font.equals() method since it needs to also check if the Font2D * is the same. @@ -2724,26 +2679,8 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * logical font definitions we may need to revisit this if GTK reports * combined metrics instead. For now though this test can be simple. */ - public boolean maybeUsingAlternateCompositeFonts() { - return _usingAlternateComposites || _usingPerAppContextComposites; - } - public boolean usingAlternateCompositeFonts() { - return (_usingAlternateComposites || - (_usingPerAppContextComposites && - AppContext.getAppContext().get(CompositeFont.class) != null)); - } - - private static boolean maybeMultiAppContext() { - Boolean appletSM = (Boolean) - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { - SecurityManager sm = System.getSecurityManager(); - return sm instanceof sun.awt.AWTSecurityManager; - } - }); - return appletSM.booleanValue(); + return _usingAlternateComposites; } /* Modifies the behaviour of a subsequent call to preferLocaleFonts() @@ -2758,22 +2695,11 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { if (!FontUtilities.isWindows) { return; } - - if (!maybeMultiAppContext()) { - gAltJAFont = true; - } else { - AppContext appContext = AppContext.getAppContext(); - appContext.put(altJAFontKey, altJAFontKey); - } + gAltJAFont = true; } public boolean usingAlternateFontforJALocales() { - if (!maybeMultiAppContext()) { - return gAltJAFont; - } else { - AppContext appContext = AppContext.getAppContext(); - return appContext.get(altJAFontKey) == altJAFontKey; - } + return gAltJAFont; } public synchronized void preferLocaleFonts() { @@ -2784,29 +2710,12 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { if (!FontConfiguration.willReorderForStartupLocale()) { return; } - - if (!maybeMultiAppContext()) { - if (gLocalePref == true) { - return; - } - gLocalePref = true; - createCompositeFonts(fontNameCache, gLocalePref, gPropPref); - _usingAlternateComposites = true; - } else { - AppContext appContext = AppContext.getAppContext(); - if (appContext.get(localeFontKey) == localeFontKey) { - return; - } - appContext.put(localeFontKey, localeFontKey); - boolean acPropPref = - appContext.get(proportionalFontKey) == proportionalFontKey; - ConcurrentHashMap - altNameCache = new ConcurrentHashMap (); - /* If there is an existing hashtable, we can drop it. */ - appContext.put(CompositeFont.class, altNameCache); - _usingPerAppContextComposites = true; - createCompositeFonts(altNameCache, true, acPropPref); + if (gLocalePref == true) { + return; } + gLocalePref = true; + createCompositeFonts(fontNameCache, gLocalePref, gPropPref); + _usingAlternateComposites = true; } public synchronized void preferProportionalFonts() { @@ -2820,29 +2729,12 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { if (!FontConfiguration.hasMonoToPropMap()) { return; } - - if (!maybeMultiAppContext()) { - if (gPropPref == true) { - return; - } - gPropPref = true; - createCompositeFonts(fontNameCache, gLocalePref, gPropPref); - _usingAlternateComposites = true; - } else { - AppContext appContext = AppContext.getAppContext(); - if (appContext.get(proportionalFontKey) == proportionalFontKey) { - return; - } - appContext.put(proportionalFontKey, proportionalFontKey); - boolean acLocalePref = - appContext.get(localeFontKey) == localeFontKey; - ConcurrentHashMap - altNameCache = new ConcurrentHashMap (); - /* If there is an existing hashtable, we can drop it. */ - appContext.put(CompositeFont.class, altNameCache); - _usingPerAppContextComposites = true; - createCompositeFonts(altNameCache, acLocalePref, true); + if (gPropPref == true) { + return; } + gPropPref = true; + createCompositeFonts(fontNameCache, gLocalePref, gPropPref); + _usingAlternateComposites = true; } private static HashSet installedNames = null; @@ -2865,13 +2757,10 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { return installedNames; } - /* Keys are used to lookup per-AppContext Hashtables */ - private static final Object regFamilyKey = new Object(); - private static final Object regFullNameKey = new Object(); + private static final Object regFamilyLock = new Object(); private Hashtable createdByFamilyName; private Hashtable createdByFullName; private boolean fontsAreRegistered = false; - private boolean fontsAreRegisteredPerAppContext = false; public boolean registerFont(Font font) { /* This method should not be called with "null". @@ -2882,7 +2771,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } /* Initialise these objects only once we start to use this API */ - synchronized (regFamilyKey) { + synchronized (regFamilyLock) { if (createdByFamilyName == null) { createdByFamilyName = new Hashtable(); createdByFullName = new Hashtable(); @@ -2919,31 +2808,10 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } /* Checks passed, now register the font */ - Hashtable familyTable; - Hashtable fullNameTable; - if (!maybeMultiAppContext()) { - familyTable = createdByFamilyName; - fullNameTable = createdByFullName; - fontsAreRegistered = true; - } else { - AppContext appContext = AppContext.getAppContext(); - @SuppressWarnings("unchecked") - Hashtable tmp1 = - (Hashtable)appContext.get(regFamilyKey); - familyTable = tmp1; - @SuppressWarnings("unchecked") - Hashtable tmp2 = - (Hashtable)appContext.get(regFullNameKey); - fullNameTable = tmp2; + Hashtable familyTable = createdByFamilyName; + Hashtable fullNameTable = createdByFullName; + fontsAreRegistered = true; - if (familyTable == null) { - familyTable = new Hashtable(); - fullNameTable = new Hashtable(); - appContext.put(regFamilyKey, familyTable); - appContext.put(regFullNameKey, fullNameTable); - } - fontsAreRegisteredPerAppContext = true; - } /* Create the FontFamily and add font to the tables */ Font2D font2D = FontUtilities.getFont2D(font); int style = font2D.getStyle(); @@ -2989,12 +2857,6 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { Hashtable familyTable; if (fontsAreRegistered) { familyTable = createdByFamilyName; - } else if (fontsAreRegisteredPerAppContext) { - AppContext appContext = AppContext.getAppContext(); - @SuppressWarnings("unchecked") - Hashtable tmp = - (Hashtable)appContext.get(regFamilyKey); - familyTable = tmp; } else { return null; } @@ -3019,12 +2881,6 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { Hashtable nameTable; if (fontsAreRegistered) { nameTable = createdByFullName; - } else if (fontsAreRegisteredPerAppContext) { - AppContext appContext = AppContext.getAppContext(); - @SuppressWarnings("unchecked") - Hashtable tmp = - (Hashtable)appContext.get(regFullNameKey); - nameTable = tmp; } else { return null; }