mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-23 04:24:49 +02:00
Merge
This commit is contained in:
commit
c440b69d06
7 changed files with 303 additions and 85 deletions
|
@ -110,7 +110,7 @@ public abstract class GraphicsEnvironment {
|
||||||
// long t1 = System.currentTimeMillis();
|
// long t1 = System.currentTimeMillis();
|
||||||
// System.out.println("GE creation took " + (t1-t0)+ "ms.");
|
// System.out.println("GE creation took " + (t1-t0)+ "ms.");
|
||||||
if (isHeadless()) {
|
if (isHeadless()) {
|
||||||
localEnv = new HeadlessGraphicsEnvironment(localEnv);
|
ge = new HeadlessGraphicsEnvironment(ge);
|
||||||
}
|
}
|
||||||
} catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
throw new Error("Could not find class: "+nm);
|
throw new Error("Could not find class: "+nm);
|
||||||
|
|
|
@ -68,23 +68,16 @@ public final class FontManagerFactory {
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
String fmClassName = AccessController.doPrivileged(
|
|
||||||
new GetPropertyAction("sun.font.fontmanager",
|
|
||||||
DEFAULT_CLASS));
|
|
||||||
|
|
||||||
try {
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
ClassLoader cl = (ClassLoader)
|
|
||||||
AccessController.doPrivileged(new PrivilegedAction() {
|
AccessController.doPrivileged(new PrivilegedAction() {
|
||||||
public Object run() {
|
|
||||||
return ClassLoader.getSystemClassLoader();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
public Object run() {
|
||||||
|
try {
|
||||||
|
String fmClassName =
|
||||||
|
System.getProperty("sun.font.fontmanager",
|
||||||
|
DEFAULT_CLASS);
|
||||||
|
ClassLoader cl = ClassLoader.getSystemClassLoader();
|
||||||
Class fmClass = Class.forName(fmClassName, true, cl);
|
Class fmClass = Class.forName(fmClassName, true, cl);
|
||||||
instance = (FontManager) fmClass.newInstance();
|
instance = (FontManager) fmClass.newInstance();
|
||||||
|
|
||||||
} catch (ClassNotFoundException ex) {
|
} catch (ClassNotFoundException ex) {
|
||||||
InternalError err = new InternalError();
|
InternalError err = new InternalError();
|
||||||
err.initCause(ex);
|
err.initCause(ex);
|
||||||
|
@ -100,6 +93,9 @@ public final class FontManagerFactory {
|
||||||
err.initCause(ex);
|
err.initCause(ex);
|
||||||
throw err;
|
throw err;
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,9 +32,9 @@ import java.io.FileInputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
|
|
||||||
|
import java.security.PrivilegedAction;
|
||||||
import javax.swing.plaf.FontUIResource;
|
import javax.swing.plaf.FontUIResource;
|
||||||
|
|
||||||
import sun.security.action.GetPropertyAction;
|
|
||||||
import sun.util.logging.PlatformLogger;
|
import sun.util.logging.PlatformLogger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -42,43 +42,42 @@ import sun.util.logging.PlatformLogger;
|
||||||
*/
|
*/
|
||||||
public final class FontUtilities {
|
public final class FontUtilities {
|
||||||
|
|
||||||
public static final boolean isSolaris;
|
public static boolean isSolaris;
|
||||||
|
|
||||||
public static final boolean isLinux;
|
public static boolean isLinux;
|
||||||
|
|
||||||
public static final boolean isSolaris8;
|
public static boolean isSolaris8;
|
||||||
|
|
||||||
public static final boolean isSolaris9;
|
public static boolean isSolaris9;
|
||||||
|
|
||||||
public static final boolean isOpenSolaris;
|
public static boolean isOpenSolaris;
|
||||||
|
|
||||||
public static final boolean useT2K;
|
public static boolean useT2K;
|
||||||
|
|
||||||
public static final boolean isWindows;
|
public static boolean isWindows;
|
||||||
|
|
||||||
public static final boolean isOpenJDK;
|
public static boolean isOpenJDK;
|
||||||
|
|
||||||
static final String LUCIDA_FILE_NAME = "LucidaSansRegular.ttf";
|
static final String LUCIDA_FILE_NAME = "LucidaSansRegular.ttf";
|
||||||
|
|
||||||
// This static initializer block figures out the OS constants.
|
// This static initializer block figures out the OS constants.
|
||||||
static {
|
static {
|
||||||
|
|
||||||
String osName = AccessController.doPrivileged(
|
AccessController.doPrivileged(new PrivilegedAction () {
|
||||||
new GetPropertyAction("os.name", "unknownOS"));
|
public Object run() {
|
||||||
|
String osName = System.getProperty("os.name", "unknownOS");
|
||||||
isSolaris = osName.startsWith("SunOS");
|
isSolaris = osName.startsWith("SunOS");
|
||||||
|
|
||||||
isLinux = osName.startsWith("Linux");
|
isLinux = osName.startsWith("Linux");
|
||||||
|
|
||||||
String t2kStr = AccessController.doPrivileged(
|
String t2kStr = System.getProperty("sun.java2d.font.scaler");
|
||||||
new GetPropertyAction("sun.java2d.font.scaler"));
|
|
||||||
if (t2kStr != null) {
|
if (t2kStr != null) {
|
||||||
useT2K = "t2k".equals(t2kStr);
|
useT2K = "t2k".equals(t2kStr);
|
||||||
} else {
|
} else {
|
||||||
useT2K = false;
|
useT2K = false;
|
||||||
}
|
}
|
||||||
if (isSolaris) {
|
if (isSolaris) {
|
||||||
String version = AccessController.doPrivileged(
|
String version = System.getProperty("os.version", "0.0");
|
||||||
new GetPropertyAction("os.version", "0.0"));
|
|
||||||
isSolaris8 = version.startsWith("5.8");
|
isSolaris8 = version.startsWith("5.8");
|
||||||
isSolaris9 = version.startsWith("5.9");
|
isSolaris9 = version.startsWith("5.9");
|
||||||
float ver = Float.parseFloat(version);
|
float ver = Float.parseFloat(version);
|
||||||
|
@ -101,7 +100,7 @@ public final class FontUtilities {
|
||||||
isOpenSolaris = false;
|
isOpenSolaris = false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
isOpenSolaris= false;
|
isOpenSolaris = false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
isSolaris8 = false;
|
isSolaris8 = false;
|
||||||
|
@ -109,12 +108,16 @@ public final class FontUtilities {
|
||||||
isOpenSolaris = false;
|
isOpenSolaris = false;
|
||||||
}
|
}
|
||||||
isWindows = osName.startsWith("Windows");
|
isWindows = osName.startsWith("Windows");
|
||||||
String jreLibDirName = AccessController.doPrivileged(
|
String jreLibDirName = System.getProperty("java.home", "")
|
||||||
new GetPropertyAction("java.home","")) + File.separator + "lib";
|
+ File.separator + "lib";
|
||||||
String jreFontDirName = jreLibDirName + File.separator + "fonts";
|
String jreFontDirName =
|
||||||
File lucidaFile =
|
jreLibDirName + File.separator + "fonts";
|
||||||
new File(jreFontDirName + File.separator + LUCIDA_FILE_NAME);
|
File lucidaFile = new File(jreFontDirName + File.separator
|
||||||
|
+ LUCIDA_FILE_NAME);
|
||||||
isOpenJDK = !lucidaFile.exists();
|
isOpenJDK = !lucidaFile.exists();
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
39
jdk/test/java/awt/FontClass/FontPrivilege.java
Normal file
39
jdk/test/java/awt/FontClass/FontPrivilege.java
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2010 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 5010310 6319835 6904882
|
||||||
|
* @summary test fonts can be created in the presence of a security manager
|
||||||
|
* @run main/othervm/secure=java.lang.SecurityManager FontPrivilege
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.awt.Font;
|
||||||
|
|
||||||
|
public class FontPrivilege {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
new Font("Helvetica", Font.PLAIN, 12).getFamily();
|
||||||
|
new Font("foo bar", Font.PLAIN, 12).getFamily();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2010 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 6896335
|
||||||
|
* @summary Test GraphicsEnvironment.getDefaultScreenDevice() in headless mode
|
||||||
|
* @run main/othervm -Djava.awt.headless=true TestGetDefScreenDevice
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.awt.*;
|
||||||
|
public class TestGetDefScreenDevice {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
GraphicsEnvironment ge = GraphicsEnvironment.getLocalGraphicsEnvironment();
|
||||||
|
try {
|
||||||
|
ge.getDefaultScreenDevice();
|
||||||
|
throw new Exception("Failed. HeadlessException not thrown");
|
||||||
|
} catch (HeadlessException he) {
|
||||||
|
// OK, test passed.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
105
jdk/test/java/awt/PrintJob/Security/SecurityDialogTest.java
Normal file
105
jdk/test/java/awt/PrintJob/Security/SecurityDialogTest.java
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2010 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 6195901 6195923 6195928 6195933 6491273 6888734
|
||||||
|
* @summary No SecurityException should be thrown when printing to a file
|
||||||
|
using the given policy.
|
||||||
|
Print to file option should be selected.
|
||||||
|
* @run main/othervm/policy=policy SecurityDialogTest
|
||||||
|
*/
|
||||||
|
import java.awt.*;
|
||||||
|
import java.awt.event.*;
|
||||||
|
import java.util.*;
|
||||||
|
import java.io.*;
|
||||||
|
|
||||||
|
|
||||||
|
public class SecurityDialogTest extends Frame implements ActionListener {
|
||||||
|
// Declare things used in the test, like buttons and labels here
|
||||||
|
|
||||||
|
Button nativeDlg, setSecurity;
|
||||||
|
boolean isNative = true;
|
||||||
|
|
||||||
|
public SecurityDialogTest() {
|
||||||
|
|
||||||
|
nativeDlg = new Button("Print Dialog");
|
||||||
|
nativeDlg.addActionListener(this);
|
||||||
|
setSecurity = new Button("Toggle Dialog");
|
||||||
|
setSecurity.addActionListener(this);
|
||||||
|
add("South", nativeDlg);
|
||||||
|
add("North", setSecurity);
|
||||||
|
setSize(300, 300);
|
||||||
|
setVisible(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String args[]) {
|
||||||
|
System.out.println("Native dialog is the default");
|
||||||
|
SecurityDialogTest test = new SecurityDialogTest();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
|
||||||
|
if (e.getSource() == setSecurity) {
|
||||||
|
if (isNative) {
|
||||||
|
isNative = false;
|
||||||
|
System.out.println("Common dialog is the default");
|
||||||
|
|
||||||
|
} else {
|
||||||
|
isNative = true;
|
||||||
|
System.out.println("Native dialog is the default");
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
JobAttributes ja = new JobAttributes();
|
||||||
|
PageAttributes pa = new PageAttributes();
|
||||||
|
|
||||||
|
if (isNative) {
|
||||||
|
ja.setDialog(JobAttributes.DialogType.NATIVE);
|
||||||
|
} else {
|
||||||
|
ja.setDialog(JobAttributes.DialogType.COMMON);
|
||||||
|
}
|
||||||
|
ja.setDestination(JobAttributes.DestinationType.FILE);
|
||||||
|
ja.setFileName("mohan.ps");
|
||||||
|
|
||||||
|
|
||||||
|
PrintJob pjob = getToolkit().getPrintJob(this, null, ja, pa);
|
||||||
|
|
||||||
|
if (pjob != null) {
|
||||||
|
Graphics pg = pjob.getGraphics();
|
||||||
|
System.out.println("PJOB: " + pjob);
|
||||||
|
if (pg != null) {
|
||||||
|
System.out.println("Printer Graphics: " + pg);
|
||||||
|
this.printAll(pg);
|
||||||
|
pg.dispose();
|
||||||
|
} else {
|
||||||
|
System.out.println("Printer Graphics is null");
|
||||||
|
}
|
||||||
|
pjob.end();
|
||||||
|
System.out.println("DONE");
|
||||||
|
} else {
|
||||||
|
System.out.println("PJOB is null");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
32
jdk/test/java/awt/PrintJob/Security/policy
Normal file
32
jdk/test/java/awt/PrintJob/Security/policy
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2010 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* AUTOMATICALLY GENERATED ON Thu Jan 03 15:48:39 PST 2002*/
|
||||||
|
/* DO NOT EDIT */
|
||||||
|
|
||||||
|
grant {
|
||||||
|
permission java.io.FilePermission "<<ALL FILES>>", "read,write";
|
||||||
|
permission java.lang.RuntimePermission "queuePrintJob";
|
||||||
|
permission java.lang.RuntimePermission "setSecurityManager";
|
||||||
|
};
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue