From 78d35f1435c7db332409172ea06f0f46eb4010ae Mon Sep 17 00:00:00 2001 From: Christoph Langer Date: Mon, 2 Mar 2020 21:04:48 +0100 Subject: [PATCH] 8239149: Cleanups in SunFontManager.java and TrueTypeFont.java Reviewed-by: prr --- .../classes/sun/font/SunFontManager.java | 648 ++++++++---------- .../share/classes/sun/font/TrueTypeFont.java | 22 +- 2 files changed, 311 insertions(+), 359 deletions(-) diff --git a/src/java.desktop/share/classes/sun/font/SunFontManager.java b/src/java.desktop/share/classes/sun/font/SunFontManager.java index 0c3a5bcdf8d..3bf8b912a42 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, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, 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 @@ -39,7 +39,6 @@ import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; import java.util.Hashtable; -import java.util.Iterator; import java.util.List; import java.util.Locale; import java.util.Map; @@ -131,25 +130,25 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { private static Font2DHandle FONT_HANDLE_NULL = new Font2DHandle(null); - public static final int FONTFORMAT_NONE = -1; - public static final int FONTFORMAT_TRUETYPE = 0; - public static final int FONTFORMAT_TYPE1 = 1; - public static final int FONTFORMAT_TTC = 2; - public static final int FONTFORMAT_COMPOSITE = 3; - public static final int FONTFORMAT_NATIVE = 4; + public static final int FONTFORMAT_NONE = -1; + public static final int FONTFORMAT_TRUETYPE = 0; + public static final int FONTFORMAT_TYPE1 = 1; + public static final int FONTFORMAT_TTC = 2; + public static final int FONTFORMAT_COMPOSITE = 3; + public static final int FONTFORMAT_NATIVE = 4; - /* Pool of 20 font file channels chosen because some UTF-8 locale - * composite fonts can use up to 16 platform fonts (including the - * Lucida fall back). This should prevent channel thrashing when - * dealing with one of these fonts. - * The pool array stores the fonts, rather than directly referencing - * the channels, as the font needs to do the open/close work. - */ - // MACOSX begin -- need to access these in subclass - protected static final int CHANNELPOOLSIZE = 20; - protected FileFont[] fontFileCache = new FileFont[CHANNELPOOLSIZE]; - // MACOSX end - private int lastPoolIndex = 0; + /* Pool of 20 font file channels chosen because some UTF-8 locale + * composite fonts can use up to 16 platform fonts (including the + * Lucida fall back). This should prevent channel thrashing when + * dealing with one of these fonts. + * The pool array stores the fonts, rather than directly referencing + * the channels, as the font needs to do the open/close work. + */ + // MACOSX begin -- need to access these in subclass + protected static final int CHANNELPOOLSIZE = 20; + protected FileFont[] fontFileCache = new FileFont[CHANNELPOOLSIZE]; + // MACOSX end + private int lastPoolIndex = 0; /* Need to implement a simple linked list scheme for fast * traversal and lookup. @@ -163,11 +162,11 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { private int maxCompFont = 0; private CompositeFont [] compFonts = new CompositeFont[20]; private ConcurrentHashMap - compositeFonts = new ConcurrentHashMap(); + compositeFonts = new ConcurrentHashMap<>(); private ConcurrentHashMap - physicalFonts = new ConcurrentHashMap(); + physicalFonts = new ConcurrentHashMap<>(); private ConcurrentHashMap - registeredFonts = new ConcurrentHashMap(); + registeredFonts = new ConcurrentHashMap<>(); /* given a full name find the Font. Remind: there's duplication * here in that this contains the content of compositeFonts + @@ -175,7 +174,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { */ // MACOSX begin -- need to access this in subclass protected ConcurrentHashMap - fullNameToFont = new ConcurrentHashMap(); + fullNameToFont = new ConcurrentHashMap<>(); // MACOSX end /* TrueType fonts have localised names. Support searching all @@ -266,34 +265,27 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { private static int maxSoftRefCnt = 10; static { + AccessController.doPrivileged(new PrivilegedAction() { + public Void run() { + FontManagerNativeLibrary.load(); - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { + // JNI throws an exception if a class/method/field is not found, + // so there's no need to do anything explicit here. + initIDs(); - public Object run() { - FontManagerNativeLibrary.load(); + switch (StrikeCache.nativeAddressSize) { + case 8: longAddresses = true; break; + case 4: longAddresses = false; break; + default: throw new RuntimeException("Unexpected address size"); + } - // JNI throws an exception if a class/method/field is not found, - // so there's no need to do anything explicit here. - initIDs(); + noType1Font = "true".equals(System.getProperty("sun.java2d.noType1Font")); + jreLibDirName = System.getProperty("java.home","") + File.separator + "lib"; + jreFontDirName = jreLibDirName + File.separator + "fonts"; - switch (StrikeCache.nativeAddressSize) { - case 8: longAddresses = true; break; - case 4: longAddresses = false; break; - default: throw new RuntimeException("Unexpected address size"); - } - - noType1Font = - "true".equals(System.getProperty("sun.java2d.noType1Font")); - jreLibDirName = - System.getProperty("java.home","") + File.separator + "lib"; - jreFontDirName = jreLibDirName + File.separator + "fonts"; - - maxSoftRefCnt = - Integer.getInteger("sun.java2d.font.maxSoftRefs", 10); - - return null; - } + maxSoftRefCnt = Integer.getInteger("sun.java2d.font.maxSoftRefs", 10); + return null; + } }); } @@ -313,192 +305,173 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { /* Initialise ptrs used by JNI methods */ private static native void initIDs(); - @SuppressWarnings("unchecked") protected SunFontManager() { - - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { - File badFontFile = - new File(jreFontDirName + File.separator + - "badfonts.txt"); - if (badFontFile.exists()) { - FileInputStream fis = null; - try { - badFonts = new ArrayList<>(); - fis = new FileInputStream(badFontFile); - InputStreamReader isr = new InputStreamReader(fis); - BufferedReader br = new BufferedReader(isr); - while (true) { - String name = br.readLine(); - if (name == null) { - break; - } else { - if (FontUtilities.debugFonts()) { - FontUtilities.getLogger().warning("read bad font: " + - name); - } - badFonts.add(name); - } - } - } catch (IOException e) { - try { - if (fis != null) { - fis.close(); - } - } catch (IOException ioe) { - } - } - } - - /* Here we get the fonts in jre/lib/fonts and register - * them so they are always available and preferred over - * other fonts. This needs to be registered before the - * composite fonts as otherwise some native font that - * corresponds may be found as we don't have a way to - * handle two fonts of the same name, so the JRE one - * must be the first one registered. Pass "true" to - * registerFonts method as on-screen these JRE fonts - * always go through the JDK rasteriser. - */ - if (FontUtilities.isLinux) { - /* Linux font configuration uses these fonts */ - registerFontDir(jreFontDirName); - } - registerFontsInDir(jreFontDirName, true, Font2D.JRE_RANK, - true, false); - - /* Create the font configuration and get any font path - * that might be specified. - */ - fontConfig = createFontConfiguration(); - - String[] fontInfo = getDefaultPlatformFont(); - defaultFontName = fontInfo[0]; - defaultFontFileName = fontInfo[1]; - - String extraFontPath = fontConfig.getExtraFontPath(); - - /* In prior releases the debugging font path replaced - * all normally located font directories except for the - * JRE fonts dir. This directory is still always located - * and placed at the head of the path but as an - * augmentation to the previous behaviour the - * changes below allow you to additionally append to - * the font path by starting with append: or prepend by - * starting with a prepend: sign. Eg: to append - * -Dsun.java2d.fontpath=append:/usr/local/myfonts - * and to prepend - * -Dsun.java2d.fontpath=prepend:/usr/local/myfonts Disp - * - * If there is an appendedfontpath it in the font - * configuration it is used instead of searching the - * system for dirs. - * The behaviour of append and prepend is then similar - * to the normal case. ie it goes after what - * you prepend and * before what you append. If the - * sun.java2d.fontpath property is used, but it - * neither the append or prepend syntaxes is used then - * as except for the JRE dir the path is replaced and it - * is up to you to make sure that all the right - * directories are located. This is platform and - * locale-specific so its almost impossible to get - * right, so it should be used with caution. - */ - boolean prependToPath = false; - boolean appendToPath = false; - String dbgFontPath = - System.getProperty("sun.java2d.fontpath"); - - if (dbgFontPath != null) { - if (dbgFontPath.startsWith("prepend:")) { - prependToPath = true; - dbgFontPath = - dbgFontPath.substring("prepend:".length()); - } else if (dbgFontPath.startsWith("append:")) { - appendToPath = true; - dbgFontPath = - dbgFontPath.substring("append:".length()); - } - } - - if (FontUtilities.debugFonts()) { - PlatformLogger logger = FontUtilities.getLogger(); - logger.info("JRE font directory: " + jreFontDirName); - logger.info("Extra font path: " + extraFontPath); - logger.info("Debug font path: " + dbgFontPath); - } - - if (dbgFontPath != null) { - /* In debugging mode we register all the paths - * Caution: this is a very expensive call on Solaris:- - */ - fontPath = getPlatformFontPath(noType1Font); - - if (extraFontPath != null) { - fontPath = - extraFontPath + File.pathSeparator + fontPath; - } - if (appendToPath) { - fontPath = - fontPath + File.pathSeparator + dbgFontPath; - } else if (prependToPath) { - fontPath = - dbgFontPath + File.pathSeparator + fontPath; + AccessController.doPrivileged(new PrivilegedAction() { + public Void run() { + File badFontFile = + new File(jreFontDirName + File.separator + "badfonts.txt"); + if (badFontFile.exists()) { + badFonts = new ArrayList<>(); + try (FileInputStream fis = new FileInputStream(badFontFile); + BufferedReader br = new BufferedReader(new InputStreamReader(fis))) { + while (true) { + String name = br.readLine(); + if (name == null) { + break; } else { - fontPath = dbgFontPath; + if (FontUtilities.debugFonts()) { + FontUtilities.getLogger().warning("read bad font: " + name); + } + badFonts.add(name); } - registerFontDirs(fontPath); - } else if (extraFontPath != null) { - /* If the font configuration contains an - * "appendedfontpath" entry, it is interpreted as a - * set of locations that should always be registered. - * It may be additional to locations normally found - * for that place, or it may be locations that need - * to have all their paths registered to locate all - * the needed platform names. - * This is typically when the same .TTF file is - * referenced from multiple font.dir files and all - * of these must be read to find all the native - * (XLFD) names for the font, so that X11 font APIs - * can be used for as many code points as possible. - */ - registerFontDirs(extraFontPath); } - - /* On Solaris, we need to register the Japanese TrueType - * directory so that we can find the corresponding - * bitmap fonts. This could be done by listing the - * directory in the font configuration file, but we - * don't want to confuse users with this quirk. There - * are no bitmap fonts for other writing systems that - * correspond to TrueType fonts and have matching XLFDs. - * We need to register the bitmap fonts only in - * environments where they're on the X font path, i.e., - * in the Japanese locale. Note that if the X Toolkit - * is in use the font path isn't set up by JDK, but - * users of a JA locale should have it - * set up already by their login environment. - */ - if (FontUtilities.isSolaris && Locale.JAPAN.equals(Locale.getDefault())) { - registerFontDir("/usr/openwin/lib/locale/ja/X11/fonts/TT"); - } - - initCompositeFonts(fontConfig, null); - - return null; + } catch (IOException e) { } - }); + } + + /* Here we get the fonts in jre/lib/fonts and register + * them so they are always available and preferred over + * other fonts. This needs to be registered before the + * composite fonts as otherwise some native font that + * corresponds may be found as we don't have a way to + * handle two fonts of the same name, so the JRE one + * must be the first one registered. Pass "true" to + * registerFonts method as on-screen these JRE fonts + * always go through the JDK rasteriser. + */ + if (FontUtilities.isLinux) { + /* Linux font configuration uses these fonts */ + registerFontDir(jreFontDirName); + } + registerFontsInDir(jreFontDirName, true, Font2D.JRE_RANK, + true, false); + + /* Create the font configuration and get any font path + * that might be specified. + */ + fontConfig = createFontConfiguration(); + + String[] fontInfo = getDefaultPlatformFont(); + defaultFontName = fontInfo[0]; + defaultFontFileName = fontInfo[1]; + + String extraFontPath = fontConfig.getExtraFontPath(); + + /* In prior releases the debugging font path replaced + * all normally located font directories except for the + * JRE fonts dir. This directory is still always located + * and placed at the head of the path but as an + * augmentation to the previous behaviour the + * changes below allow you to additionally append to + * the font path by starting with append: or prepend by + * starting with a prepend: sign. Eg: to append + * -Dsun.java2d.fontpath=append:/usr/local/myfonts + * and to prepend + * -Dsun.java2d.fontpath=prepend:/usr/local/myfonts Disp + * + * If there is an appendedfontpath it in the font + * configuration it is used instead of searching the + * system for dirs. + * The behaviour of append and prepend is then similar + * to the normal case. ie it goes after what + * you prepend and * before what you append. If the + * sun.java2d.fontpath property is used, but it + * neither the append or prepend syntaxes is used then + * as except for the JRE dir the path is replaced and it + * is up to you to make sure that all the right + * directories are located. This is platform and + * locale-specific so its almost impossible to get + * right, so it should be used with caution. + */ + boolean prependToPath = false; + boolean appendToPath = false; + String dbgFontPath = System.getProperty("sun.java2d.fontpath"); + + if (dbgFontPath != null) { + if (dbgFontPath.startsWith("prepend:")) { + prependToPath = true; + dbgFontPath = + dbgFontPath.substring("prepend:".length()); + } else if (dbgFontPath.startsWith("append:")) { + appendToPath = true; + dbgFontPath = + dbgFontPath.substring("append:".length()); + } + } + + if (FontUtilities.debugFonts()) { + PlatformLogger logger = FontUtilities.getLogger(); + logger.info("JRE font directory: " + jreFontDirName); + logger.info("Extra font path: " + extraFontPath); + logger.info("Debug font path: " + dbgFontPath); + } + + if (dbgFontPath != null) { + /* In debugging mode we register all the paths + * Caution: this is a very expensive call on Solaris:- + */ + fontPath = getPlatformFontPath(noType1Font); + + if (extraFontPath != null) { + fontPath = extraFontPath + File.pathSeparator + fontPath; + } + if (appendToPath) { + fontPath += File.pathSeparator + dbgFontPath; + } else if (prependToPath) { + fontPath = dbgFontPath + File.pathSeparator + fontPath; + } else { + fontPath = dbgFontPath; + } + registerFontDirs(fontPath); + } else if (extraFontPath != null) { + /* If the font configuration contains an + * "appendedfontpath" entry, it is interpreted as a + * set of locations that should always be registered. + * It may be additional to locations normally found + * for that place, or it may be locations that need + * to have all their paths registered to locate all + * the needed platform names. + * This is typically when the same .TTF file is + * referenced from multiple font.dir files and all + * of these must be read to find all the native + * (XLFD) names for the font, so that X11 font APIs + * can be used for as many code points as possible. + */ + registerFontDirs(extraFontPath); + } + + /* On Solaris, we need to register the Japanese TrueType + * directory so that we can find the corresponding + * bitmap fonts. This could be done by listing the + * directory in the font configuration file, but we + * don't want to confuse users with this quirk. There + * are no bitmap fonts for other writing systems that + * correspond to TrueType fonts and have matching XLFDs. + * We need to register the bitmap fonts only in + * environments where they're on the X font path, i.e., + * in the Japanese locale. Note that if the X Toolkit + * is in use the font path isn't set up by JDK, but + * users of a JA locale should have it + * set up already by their login environment. + */ + if (FontUtilities.isSolaris && Locale.JAPAN.equals(Locale.getDefault())) { + registerFontDir("/usr/openwin/lib/locale/ja/X11/fonts/TT"); + } + + initCompositeFonts(fontConfig, null); + + return null; + } + }); boolean platformFont = AccessController.doPrivileged( - new PrivilegedAction() { - public Boolean run() { - String prop = - System.getProperty("java2d.font.usePlatformFont"); - String env = System.getenv("JAVA2D_USEPLATFORMFONT"); - return "true".equals(prop) || env != null; - } - }); + new PrivilegedAction() { + public Boolean run() { + String prop = System.getProperty("java2d.font.usePlatformFont"); + String env = System.getenv("JAVA2D_USEPLATFORMFONT"); + return "true".equals(prop) || env != null; + } + }); if (platformFont) { usePlatformFontMetrics = true; @@ -822,10 +795,9 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } private final ConcurrentHashMap - deferredFontFiles = - new ConcurrentHashMap(); + deferredFontFiles = new ConcurrentHashMap<>(); private final ConcurrentHashMap - initialisedFonts = new ConcurrentHashMap(); + initialisedFonts = new ConcurrentHashMap<>(); /* Remind: possibly enhance initialiseDeferredFonts() to be * optionally given a name and a style and it could stop when it @@ -867,11 +839,10 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } synchronized (jreFontDirName) { if (jreOtherFontFiles == null) { - HashSet otherFontFiles = new HashSet(); + HashSet otherFontFiles = new HashSet<>(); for (String deferredFile : deferredFontFiles.keySet()) { File file = new File(deferredFile); String dir = file.getParent(); - String fname = file.getName(); /* skip names which aren't absolute, aren't in the JRE * directory, or are known Lucida fonts. */ @@ -1006,8 +977,6 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { PhysicalFont physicalFont = null; try { - String name; - switch (fontFormat) { case FONTFORMAT_TRUETYPE: @@ -1173,8 +1142,8 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } else { filter = new TTorT1Filter(); } - return (String[])AccessController.doPrivileged(new PrivilegedAction() { - public Object run() { + return AccessController.doPrivileged(new PrivilegedAction() { + public String[] run() { if (pathDirs.length == 1) { File dir = new File(pathDirs[0]); String[] files = dir.list(filter); @@ -1186,14 +1155,14 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } return files; } else { - ArrayList fileList = new ArrayList(); + ArrayList fileList = new ArrayList<>(); for (int i = 0; i< pathDirs.length; i++) { File dir = new File(pathDirs[i]); String[] files = dir.list(filter); if (files == null) { continue; } - for (int f=0; f(); + unmappedFontNames = new ArrayList<>(); } unmappedFontNames.add(font); } @@ -1258,7 +1227,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } if (unmappedFontNames != null) { - HashSet unmappedFontFiles = new HashSet(); + HashSet unmappedFontFiles = new HashSet<>(); /* Every font key in fontToFileMap ought to correspond to a * font key in fontToFamilyNameMap. Entries that don't seem @@ -1313,7 +1282,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * To compare we also need lower case * versions of the names from the registry. */ - ArrayList registryFiles = new ArrayList(); + ArrayList registryFiles = new ArrayList<>(); for (String regFile : fontToFileMap.values()) { registryFiles.add(regFile.toLowerCase()); @@ -1382,7 +1351,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * To compare we also need lower case * versions of the names from the registry. */ - ArrayList registryFiles = new ArrayList(); + ArrayList registryFiles = new ArrayList<>(); for (String regFile : fontToFileMap.values()) { registryFiles.add(regFile.toLowerCase()); } @@ -1409,11 +1378,9 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { continue; } if (fontToFileMap2 == null) { - fontToFileMap2 = new HashMap(fontToFileMap); - fontToFamilyNameMap2 = - new HashMap(fontToFamilyNameMap); - familyToFontListMap2 = new - HashMap>(familyToFontListMap); + fontToFileMap2 = new HashMap<>(fontToFileMap); + fontToFamilyNameMap2 = new HashMap<>(fontToFamilyNameMap); + familyToFontListMap2 = new HashMap<>(familyToFontListMap); } String fontName = f.getFontName(null); String family = f.getFamilyName(null); @@ -1422,9 +1389,9 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { fontToFileMap2.put(fontName, pathFile); ArrayList fonts = familyToFontListMap2.get(familyLC); if (fonts == null) { - fonts = new ArrayList(); + fonts = new ArrayList<>(); } else { - fonts = new ArrayList(fonts); + fonts = new ArrayList<>(fonts); } fonts.add(fontName); familyToFontListMap2.put(familyLC, fonts); @@ -1502,7 +1469,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { * default implementation does nothing. */ public HashMap populateHardcodedFileNameMap() { - return new HashMap(0); + return new HashMap<>(0); } Font2D findFontFromPlatformMap(String lcName, int style) { @@ -1597,21 +1564,20 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { final String[] files = { plainFile, boldFile, italicFile, boldItalicFile } ; - failure = java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Boolean run() { - for (int i=0; i() { + public Boolean run() { + for (int i=0; i(100); - fontToFamilyNameMap = new HashMap(100); - familyToFontListMap = new HashMap>(50); + fontToFileMap = new HashMap<>(100); + fontToFamilyNameMap = new HashMap<>(100); + familyToFontListMap = new HashMap<>(50); populateFontFileNameMap(fontToFileMap, fontToFamilyNameMap, familyToFontListMap, @@ -1720,7 +1686,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { checkForUnreferencedFontFiles(); /* This odd code with TreeMap is used to preserve a historical * behaviour wrt the sorting order .. */ - ArrayList fontNames = new ArrayList(); + ArrayList fontNames = new ArrayList<>(); for (ArrayList a : familyToFontListMap.values()) { for (String s : a) { fontNames.add(s); @@ -1799,10 +1765,10 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } else if (pathDirs.length==1) { return pathDirs[0] + File.separator + s; } else { - String path = java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { + String path = AccessController.doPrivileged( + new PrivilegedAction() { public String run() { - for (int p=0; p fontNameCache = - new ConcurrentHashMap(); + new ConcurrentHashMap<>(); /* * The client supplies a name and a style. @@ -2300,7 +2266,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { boolean isCopy, CreatedFontTracker tracker) throws FontFormatException { - List fList = new ArrayList(); + List fList = new ArrayList<>(); int cnt = 1; String fontFilePath = fontFile.getPath(); FileFont font2D = null; @@ -2343,15 +2309,14 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } } catch (FontFormatException e) { if (isCopy) { - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { - if (_tracker != null) { - _tracker.subBytes((int)fFile.length()); - } - fFile.delete(); - return null; - } + AccessController.doPrivileged(new PrivilegedAction() { + public Void run() { + if (_tracker != null) { + _tracker.subBytes((int)fFile.length()); + } + fFile.delete(); + return null; + } }); } throw(e); @@ -2367,35 +2332,31 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { if (fileCloser == null) { final Runnable fileCloserRunnable = new Runnable() { - public void run() { - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { - - for (int i=0;i() { + public Void run() { + for (int i = 0;i < CHANNELPOOLSIZE; i++) { + if (fontFileCache[i] != null) { + try { + fontFileCache[i].close(); + } catch (Exception e) { + } + } } - } - } - if (tmpFontFiles != null) { - File[] files = new File[tmpFontFiles.size()]; - files = tmpFontFiles.toArray(files); - for (int f=0; f) () -> { ThreadGroup rootTG = ThreadGroupUtils.getRootThreadGroup(); @@ -2555,7 +2516,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { if (localeFullNamesToFont != null) { return; } - localeFullNamesToFont = new HashMap(); + localeFullNamesToFont = new HashMap<>(); Font2D[] fonts = getRegisteredFonts(); for (int i=0; i names = new HashSet(); + HashSet names = new HashSet<>(); for (int i=0; i pathList = new ArrayList(); + ArrayList pathList = new ArrayList<>(); try { while (parser.hasMoreTokens()) { pathList.add(parser.nextToken()); @@ -3067,9 +3028,8 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { } initialiseDeferredFonts(); - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { + AccessController.doPrivileged(new PrivilegedAction() { + public Void run() { if (fontPath == null) { fontPath = getPlatformFontPath(noType1Font); registerFontDirs(fontPath); @@ -3184,9 +3144,8 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { Thread.dumpStack(); FontUtilities.getLogger().info("loadAllFontFiles() called"); } - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { + AccessController.doPrivileged(new PrivilegedAction() { + public Void run() { if (fontPath == null) { fontPath = getPlatformFontPath(noType1Font); } @@ -3375,7 +3334,7 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { */ protected void addToMissingFontFileList(String fileName) { if (missingFontFiles == null) { - missingFontFiles = new HashSet(); + missingFontFiles = new HashSet<>(); } missingFontFiles.add(fileName); } @@ -3542,9 +3501,8 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { protected void addNativeFontFamilyNames(TreeMap familyNames, Locale requestedLocale) { } public void register1dot0Fonts() { - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { + AccessController.doPrivileged(new PrivilegedAction() { + public Void run() { String type1Dir = "/usr/openwin/lib/X11/fonts/Type1"; registerFontsInDir(type1Dir, true, Font2D.TYPE1_RANK, false, false); @@ -3583,32 +3541,30 @@ public abstract class SunFontManager implements FontSupport, FontManagerForSGE { private static Locale systemLocale = null; private static Locale getSystemStartupLocale() { if (systemLocale == null) { - systemLocale = (Locale) - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Object run() { - /* On windows the system locale may be different than the - * user locale. This is an unsupported configuration, but - * in that case we want to return a dummy locale that will - * never cause a match in the usage of this API. This is - * important because Windows documents that the family - * names of fonts are enumerated using the language of - * the system locale. BY returning a dummy locale in that - * case we do not use the platform API which would not - * return us the names we want. - */ - String fileEncoding = System.getProperty("file.encoding", ""); - String sysEncoding = System.getProperty("sun.jnu.encoding"); - if (sysEncoding != null && !sysEncoding.equals(fileEncoding)) { - return Locale.ROOT; - } + systemLocale = AccessController.doPrivileged(new PrivilegedAction() { + public Locale run() { + /* On windows the system locale may be different than the + * user locale. This is an unsupported configuration, but + * in that case we want to return a dummy locale that will + * never cause a match in the usage of this API. This is + * important because Windows documents that the family + * names of fonts are enumerated using the language of + * the system locale. BY returning a dummy locale in that + * case we do not use the platform API which would not + * return us the names we want. + */ + String fileEncoding = System.getProperty("file.encoding", ""); + String sysEncoding = System.getProperty("sun.jnu.encoding"); + if (sysEncoding != null && !sysEncoding.equals(fileEncoding)) { + return Locale.ROOT; + } - String language = System.getProperty("user.language", "en"); - String country = System.getProperty("user.country",""); - String variant = System.getProperty("user.variant",""); - return new Locale(language, country, variant); - } - }); + String language = System.getProperty("user.language", "en"); + String country = System.getProperty("user.country",""); + String variant = System.getProperty("user.variant",""); + return new Locale(language, country, variant); + } + }); } return systemLocale; } diff --git a/src/java.desktop/share/classes/sun/font/TrueTypeFont.java b/src/java.desktop/share/classes/sun/font/TrueTypeFont.java index cc9fe129516..d79adecbdf5 100644 --- a/src/java.desktop/share/classes/sun/font/TrueTypeFont.java +++ b/src/java.desktop/share/classes/sun/font/TrueTypeFont.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2020, 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 @@ -42,16 +42,14 @@ import java.nio.channels.FileChannel; import java.security.AccessController; import java.security.PrivilegedActionException; import java.security.PrivilegedExceptionAction; -import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; -import java.util.List; import java.util.Locale; import java.util.Map; -import java.util.Map.Entry; import sun.java2d.Disposer; import sun.java2d.DisposerRecord; +import sun.security.action.GetPropertyAction; /** * TrueTypeFont is not called SFntFont because it is not expected @@ -748,8 +746,7 @@ public class TrueTypeFont extends FileFont { if (FontUtilities.isWindows) { defaultCodePage = - java.security.AccessController.doPrivileged( - new sun.security.action.GetPropertyAction("file.encoding")); + AccessController.doPrivileged(new GetPropertyAction("file.encoding")); } else { if (languages.length != codePages.length) { throw new InternalError("wrong code pages array length"); @@ -814,15 +811,15 @@ public class TrueTypeFont extends FileFont { } int range1 = buffer.getInt(78); /* ulCodePageRange1 */ - int range2 = buffer.getInt(82); /* ulCodePageRange2 */ + // int range2 = buffer.getInt(82); /* ulCodePageRange2 */ /* This test is too stringent for Arial on Solaris (and perhaps * other fonts). Arial has at least one reserved bit set for an * unknown reason. */ -// if (((range1 & reserved_bits1) | (range2 & reserved_bits2)) != 0) { -// return false; -// } + // if (((range1 & reserved_bits1) | (range2 & reserved_bits2)) != 0) { + // return false; + // } for (int em=0; em map = new HashMap(200); + Map map = new HashMap<>(200); // the following statements are derived from the langIDMap // in src/windows/native/java/lang/java_props_md.c using the following @@ -1620,7 +1617,6 @@ public class TrueTypeFont extends FileFont { * needed. */ protected void initAllNames(int requestedID, HashSet names) { - byte[] name = new byte[256]; ByteBuffer buffer = getTableBuffer(nameTag); @@ -1642,7 +1638,7 @@ public class TrueTypeFont extends FileFont { continue; // skip over this record. } short encodingID = sbuffer.get(); - short langID = sbuffer.get(); + /* short langID = */ sbuffer.get(); short nameID = sbuffer.get(); int nameLen = ((int) sbuffer.get()) & 0xffff; int namePtr = (((int) sbuffer.get()) & 0xffff) + stringPtr;