Merge
This commit is contained in:
commit
7e8a2d4068
@ -343,3 +343,4 @@ cf1dc4c035fb84693d4ae5ad818785cb4d1465d1 jdk9-b90
|
|||||||
48987460c7d49a29013963ee44d090194396bb61 jdk-9+98
|
48987460c7d49a29013963ee44d090194396bb61 jdk-9+98
|
||||||
7c0577bea4c65d69c5bef67023a89d2efa4fb2f7 jdk-9+99
|
7c0577bea4c65d69c5bef67023a89d2efa4fb2f7 jdk-9+99
|
||||||
c1f30ac14db0eaff398429c04cd9fab92e1b4b2a jdk-9+100
|
c1f30ac14db0eaff398429c04cd9fab92e1b4b2a jdk-9+100
|
||||||
|
c4d72a1620835b5d657b7b6792c2879367d0154f jdk-9+101
|
||||||
|
@ -23,6 +23,74 @@
|
|||||||
# questions.
|
# questions.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# Create a function/macro that takes a series of named arguments. The call is
|
||||||
|
# similar to AC_DEFUN, but the setup of the function looks like this:
|
||||||
|
# BASIC_DEFUN_NAMED([MYFUNC], [FOO *BAR], [$@], [
|
||||||
|
# ... do something
|
||||||
|
# AC_MSG_NOTICE([Value of BAR is ARG_BAR])
|
||||||
|
# ])
|
||||||
|
# A star (*) in front of a named argument means that it is required and it's
|
||||||
|
# presence will be verified. To pass e.g. the first value as a normal indexed
|
||||||
|
# argument, use [m4_shift($@)] as the third argument instead of [$@]. These
|
||||||
|
# arguments are referenced in the function by their name prefixed by ARG_, e.g.
|
||||||
|
# "ARG_FOO".
|
||||||
|
#
|
||||||
|
# The generated function can be called like this:
|
||||||
|
# MYFUNC(FOO: [foo-val], BAR:
|
||||||
|
# [
|
||||||
|
# $ECHO hello world
|
||||||
|
# ])
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Argument 1: Name of the function to define
|
||||||
|
# Argument 2: List of legal named arguments, with a * prefix for required arguments
|
||||||
|
# Argument 3: Argument array to treat as named, typically $@
|
||||||
|
# Argument 4: The main function body
|
||||||
|
AC_DEFUN([BASIC_DEFUN_NAMED],
|
||||||
|
[
|
||||||
|
AC_DEFUN($1, [
|
||||||
|
m4_foreach(arg, m4_split($2), [
|
||||||
|
m4_if(m4_bregexp(arg, [^\*]), -1,
|
||||||
|
[
|
||||||
|
m4_set_add(legal_named_args, arg)
|
||||||
|
],
|
||||||
|
[
|
||||||
|
m4_set_add(legal_named_args, m4_substr(arg, 1))
|
||||||
|
m4_set_add(required_named_args, m4_substr(arg, 1))
|
||||||
|
]
|
||||||
|
)
|
||||||
|
])
|
||||||
|
|
||||||
|
m4_foreach([arg], [$3], [
|
||||||
|
m4_define(arg_name, m4_substr(arg, 0, m4_bregexp(arg, [: ])))
|
||||||
|
m4_set_contains(legal_named_args, arg_name, [],[AC_MSG_ERROR([Internal error: arg_name is not a valid named argument to [$1]. Valid arguments are 'm4_set_contents(legal_named_args, [ ])'.])])
|
||||||
|
m4_set_remove(required_named_args, arg_name)
|
||||||
|
m4_set_remove(legal_named_args, arg_name)
|
||||||
|
m4_pushdef([ARG_][]arg_name, m4_substr(arg, m4_incr(m4_incr(m4_bregexp(arg, [: ])))))
|
||||||
|
m4_set_add(defined_args, arg_name)
|
||||||
|
m4_undefine([arg_name])
|
||||||
|
])
|
||||||
|
m4_set_empty(required_named_args, [], [
|
||||||
|
AC_MSG_ERROR([Internal error: Required named arguments are missing for [$1]. Missing arguments: 'm4_set_contents(required_named_args, [ ])'])
|
||||||
|
])
|
||||||
|
m4_foreach([arg], m4_indir([m4_dquote]m4_set_listc([legal_named_args])), [
|
||||||
|
m4_pushdef([ARG_][]arg, [])
|
||||||
|
m4_set_add(defined_args, arg)
|
||||||
|
])
|
||||||
|
m4_set_delete(legal_named_args)
|
||||||
|
m4_set_delete(required_named_args)
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
$4
|
||||||
|
|
||||||
|
m4_foreach([arg], m4_indir([m4_dquote]m4_set_listc([defined_args])), [
|
||||||
|
m4_popdef([ARG_][]arg)
|
||||||
|
])
|
||||||
|
|
||||||
|
m4_set_delete(defined_args)
|
||||||
|
])
|
||||||
|
])
|
||||||
|
|
||||||
# Test if $1 is a valid argument to $3 (often is $JAVA passed as $3)
|
# Test if $1 is a valid argument to $3 (often is $JAVA passed as $3)
|
||||||
# If so, then append $1 to $2 \
|
# If so, then append $1 to $2 \
|
||||||
# Also set JVM_ARG_OK to true/false depending on outcome.
|
# Also set JVM_ARG_OK to true/false depending on outcome.
|
||||||
@ -1122,7 +1190,6 @@ AC_DEFUN_ONCE([BASIC_POST_CONFIG_OUTPUT],
|
|||||||
|
|
||||||
# Move configure.log from current directory to the build output root
|
# Move configure.log from current directory to the build output root
|
||||||
if test -e ./configure.log; then
|
if test -e ./configure.log; then
|
||||||
echo found it
|
|
||||||
$MV -f ./configure.log "$OUTPUT_ROOT/configure.log" 2> /dev/null
|
$MV -f ./configure.log "$OUTPUT_ROOT/configure.log" 2> /dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -425,7 +425,7 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_OPTIMIZATION],
|
|||||||
# Add runtime stack smashing and undefined behavior checks.
|
# Add runtime stack smashing and undefined behavior checks.
|
||||||
# Not all versions of gcc support -fstack-protector
|
# Not all versions of gcc support -fstack-protector
|
||||||
STACK_PROTECTOR_CFLAG="-fstack-protector-all"
|
STACK_PROTECTOR_CFLAG="-fstack-protector-all"
|
||||||
FLAGS_COMPILER_CHECK_ARGUMENTS([$STACK_PROTECTOR_CFLAG], [], [STACK_PROTECTOR_CFLAG=""])
|
FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [$STACK_PROTECTOR_CFLAG], IF_FALSE: [STACK_PROTECTOR_CFLAG=""])
|
||||||
|
|
||||||
CFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
CFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
||||||
CXXFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
CXXFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
||||||
@ -742,7 +742,7 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
|
|||||||
-I${JDK_TOPDIR}/src/java.base/share/native/include \
|
-I${JDK_TOPDIR}/src/java.base/share/native/include \
|
||||||
-I${JDK_TOPDIR}/src/java.base/$OPENJDK_TARGET_OS/native/include \
|
-I${JDK_TOPDIR}/src/java.base/$OPENJDK_TARGET_OS/native/include \
|
||||||
-I${JDK_TOPDIR}/src/java.base/$OPENJDK_TARGET_OS_TYPE/native/include \
|
-I${JDK_TOPDIR}/src/java.base/$OPENJDK_TARGET_OS_TYPE/native/include \
|
||||||
-I${JDK_TOPDIR}/src/java.base/share/native/libjava \
|
-I${JDK_TOPDIR}/src/java.base/share/native/libjava \
|
||||||
-I${JDK_TOPDIR}/src/java.base/$OPENJDK_TARGET_OS_TYPE/native/libjava"
|
-I${JDK_TOPDIR}/src/java.base/$OPENJDK_TARGET_OS_TYPE/native/libjava"
|
||||||
|
|
||||||
# The shared libraries are compiled using the picflag.
|
# The shared libraries are compiled using the picflag.
|
||||||
@ -896,17 +896,18 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
|
|||||||
AC_SUBST(LDFLAGS_TESTEXE)
|
AC_SUBST(LDFLAGS_TESTEXE)
|
||||||
])
|
])
|
||||||
|
|
||||||
# FLAGS_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
|
# FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [ARGUMENT], IF_TRUE: [RUN-IF-TRUE],
|
||||||
# [RUN-IF-FALSE])
|
# IF_FALSE: [RUN-IF-FALSE])
|
||||||
# ------------------------------------------------------------
|
# ------------------------------------------------------------
|
||||||
# Check that the c and c++ compilers support an argument
|
# Check that the c and c++ compilers support an argument
|
||||||
AC_DEFUN([FLAGS_COMPILER_CHECK_ARGUMENTS],
|
BASIC_DEFUN_NAMED([FLAGS_COMPILER_CHECK_ARGUMENTS],
|
||||||
|
[*ARGUMENT IF_TRUE IF_FALSE], [$@],
|
||||||
[
|
[
|
||||||
AC_MSG_CHECKING([if compiler supports "$1"])
|
AC_MSG_CHECKING([if compiler supports "ARG_ARGUMENT"])
|
||||||
supports=yes
|
supports=yes
|
||||||
|
|
||||||
saved_cflags="$CFLAGS"
|
saved_cflags="$CFLAGS"
|
||||||
CFLAGS="$CFLAGS $1"
|
CFLAGS="$CFLAGS ARG_ARGUMENT"
|
||||||
AC_LANG_PUSH([C])
|
AC_LANG_PUSH([C])
|
||||||
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
|
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
|
||||||
[supports=no])
|
[supports=no])
|
||||||
@ -914,7 +915,7 @@ AC_DEFUN([FLAGS_COMPILER_CHECK_ARGUMENTS],
|
|||||||
CFLAGS="$saved_cflags"
|
CFLAGS="$saved_cflags"
|
||||||
|
|
||||||
saved_cxxflags="$CXXFLAGS"
|
saved_cxxflags="$CXXFLAGS"
|
||||||
CXXFLAGS="$CXXFLAG $1"
|
CXXFLAGS="$CXXFLAG ARG_ARGUMENT"
|
||||||
AC_LANG_PUSH([C++])
|
AC_LANG_PUSH([C++])
|
||||||
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
|
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[int i;]])], [],
|
||||||
[supports=no])
|
[supports=no])
|
||||||
@ -923,23 +924,26 @@ AC_DEFUN([FLAGS_COMPILER_CHECK_ARGUMENTS],
|
|||||||
|
|
||||||
AC_MSG_RESULT([$supports])
|
AC_MSG_RESULT([$supports])
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
m4_ifval([$2], [$2], [:])
|
:
|
||||||
|
ARG_IF_TRUE
|
||||||
else
|
else
|
||||||
m4_ifval([$3], [$3], [:])
|
:
|
||||||
|
ARG_IF_FALSE
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
# FLAGS_LINKER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
|
# FLAGS_LINKER_CHECK_ARGUMENTS(ARGUMENT: [ARGUMENT], IF_TRUE: [RUN-IF-TRUE],
|
||||||
# [RUN-IF-FALSE])
|
# IF_FALSE: [RUN-IF-FALSE])
|
||||||
# ------------------------------------------------------------
|
# ------------------------------------------------------------
|
||||||
# Check that the linker support an argument
|
# Check that the linker support an argument
|
||||||
AC_DEFUN([FLAGS_LINKER_CHECK_ARGUMENTS],
|
BASIC_DEFUN_NAMED([FLAGS_LINKER_CHECK_ARGUMENTS],
|
||||||
|
[*ARGUMENT IF_TRUE IF_FALSE], [$@],
|
||||||
[
|
[
|
||||||
AC_MSG_CHECKING([if linker supports "$1"])
|
AC_MSG_CHECKING([if linker supports "ARG_ARGUMENT"])
|
||||||
supports=yes
|
supports=yes
|
||||||
|
|
||||||
saved_ldflags="$LDFLAGS"
|
saved_ldflags="$LDFLAGS"
|
||||||
LDFLAGS="$LDFLAGS $1"
|
LDFLAGS="$LDFLAGS ARG_ARGUMENT"
|
||||||
AC_LANG_PUSH([C])
|
AC_LANG_PUSH([C])
|
||||||
AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],
|
AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],
|
||||||
[], [supports=no])
|
[], [supports=no])
|
||||||
@ -948,9 +952,11 @@ AC_DEFUN([FLAGS_LINKER_CHECK_ARGUMENTS],
|
|||||||
|
|
||||||
AC_MSG_RESULT([$supports])
|
AC_MSG_RESULT([$supports])
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
m4_ifval([$2], [$2], [:])
|
:
|
||||||
|
ARG_IF_TRUE
|
||||||
else
|
else
|
||||||
m4_ifval([$3], [$3], [:])
|
:
|
||||||
|
ARG_IF_FALSE
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
@ -965,14 +971,14 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
|
|||||||
*)
|
*)
|
||||||
ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
|
ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
|
||||||
esac
|
esac
|
||||||
FLAGS_COMPILER_CHECK_ARGUMENTS([$ZERO_ARCHFLAG], [], [ZERO_ARCHFLAG=""])
|
FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [$ZERO_ARCHFLAG], IF_FALSE: [ZERO_ARCHFLAG=""])
|
||||||
AC_SUBST(ZERO_ARCHFLAG)
|
AC_SUBST(ZERO_ARCHFLAG)
|
||||||
|
|
||||||
# Check that the compiler supports -mX (or -qX on AIX) flags
|
# Check that the compiler supports -mX (or -qX on AIX) flags
|
||||||
# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
|
# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
|
||||||
FLAGS_COMPILER_CHECK_ARGUMENTS([${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}],
|
FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}],
|
||||||
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
|
IF_TRUE: [COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
|
||||||
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
|
IF_FALSE: [COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
|
||||||
AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
|
AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
|
||||||
|
|
||||||
AC_ARG_ENABLE([warnings-as-errors], [AS_HELP_STRING([--disable-warnings-as-errors],
|
AC_ARG_ENABLE([warnings-as-errors], [AS_HELP_STRING([--disable-warnings-as-errors],
|
||||||
@ -1013,9 +1019,9 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
|
|||||||
;;
|
;;
|
||||||
gcc)
|
gcc)
|
||||||
# Prior to gcc 4.4, a -Wno-X where X is unknown for that version of gcc will cause an error
|
# Prior to gcc 4.4, a -Wno-X where X is unknown for that version of gcc will cause an error
|
||||||
FLAGS_COMPILER_CHECK_ARGUMENTS([-Wno-this-is-a-warning-that-do-not-exist],
|
FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [-Wno-this-is-a-warning-that-do-not-exist],
|
||||||
[GCC_CAN_DISABLE_WARNINGS=true],
|
IF_TRUE: [GCC_CAN_DISABLE_WARNINGS=true],
|
||||||
[GCC_CAN_DISABLE_WARNINGS=false]
|
IF_FALSE: [GCC_CAN_DISABLE_WARNINGS=false]
|
||||||
)
|
)
|
||||||
if test "x$GCC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
if test "x$GCC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
||||||
DISABLE_WARNING_PREFIX="-Wno-"
|
DISABLE_WARNING_PREFIX="-Wno-"
|
||||||
@ -1026,9 +1032,9 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
|
|||||||
# Repeate the check for the BUILD_CC
|
# Repeate the check for the BUILD_CC
|
||||||
CC_OLD="$CC"
|
CC_OLD="$CC"
|
||||||
CC="$BUILD_CC"
|
CC="$BUILD_CC"
|
||||||
FLAGS_COMPILER_CHECK_ARGUMENTS([-Wno-this-is-a-warning-that-do-not-exist],
|
FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [-Wno-this-is-a-warning-that-do-not-exist],
|
||||||
[BUILD_CC_CAN_DISABLE_WARNINGS=true],
|
IF_TRUE: [BUILD_CC_CAN_DISABLE_WARNINGS=true],
|
||||||
[BUILD_CC_CAN_DISABLE_WARNINGS=false]
|
IF_FALSE: [BUILD_CC_CAN_DISABLE_WARNINGS=false]
|
||||||
)
|
)
|
||||||
if test "x$BUILD_CC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
if test "x$BUILD_CC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
||||||
BUILD_CC_DISABLE_WARNING_PREFIX="-Wno-"
|
BUILD_CC_DISABLE_WARNING_PREFIX="-Wno-"
|
||||||
|
@ -3451,6 +3451,31 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
|
|||||||
# questions.
|
# questions.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# Create a function/macro that takes a series of named arguments. The call is
|
||||||
|
# similar to AC_DEFUN, but the setup of the function looks like this:
|
||||||
|
# BASIC_DEFUN_NAMED([MYFUNC], [FOO *BAR], [$@], [
|
||||||
|
# ... do something
|
||||||
|
# AC_MSG_NOTICE([Value of BAR is ARG_BAR])
|
||||||
|
# ])
|
||||||
|
# A star (*) in front of a named argument means that it is required and it's
|
||||||
|
# presence will be verified. To pass e.g. the first value as a normal indexed
|
||||||
|
# argument, use [m4_shift($@)] as the third argument instead of [$@]. These
|
||||||
|
# arguments are referenced in the function by their name prefixed by ARG_, e.g.
|
||||||
|
# "ARG_FOO".
|
||||||
|
#
|
||||||
|
# The generated function can be called like this:
|
||||||
|
# MYFUNC(FOO: [foo-val], BAR:
|
||||||
|
# [
|
||||||
|
# $ECHO hello world
|
||||||
|
# ])
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Argument 1: Name of the function to define
|
||||||
|
# Argument 2: List of legal named arguments, with a * prefix for required arguments
|
||||||
|
# Argument 3: Argument array to treat as named, typically $@
|
||||||
|
# Argument 4: The main function body
|
||||||
|
|
||||||
|
|
||||||
# Test if $1 is a valid argument to $3 (often is $JAVA passed as $3)
|
# Test if $1 is a valid argument to $3 (often is $JAVA passed as $3)
|
||||||
# If so, then append $1 to $2 \
|
# If so, then append $1 to $2 \
|
||||||
# Also set JVM_ARG_OK to true/false depending on outcome.
|
# Also set JVM_ARG_OK to true/false depending on outcome.
|
||||||
@ -3886,20 +3911,24 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
# FLAGS_COMPILER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
|
# FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [ARGUMENT], IF_TRUE: [RUN-IF-TRUE],
|
||||||
# [RUN-IF-FALSE])
|
# IF_FALSE: [RUN-IF-FALSE])
|
||||||
# ------------------------------------------------------------
|
# ------------------------------------------------------------
|
||||||
# Check that the c and c++ compilers support an argument
|
# Check that the c and c++ compilers support an argument
|
||||||
|
|
||||||
|
|
||||||
# FLAGS_LINKER_CHECK_ARGUMENTS([ARGUMENT], [RUN-IF-TRUE],
|
|
||||||
# [RUN-IF-FALSE])
|
|
||||||
|
# FLAGS_LINKER_CHECK_ARGUMENTS(ARGUMENT: [ARGUMENT], IF_TRUE: [RUN-IF-TRUE],
|
||||||
|
# IF_FALSE: [RUN-IF-FALSE])
|
||||||
# ------------------------------------------------------------
|
# ------------------------------------------------------------
|
||||||
# Check that the linker support an argument
|
# Check that the linker support an argument
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2015, 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.
|
||||||
@ -4810,7 +4839,7 @@ VS_SDK_PLATFORM_NAME_2013=
|
|||||||
#CUSTOM_AUTOCONF_INCLUDE
|
#CUSTOM_AUTOCONF_INCLUDE
|
||||||
|
|
||||||
# Do not change or remove the following line, it is needed for consistency checks:
|
# Do not change or remove the following line, it is needed for consistency checks:
|
||||||
DATE_WHEN_GENERATED=1452261921
|
DATE_WHEN_GENERATED=1452780299
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
@ -45358,6 +45387,54 @@ $as_echo "$as_me: Rewriting BUILD_AR to \"$new_complete\"" >&6;}
|
|||||||
# "-Og" suppported for GCC 4.8 and later
|
# "-Og" suppported for GCC 4.8 and later
|
||||||
CFLAG_OPTIMIZE_DEBUG_FLAG="-Og"
|
CFLAG_OPTIMIZE_DEBUG_FLAG="-Og"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$CFLAG_OPTIMIZE_DEBUG_FLAG\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$CFLAG_OPTIMIZE_DEBUG_FLAG\"" >&5
|
||||||
$as_echo_n "checking if compiler supports \"$CFLAG_OPTIMIZE_DEBUG_FLAG\"... " >&6; }
|
$as_echo_n "checking if compiler supports \"$CFLAG_OPTIMIZE_DEBUG_FLAG\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -45417,15 +45494,76 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
|
:
|
||||||
HAS_CFLAG_OPTIMIZE_DEBUG=true
|
HAS_CFLAG_OPTIMIZE_DEBUG=true
|
||||||
else
|
else
|
||||||
|
:
|
||||||
HAS_CFLAG_OPTIMIZE_DEBUG=false
|
HAS_CFLAG_OPTIMIZE_DEBUG=false
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# "-z relro" supported in GNU binutils 2.17 and later
|
# "-z relro" supported in GNU binutils 2.17 and later
|
||||||
LINKER_RELRO_FLAG="-Wl,-z,relro"
|
LINKER_RELRO_FLAG="-Wl,-z,relro"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if linker supports \"$LINKER_RELRO_FLAG\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if linker supports \"$LINKER_RELRO_FLAG\"" >&5
|
||||||
$as_echo_n "checking if linker supports \"$LINKER_RELRO_FLAG\"... " >&6; }
|
$as_echo_n "checking if linker supports \"$LINKER_RELRO_FLAG\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -45467,15 +45605,76 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
|
:
|
||||||
HAS_LINKER_RELRO=true
|
HAS_LINKER_RELRO=true
|
||||||
else
|
else
|
||||||
|
:
|
||||||
HAS_LINKER_RELRO=false
|
HAS_LINKER_RELRO=false
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# "-z now" supported in GNU binutils 2.11 and later
|
# "-z now" supported in GNU binutils 2.11 and later
|
||||||
LINKER_NOW_FLAG="-Wl,-z,now"
|
LINKER_NOW_FLAG="-Wl,-z,now"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if linker supports \"$LINKER_NOW_FLAG\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if linker supports \"$LINKER_NOW_FLAG\"" >&5
|
||||||
$as_echo_n "checking if linker supports \"$LINKER_NOW_FLAG\"... " >&6; }
|
$as_echo_n "checking if linker supports \"$LINKER_NOW_FLAG\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -45517,11 +45716,24 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
|
:
|
||||||
HAS_LINKER_NOW=true
|
HAS_LINKER_NOW=true
|
||||||
else
|
else
|
||||||
|
:
|
||||||
HAS_LINKER_NOW=false
|
HAS_LINKER_NOW=false
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Check for broken SuSE 'ld' for which 'Only anonymous version tag is allowed
|
# Check for broken SuSE 'ld' for which 'Only anonymous version tag is allowed
|
||||||
@ -46842,6 +47054,49 @@ $as_echo "$ac_cv_c_bigendian" >&6; }
|
|||||||
# Not all versions of gcc support -fstack-protector
|
# Not all versions of gcc support -fstack-protector
|
||||||
STACK_PROTECTOR_CFLAG="-fstack-protector-all"
|
STACK_PROTECTOR_CFLAG="-fstack-protector-all"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$STACK_PROTECTOR_CFLAG\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$STACK_PROTECTOR_CFLAG\"" >&5
|
||||||
$as_echo_n "checking if compiler supports \"$STACK_PROTECTOR_CFLAG\"... " >&6; }
|
$as_echo_n "checking if compiler supports \"$STACK_PROTECTOR_CFLAG\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -46902,11 +47157,24 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
:
|
:
|
||||||
|
|
||||||
else
|
else
|
||||||
|
:
|
||||||
STACK_PROTECTOR_CFLAG=""
|
STACK_PROTECTOR_CFLAG=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
CFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
CFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
||||||
CXXFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
CXXFLAGS_DEBUG_OPTIONS="$STACK_PROTECTOR_CFLAG --param ssp-buffer-size=1"
|
||||||
;;
|
;;
|
||||||
@ -47384,6 +47652,49 @@ $as_echo "$supports" >&6; }
|
|||||||
ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
|
ZERO_ARCHFLAG="${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}"
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$ZERO_ARCHFLAG\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"$ZERO_ARCHFLAG\"" >&5
|
||||||
$as_echo_n "checking if compiler supports \"$ZERO_ARCHFLAG\"... " >&6; }
|
$as_echo_n "checking if compiler supports \"$ZERO_ARCHFLAG\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -47444,15 +47755,76 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
:
|
:
|
||||||
|
|
||||||
else
|
else
|
||||||
|
:
|
||||||
ZERO_ARCHFLAG=""
|
ZERO_ARCHFLAG=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Check that the compiler supports -mX (or -qX on AIX) flags
|
# Check that the compiler supports -mX (or -qX on AIX) flags
|
||||||
# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
|
# Set COMPILER_SUPPORTS_TARGET_BITS_FLAG to 'true' if it does
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}\"" >&5
|
||||||
$as_echo_n "checking if compiler supports \"${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}\"... " >&6; }
|
$as_echo_n "checking if compiler supports \"${COMPILER_TARGET_BITS_FLAG}${OPENJDK_TARGET_CPU_BITS}\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -47512,13 +47884,26 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
|
:
|
||||||
COMPILER_SUPPORTS_TARGET_BITS_FLAG=true
|
COMPILER_SUPPORTS_TARGET_BITS_FLAG=true
|
||||||
else
|
else
|
||||||
|
:
|
||||||
COMPILER_SUPPORTS_TARGET_BITS_FLAG=false
|
COMPILER_SUPPORTS_TARGET_BITS_FLAG=false
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Check whether --enable-warnings-as-errors was given.
|
# Check whether --enable-warnings-as-errors was given.
|
||||||
if test "${enable_warnings_as_errors+set}" = set; then :
|
if test "${enable_warnings_as_errors+set}" = set; then :
|
||||||
enableval=$enable_warnings_as_errors;
|
enableval=$enable_warnings_as_errors;
|
||||||
@ -47565,6 +47950,54 @@ $as_echo "yes (default)" >&6; }
|
|||||||
gcc)
|
gcc)
|
||||||
# Prior to gcc 4.4, a -Wno-X where X is unknown for that version of gcc will cause an error
|
# Prior to gcc 4.4, a -Wno-X where X is unknown for that version of gcc will cause an error
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"" >&5
|
||||||
$as_echo_n "checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"... " >&6; }
|
$as_echo_n "checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -47624,12 +48057,25 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
|
:
|
||||||
GCC_CAN_DISABLE_WARNINGS=true
|
GCC_CAN_DISABLE_WARNINGS=true
|
||||||
else
|
else
|
||||||
|
:
|
||||||
GCC_CAN_DISABLE_WARNINGS=false
|
GCC_CAN_DISABLE_WARNINGS=false
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if test "x$GCC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
if test "x$GCC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
||||||
DISABLE_WARNING_PREFIX="-Wno-"
|
DISABLE_WARNING_PREFIX="-Wno-"
|
||||||
else
|
else
|
||||||
@ -47640,6 +48086,54 @@ $as_echo "$supports" >&6; }
|
|||||||
CC_OLD="$CC"
|
CC_OLD="$CC"
|
||||||
CC="$BUILD_CC"
|
CC="$BUILD_CC"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Execute function body
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"" >&5
|
||||||
$as_echo_n "checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"... " >&6; }
|
$as_echo_n "checking if compiler supports \"-Wno-this-is-a-warning-that-do-not-exist\"... " >&6; }
|
||||||
supports=yes
|
supports=yes
|
||||||
@ -47699,12 +48193,25 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $supports" >&5
|
||||||
$as_echo "$supports" >&6; }
|
$as_echo "$supports" >&6; }
|
||||||
if test "x$supports" = "xyes" ; then
|
if test "x$supports" = "xyes" ; then
|
||||||
|
:
|
||||||
BUILD_CC_CAN_DISABLE_WARNINGS=true
|
BUILD_CC_CAN_DISABLE_WARNINGS=true
|
||||||
else
|
else
|
||||||
|
:
|
||||||
BUILD_CC_CAN_DISABLE_WARNINGS=false
|
BUILD_CC_CAN_DISABLE_WARNINGS=false
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if test "x$BUILD_CC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
if test "x$BUILD_CC_CAN_DISABLE_WARNINGS" = "xtrue"; then
|
||||||
BUILD_CC_DISABLE_WARNING_PREFIX="-Wno-"
|
BUILD_CC_DISABLE_WARNING_PREFIX="-Wno-"
|
||||||
else
|
else
|
||||||
@ -61523,7 +62030,6 @@ fi
|
|||||||
|
|
||||||
# Move configure.log from current directory to the build output root
|
# Move configure.log from current directory to the build output root
|
||||||
if test -e ./configure.log; then
|
if test -e ./configure.log; then
|
||||||
echo found it
|
|
||||||
$MV -f ./configure.log "$OUTPUT_ROOT/configure.log" 2> /dev/null
|
$MV -f ./configure.log "$OUTPUT_ROOT/configure.log" 2> /dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -75,8 +75,8 @@ AC_DEFUN([TOOLCHAIN_SETUP_FILENAME_PATTERNS],
|
|||||||
# For full static builds, we're overloading the SHARED_LIBRARY
|
# For full static builds, we're overloading the SHARED_LIBRARY
|
||||||
# variables in order to limit the amount of changes required.
|
# variables in order to limit the amount of changes required.
|
||||||
# It would be better to remove SHARED and just use LIBRARY and
|
# It would be better to remove SHARED and just use LIBRARY and
|
||||||
# LIBRARY_SUFFIX for libraries that can be built either
|
# LIBRARY_SUFFIX for libraries that can be built either
|
||||||
# shared or static and use STATIC_* for libraries that are
|
# shared or static and use STATIC_* for libraries that are
|
||||||
# always built statically.
|
# always built statically.
|
||||||
if test "x$STATIC_BUILD" = xtrue; then
|
if test "x$STATIC_BUILD" = xtrue; then
|
||||||
SHARED_LIBRARY='lib[$]1.a'
|
SHARED_LIBRARY='lib[$]1.a'
|
||||||
@ -824,21 +824,21 @@ AC_DEFUN_ONCE([TOOLCHAIN_MISC_CHECKS],
|
|||||||
|
|
||||||
# "-Og" suppported for GCC 4.8 and later
|
# "-Og" suppported for GCC 4.8 and later
|
||||||
CFLAG_OPTIMIZE_DEBUG_FLAG="-Og"
|
CFLAG_OPTIMIZE_DEBUG_FLAG="-Og"
|
||||||
FLAGS_COMPILER_CHECK_ARGUMENTS([$CFLAG_OPTIMIZE_DEBUG_FLAG],
|
FLAGS_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [$CFLAG_OPTIMIZE_DEBUG_FLAG],
|
||||||
[HAS_CFLAG_OPTIMIZE_DEBUG=true],
|
IF_TRUE: [HAS_CFLAG_OPTIMIZE_DEBUG=true],
|
||||||
[HAS_CFLAG_OPTIMIZE_DEBUG=false])
|
IF_FALSE: [HAS_CFLAG_OPTIMIZE_DEBUG=false])
|
||||||
|
|
||||||
# "-z relro" supported in GNU binutils 2.17 and later
|
# "-z relro" supported in GNU binutils 2.17 and later
|
||||||
LINKER_RELRO_FLAG="-Wl,-z,relro"
|
LINKER_RELRO_FLAG="-Wl,-z,relro"
|
||||||
FLAGS_LINKER_CHECK_ARGUMENTS([$LINKER_RELRO_FLAG],
|
FLAGS_LINKER_CHECK_ARGUMENTS(ARGUMENT: [$LINKER_RELRO_FLAG],
|
||||||
[HAS_LINKER_RELRO=true],
|
IF_TRUE: [HAS_LINKER_RELRO=true],
|
||||||
[HAS_LINKER_RELRO=false])
|
IF_FALSE: [HAS_LINKER_RELRO=false])
|
||||||
|
|
||||||
# "-z now" supported in GNU binutils 2.11 and later
|
# "-z now" supported in GNU binutils 2.11 and later
|
||||||
LINKER_NOW_FLAG="-Wl,-z,now"
|
LINKER_NOW_FLAG="-Wl,-z,now"
|
||||||
FLAGS_LINKER_CHECK_ARGUMENTS([$LINKER_NOW_FLAG],
|
FLAGS_LINKER_CHECK_ARGUMENTS(ARGUMENT: [$LINKER_NOW_FLAG],
|
||||||
[HAS_LINKER_NOW=true],
|
IF_TRUE: [HAS_LINKER_NOW=true],
|
||||||
[HAS_LINKER_NOW=false])
|
IF_FALSE: [HAS_LINKER_NOW=false])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Check for broken SuSE 'ld' for which 'Only anonymous version tag is allowed
|
# Check for broken SuSE 'ld' for which 'Only anonymous version tag is allowed
|
||||||
|
@ -343,3 +343,4 @@ feb1bd85d7990dcf5584ca9e53104269c01db006 jdk-9+96
|
|||||||
ea285530245cf4e0edf0479121a41347d3030eba jdk-9+98
|
ea285530245cf4e0edf0479121a41347d3030eba jdk-9+98
|
||||||
180212ee1d8710691ba9944593dfc1ff3e4f1532 jdk-9+99
|
180212ee1d8710691ba9944593dfc1ff3e4f1532 jdk-9+99
|
||||||
791d0d3ac0138faeb6110bd840a4545bc1950df2 jdk-9+100
|
791d0d3ac0138faeb6110bd840a4545bc1950df2 jdk-9+100
|
||||||
|
30dfb3bd3d06b4bb80a087babc0d1841edba187b jdk-9+101
|
||||||
|
@ -503,3 +503,4 @@ de592ea5f7ba0f8a8c5afc03bd169f7690c72b6f jdk-9+97
|
|||||||
e5b1a23be1e105417ba1c4c576ab373eb3fa2c2b jdk-9+98
|
e5b1a23be1e105417ba1c4c576ab373eb3fa2c2b jdk-9+98
|
||||||
f008e8cc10d5b3212fb22d58c96fa01d38654f19 jdk-9+99
|
f008e8cc10d5b3212fb22d58c96fa01d38654f19 jdk-9+99
|
||||||
bdb0acafc63c42e84d9d8195bf2e2b25ee9c3306 jdk-9+100
|
bdb0acafc63c42e84d9d8195bf2e2b25ee9c3306 jdk-9+100
|
||||||
|
9f45d3d57d6948cf526fbc2e2891a9a74ac6941a jdk-9+101
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2016, 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
|
||||||
@ -124,7 +124,7 @@ static JNINativeMethod lookup_special_native_methods[] = {
|
|||||||
{ CC"Java_jdk_internal_misc_Unsafe_registerNatives", NULL, FN_PTR(JVM_RegisterUnsafeMethods) },
|
{ CC"Java_jdk_internal_misc_Unsafe_registerNatives", NULL, FN_PTR(JVM_RegisterUnsafeMethods) },
|
||||||
{ CC"Java_sun_misc_Unsafe_registerNatives", NULL, FN_PTR(JVM_RegisterUnsafeMethods) },
|
{ CC"Java_sun_misc_Unsafe_registerNatives", NULL, FN_PTR(JVM_RegisterUnsafeMethods) },
|
||||||
{ CC"Java_java_lang_invoke_MethodHandleNatives_registerNatives", NULL, FN_PTR(JVM_RegisterMethodHandleMethods) },
|
{ CC"Java_java_lang_invoke_MethodHandleNatives_registerNatives", NULL, FN_PTR(JVM_RegisterMethodHandleMethods) },
|
||||||
{ CC"Java_sun_misc_Perf_registerNatives", NULL, FN_PTR(JVM_RegisterPerfMethods) },
|
{ CC"Java_jdk_internal_perf_Perf_registerNatives", NULL, FN_PTR(JVM_RegisterPerfMethods) },
|
||||||
{ CC"Java_sun_hotspot_WhiteBox_registerNatives", NULL, FN_PTR(JVM_RegisterWhiteBoxMethods) },
|
{ CC"Java_sun_hotspot_WhiteBox_registerNatives", NULL, FN_PTR(JVM_RegisterWhiteBoxMethods) },
|
||||||
#if INCLUDE_JVMCI
|
#if INCLUDE_JVMCI
|
||||||
{ CC"Java_jdk_vm_ci_runtime_JVMCI_initializeRuntime", NULL, FN_PTR(JVM_GetJVMCIRuntime) },
|
{ CC"Java_jdk_vm_ci_runtime_JVMCI_initializeRuntime", NULL, FN_PTR(JVM_GetJVMCIRuntime) },
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2016, 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
|
||||||
@ -34,7 +34,7 @@
|
|||||||
#include "runtime/perfMemory.hpp"
|
#include "runtime/perfMemory.hpp"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Implementation of class sun.misc.Perf
|
* Implementation of class jdk.internal.perf.Perf
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@ -343,3 +343,4 @@ c8d0845877a811ab4350935892f826929359a3ff jdk-9+95
|
|||||||
52b01339235f24c93b679bd6b8fb36a1072ad0ac jdk-9+98
|
52b01339235f24c93b679bd6b8fb36a1072ad0ac jdk-9+98
|
||||||
52774b544850c791f1d1c67db2601b33739b18c9 jdk-9+99
|
52774b544850c791f1d1c67db2601b33739b18c9 jdk-9+99
|
||||||
d45bcd374f6057851e3c2dcd45607cd362afadfa jdk-9+100
|
d45bcd374f6057851e3c2dcd45607cd362afadfa jdk-9+100
|
||||||
|
d3e834ff74e724a2b92a558e18e8cbf81c6dbc59 jdk-9+101
|
||||||
|
@ -32,7 +32,6 @@ import java.net.URI;
|
|||||||
import java.net.URISyntaxException;
|
import java.net.URISyntaxException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.NoSuchElementException;
|
import java.util.NoSuchElementException;
|
||||||
@ -43,6 +42,7 @@ import java.util.stream.StreamSupport;
|
|||||||
import static javax.xml.catalog.BaseEntry.CatalogEntryType;
|
import static javax.xml.catalog.BaseEntry.CatalogEntryType;
|
||||||
import static javax.xml.catalog.CatalogFeatures.DEFER_TRUE;
|
import static javax.xml.catalog.CatalogFeatures.DEFER_TRUE;
|
||||||
import javax.xml.catalog.CatalogFeatures.Feature;
|
import javax.xml.catalog.CatalogFeatures.Feature;
|
||||||
|
import static javax.xml.catalog.CatalogMessages.formatMessage;
|
||||||
import javax.xml.parsers.ParserConfigurationException;
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
import javax.xml.parsers.SAXParser;
|
import javax.xml.parsers.SAXParser;
|
||||||
import javax.xml.parsers.SAXParserFactory;
|
import javax.xml.parsers.SAXParserFactory;
|
||||||
@ -109,25 +109,20 @@ class CatalogImpl extends GroupEntry implements Catalog {
|
|||||||
*/
|
*/
|
||||||
public CatalogImpl(CatalogImpl parent, CatalogFeatures f, String... file) throws CatalogException {
|
public CatalogImpl(CatalogImpl parent, CatalogFeatures f, String... file) throws CatalogException {
|
||||||
super(CatalogEntryType.CATALOG);
|
super(CatalogEntryType.CATALOG);
|
||||||
this.parent = parent;
|
|
||||||
if (parent == null) {
|
|
||||||
level = 0;
|
|
||||||
} else {
|
|
||||||
level = parent.level + 1;
|
|
||||||
}
|
|
||||||
if (f == null) {
|
if (f == null) {
|
||||||
this.features = CatalogFeatures.defaults();
|
throw new NullPointerException(
|
||||||
} else {
|
formatMessage(CatalogMessages.ERR_NULL_ARGUMENT, new Object[]{"CatalogFeatures"}));
|
||||||
this.features = f;
|
|
||||||
}
|
}
|
||||||
setPrefer(features.get(Feature.PREFER));
|
|
||||||
setDeferred(features.get(Feature.DEFER));
|
if (file.length > 0) {
|
||||||
setResolve(features.get(Feature.RESOLVE));
|
CatalogMessages.reportNPEOnNull("The path to the catalog file", file[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
init(parent, f);
|
||||||
|
|
||||||
//Path of catalog files
|
//Path of catalog files
|
||||||
String[] catalogFile = file;
|
String[] catalogFile = file;
|
||||||
if (level == 0
|
if (level == 0 && file.length == 0) {
|
||||||
&& (file == null || (file.length == 0 || file[0] == null))) {
|
|
||||||
String files = features.get(Feature.FILES);
|
String files = features.get(Feature.FILES);
|
||||||
if (files != null) {
|
if (files != null) {
|
||||||
catalogFile = files.split(";[ ]*");
|
catalogFile = files.split(";[ ]*");
|
||||||
@ -166,6 +161,23 @@ class CatalogImpl extends GroupEntry implements Catalog {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void init(CatalogImpl parent, CatalogFeatures f) {
|
||||||
|
this.parent = parent;
|
||||||
|
if (parent == null) {
|
||||||
|
level = 0;
|
||||||
|
} else {
|
||||||
|
level = parent.level + 1;
|
||||||
|
}
|
||||||
|
if (f == null) {
|
||||||
|
this.features = CatalogFeatures.defaults();
|
||||||
|
} else {
|
||||||
|
this.features = f;
|
||||||
|
}
|
||||||
|
setPrefer(features.get(Feature.PREFER));
|
||||||
|
setDeferred(features.get(Feature.DEFER));
|
||||||
|
setResolve(features.get(Feature.RESOLVE));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Resets the Catalog instance to its initial state.
|
* Resets the Catalog instance to its initial state.
|
||||||
*/
|
*/
|
||||||
|
@ -38,33 +38,38 @@ public final class CatalogManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a Catalog object using the specified feature settings and path to
|
* Creates a {@code Catalog} object using the specified feature settings and
|
||||||
* a catalog file. If the features is null, the default features will be used.
|
* path to one or more catalog files.
|
||||||
* If the path is empty, System property {@code javax.xml.catalog.files} will
|
|
||||||
* be read to locate the initial list of catalog files.
|
|
||||||
* <p>
|
* <p>
|
||||||
* If more than one catalog files are specified through the path argument or
|
* If {@code paths} is empty, system property {@code javax.xml.catalog.files}
|
||||||
|
* will be read to locate the initial list of catalog files.
|
||||||
|
* <p>
|
||||||
|
* If more than one catalog files are specified through the paths argument or
|
||||||
* {@code javax.xml.catalog.files} property, the first entry is considered
|
* {@code javax.xml.catalog.files} property, the first entry is considered
|
||||||
* the main catalog, while others are treated as alternative catalogs after
|
* the main catalog, while others are treated as alternative catalogs after
|
||||||
* those referenced by the {@code nextCatalog} elements in the main catalog.
|
* those referenced by the {@code nextCatalog} elements in the main catalog.
|
||||||
|
* <p>
|
||||||
|
* As specified in
|
||||||
|
* <a href="https://www.oasis-open.org/committees/download.php/14809/xml-catalogs.html#s.res.fail">
|
||||||
|
* XML Catalogs, OASIS Standard V1.1</a>, invalid path entries will be ignored.
|
||||||
|
* No error will be reported. In case all entries are invalid, the resolver
|
||||||
|
* will return as no mapping is found.
|
||||||
*
|
*
|
||||||
* @param features the catalog features
|
* @param features the catalog features
|
||||||
* @param path path(s) to one or more catalogs.
|
* @param paths path(s) to one or more catalogs.
|
||||||
*
|
*
|
||||||
* @return a catalog instance
|
* @return an instance of a {@code Catalog}
|
||||||
* @throws CatalogException If no catalog can be found whether through the
|
* @throws CatalogException If an error occurs while parsing the catalog
|
||||||
* specified path or the System property {@code javax.xml.catalog.files}, or
|
|
||||||
* an error occurs while parsing the catalog
|
|
||||||
*/
|
*/
|
||||||
public static Catalog catalog(CatalogFeatures features, String... path) {
|
public static Catalog catalog(CatalogFeatures features, String... paths) {
|
||||||
return new CatalogImpl(features, path);
|
return new CatalogImpl(features, paths);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an instance of a CatalogResolver using the specified catalog.
|
* Creates an instance of a {@code CatalogResolver} using the specified catalog.
|
||||||
*
|
*
|
||||||
* @param catalog the catalog instance
|
* @param catalog the catalog instance
|
||||||
* @return an instance of a CatalogResolver
|
* @return an instance of a {@code CatalogResolver}
|
||||||
*/
|
*/
|
||||||
public static CatalogResolver catalogResolver(Catalog catalog) {
|
public static CatalogResolver catalogResolver(Catalog catalog) {
|
||||||
if (catalog == null) CatalogMessages.reportNPEOnNull("catalog", null);
|
if (catalog == null) CatalogMessages.reportNPEOnNull("catalog", null);
|
||||||
@ -72,10 +77,10 @@ public final class CatalogManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an instance of a CatalogUriResolver using the specified catalog.
|
* Creates an instance of a {@code CatalogUriResolver} using the specified catalog.
|
||||||
*
|
*
|
||||||
* @param catalog the catalog instance
|
* @param catalog the catalog instance
|
||||||
* @return an instance of a CatalogResolver
|
* @return an instance of a {@code CatalogResolver}
|
||||||
*/
|
*/
|
||||||
public static CatalogUriResolver catalogUriResolver(Catalog catalog) {
|
public static CatalogUriResolver catalogUriResolver(Catalog catalog) {
|
||||||
if (catalog == null) CatalogMessages.reportNPEOnNull("catalog", null);
|
if (catalog == null) CatalogMessages.reportNPEOnNull("catalog", null);
|
||||||
@ -83,50 +88,60 @@ public final class CatalogManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an instance of a CatalogResolver using the specified feature settings
|
* Creates an instance of a {@code CatalogResolver} using the specified feature
|
||||||
* and path to a catalog file. If the features is null, the default features will
|
* settings and path to one or more catalog files.
|
||||||
* be used. If the path is empty, System property {@code javax.xml.catalog.files}
|
* <p>
|
||||||
|
* If {@code paths} is empty, system property {@code javax.xml.catalog.files}
|
||||||
* will be read to locate the initial list of catalog files.
|
* will be read to locate the initial list of catalog files.
|
||||||
* <p>
|
* <p>
|
||||||
* If more than one catalog files are specified through the path argument or
|
* If more than one catalog files are specified through the paths argument or
|
||||||
* {@code javax.xml.catalog.files} property, the first entry is considered
|
* {@code javax.xml.catalog.files} property, the first entry is considered
|
||||||
* the main catalog, while others are treated as alternative catalogs after
|
* the main catalog, while others are treated as alternative catalogs after
|
||||||
* those referenced by the {@code nextCatalog} elements in the main catalog.
|
* those referenced by the {@code nextCatalog} elements in the main catalog.
|
||||||
|
* <p>
|
||||||
|
* As specified in
|
||||||
|
* <a href="https://www.oasis-open.org/committees/download.php/14809/xml-catalogs.html#s.res.fail">
|
||||||
|
* XML Catalogs, OASIS Standard V1.1</a>, invalid path entries will be ignored.
|
||||||
|
* No error will be reported. In case all entries are invalid, the resolver
|
||||||
|
* will return as no mapping is found.
|
||||||
*
|
*
|
||||||
* @param features the catalog features
|
* @param features the catalog features
|
||||||
* @param path the path(s) to one or more catalogs
|
* @param paths the path(s) to one or more catalogs
|
||||||
*
|
*
|
||||||
* @return an instance of a CatalogResolver
|
* @return an instance of a {@code CatalogResolver}
|
||||||
* @throws CatalogException If no catalog can be found whether through the
|
* @throws CatalogException If an error occurs while parsing the catalog
|
||||||
* specified path or the System property {@code javax.xml.catalog.files}, or
|
|
||||||
* an error occurs while parsing the catalog
|
|
||||||
*/
|
*/
|
||||||
public static CatalogResolver catalogResolver(CatalogFeatures features, String... path) {
|
public static CatalogResolver catalogResolver(CatalogFeatures features, String... paths) {
|
||||||
Catalog catalog = catalog(features, path);
|
Catalog catalog = catalog(features, paths);
|
||||||
return new CatalogResolverImpl(catalog);
|
return new CatalogResolverImpl(catalog);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an instance of a CatalogUriResolver using the specified feature settings
|
* Creates an instance of a {@code CatalogUriResolver} using the specified
|
||||||
* and path to a catalog file. If the features is null, the default features will
|
* feature settings and path to one or more catalog files.
|
||||||
* be used. If the path is empty, System property {@code javax.xml.catalog.files}
|
* <p>
|
||||||
|
* If {@code paths} is empty, system property {@code javax.xml.catalog.files}
|
||||||
* will be read to locate the initial list of catalog files.
|
* will be read to locate the initial list of catalog files.
|
||||||
* <p>
|
* <p>
|
||||||
* If more than one catalog files are specified through the path argument or
|
* If more than one catalog files are specified through the paths argument or
|
||||||
* {@code javax.xml.catalog.files} property, the first entry is considered
|
* {@code javax.xml.catalog.files} property, the first entry is considered
|
||||||
* the main catalog, while others are treated as alternative catalogs after
|
* the main catalog, while others are treated as alternative catalogs after
|
||||||
* those referenced by the {@code nextCatalog} elements in the main catalog.
|
* those referenced by the {@code nextCatalog} elements in the main catalog.
|
||||||
|
* <p>
|
||||||
|
* As specified in
|
||||||
|
* <a href="https://www.oasis-open.org/committees/download.php/14809/xml-catalogs.html#s.res.fail">
|
||||||
|
* XML Catalogs, OASIS Standard V1.1</a>, invalid path entries will be ignored.
|
||||||
|
* No error will be reported. In case all entries are invalid, the resolver
|
||||||
|
* will return as no mapping is found.
|
||||||
*
|
*
|
||||||
* @param features the catalog features
|
* @param features the catalog features
|
||||||
* @param path the path(s) to one or more catalogs
|
* @param paths the path(s) to one or more catalogs
|
||||||
*
|
*
|
||||||
* @return an instance of a CatalogResolver
|
* @return an instance of a {@code CatalogUriResolver}
|
||||||
* @throws CatalogException If no catalog can be found whether through the
|
* @throws CatalogException If an error occurs while parsing the catalog
|
||||||
* specified path or the System property {@code javax.xml.catalog.files}, or
|
|
||||||
* an error occurs while parsing the catalog
|
|
||||||
*/
|
*/
|
||||||
public static CatalogUriResolver catalogUriResolver(CatalogFeatures features, String... path) {
|
public static CatalogUriResolver catalogUriResolver(CatalogFeatures features, String... paths) {
|
||||||
Catalog catalog = catalog(features, path);
|
Catalog catalog = catalog(features, paths);
|
||||||
return new CatalogUriResolverImpl(catalog);
|
return new CatalogUriResolverImpl(catalog);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,9 +43,9 @@ public interface CatalogUriResolver extends URIResolver {
|
|||||||
* absolute if the absolute URI is required
|
* absolute if the absolute URI is required
|
||||||
*
|
*
|
||||||
* @return a {@link javax.xml.transform.Source} object if a mapping is found.
|
* @return a {@link javax.xml.transform.Source} object if a mapping is found.
|
||||||
* If no mapping is found, returns a {@link javax.xml.transform.Source} object
|
* If no mapping is found, returns an empty {@link javax.xml.transform.Source}
|
||||||
* containing an empty {@link java.io.Reader} if the
|
* object if the {@code javax.xml.catalog.resolve} property is set to
|
||||||
* {@code javax.xml.catalog.resolve} property is set to {@code ignore};
|
* {@code ignore};
|
||||||
* returns a {@link javax.xml.transform.Source} object with the original URI
|
* returns a {@link javax.xml.transform.Source} object with the original URI
|
||||||
* (href, or href resolved with base if base is not null) if the
|
* (href, or href resolved with base if base is not null) if the
|
||||||
* {@code javax.xml.catalog.resolve} property is set to {@code continue}.
|
* {@code javax.xml.catalog.resolve} property is set to {@code continue}.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 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
|
||||||
@ -72,6 +72,7 @@ final class RewriteSystem extends BaseEntry {
|
|||||||
public String getSystemIdStartString () {
|
public String getSystemIdStartString () {
|
||||||
return systemIdStartString;
|
return systemIdStartString;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the rewritePrefix attribute.
|
* Get the rewritePrefix attribute.
|
||||||
* @return The rewritePrefix attribute value.
|
* @return The rewritePrefix attribute value.
|
||||||
@ -80,7 +81,6 @@ final class RewriteSystem extends BaseEntry {
|
|||||||
return rewritePrefix;
|
return rewritePrefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Try to match the specified systemId with the entry. Return the match if it
|
* Try to match the specified systemId with the entry. Return the match if it
|
||||||
* is successful and the length of the systemIdStartString is longer than the
|
* is successful and the length of the systemIdStartString is longer than the
|
||||||
@ -91,14 +91,20 @@ final class RewriteSystem extends BaseEntry {
|
|||||||
* @return The replacement URI if the match is successful, null if not.
|
* @return The replacement URI if the match is successful, null if not.
|
||||||
*/
|
*/
|
||||||
public String match(String systemId, int currentMatch) {
|
public String match(String systemId, int currentMatch) {
|
||||||
if (systemIdStartString.length() <= systemId.length() &&
|
if (systemIdStartString.length() < systemId.length() &&
|
||||||
systemIdStartString.equals(systemId.substring(0, systemIdStartString.length()))) {
|
systemIdStartString.equals(systemId.substring(0, systemIdStartString.length()))) {
|
||||||
if (currentMatch < systemIdStartString.length()) {
|
if (currentMatch < systemIdStartString.length()) {
|
||||||
String prefix = rewritePrefix.toExternalForm();
|
String prefix = rewritePrefix.toExternalForm();
|
||||||
if (!prefix.endsWith(SLASH) && !systemId.startsWith(SLASH)) {
|
String sysId;
|
||||||
return prefix + SLASH + systemId.substring(systemIdStartString.length());
|
if (systemIdStartString.endsWith(SLASH)) {
|
||||||
|
sysId = systemId.substring(systemIdStartString.length());
|
||||||
} else {
|
} else {
|
||||||
return prefix + systemId.substring(systemIdStartString.length());
|
sysId = systemId.substring(systemIdStartString.length() + 1);
|
||||||
|
}
|
||||||
|
if (prefix.endsWith(SLASH)) {
|
||||||
|
return prefix + sysId;
|
||||||
|
} else {
|
||||||
|
return prefix + SLASH + sysId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 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
|
||||||
@ -72,6 +72,7 @@ final class RewriteUri extends BaseEntry {
|
|||||||
public String getURIStartString () {
|
public String getURIStartString () {
|
||||||
return uriStartString;
|
return uriStartString;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the rewritePrefix attribute.
|
* Get the rewritePrefix attribute.
|
||||||
* @return The rewritePrefix attribute value.
|
* @return The rewritePrefix attribute value.
|
||||||
@ -91,14 +92,20 @@ final class RewriteUri extends BaseEntry {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String match(String systemId, int currentMatch) {
|
public String match(String systemId, int currentMatch) {
|
||||||
if (uriStartString.length() <= systemId.length() &&
|
if (uriStartString.length() < systemId.length() &&
|
||||||
uriStartString.equals(systemId.substring(0, uriStartString.length()))) {
|
uriStartString.equals(systemId.substring(0, uriStartString.length()))) {
|
||||||
if (currentMatch < uriStartString.length()) {
|
if (currentMatch < uriStartString.length()) {
|
||||||
String prefix = rewritePrefix.toExternalForm();
|
String prefix = rewritePrefix.toExternalForm();
|
||||||
if (!prefix.endsWith(SLASH) && !systemId.startsWith(SLASH)) {
|
String sysId;
|
||||||
return prefix + SLASH + systemId.substring(uriStartString.length());
|
if (uriStartString.endsWith(SLASH)) {
|
||||||
|
sysId = systemId.substring(uriStartString.length());
|
||||||
} else {
|
} else {
|
||||||
return prefix + systemId.substring(uriStartString.length());
|
sysId = systemId.substring(uriStartString.length() + 1);
|
||||||
|
}
|
||||||
|
if (prefix.endsWith(SLASH)) {
|
||||||
|
return prefix + sysId;
|
||||||
|
} else {
|
||||||
|
return prefix + SLASH + sysId;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2005, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2016, 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
|
||||||
@ -52,4 +52,17 @@ public interface Source {
|
|||||||
* if setSystemId was not called.
|
* if setSystemId was not called.
|
||||||
*/
|
*/
|
||||||
public String getSystemId();
|
public String getSystemId();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the {@code Source} object is empty. Empty means
|
||||||
|
* that there is no input available from this Source.
|
||||||
|
*
|
||||||
|
* @implSpec The default implementation of this method throws
|
||||||
|
* {@link UnsupportedOperationException}.
|
||||||
|
*
|
||||||
|
* @return true if the {@code Source} object is empty, false otherwise
|
||||||
|
*/
|
||||||
|
default boolean isEmpty() {
|
||||||
|
throw new UnsupportedOperationException("The isEmpty method is not supported.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2005, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2016, 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
|
||||||
@ -122,6 +122,7 @@ public class DOMSource implements Source {
|
|||||||
*
|
*
|
||||||
* @param systemID Base URL for this DOM tree.
|
* @param systemID Base URL for this DOM tree.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void setSystemId(String systemID) {
|
public void setSystemId(String systemID) {
|
||||||
this.systemID = systemID;
|
this.systemID = systemID;
|
||||||
}
|
}
|
||||||
@ -132,7 +133,25 @@ public class DOMSource implements Source {
|
|||||||
*
|
*
|
||||||
* @return Base URL for this DOM tree.
|
* @return Base URL for this DOM tree.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public String getSystemId() {
|
public String getSystemId() {
|
||||||
return this.systemID;
|
return this.systemID;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the {@code DOMSource} object is empty. Empty is
|
||||||
|
* defined as follows:
|
||||||
|
* <ul>
|
||||||
|
* <li>if the system identifier and node are {@code null};
|
||||||
|
* </li>
|
||||||
|
* <li>if the system identifier is null, and the {@code node} has no child nodes.
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @return true if the {@code DOMSource} object is empty, false otherwise
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return systemID == null && (node == null || !node.hasChildNodes());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2016, 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
|
||||||
@ -147,6 +147,7 @@ public class SAXSource implements Source {
|
|||||||
*
|
*
|
||||||
* @param systemId The system identifier as a URI string.
|
* @param systemId The system identifier as a URI string.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void setSystemId(String systemId) {
|
public void setSystemId(String systemId) {
|
||||||
|
|
||||||
if (null == inputSource) {
|
if (null == inputSource) {
|
||||||
@ -162,6 +163,7 @@ public class SAXSource implements Source {
|
|||||||
*
|
*
|
||||||
* @return Base URL for the <code>Source</code>, or <code>null</code>.
|
* @return Base URL for the <code>Source</code>, or <code>null</code>.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public String getSystemId() {
|
public String getSystemId() {
|
||||||
|
|
||||||
if (inputSource == null) {
|
if (inputSource == null) {
|
||||||
@ -207,4 +209,22 @@ public class SAXSource implements Source {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the {@code SAXSource} object is empty. Empty is
|
||||||
|
* defined as follows:
|
||||||
|
* <ul>
|
||||||
|
* <li>if the system identifier and {@code InputSource} are {@code null};
|
||||||
|
* </li>
|
||||||
|
* <li>if the system identifier is {@code null}, and the {@code InputSource}
|
||||||
|
* is empty.
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @return true if the {@code SAXSource} object is empty, false otherwise
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return getSystemId() == null && (inputSource == null || inputSource.isEmpty());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2016, 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
|
||||||
@ -209,6 +209,7 @@ public class StAXSource implements Source {
|
|||||||
* @throws UnsupportedOperationException Is <strong>always</strong>
|
* @throws UnsupportedOperationException Is <strong>always</strong>
|
||||||
* thrown by this method.
|
* thrown by this method.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void setSystemId(final String systemId) {
|
public void setSystemId(final String systemId) {
|
||||||
|
|
||||||
throw new UnsupportedOperationException(
|
throw new UnsupportedOperationException(
|
||||||
@ -229,8 +230,21 @@ public class StAXSource implements Source {
|
|||||||
*
|
*
|
||||||
* @return System identifier used by this <code>StAXSource</code>.
|
* @return System identifier used by this <code>StAXSource</code>.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public String getSystemId() {
|
public String getSystemId() {
|
||||||
|
|
||||||
return systemId;
|
return systemId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the {@code StAXSource} object is empty. Since a
|
||||||
|
* {@code StAXSource} object can never be empty, this method always returns
|
||||||
|
* false.
|
||||||
|
*
|
||||||
|
* @return unconditionally false
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2005, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2016, 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,10 @@
|
|||||||
package javax.xml.transform.stream;
|
package javax.xml.transform.stream;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
|
import javax.xml.transform.Result;
|
||||||
|
|
||||||
import javax.xml.transform.Source;
|
import javax.xml.transform.Source;
|
||||||
|
|
||||||
@ -233,6 +235,7 @@ public class StreamSource implements Source {
|
|||||||
*
|
*
|
||||||
* @param systemId The system identifier as a URL string.
|
* @param systemId The system identifier as a URL string.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void setSystemId(String systemId) {
|
public void setSystemId(String systemId) {
|
||||||
this.systemId = systemId;
|
this.systemId = systemId;
|
||||||
}
|
}
|
||||||
@ -243,6 +246,7 @@ public class StreamSource implements Source {
|
|||||||
* @return The system identifier that was set with setSystemId, or null
|
* @return The system identifier that was set with setSystemId, or null
|
||||||
* if setSystemId was not called.
|
* if setSystemId was not called.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public String getSystemId() {
|
public String getSystemId() {
|
||||||
return systemId;
|
return systemId;
|
||||||
}
|
}
|
||||||
@ -259,6 +263,59 @@ public class StreamSource implements Source {
|
|||||||
this.systemId = f.toURI().toASCIIString();
|
this.systemId = f.toURI().toASCIIString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the {@code StreamSource} object is empty. Empty is
|
||||||
|
* defined as follows:
|
||||||
|
* <ul>
|
||||||
|
* <li>All of the input sources, including the public identifier, system
|
||||||
|
* identifier, byte stream, and character stream, are {@code null}.
|
||||||
|
* </li>
|
||||||
|
* <li>The public identifier and system identifier are {@code null}, and
|
||||||
|
* byte and character stream are either {@code null} or contain no byte or
|
||||||
|
* character.
|
||||||
|
* <p>
|
||||||
|
* Note that this method will reset the byte stream if it is provided, or
|
||||||
|
* the character stream if the byte stream is not provided.
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
* <p>
|
||||||
|
* In case of error while checking the byte or character stream, the method
|
||||||
|
* will return false to allow the XML processor to handle the error.
|
||||||
|
*
|
||||||
|
* @return true if the {@code StreamSource} object is empty, false otherwise
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return (publicId == null && systemId == null && isStreamEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isStreamEmpty() {
|
||||||
|
boolean empty = true;
|
||||||
|
try {
|
||||||
|
if (inputStream != null) {
|
||||||
|
inputStream.reset();
|
||||||
|
int bytesRead = inputStream.available();
|
||||||
|
if (bytesRead > 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (reader != null) {
|
||||||
|
reader.reset();
|
||||||
|
int c = reader.read();
|
||||||
|
reader.reset();
|
||||||
|
if (c != -1) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (IOException ex) {
|
||||||
|
//in case of error, return false
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return empty;
|
||||||
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// Internal state.
|
// Internal state.
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2005, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2016, 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
|
||||||
@ -30,6 +30,7 @@
|
|||||||
|
|
||||||
package org.xml.sax;
|
package org.xml.sax;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
|
||||||
@ -343,8 +344,57 @@ public class InputSource {
|
|||||||
return characterStream;
|
return characterStream;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates whether the {@code InputSource} object is empty. Empty is
|
||||||
|
* defined as follows:
|
||||||
|
* <ul>
|
||||||
|
* <li>All of the input sources, including the public identifier, system
|
||||||
|
* identifier, byte stream, and character stream, are {@code null}.
|
||||||
|
* </li>
|
||||||
|
* <li>The public identifier and system identifier are {@code null}, and
|
||||||
|
* byte and character stream are either {@code null} or contain no byte
|
||||||
|
* or character.
|
||||||
|
* <p>
|
||||||
|
* Note that this method will reset the byte stream if it is provided, or
|
||||||
|
* the character stream if the byte stream is not provided.
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
* <p>
|
||||||
|
* In case of error while checking the byte or character stream, the method
|
||||||
|
* will return false to allow the XML processor to handle the error.
|
||||||
|
*
|
||||||
|
* @return true if the {@code InputSource} object is empty, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return (publicId == null && systemId == null && isStreamEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isStreamEmpty() {
|
||||||
|
boolean empty = true;
|
||||||
|
try {
|
||||||
|
if (byteStream != null) {
|
||||||
|
byteStream.reset();
|
||||||
|
int bytesRead = byteStream.available();
|
||||||
|
if (bytesRead > 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (characterStream != null) {
|
||||||
|
characterStream.reset();
|
||||||
|
int c = characterStream.read();
|
||||||
|
characterStream.reset();
|
||||||
|
if (c != -1) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (IOException ex) {
|
||||||
|
//in case of error, return false
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return empty;
|
||||||
|
}
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
// Internal state.
|
// Internal state.
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
|
@ -56,23 +56,14 @@ public class DeferFeatureTest {
|
|||||||
|
|
||||||
@DataProvider(name = "catalog-countOfLoadedCatalogFile")
|
@DataProvider(name = "catalog-countOfLoadedCatalogFile")
|
||||||
private Object[][] data() {
|
private Object[][] data() {
|
||||||
return new Object[][] {
|
return new Object[][]{
|
||||||
// This catalog specifies null catalog explicitly,
|
// By default, alternative catalogs are not loaded.
|
||||||
// and the count of loaded catalogs should be 0.
|
{createCatalog(CatalogFeatures.defaults()), 0},
|
||||||
{ createCatalog(null), 0 },
|
// Alternative catalogs are not loaded when DEFER is set to true.
|
||||||
|
{createCatalog(createDeferFeature(DEFER_TRUE)), 0},
|
||||||
// This catalog specifies null catalog implicitly,
|
// The 3 alternative catalogs are not pre-loaded
|
||||||
// and the count of loaded catalogs should be 0.
|
//when DEFER is set to false.
|
||||||
{ createCatalog(CatalogFeatures.defaults()), 0 },
|
{createCatalog(createDeferFeature(DEFER_FALSE)), 3}};
|
||||||
|
|
||||||
// This catalog loads null catalog with true DEFER,
|
|
||||||
// and the count of loaded catalogs should be 0.
|
|
||||||
{ createCatalog(createDeferFeature(DEFER_TRUE)), 0 },
|
|
||||||
|
|
||||||
// This catalog loads null catalog with false DEFER.
|
|
||||||
// It should load all of none-current catalogs and the
|
|
||||||
// count of loaded catalogs should be 3.
|
|
||||||
{ createCatalog(createDeferFeature(DEFER_FALSE)), 3 } };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private CatalogFeatures createDeferFeature(String defer) {
|
private CatalogFeatures createDeferFeature(String defer) {
|
||||||
|
@ -83,7 +83,7 @@ final class CatalogTestUtils {
|
|||||||
* Creates CatalogResolver with a set of catalogs.
|
* Creates CatalogResolver with a set of catalogs.
|
||||||
*/
|
*/
|
||||||
static CatalogResolver catalogResolver(String... catalogName) {
|
static CatalogResolver catalogResolver(String... catalogName) {
|
||||||
return catalogResolver(null, catalogName);
|
return catalogResolver(CatalogFeatures.defaults(), catalogName);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -91,15 +91,16 @@ final class CatalogTestUtils {
|
|||||||
*/
|
*/
|
||||||
static CatalogResolver catalogResolver(CatalogFeatures features,
|
static CatalogResolver catalogResolver(CatalogFeatures features,
|
||||||
String... catalogName) {
|
String... catalogName) {
|
||||||
return CatalogManager.catalogResolver(features,
|
return (catalogName == null) ?
|
||||||
getCatalogPaths(catalogName));
|
CatalogManager.catalogResolver(features) :
|
||||||
|
CatalogManager.catalogResolver(features, getCatalogPaths(catalogName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Creates catalogUriResolver with a set of catalogs.
|
* Creates catalogUriResolver with a set of catalogs.
|
||||||
*/
|
*/
|
||||||
static CatalogUriResolver catalogUriResolver(String... catalogName) {
|
static CatalogUriResolver catalogUriResolver(String... catalogName) {
|
||||||
return catalogUriResolver(null, catalogName);
|
return catalogUriResolver(CatalogFeatures.defaults(), catalogName);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -107,8 +108,9 @@ final class CatalogTestUtils {
|
|||||||
*/
|
*/
|
||||||
static CatalogUriResolver catalogUriResolver(
|
static CatalogUriResolver catalogUriResolver(
|
||||||
CatalogFeatures features, String... catalogName) {
|
CatalogFeatures features, String... catalogName) {
|
||||||
return CatalogManager.catalogUriResolver(features,
|
return (catalogName == null) ?
|
||||||
getCatalogPaths(catalogName));
|
CatalogManager.catalogUriResolver(features) :
|
||||||
|
CatalogManager.catalogUriResolver(features, getCatalogPaths(catalogName));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Gets the paths of the specified catalogs.
|
// Gets the paths of the specified catalogs.
|
||||||
|
@ -89,7 +89,7 @@ public class JAXPTestUtilities {
|
|||||||
/**
|
/**
|
||||||
* BOM table for storing BOM header.
|
* BOM table for storing BOM header.
|
||||||
*/
|
*/
|
||||||
private final static Map<String, byte[]> bom = new HashMap();
|
private final static Map<String, byte[]> bom = new HashMap<>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initialize all BOM headers.
|
* Initialize all BOM headers.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, 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,14 +27,13 @@ import javax.xml.catalog.CatalogFeatures;
|
|||||||
import javax.xml.catalog.CatalogFeatures.Feature;
|
import javax.xml.catalog.CatalogFeatures.Feature;
|
||||||
import javax.xml.catalog.CatalogManager;
|
import javax.xml.catalog.CatalogManager;
|
||||||
import javax.xml.catalog.CatalogResolver;
|
import javax.xml.catalog.CatalogResolver;
|
||||||
|
import javax.xml.catalog.CatalogUriResolver;
|
||||||
import javax.xml.parsers.ParserConfigurationException;
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
import javax.xml.parsers.SAXParser;
|
import javax.xml.parsers.SAXParser;
|
||||||
import javax.xml.parsers.SAXParserFactory;
|
import javax.xml.parsers.SAXParserFactory;
|
||||||
import static jaxp.library.JAXPTestUtilities.getPathByClassName;
|
|
||||||
import org.testng.Assert;
|
import org.testng.Assert;
|
||||||
import org.testng.annotations.DataProvider;
|
import org.testng.annotations.DataProvider;
|
||||||
import org.testng.annotations.Test;
|
import org.testng.annotations.Test;
|
||||||
import org.w3c.dom.Element;
|
|
||||||
import org.xml.sax.Attributes;
|
import org.xml.sax.Attributes;
|
||||||
import org.xml.sax.ErrorHandler;
|
import org.xml.sax.ErrorHandler;
|
||||||
import org.xml.sax.SAXException;
|
import org.xml.sax.SAXException;
|
||||||
@ -42,11 +41,65 @@ import org.xml.sax.XMLReader;
|
|||||||
import org.xml.sax.ext.DefaultHandler2;
|
import org.xml.sax.ext.DefaultHandler2;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @bug 8081248
|
* @bug 8081248, 8144966, 8146606
|
||||||
* @summary Tests basic Catalog functions.
|
* @summary Tests basic Catalog functions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class CatalogTest {
|
public class CatalogTest {
|
||||||
|
/*
|
||||||
|
@bug 8146606
|
||||||
|
Verifies that the resulting systemId does not contain duplicate slashes
|
||||||
|
*/
|
||||||
|
public void testRewriteSystem() {
|
||||||
|
String catalog = getClass().getResource("rewriteCatalog.xml").getFile();
|
||||||
|
|
||||||
|
try {
|
||||||
|
CatalogResolver resolver = CatalogManager.catalogResolver(CatalogFeatures.defaults(), catalog);
|
||||||
|
String actualSystemId = resolver.resolveEntity(null, "http://remote.com/dtd/book.dtd").getSystemId();
|
||||||
|
Assert.assertTrue(!actualSystemId.contains("//"), "result contains duplicate slashes");
|
||||||
|
} catch (Exception e) {
|
||||||
|
Assert.fail(e.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@bug 8146606
|
||||||
|
Verifies that the resulting systemId does not contain duplicate slashes
|
||||||
|
*/
|
||||||
|
public void testRewriteUri() {
|
||||||
|
String catalog = getClass().getResource("rewriteCatalog.xml").getFile();
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
CatalogUriResolver resolver = CatalogManager.catalogUriResolver(CatalogFeatures.defaults(), catalog);
|
||||||
|
String actualSystemId = resolver.resolve("http://remote.com/import/import.xsl", null).getSystemId();
|
||||||
|
Assert.assertTrue(!actualSystemId.contains("//"), "result contains duplicate slashes");
|
||||||
|
} catch (Exception e) {
|
||||||
|
Assert.fail(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@bug 8144966
|
||||||
|
Verifies that passing null as CatalogFeatures will result in a NPE.
|
||||||
|
*/
|
||||||
|
@Test(expectedExceptions = NullPointerException.class)
|
||||||
|
public void testFeatureNull() {
|
||||||
|
CatalogResolver resolver = CatalogManager.catalogResolver(null, "");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@bug 8144966
|
||||||
|
Verifies that passing null as the path will result in a NPE.
|
||||||
|
*/
|
||||||
|
@Test(expectedExceptions = NullPointerException.class)
|
||||||
|
public void testPathNull() {
|
||||||
|
String path = null;
|
||||||
|
CatalogResolver resolver = CatalogManager.catalogResolver(CatalogFeatures.defaults(), path);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Tests basic catalog feature by using a CatalogResolver instance to
|
Tests basic catalog feature by using a CatalogResolver instance to
|
||||||
resolve a DTD reference to a locally specified DTD file. If the resolution
|
resolve a DTD reference to a locally specified DTD file. If the resolution
|
||||||
@ -61,7 +114,7 @@ public class CatalogTest {
|
|||||||
}
|
}
|
||||||
String url = getClass().getResource(xml).getFile();
|
String url = getClass().getResource(xml).getFile();
|
||||||
try {
|
try {
|
||||||
CatalogResolver cr = CatalogManager.catalogResolver(null, catalog);
|
CatalogResolver cr = CatalogManager.catalogResolver(CatalogFeatures.defaults(), catalog);
|
||||||
XMLReader reader = saxParser.getXMLReader();
|
XMLReader reader = saxParser.getXMLReader();
|
||||||
reader.setEntityResolver(cr);
|
reader.setEntityResolver(cr);
|
||||||
MyHandler handler = new MyHandler(saxParser);
|
MyHandler handler = new MyHandler(saxParser);
|
||||||
@ -84,7 +137,7 @@ public class CatalogTest {
|
|||||||
|
|
||||||
String test = "testInvalidCatalog";
|
String test = "testInvalidCatalog";
|
||||||
try {
|
try {
|
||||||
CatalogResolver resolver = CatalogManager.catalogResolver(null, catalog);
|
CatalogResolver resolver = CatalogManager.catalogResolver(CatalogFeatures.defaults(), catalog);
|
||||||
String actualSystemId = resolver.resolveEntity(null, "http://remote/xml/dtd/sys/alice/docAlice.dtd").getSystemId();
|
String actualSystemId = resolver.resolveEntity(null, "http://remote/xml/dtd/sys/alice/docAlice.dtd").getSystemId();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
String msg = e.getMessage();
|
String msg = e.getMessage();
|
||||||
|
11
jaxp/test/javax/xml/jaxp/unittest/catalog/rewriteCatalog.xml
Normal file
11
jaxp/test/javax/xml/jaxp/unittest/catalog/rewriteCatalog.xml
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<catalog
|
||||||
|
xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog">
|
||||||
|
|
||||||
|
<rewriteSystem systemIdStartString="http://remote.com/dtd"
|
||||||
|
rewritePrefix="file:///share/docbook/docbook/pass"/>
|
||||||
|
|
||||||
|
<rewriteURI uriStartString="http://remote.com/import" rewritePrefix="file:///local/import" />
|
||||||
|
|
||||||
|
</catalog>
|
||||||
|
|
202
jaxp/test/javax/xml/jaxp/unittest/common/Sources.java
Normal file
202
jaxp/test/javax/xml/jaxp/unittest/common/Sources.java
Normal file
@ -0,0 +1,202 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*/
|
||||||
|
package common;
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.StringReader;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
|
import java.net.URISyntaxException;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.parsers.ParserConfigurationException;
|
||||||
|
import javax.xml.parsers.SAXParserFactory;
|
||||||
|
import javax.xml.stream.XMLEventReader;
|
||||||
|
import javax.xml.stream.XMLInputFactory;
|
||||||
|
import javax.xml.stream.XMLStreamException;
|
||||||
|
import javax.xml.stream.XMLStreamReader;
|
||||||
|
import javax.xml.transform.Source;
|
||||||
|
import javax.xml.transform.dom.DOMSource;
|
||||||
|
import javax.xml.transform.sax.SAXSource;
|
||||||
|
import javax.xml.transform.stax.StAXSource;
|
||||||
|
import javax.xml.transform.stream.StreamSource;
|
||||||
|
import org.testng.Assert;
|
||||||
|
import org.testng.annotations.DataProvider;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.xml.sax.InputSource;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
|
import org.xml.sax.XMLReader;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @bug 8144967
|
||||||
|
* @summary Tests related to the javax.xml.transform.Source
|
||||||
|
* and org.xml.sax.InputSource
|
||||||
|
*/
|
||||||
|
public class Sources {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @bug 8144967
|
||||||
|
* Tests whether a Source object is empty
|
||||||
|
* @param source the Source object
|
||||||
|
*/
|
||||||
|
@Test(dataProvider = "emptySources")
|
||||||
|
public void testIsEmpty(Source source) {
|
||||||
|
Assert.assertTrue(source.isEmpty(), "The source is not empty");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @bug 8144967
|
||||||
|
* Tests that the source is not empty
|
||||||
|
* @param source the Source object
|
||||||
|
*/
|
||||||
|
@Test(dataProvider = "nonEmptySources")
|
||||||
|
public void testIsNotEmpty(Source source) {
|
||||||
|
Assert.assertTrue(!source.isEmpty(), "The source is empty");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @bug 8144967
|
||||||
|
* Tests whether an InputSource object is empty
|
||||||
|
* @param source the InputSource object
|
||||||
|
*/
|
||||||
|
@Test(dataProvider = "emptyInputSource")
|
||||||
|
public void testISIsEmpty(InputSource source) {
|
||||||
|
Assert.assertTrue(source.isEmpty(), "The source is not empty");
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DataProvider: sources that are empty
|
||||||
|
*/
|
||||||
|
@DataProvider(name = "emptySources")
|
||||||
|
Object[][] getSources() throws URISyntaxException {
|
||||||
|
|
||||||
|
return new Object[][]{
|
||||||
|
{new DOMSource()},
|
||||||
|
{new DOMSource(getDocument())},
|
||||||
|
{new SAXSource()},
|
||||||
|
{new SAXSource(new InputSource(new StringReader("")))},
|
||||||
|
{new SAXSource(getXMLReader(), new InputSource(new StringReader("")))},
|
||||||
|
{new StreamSource()},
|
||||||
|
{new StreamSource(new ByteArrayInputStream("".getBytes()))},
|
||||||
|
{new StreamSource(new StringReader(""))},
|
||||||
|
{new StreamSource(new StringReader(""), null)},
|
||||||
|
{new StreamSource((String) null)}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DataProvider: sources that are not empty
|
||||||
|
*/
|
||||||
|
@DataProvider(name = "nonEmptySources")
|
||||||
|
Object[][] getSourcesEx() throws URISyntaxException {
|
||||||
|
StAXSource ss = null;
|
||||||
|
try {
|
||||||
|
ss = new StAXSource(getXMLEventReader());
|
||||||
|
} catch (XMLStreamException ex) {}
|
||||||
|
|
||||||
|
return new Object[][]{
|
||||||
|
//This will set a non-null systemId on the resulting StreamSource
|
||||||
|
{new StreamSource(new File(""))},
|
||||||
|
//Can't tell because XMLStreamReader is a pull parser, cursor advancement
|
||||||
|
//would have been required in order to examine the reader.
|
||||||
|
{new StAXSource(getXMLStreamReader())},
|
||||||
|
{ss}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DataProvider: sources that are empty
|
||||||
|
*/
|
||||||
|
@DataProvider(name = "emptyInputSource")
|
||||||
|
Object[][] getInputSources() throws URISyntaxException {
|
||||||
|
byte[] utf8Bytes = null;
|
||||||
|
try {
|
||||||
|
utf8Bytes = "".getBytes("UTF8");
|
||||||
|
} catch (UnsupportedEncodingException ex) {
|
||||||
|
throw new RuntimeException(ex.getMessage());
|
||||||
|
}
|
||||||
|
return new Object[][]{
|
||||||
|
{new InputSource()},
|
||||||
|
{new InputSource(new ByteArrayInputStream(utf8Bytes))},
|
||||||
|
{new InputSource(new StringReader(""))},
|
||||||
|
{new InputSource((String) null)}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an instance of Document.
|
||||||
|
*
|
||||||
|
* @return an instance of Document.
|
||||||
|
*/
|
||||||
|
private Document getDocument() {
|
||||||
|
Document doc = null;
|
||||||
|
try {
|
||||||
|
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
|
||||||
|
doc = dbf.newDocumentBuilder().newDocument();
|
||||||
|
} catch (ParserConfigurationException ex) {}
|
||||||
|
return doc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an instance of XMLReader.
|
||||||
|
*
|
||||||
|
* @return an instance of XMLReader.
|
||||||
|
*/
|
||||||
|
private XMLReader getXMLReader() {
|
||||||
|
XMLReader reader = null;
|
||||||
|
try {
|
||||||
|
reader = SAXParserFactory.newInstance().newSAXParser().getXMLReader();
|
||||||
|
} catch (ParserConfigurationException | SAXException ex) {}
|
||||||
|
return reader;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an instance of XMLStreamReader.
|
||||||
|
*
|
||||||
|
* @return an instance of XMLStreamReader.
|
||||||
|
*/
|
||||||
|
private XMLStreamReader getXMLStreamReader() {
|
||||||
|
XMLStreamReader r = null;
|
||||||
|
try {
|
||||||
|
XMLInputFactory xif = XMLInputFactory.newInstance();
|
||||||
|
r = xif.createXMLStreamReader(new ByteArrayInputStream("".getBytes()));
|
||||||
|
} catch (XMLStreamException ex) {}
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an instance of XMLEventReader.
|
||||||
|
*
|
||||||
|
* @return an instance of XMLEventReader.
|
||||||
|
*/
|
||||||
|
private XMLEventReader getXMLEventReader() {
|
||||||
|
XMLEventReader r = null;
|
||||||
|
try {
|
||||||
|
r = XMLInputFactory.newInstance().createXMLEventReader(
|
||||||
|
new ByteArrayInputStream("".getBytes()));
|
||||||
|
} catch (XMLStreamException ex) {}
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
}
|
@ -343,3 +343,4 @@ fdd84b2265ddce7f50e084b7c8635189bba6f012 jdk-9+97
|
|||||||
f86ee68d1107dad41a27efc34306e0e56244a12e jdk-9+98
|
f86ee68d1107dad41a27efc34306e0e56244a12e jdk-9+98
|
||||||
e1a789be1535741274c9779f4d4ca3495196b5c3 jdk-9+99
|
e1a789be1535741274c9779f4d4ca3495196b5c3 jdk-9+99
|
||||||
3d452840f48299a36842760d17c0c8402f0e1266 jdk-9+100
|
3d452840f48299a36842760d17c0c8402f0e1266 jdk-9+100
|
||||||
|
5e8370fb3ed925335164afe340d1e54beab2d4d5 jdk-9+101
|
||||||
|
@ -48,7 +48,6 @@ BREAK_ITERATOR_CLASSES := $(BUILDTOOLS_OUTPUTDIR)/break_iterator_classes
|
|||||||
$(eval $(call SetupJavaCompilation,BUILD_BREAKITERATOR, \
|
$(eval $(call SetupJavaCompilation,BUILD_BREAKITERATOR, \
|
||||||
SETUP := GENERATE_OLDBYTECODE, \
|
SETUP := GENERATE_OLDBYTECODE, \
|
||||||
SRC := $(TEXT_SRCDIR), \
|
SRC := $(TEXT_SRCDIR), \
|
||||||
INCLUDES := $(TEXT_PKG), \
|
|
||||||
INCLUDE_FILES := $(TEXT_SOURCES), \
|
INCLUDE_FILES := $(TEXT_SOURCES), \
|
||||||
BIN := $(BREAK_ITERATOR_CLASSES)))
|
BIN := $(BREAK_ITERATOR_CLASSES)))
|
||||||
|
|
||||||
|
@ -50,6 +50,8 @@ import java.util.Vector;
|
|||||||
import java.util.Hashtable;
|
import java.util.Hashtable;
|
||||||
import java.util.WeakHashMap;
|
import java.util.WeakHashMap;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
|
import jdk.internal.perf.PerfCounter;
|
||||||
import sun.misc.Resource;
|
import sun.misc.Resource;
|
||||||
import sun.misc.URLClassPath;
|
import sun.misc.URLClassPath;
|
||||||
import sun.reflect.CallerSensitive;
|
import sun.reflect.CallerSensitive;
|
||||||
@ -423,9 +425,9 @@ public abstract class ClassLoader {
|
|||||||
c = findClass(name);
|
c = findClass(name);
|
||||||
|
|
||||||
// this is the defining class loader; record the stats
|
// this is the defining class loader; record the stats
|
||||||
sun.misc.PerfCounter.getParentDelegationTime().addTime(t1 - t0);
|
PerfCounter.getParentDelegationTime().addTime(t1 - t0);
|
||||||
sun.misc.PerfCounter.getFindClassTime().addElapsedTimeFrom(t1);
|
PerfCounter.getFindClassTime().addElapsedTimeFrom(t1);
|
||||||
sun.misc.PerfCounter.getFindClasses().increment();
|
PerfCounter.getFindClasses().increment();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (resolve) {
|
if (resolve) {
|
||||||
|
@ -61,6 +61,9 @@ interface LiveStackFrame extends StackFrame {
|
|||||||
* local variable array is an {@link PrimitiveValue} object;
|
* local variable array is an {@link PrimitiveValue} object;
|
||||||
* otherwise, the element is an {@code Object}.
|
* otherwise, the element is an {@code Object}.
|
||||||
*
|
*
|
||||||
|
* <p>The returned array may contain null entries if a local variable is not
|
||||||
|
* live.
|
||||||
|
*
|
||||||
* @return the local variable array of this stack frame.
|
* @return the local variable array of this stack frame.
|
||||||
*/
|
*/
|
||||||
public Object[] getLocals();
|
public Object[] getLocals();
|
||||||
|
@ -1535,6 +1535,8 @@ public final class System {
|
|||||||
* @return an instance of {@link Logger} that can be used by the calling
|
* @return an instance of {@link Logger} that can be used by the calling
|
||||||
* class.
|
* class.
|
||||||
* @throws NullPointerException if {@code name} is {@code null}.
|
* @throws NullPointerException if {@code name} is {@code null}.
|
||||||
|
*
|
||||||
|
* @since 9
|
||||||
*/
|
*/
|
||||||
@CallerSensitive
|
@CallerSensitive
|
||||||
public static Logger getLogger(String name) {
|
public static Logger getLogger(String name) {
|
||||||
@ -1572,6 +1574,8 @@ public final class System {
|
|||||||
* resource bundle for message localization.
|
* resource bundle for message localization.
|
||||||
* @throws NullPointerException if {@code name} is {@code null} or
|
* @throws NullPointerException if {@code name} is {@code null} or
|
||||||
* {@code bundle} is {@code null}.
|
* {@code bundle} is {@code null}.
|
||||||
|
*
|
||||||
|
* @since 9
|
||||||
*/
|
*/
|
||||||
@CallerSensitive
|
@CallerSensitive
|
||||||
public static Logger getLogger(String name, ResourceBundle bundle) {
|
public static Logger getLogger(String name, ResourceBundle bundle) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2008, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2008, 2016, 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
|
||||||
@ -3120,6 +3120,8 @@ assertEquals("boojum", (String) catTrace.invokeExact("boo", "jum"));
|
|||||||
MethodHandle handler) {
|
MethodHandle handler) {
|
||||||
MethodType ttype = target.type();
|
MethodType ttype = target.type();
|
||||||
MethodType htype = handler.type();
|
MethodType htype = handler.type();
|
||||||
|
if (!Throwable.class.isAssignableFrom(exType))
|
||||||
|
throw new ClassCastException(exType.getName());
|
||||||
if (htype.parameterCount() < 1 ||
|
if (htype.parameterCount() < 1 ||
|
||||||
!htype.parameterType(0).isAssignableFrom(exType))
|
!htype.parameterType(0).isAssignableFrom(exType))
|
||||||
throw newIllegalArgumentException("handler does not accept exception type "+exType);
|
throw newIllegalArgumentException("handler does not accept exception type "+exType);
|
||||||
|
@ -28,7 +28,7 @@ package java.lang.ref;
|
|||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.concurrent.ThreadFactory;
|
import java.util.concurrent.ThreadFactory;
|
||||||
|
|
||||||
import jdk.internal.misc.CleanerImpl;
|
import jdk.internal.ref.CleanerImpl;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@code Cleaner} manages a set of object references and corresponding cleaning actions.
|
* {@code Cleaner} manages a set of object references and corresponding cleaning actions.
|
||||||
|
@ -376,19 +376,23 @@ public abstract class SocketImpl implements SocketOptions {
|
|||||||
* @since 1.9
|
* @since 1.9
|
||||||
*/
|
*/
|
||||||
protected <T> void setOption(SocketOption<T> name, T value) throws IOException {
|
protected <T> void setOption(SocketOption<T> name, T value) throws IOException {
|
||||||
if (name == StandardSocketOptions.SO_KEEPALIVE) {
|
if (name == StandardSocketOptions.SO_KEEPALIVE &&
|
||||||
|
(getSocket() != null)) {
|
||||||
setOption(SocketOptions.SO_KEEPALIVE, value);
|
setOption(SocketOptions.SO_KEEPALIVE, value);
|
||||||
} else if (name == StandardSocketOptions.SO_SNDBUF) {
|
} else if (name == StandardSocketOptions.SO_SNDBUF &&
|
||||||
|
(getSocket() != null)) {
|
||||||
setOption(SocketOptions.SO_SNDBUF, value);
|
setOption(SocketOptions.SO_SNDBUF, value);
|
||||||
} else if (name == StandardSocketOptions.SO_RCVBUF) {
|
} else if (name == StandardSocketOptions.SO_RCVBUF) {
|
||||||
setOption(SocketOptions.SO_RCVBUF, value);
|
setOption(SocketOptions.SO_RCVBUF, value);
|
||||||
} else if (name == StandardSocketOptions.SO_REUSEADDR) {
|
} else if (name == StandardSocketOptions.SO_REUSEADDR) {
|
||||||
setOption(SocketOptions.SO_REUSEADDR, value);
|
setOption(SocketOptions.SO_REUSEADDR, value);
|
||||||
} else if (name == StandardSocketOptions.SO_LINGER) {
|
} else if (name == StandardSocketOptions.SO_LINGER &&
|
||||||
|
(getSocket() != null)) {
|
||||||
setOption(SocketOptions.SO_LINGER, value);
|
setOption(SocketOptions.SO_LINGER, value);
|
||||||
} else if (name == StandardSocketOptions.IP_TOS) {
|
} else if (name == StandardSocketOptions.IP_TOS) {
|
||||||
setOption(SocketOptions.IP_TOS, value);
|
setOption(SocketOptions.IP_TOS, value);
|
||||||
} else if (name == StandardSocketOptions.TCP_NODELAY) {
|
} else if (name == StandardSocketOptions.TCP_NODELAY &&
|
||||||
|
(getSocket() != null)) {
|
||||||
setOption(SocketOptions.TCP_NODELAY, value);
|
setOption(SocketOptions.TCP_NODELAY, value);
|
||||||
} else {
|
} else {
|
||||||
throw new UnsupportedOperationException("unsupported option");
|
throw new UnsupportedOperationException("unsupported option");
|
||||||
@ -412,19 +416,23 @@ public abstract class SocketImpl implements SocketOptions {
|
|||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
protected <T> T getOption(SocketOption<T> name) throws IOException {
|
protected <T> T getOption(SocketOption<T> name) throws IOException {
|
||||||
if (name == StandardSocketOptions.SO_KEEPALIVE) {
|
if (name == StandardSocketOptions.SO_KEEPALIVE &&
|
||||||
|
(getSocket() != null)) {
|
||||||
return (T)getOption(SocketOptions.SO_KEEPALIVE);
|
return (T)getOption(SocketOptions.SO_KEEPALIVE);
|
||||||
} else if (name == StandardSocketOptions.SO_SNDBUF) {
|
} else if (name == StandardSocketOptions.SO_SNDBUF &&
|
||||||
|
(getSocket() != null)) {
|
||||||
return (T)getOption(SocketOptions.SO_SNDBUF);
|
return (T)getOption(SocketOptions.SO_SNDBUF);
|
||||||
} else if (name == StandardSocketOptions.SO_RCVBUF) {
|
} else if (name == StandardSocketOptions.SO_RCVBUF) {
|
||||||
return (T)getOption(SocketOptions.SO_RCVBUF);
|
return (T)getOption(SocketOptions.SO_RCVBUF);
|
||||||
} else if (name == StandardSocketOptions.SO_REUSEADDR) {
|
} else if (name == StandardSocketOptions.SO_REUSEADDR) {
|
||||||
return (T)getOption(SocketOptions.SO_REUSEADDR);
|
return (T)getOption(SocketOptions.SO_REUSEADDR);
|
||||||
} else if (name == StandardSocketOptions.SO_LINGER) {
|
} else if (name == StandardSocketOptions.SO_LINGER &&
|
||||||
|
(getSocket() != null)) {
|
||||||
return (T)getOption(SocketOptions.SO_LINGER);
|
return (T)getOption(SocketOptions.SO_LINGER);
|
||||||
} else if (name == StandardSocketOptions.IP_TOS) {
|
} else if (name == StandardSocketOptions.IP_TOS) {
|
||||||
return (T)getOption(SocketOptions.IP_TOS);
|
return (T)getOption(SocketOptions.IP_TOS);
|
||||||
} else if (name == StandardSocketOptions.TCP_NODELAY) {
|
} else if (name == StandardSocketOptions.TCP_NODELAY &&
|
||||||
|
(getSocket() != null)) {
|
||||||
return (T)getOption(SocketOptions.TCP_NODELAY);
|
return (T)getOption(SocketOptions.TCP_NODELAY);
|
||||||
} else {
|
} else {
|
||||||
throw new UnsupportedOperationException("unsupported option");
|
throw new UnsupportedOperationException("unsupported option");
|
||||||
|
@ -1146,13 +1146,30 @@ public final class URI
|
|||||||
if (part != null) {
|
if (part != null) {
|
||||||
return part;
|
return part;
|
||||||
}
|
}
|
||||||
StringBuilder sb = new StringBuilder();
|
|
||||||
appendSchemeSpecificPart(sb, null, getAuthority(), getUserInfo(),
|
String s = string;
|
||||||
|
if (s != null) {
|
||||||
|
// if string is defined, components will have been parsed
|
||||||
|
int start = 0;
|
||||||
|
int end = s.length();
|
||||||
|
if (scheme != null) {
|
||||||
|
start = scheme.length() + 1;
|
||||||
|
}
|
||||||
|
if (fragment != null) {
|
||||||
|
end -= fragment.length() + 1;
|
||||||
|
}
|
||||||
|
if (path != null && path.length() == end - start) {
|
||||||
|
part = path;
|
||||||
|
} else {
|
||||||
|
part = s.substring(start, end);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
appendSchemeSpecificPart(sb, null, getAuthority(), getUserInfo(),
|
||||||
host, port, getPath(), getQuery());
|
host, port, getPath(), getQuery());
|
||||||
if (sb.length() == 0) {
|
part = sb.toString();
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
return schemeSpecificPart = sb.toString();
|
return schemeSpecificPart = part;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -3056,7 +3073,6 @@ public final class URI
|
|||||||
//
|
//
|
||||||
void parse(boolean rsa) throws URISyntaxException {
|
void parse(boolean rsa) throws URISyntaxException {
|
||||||
requireServerAuthority = rsa;
|
requireServerAuthority = rsa;
|
||||||
int ssp; // Start of scheme-specific part
|
|
||||||
int n = input.length();
|
int n = input.length();
|
||||||
int p = scan(0, n, "/?#", ":");
|
int p = scan(0, n, "/?#", ":");
|
||||||
if ((p >= 0) && at(p, n, ':')) {
|
if ((p >= 0) && at(p, n, ':')) {
|
||||||
@ -3066,21 +3082,20 @@ public final class URI
|
|||||||
checkChars(1, p, L_SCHEME, H_SCHEME, "scheme name");
|
checkChars(1, p, L_SCHEME, H_SCHEME, "scheme name");
|
||||||
scheme = input.substring(0, p);
|
scheme = input.substring(0, p);
|
||||||
p++; // Skip ':'
|
p++; // Skip ':'
|
||||||
ssp = p;
|
|
||||||
if (at(p, n, '/')) {
|
if (at(p, n, '/')) {
|
||||||
p = parseHierarchical(p, n);
|
p = parseHierarchical(p, n);
|
||||||
} else {
|
} else {
|
||||||
|
// opaque; need to create the schemeSpecificPart
|
||||||
int q = scan(p, n, "#");
|
int q = scan(p, n, "#");
|
||||||
if (q <= p)
|
if (q <= p)
|
||||||
failExpecting("scheme-specific part", p);
|
failExpecting("scheme-specific part", p);
|
||||||
checkChars(p, q, L_URIC, H_URIC, "opaque part");
|
checkChars(p, q, L_URIC, H_URIC, "opaque part");
|
||||||
|
schemeSpecificPart = input.substring(p, q);
|
||||||
p = q;
|
p = q;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ssp = 0;
|
|
||||||
p = parseHierarchical(0, n);
|
p = parseHierarchical(0, n);
|
||||||
}
|
}
|
||||||
schemeSpecificPart = input.substring(ssp, p);
|
|
||||||
if (at(p, n, '#')) {
|
if (at(p, n, '#')) {
|
||||||
checkChars(p + 1, n, L_URIC, H_URIC, "fragment");
|
checkChars(p + 1, n, L_URIC, H_URIC, "fragment");
|
||||||
fragment = input.substring(p + 1, n);
|
fragment = input.substring(p + 1, n);
|
||||||
|
@ -52,6 +52,7 @@ import java.util.jar.Manifest;
|
|||||||
|
|
||||||
import jdk.internal.misc.JavaNetAccess;
|
import jdk.internal.misc.JavaNetAccess;
|
||||||
import jdk.internal.misc.SharedSecrets;
|
import jdk.internal.misc.SharedSecrets;
|
||||||
|
import jdk.internal.perf.PerfCounter;
|
||||||
import sun.misc.Resource;
|
import sun.misc.Resource;
|
||||||
import sun.misc.URLClassPath;
|
import sun.misc.URLClassPath;
|
||||||
import sun.net.www.ParseUtil;
|
import sun.net.www.ParseUtil;
|
||||||
@ -459,14 +460,14 @@ public class URLClassLoader extends SecureClassLoader implements Closeable {
|
|||||||
// Use (direct) ByteBuffer:
|
// Use (direct) ByteBuffer:
|
||||||
CodeSigner[] signers = res.getCodeSigners();
|
CodeSigner[] signers = res.getCodeSigners();
|
||||||
CodeSource cs = new CodeSource(url, signers);
|
CodeSource cs = new CodeSource(url, signers);
|
||||||
sun.misc.PerfCounter.getReadClassBytesTime().addElapsedTimeFrom(t0);
|
PerfCounter.getReadClassBytesTime().addElapsedTimeFrom(t0);
|
||||||
return defineClass(name, bb, cs);
|
return defineClass(name, bb, cs);
|
||||||
} else {
|
} else {
|
||||||
byte[] b = res.getBytes();
|
byte[] b = res.getBytes();
|
||||||
// must read certificates AFTER reading bytes.
|
// must read certificates AFTER reading bytes.
|
||||||
CodeSigner[] signers = res.getCodeSigners();
|
CodeSigner[] signers = res.getCodeSigners();
|
||||||
CodeSource cs = new CodeSource(url, signers);
|
CodeSource cs = new CodeSource(url, signers);
|
||||||
sun.misc.PerfCounter.getReadClassBytesTime().addElapsedTimeFrom(t0);
|
PerfCounter.getReadClassBytesTime().addElapsedTimeFrom(t0);
|
||||||
return defineClass(name, b, 0, b.length, cs);
|
return defineClass(name, b, 0, b.length, cs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2016, 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,12 +27,12 @@ package java.security;
|
|||||||
|
|
||||||
import java.lang.ref.Reference;
|
import java.lang.ref.Reference;
|
||||||
import java.lang.ref.ReferenceQueue;
|
import java.lang.ref.ReferenceQueue;
|
||||||
|
import java.lang.ref.SoftReference;
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.WeakHashMap;
|
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import jdk.internal.misc.JavaSecurityAccess;
|
import jdk.internal.misc.JavaSecurityAccess;
|
||||||
import jdk.internal.misc.JavaSecurityProtectionDomainAccess;
|
import jdk.internal.misc.JavaSecurityProtectionDomainAccess;
|
||||||
@ -472,11 +472,15 @@ public class ProtectionDomain {
|
|||||||
*
|
*
|
||||||
* This class stores ProtectionDomains as weak keys in a ConcurrentHashMap
|
* This class stores ProtectionDomains as weak keys in a ConcurrentHashMap
|
||||||
* with additional support for checking and removing weak keys that are no
|
* with additional support for checking and removing weak keys that are no
|
||||||
* longer in use.
|
* longer in use. There can be cases where the permission collection may
|
||||||
|
* have a chain of strong references back to the ProtectionDomain, which
|
||||||
|
* ordinarily would prevent the entry from being removed from the map. To
|
||||||
|
* address that, we wrap the permission collection in a SoftReference so
|
||||||
|
* that it can be reclaimed by the garbage collector due to memory demand.
|
||||||
*/
|
*/
|
||||||
private static class PDCache implements ProtectionDomainCache {
|
private static class PDCache implements ProtectionDomainCache {
|
||||||
private final ConcurrentHashMap<WeakProtectionDomainKey,
|
private final ConcurrentHashMap<WeakProtectionDomainKey,
|
||||||
PermissionCollection>
|
SoftReference<PermissionCollection>>
|
||||||
pdMap = new ConcurrentHashMap<>();
|
pdMap = new ConcurrentHashMap<>();
|
||||||
private final ReferenceQueue<Key> queue = new ReferenceQueue<>();
|
private final ReferenceQueue<Key> queue = new ReferenceQueue<>();
|
||||||
|
|
||||||
@ -485,15 +489,15 @@ public class ProtectionDomain {
|
|||||||
processQueue(queue, pdMap);
|
processQueue(queue, pdMap);
|
||||||
WeakProtectionDomainKey weakPd =
|
WeakProtectionDomainKey weakPd =
|
||||||
new WeakProtectionDomainKey(pd, queue);
|
new WeakProtectionDomainKey(pd, queue);
|
||||||
pdMap.putIfAbsent(weakPd, pc);
|
pdMap.put(weakPd, new SoftReference<>(pc));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PermissionCollection get(ProtectionDomain pd) {
|
public PermissionCollection get(ProtectionDomain pd) {
|
||||||
processQueue(queue, pdMap);
|
processQueue(queue, pdMap);
|
||||||
WeakProtectionDomainKey weakPd =
|
WeakProtectionDomainKey weakPd = new WeakProtectionDomainKey(pd);
|
||||||
new WeakProtectionDomainKey(pd, queue);
|
SoftReference<PermissionCollection> sr = pdMap.get(weakPd);
|
||||||
return pdMap.get(weakPd);
|
return (sr == null) ? null : sr.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -533,11 +537,20 @@ public class ProtectionDomain {
|
|||||||
this((pd == null ? NULL_KEY : pd.key), rq);
|
this((pd == null ? NULL_KEY : pd.key), rq);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WeakProtectionDomainKey(ProtectionDomain pd) {
|
||||||
|
this(pd == null ? NULL_KEY : pd.key);
|
||||||
|
}
|
||||||
|
|
||||||
private WeakProtectionDomainKey(Key key, ReferenceQueue<Key> rq) {
|
private WeakProtectionDomainKey(Key key, ReferenceQueue<Key> rq) {
|
||||||
super(key, rq);
|
super(key, rq);
|
||||||
hash = key.hashCode();
|
hash = key.hashCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private WeakProtectionDomainKey(Key key) {
|
||||||
|
super(key);
|
||||||
|
hash = key.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the identity hash code of the original referent.
|
* Returns the identity hash code of the original referent.
|
||||||
*/
|
*/
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2016, 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
|
||||||
@ -1369,6 +1369,23 @@ public final class LocalDate
|
|||||||
if (daysToAdd == 0) {
|
if (daysToAdd == 0) {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
long dom = day + daysToAdd;
|
||||||
|
if (dom > 0) {
|
||||||
|
if (dom <= 28) {
|
||||||
|
return new LocalDate(year, month, (int) dom);
|
||||||
|
} else if (dom <= 59) { // 59th Jan is 28th Feb, 59th Feb is 31st Mar
|
||||||
|
long monthLen = lengthOfMonth();
|
||||||
|
if (dom <= monthLen) {
|
||||||
|
return new LocalDate(year, month, (int) dom);
|
||||||
|
} else if (month < 12) {
|
||||||
|
return new LocalDate(year, month + 1, (int) (dom - monthLen));
|
||||||
|
} else {
|
||||||
|
YEAR.checkValidValue(year + 1);
|
||||||
|
return new LocalDate(year + 1, 1, (int) (dom - monthLen));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
long mjDay = Math.addExact(toEpochDay(), daysToAdd);
|
long mjDay = Math.addExact(toEpochDay(), daysToAdd);
|
||||||
return LocalDate.ofEpochDay(mjDay);
|
return LocalDate.ofEpochDay(mjDay);
|
||||||
}
|
}
|
||||||
|
@ -3144,6 +3144,18 @@ public final class Locale implements Cloneable, Serializable {
|
|||||||
&& range.equals(other.range)
|
&& range.equals(other.range)
|
||||||
&& weight == other.weight;
|
&& weight == other.weight;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an informative string representation of this {@code LanguageRange}
|
||||||
|
* object, consisting of language range and weight if the range is
|
||||||
|
* weighted and the weight is less than the max weight.
|
||||||
|
*
|
||||||
|
* @return a string representation of this {@code LanguageRange} object.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return (weight == MAX_WEIGHT) ? range : range + ";q=" + weight;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,6 +54,7 @@ import java.util.stream.Stream;
|
|||||||
import java.util.stream.StreamSupport;
|
import java.util.stream.StreamSupport;
|
||||||
import jdk.internal.misc.JavaUtilZipFileAccess;
|
import jdk.internal.misc.JavaUtilZipFileAccess;
|
||||||
import jdk.internal.misc.SharedSecrets;
|
import jdk.internal.misc.SharedSecrets;
|
||||||
|
import jdk.internal.perf.PerfCounter;
|
||||||
|
|
||||||
import static java.util.zip.ZipConstants.*;
|
import static java.util.zip.ZipConstants.*;
|
||||||
import static java.util.zip.ZipConstants64.*;
|
import static java.util.zip.ZipConstants64.*;
|
||||||
@ -210,8 +211,8 @@ class ZipFile implements ZipConstants, Closeable {
|
|||||||
this.name = name;
|
this.name = name;
|
||||||
long t0 = System.nanoTime();
|
long t0 = System.nanoTime();
|
||||||
this.zsrc = Source.get(file, (mode & OPEN_DELETE) != 0);
|
this.zsrc = Source.get(file, (mode & OPEN_DELETE) != 0);
|
||||||
sun.misc.PerfCounter.getZipFileOpenTime().addElapsedTimeFrom(t0);
|
PerfCounter.getZipFileOpenTime().addElapsedTimeFrom(t0);
|
||||||
sun.misc.PerfCounter.getZipFileCount().increment();
|
PerfCounter.getZipFileCount().increment();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,788 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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 jdk.internal.misc;
|
|
||||||
|
|
||||||
import java.lang.ref.Cleaner;
|
|
||||||
import java.lang.ref.Cleaner.Cleanable;
|
|
||||||
import java.lang.ref.PhantomReference;
|
|
||||||
import java.lang.ref.Reference;
|
|
||||||
import java.lang.ref.ReferenceQueue;
|
|
||||||
import java.lang.ref.SoftReference;
|
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
import java.security.AccessController;
|
|
||||||
import java.security.PrivilegedAction;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.concurrent.ThreadFactory;
|
|
||||||
import java.util.function.Function;
|
|
||||||
|
|
||||||
import sun.misc.InnocuousThread;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* CleanerImpl manages a set of object references and corresponding cleaning actions.
|
|
||||||
* CleanerImpl provides the functionality of {@link java.lang.ref.Cleaner}.
|
|
||||||
*/
|
|
||||||
public final class CleanerImpl implements Runnable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* An object to access the CleanerImpl from a Cleaner; set by Cleaner init.
|
|
||||||
*/
|
|
||||||
private static Function<Cleaner, CleanerImpl> cleanerImplAccess = null;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Heads of a CleanableList for each reference type.
|
|
||||||
*/
|
|
||||||
final PhantomCleanable<?> phantomCleanableList;
|
|
||||||
|
|
||||||
final WeakCleanable<?> weakCleanableList;
|
|
||||||
|
|
||||||
final SoftCleanable<?> softCleanableList;
|
|
||||||
|
|
||||||
// The ReferenceQueue of pending cleaning actions
|
|
||||||
final ReferenceQueue<Object> queue;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Called by Cleaner static initialization to provide the function
|
|
||||||
* to map from Cleaner to CleanerImpl.
|
|
||||||
* @param access a function to map from Cleaner to CleanerImpl
|
|
||||||
*/
|
|
||||||
public static void setCleanerImplAccess(Function<Cleaner, CleanerImpl> access) {
|
|
||||||
if (cleanerImplAccess == null) {
|
|
||||||
cleanerImplAccess = access;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Called to get the CleanerImpl for a Cleaner.
|
|
||||||
* @param cleaner the cleaner
|
|
||||||
* @return the corresponding CleanerImpl
|
|
||||||
*/
|
|
||||||
private static CleanerImpl getCleanerImpl(Cleaner cleaner) {
|
|
||||||
return cleanerImplAccess.apply(cleaner);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor for CleanerImpl.
|
|
||||||
*/
|
|
||||||
public CleanerImpl() {
|
|
||||||
queue = new ReferenceQueue<>();
|
|
||||||
phantomCleanableList = new PhantomCleanableRef(this);
|
|
||||||
weakCleanableList = new WeakCleanableRef(this);
|
|
||||||
softCleanableList = new SoftCleanableRef(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Starts the Cleaner implementation.
|
|
||||||
* When started waits for Cleanables to be queued.
|
|
||||||
* @param service the cleaner
|
|
||||||
* @param threadFactory the thread factory
|
|
||||||
*/
|
|
||||||
public void start(Cleaner service, ThreadFactory threadFactory) {
|
|
||||||
// schedule a nop cleaning action for the service, so the associated thread
|
|
||||||
// will continue to run at least until the service is reclaimable.
|
|
||||||
new PhantomCleanableRef(service, service, () -> {});
|
|
||||||
|
|
||||||
if (threadFactory == null) {
|
|
||||||
threadFactory = CleanerImpl.InnocuousThreadFactory.factory();
|
|
||||||
}
|
|
||||||
|
|
||||||
// now that there's at least one cleaning action, for the service,
|
|
||||||
// we can start the associated thread, which runs until
|
|
||||||
// all cleaning actions have been run.
|
|
||||||
Thread thread = threadFactory.newThread(this);
|
|
||||||
thread.setDaemon(true);
|
|
||||||
thread.start();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Process queued Cleanables as long as the cleanable lists are not empty.
|
|
||||||
* A Cleanable is in one of the lists for each Object and for the Cleaner
|
|
||||||
* itself.
|
|
||||||
* Terminates when the Cleaner is no longer reachable and
|
|
||||||
* has been cleaned and there are no more Cleanable instances
|
|
||||||
* for which the object is reachable.
|
|
||||||
* <p>
|
|
||||||
* If the thread is a ManagedLocalsThread, the threadlocals
|
|
||||||
* are erased before each cleanup
|
|
||||||
*/
|
|
||||||
public void run() {
|
|
||||||
Thread t = Thread.currentThread();
|
|
||||||
InnocuousThread mlThread = (t instanceof InnocuousThread)
|
|
||||||
? (InnocuousThread) t
|
|
||||||
: null;
|
|
||||||
while (!phantomCleanableList.isListEmpty() ||
|
|
||||||
!weakCleanableList.isListEmpty() ||
|
|
||||||
!softCleanableList.isListEmpty()) {
|
|
||||||
if (mlThread != null) {
|
|
||||||
// Clear the thread locals
|
|
||||||
mlThread.eraseThreadLocals();
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
// Wait for a Ref, with a timeout to avoid getting hung
|
|
||||||
// due to a race with clear/clean
|
|
||||||
Cleanable ref = (Cleanable) queue.remove(60 * 1000L);
|
|
||||||
if (ref != null) {
|
|
||||||
ref.clean();
|
|
||||||
}
|
|
||||||
} catch (InterruptedException i) {
|
|
||||||
continue; // ignore the interruption
|
|
||||||
} catch (Throwable e) {
|
|
||||||
// ignore exceptions from the cleanup action
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* PhantomCleanable subclasses efficiently encapsulate cleanup state and
|
|
||||||
* the cleaning action.
|
|
||||||
* Subclasses implement the abstract {@link #performCleanup()} method
|
|
||||||
* to provide the cleaning action.
|
|
||||||
* When constructed, the object reference and the {@link Cleanable Cleanable}
|
|
||||||
* are registered with the {@link Cleaner}.
|
|
||||||
* The Cleaner invokes {@link Cleaner.Cleanable#clean() clean} after the
|
|
||||||
* referent becomes phantom reachable.
|
|
||||||
*/
|
|
||||||
public static abstract class PhantomCleanable<T> extends PhantomReference<T>
|
|
||||||
implements Cleaner.Cleanable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Links to previous and next in a doubly-linked list.
|
|
||||||
*/
|
|
||||||
PhantomCleanable<?> prev = this, next = this;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The CleanerImpl for this Cleanable.
|
|
||||||
*/
|
|
||||||
private final CleanerImpl cleanerImpl;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructs new {@code PhantomCleanable} with
|
|
||||||
* {@code non-null referent} and {@code non-null cleaner}.
|
|
||||||
* The {@code cleaner} is not retained; it is only used to
|
|
||||||
* register the newly constructed {@link Cleaner.Cleanable Cleanable}.
|
|
||||||
*
|
|
||||||
* @param referent the referent to track
|
|
||||||
* @param cleaner the {@code Cleaner} to register with
|
|
||||||
*/
|
|
||||||
public PhantomCleanable(T referent, Cleaner cleaner) {
|
|
||||||
super(Objects.requireNonNull(referent), getCleanerImpl(cleaner).queue);
|
|
||||||
this.cleanerImpl = getCleanerImpl(cleaner);
|
|
||||||
insert();
|
|
||||||
|
|
||||||
// TODO: Replace getClass() with ReachabilityFence when it is available
|
|
||||||
cleaner.getClass();
|
|
||||||
referent.getClass();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Construct a new root of the list; not inserted.
|
|
||||||
*/
|
|
||||||
PhantomCleanable(CleanerImpl cleanerImpl) {
|
|
||||||
super(null, null);
|
|
||||||
this.cleanerImpl = cleanerImpl;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Insert this PhantomCleanable after the list head.
|
|
||||||
*/
|
|
||||||
private void insert() {
|
|
||||||
final PhantomCleanable<?> list = cleanerImpl.phantomCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
prev = list;
|
|
||||||
next = list.next;
|
|
||||||
next.prev = this;
|
|
||||||
list.next = this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove this PhantomCleanable from the list.
|
|
||||||
*
|
|
||||||
* @return true if Cleanable was removed or false if not because
|
|
||||||
* it had already been removed before
|
|
||||||
*/
|
|
||||||
private boolean remove() {
|
|
||||||
PhantomCleanable<?> list = cleanerImpl.phantomCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
if (next != this) {
|
|
||||||
next.prev = prev;
|
|
||||||
prev.next = next;
|
|
||||||
prev = this;
|
|
||||||
next = this;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if the list's next reference refers to itself.
|
|
||||||
*
|
|
||||||
* @return true if the list is empty
|
|
||||||
*/
|
|
||||||
boolean isListEmpty() {
|
|
||||||
PhantomCleanable<?> list = cleanerImpl.phantomCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
return list == list.next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister this PhantomCleanable and invoke {@link #performCleanup()},
|
|
||||||
* ensuring at-most-once semantics.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final void clean() {
|
|
||||||
if (remove()) {
|
|
||||||
super.clear();
|
|
||||||
performCleanup();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister this PhantomCleanable and clear the reference.
|
|
||||||
* Due to inherent concurrency, {@link #performCleanup()} may still be invoked.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void clear() {
|
|
||||||
if (remove()) {
|
|
||||||
super.clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The {@code performCleanup} abstract method is overridden
|
|
||||||
* to implement the cleaning logic.
|
|
||||||
* The {@code performCleanup} method should not be called except
|
|
||||||
* by the {@link #clean} method which ensures at most once semantics.
|
|
||||||
*/
|
|
||||||
protected abstract void performCleanup();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This method always throws {@link UnsupportedOperationException}.
|
|
||||||
* Enqueuing details of {@link Cleaner.Cleanable}
|
|
||||||
* are a private implementation detail.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final boolean isEnqueued() {
|
|
||||||
throw new UnsupportedOperationException("isEnqueued");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This method always throws {@link UnsupportedOperationException}.
|
|
||||||
* Enqueuing details of {@link Cleaner.Cleanable}
|
|
||||||
* are a private implementation detail.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final boolean enqueue() {
|
|
||||||
throw new UnsupportedOperationException("enqueue");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* WeakCleanable subclasses efficiently encapsulate cleanup state and
|
|
||||||
* the cleaning action.
|
|
||||||
* Subclasses implement the abstract {@link #performCleanup()} method
|
|
||||||
* to provide the cleaning action.
|
|
||||||
* When constructed, the object reference and the {@link Cleanable Cleanable}
|
|
||||||
* are registered with the {@link Cleaner}.
|
|
||||||
* The Cleaner invokes {@link Cleaner.Cleanable#clean() clean} after the
|
|
||||||
* referent becomes weakly reachable.
|
|
||||||
*/
|
|
||||||
public static abstract class WeakCleanable<T> extends WeakReference<T>
|
|
||||||
implements Cleaner.Cleanable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Links to previous and next in a doubly-linked list.
|
|
||||||
*/
|
|
||||||
WeakCleanable<?> prev = this, next = this;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The CleanerImpl for this Cleanable.
|
|
||||||
*/
|
|
||||||
private final CleanerImpl cleanerImpl;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructs new {@code WeakCleanableReference} with
|
|
||||||
* {@code non-null referent} and {@code non-null cleaner}.
|
|
||||||
* The {@code cleaner} is not retained by this reference; it is only used
|
|
||||||
* to register the newly constructed {@link Cleaner.Cleanable Cleanable}.
|
|
||||||
*
|
|
||||||
* @param referent the referent to track
|
|
||||||
* @param cleaner the {@code Cleaner} to register new reference with
|
|
||||||
*/
|
|
||||||
public WeakCleanable(T referent, Cleaner cleaner) {
|
|
||||||
super(Objects.requireNonNull(referent), getCleanerImpl(cleaner).queue);
|
|
||||||
cleanerImpl = getCleanerImpl(cleaner);
|
|
||||||
insert();
|
|
||||||
|
|
||||||
// TODO: Replace getClass() with ReachabilityFence when it is available
|
|
||||||
cleaner.getClass();
|
|
||||||
referent.getClass();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Construct a new root of the list; not inserted.
|
|
||||||
*/
|
|
||||||
WeakCleanable(CleanerImpl cleanerImpl) {
|
|
||||||
super(null, null);
|
|
||||||
this.cleanerImpl = cleanerImpl;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Insert this WeakCleanableReference after the list head.
|
|
||||||
*/
|
|
||||||
private void insert() {
|
|
||||||
final WeakCleanable<?> list = cleanerImpl.weakCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
prev = list;
|
|
||||||
next = list.next;
|
|
||||||
next.prev = this;
|
|
||||||
list.next = this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove this WeakCleanableReference from the list.
|
|
||||||
*
|
|
||||||
* @return true if Cleanable was removed or false if not because
|
|
||||||
* it had already been removed before
|
|
||||||
*/
|
|
||||||
private boolean remove() {
|
|
||||||
WeakCleanable<?> list = cleanerImpl.weakCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
if (next != this) {
|
|
||||||
next.prev = prev;
|
|
||||||
prev.next = next;
|
|
||||||
prev = this;
|
|
||||||
next = this;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if the list's next reference refers to itself.
|
|
||||||
*
|
|
||||||
* @return true if the list is empty
|
|
||||||
*/
|
|
||||||
boolean isListEmpty() {
|
|
||||||
WeakCleanable<?> list = cleanerImpl.weakCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
return list == list.next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister this WeakCleanable reference and invoke {@link #performCleanup()},
|
|
||||||
* ensuring at-most-once semantics.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final void clean() {
|
|
||||||
if (remove()) {
|
|
||||||
super.clear();
|
|
||||||
performCleanup();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister this WeakCleanable and clear the reference.
|
|
||||||
* Due to inherent concurrency, {@link #performCleanup()} may still be invoked.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void clear() {
|
|
||||||
if (remove()) {
|
|
||||||
super.clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The {@code performCleanup} abstract method is overridden
|
|
||||||
* to implement the cleaning logic.
|
|
||||||
* The {@code performCleanup} method should not be called except
|
|
||||||
* by the {@link #clean} method which ensures at most once semantics.
|
|
||||||
*/
|
|
||||||
protected abstract void performCleanup();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This method always throws {@link UnsupportedOperationException}.
|
|
||||||
* Enqueuing details of {@link java.lang.ref.Cleaner.Cleanable}
|
|
||||||
* are a private implementation detail.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final boolean isEnqueued() {
|
|
||||||
throw new UnsupportedOperationException("isEnqueued");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This method always throws {@link UnsupportedOperationException}.
|
|
||||||
* Enqueuing details of {@link java.lang.ref.Cleaner.Cleanable}
|
|
||||||
* are a private implementation detail.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final boolean enqueue() {
|
|
||||||
throw new UnsupportedOperationException("enqueue");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* SoftCleanable subclasses efficiently encapsulate cleanup state and
|
|
||||||
* the cleaning action.
|
|
||||||
* Subclasses implement the abstract {@link #performCleanup()} method
|
|
||||||
* to provide the cleaning action.
|
|
||||||
* When constructed, the object reference and the {@link Cleanable Cleanable}
|
|
||||||
* are registered with the {@link Cleaner}.
|
|
||||||
* The Cleaner invokes {@link Cleaner.Cleanable#clean() clean} after the
|
|
||||||
* referent becomes softly reachable.
|
|
||||||
*/
|
|
||||||
public static abstract class SoftCleanable<T> extends SoftReference<T>
|
|
||||||
implements Cleaner.Cleanable {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Links to previous and next in a doubly-linked list.
|
|
||||||
*/
|
|
||||||
SoftCleanable<?> prev = this, next = this;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The CleanerImpl for this Cleanable.
|
|
||||||
*/
|
|
||||||
private final CleanerImpl cleanerImpl;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructs new {@code SoftCleanableReference} with
|
|
||||||
* {@code non-null referent} and {@code non-null cleaner}.
|
|
||||||
* The {@code cleaner} is not retained by this reference; it is only used
|
|
||||||
* to register the newly constructed {@link Cleaner.Cleanable Cleanable}.
|
|
||||||
*
|
|
||||||
* @param referent the referent to track
|
|
||||||
* @param cleaner the {@code Cleaner} to register with
|
|
||||||
*/
|
|
||||||
public SoftCleanable(T referent, Cleaner cleaner) {
|
|
||||||
super(Objects.requireNonNull(referent), getCleanerImpl(cleaner).queue);
|
|
||||||
cleanerImpl = getCleanerImpl(cleaner);
|
|
||||||
insert();
|
|
||||||
|
|
||||||
// TODO: Replace getClass() with ReachabilityFence when it is available
|
|
||||||
cleaner.getClass();
|
|
||||||
referent.getClass();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Construct a new root of the list; not inserted.
|
|
||||||
*/
|
|
||||||
SoftCleanable(CleanerImpl cleanerImpl) {
|
|
||||||
super(null, null);
|
|
||||||
this.cleanerImpl = cleanerImpl;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Insert this SoftCleanableReference after the list head.
|
|
||||||
*/
|
|
||||||
private void insert() {
|
|
||||||
final SoftCleanable<?> list = cleanerImpl.softCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
prev = list;
|
|
||||||
next = list.next;
|
|
||||||
next.prev = this;
|
|
||||||
list.next = this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove this SoftCleanableReference from the list.
|
|
||||||
*
|
|
||||||
* @return true if Cleanable was removed or false if not because
|
|
||||||
* it had already been removed before
|
|
||||||
*/
|
|
||||||
private boolean remove() {
|
|
||||||
SoftCleanable<?> list = cleanerImpl.softCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
if (next != this) {
|
|
||||||
next.prev = prev;
|
|
||||||
prev.next = next;
|
|
||||||
prev = this;
|
|
||||||
next = this;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if the list's next reference refers to itself.
|
|
||||||
*
|
|
||||||
* @return true if the list is empty
|
|
||||||
*/
|
|
||||||
boolean isListEmpty() {
|
|
||||||
SoftCleanable<?> list = cleanerImpl.softCleanableList;
|
|
||||||
synchronized (list) {
|
|
||||||
return list == list.next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister this SoftCleanable reference and invoke {@link #performCleanup()},
|
|
||||||
* ensuring at-most-once semantics.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final void clean() {
|
|
||||||
if (remove()) {
|
|
||||||
super.clear();
|
|
||||||
performCleanup();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unregister this SoftCleanable and clear the reference.
|
|
||||||
* Due to inherent concurrency, {@link #performCleanup()} may still be invoked.
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void clear() {
|
|
||||||
if (remove()) {
|
|
||||||
super.clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The {@code performCleanup} abstract method is overridden
|
|
||||||
* to implement the cleaning logic.
|
|
||||||
* The {@code performCleanup} method should not be called except
|
|
||||||
* by the {@link #clean} method which ensures at most once semantics.
|
|
||||||
*/
|
|
||||||
protected abstract void performCleanup();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This method always throws {@link UnsupportedOperationException}.
|
|
||||||
* Enqueuing details of {@link Cleaner.Cleanable}
|
|
||||||
* are a private implementation detail.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final boolean isEnqueued() {
|
|
||||||
throw new UnsupportedOperationException("isEnqueued");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This method always throws {@link UnsupportedOperationException}.
|
|
||||||
* Enqueuing details of {@link Cleaner.Cleanable}
|
|
||||||
* are a private implementation detail.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public final boolean enqueue() {
|
|
||||||
throw new UnsupportedOperationException("enqueue");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Perform cleaning on an unreachable PhantomReference.
|
|
||||||
*/
|
|
||||||
public static final class PhantomCleanableRef extends PhantomCleanable<Object> {
|
|
||||||
private final Runnable action;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor for a phantom cleanable reference.
|
|
||||||
* @param obj the object to monitor
|
|
||||||
* @param cleaner the cleaner
|
|
||||||
* @param action the action Runnable
|
|
||||||
*/
|
|
||||||
public PhantomCleanableRef(Object obj, Cleaner cleaner, Runnable action) {
|
|
||||||
super(obj, cleaner);
|
|
||||||
this.action = action;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor used only for root of phantom cleanable list.
|
|
||||||
* @param cleanerImpl the cleanerImpl
|
|
||||||
*/
|
|
||||||
PhantomCleanableRef(CleanerImpl cleanerImpl) {
|
|
||||||
super(cleanerImpl);
|
|
||||||
this.action = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void performCleanup() {
|
|
||||||
action.run();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Prevent access to referent even when it is still alive.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Object get() {
|
|
||||||
throw new UnsupportedOperationException("get");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Direct clearing of the referent is not supported.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void clear() {
|
|
||||||
throw new UnsupportedOperationException("clear");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Perform cleaning on an unreachable WeakReference.
|
|
||||||
*/
|
|
||||||
public static final class WeakCleanableRef extends WeakCleanable<Object> {
|
|
||||||
private final Runnable action;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor for a weak cleanable reference.
|
|
||||||
* @param obj the object to monitor
|
|
||||||
* @param cleaner the cleaner
|
|
||||||
* @param action the action Runnable
|
|
||||||
*/
|
|
||||||
WeakCleanableRef(Object obj, Cleaner cleaner, Runnable action) {
|
|
||||||
super(obj, cleaner);
|
|
||||||
this.action = action;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor used only for root of weak cleanable list.
|
|
||||||
* @param cleanerImpl the cleanerImpl
|
|
||||||
*/
|
|
||||||
WeakCleanableRef(CleanerImpl cleanerImpl) {
|
|
||||||
super(cleanerImpl);
|
|
||||||
this.action = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void performCleanup() {
|
|
||||||
action.run();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Prevent access to referent even when it is still alive.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Object get() {
|
|
||||||
throw new UnsupportedOperationException("get");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Direct clearing of the referent is not supported.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void clear() {
|
|
||||||
throw new UnsupportedOperationException("clear");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Perform cleaning on an unreachable SoftReference.
|
|
||||||
*/
|
|
||||||
public static final class SoftCleanableRef extends SoftCleanable<Object> {
|
|
||||||
private final Runnable action;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor for a soft cleanable reference.
|
|
||||||
* @param obj the object to monitor
|
|
||||||
* @param cleaner the cleaner
|
|
||||||
* @param action the action Runnable
|
|
||||||
*/
|
|
||||||
SoftCleanableRef(Object obj, Cleaner cleaner, Runnable action) {
|
|
||||||
super(obj, cleaner);
|
|
||||||
this.action = action;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor used only for root of soft cleanable list.
|
|
||||||
* @param cleanerImpl the cleanerImpl
|
|
||||||
*/
|
|
||||||
SoftCleanableRef(CleanerImpl cleanerImpl) {
|
|
||||||
super(cleanerImpl);
|
|
||||||
this.action = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void performCleanup() {
|
|
||||||
action.run();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Prevent access to referent even when it is still alive.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Object get() {
|
|
||||||
throw new UnsupportedOperationException("get");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Direct clearing of the referent is not supported.
|
|
||||||
*
|
|
||||||
* @throws UnsupportedOperationException always
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void clear() {
|
|
||||||
throw new UnsupportedOperationException("clear");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A ThreadFactory for InnocuousThreads.
|
|
||||||
* The factory is a singleton.
|
|
||||||
*/
|
|
||||||
static final class InnocuousThreadFactory implements ThreadFactory {
|
|
||||||
final static ThreadFactory factory = new InnocuousThreadFactory();
|
|
||||||
|
|
||||||
static ThreadFactory factory() {
|
|
||||||
return factory;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Thread newThread(Runnable r) {
|
|
||||||
return AccessController.doPrivileged((PrivilegedAction<Thread>) () -> {
|
|
||||||
Thread t = new InnocuousThread(r);
|
|
||||||
t.setPriority(Thread.MAX_PRIORITY - 2);
|
|
||||||
t.setName("Cleaner-" + t.getId());
|
|
||||||
return t;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -22,13 +22,14 @@
|
|||||||
* or visit www.oracle.com if you need additional information or have any
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
package sun.misc;
|
package jdk.internal.perf;
|
||||||
|
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.security.Permission;
|
import java.security.Permission;
|
||||||
import java.security.PrivilegedAction;
|
import java.security.PrivilegedAction;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.UnsupportedEncodingException;
|
import java.io.UnsupportedEncodingException;
|
||||||
|
import jdk.internal.ref.CleanerFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The Perf class provides the ability to attach to an instrumentation
|
* The Perf class provides the ability to attach to an instrumentation
|
||||||
@ -46,7 +47,7 @@ import java.io.UnsupportedEncodingException;
|
|||||||
* @author Brian Doherty
|
* @author Brian Doherty
|
||||||
* @since 1.4.2
|
* @since 1.4.2
|
||||||
* @see #getPerf
|
* @see #getPerf
|
||||||
* @see sun.misc.Perf$GetPerfAction
|
* @see jdk.internal.perf.Perf.GetPerfAction
|
||||||
* @see java.nio.ByteBuffer
|
* @see java.nio.ByteBuffer
|
||||||
*/
|
*/
|
||||||
public final class Perf {
|
public final class Perf {
|
||||||
@ -123,10 +124,10 @@ public final class Perf {
|
|||||||
* Please note that the <em>"sun.misc.Perf.getPerf"</em> permission
|
* Please note that the <em>"sun.misc.Perf.getPerf"</em> permission
|
||||||
* is not a JDK specified permission.
|
* is not a JDK specified permission.
|
||||||
*
|
*
|
||||||
* @return A reference to the singleton Perf instance.
|
* @return A reference to the singleton Perf instance.
|
||||||
* @throws AccessControlException if a security manager exists and
|
* @throws SecurityException if a security manager exists and its
|
||||||
* its <code>checkPermission</code> method doesn't allow
|
* <code>checkPermission</code> method doesn't allow access
|
||||||
* access to the <em>"sun.misc.Perf.getPerf"</em> target.
|
* to the <em>"jdk.internal.perf.Perf.getPerf""</em> target.
|
||||||
* @see java.lang.RuntimePermission
|
* @see java.lang.RuntimePermission
|
||||||
* @see #attach
|
* @see #attach
|
||||||
*/
|
*/
|
||||||
@ -134,7 +135,7 @@ public final class Perf {
|
|||||||
{
|
{
|
||||||
SecurityManager security = System.getSecurityManager();
|
SecurityManager security = System.getSecurityManager();
|
||||||
if (security != null) {
|
if (security != null) {
|
||||||
Permission perm = new RuntimePermission("sun.misc.Perf.getPerf");
|
Permission perm = new RuntimePermission("jdk.internal.perf.Perf.getPerf");
|
||||||
security.checkPermission(perm);
|
security.checkPermission(perm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,27 +278,35 @@ public final class Perf {
|
|||||||
// This is an instrumentation buffer for another Java virtual
|
// This is an instrumentation buffer for another Java virtual
|
||||||
// machine with native resources that need to be managed. We
|
// machine with native resources that need to be managed. We
|
||||||
// create a duplicate of the native ByteBuffer and manage it
|
// create a duplicate of the native ByteBuffer and manage it
|
||||||
// with a Cleaner object (PhantomReference). When the duplicate
|
// with a Cleaner. When the duplicate becomes phantom reachable,
|
||||||
// becomes only phantomly reachable, the native resources will
|
// the native resources will be released.
|
||||||
// be released.
|
|
||||||
|
|
||||||
final ByteBuffer dup = b.duplicate();
|
final ByteBuffer dup = b.duplicate();
|
||||||
Cleaner.create(dup, new Runnable() {
|
|
||||||
public void run() {
|
CleanerFactory.cleaner()
|
||||||
try {
|
.register(dup, new CleanerAction(instance, b));
|
||||||
instance.detach(b);
|
|
||||||
}
|
|
||||||
catch (Throwable th) {
|
|
||||||
// avoid crashing the reference handler thread,
|
|
||||||
// but provide for some diagnosability
|
|
||||||
assert false : th.toString();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return dup;
|
return dup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static class CleanerAction implements Runnable {
|
||||||
|
private final ByteBuffer bb;
|
||||||
|
private final Perf perf;
|
||||||
|
CleanerAction(Perf perf, ByteBuffer bb) {
|
||||||
|
this.perf = perf;
|
||||||
|
this.bb = bb;
|
||||||
|
}
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
perf.detach(bb);
|
||||||
|
} catch (Throwable th) {
|
||||||
|
// avoid crashing the reference handler thread,
|
||||||
|
// but provide for some diagnosability
|
||||||
|
assert false : th.toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Native method to perform the implementation specific attach mechanism.
|
* Native method to perform the implementation specific attach mechanism.
|
||||||
* <p>
|
* <p>
|
||||||
@ -341,7 +350,7 @@ public final class Perf {
|
|||||||
* machine running this method (lvmid=0, for example), then the detach
|
* machine running this method (lvmid=0, for example), then the detach
|
||||||
* request is silently ignored.
|
* request is silently ignored.
|
||||||
*
|
*
|
||||||
* @param ByteBuffer A direct allocated byte buffer created by the
|
* @param bb A direct allocated byte buffer created by the
|
||||||
* <code>attach</code> method.
|
* <code>attach</code> method.
|
||||||
* @see java.nio.ByteBuffer
|
* @see java.nio.ByteBuffer
|
||||||
* @see #attach
|
* @see #attach
|
@ -23,7 +23,7 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package sun.misc;
|
package jdk.internal.perf;
|
||||||
|
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.nio.ByteOrder;
|
import java.nio.ByteOrder;
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 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,16 +23,26 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package jdk.internal.dynalink.beans.test;
|
package jdk.internal.ref;
|
||||||
|
|
||||||
import jdk.dynalink.beans.BeansLinker;
|
import java.lang.ref.Cleaner;
|
||||||
import jdk.nashorn.test.models.ClassLoaderAware;
|
|
||||||
import org.testng.annotations.Test;
|
|
||||||
|
|
||||||
@SuppressWarnings("javadoc")
|
/**
|
||||||
public class CallerSensitiveTest {
|
* CleanerFactory provides a Cleaner for use within OpenJDK modules.
|
||||||
@Test
|
* The cleaner is created on the first reference to the CleanerFactory.
|
||||||
public void testCallerSensitive() {
|
*/
|
||||||
BeansLinker.getLinkerForClass(ClassLoaderAware.class);
|
public final class CleanerFactory {
|
||||||
|
|
||||||
|
/* The common Cleaner. */
|
||||||
|
private final static Cleaner commonCleaner = Cleaner.create();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cleaner for use within OpenJDK modules.
|
||||||
|
*
|
||||||
|
* @return a Cleaner for use within OpenJDK modules
|
||||||
|
*/
|
||||||
|
public static Cleaner cleaner() {
|
||||||
|
return commonCleaner;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -0,0 +1,333 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 2016, 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 jdk.internal.ref;
|
||||||
|
|
||||||
|
import java.lang.ref.Cleaner;
|
||||||
|
import java.lang.ref.Cleaner.Cleanable;
|
||||||
|
import java.lang.ref.ReferenceQueue;
|
||||||
|
import java.security.AccessController;
|
||||||
|
import java.security.PrivilegedAction;
|
||||||
|
import java.util.concurrent.ThreadFactory;
|
||||||
|
import java.util.function.Function;
|
||||||
|
|
||||||
|
import sun.misc.InnocuousThread;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CleanerImpl manages a set of object references and corresponding cleaning actions.
|
||||||
|
* CleanerImpl provides the functionality of {@link java.lang.ref.Cleaner}.
|
||||||
|
*/
|
||||||
|
public final class CleanerImpl {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An object to access the CleanerImpl from a Cleaner; set by Cleaner init.
|
||||||
|
*/
|
||||||
|
private static Function<Cleaner, CleanerImpl> cleanerImplAccess = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Heads of a CleanableList for each reference type.
|
||||||
|
*/
|
||||||
|
final PhantomCleanable<?> phantomCleanableList;
|
||||||
|
|
||||||
|
final WeakCleanable<?> weakCleanableList;
|
||||||
|
|
||||||
|
final SoftCleanable<?> softCleanableList;
|
||||||
|
|
||||||
|
// The ReferenceQueue of pending cleaning actions
|
||||||
|
final ReferenceQueue<Object> queue;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called by Cleaner static initialization to provide the function
|
||||||
|
* to map from Cleaner to CleanerImpl.
|
||||||
|
* @param access a function to map from Cleaner to CleanerImpl
|
||||||
|
*/
|
||||||
|
public static void setCleanerImplAccess(Function<Cleaner, CleanerImpl> access) {
|
||||||
|
if (cleanerImplAccess == null) {
|
||||||
|
cleanerImplAccess = access;
|
||||||
|
} else {
|
||||||
|
throw new InternalError("cleanerImplAccess");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called to get the CleanerImpl for a Cleaner.
|
||||||
|
* @param cleaner the cleaner
|
||||||
|
* @return the corresponding CleanerImpl
|
||||||
|
*/
|
||||||
|
static CleanerImpl getCleanerImpl(Cleaner cleaner) {
|
||||||
|
return cleanerImplAccess.apply(cleaner);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor for CleanerImpl.
|
||||||
|
*/
|
||||||
|
public CleanerImpl() {
|
||||||
|
queue = new ReferenceQueue<>();
|
||||||
|
phantomCleanableList = new PhantomCleanableRef();
|
||||||
|
weakCleanableList = new WeakCleanableRef();
|
||||||
|
softCleanableList = new SoftCleanableRef();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Starts the Cleaner implementation.
|
||||||
|
* Ensure this is the CleanerImpl for the Cleaner.
|
||||||
|
* When started waits for Cleanables to be queued.
|
||||||
|
* @param cleaner the cleaner
|
||||||
|
* @param threadFactory the thread factory
|
||||||
|
*/
|
||||||
|
public void start(Cleaner cleaner, ThreadFactory threadFactory) {
|
||||||
|
if (getCleanerImpl(cleaner) != this) {
|
||||||
|
throw new AssertionError("wrong cleaner");
|
||||||
|
}
|
||||||
|
// schedule a nop cleaning action for the cleaner, so the associated thread
|
||||||
|
// will continue to run at least until the cleaner is reclaimable.
|
||||||
|
new PhantomCleanableRef(cleaner, cleaner, () -> {});
|
||||||
|
|
||||||
|
if (threadFactory == null) {
|
||||||
|
threadFactory = CleanerImpl.InnocuousThreadFactory.factory();
|
||||||
|
}
|
||||||
|
|
||||||
|
// now that there's at least one cleaning action, for the cleaner,
|
||||||
|
// we can start the associated thread, which runs until
|
||||||
|
// all cleaning actions have been run.
|
||||||
|
Thread thread = threadFactory.newThread(this::run);
|
||||||
|
thread.setDaemon(true);
|
||||||
|
thread.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process queued Cleanables as long as the cleanable lists are not empty.
|
||||||
|
* A Cleanable is in one of the lists for each Object and for the Cleaner
|
||||||
|
* itself.
|
||||||
|
* Terminates when the Cleaner is no longer reachable and
|
||||||
|
* has been cleaned and there are no more Cleanable instances
|
||||||
|
* for which the object is reachable.
|
||||||
|
* <p>
|
||||||
|
* If the thread is a ManagedLocalsThread, the threadlocals
|
||||||
|
* are erased before each cleanup
|
||||||
|
*/
|
||||||
|
private void run() {
|
||||||
|
Thread t = Thread.currentThread();
|
||||||
|
InnocuousThread mlThread = (t instanceof InnocuousThread)
|
||||||
|
? (InnocuousThread) t
|
||||||
|
: null;
|
||||||
|
while (!phantomCleanableList.isListEmpty() ||
|
||||||
|
!weakCleanableList.isListEmpty() ||
|
||||||
|
!softCleanableList.isListEmpty()) {
|
||||||
|
if (mlThread != null) {
|
||||||
|
// Clear the thread locals
|
||||||
|
mlThread.eraseThreadLocals();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
// Wait for a Ref, with a timeout to avoid getting hung
|
||||||
|
// due to a race with clear/clean
|
||||||
|
Cleanable ref = (Cleanable) queue.remove(60 * 1000L);
|
||||||
|
if (ref != null) {
|
||||||
|
ref.clean();
|
||||||
|
}
|
||||||
|
} catch (InterruptedException i) {
|
||||||
|
continue; // ignore the interruption
|
||||||
|
} catch (Throwable e) {
|
||||||
|
// ignore exceptions from the cleanup action
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Perform cleaning on an unreachable PhantomReference.
|
||||||
|
*/
|
||||||
|
public static final class PhantomCleanableRef extends PhantomCleanable<Object> {
|
||||||
|
private final Runnable action;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor for a phantom cleanable reference.
|
||||||
|
* @param obj the object to monitor
|
||||||
|
* @param cleaner the cleaner
|
||||||
|
* @param action the action Runnable
|
||||||
|
*/
|
||||||
|
public PhantomCleanableRef(Object obj, Cleaner cleaner, Runnable action) {
|
||||||
|
super(obj, cleaner);
|
||||||
|
this.action = action;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor used only for root of phantom cleanable list.
|
||||||
|
*/
|
||||||
|
PhantomCleanableRef() {
|
||||||
|
super();
|
||||||
|
this.action = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void performCleanup() {
|
||||||
|
action.run();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prevent access to referent even when it is still alive.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Object get() {
|
||||||
|
throw new UnsupportedOperationException("get");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Direct clearing of the referent is not supported.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
throw new UnsupportedOperationException("clear");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Perform cleaning on an unreachable WeakReference.
|
||||||
|
*/
|
||||||
|
public static final class WeakCleanableRef extends WeakCleanable<Object> {
|
||||||
|
private final Runnable action;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor for a weak cleanable reference.
|
||||||
|
* @param obj the object to monitor
|
||||||
|
* @param cleaner the cleaner
|
||||||
|
* @param action the action Runnable
|
||||||
|
*/
|
||||||
|
WeakCleanableRef(Object obj, Cleaner cleaner, Runnable action) {
|
||||||
|
super(obj, cleaner);
|
||||||
|
this.action = action;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor used only for root of weak cleanable list.
|
||||||
|
*/
|
||||||
|
WeakCleanableRef() {
|
||||||
|
super();
|
||||||
|
this.action = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void performCleanup() {
|
||||||
|
action.run();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prevent access to referent even when it is still alive.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Object get() {
|
||||||
|
throw new UnsupportedOperationException("get");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Direct clearing of the referent is not supported.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
throw new UnsupportedOperationException("clear");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Perform cleaning on an unreachable SoftReference.
|
||||||
|
*/
|
||||||
|
public static final class SoftCleanableRef extends SoftCleanable<Object> {
|
||||||
|
private final Runnable action;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor for a soft cleanable reference.
|
||||||
|
* @param obj the object to monitor
|
||||||
|
* @param cleaner the cleaner
|
||||||
|
* @param action the action Runnable
|
||||||
|
*/
|
||||||
|
SoftCleanableRef(Object obj, Cleaner cleaner, Runnable action) {
|
||||||
|
super(obj, cleaner);
|
||||||
|
this.action = action;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor used only for root of soft cleanable list.
|
||||||
|
*/
|
||||||
|
SoftCleanableRef() {
|
||||||
|
super();
|
||||||
|
this.action = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void performCleanup() {
|
||||||
|
action.run();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prevent access to referent even when it is still alive.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public Object get() {
|
||||||
|
throw new UnsupportedOperationException("get");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Direct clearing of the referent is not supported.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
throw new UnsupportedOperationException("clear");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A ThreadFactory for InnocuousThreads.
|
||||||
|
* The factory is a singleton.
|
||||||
|
*/
|
||||||
|
static final class InnocuousThreadFactory implements ThreadFactory {
|
||||||
|
final static ThreadFactory factory = new InnocuousThreadFactory();
|
||||||
|
|
||||||
|
static ThreadFactory factory() {
|
||||||
|
return factory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Thread newThread(Runnable r) {
|
||||||
|
return AccessController.doPrivileged((PrivilegedAction<Thread>) () -> {
|
||||||
|
Thread t = new InnocuousThread(r);
|
||||||
|
t.setPriority(Thread.MAX_PRIORITY - 2);
|
||||||
|
t.setName("Cleaner-" + t.getId());
|
||||||
|
return t;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,178 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 2016, 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 jdk.internal.ref;
|
||||||
|
|
||||||
|
import java.lang.ref.Cleaner;
|
||||||
|
import java.lang.ref.PhantomReference;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PhantomCleanable subclasses efficiently encapsulate cleanup state and
|
||||||
|
* the cleaning action.
|
||||||
|
* Subclasses implement the abstract {@link #performCleanup()} method
|
||||||
|
* to provide the cleaning action.
|
||||||
|
* When constructed, the object reference and the {@link Cleaner.Cleanable Cleanable}
|
||||||
|
* are registered with the {@link Cleaner}.
|
||||||
|
* The Cleaner invokes {@link Cleaner.Cleanable#clean() clean} after the
|
||||||
|
* referent becomes phantom reachable.
|
||||||
|
*/
|
||||||
|
public abstract class PhantomCleanable<T> extends PhantomReference<T>
|
||||||
|
implements Cleaner.Cleanable {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Links to previous and next in a doubly-linked list.
|
||||||
|
*/
|
||||||
|
PhantomCleanable<?> prev = this, next = this;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The list of PhantomCleanable; synchronizes insert and remove.
|
||||||
|
*/
|
||||||
|
private final PhantomCleanable<?> list;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs new {@code PhantomCleanable} with
|
||||||
|
* {@code non-null referent} and {@code non-null cleaner}.
|
||||||
|
* The {@code cleaner} is not retained; it is only used to
|
||||||
|
* register the newly constructed {@link Cleaner.Cleanable Cleanable}.
|
||||||
|
*
|
||||||
|
* @param referent the referent to track
|
||||||
|
* @param cleaner the {@code Cleaner} to register with
|
||||||
|
*/
|
||||||
|
public PhantomCleanable(T referent, Cleaner cleaner) {
|
||||||
|
super(Objects.requireNonNull(referent), CleanerImpl.getCleanerImpl(cleaner).queue);
|
||||||
|
this.list = CleanerImpl.getCleanerImpl(cleaner).phantomCleanableList;
|
||||||
|
insert();
|
||||||
|
|
||||||
|
// TODO: Replace getClass() with ReachabilityFence when it is available
|
||||||
|
cleaner.getClass();
|
||||||
|
referent.getClass();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct a new root of the list; not inserted.
|
||||||
|
*/
|
||||||
|
PhantomCleanable() {
|
||||||
|
super(null, null);
|
||||||
|
this.list = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Insert this PhantomCleanable after the list head.
|
||||||
|
*/
|
||||||
|
private void insert() {
|
||||||
|
synchronized (list) {
|
||||||
|
prev = list;
|
||||||
|
next = list.next;
|
||||||
|
next.prev = this;
|
||||||
|
list.next = this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove this PhantomCleanable from the list.
|
||||||
|
*
|
||||||
|
* @return true if Cleanable was removed or false if not because
|
||||||
|
* it had already been removed before
|
||||||
|
*/
|
||||||
|
private boolean remove() {
|
||||||
|
synchronized (list) {
|
||||||
|
if (next != this) {
|
||||||
|
next.prev = prev;
|
||||||
|
prev.next = next;
|
||||||
|
prev = this;
|
||||||
|
next = this;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the list's next reference refers to itself.
|
||||||
|
*
|
||||||
|
* @return true if the list is empty
|
||||||
|
*/
|
||||||
|
boolean isListEmpty() {
|
||||||
|
synchronized (list) {
|
||||||
|
return list == list.next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister this PhantomCleanable and invoke {@link #performCleanup()},
|
||||||
|
* ensuring at-most-once semantics.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final void clean() {
|
||||||
|
if (remove()) {
|
||||||
|
super.clear();
|
||||||
|
performCleanup();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister this PhantomCleanable and clear the reference.
|
||||||
|
* Due to inherent concurrency, {@link #performCleanup()} may still be invoked.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
if (remove()) {
|
||||||
|
super.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The {@code performCleanup} abstract method is overridden
|
||||||
|
* to implement the cleaning logic.
|
||||||
|
* The {@code performCleanup} method should not be called except
|
||||||
|
* by the {@link #clean} method which ensures at most once semantics.
|
||||||
|
*/
|
||||||
|
protected abstract void performCleanup();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method always throws {@link UnsupportedOperationException}.
|
||||||
|
* Enqueuing details of {@link Cleaner.Cleanable}
|
||||||
|
* are a private implementation detail.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final boolean isEnqueued() {
|
||||||
|
throw new UnsupportedOperationException("isEnqueued");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method always throws {@link UnsupportedOperationException}.
|
||||||
|
* Enqueuing details of {@link Cleaner.Cleanable}
|
||||||
|
* are a private implementation detail.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final boolean enqueue() {
|
||||||
|
throw new UnsupportedOperationException("enqueue");
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,178 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 2016, 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 jdk.internal.ref;
|
||||||
|
|
||||||
|
import java.lang.ref.Cleaner;
|
||||||
|
import java.lang.ref.SoftReference;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SoftCleanable subclasses efficiently encapsulate cleanup state and
|
||||||
|
* the cleaning action.
|
||||||
|
* Subclasses implement the abstract {@link #performCleanup()} method
|
||||||
|
* to provide the cleaning action.
|
||||||
|
* When constructed, the object reference and the {@link Cleaner.Cleanable Cleanable}
|
||||||
|
* are registered with the {@link Cleaner}.
|
||||||
|
* The Cleaner invokes {@link Cleaner.Cleanable#clean() clean} after the
|
||||||
|
* referent becomes softly reachable.
|
||||||
|
*/
|
||||||
|
public abstract class SoftCleanable<T> extends SoftReference<T>
|
||||||
|
implements Cleaner.Cleanable {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Links to previous and next in a doubly-linked list.
|
||||||
|
*/
|
||||||
|
SoftCleanable<?> prev = this, next = this;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The list of SoftCleanable; synchronizes insert and remove.
|
||||||
|
*/
|
||||||
|
private final SoftCleanable<?> list;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs new {@code SoftCleanableReference} with
|
||||||
|
* {@code non-null referent} and {@code non-null cleaner}.
|
||||||
|
* The {@code cleaner} is not retained by this reference; it is only used
|
||||||
|
* to register the newly constructed {@link Cleaner.Cleanable Cleanable}.
|
||||||
|
*
|
||||||
|
* @param referent the referent to track
|
||||||
|
* @param cleaner the {@code Cleaner} to register with
|
||||||
|
*/
|
||||||
|
public SoftCleanable(T referent, Cleaner cleaner) {
|
||||||
|
super(Objects.requireNonNull(referent), CleanerImpl.getCleanerImpl(cleaner).queue);
|
||||||
|
list = CleanerImpl.getCleanerImpl(cleaner).softCleanableList;
|
||||||
|
insert();
|
||||||
|
|
||||||
|
// TODO: Replace getClass() with ReachabilityFence when it is available
|
||||||
|
cleaner.getClass();
|
||||||
|
referent.getClass();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct a new root of the list; not inserted.
|
||||||
|
*/
|
||||||
|
SoftCleanable() {
|
||||||
|
super(null, null);
|
||||||
|
this.list = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Insert this SoftCleanableReference after the list head.
|
||||||
|
*/
|
||||||
|
private void insert() {
|
||||||
|
synchronized (list) {
|
||||||
|
prev = list;
|
||||||
|
next = list.next;
|
||||||
|
next.prev = this;
|
||||||
|
list.next = this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove this SoftCleanableReference from the list.
|
||||||
|
*
|
||||||
|
* @return true if Cleanable was removed or false if not because
|
||||||
|
* it had already been removed before
|
||||||
|
*/
|
||||||
|
private boolean remove() {
|
||||||
|
synchronized (list) {
|
||||||
|
if (next != this) {
|
||||||
|
next.prev = prev;
|
||||||
|
prev.next = next;
|
||||||
|
prev = this;
|
||||||
|
next = this;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the list's next reference refers to itself.
|
||||||
|
*
|
||||||
|
* @return true if the list is empty
|
||||||
|
*/
|
||||||
|
boolean isListEmpty() {
|
||||||
|
synchronized (list) {
|
||||||
|
return list == list.next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister this SoftCleanable reference and invoke {@link #performCleanup()},
|
||||||
|
* ensuring at-most-once semantics.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final void clean() {
|
||||||
|
if (remove()) {
|
||||||
|
super.clear();
|
||||||
|
performCleanup();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister this SoftCleanable and clear the reference.
|
||||||
|
* Due to inherent concurrency, {@link #performCleanup()} may still be invoked.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
if (remove()) {
|
||||||
|
super.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The {@code performCleanup} abstract method is overridden
|
||||||
|
* to implement the cleaning logic.
|
||||||
|
* The {@code performCleanup} method should not be called except
|
||||||
|
* by the {@link #clean} method which ensures at most once semantics.
|
||||||
|
*/
|
||||||
|
protected abstract void performCleanup();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method always throws {@link UnsupportedOperationException}.
|
||||||
|
* Enqueuing details of {@link Cleaner.Cleanable}
|
||||||
|
* are a private implementation detail.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final boolean isEnqueued() {
|
||||||
|
throw new UnsupportedOperationException("isEnqueued");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method always throws {@link UnsupportedOperationException}.
|
||||||
|
* Enqueuing details of {@link Cleaner.Cleanable}
|
||||||
|
* are a private implementation detail.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final boolean enqueue() {
|
||||||
|
throw new UnsupportedOperationException("enqueue");
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,178 @@
|
|||||||
|
package jdk.internal.ref;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 2016, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.lang.ref.Cleaner;
|
||||||
|
import java.lang.ref.WeakReference;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WeakCleanable subclasses efficiently encapsulate cleanup state and
|
||||||
|
* the cleaning action.
|
||||||
|
* Subclasses implement the abstract {@link #performCleanup()} method
|
||||||
|
* to provide the cleaning action.
|
||||||
|
* When constructed, the object reference and the {@link Cleaner.Cleanable Cleanable}
|
||||||
|
* are registered with the {@link Cleaner}.
|
||||||
|
* The Cleaner invokes {@link Cleaner.Cleanable#clean() clean} after the
|
||||||
|
* referent becomes weakly reachable.
|
||||||
|
*/
|
||||||
|
public abstract class WeakCleanable<T> extends WeakReference<T>
|
||||||
|
implements Cleaner.Cleanable {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Links to previous and next in a doubly-linked list.
|
||||||
|
*/
|
||||||
|
WeakCleanable<?> prev = this, next = this;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The list of WeakCleanable; synchronizes insert and remove.
|
||||||
|
*/
|
||||||
|
private final WeakCleanable<?> list;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs new {@code WeakCleanableReference} with
|
||||||
|
* {@code non-null referent} and {@code non-null cleaner}.
|
||||||
|
* The {@code cleaner} is not retained by this reference; it is only used
|
||||||
|
* to register the newly constructed {@link Cleaner.Cleanable Cleanable}.
|
||||||
|
*
|
||||||
|
* @param referent the referent to track
|
||||||
|
* @param cleaner the {@code Cleaner} to register new reference with
|
||||||
|
*/
|
||||||
|
public WeakCleanable(T referent, Cleaner cleaner) {
|
||||||
|
super(Objects.requireNonNull(referent), CleanerImpl.getCleanerImpl(cleaner).queue);
|
||||||
|
list = CleanerImpl.getCleanerImpl(cleaner).weakCleanableList;
|
||||||
|
insert();
|
||||||
|
|
||||||
|
// TODO: Replace getClass() with ReachabilityFence when it is available
|
||||||
|
cleaner.getClass();
|
||||||
|
referent.getClass();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Construct a new root of the list; not inserted.
|
||||||
|
*/
|
||||||
|
WeakCleanable() {
|
||||||
|
super(null, null);
|
||||||
|
this.list = this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Insert this WeakCleanableReference after the list head.
|
||||||
|
*/
|
||||||
|
private void insert() {
|
||||||
|
synchronized (list) {
|
||||||
|
prev = list;
|
||||||
|
next = list.next;
|
||||||
|
next.prev = this;
|
||||||
|
list.next = this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove this WeakCleanableReference from the list.
|
||||||
|
*
|
||||||
|
* @return true if Cleanable was removed or false if not because
|
||||||
|
* it had already been removed before
|
||||||
|
*/
|
||||||
|
private boolean remove() {
|
||||||
|
synchronized (list) {
|
||||||
|
if (next != this) {
|
||||||
|
next.prev = prev;
|
||||||
|
prev.next = next;
|
||||||
|
prev = this;
|
||||||
|
next = this;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the list's next reference refers to itself.
|
||||||
|
*
|
||||||
|
* @return true if the list is empty
|
||||||
|
*/
|
||||||
|
boolean isListEmpty() {
|
||||||
|
synchronized (list) {
|
||||||
|
return list == list.next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister this WeakCleanable reference and invoke {@link #performCleanup()},
|
||||||
|
* ensuring at-most-once semantics.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final void clean() {
|
||||||
|
if (remove()) {
|
||||||
|
super.clear();
|
||||||
|
performCleanup();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unregister this WeakCleanable and clear the reference.
|
||||||
|
* Due to inherent concurrency, {@link #performCleanup()} may still be invoked.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
if (remove()) {
|
||||||
|
super.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The {@code performCleanup} abstract method is overridden
|
||||||
|
* to implement the cleaning logic.
|
||||||
|
* The {@code performCleanup} method should not be called except
|
||||||
|
* by the {@link #clean} method which ensures at most once semantics.
|
||||||
|
*/
|
||||||
|
protected abstract void performCleanup();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method always throws {@link UnsupportedOperationException}.
|
||||||
|
* Enqueuing details of {@link Cleaner.Cleanable}
|
||||||
|
* are a private implementation detail.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final boolean isEnqueued() {
|
||||||
|
throw new UnsupportedOperationException("isEnqueued");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This method always throws {@link UnsupportedOperationException}.
|
||||||
|
* Enqueuing details of {@link Cleaner.Cleanable}
|
||||||
|
* are a private implementation detail.
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException always
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public final boolean enqueue() {
|
||||||
|
throw new UnsupportedOperationException("enqueue");
|
||||||
|
}
|
||||||
|
}
|
@ -1,33 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 1995, 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.misc;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
/** This exception is thrown when EOF is reached */
|
|
||||||
public class CEStreamExhausted extends IOException {
|
|
||||||
static final long serialVersionUID = -5889118049525891904L;
|
|
||||||
}
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1994, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1994, 2016, 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
|
||||||
@ -967,12 +967,6 @@ public class HttpClient extends NetworkClient {
|
|||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void finalize() throws Throwable {
|
|
||||||
// This should do nothing. The stream finalizer will
|
|
||||||
// close the fd.
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setDoNotRetry(boolean value) {
|
public void setDoNotRetry(boolean value) {
|
||||||
// failedOnce is used to determine if a request should be retried.
|
// failedOnce is used to determine if a request should be retried.
|
||||||
failedOnce = value;
|
failedOnce = value;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2016, 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
|
||||||
@ -108,13 +108,6 @@ public class URLJarFile extends JarFile {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* close the jar file.
|
|
||||||
*/
|
|
||||||
protected void finalize() throws IOException {
|
|
||||||
close();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the <code>ZipEntry</code> for the given entry name or
|
* Returns the <code>ZipEntry</code> for the given entry name or
|
||||||
* <code>null</code> if not found.
|
* <code>null</code> if not found.
|
||||||
|
@ -2211,7 +2211,7 @@ public final class SSLEngineImpl extends SSLEngine {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized String getHandshakeApplicationProtocol() {
|
public synchronized String getHandshakeApplicationProtocol() {
|
||||||
if ((handshaker != null) && !handshaker.started()) {
|
if ((handshaker != null) && handshaker.started()) {
|
||||||
return handshaker.getHandshakeApplicationProtocol();
|
return handshaker.getHandshakeApplicationProtocol();
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
@ -2598,7 +2598,7 @@ public final class SSLSocketImpl extends BaseSSLSocketImpl {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized String getHandshakeApplicationProtocol() {
|
public synchronized String getHandshakeApplicationProtocol() {
|
||||||
if ((handshaker != null) && !handshaker.started()) {
|
if ((handshaker != null) && handshaker.started()) {
|
||||||
return handshaker.getHandshakeApplicationProtocol();
|
return handshaker.getHandshakeApplicationProtocol();
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2016, 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
|
||||||
@ -153,13 +153,11 @@ final class SignatureAndHashAlgorithm {
|
|||||||
getSupportedAlgorithms(AlgorithmConstraints constraints) {
|
getSupportedAlgorithms(AlgorithmConstraints constraints) {
|
||||||
|
|
||||||
Collection<SignatureAndHashAlgorithm> supported = new ArrayList<>();
|
Collection<SignatureAndHashAlgorithm> supported = new ArrayList<>();
|
||||||
synchronized (priorityMap) {
|
for (SignatureAndHashAlgorithm sigAlg : priorityMap.values()) {
|
||||||
for (SignatureAndHashAlgorithm sigAlg : priorityMap.values()) {
|
if (sigAlg.priority <= SUPPORTED_ALG_PRIORITY_MAX_NUM &&
|
||||||
if (sigAlg.priority <= SUPPORTED_ALG_PRIORITY_MAX_NUM &&
|
constraints.permits(SIGNATURE_PRIMITIVE_SET,
|
||||||
constraints.permits(SIGNATURE_PRIMITIVE_SET,
|
sigAlg.algorithm, null)) {
|
||||||
sigAlg.algorithm, null)) {
|
supported.add(sigAlg);
|
||||||
supported.add(sigAlg);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,17 +98,6 @@ grant codeBase "jrt:/java.activation" {
|
|||||||
// default permissions granted to all domains
|
// default permissions granted to all domains
|
||||||
|
|
||||||
grant {
|
grant {
|
||||||
// Allows any thread to stop itself using the java.lang.Thread.stop()
|
|
||||||
// method that takes no argument.
|
|
||||||
// Note that this permission is granted by default only to remain
|
|
||||||
// backwards compatible.
|
|
||||||
// It is strongly recommended that you either remove this permission
|
|
||||||
// from this policy file or further restrict it to code sources
|
|
||||||
// that you specify, because Thread.stop() is potentially unsafe.
|
|
||||||
// See the API specification of java.lang.Thread.stop() for more
|
|
||||||
// information.
|
|
||||||
permission java.lang.RuntimePermission "stopThread";
|
|
||||||
|
|
||||||
// allows anyone to listen on dynamic ports
|
// allows anyone to listen on dynamic ports
|
||||||
permission java.net.SocketPermission "localhost:0", "listen";
|
permission java.net.SocketPermission "localhost:0", "listen";
|
||||||
|
|
||||||
|
@ -47,6 +47,9 @@ class PlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl
|
|||||||
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
||||||
super.setOption(name, value);
|
super.setOption(name, value);
|
||||||
} else {
|
} else {
|
||||||
|
if (!flowSupported()) {
|
||||||
|
throw new UnsupportedOperationException("unsupported option");
|
||||||
|
}
|
||||||
if (isClosed()) {
|
if (isClosed()) {
|
||||||
throw new SocketException("Socket closed");
|
throw new SocketException("Socket closed");
|
||||||
}
|
}
|
||||||
@ -61,6 +64,9 @@ class PlainDatagramSocketImpl extends AbstractPlainDatagramSocketImpl
|
|||||||
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
||||||
return super.getOption(name);
|
return super.getOption(name);
|
||||||
}
|
}
|
||||||
|
if (!flowSupported()) {
|
||||||
|
throw new UnsupportedOperationException("unsupported option");
|
||||||
|
}
|
||||||
if (isClosed()) {
|
if (isClosed()) {
|
||||||
throw new SocketException("Socket closed");
|
throw new SocketException("Socket closed");
|
||||||
}
|
}
|
||||||
|
@ -61,6 +61,9 @@ class PlainSocketImpl extends AbstractPlainSocketImpl
|
|||||||
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
||||||
super.setOption(name, value);
|
super.setOption(name, value);
|
||||||
} else {
|
} else {
|
||||||
|
if (getSocket() == null || !flowSupported()) {
|
||||||
|
throw new UnsupportedOperationException("unsupported option");
|
||||||
|
}
|
||||||
if (isClosedOrPending()) {
|
if (isClosedOrPending()) {
|
||||||
throw new SocketException("Socket closed");
|
throw new SocketException("Socket closed");
|
||||||
}
|
}
|
||||||
@ -75,6 +78,9 @@ class PlainSocketImpl extends AbstractPlainSocketImpl
|
|||||||
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
if (!name.equals(ExtendedSocketOptions.SO_FLOW_SLA)) {
|
||||||
return super.getOption(name);
|
return super.getOption(name);
|
||||||
}
|
}
|
||||||
|
if (getSocket() == null || !flowSupported()) {
|
||||||
|
throw new UnsupportedOperationException("unsupported option");
|
||||||
|
}
|
||||||
if (isClosedOrPending()) {
|
if (isClosedOrPending()) {
|
||||||
throw new SocketException("Socket closed");
|
throw new SocketException("Socket closed");
|
||||||
}
|
}
|
||||||
|
@ -42,8 +42,10 @@ import java.util.concurrent.CompletableFuture;
|
|||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import jdk.internal.misc.JavaIOFileDescriptorAccess;
|
import jdk.internal.misc.JavaIOFileDescriptorAccess;
|
||||||
import jdk.internal.misc.SharedSecrets;
|
import jdk.internal.misc.SharedSecrets;
|
||||||
|
import jdk.internal.ref.CleanerFactory;
|
||||||
|
|
||||||
/* This class is for the exclusive use of ProcessBuilder.start() to
|
/* This class is for the exclusive use of ProcessBuilder.start() to
|
||||||
* create new processes.
|
* create new processes.
|
||||||
@ -417,6 +419,10 @@ final class ProcessImpl extends Process {
|
|||||||
|
|
||||||
handle = create(cmdstr, envblock, path,
|
handle = create(cmdstr, envblock, path,
|
||||||
stdHandles, redirectErrorStream);
|
stdHandles, redirectErrorStream);
|
||||||
|
// Register a cleaning function to close the handle
|
||||||
|
final long local_handle = handle; // local to prevent capture of this
|
||||||
|
CleanerFactory.cleaner().register(this, () -> closeHandle(local_handle));
|
||||||
|
|
||||||
processHandle = ProcessHandleImpl.getInternal(getProcessId0(handle));
|
processHandle = ProcessHandleImpl.getInternal(getProcessId0(handle));
|
||||||
|
|
||||||
java.security.AccessController.doPrivileged(
|
java.security.AccessController.doPrivileged(
|
||||||
@ -463,10 +469,6 @@ final class ProcessImpl extends Process {
|
|||||||
return stderr_stream;
|
return stderr_stream;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void finalize() {
|
|
||||||
closeHandle(handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final int STILL_ACTIVE = getStillActive();
|
private static final int STILL_ACTIVE = getStillActive();
|
||||||
private static native int getStillActive();
|
private static native int getStillActive();
|
||||||
|
|
||||||
|
@ -337,6 +337,15 @@ GetJREPath(char *path, jint pathsize)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Try getting path to JRE from path to JLI.DLL */
|
||||||
|
if (GetApplicationHomeFromDll(path, pathsize)) {
|
||||||
|
JLI_Snprintf(javadll, sizeof(javadll), "%s\\bin\\" JAVA_DLL, path);
|
||||||
|
if (stat(javadll, &s) == 0) {
|
||||||
|
JLI_TraceLauncher("JRE path is %s\n", path);
|
||||||
|
return JNI_TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
JLI_ReportErrorMessage(JRE_ERROR8 JAVA_DLL);
|
JLI_ReportErrorMessage(JRE_ERROR8 JAVA_DLL);
|
||||||
return JNI_FALSE;
|
return JNI_FALSE;
|
||||||
|
|
||||||
@ -404,17 +413,17 @@ LoadJavaVM(const char *jvmpath, InvocationFunctions *ifn)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If app is "c:\foo\bin\javac", then put "c:\foo" into buf.
|
* Removes the trailing file name and one sub-folder from a path.
|
||||||
|
* If buf is "c:\foo\bin\javac", then put "c:\foo" into buf.
|
||||||
*/
|
*/
|
||||||
jboolean
|
jboolean
|
||||||
GetApplicationHome(char *buf, jint bufsize)
|
TruncatePath(char *buf)
|
||||||
{
|
{
|
||||||
char *cp;
|
char *cp;
|
||||||
GetModuleFileName(0, buf, bufsize);
|
|
||||||
*JLI_StrRChr(buf, '\\') = '\0'; /* remove .exe file name */
|
*JLI_StrRChr(buf, '\\') = '\0'; /* remove .exe file name */
|
||||||
if ((cp = JLI_StrRChr(buf, '\\')) == 0) {
|
if ((cp = JLI_StrRChr(buf, '\\')) == 0) {
|
||||||
/* This happens if the application is in a drive root, and
|
/* This happens if the application is in a drive root, and
|
||||||
* there is no bin directory. */
|
* there is no bin directory. */
|
||||||
buf[0] = '\0';
|
buf[0] = '\0';
|
||||||
return JNI_FALSE;
|
return JNI_FALSE;
|
||||||
}
|
}
|
||||||
@ -422,6 +431,36 @@ GetApplicationHome(char *buf, jint bufsize)
|
|||||||
return JNI_TRUE;
|
return JNI_TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieves the path to the JRE home by locating the executable file
|
||||||
|
* of the current process and then truncating the path to the executable
|
||||||
|
*/
|
||||||
|
jboolean
|
||||||
|
GetApplicationHome(char *buf, jint bufsize)
|
||||||
|
{
|
||||||
|
GetModuleFileName(NULL, buf, bufsize);
|
||||||
|
return TruncatePath(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieves the path to the JRE home by locating JLI.DLL and
|
||||||
|
* then truncating the path to JLI.DLL
|
||||||
|
*/
|
||||||
|
jboolean
|
||||||
|
GetApplicationHomeFromDll(char *buf, jint bufsize)
|
||||||
|
{
|
||||||
|
HMODULE hModule;
|
||||||
|
DWORD dwFlags =
|
||||||
|
GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS |
|
||||||
|
GET_MODULE_HANDLE_EX_FLAG_UNCHANGED_REFCOUNT;
|
||||||
|
|
||||||
|
if (GetModuleHandleEx(dwFlags, (LPCSTR)&GetJREPath, &hModule) == 0) {
|
||||||
|
return JNI_FALSE;
|
||||||
|
};
|
||||||
|
GetModuleFileName(hModule, buf, bufsize);
|
||||||
|
return TruncatePath(buf);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Support for doing cheap, accurate interval timing.
|
* Support for doing cheap, accurate interval timing.
|
||||||
*/
|
*/
|
||||||
|
@ -54,4 +54,7 @@ extern jlong Counter2Micros(jlong counts);
|
|||||||
|
|
||||||
int UnsetEnv(char *name);
|
int UnsetEnv(char *name);
|
||||||
|
|
||||||
|
jboolean
|
||||||
|
GetApplicationHomeFromDll(char *buf, jint bufsize);
|
||||||
|
|
||||||
#endif /* JAVA_MD_H */
|
#endif /* JAVA_MD_H */
|
||||||
|
@ -43,8 +43,8 @@ import sun.awt.AWTAccessor;
|
|||||||
import sun.awt.AppContext;
|
import sun.awt.AppContext;
|
||||||
import sun.awt.EmbeddedFrame;
|
import sun.awt.EmbeddedFrame;
|
||||||
import sun.awt.SunToolkit;
|
import sun.awt.SunToolkit;
|
||||||
|
import sun.awt.util.PerformanceLogger;
|
||||||
import sun.misc.ManagedLocalsThread;
|
import sun.misc.ManagedLocalsThread;
|
||||||
import sun.misc.PerformanceLogger;
|
|
||||||
import sun.security.util.SecurityConstants;
|
import sun.security.util.SecurityConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
package sun.misc;
|
package sun.awt.util;
|
||||||
|
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
import java.io.FileWriter;
|
import java.io.FileWriter;
|
@ -88,9 +88,9 @@ import java.awt.font.FontRenderContext;
|
|||||||
import sun.java2d.loops.XORComposite;
|
import sun.java2d.loops.XORComposite;
|
||||||
import sun.awt.ConstrainableGraphics;
|
import sun.awt.ConstrainableGraphics;
|
||||||
import sun.awt.SunHints;
|
import sun.awt.SunHints;
|
||||||
|
import sun.awt.util.PerformanceLogger;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import sun.misc.PerformanceLogger;
|
|
||||||
|
|
||||||
import java.lang.annotation.Native;
|
import java.lang.annotation.Native;
|
||||||
import java.awt.image.MultiResolutionImage;
|
import java.awt.image.MultiResolutionImage;
|
||||||
|
@ -52,6 +52,7 @@ import sun.awt.datatransfer.DataTransferer;
|
|||||||
import sun.font.FontConfigManager;
|
import sun.font.FontConfigManager;
|
||||||
import sun.java2d.SunGraphicsEnvironment;
|
import sun.java2d.SunGraphicsEnvironment;
|
||||||
import sun.misc.*;
|
import sun.misc.*;
|
||||||
|
import sun.awt.util.PerformanceLogger;
|
||||||
import sun.awt.util.ThreadGroupUtils;
|
import sun.awt.util.ThreadGroupUtils;
|
||||||
import sun.print.PrintJob2D;
|
import sun.print.PrintJob2D;
|
||||||
import sun.security.action.GetPropertyAction;
|
import sun.security.action.GetPropertyAction;
|
||||||
|
@ -67,10 +67,10 @@ import java.util.Locale;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import sun.awt.util.PerformanceLogger;
|
||||||
import sun.font.FontManager;
|
import sun.font.FontManager;
|
||||||
import sun.font.FontManagerFactory;
|
import sun.font.FontManagerFactory;
|
||||||
import sun.font.SunFontManager;
|
import sun.font.SunFontManager;
|
||||||
import sun.misc.PerformanceLogger;
|
|
||||||
import sun.util.logging.PlatformLogger;
|
import sun.util.logging.PlatformLogger;
|
||||||
|
|
||||||
public final class WToolkit extends SunToolkit implements Runnable {
|
public final class WToolkit extends SunToolkit implements Runnable {
|
||||||
|
@ -38,6 +38,7 @@ import java.awt.event.WindowListener;
|
|||||||
import java.awt.peer.WindowPeer;
|
import java.awt.peer.WindowPeer;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import jdk.internal.perf.PerfCounter;
|
||||||
import sun.awt.AWTAccessor;
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.AWTAccessor.ComponentAccessor;
|
import sun.awt.AWTAccessor.ComponentAccessor;
|
||||||
import sun.awt.Win32GraphicsDevice;
|
import sun.awt.Win32GraphicsDevice;
|
||||||
@ -69,9 +70,9 @@ public class D3DGraphicsDevice extends Win32GraphicsDevice {
|
|||||||
if (d3dAvailable) {
|
if (d3dAvailable) {
|
||||||
// we don't use pixel formats for the d3d pipeline
|
// we don't use pixel formats for the d3d pipeline
|
||||||
pfDisabled = true;
|
pfDisabled = true;
|
||||||
sun.misc.PerfCounter.getD3DAvailable().set(1);
|
PerfCounter.getD3DAvailable().set(1);
|
||||||
} else {
|
} else {
|
||||||
sun.misc.PerfCounter.getD3DAvailable().set(0);
|
PerfCounter.getD3DAvailable().set(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
import sun.misc.Perf;
|
import jdk.internal.perf.Perf;
|
||||||
import sun.management.counter.Units;
|
import sun.management.counter.Units;
|
||||||
import sun.management.counter.Counter;
|
import sun.management.counter.Counter;
|
||||||
import sun.management.counter.perf.PerfInstrumentation;
|
import sun.management.counter.perf.PerfInstrumentation;
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
package sun.management;
|
package sun.management;
|
||||||
|
|
||||||
import sun.misc.Perf;
|
import jdk.internal.perf.Perf;
|
||||||
import sun.management.counter.*;
|
import sun.management.counter.*;
|
||||||
import sun.management.counter.perf.*;
|
import sun.management.counter.perf.*;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
|
@ -31,12 +31,14 @@ import java.util.List;
|
|||||||
* <code>ScriptEngineFactory</code> is used to describe and instantiate
|
* <code>ScriptEngineFactory</code> is used to describe and instantiate
|
||||||
* <code>ScriptEngines</code>.
|
* <code>ScriptEngines</code>.
|
||||||
* <br><br>
|
* <br><br>
|
||||||
* Each class implementing <code>ScriptEngine</code> has a corresponding factory
|
* Each class implementing <code>ScriptEngine</code> has a corresponding
|
||||||
* that exposes metadata describing the engine class.
|
* factory that exposes metadata describing the engine class.
|
||||||
* <br><br>The <code>ScriptEngineManager</code>
|
* <br><br>The <code>ScriptEngineManager</code>
|
||||||
* uses the service provider mechanism described in the <i>Jar File Specification</i> to obtain
|
* uses the service-provider loader mechanism described in the
|
||||||
* instances of all <code>ScriptEngineFactories</code> available in
|
* {@link java.util.ServiceLoader} class to obtain
|
||||||
* the current ClassLoader.
|
* instances of {@code ScriptEngineFactory} instances.
|
||||||
|
* See {@link ScriptEngineManager#ScriptEngineManager()} and
|
||||||
|
* {@link ScriptEngineManager#ScriptEngineManager(java.lang.ClassLoader)}.
|
||||||
*
|
*
|
||||||
* @since 1.6
|
* @since 1.6
|
||||||
*/
|
*/
|
||||||
|
@ -33,7 +33,8 @@ import java.util.ServiceConfigurationError;
|
|||||||
* The <code>ScriptEngineManager</code> implements a discovery and instantiation
|
* The <code>ScriptEngineManager</code> implements a discovery and instantiation
|
||||||
* mechanism for <code>ScriptEngine</code> classes and also maintains a
|
* mechanism for <code>ScriptEngine</code> classes and also maintains a
|
||||||
* collection of key/value pairs storing state shared by all engines created
|
* collection of key/value pairs storing state shared by all engines created
|
||||||
* by the Manager. This class uses the <a href="../../../technotes/guides/jar/jar.html#Service%20Provider">service provider</a> mechanism to enumerate all the
|
* by the Manager. This class uses the service provider mechanism described in the
|
||||||
|
* {@link java.util.ServiceLoader} class to enumerate all the
|
||||||
* implementations of <code>ScriptEngineFactory</code>. <br><br>
|
* implementations of <code>ScriptEngineFactory</code>. <br><br>
|
||||||
* The <code>ScriptEngineManager</code> provides a method to return a list of all these factories
|
* The <code>ScriptEngineManager</code> provides a method to return a list of all these factories
|
||||||
* as well as utility methods which look up factories on the basis of language name, file extension
|
* as well as utility methods which look up factories on the basis of language name, file extension
|
||||||
@ -64,7 +65,7 @@ public class ScriptEngineManager {
|
|||||||
/**
|
/**
|
||||||
* This constructor loads the implementations of
|
* This constructor loads the implementations of
|
||||||
* <code>ScriptEngineFactory</code> visible to the given
|
* <code>ScriptEngineFactory</code> visible to the given
|
||||||
* <code>ClassLoader</code> using the <a href="../../../technotes/guides/jar/jar.html#Service%20Provider">service provider</a> mechanism.<br><br>
|
* <code>ClassLoader</code> using the service provider mechanism.<br><br>
|
||||||
* If loader is <code>null</code>, the script engine factories that are
|
* If loader is <code>null</code>, the script engine factories that are
|
||||||
* bundled with the platform are loaded. <br>
|
* bundled with the platform are loaded. <br>
|
||||||
*
|
*
|
||||||
|
@ -0,0 +1,94 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2005, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
|
||||||
|
<p>The scripting API consists of interfaces and classes that define
|
||||||
|
Java™ Scripting Engines and provides
|
||||||
|
a framework for their use in Java applications. This API is intended
|
||||||
|
for use by application programmers who wish to execute programs
|
||||||
|
written in scripting languages in their Java applications. The
|
||||||
|
scripting language programs are usually provided by the end-users of
|
||||||
|
the applications.
|
||||||
|
</p>
|
||||||
|
<p>The main areas of functionality of <code>javax.script</code>
|
||||||
|
package include
|
||||||
|
</p>
|
||||||
|
<ol>
|
||||||
|
<li><p><b>Script execution</b>: Scripts
|
||||||
|
are streams of characters used as sources for programs executed by
|
||||||
|
script engines. Script execution uses
|
||||||
|
{@link javax.script.ScriptEngine#eval eval} methods of
|
||||||
|
{@link javax.script.ScriptEngine ScriptEngine} and methods of the
|
||||||
|
{@link javax.script.Invocable Invocable} interface.
|
||||||
|
</p>
|
||||||
|
<li><p><b>Binding</b>: This facility
|
||||||
|
allows Java objects to be exposed to script programs as named
|
||||||
|
variables. {@link javax.script.Bindings Bindings} and
|
||||||
|
{@link javax.script.ScriptContext ScriptContext}
|
||||||
|
classes are used for this purpose.
|
||||||
|
</p>
|
||||||
|
<li><p><b>Compilation</b>: This
|
||||||
|
functionality allows the intermediate code generated by the
|
||||||
|
front-end of a script engine to be stored and executed repeatedly.
|
||||||
|
This benefits applications that execute the same script multiple
|
||||||
|
times. These applications can gain efficiency since the engines'
|
||||||
|
front-ends only need to execute once per script rather than once per
|
||||||
|
script execution. Note that this functionality is optional and
|
||||||
|
script engines may choose not to implement it. Callers need to check
|
||||||
|
for availability of the {@link javax.script.Compilable Compilable}
|
||||||
|
interface using an <I>instanceof</I> check.
|
||||||
|
</p>
|
||||||
|
<li><p><b>Invocation</b>: This
|
||||||
|
functionality allows the reuse of intermediate code generated by a
|
||||||
|
script engine's front-end. Whereas Compilation allows entire scripts
|
||||||
|
represented by intermediate code to be re-executed, Invocation
|
||||||
|
functionality allows individual procedures/methods in the scripts to
|
||||||
|
be re-executed. As in the case with compilation, not all script
|
||||||
|
engines are required to provide this facility. Caller has to check
|
||||||
|
for {@link javax.script.Invocable Invocable} availability.
|
||||||
|
</p>
|
||||||
|
<li><p><b>Script engine discovery</b>: Applications
|
||||||
|
written to the Scripting API might have specific requirements on
|
||||||
|
script engines. Some may require a specific scripting language
|
||||||
|
and/or version while others may require a specific implementation
|
||||||
|
engine and/or version. Script engines are packaged in a specified
|
||||||
|
way so that engines can be discovered at runtime and queried for
|
||||||
|
attributes. The Engine discovery mechanism is based on the service-provider
|
||||||
|
loading facility described in the {@link java.util.ServiceLoader} class.
|
||||||
|
{@link javax.script.ScriptEngineManager ScriptEngineManager}
|
||||||
|
includes
|
||||||
|
{@link javax.script.ScriptEngineManager#getEngineFactories getEngineFactories} method to get all
|
||||||
|
{@link javax.script.ScriptEngineFactory ScriptEngineFactory} instances
|
||||||
|
discovered using this mechanism. <code>ScriptEngineFactory</code> has
|
||||||
|
methods to query attributes about script engine.
|
||||||
|
</p>
|
||||||
|
</ol>
|
||||||
|
|
||||||
|
@since 1.6
|
||||||
|
*/
|
||||||
|
|
||||||
|
package javax.script;
|
||||||
|
|
@ -1,102 +0,0 @@
|
|||||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<!--
|
|
||||||
Copyright (c) 2005, 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
</head>
|
|
||||||
<body bgcolor="white">
|
|
||||||
<p>The scripting API consists of interfaces and classes that define
|
|
||||||
Java™ Scripting Engines and provides
|
|
||||||
a framework for their use in Java applications. This API is intended
|
|
||||||
for use by application programmers who wish to execute programs
|
|
||||||
written in scripting languages in their Java applications. The
|
|
||||||
scripting language programs are usually provided by the end-users of
|
|
||||||
the applications.
|
|
||||||
</p>
|
|
||||||
<p>The main areas of functionality of <code>javax.script</code>
|
|
||||||
package include
|
|
||||||
</p>
|
|
||||||
<ol>
|
|
||||||
<li><p><b>Script execution</b>: Scripts
|
|
||||||
are streams of characters used as sources for programs executed by
|
|
||||||
script engines. Script execution uses
|
|
||||||
{@link javax.script.ScriptEngine#eval eval} methods of
|
|
||||||
{@link javax.script.ScriptEngine ScriptEngine} and methods of the
|
|
||||||
{@link javax.script.Invocable Invocable} interface.
|
|
||||||
</p>
|
|
||||||
<li><p><b>Binding</b>: This facility
|
|
||||||
allows Java objects to be exposed to script programs as named
|
|
||||||
variables. {@link javax.script.Bindings Bindings} and
|
|
||||||
{@link javax.script.ScriptContext ScriptContext}
|
|
||||||
classes are used for this purpose.
|
|
||||||
</p>
|
|
||||||
<li><p><b>Compilation</b>: This
|
|
||||||
functionality allows the intermediate code generated by the
|
|
||||||
front-end of a script engine to be stored and executed repeatedly.
|
|
||||||
This benefits applications that execute the same script multiple
|
|
||||||
times. These applications can gain efficiency since the engines'
|
|
||||||
front-ends only need to execute once per script rather than once per
|
|
||||||
script execution. Note that this functionality is optional and
|
|
||||||
script engines may choose not to implement it. Callers need to check
|
|
||||||
for availability of the {@link javax.script.Compilable Compilable}
|
|
||||||
interface using an <I>instanceof</I> check.
|
|
||||||
</p>
|
|
||||||
<li><p><b>Invocation</b>: This
|
|
||||||
functionality allows the reuse of intermediate code generated by a
|
|
||||||
script engine's front-end. Whereas Compilation allows entire scripts
|
|
||||||
represented by intermediate code to be re-executed, Invocation
|
|
||||||
functionality allows individual procedures/methods in the scripts to
|
|
||||||
be re-executed. As in the case with compilation, not all script
|
|
||||||
engines are required to provide this facility. Caller has to check
|
|
||||||
for {@link javax.script.Invocable Invocable} availability.
|
|
||||||
</p>
|
|
||||||
<li><p><b>Script engine discovery and Metadata</b>: Applications
|
|
||||||
written to the Scripting API might have specific requirements on
|
|
||||||
script engines. Some may require a specific scripting language
|
|
||||||
and/or version while others may require a specific implementation
|
|
||||||
engine and/or version. Script engines are packaged in a specified
|
|
||||||
way so that engines can be discovered at runtime and queried for
|
|
||||||
attributes. The Engine discovery mechanism is based on the Service
|
|
||||||
discovery mechanism described in the <b>Jar File Specification</b>.
|
|
||||||
Script engine implementing classes are packaged in jar files that
|
|
||||||
include a text resource named
|
|
||||||
<b>META-INF/services/javax.script.ScriptEngineFactory</b>. This
|
|
||||||
resource must include a line for each
|
|
||||||
{@link javax.script.ScriptEngineFactory ScriptEngineFactory}
|
|
||||||
that is packaged in the jar file.
|
|
||||||
{@link javax.script.ScriptEngineManager ScriptEngineManager}
|
|
||||||
includes
|
|
||||||
{@link javax.script.ScriptEngineManager#getEngineFactories getEngineFactories} method to get all
|
|
||||||
{@link javax.script.ScriptEngineFactory ScriptEngineFactory} instances
|
|
||||||
discovered using this mechanism. <code>ScriptEngineFactory</code> has
|
|
||||||
methods to query attributes about script engine.
|
|
||||||
</p>
|
|
||||||
</ol>
|
|
||||||
|
|
||||||
@since 1.6
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -95,7 +95,7 @@ public abstract class AbstractMonitoredVm implements BufferedMonitoredVm {
|
|||||||
public void detach() {
|
public void detach() {
|
||||||
/*
|
/*
|
||||||
* no default action required because the detach operation for the
|
* no default action required because the detach operation for the
|
||||||
* native byte buffer is managed by the sun.misc.Perf class.
|
* native byte buffer is managed by the Perf class.
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
|
|
||||||
package sun.jvmstat.perfdata.monitor;
|
package sun.jvmstat.perfdata.monitor;
|
||||||
|
|
||||||
import sun.misc.Perf;
|
|
||||||
import sun.jvmstat.monitor.*;
|
import sun.jvmstat.monitor.*;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
package sun.jvmstat.perfdata.monitor.protocol.local;
|
package sun.jvmstat.perfdata.monitor.protocol.local;
|
||||||
|
|
||||||
import sun.misc.Perf;
|
import jdk.internal.perf.Perf;
|
||||||
import sun.jvmstat.monitor.*;
|
import sun.jvmstat.monitor.*;
|
||||||
import sun.jvmstat.perfdata.monitor.*;
|
import sun.jvmstat.perfdata.monitor.*;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
###########################################################################
|
###########################################################################
|
||||||
#
|
#
|
||||||
# Copyright (c) 2009, 2015, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2009, 2016, 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
|
||||||
@ -299,6 +299,9 @@ sun/security/provider/SecureRandom/StrongSecureRandom.java macosx-10.10
|
|||||||
# 8074580
|
# 8074580
|
||||||
sun/security/pkcs11/rsa/TestKeyPairGenerator.java generic-all
|
sun/security/pkcs11/rsa/TestKeyPairGenerator.java generic-all
|
||||||
|
|
||||||
|
# 8146387
|
||||||
|
javax/net/ssl/SSLSession/SessionCacheSizeTests.java windows-all,solaris-all
|
||||||
|
|
||||||
############################################################################
|
############################################################################
|
||||||
|
|
||||||
# jdk_sound
|
# jdk_sound
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2013, 2016, 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
|
||||||
@ -31,8 +31,8 @@ tier1 = \
|
|||||||
-java/util/zip/TestLocalTime.java \
|
-java/util/zip/TestLocalTime.java \
|
||||||
:jdk_util \
|
:jdk_util \
|
||||||
-java/util/WeakHashMap/GCDuringIteration.java \
|
-java/util/WeakHashMap/GCDuringIteration.java \
|
||||||
-java/util/concurrent/Phaser/Basic.java \
|
|
||||||
-java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java
|
-java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java
|
||||||
|
-java/util/concurrent/forkjoin/FJExceptionTableLeak.java
|
||||||
sun/nio/cs/ISO8859x.java \
|
sun/nio/cs/ISO8859x.java \
|
||||||
java/nio/Buffer \
|
java/nio/Buffer \
|
||||||
com/sun/crypto/provider/Cipher \
|
com/sun/crypto/provider/Cipher \
|
||||||
@ -41,9 +41,9 @@ tier1 = \
|
|||||||
tier2 = \
|
tier2 = \
|
||||||
java/lang/ProcessHandle/TreeTest.java \
|
java/lang/ProcessHandle/TreeTest.java \
|
||||||
java/util/zip/TestLocalTime.java \
|
java/util/zip/TestLocalTime.java \
|
||||||
java/util/concurrent/Phaser/Basic.java \
|
|
||||||
java/util/WeakHashMap/GCDuringIteration.java \
|
java/util/WeakHashMap/GCDuringIteration.java \
|
||||||
java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java \
|
java/util/concurrent/ThreadPoolExecutor/ConfigChanges.java \
|
||||||
|
java/util/concurrent/forkjoin/FJExceptionTableLeak.java
|
||||||
:jdk_io \
|
:jdk_io \
|
||||||
:jdk_nio \
|
:jdk_nio \
|
||||||
-sun/nio/cs/ISO8859x.java \
|
-sun/nio/cs/ISO8859x.java \
|
||||||
@ -77,7 +77,6 @@ jdk_lang = \
|
|||||||
sun/misc \
|
sun/misc \
|
||||||
sun/reflect \
|
sun/reflect \
|
||||||
jdk/lambda \
|
jdk/lambda \
|
||||||
jdk/internal/jimage \
|
|
||||||
vm
|
vm
|
||||||
|
|
||||||
# All of the java.util package
|
# All of the java.util package
|
||||||
|
@ -86,29 +86,43 @@ public class LocalsAndOperands {
|
|||||||
System.out.println("frame: " + f);
|
System.out.println("frame: " + f);
|
||||||
Object[] locals = (Object[]) getLocals.invoke(f);
|
Object[] locals = (Object[]) getLocals.invoke(f);
|
||||||
for (int i = 0; i < locals.length; i++) {
|
for (int i = 0; i < locals.length; i++) {
|
||||||
System.out.format("local %d: %s type %s%n", i, locals[i], type(locals[i]));
|
System.out.format(" local %d: %s type %s\n", i, locals[i], type(locals[i]));
|
||||||
|
|
||||||
|
// check for non-null locals in LocalsAndOperands.test()
|
||||||
|
if (f.getClassName().equals("LocalsAndOperands") &&
|
||||||
|
f.getMethodName().equals("test")) {
|
||||||
|
if (locals[i] == null) {
|
||||||
|
throw new RuntimeException("kept-alive locals should not be null");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Object[] operands = (Object[]) getOperands.invoke(f);
|
Object[] operands = (Object[]) getOperands.invoke(f);
|
||||||
for (int i = 0; i < operands.length; i++) {
|
for (int i = 0; i < operands.length; i++) {
|
||||||
System.out.format("operand %d: %s type %s%n", i, operands[i], type(operands[i]));
|
System.out.format(" operand %d: %s type %s%n", i, operands[i],
|
||||||
|
type(operands[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
Object[] monitors = (Object[]) getMonitors.invoke(f);
|
Object[] monitors = (Object[]) getMonitors.invoke(f);
|
||||||
for (int i = 0; i < monitors.length; i++) {
|
for (int i = 0; i < monitors.length; i++) {
|
||||||
System.out.format("monitor %d: %s%n", i, monitors[i]);
|
System.out.format(" monitor %d: %s%n", i, monitors[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (StackFrame f : frames) {
|
for (StackFrame f : frames) {
|
||||||
if (liveStackFrameClass.isInstance(f))
|
if (liveStackFrameClass.isInstance(f)) {
|
||||||
throw new RuntimeException("should not be LiveStackFrame");
|
throw new RuntimeException("should not be LiveStackFrame");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Use local variables so they stay alive
|
||||||
|
System.out.println("Stayin' alive: "+x+" "+c+" "+hi+" "+l+" "+d);
|
||||||
}
|
}
|
||||||
|
|
||||||
String type(Object o) throws Exception {
|
String type(Object o) throws Exception {
|
||||||
if (primitiveValueClass.isInstance(o)) {
|
if (o == null) {
|
||||||
|
return "null";
|
||||||
|
} else if (primitiveValueClass.isInstance(o)) {
|
||||||
char c = (char)primitiveType.invoke(o);
|
char c = (char)primitiveType.invoke(o);
|
||||||
return String.valueOf(c);
|
return String.valueOf(c);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2006, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, 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,23 +23,28 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package sun.misc;
|
/* @test
|
||||||
|
* @bug 8076596
|
||||||
import java.io.File;
|
* @run main/othervm/policy=Test8076596.security.policy/secure=Test8076596 -ea -esa Test8076596
|
||||||
import java.io.FilenameFilter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class checks that only jar and zip files are included in the file list.
|
|
||||||
* This class is used in extension installation support (ExtensionDependency).
|
|
||||||
*
|
|
||||||
* @deprecated this class will be removed in a future release.
|
|
||||||
* @author Michael Colburn
|
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
|
||||||
public class JarFilter implements FilenameFilter {
|
|
||||||
|
|
||||||
public boolean accept(File dir, String name) {
|
import java.security.AccessController;
|
||||||
String lower = name.toLowerCase();
|
import java.security.PrivilegedAction;
|
||||||
return lower.endsWith(".jar") || lower.endsWith(".zip");
|
|
||||||
|
public class Test8076596 extends SecurityManager {
|
||||||
|
public Test8076596() {
|
||||||
|
// 1. Using lambda
|
||||||
|
AccessController.doPrivileged((PrivilegedAction<Void>) () -> null);
|
||||||
|
// 2. Using inner class
|
||||||
|
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
||||||
|
@Override
|
||||||
|
public Void run() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
// empty
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -0,0 +1,8 @@
|
|||||||
|
/*
|
||||||
|
* Security policy used by the Test8076596.
|
||||||
|
* Must allow file reads so that jtreg itself can run.
|
||||||
|
*/
|
||||||
|
|
||||||
|
grant {
|
||||||
|
permission java.io.FilePermission "*", "read";
|
||||||
|
};
|
82
jdk/test/java/lang/invoke/8147078/Test8147078.java
Normal file
82
jdk/test/java/lang/invoke/8147078/Test8147078.java
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* @test
|
||||||
|
* @bug 8147078
|
||||||
|
* @run testng/othervm -ea -esa Test8147078
|
||||||
|
*/
|
||||||
|
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import java.lang.invoke.MethodHandle;
|
||||||
|
import java.lang.invoke.MethodHandles;
|
||||||
|
|
||||||
|
import static java.lang.invoke.MethodType.methodType;
|
||||||
|
|
||||||
|
import static org.testng.AssertJUnit.*;
|
||||||
|
|
||||||
|
public class Test8147078 {
|
||||||
|
|
||||||
|
static int target(int x) {
|
||||||
|
throw new RuntimeException("ieps");
|
||||||
|
}
|
||||||
|
|
||||||
|
static int handler(String s, int x) {
|
||||||
|
return 4*x;
|
||||||
|
}
|
||||||
|
|
||||||
|
static final MethodHandle MH_target;
|
||||||
|
static final MethodHandle MH_handler;
|
||||||
|
static final MethodHandle MH_catchException;
|
||||||
|
|
||||||
|
static final MethodHandles.Lookup LOOKUP = MethodHandles.lookup();
|
||||||
|
|
||||||
|
static {
|
||||||
|
try {
|
||||||
|
Class<Test8147078> C = Test8147078.class;
|
||||||
|
MH_target = LOOKUP.findStatic(C, "target", methodType(int.class, int.class));
|
||||||
|
MH_handler = LOOKUP.findStatic(C, "handler", methodType(int.class, String.class, int.class));
|
||||||
|
MH_catchException = LOOKUP.findStatic(MethodHandles.class, "catchException",
|
||||||
|
methodType(MethodHandle.class, MethodHandle.class, Class.class, MethodHandle.class));
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new ExceptionInInitializerError(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNoExceptionType() {
|
||||||
|
boolean caught = false;
|
||||||
|
try {
|
||||||
|
MethodHandle eek = (MethodHandle) MH_catchException.invoke(MH_target, String.class, MH_handler);
|
||||||
|
} catch (ClassCastException cce) {
|
||||||
|
assertEquals("java.lang.String", cce.getMessage());
|
||||||
|
caught = true;
|
||||||
|
} catch (Throwable t) {
|
||||||
|
fail("unexpected exception caught: " + t);
|
||||||
|
}
|
||||||
|
assertTrue(caught);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -24,6 +24,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* @test
|
/* @test
|
||||||
|
* @bug 8139885
|
||||||
* @run main/othervm/policy=findclass.security.policy/secure=java.lang.SecurityManager -ea -esa test.java.lang.invoke.FindClassSecurityManager
|
* @run main/othervm/policy=findclass.security.policy/secure=java.lang.SecurityManager -ea -esa test.java.lang.invoke.FindClassSecurityManager
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, 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
|
||||||
@ -24,6 +24,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* @test
|
/* @test
|
||||||
|
* @bug 8139885
|
||||||
|
* @bug 8143798
|
||||||
* @run testng/othervm -ea -esa test.java.lang.invoke.T8139885
|
* @run testng/othervm -ea -esa test.java.lang.invoke.T8139885
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, 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
|
||||||
@ -34,9 +34,10 @@ import java.util.concurrent.TimeUnit;
|
|||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
import jdk.internal.misc.CleanerImpl.PhantomCleanable;
|
import jdk.internal.ref.PhantomCleanable;
|
||||||
import jdk.internal.misc.CleanerImpl.WeakCleanable;
|
import jdk.internal.ref.WeakCleanable;
|
||||||
import jdk.internal.misc.CleanerImpl.SoftCleanable;
|
import jdk.internal.ref.SoftCleanable;
|
||||||
|
import jdk.internal.ref.CleanerFactory;
|
||||||
|
|
||||||
import sun.hotspot.WhiteBox;
|
import sun.hotspot.WhiteBox;
|
||||||
|
|
||||||
@ -48,17 +49,17 @@ import org.testng.annotations.Test;
|
|||||||
* @test
|
* @test
|
||||||
* @library /lib/testlibrary /test/lib
|
* @library /lib/testlibrary /test/lib
|
||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @modules java.base/jdk.internal.misc
|
* @modules java.base/jdk.internal.misc java.base/jdk.internal.ref
|
||||||
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
||||||
* @run testng/othervm
|
* @run testng/othervm
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbootclasspath/a:.
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xbootclasspath/a:.
|
||||||
* -verbose:gc -Xmx4m CleanerTest
|
* -verbose:gc CleanerTest
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public class CleanerTest {
|
public class CleanerTest {
|
||||||
// A common CleaningService used by the test for notifications
|
// A common CleaningService used by the test for notifications
|
||||||
static final Cleaner COMMON = Cleaner.create();
|
static final Cleaner COMMON = CleanerFactory.cleaner();
|
||||||
|
|
||||||
// Access to WhiteBox utilities
|
// Access to WhiteBox utilities
|
||||||
static final WhiteBox whitebox = WhiteBox.getWhiteBox();
|
static final WhiteBox whitebox = WhiteBox.getWhiteBox();
|
||||||
@ -702,4 +703,17 @@ public class CleanerTest {
|
|||||||
cleaner = null;
|
cleaner = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test the Cleaner from the CleanerFactory.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
void testCleanerFactory() {
|
||||||
|
Cleaner cleaner = CleanerFactory.cleaner();
|
||||||
|
|
||||||
|
Object obj = new Object();
|
||||||
|
CleanableCase s = setupPhantom(cleaner, obj);
|
||||||
|
obj = null;
|
||||||
|
Assert.assertTrue(checkCleaned(s.getSemaphore()),
|
||||||
|
"Object cleaning should have occurred using CleanerFactor.cleaner()");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1999, 2016, 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
|
||||||
@ -41,7 +41,11 @@ public class ADatagramSocket {
|
|||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
throw new RuntimeException("Setting DatagramSocketImplFactory failed!");
|
throw new RuntimeException("Setting DatagramSocketImplFactory failed!");
|
||||||
}
|
}
|
||||||
new QuoteServerThread().start();
|
|
||||||
|
QuoteServerThread server = new QuoteServerThread();
|
||||||
|
int port = server.getPort();
|
||||||
|
System.out.println("Server port is " + port);
|
||||||
|
server.start();
|
||||||
|
|
||||||
// get a datagram socket
|
// get a datagram socket
|
||||||
DatagramSocket socket = new DatagramSocket();
|
DatagramSocket socket = new DatagramSocket();
|
||||||
@ -49,7 +53,7 @@ public class ADatagramSocket {
|
|||||||
// send request
|
// send request
|
||||||
byte[] buf = new byte[256];
|
byte[] buf = new byte[256];
|
||||||
InetAddress address = InetAddress.getLocalHost();
|
InetAddress address = InetAddress.getLocalHost();
|
||||||
DatagramPacket packet = new DatagramPacket(buf, buf.length, address, 4445);
|
DatagramPacket packet = new DatagramPacket(buf, buf.length, address, port);
|
||||||
socket.send(packet);
|
socket.send(packet);
|
||||||
|
|
||||||
// get response
|
// get response
|
||||||
@ -67,6 +71,7 @@ public class ADatagramSocket {
|
|||||||
class QuoteServerThread extends Thread {
|
class QuoteServerThread extends Thread {
|
||||||
|
|
||||||
protected DatagramSocket socket = null;
|
protected DatagramSocket socket = null;
|
||||||
|
private final int port;
|
||||||
|
|
||||||
public QuoteServerThread() throws IOException {
|
public QuoteServerThread() throws IOException {
|
||||||
this("QuoteServerThread");
|
this("QuoteServerThread");
|
||||||
@ -74,7 +79,11 @@ class QuoteServerThread extends Thread {
|
|||||||
|
|
||||||
public QuoteServerThread(String name) throws IOException {
|
public QuoteServerThread(String name) throws IOException {
|
||||||
super(name);
|
super(name);
|
||||||
socket = new DatagramSocket(4445);
|
socket = new DatagramSocket(0);
|
||||||
|
port = socket.getLocalPort();
|
||||||
|
}
|
||||||
|
public int getPort(){
|
||||||
|
return port;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void run() {
|
public void run() {
|
||||||
@ -101,3 +110,4 @@ class QuoteServerThread extends Thread {
|
|||||||
socket.close();
|
socket.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
141
jdk/test/java/net/SocketOption/UnsupportedOptionsTest.java
Normal file
141
jdk/test/java/net/SocketOption/UnsupportedOptionsTest.java
Normal file
@ -0,0 +1,141 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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 jdk.net.ExtendedSocketOptions;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.*;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8143554
|
||||||
|
* @run main UnsupportedOptionsTest
|
||||||
|
* @summary Test checks that UnsupportedOperationException for unsupported
|
||||||
|
* SOCKET_OPTIONS is thrown by both getOption() and setOption() methods.
|
||||||
|
*/
|
||||||
|
public class UnsupportedOptionsTest {
|
||||||
|
|
||||||
|
private static final SocketOption[] SOCKET_OPTIONS = {
|
||||||
|
StandardSocketOptions.IP_MULTICAST_IF,
|
||||||
|
StandardSocketOptions.IP_MULTICAST_LOOP,
|
||||||
|
StandardSocketOptions.IP_MULTICAST_TTL,
|
||||||
|
StandardSocketOptions.IP_TOS,
|
||||||
|
StandardSocketOptions.SO_BROADCAST,
|
||||||
|
StandardSocketOptions.SO_KEEPALIVE,
|
||||||
|
StandardSocketOptions.SO_LINGER,
|
||||||
|
StandardSocketOptions.SO_RCVBUF,
|
||||||
|
StandardSocketOptions.SO_REUSEADDR,
|
||||||
|
StandardSocketOptions.SO_SNDBUF,
|
||||||
|
StandardSocketOptions.TCP_NODELAY,
|
||||||
|
ExtendedSocketOptions.SO_FLOW_SLA
|
||||||
|
};
|
||||||
|
|
||||||
|
public static void main(String[] args) throws IOException {
|
||||||
|
Socket s = new Socket();
|
||||||
|
ServerSocket ss = new ServerSocket();
|
||||||
|
DatagramSocket ds = new DatagramSocket();
|
||||||
|
MulticastSocket ms = new MulticastSocket();
|
||||||
|
|
||||||
|
for (SocketOption option : SOCKET_OPTIONS) {
|
||||||
|
if (!s.supportedOptions().contains(option)) {
|
||||||
|
testUnsupportedSocketOption(s, option);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ss.supportedOptions().contains(option)) {
|
||||||
|
testUnsupportedSocketOption(ss, option);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ms.supportedOptions().contains(option)) {
|
||||||
|
testUnsupportedSocketOption(ms, option);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ds.supportedOptions().contains(option)) {
|
||||||
|
testUnsupportedSocketOption(ds, option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check that UnsupportedOperationException for unsupported option is
|
||||||
|
* thrown from both getOption() and setOption() methods.
|
||||||
|
*/
|
||||||
|
private static void testUnsupportedSocketOption(Object socket,
|
||||||
|
SocketOption option) {
|
||||||
|
testSet(socket, option);
|
||||||
|
testGet(socket, option);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void testSet(Object socket, SocketOption option) {
|
||||||
|
try {
|
||||||
|
setOption(socket, option);
|
||||||
|
} catch (UnsupportedOperationException e) {
|
||||||
|
System.out.println("UnsupportedOperationException was throw " +
|
||||||
|
"as expected. Socket: " + socket + " Option: " + option);
|
||||||
|
return;
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException("FAIL. Unexpected exception.", e);
|
||||||
|
}
|
||||||
|
throw new RuntimeException("FAIL. UnsupportedOperationException " +
|
||||||
|
"hasn't been thrown. Socket: " + socket + " Option: " + option);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void testGet(Object socket, SocketOption option) {
|
||||||
|
try {
|
||||||
|
getOption(socket, option);
|
||||||
|
} catch (UnsupportedOperationException e) {
|
||||||
|
System.out.println("UnsupportedOperationException was throw " +
|
||||||
|
"as expected. Socket: " + socket + " Option: " + option);
|
||||||
|
return;
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException("FAIL. Unexpected exception.", e);
|
||||||
|
}
|
||||||
|
throw new RuntimeException("FAIL. UnsupportedOperationException " +
|
||||||
|
"hasn't been thrown. Socket: " + socket + " Option: " + option);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void getOption(Object socket,
|
||||||
|
SocketOption option) throws IOException {
|
||||||
|
if (socket instanceof Socket) {
|
||||||
|
((Socket) socket).getOption(option);
|
||||||
|
} else if (socket instanceof ServerSocket) {
|
||||||
|
((ServerSocket) socket).getOption(option);
|
||||||
|
} else if (socket instanceof DatagramSocket) {
|
||||||
|
((DatagramSocket) socket).getOption(option);
|
||||||
|
} else {
|
||||||
|
throw new RuntimeException("Unsupported socket type");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void setOption(Object socket,
|
||||||
|
SocketOption option) throws IOException {
|
||||||
|
if (socket instanceof Socket) {
|
||||||
|
((Socket) socket).setOption(option, null);
|
||||||
|
} else if (socket instanceof ServerSocket) {
|
||||||
|
((ServerSocket) socket).setOption(option, null);
|
||||||
|
} else if (socket instanceof DatagramSocket) {
|
||||||
|
((DatagramSocket) socket).setOption(option, null);
|
||||||
|
} else {
|
||||||
|
throw new RuntimeException("Unsupported socket type");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2016, 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,6 +22,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* @test
|
/* @test
|
||||||
|
* @bug 4286936 8143100
|
||||||
* @summary Unit test for server-socket channels
|
* @summary Unit test for server-socket channels
|
||||||
* @library ..
|
* @library ..
|
||||||
*/
|
*/
|
||||||
@ -130,7 +131,7 @@ public class Basic {
|
|||||||
Client client = new Client(port, block);
|
Client client = new Client(port, block);
|
||||||
server.start();
|
server.start();
|
||||||
client.start();
|
client.start();
|
||||||
if ((server.finish(2000) & client.finish(100)) == 0)
|
if ((server.finish(0) & client.finish(0)) == 0)
|
||||||
throw new Exception("Failure");
|
throw new Exception("Failure");
|
||||||
log.println();
|
log.println();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2016, 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,7 +22,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* @test
|
/* @test
|
||||||
* @bug 4801882 5046333
|
* @bug 4801882 5046333 8141595
|
||||||
* @summary test ServerSocketAdaptor.accept on nonblocking channel
|
* @summary test ServerSocketAdaptor.accept on nonblocking channel
|
||||||
* @library ..
|
* @library ..
|
||||||
* @build TestUtil
|
* @build TestUtil
|
||||||
@ -57,8 +57,17 @@ public class NonBlockingAccept {
|
|||||||
SocketChannel sc = SocketChannel.open();
|
SocketChannel sc = SocketChannel.open();
|
||||||
sc.configureBlocking(false);
|
sc.configureBlocking(false);
|
||||||
sc.connect(isa);
|
sc.connect(isa);
|
||||||
Thread.sleep(100);
|
|
||||||
ss.accept();
|
// loop until accepted
|
||||||
|
while (true) {
|
||||||
|
try {
|
||||||
|
ss.accept();
|
||||||
|
break;
|
||||||
|
} catch (IllegalBlockingModeException ex) {
|
||||||
|
System.out.println(ex + ", sleeping ...");
|
||||||
|
Thread.sleep(100);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2016, 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
|
||||||
@ -1285,13 +1285,37 @@ public class TCKLocalDate extends AbstractDateTimeTest {
|
|||||||
public void test_plusWeeks_invalidMaxMinusMin() {
|
public void test_plusWeeks_invalidMaxMinusMin() {
|
||||||
LocalDate.of(Year.MAX_VALUE, 12, 25).plusWeeks(Long.MIN_VALUE);
|
LocalDate.of(Year.MAX_VALUE, 12, 25).plusWeeks(Long.MIN_VALUE);
|
||||||
}
|
}
|
||||||
|
//-----------------------------------------------------------------------
|
||||||
@Test
|
@DataProvider(name="PlusDays")
|
||||||
public void test_plusDays_normal() {
|
Object[][] provider_plusDays() {
|
||||||
LocalDate t = TEST_2007_07_15.plusDays(1);
|
return new Object[][] {
|
||||||
assertEquals(t, LocalDate.of(2007, 7, 16));
|
{LocalDate.of(2007, 7, 15), 1, LocalDate.of(2007, 7, 16)},
|
||||||
|
{LocalDate.of(2007, 7, 15), 17, LocalDate.of(2007, 8, 1)},
|
||||||
|
{LocalDate.of(2007, 12, 31), 1, LocalDate.of(2008, 1, 1)},
|
||||||
|
{LocalDate.of(2007, 1, 1), 58, LocalDate.of(2007, 2, 28)},
|
||||||
|
{LocalDate.of(2007, 1, 1), 59, LocalDate.of(2007, 3, 1)},
|
||||||
|
{LocalDate.of(2008, 1, 1), 60, LocalDate.of(2008, 3, 1)},
|
||||||
|
{LocalDate.of(2007, 2, 1), 27, LocalDate.of(2007, 2, 28)},
|
||||||
|
{LocalDate.of(2007, 2, 1), 28, LocalDate.of(2007, 3, 1)},
|
||||||
|
{LocalDate.of(2007, 1, 1), 29, LocalDate.of(2007, 1, 30)},
|
||||||
|
{LocalDate.of(2007, 1, 1), 30, LocalDate.of(2007, 1, 31)},
|
||||||
|
{LocalDate.of(2007, 1, 15), 13, LocalDate.of(2007, 1, 28)},
|
||||||
|
{LocalDate.of(2007, 1, 15), 14, LocalDate.of(2007, 1, 29)},
|
||||||
|
{LocalDate.of(2007, 1, 15), 15, LocalDate.of(2007, 1, 30)},
|
||||||
|
{LocalDate.of(2007, 1, 15), 16, LocalDate.of(2007, 1, 31)},
|
||||||
|
{LocalDate.of(2007, 2, 15), 13, LocalDate.of(2007, 2, 28)},
|
||||||
|
{LocalDate.of(2007, 2, 15), 14, LocalDate.of(2007, 3, 1)},
|
||||||
|
{LocalDate.of(2007, 2, 15), 15, LocalDate.of(2007, 3, 2)},
|
||||||
|
{LocalDate.of(2007, 2, 15), 16, LocalDate.of(2007, 3, 3)},
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(dataProvider="PlusDays")
|
||||||
|
public void test_plusDays_normal(LocalDate input, int amountsToAdd, LocalDate expected) {
|
||||||
|
LocalDate actual = input.plusDays(amountsToAdd);
|
||||||
|
assertEquals(actual, expected);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test_plusDays_overMonths() {
|
public void test_plusDays_overMonths() {
|
||||||
LocalDate t = TEST_2007_07_15.plusDays(62);
|
LocalDate t = TEST_2007_07_15.plusDays(62);
|
||||||
|
@ -1,12 +1,10 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 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,14 +21,25 @@
|
|||||||
* questions.
|
* questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package sun.misc;
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8026766
|
||||||
|
* @summary Confirm that LanguageRange.toString() returns an expected result.
|
||||||
|
* @run main Bug8026766
|
||||||
|
*/
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.util.Locale.LanguageRange;
|
||||||
|
|
||||||
public class CEFormatException extends IOException {
|
public class Bug8026766 {
|
||||||
static final long serialVersionUID = -7139121221067081482L;
|
|
||||||
public CEFormatException(String s) {
|
public static void main(String[] args) {
|
||||||
super(s);
|
LanguageRange lr1 = new LanguageRange("ja", 1.0);
|
||||||
|
LanguageRange lr2 = new LanguageRange("fr", 0.0);
|
||||||
|
|
||||||
|
if (!lr1.toString().equals("ja") ||
|
||||||
|
!lr2.toString().equals("fr;q=0.0")) {
|
||||||
|
throw new RuntimeException("LanguageRange.toString() returned an unexpected result.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
}
|
@ -37,6 +37,7 @@
|
|||||||
* @bug 8004138
|
* @bug 8004138
|
||||||
* @summary Check if ForkJoinPool table leaks thrown exceptions.
|
* @summary Check if ForkJoinPool table leaks thrown exceptions.
|
||||||
* @run main/othervm -Xmx2200k FJExceptionTableLeak
|
* @run main/othervm -Xmx2200k FJExceptionTableLeak
|
||||||
|
* @key intermittent
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.util.concurrent.ForkJoinPool;
|
import java.util.concurrent.ForkJoinPool;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, 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
|
||||||
@ -209,8 +209,9 @@ public class UpdateConfigurationTest {
|
|||||||
+ barChild.getParent() +"\n\texpected: " + barRef.get());
|
+ barChild.getParent() +"\n\texpected: " + barRef.get());
|
||||||
}
|
}
|
||||||
Reference<? extends Logger> ref2;
|
Reference<? extends Logger> ref2;
|
||||||
int max = 3;
|
int max = 10;
|
||||||
barChild = null;
|
barChild = null;
|
||||||
|
System.gc();
|
||||||
while ((ref2 = queue.poll()) == null) {
|
while ((ref2 = queue.poll()) == null) {
|
||||||
System.gc();
|
System.gc();
|
||||||
Thread.sleep(100);
|
Thread.sleep(100);
|
||||||
@ -276,24 +277,27 @@ public class UpdateConfigurationTest {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Now we need to forget the child, so that loggers are released,
|
if (suppressed == null) {
|
||||||
// and so that we can run the test with the next configuration...
|
// Now we need to forget the child, so that loggers are released,
|
||||||
|
// and so that we can run the test with the next configuration...
|
||||||
fooChild = null;
|
// No need to do that if failed!=null however, as the first
|
||||||
System.out.println("Setting fooChild to: " + fooChild);
|
// ref might not have been cleared yet and failing here would
|
||||||
while ((ref2 = queue.poll()) == null) {
|
// hide the original failure.
|
||||||
System.gc();
|
fooChild = null;
|
||||||
Thread.sleep(1000);
|
System.out.println("Setting fooChild to: " + fooChild);
|
||||||
|
while ((ref2 = queue.poll()) == null) {
|
||||||
|
System.gc();
|
||||||
|
Thread.sleep(1000);
|
||||||
|
}
|
||||||
|
if (ref2 != fooRef) {
|
||||||
|
throw new RuntimeException("Unexpected reference: "
|
||||||
|
+ ref2 +"\n\texpected: " + fooRef);
|
||||||
|
}
|
||||||
|
if (ref2.get() != null) {
|
||||||
|
throw new RuntimeException("Referent not cleared: " + ref2.get());
|
||||||
|
}
|
||||||
|
System.out.println("Got fooRef after reset(), fooChild is " + fooChild);
|
||||||
}
|
}
|
||||||
if (ref2 != fooRef) {
|
|
||||||
throw new RuntimeException("Unexpected reference: "
|
|
||||||
+ ref2 +"\n\texpected: " + fooRef);
|
|
||||||
}
|
|
||||||
if (ref2.get() != null) {
|
|
||||||
throw new RuntimeException("Referent not cleared: " + ref2.get());
|
|
||||||
}
|
|
||||||
System.out.println("Got fooRef after reset(), fooChild is " + fooChild);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (failed != null) {
|
if (failed != null) {
|
||||||
|
130
jdk/test/javax/net/ssl/ALPN/MyX509ExtendedKeyManager.java
Normal file
130
jdk/test/javax/net/ssl/ALPN/MyX509ExtendedKeyManager.java
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.net.Socket;
|
||||||
|
import java.security.Principal;
|
||||||
|
import java.security.PrivateKey;
|
||||||
|
import java.security.cert.X509Certificate;
|
||||||
|
import javax.net.ssl.SSLEngine;
|
||||||
|
import javax.net.ssl.SSLSocket;
|
||||||
|
import javax.net.ssl.X509ExtendedKeyManager;
|
||||||
|
|
||||||
|
public class MyX509ExtendedKeyManager extends X509ExtendedKeyManager {
|
||||||
|
|
||||||
|
static final String ERROR = "ERROR";
|
||||||
|
X509ExtendedKeyManager akm;
|
||||||
|
String expectedAP;
|
||||||
|
|
||||||
|
MyX509ExtendedKeyManager(X509ExtendedKeyManager akm) {
|
||||||
|
this.akm = akm;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MyX509ExtendedKeyManager(
|
||||||
|
X509ExtendedKeyManager akm, String expectedAP) {
|
||||||
|
this.akm = akm;
|
||||||
|
this.expectedAP = expectedAP;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String[] getClientAliases(String keyType, Principal[] issuers) {
|
||||||
|
return akm.getClientAliases(keyType, issuers);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String chooseClientAlias(String[] keyType, Principal[] issuers,
|
||||||
|
Socket socket) {
|
||||||
|
String nap = ((SSLSocket) socket).getHandshakeApplicationProtocol();
|
||||||
|
checkALPN(nap);
|
||||||
|
|
||||||
|
return akm.chooseClientAlias(keyType, issuers, socket);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String[] getServerAliases(String keyType, Principal[] issuers) {
|
||||||
|
return akm.getServerAliases(keyType, issuers);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String chooseServerAlias(String keyType, Principal[] issuers,
|
||||||
|
Socket socket) {
|
||||||
|
String nap = ((SSLSocket) socket).getHandshakeApplicationProtocol();
|
||||||
|
checkALPN(nap);
|
||||||
|
|
||||||
|
return akm.chooseServerAlias(keyType, issuers, socket);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public X509Certificate[] getCertificateChain(String alias) {
|
||||||
|
return akm.getCertificateChain(alias);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PrivateKey getPrivateKey(String alias) {
|
||||||
|
return akm.getPrivateKey(alias);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String chooseEngineClientAlias(String[] keyType, Principal[] issuers,
|
||||||
|
SSLEngine engine) {
|
||||||
|
String nap = engine.getHandshakeApplicationProtocol();
|
||||||
|
checkALPN(nap);
|
||||||
|
|
||||||
|
return akm.chooseEngineClientAlias(keyType, issuers, engine);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String chooseEngineServerAlias(String keyType, Principal[] issuers,
|
||||||
|
SSLEngine engine) {
|
||||||
|
String nap = engine.getHandshakeApplicationProtocol();
|
||||||
|
checkALPN(nap);
|
||||||
|
|
||||||
|
return akm.chooseEngineServerAlias(keyType, issuers, engine);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkALPN(String ap) {
|
||||||
|
|
||||||
|
if (ERROR.equals(expectedAP)) {
|
||||||
|
throw new RuntimeException("Should not reach here");
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("Expected ALPN value: " + expectedAP
|
||||||
|
+ " Got: " + ap);
|
||||||
|
|
||||||
|
if (ap == null) {
|
||||||
|
throw new RuntimeException(
|
||||||
|
"ALPN should be negotiated, but null was received");
|
||||||
|
}
|
||||||
|
if (expectedAP.equals("NONE")) {
|
||||||
|
if (!ap.isEmpty()) {
|
||||||
|
throw new RuntimeException("Expected no ALPN value");
|
||||||
|
} else {
|
||||||
|
System.out.println("No ALPN value negotiated, as expected");
|
||||||
|
}
|
||||||
|
} else if (!expectedAP.equals(ap)) {
|
||||||
|
throw new RuntimeException(expectedAP
|
||||||
|
+ " ALPN value not available on negotiated connection");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2016, 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 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8051498
|
* @bug 8051498 8145849
|
||||||
* @summary JEP 244: TLS Application-Layer Protocol Negotiation Extension
|
* @summary JEP 244: TLS Application-Layer Protocol Negotiation Extension
|
||||||
|
* @compile MyX509ExtendedKeyManager.java
|
||||||
* @run main/othervm SSLEngineAlpnTest h2 h2 h2
|
* @run main/othervm SSLEngineAlpnTest h2 h2 h2
|
||||||
* @run main/othervm SSLEngineAlpnTest h2 h2,http/1.1 h2
|
* @run main/othervm SSLEngineAlpnTest h2 h2,http/1.1 h2
|
||||||
* @run main/othervm SSLEngineAlpnTest h2,http/1.1 h2,http/1.1 h2
|
* @run main/othervm SSLEngineAlpnTest h2,http/1.1 h2,http/1.1 h2
|
||||||
@ -162,7 +163,7 @@ public class SSLEngineAlpnTest {
|
|||||||
throw new Exception("Invalid number of test parameters");
|
throw new Exception("Invalid number of test parameters");
|
||||||
}
|
}
|
||||||
|
|
||||||
SSLEngineAlpnTest test = new SSLEngineAlpnTest();
|
SSLEngineAlpnTest test = new SSLEngineAlpnTest(args[2]);
|
||||||
try {
|
try {
|
||||||
test.runTest(convert(args[0]), convert(args[1]), args[2]);
|
test.runTest(convert(args[0]), convert(args[1]), args[2]);
|
||||||
} catch (SSLHandshakeException she) {
|
} catch (SSLHandshakeException she) {
|
||||||
@ -179,7 +180,7 @@ public class SSLEngineAlpnTest {
|
|||||||
/*
|
/*
|
||||||
* Create an initialized SSLContext to use for these tests.
|
* Create an initialized SSLContext to use for these tests.
|
||||||
*/
|
*/
|
||||||
public SSLEngineAlpnTest() throws Exception {
|
public SSLEngineAlpnTest(String expectedAP) throws Exception {
|
||||||
|
|
||||||
KeyStore ks = KeyStore.getInstance("JKS");
|
KeyStore ks = KeyStore.getInstance("JKS");
|
||||||
KeyStore ts = KeyStore.getInstance("JKS");
|
KeyStore ts = KeyStore.getInstance("JKS");
|
||||||
@ -192,12 +193,20 @@ public class SSLEngineAlpnTest {
|
|||||||
KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
|
KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
|
||||||
kmf.init(ks, passphrase);
|
kmf.init(ks, passphrase);
|
||||||
|
|
||||||
|
KeyManager [] kms = kmf.getKeyManagers();
|
||||||
|
if (!(kms[0] instanceof X509ExtendedKeyManager)) {
|
||||||
|
throw new Exception("kms[0] not X509ExtendedKeyManager");
|
||||||
|
}
|
||||||
|
|
||||||
|
kms = new KeyManager[] { new MyX509ExtendedKeyManager(
|
||||||
|
(X509ExtendedKeyManager) kms[0], expectedAP) };
|
||||||
|
|
||||||
TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
|
TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
|
||||||
tmf.init(ts);
|
tmf.init(ts);
|
||||||
|
|
||||||
SSLContext sslCtx = SSLContext.getInstance("TLS");
|
SSLContext sslCtx = SSLContext.getInstance("TLS");
|
||||||
|
|
||||||
sslCtx.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
|
sslCtx.init(kms, tmf.getTrustManagers(), null);
|
||||||
|
|
||||||
sslc = sslCtx;
|
sslc = sslCtx;
|
||||||
}
|
}
|
||||||
@ -327,6 +336,11 @@ public class SSLEngineAlpnTest {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (engine.getHandshakeApplicationProtocol() != null) {
|
||||||
|
throw new Exception ("getHandshakeApplicationProtocol() should "
|
||||||
|
+ "return null after the handshake is completed");
|
||||||
|
}
|
||||||
|
|
||||||
String ap = engine.getApplicationProtocol();
|
String ap = engine.getApplicationProtocol();
|
||||||
System.out.println("Application Protocol: \"" + ap + "\"");
|
System.out.println("Application Protocol: \"" + ap + "\"");
|
||||||
|
|
||||||
@ -384,6 +398,12 @@ public class SSLEngineAlpnTest {
|
|||||||
sslp = clientEngine.getSSLParameters();
|
sslp = clientEngine.getSSLParameters();
|
||||||
sslp.setApplicationProtocols(clientAPs);
|
sslp.setApplicationProtocols(clientAPs);
|
||||||
clientEngine.setSSLParameters(sslp);
|
clientEngine.setSSLParameters(sslp);
|
||||||
|
|
||||||
|
if ((clientEngine.getHandshakeApplicationProtocol() != null) ||
|
||||||
|
(serverEngine.getHandshakeApplicationProtocol() != null)) {
|
||||||
|
throw new Exception ("getHandshakeApplicationProtocol() should "
|
||||||
|
+ "return null before the handshake starts");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2016, 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 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8051498
|
* @bug 8051498 8145849
|
||||||
* @summary JEP 244: TLS Application-Layer Protocol Negotiation Extension
|
* @summary JEP 244: TLS Application-Layer Protocol Negotiation Extension
|
||||||
|
* @compile MyX509ExtendedKeyManager.java
|
||||||
* @run main/othervm SSLSocketAlpnTest h2 h2 h2
|
* @run main/othervm SSLSocketAlpnTest h2 h2 h2
|
||||||
* @run main/othervm SSLSocketAlpnTest h2 h2,http/1.1 h2
|
* @run main/othervm SSLSocketAlpnTest h2 h2,http/1.1 h2
|
||||||
* @run main/othervm SSLSocketAlpnTest h2,http/1.1 h2,http/1.1 h2
|
* @run main/othervm SSLSocketAlpnTest h2,http/1.1 h2,http/1.1 h2
|
||||||
@ -40,6 +41,8 @@
|
|||||||
* @author Brad Wetmore
|
* @author Brad Wetmore
|
||||||
*/
|
*/
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
|
import java.security.KeyStore;
|
||||||
|
|
||||||
import javax.net.ssl.*;
|
import javax.net.ssl.*;
|
||||||
|
|
||||||
public class SSLSocketAlpnTest {
|
public class SSLSocketAlpnTest {
|
||||||
@ -65,6 +68,16 @@ public class SSLSocketAlpnTest {
|
|||||||
static String trustStoreFile = "truststore";
|
static String trustStoreFile = "truststore";
|
||||||
static String passwd = "passphrase";
|
static String passwd = "passphrase";
|
||||||
|
|
||||||
|
static String keyFilename = System.getProperty("test.src", ".") + "/"
|
||||||
|
+ pathToStores + "/" + keyStoreFile;
|
||||||
|
static String trustFilename = System.getProperty("test.src", ".") + "/"
|
||||||
|
+ pathToStores + "/" + trustStoreFile;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SSLContext
|
||||||
|
*/
|
||||||
|
SSLContext mySSLContext = null;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Is the server ready to serve?
|
* Is the server ready to serve?
|
||||||
*/
|
*/
|
||||||
@ -82,7 +95,7 @@ public class SSLSocketAlpnTest {
|
|||||||
/*
|
/*
|
||||||
* If the client or server is doing some kind of object creation
|
* If the client or server is doing some kind of object creation
|
||||||
* that the other side depends on, and that thread prematurely
|
* that the other side depends on, and that thread prematurely
|
||||||
* exits, you may experience a hang. The test harness will
|
* exits, you may experience a hang. The test harness will
|
||||||
* terminate all hung threads after its timeout has expired,
|
* terminate all hung threads after its timeout has expired,
|
||||||
* currently 3 minutes by default, but you might try to be
|
* currently 3 minutes by default, but you might try to be
|
||||||
* smart about it....
|
* smart about it....
|
||||||
@ -95,10 +108,11 @@ public class SSLSocketAlpnTest {
|
|||||||
* to avoid infinite hangs.
|
* to avoid infinite hangs.
|
||||||
*/
|
*/
|
||||||
void doServerSide() throws Exception {
|
void doServerSide() throws Exception {
|
||||||
SSLServerSocketFactory sslssf
|
SSLServerSocketFactory sslssf = mySSLContext.getServerSocketFactory();
|
||||||
= (SSLServerSocketFactory) SSLServerSocketFactory.getDefault();
|
|
||||||
SSLServerSocket sslServerSocket
|
SSLServerSocket sslServerSocket
|
||||||
= (SSLServerSocket) sslssf.createServerSocket(serverPort);
|
= (SSLServerSocket) sslssf.createServerSocket(serverPort);
|
||||||
|
// for both client/server to call into X509KM
|
||||||
|
sslServerSocket.setNeedClientAuth(true);
|
||||||
|
|
||||||
serverPort = sslServerSocket.getLocalPort();
|
serverPort = sslServerSocket.getLocalPort();
|
||||||
|
|
||||||
@ -119,20 +133,30 @@ public class SSLSocketAlpnTest {
|
|||||||
*/
|
*/
|
||||||
String[] suites = sslp.getCipherSuites();
|
String[] suites = sslp.getCipherSuites();
|
||||||
sslp.setCipherSuites(suites);
|
sslp.setCipherSuites(suites);
|
||||||
sslp.setUseCipherSuitesOrder(true); // Set server side order
|
sslp.setUseCipherSuitesOrder(true); // Set server side order
|
||||||
|
|
||||||
// Set the ALPN selection.
|
// Set the ALPN selection.
|
||||||
sslp.setApplicationProtocols(serverAPs);
|
sslp.setApplicationProtocols(serverAPs);
|
||||||
sslSocket.setSSLParameters(sslp);
|
sslSocket.setSSLParameters(sslp);
|
||||||
|
|
||||||
|
if (sslSocket.getHandshakeApplicationProtocol() != null) {
|
||||||
|
throw new Exception ("getHandshakeApplicationProtocol() should "
|
||||||
|
+ "return null before the handshake starts");
|
||||||
|
}
|
||||||
|
|
||||||
sslSocket.startHandshake();
|
sslSocket.startHandshake();
|
||||||
|
|
||||||
|
if (sslSocket.getHandshakeApplicationProtocol() != null) {
|
||||||
|
throw new Exception ("getHandshakeApplicationProtocol() should "
|
||||||
|
+ "return null after the handshake is completed");
|
||||||
|
}
|
||||||
|
|
||||||
String ap = sslSocket.getApplicationProtocol();
|
String ap = sslSocket.getApplicationProtocol();
|
||||||
System.out.println("Application Protocol: \"" + ap + "\"");
|
System.out.println("Application Protocol: \"" + ap + "\"");
|
||||||
|
|
||||||
if (ap == null) {
|
if (ap == null) {
|
||||||
throw new Exception(
|
throw new Exception(
|
||||||
"Handshake was completed but null was received");
|
"Handshake was completed but null was received");
|
||||||
}
|
}
|
||||||
if (expectedAP.equals("NONE")) {
|
if (expectedAP.equals("NONE")) {
|
||||||
if (!ap.isEmpty()) {
|
if (!ap.isEmpty()) {
|
||||||
@ -141,8 +165,8 @@ public class SSLSocketAlpnTest {
|
|||||||
System.out.println("No ALPN value negotiated, as expected");
|
System.out.println("No ALPN value negotiated, as expected");
|
||||||
}
|
}
|
||||||
} else if (!expectedAP.equals(ap)) {
|
} else if (!expectedAP.equals(ap)) {
|
||||||
throw new Exception(expectedAP +
|
throw new Exception(expectedAP
|
||||||
" ALPN value not available on negotiated connection");
|
+ " ALPN value not available on negotiated connection");
|
||||||
}
|
}
|
||||||
|
|
||||||
InputStream sslIS = sslSocket.getInputStream();
|
InputStream sslIS = sslSocket.getInputStream();
|
||||||
@ -170,8 +194,7 @@ public class SSLSocketAlpnTest {
|
|||||||
Thread.sleep(50);
|
Thread.sleep(50);
|
||||||
}
|
}
|
||||||
|
|
||||||
SSLSocketFactory sslsf
|
SSLSocketFactory sslsf = mySSLContext.getSocketFactory();
|
||||||
= (SSLSocketFactory) SSLSocketFactory.getDefault();
|
|
||||||
SSLSocket sslSocket
|
SSLSocket sslSocket
|
||||||
= (SSLSocket) sslsf.createSocket("localhost", serverPort);
|
= (SSLSocket) sslsf.createSocket("localhost", serverPort);
|
||||||
|
|
||||||
@ -185,28 +208,35 @@ public class SSLSocketAlpnTest {
|
|||||||
*/
|
*/
|
||||||
String[] suites = sslp.getCipherSuites();
|
String[] suites = sslp.getCipherSuites();
|
||||||
sslp.setCipherSuites(suites);
|
sslp.setCipherSuites(suites);
|
||||||
sslp.setUseCipherSuitesOrder(true); // Set server side order
|
sslp.setUseCipherSuitesOrder(true); // Set server side order
|
||||||
|
|
||||||
// Set the ALPN selection.
|
// Set the ALPN selection.
|
||||||
sslp.setApplicationProtocols(clientAPs);
|
sslp.setApplicationProtocols(clientAPs);
|
||||||
sslSocket.setSSLParameters(sslp);
|
sslSocket.setSSLParameters(sslp);
|
||||||
|
|
||||||
|
if (sslSocket.getHandshakeApplicationProtocol() != null) {
|
||||||
|
throw new Exception ("getHandshakeApplicationProtocol() should "
|
||||||
|
+ "return null before the handshake starts");
|
||||||
|
}
|
||||||
|
|
||||||
sslSocket.startHandshake();
|
sslSocket.startHandshake();
|
||||||
|
|
||||||
|
if (sslSocket.getHandshakeApplicationProtocol() != null) {
|
||||||
|
throw new Exception ("getHandshakeApplicationProtocol() should "
|
||||||
|
+ "return null after the handshake is completed");
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check that the resulting connection meets our defined ALPN
|
* Check that the resulting connection meets our defined ALPN
|
||||||
* criteria. If we were connecting to a non-JSSE implementation,
|
* criteria. If we were connecting to a non-JSSE implementation,
|
||||||
* the server might have negotiated something we shouldn't accept.
|
* the server might have negotiated something we shouldn't accept.
|
||||||
*
|
|
||||||
* We were expecting H2 from server, let's make sure the
|
|
||||||
* conditions match.
|
|
||||||
*/
|
*/
|
||||||
String ap = sslSocket.getApplicationProtocol();
|
String ap = sslSocket.getApplicationProtocol();
|
||||||
System.out.println("Application Protocol: \"" + ap + "\"");
|
System.out.println("Application Protocol: \"" + ap + "\"");
|
||||||
|
|
||||||
if (ap == null) {
|
if (ap == null) {
|
||||||
throw new Exception(
|
throw new Exception(
|
||||||
"Handshake was completed but null was received");
|
"Handshake was completed but null was received");
|
||||||
}
|
}
|
||||||
if (expectedAP.equals("NONE")) {
|
if (expectedAP.equals("NONE")) {
|
||||||
if (!ap.isEmpty()) {
|
if (!ap.isEmpty()) {
|
||||||
@ -215,8 +245,8 @@ public class SSLSocketAlpnTest {
|
|||||||
System.out.println("No ALPN value negotiated, as expected");
|
System.out.println("No ALPN value negotiated, as expected");
|
||||||
}
|
}
|
||||||
} else if (!expectedAP.equals(ap)) {
|
} else if (!expectedAP.equals(ap)) {
|
||||||
throw new Exception(expectedAP +
|
throw new Exception(expectedAP
|
||||||
" ALPN value not available on negotiated connection");
|
+ " ALPN value not available on negotiated connection");
|
||||||
}
|
}
|
||||||
|
|
||||||
InputStream sslIS = sslSocket.getInputStream();
|
InputStream sslIS = sslSocket.getInputStream();
|
||||||
@ -240,17 +270,6 @@ public class SSLSocketAlpnTest {
|
|||||||
volatile Exception clientException = null;
|
volatile Exception clientException = null;
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
String keyFilename
|
|
||||||
= System.getProperty("test.src", ".") + "/" + pathToStores
|
|
||||||
+ "/" + keyStoreFile;
|
|
||||||
String trustFilename
|
|
||||||
= System.getProperty("test.src", ".") + "/" + pathToStores
|
|
||||||
+ "/" + trustStoreFile;
|
|
||||||
|
|
||||||
System.setProperty("javax.net.ssl.keyStore", keyFilename);
|
|
||||||
System.setProperty("javax.net.ssl.keyStorePassword", passwd);
|
|
||||||
System.setProperty("javax.net.ssl.trustStore", trustFilename);
|
|
||||||
System.setProperty("javax.net.ssl.trustStorePassword", passwd);
|
|
||||||
|
|
||||||
if (debug) {
|
if (debug) {
|
||||||
System.setProperty("javax.net.debug", "all");
|
System.setProperty("javax.net.debug", "all");
|
||||||
@ -280,6 +299,39 @@ public class SSLSocketAlpnTest {
|
|||||||
System.out.println("Test Passed.");
|
System.out.println("Test Passed.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SSLContext getSSLContext(String keyFilename, String trustFilename)
|
||||||
|
throws Exception {
|
||||||
|
SSLContext ctx = SSLContext.getInstance("TLS");
|
||||||
|
|
||||||
|
// Keystores
|
||||||
|
KeyStore keyKS = KeyStore.getInstance("JKS");
|
||||||
|
keyKS.load(new FileInputStream(keyFilename), passwd.toCharArray());
|
||||||
|
|
||||||
|
KeyStore trustKS = KeyStore.getInstance("JKS");
|
||||||
|
trustKS.load(new FileInputStream(trustFilename), passwd.toCharArray());
|
||||||
|
|
||||||
|
// Generate KeyManager and TrustManager
|
||||||
|
KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
|
||||||
|
kmf.init(keyKS, passwd.toCharArray());
|
||||||
|
|
||||||
|
KeyManager[] kms = kmf.getKeyManagers();
|
||||||
|
if (!(kms[0] instanceof X509ExtendedKeyManager)) {
|
||||||
|
throw new Exception("kms[0] not X509ExtendedKeyManager");
|
||||||
|
}
|
||||||
|
|
||||||
|
kms = new KeyManager[] { new MyX509ExtendedKeyManager(
|
||||||
|
(X509ExtendedKeyManager) kms[0], expectedAP) };
|
||||||
|
|
||||||
|
TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
|
||||||
|
tmf.init(trustKS);
|
||||||
|
TrustManager[] tms = tmf.getTrustManagers();
|
||||||
|
|
||||||
|
// initial SSLContext
|
||||||
|
ctx.init(kms, tms, null);
|
||||||
|
|
||||||
|
return ctx;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Convert a comma-separated list into an array of strings.
|
* Convert a comma-separated list into an array of strings.
|
||||||
*/
|
*/
|
||||||
@ -309,6 +361,7 @@ public class SSLSocketAlpnTest {
|
|||||||
*/
|
*/
|
||||||
SSLSocketAlpnTest() throws Exception {
|
SSLSocketAlpnTest() throws Exception {
|
||||||
Exception startException = null;
|
Exception startException = null;
|
||||||
|
mySSLContext = getSSLContext(keyFilename, trustFilename);
|
||||||
try {
|
try {
|
||||||
if (separateServerThread) {
|
if (separateServerThread) {
|
||||||
startServer(true);
|
startServer(true);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2016, 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
|
||||||
@ -31,6 +31,7 @@
|
|||||||
* @bug 4366807
|
* @bug 4366807
|
||||||
* @summary Need new APIs to get/set session timeout and session cache size.
|
* @summary Need new APIs to get/set session timeout and session cache size.
|
||||||
* @run main/othervm SessionCacheSizeTests
|
* @run main/othervm SessionCacheSizeTests
|
||||||
|
* @key intermittent
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
@ -108,28 +109,34 @@ public class SessionCacheSizeTests {
|
|||||||
|
|
||||||
void doServerSide(int serverPort, int serverConns) throws Exception {
|
void doServerSide(int serverPort, int serverConns) throws Exception {
|
||||||
|
|
||||||
SSLServerSocket sslServerSocket =
|
try (SSLServerSocket sslServerSocket =
|
||||||
(SSLServerSocket) sslssf.createServerSocket(serverPort);
|
(SSLServerSocket) sslssf.createServerSocket(serverPort)) {
|
||||||
sslServerSocket.setSoTimeout(45000); // timeout to accept a connection
|
|
||||||
serverPorts[createdPorts++] = sslServerSocket.getLocalPort();
|
|
||||||
|
|
||||||
/*
|
// timeout to accept a connection
|
||||||
* Signal Client, we're ready for his connect.
|
sslServerSocket.setSoTimeout(45000);
|
||||||
*/
|
|
||||||
if (createdPorts == serverPorts.length) {
|
// make sure createdPorts++ is atomic
|
||||||
serverReady = true;
|
synchronized(serverPorts) {
|
||||||
}
|
serverPorts[createdPorts++] = sslServerSocket.getLocalPort();
|
||||||
int read = 0;
|
|
||||||
int nConnections = 0;
|
/*
|
||||||
/*
|
* Signal Client, we're ready for his connect.
|
||||||
* Divide the max connections among the available server ports.
|
*/
|
||||||
* The use of more than one server port ensures creation of more
|
if (createdPorts == serverPorts.length) {
|
||||||
* than one session.
|
serverReady = true;
|
||||||
*/
|
}
|
||||||
SSLSession sessions [] = new SSLSession [serverConns];
|
}
|
||||||
SSLSessionContext sessCtx = sslctx.getServerSessionContext();
|
int read = 0;
|
||||||
|
int nConnections = 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Divide the max connections among the available server ports.
|
||||||
|
* The use of more than one server port ensures creation of more
|
||||||
|
* than one session.
|
||||||
|
*/
|
||||||
|
SSLSession sessions [] = new SSLSession [serverConns];
|
||||||
|
SSLSessionContext sessCtx = sslctx.getServerSessionContext();
|
||||||
|
|
||||||
try {
|
|
||||||
while (nConnections < serverConns) {
|
while (nConnections < serverConns) {
|
||||||
try (SSLSocket sslSocket =
|
try (SSLSocket sslSocket =
|
||||||
(SSLSocket)sslServerSocket.accept()) {
|
(SSLSocket)sslServerSocket.accept()) {
|
||||||
@ -143,8 +150,6 @@ public class SessionCacheSizeTests {
|
|||||||
nConnections++;
|
nConnections++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} finally {
|
|
||||||
sslServerSocket.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -270,8 +275,8 @@ public class SessionCacheSizeTests {
|
|||||||
* Using four ports (one per each connection), we are able to create
|
* Using four ports (one per each connection), we are able to create
|
||||||
* alteast four sessions.
|
* alteast four sessions.
|
||||||
*/
|
*/
|
||||||
volatile int serverPorts[] = new int[]{0, 0, 0, 0};
|
int serverPorts[] = new int[]{0, 0, 0, 0}; // MAX_ACTIVE_CONNECTIONS: 4
|
||||||
volatile int createdPorts = 0;
|
int createdPorts = 0;
|
||||||
static SSLServerSocketFactory sslssf;
|
static SSLServerSocketFactory sslssf;
|
||||||
static SSLSocketFactory sslsf;
|
static SSLSocketFactory sslsf;
|
||||||
static SSLContext sslctx;
|
static SSLContext sslctx;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2003, 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
|
||||||
@ -37,13 +37,16 @@ public class Optimize {
|
|||||||
|
|
||||||
ProtectionDomain pd1 = new ProtectionDomain(
|
ProtectionDomain pd1 = new ProtectionDomain(
|
||||||
new CodeSource(null, (java.security.cert.Certificate[]) null),
|
new CodeSource(null, (java.security.cert.Certificate[]) null),
|
||||||
new Permissions());
|
new Permissions(),
|
||||||
|
null, null);
|
||||||
ProtectionDomain pd2 = new ProtectionDomain(
|
ProtectionDomain pd2 = new ProtectionDomain(
|
||||||
new CodeSource(null, (java.security.cert.Certificate[]) null),
|
new CodeSource(null, (java.security.cert.Certificate[]) null),
|
||||||
new Permissions());
|
new Permissions(),
|
||||||
|
null, null);
|
||||||
ProtectionDomain pd3 = new ProtectionDomain(
|
ProtectionDomain pd3 = new ProtectionDomain(
|
||||||
new CodeSource(null, (java.security.cert.Certificate[]) null),
|
new CodeSource(null, (java.security.cert.Certificate[]) null),
|
||||||
new Permissions());
|
new Permissions(),
|
||||||
|
null, null);
|
||||||
|
|
||||||
ProtectionDomain[] current = new ProtectionDomain[] {pd1, pd2};
|
ProtectionDomain[] current = new ProtectionDomain[] {pd1, pd2};
|
||||||
ProtectionDomain[] assigned = new ProtectionDomain[] {pd3, pd2};
|
ProtectionDomain[] assigned = new ProtectionDomain[] {pd3, pd2};
|
||||||
|
@ -313,7 +313,7 @@ public class JImageReadTest {
|
|||||||
static boolean isMetaName(String name) {
|
static boolean isMetaName(String name) {
|
||||||
return name.startsWith("/modules")
|
return name.startsWith("/modules")
|
||||||
|| name.startsWith("/packages")
|
|| name.startsWith("/packages")
|
||||||
|| name.startsWith("META-INF/services")
|
|| name.startsWith("META-INF")
|
||||||
|| name.equals("bootmodules.jdata");
|
|| name.equals("bootmodules.jdata");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,23 +202,28 @@ define SetupJavaCompilationBody
|
|||||||
# CacheFind does not preserve order so need to call it for each root.
|
# CacheFind does not preserve order so need to call it for each root.
|
||||||
$1_ALL_SRCS += $$(foreach s, $$($1_SRC), $$(call CacheFind, $$(s)))
|
$1_ALL_SRCS += $$(foreach s, $$($1_SRC), $$(call CacheFind, $$(s)))
|
||||||
# Extract the java files.
|
# Extract the java files.
|
||||||
ifneq ($$($1_EXCLUDE_FILES),)
|
$1_SRCS := $$(filter %.java, $$($1_ALL_SRCS))
|
||||||
$1_EXCLUDE_FILES_PATTERN:=$$(addprefix %,$$($1_EXCLUDE_FILES))
|
|
||||||
|
# Translate include/exclude into patterns
|
||||||
|
ifneq ($$($1_EXCLUDE_FILES), )
|
||||||
|
$1_EXCLUDE_PATTERN := $$(addprefix %, $$($1_EXCLUDE_FILES))
|
||||||
endif
|
endif
|
||||||
$1_SRCS := $$(filter-out $$($1_EXCLUDE_FILES_PATTERN),$$(filter %.java,$$($1_ALL_SRCS)))
|
ifneq ($$($1_INCLUDE_FILES), )
|
||||||
ifneq ($$($1_INCLUDE_FILES),)
|
$1_INCLUDE_PATTERN := $$(foreach i, $$($1_SRC), $$(addprefix $$i/, $$($1_INCLUDE_FILES)))
|
||||||
$1_INCLUDE_FILES:=$$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$($1_INCLUDE_FILES)))
|
endif
|
||||||
$1_SRCS := $$(filter $$($1_INCLUDE_FILES), $$($1_SRCS))
|
ifneq ($$($1_EXCLUDES), )
|
||||||
|
$1_EXCLUDE_PATTERN += $$(foreach i, $$($1_SRC), $$(addprefix $$i/, $$(addsuffix /%, $$($1_EXCLUDES))))
|
||||||
|
endif
|
||||||
|
ifneq ($$($1_INCLUDES), )
|
||||||
|
$1_INCLUDE_PATTERN += $$(foreach i, $$($1_SRC), $$(addprefix $$i/, $$(addsuffix /%, $$($1_INCLUDES))))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Prepend the source/bin path to the filter expressions.
|
# Apply include/exclude patterns to java sources
|
||||||
ifneq ($$($1_INCLUDES),)
|
ifneq ($$($1_EXCLUDE_PATTERN), )
|
||||||
$1_SRC_INCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_INCLUDES))))
|
$1_SRCS := $$(filter-out $$($1_EXCLUDE_PATTERN), $$($1_SRCS))
|
||||||
$1_SRCS := $$(filter $$($1_SRC_INCLUDES),$$($1_SRCS))
|
|
||||||
endif
|
endif
|
||||||
ifneq ($$($1_EXCLUDES),)
|
ifneq ($$($1_INCLUDE_PATTERN), )
|
||||||
$1_SRC_EXCLUDES := $$(foreach i,$$($1_SRC),$$(addprefix $$i/,$$(addsuffix /%,$$($1_EXCLUDES))))
|
$1_SRCS := $$(filter $$($1_INCLUDE_PATTERN), $$($1_SRCS))
|
||||||
$1_SRCS := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_SRCS))
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq ($$($1_KEEP_DUPS), true)
|
ifneq ($$($1_KEEP_DUPS), true)
|
||||||
@ -242,10 +247,10 @@ define SetupJavaCompilationBody
|
|||||||
$1_SAFE_NAME := $$(strip $$(subst /,_, $1))
|
$1_SAFE_NAME := $$(strip $$(subst /,_, $1))
|
||||||
|
|
||||||
# Create the corresponding smart javac wrapper command line.
|
# Create the corresponding smart javac wrapper command line.
|
||||||
$1_SJAVAC_ARGS:=$$(addprefix -x ,$$(addsuffix /*,$$($1_EXCLUDES))) \
|
$1_SJAVAC_ARGS:=$$(addprefix -x ,$$(addsuffix /**,$$($1_EXCLUDES))) \
|
||||||
$$(addprefix -i ,$$(addsuffix /*,$$($1_INCLUDES))) \
|
$$(addprefix -i ,$$(addsuffix /**,$$($1_INCLUDES))) \
|
||||||
$$(addprefix -xf *,$$(strip $$($1_EXCLUDE_FILES) $$($1_SJAVAC_EXCLUDE_FILES))) \
|
$$(addprefix -x **,$$(strip $$($1_EXCLUDE_FILES) $$($1_SJAVAC_EXCLUDE_FILES))) \
|
||||||
$$(addprefix -if *,$$(strip $$($1_INCLUDE_FILES))) \
|
$$(addprefix -i **,$$(strip $$($1_INCLUDE_FILES))) \
|
||||||
-src $$(call PathList, $$($1_SRC))
|
-src $$(call PathList, $$($1_SRC))
|
||||||
|
|
||||||
# All files below META-INF are always copied.
|
# All files below META-INF are always copied.
|
||||||
@ -258,14 +263,11 @@ define SetupJavaCompilationBody
|
|||||||
$1_ALL_COPIES += $$($1_COPY_FILES)
|
$1_ALL_COPIES += $$($1_COPY_FILES)
|
||||||
endif
|
endif
|
||||||
# Copy must also respect filters.
|
# Copy must also respect filters.
|
||||||
ifneq (,$$($1_INCLUDES))
|
ifneq (,$$($1_INCLUDE_PATTERN))
|
||||||
$1_ALL_COPIES := $$(filter $$($1_SRC_INCLUDES),$$($1_ALL_COPIES))
|
$1_ALL_COPIES := $$(filter $$($1_INCLUDE_PATTERN),$$($1_ALL_COPIES))
|
||||||
endif
|
endif
|
||||||
ifneq (,$$($1_EXCLUDES))
|
ifneq (,$$($1_EXCLUDE_PATTERN))
|
||||||
$1_ALL_COPIES := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_ALL_COPIES))
|
$1_ALL_COPIES := $$(filter-out $$($1_EXCLUDE_PATTERN),$$($1_ALL_COPIES))
|
||||||
endif
|
|
||||||
ifneq (,$$($1_EXCLUDE_FILES))
|
|
||||||
$1_ALL_COPIES := $$(filter-out $$($1_EXCLUDE_FILES_PATTERN),$$($1_ALL_COPIES))
|
|
||||||
endif
|
endif
|
||||||
ifneq (,$$($1_ALL_COPIES))
|
ifneq (,$$($1_ALL_COPIES))
|
||||||
# Yep, there are files to be copied!
|
# Yep, there are files to be copied!
|
||||||
@ -281,14 +283,11 @@ define SetupJavaCompilationBody
|
|||||||
# Clean these explicitly
|
# Clean these explicitly
|
||||||
$1_ALL_CLEANS += $$($1_CLEAN_FILES)
|
$1_ALL_CLEANS += $$($1_CLEAN_FILES)
|
||||||
# Copy and clean must also respect filters.
|
# Copy and clean must also respect filters.
|
||||||
ifneq (,$$($1_INCLUDES))
|
ifneq (,$$($1_INCLUDE_PATTERN))
|
||||||
$1_ALL_CLEANS := $$(filter $$($1_SRC_INCLUDES),$$($1_ALL_CLEANS))
|
$1_ALL_CLEANS := $$(filter $$($1_INCLUDE_PATTERN),$$($1_ALL_CLEANS))
|
||||||
endif
|
endif
|
||||||
ifneq (,$$($1_EXCLUDES))
|
ifneq (,$$($1_EXCLUDE_PATTERN))
|
||||||
$1_ALL_CLEANS := $$(filter-out $$($1_SRC_EXCLUDES),$$($1_ALL_CLEANS))
|
$1_ALL_CLEANS := $$(filter-out $$($1_EXCLUDE_PATTERN),$$($1_ALL_CLEANS))
|
||||||
endif
|
|
||||||
ifneq (,$$($1_EXCLUDE_FILES))
|
|
||||||
$1_ALL_CLEANS := $$(filter-out $$($1_EXCLUDE_FILES_PATTERN),$$($1_ALL_CLEANS))
|
|
||||||
endif
|
endif
|
||||||
ifneq (,$$($1_ALL_CLEANS))
|
ifneq (,$$($1_ALL_CLEANS))
|
||||||
# Yep, there are files to be copied and cleaned!
|
# Yep, there are files to be copied and cleaned!
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user