mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-24 04:54:40 +02:00
7131021: [macosx] Consider using system properties to pass arguments from the launcher to AWT/SplashScreen
Document the environment variables and add tests Reviewed-by: ksrini
This commit is contained in:
parent
2942df6c93
commit
14842a2b97
4 changed files with 241 additions and 2 deletions
|
@ -906,11 +906,41 @@ SetXDockArgForAWT(const char *arg)
|
||||||
{
|
{
|
||||||
char envVar[80];
|
char envVar[80];
|
||||||
if (strstr(arg, "-Xdock:name=") == arg) {
|
if (strstr(arg, "-Xdock:name=") == arg) {
|
||||||
|
/*
|
||||||
|
* The APP_NAME_<pid> environment variable is used to pass
|
||||||
|
* an application name as specified with the -Xdock:name command
|
||||||
|
* line option from Java launcher code to the AWT code in order
|
||||||
|
* to assign this name to the app's dock tile on the Mac.
|
||||||
|
* The _<pid> part is added to avoid collisions with child processes.
|
||||||
|
*
|
||||||
|
* WARNING: This environment variable is an implementation detail and
|
||||||
|
* isn't meant for use outside of the core platform. The mechanism for
|
||||||
|
* passing this information from Java launcher to other modules may
|
||||||
|
* change drastically between update release, and it may even be
|
||||||
|
* removed or replaced with another mechanism.
|
||||||
|
*
|
||||||
|
* NOTE: It is used by SWT, and JavaFX.
|
||||||
|
*/
|
||||||
snprintf(envVar, sizeof(envVar), "APP_NAME_%d", getpid());
|
snprintf(envVar, sizeof(envVar), "APP_NAME_%d", getpid());
|
||||||
setenv(envVar, (arg + 12), 1);
|
setenv(envVar, (arg + 12), 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strstr(arg, "-Xdock:icon=") == arg) {
|
if (strstr(arg, "-Xdock:icon=") == arg) {
|
||||||
|
/*
|
||||||
|
* The APP_ICON_<pid> environment variable is used to pass
|
||||||
|
* an application icon as specified with the -Xdock:icon command
|
||||||
|
* line option from Java launcher code to the AWT code in order
|
||||||
|
* to assign this icon to the app's dock tile on the Mac.
|
||||||
|
* The _<pid> part is added to avoid collisions with child processes.
|
||||||
|
*
|
||||||
|
* WARNING: This environment variable is an implementation detail and
|
||||||
|
* isn't meant for use outside of the core platform. The mechanism for
|
||||||
|
* passing this information from Java launcher to other modules may
|
||||||
|
* change drastically between update release, and it may even be
|
||||||
|
* removed or replaced with another mechanism.
|
||||||
|
*
|
||||||
|
* NOTE: It is used by SWT, and JavaFX.
|
||||||
|
*/
|
||||||
snprintf(envVar, sizeof(envVar), "APP_ICON_%d", getpid());
|
snprintf(envVar, sizeof(envVar), "APP_ICON_%d", getpid());
|
||||||
setenv(envVar, (arg + 12), 1);
|
setenv(envVar, (arg + 12), 1);
|
||||||
}
|
}
|
||||||
|
@ -931,6 +961,22 @@ SetMainClassForAWT(JNIEnv *env, jclass mainClass) {
|
||||||
NULL_CHECK(mainClassName = (*env)->GetStringUTFChars(env, mainClassString, NULL));
|
NULL_CHECK(mainClassName = (*env)->GetStringUTFChars(env, mainClassString, NULL));
|
||||||
|
|
||||||
char envVar[80];
|
char envVar[80];
|
||||||
|
/*
|
||||||
|
* The JAVA_MAIN_CLASS_<pid> environment variable is used to pass
|
||||||
|
* the name of a Java class whose main() method is invoked by
|
||||||
|
* the Java launcher code to start the application, to the AWT code
|
||||||
|
* in order to assign the name to the Apple menu bar when the app
|
||||||
|
* is active on the Mac.
|
||||||
|
* The _<pid> part is added to avoid collisions with child processes.
|
||||||
|
*
|
||||||
|
* WARNING: This environment variable is an implementation detail and
|
||||||
|
* isn't meant for use outside of the core platform. The mechanism for
|
||||||
|
* passing this information from Java launcher to other modules may
|
||||||
|
* change drastically between update release, and it may even be
|
||||||
|
* removed or replaced with another mechanism.
|
||||||
|
*
|
||||||
|
* NOTE: It is used by SWT, and JavaFX.
|
||||||
|
*/
|
||||||
snprintf(envVar, sizeof(envVar), "JAVA_MAIN_CLASS_%d", getpid());
|
snprintf(envVar, sizeof(envVar), "JAVA_MAIN_CLASS_%d", getpid());
|
||||||
setenv(envVar, mainClassName, 1);
|
setenv(envVar, mainClassName, 1);
|
||||||
|
|
||||||
|
|
79
jdk/test/tools/launcher/EnvironmentVariables.java
Normal file
79
jdk/test/tools/launcher/EnvironmentVariables.java
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* see TestSpecialArgs.java
|
||||||
|
* bug 7131021
|
||||||
|
* summary Checks for environment variables set by the launcher
|
||||||
|
* author anthony.petrov@oracle.com: area=launcher
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class EnvironmentVariables {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
if (args.length != 2) {
|
||||||
|
throw new RuntimeException("ERROR: two command line arguments expected");
|
||||||
|
}
|
||||||
|
|
||||||
|
String name = args[0];
|
||||||
|
String expect = args[1];
|
||||||
|
String key = null;
|
||||||
|
|
||||||
|
if (!name.endsWith("*")) {
|
||||||
|
key = name;
|
||||||
|
} else {
|
||||||
|
name = name.split("\\*")[0];
|
||||||
|
|
||||||
|
for (String s : System.getenv().keySet()) {
|
||||||
|
if (s.startsWith(name)) {
|
||||||
|
if (key == null) {
|
||||||
|
key = s;
|
||||||
|
} else {
|
||||||
|
System.err.println("WARNING: more variables match: " + s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (key == null) {
|
||||||
|
throw new RuntimeException("ERROR: unable to find a match for: " + name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
System.err.println("Will check the variable named: '" + key +
|
||||||
|
"' expecting the value: '" + expect + "'");
|
||||||
|
|
||||||
|
if (!System.getenv().containsKey(key)) {
|
||||||
|
throw new RuntimeException("ERROR: the variable '" + key +
|
||||||
|
"' is not present in the environment");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!expect.equals(System.getenv().get(key))) {
|
||||||
|
throw new RuntimeException("ERROR: expected: '" + expect +
|
||||||
|
"', got: '" + System.getenv().get(key) + "'");
|
||||||
|
}
|
||||||
|
for (String x : args) {
|
||||||
|
System.err.print(x + " ");
|
||||||
|
}
|
||||||
|
System.err.println("-----> Passed!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileFilter;
|
import java.io.FileFilter;
|
||||||
|
@ -316,19 +317,28 @@ public class TestHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
static TestResult doExec(String...cmds) {
|
static TestResult doExec(String...cmds) {
|
||||||
return doExec(null, cmds);
|
return doExec(null, null, cmds);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static TestResult doExec(Map<String, String> envToSet, String...cmds) {
|
||||||
|
return doExec(envToSet, null, cmds);
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* A method which executes a java cmd and returns the results in a container
|
* A method which executes a java cmd and returns the results in a container
|
||||||
*/
|
*/
|
||||||
static TestResult doExec(Map<String, String> envToSet, String...cmds) {
|
static TestResult doExec(Map<String, String> envToSet,
|
||||||
|
Set<String> envToRemove, String...cmds) {
|
||||||
String cmdStr = "";
|
String cmdStr = "";
|
||||||
for (String x : cmds) {
|
for (String x : cmds) {
|
||||||
cmdStr = cmdStr.concat(x + " ");
|
cmdStr = cmdStr.concat(x + " ");
|
||||||
}
|
}
|
||||||
ProcessBuilder pb = new ProcessBuilder(cmds);
|
ProcessBuilder pb = new ProcessBuilder(cmds);
|
||||||
Map<String, String> env = pb.environment();
|
Map<String, String> env = pb.environment();
|
||||||
|
if (envToRemove != null) {
|
||||||
|
for (String key : envToRemove) {
|
||||||
|
env.remove(key);
|
||||||
|
}
|
||||||
|
}
|
||||||
if (envToSet != null) {
|
if (envToSet != null) {
|
||||||
env.putAll(envToSet);
|
env.putAll(envToSet);
|
||||||
}
|
}
|
||||||
|
|
104
jdk/test/tools/launcher/TestSpecialArgs.java
Normal file
104
jdk/test/tools/launcher/TestSpecialArgs.java
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
/*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 7124089 7131021
|
||||||
|
* @summary Checks for MacOSX specific flags are accepted or rejected, and
|
||||||
|
* MacOSX platforms specific environment is consistent.
|
||||||
|
* @compile -XDignore.symbol.file TestSpecialArgs.java EnvironmentVariables.java
|
||||||
|
* @run main TestSpecialArgs
|
||||||
|
*/
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
public class TestSpecialArgs extends TestHelper {
|
||||||
|
|
||||||
|
public static void main(String... args) {
|
||||||
|
final Map<String, String> envMap = new HashMap<>();
|
||||||
|
envMap.put("_JAVA_LAUNCHER_DEBUG", "true");
|
||||||
|
|
||||||
|
TestResult tr = doExec(envMap, javaCmd, "-XstartOnFirstThread", "-version");
|
||||||
|
if (isMacOSX) {
|
||||||
|
if (!tr.contains("In same thread")) {
|
||||||
|
System.out.println(tr);
|
||||||
|
throw new RuntimeException("Error: not running in the same thread ?");
|
||||||
|
}
|
||||||
|
if (!tr.isOK()) {
|
||||||
|
System.out.println(tr);
|
||||||
|
throw new RuntimeException("Error: arg was rejected ????");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (tr.isOK()) {
|
||||||
|
System.out.println(tr);
|
||||||
|
throw new RuntimeException("Error: argument was accepted ????");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tr = doExec(javaCmd, "-Xdock:/tmp/not-available", "-version");
|
||||||
|
if (isMacOSX) {
|
||||||
|
if (!tr.isOK()) {
|
||||||
|
System.out.println(tr);
|
||||||
|
throw new RuntimeException("Error: arg was rejected ????");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (tr.isOK()) {
|
||||||
|
System.out.println(tr);
|
||||||
|
throw new RuntimeException("Error: argument was accepted ????");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// MacOSX specific tests ensue......
|
||||||
|
if (!isMacOSX)
|
||||||
|
return;
|
||||||
|
Set<String> envToRemove = new HashSet<>();
|
||||||
|
Map<String, String> map = System.getenv();
|
||||||
|
for (String s : map.keySet()) {
|
||||||
|
if (s.startsWith("JAVA_MAIN_CLASS_")
|
||||||
|
|| s.startsWith("APP_NAME_")
|
||||||
|
|| s.startsWith("APP_ICON_")) {
|
||||||
|
envToRemove.add(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
runTest(envToRemove, javaCmd, "-cp", TEST_CLASSES_DIR.getAbsolutePath(),
|
||||||
|
"EnvironmentVariables", "JAVA_MAIN_CLASS_*",
|
||||||
|
"EnvironmentVariables");
|
||||||
|
|
||||||
|
runTest(envToRemove, javaCmd, "-cp", TEST_CLASSES_DIR.getAbsolutePath(),
|
||||||
|
"-Xdock:name=TestAppName", "EnvironmentVariables",
|
||||||
|
"APP_NAME_*", "TestAppName");
|
||||||
|
|
||||||
|
runTest(envToRemove, javaCmd, "-cp", TEST_CLASSES_DIR.getAbsolutePath(),
|
||||||
|
"-Xdock:icon=TestAppIcon", "EnvironmentVariables",
|
||||||
|
"APP_ICON_*", "TestAppIcon");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void runTest(Set<String> envToRemove, String... args) {
|
||||||
|
TestResult tr = doExec(null, envToRemove, args);
|
||||||
|
if (!tr.isOK()) {
|
||||||
|
System.err.println(tr.toString());
|
||||||
|
throw new RuntimeException("Test Fails");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue