This commit is contained in:
Vladimir Kozlov 2015-03-02 10:09:33 -08:00
commit 6fd49139e8
167 changed files with 8353 additions and 5018 deletions

View File

@ -294,3 +294,4 @@ b2f9702efbe95527ea3a991474fda23987ff1c5c jdk9-b48
5b8db585a33c3cc48e70e688ceee57dd9271dc5d jdk9-b49 5b8db585a33c3cc48e70e688ceee57dd9271dc5d jdk9-b49
1550b2f6b63d1411fa84dc7bbc6f04809aedb43f jdk9-b50 1550b2f6b63d1411fa84dc7bbc6f04809aedb43f jdk9-b50
6efe265424e3f1ea596408a1f71baf2de316c772 jdk9-b51 6efe265424e3f1ea596408a1f71baf2de316c772 jdk9-b51
d6224d6021459ac8b3832e822f5acc849fa944af jdk9-b52

View File

@ -294,3 +294,4 @@ b6cca3e6175a69f39e5799b7349ddb0176630291 jdk9-b47
d91ed1951b948210590ce1394bea5515357246ba jdk9-b49 d91ed1951b948210590ce1394bea5515357246ba jdk9-b49
d1f37d39ff2421f956a6ddf316cf763807bc3363 jdk9-b50 d1f37d39ff2421f956a6ddf316cf763807bc3363 jdk9-b50
6207b4b8731ca75c51b031c47daa813ab92ef558 jdk9-b51 6207b4b8731ca75c51b031c47daa813ab92ef558 jdk9-b51
1822e59f17121b09e7899cf338cfb6e37fe5fceb jdk9-b52

View File

@ -1,5 +1,5 @@
# #
# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved. # Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# #
# This code is free software; you can redistribute it and/or modify it # This code is free software; you can redistribute it and/or modify it
@ -77,6 +77,9 @@ AC_DEFUN([BASIC_PREPEND_TO_PATH],
# $1: The name of the variable to fix # $1: The name of the variable to fix
AC_DEFUN([BASIC_FIXUP_PATH], AC_DEFUN([BASIC_FIXUP_PATH],
[ [
# Only process if variable expands to non-empty
if test "x[$]$1" != x; then
if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then
BASIC_FIXUP_PATH_CYGWIN($1) BASIC_FIXUP_PATH_CYGWIN($1)
elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then
@ -98,6 +101,7 @@ AC_DEFUN([BASIC_FIXUP_PATH],
$1="`cd "$path"; $THEPWDCMD -L`" $1="`cd "$path"; $THEPWDCMD -L`"
fi fi
fi
]) ])
# This will make sure the given variable points to a executable # This will make sure the given variable points to a executable
@ -113,6 +117,9 @@ AC_DEFUN([BASIC_FIXUP_PATH],
# $1: The name of the variable to fix # $1: The name of the variable to fix
AC_DEFUN([BASIC_FIXUP_EXECUTABLE], AC_DEFUN([BASIC_FIXUP_EXECUTABLE],
[ [
# Only process if variable expands to non-empty
if test "x[$]$1" != x; then
if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then
BASIC_FIXUP_EXECUTABLE_CYGWIN($1) BASIC_FIXUP_EXECUTABLE_CYGWIN($1)
elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then
@ -165,6 +172,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE],
$1="$new_complete" $1="$new_complete"
AC_MSG_NOTICE([Rewriting $1 to "$new_complete"]) AC_MSG_NOTICE([Rewriting $1 to "$new_complete"])
fi fi
fi
]) ])
AC_DEFUN([BASIC_REMOVE_SYMBOLIC_LINKS], AC_DEFUN([BASIC_REMOVE_SYMBOLIC_LINKS],

File diff suppressed because it is too large Load Diff

View File

@ -351,18 +351,34 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV],
IFS=";" IFS=";"
for i in $VS_INCLUDE; do for i in $VS_INCLUDE; do
ipath=$i ipath=$i
# Only process non-empty elements
if test "x$ipath" != x; then
IFS="$OLDIFS" IFS="$OLDIFS"
# Check that directory exists before calling fixup_path
testpath=$ipath
BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([testpath])
if test -d "$testpath"; then
BASIC_FIXUP_PATH([ipath]) BASIC_FIXUP_PATH([ipath])
IFS=";"
SYSROOT_CFLAGS="$SYSROOT_CFLAGS -I$ipath" SYSROOT_CFLAGS="$SYSROOT_CFLAGS -I$ipath"
fi
IFS=";"
fi
done done
# Convert VS_LIB into SYSROOT_LDFLAGS # Convert VS_LIB into SYSROOT_LDFLAGS
for i in $VS_LIB; do for i in $VS_LIB; do
libpath=$i libpath=$i
# Only process non-empty elements
if test "x$libpath" != x; then
IFS="$OLDIFS" IFS="$OLDIFS"
# Check that directory exists before calling fixup_path
testpath=$libpath
BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([testpath])
if test -d "$testpath"; then
BASIC_FIXUP_PATH([libpath]) BASIC_FIXUP_PATH([libpath])
IFS=";"
SYSROOT_LDFLAGS="$SYSROOT_LDFLAGS -libpath:$libpath" SYSROOT_LDFLAGS="$SYSROOT_LDFLAGS -libpath:$libpath"
fi
IFS=";"
fi
done done
IFS="$OLDIFS" IFS="$OLDIFS"
fi fi

View File

@ -180,7 +180,6 @@ jdk/src/java.base/share/classes/sun/nio/ch : jdk/src/share/classes/sun/nio/ch
jdk/src/java.base/share/classes/sun/nio/cs : jdk/src/share/classes/sun/nio/cs jdk/src/java.base/share/classes/sun/nio/cs : jdk/src/share/classes/sun/nio/cs
jdk/src/java.base/share/classes/sun/nio/fs : jdk/src/share/classes/sun/nio/fs jdk/src/java.base/share/classes/sun/nio/fs : jdk/src/share/classes/sun/nio/fs
jdk/src/java.base/share/classes/sun/reflect : jdk/src/share/classes/sun/reflect jdk/src/java.base/share/classes/sun/reflect : jdk/src/share/classes/sun/reflect
jdk/src/java.base/share/classes/sun/security/acl : jdk/src/share/classes/sun/security/acl
jdk/src/java.base/share/classes/sun/security/action : jdk/src/share/classes/sun/security/action jdk/src/java.base/share/classes/sun/security/action : jdk/src/share/classes/sun/security/action
jdk/src/java.base/share/classes/sun/security/internal : jdk/src/share/classes/sun/security/internal jdk/src/java.base/share/classes/sun/security/internal : jdk/src/share/classes/sun/security/internal
jdk/src/java.base/share/classes/sun/security/jca : jdk/src/share/classes/sun/security/jca jdk/src/java.base/share/classes/sun/security/jca : jdk/src/share/classes/sun/security/jca

View File

@ -294,3 +294,4 @@ a13c49c5f2899b702652a460ed7aa73123e671e6 jdk9-b48
9285d14eb7b6b0815679bae98dd936dbc136218d jdk9-b49 9285d14eb7b6b0815679bae98dd936dbc136218d jdk9-b49
224f593393e5b01b3c8f1e591b7f4b1790a3737a jdk9-b50 224f593393e5b01b3c8f1e591b7f4b1790a3737a jdk9-b50
2309c02386d1fa4ced5051873ffb9e04874f7a44 jdk9-b51 2309c02386d1fa4ced5051873ffb9e04874f7a44 jdk9-b51
b8538bbb6f224ab1dabba579137099c166ad4724 jdk9-b52

View File

@ -43,7 +43,6 @@ import java.io.FileInputStream;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedAction; import java.security.PrivilegedAction;
import sun.security.action.GetPropertyAction;
import java.util.Properties; import java.util.Properties;
class GetORBPropertiesFileAction implements PrivilegedAction { class GetORBPropertiesFileAction implements PrivilegedAction {

View File

@ -454,3 +454,4 @@ cc775a4a24c7f5d9e624b4205e9fbd48a17331f6 jdk9-b48
360cd1fc42f10941a9fd17cc32d5b85a22d12a0b jdk9-b49 360cd1fc42f10941a9fd17cc32d5b85a22d12a0b jdk9-b49
e0947f58c9c1426aa0d98b98ebb78357b27a7b99 jdk9-b50 e0947f58c9c1426aa0d98b98ebb78357b27a7b99 jdk9-b50
403b9cbadb04d3d1201823591cf931dc93b38e3a jdk9-b51 403b9cbadb04d3d1201823591cf931dc93b38e3a jdk9-b51
9fb7fdc554db5be5c5b10f88f529ec3b870c44e3 jdk9-b52

View File

@ -0,0 +1,81 @@
#
# Copyright (c) 2015, 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.
#
################################################################################
# This file builds the native component of the JTReg tests for Hotspot.
# It also covers the test-image part, where the built files are copied to the
# test image.
################################################################################
default: all
include $(SPEC)
include MakeBase.gmk
include TestFilesCompilation.gmk
################################################################################
# Targets for building the native tests themselves.
################################################################################
# Add more directories here when needed.
BUILD_HOTSPOT_JTREG_NATIVE_SRC := \
$(HOTSPOT_TOPDIR)/test/native_sanity \
#
BUILD_HOTSPOT_JTREG_OUTPUT_DIR := $(BUILD_OUTPUT)/support/test/hotspot/jtreg/native
BUILD_HOTSPOT_JTREG_IMAGE_DIR := $(TEST_IMAGE_DIR)/hotspot/jtreg
$(eval $(call SetupTestFilesCompilation, BUILD_HOTSPOT_JTREG_LIBRARIES, \
TYPE := LIBRARY, \
SOURCE_DIRS := $(BUILD_HOTSPOT_JTREG_NATIVE_SRC), \
OUTPUT_DIR := $(BUILD_HOTSPOT_JTREG_OUTPUT_DIR), \
))
$(eval $(call SetupTestFilesCompilation, BUILD_HOTSPOT_JTREG_EXECUTABLES, \
TYPE := PROGRAM, \
SOURCE_DIRS := $(BUILD_HOTSPOT_JTREG_NATIVE_SRC), \
OUTPUT_DIR := $(BUILD_HOTSPOT_JTREG_OUTPUT_DIR), \
))
build-test-hotspot-jtreg-native: $(BUILD_HOTSPOT_JTREG_LIBRARIES) $(BUILD_HOTSPOT_JTREG_EXECUTABLES)
################################################################################
# Targets for building test-image.
################################################################################
# Copy to hotspot jtreg test image
$(eval $(call SetupCopyFiles,COPY_HOTSPOT_JTREG_NATIVE, \
SRC := $(BUILD_HOTSPOT_JTREG_OUTPUT_DIR), \
DEST := $(TEST_IMAGE_DIR)/hotspot/jtreg/native, \
FILES := $(BUILD_HOTSPOT_JTREG_LIBRARIES) $(BUILD_HOTSPOT_JTREG_EXECUTABLES), \
FLATTEN := true))
test-image-hotspot-jtreg-native: $(COPY_HOTSPOT_JTREG_NATIVE)
all: build-test-hotspot-jtreg-native
test-image: test-image-hotspot-jtreg-native
.PHONY: default all build-test-hotspot-jtreg-native test-image-hotspot-jtreg-native test-image

View File

@ -1,5 +1,5 @@
# #
# Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved. # Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# #
# This code is free software; you can redistribute it and/or modify it # This code is free software; you can redistribute it and/or modify it
@ -148,6 +148,19 @@ ifdef JAVA_ARGS
JAVA_OPTIONS = $(JAVA_ARGS) JAVA_OPTIONS = $(JAVA_ARGS)
endif endif
# jtreg -nativepath <dir>
#
# Local make tests will be TEST_IMAGE_DIR and JPRT with jprt.use.reg.test.bundle=true
# should be JPRT_TESTNATIVE_PATH
ifdef TEST_IMAGE_DIR
TESTNATIVE_DIR = $(TEST_IMAGE_DIR)
else ifdef JPRT_TESTNATIVE_PATH
TESTNATIVE_DIR = $(JPRT_TESTNATIVE_PATH)
endif
ifdef TESTNATIVE_DIR
JTREG_NATIVE_PATH = -nativepath:$(shell $(GETMIXEDPATH) "$(TESTNATIVE_DIR)/hotspot/jtreg/native")
endif
# Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results) # Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results)
ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip
ifdef JPRT_ARCHIVE_BUNDLE ifdef JPRT_ARCHIVE_BUNDLE
@ -303,6 +316,7 @@ jtreg_tests: prep $(PRODUCT_HOME) $(JTREG)
-r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport") \ -r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport") \
-w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTwork") \ -w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTwork") \
-jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)") \ -jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)") \
$(JTREG_NATIVE_PATH) \
$(JTREG_EXCLUSIONS) \ $(JTREG_EXCLUSIONS) \
$(JTREG_TEST_OPTIONS) \ $(JTREG_TEST_OPTIONS) \
$(TEST_SELECTION) \ $(TEST_SELECTION) \

View File

@ -332,6 +332,9 @@ applicable_cmsgc = \
hotspot_wbapitest = \ hotspot_wbapitest = \
sanity/ sanity/
hotspot_native_sanity = \
native_sanity
hotspot_compiler_1 = \ hotspot_compiler_1 = \
compiler/arraycopy/ \ compiler/arraycopy/ \
compiler/c1/ \ compiler/c1/ \

View File

@ -0,0 +1,41 @@
/*
* Copyright (c) 2015, 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
* @run main/native JniVersion
*/
public class JniVersion {
public static final int JNI_VERSION_1_8 = 0x00010008;
public static void main(String... args) throws Exception {
System.loadLibrary("JniVersion");
int res = getJniVersion();
if (res < JNI_VERSION_1_8) {
throw new Exception("Unexpected value returned from getJniVersion(): 0x" + Integer.toHexString(res));
}
}
static native int getJniVersion();
}

View File

@ -0,0 +1,29 @@
/*
* Copyright (c) 2015, 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.
*/
#include <jni.h>
JNIEXPORT jint JNICALL
Java_JniVersion_getJniVersion(JNIEnv *env, jclass clz) {
return (*env)->GetVersion(env);
}

View File

@ -294,3 +294,4 @@ e391de88e69b59d7c618387e3cf91032f6991ce9 jdk9-b47
786058752e0ac3e48d7aef79e0885d29d6a2a7eb jdk9-b49 786058752e0ac3e48d7aef79e0885d29d6a2a7eb jdk9-b49
74ead7bddde19263fd463bc1bd87de84f27d1b5e jdk9-b50 74ead7bddde19263fd463bc1bd87de84f27d1b5e jdk9-b50
7cb3674cbd8c06222851444285bb66b2952a2a5c jdk9-b51 7cb3674cbd8c06222851444285bb66b2952a2a5c jdk9-b51
57b26c883d54f45912bc3885ccad3c6b80960b1f jdk9-b52

View File

@ -297,3 +297,4 @@ e529374fbe526dbd668e5e98fc047b42b3bc6d33 jdk9-b45
435a49db1de0589acc86b2cc5fd61d546f94b56c jdk9-b49 435a49db1de0589acc86b2cc5fd61d546f94b56c jdk9-b49
45a30e7ee623031a1532685512dd2c2d8e8fa0ad jdk9-b50 45a30e7ee623031a1532685512dd2c2d8e8fa0ad jdk9-b50
bb9cf97a5ac6aa1aa2a1034676d64413071f58ea jdk9-b51 bb9cf97a5ac6aa1aa2a1034676d64413071f58ea jdk9-b51
1d1e7704eca9c77ebe6a8705d17ac568801f7a3b jdk9-b52

View File

@ -30,6 +30,8 @@ import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.lang.reflect.Modifier; import java.lang.reflect.Modifier;
import java.lang.ref.WeakReference; import java.lang.ref.WeakReference;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.Map; import java.util.Map;
import java.util.WeakHashMap; import java.util.WeakHashMap;
import java.util.logging.Level; import java.util.logging.Level;
@ -85,19 +87,25 @@ public final class ClassFactory {
if(consRef!=null) if(consRef!=null)
cons = consRef.get(); cons = consRef.get();
if(cons==null) { if(cons==null) {
cons = AccessController.doPrivileged(new PrivilegedAction<Constructor<T>>() {
@Override
public Constructor<T> run() {
try { try {
cons = clazz.getDeclaredConstructor(emptyClass); return clazz.getDeclaredConstructor(emptyClass);
} catch (NoSuchMethodException e) { } catch (NoSuchMethodException e) {
logger.log(Level.INFO,"No default constructor found on "+clazz,e); logger.log(Level.INFO,"No default constructor found on "+clazz,e);
NoSuchMethodError exp; NoSuchMethodError exp;
if(clazz.getDeclaringClass()!=null && !Modifier.isStatic(clazz.getModifiers())) { if(clazz.getDeclaringClass()!=null && !Modifier.isStatic(clazz.getModifiers())) {
exp = new NoSuchMethodError(Messages.NO_DEFAULT_CONSTRUCTOR_IN_INNER_CLASS.format(clazz.getName())); exp = new NoSuchMethodError(Messages.NO_DEFAULT_CONSTRUCTOR_IN_INNER_CLASS
.format(clazz.getName()));
} else { } else {
exp = new NoSuchMethodError(e.getMessage()); exp = new NoSuchMethodError(e.getMessage());
} }
exp.initCause(e); exp.initCause(e);
throw exp; throw exp;
} }
}
});
int classMod = clazz.getModifiers(); int classMod = clazz.getModifiers();

View File

@ -36,9 +36,6 @@ import com.sun.xml.internal.bind.marshaller.SAX2DOMEx;
//TODO DOMHeader DOMMessage SAAJMessage StatefulInstanceResolver //TODO DOMHeader DOMMessage SAAJMessage StatefulInstanceResolver
import com.sun.xml.internal.bind.unmarshaller.DOMScanner; import com.sun.xml.internal.bind.unmarshaller.DOMScanner;
//TODO MtomCodec
import com.sun.xml.internal.bind.v2.runtime.output.Encoded;
//TODO ExceptionBean //TODO ExceptionBean
import com.sun.xml.internal.bind.marshaller.NamespacePrefixMapper; import com.sun.xml.internal.bind.marshaller.NamespacePrefixMapper;

View File

@ -25,8 +25,6 @@
package com.sun.tools.internal.ws.wsdl.document.soap; package com.sun.tools.internal.ws.wsdl.document.soap;
import com.sun.xml.internal.ws.encoding.soap.streaming.SOAPNamespaceConstants;
import javax.xml.namespace.QName; import javax.xml.namespace.QName;
/** /**
@ -37,7 +35,9 @@ import javax.xml.namespace.QName;
public interface SOAPConstants { public interface SOAPConstants {
// namespace URIs // namespace URIs
public static final String URI_ENVELOPE = SOAPNamespaceConstants.ENVELOPE; public static final String URI_ENVELOPE =
"http://schemas.xmlsoap.org/soap/envelope/";
public static final String NS_WSDL_SOAP = public static final String NS_WSDL_SOAP =
"http://schemas.xmlsoap.org/wsdl/soap/"; "http://schemas.xmlsoap.org/wsdl/soap/";
public static final String NS_SOAP_ENCODING = "http://schemas.xmlsoap.org/soap/encoding/"; public static final String NS_SOAP_ENCODING = "http://schemas.xmlsoap.org/soap/encoding/";

View File

@ -294,3 +294,4 @@ ebb2eb7f1aec78eb6d8cc4c96f018afa11093cde jdk9-b48
541a8cef4e0d54c3e4b52a98c6af3c31e2096669 jdk9-b49 541a8cef4e0d54c3e4b52a98c6af3c31e2096669 jdk9-b49
f6b8edd397ee463be208fee27517c99101293267 jdk9-b50 f6b8edd397ee463be208fee27517c99101293267 jdk9-b50
a0dad230aeb3b0d5cfd5b0715029e48d50573f8c jdk9-b51 a0dad230aeb3b0d5cfd5b0715029e48d50573f8c jdk9-b51
607ea68032cd4a4cf2c7a7a41fcb39602d6a75e2 jdk9-b52

View File

@ -0,0 +1 @@
0x15 U+0085

View File

@ -0,0 +1,256 @@
0x00 U+0000
0x01 U+0001
0x02 U+0002
0x03 U+0003
0x04 U+009c
0x05 U+0009
0x06 U+0086
0x07 U+007f
0x08 U+0097
0x09 U+008d
0x0a U+008e
0x0b U+000b
0x0c U+000c
0x0d U+000d
0x0e U+000e
0x0f U+000f
0x10 U+0010
0x11 U+0011
0x12 U+0012
0x13 U+0013
0x14 U+009d
0x15 U+000a
0x16 U+0008
0x17 U+0087
0x18 U+0018
0x19 U+0019
0x1a U+0092
0x1b U+008f
0x1c U+001c
0x1d U+001d
0x1e U+001e
0x1f U+001f
0x20 U+0080
0x21 U+0081
0x22 U+0082
0x23 U+0083
0x24 U+0084
0x25 U+000a
0x26 U+0017
0x27 U+001b
0x28 U+0088
0x29 U+0089
0x2a U+008a
0x2b U+008b
0x2c U+008c
0x2d U+0005
0x2e U+0006
0x2f U+0007
0x30 U+0090
0x31 U+0091
0x32 U+0016
0x33 U+0093
0x34 U+0094
0x35 U+0095
0x36 U+0096
0x37 U+0004
0x38 U+0098
0x39 U+0099
0x3a U+009a
0x3b U+009b
0x3c U+0014
0x3d U+0015
0x3e U+009e
0x3f U+001a
0x40 U+0020
0x41 U+00a0
0x42 U+04d9
0x43 U+0493
0x44 U+0451
0x45 U+0454
0x46 U+0455
0x47 U+0456
0x48 U+049b
0x49 U+0458
0x4a U+005b
0x4b U+002e
0x4c U+003c
0x4d U+0028
0x4e U+002b
0x4f U+0021
0x50 U+0026
0x51 U+04a3
0x52 U+04e9
0x53 U+04b1
0x54 U+04af
0x55 U+045e
0x56 U+04bb
0x57 U+042a
0x58 U+2116
0x59 U+04d8
0x5a U+005d
0x5b U+0024
0x5c U+002a
0x5d U+0029
0x5e U+003b
0x5f U+005e
0x60 U+002d
0x61 U+002f
0x62 U+0492
0x63 U+0401
0x64 U+0404
0x65 U+0405
0x66 U+0406
0x67 U+049a
0x68 U+0408
0x69 U+04a2
0x6a U+007c
0x6b U+002c
0x6c U+0025
0x6d U+005f
0x6e U+003e
0x6f U+003f
0x70 U+04e8
0x71 U+04b0
0x72 U+04ae
0x73 U+00ad
0x74 U+040e
0x75 U+04ba
0x76 U+044e
0x77 U+0430
0x78 U+0431
0x79 U+0060
0x7a U+003a
0x7b U+0023
0x7c U+0040
0x7d U+0027
0x7e U+003d
0x7f U+0022
0x80 U+0446
0x81 U+0061
0x82 U+0062
0x83 U+0063
0x84 U+0064
0x85 U+0065
0x86 U+0066
0x87 U+0067
0x88 U+0068
0x89 U+0069
0x8a U+0434
0x8b U+0435
0x8c U+0444
0x8d U+0433
0x8e U+0445
0x8f U+0438
0x90 U+0439
0x91 U+006a
0x92 U+006b
0x93 U+006c
0x94 U+006d
0x95 U+006e
0x96 U+006f
0x97 U+0070
0x98 U+0071
0x99 U+0072
0x9a U+043a
0x9b U+043b
0x9c U+043c
0x9d U+043d
0x9e U+043e
0x9f U+043f
0xa0 U+044f
0xa1 U+007e
0xa2 U+0073
0xa3 U+0074
0xa4 U+0075
0xa5 U+0076
0xa6 U+0077
0xa7 U+0078
0xa8 U+0079
0xa9 U+007a
0xaa U+0440
0xab U+0441
0xac U+0442
0xad U+0443
0xae U+0436
0xaf U+0432
0xb0 U+044c
0xb1 U+044b
0xb2 U+0437
0xb3 U+0448
0xb4 U+044d
0xb5 U+0449
0xb6 U+0447
0xb7 U+044a
0xb8 U+042e
0xb9 U+0410
0xba U+0411
0xbb U+0426
0xbc U+0414
0xbd U+0415
0xbe U+0424
0xbf U+0413
0xc0 U+007b
0xc1 U+0041
0xc2 U+0042
0xc3 U+0043
0xc4 U+0044
0xc5 U+0045
0xc6 U+0046
0xc7 U+0047
0xc8 U+0048
0xc9 U+0049
0xca U+0425
0xcb U+0418
0xcc U+0419
0xcd U+041a
0xce U+041b
0xcf U+041c
0xd0 U+007d
0xd1 U+004a
0xd2 U+004b
0xd3 U+004c
0xd4 U+004d
0xd5 U+004e
0xd6 U+004f
0xd7 U+0050
0xd8 U+0051
0xd9 U+0052
0xda U+041d
0xdb U+041e
0xdc U+041f
0xdd U+042f
0xde U+0420
0xdf U+0421
0xe0 U+005c
0xe1 U+20ac
0xe2 U+0053
0xe3 U+0054
0xe4 U+0055
0xe5 U+0056
0xe6 U+0057
0xe7 U+0058
0xe8 U+0059
0xe9 U+005a
0xea U+0422
0xeb U+0423
0xec U+0416
0xed U+0412
0xee U+042c
0xef U+042b
0xf0 U+0030
0xf1 U+0031
0xf2 U+0032
0xf3 U+0033
0xf4 U+0034
0xf5 U+0035
0xf6 U+0036
0xf7 U+0037
0xf8 U+0038
0xf9 U+0039
0xfa U+0417
0xfb U+0428
0xfc U+042d
0xfd U+0429
0xfe U+0427
0xff U+009f

View File

@ -0,0 +1 @@
0x25 U+000a

View File

@ -503,7 +503,7 @@ charset x-windows-874 MS874
charset x-EUC-TW EUC_TW charset x-EUC-TW EUC_TW
package sun.nio.cs.ext package sun.nio.cs.ext
type source type template
alias euc_tw # JDK historical alias euc_tw # JDK historical
alias euctw alias euctw
alias cns11643 alias cns11643
@ -1660,6 +1660,16 @@ charset IBM290 IBM290
alias EBCDIC-JP-kana alias EBCDIC-JP-kana
alias 290 alias 290
charset x-IBM1166 IBM1166
package sun.nio.cs.ext
type sbcs
hisname Cp1166
ascii false
alias cp1166
alias ibm1166
alias ibm-1166
alias 1166
charset x-IBM300 IBM300 charset x-IBM300 IBM300
package sun.nio.cs.ext package sun.nio.cs.ext
type dbcsonly type dbcsonly
@ -1816,3 +1826,17 @@ charset x-JIS0212_MS5022X JIS_X_0212_MS5022X
ascii false ascii false
minmax 0x21 0x7e 0x21 0x7e minmax 0x21 0x7e 0x21 0x7e
internal true # "internal implementation internal true # "internal implementation
########################################################
#
# platform specific charsets, to be registered into spi
##
########################################################
charset x-COMPOUND_TEXT COMPOUND_TEXT
package sun.nio.cs.ext
type source
os unix
alias COMPOUND_TEXT # JDK historical
alias x11-compound_text
alias x-compound-text

View File

@ -57,6 +57,7 @@ IBM1146 IBM01146 Cp1146 false sun.nio.cs.ext
IBM1147 IBM01147 Cp1147 false sun.nio.cs.ext IBM1147 IBM01147 Cp1147 false sun.nio.cs.ext
IBM1148 IBM01148 Cp1148 false sun.nio.cs.ext IBM1148 IBM01148 Cp1148 false sun.nio.cs.ext
IBM1149 IBM01149 Cp1149 false sun.nio.cs.ext IBM1149 IBM01149 Cp1149 false sun.nio.cs.ext
IBM1166 x-IBM1166 Cp1166 false sun.nio.cs.ext
IBM273 IBM273 Cp273 false sun.nio.cs.ext IBM273 IBM273 Cp273 false sun.nio.cs.ext
IBM277 IBM277 Cp277 false sun.nio.cs.ext IBM277 IBM277 Cp277 false sun.nio.cs.ext
IBM278 IBM278 Cp278 false sun.nio.cs.ext IBM278 IBM278 Cp278 false sun.nio.cs.ext

View File

@ -9,6 +9,7 @@ EUC_KR
EUC_JP EUC_JP
EUC_JP_LINUX EUC_JP_LINUX
EUC_JP_Open EUC_JP_Open
EUC_TW
GBK GBK
ISO_8859_11 ISO_8859_11
ISO_8859_3 ISO_8859_3

View File

@ -50,7 +50,9 @@ $(CHARSET_DONE_CS)-extcs: $(CHARSET_DATA_DIR)/charsets \
$(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_CS) \ $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_CS) \
extcs charsets $(CHARSET_STANDARD_OS) \ extcs charsets $(CHARSET_STANDARD_OS) \
$(CHARSET_EXTENDED_JAVA_TEMPLATES) \ $(CHARSET_EXTENDED_JAVA_TEMPLATES) \
$(CHARSET_EXTENDED_JAVA_DIR) $(LOG_INFO) $(CHARSET_EXTENDED_JAVA_DIR) \
$(CHARSET_COPYRIGHT_HEADER) \
$(LOG_INFO)
$(TOUCH) '$@' $(TOUCH) '$@'
$(CHARSET_DONE_CS)-hkscs: $(CHARSET_COPYRIGHT_HEADER)/HKSCS.java \ $(CHARSET_DONE_CS)-hkscs: $(CHARSET_COPYRIGHT_HEADER)/HKSCS.java \

View File

@ -32,6 +32,7 @@ CHARSET_DATA_DIR := $(JDK_TOPDIR)/make/data/charsetmapping
CHARSET_EXTSRC_DIR := $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext CHARSET_EXTSRC_DIR := $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext
CHARSET_GENSRC_JAVA_DIR_BASE := $(SUPPORT_OUTPUTDIR)/gensrc/java.base/sun/nio/cs CHARSET_GENSRC_JAVA_DIR_BASE := $(SUPPORT_OUTPUTDIR)/gensrc/java.base/sun/nio/cs
CHARSET_DONE_BASE := $(CHARSET_GENSRC_JAVA_DIR_BASE)/_the.charsetmapping CHARSET_DONE_BASE := $(CHARSET_GENSRC_JAVA_DIR_BASE)/_the.charsetmapping
CHARSET_COPYRIGHT_HEADER := $(JDK_TOPDIR)/make/src/classes/build/tools/charsetmapping
CHARSET_TEMPLATES := \ CHARSET_TEMPLATES := \
$(CHARSET_DATA_DIR)/SingleByte-X.java.template \ $(CHARSET_DATA_DIR)/SingleByte-X.java.template \
$(CHARSET_DATA_DIR)/DoubleByte-X.java.template $(CHARSET_DATA_DIR)/DoubleByte-X.java.template
@ -46,7 +47,9 @@ $(CHARSET_DONE_BASE)-stdcs: $(CHARSET_DATA_DIR)/charsets \
$(MKDIR) -p $(@D) $(MKDIR) -p $(@D)
$(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_BASE) \ $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_BASE) \
stdcs charsets $(CHARSET_STANDARD_OS) \ stdcs charsets $(CHARSET_STANDARD_OS) \
$(CHARSET_STANDARD_JAVA_TEMPLATES) $(CHARSET_EXTSRC_DIR) $(LOG_INFO) $(CHARSET_STANDARD_JAVA_TEMPLATES) $(CHARSET_EXTSRC_DIR) \
$(CHARSET_COPYRIGHT_HEADER) \
$(LOG_INFO)
$(TOUCH) '$@' $(TOUCH) '$@'
GENSRC_JAVA_BASE += $(CHARSET_DONE_BASE)-stdcs GENSRC_JAVA_BASE += $(CHARSET_DONE_BASE)-stdcs

View File

@ -53,15 +53,21 @@ endef
# Param 1 - Variable to add targets to, must not contain space # Param 1 - Variable to add targets to, must not contain space
# Param 2 - Properties files to process # Param 2 - Properties files to process
# Param 3 - The super class for the generated classes # Param 3 - The super class for the generated classes
# Param 4 - Module path root, defaults to $(JDK_TOPDIR)/src
define SetupCompileProperties define SetupCompileProperties
$1_SRCS := $2 $1_SRCS := $2
$1_CLASS := $3 $1_CLASS := $3
$1_MODULE_PATH_ROOT := $4
ifeq ($$($1_MODULE_PATH_ROOT), )
$1_MODULE_PATH_ROOT := $(JDK_TOPDIR)/src
endif
# Convert .../src/<module>/share/classes/com/sun/tools/javac/resources/javac_zh_CN.properties # Convert .../src/<module>/share/classes/com/sun/tools/javac/resources/javac_zh_CN.properties
# to .../support/gensrc/<module>/com/sun/tools/javac/resources/javac_zh_CN.java # to .../support/gensrc/<module>/com/sun/tools/javac/resources/javac_zh_CN.java
# Strip away prefix and suffix, leaving for example only: # Strip away prefix and suffix, leaving for example only:
# "<module>/share/classes/com/sun/tools/javac/resources/javac_zh_CN" # "<module>/share/classes/com/sun/tools/javac/resources/javac_zh_CN"
$1_JAVAS := $$(patsubst $(JDK_TOPDIR)/src/%, \ $1_JAVAS := $$(patsubst $$($1_MODULE_PATH_ROOT)/%, \
$(SUPPORT_OUTPUTDIR)/gensrc/%, \ $(SUPPORT_OUTPUTDIR)/gensrc/%, \
$$(patsubst %.properties, %.java, \ $$(patsubst %.properties, %.java, \
$$(subst /$(OPENJDK_TARGET_OS)/classes,, \ $$(subst /$(OPENJDK_TARGET_OS)/classes,, \

View File

@ -31,6 +31,7 @@ class Charset {
String csName; String csName;
String hisName; String hisName;
String type; String type;
String os;
boolean isASCII; boolean isASCII;
int b1Min; int b1Min;
int b1Max; int b1Max;

View File

@ -80,12 +80,12 @@ public class EUC_TW {
private static Pattern euctw = Pattern.compile("(?:8ea)?(\\p{XDigit}++)\\s++(\\p{XDigit}++)?\\s*+.*"); private static Pattern euctw = Pattern.compile("(?:8ea)?(\\p{XDigit}++)\\s++(\\p{XDigit}++)?\\s*+.*");
static void genClass(String args[]) throws Exception static void genClass(String pkg, String args[]) throws Exception
{ {
InputStream is = new FileInputStream(new File(args[0], "euc_tw.map")); InputStream is = new FileInputStream(new File(args[0], "euc_tw.map"));
PrintStream ps = new PrintStream(new File(args[1], "EUC_TWMapping.java"), PrintStream ps = new PrintStream(new File(args[1], "EUC_TWMapping.java"),
"ISO-8859-1"); "ISO-8859-1");
String copyright = getCopyright(new File(args[3])); String copyright = getCopyright(new File(args[7], "EUC_TW.java"));
// ranges of byte1 and byte2, something should come from a "config" file // ranges of byte1 and byte2, something should come from a "config" file
@ -128,7 +128,7 @@ public class EUC_TW {
out.format(copyright); out.format(copyright);
out.format("%n// -- This file was mechanically generated: Do not edit! -- //%n"); out.format("%n// -- This file was mechanically generated: Do not edit! -- //%n");
out.format("package sun.nio.cs.ext;%n%n"); out.format("package %s;%n%n", pkg);
out.format("class EUC_TWMapping {%n%n"); out.format("class EUC_TWMapping {%n%n");
// boundaries // boundaries

View File

@ -42,7 +42,7 @@ public class HKSCS {
private static Pattern hkscs = private static Pattern hkscs =
Pattern.compile("(?:0x)?+(\\p{XDigit}++)\\s++(?:0x|U\\+)?+(\\p{XDigit}++)?\\s*+(?:0x|U\\+)?(\\p{XDigit}++)?\\s*+.*"); Pattern.compile("(?:0x)?+(\\p{XDigit}++)\\s++(?:0x|U\\+)?+(\\p{XDigit}++)?\\s*+(?:0x|U\\+)?(\\p{XDigit}++)?\\s*+.*");
static void genClass2008(String srcDir, String dstDir, String pkgName) static void genClass2008(String srcDir, String dstDir, String pkgName, File copyright)
throws Exception throws Exception
{ {
// hkscs2008 // hkscs2008
@ -53,10 +53,11 @@ public class HKSCS {
pkgName, pkgName,
"HKSCSMapping", "HKSCSMapping",
true, true,
""); getCopyright(copyright));
} }
static void genClassXP(String srcDir, String dstDir, String pkgName) static void genClassXP(String srcDir, String dstDir, String pkgName, File copyright)
throws Exception throws Exception
{ {
genClass0(new FileInputStream(new File(srcDir, "HKSCS_XP.map")), genClass0(new FileInputStream(new File(srcDir, "HKSCS_XP.map")),
@ -66,7 +67,7 @@ public class HKSCS {
pkgName, pkgName,
"HKSCS_XPMapping", "HKSCS_XPMapping",
false, false,
""); getCopyright(copyright));
} }
static void genClass2001(String args[]) throws Exception { static void genClass2001(String args[]) throws Exception {

View File

@ -41,6 +41,7 @@ public class Main {
int OS = 4; int OS = 4;
int TEMPLATE = 5; int TEMPLATE = 5;
int EXT_SRC = 6; int EXT_SRC = 6;
int COPYRIGHT_SRC = 7;
if (args.length < 3 ) { if (args.length < 3 ) {
System.out.println("Usage: java -jar charsetmapping.jar src dst spiType charsets os [template]"); System.out.println("Usage: java -jar charsetmapping.jar src dst spiType charsets os [template]");
@ -54,6 +55,7 @@ public class Main {
String[] osStdcs = getOSStdCSList(new File(args[SRC_DIR], args[OS])); String[] osStdcs = getOSStdCSList(new File(args[SRC_DIR], args[OS]));
boolean hasBig5_HKSCS = false; boolean hasBig5_HKSCS = false;
boolean hasMS950_HKSCS_XP = false; boolean hasMS950_HKSCS_XP = false;
boolean hasEUC_TW = false;
for (String name : osStdcs) { for (String name : osStdcs) {
Charset cs = charsets.get(name); Charset cs = charsets.get(name);
if (cs != null) { if (cs != null) {
@ -63,6 +65,8 @@ public class Main {
hasBig5_HKSCS = true; hasBig5_HKSCS = true;
} else if (name.equals("MS950_HKSCS_XP")) { } else if (name.equals("MS950_HKSCS_XP")) {
hasMS950_HKSCS_XP = true; hasMS950_HKSCS_XP = true;
} else if (name.equals("EUC_TW")) {
hasEUC_TW = true;
} }
} }
for (Charset cs : charsets.values()) { for (Charset cs : charsets.values()) {
@ -89,19 +93,28 @@ public class Main {
} }
} }
// provider StandardCharsets.java / ExtendedCharsets.java // provider StandardCharsets.java / ExtendedCharsets.java
SPI.genClass(args[TYPE], charsets, args[SRC_DIR], args[DST_DIR], args[TEMPLATE]); SPI.genClass(args[TYPE], charsets,
args[SRC_DIR], args[DST_DIR],
args[TEMPLATE],
args[OS].endsWith("windows") ? "windows" : "unix");
// HKSCSMapping2008/XP.java goes together with Big5/MS950XP_HKSCS // HKSCSMapping2008/XP.java goes together with Big5/MS950XP_HKSCS
if (isStandard && hasBig5_HKSCS || isExtended && !hasBig5_HKSCS) { if (isStandard && hasBig5_HKSCS || isExtended && !hasBig5_HKSCS) {
HKSCS.genClass2008(args[SRC_DIR], args[DST_DIR], HKSCS.genClass2008(args[SRC_DIR], args[DST_DIR],
isStandard ? "sun.nio.cs" : "sun.nio.cs.ext"); isStandard ? "sun.nio.cs" : "sun.nio.cs.ext",
new File(args[COPYRIGHT_SRC], "HKSCS.java"));
} }
if (isStandard && hasMS950_HKSCS_XP || isExtended && !hasMS950_HKSCS_XP) { if (isStandard && hasMS950_HKSCS_XP || isExtended && !hasMS950_HKSCS_XP) {
HKSCS.genClassXP(args[SRC_DIR], args[DST_DIR], HKSCS.genClassXP(args[SRC_DIR], args[DST_DIR],
isStandard ? "sun.nio.cs" : "sun.nio.cs.ext"); isStandard ? "sun.nio.cs" : "sun.nio.cs.ext",
new File(args[COPYRIGHT_SRC], "HKSCS.java"));
}
if (isStandard && hasEUC_TW) {
EUC_TW.genClass("sun.nio.cs", args);
}
if (!isStandard && !hasEUC_TW) {
EUC_TW.genClass("sun.nio.cs.ext", args);
} }
} else if ("euctw".equals(args[TYPE])) {
EUC_TW.genClass(args);
} else if ("sjis0213".equals(args[TYPE])) { } else if ("sjis0213".equals(args[TYPE])) {
JIS0213.genClass(args); JIS0213.genClass(args);
} else if ("hkscs".equals(args[TYPE])) { } else if ("hkscs".equals(args[TYPE])) {
@ -157,6 +170,9 @@ public class Main {
case "type": case "type":
cs.type = tokens[2]; cs.type = tokens[2];
break; break;
case "os":
cs.os = tokens[2];
break;
case "hisname": case "hisname":
cs.hisName = tokens[2]; cs.hisName = tokens[2];
break; break;

View File

@ -33,8 +33,10 @@ import java.util.Scanner;
public class SPI { public class SPI {
public static void genClass(String type, LinkedHashMap<String, Charset> charsets, public static void genClass(String type,
String srcDir, String dstDir, String template) LinkedHashMap<String, Charset> charsets,
String srcDir, String dstDir, String template,
String os)
throws Exception throws Exception
{ {
try (Scanner s = new Scanner(new File(template)); try (Scanner s = new Scanner(new File(template));
@ -50,7 +52,8 @@ public class SPI {
charsets.values() charsets.values()
.stream() .stream()
.filter(cs -> cs.pkgName.equals("sun.nio.cs.ext") && .filter(cs -> cs.pkgName.equals("sun.nio.cs.ext") &&
!cs.isInternal) !cs.isInternal &&
(cs.os == null || cs.os.equals(os)))
.forEach( cs -> { .forEach( cs -> {
out.printf(" charset(\"%s\", \"%s\",%n", cs.csName, cs.clzName); out.printf(" charset(\"%s\", \"%s\",%n", cs.csName, cs.clzName);
out.printf(" new String[] {%n"); out.printf(" new String[] {%n");

View File

@ -1063,16 +1063,24 @@ public final class Class<T> implements java.io.Serializable,
parameterClasses[i] = toClass(parameterTypes[i]); parameterClasses[i] = toClass(parameterTypes[i]);
// Perform access check // Perform access check
Class<?> enclosingCandidate = enclosingInfo.getEnclosingClass(); final Class<?> enclosingCandidate = enclosingInfo.getEnclosingClass();
enclosingCandidate.checkMemberAccess(Member.DECLARED, enclosingCandidate.checkMemberAccess(Member.DECLARED,
Reflection.getCallerClass(), true); Reflection.getCallerClass(), true);
// Client is ok to access declared methods but j.l.Class might not be.
Method[] candidates = AccessController.doPrivileged(
new PrivilegedAction<Method[]>() {
@Override
public Method[] run() {
return enclosingCandidate.getDeclaredMethods();
}
});
/* /*
* Loop over all declared methods; match method name, * Loop over all declared methods; match method name,
* number of and type of parameters, *and* return * number of and type of parameters, *and* return
* type. Matching return type is also necessary * type. Matching return type is also necessary
* because of covariant returns, etc. * because of covariant returns, etc.
*/ */
for(Method m: enclosingCandidate.getDeclaredMethods()) { for(Method m: candidates) {
if (m.getName().equals(enclosingInfo.getName()) ) { if (m.getName().equals(enclosingInfo.getName()) ) {
Class<?>[] candidateParamClasses = m.getParameterTypes(); Class<?>[] candidateParamClasses = m.getParameterTypes();
if (candidateParamClasses.length == parameterClasses.length) { if (candidateParamClasses.length == parameterClasses.length) {
@ -1215,14 +1223,22 @@ public final class Class<T> implements java.io.Serializable,
parameterClasses[i] = toClass(parameterTypes[i]); parameterClasses[i] = toClass(parameterTypes[i]);
// Perform access check // Perform access check
Class<?> enclosingCandidate = enclosingInfo.getEnclosingClass(); final Class<?> enclosingCandidate = enclosingInfo.getEnclosingClass();
enclosingCandidate.checkMemberAccess(Member.DECLARED, enclosingCandidate.checkMemberAccess(Member.DECLARED,
Reflection.getCallerClass(), true); Reflection.getCallerClass(), true);
// Client is ok to access declared methods but j.l.Class might not be.
Constructor<?>[] candidates = AccessController.doPrivileged(
new PrivilegedAction<Constructor<?>[]>() {
@Override
public Constructor<?>[] run() {
return enclosingCandidate.getDeclaredConstructors();
}
});
/* /*
* Loop over all declared constructors; match number * Loop over all declared constructors; match number
* of and type of parameters. * of and type of parameters.
*/ */
for(Constructor<?> c: enclosingCandidate.getDeclaredConstructors()) { for(Constructor<?> c: candidates) {
Class<?>[] candidateParamClasses = c.getParameterTypes(); Class<?>[] candidateParamClasses = c.getParameterTypes();
if (candidateParamClasses.length == parameterClasses.length) { if (candidateParamClasses.length == parameterClasses.length) {
boolean matches = true; boolean matches = true;

View File

@ -35,6 +35,7 @@ import static java.lang.invoke.MethodTypeForm.*;
import static java.lang.invoke.MethodHandleStatics.*; import static java.lang.invoke.MethodHandleStatics.*;
import java.lang.ref.WeakReference; import java.lang.ref.WeakReference;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import java.util.Objects;
import sun.invoke.util.ValueConversions; import sun.invoke.util.ValueConversions;
import sun.invoke.util.VerifyType; import sun.invoke.util.VerifyType;
import sun.invoke.util.Wrapper; import sun.invoke.util.Wrapper;
@ -439,8 +440,7 @@ class DirectMethodHandle extends MethodHandle {
// Therefore, the only remaining check is for null. // Therefore, the only remaining check is for null.
// Since this check is *not* guaranteed by Unsafe.getInt // Since this check is *not* guaranteed by Unsafe.getInt
// and its siblings, we need to make an explicit one here. // and its siblings, we need to make an explicit one here.
obj.getClass(); // maybe throw NPE return Objects.requireNonNull(obj);
return obj;
} }
/** This subclass handles static field references. */ /** This subclass handles static field references. */
@ -468,8 +468,7 @@ class DirectMethodHandle extends MethodHandle {
@ForceInline @ForceInline
/*non-public*/ static Object nullCheck(Object obj) { /*non-public*/ static Object nullCheck(Object obj) {
obj.getClass(); return Objects.requireNonNull(obj);
return obj;
} }
@ForceInline @ForceInline

View File

@ -521,7 +521,7 @@ import java.util.Objects;
} }
@SuppressWarnings("LeakingThisInConstructor") @SuppressWarnings("LeakingThisInConstructor")
public MemberName(Method m, boolean wantSpecial) { public MemberName(Method m, boolean wantSpecial) {
m.getClass(); // NPE check Objects.requireNonNull(m);
// fill in vmtarget, vmindex while we have m in hand: // fill in vmtarget, vmindex while we have m in hand:
MethodHandleNatives.init(this, m); MethodHandleNatives.init(this, m);
if (clazz == null) { // MHN.init failed if (clazz == null) { // MHN.init failed
@ -600,7 +600,7 @@ import java.util.Objects;
/** Create a name for the given reflected constructor. The resulting name will be in a resolved state. */ /** Create a name for the given reflected constructor. The resulting name will be in a resolved state. */
@SuppressWarnings("LeakingThisInConstructor") @SuppressWarnings("LeakingThisInConstructor")
public MemberName(Constructor<?> ctor) { public MemberName(Constructor<?> ctor) {
ctor.getClass(); // NPE check Objects.requireNonNull(ctor);
// fill in vmtarget, vmindex while we have ctor in hand: // fill in vmtarget, vmindex while we have ctor in hand:
MethodHandleNatives.init(this, ctor); MethodHandleNatives.init(this, ctor);
assert(isResolved() && this.clazz != null); assert(isResolved() && this.clazz != null);
@ -615,7 +615,7 @@ import java.util.Objects;
} }
@SuppressWarnings("LeakingThisInConstructor") @SuppressWarnings("LeakingThisInConstructor")
public MemberName(Field fld, boolean makeSetter) { public MemberName(Field fld, boolean makeSetter) {
fld.getClass(); // NPE check Objects.requireNonNull(fld);
// fill in vmtarget, vmindex while we have fld in hand: // fill in vmtarget, vmindex while we have fld in hand:
MethodHandleNatives.init(this, fld); MethodHandleNatives.init(this, fld);
assert(isResolved() && this.clazz != null); assert(isResolved() && this.clazz != null);

View File

@ -453,10 +453,8 @@ public abstract class MethodHandle {
*/ */
// @param type type (permanently assigned) of the new method handle // @param type type (permanently assigned) of the new method handle
/*non-public*/ MethodHandle(MethodType type, LambdaForm form) { /*non-public*/ MethodHandle(MethodType type, LambdaForm form) {
type.getClass(); // explicit NPE this.type = Objects.requireNonNull(type);
form.getClass(); // explicit NPE this.form = Objects.requireNonNull(form).uncustomize();
this.type = type;
this.form = form.uncustomize();
this.form.prepare(); // TO DO: Try to delay this step until just before invocation. this.form.prepare(); // TO DO: Try to delay this step until just before invocation.
} }
@ -1171,7 +1169,7 @@ assertEquals("[three, thee, tee]", Arrays.toString((Object[])ls.get(0)));
* @see #asFixedArity * @see #asFixedArity
*/ */
public MethodHandle asVarargsCollector(Class<?> arrayType) { public MethodHandle asVarargsCollector(Class<?> arrayType) {
arrayType.getClass(); // explicit NPE Objects.requireNonNull(arrayType);
boolean lastMatch = asCollectorChecks(arrayType, 0); boolean lastMatch = asCollectorChecks(arrayType, 0);
if (isVarargsCollector() && lastMatch) if (isVarargsCollector() && lastMatch)
return this; return this;

View File

@ -29,6 +29,7 @@ import java.lang.reflect.*;
import java.util.BitSet; import java.util.BitSet;
import java.util.List; import java.util.List;
import java.util.Arrays; import java.util.Arrays;
import java.util.Objects;
import sun.invoke.util.ValueConversions; import sun.invoke.util.ValueConversions;
import sun.invoke.util.VerifyAccess; import sun.invoke.util.VerifyAccess;
@ -632,7 +633,7 @@ public class MethodHandles {
* @throws NullPointerException if the argument is null * @throws NullPointerException if the argument is null
*/ */
public Lookup in(Class<?> requestedLookupClass) { public Lookup in(Class<?> requestedLookupClass) {
requestedLookupClass.getClass(); // null check Objects.requireNonNull(requestedLookupClass);
if (allowedModes == TRUSTED) // IMPL_LOOKUP can make any lookup at all if (allowedModes == TRUSTED) // IMPL_LOOKUP can make any lookup at all
return new Lookup(requestedLookupClass, ALL_MODES); return new Lookup(requestedLookupClass, ALL_MODES);
if (requestedLookupClass == this.lookupClass) if (requestedLookupClass == this.lookupClass)
@ -1367,16 +1368,16 @@ return mh1;
MemberName resolveOrFail(byte refKind, Class<?> refc, String name, Class<?> type) throws NoSuchFieldException, IllegalAccessException { MemberName resolveOrFail(byte refKind, Class<?> refc, String name, Class<?> type) throws NoSuchFieldException, IllegalAccessException {
checkSymbolicClass(refc); // do this before attempting to resolve checkSymbolicClass(refc); // do this before attempting to resolve
name.getClass(); // NPE Objects.requireNonNull(name);
type.getClass(); // NPE Objects.requireNonNull(type);
return IMPL_NAMES.resolveOrFail(refKind, new MemberName(refc, name, type, refKind), lookupClassOrNull(), return IMPL_NAMES.resolveOrFail(refKind, new MemberName(refc, name, type, refKind), lookupClassOrNull(),
NoSuchFieldException.class); NoSuchFieldException.class);
} }
MemberName resolveOrFail(byte refKind, Class<?> refc, String name, MethodType type) throws NoSuchMethodException, IllegalAccessException { MemberName resolveOrFail(byte refKind, Class<?> refc, String name, MethodType type) throws NoSuchMethodException, IllegalAccessException {
checkSymbolicClass(refc); // do this before attempting to resolve checkSymbolicClass(refc); // do this before attempting to resolve
name.getClass(); // NPE Objects.requireNonNull(name);
type.getClass(); // NPE Objects.requireNonNull(type);
checkMethodName(refKind, name); // NPE check on name checkMethodName(refKind, name); // NPE check on name
return IMPL_NAMES.resolveOrFail(refKind, new MemberName(refc, name, type, refKind), lookupClassOrNull(), return IMPL_NAMES.resolveOrFail(refKind, new MemberName(refc, name, type, refKind), lookupClassOrNull(),
NoSuchMethodException.class); NoSuchMethodException.class);
@ -1384,14 +1385,14 @@ return mh1;
MemberName resolveOrFail(byte refKind, MemberName member) throws ReflectiveOperationException { MemberName resolveOrFail(byte refKind, MemberName member) throws ReflectiveOperationException {
checkSymbolicClass(member.getDeclaringClass()); // do this before attempting to resolve checkSymbolicClass(member.getDeclaringClass()); // do this before attempting to resolve
member.getName().getClass(); // NPE Objects.requireNonNull(member.getName());
member.getType().getClass(); // NPE Objects.requireNonNull(member.getType());
return IMPL_NAMES.resolveOrFail(refKind, member, lookupClassOrNull(), return IMPL_NAMES.resolveOrFail(refKind, member, lookupClassOrNull(),
ReflectiveOperationException.class); ReflectiveOperationException.class);
} }
void checkSymbolicClass(Class<?> refc) throws IllegalAccessException { void checkSymbolicClass(Class<?> refc) throws IllegalAccessException {
refc.getClass(); // NPE Objects.requireNonNull(refc);
Class<?> caller = lookupClassOrNull(); Class<?> caller = lookupClassOrNull();
if (caller != null && !VerifyAccess.isClassAccessible(refc, caller, allowedModes)) if (caller != null && !VerifyAccess.isClassAccessible(refc, caller, allowedModes))
throw new MemberName(refc).makeAccessException("symbolic reference class is not public", this); throw new MemberName(refc).makeAccessException("symbolic reference class is not public", this);

View File

@ -25,6 +25,7 @@
package java.lang.invoke; package java.lang.invoke;
import java.util.Objects;
import java.util.concurrent.atomic.AtomicInteger; import java.util.concurrent.atomic.AtomicInteger;
/** /**
@ -275,7 +276,7 @@ public class MutableCallSite extends CallSite {
if (sites.length == 0) return; if (sites.length == 0) return;
STORE_BARRIER.lazySet(0); STORE_BARRIER.lazySet(0);
for (MutableCallSite site : sites) { for (MutableCallSite site : sites) {
site.getClass(); // trigger NPE on first null Objects.requireNonNull(site); // trigger NPE on first null
} }
// FIXME: NYI // FIXME: NYI
} }

View File

@ -296,7 +296,8 @@ public final class Constructor<T> extends Executable {
* constructor has default (package) access. * constructor has default (package) access.
* *
* @return a string describing this {@code Constructor} * @return a string describing this {@code Constructor}
* @jls 8.8.3. Constructor Modifiers * @jls 8.8.3 Constructor Modifiers
* @jls 8.9.2 Enum Body Declarations
*/ */
public String toString() { public String toString() {
return sharedToString(Modifier.constructorModifiers(), return sharedToString(Modifier.constructorModifiers(),
@ -342,7 +343,8 @@ public final class Constructor<T> extends Executable {
* include type parameters * include type parameters
* *
* @since 1.5 * @since 1.5
* @jls 8.8.3. Constructor Modifiers * @jls 8.8.3 Constructor Modifiers
* @jls 8.9.2 Enum Body Declarations
*/ */
@Override @Override
public String toGenericString() { public String toGenericString() {

View File

@ -356,6 +356,8 @@ public final class Method extends Executable {
* @return a string describing this {@code Method} * @return a string describing this {@code Method}
* *
* @jls 8.4.3 Method Modifiers * @jls 8.4.3 Method Modifiers
* @jls 9.4 Method Declarations
* @jls 9.6.1 Annotation Type Elements
*/ */
public String toString() { public String toString() {
return sharedToString(Modifier.methodModifiers(), return sharedToString(Modifier.methodModifiers(),
@ -409,6 +411,8 @@ public final class Method extends Executable {
* @since 1.5 * @since 1.5
* *
* @jls 8.4.3 Method Modifiers * @jls 8.4.3 Method Modifiers
* @jls 9.4 Method Declarations
* @jls 9.6.1 Annotation Type Elements
*/ */
@Override @Override
public String toGenericString() { public String toGenericString() {

View File

@ -388,14 +388,13 @@ class SocksSocketImpl extends PlainSocketImpl implements SocksConsts {
} }
while (iProxy.hasNext()) { while (iProxy.hasNext()) {
p = iProxy.next(); p = iProxy.next();
if (p == null || p == Proxy.NO_PROXY) { if (p == null || p.type() != Proxy.Type.SOCKS) {
super.connect(epoint, remainingMillis(deadlineMillis)); super.connect(epoint, remainingMillis(deadlineMillis));
return; return;
} }
if (p.type() != Proxy.Type.SOCKS)
throw new SocketException("Unknown proxy type : " + p.type());
if (!(p.address() instanceof InetSocketAddress)) if (!(p.address() instanceof InetSocketAddress))
throw new SocketException("Unknow address type for proxy: " + p); throw new SocketException("Unknown address type for proxy: " + p);
// Use getHostString() to avoid reverse lookups // Use getHostString() to avoid reverse lookups
server = ((InetSocketAddress) p.address()).getHostString(); server = ((InetSocketAddress) p.address()).getHostString();
serverPort = ((InetSocketAddress) p.address()).getPort(); serverPort = ((InetSocketAddress) p.address()).getPort();
@ -707,13 +706,12 @@ class SocksSocketImpl extends PlainSocketImpl implements SocksConsts {
} }
while (iProxy.hasNext()) { while (iProxy.hasNext()) {
p = iProxy.next(); p = iProxy.next();
if (p == null || p == Proxy.NO_PROXY) { if (p == null || p.type() != Proxy.Type.SOCKS) {
return; return;
} }
if (p.type() != Proxy.Type.SOCKS)
throw new SocketException("Unknown proxy type : " + p.type());
if (!(p.address() instanceof InetSocketAddress)) if (!(p.address() instanceof InetSocketAddress))
throw new SocketException("Unknow address type for proxy: " + p); throw new SocketException("Unknown address type for proxy: " + p);
// Use getHostString() to avoid reverse lookups // Use getHostString() to avoid reverse lookups
server = ((InetSocketAddress) p.address()).getHostString(); server = ((InetSocketAddress) p.address()).getHostString();
serverPort = ((InetSocketAddress) p.address()).getPort(); serverPort = ((InetSocketAddress) p.address()).getPort();

View File

@ -27,8 +27,15 @@ package java.net;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.net.spi.URLStreamHandlerProvider;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.StringTokenizer; import java.util.Iterator;
import java.util.NoSuchElementException;
import java.util.ServiceConfigurationError;
import java.util.ServiceLoader;
import sun.security.util.SecurityConstants; import sun.security.util.SecurityConstants;
/** /**
@ -248,23 +255,19 @@ public final class URL implements java.io.Serializable {
* stream protocol handler. * stream protocol handler.
* <li>If no {@code URLStreamHandlerFactory} has yet been set up, * <li>If no {@code URLStreamHandlerFactory} has yet been set up,
* or if the factory's {@code createURLStreamHandler} method * or if the factory's {@code createURLStreamHandler} method
* returns {@code null}, then the constructor finds the * returns {@code null}, then the {@linkplain java.util.ServiceLoader
* value of the system property: * ServiceLoader} mechanism is used to locate {@linkplain
* <blockquote><pre> * java.net.spi.URLStreamHandlerProvider URLStreamHandlerProvider}
* java.protocol.handler.pkgs * implementations using the system class
* </pre></blockquote> * loader. The order that providers are located is implementation
* If the value of that system property is not {@code null}, * specific, and an implementation is free to cache the located
* it is interpreted as a list of packages separated by a vertical * providers. A {@linkplain java.util.ServiceConfigurationError
* slash character '{@code |}'. The constructor tries to load * ServiceConfigurationError}, {@code Error} or {@code RuntimeException}
* the class named: * thrown from the {@code createURLStreamHandler}, if encountered, will
* <blockquote><pre> * be propagated to the calling thread. The {@code
* &lt;<i>package</i>&gt;.&lt;<i>protocol</i>&gt;.Handler * createURLStreamHandler} method of each provider, if instantiated, is
* </pre></blockquote> * invoked, with the protocol string, until a provider returns non-null,
* where &lt;<i>package</i>&gt; is replaced by the name of the package * or all providers have been exhausted.
* and &lt;<i>protocol</i>&gt; is replaced by the name of the protocol.
* If this class does not exist, or if the class exists but it is not
* a subclass of {@code URLStreamHandler}, then the next package
* in the list is tried.
* <li>If the previous step fails to find a protocol handler, then the * <li>If the previous step fails to find a protocol handler, then the
* constructor tries to load a built-in protocol handler. * constructor tries to load a built-in protocol handler.
* If this class does not exist, or if the class exists but it is not a * If this class does not exist, or if the class exists but it is not a
@ -277,8 +280,12 @@ public final class URL implements java.io.Serializable {
* <blockquote><pre> * <blockquote><pre>
* http, https, file, and jar * http, https, file, and jar
* </pre></blockquote> * </pre></blockquote>
* Protocol handlers for additional protocols may also be * Protocol handlers for additional protocols may also be available.
* available. * Some protocol handlers, for example those used for loading platform
* classes or classes on the class path, may not be overridden. The details
* of such restrictions, and when those restrictions apply (during
* initialization of the runtime for example), are implementation specific
* and therefore not specified
* *
* <p>No validation of the inputs is performed by this constructor. * <p>No validation of the inputs is performed by this constructor.
* *
@ -1107,20 +1114,115 @@ public final class URL implements java.io.Serializable {
} }
handlers.clear(); handlers.clear();
// ensure the core protocol handlers are loaded before setting
// a custom URLStreamHandlerFactory
ensureHandlersLoaded("jrt", "jar", "file");
// safe publication of URLStreamHandlerFactory with volatile write // safe publication of URLStreamHandlerFactory with volatile write
factory = fac; factory = fac;
} }
} }
private static final URLStreamHandlerFactory defaultFactory = new DefaultFactory();
private static class DefaultFactory implements URLStreamHandlerFactory {
private static String PREFIX = "sun.net.www.protocol";
public URLStreamHandler createURLStreamHandler(String protocol) {
String name = PREFIX + "." + protocol + ".Handler";
try {
Class<?> c = Class.forName(name);
return (URLStreamHandler)c.newInstance();
} catch (ClassNotFoundException x) {
// ignore
} catch (Exception e) {
// For compatibility, all Exceptions are ignored.
// any number of exceptions can get thrown here
}
return null;
}
}
private static Iterator<URLStreamHandlerProvider> providers() {
return new Iterator<URLStreamHandlerProvider>() {
ClassLoader cl = ClassLoader.getSystemClassLoader();
ServiceLoader<URLStreamHandlerProvider> sl =
ServiceLoader.load(URLStreamHandlerProvider.class, cl);
Iterator<URLStreamHandlerProvider> i = sl.iterator();
URLStreamHandlerProvider next = null;
private boolean getNext() {
while (next == null) {
try {
if (!i.hasNext())
return false;
next = i.next();
} catch (ServiceConfigurationError sce) {
if (sce.getCause() instanceof SecurityException) {
// Ignore security exceptions
continue;
}
throw sce;
}
}
return true;
}
public boolean hasNext() {
return getNext();
}
public URLStreamHandlerProvider next() {
if (!getNext())
throw new NoSuchElementException();
URLStreamHandlerProvider n = next;
next = null;
return n;
}
};
}
// Thread-local gate to prevent recursive provider lookups
private static ThreadLocal<Object> gate = new ThreadLocal<>();
private static URLStreamHandler lookupViaProviders(final String protocol) {
if (!sun.misc.VM.isBooted())
return null;
if (gate.get() != null)
throw new Error("Circular loading of URL stream handler providers detected");
gate.set(gate);
try {
return AccessController.doPrivileged(
new PrivilegedAction<URLStreamHandler>() {
public URLStreamHandler run() {
Iterator<URLStreamHandlerProvider> itr = providers();
while (itr.hasNext()) {
URLStreamHandlerProvider f = itr.next();
URLStreamHandler h = f.createURLStreamHandler(protocol);
if (h != null)
return h;
}
return null;
}
});
} finally {
gate.set(null);
}
}
private static final String[] NON_OVERRIDEABLE_PROTOCOLS = {"file", "jrt"};
private static boolean isOverrideable(String protocol) {
for (String p : NON_OVERRIDEABLE_PROTOCOLS)
if (protocol.equalsIgnoreCase(p))
return false;
return true;
}
/** /**
* A table of protocol handlers. * A table of protocol handlers.
*/ */
static Hashtable<String,URLStreamHandler> handlers = new Hashtable<>(); static Hashtable<String,URLStreamHandler> handlers = new Hashtable<>();
private static Object streamHandlerLock = new Object(); private static final Object streamHandlerLock = new Object();
/** /**
* Returns the Stream Handler. * Returns the Stream Handler.
@ -1129,66 +1231,33 @@ public final class URL implements java.io.Serializable {
static URLStreamHandler getURLStreamHandler(String protocol) { static URLStreamHandler getURLStreamHandler(String protocol) {
URLStreamHandler handler = handlers.get(protocol); URLStreamHandler handler = handlers.get(protocol);
if (handler == null) {
if (handler != null) {
return handler;
}
URLStreamHandlerFactory fac;
boolean checkedWithFactory = false; boolean checkedWithFactory = false;
if (isOverrideable(protocol)) {
// Use the factory (if any). Volatile read makes // Use the factory (if any). Volatile read makes
// URLStreamHandlerFactory appear fully initialized to current thread. // URLStreamHandlerFactory appear fully initialized to current thread.
URLStreamHandlerFactory fac = factory; fac = factory;
if (fac != null) { if (fac != null) {
handler = fac.createURLStreamHandler(protocol); handler = fac.createURLStreamHandler(protocol);
checkedWithFactory = true; checkedWithFactory = true;
} }
// Try java protocol handler if (handler == null && !protocol.equalsIgnoreCase("jar")) {
if (handler == null) { handler = lookupViaProviders(protocol);
String packagePrefixList = null;
packagePrefixList
= java.security.AccessController.doPrivileged(
new sun.security.action.GetPropertyAction(
protocolPathProp,""));
if (packagePrefixList != "") {
packagePrefixList += "|";
}
// REMIND: decide whether to allow the "null" class prefix
// or not.
packagePrefixList += "sun.net.www.protocol";
StringTokenizer packagePrefixIter =
new StringTokenizer(packagePrefixList, "|");
while (handler == null &&
packagePrefixIter.hasMoreTokens()) {
String packagePrefix =
packagePrefixIter.nextToken().trim();
try {
String clsName = packagePrefix + "." + protocol +
".Handler";
Class<?> cls = null;
try {
cls = Class.forName(clsName);
} catch (ClassNotFoundException e) {
ClassLoader cl = ClassLoader.getSystemClassLoader();
if (cl != null) {
cls = cl.loadClass(clsName);
}
}
if (cls != null) {
handler =
(URLStreamHandler)cls.newInstance();
}
} catch (Exception e) {
// any number of exceptions can get thrown here
}
} }
} }
synchronized (streamHandlerLock) { synchronized (streamHandlerLock) {
if (handler == null) {
// Try the built-in protocol handler
handler = defaultFactory.createURLStreamHandler(protocol);
} else {
URLStreamHandler handler2 = null; URLStreamHandler handler2 = null;
// Check again with hashtable just in case another // Check again with hashtable just in case another
@ -1211,29 +1280,17 @@ public final class URL implements java.io.Serializable {
// this thread created. // this thread created.
handler = handler2; handler = handler2;
} }
}
// Insert this handler into the hashtable // Insert this handler into the hashtable
if (handler != null) { if (handler != null) {
handlers.put(protocol, handler); handlers.put(protocol, handler);
} }
}
} }
return handler; return handler;
} }
/**
* Ensures that the given protocol handlers are loaded
*/
private static void ensureHandlersLoaded(String... protocols) {
for (String protocol: protocols) {
getURLStreamHandler(protocol);
}
}
/** /**
* WriteObject is called to save the state of the URL to an * WriteObject is called to save the state of the URL to an
* ObjectOutputStream. The handler is not saved since it is * ObjectOutputStream. The handler is not saved since it is

View File

@ -44,7 +44,9 @@ public interface URLStreamHandlerFactory {
* *
* @param protocol the protocol ("{@code ftp}", * @param protocol the protocol ("{@code ftp}",
* "{@code http}", "{@code nntp}", etc.). * "{@code http}", "{@code nntp}", etc.).
* @return a {@code URLStreamHandler} for the specific protocol. * @return a {@code URLStreamHandler} for the specific protocol, or {@code
* null} if this factory cannot create a handler for the specific
* protocol
* @see java.net.URLStreamHandler * @see java.net.URLStreamHandler
*/ */
URLStreamHandler createURLStreamHandler(String protocol); URLStreamHandler createURLStreamHandler(String protocol);

View File

@ -143,13 +143,11 @@
* a similar URL will try to instantiate the handler for the specified protocol; * a similar URL will try to instantiate the handler for the specified protocol;
* if it doesn't exist an exception will be thrown. * if it doesn't exist an exception will be thrown.
* <p>By default the protocol handlers are loaded dynamically from the default * <p>By default the protocol handlers are loaded dynamically from the default
* location. It is, however, possible to add to the search path by setting * location. It is, however, possible to deploy additional protocols handlers
* the {@code java.protocol.handler.pkgs} system property. For instance if * as {@link java.util.ServiceLoader services}. Service providers of type
* it is set to {@code myapp.protocols}, then the URL code will try, in the * {@linkplain java.net.spi.URLStreamHandlerProvider} are located at
* case of http, first to load {@code myapp.protocols.http.Handler}, then, * runtime, as specified in the {@linkplain
* if this fails, {@code http.Handler} from the default location. * java.net.URL#URL(String,String,int,String) URL constructor}.
* <p>Note that the Handler class <b>has to</b> be a subclass of the abstract
* class {@link java.net.URLStreamHandler}.</p>
* <h2>Additional Specification</h2> * <h2>Additional Specification</h2>
* <ul> * <ul>
* <li><a href="doc-files/net-properties.html"> * <li><a href="doc-files/net-properties.html">

View File

@ -0,0 +1,67 @@
/*
* Copyright (c) 2015, 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 java.net.spi;
import java.net.URLStreamHandlerFactory;
/**
* URL stream handler service-provider class.
*
*<p> A URL stream handler provider is a concrete subclass of this class that
* has a zero-argument constructor. URL stream handler providers may be
* installed in an instance of the Java platform by adding them to the
* application class path.
*
* <p> A URL stream handler provider identifies itself with a
* provider-configuration file named java.net.spi.URLStreamHandlerProvider in
* the resource directory META-INF/services. The file should contain a list of
* fully-qualified concrete URL stream handler provider class names, one per
* line.
*
* @since 1.9
*/
public abstract class URLStreamHandlerProvider
implements URLStreamHandlerFactory
{
private static Void checkPermission() {
SecurityManager sm = System.getSecurityManager();
if (sm != null)
sm.checkPermission(new RuntimePermission("setFactory"));
return null;
}
private URLStreamHandlerProvider(Void ignore) { }
/**
* Initializes a new URL stream handler provider.
*
* @throws SecurityException
* If a security manager has been installed and it denies
* {@link RuntimePermission}{@code ("setFactory")}.
*/
protected URLStreamHandlerProvider() {
this(checkPermission());
}
}

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1996, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -23,26 +23,13 @@
* questions. * questions.
*/ */
package sun.security.acl;
import java.security.*;
/** /**
* This class implements a group of principals. * Service-provider classes for the <tt>{@link java.net}</tt> package.
* @author Satish Dharmaraj *
* <p> Only developers who are defining new URL stream handler providers
* should need to make direct use of this package.
*
* @since 1.9
*/ */
public class WorldGroupImpl extends GroupImpl {
public WorldGroupImpl(String s) { package java.net.spi;
super(s);
}
/**
* returns true for all passed principals
* @param member The principal whose membership must be checked in this Group.
* @return true always since this is the "world" group.
*/
public boolean isMember(Principal member) {
return true;
}
}

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1996, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -68,11 +68,7 @@ import java.security.Principal;
* *
* The {@code java.security.acl } package provides the * The {@code java.security.acl } package provides the
* interfaces to the ACL and related data structures (ACL entries, * interfaces to the ACL and related data structures (ACL entries,
* groups, permissions, etc.), and the {@code sun.security.acl } * groups, permissions, etc.).<p>
* classes provide a default implementation of the interfaces. For
* example, {@code java.security.acl.Acl } provides the
* interface to an ACL and the {@code sun.security.acl.AclImpl }
* class provides the default implementation of the interface.<p>
* *
* The {@code java.security.acl.Acl } interface extends the * The {@code java.security.acl.Acl } interface extends the
* {@code java.security.acl.Owner } interface. The Owner * {@code java.security.acl.Owner } interface. The Owner

View File

@ -155,7 +155,7 @@ public abstract class Clock {
* @return a clock that uses the best available system clock in the UTC zone, not null * @return a clock that uses the best available system clock in the UTC zone, not null
*/ */
public static Clock systemUTC() { public static Clock systemUTC() {
return new SystemClock(ZoneOffset.UTC); return SystemClock.UTC;
} }
/** /**
@ -198,6 +198,9 @@ public abstract class Clock {
*/ */
public static Clock system(ZoneId zone) { public static Clock system(ZoneId zone) {
Objects.requireNonNull(zone, "zone"); Objects.requireNonNull(zone, "zone");
if (zone == ZoneOffset.UTC) {
return SystemClock.UTC;
}
return new SystemClock(zone); return new SystemClock(zone);
} }
@ -451,6 +454,8 @@ public abstract class Clock {
private static final long serialVersionUID = 6740630888130243051L; private static final long serialVersionUID = 6740630888130243051L;
private static final long OFFSET_SEED = private static final long OFFSET_SEED =
System.currentTimeMillis()/1000 - 1024; // initial offest System.currentTimeMillis()/1000 - 1024; // initial offest
static final SystemClock UTC = new SystemClock(ZoneOffset.UTC);
private final ZoneId zone; private final ZoneId zone;
// We don't actually need a volatile here. // We don't actually need a volatile here.
// We don't care if offset is set or read concurrently by multiple // We don't care if offset is set or read concurrently by multiple

View File

@ -848,7 +848,7 @@ public interface DoubleStream extends BaseStream<Double, DoubleStream> {
* @implNote * @implNote
* Use caution when constructing streams from repeated concatenation. * Use caution when constructing streams from repeated concatenation.
* Accessing an element of a deeply concatenated stream can result in deep * Accessing an element of a deeply concatenated stream can result in deep
* call chains, or even {@code StackOverflowException}. * call chains, or even {@code StackOverflowError}.
* *
* @param a the first stream * @param a the first stream
* @param b the second stream * @param b the second stream

View File

@ -837,7 +837,7 @@ public interface IntStream extends BaseStream<Integer, IntStream> {
* @implNote * @implNote
* Use caution when constructing streams from repeated concatenation. * Use caution when constructing streams from repeated concatenation.
* Accessing an element of a deeply concatenated stream can result in deep * Accessing an element of a deeply concatenated stream can result in deep
* call chains, or even {@code StackOverflowException}. * call chains, or even {@code StackOverflowError}.
* *
* @param a the first stream * @param a the first stream
* @param b the second stream * @param b the second stream

View File

@ -845,7 +845,7 @@ public interface LongStream extends BaseStream<Long, LongStream> {
* @implNote * @implNote
* Use caution when constructing streams from repeated concatenation. * Use caution when constructing streams from repeated concatenation.
* Accessing an element of a deeply concatenated stream can result in deep * Accessing an element of a deeply concatenated stream can result in deep
* call chains, or even {@code StackOverflowException}. * call chains, or even {@code StackOverflowError}.
* *
* @param a the first stream * @param a the first stream
* @param b the second stream * @param b the second stream

View File

@ -1079,7 +1079,7 @@ public interface Stream<T> extends BaseStream<T, Stream<T>> {
* @implNote * @implNote
* Use caution when constructing streams from repeated concatenation. * Use caution when constructing streams from repeated concatenation.
* Accessing an element of a deeply concatenated stream can result in deep * Accessing an element of a deeply concatenated stream can result in deep
* call chains, or even {@code StackOverflowException}. * call chains, or even {@code StackOverflowError}.
* *
* @param <T> The type of stream elements * @param <T> The type of stream elements
* @param a the first stream * @param a the first stream

View File

@ -180,8 +180,7 @@ class ZipEntry implements ZipConstants, Cloneable {
* @since 1.8 * @since 1.8
*/ */
public ZipEntry setLastModifiedTime(FileTime time) { public ZipEntry setLastModifiedTime(FileTime time) {
Objects.requireNonNull(name, "time"); this.mtime = Objects.requireNonNull(time, "lastModifiedTime");
this.mtime = time;
this.time = time.to(TimeUnit.MILLISECONDS); this.time = time.to(TimeUnit.MILLISECONDS);
return this; return this;
} }
@ -227,8 +226,7 @@ class ZipEntry implements ZipConstants, Cloneable {
* @since 1.8 * @since 1.8
*/ */
public ZipEntry setLastAccessTime(FileTime time) { public ZipEntry setLastAccessTime(FileTime time) {
Objects.requireNonNull(name, "time"); this.atime = Objects.requireNonNull(time, "lastAccessTime");
this.atime = time;
return this; return this;
} }
@ -265,8 +263,7 @@ class ZipEntry implements ZipConstants, Cloneable {
* @since 1.8 * @since 1.8
*/ */
public ZipEntry setCreationTime(FileTime time) { public ZipEntry setCreationTime(FileTime time) {
Objects.requireNonNull(name, "time"); this.ctime = Objects.requireNonNull(time, "creationTime");
this.ctime = time;
return this; return this;
} }

View File

@ -1,181 +0,0 @@
/*
* Copyright (c) 1996, 2011, 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.security.acl;
import java.util.*;
import java.security.Principal;
import java.security.acl.*;
/**
* This is a class that describes one entry that associates users
* or groups with permissions in the ACL.
* The entry may be used as a way of granting or denying permissions.
* @author Satish Dharmaraj
*/
public class AclEntryImpl implements AclEntry {
private Principal user = null;
private Vector<Permission> permissionSet = new Vector<>(10, 10);
private boolean negative = false;
/**
* Construct an ACL entry that associates a user with permissions
* in the ACL.
* @param user The user that is associated with this entry.
*/
public AclEntryImpl(Principal user) {
this.user = user;
}
/**
* Construct a null ACL entry
*/
public AclEntryImpl() {
}
/**
* Sets the principal in the entity. If a group or a
* principal had already been set, a false value is
* returned, otherwise a true value is returned.
* @param user The user that is associated with this entry.
* @return true if the principal is set, false if there is
* one already.
*/
public boolean setPrincipal(Principal user) {
if (this.user != null)
return false;
this.user = user;
return true;
}
/**
* This method sets the ACL to have negative permissions.
* That is the user or group is denied the permission set
* specified in the entry.
*/
public void setNegativePermissions() {
negative = true;
}
/**
* Returns true if this is a negative ACL.
*/
public boolean isNegative() {
return negative;
}
/**
* A principal or a group can be associated with multiple
* permissions. This method adds a permission to the ACL entry.
* @param permission The permission to be associated with
* the principal or the group in the entry.
* @return true if the permission was added, false if the
* permission was already part of the permission set.
*/
public boolean addPermission(Permission permission) {
if (permissionSet.contains(permission))
return false;
permissionSet.addElement(permission);
return true;
}
/**
* The method disassociates the permission from the Principal
* or the Group in this ACL entry.
* @param permission The permission to be disassociated with
* the principal or the group in the entry.
* @return true if the permission is removed, false if the
* permission is not part of the permission set.
*/
public boolean removePermission(Permission permission) {
return permissionSet.removeElement(permission);
}
/**
* Checks if the passed permission is part of the allowed
* permission set in this entry.
* @param permission The permission that has to be part of
* the permission set in the entry.
* @return true if the permission passed is part of the
* permission set in the entry, false otherwise.
*/
public boolean checkPermission(Permission permission) {
return permissionSet.contains(permission);
}
/**
* return an enumeration of the permissions in this ACL entry.
*/
public Enumeration<Permission> permissions() {
return permissionSet.elements();
}
/**
* Return a string representation of the contents of the ACL entry.
*/
public String toString() {
StringBuffer s = new StringBuffer();
if (negative)
s.append("-");
else
s.append("+");
if (user instanceof Group)
s.append("Group.");
else
s.append("User.");
s.append(user + "=");
Enumeration<Permission> e = permissions();
while(e.hasMoreElements()) {
Permission p = e.nextElement();
s.append(p);
if (e.hasMoreElements())
s.append(",");
}
return new String(s);
}
/**
* Clones an AclEntry.
*/
@SuppressWarnings("unchecked") // Safe casts assuming clone() works correctly
public synchronized Object clone() {
AclEntryImpl cloned;
cloned = new AclEntryImpl(user);
cloned.permissionSet = (Vector<Permission>) permissionSet.clone();
cloned.negative = negative;
return cloned;
}
/**
* Return the Principal associated in this ACL entry.
* The method returns null if the entry uses a group
* instead of a principal.
*/
public Principal getPrincipal() {
return user;
}
}

View File

@ -1,408 +0,0 @@
/*
* Copyright (c) 1996, 2011, 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.security.acl;
import java.io.*;
import java.util.*;
import java.security.Principal;
import java.security.acl.*;
/**
* An Access Control List (ACL) is encapsulated by this class.
* @author Satish Dharmaraj
*/
public class AclImpl extends OwnerImpl implements Acl {
//
// Maintain four tables. one each for positive and negative
// ACLs. One each depending on whether the entity is a group
// or principal.
//
private Hashtable<Principal, AclEntry> allowedUsersTable =
new Hashtable<>(23);
private Hashtable<Principal, AclEntry> allowedGroupsTable =
new Hashtable<>(23);
private Hashtable<Principal, AclEntry> deniedUsersTable =
new Hashtable<>(23);
private Hashtable<Principal, AclEntry> deniedGroupsTable =
new Hashtable<>(23);
private String aclName = null;
private Vector<Permission> zeroSet = new Vector<>(1,1);
/**
* Constructor for creating an empty ACL.
*/
public AclImpl(Principal owner, String name) {
super(owner);
try {
setName(owner, name);
} catch (Exception e) {}
}
/**
* Sets the name of the ACL.
* @param caller the principal who is invoking this method.
* @param name the name of the ACL.
* @exception NotOwnerException if the caller principal is
* not on the owners list of the Acl.
*/
public void setName(Principal caller, String name)
throws NotOwnerException
{
if (!isOwner(caller))
throw new NotOwnerException();
aclName = name;
}
/**
* Returns the name of the ACL.
* @return the name of the ACL.
*/
public String getName() {
return aclName;
}
/**
* Adds an ACL entry to this ACL. An entry associates a
* group or a principal with a set of permissions. Each
* user or group can have one positive ACL entry and one
* negative ACL entry. If there is one of the type (negative
* or positive) already in the table, a false value is returned.
* The caller principal must be a part of the owners list of
* the ACL in order to invoke this method.
* @param caller the principal who is invoking this method.
* @param entry the ACL entry that must be added to the ACL.
* @return true on success, false if the entry is already present.
* @exception NotOwnerException if the caller principal
* is not on the owners list of the Acl.
*/
public synchronized boolean addEntry(Principal caller, AclEntry entry)
throws NotOwnerException
{
if (!isOwner(caller))
throw new NotOwnerException();
Hashtable<Principal, AclEntry> aclTable = findTable(entry);
Principal key = entry.getPrincipal();
if (aclTable.get(key) != null)
return false;
aclTable.put(key, entry);
return true;
}
/**
* Removes an ACL entry from this ACL.
* The caller principal must be a part of the owners list of the ACL
* in order to invoke this method.
* @param caller the principal who is invoking this method.
* @param entry the ACL entry that must be removed from the ACL.
* @return true on success, false if the entry is not part of the ACL.
* @exception NotOwnerException if the caller principal is not
* the owners list of the Acl.
*/
public synchronized boolean removeEntry(Principal caller, AclEntry entry)
throws NotOwnerException
{
if (!isOwner(caller))
throw new NotOwnerException();
Hashtable<Principal, AclEntry> aclTable = findTable(entry);
Principal key = entry.getPrincipal();
AclEntry o = aclTable.remove(key);
return (o != null);
}
/**
* This method returns the set of allowed permissions for the
* specified principal. This set of allowed permissions is calculated
* as follows:
*
* If there is no entry for a group or a principal an empty permission
* set is assumed.
*
* The group positive permission set is the union of all
* the positive permissions of each group that the individual belongs to.
* The group negative permission set is the union of all
* the negative permissions of each group that the individual belongs to.
* If there is a specific permission that occurs in both
* the postive permission set and the negative permission set,
* it is removed from both. The group positive and negatoive permission
* sets are calculated.
*
* The individial positive permission set and the individual negative
* permission set is then calculated. Again abscence of an entry means
* the empty set.
*
* The set of permissions granted to the principal is then calculated using
* the simple rule: Individual permissions always override the Group permissions.
* Specifically, individual negative permission set (specific
* denial of permissions) overrides the group positive permission set.
* And the individual positive permission set override the group negative
* permission set.
*
* @param user the principal for which the ACL entry is returned.
* @return The resulting permission set that the principal is allowed.
*/
public synchronized Enumeration<Permission> getPermissions(Principal user) {
Enumeration<Permission> individualPositive;
Enumeration<Permission> individualNegative;
Enumeration<Permission> groupPositive;
Enumeration<Permission> groupNegative;
//
// canonicalize the sets. That is remove common permissions from
// positive and negative sets.
//
groupPositive =
subtract(getGroupPositive(user), getGroupNegative(user));
groupNegative =
subtract(getGroupNegative(user), getGroupPositive(user));
individualPositive =
subtract(getIndividualPositive(user), getIndividualNegative(user));
individualNegative =
subtract(getIndividualNegative(user), getIndividualPositive(user));
//
// net positive permissions is individual positive permissions
// plus (group positive - individual negative).
//
Enumeration<Permission> temp1 =
subtract(groupPositive, individualNegative);
Enumeration<Permission> netPositive =
union(individualPositive, temp1);
// recalculate the enumeration since we lost it in performing the
// subtraction
//
individualPositive =
subtract(getIndividualPositive(user), getIndividualNegative(user));
individualNegative =
subtract(getIndividualNegative(user), getIndividualPositive(user));
//
// net negative permissions is individual negative permissions
// plus (group negative - individual positive).
//
temp1 = subtract(groupNegative, individualPositive);
Enumeration<Permission> netNegative = union(individualNegative, temp1);
return subtract(netPositive, netNegative);
}
/**
* This method checks whether or not the specified principal
* has the required permission. If permission is denied
* permission false is returned, a true value is returned otherwise.
* This method does not authenticate the principal. It presumes that
* the principal is a valid authenticated principal.
* @param principal the name of the authenticated principal
* @param permission the permission that the principal must have.
* @return true of the principal has the permission desired, false
* otherwise.
*/
public boolean checkPermission(Principal principal, Permission permission)
{
Enumeration<Permission> permSet = getPermissions(principal);
while (permSet.hasMoreElements()) {
Permission p = permSet.nextElement();
if (p.equals(permission))
return true;
}
return false;
}
/**
* returns an enumeration of the entries in this ACL.
*/
public synchronized Enumeration<AclEntry> entries() {
return new AclEnumerator(this,
allowedUsersTable, allowedGroupsTable,
deniedUsersTable, deniedGroupsTable);
}
/**
* return a stringified version of the
* ACL.
*/
public String toString() {
StringBuilder sb = new StringBuilder();
Enumeration<AclEntry> entries = entries();
while (entries.hasMoreElements()) {
AclEntry entry = entries.nextElement();
sb.append(entry.toString().trim());
sb.append("\n");
}
return sb.toString();
}
//
// Find the table that this entry belongs to. There are 4
// tables that are maintained. One each for postive and
// negative ACLs and one each for groups and users.
// This method figures out which
// table is the one that this AclEntry belongs to.
//
private Hashtable<Principal, AclEntry> findTable(AclEntry entry) {
Hashtable<Principal, AclEntry> aclTable = null;
Principal p = entry.getPrincipal();
if (p instanceof Group) {
if (entry.isNegative())
aclTable = deniedGroupsTable;
else
aclTable = allowedGroupsTable;
} else {
if (entry.isNegative())
aclTable = deniedUsersTable;
else
aclTable = allowedUsersTable;
}
return aclTable;
}
//
// returns the set e1 U e2.
//
private static Enumeration<Permission> union(Enumeration<Permission> e1,
Enumeration<Permission> e2) {
Vector<Permission> v = new Vector<>(20, 20);
while (e1.hasMoreElements())
v.addElement(e1.nextElement());
while (e2.hasMoreElements()) {
Permission o = e2.nextElement();
if (!v.contains(o))
v.addElement(o);
}
return v.elements();
}
//
// returns the set e1 - e2.
//
private Enumeration<Permission> subtract(Enumeration<Permission> e1,
Enumeration<Permission> e2) {
Vector<Permission> v = new Vector<>(20, 20);
while (e1.hasMoreElements())
v.addElement(e1.nextElement());
while (e2.hasMoreElements()) {
Permission o = e2.nextElement();
if (v.contains(o))
v.removeElement(o);
}
return v.elements();
}
private Enumeration<Permission> getGroupPositive(Principal user) {
Enumeration<Permission> groupPositive = zeroSet.elements();
Enumeration<Principal> e = allowedGroupsTable.keys();
while (e.hasMoreElements()) {
Group g = (Group)e.nextElement();
if (g.isMember(user)) {
AclEntry ae = allowedGroupsTable.get(g);
groupPositive = union(ae.permissions(), groupPositive);
}
}
return groupPositive;
}
private Enumeration<Permission> getGroupNegative(Principal user) {
Enumeration<Permission> groupNegative = zeroSet.elements();
Enumeration<Principal> e = deniedGroupsTable.keys();
while (e.hasMoreElements()) {
Group g = (Group)e.nextElement();
if (g.isMember(user)) {
AclEntry ae = deniedGroupsTable.get(g);
groupNegative = union(ae.permissions(), groupNegative);
}
}
return groupNegative;
}
private Enumeration<Permission> getIndividualPositive(Principal user) {
Enumeration<Permission> individualPositive = zeroSet.elements();
AclEntry ae = allowedUsersTable.get(user);
if (ae != null)
individualPositive = ae.permissions();
return individualPositive;
}
private Enumeration<Permission> getIndividualNegative(Principal user) {
Enumeration<Permission> individualNegative = zeroSet.elements();
AclEntry ae = deniedUsersTable.get(user);
if (ae != null)
individualNegative = ae.permissions();
return individualNegative;
}
}
final class AclEnumerator implements Enumeration<AclEntry> {
Acl acl;
Enumeration<AclEntry> u1, u2, g1, g2;
AclEnumerator(Acl acl, Hashtable<?,AclEntry> u1, Hashtable<?,AclEntry> g1,
Hashtable<?,AclEntry> u2, Hashtable<?,AclEntry> g2) {
this.acl = acl;
this.u1 = u1.elements();
this.u2 = u2.elements();
this.g1 = g1.elements();
this.g2 = g2.elements();
}
public boolean hasMoreElements() {
return (u1.hasMoreElements() ||
u2.hasMoreElements() ||
g1.hasMoreElements() ||
g2.hasMoreElements());
}
public AclEntry nextElement()
{
AclEntry o;
synchronized (acl) {
if (u1.hasMoreElements())
return u1.nextElement();
if (u2.hasMoreElements())
return u2.nextElement();
if (g1.hasMoreElements())
return g1.nextElement();
if (g2.hasMoreElements())
return g2.nextElement();
}
throw new NoSuchElementException("Acl Enumerator");
}
}

View File

@ -1,186 +0,0 @@
/*
* Copyright (c) 1996, 2011, 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.security.acl;
import java.util.*;
import java.security.*;
import java.security.acl.*;
/**
* This class implements a group of principals.
* @author Satish Dharmaraj
*/
public class GroupImpl implements Group {
private Vector<Principal> groupMembers = new Vector<>(50, 100);
private String group;
/**
* Constructs a Group object with no members.
* @param groupName the name of the group
*/
public GroupImpl(String groupName) {
this.group = groupName;
}
/**
* adds the specified member to the group.
* @param user The principal to add to the group.
* @return true if the member was added - false if the
* member could not be added.
*/
public boolean addMember(Principal user) {
if (groupMembers.contains(user))
return false;
// do not allow groups to be added to itself.
if (group.equals(user.toString()))
throw new IllegalArgumentException();
groupMembers.addElement(user);
return true;
}
/**
* removes the specified member from the group.
* @param user The principal to remove from the group.
* @param true if the principal was removed false if
* the principal was not a member
*/
public boolean removeMember(Principal user) {
return groupMembers.removeElement(user);
}
/**
* returns the enumeration of the members in the group.
*/
public Enumeration<? extends Principal> members() {
return groupMembers.elements();
}
/**
* This function returns true if the group passed matches
* the group represented in this interface.
* @param another The group to compare this group to.
*/
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj instanceof Group == false) {
return false;
}
Group another = (Group)obj;
return group.equals(another.toString());
}
// equals(Group) for compatibility
public boolean equals(Group another) {
return equals((Object)another);
}
/**
* Prints a stringified version of the group.
*/
public String toString() {
return group;
}
/**
* return a hashcode for the principal.
*/
public int hashCode() {
return group.hashCode();
}
/**
* returns true if the passed principal is a member of the group.
* @param member The principal whose membership must be checked for.
* @return true if the principal is a member of this group,
* false otherwise
*/
public boolean isMember(Principal member) {
//
// if the member is part of the group (common case), return true.
// if not, recursively search depth first in the group looking for the
// principal.
//
if (groupMembers.contains(member)) {
return true;
} else {
Vector<Group> alreadySeen = new Vector<>(10);
return isMemberRecurse(member, alreadySeen);
}
}
/**
* return the name of the principal.
*/
public String getName() {
return group;
}
//
// This function is the recursive search of groups for this
// implementation of the Group. The search proceeds building up
// a vector of already seen groups. Only new groups are considered,
// thereby avoiding loops.
//
boolean isMemberRecurse(Principal member, Vector<Group> alreadySeen) {
Enumeration<? extends Principal> e = members();
while (e.hasMoreElements()) {
boolean mem = false;
Principal p = (Principal) e.nextElement();
// if the member is in this collection, return true
if (p.equals(member)) {
return true;
} else if (p instanceof GroupImpl) {
//
// if not recurse if the group has not been checked already.
// Can call method in this package only if the object is an
// instance of this class. Otherwise call the method defined
// in the interface. (This can lead to a loop if a mixture of
// implementations form a loop, but we live with this improbable
// case rather than clutter the interface by forcing the
// implementation of this method.)
//
GroupImpl g = (GroupImpl) p;
alreadySeen.addElement(this);
if (!alreadySeen.contains(g))
mem = g.isMemberRecurse(member, alreadySeen);
} else if (p instanceof Group) {
Group g = (Group) p;
if (!alreadySeen.contains(g))
mem = g.isMember(member);
}
if (mem)
return mem;
}
return false;
}
}

View File

@ -1,108 +0,0 @@
/*
* Copyright (c) 1996, 2006, 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.security.acl;
import java.util.*;
import java.security.*;
import java.security.acl.*;
/**
* Class implementing the Owner interface. The
* initial owner principal is configured as
* part of the constructor.
* @author Satish Dharmaraj
*/
public class OwnerImpl implements Owner {
private Group ownerGroup;
public OwnerImpl(Principal owner) {
ownerGroup = new GroupImpl("AclOwners");
ownerGroup.addMember(owner);
}
/**
* Adds an owner. Owners can modify ACL contents and can disassociate
* ACLs from the objects they protect in the AclConfig interface.
* The caller principal must be a part of the owners list of the ACL in
* order to invoke this method. The initial owner is configured
* at ACL construction time.
* @param caller the principal who is invoking this method.
* @param owner The owner that should be added to the owners list.
* @return true if success, false if already an owner.
* @exception NotOwnerException if the caller principal is not on
* the owners list of the Acl.
*/
public synchronized boolean addOwner(Principal caller, Principal owner)
throws NotOwnerException
{
if (!isOwner(caller))
throw new NotOwnerException();
ownerGroup.addMember(owner);
return false;
}
/**
* Delete owner. If this is the last owner in the ACL, an exception is
* raised.
* The caller principal must be a part of the owners list of the ACL in
* order to invoke this method.
* @param caller the principal who is invoking this method.
* @param owner The owner to be removed from the owners list.
* @return true if the owner is removed, false if the owner is not part
* of the owners list.
* @exception NotOwnerException if the caller principal is not on
* the owners list of the Acl.
* @exception LastOwnerException if there is only one owner left in the group, then
* deleteOwner would leave the ACL owner-less. This exception is raised in such a case.
*/
public synchronized boolean deleteOwner(Principal caller, Principal owner)
throws NotOwnerException, LastOwnerException
{
if (!isOwner(caller))
throw new NotOwnerException();
Enumeration<? extends Principal> e = ownerGroup.members();
//
// check if there is atleast 2 members left.
//
Object o = e.nextElement();
if (e.hasMoreElements())
return ownerGroup.removeMember(owner);
else
throw new LastOwnerException();
}
/**
* returns if the given principal belongs to the owner list.
* @param owner The owner to check if part of the owners list
* @return true if the passed principal is in the owner list, false if not.
*/
public synchronized boolean isOwner(Principal owner) {
return ownerGroup.isMember(owner);
}
}

View File

@ -1,80 +0,0 @@
/*
* Copyright (c) 1996, 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.security.acl;
import java.security.Principal;
import java.security.acl.*;
/**
* The PermissionImpl class implements the permission
* interface for permissions that are strings.
* @author Satish Dharmaraj
*/
public class PermissionImpl implements Permission {
private String permission;
/**
* Construct a permission object using a string.
* @param permission the stringified version of the permission.
*/
public PermissionImpl(String permission) {
this.permission = permission;
}
/**
* This function returns true if the object passed matches the permission
* represented in this interface.
* @param another The Permission object to compare with.
* @return true if the Permission objects are equal, false otherwise
*/
public boolean equals(Object another) {
if (another instanceof Permission) {
Permission p = (Permission) another;
return permission.equals(p.toString());
} else {
return false;
}
}
/**
* Prints a stringified version of the permission.
* @return the string representation of the Permission.
*/
public String toString() {
return permission;
}
/**
* Returns a hashcode for this PermissionImpl.
*
* @return a hashcode for this PermissionImpl.
*/
public int hashCode() {
return toString().hashCode();
}
}

View File

@ -1,83 +0,0 @@
/*
* Copyright (c) 1996, 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.security.acl;
import java.security.*;
/**
* This class implements the principal interface.
*
* @author Satish Dharmaraj
*/
public class PrincipalImpl implements Principal {
private String user;
/**
* Construct a principal from a string user name.
* @param user The string form of the principal name.
*/
public PrincipalImpl(String user) {
this.user = user;
}
/**
* This function returns true if the object passed matches
* the principal represented in this implementation
* @param another the Principal to compare with.
* @return true if the Principal passed is the same as that
* encapsulated in this object, false otherwise
*/
public boolean equals(Object another) {
if (another instanceof PrincipalImpl) {
PrincipalImpl p = (PrincipalImpl) another;
return user.equals(p.toString());
} else
return false;
}
/**
* Prints a stringified version of the principal.
*/
public String toString() {
return user;
}
/**
* return a hashcode for the principal.
*/
public int hashCode() {
return user.hashCode();
}
/**
* return the name of the principal.
*/
public String getName() {
return user;
}
}

View File

@ -3765,55 +3765,70 @@ public final class Main {
} }
} }
// Add an extension into a CertificateExtensions, always using OID as key
private static void setExt(CertificateExtensions result, Extension ex)
throws IOException {
result.set(ex.getId(), ex);
}
/** /**
* Create X509v3 extensions from a string representation. Note that the * Create X509v3 extensions from a string representation. Note that the
* SubjectKeyIdentifierExtension will always be created non-critical besides * SubjectKeyIdentifierExtension will always be created non-critical besides
* the extension requested in the <code>extstr</code> argument. * the extension requested in the <code>extstr</code> argument.
* *
* @param reqex the requested extensions, can be null, used for -gencert * @param requestedEx the requested extensions, can be null, used for -gencert
* @param ext the original extensions, can be null, used for -selfcert * @param existingEx the original extensions, can be null, used for -selfcert
* @param extstrs -ext values, Read keytool doc * @param extstrs -ext values, Read keytool doc
* @param pkey the public key for the certificate * @param pkey the public key for the certificate
* @param akey the public key for the authority (issuer) * @param akey the public key for the authority (issuer)
* @return the created CertificateExtensions * @return the created CertificateExtensions
*/ */
private CertificateExtensions createV3Extensions( private CertificateExtensions createV3Extensions(
CertificateExtensions reqex, CertificateExtensions requestedEx,
CertificateExtensions ext, CertificateExtensions existingEx,
List <String> extstrs, List <String> extstrs,
PublicKey pkey, PublicKey pkey,
PublicKey akey) throws Exception { PublicKey akey) throws Exception {
if (ext != null && reqex != null) { if (existingEx != null && requestedEx != null) {
// This should not happen // This should not happen
throw new Exception("One of request and original should be null."); throw new Exception("One of request and original should be null.");
} }
if (ext == null) ext = new CertificateExtensions(); // A new extensions always using OID as key
CertificateExtensions result = new CertificateExtensions();
if (existingEx != null) {
for (Extension ex: existingEx.getAllExtensions()) {
setExt(result, ex);
}
}
try { try {
// name{:critical}{=value} // name{:critical}{=value}
// Honoring requested extensions // Honoring requested extensions
if (reqex != null) { if (requestedEx != null) {
for(String extstr: extstrs) { for(String extstr: extstrs) {
if (extstr.toLowerCase(Locale.ENGLISH).startsWith("honored=")) { if (extstr.toLowerCase(Locale.ENGLISH).startsWith("honored=")) {
List<String> list = Arrays.asList( List<String> list = Arrays.asList(
extstr.toLowerCase(Locale.ENGLISH).substring(8).split(",")); extstr.toLowerCase(Locale.ENGLISH).substring(8).split(","));
// First check existence of "all" // First check existence of "all"
if (list.contains("all")) { if (list.contains("all")) {
ext = reqex; // we know ext was null for (Extension ex: requestedEx.getAllExtensions()) {
setExt(result, ex);
}
} }
// one by one for others // one by one for others
for (String item: list) { for (String item: list) {
if (item.equals("all")) continue; if (item.equals("all")) continue;
// add or remove // add or remove
boolean add = true; boolean add;
// -1, unchanged, 0 crtical, 1 non-critical // -1, unchanged, 0 critical, 1 non-critical
int action = -1; int action = -1;
String type = null; String type = null;
if (item.startsWith("-")) { if (item.startsWith("-")) {
add = false; add = false;
type = item.substring(1); type = item.substring(1);
} else { } else {
add = true;
int colonpos = item.indexOf(':'); int colonpos = item.indexOf(':');
if (colonpos >= 0) { if (colonpos >= 0) {
type = item.substring(0, colonpos); type = item.substring(0, colonpos);
@ -3823,21 +3838,23 @@ public final class Main {
throw new Exception(rb.getString throw new Exception(rb.getString
("Illegal.value.") + item); ("Illegal.value.") + item);
} }
} else {
type = item;
} }
} }
String n = reqex.getNameByOid(findOidForExtName(type)); String n = findOidForExtName(type).toString();
if (add) { if (add) {
Extension e = reqex.get(n); Extension e = requestedEx.get(n);
if (!e.isCritical() && action == 0 if (!e.isCritical() && action == 0
|| e.isCritical() && action == 1) { || e.isCritical() && action == 1) {
e = Extension.newExtension( e = Extension.newExtension(
e.getExtensionId(), e.getExtensionId(),
!e.isCritical(), !e.isCritical(),
e.getExtensionValue()); e.getExtensionValue());
ext.set(n, e);
} }
setExt(result, e);
} else { } else {
ext.delete(n); result.delete(n);
} }
} }
break; break;
@ -3899,8 +3916,7 @@ public final class Main {
} }
} }
} }
ext.set(BasicConstraintsExtension.NAME, setExt(result, new BasicConstraintsExtension(isCritical, isCA,
new BasicConstraintsExtension(isCritical, isCA,
pathLen)); pathLen));
break; break;
case 1: // KU case 1: // KU
@ -3928,7 +3944,7 @@ public final class Main {
KeyUsageExtension kue = new KeyUsageExtension(ok); KeyUsageExtension kue = new KeyUsageExtension(ok);
// The above KeyUsageExtension constructor does not // The above KeyUsageExtension constructor does not
// allow isCritical value, so... // allow isCritical value, so...
ext.set(KeyUsageExtension.NAME, Extension.newExtension( setExt(result, Extension.newExtension(
kue.getExtensionId(), kue.getExtensionId(),
isCritical, isCritical,
kue.getExtensionValue())); kue.getExtensionValue()));
@ -3966,8 +3982,7 @@ public final class Main {
v.add(new ObjectIdentifier("1.3.6.1.5.5.7.3." + p)); v.add(new ObjectIdentifier("1.3.6.1.5.5.7.3." + p));
} }
} }
ext.set(ExtendedKeyUsageExtension.NAME, setExt(result, new ExtendedKeyUsageExtension(isCritical, v));
new ExtendedKeyUsageExtension(isCritical, v));
} else { } else {
throw new Exception(rb.getString throw new Exception(rb.getString
("Illegal.value.") + extstr); ("Illegal.value.") + extstr);
@ -3988,12 +4003,10 @@ public final class Main {
gnames.add(createGeneralName(t, v)); gnames.add(createGeneralName(t, v));
} }
if (exttype == 3) { if (exttype == 3) {
ext.set(SubjectAlternativeNameExtension.NAME, setExt(result, new SubjectAlternativeNameExtension(
new SubjectAlternativeNameExtension(
isCritical, gnames)); isCritical, gnames));
} else { } else {
ext.set(IssuerAlternativeNameExtension.NAME, setExt(result, new IssuerAlternativeNameExtension(
new IssuerAlternativeNameExtension(
isCritical, gnames)); isCritical, gnames));
} }
} else { } else {
@ -4044,11 +4057,9 @@ public final class Main {
oid, createGeneralName(t, v))); oid, createGeneralName(t, v)));
} }
if (exttype == 5) { if (exttype == 5) {
ext.set(SubjectInfoAccessExtension.NAME, setExt(result, new SubjectInfoAccessExtension(accessDescriptions));
new SubjectInfoAccessExtension(accessDescriptions));
} else { } else {
ext.set(AuthorityInfoAccessExtension.NAME, setExt(result, new AuthorityInfoAccessExtension(accessDescriptions));
new AuthorityInfoAccessExtension(accessDescriptions));
} }
} else { } else {
throw new Exception(rb.getString throw new Exception(rb.getString
@ -4068,8 +4079,7 @@ public final class Main {
String v = item.substring(colonpos+1); String v = item.substring(colonpos+1);
gnames.add(createGeneralName(t, v)); gnames.add(createGeneralName(t, v));
} }
ext.set(CRLDistributionPointsExtension.NAME, setExt(result, new CRLDistributionPointsExtension(
new CRLDistributionPointsExtension(
isCritical, Collections.singletonList( isCritical, Collections.singletonList(
new DistributionPoint(gnames, null, null)))); new DistributionPoint(gnames, null, null))));
} else { } else {
@ -4109,7 +4119,7 @@ public final class Main {
} else { } else {
data = new byte[0]; data = new byte[0];
} }
ext.set(oid.toString(), new Extension(oid, isCritical, setExt(result, new Extension(oid, isCritical,
new DerValue(DerValue.tag_OctetString, data) new DerValue(DerValue.tag_OctetString, data)
.toByteArray())); .toByteArray()));
break; break;
@ -4119,18 +4129,16 @@ public final class Main {
} }
} }
// always non-critical // always non-critical
ext.set(SubjectKeyIdentifierExtension.NAME, setExt(result, new SubjectKeyIdentifierExtension(
new SubjectKeyIdentifierExtension(
new KeyIdentifier(pkey).getIdentifier())); new KeyIdentifier(pkey).getIdentifier()));
if (akey != null && !pkey.equals(akey)) { if (akey != null && !pkey.equals(akey)) {
ext.set(AuthorityKeyIdentifierExtension.NAME, setExt(result, new AuthorityKeyIdentifierExtension(
new AuthorityKeyIdentifierExtension(
new KeyIdentifier(akey), null, null)); new KeyIdentifier(akey), null, null));
} }
} catch(IOException e) { } catch(IOException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
return ext; return result;
} }
/** /**

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -80,11 +80,13 @@ public class Debug {
System.err.println("jar jar verification"); System.err.println("jar jar verification");
System.err.println("logincontext login context results"); System.err.println("logincontext login context results");
System.err.println("jca JCA engine class debugging"); System.err.println("jca JCA engine class debugging");
System.err.println("keystore KeyStore debugging");
System.err.println("policy loading and granting"); System.err.println("policy loading and granting");
System.err.println("provider security provider debugging"); System.err.println("provider security provider debugging");
System.err.println("pkcs11 PKCS11 session manager debugging"); System.err.println("pkcs11 PKCS11 session manager debugging");
System.err.println("pkcs11keystore"); System.err.println("pkcs11keystore");
System.err.println(" PKCS11 KeyStore debugging"); System.err.println(" PKCS11 KeyStore debugging");
System.err.println("pkcs12 PKCS12 KeyStore debugging");
System.err.println("sunpkcs11 SunPKCS11 provider debugging"); System.err.println("sunpkcs11 SunPKCS11 provider debugging");
System.err.println("scl permissions SecureClassLoader assigns"); System.err.println("scl permissions SecureClassLoader assigns");
System.err.println("ts timestamping"); System.err.println("ts timestamping");
@ -114,6 +116,10 @@ public class Debug {
System.err.println(" KeyPairGenerator, KeyStore, Mac,"); System.err.println(" KeyPairGenerator, KeyStore, Mac,");
System.err.println(" MessageDigest, SecureRandom, Signature."); System.err.println(" MessageDigest, SecureRandom, Signature.");
System.err.println(); System.err.println();
System.err.println("The following can be used with certpath:");
System.err.println();
System.err.println("ocsp dump the OCSP protocol exchanges");
System.err.println();
System.err.println("Note: Separate multiple options with a comma"); System.err.println("Note: Separate multiple options with a comma");
System.exit(0); System.exit(0);
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -29,7 +29,7 @@ package sun.util.logging;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedAction; import java.security.PrivilegedAction;
import java.util.Date; import java.time.ZonedDateTime;
/** /**
* Internal API to support JRE implementation to detect if the java.util.logging * Internal API to support JRE implementation to detect if the java.util.logging
@ -145,6 +145,11 @@ public class LoggingSupport {
return proxy.getLevelValue(level); return proxy.getLevelValue(level);
} }
// Since JDK 9, logging uses java.time to get more precise time stamps.
// It is possible to configure the simple format to print nano seconds (.%1$tN)
// by specifying:
// java.util.logging.SimpleFormatter.format=%1$tb %1$td, %1$tY %1$tl:%1$tM:%1$tS.%1$tN %1$Tp %2$s%n%4$s: %5$s%6$s%n
// in the logging configuration
private static final String DEFAULT_FORMAT = private static final String DEFAULT_FORMAT =
"%1$tb %1$td, %1$tY %1$tl:%1$tM:%1$tS %1$Tp %2$s%n%4$s: %5$s%6$s%n"; "%1$tb %1$td, %1$tY %1$tl:%1$tM:%1$tS %1$Tp %2$s%n%4$s: %5$s%6$s%n";
@ -171,7 +176,7 @@ public class LoggingSupport {
if (format != null) { if (format != null) {
try { try {
// validate the user-defined format string // validate the user-defined format string
String.format(format, new Date(), "", "", "", "", ""); String.format(format, ZonedDateTime.now(), "", "", "", "", "");
} catch (IllegalArgumentException e) { } catch (IllegalArgumentException e) {
// illegal syntax; fall back to the default format // illegal syntax; fall back to the default format
format = DEFAULT_FORMAT; format = DEFAULT_FORMAT;

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -32,8 +32,11 @@ import java.io.PrintWriter;
import java.io.StringWriter; import java.io.StringWriter;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedAction; import java.security.PrivilegedAction;
import java.time.Clock;
import java.time.Instant;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.util.Arrays; import java.util.Arrays;
import java.util.Date;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import sun.misc.JavaLangAccess; import sun.misc.JavaLangAccess;
@ -514,11 +517,9 @@ public class PlatformLogger {
private static final String formatString = private static final String formatString =
LoggingSupport.getSimpleFormat(false); // don't check logging.properties LoggingSupport.getSimpleFormat(false); // don't check logging.properties
private final ZoneId zoneId = ZoneId.systemDefault();
// minimize memory allocation
private Date date = new Date();
private synchronized String format(Level level, String msg, Throwable thrown) { private synchronized String format(Level level, String msg, Throwable thrown) {
date.setTime(System.currentTimeMillis()); ZonedDateTime zdt = ZonedDateTime.now(zoneId);
String throwable = ""; String throwable = "";
if (thrown != null) { if (thrown != null) {
StringWriter sw = new StringWriter(); StringWriter sw = new StringWriter();
@ -530,7 +531,7 @@ public class PlatformLogger {
} }
return String.format(formatString, return String.format(formatString,
date, zdt,
getCallerInfo(), getCallerInfo(),
name, name,
level.name(), level.name(),

View File

@ -651,9 +651,26 @@ static void
SetJvmEnvironment(int argc, char **argv) { SetJvmEnvironment(int argc, char **argv) {
static const char* NMT_Env_Name = "NMT_LEVEL_"; static const char* NMT_Env_Name = "NMT_LEVEL_";
int i; int i;
for (i = 0; i < argc; i++) { for (i = 0; i < argc; i++) {
char *arg = argv[i];
/*
* Since this must be a VM flag we stop processing once we see
* an argument the launcher would not have processed beyond (such
* as -version or -h), or an argument that indicates the following
* arguments are for the application (i.e. the main class name, or
* the -jar argument).
*/
if ((i > 0 && *arg != '-')
|| JLI_StrCmp(arg, "-version") == 0
|| JLI_StrCmp(arg, "-fullversion") == 0
|| JLI_StrCmp(arg, "-help") == 0
|| JLI_StrCmp(arg, "-?") == 0
|| JLI_StrCmp(arg, "-jar") == 0
|| JLI_StrCmp(arg, "-X") == 0
) {
return;
}
/* /*
* The following case checks for "-XX:NativeMemoryTracking=value". * The following case checks for "-XX:NativeMemoryTracking=value".
* If value is non null, an environmental variable set to this value * If value is non null, an environmental variable set to this value
@ -661,7 +678,6 @@ SetJvmEnvironment(int argc, char **argv) {
* The argument is passed to the JVM, which will check validity. * The argument is passed to the JVM, which will check validity.
* The JVM is responsible for removing the env variable. * The JVM is responsible for removing the env variable.
*/ */
char *arg = argv[i];
if (JLI_StrCCmp(arg, "-XX:NativeMemoryTracking=") == 0) { if (JLI_StrCCmp(arg, "-XX:NativeMemoryTracking=") == 0) {
int retval; int retval;
// get what follows this parameter, include "=" // get what follows this parameter, include "="

View File

@ -88,6 +88,7 @@ JNIEXPORT void JNICALL Java_sun_net_ExtendedOptionsImpl_init
/* SocketFlow fields */ /* SocketFlow fields */
c = (*env)->FindClass(env, "jdk/net/SocketFlow"); c = (*env)->FindClass(env, "jdk/net/SocketFlow");
CHECK_NULL(c);
/* status */ /* status */

View File

@ -201,7 +201,7 @@ Java_sun_nio_ch_DatagramChannelImpl_receive0(JNIEnv *env, jobject this,
} }
if (senderAddr == NULL) { if (senderAddr == NULL) {
jobject isa = NULL; jobject isa = NULL;
int port; int port = 0;
jobject ia = NET_SockaddrToInetAddress(env, (struct sockaddr *)&sa, &port); jobject ia = NET_SockaddrToInetAddress(env, (struct sockaddr *)&sa, &port);
if (ia != NULL) { if (ia != NULL) {
isa = (*env)->NewObject(env, isa_class, isa_ctorID, ia, port); isa = (*env)->NewObject(env, isa_class, isa_ctorID, ia, port);

View File

@ -84,7 +84,7 @@ Java_sun_nio_ch_ServerSocketChannelImpl_accept0(JNIEnv *env, jobject this,
int alloc_len; int alloc_len;
jobject remote_ia = 0; jobject remote_ia = 0;
jobject isa; jobject isa;
jint remote_port; jint remote_port = 0;
NET_AllocSockaddr(&sa, &alloc_len); NET_AllocSockaddr(&sa, &alloc_len);
if (sa == NULL) { if (sa == NULL) {

View File

@ -188,6 +188,7 @@ getJavaIDFromLangID(LANGID langID)
free(elems[index]); free(elems[index]);
} }
} else { } else {
free(ret);
ret = NULL; ret = NULL;
} }

View File

@ -28,7 +28,8 @@ package sun.awt.motif;
import java.nio.CharBuffer; import java.nio.CharBuffer;
import java.nio.ByteBuffer; import java.nio.ByteBuffer;
import java.nio.charset.*; import java.nio.charset.*;
import sun.nio.cs.ext.EUC_TW; import sun.nio.cs.*;
import sun.nio.cs.ext.*;
public abstract class X11CNS11643 extends Charset { public abstract class X11CNS11643 extends Charset {
private final int plane; private final int plane;

View File

@ -26,6 +26,7 @@
package java.util.logging; package java.util.logging;
import java.util.Objects;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.security.AccessController; import java.security.AccessController;
import java.security.PrivilegedAction; import java.security.PrivilegedAction;
@ -165,9 +166,7 @@ public abstract class Handler {
*/ */
public synchronized void setFormatter(Formatter newFormatter) throws SecurityException { public synchronized void setFormatter(Formatter newFormatter) throws SecurityException {
checkPermission(); checkPermission();
// Check for a null pointer: formatter = Objects.requireNonNull(newFormatter);
newFormatter.getClass();
formatter = newFormatter;
} }
/** /**

View File

@ -24,10 +24,12 @@
*/ */
package java.util.logging; package java.util.logging;
import java.time.Instant;
import java.util.*; import java.util.*;
import java.util.concurrent.atomic.AtomicInteger; import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicLong;
import java.io.*; import java.io.*;
import java.time.Clock;
import sun.misc.JavaLangAccess; import sun.misc.JavaLangAccess;
import sun.misc.SharedSecrets; import sun.misc.SharedSecrets;
@ -88,55 +90,94 @@ public class LogRecord implements java.io.Serializable {
private static final ThreadLocal<Integer> threadIds = new ThreadLocal<>(); private static final ThreadLocal<Integer> threadIds = new ThreadLocal<>();
/** /**
* @serial Logging message level * Logging message level
*/ */
private Level level; private Level level;
/** /**
* @serial Sequence number * Sequence number
*/ */
private long sequenceNumber; private long sequenceNumber;
/** /**
* @serial Class that issued logging call * Class that issued logging call
*/ */
private String sourceClassName; private String sourceClassName;
/** /**
* @serial Method that issued logging call * Method that issued logging call
*/ */
private String sourceMethodName; private String sourceMethodName;
/** /**
* @serial Non-localized raw message text * Non-localized raw message text
*/ */
private String message; private String message;
/** /**
* @serial Thread ID for thread that issued logging call. * Thread ID for thread that issued logging call.
*/ */
private int threadID; private int threadID;
/** /**
* @serial Event time in milliseconds since 1970 * The Throwable (if any) associated with log message
*/
private long millis;
/**
* @serial The Throwable (if any) associated with log message
*/ */
private Throwable thrown; private Throwable thrown;
/** /**
* @serial Name of the source Logger. * Name of the source Logger.
*/ */
private String loggerName; private String loggerName;
/** /**
* @serial Resource bundle name to localized log message. * Resource bundle name to localized log message.
*/ */
private String resourceBundleName; private String resourceBundleName;
/**
* Event time.
* @since 1.9
*/
private Instant instant;
/**
* @serialField level Level Logging message level
* @serialField sequenceNumber long Sequence number
* @serialField sourceClassName String Class that issued logging call
* @serialField sourceMethodName String Method that issued logging call
* @serialField message String Non-localized raw message text
* @serialField threadID int Thread ID for thread that issued logging call
* @serialField millis long Truncated event time in milliseconds since 1970
* - calculated as getInstant().toEpochMilli().
* The event time instant can be reconstructed using
* <code>Instant.ofEpochSecond(millis/1000, (millis % 1000) * 1000_000 + nanoAdjustment)</code>
* @serialField nanoAdjustment int Nanoseconds adjustment to the millisecond of
* event time - calculated as getInstant().getNano() % 1000_000
* The event time instant can be reconstructed using
* <code>Instant.ofEpochSecond(millis/1000, (millis % 1000) * 1000_000 + nanoAdjustment)</code>
* <p>
* Since: 1.9
* @serialField thrown Throwable The Throwable (if any) associated with log
* message
* @serialField loggerName String Name of the source Logger
* @serialField resourceBundleName String Resource bundle name to localized
* log message
*/
private static final ObjectStreamField[] serialPersistentFields =
new ObjectStreamField[] {
new ObjectStreamField("level", Level.class),
new ObjectStreamField("sequenceNumber", long.class),
new ObjectStreamField("sourceClassName", String.class),
new ObjectStreamField("sourceMethodName", String.class),
new ObjectStreamField("message", String.class),
new ObjectStreamField("threadID", int.class),
new ObjectStreamField("millis", long.class),
new ObjectStreamField("nanoAdjustment", int.class),
new ObjectStreamField("thrown", Throwable.class),
new ObjectStreamField("loggerName", String.class),
new ObjectStreamField("resourceBundleName", String.class),
};
private transient boolean needToInferCaller; private transient boolean needToInferCaller;
private transient Object parameters[]; private transient Object parameters[];
private transient ResourceBundle resourceBundle; private transient ResourceBundle resourceBundle;
@ -164,7 +205,10 @@ public class LogRecord implements java.io.Serializable {
* The sequence property will be initialized with a new unique value. * The sequence property will be initialized with a new unique value.
* These sequence values are allocated in increasing order within a VM. * These sequence values are allocated in increasing order within a VM.
* <p> * <p>
* The millis property will be initialized to the current time. * Since JDK 1.9, the event time is represented by an {@link Instant}.
* The instant property will be initialized to the {@linkplain
* Instant#now() current instant}, using the best available
* {@linkplain Clock#systemUTC() clock} on the system.
* <p> * <p>
* The thread ID property will be initialized with a unique ID for * The thread ID property will be initialized with a unique ID for
* the current thread. * the current thread.
@ -173,16 +217,15 @@ public class LogRecord implements java.io.Serializable {
* *
* @param level a logging level value * @param level a logging level value
* @param msg the raw non-localized logging message (may be null) * @param msg the raw non-localized logging message (may be null)
* @see java.time.Clock#systemUTC()
*/ */
public LogRecord(Level level, String msg) { public LogRecord(Level level, String msg) {
// Make sure level isn't null, by calling random method. this.level = Objects.requireNonNull(level);
level.getClass();
this.level = level;
message = msg; message = msg;
// Assign a thread ID and a unique sequence number. // Assign a thread ID and a unique sequence number.
sequenceNumber = globalSequenceNumber.getAndIncrement(); sequenceNumber = globalSequenceNumber.getAndIncrement();
threadID = defaultThreadID(); threadID = defaultThreadID();
millis = System.currentTimeMillis(); instant = Instant.now();
needToInferCaller = true; needToInferCaller = true;
} }
@ -418,21 +461,63 @@ public class LogRecord implements java.io.Serializable {
} }
/** /**
* Get event time in milliseconds since 1970. * Get truncated event time in milliseconds since 1970.
* *
* @return event time in millis since 1970 * @return truncated event time in millis since 1970
*
* @implSpec This is equivalent to calling
* {@link #getInstant() getInstant().toEpochMilli()}.
*
* @deprecated To get the full nanosecond resolution event time,
* use {@link #getInstant()}.
*
* @see #getInstant()
*/ */
@Deprecated
public long getMillis() { public long getMillis() {
return millis; return instant.toEpochMilli();
} }
/** /**
* Set event time. * Set event time.
* *
* @param millis event time in millis since 1970 * @param millis event time in millis since 1970.
*
* @implSpec This is equivalent to calling
* {@link #setInstant(java.time.Instant)
* setInstant(Instant.ofEpochMilli(millis))}.
*
* @deprecated To set event time with nanosecond resolution,
* use {@link #setInstant(java.time.Instant)}.
*
* @see #setInstant(java.time.Instant)
*/ */
@Deprecated
public void setMillis(long millis) { public void setMillis(long millis) {
this.millis = millis; this.instant = Instant.ofEpochMilli(millis);
}
/**
* Gets the instant that the event occurred.
*
* @return the instant that the event occurred.
*
* @since 1.9
*/
public Instant getInstant() {
return instant;
}
/**
* Sets the instant that the event occurred.
*
* @param instant the instant that the event occurred.
*
* @throws NullPointerException if {@code instant} is null.
* @since 1.9
*/
public void setInstant(Instant instant) {
this.instant = Objects.requireNonNull(instant);
} }
/** /**
@ -459,7 +544,7 @@ public class LogRecord implements java.io.Serializable {
private static final long serialVersionUID = 5372048053134512534L; private static final long serialVersionUID = 5372048053134512534L;
/** /**
* @serialData Default fields, followed by a two byte version number * @serialData Serialized fields, followed by a two byte version number
* (major byte, followed by minor byte), followed by information on * (major byte, followed by minor byte), followed by information on
* the log record parameter array. If there is no parameter array, * the log record parameter array. If there is no parameter array,
* then -1 is written. If there is a parameter array (possible of zero * then -1 is written. If there is a parameter array (possible of zero
@ -469,8 +554,20 @@ public class LogRecord implements java.io.Serializable {
* is written. * is written.
*/ */
private void writeObject(ObjectOutputStream out) throws IOException { private void writeObject(ObjectOutputStream out) throws IOException {
// We have to call defaultWriteObject first. // We have to write serialized fields first.
out.defaultWriteObject(); ObjectOutputStream.PutField pf = out.putFields();
pf.put("level", level);
pf.put("sequenceNumber", sequenceNumber);
pf.put("sourceClassName", sourceClassName);
pf.put("sourceMethodName", sourceMethodName);
pf.put("message", message);
pf.put("threadID", threadID);
pf.put("millis", instant.toEpochMilli());
pf.put("nanoAdjustment", instant.getNano() % 1000_000);
pf.put("thrown", thrown);
pf.put("loggerName", loggerName);
pf.put("resourceBundleName", resourceBundleName);
out.writeFields();
// Write our version number. // Write our version number.
out.writeByte(1); out.writeByte(1);
@ -488,8 +585,21 @@ public class LogRecord implements java.io.Serializable {
private void readObject(ObjectInputStream in) private void readObject(ObjectInputStream in)
throws IOException, ClassNotFoundException { throws IOException, ClassNotFoundException {
// We have to call defaultReadObject first. // We have to read serialized fields first.
in.defaultReadObject(); ObjectInputStream.GetField gf = in.readFields();
level = (Level) gf.get("level", null);
sequenceNumber = gf.get("sequenceNumber", 0L);
sourceClassName = (String) gf.get("sourceClassName", null);
sourceMethodName = (String) gf.get("sourceMethodName", null);
message = (String) gf.get("message", null);
threadID = gf.get("threadID", 0);
long millis = gf.get("millis", 0L);
int nanoOfMilli = gf.get("nanoAdjustment", 0);
instant = Instant.ofEpochSecond(
millis / 1000L, (millis % 1000L) * 1000_000L + nanoOfMilli);
thrown = (Throwable) gf.get("thrown", null);
loggerName = (String) gf.get("loggerName", null);
resourceBundleName = (String) gf.get("resourceBundleName", null);
// Read version number. // Read version number.
byte major = in.readByte(); byte major = in.readByte();

View File

@ -33,6 +33,7 @@ import java.util.ArrayList;
import java.util.Iterator; import java.util.Iterator;
import java.util.Locale; import java.util.Locale;
import java.util.MissingResourceException; import java.util.MissingResourceException;
import java.util.Objects;
import java.util.ResourceBundle; import java.util.ResourceBundle;
import java.util.concurrent.CopyOnWriteArrayList; import java.util.concurrent.CopyOnWriteArrayList;
import java.util.function.Supplier; import java.util.function.Supplier;
@ -1746,8 +1747,7 @@ public class Logger {
* does not have LoggingPermission("control"). * does not have LoggingPermission("control").
*/ */
public void addHandler(Handler handler) throws SecurityException { public void addHandler(Handler handler) throws SecurityException {
// Check for null handler Objects.requireNonNull(handler);
handler.getClass();
checkPermission(); checkPermission();
handlers.add(handler); handlers.add(handler);
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -27,8 +27,9 @@
package java.util.logging; package java.util.logging;
import java.io.*; import java.io.*;
import java.text.*; import java.time.LocalDateTime;
import java.util.Date; import java.time.ZoneId;
import java.time.ZonedDateTime;
import sun.util.logging.LoggingSupport; import sun.util.logging.LoggingSupport;
/** /**
@ -59,8 +60,8 @@ import sun.util.logging.LoggingSupport;
public class SimpleFormatter extends Formatter { public class SimpleFormatter extends Formatter {
// format string for printing the log record // format string for printing the log record
private static final String format = LoggingSupport.getSimpleFormat(); private final String format = LoggingSupport.getSimpleFormat();
private final Date dat = new Date(); private final ZoneId zoneId = ZoneId.systemDefault();
/** /**
* Format the given LogRecord. * Format the given LogRecord.
@ -79,8 +80,9 @@ public class SimpleFormatter extends Formatter {
* java.util.Formatter} format string specified in the * java.util.Formatter} format string specified in the
* {@code java.util.logging.SimpleFormatter.format} property * {@code java.util.logging.SimpleFormatter.format} property
* or the default format.</li> * or the default format.</li>
* <li>{@code date} - a {@link Date} object representing * <li>{@code date} - a {@link ZonedDateTime} object representing
* {@linkplain LogRecord#getMillis event time} of the log record.</li> * {@linkplain LogRecord#getInstant() event time} of the log record
* in the {@link ZoneId#systemDefault()} system time zone.</li>
* <li>{@code source} - a string representing the caller, if available; * <li>{@code source} - a string representing the caller, if available;
* otherwise, the logger's name.</li> * otherwise, the logger's name.</li>
* <li>{@code logger} - the logger's name.</li> * <li>{@code logger} - the logger's name.</li>
@ -129,6 +131,16 @@ public class SimpleFormatter extends Formatter {
* Mar 22, 2011 1:11:31 PM MyClass fatal * Mar 22, 2011 1:11:31 PM MyClass fatal
* SEVERE: several message with an exception * SEVERE: several message with an exception
* </pre></li> * </pre></li>
* <li> {@code java.util.logging.SimpleFormatter.format="%1$tb %1$td, %1$tY %1$tl:%1$tM:%1$tS.%1$tN %1$Tp %2$s%n%4$s: %5$s%6$s%n"}
* <p>Since JDK 1.9, {@code java.util.logging} uses {@link
* java.time.Clock#systemUTC() java.time} to create more precise time
* stamps.
* The format above can be used to add a {@code .%1$tN} to the
* date/time formatting so that nanoseconds will also be printed:
* <pre>
* Feb 06, 2015 5:33:10.279216000 PM example.Main main
* INFO: This is a test
* </pre></li>
* </ul> * </ul>
* <p>This method can also be overridden in a subclass. * <p>This method can also be overridden in a subclass.
* It is recommended to use the {@link Formatter#formatMessage} * It is recommended to use the {@link Formatter#formatMessage}
@ -137,8 +149,10 @@ public class SimpleFormatter extends Formatter {
* @param record the log record to be formatted. * @param record the log record to be formatted.
* @return a formatted log record * @return a formatted log record
*/ */
@Override
public synchronized String format(LogRecord record) { public synchronized String format(LogRecord record) {
dat.setTime(record.getMillis()); ZonedDateTime zdt = ZonedDateTime.ofInstant(
record.getInstant(), zoneId);
String source; String source;
if (record.getSourceClassName() != null) { if (record.getSourceClassName() != null) {
source = record.getSourceClassName(); source = record.getSourceClassName();
@ -159,7 +173,7 @@ public class SimpleFormatter extends Formatter {
throwable = sw.toString(); throwable = sw.toString();
} }
return String.format(format, return String.format(format,
dat, zdt,
source, source,
record.getLoggerName(), record.getLoggerName(),
record.getLevel().getLocalizedLevelName(), record.getLevel().getLocalizedLevelName(),

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -26,8 +26,9 @@
package java.util.logging; package java.util.logging;
import java.io.*;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.time.Instant;
import java.time.format.DateTimeFormatter;
import java.util.*; import java.util.*;
/** /**
@ -40,11 +41,70 @@ import java.util.*;
* but it is recommended that it normally be used with UTF-8. The * but it is recommended that it normally be used with UTF-8. The
* character encoding can be set on the output Handler. * character encoding can be set on the output Handler.
* *
* @implSpec Since JDK 1.9, instances of {@linkplain LogRecord} contain
* an {@link LogRecord#getInstant() Instant} which can have nanoseconds below
* the millisecond resolution.
* The DTD specification has been updated to allow for an optional
* {@code <nanos>} element. By default, the XMLFormatter will compute the
* nanosecond adjustment below the millisecond resolution (using
* {@code LogRecord.getInstant().getNano() % 1000_000}) - and if this is not 0,
* this adjustment value will be printed in the new {@code <nanos>} element.
* The event instant can then be reconstructed using
* {@code Instant.ofEpochSecond(millis/1000L, (millis % 1000L) * 1000_000L + nanos)}
* where {@code millis} and {@code nanos} represent the numbers serialized in
* the {@code <millis>} and {@code <nanos>} elements, respectively.
* <br>
* The {@code <date>} element will now contain the whole instant as formatted
* by the {@link DateTimeFormatter#ISO_INSTANT DateTimeFormatter.ISO_INSTANT}
* formatter.
* <p>
* For compatibility with old parsers, XMLFormatters can
* be configured to revert to the old format by specifying a
* {@code <xml-formatter-fully-qualified-class-name>.useInstant = false}
* {@linkplain LogManager#getProperty(java.lang.String) property} in the
* logging configuration. When {@code useInstant} is {@code false}, the old
* formatting will be preserved. When {@code useInstant} is {@code true}
* (the default), the {@code <nanos>} element will be printed and the
* {@code <date>} element will contain the {@linkplain
* DateTimeFormatter#ISO_INSTANT formatted} instant.
* <p>
* For instance, in order to configure plain instances of XMLFormatter to omit
* the new {@code <nano>} element,
* {@code java.util.logging.XMLFormatter.useInstant = false} can be specified
* in the logging configuration.
*
* @since 1.4 * @since 1.4
*/ */
public class XMLFormatter extends Formatter { public class XMLFormatter extends Formatter {
private LogManager manager = LogManager.getLogManager(); private final LogManager manager = LogManager.getLogManager();
private final boolean useInstant;
/**
* Creates a new instance of XMLFormatter.
*
* @implSpec
* Since JDK 1.9, the XMLFormatter will print out the record {@linkplain
* LogRecord#getInstant() event time} as an Instant. This instant
* has the best resolution available on the system. The {@code <date>}
* element will contain the instant as formatted by the {@link
* DateTimeFormatter#ISO_INSTANT}.
* In addition, an optional {@code <nanos>} element containing a
* nanosecond adjustment will be printed if the instant contains some
* nanoseconds below the millisecond resolution.
* <p>
* This new behavior can be turned off, and the old formatting restored,
* by specifying a property in the {@linkplain
* LogManager#getProperty(java.lang.String) logging configuration}.
* If {@code LogManager.getLogManager().getProperty(
* this.getClass().getName()+".useInstant")} is {@code "false"} or
* {@code "0"}, the old formatting will be restored.
*/
public XMLFormatter() {
useInstant = (manager == null)
|| manager.getBooleanProperty(
this.getClass().getName()+".useInstant", true);
}
// Append a two digit number. // Append a two digit number.
private void a2(StringBuilder sb, int x) { private void a2(StringBuilder sb, int x) {
@ -102,18 +162,35 @@ public class XMLFormatter extends Formatter {
* @param record the log record to be formatted. * @param record the log record to be formatted.
* @return a formatted log record * @return a formatted log record
*/ */
@Override
public String format(LogRecord record) { public String format(LogRecord record) {
StringBuilder sb = new StringBuilder(500); StringBuilder sb = new StringBuilder(500);
sb.append("<record>\n"); sb.append("<record>\n");
final Instant instant = record.getInstant();
sb.append(" <date>"); sb.append(" <date>");
appendISO8601(sb, record.getMillis()); if (useInstant) {
// If useInstant is true - we will print the instant in the
// date field, using the ISO_INSTANT formatter.
DateTimeFormatter.ISO_INSTANT.formatTo(instant, sb);
} else {
// If useInstant is false - we will keep the 'old' formating
appendISO8601(sb, instant.toEpochMilli());
}
sb.append("</date>\n"); sb.append("</date>\n");
sb.append(" <millis>"); sb.append(" <millis>");
sb.append(record.getMillis()); sb.append(instant.toEpochMilli());
sb.append("</millis>\n"); sb.append("</millis>\n");
final int nanoAdjustment = instant.getNano() % 1000_000;
if (useInstant && nanoAdjustment != 0) {
sb.append(" <nanos>");
sb.append(nanoAdjustment);
sb.append("</nanos>\n");
}
sb.append(" <sequence>"); sb.append(" <sequence>");
sb.append(record.getSequenceNumber()); sb.append(record.getSequenceNumber());
sb.append("</sequence>\n"); sb.append("</sequence>\n");
@ -223,6 +300,7 @@ public class XMLFormatter extends Formatter {
* @param h The target handler (can be null) * @param h The target handler (can be null)
* @return a valid XML string * @return a valid XML string
*/ */
@Override
public String getHead(Handler h) { public String getHead(Handler h) {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
String encoding; String encoding;
@ -251,6 +329,7 @@ public class XMLFormatter extends Formatter {
sb.append(encoding); sb.append(encoding);
sb.append("\""); sb.append("\"");
sb.append(" standalone=\"no\"?>\n"); sb.append(" standalone=\"no\"?>\n");
sb.append("<!DOCTYPE log SYSTEM \"logger.dtd\">\n"); sb.append("<!DOCTYPE log SYSTEM \"logger.dtd\">\n");
sb.append("<log>\n"); sb.append("<log>\n");
return sb.toString(); return sb.toString();
@ -262,6 +341,7 @@ public class XMLFormatter extends Formatter {
* @param h The target handler (can be null) * @param h The target handler (can be null)
* @return a valid XML string * @return a valid XML string
*/ */
@Override
public String getTail(Handler h) { public String getTail(Handler h) {
return "</log>\n"; return "</log>\n";
} }

View File

@ -45,7 +45,7 @@ import java.lang.management.PlatformManagedObject;
* All methods throw a {@code NullPointerException} if any input argument is * All methods throw a {@code NullPointerException} if any input argument is
* {@code null} unless it's stated otherwise. * {@code null} unless it's stated otherwise.
* *
* @see ManagementFactory#getPlatformMXBeans(Class) * @see java.lang.management.ManagementFactory#getPlatformMXBeans(Class)
*/ */
@jdk.Exported @jdk.Exported
public interface HotSpotDiagnosticMXBean extends PlatformManagedObject { public interface HotSpotDiagnosticMXBean extends PlatformManagedObject {

View File

@ -31,12 +31,13 @@ import sun.management.ThreadInfoCompositeData;
import static java.lang.Thread.State.*; import static java.lang.Thread.State.*;
/** /**
* Thread information. <tt>ThreadInfo</tt> contains the information * Thread information. {@code ThreadInfo} contains the information
* about a thread including: * about a thread including:
* <h3>General thread information</h3> * <h3>General thread information</h3>
* <ul> * <ul>
* <li>Thread ID.</li> * <li>Thread ID.</li>
* <li>Name of the thread.</li> * <li>Name of the thread.</li>
* <li>Whether a thread is a daemon thread</li>
* </ul> * </ul>
* *
* <h3>Execution information</h3> * <h3>Execution information</h3>
@ -57,6 +58,7 @@ import static java.lang.Thread.State.*;
* <li>List of object monitors locked by the thread.</li> * <li>List of object monitors locked by the thread.</li>
* <li>List of <a href="LockInfo.html#OwnableSynchronizer"> * <li>List of <a href="LockInfo.html#OwnableSynchronizer">
* ownable synchronizers</a> locked by the thread.</li> * ownable synchronizers</a> locked by the thread.</li>
* <li>Thread priority</li>
* </ul> * </ul>
* *
* <h4><a name="SyncStats">Synchronization Statistics</a></h4> * <h4><a name="SyncStats">Synchronization Statistics</a></h4>
@ -78,7 +80,7 @@ import static java.lang.Thread.State.*;
* the system, not for synchronization control. * the system, not for synchronization control.
* *
* <h4>MXBean Mapping</h4> * <h4>MXBean Mapping</h4>
* <tt>ThreadInfo</tt> is mapped to a {@link CompositeData CompositeData} * {@code ThreadInfo} is mapped to a {@link CompositeData CompositeData}
* with attributes as specified in * with attributes as specified in
* the {@link #from from} method. * the {@link #from from} method.
* *
@ -100,9 +102,11 @@ public class ThreadInfo {
private String lockName; private String lockName;
private long lockOwnerId; private long lockOwnerId;
private String lockOwnerName; private String lockOwnerName;
private boolean daemon;
private boolean inNative; private boolean inNative;
private boolean suspended; private boolean suspended;
private Thread.State threadState; private Thread.State threadState;
private int priority;
private StackTraceElement[] stackTrace; private StackTraceElement[] stackTrace;
private MonitorInfo[] lockedMonitors; private MonitorInfo[] lockedMonitors;
private LockInfo[] lockedSynchronizers; private LockInfo[] lockedSynchronizers;
@ -229,6 +233,8 @@ public class ThreadInfo {
this.blockedTime = blockedTime; this.blockedTime = blockedTime;
this.waitedCount = waitedCount; this.waitedCount = waitedCount;
this.waitedTime = waitedTime; this.waitedTime = waitedTime;
this.daemon = t.isDaemon();
this.priority = t.getPriority();
if (lockObj == null) { if (lockObj == null) {
this.lock = null; this.lock = null;
@ -256,7 +262,7 @@ public class ThreadInfo {
} }
/* /*
* Constructs a <tt>ThreadInfo</tt> object from a * Constructs a {@code ThreadInfo} object from a
* {@link CompositeData CompositeData}. * {@link CompositeData CompositeData}.
*/ */
private ThreadInfo(CompositeData cd) { private ThreadInfo(CompositeData cd) {
@ -277,7 +283,7 @@ public class ThreadInfo {
stackTrace = ticd.stackTrace(); stackTrace = ticd.stackTrace();
// 6.0 attributes // 6.0 attributes
if (ticd.isCurrentVersion()) { if (ticd.hasV6()) {
lock = ticd.lockInfo(); lock = ticd.lockInfo();
lockedMonitors = ticd.lockedMonitors(); lockedMonitors = ticd.lockedMonitors();
lockedSynchronizers = ticd.lockedSynchronizers(); lockedSynchronizers = ticd.lockedSynchronizers();
@ -300,10 +306,20 @@ public class ThreadInfo {
lockedMonitors = EMPTY_MONITORS; lockedMonitors = EMPTY_MONITORS;
lockedSynchronizers = EMPTY_SYNCS; lockedSynchronizers = EMPTY_SYNCS;
} }
// 9.0 attributes
if (ticd.isCurrentVersion()) {
daemon = ticd.isDaemon();
priority = ticd.getPriority();
} else {
// Not ideal, but unclear what else we can do.
daemon = false;
priority = Thread.NORM_PRIORITY;
}
} }
/** /**
* Returns the ID of the thread associated with this <tt>ThreadInfo</tt>. * Returns the ID of the thread associated with this {@code ThreadInfo}.
* *
* @return the ID of the associated thread. * @return the ID of the associated thread.
*/ */
@ -312,7 +328,7 @@ public class ThreadInfo {
} }
/** /**
* Returns the name of the thread associated with this <tt>ThreadInfo</tt>. * Returns the name of the thread associated with this {@code ThreadInfo}.
* *
* @return the name of the associated thread. * @return the name of the associated thread.
*/ */
@ -321,9 +337,9 @@ public class ThreadInfo {
} }
/** /**
* Returns the state of the thread associated with this <tt>ThreadInfo</tt>. * Returns the state of the thread associated with this {@code ThreadInfo}.
* *
* @return <tt>Thread.State</tt> of the associated thread. * @return {@code Thread.State} of the associated thread.
*/ */
public Thread.State getThreadState() { public Thread.State getThreadState() {
return threadState; return threadState;
@ -331,13 +347,13 @@ public class ThreadInfo {
/** /**
* Returns the approximate accumulated elapsed time (in milliseconds) * Returns the approximate accumulated elapsed time (in milliseconds)
* that the thread associated with this <tt>ThreadInfo</tt> * that the thread associated with this {@code ThreadInfo}
* has blocked to enter or reenter a monitor * has blocked to enter or reenter a monitor
* since thread contention monitoring is enabled. * since thread contention monitoring is enabled.
* I.e. the total accumulated time the thread has been in the * I.e. the total accumulated time the thread has been in the
* {@link java.lang.Thread.State#BLOCKED BLOCKED} state since thread * {@link java.lang.Thread.State#BLOCKED BLOCKED} state since thread
* contention monitoring was last enabled. * contention monitoring was last enabled.
* This method returns <tt>-1</tt> if thread contention monitoring * This method returns {@code -1} if thread contention monitoring
* is disabled. * is disabled.
* *
* <p>The Java virtual machine may measure the time with a high * <p>The Java virtual machine may measure the time with a high
@ -345,8 +361,8 @@ public class ThreadInfo {
* the thread contention monitoring is reenabled. * the thread contention monitoring is reenabled.
* *
* @return the approximate accumulated elapsed time in milliseconds * @return the approximate accumulated elapsed time in milliseconds
* that a thread entered the <tt>BLOCKED</tt> state; * that a thread entered the {@code BLOCKED} state;
* <tt>-1</tt> if thread contention monitoring is disabled. * {@code -1} if thread contention monitoring is disabled.
* *
* @throws java.lang.UnsupportedOperationException if the Java * @throws java.lang.UnsupportedOperationException if the Java
* virtual machine does not support this operation. * virtual machine does not support this operation.
@ -360,13 +376,13 @@ public class ThreadInfo {
/** /**
* Returns the total number of times that * Returns the total number of times that
* the thread associated with this <tt>ThreadInfo</tt> * the thread associated with this {@code ThreadInfo}
* blocked to enter or reenter a monitor. * blocked to enter or reenter a monitor.
* I.e. the number of times a thread has been in the * I.e. the number of times a thread has been in the
* {@link java.lang.Thread.State#BLOCKED BLOCKED} state. * {@link java.lang.Thread.State#BLOCKED BLOCKED} state.
* *
* @return the total number of times that the thread * @return the total number of times that the thread
* entered the <tt>BLOCKED</tt> state. * entered the {@code BLOCKED} state.
*/ */
public long getBlockedCount() { public long getBlockedCount() {
return blockedCount; return blockedCount;
@ -374,14 +390,14 @@ public class ThreadInfo {
/** /**
* Returns the approximate accumulated elapsed time (in milliseconds) * Returns the approximate accumulated elapsed time (in milliseconds)
* that the thread associated with this <tt>ThreadInfo</tt> * that the thread associated with this {@code ThreadInfo}
* has waited for notification * has waited for notification
* since thread contention monitoring is enabled. * since thread contention monitoring is enabled.
* I.e. the total accumulated time the thread has been in the * I.e. the total accumulated time the thread has been in the
* {@link java.lang.Thread.State#WAITING WAITING} * {@link java.lang.Thread.State#WAITING WAITING}
* or {@link java.lang.Thread.State#TIMED_WAITING TIMED_WAITING} state * or {@link java.lang.Thread.State#TIMED_WAITING TIMED_WAITING} state
* since thread contention monitoring is enabled. * since thread contention monitoring is enabled.
* This method returns <tt>-1</tt> if thread contention monitoring * This method returns {@code -1} if thread contention monitoring
* is disabled. * is disabled.
* *
* <p>The Java virtual machine may measure the time with a high * <p>The Java virtual machine may measure the time with a high
@ -389,9 +405,9 @@ public class ThreadInfo {
* the thread contention monitoring is reenabled. * the thread contention monitoring is reenabled.
* *
* @return the approximate accumulated elapsed time in milliseconds * @return the approximate accumulated elapsed time in milliseconds
* that a thread has been in the <tt>WAITING</tt> or * that a thread has been in the {@code WAITING} or
* <tt>TIMED_WAITING</tt> state; * {@code TIMED_WAITING} state;
* <tt>-1</tt> if thread contention monitoring is disabled. * {@code -1} if thread contention monitoring is disabled.
* *
* @throws java.lang.UnsupportedOperationException if the Java * @throws java.lang.UnsupportedOperationException if the Java
* virtual machine does not support this operation. * virtual machine does not support this operation.
@ -405,29 +421,29 @@ public class ThreadInfo {
/** /**
* Returns the total number of times that * Returns the total number of times that
* the thread associated with this <tt>ThreadInfo</tt> * the thread associated with this {@code ThreadInfo}
* waited for notification. * waited for notification.
* I.e. the number of times that a thread has been * I.e. the number of times that a thread has been
* in the {@link java.lang.Thread.State#WAITING WAITING} * in the {@link java.lang.Thread.State#WAITING WAITING}
* or {@link java.lang.Thread.State#TIMED_WAITING TIMED_WAITING} state. * or {@link java.lang.Thread.State#TIMED_WAITING TIMED_WAITING} state.
* *
* @return the total number of times that the thread * @return the total number of times that the thread
* was in the <tt>WAITING</tt> or <tt>TIMED_WAITING</tt> state. * was in the {@code WAITING} or {@code TIMED_WAITING} state.
*/ */
public long getWaitedCount() { public long getWaitedCount() {
return waitedCount; return waitedCount;
} }
/** /**
* Returns the <tt>LockInfo</tt> of an object for which * Returns the {@code LockInfo} of an object for which
* the thread associated with this <tt>ThreadInfo</tt> * the thread associated with this {@code ThreadInfo}
* is blocked waiting. * is blocked waiting.
* A thread can be blocked waiting for one of the following: * A thread can be blocked waiting for one of the following:
* <ul> * <ul>
* <li>an object monitor to be acquired for entering or reentering * <li>an object monitor to be acquired for entering or reentering
* a synchronization block/method. * a synchronization block/method.
* <br>The thread is in the {@link java.lang.Thread.State#BLOCKED BLOCKED} * <br>The thread is in the {@link java.lang.Thread.State#BLOCKED BLOCKED}
* state waiting to enter the <tt>synchronized</tt> statement * state waiting to enter the {@code synchronized} statement
* or method. * or method.
* </li> * </li>
* <li>an object monitor to be notified by another thread. * <li>an object monitor to be notified by another thread.
@ -448,11 +464,11 @@ public class ThreadInfo {
* or a {@link java.util.concurrent.locks.Condition Condition}.</li> * or a {@link java.util.concurrent.locks.Condition Condition}.</li>
* </ul> * </ul>
* *
* <p>This method returns <tt>null</tt> if the thread is not in any of * <p>This method returns {@code null} if the thread is not in any of
* the above conditions. * the above conditions.
* *
* @return <tt>LockInfo</tt> of an object for which the thread * @return {@code LockInfo} of an object for which the thread
* is blocked waiting if any; <tt>null</tt> otherwise. * is blocked waiting if any; {@code null} otherwise.
* @since 1.6 * @since 1.6
*/ */
public LockInfo getLockInfo() { public LockInfo getLockInfo() {
@ -462,19 +478,19 @@ public class ThreadInfo {
/** /**
* Returns the {@link LockInfo#toString string representation} * Returns the {@link LockInfo#toString string representation}
* of an object for which the thread associated with this * of an object for which the thread associated with this
* <tt>ThreadInfo</tt> is blocked waiting. * {@code ThreadInfo} is blocked waiting.
* This method is equivalent to calling: * This method is equivalent to calling:
* <blockquote> * <blockquote>
* <pre> * <pre>
* getLockInfo().toString() * getLockInfo().toString()
* </pre></blockquote> * </pre></blockquote>
* *
* <p>This method will return <tt>null</tt> if this thread is not blocked * <p>This method will return {@code null} if this thread is not blocked
* waiting for any object or if the object is not owned by any thread. * waiting for any object or if the object is not owned by any thread.
* *
* @return the string representation of the object on which * @return the string representation of the object on which
* the thread is blocked if any; * the thread is blocked if any;
* <tt>null</tt> otherwise. * {@code null} otherwise.
* *
* @see #getLockInfo * @see #getLockInfo
*/ */
@ -484,14 +500,14 @@ public class ThreadInfo {
/** /**
* Returns the ID of the thread which owns the object * Returns the ID of the thread which owns the object
* for which the thread associated with this <tt>ThreadInfo</tt> * for which the thread associated with this {@code ThreadInfo}
* is blocked waiting. * is blocked waiting.
* This method will return <tt>-1</tt> if this thread is not blocked * This method will return {@code -1} if this thread is not blocked
* waiting for any object or if the object is not owned by any thread. * waiting for any object or if the object is not owned by any thread.
* *
* @return the thread ID of the owner thread of the object * @return the thread ID of the owner thread of the object
* this thread is blocked on; * this thread is blocked on;
* <tt>-1</tt> if this thread is not blocked * {@code -1} if this thread is not blocked
* or if the object is not owned by any thread. * or if the object is not owned by any thread.
* *
* @see #getLockInfo * @see #getLockInfo
@ -502,14 +518,14 @@ public class ThreadInfo {
/** /**
* Returns the name of the thread which owns the object * Returns the name of the thread which owns the object
* for which the thread associated with this <tt>ThreadInfo</tt> * for which the thread associated with this {@code ThreadInfo}
* is blocked waiting. * is blocked waiting.
* This method will return <tt>null</tt> if this thread is not blocked * This method will return {@code null} if this thread is not blocked
* waiting for any object or if the object is not owned by any thread. * waiting for any object or if the object is not owned by any thread.
* *
* @return the name of the thread that owns the object * @return the name of the thread that owns the object
* this thread is blocked on; * this thread is blocked on;
* <tt>null</tt> if this thread is not blocked * {@code null} if this thread is not blocked
* or if the object is not owned by any thread. * or if the object is not owned by any thread.
* *
* @see #getLockInfo * @see #getLockInfo
@ -520,7 +536,7 @@ public class ThreadInfo {
/** /**
* Returns the stack trace of the thread * Returns the stack trace of the thread
* associated with this <tt>ThreadInfo</tt>. * associated with this {@code ThreadInfo}.
* If no stack trace was requested for this thread info, this method * If no stack trace was requested for this thread info, this method
* will return a zero-length array. * will return a zero-length array.
* If the returned array is of non-zero length then the first element of * If the returned array is of non-zero length then the first element of
@ -532,41 +548,66 @@ public class ThreadInfo {
* <p>Some Java virtual machines may, under some circumstances, omit one * <p>Some Java virtual machines may, under some circumstances, omit one
* or more stack frames from the stack trace. In the extreme case, * or more stack frames from the stack trace. In the extreme case,
* a virtual machine that has no stack trace information concerning * a virtual machine that has no stack trace information concerning
* the thread associated with this <tt>ThreadInfo</tt> * the thread associated with this {@code ThreadInfo}
* is permitted to return a zero-length array from this method. * is permitted to return a zero-length array from this method.
* *
* @return an array of <tt>StackTraceElement</tt> objects of the thread. * @return an array of {@code StackTraceElement} objects of the thread.
*/ */
public StackTraceElement[] getStackTrace() { public StackTraceElement[] getStackTrace() {
return stackTrace; return stackTrace;
} }
/** /**
* Tests if the thread associated with this <tt>ThreadInfo</tt> * Tests if the thread associated with this {@code ThreadInfo}
* is suspended. This method returns <tt>true</tt> if * is suspended. This method returns {@code true} if
* {@link Thread#suspend} has been called. * {@link Thread#suspend} has been called.
* *
* @return <tt>true</tt> if the thread is suspended; * @return {@code true} if the thread is suspended;
* <tt>false</tt> otherwise. * {@code false} otherwise.
*/ */
public boolean isSuspended() { public boolean isSuspended() {
return suspended; return suspended;
} }
/** /**
* Tests if the thread associated with this <tt>ThreadInfo</tt> * Tests if the thread associated with this {@code ThreadInfo}
* is executing native code via the Java Native Interface (JNI). * is executing native code via the Java Native Interface (JNI).
* The JNI native code does not include * The JNI native code does not include
* the virtual machine support code or the compiled native * the virtual machine support code or the compiled native
* code generated by the virtual machine. * code generated by the virtual machine.
* *
* @return <tt>true</tt> if the thread is executing native code; * @return {@code true} if the thread is executing native code;
* <tt>false</tt> otherwise. * {@code false} otherwise.
*/ */
public boolean isInNative() { public boolean isInNative() {
return inNative; return inNative;
} }
/**
* Tests if the thread associated with this {@code ThreadInfo} is
* a {@linkplain Thread#isDaemon daemon thread}.
*
* @return {@code true} if the thread is a daemon thread,
* {@code false} otherwise.
* @see Thread#isDaemon
* @since 1.9
*/
public boolean isDaemon() {
return daemon;
}
/**
* Returns the {@linkplain Thread#getPriority() thread priority} of the
* thread associated with this {@code ThreadInfo}.
*
* @return The priority of the thread associated with this
* {@code ThreadInfo}.
* @since 1.9
*/
public int getPriority() {
return priority;
}
/** /**
* Returns a string representation of this thread info. * Returns a string representation of this thread info.
* The format of this string depends on the implementation. * The format of this string depends on the implementation.
@ -580,6 +621,8 @@ public class ThreadInfo {
*/ */
public String toString() { public String toString() {
StringBuilder sb = new StringBuilder("\"" + getThreadName() + "\"" + StringBuilder sb = new StringBuilder("\"" + getThreadName() + "\"" +
(daemon ? " daemon" : "") +
" prio=" + priority +
" Id=" + getThreadId() + " " + " Id=" + getThreadId() + " " +
getThreadState()); getThreadState());
if (getLockName() != null) { if (getLockName() != null) {
@ -647,9 +690,9 @@ public class ThreadInfo {
private static final int MAX_FRAMES = 8; private static final int MAX_FRAMES = 8;
/** /**
* Returns a <tt>ThreadInfo</tt> object represented by the * Returns a {@code ThreadInfo} object represented by the
* given <tt>CompositeData</tt>. * given {@code CompositeData}.
* The given <tt>CompositeData</tt> must contain the following attributes * The given {@code CompositeData} must contain the following attributes
* unless otherwise specified below: * unless otherwise specified below:
* <blockquote> * <blockquote>
* <table border summary="The attributes and their types the given CompositeData contains"> * <table border summary="The attributes and their types the given CompositeData contains">
@ -659,67 +702,67 @@ public class ThreadInfo {
* </tr> * </tr>
* <tr> * <tr>
* <td>threadId</td> * <td>threadId</td>
* <td><tt>java.lang.Long</tt></td> * <td>{@code java.lang.Long}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>threadName</td> * <td>threadName</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>threadState</td> * <td>threadState</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>suspended</td> * <td>suspended</td>
* <td><tt>java.lang.Boolean</tt></td> * <td>{@code java.lang.Boolean}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>inNative</td> * <td>inNative</td>
* <td><tt>java.lang.Boolean</tt></td> * <td>{@code java.lang.Boolean}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>blockedCount</td> * <td>blockedCount</td>
* <td><tt>java.lang.Long</tt></td> * <td>{@code java.lang.Long}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>blockedTime</td> * <td>blockedTime</td>
* <td><tt>java.lang.Long</tt></td> * <td>{@code java.lang.Long}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>waitedCount</td> * <td>waitedCount</td>
* <td><tt>java.lang.Long</tt></td> * <td>{@code java.lang.Long}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>waitedTime</td> * <td>waitedTime</td>
* <td><tt>java.lang.Long</tt></td> * <td>{@code java.lang.Long}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>lockInfo</td> * <td>lockInfo</td>
* <td><tt>javax.management.openmbean.CompositeData</tt> * <td>{@code javax.management.openmbean.CompositeData}
* - the mapped type for {@link LockInfo} as specified in the * - the mapped type for {@link LockInfo} as specified in the
* {@link LockInfo#from} method. * {@link LockInfo#from} method.
* <p> * <p>
* If <tt>cd</tt> does not contain this attribute, * If {@code cd} does not contain this attribute,
* the <tt>LockInfo</tt> object will be constructed from * the {@code LockInfo} object will be constructed from
* the value of the <tt>lockName</tt> attribute. </td> * the value of the {@code lockName} attribute. </td>
* </tr> * </tr>
* <tr> * <tr>
* <td>lockName</td> * <td>lockName</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>lockOwnerId</td> * <td>lockOwnerId</td>
* <td><tt>java.lang.Long</tt></td> * <td>{@code java.lang.Long}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>lockOwnerName</td> * <td>lockOwnerName</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td><a name="StackTrace">stackTrace</a></td> * <td><a name="StackTrace">stackTrace</a></td>
* <td><tt>javax.management.openmbean.CompositeData[]</tt> * <td>{@code javax.management.openmbean.CompositeData[]}
* <p> * <p>
* Each element is a <tt>CompositeData</tt> representing * Each element is a {@code CompositeData} representing
* StackTraceElement containing the following attributes: * StackTraceElement containing the following attributes:
* <blockquote> * <blockquote>
* <table cellspacing=1 cellpadding=0 summary="The attributes and their types the given CompositeData contains"> * <table cellspacing=1 cellpadding=0 summary="The attributes and their types the given CompositeData contains">
@ -729,23 +772,23 @@ public class ThreadInfo {
* </tr> * </tr>
* <tr> * <tr>
* <td>className</td> * <td>className</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>methodName</td> * <td>methodName</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>fileName</td> * <td>fileName</td>
* <td><tt>java.lang.String</tt></td> * <td>{@code java.lang.String}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>lineNumber</td> * <td>lineNumber</td>
* <td><tt>java.lang.Integer</tt></td> * <td>{@code java.lang.Integer}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>nativeMethod</td> * <td>nativeMethod</td>
* <td><tt>java.lang.Boolean</tt></td> * <td>{@code java.lang.Boolean}</td>
* </tr> * </tr>
* </table> * </table>
* </blockquote> * </blockquote>
@ -753,35 +796,43 @@ public class ThreadInfo {
* </tr> * </tr>
* <tr> * <tr>
* <td>lockedMonitors</td> * <td>lockedMonitors</td>
* <td><tt>javax.management.openmbean.CompositeData[]</tt> * <td>{@code javax.management.openmbean.CompositeData[]}
* whose element type is the mapped type for * whose element type is the mapped type for
* {@link MonitorInfo} as specified in the * {@link MonitorInfo} as specified in the
* {@link MonitorInfo#from Monitor.from} method. * {@link MonitorInfo#from Monitor.from} method.
* <p> * <p>
* If <tt>cd</tt> does not contain this attribute, * If {@code cd} does not contain this attribute,
* this attribute will be set to an empty array. </td> * this attribute will be set to an empty array. </td>
* </tr> * </tr>
* <tr> * <tr>
* <td>lockedSynchronizers</td> * <td>lockedSynchronizers</td>
* <td><tt>javax.management.openmbean.CompositeData[]</tt> * <td>{@code javax.management.openmbean.CompositeData[]}
* whose element type is the mapped type for * whose element type is the mapped type for
* {@link LockInfo} as specified in the {@link LockInfo#from} method. * {@link LockInfo} as specified in the {@link LockInfo#from} method.
* <p> * <p>
* If <tt>cd</tt> does not contain this attribute, * If {@code cd} does not contain this attribute,
* this attribute will be set to an empty array. </td> * this attribute will be set to an empty array. </td>
* </tr> * </tr>
* <tr>
* <td>daemon</td>
* <td>{@code java.lang.Boolean}</td>
* </tr>
* <tr>
* <td>priority</td>
* <td>{@code java.lang.Integer}</td>
* </tr>
* </table> * </table>
* </blockquote> * </blockquote>
* *
* @param cd <tt>CompositeData</tt> representing a <tt>ThreadInfo</tt> * @param cd {@code CompositeData} representing a {@code ThreadInfo}
* *
* @throws IllegalArgumentException if <tt>cd</tt> does not * @throws IllegalArgumentException if {@code cd} does not
* represent a <tt>ThreadInfo</tt> with the attributes described * represent a {@code ThreadInfo} with the attributes described
* above. * above.
* *
* @return a <tt>ThreadInfo</tt> object represented * @return a {@code ThreadInfo} object represented
* by <tt>cd</tt> if <tt>cd</tt> is not <tt>null</tt>; * by {@code cd} if {@code cd} is not {@code null};
* <tt>null</tt> otherwise. * {@code null} otherwise.
*/ */
public static ThreadInfo from(CompositeData cd) { public static ThreadInfo from(CompositeData cd) {
if (cd == null) { if (cd == null) {
@ -798,12 +849,12 @@ public class ThreadInfo {
/** /**
* Returns an array of {@link MonitorInfo} objects, each of which * Returns an array of {@link MonitorInfo} objects, each of which
* represents an object monitor currently locked by the thread * represents an object monitor currently locked by the thread
* associated with this <tt>ThreadInfo</tt>. * associated with this {@code ThreadInfo}.
* If no locked monitor was requested for this thread info or * If no locked monitor was requested for this thread info or
* no monitor is locked by the thread, this method * no monitor is locked by the thread, this method
* will return a zero-length array. * will return a zero-length array.
* *
* @return an array of <tt>MonitorInfo</tt> objects representing * @return an array of {@code MonitorInfo} objects representing
* the object monitors locked by the thread. * the object monitors locked by the thread.
* *
* @since 1.6 * @since 1.6
@ -816,11 +867,11 @@ public class ThreadInfo {
* Returns an array of {@link LockInfo} objects, each of which * Returns an array of {@link LockInfo} objects, each of which
* represents an <a href="LockInfo.html#OwnableSynchronizer">ownable * represents an <a href="LockInfo.html#OwnableSynchronizer">ownable
* synchronizer</a> currently locked by the thread associated with * synchronizer</a> currently locked by the thread associated with
* this <tt>ThreadInfo</tt>. If no locked synchronizer was * this {@code ThreadInfo}. If no locked synchronizer was
* requested for this thread info or no synchronizer is locked by * requested for this thread info or no synchronizer is locked by
* the thread, this method will return a zero-length array. * the thread, this method will return a zero-length array.
* *
* @return an array of <tt>LockInfo</tt> objects representing * @return an array of {@code LockInfo} objects representing
* the ownable synchronizers locked by the thread. * the ownable synchronizers locked by the thread.
* *
* @since 1.6 * @since 1.6

View File

@ -87,26 +87,6 @@ public class AgentConfigurationError extends Error {
"agent.err.connector.server.io.error"; "agent.err.connector.server.io.error";
public static final String INVALID_OPTION = public static final String INVALID_OPTION =
"agent.err.invalid.option"; "agent.err.invalid.option";
public static final String INVALID_SNMP_PORT =
"agent.err.invalid.snmp.port";
public static final String INVALID_SNMP_TRAP_PORT =
"agent.err.invalid.snmp.trap.port";
public static final String UNKNOWN_SNMP_INTERFACE =
"agent.err.unknown.snmp.interface";
public static final String SNMP_ACL_FILE_NOT_SET =
"agent.err.acl.file.notset";
public static final String SNMP_ACL_FILE_NOT_FOUND =
"agent.err.acl.file.notfound";
public static final String SNMP_ACL_FILE_NOT_READABLE =
"agent.err.acl.file.not.readable";
public static final String SNMP_ACL_FILE_READ_FAILED =
"agent.err.acl.file.read.failed";
public static final String SNMP_ACL_FILE_ACCESS_NOT_RESTRICTED =
"agent.err.acl.file.access.notrestricted";
public static final String SNMP_ADAPTOR_START_FAILED =
"agent.err.snmp.adaptor.start.failed";
public static final String SNMP_MIB_INIT_FAILED =
"agent.err.snmp.mib.init.failed";
public static final String INVALID_STATE = public static final String INVALID_STATE =
"agent.err.invalid.state"; "agent.err.invalid.state";

View File

@ -43,23 +43,30 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
private final ThreadInfo threadInfo; private final ThreadInfo threadInfo;
private final CompositeData cdata; private final CompositeData cdata;
private final boolean currentVersion; private final boolean currentVersion;
private final boolean hasV6;
private ThreadInfoCompositeData(ThreadInfo ti) { private ThreadInfoCompositeData(ThreadInfo ti) {
this.threadInfo = ti; this.threadInfo = ti;
this.currentVersion = true; this.currentVersion = true;
this.cdata = null; this.cdata = null;
this.hasV6 = true;
} }
private ThreadInfoCompositeData(CompositeData cd) { private ThreadInfoCompositeData(CompositeData cd) {
this.threadInfo = null; this.threadInfo = null;
this.currentVersion = ThreadInfoCompositeData.isCurrentVersion(cd); this.currentVersion = ThreadInfoCompositeData.isCurrentVersion(cd);
this.cdata = cd; this.cdata = cd;
this.hasV6 = ThreadInfoCompositeData.hasV6(cd);
} }
public ThreadInfo getThreadInfo() { public ThreadInfo getThreadInfo() {
return threadInfo; return threadInfo;
} }
public boolean hasV6() {
return hasV6;
}
public boolean isCurrentVersion() { public boolean isCurrentVersion() {
return currentVersion; return currentVersion;
} }
@ -124,6 +131,8 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
threadInfo.isInNative(), threadInfo.isInNative(),
lockedMonitorsData, lockedMonitorsData,
lockedSyncsData, lockedSyncsData,
threadInfo.isDaemon(),
threadInfo.getPriority(),
}; };
try { try {
@ -151,6 +160,8 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
private static final String STACK_TRACE = "stackTrace"; private static final String STACK_TRACE = "stackTrace";
private static final String SUSPENDED = "suspended"; private static final String SUSPENDED = "suspended";
private static final String IN_NATIVE = "inNative"; private static final String IN_NATIVE = "inNative";
private static final String DAEMON = "daemon";
private static final String PRIORITY = "priority";
private static final String LOCKED_MONITORS = "lockedMonitors"; private static final String LOCKED_MONITORS = "lockedMonitors";
private static final String LOCKED_SYNCS = "lockedSynchronizers"; private static final String LOCKED_SYNCS = "lockedSynchronizers";
@ -171,6 +182,8 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
IN_NATIVE, IN_NATIVE,
LOCKED_MONITORS, LOCKED_MONITORS,
LOCKED_SYNCS, LOCKED_SYNCS,
DAEMON,
PRIORITY,
}; };
// New attributes added in 6.0 ThreadInfo // New attributes added in 6.0 ThreadInfo
@ -180,9 +193,16 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
LOCKED_SYNCS, LOCKED_SYNCS,
}; };
private static final String[] threadInfoV9Attributes = {
DAEMON,
PRIORITY,
};
// Current version of ThreadInfo // Current version of ThreadInfo
private static final CompositeType threadInfoCompositeType; private static final CompositeType threadInfoCompositeType;
// Previous version of ThreadInfo // Previous version of ThreadInfo
private static final CompositeType threadInfoV6CompositeType;
// Previous-previous version of ThreadInfo
private static final CompositeType threadInfoV5CompositeType; private static final CompositeType threadInfoV5CompositeType;
private static final CompositeType lockInfoCompositeType; private static final CompositeType lockInfoCompositeType;
static { static {
@ -193,7 +213,7 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
String[] itemNames = String[] itemNames =
threadInfoCompositeType.keySet().toArray(new String[0]); threadInfoCompositeType.keySet().toArray(new String[0]);
int numV5Attributes = threadInfoItemNames.length - int numV5Attributes = threadInfoItemNames.length -
threadInfoV6Attributes.length; threadInfoV6Attributes.length - threadInfoV9Attributes.length;
String[] v5ItemNames = new String[numV5Attributes]; String[] v5ItemNames = new String[numV5Attributes];
String[] v5ItemDescs = new String[numV5Attributes]; String[] v5ItemDescs = new String[numV5Attributes];
OpenType<?>[] v5ItemTypes = new OpenType<?>[numV5Attributes]; OpenType<?>[] v5ItemTypes = new OpenType<?>[numV5Attributes];
@ -213,6 +233,31 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
v5ItemNames, v5ItemNames,
v5ItemDescs, v5ItemDescs,
v5ItemTypes); v5ItemTypes);
// Form a CompositeType for JDK 6.0 ThreadInfo version
int numV6Attributes = threadInfoItemNames.length -
threadInfoV9Attributes.length;
String[] v6ItemNames = new String[numV6Attributes];
String[] v6ItemDescs = new String[numV6Attributes];
OpenType<?>[] v6ItemTypes = new OpenType<?>[numV6Attributes];
i = 0;
for (String n : itemNames) {
if (isV5Attribute(n) || isV6Attribute(n)) {
v6ItemNames[i] = n;
v6ItemDescs[i] = threadInfoCompositeType.getDescription(n);
v6ItemTypes[i] = threadInfoCompositeType.getType(n);
i++;
}
}
threadInfoV6CompositeType =
new CompositeType("java.lang.management.ThreadInfo",
"Java SE 6 java.lang.management.ThreadInfo",
v6ItemNames,
v6ItemDescs,
v6ItemTypes);
} catch (OpenDataException e) { } catch (OpenDataException e) {
// Should never reach here // Should never reach here
throw new AssertionError(e); throw new AssertionError(e);
@ -236,6 +281,20 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
return false; return false;
} }
} }
for (String n : threadInfoV9Attributes) {
if (itemName.equals(n)) {
return false;
}
}
return true;
}
private static boolean isV6Attribute(String itemName) {
for (String n : threadInfoV9Attributes) {
if (itemName.equals(n)) {
return false;
}
}
return true; return true;
} }
@ -247,6 +306,15 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
return isTypeMatched(threadInfoCompositeType, cd.getCompositeType()); return isTypeMatched(threadInfoCompositeType, cd.getCompositeType());
} }
private static boolean hasV6(CompositeData cd) {
if (cd == null) {
throw new NullPointerException("Null CompositeData");
}
return isTypeMatched(threadInfoCompositeType, cd.getCompositeType()) ||
isTypeMatched(threadInfoV6CompositeType, cd.getCompositeType());
}
public long threadId() { public long threadId() {
return getLong(cdata, THREAD_ID); return getLong(cdata, THREAD_ID);
} }
@ -304,6 +372,14 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
return getBoolean(cdata, IN_NATIVE); return getBoolean(cdata, IN_NATIVE);
} }
public boolean isDaemon() {
return getBoolean(cdata, DAEMON);
}
public int getPriority(){
return getInt(cdata, PRIORITY);
}
public StackTraceElement[] stackTrace() { public StackTraceElement[] stackTrace() {
CompositeData[] stackTraceData = CompositeData[] stackTraceData =
(CompositeData[]) cdata.get(STACK_TRACE); (CompositeData[]) cdata.get(STACK_TRACE);
@ -368,7 +444,8 @@ public class ThreadInfoCompositeData extends LazyCompositeData {
if (!isTypeMatched(threadInfoCompositeType, type)) { if (!isTypeMatched(threadInfoCompositeType, type)) {
currentVersion = false; currentVersion = false;
// check if cd is an older version // check if cd is an older version
if (!isTypeMatched(threadInfoV5CompositeType, type)) { if (!isTypeMatched(threadInfoV5CompositeType, type) &&
!isTypeMatched(threadInfoV6CompositeType, type)) {
throw new IllegalArgumentException( throw new IllegalArgumentException(
"Unexpected composite type for ThreadInfo"); "Unexpected composite type for ThreadInfo");
} }

View File

@ -1,5 +1,4 @@
# #
#
# Copyright (c) 2004, 2012, Oracle and/or its affiliates. All rights reserved. # Copyright (c) 2004, 2012, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# #
@ -24,9 +23,6 @@
# questions. # questions.
# #
# Localizations for Level names. For the US locale
# these are the same as the non-localized level name.
agent.err.error = Error agent.err.error = Error
agent.err.exception = Exception thrown by the agent agent.err.exception = Exception thrown by the agent
agent.err.warning = Warning agent.err.warning = Warning
@ -67,27 +63,9 @@ agent.err.access.file.notfound = Access file not found
agent.err.connector.server.io.error = JMX connector server communication error agent.err.connector.server.io.error = JMX connector server communication error
agent.err.invalid.option = Invalid option specified agent.err.invalid.option = Invalid option specified
agent.err.invalid.snmp.port = Invalid com.sun.management.snmp.port number
agent.err.invalid.snmp.trap.port = Invalid com.sun.management.snmp.trap number
agent.err.unknown.snmp.interface = Unknown SNMP interface
agent.err.acl.file.notset = No SNMP ACL file is specified but com.sun.management.snmp.acl=true
agent.err.acl.file.notfound = SNMP ACL file not found
agent.err.acl.file.not.readable = SNMP ACL file not readable
agent.err.acl.file.read.failed = Failed in reading SNMP ACL file
agent.err.acl.file.access.notrestricted = Password file read access must be restricted
agent.err.snmp.adaptor.start.failed = Failed to start SNMP adaptor with address
agent.err.snmp.mib.init.failed = Failed to initialize SNMP MIB with error
jmxremote.ConnectorBootstrap.starting = Starting JMX Connector Server: jmxremote.ConnectorBootstrap.starting = Starting JMX Connector Server:
jmxremote.ConnectorBootstrap.noAuthentication = No Authentication jmxremote.ConnectorBootstrap.noAuthentication = No Authentication
jmxremote.ConnectorBootstrap.ready = JMX Connector ready at: {0} jmxremote.ConnectorBootstrap.ready = JMX Connector ready at: {0}
jmxremote.ConnectorBootstrap.password.readonly = Password file read access must be restricted: {0} jmxremote.ConnectorBootstrap.password.readonly = Password file read access must be restricted: {0}
jmxremote.ConnectorBootstrap.file.readonly = File read access must be restricted: {0} jmxremote.ConnectorBootstrap.file.readonly = File read access must be restricted: {0}
jmxremote.AdaptorBootstrap.getTargetList.processing = Processing ACL
jmxremote.AdaptorBootstrap.getTargetList.adding = Adding target: {0}
jmxremote.AdaptorBootstrap.getTargetList.starting = Starting Adaptor Server:
jmxremote.AdaptorBootstrap.getTargetList.initialize1 = Adaptor ready.
jmxremote.AdaptorBootstrap.getTargetList.initialize2 = SNMP Adaptor ready on: {0}:{1}
jmxremote.AdaptorBootstrap.getTargetList.terminate = terminate {0}

View File

@ -46,7 +46,7 @@ public class AttachOperationFailedException extends IOException {
* Constructs an <code>AttachOperationFailedException</code> with * Constructs an <code>AttachOperationFailedException</code> with
* the specified detail message. * the specified detail message.
* *
* @param s the detail message. * @param message the detail message.
*/ */
public AttachOperationFailedException(String message) { public AttachOperationFailedException(String message) {
super(message); super(message);

View File

@ -23,7 +23,7 @@
* questions. * questions.
*/ */
package sun.nio.cs.ext; package $PACKAGE$;
import java.io.*; import java.io.*;
import java.nio.CharBuffer; import java.nio.CharBuffer;
@ -79,7 +79,7 @@ public class EUC_TW extends Charset implements HistoricallyNamedCharset
*/ */
public EUC_TW() { public EUC_TW() {
super("x-EUC-TW", ExtendedCharsets.aliasesFor("x-EUC-TW")); super("x-EUC-TW", $ALIASES$);
} }
public String historicalName() { public String historicalName() {

View File

@ -222,16 +222,6 @@ public class ExtendedCharsets extends AbstractCharsetProvider {
} }
} }
String osName = getProperty("os.name");
if ("SunOS".equals(osName) || "Linux".equals(osName) || "AIX".equals(osName)
|| osName.contains("OS X")) {
charset("x-COMPOUND_TEXT", "COMPOUND_TEXT",
new String[] {
"COMPOUND_TEXT", // JDK historical
"x11-compound_text",
"x-compound-text"
});
}
initialized = true; initialized = true;
} }

View File

@ -35,6 +35,7 @@ import java.nio.charset.CharsetDecoder;
import java.nio.charset.CharsetEncoder; import java.nio.charset.CharsetEncoder;
import java.nio.charset.CoderResult; import java.nio.charset.CoderResult;
import sun.nio.cs.HistoricallyNamedCharset; import sun.nio.cs.HistoricallyNamedCharset;
import sun.nio.cs.*;
public class ISO2022_CN_CNS extends ISO2022 implements HistoricallyNamedCharset public class ISO2022_CN_CNS extends ISO2022 implements HistoricallyNamedCharset
{ {

View File

@ -31,7 +31,6 @@ import java.nio.channels.*;
import java.net.*; import java.net.*;
import javax.net.ssl.*; import javax.net.ssl.*;
import java.util.*; import java.util.*;
import sun.net.www.MessageHeader;
/** /**
* This class encapsulates a HTTP request received and a * This class encapsulates a HTTP request received and a

View File

@ -29,7 +29,6 @@ import com.sun.net.httpserver.*;
import java.io.*; import java.io.*;
import java.nio.*; import java.nio.*;
import java.nio.channels.*; import java.nio.channels.*;
import sun.net.www.MessageHeader;
import java.util.*; import java.util.*;
import javax.security.auth.*; import javax.security.auth.*;
import javax.security.auth.callback.*; import javax.security.auth.callback.*;

View File

@ -31,7 +31,6 @@ import java.nio.channels.*;
import java.net.*; import java.net.*;
import javax.net.ssl.*; import javax.net.ssl.*;
import java.util.*; import java.util.*;
import sun.net.www.MessageHeader;
import com.sun.net.httpserver.*; import com.sun.net.httpserver.*;
import com.sun.net.httpserver.spi.*; import com.sun.net.httpserver.spi.*;

View File

@ -31,7 +31,6 @@ import java.nio.channels.*;
import java.net.*; import java.net.*;
import javax.net.ssl.*; import javax.net.ssl.*;
import java.util.*; import java.util.*;
import sun.net.www.MessageHeader;
import com.sun.net.httpserver.*; import com.sun.net.httpserver.*;
import com.sun.net.httpserver.spi.*; import com.sun.net.httpserver.spi.*;

View File

@ -145,7 +145,7 @@ public interface InterfaceType extends ReferenceType {
* not be done from the client's event handler thread. * not be done from the client's event handler thread.
* <p> * <p>
* The resumption of other threads during the invocation can be prevented * The resumption of other threads during the invocation can be prevented
* by specifying the {@link #INVOKE_SINGLE_THREADED} * by specifying the {@link ClassType#INVOKE_SINGLE_THREADED}
* bit flag in the <code>options</code> argument; however, * bit flag in the <code>options</code> argument; however,
* there is no protection against or recovery from the deadlocks * there is no protection against or recovery from the deadlocks
* described above, so this option should be used with great caution. * described above, so this option should be used with great caution.

View File

@ -431,7 +431,7 @@ jobjectArray getRemoteAddresses
paddr = addr_buf; paddr = addr_buf;
for (i=0; i<addrCount; i++) { for (i=0; i<addrCount; i++) {
jobject ia, isa = NULL; jobject ia, isa = NULL;
int port; int port = 0;
sap = (struct sockaddr*)addr_buf; sap = (struct sockaddr*)addr_buf;
ia = NET_SockaddrToInetAddress(env, sap, &port); ia = NET_SockaddrToInetAddress(env, sap, &port);
if (ia != NULL) if (ia != NULL)
@ -543,6 +543,7 @@ JNIEXPORT int JNICALL Java_sun_nio_ch_sctp_SctpNet_getIntOption0
void *arg; void *arg;
int arglen; int arglen;
memset((char *) &linger, 0, sizeof(linger));
if (mapSocketOption(opt, &klevel, &kopt) < 0) { if (mapSocketOption(opt, &klevel, &kopt) < 0) {
JNU_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", JNU_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException",
"Unsupported socket option"); "Unsupported socket option");
@ -600,7 +601,7 @@ JNIEXPORT void JNICALL Java_sun_nio_ch_sctp_SctpNet_setPrimAddrOption0
(JNIEnv *env, jclass klass, jint fd, jint assocId, jobject iaObj, jint port) { (JNIEnv *env, jclass klass, jint fd, jint assocId, jobject iaObj, jint port) {
struct sctp_setprim prim; struct sctp_setprim prim;
struct sockaddr* sap = (struct sockaddr*)&prim.ssp_addr; struct sockaddr* sap = (struct sockaddr*)&prim.ssp_addr;
int sap_len; int sap_len = sizeof(sap);
if (NET_InetAddressToSockaddr(env, iaObj, port, sap, if (NET_InetAddressToSockaddr(env, iaObj, port, sap,
&sap_len, JNI_TRUE) != 0) { &sap_len, JNI_TRUE) != 0) {
@ -625,7 +626,7 @@ JNIEXPORT void JNICALL Java_sun_nio_ch_sctp_SctpNet_setPeerPrimAddrOption0
jobject iaObj, jint port, jboolean preferIPv6) { jobject iaObj, jint port, jboolean preferIPv6) {
struct sctp_setpeerprim prim; struct sctp_setpeerprim prim;
struct sockaddr* sap = (struct sockaddr*)&prim.sspp_addr; struct sockaddr* sap = (struct sockaddr*)&prim.sspp_addr;
int sap_len; int sap_len = sizeof(sap);
if (NET_InetAddressToSockaddr(env, iaObj, port, sap, if (NET_InetAddressToSockaddr(env, iaObj, port, sap,
&sap_len, preferIPv6) != 0) { &sap_len, preferIPv6) != 0) {

View File

@ -1,4 +1,4 @@
# Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved. # Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# #
# This code is free software; you can redistribute it and/or modify it # This code is free software; you can redistribute it and/or modify it
@ -567,7 +567,6 @@ needs_compact3 = \
javax/smartcardio \ javax/smartcardio \
javax/sql/rowset \ javax/sql/rowset \
javax/xml/crypto \ javax/xml/crypto \
sun/security/acl \
sun/security/jgss \ sun/security/jgss \
sun/security/krb5 \ sun/security/krb5 \
java/lang/annotation/AnnotationType/AnnotationTypeDeadlockTest.java \ java/lang/annotation/AnnotationType/AnnotationTypeDeadlockTest.java \

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2003, 2005, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -22,11 +22,16 @@
*/ */
/* /*
* * @test
*
* @bug 4858522 * @bug 4858522
* @summary Basic unit test of OperatingSystemMXBean.getTotalSwapSpaceSize() * @summary Basic unit test of OperatingSystemMXBean.getTotalSwapSpaceSize()
*
* @library /lib/testlibrary
* @build TestTotalSwap jdk.testlibrary.*
* @run main TestTotalSwap
*
* @author Steve Bohne * @author Steve Bohne
* @author Jaroslav Bachorik
*/ */
/* /*
@ -50,9 +55,13 @@
import com.sun.management.OperatingSystemMXBean; import com.sun.management.OperatingSystemMXBean;
import java.lang.management.*; import java.lang.management.*;
public class GetTotalSwapSpaceSize { import jdk.testlibrary.OSInfo;
import jdk.testlibrary.ProcessTools;
import jdk.testlibrary.OutputAnalyzer;
private static OperatingSystemMXBean mbean = public class TestTotalSwap {
private static final OperatingSystemMXBean mbean =
(com.sun.management.OperatingSystemMXBean) (com.sun.management.OperatingSystemMXBean)
ManagementFactory.getOperatingSystemMXBean(); ManagementFactory.getOperatingSystemMXBean();
@ -62,19 +71,9 @@ public class GetTotalSwapSpaceSize {
private static long min_size_for_pass = 0; private static long min_size_for_pass = 0;
private static final long MAX_SIZE_FOR_PASS = Long.MAX_VALUE; private static final long MAX_SIZE_FOR_PASS = Long.MAX_VALUE;
private static boolean trace = false; public static void main(String args[]) throws Throwable {
public static void main(String args[]) throws Exception {
if (args.length > 1 && args[1].equals("trace")) {
trace = true;
}
long expected_swap_size = 0;
if (args.length < 1 || args.length > 2) {
throw new IllegalArgumentException("Unexpected number of args " + args.length);
}
long expected_swap_size = getSwapSizeFromOs();
long min_size = mbean.getFreeSwapSpaceSize(); long min_size = mbean.getFreeSwapSpaceSize();
if (min_size > 0) { if (min_size > 0) {
@ -83,12 +82,9 @@ public class GetTotalSwapSpaceSize {
long size = mbean.getTotalSwapSpaceSize(); long size = mbean.getTotalSwapSpaceSize();
if (trace) {
System.out.println("Total swap space size in bytes: " + size); System.out.println("Total swap space size in bytes: " + size);
}
if (!args[0].matches("sanity-only")) { if (expected_swap_size > -1) {
expected_swap_size = Long.parseLong(args[0]);
if (size != expected_swap_size) { if (size != expected_swap_size) {
throw new RuntimeException("Expected total swap size : " + throw new RuntimeException("Expected total swap size : " +
expected_swap_size + expected_swap_size +
@ -97,6 +93,7 @@ public class GetTotalSwapSpaceSize {
} }
} }
// sanity check
if (size < min_size_for_pass || size > MAX_SIZE_FOR_PASS) { if (size < min_size_for_pass || size > MAX_SIZE_FOR_PASS) {
throw new RuntimeException("Total swap space size " + throw new RuntimeException("Total swap space size " +
"illegal value: " + size + " bytes " + "illegal value: " + size + " bytes " +
@ -106,4 +103,60 @@ public class GetTotalSwapSpaceSize {
System.out.println("Test passed."); System.out.println("Test passed.");
} }
private static long getSwapSizeFromOs() throws Throwable {
OSInfo.OSType os = OSInfo.getOSType();
switch (os) {
// total used free shared buffers cached
// Mem: 16533540864 13638467584 2895073280 534040576 1630248960 6236909568
// -/+ buffers/cache: 5771309056 10762231808
// Swap: 15999168512 0 15999168512
case LINUX: {
String swapSizeStr = ProcessTools.executeCommand("free", "-b")
.firstMatch("Swap:\\s+([0-9]+)\\s+.*", 1);
return Long.parseLong(swapSizeStr);
}
case SOLARIS: {
// swapfile dev swaplo blocks free
// /dev/dsk/c0t0d0s1 136,1 16 1638608 1600528
OutputAnalyzer out= ProcessTools.executeCommand(
"/usr/sbin/swap",
"-l"
);
long swapSize = 0;
for (String line : out.asLines()) {
if (line.contains("swapfile")) continue;
String[] vals = line.split("\\s+");
if (vals.length == 5) {
swapSize += Long.parseLong(vals[3]) * 512; // size is reported in 512b blocks
}
}
return swapSize;
}
case MACOSX: {
// total = 8192.00M used = 7471.11M free = 720.89M (encrypted)
String swapSizeStr = ProcessTools.executeCommand(
"/usr/sbin/sysctl",
"-n",
"vm.swapusage"
).firstMatch("total\\s+=\\s+([0-9]+(\\.[0-9]+)?[Mm]?).*", 1);
if (swapSizeStr.toLowerCase().endsWith("m")) {
swapSizeStr = swapSizeStr.substring(0, swapSizeStr.length() - 1);
return (long)(Double.parseDouble(swapSizeStr) * 1024 * 1024); // size in MB
}
return (long)(Double.parseDouble(swapSizeStr) * 1024 * 1024);
}
default: {
System.err.println("Unsupported operating system: " + os);
}
}
return -1;
}
} }

View File

@ -1,99 +0,0 @@
#
# Copyright (c) 2005, 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
# @summary Tests MM getTotalSwapSpaceSize() api.
# @author Swamy V
# @bug 6252770
#
# @run build GetTotalSwapSpaceSize
# @run shell TestTotalSwap.sh
#
#
# This test tests the actual swap size on linux and solaris.
# On windows this is just a sanity check and correct size should
# be checked manually:
#
# Windows NT/XP/2000:
# 1. Run Start->Accessories->System Tools->System Information.
# 2. The value (reported in Kbytes) is in the "Page File Space" entry
# Windows 98/ME:
# Unknown.
#
#set -x
#Set appropriate jdk
#
if [ ! -z "${TESTJAVA}" ] ; then
jdk="$TESTJAVA"
else
echo "--Error: TESTJAVA must be defined as the pathname of a jdk to test."
exit 1
fi
runOne()
{
echo "runOne $@"
$TESTJAVA/bin/java ${TESTVMOPTS} -classpath $TESTCLASSES $@ || exit 3
}
solaris_swap_size()
{
total_swap=0
for i in `/usr/sbin/swap -l | awk '{print $4}' | grep -v blocks`
do
# swap -l returns size in blocks of 512 bytes.
total_swap=`expr $i \* 512 + $total_swap`
done
}
# Test GetTotalSwapSpaceSize if we are running on Unix
total_swap=0
case `uname -s` in
SunOS )
solaris_swap_size
runOne GetTotalSwapSpaceSize $total_swap
;;
Linux )
total_swap=`free -b | grep -i swap | awk '{print $2}'`
runOne GetTotalSwapSpaceSize $total_swap
;;
Darwin )
# $ sysctl -n vm.swapusage
# total = 8192.00M used = 7471.11M free = 720.89M (encrypted)
swap=`/usr/sbin/sysctl -n vm.swapusage | awk '{ print $3 }' | awk -F . '{ print $1 }'` || exit 2
total_swap=`expr $swap \* 1024 \* 1024` || exit 2
runOne GetTotalSwapSpaceSize $total_swap
;;
* )
runOne GetTotalSwapSpaceSize "sanity-only"
;;
esac
exit 0

View File

@ -1,12 +1,10 @@
/* /*
* Copyright (c) 1996, 1997, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * 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 * under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this * published by the Free Software Foundation.
* 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 * This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
@ -23,28 +21,30 @@
* questions. * questions.
*/ */
package sun.security.acl; /*
* @test
import java.security.Principal; * @bug 8014678
import java.security.acl.*; * @run main EnclosingConstructorWithSecurityManager
* @run main/othervm EnclosingConstructorWithSecurityManager "WithSecurityManager"
/**
* This class implements the principal interface for the set of all permissions.
* @author Satish Dharmaraj
*/ */
public class AllPermissionsImpl extends PermissionImpl {
public AllPermissionsImpl(String s) { public class EnclosingConstructorWithSecurityManager {
super(s); public static void main(String[] args) {
if (args.length == 1) {
System.setSecurityManager(new SecurityManager());
} }
/** new Inner();
* This function returns true if the permission passed matches the permission represented in Inner.theInner.getEnclosingConstructor();
* this interface. }
* @param another The Permission object to compare with.
* @returns true always public static class Inner {
*/ public static Class<?> theInner;
public boolean equals(Permission another) {
return true; public Inner() {
Object o = new Object() {
};
Inner.theInner = o.getClass();
}
} }
} }

View File

@ -0,0 +1,50 @@
/*
* Copyright (c) 2015, 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 8014678
* @run main EnclosingMethodWithSecurityManager
* @run main/othervm EnclosingMethodWithSecurityManager "WithSecurityManager"
*/
public class EnclosingMethodWithSecurityManager {
public static void main(String[] args) {
if (args.length == 1) {
System.setSecurityManager(new SecurityManager());
}
new Inner().setTheInner();
Inner.theInner.getEnclosingMethod();
}
public static class Inner {
public static Class<?> theInner;
public void setTheInner() {
Object o = new Object() {
};
Inner.theInner = o.getClass();
}
}
}

View File

@ -33,6 +33,7 @@
import java.lang.invoke.MethodHandle; import java.lang.invoke.MethodHandle;
import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodHandles;
import java.util.Objects;
interface Intf { interface Intf {
static int i = 0; static int i = 0;
@ -40,9 +41,8 @@ interface Intf {
public class Test8009222 { public class Test8009222 {
public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
MethodHandles.lookup() Objects.requireNonNull(MethodHandles.lookup()
.findStaticGetter(Intf.class, "i", int.class) .findStaticGetter(Intf.class, "i", int.class));
.getClass(); // null check
System.out.println("TEST PASSED"); System.out.println("TEST PASSED");
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -32,6 +32,7 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.function.Predicate;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.Paths; import java.nio.file.Paths;
@ -235,8 +236,23 @@ public class LogGeneratedClassesTest extends LUtils {
.filter(s -> s.startsWith("WARNING: Exception")) .filter(s -> s.startsWith("WARNING: Exception"))
.count(), .count(),
2, "show error each capture"); 2, "show error each capture");
// dumpLong/com/example/nosense/nosense // dumpLong/com/example/nonsense/nonsense
assertEquals(Files.walk(Paths.get("dumpLong")).count(), 5, "Two lambda captured failed to log"); Path dumpPath = Paths.get("dumpLong/com/example/nonsense");
Predicate<Path> filter = p -> p.getParent() == null || dumpPath.startsWith(p) || p.startsWith(dumpPath);
boolean debug = true;
if (debug) {
Files.walk(Paths.get("dumpLong"))
.forEachOrdered(p -> {
if (filter.test(p)) {
System.out.println("accepted: " + p.toString());
} else {
System.out.println("filetered out: " + p.toString());
}
});
}
assertEquals(Files.walk(Paths.get("dumpLong"))
.filter(filter)
.count(), 5, "Two lambda captured failed to log");
tr.assertZero("Should still return 0"); tr.assertZero("Should still return 0");
} }
} }

View File

@ -147,6 +147,11 @@ public class ThreadInfoCompositeData {
info.getLockOwnerName() + " expected = " + info.getLockOwnerName() + " expected = " +
values[LOCK_OWNER_NAME]); values[LOCK_OWNER_NAME]);
} }
if (!values[DAEMON].equals(info.isDaemon())) {
throw new RuntimeException("Daemon = " +
info.isDaemon() + " expected = " +
values[DAEMON]);
}
checkStackTrace(info.getStackTrace()); checkStackTrace(info.getStackTrace());
@ -258,8 +263,11 @@ public class ThreadInfoCompositeData {
private static final int SUSPENDED = 11; private static final int SUSPENDED = 11;
private static final int IN_NATIVE = 12; private static final int IN_NATIVE = 12;
private static final int NUM_V5_ATTS = 13; private static final int NUM_V5_ATTS = 13;
// JDK 6.0 ThreadInfo attribtues // JDK 6.0 ThreadInfo attributes
private static final int LOCK_INFO = 13; private static final int LOCK_INFO = 13;
// JDK 9.0 ThreadInfo attributes
private static final int DAEMON = 14;
private static final int PRIORITY = 15;
private static final String[] validItemNames = { private static final String[] validItemNames = {
"threadId", "threadId",
@ -276,6 +284,8 @@ public class ThreadInfoCompositeData {
"suspended", "suspended",
"inNative", "inNative",
"lockInfo", "lockInfo",
"daemon",
"priority",
}; };
private static OpenType[] validItemTypes = { private static OpenType[] validItemTypes = {
@ -293,6 +303,8 @@ public class ThreadInfoCompositeData {
SimpleType.BOOLEAN, SimpleType.BOOLEAN,
SimpleType.BOOLEAN, SimpleType.BOOLEAN,
null, // CompositeType for LockInfo null, // CompositeType for LockInfo
SimpleType.BOOLEAN,
SimpleType.INTEGER,
}; };
private static Object[] values = { private static Object[] values = {
@ -310,6 +322,8 @@ public class ThreadInfoCompositeData {
new Boolean(false), new Boolean(false),
new Boolean(false), new Boolean(false),
null, // To be initialized to lockInfoCD null, // To be initialized to lockInfoCD
new Boolean(false),
Thread.NORM_PRIORITY,
}; };
private static final String[] steItemNames = { private static final String[] steItemNames = {
@ -381,6 +395,8 @@ public class ThreadInfoCompositeData {
"suspended", "suspended",
"inNative", "inNative",
"lockInfo", "lockInfo",
"daemon",
"priority",
}; };
private static final OpenType[] badItemTypes = { private static final OpenType[] badItemTypes = {
SimpleType.LONG, SimpleType.LONG,
@ -397,6 +413,8 @@ public class ThreadInfoCompositeData {
SimpleType.BOOLEAN, SimpleType.BOOLEAN,
SimpleType.BOOLEAN, SimpleType.BOOLEAN,
SimpleType.LONG, // bad type SimpleType.LONG, // bad type
SimpleType.BOOLEAN,
SimpleType.INTEGER,
}; };
} }

View File

@ -0,0 +1,96 @@
/*
* Copyright (c) 2015, 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.
*/
import java.lang.management.*;
import java.util.*;
import java.util.concurrent.*;
import java.util.concurrent.atomic.*;
/*
* @test
* @bug 6588467
* @summary Basic test of ThreadInfo.isDaemon
* @author Jeremy Manson
*/
public class ThreadDaemonTest {
public static void main(String[] args) throws Exception {
final int NUM_THREADS = 20;
final String THREAD_PREFIX = "ThreadDaemonTest-";
final CountDownLatch started = new CountDownLatch(NUM_THREADS);
final CountDownLatch finished = new CountDownLatch(1);
final AtomicReference<Exception> fail = new AtomicReference<>(null);
Thread[] allThreads = new Thread[NUM_THREADS];
ThreadMXBean mbean = ManagementFactory.getThreadMXBean();
Random rand = new Random();
for (int i = 0; i < NUM_THREADS; i++) {
allThreads[i] = new Thread(new Runnable() {
public void run() {
try {
started.countDown();
finished.await();
} catch (InterruptedException e) {
fail.set(new Exception(
"Unexpected InterruptedException"));
}
}
}, THREAD_PREFIX + i);
allThreads[i].setDaemon(rand.nextBoolean());
allThreads[i].start();
}
started.await();
try {
ThreadInfo[] allThreadInfos = mbean.dumpAllThreads(false, false);
int count = 0;
for (int i = 0; i < allThreadInfos.length; i++) {
String threadName = allThreadInfos[i].getThreadName();
if (threadName.startsWith(THREAD_PREFIX)) {
count++;
String[] nameAndNumber = threadName.split("-");
int threadNum = Integer.parseInt(nameAndNumber[1]);
if (allThreads[threadNum].isDaemon() !=
allThreadInfos[i].isDaemon()) {
throw new RuntimeException(
allThreads[threadNum] + " is not like " +
allThreadInfos[i] + ". TEST FAILED.");
}
}
}
if (count != NUM_THREADS) {
throw new RuntimeException("Wrong number of threads examined");
}
}
finally { finished.countDown(); }
for (int i = 0; i < NUM_THREADS; i++) {
allThreads[i].join();
}
if (fail.get() != null) {
throw fail.get();
}
}
}

Some files were not shown because too many files have changed in this diff Show More