提交 e8acb837 编写于 作者: P prr

6752638: java.awt.GraphicsEnvironment.preferLocaleFonts() throws NPE on Linux

6755034: Legal notice repair: jdk/src/solaris/classes/sun/font/FcFontConfiguration.java
Reviewed-by: bae, igor
上级 4deb9ff8
...@@ -356,6 +356,9 @@ public abstract class GraphicsEnvironment { ...@@ -356,6 +356,9 @@ public abstract class GraphicsEnvironment {
* @since 1.5 * @since 1.5
*/ */
public void preferLocaleFonts() { public void preferLocaleFonts() {
if (!(this instanceof SunGraphicsEnvironment)) {
return;
}
sun.font.FontManager.preferLocaleFonts(); sun.font.FontManager.preferLocaleFonts();
} }
...@@ -376,6 +379,9 @@ public abstract class GraphicsEnvironment { ...@@ -376,6 +379,9 @@ public abstract class GraphicsEnvironment {
* @since 1.5 * @since 1.5
*/ */
public void preferProportionalFonts() { public void preferProportionalFonts() {
if (!(this instanceof SunGraphicsEnvironment)) {
return;
}
sun.font.FontManager.preferProportionalFonts(); sun.font.FontManager.preferProportionalFonts();
} }
......
...@@ -98,7 +98,7 @@ public abstract class FontConfiguration { ...@@ -98,7 +98,7 @@ public abstract class FontConfiguration {
if (!inited) { if (!inited) {
this.preferLocaleFonts = false; this.preferLocaleFonts = false;
this.preferPropFonts = false; this.preferPropFonts = false;
fontConfig = this; /* static initialization */ setFontConfiguration();
readFontConfigFile(fontConfigFile); readFontConfigFile(fontConfigFile);
initFontConfig(); initFontConfig();
inited = true; inited = true;
...@@ -1244,6 +1244,10 @@ public abstract class FontConfiguration { ...@@ -1244,6 +1244,10 @@ public abstract class FontConfiguration {
return fontConfig; return fontConfig;
} }
protected void setFontConfiguration() {
fontConfig = this; /* static initialization */
}
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////
// FontConfig data tables and the index constants in binary file // // FontConfig data tables and the index constants in binary file //
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
* accompanied this code). * accompanied this code).
* *
* You should have received a copy of the GNU General Public License version * You should have received a copy of the GNU General Public License version
* along with this work; if not, write to the Free Software Foundation, * 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
* *
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
...@@ -87,6 +87,7 @@ public class FcFontConfiguration extends FontConfiguration { ...@@ -87,6 +87,7 @@ public class FcFontConfiguration extends FontConfiguration {
return true; return true;
} }
setFontConfiguration();
readFcInfo(); readFcInfo();
if (fcCompFonts == null) { if (fcCompFonts == null) {
fcCompFonts = FontManager.loadFontConfig(); fcCompFonts = FontManager.loadFontConfig();
......
/*
* Copyright (c) 2008 Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/*
* @test
* @bug 6752638
* @summary Test no NPE calling preferLocaleFonts() on custom GE.
* @run main PreferLocaleFonts
*/
import java.util.*;
import java.awt.*;
import java.awt.image.*;
public class PreferLocaleFonts extends GraphicsEnvironment {
public static void main(String args[]) {
(new PreferLocaleFonts()).preferLocaleFonts();
}
public PreferLocaleFonts() {
super();
}
public Graphics2D createGraphics(BufferedImage image) {
return null;
}
public String[] getAvailableFontFamilyNames(Locale locale) {
return null;
}
public String[] getAvailableFontFamilyNames() {
return null;
}
public Font[] getAllFonts() {
return null;
}
public GraphicsDevice getDefaultScreenDevice() throws HeadlessException {
return null;
}
public GraphicsDevice[] getScreenDevices() throws HeadlessException {
return null;
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册