Merge
This commit is contained in:
commit
84371ae0b4
@ -304,3 +304,4 @@ f25ee9f62427a9ba27418e5531a89754791a305b jdk9-b57
|
||||
39e8a131289e8386aa4c3e4b184faa812a7c0421 jdk9-b59
|
||||
9fa2185bee17462d1014538bff60af6e6f0b01e7 jdk9-b60
|
||||
ea38728b4f4bdd8fd0d7a89b18069f521cf05013 jdk9-b61
|
||||
105d045a69174d870b69bfe471b3f2d05a9f8ecc jdk9-b62
|
||||
|
@ -478,6 +478,15 @@ AC_DEFUN_ONCE([BASIC_SETUP_PATHS],
|
||||
AUTOCONF_DIR=$TOPDIR/common/autoconf
|
||||
])
|
||||
|
||||
# Evaluates platform specific overrides for devkit variables.
|
||||
# $1: Name of variable
|
||||
AC_DEFUN([BASIC_EVAL_DEVKIT_VARIABLE],
|
||||
[
|
||||
if test "x[$]$1" = x; then
|
||||
eval $1="\${$1_${OPENJDK_TARGET_CPU}}"
|
||||
fi
|
||||
])
|
||||
|
||||
AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT],
|
||||
[
|
||||
AC_ARG_WITH([devkit], [AS_HELP_STRING([--with-devkit],
|
||||
@ -487,12 +496,27 @@ AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT],
|
||||
DEVKIT_ROOT="$with_devkit"
|
||||
# Check for a meta data info file in the root of the devkit
|
||||
if test -f "$DEVKIT_ROOT/devkit.info"; then
|
||||
# This potentially sets the following:
|
||||
# DEVKIT_NAME: A descriptive name of the devkit
|
||||
# DEVKIT_TOOLCHAIN_PATH: Corresponds to --with-toolchain-path
|
||||
# DEVKIT_EXTRA_PATH: Corresponds to --with-extra-path
|
||||
# DEVKIT_SYSROOT: Corresponds to --with-sysroot
|
||||
. $DEVKIT_ROOT/devkit.info
|
||||
# This potentially sets the following:
|
||||
# A descriptive name of the devkit
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_NAME])
|
||||
# Corresponds to --with-extra-path
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_EXTRA_PATH])
|
||||
# Corresponds to --with-toolchain-path
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_TOOLCHAIN_PATH])
|
||||
# Corresponds to --with-sysroot
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_SYSROOT])
|
||||
|
||||
# Identifies the Visual Studio version in the devkit
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_VERSION])
|
||||
# The Visual Studio include environment variable
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_INCLUDE])
|
||||
# The Visual Studio lib environment variable
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_LIB])
|
||||
# Corresponds to --with-msvcr-dll
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_MSVCR_DLL])
|
||||
# Corresponds to --with-msvcp-dll
|
||||
BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_MSVCP_DLL])
|
||||
fi
|
||||
|
||||
AC_MSG_CHECKING([for devkit])
|
||||
@ -502,9 +526,7 @@ AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT],
|
||||
AC_MSG_RESULT([$DEVKIT_ROOT])
|
||||
fi
|
||||
|
||||
if test "x$DEVKIT_EXTRA_PATH" != x; then
|
||||
BASIC_PREPEND_TO_PATH([EXTRA_PATH],$DEVKIT_EXTRA_PATH)
|
||||
fi
|
||||
BASIC_PREPEND_TO_PATH([EXTRA_PATH],$DEVKIT_EXTRA_PATH)
|
||||
|
||||
# Fallback default of just /bin if DEVKIT_PATH is not defined
|
||||
if test "x$DEVKIT_TOOLCHAIN_PATH" = x; then
|
||||
@ -681,8 +703,12 @@ AC_DEFUN_ONCE([BASIC_SETUP_OUTPUT_DIR],
|
||||
files_present=`$LS $OUTPUT_ROOT`
|
||||
# Configure has already touched config.log and confdefs.h in the current dir when this check
|
||||
# is performed.
|
||||
filtered_files=`$ECHO "$files_present" | $SED -e 's/config.log//g' -e 's/confdefs.h//g' -e 's/ //g' \
|
||||
| $TR -d '\n'`
|
||||
filtered_files=`$ECHO "$files_present" \
|
||||
| $SED -e 's/config.log//g' \
|
||||
-e 's/confdefs.h//g' \
|
||||
-e 's/fixpath.exe//g' \
|
||||
-e 's/ //g' \
|
||||
| $TR -d '\n'`
|
||||
if test "x$filtered_files" != x; then
|
||||
AC_MSG_NOTICE([Current directory is $CURDIR.])
|
||||
AC_MSG_NOTICE([Since this is not the source root, configure will output the configuration here])
|
||||
|
@ -66,7 +66,7 @@ AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_CYGWIN],
|
||||
# Going to short mode and back again did indeed matter. Since short mode is
|
||||
# case insensitive, let's make it lowercase to improve readability.
|
||||
shortmode_path=`$ECHO "$shortmode_path" | $TR 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
||||
# Now convert it back to Unix-stile (cygpath)
|
||||
# Now convert it back to Unix-style (cygpath)
|
||||
input_path=`$CYGPATH -u "$shortmode_path"`
|
||||
new_path="$input_path"
|
||||
fi
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -189,11 +189,15 @@ AC_DEFUN_ONCE([TOOLCHAIN_PRE_DETECTION],
|
||||
ORG_CFLAGS="$CFLAGS"
|
||||
ORG_CXXFLAGS="$CXXFLAGS"
|
||||
|
||||
# autoconf magic only relies on PATH, so update it if tools dir is specified
|
||||
OLD_PATH="$PATH"
|
||||
|
||||
# On Windows, we need to detect the visual studio installation first.
|
||||
# This will change the PATH, but we need to keep that new PATH even
|
||||
# after toolchain detection is done, since the compiler (on x86) uses
|
||||
# it for DLL resolution in runtime.
|
||||
if test "x$OPENJDK_BUILD_OS" = "xwindows" && test "x$TOOLCHAIN_TYPE" = "xmicrosoft"; then
|
||||
if test "x$OPENJDK_BUILD_OS" = "xwindows" \
|
||||
&& test "x$TOOLCHAIN_TYPE" = "xmicrosoft"; then
|
||||
TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV
|
||||
# Reset path to VS_PATH. It will include everything that was on PATH at the time we
|
||||
# ran TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV.
|
||||
@ -203,9 +207,6 @@ AC_DEFUN_ONCE([TOOLCHAIN_PRE_DETECTION],
|
||||
export LIB="$VS_LIB"
|
||||
fi
|
||||
|
||||
# autoconf magic only relies on PATH, so update it if tools dir is specified
|
||||
OLD_PATH="$PATH"
|
||||
|
||||
# For solaris we really need solaris tools, and not the GNU equivalent.
|
||||
# The build tools on Solaris reside in /usr/ccs (C Compilation System),
|
||||
# so add that to path before starting to probe.
|
||||
|
@ -210,6 +210,37 @@ AC_DEFUN([TOOLCHAIN_FIND_VISUAL_STUDIO],
|
||||
done
|
||||
|
||||
exit 0
|
||||
elif test "x$DEVKIT_VS_VERSION" != x; then
|
||||
VS_VERSION=$DEVKIT_VS_VERSION
|
||||
TOOLCHAIN_VERSION=$VS_VERSION
|
||||
eval VS_DESCRIPTION="\${VS_DESCRIPTION_${VS_VERSION}}"
|
||||
eval VS_VERSION_INTERNAL="\${VS_VERSION_INTERNAL_${VS_VERSION}}"
|
||||
eval MSVCR_NAME="\${VS_MSVCR_${VS_VERSION}}"
|
||||
eval MSVCP_NAME="\${VS_MSVCP_${VS_VERSION}}"
|
||||
eval PLATFORM_TOOLSET="\${VS_VS_PLATFORM_NAME_${VS_VERSION}}"
|
||||
VS_PATH="$TOOLCHAIN_PATH:$PATH"
|
||||
|
||||
# Convert DEVKIT_VS_INCLUDE into windows style VS_INCLUDE so that it
|
||||
# can still be exported as INCLUDE for compiler invocations without
|
||||
# SYSROOT_CFLAGS
|
||||
OLDIFS="$IFS"
|
||||
IFS=";"
|
||||
for i in $DEVKIT_VS_INCLUDE; do
|
||||
ipath=$i
|
||||
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([ipath])
|
||||
VS_INCLUDE="$VS_INCLUDE;$ipath"
|
||||
done
|
||||
# Convert DEVKIT_VS_LIB into VS_LIB so that it can still be exported
|
||||
# as LIB for compiler invocations without SYSROOT_LDFLAGS
|
||||
for i in $DEVKIT_VS_LIB; do
|
||||
libpath=$i
|
||||
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([libpath])
|
||||
VS_LIB="$VS_LIB;$libpath"
|
||||
done
|
||||
IFS="$OLDIFS"
|
||||
|
||||
AC_MSG_NOTICE([Found devkit $VS_DESCRIPTION])
|
||||
|
||||
elif test "x$with_toolchain_version" != x; then
|
||||
# User override; check that it is valid
|
||||
if test "x${VALID_VS_VERSIONS/$with_toolchain_version/}" = "x${VALID_VS_VERSIONS}"; then
|
||||
@ -262,71 +293,81 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV],
|
||||
# First-hand choice is to locate and run the vsvars bat file.
|
||||
TOOLCHAIN_FIND_VISUAL_STUDIO
|
||||
|
||||
if test "x$VS_ENV_CMD" != x; then
|
||||
# We have found a Visual Studio environment on disk, let's extract variables from the vsvars bat file.
|
||||
BASIC_FIXUP_EXECUTABLE(VS_ENV_CMD)
|
||||
# If we have a devkit, skip all of the below.
|
||||
if test "x$DEVKIT_VS_VERSION" = x; then
|
||||
if test "x$VS_ENV_CMD" != x; then
|
||||
# We have found a Visual Studio environment on disk, let's extract variables from the vsvars bat file.
|
||||
BASIC_FIXUP_EXECUTABLE(VS_ENV_CMD)
|
||||
|
||||
# Lets extract the variables that are set by vcvarsall.bat/vsvars32.bat/vsvars64.bat
|
||||
AC_MSG_NOTICE([Trying to extract Visual Studio environment variables])
|
||||
# Lets extract the variables that are set by vcvarsall.bat/vsvars32.bat/vsvars64.bat
|
||||
AC_MSG_NOTICE([Trying to extract Visual Studio environment variables])
|
||||
|
||||
# We need to create a couple of temporary files.
|
||||
VS_ENV_TMP_DIR="$CONFIGURESUPPORT_OUTPUTDIR/vs-env"
|
||||
$MKDIR -p $VS_ENV_TMP_DIR
|
||||
# We need to create a couple of temporary files.
|
||||
VS_ENV_TMP_DIR="$CONFIGURESUPPORT_OUTPUTDIR/vs-env"
|
||||
$MKDIR -p $VS_ENV_TMP_DIR
|
||||
|
||||
# Cannot use the VS10 setup script directly (since it only updates the DOS subshell environment).
|
||||
# Instead create a shell script which will set the relevant variables when run.
|
||||
WINPATH_VS_ENV_CMD="$VS_ENV_CMD"
|
||||
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_VS_ENV_CMD])
|
||||
WINPATH_BASH="$BASH"
|
||||
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_BASH])
|
||||
# Cannot use the VS10 setup script directly (since it only updates the DOS subshell environment).
|
||||
# Instead create a shell script which will set the relevant variables when run.
|
||||
WINPATH_VS_ENV_CMD="$VS_ENV_CMD"
|
||||
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_VS_ENV_CMD])
|
||||
WINPATH_BASH="$BASH"
|
||||
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_BASH])
|
||||
|
||||
# Generate a DOS batch file which runs $VS_ENV_CMD, and then creates a shell
|
||||
# script (executable by bash) that will setup the important variables.
|
||||
EXTRACT_VC_ENV_BAT_FILE="$VS_ENV_TMP_DIR/extract-vs-env.bat"
|
||||
$ECHO "@echo off" > $EXTRACT_VC_ENV_BAT_FILE
|
||||
# This will end up something like:
|
||||
# call C:/progra~2/micros~2.0/vc/bin/amd64/vcvars64.bat
|
||||
$ECHO "call $WINPATH_VS_ENV_CMD $VS_ENV_ARGS" >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
# These will end up something like:
|
||||
# C:/CygWin/bin/bash -c 'echo VS_PATH=\"$PATH\" > localdevenv.sh
|
||||
# The trailing space for everyone except PATH is no typo, but is needed due
|
||||
# to trailing \ in the Windows paths. These will be stripped later.
|
||||
$ECHO "$WINPATH_BASH -c 'echo VS_PATH="'\"$PATH\" > set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo VS_INCLUDE="'\"$INCLUDE\;$include \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo VS_LIB="'\"$LIB\;$lib \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo VCINSTALLDIR="'\"$VCINSTALLDIR \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo WindowsSdkDir="'\"$WindowsSdkDir \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo WINDOWSSDKDIR="'\"$WINDOWSSDKDIR \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
# Generate a DOS batch file which runs $VS_ENV_CMD, and then creates a shell
|
||||
# script (executable by bash) that will setup the important variables.
|
||||
EXTRACT_VC_ENV_BAT_FILE="$VS_ENV_TMP_DIR/extract-vs-env.bat"
|
||||
$ECHO "@echo off" > $EXTRACT_VC_ENV_BAT_FILE
|
||||
# This will end up something like:
|
||||
# call C:/progra~2/micros~2.0/vc/bin/amd64/vcvars64.bat
|
||||
$ECHO "call $WINPATH_VS_ENV_CMD $VS_ENV_ARGS" >> $EXTRACT_VC_ENV_BAT_FILE
|
||||
# These will end up something like:
|
||||
# C:/CygWin/bin/bash -c 'echo VS_PATH=\"$PATH\" > localdevenv.sh
|
||||
# The trailing space for everyone except PATH is no typo, but is needed due
|
||||
# to trailing \ in the Windows paths. These will be stripped later.
|
||||
$ECHO "$WINPATH_BASH -c 'echo VS_PATH="'\"$PATH\" > set-vs-env.sh' \
|
||||
>> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo VS_INCLUDE="'\"$INCLUDE\;$include \" >> set-vs-env.sh' \
|
||||
>> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo VS_LIB="'\"$LIB\;$lib \" >> set-vs-env.sh' \
|
||||
>> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo VCINSTALLDIR="'\"$VCINSTALLDIR \" >> set-vs-env.sh' \
|
||||
>> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo WindowsSdkDir="'\"$WindowsSdkDir \" >> set-vs-env.sh' \
|
||||
>> $EXTRACT_VC_ENV_BAT_FILE
|
||||
$ECHO "$WINPATH_BASH -c 'echo WINDOWSSDKDIR="'\"$WINDOWSSDKDIR \" >> set-vs-env.sh' \
|
||||
>> $EXTRACT_VC_ENV_BAT_FILE
|
||||
|
||||
# Now execute the newly created bat file.
|
||||
# The | cat is to stop SetEnv.Cmd to mess with system colors on msys.
|
||||
# Change directory so we don't need to mess with Windows paths in redirects.
|
||||
cd $VS_ENV_TMP_DIR
|
||||
cmd /c extract-vs-env.bat | $CAT
|
||||
cd $CURDIR
|
||||
# Now execute the newly created bat file.
|
||||
# The | cat is to stop SetEnv.Cmd to mess with system colors on msys.
|
||||
# Change directory so we don't need to mess with Windows paths in redirects.
|
||||
cd $VS_ENV_TMP_DIR
|
||||
cmd /c extract-vs-env.bat | $CAT
|
||||
cd $CURDIR
|
||||
|
||||
if test ! -s $VS_ENV_TMP_DIR/set-vs-env.sh; then
|
||||
AC_MSG_NOTICE([Could not succesfully extract the envionment variables needed for the VS setup.])
|
||||
AC_MSG_NOTICE([Try setting --with-tools-dir to the VC/bin directory within the VS installation])
|
||||
AC_MSG_NOTICE([or run "bash.exe -l" from a VS command prompt and then run configure from there.])
|
||||
AC_MSG_ERROR([Cannot continue])
|
||||
if test ! -s $VS_ENV_TMP_DIR/set-vs-env.sh; then
|
||||
AC_MSG_NOTICE([Could not succesfully extract the envionment variables needed for the VS setup.])
|
||||
AC_MSG_NOTICE([Try setting --with-tools-dir to the VC/bin directory within the VS installation])
|
||||
AC_MSG_NOTICE([or run "bash.exe -l" from a VS command prompt and then run configure from there.])
|
||||
AC_MSG_ERROR([Cannot continue])
|
||||
fi
|
||||
|
||||
# Now set all paths and other env variables. This will allow the rest of
|
||||
# the configure script to find and run the compiler in the proper way.
|
||||
AC_MSG_NOTICE([Setting extracted environment variables])
|
||||
. $VS_ENV_TMP_DIR/set-vs-env.sh
|
||||
# Now we have VS_PATH, VS_INCLUDE, VS_LIB. For further checking, we
|
||||
# also define VCINSTALLDIR, WindowsSdkDir and WINDOWSSDKDIR.
|
||||
else
|
||||
# We did not find a vsvars bat file, let's hope we are run from a VS command prompt.
|
||||
AC_MSG_NOTICE([Cannot locate a valid Visual Studio installation, checking current environment])
|
||||
fi
|
||||
|
||||
# Now set all paths and other env variables. This will allow the rest of
|
||||
# the configure script to find and run the compiler in the proper way.
|
||||
AC_MSG_NOTICE([Setting extracted environment variables])
|
||||
. $VS_ENV_TMP_DIR/set-vs-env.sh
|
||||
# Now we have VS_PATH, VS_INCLUDE, VS_LIB. For further checking, we
|
||||
# also define VCINSTALLDIR, WindowsSdkDir and WINDOWSSDKDIR.
|
||||
else
|
||||
# We did not find a vsvars bat file, let's hope we are run from a VS command prompt.
|
||||
AC_MSG_NOTICE([Cannot locate a valid Visual Studio installation, checking current environment])
|
||||
fi
|
||||
|
||||
# At this point, we should have correct variables in the environment, or we can't continue.
|
||||
AC_MSG_CHECKING([for Visual Studio variables])
|
||||
|
||||
if test "x$VCINSTALLDIR" != x || test "x$WindowsSDKDir" != x || test "x$WINDOWSSDKDIR" != x; then
|
||||
if test "x$VCINSTALLDIR" != x || test "x$WindowsSDKDir" != x \
|
||||
|| test "x$WINDOWSSDKDIR" != x || test "x$DEVKIT_NAME" != x; then
|
||||
if test "x$VS_INCLUDE" = x || test "x$VS_LIB" = x; then
|
||||
AC_MSG_RESULT([present but broken])
|
||||
AC_MSG_ERROR([Your VC command prompt seems broken, INCLUDE and/or LIB is missing.])
|
||||
@ -403,10 +444,10 @@ AC_DEFUN([TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL],
|
||||
POSSIBLE_MSVC_DLL="$2"
|
||||
METHOD="$3"
|
||||
if test -n "$POSSIBLE_MSVC_DLL" -a -e "$POSSIBLE_MSVC_DLL"; then
|
||||
AC_MSG_NOTICE([Found $1 at $POSSIBLE_MSVC_DLL using $METHOD])
|
||||
AC_MSG_NOTICE([Found $DLL_NAME at $POSSIBLE_MSVC_DLL using $METHOD])
|
||||
|
||||
# Need to check if the found msvcr is correct architecture
|
||||
AC_MSG_CHECKING([found $1 architecture])
|
||||
AC_MSG_CHECKING([found $DLL_NAME architecture])
|
||||
MSVC_DLL_FILETYPE=`$FILE -b "$POSSIBLE_MSVC_DLL"`
|
||||
if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then
|
||||
# The MSYS 'file' command returns "PE32 executable for MS Windows (DLL) (GUI) Intel 80386 32-bit"
|
||||
@ -426,19 +467,19 @@ AC_DEFUN([TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL],
|
||||
if $ECHO "$MSVC_DLL_FILETYPE" | $GREP "$CORRECT_MSVCR_ARCH" 2>&1 > /dev/null; then
|
||||
AC_MSG_RESULT([ok])
|
||||
MSVC_DLL="$POSSIBLE_MSVC_DLL"
|
||||
AC_MSG_CHECKING([for $1])
|
||||
BASIC_FIXUP_PATH(MSVC_DLL)
|
||||
AC_MSG_CHECKING([for $DLL_NAME])
|
||||
AC_MSG_RESULT([$MSVC_DLL])
|
||||
else
|
||||
AC_MSG_RESULT([incorrect, ignoring])
|
||||
AC_MSG_NOTICE([The file type of the located $1 is $MSVC_DLL_FILETYPE])
|
||||
AC_MSG_NOTICE([The file type of the located $DLL_NAME is $MSVC_DLL_FILETYPE])
|
||||
fi
|
||||
fi
|
||||
])
|
||||
|
||||
AC_DEFUN([TOOLCHAIN_SETUP_MSVC_DLL],
|
||||
[
|
||||
VAR_NAME="$1"
|
||||
DLL_NAME="$2"
|
||||
DLL_NAME="$1"
|
||||
MSVC_DLL=
|
||||
|
||||
if test "x$MSVC_DLL" = x; then
|
||||
@ -517,10 +558,6 @@ AC_DEFUN([TOOLCHAIN_SETUP_MSVC_DLL],
|
||||
AC_MSG_RESULT([no])
|
||||
AC_MSG_ERROR([Could not find $DLL_NAME. Please specify using --with-msvcr-dll.])
|
||||
fi
|
||||
|
||||
$1=$MSVC_DLL
|
||||
BASIC_FIXUP_PATH($1)
|
||||
AC_SUBST($1, [$]$1)
|
||||
])
|
||||
|
||||
AC_DEFUN([TOOLCHAIN_SETUP_VS_RUNTIME_DLLS],
|
||||
@ -530,14 +567,22 @@ AC_DEFUN([TOOLCHAIN_SETUP_VS_RUNTIME_DLLS],
|
||||
|
||||
if test "x$with_msvcr_dll" != x; then
|
||||
# If given explicitely by user, do not probe. If not present, fail directly.
|
||||
TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL([$DLL_NAME], [$with_msvcr_dll],
|
||||
[--with-msvcr-dll])
|
||||
TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL($MSVCR_NAME, [$with_msvcr_dll], [--with-msvcr-dll])
|
||||
if test "x$MSVC_DLL" = x; then
|
||||
AC_MSG_ERROR([Could not find a proper $MSVCR_NAME as specified by --with-msvcr-dll])
|
||||
fi
|
||||
MSVCR_DLL="$MSVC_DLL"
|
||||
elif test "x$DEVKIT_MSVCR_DLL" != x; then
|
||||
TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL($MSVCR_NAME, [$DEVKIT_MSVCR_DLL], [devkit])
|
||||
if test "x$MSVC_DLL" = x; then
|
||||
AC_MSG_ERROR([Could not find a proper $MSVCR_NAME as specified by devkit])
|
||||
fi
|
||||
MSVCR_DLL="$MSVC_DLL"
|
||||
else
|
||||
TOOLCHAIN_SETUP_MSVC_DLL([MSVCR_DLL], [${MSVCR_NAME}])
|
||||
TOOLCHAIN_SETUP_MSVC_DLL([${MSVCR_NAME}])
|
||||
MSVCR_DLL="$MSVC_DLL"
|
||||
fi
|
||||
AC_SUBST(MSVCR_DLL)
|
||||
|
||||
AC_ARG_WITH(msvcp-dll, [AS_HELP_STRING([--with-msvcp-dll],
|
||||
[path to microsoft C++ runtime dll (msvcp*.dll) (Windows only) @<:@probed@:>@])])
|
||||
@ -545,13 +590,21 @@ AC_DEFUN([TOOLCHAIN_SETUP_VS_RUNTIME_DLLS],
|
||||
if test "x$MSVCP_NAME" != "x"; then
|
||||
if test "x$with_msvcp_dll" != x; then
|
||||
# If given explicitely by user, do not probe. If not present, fail directly.
|
||||
TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL([$DLL_NAME], [$with_msvcp_dll],
|
||||
[--with-msvcp-dll])
|
||||
TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL($MSVCP_NAME, [$with_msvcp_dll], [--with-msvcp-dll])
|
||||
if test "x$MSVC_DLL" = x; then
|
||||
AC_MSG_ERROR([Could not find a proper $MSVCP_NAME as specified by --with-msvcp-dll])
|
||||
fi
|
||||
MSVCP_DLL="$MSVC_DLL"
|
||||
elif test "x$DEVKIT_MSVCP_DLL" != x; then
|
||||
TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL($MSVCP_NAME, [$DEVKIT_MSVCP_DLL], [devkit])
|
||||
if test "x$MSVC_DLL" = x; then
|
||||
AC_MSG_ERROR([Could not find a proper $MSVCP_NAME as specified by devkit])
|
||||
fi
|
||||
MSVCP_DLL="$MSVC_DLL"
|
||||
else
|
||||
TOOLCHAIN_SETUP_MSVC_DLL([MSVCP_DLL], [${MSVCP_NAME}])
|
||||
TOOLCHAIN_SETUP_MSVC_DLL([${MSVCP_NAME}])
|
||||
MSVCP_DLL="$MSVC_DLL"
|
||||
fi
|
||||
AC_SUBST(MSVCP_DLL)
|
||||
fi
|
||||
])
|
||||
|
@ -304,3 +304,4 @@ d8ebf1a5b18ccbc849f5bf0f80aa3d78583eee68 jdk9-b57
|
||||
cda6ae062f85fac5555f4e1318885b0ecd998bd1 jdk9-b59
|
||||
caa330b275f39282793466529f6864766b31d9fd jdk9-b60
|
||||
d690f489ca0bb95a6157d996da2fa72bcbcf02ea jdk9-b61
|
||||
d27f7e0a7aca129969de23e9934408a31b4abf4c jdk9-b62
|
||||
|
@ -464,3 +464,4 @@ ee878f3d6732856f7725c590312bfbe2ffa52cc7 jdk9-b58
|
||||
96bcaec07cb165782bae1b9a1f28450b37a10e3a jdk9-b59
|
||||
9c916db4bf3bc164a47b5a9cefe5ffd71e111f6a jdk9-b60
|
||||
715d2da5801c410746e92f08066d53bde1496286 jdk9-b61
|
||||
1eab877142cce6ca06e556e2ad0af688f993f00b jdk9-b62
|
||||
|
@ -74,7 +74,8 @@ LP64=1
|
||||
|
||||
!if "$(BUILDARCH)" == "i486"
|
||||
MACHINE=I386
|
||||
CXX_FLAGS=$(CXX_FLAGS) /D "IA32"
|
||||
# VS2013 generates bad l2f without /arch:IA32
|
||||
CXX_FLAGS=$(CXX_FLAGS) /D "IA32" /arch:IA32
|
||||
!endif
|
||||
|
||||
CXX_FLAGS=$(CXX_FLAGS) /D "WIN32" /D "_WINDOWS"
|
||||
|
@ -449,7 +449,7 @@ reg_class no_special_reg32(
|
||||
R26
|
||||
/* R27, */ // heapbase
|
||||
/* R28, */ // thread
|
||||
/* R29, */ // fp
|
||||
R29, // fp
|
||||
/* R30, */ // lr
|
||||
/* R31 */ // sp
|
||||
);
|
||||
@ -483,7 +483,7 @@ reg_class no_special_reg(
|
||||
R26, R26_H,
|
||||
/* R27, R27_H, */ // heapbase
|
||||
/* R28, R28_H, */ // thread
|
||||
/* R29, R29_H, */ // fp
|
||||
R29, R29_H, // fp
|
||||
/* R30, R30_H, */ // lr
|
||||
/* R31, R31_H */ // sp
|
||||
);
|
||||
@ -758,6 +758,8 @@ definitions %{
|
||||
|
||||
source_hpp %{
|
||||
|
||||
#include "memory/cardTableModRefBS.hpp"
|
||||
|
||||
class CallStubImpl {
|
||||
|
||||
//--------------------------------------------------------------
|
||||
@ -2538,7 +2540,7 @@ RegMask Matcher::modL_proj_mask() {
|
||||
}
|
||||
|
||||
const RegMask Matcher::method_handle_invoke_SP_save_mask() {
|
||||
return RegMask();
|
||||
return FP_REG_mask();
|
||||
}
|
||||
|
||||
// helper for encoding java_to_runtime calls on sim
|
||||
|
@ -77,12 +77,6 @@ inline frame::frame(intptr_t* sp, intptr_t* fp, address pc) {
|
||||
inline frame::frame(intptr_t* sp, intptr_t* unextended_sp, intptr_t* fp, address pc) {
|
||||
intptr_t a = intptr_t(sp);
|
||||
intptr_t b = intptr_t(fp);
|
||||
#ifndef PRODUCT
|
||||
if (fp)
|
||||
if (sp > fp || (fp - sp > 0x100000))
|
||||
for(;;)
|
||||
asm("nop");
|
||||
#endif
|
||||
_sp = sp;
|
||||
_unextended_sp = unextended_sp;
|
||||
_fp = fp;
|
||||
@ -104,12 +98,6 @@ inline frame::frame(intptr_t* sp, intptr_t* unextended_sp, intptr_t* fp, address
|
||||
inline frame::frame(intptr_t* sp, intptr_t* fp) {
|
||||
intptr_t a = intptr_t(sp);
|
||||
intptr_t b = intptr_t(fp);
|
||||
#ifndef PRODUCT
|
||||
if (fp)
|
||||
if (sp > fp || (fp - sp > 0x100000))
|
||||
for(;;)
|
||||
asm("nop");
|
||||
#endif
|
||||
_sp = sp;
|
||||
_unextended_sp = sp;
|
||||
_fp = fp;
|
||||
|
@ -32,22 +32,14 @@
|
||||
|
||||
#include "compiler/disassembler.hpp"
|
||||
#include "memory/resourceArea.hpp"
|
||||
#include "nativeInst_aarch64.hpp"
|
||||
#include "opto/compile.hpp"
|
||||
#include "opto/node.hpp"
|
||||
#include "runtime/biasedLocking.hpp"
|
||||
#include "runtime/icache.hpp"
|
||||
#include "runtime/interfaceSupport.hpp"
|
||||
#include "runtime/sharedRuntime.hpp"
|
||||
|
||||
// #include "gc_interface/collectedHeap.inline.hpp"
|
||||
// #include "interpreter/interpreter.hpp"
|
||||
// #include "memory/cardTableModRefBS.hpp"
|
||||
// #include "prims/methodHandles.hpp"
|
||||
// #include "runtime/biasedLocking.hpp"
|
||||
// #include "runtime/interfaceSupport.hpp"
|
||||
// #include "runtime/objectMonitor.hpp"
|
||||
// #include "runtime/os.hpp"
|
||||
// #include "runtime/sharedRuntime.hpp"
|
||||
// #include "runtime/stubRoutines.hpp"
|
||||
|
||||
#if INCLUDE_ALL_GCS
|
||||
#include "gc_implementation/g1/g1CollectedHeap.inline.hpp"
|
||||
#include "gc_implementation/g1/g1SATBCardTableModRefBS.hpp"
|
||||
|
@ -25,7 +25,7 @@
|
||||
* @test
|
||||
* @bug 8015396
|
||||
* @summary double a%b returns NaN for some (a,b) (|a| < inf, |b|>0) (on Core i7 980X)
|
||||
*
|
||||
* @ignore 8015396
|
||||
* @run main ModNaN
|
||||
*/
|
||||
public class ModNaN {
|
||||
|
@ -304,3 +304,4 @@ c76339e86ea7da5d9ac7856f3fae9ef73eef04a2 jdk9-b57
|
||||
48ee960f29df93a9b2a895621321358a86909086 jdk9-b59
|
||||
84c5527f742bc64562e47d3149c16197fe1c4c1a jdk9-b60
|
||||
da84dcac1b0b12c5b836b05ac75ecbfadee0cd32 jdk9-b61
|
||||
49118e68fbd4cc0044e718c47db681946d5efd69 jdk9-b62
|
||||
|
@ -711,7 +711,7 @@ public final class JceKeyStore extends KeyStoreSpi {
|
||||
cf = CertificateFactory.getInstance("X509");
|
||||
} else {
|
||||
// version 2
|
||||
cfs = new Hashtable<String, CertificateFactory>(3);
|
||||
cfs = new Hashtable<>(3);
|
||||
}
|
||||
|
||||
entries.clear();
|
||||
|
@ -56,7 +56,7 @@ abstract class PBEKeyFactory extends SecretKeyFactorySpi {
|
||||
}
|
||||
|
||||
static {
|
||||
validTypes = new HashSet<String>(17);
|
||||
validTypes = new HashSet<>(17);
|
||||
validTypes.add("PBEWithMD5AndDES".toUpperCase(Locale.ENGLISH));
|
||||
validTypes.add("PBEWithSHA1AndDESede".toUpperCase(Locale.ENGLISH));
|
||||
validTypes.add("PBEWithSHA1AndRC2_40".toUpperCase(Locale.ENGLISH));
|
||||
|
@ -115,7 +115,7 @@ public final class SunJCE extends Provider {
|
||||
final String BLOCK_PADS = "NOPADDING|PKCS5PADDING|ISO10126PADDING";
|
||||
|
||||
AccessController.doPrivileged(
|
||||
new java.security.PrivilegedAction<Object>() {
|
||||
new java.security.PrivilegedAction<>() {
|
||||
public Object run() {
|
||||
|
||||
/*
|
||||
|
@ -63,7 +63,7 @@ public class KeyManagerFactory {
|
||||
*/
|
||||
public final static String getDefaultAlgorithm() {
|
||||
String type;
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty("sun.ssl.keymanager.type");
|
||||
}
|
||||
|
@ -63,7 +63,7 @@ public class TrustManagerFactory {
|
||||
*/
|
||||
public final static String getDefaultAlgorithm() {
|
||||
String type;
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty("sun.ssl.trustmanager.type");
|
||||
}
|
||||
|
@ -32,9 +32,9 @@ import sun.reflect.Reflection;
|
||||
|
||||
/**
|
||||
* Every Java application has a single instance of class
|
||||
* <code>Runtime</code> that allows the application to interface with
|
||||
* {@code Runtime} that allows the application to interface with
|
||||
* the environment in which the application is running. The current
|
||||
* runtime can be obtained from the <code>getRuntime</code> method.
|
||||
* runtime can be obtained from the {@code getRuntime} method.
|
||||
* <p>
|
||||
* An application cannot create its own instance of this class.
|
||||
*
|
||||
@ -48,10 +48,10 @@ public class Runtime {
|
||||
|
||||
/**
|
||||
* Returns the runtime object associated with the current Java application.
|
||||
* Most of the methods of class <code>Runtime</code> are instance
|
||||
* Most of the methods of class {@code Runtime} are instance
|
||||
* methods and must be invoked with respect to the current runtime object.
|
||||
*
|
||||
* @return the <code>Runtime</code> object associated with the current
|
||||
* @return the {@code Runtime} object associated with the current
|
||||
* Java application.
|
||||
*/
|
||||
public static Runtime getRuntime() {
|
||||
@ -72,8 +72,7 @@ public class Runtime {
|
||||
* if any, are started in some unspecified order and allowed to run
|
||||
* concurrently until they finish. In the second phase all uninvoked
|
||||
* finalizers are run if {@link #runFinalizersOnExit finalization-on-exit}
|
||||
* has been enabled. Once this is done the virtual machine {@link #halt
|
||||
* halts}.
|
||||
* has been enabled. Once this is done the virtual machine {@link #halt halts}.
|
||||
*
|
||||
* <p> If this method is invoked after the virtual machine has begun its
|
||||
* shutdown sequence then if shutdown hooks are being run this method will
|
||||
@ -82,7 +81,7 @@ public class Runtime {
|
||||
* with the given status code if the status is nonzero; otherwise, it
|
||||
* blocks indefinitely.
|
||||
*
|
||||
* <p> The <tt>{@link System#exit(int) System.exit}</tt> method is the
|
||||
* <p> The {@link System#exit(int) System.exit} method is the
|
||||
* conventional and convenient means of invoking this method.
|
||||
*
|
||||
* @param status
|
||||
@ -90,8 +89,8 @@ public class Runtime {
|
||||
* indicates abnormal termination.
|
||||
*
|
||||
* @throws SecurityException
|
||||
* If a security manager is present and its <tt>{@link
|
||||
* SecurityManager#checkExit checkExit}</tt> method does not permit
|
||||
* If a security manager is present and its
|
||||
* {@link SecurityManager#checkExit checkExit} method does not permit
|
||||
* exiting with the specified status
|
||||
*
|
||||
* @see java.lang.SecurityException
|
||||
@ -118,11 +117,11 @@ public class Runtime {
|
||||
* <ul>
|
||||
*
|
||||
* <li> The program <i>exits</i> normally, when the last non-daemon
|
||||
* thread exits or when the <tt>{@link #exit exit}</tt> (equivalently,
|
||||
* thread exits or when the {@link #exit exit} (equivalently,
|
||||
* {@link System#exit(int) System.exit}) method is invoked, or
|
||||
*
|
||||
* <li> The virtual machine is <i>terminated</i> in response to a
|
||||
* user interrupt, such as typing <tt>^C</tt>, or a system-wide event,
|
||||
* user interrupt, such as typing {@code ^C}, or a system-wide event,
|
||||
* such as user logoff or system shutdown.
|
||||
*
|
||||
* </ul>
|
||||
@ -134,17 +133,16 @@ public class Runtime {
|
||||
* run all uninvoked finalizers if finalization-on-exit has been enabled.
|
||||
* Finally, the virtual machine will halt. Note that daemon threads will
|
||||
* continue to run during the shutdown sequence, as will non-daemon threads
|
||||
* if shutdown was initiated by invoking the <tt>{@link #exit exit}</tt>
|
||||
* method.
|
||||
* if shutdown was initiated by invoking the {@link #exit exit} method.
|
||||
*
|
||||
* <p> Once the shutdown sequence has begun it can be stopped only by
|
||||
* invoking the <tt>{@link #halt halt}</tt> method, which forcibly
|
||||
* invoking the {@link #halt halt} method, which forcibly
|
||||
* terminates the virtual machine.
|
||||
*
|
||||
* <p> Once the shutdown sequence has begun it is impossible to register a
|
||||
* new shutdown hook or de-register a previously-registered hook.
|
||||
* Attempting either of these operations will cause an
|
||||
* <tt>{@link IllegalStateException}</tt> to be thrown.
|
||||
* {@link IllegalStateException} to be thrown.
|
||||
*
|
||||
* <p> Shutdown hooks run at a delicate time in the life cycle of a virtual
|
||||
* machine and should therefore be coded defensively. They should, in
|
||||
@ -156,7 +154,7 @@ public class Runtime {
|
||||
* deadlocks.
|
||||
*
|
||||
* <p> Shutdown hooks should also finish their work quickly. When a
|
||||
* program invokes <tt>{@link #exit exit}</tt> the expectation is
|
||||
* program invokes {@link #exit exit} the expectation is
|
||||
* that the virtual machine will promptly shut down and exit. When the
|
||||
* virtual machine is terminated due to user logoff or system shutdown the
|
||||
* underlying operating system may only allow a fixed amount of time in
|
||||
@ -165,17 +163,17 @@ public class Runtime {
|
||||
* hook.
|
||||
*
|
||||
* <p> Uncaught exceptions are handled in shutdown hooks just as in any
|
||||
* other thread, by invoking the <tt>{@link ThreadGroup#uncaughtException
|
||||
* uncaughtException}</tt> method of the thread's <tt>{@link
|
||||
* ThreadGroup}</tt> object. The default implementation of this method
|
||||
* prints the exception's stack trace to <tt>{@link System#err}</tt> and
|
||||
* other thread, by invoking the
|
||||
* {@link ThreadGroup#uncaughtException uncaughtException} method of the
|
||||
* thread's {@link ThreadGroup} object. The default implementation of this
|
||||
* method prints the exception's stack trace to {@link System#err} and
|
||||
* terminates the thread; it does not cause the virtual machine to exit or
|
||||
* halt.
|
||||
*
|
||||
* <p> In rare circumstances the virtual machine may <i>abort</i>, that is,
|
||||
* stop running without shutting down cleanly. This occurs when the
|
||||
* virtual machine is terminated externally, for example with the
|
||||
* <tt>SIGKILL</tt> signal on Unix or the <tt>TerminateProcess</tt> call on
|
||||
* {@code SIGKILL} signal on Unix or the {@code TerminateProcess} call on
|
||||
* Microsoft Windows. The virtual machine may also abort if a native
|
||||
* method goes awry by, for example, corrupting internal data structures or
|
||||
* attempting to access nonexistent memory. If the virtual machine aborts
|
||||
@ -183,7 +181,7 @@ public class Runtime {
|
||||
* will be run.
|
||||
*
|
||||
* @param hook
|
||||
* An initialized but unstarted <tt>{@link Thread}</tt> object
|
||||
* An initialized but unstarted {@link Thread} object
|
||||
*
|
||||
* @throws IllegalArgumentException
|
||||
* If the specified hook has already been registered,
|
||||
@ -196,7 +194,7 @@ public class Runtime {
|
||||
*
|
||||
* @throws SecurityException
|
||||
* If a security manager is present and it denies
|
||||
* <tt>{@link RuntimePermission}("shutdownHooks")</tt>
|
||||
* {@link RuntimePermission}("shutdownHooks")
|
||||
*
|
||||
* @see #removeShutdownHook
|
||||
* @see #halt(int)
|
||||
@ -212,11 +210,11 @@ public class Runtime {
|
||||
}
|
||||
|
||||
/**
|
||||
* De-registers a previously-registered virtual-machine shutdown hook. <p>
|
||||
* De-registers a previously-registered virtual-machine shutdown hook.
|
||||
*
|
||||
* @param hook the hook to remove
|
||||
* @return <tt>true</tt> if the specified hook had previously been
|
||||
* registered and was successfully de-registered, <tt>false</tt>
|
||||
* @return {@code true} if the specified hook had previously been
|
||||
* registered and was successfully de-registered, {@code false}
|
||||
* otherwise.
|
||||
*
|
||||
* @throws IllegalStateException
|
||||
@ -225,7 +223,7 @@ public class Runtime {
|
||||
*
|
||||
* @throws SecurityException
|
||||
* If a security manager is present and it denies
|
||||
* <tt>{@link RuntimePermission}("shutdownHooks")</tt>
|
||||
* {@link RuntimePermission}("shutdownHooks")
|
||||
*
|
||||
* @see #addShutdownHook
|
||||
* @see #exit(int)
|
||||
@ -244,23 +242,23 @@ public class Runtime {
|
||||
* method never returns normally.
|
||||
*
|
||||
* <p> This method should be used with extreme caution. Unlike the
|
||||
* <tt>{@link #exit exit}</tt> method, this method does not cause shutdown
|
||||
* {@link #exit exit} method, this method does not cause shutdown
|
||||
* hooks to be started and does not run uninvoked finalizers if
|
||||
* finalization-on-exit has been enabled. If the shutdown sequence has
|
||||
* already been initiated then this method does not wait for any running
|
||||
* shutdown hooks or finalizers to finish their work.
|
||||
*
|
||||
* @param status
|
||||
* Termination status. By convention, a nonzero status code
|
||||
* indicates abnormal termination. If the <tt>{@link Runtime#exit
|
||||
* exit}</tt> (equivalently, <tt>{@link System#exit(int)
|
||||
* System.exit}</tt>) method has already been invoked then this
|
||||
* status code will override the status code passed to that method.
|
||||
* Termination status. By convention, a nonzero status code
|
||||
* indicates abnormal termination. If the {@link Runtime#exit exit}
|
||||
* (equivalently, {@link System#exit(int) System.exit}) method
|
||||
* has already been invoked then this status code
|
||||
* will override the status code passed to that method.
|
||||
*
|
||||
* @throws SecurityException
|
||||
* If a security manager is present and its <tt>{@link
|
||||
* SecurityManager#checkExit checkExit}</tt> method does not permit
|
||||
* an exit with the specified status
|
||||
* If a security manager is present and its
|
||||
* {@link SecurityManager#checkExit checkExit} method
|
||||
* does not permit an exit with the specified status
|
||||
*
|
||||
* @see #exit
|
||||
* @see #addShutdownHook
|
||||
@ -282,7 +280,7 @@ public class Runtime {
|
||||
* By default, finalization on exit is disabled.
|
||||
*
|
||||
* <p>If there is a security manager,
|
||||
* its <code>checkExit</code> method is first called
|
||||
* its {@code checkExit} method is first called
|
||||
* with 0 as its argument to ensure the exit is allowed.
|
||||
* This could result in a SecurityException.
|
||||
*
|
||||
@ -293,7 +291,7 @@ public class Runtime {
|
||||
* behavior or deadlock.
|
||||
*
|
||||
* @throws SecurityException
|
||||
* if a security manager exists and its <code>checkExit</code>
|
||||
* if a security manager exists and its {@code checkExit}
|
||||
* method doesn't allow the exit.
|
||||
*
|
||||
* @see java.lang.Runtime#exit(int)
|
||||
@ -318,9 +316,9 @@ public class Runtime {
|
||||
* Executes the specified string command in a separate process.
|
||||
*
|
||||
* <p>This is a convenience method. An invocation of the form
|
||||
* <tt>exec(command)</tt>
|
||||
* {@code exec(command)}
|
||||
* behaves in exactly the same way as the invocation
|
||||
* <tt>{@link #exec(String, String[], File) exec}(command, null, null)</tt>.
|
||||
* {@link #exec(String, String[], File) exec}{@code (command, null, null)}.
|
||||
*
|
||||
* @param command a specified system command.
|
||||
*
|
||||
@ -335,10 +333,10 @@ public class Runtime {
|
||||
* If an I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>command</code> is <code>null</code>
|
||||
* If {@code command} is {@code null}
|
||||
*
|
||||
* @throws IllegalArgumentException
|
||||
* If <code>command</code> is empty
|
||||
* If {@code command} is empty
|
||||
*
|
||||
* @see #exec(String[], String[], File)
|
||||
* @see ProcessBuilder
|
||||
@ -352,16 +350,16 @@ public class Runtime {
|
||||
* specified environment.
|
||||
*
|
||||
* <p>This is a convenience method. An invocation of the form
|
||||
* <tt>exec(command, envp)</tt>
|
||||
* {@code exec(command, envp)}
|
||||
* behaves in exactly the same way as the invocation
|
||||
* <tt>{@link #exec(String, String[], File) exec}(command, envp, null)</tt>.
|
||||
* {@link #exec(String, String[], File) exec}{@code (command, envp, null)}.
|
||||
*
|
||||
* @param command a specified system command.
|
||||
*
|
||||
* @param envp array of strings, each element of which
|
||||
* has environment variable settings in the format
|
||||
* <i>name</i>=<i>value</i>, or
|
||||
* <tt>null</tt> if the subprocess should inherit
|
||||
* {@code null} if the subprocess should inherit
|
||||
* the environment of the current process.
|
||||
*
|
||||
* @return A new {@link Process} object for managing the subprocess
|
||||
@ -375,11 +373,11 @@ public class Runtime {
|
||||
* If an I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>command</code> is <code>null</code>,
|
||||
* or one of the elements of <code>envp</code> is <code>null</code>
|
||||
* If {@code command} is {@code null},
|
||||
* or one of the elements of {@code envp} is {@code null}
|
||||
*
|
||||
* @throws IllegalArgumentException
|
||||
* If <code>command</code> is empty
|
||||
* If {@code command} is empty
|
||||
*
|
||||
* @see #exec(String[], String[], File)
|
||||
* @see ProcessBuilder
|
||||
@ -393,29 +391,29 @@ public class Runtime {
|
||||
* specified environment and working directory.
|
||||
*
|
||||
* <p>This is a convenience method. An invocation of the form
|
||||
* <tt>exec(command, envp, dir)</tt>
|
||||
* {@code exec(command, envp, dir)}
|
||||
* behaves in exactly the same way as the invocation
|
||||
* <tt>{@link #exec(String[], String[], File) exec}(cmdarray, envp, dir)</tt>,
|
||||
* where <code>cmdarray</code> is an array of all the tokens in
|
||||
* <code>command</code>.
|
||||
* {@link #exec(String[], String[], File) exec}{@code (cmdarray, envp, dir)},
|
||||
* where {@code cmdarray} is an array of all the tokens in
|
||||
* {@code command}.
|
||||
*
|
||||
* <p>More precisely, the <code>command</code> string is broken
|
||||
* <p>More precisely, the {@code command} string is broken
|
||||
* into tokens using a {@link StringTokenizer} created by the call
|
||||
* <code>new {@link StringTokenizer}(command)</code> with no
|
||||
* {@code new {@link StringTokenizer}(command)} with no
|
||||
* further modification of the character categories. The tokens
|
||||
* produced by the tokenizer are then placed in the new string
|
||||
* array <code>cmdarray</code>, in the same order.
|
||||
* array {@code cmdarray}, in the same order.
|
||||
*
|
||||
* @param command a specified system command.
|
||||
*
|
||||
* @param envp array of strings, each element of which
|
||||
* has environment variable settings in the format
|
||||
* <i>name</i>=<i>value</i>, or
|
||||
* <tt>null</tt> if the subprocess should inherit
|
||||
* {@code null} if the subprocess should inherit
|
||||
* the environment of the current process.
|
||||
*
|
||||
* @param dir the working directory of the subprocess, or
|
||||
* <tt>null</tt> if the subprocess should inherit
|
||||
* {@code null} if the subprocess should inherit
|
||||
* the working directory of the current process.
|
||||
*
|
||||
* @return A new {@link Process} object for managing the subprocess
|
||||
@ -429,11 +427,11 @@ public class Runtime {
|
||||
* If an I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>command</code> is <code>null</code>,
|
||||
* or one of the elements of <code>envp</code> is <code>null</code>
|
||||
* If {@code command} is {@code null},
|
||||
* or one of the elements of {@code envp} is {@code null}
|
||||
*
|
||||
* @throws IllegalArgumentException
|
||||
* If <code>command</code> is empty
|
||||
* If {@code command} is empty
|
||||
*
|
||||
* @see ProcessBuilder
|
||||
* @since 1.3
|
||||
@ -454,9 +452,9 @@ public class Runtime {
|
||||
* Executes the specified command and arguments in a separate process.
|
||||
*
|
||||
* <p>This is a convenience method. An invocation of the form
|
||||
* <tt>exec(cmdarray)</tt>
|
||||
* {@code exec(cmdarray)}
|
||||
* behaves in exactly the same way as the invocation
|
||||
* <tt>{@link #exec(String[], String[], File) exec}(cmdarray, null, null)</tt>.
|
||||
* {@link #exec(String[], String[], File) exec}{@code (cmdarray, null, null)}.
|
||||
*
|
||||
* @param cmdarray array containing the command to call and
|
||||
* its arguments.
|
||||
@ -472,12 +470,12 @@ public class Runtime {
|
||||
* If an I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>cmdarray</code> is <code>null</code>,
|
||||
* or one of the elements of <code>cmdarray</code> is <code>null</code>
|
||||
* If {@code cmdarray} is {@code null},
|
||||
* or one of the elements of {@code cmdarray} is {@code null}
|
||||
*
|
||||
* @throws IndexOutOfBoundsException
|
||||
* If <code>cmdarray</code> is an empty array
|
||||
* (has length <code>0</code>)
|
||||
* If {@code cmdarray} is an empty array
|
||||
* (has length {@code 0})
|
||||
*
|
||||
* @see ProcessBuilder
|
||||
*/
|
||||
@ -490,9 +488,9 @@ public class Runtime {
|
||||
* with the specified environment.
|
||||
*
|
||||
* <p>This is a convenience method. An invocation of the form
|
||||
* <tt>exec(cmdarray, envp)</tt>
|
||||
* {@code exec(cmdarray, envp)}
|
||||
* behaves in exactly the same way as the invocation
|
||||
* <tt>{@link #exec(String[], String[], File) exec}(cmdarray, envp, null)</tt>.
|
||||
* {@link #exec(String[], String[], File) exec}{@code (cmdarray, envp, null)}.
|
||||
*
|
||||
* @param cmdarray array containing the command to call and
|
||||
* its arguments.
|
||||
@ -500,7 +498,7 @@ public class Runtime {
|
||||
* @param envp array of strings, each element of which
|
||||
* has environment variable settings in the format
|
||||
* <i>name</i>=<i>value</i>, or
|
||||
* <tt>null</tt> if the subprocess should inherit
|
||||
* {@code null} if the subprocess should inherit
|
||||
* the environment of the current process.
|
||||
*
|
||||
* @return A new {@link Process} object for managing the subprocess
|
||||
@ -514,13 +512,13 @@ public class Runtime {
|
||||
* If an I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>cmdarray</code> is <code>null</code>,
|
||||
* or one of the elements of <code>cmdarray</code> is <code>null</code>,
|
||||
* or one of the elements of <code>envp</code> is <code>null</code>
|
||||
* If {@code cmdarray} is {@code null},
|
||||
* or one of the elements of {@code cmdarray} is {@code null},
|
||||
* or one of the elements of {@code envp} is {@code null}
|
||||
*
|
||||
* @throws IndexOutOfBoundsException
|
||||
* If <code>cmdarray</code> is an empty array
|
||||
* (has length <code>0</code>)
|
||||
* If {@code cmdarray} is an empty array
|
||||
* (has length {@code 0})
|
||||
*
|
||||
* @see ProcessBuilder
|
||||
*/
|
||||
@ -533,17 +531,17 @@ public class Runtime {
|
||||
* Executes the specified command and arguments in a separate process with
|
||||
* the specified environment and working directory.
|
||||
*
|
||||
* <p>Given an array of strings <code>cmdarray</code>, representing the
|
||||
* tokens of a command line, and an array of strings <code>envp</code>,
|
||||
* <p>Given an array of strings {@code cmdarray}, representing the
|
||||
* tokens of a command line, and an array of strings {@code envp},
|
||||
* representing "environment" variable settings, this method creates
|
||||
* a new process in which to execute the specified command.
|
||||
*
|
||||
* <p>This method checks that <code>cmdarray</code> is a valid operating
|
||||
* <p>This method checks that {@code cmdarray} is a valid operating
|
||||
* system command. Which commands are valid is system-dependent,
|
||||
* but at the very least the command must be a non-empty list of
|
||||
* non-null strings.
|
||||
*
|
||||
* <p>If <tt>envp</tt> is <tt>null</tt>, the subprocess inherits the
|
||||
* <p>If {@code envp} is {@code null}, the subprocess inherits the
|
||||
* environment settings of the current process.
|
||||
*
|
||||
* <p>A minimal set of system dependent environment variables may
|
||||
@ -554,14 +552,14 @@ public class Runtime {
|
||||
* <p>{@link ProcessBuilder#start()} is now the preferred way to
|
||||
* start a process with a modified environment.
|
||||
*
|
||||
* <p>The working directory of the new subprocess is specified by <tt>dir</tt>.
|
||||
* If <tt>dir</tt> is <tt>null</tt>, the subprocess inherits the
|
||||
* <p>The working directory of the new subprocess is specified by {@code dir}.
|
||||
* If {@code dir} is {@code null}, the subprocess inherits the
|
||||
* current working directory of the current process.
|
||||
*
|
||||
* <p>If a security manager exists, its
|
||||
* {@link SecurityManager#checkExec checkExec}
|
||||
* method is invoked with the first component of the array
|
||||
* <code>cmdarray</code> as its argument. This may result in a
|
||||
* {@code cmdarray} as its argument. This may result in a
|
||||
* {@link SecurityException} being thrown.
|
||||
*
|
||||
* <p>Starting an operating system process is highly system-dependent.
|
||||
@ -586,11 +584,11 @@ public class Runtime {
|
||||
* @param envp array of strings, each element of which
|
||||
* has environment variable settings in the format
|
||||
* <i>name</i>=<i>value</i>, or
|
||||
* <tt>null</tt> if the subprocess should inherit
|
||||
* {@code null} if the subprocess should inherit
|
||||
* the environment of the current process.
|
||||
*
|
||||
* @param dir the working directory of the subprocess, or
|
||||
* <tt>null</tt> if the subprocess should inherit
|
||||
* {@code null} if the subprocess should inherit
|
||||
* the working directory of the current process.
|
||||
*
|
||||
* @return A new {@link Process} object for managing the subprocess
|
||||
@ -607,13 +605,13 @@ public class Runtime {
|
||||
* If an I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>cmdarray</code> is <code>null</code>,
|
||||
* or one of the elements of <code>cmdarray</code> is <code>null</code>,
|
||||
* or one of the elements of <code>envp</code> is <code>null</code>
|
||||
* If {@code cmdarray} is {@code null},
|
||||
* or one of the elements of {@code cmdarray} is {@code null},
|
||||
* or one of the elements of {@code envp} is {@code null}
|
||||
*
|
||||
* @throws IndexOutOfBoundsException
|
||||
* If <code>cmdarray</code> is an empty array
|
||||
* (has length <code>0</code>)
|
||||
* If {@code cmdarray} is an empty array
|
||||
* (has length {@code 0})
|
||||
*
|
||||
* @see ProcessBuilder
|
||||
* @since 1.3
|
||||
@ -643,8 +641,8 @@ public class Runtime {
|
||||
/**
|
||||
* Returns the amount of free memory in the Java Virtual Machine.
|
||||
* Calling the
|
||||
* <code>gc</code> method may result in increasing the value returned
|
||||
* by <code>freeMemory.</code>
|
||||
* {@code gc} method may result in increasing the value returned
|
||||
* by {@code freeMemory.}
|
||||
*
|
||||
* @return an approximation to the total amount of memory currently
|
||||
* available for future allocated objects, measured in bytes.
|
||||
@ -665,9 +663,9 @@ public class Runtime {
|
||||
public native long totalMemory();
|
||||
|
||||
/**
|
||||
* Returns the maximum amount of memory that the Java virtual machine will
|
||||
* attempt to use. If there is no inherent limit then the value {@link
|
||||
* java.lang.Long#MAX_VALUE} will be returned.
|
||||
* Returns the maximum amount of memory that the Java virtual machine
|
||||
* will attempt to use. If there is no inherent limit then the value
|
||||
* {@link java.lang.Long#MAX_VALUE} will be returned.
|
||||
*
|
||||
* @return the maximum amount of memory that the virtual machine will
|
||||
* attempt to use, measured in bytes
|
||||
@ -683,10 +681,10 @@ public class Runtime {
|
||||
* returns from the method call, the virtual machine has made
|
||||
* its best effort to recycle all discarded objects.
|
||||
* <p>
|
||||
* The name <code>gc</code> stands for "garbage
|
||||
* The name {@code gc} stands for "garbage
|
||||
* collector". The virtual machine performs this recycling
|
||||
* process automatically as needed, in a separate thread, even if the
|
||||
* <code>gc</code> method is not invoked explicitly.
|
||||
* {@code gc} method is not invoked explicitly.
|
||||
* <p>
|
||||
* The method {@link System#gc()} is the conventional and convenient
|
||||
* means of invoking this method.
|
||||
@ -699,15 +697,15 @@ public class Runtime {
|
||||
/**
|
||||
* Runs the finalization methods of any objects pending finalization.
|
||||
* Calling this method suggests that the Java virtual machine expend
|
||||
* effort toward running the <code>finalize</code> methods of objects
|
||||
* that have been found to be discarded but whose <code>finalize</code>
|
||||
* effort toward running the {@code finalize} methods of objects
|
||||
* that have been found to be discarded but whose {@code finalize}
|
||||
* methods have not yet been run. When control returns from the
|
||||
* method call, the virtual machine has made a best effort to
|
||||
* complete all outstanding finalizations.
|
||||
* <p>
|
||||
* The virtual machine performs the finalization process
|
||||
* automatically as needed, in a separate thread, if the
|
||||
* <code>runFinalization</code> method is not invoked explicitly.
|
||||
* {@code runFinalization} method is not invoked explicitly.
|
||||
* <p>
|
||||
* The method {@link System#runFinalization()} is the conventional
|
||||
* and convenient means of invoking this method.
|
||||
@ -720,7 +718,7 @@ public class Runtime {
|
||||
|
||||
/**
|
||||
* Enables/Disables tracing of instructions.
|
||||
* If the <code>boolean</code> argument is <code>true</code>, this
|
||||
* If the {@code boolean} argument is {@code true}, this
|
||||
* method suggests that the Java virtual machine emit debugging
|
||||
* information for each instruction in the virtual machine as it
|
||||
* is executed. The format of this information, and the file or other
|
||||
@ -729,18 +727,18 @@ public class Runtime {
|
||||
* this feature. The destination of the trace output is system
|
||||
* dependent.
|
||||
* <p>
|
||||
* If the <code>boolean</code> argument is <code>false</code>, this
|
||||
* If the {@code boolean} argument is {@code false}, this
|
||||
* method causes the virtual machine to stop performing the
|
||||
* detailed instruction trace it is performing.
|
||||
*
|
||||
* @param on <code>true</code> to enable instruction tracing;
|
||||
* <code>false</code> to disable this feature.
|
||||
* @param on {@code true} to enable instruction tracing;
|
||||
* {@code false} to disable this feature.
|
||||
*/
|
||||
public void traceInstructions(boolean on) { }
|
||||
|
||||
/**
|
||||
* Enables/Disables tracing of method calls.
|
||||
* If the <code>boolean</code> argument is <code>true</code>, this
|
||||
* If the {@code boolean} argument is {@code true}, this
|
||||
* method suggests that the Java virtual machine emit debugging
|
||||
* information for each method in the virtual machine as it is
|
||||
* called. The format of this information, and the file or other output
|
||||
@ -751,8 +749,8 @@ public class Runtime {
|
||||
* Calling this method with argument false suggests that the
|
||||
* virtual machine cease emitting per-call debugging information.
|
||||
*
|
||||
* @param on <code>true</code> to enable instruction tracing;
|
||||
* <code>false</code> to disable this feature.
|
||||
* @param on {@code true} to enable instruction tracing;
|
||||
* {@code false} to disable this feature.
|
||||
*/
|
||||
public void traceMethodCalls(boolean on) { }
|
||||
|
||||
@ -760,7 +758,7 @@ public class Runtime {
|
||||
* Loads the native library specified by the filename argument. The filename
|
||||
* argument must be an absolute path name.
|
||||
* (for example
|
||||
* <code>Runtime.getRuntime().load("/home/avh/lib/libX11.so");</code>).
|
||||
* {@code Runtime.getRuntime().load("/home/avh/lib/libX11.so");}).
|
||||
*
|
||||
* If the filename argument, when stripped of any platform-specific library
|
||||
* prefix, path, and file extension, indicates a library whose name is,
|
||||
@ -773,8 +771,8 @@ public class Runtime {
|
||||
* Otherwise, the filename argument is mapped to a native library image in
|
||||
* an implementation-dependent manner.
|
||||
* <p>
|
||||
* First, if there is a security manager, its <code>checkLink</code>
|
||||
* method is called with the <code>filename</code> as its argument.
|
||||
* First, if there is a security manager, its {@code checkLink}
|
||||
* method is called with the {@code filename} as its argument.
|
||||
* This may result in a security exception.
|
||||
* <p>
|
||||
* This is similar to the method {@link #loadLibrary(String)}, but it
|
||||
@ -786,14 +784,14 @@ public class Runtime {
|
||||
*
|
||||
* @param filename the file to load.
|
||||
* @exception SecurityException if a security manager exists and its
|
||||
* <code>checkLink</code> method doesn't allow
|
||||
* {@code checkLink} method doesn't allow
|
||||
* loading of the specified dynamic library
|
||||
* @exception UnsatisfiedLinkError if either the filename is not an
|
||||
* absolute path name, the native library is not statically
|
||||
* linked with the VM, or the library cannot be mapped to
|
||||
* a native library image by the host system.
|
||||
* @exception NullPointerException if <code>filename</code> is
|
||||
* <code>null</code>
|
||||
* @exception NullPointerException if {@code filename} is
|
||||
* {@code null}
|
||||
* @see java.lang.Runtime#getRuntime()
|
||||
* @see java.lang.SecurityException
|
||||
* @see java.lang.SecurityManager#checkLink(java.lang.String)
|
||||
@ -816,26 +814,26 @@ public class Runtime {
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads the native library specified by the <code>libname</code>
|
||||
* argument. The <code>libname</code> argument must not contain any platform
|
||||
* Loads the native library specified by the {@code libname}
|
||||
* argument. The {@code libname} argument must not contain any platform
|
||||
* specific prefix, file extension or path. If a native library
|
||||
* called <code>libname</code> is statically linked with the VM, then the
|
||||
* JNI_OnLoad_<code>libname</code> function exported by the library is invoked.
|
||||
* called {@code libname} is statically linked with the VM, then the
|
||||
* JNI_OnLoad_{@code libname} function exported by the library is invoked.
|
||||
* See the JNI Specification for more details.
|
||||
*
|
||||
* Otherwise, the libname argument is loaded from a system library
|
||||
* location and mapped to a native library image in an implementation-
|
||||
* dependent manner.
|
||||
* <p>
|
||||
* First, if there is a security manager, its <code>checkLink</code>
|
||||
* method is called with the <code>libname</code> as its argument.
|
||||
* First, if there is a security manager, its {@code checkLink}
|
||||
* method is called with the {@code libname} as its argument.
|
||||
* This may result in a security exception.
|
||||
* <p>
|
||||
* The method {@link System#loadLibrary(String)} is the conventional
|
||||
* and convenient means of invoking this method. If native
|
||||
* methods are to be used in the implementation of a class, a standard
|
||||
* strategy is to put the native code in a library file (call it
|
||||
* <code>LibFile</code>) and then to put a static initializer:
|
||||
* {@code LibFile}) and then to put a static initializer:
|
||||
* <blockquote><pre>
|
||||
* static { System.loadLibrary("LibFile"); }
|
||||
* </pre></blockquote>
|
||||
@ -848,14 +846,14 @@ public class Runtime {
|
||||
*
|
||||
* @param libname the name of the library.
|
||||
* @exception SecurityException if a security manager exists and its
|
||||
* <code>checkLink</code> method doesn't allow
|
||||
* {@code checkLink} method doesn't allow
|
||||
* loading of the specified dynamic library
|
||||
* @exception UnsatisfiedLinkError if either the libname argument
|
||||
* contains a file path, the native library is not statically
|
||||
* linked with the VM, or the library cannot be mapped to a
|
||||
* native library image by the host system.
|
||||
* @exception NullPointerException if <code>libname</code> is
|
||||
* <code>null</code>
|
||||
* @exception NullPointerException if {@code libname} is
|
||||
* {@code null}
|
||||
* @see java.lang.SecurityException
|
||||
* @see java.lang.SecurityManager#checkLink(java.lang.String)
|
||||
*/
|
||||
@ -878,7 +876,7 @@ public class Runtime {
|
||||
|
||||
/**
|
||||
* Creates a localized version of an input stream. This method takes
|
||||
* an <code>InputStream</code> and returns an <code>InputStream</code>
|
||||
* an {@code InputStream} and returns an {@code InputStream}
|
||||
* equivalent to the argument in all respects except that it is
|
||||
* localized: as characters in the local character set are read from
|
||||
* the stream, they are automatically converted from the local
|
||||
@ -894,7 +892,7 @@ public class Runtime {
|
||||
* @see java.io.InputStreamReader#InputStreamReader(java.io.InputStream)
|
||||
* @deprecated As of JDK 1.1, the preferred way to translate a byte
|
||||
* stream in the local encoding into a character stream in Unicode is via
|
||||
* the <code>InputStreamReader</code> and <code>BufferedReader</code>
|
||||
* the {@code InputStreamReader} and {@code BufferedReader}
|
||||
* classes.
|
||||
*/
|
||||
@Deprecated
|
||||
@ -904,8 +902,8 @@ public class Runtime {
|
||||
|
||||
/**
|
||||
* Creates a localized version of an output stream. This method
|
||||
* takes an <code>OutputStream</code> and returns an
|
||||
* <code>OutputStream</code> equivalent to the argument in all respects
|
||||
* takes an {@code OutputStream} and returns an
|
||||
* {@code OutputStream} equivalent to the argument in all respects
|
||||
* except that it is localized: as Unicode characters are written to
|
||||
* the stream, they are automatically converted to the local
|
||||
* character set.
|
||||
@ -915,8 +913,8 @@ public class Runtime {
|
||||
*
|
||||
* @deprecated As of JDK 1.1, the preferred way to translate a
|
||||
* Unicode character stream into a byte stream in the local encoding is via
|
||||
* the <code>OutputStreamWriter</code>, <code>BufferedWriter</code>, and
|
||||
* <code>PrintWriter</code> classes.
|
||||
* the {@code OutputStreamWriter}, {@code BufferedWriter}, and
|
||||
* {@code PrintWriter} classes.
|
||||
*
|
||||
* @param out OutputStream to localize
|
||||
* @return a localized output stream
|
||||
|
@ -631,7 +631,7 @@ class LambdaForm {
|
||||
* as a sort of pre-invocation linkage step.)
|
||||
*/
|
||||
public void prepare() {
|
||||
if (COMPILE_THRESHOLD == 0) {
|
||||
if (COMPILE_THRESHOLD == 0 && !isCompiled) {
|
||||
compileToBytecode();
|
||||
}
|
||||
if (this.vmentry != null) {
|
||||
@ -645,11 +645,11 @@ class LambdaForm {
|
||||
|
||||
/** Generate optimizable bytecode for this form. */
|
||||
MemberName compileToBytecode() {
|
||||
MethodType invokerType = methodType();
|
||||
assert(vmentry == null || vmentry.getMethodType().basicType().equals(invokerType));
|
||||
if (vmentry != null && isCompiled) {
|
||||
return vmentry; // already compiled somehow
|
||||
}
|
||||
MethodType invokerType = methodType();
|
||||
assert(vmentry == null || vmentry.getMethodType().basicType().equals(invokerType));
|
||||
try {
|
||||
vmentry = InvokerBytecodeGenerator.generateCustomizedCode(this, invokerType);
|
||||
if (TRACE_INTERPRETER)
|
||||
|
@ -45,7 +45,7 @@ public class AtomicMoveNotSupportedException
|
||||
* @param target
|
||||
* a string identifying the target file or {@code null} if not known
|
||||
* @param reason
|
||||
* a reason message with additional information
|
||||
* a reason message with additional information or {@code null}
|
||||
*/
|
||||
public AtomicMoveNotSupportedException(String source,
|
||||
String target,
|
||||
|
@ -458,7 +458,7 @@ public final class AccessControlContext {
|
||||
Thread.dumpStack();
|
||||
final ProtectionDomain pd = context[i];
|
||||
final Debug db = debug;
|
||||
AccessController.doPrivileged (new PrivilegedAction<Void>() {
|
||||
AccessController.doPrivileged (new PrivilegedAction<>() {
|
||||
public Void run() {
|
||||
db.println("domain that failed "+pd);
|
||||
return null;
|
||||
|
@ -612,7 +612,7 @@ public final class AccessController {
|
||||
|
||||
private static ProtectionDomain getCallerPD(final Class <?> caller) {
|
||||
ProtectionDomain callerPd = doPrivileged
|
||||
(new PrivilegedAction<ProtectionDomain>() {
|
||||
(new PrivilegedAction<>() {
|
||||
public ProtectionDomain run() {
|
||||
return caller.getProtectionDomain();
|
||||
}
|
||||
|
@ -212,7 +212,7 @@ final class AllPermissionCollection
|
||||
* @return an enumeration of all the AllPermission objects.
|
||||
*/
|
||||
public Enumeration<Permission> elements() {
|
||||
return new Enumeration<Permission>() {
|
||||
return new Enumeration<>() {
|
||||
private boolean hasMore = all_allowed;
|
||||
|
||||
public boolean hasMoreElements() {
|
||||
|
@ -332,7 +332,7 @@ final class BasicPermissionCollection
|
||||
*/
|
||||
|
||||
public BasicPermissionCollection(Class<?> clazz) {
|
||||
perms = new HashMap<String, Permission>(11);
|
||||
perms = new HashMap<>(11);
|
||||
all_allowed = false;
|
||||
permClass = clazz;
|
||||
}
|
||||
@ -533,7 +533,7 @@ final class BasicPermissionCollection
|
||||
@SuppressWarnings("unchecked")
|
||||
Hashtable<String, Permission> permissions =
|
||||
(Hashtable<String, Permission>)gfields.get("permissions", null);
|
||||
perms = new HashMap<String, Permission>(permissions.size()*2);
|
||||
perms = new HashMap<>(permissions.size()*2);
|
||||
perms.putAll(permissions);
|
||||
|
||||
// Get all_allowed
|
||||
|
@ -543,7 +543,7 @@ public class CodeSource implements java.io.Serializable {
|
||||
if (size > 0) {
|
||||
// we know of 3 different cert types: X.509, PGP, SDSI, which
|
||||
// could all be present in the stream at the same time
|
||||
cfs = new Hashtable<String, CertificateFactory>(3);
|
||||
cfs = new Hashtable<>(3);
|
||||
this.certs = new java.security.cert.Certificate[size];
|
||||
}
|
||||
|
||||
|
@ -185,7 +185,7 @@ public abstract class Identity implements Principal, Serializable {
|
||||
|
||||
check("setIdentityPublicKey");
|
||||
this.publicKey = key;
|
||||
certificates = new Vector<Certificate>();
|
||||
certificates = new Vector<>();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -248,7 +248,7 @@ public abstract class Identity implements Principal, Serializable {
|
||||
check("addIdentityCertificate");
|
||||
|
||||
if (certificates == null) {
|
||||
certificates = new Vector<Certificate>();
|
||||
certificates = new Vector<>();
|
||||
}
|
||||
if (publicKey != null) {
|
||||
if (!keyEquals(publicKey, certificate.getPublicKey())) {
|
||||
|
@ -74,7 +74,7 @@ class IdentityScope extends Identity {
|
||||
private static void initializeSystemScope() {
|
||||
|
||||
String classname = AccessController.doPrivileged(
|
||||
new PrivilegedAction<String>() {
|
||||
new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty("system.scope");
|
||||
}
|
||||
|
@ -976,7 +976,7 @@ public class KeyStore {
|
||||
*/
|
||||
public final static String getDefaultType() {
|
||||
String kstype;
|
||||
kstype = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
kstype = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty(KEYSTORE_TYPE);
|
||||
}
|
||||
|
@ -99,7 +99,7 @@ implements Serializable
|
||||
* Creates a new Permissions object containing no PermissionCollections.
|
||||
*/
|
||||
public Permissions() {
|
||||
permsMap = new HashMap<Class<?>, PermissionCollection>(11);
|
||||
permsMap = new HashMap<>(11);
|
||||
allPermission = null;
|
||||
}
|
||||
|
||||
@ -394,7 +394,7 @@ implements Serializable
|
||||
@SuppressWarnings("unchecked")
|
||||
Hashtable<Class<?>, PermissionCollection> perms =
|
||||
(Hashtable<Class<?>, PermissionCollection>)gfields.get("perms", null);
|
||||
permsMap = new HashMap<Class<?>, PermissionCollection>(perms.size()*2);
|
||||
permsMap = new HashMap<>(perms.size()*2);
|
||||
permsMap.putAll(perms);
|
||||
|
||||
// Set hasUnresolved
|
||||
@ -488,7 +488,7 @@ implements Serializable
|
||||
*/
|
||||
|
||||
PermissionsHash() {
|
||||
permsMap = new HashMap<Permission, Permission>(11);
|
||||
permsMap = new HashMap<>(11);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -597,7 +597,7 @@ implements Serializable
|
||||
@SuppressWarnings("unchecked")
|
||||
Hashtable<Permission, Permission> perms =
|
||||
(Hashtable<Permission, Permission>)gfields.get("perms", null);
|
||||
permsMap = new HashMap<Permission, Permission>(perms.size()*2);
|
||||
permsMap = new HashMap<>(perms.size()*2);
|
||||
permsMap.putAll(perms);
|
||||
}
|
||||
}
|
||||
|
@ -170,7 +170,7 @@ public abstract class Policy {
|
||||
PolicyInfo pinfo = policy.get();
|
||||
if (pinfo.policy == null) {
|
||||
String policy_class = AccessController.doPrivileged(
|
||||
new PrivilegedAction<String>() {
|
||||
new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty("policy.provider");
|
||||
}
|
||||
@ -199,7 +199,7 @@ public abstract class Policy {
|
||||
|
||||
final String pc = policy_class;
|
||||
Policy pol = AccessController.doPrivileged(
|
||||
new PrivilegedAction<Policy>() {
|
||||
new PrivilegedAction<>() {
|
||||
public Policy run() {
|
||||
try {
|
||||
ClassLoader cl =
|
||||
@ -303,7 +303,7 @@ public abstract class Policy {
|
||||
*/
|
||||
|
||||
ProtectionDomain policyDomain =
|
||||
AccessController.doPrivileged(new PrivilegedAction<ProtectionDomain>() {
|
||||
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public ProtectionDomain run() {
|
||||
return p.getClass().getProtectionDomain();
|
||||
}
|
||||
|
@ -367,7 +367,7 @@ public class ProtectionDomain {
|
||||
|
||||
PermissionCollection perms =
|
||||
java.security.AccessController.doPrivileged
|
||||
(new java.security.PrivilegedAction<PermissionCollection>() {
|
||||
(new java.security.PrivilegedAction<>() {
|
||||
public PermissionCollection run() {
|
||||
Policy p = Policy.getPolicyNoCheck();
|
||||
return p.getPermissions(ProtectionDomain.this);
|
||||
|
@ -711,7 +711,7 @@ public abstract class Provider extends Properties {
|
||||
|
||||
legacyChanged = true;
|
||||
if (legacyStrings == null) {
|
||||
legacyStrings = new LinkedHashMap<String,String>();
|
||||
legacyStrings = new LinkedHashMap<>();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
@ -773,7 +773,7 @@ public abstract class Provider extends Properties {
|
||||
private void implReplaceAll(BiFunction<? super Object, ? super Object, ? extends Object> function) {
|
||||
legacyChanged = true;
|
||||
if (legacyStrings == null) {
|
||||
legacyStrings = new LinkedHashMap<String,String>();
|
||||
legacyStrings = new LinkedHashMap<>();
|
||||
} else {
|
||||
legacyStrings.replaceAll((BiFunction<? super String, ? super String, ? extends String>) function);
|
||||
}
|
||||
@ -905,7 +905,7 @@ public abstract class Provider extends Properties {
|
||||
}
|
||||
serviceSet = null;
|
||||
if (legacyMap == null) {
|
||||
legacyMap = new LinkedHashMap<ServiceKey,Service>();
|
||||
legacyMap = new LinkedHashMap<>();
|
||||
} else {
|
||||
legacyMap.clear();
|
||||
}
|
||||
@ -1133,7 +1133,7 @@ public abstract class Provider extends Properties {
|
||||
("service.getProvider() must match this Provider object");
|
||||
}
|
||||
if (serviceMap == null) {
|
||||
serviceMap = new LinkedHashMap<ServiceKey,Service>();
|
||||
serviceMap = new LinkedHashMap<>();
|
||||
}
|
||||
servicesChanged = true;
|
||||
String type = s.getType();
|
||||
@ -1305,7 +1305,7 @@ public abstract class Provider extends Properties {
|
||||
}
|
||||
|
||||
static {
|
||||
knownEngines = new HashMap<String,EngineDescription>();
|
||||
knownEngines = new HashMap<>();
|
||||
// JCA
|
||||
addEngine("AlgorithmParameterGenerator", false, null);
|
||||
addEngine("AlgorithmParameters", false, null);
|
||||
@ -1431,14 +1431,14 @@ public abstract class Provider extends Properties {
|
||||
|
||||
private void addAlias(String alias) {
|
||||
if (aliases.isEmpty()) {
|
||||
aliases = new ArrayList<String>(2);
|
||||
aliases = new ArrayList<>(2);
|
||||
}
|
||||
aliases.add(alias);
|
||||
}
|
||||
|
||||
void addAttribute(String type, String value) {
|
||||
if (attributes.isEmpty()) {
|
||||
attributes = new HashMap<UString,String>(8);
|
||||
attributes = new HashMap<>(8);
|
||||
}
|
||||
attributes.put(new UString(type), value);
|
||||
}
|
||||
@ -1471,12 +1471,12 @@ public abstract class Provider extends Properties {
|
||||
if (aliases == null) {
|
||||
this.aliases = Collections.<String>emptyList();
|
||||
} else {
|
||||
this.aliases = new ArrayList<String>(aliases);
|
||||
this.aliases = new ArrayList<>(aliases);
|
||||
}
|
||||
if (attributes == null) {
|
||||
this.attributes = Collections.<UString,String>emptyMap();
|
||||
} else {
|
||||
this.attributes = new HashMap<UString,String>();
|
||||
this.attributes = new HashMap<>();
|
||||
for (Map.Entry<String,String> entry : attributes.entrySet()) {
|
||||
this.attributes.put(new UString(entry.getKey()), entry.getValue());
|
||||
}
|
||||
@ -1644,7 +1644,7 @@ public abstract class Provider extends Properties {
|
||||
("class configured for " + type + " (provider: " +
|
||||
provider.getName() + ") is not public.");
|
||||
}
|
||||
classRef = new WeakReference<Class<?>>(clazz);
|
||||
classRef = new WeakReference<>(clazz);
|
||||
}
|
||||
return clazz;
|
||||
} catch (ClassNotFoundException e) {
|
||||
|
@ -616,7 +616,7 @@ public class SecureRandom extends java.util.Random {
|
||||
throws NoSuchAlgorithmException {
|
||||
|
||||
String property = AccessController.doPrivileged(
|
||||
new PrivilegedAction<String>() {
|
||||
new PrivilegedAction<>() {
|
||||
@Override
|
||||
public String run() {
|
||||
return Security.getProperty(
|
||||
|
@ -66,7 +66,7 @@ public final class Security {
|
||||
// things in initialize that might require privs.
|
||||
// (the FileInputStream call and the File.exists call,
|
||||
// the securityPropFile call, etc)
|
||||
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
||||
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public Void run() {
|
||||
initialize();
|
||||
return null;
|
||||
@ -810,7 +810,7 @@ public final class Security {
|
||||
final boolean pd = key.equals("package.definition");
|
||||
|
||||
if (pa || pd) {
|
||||
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
||||
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public Void run() {
|
||||
try {
|
||||
/* Get the class via the bootstrap class loader. */
|
||||
|
@ -265,7 +265,7 @@ public abstract class Signature extends SignatureSpi {
|
||||
private final static Map<String,Boolean> signatureInfo;
|
||||
|
||||
static {
|
||||
signatureInfo = new ConcurrentHashMap<String,Boolean>();
|
||||
signatureInfo = new ConcurrentHashMap<>();
|
||||
Boolean TRUE = Boolean.TRUE;
|
||||
// pre-initialize with values for our SignatureSpi implementations
|
||||
signatureInfo.put("sun.security.provider.DSA$RawDSA", TRUE);
|
||||
|
@ -140,7 +140,7 @@ public abstract class Signer extends Identity {
|
||||
}
|
||||
try {
|
||||
AccessController.doPrivileged(
|
||||
new PrivilegedExceptionAction<Void>() {
|
||||
new PrivilegedExceptionAction<>() {
|
||||
public Void run() throws KeyManagementException {
|
||||
setPublicKey(pub);
|
||||
return null;
|
||||
|
@ -560,7 +560,7 @@ implements java.io.Serializable
|
||||
if (size > 0) {
|
||||
// we know of 3 different cert types: X.509, PGP, SDSI, which
|
||||
// could all be present in the stream at the same time
|
||||
cfs = new Hashtable<String, CertificateFactory>(3);
|
||||
cfs = new Hashtable<>(3);
|
||||
this.certs = new java.security.cert.Certificate[size];
|
||||
}
|
||||
|
||||
|
@ -61,7 +61,7 @@ implements java.io.Serializable
|
||||
*
|
||||
*/
|
||||
public UnresolvedPermissionCollection() {
|
||||
perms = new HashMap<String, List<UnresolvedPermission>>(11);
|
||||
perms = new HashMap<>(11);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -82,7 +82,7 @@ implements java.io.Serializable
|
||||
synchronized (this) {
|
||||
v = perms.get(up.getName());
|
||||
if (v == null) {
|
||||
v = new ArrayList<UnresolvedPermission>();
|
||||
v = new ArrayList<>();
|
||||
perms.put(up.getName(), v);
|
||||
}
|
||||
}
|
||||
@ -203,7 +203,7 @@ implements java.io.Serializable
|
||||
Hashtable<String, Vector<UnresolvedPermission>> permissions =
|
||||
(Hashtable<String, Vector<UnresolvedPermission>>)
|
||||
gfields.get("permissions", null);
|
||||
perms = new HashMap<String, List<UnresolvedPermission>>(permissions.size()*2);
|
||||
perms = new HashMap<>(permissions.size()*2);
|
||||
|
||||
// Convert each entry (Vector) into a List
|
||||
Set<Map.Entry<String, Vector<UnresolvedPermission>>> set = permissions.entrySet();
|
||||
|
@ -301,7 +301,7 @@ public class CertPathBuilder {
|
||||
*/
|
||||
public final static String getDefaultType() {
|
||||
String cpbtype =
|
||||
AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty(CPB_TYPE);
|
||||
}
|
||||
|
@ -313,7 +313,7 @@ public class CertPathValidator {
|
||||
*/
|
||||
public final static String getDefaultType() {
|
||||
String cpvtype =
|
||||
AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty(CPV_TYPE);
|
||||
}
|
||||
|
@ -409,7 +409,7 @@ public class CertStore {
|
||||
*/
|
||||
public final static String getDefaultType() {
|
||||
String cstype;
|
||||
cstype = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
cstype = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty(CERTSTORE_TYPE);
|
||||
}
|
||||
|
@ -231,7 +231,7 @@ public class CertificateRevokedException extends CertificateException {
|
||||
if (size == 0) {
|
||||
extensions = Collections.emptyMap();
|
||||
} else {
|
||||
extensions = new HashMap<String, Extension>(size);
|
||||
extensions = new HashMap<>(size);
|
||||
}
|
||||
|
||||
// Read in the extensions and put the mappings in the extensions map
|
||||
|
@ -120,8 +120,8 @@ public class PKIXParameters implements CertPathParameters {
|
||||
setTrustAnchors(trustAnchors);
|
||||
|
||||
this.unmodInitialPolicies = Collections.<String>emptySet();
|
||||
this.certPathCheckers = new ArrayList<PKIXCertPathChecker>();
|
||||
this.certStores = new ArrayList<CertStore>();
|
||||
this.certPathCheckers = new ArrayList<>();
|
||||
this.certStores = new ArrayList<>();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -144,7 +144,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
if (keystore == null)
|
||||
throw new NullPointerException("the keystore parameter must be " +
|
||||
"non-null");
|
||||
Set<TrustAnchor> hashSet = new HashSet<TrustAnchor>();
|
||||
Set<TrustAnchor> hashSet = new HashSet<>();
|
||||
Enumeration<String> aliases = keystore.aliases();
|
||||
while (aliases.hasMoreElements()) {
|
||||
String alias = aliases.nextElement();
|
||||
@ -156,8 +156,8 @@ public class PKIXParameters implements CertPathParameters {
|
||||
}
|
||||
setTrustAnchors(hashSet);
|
||||
this.unmodInitialPolicies = Collections.<String>emptySet();
|
||||
this.certPathCheckers = new ArrayList<PKIXCertPathChecker>();
|
||||
this.certStores = new ArrayList<CertStore>();
|
||||
this.certPathCheckers = new ArrayList<>();
|
||||
this.certStores = new ArrayList<>();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -207,7 +207,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
}
|
||||
}
|
||||
this.unmodTrustAnchors = Collections.unmodifiableSet
|
||||
(new HashSet<TrustAnchor>(trustAnchors));
|
||||
(new HashSet<>(trustAnchors));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -256,7 +256,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
+ "of type java.lang.String");
|
||||
}
|
||||
this.unmodInitialPolicies =
|
||||
Collections.unmodifiableSet(new HashSet<String>(initialPolicies));
|
||||
Collections.unmodifiableSet(new HashSet<>(initialPolicies));
|
||||
} else
|
||||
this.unmodInitialPolicies = Collections.<String>emptySet();
|
||||
}
|
||||
@ -280,7 +280,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
*/
|
||||
public void setCertStores(List<CertStore> stores) {
|
||||
if (stores == null) {
|
||||
this.certStores = new ArrayList<CertStore>();
|
||||
this.certStores = new ArrayList<>();
|
||||
} else {
|
||||
for (Iterator<CertStore> i = stores.iterator(); i.hasNext();) {
|
||||
if (!(i.next() instanceof CertStore)) {
|
||||
@ -288,7 +288,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
+ "of type java.security.cert.CertStore");
|
||||
}
|
||||
}
|
||||
this.certStores = new ArrayList<CertStore>(stores);
|
||||
this.certStores = new ArrayList<>(stores);
|
||||
}
|
||||
}
|
||||
|
||||
@ -316,7 +316,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
*/
|
||||
public List<CertStore> getCertStores() {
|
||||
return Collections.unmodifiableList
|
||||
(new ArrayList<CertStore>(this.certStores));
|
||||
(new ArrayList<>(this.certStores));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -544,14 +544,13 @@ public class PKIXParameters implements CertPathParameters {
|
||||
*/
|
||||
public void setCertPathCheckers(List<PKIXCertPathChecker> checkers) {
|
||||
if (checkers != null) {
|
||||
List<PKIXCertPathChecker> tmpList =
|
||||
new ArrayList<PKIXCertPathChecker>();
|
||||
List<PKIXCertPathChecker> tmpList = new ArrayList<>();
|
||||
for (PKIXCertPathChecker checker : checkers) {
|
||||
tmpList.add((PKIXCertPathChecker)checker.clone());
|
||||
}
|
||||
this.certPathCheckers = tmpList;
|
||||
} else {
|
||||
this.certPathCheckers = new ArrayList<PKIXCertPathChecker>();
|
||||
this.certPathCheckers = new ArrayList<>();
|
||||
}
|
||||
}
|
||||
|
||||
@ -567,7 +566,7 @@ public class PKIXParameters implements CertPathParameters {
|
||||
* @see #setCertPathCheckers
|
||||
*/
|
||||
public List<PKIXCertPathChecker> getCertPathCheckers() {
|
||||
List<PKIXCertPathChecker> tmpList = new ArrayList<PKIXCertPathChecker>();
|
||||
List<PKIXCertPathChecker> tmpList = new ArrayList<>();
|
||||
for (PKIXCertPathChecker ck : certPathCheckers) {
|
||||
tmpList.add((PKIXCertPathChecker)ck.clone());
|
||||
}
|
||||
@ -667,11 +666,11 @@ public class PKIXParameters implements CertPathParameters {
|
||||
|
||||
// must clone these because addCertStore, et al. modify them
|
||||
if (certStores != null) {
|
||||
copy.certStores = new ArrayList<CertStore>(certStores);
|
||||
copy.certStores = new ArrayList<>(certStores);
|
||||
}
|
||||
if (certPathCheckers != null) {
|
||||
copy.certPathCheckers =
|
||||
new ArrayList<PKIXCertPathChecker>(certPathCheckers.size());
|
||||
new ArrayList<>(certPathCheckers.size());
|
||||
for (PKIXCertPathChecker checker : certPathCheckers) {
|
||||
copy.certPathCheckers.add(
|
||||
(PKIXCertPathChecker)checker.clone());
|
||||
|
@ -170,7 +170,7 @@ public abstract class PKIXRevocationChecker extends PKIXCertPathChecker {
|
||||
{
|
||||
this.ocspExtensions = (extensions == null)
|
||||
? Collections.<Extension>emptyList()
|
||||
: new ArrayList<Extension>(extensions);
|
||||
: new ArrayList<>(extensions);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -232,7 +232,7 @@ public abstract class PKIXRevocationChecker extends PKIXCertPathChecker {
|
||||
public void setOptions(Set<Option> options) {
|
||||
this.options = (options == null)
|
||||
? Collections.<Option>emptySet()
|
||||
: new HashSet<Option>(options);
|
||||
: new HashSet<>(options);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -124,8 +124,8 @@ public class X509CRLSelector implements CRLSelector {
|
||||
issuerX500Principals = null;
|
||||
} else {
|
||||
// clone
|
||||
issuerX500Principals = new HashSet<X500Principal>(issuers);
|
||||
issuerNames = new HashSet<Object>();
|
||||
issuerX500Principals = new HashSet<>(issuers);
|
||||
issuerNames = new HashSet<>();
|
||||
for (X500Principal p : issuerX500Principals) {
|
||||
issuerNames.add(p.getEncoded());
|
||||
}
|
||||
@ -288,10 +288,10 @@ public class X509CRLSelector implements CRLSelector {
|
||||
*/
|
||||
private void addIssuerNameInternal(Object name, X500Principal principal) {
|
||||
if (issuerNames == null) {
|
||||
issuerNames = new HashSet<Object>();
|
||||
issuerNames = new HashSet<>();
|
||||
}
|
||||
if (issuerX500Principals == null) {
|
||||
issuerX500Principals = new HashSet<X500Principal>();
|
||||
issuerX500Principals = new HashSet<>();
|
||||
}
|
||||
issuerNames.add(name);
|
||||
issuerX500Principals.add(principal);
|
||||
@ -311,7 +311,7 @@ public class X509CRLSelector implements CRLSelector {
|
||||
private static HashSet<Object> cloneAndCheckIssuerNames(Collection<?> names)
|
||||
throws IOException
|
||||
{
|
||||
HashSet<Object> namesCopy = new HashSet<Object>();
|
||||
HashSet<Object> namesCopy = new HashSet<>();
|
||||
Iterator<?> i = names.iterator();
|
||||
while (i.hasNext()) {
|
||||
Object nameObject = i.next();
|
||||
@ -363,7 +363,7 @@ public class X509CRLSelector implements CRLSelector {
|
||||
*/
|
||||
private static HashSet<X500Principal> parseIssuerNames(Collection<Object> names)
|
||||
throws IOException {
|
||||
HashSet<X500Principal> x500Principals = new HashSet<X500Principal>();
|
||||
HashSet<X500Principal> x500Principals = new HashSet<>();
|
||||
for (Iterator<Object> t = names.iterator(); t.hasNext(); ) {
|
||||
Object nameObject = t.next();
|
||||
if (nameObject instanceof String) {
|
||||
@ -701,9 +701,9 @@ public class X509CRLSelector implements CRLSelector {
|
||||
X509CRLSelector copy = (X509CRLSelector)super.clone();
|
||||
if (issuerNames != null) {
|
||||
copy.issuerNames =
|
||||
new HashSet<Object>(issuerNames);
|
||||
new HashSet<>(issuerNames);
|
||||
copy.issuerX500Principals =
|
||||
new HashSet<X500Principal>(issuerX500Principals);
|
||||
new HashSet<>(issuerX500Principals);
|
||||
}
|
||||
return copy;
|
||||
} catch (CloneNotSupportedException e) {
|
||||
|
@ -619,8 +619,8 @@ public class X509CertSelector implements CertSelector {
|
||||
keyPurposeOIDSet = null;
|
||||
} else {
|
||||
this.keyPurposeSet =
|
||||
Collections.unmodifiableSet(new HashSet<String>(keyPurposeSet));
|
||||
keyPurposeOIDSet = new HashSet<ObjectIdentifier>();
|
||||
Collections.unmodifiableSet(new HashSet<>(keyPurposeSet));
|
||||
keyPurposeOIDSet = new HashSet<>();
|
||||
for (String s : this.keyPurposeSet) {
|
||||
keyPurposeOIDSet.add(new ObjectIdentifier(s));
|
||||
}
|
||||
@ -815,12 +815,12 @@ public class X509CertSelector implements CertSelector {
|
||||
// First, ensure that the name parses
|
||||
GeneralNameInterface tempName = makeGeneralNameInterface(type, name);
|
||||
if (subjectAlternativeNames == null) {
|
||||
subjectAlternativeNames = new HashSet<List<?>>();
|
||||
subjectAlternativeNames = new HashSet<>();
|
||||
}
|
||||
if (subjectAlternativeGeneralNames == null) {
|
||||
subjectAlternativeGeneralNames = new HashSet<GeneralNameInterface>();
|
||||
subjectAlternativeGeneralNames = new HashSet<>();
|
||||
}
|
||||
List<Object> list = new ArrayList<Object>(2);
|
||||
List<Object> list = new ArrayList<>(2);
|
||||
list.add(Integer.valueOf(type));
|
||||
list.add(name);
|
||||
subjectAlternativeNames.add(list);
|
||||
@ -845,7 +845,7 @@ public class X509CertSelector implements CertSelector {
|
||||
* @throws IOException if a parsing error occurs
|
||||
*/
|
||||
private static Set<GeneralNameInterface> parseNames(Collection<List<?>> names) throws IOException {
|
||||
Set<GeneralNameInterface> genNames = new HashSet<GeneralNameInterface>();
|
||||
Set<GeneralNameInterface> genNames = new HashSet<>();
|
||||
for (List<?> nameList : names) {
|
||||
if (nameList.size() != 2) {
|
||||
throw new IOException("name list size not 2");
|
||||
@ -1096,10 +1096,10 @@ public class X509CertSelector implements CertSelector {
|
||||
} else {
|
||||
// Snapshot set and parse it
|
||||
Set<String> tempSet = Collections.unmodifiableSet
|
||||
(new HashSet<String>(certPolicySet));
|
||||
(new HashSet<>(certPolicySet));
|
||||
/* Convert to Vector of ObjectIdentifiers */
|
||||
Iterator<String> i = tempSet.iterator();
|
||||
Vector<CertificatePolicyId> polIdVector = new Vector<CertificatePolicyId>();
|
||||
Vector<CertificatePolicyId> polIdVector = new Vector<>();
|
||||
while (i.hasNext()) {
|
||||
Object o = i.next();
|
||||
if (!(o instanceof String)) {
|
||||
@ -1267,10 +1267,10 @@ public class X509CertSelector implements CertSelector {
|
||||
// First, ensure that the name parses
|
||||
GeneralNameInterface tempName = makeGeneralNameInterface(type, name);
|
||||
if (pathToGeneralNames == null) {
|
||||
pathToNames = new HashSet<List<?>>();
|
||||
pathToGeneralNames = new HashSet<GeneralNameInterface>();
|
||||
pathToNames = new HashSet<>();
|
||||
pathToGeneralNames = new HashSet<>();
|
||||
}
|
||||
List<Object> list = new ArrayList<Object>(2);
|
||||
List<Object> list = new ArrayList<>(2);
|
||||
list.add(Integer.valueOf(type));
|
||||
list.add(name);
|
||||
pathToNames.add(list);
|
||||
@ -1671,10 +1671,10 @@ public class X509CertSelector implements CertSelector {
|
||||
*/
|
||||
private static Set<List<?>> cloneAndCheckNames(Collection<List<?>> names) throws IOException {
|
||||
// Copy the Lists and Collection
|
||||
Set<List<?>> namesCopy = new HashSet<List<?>>();
|
||||
Set<List<?>> namesCopy = new HashSet<>();
|
||||
for (List<?> o : names)
|
||||
{
|
||||
namesCopy.add(new ArrayList<Object>(o));
|
||||
namesCopy.add(new ArrayList<>(o));
|
||||
}
|
||||
|
||||
// Check the contents of the Lists and clone any byte arrays
|
||||
@ -2397,7 +2397,7 @@ public class X509CertSelector implements CertSelector {
|
||||
* Convert the Vector of PolicyInformation to a Vector
|
||||
* of CertificatePolicyIds for easier comparison.
|
||||
*/
|
||||
List<CertificatePolicyId> policyIDs = new ArrayList<CertificatePolicyId>(policies.size());
|
||||
List<CertificatePolicyId> policyIDs = new ArrayList<>(policies.size());
|
||||
for (PolicyInformation info : policies) {
|
||||
policyIDs.add(info.getPolicyIdentifier());
|
||||
}
|
||||
|
@ -53,9 +53,9 @@ import sun.util.calendar.ZoneInfo;
|
||||
* ------------------------------------------------------
|
||||
* }</pre>
|
||||
*
|
||||
* <p><code>ERA</code> value 0 specifies the years before Meiji and
|
||||
* the Gregorian year values are used. Unlike {@link
|
||||
* GregorianCalendar}, the Julian to Gregorian transition is not
|
||||
* <p>{@code ERA} value 0 specifies the years before Meiji and
|
||||
* the Gregorian year values are used. Unlike
|
||||
* {@link GregorianCalendar}, the Julian to Gregorian transition is not
|
||||
* supported because it doesn't make any sense to the Japanese
|
||||
* calendar systems used before Meiji. To represent the years before
|
||||
* Gregorian year 1, 0 and negative values are used. The Japanese
|
||||
@ -66,7 +66,7 @@ import sun.util.calendar.ZoneInfo;
|
||||
* <p>A new era can be specified using property
|
||||
* jdk.calendar.japanese.supplemental.era. The new era is added to the
|
||||
* predefined eras. The syntax of the property is as follows.
|
||||
* <p><pre>
|
||||
* <pre>
|
||||
* {@code name=<name>,abbr=<abbr>,since=<time['u']>}
|
||||
* </pre>
|
||||
* where
|
||||
@ -83,7 +83,7 @@ import sun.util.calendar.ZoneInfo;
|
||||
* ignored.
|
||||
*
|
||||
* <p>The following is an example of the property usage.
|
||||
* <p><pre>
|
||||
* <pre>
|
||||
* java -Djdk.calendar.japanese.supplemental.era="name=NewEra,abbr=N,since=253374307200000"
|
||||
* </pre>
|
||||
* The property specifies an era change to NewEra at 9999-02-11T00:00:00 local time.
|
||||
@ -315,7 +315,7 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
private transient int[] originalFields;
|
||||
|
||||
/**
|
||||
* Constructs a <code>JapaneseImperialCalendar</code> based on the current time
|
||||
* Constructs a {@code JapaneseImperialCalendar} based on the current time
|
||||
* in the given time zone with the given locale.
|
||||
*
|
||||
* @param zone the given time zone.
|
||||
@ -351,16 +351,16 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
}
|
||||
|
||||
/**
|
||||
* Compares this <code>JapaneseImperialCalendar</code> to the specified
|
||||
* <code>Object</code>. The result is <code>true</code> if and
|
||||
* only if the argument is a <code>JapaneseImperialCalendar</code> object
|
||||
* Compares this {@code JapaneseImperialCalendar} to the specified
|
||||
* {@code Object}. The result is {@code true} if and
|
||||
* only if the argument is a {@code JapaneseImperialCalendar} object
|
||||
* that represents the same time value (millisecond offset from
|
||||
* the <a href="Calendar.html#Epoch">Epoch</a>) under the same
|
||||
* <code>Calendar</code> parameters.
|
||||
* {@code Calendar} parameters.
|
||||
*
|
||||
* @param obj the object to compare with.
|
||||
* @return <code>true</code> if this object is equal to <code>obj</code>;
|
||||
* <code>false</code> otherwise.
|
||||
* @return {@code true} if this object is equal to {@code obj};
|
||||
* {@code false} otherwise.
|
||||
* @see Calendar#compareTo(Calendar)
|
||||
*/
|
||||
@Override
|
||||
@ -371,7 +371,7 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
|
||||
/**
|
||||
* Generates the hash code for this
|
||||
* <code>JapaneseImperialCalendar</code> object.
|
||||
* {@code JapaneseImperialCalendar} object.
|
||||
*/
|
||||
@Override
|
||||
public int hashCode() {
|
||||
@ -382,27 +382,27 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
* Adds the specified (signed) amount of time to the given calendar field,
|
||||
* based on the calendar's rules.
|
||||
*
|
||||
* <p><em>Add rule 1</em>. The value of <code>field</code>
|
||||
* after the call minus the value of <code>field</code> before the
|
||||
* call is <code>amount</code>, modulo any overflow that has occurred in
|
||||
* <code>field</code>. Overflow occurs when a field value exceeds its
|
||||
* <p><em>Add rule 1</em>. The value of {@code field}
|
||||
* after the call minus the value of {@code field} before the
|
||||
* call is {@code amount}, modulo any overflow that has occurred in
|
||||
* {@code field}. Overflow occurs when a field value exceeds its
|
||||
* range and, as a result, the next larger field is incremented or
|
||||
* decremented and the field value is adjusted back into its range.</p>
|
||||
*
|
||||
* <p><em>Add rule 2</em>. If a smaller field is expected to be
|
||||
* invariant, but it is impossible for it to be equal to its
|
||||
* prior value because of changes in its minimum or maximum after
|
||||
* <code>field</code> is changed, then its value is adjusted to be as close
|
||||
* {@code field} is changed, then its value is adjusted to be as close
|
||||
* as possible to its expected value. A smaller field represents a
|
||||
* smaller unit of time. <code>HOUR</code> is a smaller field than
|
||||
* <code>DAY_OF_MONTH</code>. No adjustment is made to smaller fields
|
||||
* smaller unit of time. {@code HOUR} is a smaller field than
|
||||
* {@code DAY_OF_MONTH}. No adjustment is made to smaller fields
|
||||
* that are not expected to be invariant. The calendar system
|
||||
* determines what fields are expected to be invariant.</p>
|
||||
*
|
||||
* @param field the calendar field.
|
||||
* @param amount the amount of date or time to be added to the field.
|
||||
* @exception IllegalArgumentException if <code>field</code> is
|
||||
* <code>ZONE_OFFSET</code>, <code>DST_OFFSET</code>, or unknown,
|
||||
* @exception IllegalArgumentException if {@code field} is
|
||||
* {@code ZONE_OFFSET}, {@code DST_OFFSET}, or unknown,
|
||||
* or if any calendar fields have out-of-range values in
|
||||
* non-lenient mode.
|
||||
*/
|
||||
@ -548,12 +548,12 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
* <p>This method calls {@link #complete()} before adding the
|
||||
* amount so that all the calendar fields are normalized. If there
|
||||
* is any calendar field having an out-of-range value in non-lenient mode, then an
|
||||
* <code>IllegalArgumentException</code> is thrown.
|
||||
* {@code IllegalArgumentException} is thrown.
|
||||
*
|
||||
* @param field the calendar field.
|
||||
* @param amount the signed amount to add to <code>field</code>.
|
||||
* @exception IllegalArgumentException if <code>field</code> is
|
||||
* <code>ZONE_OFFSET</code>, <code>DST_OFFSET</code>, or unknown,
|
||||
* @param amount the signed amount to add to {@code field}.
|
||||
* @exception IllegalArgumentException if {@code field} is
|
||||
* {@code ZONE_OFFSET}, {@code DST_OFFSET}, or unknown,
|
||||
* or if any calendar fields have out-of-range values in
|
||||
* non-lenient mode.
|
||||
* @see #roll(int,boolean)
|
||||
@ -1055,9 +1055,9 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
|
||||
/**
|
||||
* Returns the minimum value for the given calendar field of this
|
||||
* <code>Calendar</code> instance. The minimum value is
|
||||
* defined as the smallest value returned by the {@link
|
||||
* Calendar#get(int) get} method for any possible time value,
|
||||
* {@code Calendar} instance. The minimum value is
|
||||
* defined as the smallest value returned by the
|
||||
* {@link Calendar#get(int) get} method for any possible time value,
|
||||
* taking into consideration the current values of the
|
||||
* {@link Calendar#getFirstDayOfWeek() getFirstDayOfWeek},
|
||||
* {@link Calendar#getMinimalDaysInFirstWeek() getMinimalDaysInFirstWeek},
|
||||
@ -1077,9 +1077,9 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
|
||||
/**
|
||||
* Returns the maximum value for the given calendar field of this
|
||||
* <code>GregorianCalendar</code> instance. The maximum value is
|
||||
* defined as the largest value returned by the {@link
|
||||
* Calendar#get(int) get} method for any possible time value,
|
||||
* {@code GregorianCalendar} instance. The maximum value is
|
||||
* defined as the largest value returned by the
|
||||
* {@link Calendar#get(int) get} method for any possible time value,
|
||||
* taking into consideration the current values of the
|
||||
* {@link Calendar#getFirstDayOfWeek() getFirstDayOfWeek},
|
||||
* {@link Calendar#getMinimalDaysInFirstWeek() getMinimalDaysInFirstWeek},
|
||||
@ -1108,7 +1108,7 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
|
||||
/**
|
||||
* Returns the highest minimum value for the given calendar field
|
||||
* of this <code>GregorianCalendar</code> instance. The highest
|
||||
* of this {@code GregorianCalendar} instance. The highest
|
||||
* minimum value is defined as the largest value returned by
|
||||
* {@link #getActualMinimum(int)} for any possible time value,
|
||||
* taking into consideration the current values of the
|
||||
@ -1130,7 +1130,7 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
|
||||
/**
|
||||
* Returns the lowest maximum value for the given calendar field
|
||||
* of this <code>GregorianCalendar</code> instance. The lowest
|
||||
* of this {@code GregorianCalendar} instance. The lowest
|
||||
* maximum value is defined as the smallest value returned by
|
||||
* {@link #getActualMaximum(int)} for any possible time value,
|
||||
* taking into consideration the current values of the
|
||||
@ -1166,7 +1166,7 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
*
|
||||
* @param field the calendar field
|
||||
* @return the minimum of the given field for the time value of
|
||||
* this <code>JapaneseImperialCalendar</code>
|
||||
* this {@code JapaneseImperialCalendar}
|
||||
* @see #getMinimum(int)
|
||||
* @see #getMaximum(int)
|
||||
* @see #getGreatestMinimum(int)
|
||||
@ -1269,13 +1269,13 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
* and
|
||||
* {@link Calendar#getTimeZone() getTimeZone} methods.
|
||||
* For example, if the date of this instance is Heisei 16February 1,
|
||||
* the actual maximum value of the <code>DAY_OF_MONTH</code> field
|
||||
* the actual maximum value of the {@code DAY_OF_MONTH} field
|
||||
* is 29 because Heisei 16 is a leap year, and if the date of this
|
||||
* instance is Heisei 17 February 1, it's 28.
|
||||
*
|
||||
* @param field the calendar field
|
||||
* @return the maximum of the given field for the time value of
|
||||
* this <code>JapaneseImperialCalendar</code>
|
||||
* this {@code JapaneseImperialCalendar}
|
||||
* @see #getMinimum(int)
|
||||
* @see #getMaximum(int)
|
||||
* @see #getGreatestMinimum(int)
|
||||
@ -1558,7 +1558,7 @@ class JapaneseImperialCalendar extends Calendar {
|
||||
* href="Calendar.html#Epoch">Epoch</a>) to calendar field values.
|
||||
* The time is <em>not</em>
|
||||
* recomputed first; to recompute the time, then the fields, call the
|
||||
* <code>complete</code> method.
|
||||
* {@code complete} method.
|
||||
*
|
||||
* @see Calendar#complete
|
||||
*/
|
||||
|
@ -2411,7 +2411,7 @@ public class ForkJoinPool extends AbstractExecutorService {
|
||||
int j = ((am & s) << ASHIFT) + ABASE;
|
||||
U.putOrderedObject(a, j, task);
|
||||
U.putOrderedInt(q, QTOP, s + 1);
|
||||
U.putOrderedInt(q, QLOCK, 0);
|
||||
U.putIntVolatile(q, QLOCK, 0);
|
||||
if (n <= 1)
|
||||
signalWork(ws, q);
|
||||
return;
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2005, 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
|
||||
@ -140,11 +140,24 @@ import java.util.Locale;
|
||||
*/
|
||||
public abstract class LocaleServiceProvider {
|
||||
|
||||
private static Void checkPermission() {
|
||||
SecurityManager sm = System.getSecurityManager();
|
||||
if (sm != null) {
|
||||
sm.checkPermission(new RuntimePermission("localeServiceProvider"));
|
||||
}
|
||||
return null;
|
||||
}
|
||||
private LocaleServiceProvider(Void ignore) { }
|
||||
|
||||
/**
|
||||
* Sole constructor. (For invocation by subclass constructors, typically
|
||||
* implicit.)
|
||||
* Initializes a new locale service provider.
|
||||
*
|
||||
* @throws SecurityException
|
||||
* If a security manager has been installed and it denies
|
||||
* {@link RuntimePermission RuntimePermission("localeServiceProvider")}
|
||||
*/
|
||||
protected LocaleServiceProvider() {
|
||||
this(checkPermission());
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -76,7 +76,7 @@ final class JceSecurity {
|
||||
static {
|
||||
try {
|
||||
AccessController.doPrivileged(
|
||||
new PrivilegedExceptionAction<Void> () {
|
||||
new PrivilegedExceptionAction<> () {
|
||||
@Override
|
||||
public Void run() throws Exception {
|
||||
setupJurisdictionPolicies();
|
||||
@ -225,7 +225,7 @@ final class JceSecurity {
|
||||
URL url = codeBaseCacheRef.get(clazz);
|
||||
if (url == null) {
|
||||
url = AccessController.doPrivileged(
|
||||
new PrivilegedAction<URL>() {
|
||||
new PrivilegedAction<>() {
|
||||
@Override
|
||||
public URL run() {
|
||||
ProtectionDomain pd = clazz.getProtectionDomain();
|
||||
|
@ -66,7 +66,7 @@ final class JceSecurityManager extends SecurityManager {
|
||||
exemptPolicy = JceSecurity.getExemptPolicy();
|
||||
allPerm = CryptoAllPermission.INSTANCE;
|
||||
INSTANCE = AccessController.doPrivileged(
|
||||
new PrivilegedAction<JceSecurityManager>() {
|
||||
new PrivilegedAction<>() {
|
||||
public JceSecurityManager run() {
|
||||
return new JceSecurityManager();
|
||||
}
|
||||
|
@ -63,7 +63,7 @@ public class KeyManagerFactory {
|
||||
*/
|
||||
public final static String getDefaultAlgorithm() {
|
||||
String type;
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
@Override
|
||||
public String run() {
|
||||
return Security.getProperty(
|
||||
|
@ -126,7 +126,7 @@ public abstract class SSLSocketFactory extends SocketFactory
|
||||
}
|
||||
|
||||
static String getSecurityProperty(final String name) {
|
||||
return AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
return AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
@Override
|
||||
public String run() {
|
||||
String s = java.security.Security.getProperty(name);
|
||||
|
@ -63,7 +63,7 @@ public class TrustManagerFactory {
|
||||
*/
|
||||
public final static String getDefaultAlgorithm() {
|
||||
String type;
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<String>() {
|
||||
type = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
@Override
|
||||
public String run() {
|
||||
return Security.getProperty(
|
||||
|
@ -154,11 +154,11 @@ public final class Subject implements java.io.Serializable {
|
||||
public Subject() {
|
||||
|
||||
this.principals = Collections.synchronizedSet
|
||||
(new SecureSet<Principal>(this, PRINCIPAL_SET));
|
||||
(new SecureSet<>(this, PRINCIPAL_SET));
|
||||
this.pubCredentials = Collections.synchronizedSet
|
||||
(new SecureSet<Object>(this, PUB_CREDENTIAL_SET));
|
||||
(new SecureSet<>(this, PUB_CREDENTIAL_SET));
|
||||
this.privCredentials = Collections.synchronizedSet
|
||||
(new SecureSet<Object>(this, PRIV_CREDENTIAL_SET));
|
||||
(new SecureSet<>(this, PRIV_CREDENTIAL_SET));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -206,11 +206,11 @@ public final class Subject implements java.io.Serializable {
|
||||
collectionNullClean(pubCredentials);
|
||||
collectionNullClean(privCredentials);
|
||||
|
||||
this.principals = Collections.synchronizedSet(new SecureSet<Principal>
|
||||
this.principals = Collections.synchronizedSet(new SecureSet<>
|
||||
(this, PRINCIPAL_SET, principals));
|
||||
this.pubCredentials = Collections.synchronizedSet(new SecureSet<Object>
|
||||
this.pubCredentials = Collections.synchronizedSet(new SecureSet<>
|
||||
(this, PUB_CREDENTIAL_SET, pubCredentials));
|
||||
this.privCredentials = Collections.synchronizedSet(new SecureSet<Object>
|
||||
this.privCredentials = Collections.synchronizedSet(new SecureSet<>
|
||||
(this, PRIV_CREDENTIAL_SET, privCredentials));
|
||||
this.readOnly = readOnly;
|
||||
}
|
||||
@ -292,7 +292,7 @@ public final class Subject implements java.io.Serializable {
|
||||
|
||||
// return the Subject from the DomainCombiner of the provided context
|
||||
return AccessController.doPrivileged
|
||||
(new java.security.PrivilegedAction<Subject>() {
|
||||
(new java.security.PrivilegedAction<>() {
|
||||
public Subject run() {
|
||||
DomainCombiner dc = acc.getDomainCombiner();
|
||||
if (!(dc instanceof SubjectDomainCombiner)) {
|
||||
@ -555,7 +555,7 @@ public final class Subject implements java.io.Serializable {
|
||||
|
||||
|
||||
return java.security.AccessController.doPrivileged
|
||||
(new java.security.PrivilegedAction<AccessControlContext>() {
|
||||
(new java.security.PrivilegedAction<>() {
|
||||
public AccessControlContext run() {
|
||||
if (subject == null) {
|
||||
return new AccessControlContext(acc, null);
|
||||
@ -801,7 +801,7 @@ public final class Subject implements java.io.Serializable {
|
||||
Set<Principal> thatPrincipals;
|
||||
synchronized(that.principals) {
|
||||
// avoid deadlock from dual locks
|
||||
thatPrincipals = new HashSet<Principal>(that.principals);
|
||||
thatPrincipals = new HashSet<>(that.principals);
|
||||
}
|
||||
if (!principals.equals(thatPrincipals)) {
|
||||
return false;
|
||||
@ -810,7 +810,7 @@ public final class Subject implements java.io.Serializable {
|
||||
Set<Object> thatPubCredentials;
|
||||
synchronized(that.pubCredentials) {
|
||||
// avoid deadlock from dual locks
|
||||
thatPubCredentials = new HashSet<Object>(that.pubCredentials);
|
||||
thatPubCredentials = new HashSet<>(that.pubCredentials);
|
||||
}
|
||||
if (!pubCredentials.equals(thatPubCredentials)) {
|
||||
return false;
|
||||
@ -819,7 +819,7 @@ public final class Subject implements java.io.Serializable {
|
||||
Set<Object> thatPrivCredentials;
|
||||
synchronized(that.privCredentials) {
|
||||
// avoid deadlock from dual locks
|
||||
thatPrivCredentials = new HashSet<Object>(that.privCredentials);
|
||||
thatPrivCredentials = new HashSet<>(that.privCredentials);
|
||||
}
|
||||
if (!privCredentials.equals(thatPrivCredentials)) {
|
||||
return false;
|
||||
@ -970,21 +970,21 @@ public final class Subject implements java.io.Serializable {
|
||||
|
||||
// Rewrap the principals into a SecureSet
|
||||
try {
|
||||
principals = Collections.synchronizedSet(new SecureSet<Principal>
|
||||
principals = Collections.synchronizedSet(new SecureSet<>
|
||||
(this, PRINCIPAL_SET, inputPrincs));
|
||||
} catch (NullPointerException npe) {
|
||||
// Sometimes people deserialize the principals set only.
|
||||
// Subject is not accessible, so just don't fail.
|
||||
principals = Collections.synchronizedSet
|
||||
(new SecureSet<Principal>(this, PRINCIPAL_SET));
|
||||
(new SecureSet<>(this, PRINCIPAL_SET));
|
||||
}
|
||||
|
||||
// The Credential {@code Set} is not serialized, but we do not
|
||||
// want the default deserialization routine to set it to null.
|
||||
this.pubCredentials = Collections.synchronizedSet
|
||||
(new SecureSet<Object>(this, PUB_CREDENTIAL_SET));
|
||||
(new SecureSet<>(this, PUB_CREDENTIAL_SET));
|
||||
this.privCredentials = Collections.synchronizedSet
|
||||
(new SecureSet<Object>(this, PRIV_CREDENTIAL_SET));
|
||||
(new SecureSet<>(this, PRIV_CREDENTIAL_SET));
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1497,7 +1497,7 @@ public final class Subject implements java.io.Serializable {
|
||||
Object next;
|
||||
if (which == Subject.PRIV_CREDENTIAL_SET) {
|
||||
next = java.security.AccessController.doPrivileged
|
||||
(new java.security.PrivilegedAction<Object>() {
|
||||
(new java.security.PrivilegedAction<>() {
|
||||
public Object run() {
|
||||
return iterator.next();
|
||||
}
|
||||
|
@ -229,7 +229,7 @@ public abstract class Configuration {
|
||||
if (configuration == null) {
|
||||
String config_class = null;
|
||||
config_class = AccessController.doPrivileged
|
||||
(new PrivilegedAction<String>() {
|
||||
(new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return java.security.Security.getProperty
|
||||
("login.configuration.provider");
|
||||
@ -242,7 +242,7 @@ public abstract class Configuration {
|
||||
try {
|
||||
final String finalClass = config_class;
|
||||
Configuration untrustedImpl = AccessController.doPrivileged(
|
||||
new PrivilegedExceptionAction<Configuration>() {
|
||||
new PrivilegedExceptionAction<>() {
|
||||
public Configuration run() throws ClassNotFoundException,
|
||||
InstantiationException,
|
||||
IllegalAccessException {
|
||||
@ -254,7 +254,7 @@ public abstract class Configuration {
|
||||
}
|
||||
});
|
||||
AccessController.doPrivileged(
|
||||
new PrivilegedExceptionAction<Void>() {
|
||||
new PrivilegedExceptionAction<>() {
|
||||
public Void run() {
|
||||
setConfiguration(untrustedImpl);
|
||||
return null;
|
||||
|
@ -142,7 +142,7 @@ public abstract class X509Certificate extends Certificate {
|
||||
|
||||
static {
|
||||
X509Provider = AccessController.doPrivileged(
|
||||
new PrivilegedAction<String>() {
|
||||
new PrivilegedAction<>() {
|
||||
public String run() {
|
||||
return Security.getProperty(X509_PROVIDER);
|
||||
}
|
||||
|
@ -33,7 +33,7 @@ import java.security.BasicPermission;
|
||||
* name, but no actions list. Callers either possess the permission or not.
|
||||
* <p>
|
||||
* The following targets are defined:
|
||||
* <p>
|
||||
*
|
||||
* <table border=1 cellpadding=5 summary="permission target name,
|
||||
* what the target allows,and associated risks">
|
||||
* <tr>
|
||||
|
@ -530,7 +530,7 @@ public class PKCS7 {
|
||||
// CRLs (optional)
|
||||
if (crls != null && crls.length != 0) {
|
||||
// cast to X509CRLImpl[] since X509CRLImpl implements DerEncoder
|
||||
Set<X509CRLImpl> implCRLs = new HashSet<X509CRLImpl>(crls.length);
|
||||
Set<X509CRLImpl> implCRLs = new HashSet<>(crls.length);
|
||||
for (X509CRL crl: crls) {
|
||||
if (crl instanceof X509CRLImpl)
|
||||
implCRLs.add((X509CRLImpl) crl);
|
||||
@ -590,7 +590,7 @@ public class PKCS7 {
|
||||
public SignerInfo[] verify(byte[] bytes)
|
||||
throws NoSuchAlgorithmException, SignatureException {
|
||||
|
||||
Vector<SignerInfo> intResult = new Vector<SignerInfo>();
|
||||
Vector<SignerInfo> intResult = new Vector<>();
|
||||
for (int i = 0; i < signerInfos.length; i++) {
|
||||
|
||||
SignerInfo signerInfo = verify(signerInfos[i], bytes);
|
||||
|
@ -85,8 +85,7 @@ public class PKCS9Attributes {
|
||||
DerInputStream in) throws IOException {
|
||||
if (permittedAttributes != null) {
|
||||
this.permittedAttributes =
|
||||
new Hashtable<ObjectIdentifier, ObjectIdentifier>(
|
||||
permittedAttributes.length);
|
||||
new Hashtable<>(permittedAttributes.length);
|
||||
|
||||
for (int i = 0; i < permittedAttributes.length; i++)
|
||||
this.permittedAttributes.put(permittedAttributes[i],
|
||||
|
@ -237,7 +237,7 @@ public class SignerInfo implements DerEncoder {
|
||||
if (userCert == null)
|
||||
return null;
|
||||
|
||||
ArrayList<X509Certificate> certList = new ArrayList<X509Certificate>();
|
||||
ArrayList<X509Certificate> certList = new ArrayList<>();
|
||||
certList.add(userCert);
|
||||
|
||||
X509Certificate[] pkcsCerts = block.getCertificates();
|
||||
|
@ -165,7 +165,7 @@ abstract class SeedGenerator {
|
||||
md.update(b);
|
||||
|
||||
java.security.AccessController.doPrivileged
|
||||
(new java.security.PrivilegedAction<Void>() {
|
||||
(new java.security.PrivilegedAction<>() {
|
||||
@Override
|
||||
public Void run() {
|
||||
try {
|
||||
@ -295,7 +295,7 @@ abstract class SeedGenerator {
|
||||
|
||||
final ThreadGroup[] finalsg = new ThreadGroup[1];
|
||||
Thread t = java.security.AccessController.doPrivileged
|
||||
(new java.security.PrivilegedAction<Thread>() {
|
||||
(new java.security.PrivilegedAction<>() {
|
||||
@Override
|
||||
public Thread run() {
|
||||
ThreadGroup parent, group =
|
||||
@ -501,7 +501,7 @@ abstract class SeedGenerator {
|
||||
final URL device = new URL(deviceName);
|
||||
try {
|
||||
seedStream = java.security.AccessController.doPrivileged
|
||||
(new java.security.PrivilegedExceptionAction<InputStream>() {
|
||||
(new java.security.PrivilegedExceptionAction<>() {
|
||||
@Override
|
||||
public InputStream run() throws IOException {
|
||||
/*
|
||||
|
@ -148,7 +148,7 @@ public abstract class SunJSSE extends java.security.Provider {
|
||||
}
|
||||
|
||||
private void registerAlgorithms(final boolean isfips) {
|
||||
AccessController.doPrivileged(new PrivilegedAction<Object>() {
|
||||
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||
@Override
|
||||
public Object run() {
|
||||
doRegister(isfips);
|
||||
|
@ -394,7 +394,7 @@ public class DerInputStream {
|
||||
/*
|
||||
* Pull values out of the stream.
|
||||
*/
|
||||
Vector<DerValue> vec = new Vector<DerValue>(startLen);
|
||||
Vector<DerValue> vec = new Vector<>(startLen);
|
||||
DerValue value;
|
||||
|
||||
do {
|
||||
|
@ -110,7 +110,7 @@ public class ManifestDigester {
|
||||
public ManifestDigester(byte bytes[])
|
||||
{
|
||||
rawBytes = bytes;
|
||||
entries = new HashMap<String, Entry>();
|
||||
entries = new HashMap<>();
|
||||
|
||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||
|
||||
|
@ -77,9 +77,9 @@ public class ManifestEntryVerifier {
|
||||
*/
|
||||
public ManifestEntryVerifier(Manifest man)
|
||||
{
|
||||
createdDigests = new HashMap<String, MessageDigest>(11);
|
||||
digests = new ArrayList<MessageDigest>();
|
||||
manifestHashes = new ArrayList<byte[]>();
|
||||
createdDigests = new HashMap<>(11);
|
||||
digests = new ArrayList<>();
|
||||
manifestHashes = new ArrayList<>();
|
||||
this.man = man;
|
||||
}
|
||||
|
||||
|
@ -203,7 +203,7 @@ public class SignatureFileVerifier {
|
||||
private MessageDigest getDigest(String algorithm)
|
||||
{
|
||||
if (createdDigests == null)
|
||||
createdDigests = new HashMap<String, MessageDigest>();
|
||||
createdDigests = new HashMap<>();
|
||||
|
||||
MessageDigest digest = createdDigests.get(algorithm);
|
||||
|
||||
@ -523,7 +523,7 @@ public class SignatureFileVerifier {
|
||||
ArrayList<X509Certificate> chain = info.getCertificateChain(block);
|
||||
CertPath certChain = certificateFactory.generateCertPath(chain);
|
||||
if (signers == null) {
|
||||
signers = new ArrayList<CodeSigner>();
|
||||
signers = new ArrayList<>();
|
||||
}
|
||||
// Append the new code signer
|
||||
signers.add(new CodeSigner(certChain, info.getTimestamp()));
|
||||
|
@ -307,7 +307,7 @@ public class AVA implements DerEncoder {
|
||||
// doublequote.
|
||||
int c = readChar(in, "Quoted string did not end in quote");
|
||||
|
||||
List<Byte> embeddedHex = new ArrayList<Byte>();
|
||||
List<Byte> embeddedHex = new ArrayList<>();
|
||||
boolean isPrintableString = true;
|
||||
while (c != '"') {
|
||||
if (c == '\\') {
|
||||
|
@ -571,7 +571,7 @@ public class AlgorithmId implements Serializable, DerEncoder {
|
||||
break;
|
||||
}
|
||||
if (oidTable == null) {
|
||||
oidTable = new HashMap<String,ObjectIdentifier>();
|
||||
oidTable = new HashMap<>();
|
||||
}
|
||||
oidString = alias.substring(index);
|
||||
String stdAlgName = provs[i].getProperty(alias);
|
||||
@ -588,7 +588,7 @@ public class AlgorithmId implements Serializable, DerEncoder {
|
||||
}
|
||||
|
||||
if (oidTable == null) {
|
||||
oidTable = new HashMap<String,ObjectIdentifier>(1);
|
||||
oidTable = new HashMap<>(1);
|
||||
}
|
||||
initOidTable = true;
|
||||
}
|
||||
@ -887,7 +887,7 @@ public class AlgorithmId implements Serializable, DerEncoder {
|
||||
*/
|
||||
sha1WithDSA_oid = ObjectIdentifier.newInternal(dsaWithSHA1_PKIX_data);
|
||||
|
||||
nameTable = new HashMap<ObjectIdentifier,String>();
|
||||
nameTable = new HashMap<>();
|
||||
nameTable.put(MD5_oid, "MD5");
|
||||
nameTable.put(MD2_oid, "MD2");
|
||||
nameTable.put(SHA_oid, "SHA-1");
|
||||
|
@ -58,7 +58,7 @@ public class CertificatePolicySet {
|
||||
* @exception IOException on decoding errors.
|
||||
*/
|
||||
public CertificatePolicySet(DerInputStream in) throws IOException {
|
||||
ids = new Vector<CertificatePolicyId>();
|
||||
ids = new Vector<>();
|
||||
DerValue[] seq = in.getSequence(5);
|
||||
|
||||
for (int i = 0; i < seq.length; i++) {
|
||||
|
@ -59,11 +59,11 @@ public class GeneralSubtrees implements Cloneable {
|
||||
* The default constructor for the class.
|
||||
*/
|
||||
public GeneralSubtrees() {
|
||||
trees = new ArrayList<GeneralSubtree>();
|
||||
trees = new ArrayList<>();
|
||||
}
|
||||
|
||||
private GeneralSubtrees(GeneralSubtrees source) {
|
||||
trees = new ArrayList<GeneralSubtree>(source.trees);
|
||||
trees = new ArrayList<>(source.trees);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -102,7 +102,7 @@ public class RDN {
|
||||
int quoteCount = 0;
|
||||
int searchOffset = 0;
|
||||
int avaOffset = 0;
|
||||
List<AVA> avaVec = new ArrayList<AVA>(3);
|
||||
List<AVA> avaVec = new ArrayList<>(3);
|
||||
int nextPlus = name.indexOf('+');
|
||||
while (nextPlus >= 0) {
|
||||
quoteCount += X500Name.countQuotes(name, searchOffset, nextPlus);
|
||||
@ -182,7 +182,7 @@ public class RDN {
|
||||
}
|
||||
int searchOffset = 0;
|
||||
int avaOffset = 0;
|
||||
List<AVA> avaVec = new ArrayList<AVA>(3);
|
||||
List<AVA> avaVec = new ArrayList<>(3);
|
||||
int nextPlus = name.indexOf('+');
|
||||
while (nextPlus >= 0) {
|
||||
/*
|
||||
@ -453,7 +453,7 @@ public class RDN {
|
||||
} else {
|
||||
// order the string type AVA's alphabetically,
|
||||
// followed by the oid type AVA's numerically
|
||||
List<AVA> avaList = new ArrayList<AVA>(assertion.length);
|
||||
List<AVA> avaList = new ArrayList<>(assertion.length);
|
||||
for (int i = 0; i < assertion.length; i++) {
|
||||
avaList.add(assertion[i]);
|
||||
}
|
||||
|
@ -342,7 +342,7 @@ public class X500Name implements GeneralNameInterface, Principal {
|
||||
public List<AVA> allAvas() {
|
||||
List<AVA> list = allAvaList;
|
||||
if (list == null) {
|
||||
list = new ArrayList<AVA>();
|
||||
list = new ArrayList<>();
|
||||
for (int i = 0; i < names.length; i++) {
|
||||
list.addAll(names[i].avas());
|
||||
}
|
||||
@ -1382,7 +1382,7 @@ public class X500Name implements GeneralNameInterface, Principal {
|
||||
*/
|
||||
static {
|
||||
PrivilegedExceptionAction<Object[]> pa =
|
||||
new PrivilegedExceptionAction<Object[]>() {
|
||||
new PrivilegedExceptionAction<>() {
|
||||
public Object[] run() throws Exception {
|
||||
Class<X500Principal> pClass = X500Principal.class;
|
||||
Class<?>[] args = new Class<?>[] { X500Name.class };
|
||||
|
@ -25,6 +25,8 @@
|
||||
|
||||
package sun.util.locale.provider;
|
||||
|
||||
import java.security.AccessController;
|
||||
import java.security.PrivilegedAction;
|
||||
import java.text.spi.BreakIteratorProvider;
|
||||
import java.text.spi.CollatorProvider;
|
||||
import java.text.spi.DateFormatProvider;
|
||||
@ -177,7 +179,9 @@ public abstract class AuxLocaleProviderAdapter extends LocaleProviderAdapter {
|
||||
* A dummy locale service provider that indicates there is no
|
||||
* provider available
|
||||
*/
|
||||
private static final NullProvider NULL_PROVIDER = new NullProvider();
|
||||
private static final NullProvider NULL_PROVIDER = AccessController.doPrivileged(
|
||||
(PrivilegedAction<NullProvider>) () -> new NullProvider());
|
||||
|
||||
private static class NullProvider extends LocaleServiceProvider {
|
||||
@Override
|
||||
public Locale[] getAvailableLocales() {
|
||||
|
@ -26,7 +26,7 @@
|
||||
package sun.util.locale.provider;
|
||||
|
||||
import java.security.AccessController;
|
||||
import java.security.PrivilegedActionException;
|
||||
import java.security.PrivilegedAction;
|
||||
import java.security.PrivilegedExceptionAction;
|
||||
import java.text.spi.BreakIteratorProvider;
|
||||
import java.text.spi.CollatorProvider;
|
||||
@ -133,8 +133,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public BreakIteratorProvider getBreakIteratorProvider() {
|
||||
if (breakIteratorProvider == null) {
|
||||
BreakIteratorProvider provider = new BreakIteratorProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("FormatData"));
|
||||
BreakIteratorProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<BreakIteratorProvider>) () ->
|
||||
new BreakIteratorProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("FormatData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (breakIteratorProvider == null) {
|
||||
breakIteratorProvider = provider;
|
||||
@ -147,8 +151,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public CollatorProvider getCollatorProvider() {
|
||||
if (collatorProvider == null) {
|
||||
CollatorProvider provider = new CollatorProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("CollationData"));
|
||||
CollatorProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<CollatorProvider>) () ->
|
||||
new CollatorProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("CollationData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (collatorProvider == null) {
|
||||
collatorProvider = provider;
|
||||
@ -161,8 +169,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public DateFormatProvider getDateFormatProvider() {
|
||||
if (dateFormatProvider == null) {
|
||||
DateFormatProvider provider = new DateFormatProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("FormatData"));
|
||||
DateFormatProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<DateFormatProvider>) () ->
|
||||
new DateFormatProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("FormatData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (dateFormatProvider == null) {
|
||||
dateFormatProvider = provider;
|
||||
@ -175,8 +187,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public DateFormatSymbolsProvider getDateFormatSymbolsProvider() {
|
||||
if (dateFormatSymbolsProvider == null) {
|
||||
DateFormatSymbolsProvider provider = new DateFormatSymbolsProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("FormatData"));
|
||||
DateFormatSymbolsProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<DateFormatSymbolsProvider>) () ->
|
||||
new DateFormatSymbolsProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("FormatData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (dateFormatSymbolsProvider == null) {
|
||||
dateFormatSymbolsProvider = provider;
|
||||
@ -189,7 +205,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public DecimalFormatSymbolsProvider getDecimalFormatSymbolsProvider() {
|
||||
if (decimalFormatSymbolsProvider == null) {
|
||||
DecimalFormatSymbolsProvider provider = new DecimalFormatSymbolsProviderImpl(getAdapterType(), getLanguageTagSet("FormatData"));
|
||||
DecimalFormatSymbolsProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<DecimalFormatSymbolsProvider>) () ->
|
||||
new DecimalFormatSymbolsProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("FormatData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (decimalFormatSymbolsProvider == null) {
|
||||
decimalFormatSymbolsProvider = provider;
|
||||
@ -202,8 +223,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public NumberFormatProvider getNumberFormatProvider() {
|
||||
if (numberFormatProvider == null) {
|
||||
NumberFormatProvider provider = new NumberFormatProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("FormatData"));
|
||||
NumberFormatProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<NumberFormatProvider>) () ->
|
||||
new NumberFormatProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("FormatData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (numberFormatProvider == null) {
|
||||
numberFormatProvider = provider;
|
||||
@ -219,8 +244,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public CurrencyNameProvider getCurrencyNameProvider() {
|
||||
if (currencyNameProvider == null) {
|
||||
CurrencyNameProvider provider = new CurrencyNameProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("CurrencyNames"));
|
||||
CurrencyNameProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<CurrencyNameProvider>) () ->
|
||||
new CurrencyNameProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("CurrencyNames")));
|
||||
|
||||
synchronized (this) {
|
||||
if (currencyNameProvider == null) {
|
||||
currencyNameProvider = provider;
|
||||
@ -233,8 +262,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public LocaleNameProvider getLocaleNameProvider() {
|
||||
if (localeNameProvider == null) {
|
||||
LocaleNameProvider provider = new LocaleNameProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("LocaleNames"));
|
||||
LocaleNameProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<LocaleNameProvider>) () ->
|
||||
new LocaleNameProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("LocaleNames")));
|
||||
|
||||
synchronized (this) {
|
||||
if (localeNameProvider == null) {
|
||||
localeNameProvider = provider;
|
||||
@ -247,8 +280,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public TimeZoneNameProvider getTimeZoneNameProvider() {
|
||||
if (timeZoneNameProvider == null) {
|
||||
TimeZoneNameProvider provider = new TimeZoneNameProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("TimeZoneNames"));
|
||||
TimeZoneNameProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<TimeZoneNameProvider>) () ->
|
||||
new TimeZoneNameProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("TimeZoneNames")));
|
||||
|
||||
synchronized (this) {
|
||||
if (timeZoneNameProvider == null) {
|
||||
timeZoneNameProvider = provider;
|
||||
@ -261,9 +298,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public CalendarDataProvider getCalendarDataProvider() {
|
||||
if (calendarDataProvider == null) {
|
||||
CalendarDataProvider provider;
|
||||
provider = new CalendarDataProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("CalendarData"));
|
||||
CalendarDataProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<CalendarDataProvider>) () ->
|
||||
new CalendarDataProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("CalendarData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (calendarDataProvider == null) {
|
||||
calendarDataProvider = provider;
|
||||
@ -276,9 +316,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public CalendarNameProvider getCalendarNameProvider() {
|
||||
if (calendarNameProvider == null) {
|
||||
CalendarNameProvider provider;
|
||||
provider = new CalendarNameProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("FormatData"));
|
||||
CalendarNameProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<CalendarNameProvider>) () ->
|
||||
new CalendarNameProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("FormatData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (calendarNameProvider == null) {
|
||||
calendarNameProvider = provider;
|
||||
@ -294,8 +337,12 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
@Override
|
||||
public CalendarProvider getCalendarProvider() {
|
||||
if (calendarProvider == null) {
|
||||
CalendarProvider provider = new CalendarProviderImpl(getAdapterType(),
|
||||
getLanguageTagSet("CalendarData"));
|
||||
CalendarProvider provider = AccessController.doPrivileged(
|
||||
(PrivilegedAction<CalendarProvider>) () ->
|
||||
new CalendarProviderImpl(
|
||||
getAdapterType(),
|
||||
getLanguageTagSet("CalendarData")));
|
||||
|
||||
synchronized (this) {
|
||||
if (calendarProvider == null) {
|
||||
calendarProvider = provider;
|
||||
@ -319,6 +366,7 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
}
|
||||
|
||||
// ResourceBundleBasedAdapter method implementation
|
||||
|
||||
@Override
|
||||
public LocaleData getLocaleData() {
|
||||
if (localeData == null) {
|
||||
@ -449,4 +497,4 @@ public class JRELocaleProviderAdapter extends LocaleProviderAdapter implements R
|
||||
}
|
||||
return locales;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -125,7 +125,7 @@ public final class NativePRNG extends SecureRandomSpi {
|
||||
*/
|
||||
private static RandomIO initIO(final Variant v) {
|
||||
return AccessController.doPrivileged(
|
||||
new PrivilegedAction<RandomIO>() {
|
||||
new PrivilegedAction<>() {
|
||||
@Override
|
||||
public RandomIO run() {
|
||||
|
||||
@ -440,7 +440,7 @@ public final class NativePRNG extends SecureRandomSpi {
|
||||
if (seedOutInitialized == false) {
|
||||
seedOutInitialized = true;
|
||||
seedOut = AccessController.doPrivileged(
|
||||
new PrivilegedAction<OutputStream>() {
|
||||
new PrivilegedAction<>() {
|
||||
@Override
|
||||
public OutputStream run() {
|
||||
try {
|
||||
|
@ -93,7 +93,7 @@ import javax.management.DynamicMBean;
|
||||
* returns the diagnostic command description
|
||||
* (the same as the one return in the 'help' command)</li>
|
||||
* <li>{@link javax.management.MBeanOperationInfo#getImpact() getImpact()}
|
||||
* returns <code>ACTION_INFO</code></li>
|
||||
* returns {@code ACTION_INFO}</li>
|
||||
* <li>{@link javax.management.MBeanOperationInfo#getReturnType() getReturnType()}
|
||||
* returns {@code java.lang.String}</li>
|
||||
* <li>{@link javax.management.MBeanOperationInfo#getDescriptor() getDescriptor()}
|
||||
@ -105,7 +105,6 @@ import javax.management.DynamicMBean;
|
||||
* meta-data for a JMX element. A field is a name and an associated value.
|
||||
* The additional meta-data provided for an operation associated with a
|
||||
* diagnostic command are described in the table below:
|
||||
* <p>
|
||||
*
|
||||
* <table border="1" cellpadding="5">
|
||||
* <tr>
|
||||
@ -161,7 +160,6 @@ import javax.management.DynamicMBean;
|
||||
* arguments supported by the diagnostic command (see below)</td>
|
||||
* </tr>
|
||||
* </table>
|
||||
* <p>
|
||||
*
|
||||
* <p>The description of parameters (options or arguments) of a diagnostic
|
||||
* command is provided within a Descriptor instance. In this Descriptor,
|
||||
|
@ -41,14 +41,14 @@ import sun.management.GarbageCollectionNotifInfoCompositeData;
|
||||
* when the Java virtual machine completes a garbage collection action
|
||||
* The notification emitted will contain the garbage collection notification
|
||||
* information about the status of the memory:
|
||||
* <u1>
|
||||
* <ul>
|
||||
* <li>The name of the garbage collector used to perform the collection.</li>
|
||||
* <li>The action performed by the garbage collector.</li>
|
||||
* <li>The cause of the garbage collection action.</li>
|
||||
* <li>A {@link GcInfo} object containing some statistics about the GC cycle
|
||||
(start time, end time) and the memory usage before and after
|
||||
the GC cycle.</li>
|
||||
* </u1>
|
||||
* </ul>
|
||||
*
|
||||
* <p>
|
||||
* A {@link CompositeData CompositeData} representing
|
||||
@ -81,7 +81,7 @@ import sun.management.GarbageCollectionNotifInfoCompositeData;
|
||||
* <li>A {@linkplain #GARBAGE_COLLECTION_NOTIFICATION garbage collection notification}.
|
||||
* <br>Used by every notification emitted by the garbage collector, the details about
|
||||
* the notification are provided in the {@linkplain #getGcAction action} String
|
||||
* <p></li>
|
||||
* </li>
|
||||
* </ul>
|
||||
**/
|
||||
|
||||
|
@ -52,13 +52,13 @@ import sun.management.GcInfoBuilder;
|
||||
* </blockquote>
|
||||
*
|
||||
* <p>
|
||||
* <tt>GcInfo</tt> is a {@link CompositeData CompositeData}
|
||||
* {@code GcInfo} is a {@link CompositeData CompositeData}
|
||||
* The GC-specific attributes can be obtained via the CompositeData
|
||||
* interface. This is a historical relic, and other classes should
|
||||
* not copy this pattern. Use {@link CompositeDataView} instead.
|
||||
*
|
||||
* <h4>MXBean Mapping</h4>
|
||||
* <tt>GcInfo</tt> is mapped to a {@link CompositeData CompositeData}
|
||||
* {@code GcInfo} is mapped to a {@link CompositeData CompositeData}
|
||||
* with attributes as specified in the {@link #from from} method.
|
||||
*
|
||||
* @author Mandy Chung
|
||||
@ -152,11 +152,11 @@ public class GcInfo implements CompositeData, CompositeDataView {
|
||||
* Returns the memory usage of all memory pools
|
||||
* at the beginning of this GC.
|
||||
* This method returns
|
||||
* a <tt>Map</tt> of the name of a memory pool
|
||||
* a {@code Map} of the name of a memory pool
|
||||
* to the memory usage of the corresponding
|
||||
* memory pool before GC starts.
|
||||
*
|
||||
* @return a <tt>Map</tt> of memory pool names to the memory
|
||||
* @return a {@code Map} of memory pool names to the memory
|
||||
* usage of a memory pool before GC starts.
|
||||
*/
|
||||
public Map<String, MemoryUsage> getMemoryUsageBeforeGc() {
|
||||
@ -167,11 +167,11 @@ public class GcInfo implements CompositeData, CompositeDataView {
|
||||
* Returns the memory usage of all memory pools
|
||||
* at the end of this GC.
|
||||
* This method returns
|
||||
* a <tt>Map</tt> of the name of a memory pool
|
||||
* a {@code Map} of the name of a memory pool
|
||||
* to the memory usage of the corresponding
|
||||
* memory pool when GC finishes.
|
||||
*
|
||||
* @return a <tt>Map</tt> of memory pool names to the memory
|
||||
* @return a {@code Map} of memory pool names to the memory
|
||||
* usage of a memory pool when GC finishes.
|
||||
*/
|
||||
public Map<String, MemoryUsage> getMemoryUsageAfterGc() {
|
||||
@ -179,12 +179,11 @@ public class GcInfo implements CompositeData, CompositeDataView {
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a <tt>GcInfo</tt> object represented by the
|
||||
* given <tt>CompositeData</tt>. The given
|
||||
* <tt>CompositeData</tt> must contain
|
||||
* Returns a {@code GcInfo} object represented by the
|
||||
* given {@code CompositeData}. The given
|
||||
* {@code CompositeData} must contain
|
||||
* all the following attributes:
|
||||
*
|
||||
* <p>
|
||||
* <blockquote>
|
||||
* <table border>
|
||||
* <tr>
|
||||
@ -193,33 +192,33 @@ public class GcInfo implements CompositeData, CompositeDataView {
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>index</td>
|
||||
* <td><tt>java.lang.Long</tt></td>
|
||||
* <td>{@code java.lang.Long}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>startTime</td>
|
||||
* <td><tt>java.lang.Long</tt></td>
|
||||
* <td>{@code java.lang.Long}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>endTime</td>
|
||||
* <td><tt>java.lang.Long</tt></td>
|
||||
* <td>{@code java.lang.Long}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>memoryUsageBeforeGc</td>
|
||||
* <td><tt>javax.management.openmbean.TabularData</tt></td>
|
||||
* <td>{@code javax.management.openmbean.TabularData}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>memoryUsageAfterGc</td>
|
||||
* <td><tt>javax.management.openmbean.TabularData</tt></td>
|
||||
* <td>{@code javax.management.openmbean.TabularData}</td>
|
||||
* </tr>
|
||||
* </table>
|
||||
* </blockquote>
|
||||
*
|
||||
* @throws IllegalArgumentException if <tt>cd</tt> does not
|
||||
* represent a <tt>GcInfo</tt> object with the attributes
|
||||
* @throws IllegalArgumentException if {@code cd} does not
|
||||
* represent a {@code GcInfo} object with the attributes
|
||||
* described above.
|
||||
*
|
||||
* @return a <tt>GcInfo</tt> object represented by <tt>cd</tt>
|
||||
* if <tt>cd</tt> is not <tt>null</tt>; <tt>null</tt> otherwise.
|
||||
* @return a {@code GcInfo} object represented by {@code cd}
|
||||
* if {@code cd} is not {@code null}; {@code null} otherwise.
|
||||
*/
|
||||
public static GcInfo from(CompositeData cd) {
|
||||
if (cd == null) {
|
||||
@ -272,7 +271,7 @@ public class GcInfo implements CompositeData, CompositeDataView {
|
||||
}
|
||||
|
||||
/**
|
||||
* <p>Return the {@code CompositeData} representation of this
|
||||
* Return the {@code CompositeData} representation of this
|
||||
* {@code GcInfo}, including any GC-specific attributes. The
|
||||
* returned value will have at least all the attributes described
|
||||
* in the {@link #from(CompositeData) from} method, plus optionally
|
||||
|
@ -42,10 +42,10 @@ import javax.management.openmbean.CompositeData;
|
||||
* be set dynamically via a management interface after
|
||||
* the VM was started.
|
||||
*
|
||||
* A <tt>VMOption</tt> contains the value of a VM option
|
||||
* and the origin of that value at the time this <tt>VMOption</tt>
|
||||
* A {@code VMOption} contains the value of a VM option
|
||||
* and the origin of that value at the time this {@code VMOption}
|
||||
* object was constructed. The value of the VM option
|
||||
* may be changed after the <tt>VMOption</tt> object was constructed,
|
||||
* may be changed after the {@code VMOption} object was constructed,
|
||||
*
|
||||
* @see <a href="{@docRoot}/../../../../technotes/guides/vm/index.html">
|
||||
* Java Virtual Machine</a>
|
||||
@ -108,15 +108,15 @@ public class VMOption {
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a <tt>VMOption</tt>.
|
||||
* Constructs a {@code VMOption}.
|
||||
*
|
||||
* @param name Name of a VM option.
|
||||
* @param value Value of a VM option.
|
||||
* @param writeable <tt>true</tt> if a VM option can be set dynamically,
|
||||
* or <tt>false</tt> otherwise.
|
||||
* @param writeable {@code true} if a VM option can be set dynamically,
|
||||
* or {@code false} otherwise.
|
||||
* @param origin where the value of a VM option came from.
|
||||
*
|
||||
* @throws NullPointerException if the name or value is <tt>null</tt>
|
||||
* @throws NullPointerException if the name or value is {@code null}
|
||||
*/
|
||||
public VMOption(String name, String value, boolean writeable, Origin origin) {
|
||||
this.name = name;
|
||||
@ -126,7 +126,7 @@ public class VMOption {
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a <tt>VMOption</tt> object from a
|
||||
* Constructs a {@code VMOption} object from a
|
||||
* {@link CompositeData CompositeData}.
|
||||
*/
|
||||
private VMOption(CompositeData cd) {
|
||||
@ -150,10 +150,10 @@ public class VMOption {
|
||||
|
||||
/**
|
||||
* Returns the value of this VM option at the time when
|
||||
* this <tt>VMOption</tt> was created. The value could have been changed.
|
||||
* this {@code VMOption} was created. The value could have been changed.
|
||||
*
|
||||
* @return the value of the VM option at the time when
|
||||
* this <tt>VMOption</tt> was created.
|
||||
* this {@code VMOption} was created.
|
||||
*/
|
||||
public String getValue() {
|
||||
return value;
|
||||
@ -174,7 +174,7 @@ public class VMOption {
|
||||
* it can be set by the {@link HotSpotDiagnosticMXBean#setVMOption
|
||||
* HotSpotDiagnosticMXBean.setVMOption} method.
|
||||
*
|
||||
* @return <tt>true</tt> if this VM option is writeable; <tt>false</tt>
|
||||
* @return {@code true} if this VM option is writeable; {@code false}
|
||||
* otherwise.
|
||||
*/
|
||||
public boolean isWriteable() {
|
||||
@ -189,10 +189,10 @@ public class VMOption {
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a <tt>VMOption</tt> object represented by the
|
||||
* given <tt>CompositeData</tt>. The given <tt>CompositeData</tt>
|
||||
* Returns a {@code VMOption} object represented by the
|
||||
* given {@code CompositeData}. The given {@code CompositeData}
|
||||
* must contain the following attributes:
|
||||
* <p>
|
||||
*
|
||||
* <blockquote>
|
||||
* <table border>
|
||||
* <tr>
|
||||
@ -201,32 +201,32 @@ public class VMOption {
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>name</td>
|
||||
* <td><tt>java.lang.String</tt></td>
|
||||
* <td>{@code java.lang.String}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>value</td>
|
||||
* <td><tt>java.lang.String</tt></td>
|
||||
* <td>{@code java.lang.String}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>origin</td>
|
||||
* <td><tt>java.lang.String</tt></td>
|
||||
* <td>{@code java.lang.String}</td>
|
||||
* </tr>
|
||||
* <tr>
|
||||
* <td>writeable</td>
|
||||
* <td><tt>java.lang.Boolean</tt></td>
|
||||
* <td>{@code java.lang.Boolean}</td>
|
||||
* </tr>
|
||||
* </table>
|
||||
* </blockquote>
|
||||
*
|
||||
* @param cd <tt>CompositeData</tt> representing a <tt>VMOption</tt>
|
||||
* @param cd {@code CompositeData} representing a {@code VMOption}
|
||||
*
|
||||
* @throws IllegalArgumentException if <tt>cd</tt> does not
|
||||
* represent a <tt>VMOption</tt> with the attributes described
|
||||
* @throws IllegalArgumentException if {@code cd} does not
|
||||
* represent a {@code VMOption} with the attributes described
|
||||
* above.
|
||||
*
|
||||
* @return a <tt>VMOption</tt> object represented by <tt>cd</tt>
|
||||
* if <tt>cd</tt> is not <tt>null</tt>;
|
||||
* <tt>null</tt> otherwise.
|
||||
* @return a {@code VMOption} object represented by {@code cd}
|
||||
* if {@code cd} is not {@code null};
|
||||
* {@code null} otherwise.
|
||||
*/
|
||||
public static VMOption from(CompositeData cd) {
|
||||
if (cd == null) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -78,10 +78,9 @@ import java.lang.Double;
|
||||
* under which these calls cannot even enqueue the requested operation for
|
||||
* later processing. Even under these circumstances it is generally better to
|
||||
* simply ignore the invocation and return, rather than throwing an
|
||||
* exception. Under these circumstances, however, all subsequent invocations
|
||||
* of <tt>flush()</tt> and <tt>sync</tt> should return <tt>false</tt>, as
|
||||
* returning <tt>true</tt> would imply that all previous operations had
|
||||
* successfully been made permanent.
|
||||
* exception. Under these circumstances, however, subsequently invoking
|
||||
* <tt>flush()</tt> or <tt>sync</tt> would not imply that all previous
|
||||
* operations had successfully been made permanent.
|
||||
*
|
||||
* <p>There is one circumstance under which <tt>putSpi, removeSpi and
|
||||
* childSpi</tt> <i>should</i> throw an exception: if the caller lacks
|
||||
@ -122,6 +121,13 @@ import java.lang.Double;
|
||||
* @since 1.4
|
||||
*/
|
||||
public abstract class AbstractPreferences extends Preferences {
|
||||
/**
|
||||
* The code point U+0000, assigned to the null control character, is the
|
||||
* only character encoded in Unicode and ISO/IEC 10646 that is always
|
||||
* invalid in any XML 1.0 and 1.1 document.
|
||||
*/
|
||||
static final int CODE_POINT_U0000 = '\u0000';
|
||||
|
||||
/**
|
||||
* Our name relative to parent.
|
||||
*/
|
||||
@ -234,6 +240,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws IllegalArgumentException if <tt>key.length()</tt> exceeds
|
||||
* <tt>MAX_KEY_LENGTH</tt> or if <tt>value.length</tt> exceeds
|
||||
* <tt>MAX_VALUE_LENGTH</tt>.
|
||||
* @throws IllegalArgumentException if either key or value contain
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -244,6 +252,10 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
throw new IllegalArgumentException("Key too long: "+key);
|
||||
if (value.length() > MAX_VALUE_LENGTH)
|
||||
throw new IllegalArgumentException("Value too long: "+value);
|
||||
if (key.indexOf(CODE_POINT_U0000) != -1)
|
||||
throw new IllegalArgumentException("Key contains code point U+0000");
|
||||
if (value.indexOf(CODE_POINT_U0000) != -1)
|
||||
throw new IllegalArgumentException("Value contains code point U+0000");
|
||||
|
||||
synchronized(lock) {
|
||||
if (removed)
|
||||
@ -275,10 +287,14 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if key is <tt>null</tt>. (A
|
||||
* <tt>null</tt> default <i>is</i> permitted.)
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public String get(String key, String def) {
|
||||
if (key==null)
|
||||
throw new NullPointerException("Null key");
|
||||
if (key.indexOf(CODE_POINT_U0000) != -1)
|
||||
throw new IllegalArgumentException("Key contains code point U+0000");
|
||||
synchronized(lock) {
|
||||
if (removed)
|
||||
throw new IllegalStateException("Node has been removed.");
|
||||
@ -306,10 +322,14 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @param key key whose mapping is to be removed from the preference node.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @throws NullPointerException {@inheritDoc}.
|
||||
*/
|
||||
public void remove(String key) {
|
||||
Objects.requireNonNull(key, "Specified key cannot be null");
|
||||
if (key.indexOf(CODE_POINT_U0000) != -1)
|
||||
throw new IllegalArgumentException("Key contains code point U+0000");
|
||||
synchronized(lock) {
|
||||
if (removed)
|
||||
throw new IllegalStateException("Node has been removed.");
|
||||
@ -353,6 +373,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws NullPointerException if key is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if <tt>key.length()</tt> exceeds
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -381,6 +403,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public int getInt(String key, int def) {
|
||||
int result = def;
|
||||
@ -408,6 +432,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws NullPointerException if key is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if <tt>key.length()</tt> exceeds
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -436,6 +462,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public long getLong(String key, long def) {
|
||||
long result = def;
|
||||
@ -463,6 +491,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws NullPointerException if key is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if <tt>key.length()</tt> exceeds
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -494,6 +524,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public boolean getBoolean(String key, boolean def) {
|
||||
boolean result = def;
|
||||
@ -521,6 +553,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws NullPointerException if key is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if <tt>key.length()</tt> exceeds
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -549,6 +583,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public float getFloat(String key, float def) {
|
||||
float result = def;
|
||||
@ -576,6 +612,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws NullPointerException if key is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if <tt>key.length()</tt> exceeds
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -604,6 +642,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public double getDouble(String key, double def) {
|
||||
double result = def;
|
||||
@ -627,6 +667,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* @throws NullPointerException if key or value is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key.length() exceeds MAX_KEY_LENGTH
|
||||
* or if value.length exceeds MAX_VALUE_LENGTH*3/4.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
*/
|
||||
@ -650,6 +692,8 @@ public abstract class AbstractPreferences extends Preferences {
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>. (A
|
||||
* <tt>null</tt> value for <tt>def</tt> <i>is</i> permitted.)
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public byte[] getByteArray(String key, byte[] def) {
|
||||
byte[] result = def;
|
||||
|
@ -489,7 +489,7 @@ public abstract class Preferences {
|
||||
* <tt>MAX_VALUE_LENGTH</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if either the key or the value contain
|
||||
* @throws IllegalArgumentException if either key or value contain
|
||||
* the null control character, code point U+0000.
|
||||
*/
|
||||
public abstract void put(String key, String value);
|
||||
@ -514,6 +514,8 @@ public abstract class Preferences {
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>. (A
|
||||
* <tt>null</tt> value for <tt>def</tt> <i>is</i> permitted.)
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public abstract String get(String key, String def);
|
||||
|
||||
@ -530,6 +532,8 @@ public abstract class Preferences {
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
*/
|
||||
public abstract void remove(String key);
|
||||
|
||||
@ -566,6 +570,8 @@ public abstract class Preferences {
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @see #getInt(String,int)
|
||||
*/
|
||||
public abstract void putInt(String key, int value);
|
||||
@ -597,6 +603,8 @@ public abstract class Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @see #putInt(String,int)
|
||||
* @see #get(String,String)
|
||||
*/
|
||||
@ -616,6 +624,8 @@ public abstract class Preferences {
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @see #getLong(String,long)
|
||||
*/
|
||||
public abstract void putLong(String key, long value);
|
||||
@ -647,6 +657,8 @@ public abstract class Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @see #putLong(String,long)
|
||||
* @see #get(String,String)
|
||||
*/
|
||||
@ -666,6 +678,8 @@ public abstract class Preferences {
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @see #getBoolean(String,boolean)
|
||||
* @see #get(String,String)
|
||||
*/
|
||||
@ -702,6 +716,8 @@ public abstract class Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @see #get(String,String)
|
||||
* @see #putBoolean(String,boolean)
|
||||
*/
|
||||
@ -721,6 +737,8 @@ public abstract class Preferences {
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @see #getFloat(String,float)
|
||||
*/
|
||||
public abstract void putFloat(String key, float value);
|
||||
@ -751,6 +769,8 @@ public abstract class Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @see #putFloat(String,float)
|
||||
* @see #get(String,String)
|
||||
*/
|
||||
@ -770,6 +790,8 @@ public abstract class Preferences {
|
||||
* <tt>MAX_KEY_LENGTH</tt>.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @see #getDouble(String,double)
|
||||
*/
|
||||
public abstract void putDouble(String key, double value);
|
||||
@ -800,6 +822,8 @@ public abstract class Preferences {
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>.
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @see #putDouble(String,double)
|
||||
* @see #get(String,String)
|
||||
*/
|
||||
@ -825,6 +849,8 @@ public abstract class Preferences {
|
||||
* or if value.length exceeds MAX_VALUE_LENGTH*3/4.
|
||||
* @throws IllegalStateException if this node (or an ancestor) has been
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws IllegalArgumentException if key contains
|
||||
* the null control character, code point U+0000.
|
||||
* @see #getByteArray(String,byte[])
|
||||
* @see #get(String,String)
|
||||
*/
|
||||
@ -864,6 +890,8 @@ public abstract class Preferences {
|
||||
* removed with the {@link #removeNode()} method.
|
||||
* @throws NullPointerException if <tt>key</tt> is <tt>null</tt>. (A
|
||||
* <tt>null</tt> value for <tt>def</tt> <i>is</i> permitted.)
|
||||
* @throws IllegalArgumentException if key contains the null control
|
||||
* character, code point U+0000.
|
||||
* @see #get(String,String)
|
||||
* @see #putByteArray(String,byte[])
|
||||
*/
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2000, 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
|
||||
@ -49,13 +49,6 @@ import sun.util.logging.PlatformLogger;
|
||||
*/
|
||||
class FileSystemPreferences extends AbstractPreferences {
|
||||
|
||||
/**
|
||||
* The code point U+0000, assigned to the null control character, is the
|
||||
* only character encoded in Unicode and ISO/IEC 10646 that is always
|
||||
* invalid in any XML 1.0 and 1.1 document.
|
||||
*/
|
||||
private static final String CODE_POINT_U0000 = String.valueOf('\u0000');
|
||||
|
||||
static {
|
||||
PrivilegedAction<Void> load = () -> {
|
||||
System.loadLibrary("prefs");
|
||||
@ -532,11 +525,6 @@ class FileSystemPreferences extends AbstractPreferences {
|
||||
}
|
||||
|
||||
protected void putSpi(String key, String value) {
|
||||
if (key.indexOf(CODE_POINT_U0000) != -1) {
|
||||
throw new IllegalArgumentException("Key contains code point U+0000");
|
||||
} else if (value.indexOf(CODE_POINT_U0000) != -1) {
|
||||
throw new IllegalArgumentException("Value contains code point U+0000");
|
||||
}
|
||||
initCacheIfNecessary();
|
||||
changeLog.add(new Put(key, value));
|
||||
prefsCache.put(key, value);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2000, 2002, 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.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -25,8 +25,6 @@
|
||||
|
||||
package java.util.prefs;
|
||||
|
||||
import java.util.Map;
|
||||
import java.util.TreeMap;
|
||||
import java.util.StringTokenizer;
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.security.AccessController;
|
||||
@ -46,7 +44,7 @@ import sun.util.logging.PlatformLogger;
|
||||
* @since 1.4
|
||||
*/
|
||||
|
||||
class WindowsPreferences extends AbstractPreferences{
|
||||
class WindowsPreferences extends AbstractPreferences {
|
||||
|
||||
static {
|
||||
PrivilegedAction<Void> load = () -> {
|
||||
@ -620,22 +618,22 @@ class WindowsPreferences extends AbstractPreferences{
|
||||
* @see #getSpi(String)
|
||||
*/
|
||||
protected void putSpi(String javaName, String value) {
|
||||
int nativeHandle = openKey(KEY_SET_VALUE);
|
||||
if (nativeHandle == NULL_NATIVE_HANDLE) {
|
||||
isBackingStoreAvailable = false;
|
||||
return;
|
||||
}
|
||||
int result = WindowsRegSetValueEx1(nativeHandle,
|
||||
toWindowsName(javaName), toWindowsValueString(value));
|
||||
if (result != ERROR_SUCCESS) {
|
||||
logger().warning("Could not assign value to key " +
|
||||
byteArrayToString(toWindowsName(javaName))+ " at Windows registry node "
|
||||
+ byteArrayToString(windowsAbsolutePath()) + " at root 0x"
|
||||
+ Integer.toHexString(rootNativeHandle()) +
|
||||
". Windows RegSetValueEx(...) returned error code " + result + ".");
|
||||
isBackingStoreAvailable = false;
|
||||
int nativeHandle = openKey(KEY_SET_VALUE);
|
||||
if (nativeHandle == NULL_NATIVE_HANDLE) {
|
||||
isBackingStoreAvailable = false;
|
||||
return;
|
||||
}
|
||||
closeKey(nativeHandle);
|
||||
int result = WindowsRegSetValueEx1(nativeHandle,
|
||||
toWindowsName(javaName), toWindowsValueString(value));
|
||||
if (result != ERROR_SUCCESS) {
|
||||
logger().warning("Could not assign value to key " +
|
||||
byteArrayToString(toWindowsName(javaName))+ " at Windows registry node "
|
||||
+ byteArrayToString(windowsAbsolutePath()) + " at root 0x"
|
||||
+ Integer.toHexString(rootNativeHandle()) +
|
||||
". Windows RegSetValueEx(...) returned error code " + result + ".");
|
||||
isBackingStoreAvailable = false;
|
||||
}
|
||||
closeKey(nativeHandle);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -645,18 +643,18 @@ class WindowsPreferences extends AbstractPreferences{
|
||||
* @see #putSpi(String, String)
|
||||
*/
|
||||
protected String getSpi(String javaName) {
|
||||
int nativeHandle = openKey(KEY_QUERY_VALUE);
|
||||
if (nativeHandle == NULL_NATIVE_HANDLE) {
|
||||
return null;
|
||||
}
|
||||
Object resultObject = WindowsRegQueryValueEx(nativeHandle,
|
||||
toWindowsName(javaName));
|
||||
if (resultObject == null) {
|
||||
int nativeHandle = openKey(KEY_QUERY_VALUE);
|
||||
if (nativeHandle == NULL_NATIVE_HANDLE) {
|
||||
return null;
|
||||
}
|
||||
Object resultObject = WindowsRegQueryValueEx(nativeHandle,
|
||||
toWindowsName(javaName));
|
||||
if (resultObject == null) {
|
||||
closeKey(nativeHandle);
|
||||
return null;
|
||||
}
|
||||
closeKey(nativeHandle);
|
||||
return null;
|
||||
}
|
||||
closeKey(nativeHandle);
|
||||
return toJavaValueString((byte[]) resultObject);
|
||||
return toJavaValueString((byte[]) resultObject);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -46,27 +46,23 @@ The API is defined by classes in the package
|
||||
<a href="CommandAPDU.html">CommandAPDU</a>,
|
||||
<a href="ResponseAPDU.html">ResponseAPDU</a>
|
||||
|
||||
<p>
|
||||
<dt>Factory to obtain implementations
|
||||
<dd>
|
||||
<a href="TerminalFactory.html">TerminalFactory</a>
|
||||
|
||||
<p>
|
||||
<dt>Main classes for card and terminal functions
|
||||
<dd>
|
||||
<a href="CardTerminals.html">CardTerminals</a>,
|
||||
<a href="CardTerminal.html">CardTerminal</a>,
|
||||
<a href="CardTerminals.html">CardTerminals</a>,
|
||||
<a href="CardTerminal.html">CardTerminal</a>,
|
||||
<a href="Card.html">Card</a>,
|
||||
<a href="CardChannel.html">CardChannel</a>
|
||||
|
||||
<p>
|
||||
<dt>Supporting permission and exception classes
|
||||
<dd>
|
||||
<a href="CardPermission.html">CardPermission</a>,
|
||||
<a href="CardException.html">CardException</a>,
|
||||
<a href="CardPermission.html">CardPermission</a>,
|
||||
<a href="CardException.html">CardException</a>,
|
||||
<a href="CardNotPresentException.html">CardNotPresentException</a>
|
||||
|
||||
<p>
|
||||
<dt>Service provider interface, not accessed directly by applications
|
||||
<dd>
|
||||
<a href="TerminalFactorySpi.html">TerminalFactorySpi</a>
|
||||
@ -94,7 +90,6 @@ A simple example of using the API is:
|
||||
card.disconnect(false);
|
||||
</pre>
|
||||
|
||||
<P>
|
||||
@since 1.6
|
||||
@author Andreas Sterbenz
|
||||
@author JSR 268 Expert Group
|
||||
|
@ -29,15 +29,15 @@ package com.sun.tools.attach;
|
||||
* The exception thrown when an agent fails to initialize in the target
|
||||
* Java virtual machine.
|
||||
*
|
||||
* <p> This exception is thrown by {@link
|
||||
* com.sun.tools.attach.VirtualMachine#loadAgent VirtualMachine.loadAgent},
|
||||
* <p> This exception is thrown by
|
||||
* {@link com.sun.tools.attach.VirtualMachine#loadAgent VirtualMachine.loadAgent},
|
||||
* {@link com.sun.tools.attach.VirtualMachine#loadAgentLibrary
|
||||
* VirtualMachine.loadAgentLibrary}, {@link
|
||||
* com.sun.tools.attach.VirtualMachine#loadAgentPath VirtualMachine.loadAgentPath}
|
||||
* VirtualMachine.loadAgentLibrary},
|
||||
* {@link com.sun.tools.attach.VirtualMachine#loadAgentPath VirtualMachine.loadAgentPath}
|
||||
* methods if an agent, or agent library, cannot be initialized.
|
||||
* When thrown by <tt>VirtualMachine.loadAgentLibrary</tt>, or
|
||||
* <tt>VirtualMachine.loadAgentPath</tt> then the exception encapsulates
|
||||
* the error returned by the agent's <code>Agent_OnAttach</code> function.
|
||||
* When thrown by {@code VirtualMachine.loadAgentLibrary}, or
|
||||
* {@code VirtualMachine.loadAgentPath} then the exception encapsulates
|
||||
* the error returned by the agent's {@code Agent_OnAttach} function.
|
||||
* This error code can be obtained by invoking the {@link #returnValue() returnValue} method.
|
||||
*/
|
||||
@jdk.Exported
|
||||
@ -49,7 +49,7 @@ public class AgentInitializationException extends Exception {
|
||||
private int returnValue;
|
||||
|
||||
/**
|
||||
* Constructs an <code>AgentInitializationException</code> with
|
||||
* Constructs an {@code AgentInitializationException} with
|
||||
* no detail message.
|
||||
*/
|
||||
public AgentInitializationException() {
|
||||
@ -58,7 +58,7 @@ public class AgentInitializationException extends Exception {
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs an <code>AgentInitializationException</code> with
|
||||
* Constructs an {@code AgentInitializationException} with
|
||||
* the specified detail message.
|
||||
*
|
||||
* @param s the detail message.
|
||||
@ -69,9 +69,9 @@ public class AgentInitializationException extends Exception {
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs an <code>AgentInitializationException</code> with
|
||||
* Constructs an {@code AgentInitializationException} with
|
||||
* the specified detail message and the return value from the
|
||||
* execution of the agent's <code>Agent_OnAttach</code> function.
|
||||
* execution of the agent's {@code Agent_OnAttach} function.
|
||||
*
|
||||
* @param s the detail message.
|
||||
* @param returnValue the return value
|
||||
@ -83,8 +83,8 @@ public class AgentInitializationException extends Exception {
|
||||
|
||||
/**
|
||||
* If the exception was created with the return value from the agent
|
||||
* <code>Agent_OnAttach</code> function then this returns that value,
|
||||
* otherwise returns <code>0</code>. </p>
|
||||
* {@code Agent_OnAttach} function then this returns that value,
|
||||
* otherwise returns {@code 0}.
|
||||
*
|
||||
* @return the return value
|
||||
*/
|
||||
|
@ -41,7 +41,7 @@ import java.util.ServiceLoader;
|
||||
*
|
||||
* <p> An attach provider is a concrete subclass of this class that has a
|
||||
* zero-argument constructor and implements the abstract methods specified
|
||||
* below. </p>
|
||||
* below.
|
||||
*
|
||||
* <p> An attach provider implementation is typically tied to a Java virtual
|
||||
* machine implementation, version, or even mode of operation. That is, a specific
|
||||
@ -51,7 +51,7 @@ import java.util.ServiceLoader;
|
||||
* Sun's <i>HotSpot</i> virtual machine. In general, if an environment
|
||||
* consists of Java virtual machines of different versions and from different
|
||||
* vendors then there will be an attach provider implementation for each
|
||||
* <i>family</i> of implementations or versions. </p>
|
||||
* <i>family</i> of implementations or versions.
|
||||
*
|
||||
* <p> An attach provider is identified by its {@link #name <i>name</i>} and
|
||||
* {@link #type <i>type</i>}. The <i>name</i> is typically, but not required to
|
||||
@ -61,15 +61,15 @@ import java.util.ServiceLoader;
|
||||
* implementation that uses the Doors inter-process communication mechanism
|
||||
* might use the type <i>"doors"</i>. The purpose of the name and type is to
|
||||
* identify providers in environments where there are multiple providers
|
||||
* installed. </p>
|
||||
* installed.
|
||||
*
|
||||
* <p> AttachProvider implementations are loaded and instantiated at the first
|
||||
* invocation of the {@link #providers() providers} method. This method
|
||||
* attempts to load all provider implementations that are installed on the
|
||||
* platform. </p>
|
||||
* platform.
|
||||
*
|
||||
* <p> All of the methods in this class are safe for use by multiple
|
||||
* concurrent threads. </p>
|
||||
* concurrent threads.
|
||||
*
|
||||
* @since 1.6
|
||||
*/
|
||||
@ -81,12 +81,12 @@ public abstract class AttachProvider {
|
||||
private static List<AttachProvider> providers = null;
|
||||
|
||||
/**
|
||||
* Initializes a new instance of this class. </p>
|
||||
* Initializes a new instance of this class.
|
||||
*
|
||||
* @throws SecurityException
|
||||
* If a security manager has been installed and it denies
|
||||
* {@link com.sun.tools.attach.AttachPermission AttachPermission}
|
||||
* <tt>("createAttachProvider")</tt>
|
||||
* ("{@code createAttachProvider}")
|
||||
*/
|
||||
protected AttachProvider() {
|
||||
SecurityManager sm = System.getSecurityManager();
|
||||
@ -95,14 +95,14 @@ public abstract class AttachProvider {
|
||||
}
|
||||
|
||||
/**
|
||||
* Return this provider's name. </p>
|
||||
* Return this provider's name.
|
||||
*
|
||||
* @return The name of this provider
|
||||
*/
|
||||
public abstract String name();
|
||||
|
||||
/**
|
||||
* Return this provider's type. </p>
|
||||
* Return this provider's type.
|
||||
*
|
||||
* @return The type of this provider
|
||||
*/
|
||||
@ -113,18 +113,18 @@ public abstract class AttachProvider {
|
||||
*
|
||||
* <p> A Java virtual machine is identified by an abstract identifier. The
|
||||
* nature of this identifier is platform dependent but in many cases it will be the
|
||||
* string representation of the process identifier (or pid). </p>
|
||||
* string representation of the process identifier (or pid).
|
||||
*
|
||||
* <p> This method parses the identifier and maps the identifier to a Java
|
||||
* virtual machine (in an implementation dependent manner). If the identifier
|
||||
* cannot be parsed by the provider then an {@link
|
||||
* com.sun.tools.attach.AttachNotSupportedException AttachNotSupportedException}
|
||||
* cannot be parsed by the provider then an
|
||||
* {@link com.sun.tools.attach.AttachNotSupportedException AttachNotSupportedException}
|
||||
* is thrown. Once parsed this method attempts to attach to the Java virtual machine.
|
||||
* If the provider detects that the identifier corresponds to a Java virtual machine
|
||||
* that does not exist, or it corresponds to a Java virtual machine that does not support
|
||||
* the attach mechanism implemented by this provider, or it detects that the
|
||||
* Java virtual machine is a version to which this provider cannot attach, then
|
||||
* an <code>AttachNotSupportedException</code> is thrown. </p>
|
||||
* an {@code AttachNotSupportedException} is thrown.
|
||||
*
|
||||
* @param id
|
||||
* The abstract identifier that identifies the Java virtual machine.
|
||||
@ -134,7 +134,7 @@ public abstract class AttachProvider {
|
||||
* @throws SecurityException
|
||||
* If a security manager has been installed and it denies
|
||||
* {@link com.sun.tools.attach.AttachPermission AttachPermission}
|
||||
* <tt>("attachVirtualMachine")</tt>, or other permission
|
||||
* ("{@code attachVirtualMachine}"), or other permission
|
||||
* required by the implementation.
|
||||
*
|
||||
* @throws AttachNotSupportedException
|
||||
@ -147,7 +147,7 @@ public abstract class AttachProvider {
|
||||
* If some other I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>id</code> is <code>null</code>
|
||||
* If {@code id} is {@code null}
|
||||
*/
|
||||
public abstract VirtualMachine attachVirtualMachine(String id)
|
||||
throws AttachNotSupportedException, IOException;
|
||||
@ -155,10 +155,10 @@ public abstract class AttachProvider {
|
||||
/**
|
||||
* Attaches to a Java virtual machine.
|
||||
*
|
||||
* <p> A Java virtual machine can be described using a {@link
|
||||
* com.sun.tools.attach.VirtualMachineDescriptor VirtualMachineDescriptor}.
|
||||
* This method invokes the descriptor's {@link
|
||||
* com.sun.tools.attach.VirtualMachineDescriptor#provider() provider()} method
|
||||
* <p> A Java virtual machine can be described using a
|
||||
* {@link com.sun.tools.attach.VirtualMachineDescriptor VirtualMachineDescriptor}.
|
||||
* This method invokes the descriptor's
|
||||
* {@link com.sun.tools.attach.VirtualMachineDescriptor#provider() provider()} method
|
||||
* to check that it is equal to this provider. It then attempts to attach to the
|
||||
* Java virtual machine.
|
||||
*
|
||||
@ -170,20 +170,20 @@ public abstract class AttachProvider {
|
||||
* @throws SecurityException
|
||||
* If a security manager has been installed and it denies
|
||||
* {@link com.sun.tools.attach.AttachPermission AttachPermission}
|
||||
* <tt>("attachVirtualMachine")</tt>, or other permission
|
||||
* ("{@code attachVirtualMachine}"), or other permission
|
||||
* required by the implementation.
|
||||
*
|
||||
* @throws AttachNotSupportedException
|
||||
* If the descriptor's {@link
|
||||
* com.sun.tools.attach.VirtualMachineDescriptor#provider() provider()} method
|
||||
* returns a provider that is not this provider, or it does not correspond
|
||||
* to a Java virtual machine to which this provider can attach.
|
||||
* If the descriptor's
|
||||
* {@link com.sun.tools.attach.VirtualMachineDescriptor#provider() provider()}
|
||||
* method returns a provider that is not this provider, or it does not
|
||||
* correspond to a Java virtual machine to which this provider can attach.
|
||||
*
|
||||
* @throws IOException
|
||||
* If some other I/O error occurs
|
||||
*
|
||||
* @throws NullPointerException
|
||||
* If <code>vmd</code> is <code>null</code>
|
||||
* If {@code vmd} is {@code null}
|
||||
*/
|
||||
public VirtualMachine attachVirtualMachine(VirtualMachineDescriptor vmd)
|
||||
throws AttachNotSupportedException, IOException
|
||||
@ -197,12 +197,13 @@ public abstract class AttachProvider {
|
||||
/**
|
||||
* Lists the Java virtual machines known to this provider.
|
||||
*
|
||||
* <p> This method returns a list of {@link
|
||||
* com.sun.tools.attach.VirtualMachineDescriptor} elements. Each
|
||||
* <code>VirtualMachineDescriptor</code> describes a Java virtual machine
|
||||
* <p> This method returns a list of
|
||||
* {@link com.sun.tools.attach.VirtualMachineDescriptor} elements. Each
|
||||
* {@code VirtualMachineDescriptor} describes a Java virtual machine
|
||||
* to which this provider can <i>potentially</i> attach. There isn't any
|
||||
* guarantee that invoking {@link #attachVirtualMachine(VirtualMachineDescriptor)
|
||||
* attachVirtualMachine} on each descriptor in the list will succeed.
|
||||
* guarantee that invoking
|
||||
* {@link #attachVirtualMachine(VirtualMachineDescriptor) attachVirtualMachine}
|
||||
* on each descriptor in the list will succeed.
|
||||
*
|
||||
* @return The list of virtual machine descriptors which describe the
|
||||
* Java virtual machines known to this provider (may be empty).
|
||||
@ -216,31 +217,31 @@ public abstract class AttachProvider {
|
||||
* <p> An AttachProvider is installed on the platform if:
|
||||
*
|
||||
* <ul>
|
||||
* <li><p>It is installed in a JAR file that is visible to the defining
|
||||
* <li>It is installed in a JAR file that is visible to the defining
|
||||
* class loader of the AttachProvider type (usually, but not required
|
||||
* to be, the {@link java.lang.ClassLoader#getSystemClassLoader system
|
||||
* class loader}).</p></li>
|
||||
* class loader}).</li>
|
||||
*
|
||||
* <li><p>The JAR file contains a provider configuration named
|
||||
* <tt>com.sun.tools.attach.spi.AttachProvider</tt> in the resource directory
|
||||
* <tt>META-INF/services</tt>. </p></li>
|
||||
* <li>The JAR file contains a provider configuration named
|
||||
* {@code com.sun.tools.attach.spi.AttachProvider} in the resource directory
|
||||
* {@code META-INF/services}.</li>
|
||||
*
|
||||
* <li><p>The provider configuration file lists the full-qualified class
|
||||
* name of the AttachProvider implementation. </p></li>
|
||||
* <li>The provider configuration file lists the full-qualified class
|
||||
* name of the AttachProvider implementation.</li>
|
||||
* </ul>
|
||||
*
|
||||
* <p> The format of the provider configuration file is one fully-qualified
|
||||
* class name per line. Space and tab characters surrounding each class name,
|
||||
* as well as blank lines are ignored. The comment character is
|
||||
* <tt>'#'</tt> (<tt>0x23</tt>), and on each line all characters following
|
||||
* {@code '#'} ({@code 0x23}), and on each line all characters following
|
||||
* the first comment character are ignored. The file must be encoded in
|
||||
* UTF-8. </p>
|
||||
* UTF-8.
|
||||
*
|
||||
* <p> AttachProvider implementations are loaded and instantiated
|
||||
* (using the zero-arg constructor) at the first invocation of this method.
|
||||
* The list returned by the first invocation of this method is the list
|
||||
* of providers. Subsequent invocations of this method return a list of the same
|
||||
* providers. The list is unmodifable.</p>
|
||||
* providers. The list is unmodifable.
|
||||
*
|
||||
* @return A list of the installed attach providers.
|
||||
*/
|
||||
|
@ -72,7 +72,7 @@ public abstract class Filter {
|
||||
* exchange handler will not be invoked.
|
||||
* @param exchange the HttpExchange
|
||||
* @throws IOException let exceptions pass up the stack
|
||||
* @throws NullPointerException if exchange is <code>null</code>
|
||||
* @throws NullPointerException if exchange is {@code null}
|
||||
*/
|
||||
public void doFilter (HttpExchange exchange) throws IOException {
|
||||
if (!iter.hasNext()) {
|
||||
@ -86,14 +86,14 @@ public abstract class Filter {
|
||||
|
||||
/**
|
||||
* Asks this filter to pre/post-process the given exchange. The filter
|
||||
* can :-
|
||||
* can:
|
||||
* <ul><li>examine or modify the request headers</li>
|
||||
* <li>filter the request body or the response body, by creating suitable
|
||||
* filter streams and calling
|
||||
* {@link HttpExchange#setStreams(InputStream,OutputStream)}</li>
|
||||
* <li>set attribute Objects in the exchange, which other filters or the
|
||||
* exchange handler can access.</li>
|
||||
* <li>decide to either :-<ol>
|
||||
* <li>decide to either<ol>
|
||||
* <li>invoke the next filter in the chain, by calling
|
||||
* {@link Filter.Chain#doFilter(HttpExchange)}</li>
|
||||
* <li>terminate the chain of invocation, by <b>not</b> calling
|
||||
@ -102,12 +102,13 @@ public abstract class Filter {
|
||||
* filters in the Chain have been called, and the response headers can be
|
||||
* examined or modified.</li>
|
||||
* <li>if option 2. above taken, then this Filter must use the HttpExchange
|
||||
* to send back an appropriate response</li></ul><p>
|
||||
* @param exchange the <code>HttpExchange</code> to be filtered.
|
||||
* to send back an appropriate response</li></ul>
|
||||
*
|
||||
* @param exchange the {@code HttpExchange} to be filtered.
|
||||
* @param chain the Chain which allows the next filter to be invoked.
|
||||
* @throws IOException may be thrown by any filter module, and if
|
||||
* caught, must be rethrown again.
|
||||
* @throws NullPointerException if either exchange or chain are <code>null</code>
|
||||
* @throws NullPointerException if either exchange or chain are {@code null}
|
||||
*/
|
||||
public abstract void doFilter (HttpExchange exchange, Chain chain)
|
||||
throws IOException;
|
||||
|
@ -29,18 +29,21 @@ import java.util.*;
|
||||
|
||||
/**
|
||||
* HTTP request and response headers are represented by this class which implements
|
||||
* the interface {@link java.util.Map}<
|
||||
* {@link java.lang.String},{@link java.util.List}<{@link java.lang.String}>>.
|
||||
* the interface
|
||||
* {@link java.util.Map}{@literal <}{@link java.lang.String}, {@link java.util.List}
|
||||
* {@literal <}{@link java.lang.String}{@literal >>}.
|
||||
* The keys are case-insensitive Strings representing the header names and
|
||||
* the value associated with each key is a {@link List}<{@link String}> with one
|
||||
* the value associated with each key is
|
||||
* a {@link List}{@literal <}{@link String}{@literal >} with one
|
||||
* element for each occurrence of the header name in the request or response.
|
||||
* <p>
|
||||
* For example, if a response header instance contains one key "HeaderName" with two values "value1 and value2"
|
||||
* For example, if a response header instance contains
|
||||
* one key "HeaderName" with two values "value1 and value2"
|
||||
* then this object is output as two header lines:
|
||||
* <blockquote><pre>
|
||||
* HeaderName: value1
|
||||
* HeaderName: value2
|
||||
* </blockquote></pre>
|
||||
* </pre></blockquote>
|
||||
* <p>
|
||||
* All the normal {@link java.util.Map} methods are provided, but the following
|
||||
* additional convenience methods are most likely to be used:
|
||||
|
@ -116,9 +116,9 @@ public abstract class HttpExchange {
|
||||
public abstract HttpContext getHttpContext ();
|
||||
|
||||
/**
|
||||
* Ends this exchange by doing the following in sequence:<p><ol>
|
||||
* <li>close the request InputStream, if not already closed<p></li>
|
||||
* <li>close the response OutputStream, if not already closed. </li>
|
||||
* Ends this exchange by doing the following in sequence:<ol>
|
||||
* <li>close the request InputStream, if not already closed;</li>
|
||||
* <li>close the response OutputStream, if not already closed.</li>
|
||||
* </ol>
|
||||
*/
|
||||
public abstract void close () ;
|
||||
@ -163,9 +163,9 @@ public abstract class HttpExchange {
|
||||
* and the numeric response code as specified in this method. The response body length is also specified
|
||||
* as follows. If the response length parameter is greater than zero, this specifies an exact
|
||||
* number of bytes to send and the application must send that exact amount of data.
|
||||
* If the response length parameter is <code>zero</code>, then chunked transfer encoding is
|
||||
* If the response length parameter is {@code zero}, then chunked transfer encoding is
|
||||
* used and an arbitrary amount of data may be sent. The application terminates the
|
||||
* response body by closing the OutputStream. If response length has the value <code>-1</code>
|
||||
* response body by closing the OutputStream. If response length has the value {@code -1}
|
||||
* then no response body is being sent.
|
||||
* <p>
|
||||
* If the content-length response header has not already been set then
|
||||
@ -192,7 +192,7 @@ public abstract class HttpExchange {
|
||||
|
||||
/**
|
||||
* Returns the response code, if it has already been set
|
||||
* @return the response code, if available. <code>-1</code> if not available yet.
|
||||
* @return the response code, if available. {@code -1} if not available yet.
|
||||
*/
|
||||
public abstract int getResponseCode ();
|
||||
|
||||
@ -219,7 +219,7 @@ public abstract class HttpExchange {
|
||||
* available.
|
||||
* @param name the name of the attribute to retrieve
|
||||
* @return the attribute object, or null if it does not exist
|
||||
* @throws NullPointerException if name is <code>null</code>
|
||||
* @throws NullPointerException if name is {@code null}
|
||||
*/
|
||||
public abstract Object getAttribute (String name) ;
|
||||
|
||||
@ -231,9 +231,9 @@ public abstract class HttpExchange {
|
||||
* Each Filter class will document the attributes which they make
|
||||
* available.
|
||||
* @param name the name to associate with the attribute value
|
||||
* @param value the object to store as the attribute value. <code>null</code>
|
||||
* @param value the object to store as the attribute value. {@code null}
|
||||
* value is permitted.
|
||||
* @throws NullPointerException if name is <code>null</code>
|
||||
* @throws NullPointerException if name is {@code null}
|
||||
*/
|
||||
public abstract void setAttribute (String name, Object value) ;
|
||||
|
||||
@ -248,9 +248,9 @@ public abstract class HttpExchange {
|
||||
* required to be) sub-classes of {@link java.io.FilterInputStream}
|
||||
* and {@link java.io.FilterOutputStream}.
|
||||
* @param i the filtered input stream to set as this object's inputstream,
|
||||
* or <code>null</code> if no change.
|
||||
* or {@code null} if no change.
|
||||
* @param o the filtered output stream to set as this object's outputstream,
|
||||
* or <code>null</code> if no change.
|
||||
* or {@code null} if no change.
|
||||
*/
|
||||
public abstract void setStreams (InputStream i, OutputStream o);
|
||||
|
||||
@ -259,7 +259,7 @@ public abstract class HttpExchange {
|
||||
* If an authenticator is set on the HttpContext that owns this exchange,
|
||||
* then this method will return the {@link HttpPrincipal} that represents
|
||||
* the authenticated user for this HttpExchange.
|
||||
* @return the HttpPrincipal, or <code>null</code> if no authenticator is set.
|
||||
* @return the HttpPrincipal, or {@code null} if no authenticator is set.
|
||||
*/
|
||||
public abstract HttpPrincipal getPrincipal ();
|
||||
}
|
||||
|
@ -58,8 +58,8 @@ import com.sun.net.httpserver.spi.HttpServerProvider;
|
||||
* whose path is the longest matching prefix of the request URI's path.
|
||||
* Paths are matched literally, which means that the strings are compared
|
||||
* case sensitively, and with no conversion to or from any encoded forms.
|
||||
* For example. Given a HttpServer with the following HttpContexts configured.<p>
|
||||
* <table >
|
||||
* For example. Given a HttpServer with the following HttpContexts configured.
|
||||
* <table>
|
||||
* <tr><td><i>Context</i></td><td><i>Context path</i></td></tr>
|
||||
* <tr><td>ctx1</td><td>"/"</td></tr>
|
||||
* <tr><td>ctx2</td><td>"/apps/"</td></tr>
|
||||
@ -67,7 +67,7 @@ import com.sun.net.httpserver.spi.HttpServerProvider;
|
||||
* </table>
|
||||
* <p>
|
||||
* the following table shows some request URIs and which, if any context they would
|
||||
* match with.<p>
|
||||
* match with.
|
||||
* <table>
|
||||
* <tr><td><i>Request URI</i></td><td><i>Matches context</i></td></tr>
|
||||
* <tr><td>"http://foo.com/apps/foo/bar"</td><td>ctx3</td></tr>
|
||||
@ -181,7 +181,7 @@ public abstract class HttpServer {
|
||||
* approximately <i>delay</i> seconds have elapsed (whichever happens
|
||||
* sooner). Then, all open TCP connections are closed, the background
|
||||
* thread created by start() exits, and the method returns.
|
||||
* Once stopped, a HttpServer cannot be re-used. <p>
|
||||
* Once stopped, a HttpServer cannot be re-used.
|
||||
*
|
||||
* @param delay the maximum time in seconds to wait until exchanges have finished.
|
||||
* @throws IllegalArgumentException if delay is less than zero.
|
||||
|
@ -42,8 +42,8 @@ import javax.net.ssl.*;
|
||||
* the default configuration.
|
||||
* <p>
|
||||
* The following <a name="example">example</a> shows how this may be done:
|
||||
* <p>
|
||||
* <pre><blockquote>
|
||||
*
|
||||
* <blockquote><pre>
|
||||
* SSLContext sslContext = SSLContext.getInstance (....);
|
||||
* HttpsServer server = HttpsServer.create();
|
||||
*
|
||||
@ -64,7 +64,7 @@ import javax.net.ssl.*;
|
||||
* params.setSSLParameters(sslparams);
|
||||
* }
|
||||
* });
|
||||
* </blockquote></pre>
|
||||
* </pre></blockquote>
|
||||
* @since 1.6
|
||||
*/
|
||||
@jdk.Exported
|
||||
@ -102,7 +102,7 @@ public class HttpsConfigurator {
|
||||
* <p>
|
||||
* The default implementation of this method uses the
|
||||
* SSLParameters returned from <p>
|
||||
* <code>getSSLContext().getDefaultSSLParameters()</code>
|
||||
* {@code getSSLContext().getDefaultSSLParameters()}
|
||||
* <p>
|
||||
* configure() may be overridden in order to modify this behavior.
|
||||
* See, the example <a href="#example">above</a>.
|
||||
|
@ -58,7 +58,7 @@
|
||||
server.createContext("/applications/myapp", new MyHandler());
|
||||
server.setExecutor(null); // creates a default executor
|
||||
server.start();
|
||||
</blockquote></pre>
|
||||
</pre></blockquote>
|
||||
<p>The example above creates a simple HttpServer which uses the calling
|
||||
application thread to invoke the handle() method for incoming http
|
||||
requests directed to port 8000, and to the path /applications/myapp/.
|
||||
@ -92,7 +92,7 @@
|
||||
|
||||
SSLContext ssl = SSLContext.getInstance("TLS");
|
||||
ssl.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
|
||||
</blockquote></pre>
|
||||
</pre></blockquote>
|
||||
<p>
|
||||
In the example above, a keystore file called "testkeys", created with the keytool utility
|
||||
is used as a certificate store for client and server certificates.
|
||||
@ -119,8 +119,8 @@
|
||||
|
||||
}
|
||||
});
|
||||
</blockquote></pre>
|
||||
<p>
|
||||
</pre></blockquote>
|
||||
|
||||
@since 1.6
|
||||
*/
|
||||
@jdk.Exported
|
||||
|
@ -43,13 +43,12 @@ public class Bootstrap extends Object {
|
||||
* <p> May throw an unspecified error if initialization of the
|
||||
* {@link com.sun.jdi.VirtualMachineManager} fails or if
|
||||
* the virtual machine manager is unable to locate or create
|
||||
* any {@link com.sun.jdi.connect.Connector Connectors}. </p>
|
||||
* <p>
|
||||
* any {@link com.sun.jdi.connect.Connector Connectors}.
|
||||
*
|
||||
* @throws java.lang.SecurityException if a security manager has been
|
||||
* installed and it denies {@link JDIPermission}
|
||||
* <tt>("virtualMachineManager")</tt> or other unspecified
|
||||
* ("{@code virtualMachineManager}") or other unspecified
|
||||
* permissions required by the implementation.
|
||||
* </p>
|
||||
*/
|
||||
static public synchronized VirtualMachineManager virtualMachineManager() {
|
||||
return com.sun.tools.jdi.VirtualMachineManagerImpl.virtualMachineManager();
|
||||
|
@ -65,22 +65,22 @@ public interface Field extends TypeComponent, Comparable<Field> {
|
||||
* short s;
|
||||
* Date d;
|
||||
* byte[] ba;</PRE>
|
||||
* And the JDI client defines these <CODE>Field</CODE> objects:
|
||||
* And the JDI client defines these {@code Field} objects:
|
||||
* <PRE>
|
||||
* Field sField = targetClass.fieldByName("s");
|
||||
* Field dField = targetClass.fieldByName("d");
|
||||
* Field baField = targetClass.fieldByName("ba");</PRE>
|
||||
* to mirror the corresponding fields, then <CODE>sField.type()</CODE>
|
||||
* is a {@link ShortType}, <CODE>dField.type()</CODE> is the
|
||||
* {@link ReferenceType} for <CODE>java.util.Date</CODE> and
|
||||
* <CODE>((ArrayType)(baField.type())).componentType()</CODE> is a
|
||||
* to mirror the corresponding fields, then {@code sField.type()}
|
||||
* is a {@link ShortType}, {@code dField.type()} is the
|
||||
* {@link ReferenceType} for {@code java.util.Date} and
|
||||
* {@code ((ArrayType)(baField.type())).componentType()} is a
|
||||
* {@link ByteType}.
|
||||
* <P>
|
||||
* Note: if the type of this field is a reference type (class,
|
||||
* interface, or array) and it has not been created or loaded
|
||||
* by the declaring type's class loader - that is,
|
||||
* {@link TypeComponent#declaringType <CODE>declaringType()</CODE>}
|
||||
* <CODE>.classLoader()</CODE>,
|
||||
* {@link TypeComponent#declaringType declaringType()}
|
||||
* {@code .classLoader()},
|
||||
* then ClassNotLoadedException will be thrown.
|
||||
* Also, a reference type may have been loaded but not yet prepared,
|
||||
* in which case the type will be returned
|
||||
@ -100,28 +100,28 @@ public interface Field extends TypeComponent, Comparable<Field> {
|
||||
/**
|
||||
* Determine if this is a transient field.
|
||||
*
|
||||
* @return <code>true</code> if this field is transient; false otherwise.
|
||||
* @return {@code true} if this field is transient; {@code false} otherwise.
|
||||
*/
|
||||
boolean isTransient();
|
||||
|
||||
/**
|
||||
* Determine if this is a volatile field.
|
||||
*
|
||||
* @return <code>true</code> if this field is volatile; false otherwise.
|
||||
* @return {@code true} if this field is volatile; {@code false} otherwise.
|
||||
*/
|
||||
boolean isVolatile();
|
||||
|
||||
/**
|
||||
* Determine if this is a field that represents an enum constant.
|
||||
* @return <code>true</code> if this field represents an enum constant;
|
||||
* false otherwise.
|
||||
* @return {@code true} if this field represents an enum constant;
|
||||
* {@code false} otherwise.
|
||||
*/
|
||||
boolean isEnumConstant();
|
||||
|
||||
/**
|
||||
* Compares the specified Object with this field for equality.
|
||||
*
|
||||
* @return true if the Object is a Field and if both
|
||||
* @return {@code true} if the Object is a Field and if both
|
||||
* mirror the same field (declared in the same class or interface, in
|
||||
* the same VM).
|
||||
*/
|
||||
@ -130,7 +130,7 @@ public interface Field extends TypeComponent, Comparable<Field> {
|
||||
/**
|
||||
* Returns the hash code value for this Field.
|
||||
*
|
||||
* @return the integer hash code
|
||||
* @return the integer hash code.
|
||||
*/
|
||||
int hashCode();
|
||||
}
|
||||
|
@ -26,20 +26,20 @@
|
||||
package com.sun.jdi;
|
||||
|
||||
/**
|
||||
* The <code>JDIPermission</code> class represents access rights to
|
||||
* the <code>VirtualMachineManager</code>. This is the permission
|
||||
* The {@code JDIPermission} class represents access rights to
|
||||
* the {@code VirtualMachineManager}. This is the permission
|
||||
* which the SecurityManager will check when code that is running with
|
||||
* a SecurityManager requests access to the VirtualMachineManager, as
|
||||
* defined in the Java Debug Interface (JDI) for the Java platform.
|
||||
* <P>
|
||||
* A <code>JDIPermission</code> object contains a name (also referred
|
||||
* A {@code JDIPermission} object contains a name (also referred
|
||||
* to as a "target name") but no actions list; you either have the
|
||||
* named permission or you don't.
|
||||
* <P>
|
||||
* The following table provides a summary description of what the
|
||||
* permission allows, and discusses the risks of granting code the
|
||||
* permission.
|
||||
* <P>
|
||||
*
|
||||
* <table border=1 cellpadding=5 summary="Table shows permission
|
||||
* target name, what the permission allows, and associated risks">
|
||||
* <tr>
|
||||
@ -51,10 +51,10 @@ package com.sun.jdi;
|
||||
* <tr>
|
||||
* <td>virtualMachineManager</td>
|
||||
* <td>Ability to inspect and modify the JDI objects in the
|
||||
* <code>VirtualMachineManager</code>
|
||||
* {@code VirtualMachineManager}
|
||||
* </td>
|
||||
* <td>This allows an attacker to control the
|
||||
* <code>VirtualMachineManager</code> and cause the system to
|
||||
* {@code VirtualMachineManager} and cause the system to
|
||||
* misbehave.
|
||||
* </td>
|
||||
* </tr>
|
||||
@ -82,8 +82,8 @@ package com.sun.jdi;
|
||||
public final class JDIPermission extends java.security.BasicPermission {
|
||||
private static final long serialVersionUID = -6988461416938786271L;
|
||||
/**
|
||||
* The <code>JDIPermission</code> class represents access rights to the
|
||||
* <code>VirtualMachineManager</code>
|
||||
* The {@code JDIPermission} class represents access rights to the
|
||||
* {@code VirtualMachineManager}
|
||||
* @param name Permission name. Must be "virtualMachineManager".
|
||||
* @throws IllegalArgumentException if the name argument is invalid.
|
||||
*/
|
||||
|
@ -49,7 +49,7 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* This type name is always available even if
|
||||
* the type has not yet been created or loaded.
|
||||
*
|
||||
* @return a String containing the return type name.
|
||||
* @return a {@code String} containing the return type name.
|
||||
*/
|
||||
String returnTypeName();
|
||||
|
||||
@ -60,8 +60,8 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* Note: if the return type of this method is a reference type (class,
|
||||
* interface, or array) and it has not been created or loaded
|
||||
* by the declaring type's class loader - that is,
|
||||
* {@link TypeComponent#declaringType <CODE>declaringType()</CODE>}
|
||||
* <CODE>.classLoader()</CODE>,
|
||||
* {@link TypeComponent#declaringType declaringType()}
|
||||
* {@code .classLoader()},
|
||||
* then ClassNotLoadedException will be thrown.
|
||||
* Also, a reference type may have been loaded but not yet prepared,
|
||||
* in which case the type will be returned
|
||||
@ -93,7 +93,6 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* as specified at compile-time.
|
||||
* If the formal parameter was declared with an ellipsis, then
|
||||
* it is represented as an array of the type before the ellipsis.
|
||||
*
|
||||
*/
|
||||
List<String> argumentTypeNames();
|
||||
|
||||
@ -105,8 +104,8 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* is a reference type (class, interface, or array)
|
||||
* and it has not been created or loaded
|
||||
* by the declaring type's class loader - that is,
|
||||
* {@link TypeComponent#declaringType <CODE>declaringType()</CODE>}
|
||||
* <CODE>.classLoader()</CODE>,
|
||||
* {@link TypeComponent#declaringType declaringType()}
|
||||
* {@code .classLoader()},
|
||||
* then ClassNotLoadedException will be thrown.
|
||||
* Also, a reference type may have been loaded but not yet prepared,
|
||||
* in which case the list will be returned
|
||||
@ -132,16 +131,16 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
/**
|
||||
* Determine if this method is abstract.
|
||||
*
|
||||
* @return <code>true</code> if the method is declared abstract;
|
||||
* false otherwise.
|
||||
* @return {@code true} if the method is declared abstract;
|
||||
* {@code false} otherwise.
|
||||
*/
|
||||
boolean isAbstract();
|
||||
|
||||
/**
|
||||
* Determine if this method is a default method
|
||||
*
|
||||
* @return <code>true</code> if the method is declared default;
|
||||
* false otherwise
|
||||
* @return {@code true} if the method is declared default;
|
||||
* {@code false} otherwise.
|
||||
*
|
||||
* @since 1.8
|
||||
*/
|
||||
@ -152,24 +151,24 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
/**
|
||||
* Determine if this method is synchronized.
|
||||
*
|
||||
* @return <code>true</code> if the method is declared synchronized;
|
||||
* false otherwise.
|
||||
* @return {@code true} if the method is declared synchronized;
|
||||
* {@code false} otherwise.
|
||||
*/
|
||||
boolean isSynchronized();
|
||||
|
||||
/**
|
||||
* Determine if this method is native.
|
||||
*
|
||||
* @return <code>true</code> if the method is declared native;
|
||||
* false otherwise.
|
||||
* @return {@code true} if the method is declared native;
|
||||
* {@code false} otherwise.
|
||||
*/
|
||||
boolean isNative();
|
||||
|
||||
/**
|
||||
* Determine if this method accepts a variable number of arguments.
|
||||
*
|
||||
* @return <code>true</code> if the method accepts a variable number
|
||||
* of arguments, false otherwise.
|
||||
* @return {@code true} if the method accepts a variable number
|
||||
* of arguments, {@code false} otherwise.
|
||||
*
|
||||
* @since 1.5
|
||||
*/
|
||||
@ -180,8 +179,8 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* methods are defined in
|
||||
* <cite>The Java™ Language Specification</cite>.
|
||||
*
|
||||
* @return <code>true</code> if the method is a bridge method,
|
||||
* false otherwise.
|
||||
* @return {@code true} if the method is a bridge method,
|
||||
* {@code false} otherwise.
|
||||
*
|
||||
* @since 1.5
|
||||
*/
|
||||
@ -190,23 +189,23 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
/**
|
||||
* Determine if this method is a constructor.
|
||||
*
|
||||
* @return <code>true</code> if the method is a constructor;
|
||||
* false otherwise.
|
||||
* @return {@code true} if the method is a constructor;
|
||||
* {@code false} otherwise.
|
||||
*/
|
||||
boolean isConstructor();
|
||||
|
||||
/**
|
||||
* Determine if this method is a static initializer.
|
||||
*
|
||||
* @return <code>true</code> if the method is a static initializer;
|
||||
* false otherwise.
|
||||
* @return {@code true} if the method is a static initializer;
|
||||
* {@code false} otherwise.
|
||||
*/
|
||||
boolean isStaticInitializer();
|
||||
|
||||
/**
|
||||
* Determine if this method is obsolete.
|
||||
*
|
||||
* @return <code>true</code> if this method has been made obsolete by a
|
||||
* @return {@code true} if this method has been made obsolete by a
|
||||
* {@link VirtualMachine#redefineClasses} operation.
|
||||
*
|
||||
* @since 1.4
|
||||
@ -218,7 +217,7 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* each executable source line in this method.
|
||||
* <P>
|
||||
* This method is equivalent to
|
||||
* <code>allLineLocations(vm.getDefaultStratum(),null)</code> -
|
||||
* {@code allLineLocations(vm.getDefaultStratum(),null)} -
|
||||
* see {@link #allLineLocations(String,String)}
|
||||
* for more information.
|
||||
*
|
||||
@ -252,16 +251,16 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* (see {@link Location} for a description of strata).
|
||||
*
|
||||
* @param stratum The stratum to retrieve information from
|
||||
* or <code>null</code> for the {@link ReferenceType#defaultStratum()}
|
||||
* or {@code null} for the {@link ReferenceType#defaultStratum()}
|
||||
*
|
||||
* @param sourceName Return locations only within this
|
||||
* source file or <code>null</code> to return locations.
|
||||
* source file or {@code null} to return locations.
|
||||
*
|
||||
* @return a List of all source line {@link Location} objects.
|
||||
*
|
||||
* @throws AbsentInformationException if there is no line
|
||||
* number information for this (non-native, non-abstract)
|
||||
* method. Or if <i>sourceName</i> is non-<code>null</code>
|
||||
* method. Or if <i>sourceName</i> is non-{@code null}
|
||||
* and source name information is not present.
|
||||
*
|
||||
* @since 1.4
|
||||
@ -274,8 +273,8 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
* that map to the given line number.
|
||||
* <P>
|
||||
* This method is equivalent to
|
||||
* <code>locationsOfLine(vm.getDefaultStratum(), null,
|
||||
* lineNumber)</code> -
|
||||
* {@code locationsOfLine(vm.getDefaultStratum(), null,
|
||||
* lineNumber)} -
|
||||
* see {@link
|
||||
* #locationsOfLine(java.lang.String,java.lang.String,int)}
|
||||
* for more information.
|
||||
@ -320,7 +319,7 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
*
|
||||
* @throws AbsentInformationException if there is no line
|
||||
* number information for this method.
|
||||
* Or if <i>sourceName</i> is non-<code>null</code>
|
||||
* Or if <i>sourceName</i> is non-{@code null}
|
||||
* and source name information is not present.
|
||||
*
|
||||
* @since 1.4
|
||||
@ -436,7 +435,7 @@ public interface Method extends TypeComponent, Locatable, Comparable<Method> {
|
||||
/**
|
||||
* Returns the hash code value for this Method.
|
||||
*
|
||||
* @return the integer hash code
|
||||
* @return the integer hash code.
|
||||
*/
|
||||
int hashCode();
|
||||
}
|
||||
|
@ -63,47 +63,47 @@ package com.sun.jdi;
|
||||
* <TH id="type" align="left">{@link Type} of value<br>{@link #type() Value.type()}</TH>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a boolean</TD>
|
||||
* <TD headers="primval example"> <CODE>true</CODE></TD>
|
||||
* <TD headers="primval example"> {@code true}</TD>
|
||||
* <TD headers="primval mirrored"> {@link BooleanValue}</TD>
|
||||
* <TD headers="primval type"> {@link BooleanType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a byte</TD>
|
||||
* <TD headers="primval example"> <CODE>(byte)4</CODE></TD>
|
||||
* <TD headers="primval example"> {@code (byte)4}</TD>
|
||||
* <TD headers="primval mirrored"> {@link ByteValue}</TD>
|
||||
* <TD headers="primval type"> {@link ByteType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a char</TD>
|
||||
* <TD headers="primval example"> <CODE>'a'</CODE></TD>
|
||||
* <TD headers="primval example"> {@code 'a'}</TD>
|
||||
* <TD headers="primval mirrored"> {@link CharValue}</TD>
|
||||
* <TD headers="primval type"> {@link CharType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a double</TD>
|
||||
* <TD headers="primval example"> <CODE>3.1415926</CODE></TD>
|
||||
* <TD headers="primval example"> {@code 3.1415926}</TD>
|
||||
* <TD headers="primval mirrored"> {@link DoubleValue}</TD>
|
||||
* <TD headers="primval type"> {@link DoubleType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a float</TD>
|
||||
* <TD headers="primval example"> <CODE>2.5f</CODE></TD>
|
||||
* <TD headers="primval example"> {@code 2.5f}</TD>
|
||||
* <TD headers="primval mirrored"> {@link FloatValue}</TD>
|
||||
* <TD headers="primval type"> {@link FloatType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> an int</TD>
|
||||
* <TD headers="primval example"> <CODE>22</CODE></TD>
|
||||
* <TD headers="primval example"> {@code 22}</TD>
|
||||
* <TD headers="primval mirrored"> {@link IntegerValue}</TD>
|
||||
* <TD headers="primval type"> {@link IntegerType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a long</TD>
|
||||
* <TD headers="primval example"> <CODE>1024L</CODE></TD>
|
||||
* <TD headers="primval example"> {@code 1024L}</TD>
|
||||
* <TD headers="primval mirrored"> {@link LongValue}</TD>
|
||||
* <TD headers="primval type"> {@link LongType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a short</TD>
|
||||
* <TD headers="primval example"> <CODE>(short)12</CODE></TD>
|
||||
* <TD headers="primval example"> {@code (short)12}</TD>
|
||||
* <TD headers="primval mirrored"> {@link ShortValue}</TD>
|
||||
* <TD headers="primval type"> {@link ShortType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="primval kind"> a void</TD>
|
||||
* <TD headers="primval example"> <CODE> </CODE></TD>
|
||||
* <TD headers="primval example"> </TD>
|
||||
* <TD headers="primval mirrored"> {@link VoidValue}</TD>
|
||||
* <TD headers="primval type"> {@link VoidType}</TD>
|
||||
* <TR BGCOLOR="#EEEEFF">
|
||||
@ -115,50 +115,50 @@ package com.sun.jdi;
|
||||
* <TH id="type2" align="left">{@link Type} of value<br>{@link #type() Value.type()}</TH>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> a class instance</TD>
|
||||
* <TD headers="objref example2"> <CODE>this</CODE></TD>
|
||||
* <TD headers="objref example2"> {@code this}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link ObjectReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ClassType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> an array</TD>
|
||||
* <TD headers="objref example2"> <CODE>new int[5]</CODE></TD>
|
||||
* <TD headers="objref example2"> {@code new int[5]}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link ArrayReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ArrayType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> a string</TD>
|
||||
* <TD headers="objref example2"> <CODE>"hello"</CODE></TD>
|
||||
* <TD headers="objref example2"> {@code "hello"}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link StringReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ClassType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> a thread</TD>
|
||||
* <TD headers="objref example2"> <CODE>Thread.currentThread()</CODE></TD>
|
||||
* <TD headers="objref example2"> {@code Thread.currentThread()}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link ThreadReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ClassType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> a thread group</TD>
|
||||
* <TD headers="objref example2"> <CODE>Thread.currentThread()<br> .getThreadGroup()</CODE></TD>
|
||||
* <TD headers="objref example2"> {@code Thread.currentThread()}<br> {@code .getThreadGroup()}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link ThreadGroupReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ClassType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> a <CODE>java.lang.Class</CODE><br>instance</TD>
|
||||
* <TD headers="objref example2"> <CODE>this.getClass()</CODE></TD>
|
||||
* <TD headers="objref kind2"> a {@code java.lang.Class}<br>instance</TD>
|
||||
* <TD headers="objref example2"> {@code this.getClass()}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link ClassObjectReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ClassType}</TD>
|
||||
* <TR>
|
||||
* <TD headers="objref kind2"> a class loader</TD>
|
||||
* <TD headers="objref example2"> <CODE>this.getClass()<br> .getClassLoader() </CODE></TD>
|
||||
* <TD headers="objref example2"> {@code this.getClass()}<br> {@code .getClassLoader()}</TD>
|
||||
* <TD headers="objref mirrored2"> {@link ClassLoaderReference}</TD>
|
||||
* <TD headers="objref type2"> {@link ClassType}</TD>
|
||||
* <TR BGCOLOR="#EEEEFF">
|
||||
* <TH id="other" colspan=4>Other</TH>
|
||||
* <TR BGCOLOR="#EEEEFF">
|
||||
* <TH id="kind3" align="left">Kind of value</TD>
|
||||
* <TH id="example3" align="left">For example -<br>expression in target</TD>
|
||||
* <TH id="mirrored3" align="left">Is mirrored as</TD>
|
||||
* <TH id="type3" align="left">{@link Type} of value</TD>
|
||||
* <TD id="kind3" align="left">Kind of value</TD>
|
||||
* <TD id="example3" align="left">For example -<br>expression in target</TD>
|
||||
* <TD id="mirrored3" align="left">Is mirrored as</TD>
|
||||
* <TD id="type3" align="left">{@link Type} of value</TD>
|
||||
* <TR>
|
||||
* <TD headers="other kind3"> null</TD>
|
||||
* <TD headers="other example3"> <CODE>null</CODE></TD>
|
||||
* <TD headers="other mirrored3"> <CODE>null</CODE></TD>
|
||||
* <TD headers="other example3"> {@code null}</TD>
|
||||
* <TD headers="other mirrored3"> {@code null}</TD>
|
||||
* <TD headers="other type3"> n/a</TD>
|
||||
* </TABLE>
|
||||
*
|
||||
|
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