Merge
This commit is contained in:
commit
b0fb6e8669
@ -306,3 +306,4 @@ f25ee9f62427a9ba27418e5531a89754791a305b jdk9-b57
|
|||||||
ea38728b4f4bdd8fd0d7a89b18069f521cf05013 jdk9-b61
|
ea38728b4f4bdd8fd0d7a89b18069f521cf05013 jdk9-b61
|
||||||
105d045a69174d870b69bfe471b3f2d05a9f8ecc jdk9-b62
|
105d045a69174d870b69bfe471b3f2d05a9f8ecc jdk9-b62
|
||||||
0b32ed628fa60e4ab99fb0b5866d648e16231f17 jdk9-b63
|
0b32ed628fa60e4ab99fb0b5866d648e16231f17 jdk9-b63
|
||||||
|
82cf9aab9a83e41c8194ba01af9666afdb856cbe jdk9-b64
|
||||||
|
@ -705,9 +705,9 @@ AC_DEFUN_ONCE([BASIC_SETUP_OUTPUT_DIR],
|
|||||||
# is performed.
|
# is performed.
|
||||||
filtered_files=`$ECHO "$files_present" \
|
filtered_files=`$ECHO "$files_present" \
|
||||||
| $SED -e 's/config.log//g' \
|
| $SED -e 's/config.log//g' \
|
||||||
-e 's/confdefs.h//g' \
|
-e 's/configure.log//g' \
|
||||||
-e 's/fixpath.exe//g' \
|
-e 's/confdefs.h//g' \
|
||||||
-e 's/ //g' \
|
-e 's/ //g' \
|
||||||
| $TR -d '\n'`
|
| $TR -d '\n'`
|
||||||
if test "x$filtered_files" != x; then
|
if test "x$filtered_files" != x; then
|
||||||
AC_MSG_NOTICE([Current directory is $CURDIR.])
|
AC_MSG_NOTICE([Current directory is $CURDIR.])
|
||||||
@ -1054,3 +1054,29 @@ AC_DEFUN_ONCE([BASIC_CHECK_BASH_OPTIONS],
|
|||||||
|
|
||||||
AC_SUBST(BASH_ARGS)
|
AC_SUBST(BASH_ARGS)
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# Code to run after AC_OUTPUT
|
||||||
|
AC_DEFUN_ONCE([BASIC_POST_CONFIG_OUTPUT],
|
||||||
|
[
|
||||||
|
# Try to move config.log (generated by autoconf) to the configure-support directory.
|
||||||
|
if test -e ./config.log; then
|
||||||
|
$MV -f ./config.log "$CONFIGURESUPPORT_OUTPUTDIR/config.log" 2> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Rotate our log file (configure.log)
|
||||||
|
if test -e "$OUTPUT_ROOT/configure.log.old"; then
|
||||||
|
$RM -f "$OUTPUT_ROOT/configure.log.old"
|
||||||
|
fi
|
||||||
|
if test -e "$OUTPUT_ROOT/configure.log"; then
|
||||||
|
$MV -f "$OUTPUT_ROOT/configure.log" "$OUTPUT_ROOT/configure.log.old" 2> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Move configure.log from current directory to the build output root
|
||||||
|
if test -e ./configure.log; then
|
||||||
|
echo found it
|
||||||
|
$MV -f ./configure.log "$OUTPUT_ROOT/configure.log" 2> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Make the compare script executable
|
||||||
|
$CHMOD +x $OUTPUT_ROOT/compare.sh
|
||||||
|
])
|
||||||
|
11
common/autoconf/configure
vendored
11
common/autoconf/configure
vendored
@ -255,13 +255,10 @@ if test "x$conf_debug_configure" != x; then
|
|||||||
set -x
|
set -x
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "x$conf_debug_configure" = xtrue; then
|
# Now transfer control to the script generated by autoconf. This is where the
|
||||||
# Turn on logging, but don't turn on twice when called recursive
|
# main work is done.
|
||||||
conf_debug_logfile=./debug-configure.log
|
conf_logfile=./configure.log
|
||||||
(exec 3>&1 ; (. $conf_script_to_run "${conf_processed_arguments[@]}" 2>&1 1>&3 ) | tee -a $conf_debug_logfile 1>&2 ; exec 3>&-) | tee -a $conf_debug_logfile
|
(exec 3>&1 ; (. $conf_script_to_run "${conf_processed_arguments[@]}" 2>&1 1>&3 ) | tee -a $conf_logfile 1>&2 ; exec 3>&-) | tee -a $conf_logfile
|
||||||
else
|
|
||||||
( . $conf_script_to_run "${conf_processed_arguments[@]}" )
|
|
||||||
fi
|
|
||||||
|
|
||||||
conf_result_code=$?
|
conf_result_code=$?
|
||||||
###
|
###
|
||||||
|
@ -265,15 +265,10 @@ CONFIG_STATUS="$CONFIGURESUPPORT_OUTPUTDIR/config.status"
|
|||||||
|
|
||||||
# Create the actual output files. Now the main work of configure is done.
|
# Create the actual output files. Now the main work of configure is done.
|
||||||
AC_OUTPUT
|
AC_OUTPUT
|
||||||
|
|
||||||
|
# After AC_OUTPUT, we need to do final work
|
||||||
CUSTOM_CONFIG_OUTPUT_GENERATED_HOOK
|
CUSTOM_CONFIG_OUTPUT_GENERATED_HOOK
|
||||||
|
BASIC_POST_CONFIG_OUTPUT
|
||||||
# Try to move the config.log file to the output directory.
|
|
||||||
if test -e ./config.log; then
|
|
||||||
$MV -f ./config.log "$CONFIGURESUPPORT_OUTPUTDIR/config.log" 2> /dev/null
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Make the compare script executable
|
|
||||||
$CHMOD +x $OUTPUT_ROOT/compare.sh
|
|
||||||
|
|
||||||
# Finally output some useful information to the user
|
# Finally output some useful information to the user
|
||||||
HELP_PRINT_SUMMARY_AND_WARNINGS
|
HELP_PRINT_SUMMARY_AND_WARNINGS
|
||||||
|
@ -231,7 +231,6 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_LIBS],
|
|||||||
|
|
||||||
AC_SUBST(C_FLAG_REORDER)
|
AC_SUBST(C_FLAG_REORDER)
|
||||||
AC_SUBST(CXX_FLAG_REORDER)
|
AC_SUBST(CXX_FLAG_REORDER)
|
||||||
AC_SUBST(SHARED_LIBRARY_FLAGS)
|
|
||||||
AC_SUBST(SET_EXECUTABLE_ORIGIN)
|
AC_SUBST(SET_EXECUTABLE_ORIGIN)
|
||||||
AC_SUBST(SET_SHARED_LIBRARY_ORIGIN)
|
AC_SUBST(SET_SHARED_LIBRARY_ORIGIN)
|
||||||
AC_SUBST(SET_SHARED_LIBRARY_NAME)
|
AC_SUBST(SET_SHARED_LIBRARY_NAME)
|
||||||
@ -524,6 +523,10 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
|
|||||||
# CXXFLAGS_JDK - C++ Compiler flags
|
# CXXFLAGS_JDK - C++ Compiler flags
|
||||||
# COMMON_CCXXFLAGS_JDK - common to C and C++
|
# COMMON_CCXXFLAGS_JDK - common to C and C++
|
||||||
if test "x$TOOLCHAIN_TYPE" = xgcc; then
|
if test "x$TOOLCHAIN_TYPE" = xgcc; then
|
||||||
|
if test "x$OPENJDK_TARGET_CPU" = xx86; then
|
||||||
|
# Force compatibility with i586 on 32 bit intel platforms.
|
||||||
|
COMMON_CCXXFLAGS="${COMMON_CCXXFLAGS} -march=i586"
|
||||||
|
fi
|
||||||
COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS $COMMON_CCXXFLAGS_JDK -Wall -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
|
COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS $COMMON_CCXXFLAGS_JDK -Wall -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
|
||||||
-pipe -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
|
-pipe -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
|
||||||
case $OPENJDK_TARGET_CPU_ARCH in
|
case $OPENJDK_TARGET_CPU_ARCH in
|
||||||
@ -900,6 +903,24 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
|
|||||||
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
|
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
|
||||||
AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
|
AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
|
||||||
|
|
||||||
|
AC_ARG_ENABLE([warnings-as-errors], [AS_HELP_STRING([--disable-warnings-as-errors],
|
||||||
|
[do not consider native warnings to be an error @<:@enabled@:>@])])
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([if native warnings are errors])
|
||||||
|
if test "x$enable_warnings_as_errors" = "xyes"; then
|
||||||
|
AC_MSG_RESULT([yes (explicitely set)])
|
||||||
|
WARNINGS_AS_ERRORS=true
|
||||||
|
elif test "x$enable_warnings_as_errors" = "xno"; then
|
||||||
|
AC_MSG_RESULT([no])
|
||||||
|
WARNINGS_AS_ERRORS=false
|
||||||
|
elif test "x$enable_warnings_as_errors" = "x"; then
|
||||||
|
AC_MSG_RESULT([yes (default)])
|
||||||
|
WARNINGS_AS_ERRORS=true
|
||||||
|
else
|
||||||
|
AC_MSG_ERROR([--enable-warnings-as-errors accepts no argument])
|
||||||
|
fi
|
||||||
|
AC_SUBST(WARNINGS_AS_ERRORS)
|
||||||
|
|
||||||
case "${TOOLCHAIN_TYPE}" in
|
case "${TOOLCHAIN_TYPE}" in
|
||||||
microsoft)
|
microsoft)
|
||||||
DISABLE_WARNING_PREFIX="-wd"
|
DISABLE_WARNING_PREFIX="-wd"
|
||||||
|
@ -684,6 +684,7 @@ ZIP_DEBUGINFO_FILES
|
|||||||
ENABLE_DEBUG_SYMBOLS
|
ENABLE_DEBUG_SYMBOLS
|
||||||
CFLAGS_WARNINGS_ARE_ERRORS
|
CFLAGS_WARNINGS_ARE_ERRORS
|
||||||
DISABLE_WARNING_PREFIX
|
DISABLE_WARNING_PREFIX
|
||||||
|
WARNINGS_AS_ERRORS
|
||||||
COMPILER_SUPPORTS_TARGET_BITS_FLAG
|
COMPILER_SUPPORTS_TARGET_BITS_FLAG
|
||||||
ZERO_ARCHFLAG
|
ZERO_ARCHFLAG
|
||||||
LDFLAGS_TESTEXE_SUFFIX
|
LDFLAGS_TESTEXE_SUFFIX
|
||||||
@ -727,7 +728,6 @@ SET_SHARED_LIBRARY_MAPFILE
|
|||||||
SET_SHARED_LIBRARY_NAME
|
SET_SHARED_LIBRARY_NAME
|
||||||
SET_SHARED_LIBRARY_ORIGIN
|
SET_SHARED_LIBRARY_ORIGIN
|
||||||
SET_EXECUTABLE_ORIGIN
|
SET_EXECUTABLE_ORIGIN
|
||||||
SHARED_LIBRARY_FLAGS
|
|
||||||
CXX_FLAG_REORDER
|
CXX_FLAG_REORDER
|
||||||
C_FLAG_REORDER
|
C_FLAG_REORDER
|
||||||
SYSROOT_LDFLAGS
|
SYSROOT_LDFLAGS
|
||||||
@ -1086,6 +1086,7 @@ with_jtreg
|
|||||||
with_extra_cflags
|
with_extra_cflags
|
||||||
with_extra_cxxflags
|
with_extra_cxxflags
|
||||||
with_extra_ldflags
|
with_extra_ldflags
|
||||||
|
enable_warnings_as_errors
|
||||||
enable_debug_symbols
|
enable_debug_symbols
|
||||||
enable_zip_debug_info
|
enable_zip_debug_info
|
||||||
enable_native_coverage
|
enable_native_coverage
|
||||||
@ -1852,6 +1853,9 @@ Optional Features:
|
|||||||
--enable-rmiconnector-iiop
|
--enable-rmiconnector-iiop
|
||||||
enable the JMX RMIConnector iiop transport
|
enable the JMX RMIConnector iiop transport
|
||||||
[disabled]
|
[disabled]
|
||||||
|
--disable-warnings-as-errors
|
||||||
|
do not consider native warnings to be an error
|
||||||
|
[enabled]
|
||||||
--disable-debug-symbols disable generation of debug symbols [enabled]
|
--disable-debug-symbols disable generation of debug symbols [enabled]
|
||||||
--disable-zip-debug-info
|
--disable-zip-debug-info
|
||||||
disable zipping of debug-info files [enabled]
|
disable zipping of debug-info files [enabled]
|
||||||
@ -3496,6 +3500,9 @@ ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var.
|
|||||||
# Check for support for specific options in bash
|
# Check for support for specific options in bash
|
||||||
|
|
||||||
|
|
||||||
|
# Code to run after AC_OUTPUT
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
@ -4359,7 +4366,7 @@ VS_SDK_PLATFORM_NAME_2013=
|
|||||||
#CUSTOM_AUTOCONF_INCLUDE
|
#CUSTOM_AUTOCONF_INCLUDE
|
||||||
|
|
||||||
# Do not change or remove the following line, it is needed for consistency checks:
|
# Do not change or remove the following line, it is needed for consistency checks:
|
||||||
DATE_WHEN_GENERATED=1430918902
|
DATE_WHEN_GENERATED=1431429776
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
@ -15335,9 +15342,9 @@ $as_echo "in current directory" >&6; }
|
|||||||
# is performed.
|
# is performed.
|
||||||
filtered_files=`$ECHO "$files_present" \
|
filtered_files=`$ECHO "$files_present" \
|
||||||
| $SED -e 's/config.log//g' \
|
| $SED -e 's/config.log//g' \
|
||||||
-e 's/confdefs.h//g' \
|
-e 's/configure.log//g' \
|
||||||
-e 's/fixpath.exe//g' \
|
-e 's/confdefs.h//g' \
|
||||||
-e 's/ //g' \
|
-e 's/ //g' \
|
||||||
| $TR -d '\n'`
|
| $TR -d '\n'`
|
||||||
if test "x$filtered_files" != x; then
|
if test "x$filtered_files" != x; then
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: Current directory is $CURDIR." >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: Current directory is $CURDIR." >&5
|
||||||
@ -41761,7 +41768,6 @@ $as_echo "$ac_cv_c_bigendian" >&6; }
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if test "x$OPENJDK_TARGET_OS" = xsolaris; then
|
if test "x$OPENJDK_TARGET_OS" = xsolaris; then
|
||||||
CFLAGS_JDK="${CFLAGS_JDK} -D__solaris__"
|
CFLAGS_JDK="${CFLAGS_JDK} -D__solaris__"
|
||||||
CXXFLAGS_JDK="${CXXFLAGS_JDK} -D__solaris__"
|
CXXFLAGS_JDK="${CXXFLAGS_JDK} -D__solaris__"
|
||||||
@ -42029,6 +42035,10 @@ fi
|
|||||||
# CXXFLAGS_JDK - C++ Compiler flags
|
# CXXFLAGS_JDK - C++ Compiler flags
|
||||||
# COMMON_CCXXFLAGS_JDK - common to C and C++
|
# COMMON_CCXXFLAGS_JDK - common to C and C++
|
||||||
if test "x$TOOLCHAIN_TYPE" = xgcc; then
|
if test "x$TOOLCHAIN_TYPE" = xgcc; then
|
||||||
|
if test "x$OPENJDK_TARGET_CPU" = xx86; then
|
||||||
|
# Force compatibility with i586 on 32 bit intel platforms.
|
||||||
|
COMMON_CCXXFLAGS="${COMMON_CCXXFLAGS} -march=i586"
|
||||||
|
fi
|
||||||
COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS $COMMON_CCXXFLAGS_JDK -Wall -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
|
COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS $COMMON_CCXXFLAGS_JDK -Wall -Wextra -Wno-unused -Wno-unused-parameter -Wformat=2 \
|
||||||
-pipe -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
|
-pipe -D_GNU_SOURCE -D_REENTRANT -D_LARGEFILE64_SOURCE"
|
||||||
case $OPENJDK_TARGET_CPU_ARCH in
|
case $OPENJDK_TARGET_CPU_ARCH in
|
||||||
@ -42471,6 +42481,31 @@ $as_echo "$supports" >&6; }
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Check whether --enable-warnings-as-errors was given.
|
||||||
|
if test "${enable_warnings_as_errors+set}" = set; then :
|
||||||
|
enableval=$enable_warnings_as_errors;
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if native warnings are errors" >&5
|
||||||
|
$as_echo_n "checking if native warnings are errors... " >&6; }
|
||||||
|
if test "x$enable_warnings_as_errors" = "xyes"; then
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes (explicitely set)" >&5
|
||||||
|
$as_echo "yes (explicitely set)" >&6; }
|
||||||
|
WARNINGS_AS_ERRORS=true
|
||||||
|
elif test "x$enable_warnings_as_errors" = "xno"; then
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
|
||||||
|
$as_echo "no" >&6; }
|
||||||
|
WARNINGS_AS_ERRORS=false
|
||||||
|
elif test "x$enable_warnings_as_errors" = "x"; then
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes (default)" >&5
|
||||||
|
$as_echo "yes (default)" >&6; }
|
||||||
|
WARNINGS_AS_ERRORS=true
|
||||||
|
else
|
||||||
|
as_fn_error $? "--enable-warnings-as-errors accepts no argument" "$LINENO" 5
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
case "${TOOLCHAIN_TYPE}" in
|
case "${TOOLCHAIN_TYPE}" in
|
||||||
microsoft)
|
microsoft)
|
||||||
DISABLE_WARNING_PREFIX="-wd"
|
DISABLE_WARNING_PREFIX="-wd"
|
||||||
@ -54179,14 +54214,31 @@ $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;}
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# After AC_OUTPUT, we need to do final work
|
||||||
|
|
||||||
# Try to move the config.log file to the output directory.
|
|
||||||
if test -e ./config.log; then
|
|
||||||
$MV -f ./config.log "$CONFIGURESUPPORT_OUTPUTDIR/config.log" 2> /dev/null
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Make the compare script executable
|
# Try to move config.log (generated by autoconf) to the configure-support directory.
|
||||||
$CHMOD +x $OUTPUT_ROOT/compare.sh
|
if test -e ./config.log; then
|
||||||
|
$MV -f ./config.log "$CONFIGURESUPPORT_OUTPUTDIR/config.log" 2> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Rotate our log file (configure.log)
|
||||||
|
if test -e "$OUTPUT_ROOT/configure.log.old"; then
|
||||||
|
$RM -f "$OUTPUT_ROOT/configure.log.old"
|
||||||
|
fi
|
||||||
|
if test -e "$OUTPUT_ROOT/configure.log"; then
|
||||||
|
$MV -f "$OUTPUT_ROOT/configure.log" "$OUTPUT_ROOT/configure.log.old" 2> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Move configure.log from current directory to the build output root
|
||||||
|
if test -e ./configure.log; then
|
||||||
|
echo found it
|
||||||
|
$MV -f ./configure.log "$OUTPUT_ROOT/configure.log" 2> /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Make the compare script executable
|
||||||
|
$CHMOD +x $OUTPUT_ROOT/compare.sh
|
||||||
|
|
||||||
|
|
||||||
# Finally output some useful information to the user
|
# Finally output some useful information to the user
|
||||||
|
|
||||||
@ -54280,14 +54332,20 @@ $CHMOD +x $OUTPUT_ROOT/compare.sh
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if test -e "$OUTPUT_ROOT/config.log"; then
|
# Locate config.log.
|
||||||
$GREP '^configure:.*: WARNING:' "$OUTPUT_ROOT/config.log" > /dev/null 2>&1
|
if test -e "$CONFIGURESUPPORT_OUTPUTDIR/config.log"; then
|
||||||
if test $? -eq 0; then
|
CONFIG_LOG_PATH="$CONFIGURESUPPORT_OUTPUTDIR"
|
||||||
printf "The following warnings were produced. Repeated here for convenience:\n"
|
elif test -e "./config.log"; then
|
||||||
# We must quote sed expression (using []) to stop m4 from eating the [].
|
CONFIG_LOG_PATH="."
|
||||||
$GREP '^configure:.*: WARNING:' "$OUTPUT_ROOT/config.log" | $SED -e 's/^configure:[0-9]*: //'
|
|
||||||
printf "\n"
|
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
|
|
||||||
|
if test -e "$CONFIG_LOG_PATH/config.log"; then
|
||||||
|
$GREP '^configure:.*: WARNING:' "$CONFIG_LOG_PATH/config.log" > /dev/null 2>&1
|
||||||
|
if test $? -eq 0; then
|
||||||
|
printf "The following warnings were produced. Repeated here for convenience:\n"
|
||||||
|
# We must quote sed expression (using []) to stop m4 from eating the [].
|
||||||
|
$GREP '^configure:.*: WARNING:' "$CONFIG_LOG_PATH/config.log" | $SED -e 's/^configure:[0-9]*: //'
|
||||||
|
printf "\n"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
@ -263,14 +263,20 @@ AC_DEFUN_ONCE([HELP_PRINT_SUMMARY_AND_WARNINGS],
|
|||||||
|
|
||||||
AC_DEFUN_ONCE([HELP_REPEAT_WARNINGS],
|
AC_DEFUN_ONCE([HELP_REPEAT_WARNINGS],
|
||||||
[
|
[
|
||||||
if test -e "$OUTPUT_ROOT/config.log"; then
|
# Locate config.log.
|
||||||
$GREP '^configure:.*: WARNING:' "$OUTPUT_ROOT/config.log" > /dev/null 2>&1
|
if test -e "$CONFIGURESUPPORT_OUTPUTDIR/config.log"; then
|
||||||
if test $? -eq 0; then
|
CONFIG_LOG_PATH="$CONFIGURESUPPORT_OUTPUTDIR"
|
||||||
printf "The following warnings were produced. Repeated here for convenience:\n"
|
elif test -e "./config.log"; then
|
||||||
# We must quote sed expression (using []) to stop m4 from eating the [].
|
CONFIG_LOG_PATH="."
|
||||||
$GREP '^configure:.*: WARNING:' "$OUTPUT_ROOT/config.log" | $SED -e [ 's/^configure:[0-9]*: //' ]
|
|
||||||
printf "\n"
|
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
|
|
||||||
|
if test -e "$CONFIG_LOG_PATH/config.log"; then
|
||||||
|
$GREP '^configure:.*: WARNING:' "$CONFIG_LOG_PATH/config.log" > /dev/null 2>&1
|
||||||
|
if test $? -eq 0; then
|
||||||
|
printf "The following warnings were produced. Repeated here for convenience:\n"
|
||||||
|
# We must quote sed expression (using []) to stop m4 from eating the [].
|
||||||
|
$GREP '^configure:.*: WARNING:' "$CONFIG_LOG_PATH/config.log" | $SED -e [ 's/^configure:[0-9]*: //' ]
|
||||||
|
printf "\n"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
])
|
])
|
||||||
|
@ -321,6 +321,9 @@ CXX_FLAG_DEPS:=@CXX_FLAG_DEPS@
|
|||||||
DISABLE_WARNING_PREFIX := @DISABLE_WARNING_PREFIX@
|
DISABLE_WARNING_PREFIX := @DISABLE_WARNING_PREFIX@
|
||||||
CFLAGS_WARNINGS_ARE_ERRORS:=@CFLAGS_WARNINGS_ARE_ERRORS@
|
CFLAGS_WARNINGS_ARE_ERRORS:=@CFLAGS_WARNINGS_ARE_ERRORS@
|
||||||
|
|
||||||
|
# A global flag (true or false) determining if native warnings are considered errors.
|
||||||
|
WARNINGS_AS_ERRORS := @WARNINGS_AS_ERRORS@
|
||||||
|
|
||||||
CFLAGS_CCACHE:=@CFLAGS_CCACHE@
|
CFLAGS_CCACHE:=@CFLAGS_CCACHE@
|
||||||
|
|
||||||
# Tools that potentially need to be cross compilation aware.
|
# Tools that potentially need to be cross compilation aware.
|
||||||
@ -394,9 +397,6 @@ STRIP:=@STRIP@
|
|||||||
|
|
||||||
LIPO:=@LIPO@
|
LIPO:=@LIPO@
|
||||||
|
|
||||||
# Command to create a shared library
|
|
||||||
SHARED_LIBRARY_FLAGS:=@SHARED_LIBRARY_FLAGS@
|
|
||||||
|
|
||||||
# Options to linker to specify a mapfile.
|
# Options to linker to specify a mapfile.
|
||||||
# (Note absence of := assignment, because we do not want to evaluate the macro body here)
|
# (Note absence of := assignment, because we do not want to evaluate the macro body here)
|
||||||
SET_SHARED_LIBRARY_MAPFILE=@SET_SHARED_LIBRARY_MAPFILE@
|
SET_SHARED_LIBRARY_MAPFILE=@SET_SHARED_LIBRARY_MAPFILE@
|
||||||
|
@ -306,3 +306,4 @@ caa330b275f39282793466529f6864766b31d9fd jdk9-b60
|
|||||||
d690f489ca0bb95a6157d996da2fa72bcbcf02ea jdk9-b61
|
d690f489ca0bb95a6157d996da2fa72bcbcf02ea jdk9-b61
|
||||||
d27f7e0a7aca129969de23e9934408a31b4abf4c jdk9-b62
|
d27f7e0a7aca129969de23e9934408a31b4abf4c jdk9-b62
|
||||||
0acac6937de7a0868f8c6f88b7d036d780abeee6 jdk9-b63
|
0acac6937de7a0868f8c6f88b7d036d780abeee6 jdk9-b63
|
||||||
|
0a5e5a7c3539e8bde73d9fe55750e49a49cb8dac jdk9-b64
|
||||||
|
@ -466,3 +466,4 @@ ee878f3d6732856f7725c590312bfbe2ffa52cc7 jdk9-b58
|
|||||||
715d2da5801c410746e92f08066d53bde1496286 jdk9-b61
|
715d2da5801c410746e92f08066d53bde1496286 jdk9-b61
|
||||||
1eab877142cce6ca06e556e2ad0af688f993f00b jdk9-b62
|
1eab877142cce6ca06e556e2ad0af688f993f00b jdk9-b62
|
||||||
2ac9b6b36689b50d1562627067c92d51781b5684 jdk9-b63
|
2ac9b6b36689b50d1562627067c92d51781b5684 jdk9-b63
|
||||||
|
bf92b8db249cdfa5651ef954b6c0743a7e0ea4cd jdk9-b64
|
||||||
|
@ -810,9 +810,6 @@ class HandlerImpl {
|
|||||||
bool unnecessary_volatile(const Node *barrier);
|
bool unnecessary_volatile(const Node *barrier);
|
||||||
bool needs_releasing_store(const Node *store);
|
bool needs_releasing_store(const Node *store);
|
||||||
|
|
||||||
// Use barrier instructions rather than load acquire / store
|
|
||||||
// release.
|
|
||||||
const bool UseBarriersForVolatile = false;
|
|
||||||
// Use barrier instructions for unsafe volatile gets rather than
|
// Use barrier instructions for unsafe volatile gets rather than
|
||||||
// trying to identify an exact signature for them
|
// trying to identify an exact signature for them
|
||||||
const bool UseBarriersForUnsafeVolatileGet = false;
|
const bool UseBarriersForUnsafeVolatileGet = false;
|
||||||
|
@ -98,8 +98,8 @@ define_pd_global(intx, InlineSmallCode, 1000);
|
|||||||
product(bool, NearCpool, true, \
|
product(bool, NearCpool, true, \
|
||||||
"constant pool is close to instructions") \
|
"constant pool is close to instructions") \
|
||||||
\
|
\
|
||||||
notproduct(bool, UseAcqRelForVolatileFields, false, \
|
product(bool, UseBarriersForVolatile, false, \
|
||||||
"Use acquire and release insns for volatile fields") \
|
"Use memory barriers to implement volatile accesses") \
|
||||||
\
|
\
|
||||||
product(bool, UseCRC32, false, \
|
product(bool, UseCRC32, false, \
|
||||||
"Use CRC32 instructions for CRC32 computation") \
|
"Use CRC32 instructions for CRC32 computation") \
|
||||||
@ -117,8 +117,8 @@ define_pd_global(intx, InlineSmallCode, 1000);
|
|||||||
product(bool, NearCpool, true, \
|
product(bool, NearCpool, true, \
|
||||||
"constant pool is close to instructions") \
|
"constant pool is close to instructions") \
|
||||||
\
|
\
|
||||||
notproduct(bool, UseAcqRelForVolatileFields, false, \
|
product(bool, UseBarriersForVolatile, false, \
|
||||||
"Use acquire and release insns for volatile fields") \
|
"Use memory barriers to implement volatile accesses") \
|
||||||
product(bool, UseNeon, false, \
|
product(bool, UseNeon, false, \
|
||||||
"Use Neon for CRC32 computation") \
|
"Use Neon for CRC32 computation") \
|
||||||
product(bool, UseCRC32, false, \
|
product(bool, UseCRC32, false, \
|
||||||
|
@ -1314,7 +1314,7 @@ void InterpreterMacroAssembler::profile_switch_case(Register index,
|
|||||||
// case_array_offset_in_bytes()
|
// case_array_offset_in_bytes()
|
||||||
movw(reg2, in_bytes(MultiBranchData::per_case_size()));
|
movw(reg2, in_bytes(MultiBranchData::per_case_size()));
|
||||||
movw(rscratch1, in_bytes(MultiBranchData::case_array_offset()));
|
movw(rscratch1, in_bytes(MultiBranchData::case_array_offset()));
|
||||||
maddw(index, index, reg2, rscratch1);
|
Assembler::maddw(index, index, reg2, rscratch1);
|
||||||
|
|
||||||
// Update the case count
|
// Update the case count
|
||||||
increment_mdp_data_at(mdp,
|
increment_mdp_data_at(mdp,
|
||||||
|
@ -1625,7 +1625,7 @@ int MacroAssembler::corrected_idivl(Register result, Register ra, Register rb,
|
|||||||
sdivw(result, ra, rb);
|
sdivw(result, ra, rb);
|
||||||
} else {
|
} else {
|
||||||
sdivw(scratch, ra, rb);
|
sdivw(scratch, ra, rb);
|
||||||
msubw(result, scratch, rb, ra);
|
Assembler::msubw(result, scratch, rb, ra);
|
||||||
}
|
}
|
||||||
|
|
||||||
return idivl_offset;
|
return idivl_offset;
|
||||||
@ -1655,7 +1655,7 @@ int MacroAssembler::corrected_idivq(Register result, Register ra, Register rb,
|
|||||||
sdiv(result, ra, rb);
|
sdiv(result, ra, rb);
|
||||||
} else {
|
} else {
|
||||||
sdiv(scratch, ra, rb);
|
sdiv(scratch, ra, rb);
|
||||||
msub(result, scratch, rb, ra);
|
Assembler::msub(result, scratch, rb, ra);
|
||||||
}
|
}
|
||||||
|
|
||||||
return idivq_offset;
|
return idivq_offset;
|
||||||
@ -3787,14 +3787,6 @@ void MacroAssembler::adrp(Register reg1, const Address &dest, unsigned long &byt
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MacroAssembler::use_acq_rel_for_volatile_fields() {
|
|
||||||
#ifdef PRODUCT
|
|
||||||
return false;
|
|
||||||
#else
|
|
||||||
return UseAcqRelForVolatileFields;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::build_frame(int framesize) {
|
void MacroAssembler::build_frame(int framesize) {
|
||||||
if (framesize == 0) {
|
if (framesize == 0) {
|
||||||
// Is this even possible?
|
// Is this even possible?
|
||||||
|
@ -405,6 +405,18 @@ class MacroAssembler: public Assembler {
|
|||||||
umaddl(Rd, Rn, Rm, zr);
|
umaddl(Rd, Rn, Rm, zr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define WRAP(INSN) \
|
||||||
|
void INSN(Register Rd, Register Rn, Register Rm, Register Ra) { \
|
||||||
|
if ((VM_Version::cpu_cpuFeatures() & VM_Version::CPU_A53MAC) && Ra != zr) \
|
||||||
|
nop(); \
|
||||||
|
Assembler::INSN(Rd, Rn, Rm, Ra); \
|
||||||
|
}
|
||||||
|
|
||||||
|
WRAP(madd) WRAP(msub) WRAP(maddw) WRAP(msubw)
|
||||||
|
WRAP(smaddl) WRAP(smsubl) WRAP(umaddl) WRAP(umsubl)
|
||||||
|
#undef WRAP
|
||||||
|
|
||||||
|
|
||||||
// macro assembly operations needed for aarch64
|
// macro assembly operations needed for aarch64
|
||||||
|
|
||||||
// first two private routines for loading 32 bit or 64 bit constants
|
// first two private routines for loading 32 bit or 64 bit constants
|
||||||
@ -1094,9 +1106,6 @@ public:
|
|||||||
address read_polling_page(Register r, address page, relocInfo::relocType rtype);
|
address read_polling_page(Register r, address page, relocInfo::relocType rtype);
|
||||||
address read_polling_page(Register r, relocInfo::relocType rtype);
|
address read_polling_page(Register r, relocInfo::relocType rtype);
|
||||||
|
|
||||||
// Used by aarch64.ad to control code generation
|
|
||||||
static bool use_acq_rel_for_volatile_fields();
|
|
||||||
|
|
||||||
// CRC32 code for java.util.zip.CRC32::updateBytes() instrinsic.
|
// CRC32 code for java.util.zip.CRC32::updateBytes() instrinsic.
|
||||||
void update_byte_crc32(Register crc, Register val, Register table);
|
void update_byte_crc32(Register crc, Register val, Register table);
|
||||||
void update_word_crc32(Register crc, Register v, Register tmp,
|
void update_word_crc32(Register crc, Register v, Register tmp,
|
||||||
@ -1150,10 +1159,6 @@ private:
|
|||||||
int offset, int size);
|
int offset, int size);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Used by aarch64.ad to control code generation
|
|
||||||
#define treat_as_volatile(MEM_NODE) \
|
|
||||||
(MacroAssembler::use_acq_rel_for_volatile_fields() ? (MEM_NODE)->is_volatile() : false)
|
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
inline bool AbstractAssembler::pd_check_instruction_mark() { return false; }
|
inline bool AbstractAssembler::pd_check_instruction_mark() { return false; }
|
||||||
#endif
|
#endif
|
||||||
|
@ -59,6 +59,9 @@
|
|||||||
|
|
||||||
int VM_Version::_cpu;
|
int VM_Version::_cpu;
|
||||||
int VM_Version::_model;
|
int VM_Version::_model;
|
||||||
|
int VM_Version::_model2;
|
||||||
|
int VM_Version::_variant;
|
||||||
|
int VM_Version::_revision;
|
||||||
int VM_Version::_stepping;
|
int VM_Version::_stepping;
|
||||||
int VM_Version::_cpuFeatures;
|
int VM_Version::_cpuFeatures;
|
||||||
const char* VM_Version::_features_str = "";
|
const char* VM_Version::_features_str = "";
|
||||||
@ -122,13 +125,47 @@ void VM_Version::get_processor_features() {
|
|||||||
|
|
||||||
char buf[512];
|
char buf[512];
|
||||||
|
|
||||||
strcpy(buf, "simd");
|
_cpuFeatures = auxv;
|
||||||
|
|
||||||
|
int cpu_lines = 0;
|
||||||
|
if (FILE *f = fopen("/proc/cpuinfo", "r")) {
|
||||||
|
char buf[128], *p;
|
||||||
|
while (fgets(buf, sizeof (buf), f) != NULL) {
|
||||||
|
if (p = strchr(buf, ':')) {
|
||||||
|
long v = strtol(p+1, NULL, 0);
|
||||||
|
if (strncmp(buf, "CPU implementer", sizeof "CPU implementer" - 1) == 0) {
|
||||||
|
_cpu = v;
|
||||||
|
cpu_lines++;
|
||||||
|
} else if (strncmp(buf, "CPU variant", sizeof "CPU variant" - 1) == 0) {
|
||||||
|
_variant = v;
|
||||||
|
} else if (strncmp(buf, "CPU part", sizeof "CPU part" - 1) == 0) {
|
||||||
|
if (_model != v) _model2 = _model;
|
||||||
|
_model = v;
|
||||||
|
} else if (strncmp(buf, "CPU revision", sizeof "CPU revision" - 1) == 0) {
|
||||||
|
_revision = v;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose(f);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enable vendor specific features
|
||||||
|
if (_cpu == CPU_CAVIUM && _variant == 0) _cpuFeatures |= CPU_DMB_ATOMICS;
|
||||||
|
if (_cpu == CPU_ARM && (_model == 0xd03 || _model2 == 0xd03)) _cpuFeatures |= CPU_A53MAC;
|
||||||
|
// If an olde style /proc/cpuinfo (cpu_lines == 1) then if _model is an A57 (0xd07)
|
||||||
|
// we assume the worst and assume we could be on a big little system and have
|
||||||
|
// undisclosed A53 cores which we could be swapped to at any stage
|
||||||
|
if (_cpu == CPU_ARM && cpu_lines == 1 && _model == 0xd07) _cpuFeatures |= CPU_A53MAC;
|
||||||
|
|
||||||
|
sprintf(buf, "0x%02x:0x%x:0x%03x:%d", _cpu, _variant, _model, _revision);
|
||||||
|
if (_model2) sprintf(buf+strlen(buf), "(0x%03x)", _model2);
|
||||||
|
if (auxv & HWCAP_ASIMD) strcat(buf, ", simd");
|
||||||
if (auxv & HWCAP_CRC32) strcat(buf, ", crc");
|
if (auxv & HWCAP_CRC32) strcat(buf, ", crc");
|
||||||
if (auxv & HWCAP_AES) strcat(buf, ", aes");
|
if (auxv & HWCAP_AES) strcat(buf, ", aes");
|
||||||
if (auxv & HWCAP_SHA1) strcat(buf, ", sha1");
|
if (auxv & HWCAP_SHA1) strcat(buf, ", sha1");
|
||||||
if (auxv & HWCAP_SHA2) strcat(buf, ", sha256");
|
if (auxv & HWCAP_SHA2) strcat(buf, ", sha256");
|
||||||
|
|
||||||
_features_str = strdup(buf);
|
_features_str = os::strdup(buf);
|
||||||
|
|
||||||
if (FLAG_IS_DEFAULT(UseCRC32)) {
|
if (FLAG_IS_DEFAULT(UseCRC32)) {
|
||||||
UseCRC32 = (auxv & HWCAP_CRC32) != 0;
|
UseCRC32 = (auxv & HWCAP_CRC32) != 0;
|
||||||
@ -202,6 +239,10 @@ void VM_Version::get_processor_features() {
|
|||||||
UseMultiplyToLenIntrinsic = true;
|
UseMultiplyToLenIntrinsic = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (FLAG_IS_DEFAULT(UseBarriersForVolatile)) {
|
||||||
|
UseBarriersForVolatile = (_cpuFeatures & CPU_DMB_ATOMICS) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef COMPILER2
|
#ifdef COMPILER2
|
||||||
if (FLAG_IS_DEFAULT(OptoScheduling)) {
|
if (FLAG_IS_DEFAULT(OptoScheduling)) {
|
||||||
OptoScheduling = true;
|
OptoScheduling = true;
|
||||||
|
@ -34,6 +34,9 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
static int _cpu;
|
static int _cpu;
|
||||||
static int _model;
|
static int _model;
|
||||||
|
static int _model2;
|
||||||
|
static int _variant;
|
||||||
|
static int _revision;
|
||||||
static int _stepping;
|
static int _stepping;
|
||||||
static int _cpuFeatures; // features returned by the "cpuid" instruction
|
static int _cpuFeatures; // features returned by the "cpuid" instruction
|
||||||
// 0 if this instruction is not available
|
// 0 if this instruction is not available
|
||||||
@ -49,7 +52,40 @@ public:
|
|||||||
static void assert_is_initialized() {
|
static void assert_is_initialized() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum {
|
||||||
|
CPU_ARM = 'A',
|
||||||
|
CPU_BROADCOM = 'B',
|
||||||
|
CPU_CAVIUM = 'C',
|
||||||
|
CPU_DEC = 'D',
|
||||||
|
CPU_INFINEON = 'I',
|
||||||
|
CPU_MOTOROLA = 'M',
|
||||||
|
CPU_NVIDIA = 'N',
|
||||||
|
CPU_AMCC = 'P',
|
||||||
|
CPU_QUALCOM = 'Q',
|
||||||
|
CPU_MARVELL = 'V',
|
||||||
|
CPU_INTEL = 'i',
|
||||||
|
} cpuFamily;
|
||||||
|
|
||||||
|
enum {
|
||||||
|
CPU_FP = (1<<0),
|
||||||
|
CPU_ASIMD = (1<<1),
|
||||||
|
CPU_EVTSTRM = (1<<2),
|
||||||
|
CPU_AES = (1<<3),
|
||||||
|
CPU_PMULL = (1<<4),
|
||||||
|
CPU_SHA1 = (1<<5),
|
||||||
|
CPU_SHA2 = (1<<6),
|
||||||
|
CPU_CRC32 = (1<<7),
|
||||||
|
CPU_A53MAC = (1 << 30),
|
||||||
|
CPU_DMB_ATOMICS = (1 << 31),
|
||||||
|
} cpuFeatureFlags;
|
||||||
|
|
||||||
static const char* cpu_features() { return _features_str; }
|
static const char* cpu_features() { return _features_str; }
|
||||||
|
static int cpu_family() { return _cpu; }
|
||||||
|
static int cpu_model() { return _model; }
|
||||||
|
static int cpu_model2() { return _model2; }
|
||||||
|
static int cpu_variant() { return _variant; }
|
||||||
|
static int cpu_revision() { return _revision; }
|
||||||
|
static int cpu_cpuFeatures() { return _cpuFeatures; }
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -306,3 +306,4 @@ c76339e86ea7da5d9ac7856f3fae9ef73eef04a2 jdk9-b57
|
|||||||
da84dcac1b0b12c5b836b05ac75ecbfadee0cd32 jdk9-b61
|
da84dcac1b0b12c5b836b05ac75ecbfadee0cd32 jdk9-b61
|
||||||
49118e68fbd4cc0044e718c47db681946d5efd69 jdk9-b62
|
49118e68fbd4cc0044e718c47db681946d5efd69 jdk9-b62
|
||||||
fd3281c400347088b36aeb16273aa679d53a81a4 jdk9-b63
|
fd3281c400347088b36aeb16273aa679d53a81a4 jdk9-b63
|
||||||
|
7de8d036ad0980d988d1b9b4b4e6be555d9fbf98 jdk9-b64
|
||||||
|
@ -396,7 +396,7 @@ ifeq ($(OPENJDK_TARGET_OS), solaris)
|
|||||||
$(eval $(call SetupNativeCompilation,BUILD_LIBPOLLER, \
|
$(eval $(call SetupNativeCompilation,BUILD_LIBPOLLER, \
|
||||||
SRC := $(DEMO_SOLARIS_SRC)/jni/Poller, \
|
SRC := $(DEMO_SOLARIS_SRC)/jni/Poller, \
|
||||||
OPTIMIZATION := LOW, \
|
OPTIMIZATION := LOW, \
|
||||||
CFLAGS := $(CFLAGS_JDKLIB) $(SHARED_LIBRARY_FLAGS) \
|
CFLAGS := $(CFLAGS_JDKLIB) \
|
||||||
-I$(SUPPORT_OUTPUTDIR)/demo/classes/jni/Poller, \
|
-I$(SUPPORT_OUTPUTDIR)/demo/classes/jni/Poller, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB), \
|
LDFLAGS := $(LDFLAGS_JDKLIB), \
|
||||||
LDFLAGS_SUFFIX_solaris := -lc, \
|
LDFLAGS_SUFFIX_solaris := -lc, \
|
||||||
|
@ -1833,10 +1833,3 @@ charset x-JIS0212_MS5022X JIS_X_0212_MS5022X
|
|||||||
##
|
##
|
||||||
########################################################
|
########################################################
|
||||||
|
|
||||||
charset x-COMPOUND_TEXT COMPOUND_TEXT
|
|
||||||
package sun.nio.cs.ext
|
|
||||||
type source
|
|
||||||
os unix
|
|
||||||
alias COMPOUND_TEXT # JDK historical
|
|
||||||
alias x11-compound_text
|
|
||||||
alias x-compound-text
|
|
||||||
|
@ -39,7 +39,7 @@ ifeq ($(OPENJDK_TARGET_OS), windows)
|
|||||||
CFLAGS := $(filter-out -Zc:wchar_t-, $(CFLAGS_JDKEXE)) -Zc:wchar_t \
|
CFLAGS := $(filter-out -Zc:wchar_t-, $(CFLAGS_JDKEXE)) -Zc:wchar_t \
|
||||||
-analyze- -Od -Gd -D_WINDOWS \
|
-analyze- -Od -Gd -D_WINDOWS \
|
||||||
-D_UNICODE -DUNICODE -RTC1 -EHsc, \
|
-D_UNICODE -DUNICODE -RTC1 -EHsc, \
|
||||||
DISABLED_WARNINGS_microsoft := 4267, \
|
DISABLED_WARNINGS_microsoft := 4267 4996, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKEXE) \
|
LDFLAGS := $(LDFLAGS_JDKEXE) \
|
||||||
Advapi32.lib Version.lib User32.lib, \
|
Advapi32.lib Version.lib User32.lib, \
|
||||||
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/jdk.accessibility/jabswitch, \
|
OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/jdk.accessibility/jabswitch, \
|
||||||
|
@ -84,6 +84,7 @@ $(eval $(call SetupNativeCompilation,BUILD_UNPACKEXE, \
|
|||||||
CFLAGS_linux := -fPIC, \
|
CFLAGS_linux := -fPIC, \
|
||||||
CFLAGS_solaris := -KPIC, \
|
CFLAGS_solaris := -KPIC, \
|
||||||
CFLAGS_macosx := -fPIC, \
|
CFLAGS_macosx := -fPIC, \
|
||||||
|
DISABLED_WARNINGS_gcc := unused-result, \
|
||||||
MAPFILE := $(UNPACK_MAPFILE),\
|
MAPFILE := $(UNPACK_MAPFILE),\
|
||||||
LDFLAGS := $(UNPACKEXE_ZIPOBJS) \
|
LDFLAGS := $(UNPACKEXE_ZIPOBJS) \
|
||||||
$(LDFLAGS_JDKEXE) $(LDFLAGS_CXX_JDK) \
|
$(LDFLAGS_JDKEXE) $(LDFLAGS_CXX_JDK) \
|
||||||
|
@ -246,9 +246,10 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBAWT, \
|
|||||||
CFLAGS := $(CFLAGS_JDKLIB) $(LIBAWT_CFLAGS), \
|
CFLAGS := $(CFLAGS_JDKLIB) $(LIBAWT_CFLAGS), \
|
||||||
DISABLED_WARNINGS_gcc := sign-compare unused-result maybe-uninitialized \
|
DISABLED_WARNINGS_gcc := sign-compare unused-result maybe-uninitialized \
|
||||||
format-nonliteral parentheses, \
|
format-nonliteral parentheses, \
|
||||||
DISABLED_WARNINGS_clang := logical-op-parentheses, \
|
DISABLED_WARNINGS_clang := logical-op-parentheses extern-initializer, \
|
||||||
DISABLED_WARNINGS_solstudio := E_DECLARATION_IN_CODE, \
|
DISABLED_WARNINGS_solstudio := E_DECLARATION_IN_CODE, \
|
||||||
DISABLED_WARNINGS_microsoft := 4297 4244 4267, \
|
DISABLED_WARNINGS_microsoft := 4297 4244 4267 4996, \
|
||||||
|
WARNINGS_AS_ERRORS_gcc := false, \
|
||||||
ASFLAGS := $(LIBAWT_ASFLAGS), \
|
ASFLAGS := $(LIBAWT_ASFLAGS), \
|
||||||
MAPFILE := $(LIBAWT_MAPFILE), \
|
MAPFILE := $(LIBAWT_MAPFILE), \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) $(call SET_SHARED_LIBRARY_ORIGIN), \
|
LDFLAGS := $(LDFLAGS_JDKLIB) $(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
@ -357,6 +358,7 @@ ifeq ($(findstring $(OPENJDK_TARGET_OS),windows macosx),)
|
|||||||
format-security int-to-pointer-cast parentheses, \
|
format-security int-to-pointer-cast parentheses, \
|
||||||
DISABLED_WARNINGS_solstudio := E_DECLARATION_IN_CODE \
|
DISABLED_WARNINGS_solstudio := E_DECLARATION_IN_CODE \
|
||||||
E_ASSIGNMENT_TYPE_MISMATCH E_NON_CONST_INIT, \
|
E_ASSIGNMENT_TYPE_MISMATCH E_NON_CONST_INIT, \
|
||||||
|
WARNINGS_AS_ERRORS_gcc := false, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libawt_xawt/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libawt_xawt/mapfile-vers, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
||||||
$(X_LIBS) $(LIBAWT_XAWT_LDFLAGS) \
|
$(X_LIBS) $(LIBAWT_XAWT_LDFLAGS) \
|
||||||
@ -408,11 +410,11 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBLCMS, \
|
|||||||
INCLUDE_FILES := $(BUILD_LIBLCMS_INCLUDE_FILES), \
|
INCLUDE_FILES := $(BUILD_LIBLCMS_INCLUDE_FILES), \
|
||||||
OPTIMIZATION := HIGHEST, \
|
OPTIMIZATION := HIGHEST, \
|
||||||
CFLAGS := $(filter-out -xc99=%none, $(CFLAGS_JDKLIB)) \
|
CFLAGS := $(filter-out -xc99=%none, $(CFLAGS_JDKLIB)) \
|
||||||
$(SHARED_LIBRARY_FLAGS) $(LIBLCMS_CPPFLAGS) \
|
$(LIBLCMS_CPPFLAGS) \
|
||||||
$(LCMS_CFLAGS), \
|
$(LCMS_CFLAGS), \
|
||||||
CFLAGS_solaris := -xc99=no_lib, \
|
CFLAGS_solaris := -xc99=no_lib, \
|
||||||
CFLAGS_windows := -DCMS_IS_WINDOWS_, \
|
CFLAGS_windows := -DCMS_IS_WINDOWS_, \
|
||||||
DISABLED_WARNINGS_gcc := format-nonliteral, \
|
DISABLED_WARNINGS_gcc := format-nonliteral type-limits, \
|
||||||
DISABLED_WARNINGS_clang := tautological-compare, \
|
DISABLED_WARNINGS_clang := tautological-compare, \
|
||||||
DISABLED_WARNINGS_solstudio := E_STATEMENT_NOT_REACHED, \
|
DISABLED_WARNINGS_solstudio := E_STATEMENT_NOT_REACHED, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/liblcms/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/liblcms/mapfile-vers, \
|
||||||
@ -647,10 +649,13 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBFONTMANAGER, \
|
|||||||
OPTIMIZATION := $(LIBFONTMANAGER_OPTIMIZATION), \
|
OPTIMIZATION := $(LIBFONTMANAGER_OPTIMIZATION), \
|
||||||
CFLAGS_windows = -DCC_NOEX, \
|
CFLAGS_windows = -DCC_NOEX, \
|
||||||
DISABLED_WARNINGS_gcc := sign-compare int-to-pointer-cast reorder \
|
DISABLED_WARNINGS_gcc := sign-compare int-to-pointer-cast reorder \
|
||||||
delete-non-virtual-dtor, \
|
delete-non-virtual-dtor type-limits, \
|
||||||
DISABLED_WARNINGS_clang := unused-value incompatible-pointer-types, \
|
DISABLED_WARNINGS_clang := unused-value incompatible-pointer-types \
|
||||||
|
tautological-constant-out-of-range-compare int-to-pointer-cast, \
|
||||||
DISABLED_WARNINGS_solstudio := truncwarn, \
|
DISABLED_WARNINGS_solstudio := truncwarn, \
|
||||||
DISABLED_WARNINGS_microsoft := 4267 4244 4018 4090, \
|
DISABLED_WARNINGS_microsoft := 4267 4244 4018 4090 4996 4146, \
|
||||||
|
WARNINGS_AS_ERRORS_gcc := false, \
|
||||||
|
WARNINGS_AS_ERRORS_solstudio := false, \
|
||||||
MAPFILE := $(BUILD_LIBFONTMANAGER_MAPFILE), \
|
MAPFILE := $(BUILD_LIBFONTMANAGER_MAPFILE), \
|
||||||
LDFLAGS := $(subst -Xlinker -z -Xlinker defs,,$(LDFLAGS_JDKLIB)) $(LDFLAGS_CXX_JDK) \
|
LDFLAGS := $(subst -Xlinker -z -Xlinker defs,,$(LDFLAGS_JDKLIB)) $(LDFLAGS_CXX_JDK) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
@ -880,10 +885,10 @@ ifndef BUILD_HEADLESS_ONLY
|
|||||||
OPTIMIZATION := LOW, \
|
OPTIMIZATION := LOW, \
|
||||||
CFLAGS := $(LIBSPLASHSCREEN_CFLAGS) $(CFLAGS_JDKLIB) \
|
CFLAGS := $(LIBSPLASHSCREEN_CFLAGS) $(CFLAGS_JDKLIB) \
|
||||||
$(GIFLIB_CFLAGS) $(LIBJPEG_CFLAGS) $(PNG_CFLAGS), \
|
$(GIFLIB_CFLAGS) $(LIBJPEG_CFLAGS) $(PNG_CFLAGS), \
|
||||||
DISABLED_WARNINGS_gcc := type-limits unused-result maybe-uninitialized, \
|
DISABLED_WARNINGS_gcc := sign-compare type-limits unused-result maybe-uninitialized, \
|
||||||
DISABLED_WARNINGS_clang := incompatible-pointer-types, \
|
DISABLED_WARNINGS_clang := incompatible-pointer-types, \
|
||||||
DISABLED_WARNINGS_solstudio := E_NEWLINE_NOT_LAST, \
|
DISABLED_WARNINGS_solstudio := E_NEWLINE_NOT_LAST E_DECLARATION_IN_CODE, \
|
||||||
DISABLED_WARNINGS_microsoft := 4244 4267, \
|
DISABLED_WARNINGS_microsoft := 4018 4244 4267, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libsplashscreen/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libsplashscreen/mapfile-vers, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
@ -956,6 +961,7 @@ ifeq ($(OPENJDK_TARGET_OS), macosx)
|
|||||||
DISABLED_WARNINGS_clang := incomplete-implementation \
|
DISABLED_WARNINGS_clang := incomplete-implementation \
|
||||||
deprecated-declarations objc-method-access bitwise-op-parentheses \
|
deprecated-declarations objc-method-access bitwise-op-parentheses \
|
||||||
incompatible-pointer-types parentheses-equality extra-tokens, \
|
incompatible-pointer-types parentheses-equality extra-tokens, \
|
||||||
|
WARNINGS_AS_ERRORS_clang := false, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN) \
|
$(call SET_SHARED_LIBRARY_ORIGIN) \
|
||||||
-L$(INSTALL_LIBRARIES_HERE), \
|
-L$(INSTALL_LIBRARIES_HERE), \
|
||||||
|
@ -149,7 +149,8 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBJAVA, \
|
|||||||
DISABLED_WARNINGS_gcc := type-limits format-nonliteral, \
|
DISABLED_WARNINGS_gcc := type-limits format-nonliteral, \
|
||||||
DISABLED_WARNINGS_clang := int-conversion, \
|
DISABLED_WARNINGS_clang := int-conversion, \
|
||||||
DISABLED_WARNINGS_solstudio := E_DECLARATION_IN_CODE, \
|
DISABLED_WARNINGS_solstudio := E_DECLARATION_IN_CODE, \
|
||||||
DISABLED_WARNINGS_microsoft := 4022 4267, \
|
DISABLED_WARNINGS_microsoft := 4022 4267 4996, \
|
||||||
|
WARNINGS_AS_ERRORS_solstudio := false, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjava/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjava/mapfile-vers, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
|
@ -38,6 +38,7 @@ ifeq ($(OPENJDK_TARGET_OS), solaris)
|
|||||||
OPTIMIZATION := LOW, \
|
OPTIMIZATION := LOW, \
|
||||||
CFLAGS := $(CFLAGS_JDKLIB) \
|
CFLAGS := $(CFLAGS_JDKLIB) \
|
||||||
$(addprefix -I, $(LIBJ2UCRYPTO_SRC)), \
|
$(addprefix -I, $(LIBJ2UCRYPTO_SRC)), \
|
||||||
|
DISABLED_WARNINGS_solstudio := E_MACRO_REDEFINED, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libj2ucrypto/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libj2ucrypto/mapfile-vers, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB), \
|
LDFLAGS := $(LDFLAGS_JDKLIB), \
|
||||||
LDFLAGS_SUFFIX := $(LIBDL), \
|
LDFLAGS_SUFFIX := $(LIBDL), \
|
||||||
|
@ -34,7 +34,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBNET, \
|
|||||||
$(LIBJAVA_HEADER_FLAGS) $(addprefix -I, $(LIBNET_SRC_DIRS)), \
|
$(LIBJAVA_HEADER_FLAGS) $(addprefix -I, $(LIBNET_SRC_DIRS)), \
|
||||||
DISABLED_WARNINGS_gcc := format-nonliteral, \
|
DISABLED_WARNINGS_gcc := format-nonliteral, \
|
||||||
DISABLED_WARNINGS_clang := parentheses-equality constant-logical-operand, \
|
DISABLED_WARNINGS_clang := parentheses-equality constant-logical-operand, \
|
||||||
DISABLED_WARNINGS_microsoft := 4244 4047 4133, \
|
DISABLED_WARNINGS_microsoft := 4244 4047 4133 4996, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libnet/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libnet/mapfile-vers, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
|
@ -70,7 +70,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBNIO, \
|
|||||||
$(BUILD_LIBNIO_CFLAGS), \
|
$(BUILD_LIBNIO_CFLAGS), \
|
||||||
DISABLED_WARNINGS_gcc := type-limits, \
|
DISABLED_WARNINGS_gcc := type-limits, \
|
||||||
DISABLED_WARNINGS_clang := tautological-compare, \
|
DISABLED_WARNINGS_clang := tautological-compare, \
|
||||||
DISABLED_WARNINGS_microsoft := 4244, \
|
DISABLED_WARNINGS_microsoft := 4244 4996, \
|
||||||
MAPFILE := $(BUILD_LIBNIO_MAPFILE), \
|
MAPFILE := $(BUILD_LIBNIO_MAPFILE), \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) $(BUILD_LIBNIO_LDFLAGS) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) $(BUILD_LIBNIO_LDFLAGS) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
|
@ -111,10 +111,6 @@ ifeq ($(OPENJDK_TARGET_OS), solaris)
|
|||||||
LIBJSOUND_SRC_FILES += $(LIBJSOUND_DAUDIOFILES)
|
LIBJSOUND_SRC_FILES += $(LIBJSOUND_DAUDIOFILES)
|
||||||
endif # OPENJDK_TARGET_OS solaris
|
endif # OPENJDK_TARGET_OS solaris
|
||||||
|
|
||||||
|
|
||||||
ifeq ($(OPENJDK_TARGET_CPU), aarch64)
|
|
||||||
LIBJSOUND_CFLAGS += -DX_ARCH=X_AARCH64
|
|
||||||
endif
|
|
||||||
LIBJSOUND_CFLAGS += -DEXTRA_SOUND_JNI_LIBS='"$(EXTRA_SOUND_JNI_LIBS)"'
|
LIBJSOUND_CFLAGS += -DEXTRA_SOUND_JNI_LIBS='"$(EXTRA_SOUND_JNI_LIBS)"'
|
||||||
|
|
||||||
$(eval $(call SetupNativeCompilation,BUILD_LIBJSOUND, \
|
$(eval $(call SetupNativeCompilation,BUILD_LIBJSOUND, \
|
||||||
@ -129,6 +125,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBJSOUND, \
|
|||||||
CXXFLAGS := $(CXXFLAGS_JDKLIB) $(LIBJSOUND_CFLAGS), \
|
CXXFLAGS := $(CXXFLAGS_JDKLIB) $(LIBJSOUND_CFLAGS), \
|
||||||
DISABLED_WARNINGS_clang := implicit-function-declaration \
|
DISABLED_WARNINGS_clang := implicit-function-declaration \
|
||||||
deprecated-writable-strings, \
|
deprecated-writable-strings, \
|
||||||
|
WARNINGS_AS_ERRORS_clang := false, \
|
||||||
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjsound/mapfile-vers, \
|
MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjsound/mapfile-vers, \
|
||||||
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
LDFLAGS := $(LDFLAGS_JDKLIB) \
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
$(call SET_SHARED_LIBRARY_ORIGIN), \
|
||||||
|
@ -948,8 +948,15 @@ SetMainClassForAWT(JNIEnv *env, jclass mainClass) {
|
|||||||
jmethodID getCanonicalNameMID = NULL;
|
jmethodID getCanonicalNameMID = NULL;
|
||||||
NULL_CHECK(getCanonicalNameMID = (*env)->GetMethodID(env, classClass, "getCanonicalName", "()Ljava/lang/String;"));
|
NULL_CHECK(getCanonicalNameMID = (*env)->GetMethodID(env, classClass, "getCanonicalName", "()Ljava/lang/String;"));
|
||||||
|
|
||||||
jstring mainClassString = NULL;
|
jstring mainClassString = (*env)->CallObjectMethod(env, mainClass, getCanonicalNameMID);
|
||||||
NULL_CHECK(mainClassString = (*env)->CallObjectMethod(env, mainClass, getCanonicalNameMID));
|
if ((*env)->ExceptionCheck(env)) {
|
||||||
|
/*
|
||||||
|
* Clears all errors caused by getCanonicalName() on the mainclass and
|
||||||
|
* leaves the JAVA_MAIN_CLASS__<pid> empty.
|
||||||
|
*/
|
||||||
|
(*env)->ExceptionClear(env);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
const char *mainClassName = NULL;
|
const char *mainClassName = NULL;
|
||||||
NULL_CHECK(mainClassName = (*env)->GetStringUTFChars(env, mainClassString, NULL));
|
NULL_CHECK(mainClassName = (*env)->GetStringUTFChars(env, mainClassString, NULL));
|
||||||
@ -1056,7 +1063,7 @@ JVMInit(InvocationFunctions* ifn, jlong threadStackSize,
|
|||||||
* Note the jvmInstance must be initialized first before entering into
|
* Note the jvmInstance must be initialized first before entering into
|
||||||
* ShowSplashScreen, as there is a callback into the JLI_GetJavaVMInstance.
|
* ShowSplashScreen, as there is a callback into the JLI_GetJavaVMInstance.
|
||||||
*/
|
*/
|
||||||
void PostJVMInit(JNIEnv *env, jstring mainClass, JavaVM *vm) {
|
void PostJVMInit(JNIEnv *env, jclass mainClass, JavaVM *vm) {
|
||||||
jvmInstance = vm;
|
jvmInstance = vm;
|
||||||
SetMainClassForAWT(env, mainClass);
|
SetMainClassForAWT(env, mainClass);
|
||||||
CHECK_EXCEPTION_RETURN();
|
CHECK_EXCEPTION_RETURN();
|
||||||
|
@ -272,6 +272,7 @@ public class BufferedReader extends Reader {
|
|||||||
* stream has been reached
|
* stream has been reached
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public int read(char cbuf[], int off, int len) throws IOException {
|
public int read(char cbuf[], int off, int len) throws IOException {
|
||||||
synchronized (lock) {
|
synchronized (lock) {
|
||||||
|
@ -116,6 +116,7 @@ public class CharArrayReader extends Reader {
|
|||||||
* the end of the stream has been reached
|
* the end of the stream has been reached
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public int read(char b[], int off, int len) throws IOException {
|
public int read(char b[], int off, int len) throws IOException {
|
||||||
synchronized (lock) {
|
synchronized (lock) {
|
||||||
|
@ -69,6 +69,7 @@ public abstract class FilterReader extends Reader {
|
|||||||
* Reads characters into a portion of an array.
|
* Reads characters into a portion of an array.
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public int read(char cbuf[], int off, int len) throws IOException {
|
public int read(char cbuf[], int off, int len) throws IOException {
|
||||||
return in.read(cbuf, off, len);
|
return in.read(cbuf, off, len);
|
||||||
|
@ -179,6 +179,7 @@ public class InputStreamReader extends Reader {
|
|||||||
* stream has been reached
|
* stream has been reached
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public int read(char cbuf[], int offset, int length) throws IOException {
|
public int read(char cbuf[], int offset, int length) throws IOException {
|
||||||
return sd.read(cbuf, offset, length);
|
return sd.read(cbuf, offset, length);
|
||||||
|
@ -159,6 +159,8 @@ public class LineNumberReader extends BufferedReader {
|
|||||||
*
|
*
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
* If an I/O error occurs
|
* If an I/O error occurs
|
||||||
|
*
|
||||||
|
* @throws IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("fallthrough")
|
@SuppressWarnings("fallthrough")
|
||||||
public int read(char cbuf[], int off, int len) throws IOException {
|
public int read(char cbuf[], int off, int len) throws IOException {
|
||||||
|
@ -286,6 +286,7 @@ public class PipedReader extends Reader {
|
|||||||
* <a href=PipedInputStream.html#BROKEN> <code>broken</code></a>,
|
* <a href=PipedInputStream.html#BROKEN> <code>broken</code></a>,
|
||||||
* {@link #connect(java.io.PipedWriter) unconnected}, closed,
|
* {@link #connect(java.io.PipedWriter) unconnected}, closed,
|
||||||
* or an I/O error occurs.
|
* or an I/O error occurs.
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public synchronized int read(char cbuf[], int off, int len) throws IOException {
|
public synchronized int read(char cbuf[], int off, int len) throws IOException {
|
||||||
if (!connected) {
|
if (!connected) {
|
||||||
|
@ -102,6 +102,7 @@ public class PushbackReader extends FilterReader {
|
|||||||
* stream has been reached
|
* stream has been reached
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public int read(char cbuf[], int off, int len) throws IOException {
|
public int read(char cbuf[], int off, int len) throws IOException {
|
||||||
synchronized (lock) {
|
synchronized (lock) {
|
||||||
|
@ -153,6 +153,9 @@ public abstract class Reader implements Readable, Closeable {
|
|||||||
* stream has been reached
|
* stream has been reached
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException
|
||||||
|
* If {@code off} is negative, or {@code len} is negative,
|
||||||
|
* or {@code len} is greater than {@code cbuf.length - off}
|
||||||
*/
|
*/
|
||||||
abstract public int read(char cbuf[], int off, int len) throws IOException;
|
abstract public int read(char cbuf[], int off, int len) throws IOException;
|
||||||
|
|
||||||
|
@ -84,6 +84,7 @@ public class StringReader extends Reader {
|
|||||||
* stream has been reached
|
* stream has been reached
|
||||||
*
|
*
|
||||||
* @exception IOException If an I/O error occurs
|
* @exception IOException If an I/O error occurs
|
||||||
|
* @exception IndexOutOfBoundsException {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
public int read(char cbuf[], int off, int len) throws IOException {
|
public int read(char cbuf[], int off, int len) throws IOException {
|
||||||
synchronized (lock) {
|
synchronized (lock) {
|
||||||
|
@ -26,12 +26,24 @@
|
|||||||
package java.lang.annotation;
|
package java.lang.annotation;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates that annotations with a type are to be documented by javadoc
|
* If the annotation {@code @Documented} is present on the declaration
|
||||||
* and similar tools by default. This type should be used to annotate the
|
* of an annotation type <i>A</i>, then any {@code @A} annotation on
|
||||||
* declarations of types whose annotations affect the use of annotated
|
* an element is considered part of the element's public contract.
|
||||||
* elements by their clients. If a type declaration is annotated with
|
*
|
||||||
* Documented, its annotations become part of the public API
|
* In more detail, when an annotation type <i>A</i> is annotated with
|
||||||
* of the annotated elements.
|
* {@code Documented}, the presence and value of annotations of type
|
||||||
|
* <i>A</i> are a part of the public contract of the elements <i>A</i>
|
||||||
|
* annotates.
|
||||||
|
*
|
||||||
|
* Conversely, if an annotation type <i>B</i> is <em>not</em>
|
||||||
|
* annotated with {@code Documented}, the presence and value of
|
||||||
|
* <i>B</i> annotations are <em>not</em> part of the public contract
|
||||||
|
* of the elements <i>B</i> annotates.
|
||||||
|
*
|
||||||
|
* Concretely, if an annotation type is annotated with {@code
|
||||||
|
* Documented}, by default a tool like javadoc will display
|
||||||
|
* annotations of that type in its output while annotations of
|
||||||
|
* annotation types without {@code Documented} will not be displayed.
|
||||||
*
|
*
|
||||||
* @author Joshua Bloch
|
* @author Joshua Bloch
|
||||||
* @since 1.5
|
* @since 1.5
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -49,7 +49,8 @@ import sun.security.util.SecurityConstants;
|
|||||||
* implementation (a default subclass implementation of this abstract class).
|
* implementation (a default subclass implementation of this abstract class).
|
||||||
* The default Policy implementation can be changed by setting the value
|
* The default Policy implementation can be changed by setting the value
|
||||||
* of the {@code policy.provider} security property to the fully qualified
|
* of the {@code policy.provider} security property to the fully qualified
|
||||||
* name of the desired Policy subclass implementation.
|
* name of the desired Policy subclass implementation. The system class loader
|
||||||
|
* is used to load this class.
|
||||||
*
|
*
|
||||||
* <p> Application code can directly subclass Policy to provide a custom
|
* <p> Application code can directly subclass Policy to provide a custom
|
||||||
* implementation. In addition, an instance of a Policy object can be
|
* implementation. In addition, an instance of a Policy object can be
|
||||||
@ -111,6 +112,10 @@ public abstract class Policy {
|
|||||||
|
|
||||||
private static final Debug debug = Debug.getInstance("policy");
|
private static final Debug debug = Debug.getInstance("policy");
|
||||||
|
|
||||||
|
// Default policy provider
|
||||||
|
private static final String DEFAULT_POLICY =
|
||||||
|
"sun.security.provider.PolicyFile";
|
||||||
|
|
||||||
// Cache mapping ProtectionDomain.Key to PermissionCollection
|
// Cache mapping ProtectionDomain.Key to PermissionCollection
|
||||||
private WeakHashMap<ProtectionDomain.Key, PermissionCollection> pdMapping;
|
private WeakHashMap<ProtectionDomain.Key, PermissionCollection> pdMapping;
|
||||||
|
|
||||||
@ -169,74 +174,7 @@ public abstract class Policy {
|
|||||||
synchronized (Policy.class) {
|
synchronized (Policy.class) {
|
||||||
PolicyInfo pinfo = policy.get();
|
PolicyInfo pinfo = policy.get();
|
||||||
if (pinfo.policy == null) {
|
if (pinfo.policy == null) {
|
||||||
String policy_class = AccessController.doPrivileged(
|
return loadPolicyProvider();
|
||||||
new PrivilegedAction<>() {
|
|
||||||
public String run() {
|
|
||||||
return Security.getProperty("policy.provider");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (policy_class == null) {
|
|
||||||
policy_class = "sun.security.provider.PolicyFile";
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
pinfo = new PolicyInfo(
|
|
||||||
(Policy) Class.forName(policy_class).newInstance(),
|
|
||||||
true);
|
|
||||||
} catch (Exception e) {
|
|
||||||
/*
|
|
||||||
* The policy_class seems to be an extension
|
|
||||||
* so we have to bootstrap loading it via a policy
|
|
||||||
* provider that is on the bootclasspath.
|
|
||||||
* If it loads then shift gears to using the configured
|
|
||||||
* provider.
|
|
||||||
*/
|
|
||||||
|
|
||||||
// install the bootstrap provider to avoid recursion
|
|
||||||
Policy polFile = new sun.security.provider.PolicyFile();
|
|
||||||
pinfo = new PolicyInfo(polFile, false);
|
|
||||||
policy.set(pinfo);
|
|
||||||
|
|
||||||
final String pc = policy_class;
|
|
||||||
Policy pol = AccessController.doPrivileged(
|
|
||||||
new PrivilegedAction<>() {
|
|
||||||
public Policy run() {
|
|
||||||
try {
|
|
||||||
ClassLoader cl =
|
|
||||||
ClassLoader.getSystemClassLoader();
|
|
||||||
// we want the extension loader
|
|
||||||
ClassLoader extcl = null;
|
|
||||||
while (cl != null) {
|
|
||||||
extcl = cl;
|
|
||||||
cl = cl.getParent();
|
|
||||||
}
|
|
||||||
return (extcl != null ? (Policy)Class.forName(
|
|
||||||
pc, true, extcl).newInstance() : null);
|
|
||||||
} catch (Exception e) {
|
|
||||||
if (debug != null) {
|
|
||||||
debug.println("policy provider " +
|
|
||||||
pc +
|
|
||||||
" not available");
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
/*
|
|
||||||
* if it loaded install it as the policy provider. Otherwise
|
|
||||||
* continue to use the system default implementation
|
|
||||||
*/
|
|
||||||
if (pol != null) {
|
|
||||||
pinfo = new PolicyInfo(pol, true);
|
|
||||||
} else {
|
|
||||||
if (debug != null) {
|
|
||||||
debug.println("using sun.security.provider.PolicyFile");
|
|
||||||
}
|
|
||||||
pinfo = new PolicyInfo(polFile, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
policy.set(pinfo);
|
|
||||||
}
|
}
|
||||||
return pinfo.policy;
|
return pinfo.policy;
|
||||||
}
|
}
|
||||||
@ -244,6 +182,70 @@ public abstract class Policy {
|
|||||||
return pi.policy;
|
return pi.policy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads and instantiates a Policy implementation specified by the
|
||||||
|
* policy.provider security property. Note that this method should only
|
||||||
|
* be called by getPolicyNoCheck and from within a synchronized block with
|
||||||
|
* an intrinsic lock on the Policy.class.
|
||||||
|
*/
|
||||||
|
private static Policy loadPolicyProvider() {
|
||||||
|
String policyProvider =
|
||||||
|
AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||||
|
@Override
|
||||||
|
public String run() {
|
||||||
|
return Security.getProperty("policy.provider");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If policy.provider is not set or is set to the default provider,
|
||||||
|
* simply instantiate it and return.
|
||||||
|
*/
|
||||||
|
if (policyProvider == null || policyProvider.isEmpty() ||
|
||||||
|
policyProvider.equals(DEFAULT_POLICY))
|
||||||
|
{
|
||||||
|
Policy polFile = new sun.security.provider.PolicyFile();
|
||||||
|
policy.set(new PolicyInfo(polFile, true));
|
||||||
|
return polFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Locate, load, and instantiate the policy.provider impl using
|
||||||
|
* the system class loader. While doing so, install the bootstrap
|
||||||
|
* provider to avoid potential recursion.
|
||||||
|
*/
|
||||||
|
Policy polFile = new sun.security.provider.PolicyFile();
|
||||||
|
policy.set(new PolicyInfo(polFile, false));
|
||||||
|
|
||||||
|
Policy pol = AccessController.doPrivileged(new PrivilegedAction<>() {
|
||||||
|
@Override
|
||||||
|
public Policy run() {
|
||||||
|
try {
|
||||||
|
ClassLoader scl = ClassLoader.getSystemClassLoader();
|
||||||
|
Class<?> c = Class.forName(policyProvider, true, scl);
|
||||||
|
return (Policy)c.newInstance();
|
||||||
|
} catch (Exception e) {
|
||||||
|
if (debug != null) {
|
||||||
|
debug.println("policy provider " + policyProvider +
|
||||||
|
" not available");
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (pol == null) {
|
||||||
|
// Fallback and use the system default implementation
|
||||||
|
if (debug != null) {
|
||||||
|
debug.println("using " + DEFAULT_POLICY);
|
||||||
|
}
|
||||||
|
pol = polFile;
|
||||||
|
}
|
||||||
|
policy.set(new PolicyInfo(pol, true));
|
||||||
|
return pol;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the system-wide Policy object. This method first calls
|
* Sets the system-wide Policy object. This method first calls
|
||||||
* {@code SecurityManager.checkPermission} with a
|
* {@code SecurityManager.checkPermission} with a
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,7 +30,12 @@ package java.security.cert;
|
|||||||
* <p>
|
* <p>
|
||||||
* This class is used to provide necessary configuration parameters (server
|
* This class is used to provide necessary configuration parameters (server
|
||||||
* name and port number) to implementations of the LDAP {@code CertStore}
|
* name and port number) to implementations of the LDAP {@code CertStore}
|
||||||
* algorithm.
|
* algorithm. However, if you are retrieving certificates or CRLs from
|
||||||
|
* an ldap URI as specified by RFC 5280, use the
|
||||||
|
* {@link java.security.cert.URICertStoreParameters URICertStoreParameters}
|
||||||
|
* instead as the URI may contain additional information such as the
|
||||||
|
* distinguished name that will help the LDAP CertStore find the specific
|
||||||
|
* certificates and CRLs.
|
||||||
* <p>
|
* <p>
|
||||||
* <b>Concurrent Access</b>
|
* <b>Concurrent Access</b>
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -0,0 +1,149 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation. Oracle designates this
|
||||||
|
* particular file as subject to the "Classpath" exception as provided
|
||||||
|
* by Oracle in the LICENSE file that accompanied this code.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package java.security.cert;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parameters used as input for {@code CertStore} algorithms which use
|
||||||
|
* information contained in a URI to retrieve certificates and CRLs.
|
||||||
|
* <p>
|
||||||
|
* This class is used to provide necessary configuration parameters
|
||||||
|
* through a URI as defined in RFC 5280 to implementations of
|
||||||
|
* {@code CertStore} algorithms.
|
||||||
|
* <p>
|
||||||
|
* <b>Concurrent Access</b>
|
||||||
|
* <p>
|
||||||
|
* Unless otherwise specified, the methods defined in this class are not
|
||||||
|
* thread-safe. Multiple threads that need to access a single
|
||||||
|
* object concurrently should synchronize amongst themselves and
|
||||||
|
* provide the necessary locking. Multiple threads each manipulating
|
||||||
|
* separate objects need not synchronize.
|
||||||
|
*
|
||||||
|
* @since 1.9
|
||||||
|
* @see CertStore
|
||||||
|
* @see java.net.URI
|
||||||
|
*/
|
||||||
|
public final class URICertStoreParameters implements CertStoreParameters {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The uri, cannot be null
|
||||||
|
*/
|
||||||
|
private final URI uri;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Hash code for this parameters.
|
||||||
|
*/
|
||||||
|
private int myhash = -1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance of {@code URICertStoreParameters} with the
|
||||||
|
* specified URI.
|
||||||
|
*
|
||||||
|
* @param uri the URI which contains configuration information.
|
||||||
|
* @throws NullPointerException if {@code uri} is null
|
||||||
|
*/
|
||||||
|
public URICertStoreParameters(URI uri) {
|
||||||
|
if (uri == null) {
|
||||||
|
throw new NullPointerException();
|
||||||
|
}
|
||||||
|
this.uri = uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the URI used to construct this
|
||||||
|
* {@code URICertStoreParameters} object.
|
||||||
|
*
|
||||||
|
* @return the URI.
|
||||||
|
*/
|
||||||
|
public URI getURI() {
|
||||||
|
return uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a copy of this object. Changes to the copy will not affect
|
||||||
|
* the original and vice versa.
|
||||||
|
*
|
||||||
|
* @return the copy
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public URICertStoreParameters clone() {
|
||||||
|
try {
|
||||||
|
return new URICertStoreParameters(uri);
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
/* Cannot happen */
|
||||||
|
throw new InternalError(e.toString(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a hash code value for this parameters object.
|
||||||
|
* The hash code is generated using the URI supplied at construction.
|
||||||
|
*
|
||||||
|
* @return a hash code value for this parameters.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
if (myhash == -1) {
|
||||||
|
myhash = uri.hashCode()*7;
|
||||||
|
}
|
||||||
|
return myhash;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Compares the specified object with this parameters object for equality.
|
||||||
|
* Two URICertStoreParameters are considered equal if the URIs used
|
||||||
|
* to construct them are equal.
|
||||||
|
*
|
||||||
|
* @param p the object to test for equality with this parameters.
|
||||||
|
*
|
||||||
|
* @return true if the specified object is equal to this parameters object.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object p) {
|
||||||
|
if (p == null || (!(p instanceof URICertStoreParameters))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (p == this) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
URICertStoreParameters other = (URICertStoreParameters)p;
|
||||||
|
return uri.equals(other.getURI());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a formatted string describing the parameters
|
||||||
|
* including the URI used to construct this object.
|
||||||
|
*
|
||||||
|
* @return a formatted string describing the parameters
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "URICertStoreParameters: " + uri.toString();
|
||||||
|
}
|
||||||
|
}
|
@ -64,6 +64,7 @@ import java.util.function.DoubleBinaryOperator;
|
|||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.function.IntBinaryOperator;
|
import java.util.function.IntBinaryOperator;
|
||||||
import java.util.function.LongBinaryOperator;
|
import java.util.function.LongBinaryOperator;
|
||||||
|
import java.util.function.Predicate;
|
||||||
import java.util.function.ToDoubleBiFunction;
|
import java.util.function.ToDoubleBiFunction;
|
||||||
import java.util.function.ToDoubleFunction;
|
import java.util.function.ToDoubleFunction;
|
||||||
import java.util.function.ToIntBiFunction;
|
import java.util.function.ToIntBiFunction;
|
||||||
@ -1618,6 +1619,45 @@ public class ConcurrentHashMap<K,V> extends AbstractMap<K,V>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper method for EntrySet.removeIf
|
||||||
|
*/
|
||||||
|
boolean removeEntryIf(Predicate<? super Entry<K, V>> function) {
|
||||||
|
if (function == null) throw new NullPointerException();
|
||||||
|
Node<K,V>[] t;
|
||||||
|
boolean removed = false;
|
||||||
|
if ((t = table) != null) {
|
||||||
|
Traverser<K,V> it = new Traverser<K,V>(t, t.length, 0, t.length);
|
||||||
|
for (Node<K,V> p; (p = it.advance()) != null; ) {
|
||||||
|
K k = p.key;
|
||||||
|
V v = p.val;
|
||||||
|
Map.Entry<K,V> e = new AbstractMap.SimpleImmutableEntry<>(k, v);
|
||||||
|
if (function.test(e) && replaceNode(k, null, v) != null)
|
||||||
|
removed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper method for Values.removeIf
|
||||||
|
*/
|
||||||
|
boolean removeValueIf(Predicate<? super V> function) {
|
||||||
|
if (function == null) throw new NullPointerException();
|
||||||
|
Node<K,V>[] t;
|
||||||
|
boolean removed = false;
|
||||||
|
if ((t = table) != null) {
|
||||||
|
Traverser<K,V> it = new Traverser<K,V>(t, t.length, 0, t.length);
|
||||||
|
for (Node<K,V> p; (p = it.advance()) != null; ) {
|
||||||
|
K k = p.key;
|
||||||
|
V v = p.val;
|
||||||
|
if (function.test(v) && replaceNode(k, null, v) != null)
|
||||||
|
removed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If the specified key is not already associated with a value,
|
* If the specified key is not already associated with a value,
|
||||||
* attempts to compute its value using the given mapping function
|
* attempts to compute its value using the given mapping function
|
||||||
@ -4690,6 +4730,10 @@ public class ConcurrentHashMap<K,V> extends AbstractMap<K,V>
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean removeIf(Predicate<? super V> filter) {
|
||||||
|
return map.removeValueIf(filter);
|
||||||
|
}
|
||||||
|
|
||||||
public Spliterator<V> spliterator() {
|
public Spliterator<V> spliterator() {
|
||||||
Node<K,V>[] t;
|
Node<K,V>[] t;
|
||||||
ConcurrentHashMap<K,V> m = map;
|
ConcurrentHashMap<K,V> m = map;
|
||||||
@ -4759,6 +4803,10 @@ public class ConcurrentHashMap<K,V> extends AbstractMap<K,V>
|
|||||||
return added;
|
return added;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean removeIf(Predicate<? super Entry<K, V>> filter) {
|
||||||
|
return map.removeEntryIf(filter);
|
||||||
|
}
|
||||||
|
|
||||||
public final int hashCode() {
|
public final int hashCode() {
|
||||||
int h = 0;
|
int h = 0;
|
||||||
Node<K,V>[] t;
|
Node<K,V>[] t;
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
package java.util.concurrent;
|
package java.util.concurrent;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.function.BiConsumer;
|
import java.util.function.BiConsumer;
|
||||||
@ -44,6 +45,14 @@ import java.util.function.Function;
|
|||||||
* A {@link java.util.Map} providing thread safety and atomicity
|
* A {@link java.util.Map} providing thread safety and atomicity
|
||||||
* guarantees.
|
* guarantees.
|
||||||
*
|
*
|
||||||
|
* <p>To maintain the specified guarantees, default implementations of
|
||||||
|
* methods including {@link #putIfAbsent} inherited from {@link Map}
|
||||||
|
* must be overridden by implementations of this interface. Similarly,
|
||||||
|
* implementations of the collections returned by methods {@link
|
||||||
|
* #keySet}, {@link #values}, and {@link #entrySet} must override
|
||||||
|
* methods such as {@code removeIf} when necessary to
|
||||||
|
* preserve atomicity guarantees.
|
||||||
|
*
|
||||||
* <p>Memory consistency effects: As with other concurrent
|
* <p>Memory consistency effects: As with other concurrent
|
||||||
* collections, actions in a thread prior to placing an object into a
|
* collections, actions in a thread prior to placing an object into a
|
||||||
* {@code ConcurrentMap} as a key or value
|
* {@code ConcurrentMap} as a key or value
|
||||||
@ -60,7 +69,7 @@ import java.util.function.Function;
|
|||||||
* @param <K> the type of keys maintained by this map
|
* @param <K> the type of keys maintained by this map
|
||||||
* @param <V> the type of mapped values
|
* @param <V> the type of mapped values
|
||||||
*/
|
*/
|
||||||
public interface ConcurrentMap<K, V> extends Map<K, V> {
|
public interface ConcurrentMap<K,V> extends Map<K,V> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
@ -86,9 +95,9 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
* @implSpec The default implementation is equivalent to, for this
|
* @implSpec The default implementation is equivalent to, for this
|
||||||
* {@code map}:
|
* {@code map}:
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* for ((Map.Entry<K, V> entry : map.entrySet())
|
* for (Map.Entry<K,V> entry : map.entrySet()) {
|
||||||
* action.accept(entry.getKey(), entry.getValue());
|
* action.accept(entry.getKey(), entry.getValue());
|
||||||
* }</pre>
|
* }}</pre>
|
||||||
*
|
*
|
||||||
* @implNote The default implementation assumes that
|
* @implNote The default implementation assumes that
|
||||||
* {@code IllegalStateException} thrown by {@code getKey()} or
|
* {@code IllegalStateException} thrown by {@code getKey()} or
|
||||||
@ -101,13 +110,13 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
@Override
|
@Override
|
||||||
default void forEach(BiConsumer<? super K, ? super V> action) {
|
default void forEach(BiConsumer<? super K, ? super V> action) {
|
||||||
Objects.requireNonNull(action);
|
Objects.requireNonNull(action);
|
||||||
for (Map.Entry<K, V> entry : entrySet()) {
|
for (Map.Entry<K,V> entry : entrySet()) {
|
||||||
K k;
|
K k;
|
||||||
V v;
|
V v;
|
||||||
try {
|
try {
|
||||||
k = entry.getKey();
|
k = entry.getKey();
|
||||||
v = entry.getValue();
|
v = entry.getValue();
|
||||||
} catch(IllegalStateException ise) {
|
} catch (IllegalStateException ise) {
|
||||||
// this usually means the entry is no longer in the map.
|
// this usually means the entry is no longer in the map.
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -117,14 +126,13 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* If the specified key is not already associated
|
* If the specified key is not already associated
|
||||||
* with a value, associate it with the given value.
|
* with a value, associates it with the given value.
|
||||||
* This is equivalent to
|
* This is equivalent to, for this {@code map}:
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* if (!map.containsKey(key))
|
* if (!map.containsKey(key))
|
||||||
* return map.put(key, value);
|
* return map.put(key, value);
|
||||||
* else
|
* else
|
||||||
* return map.get(key);
|
* return map.get(key);}</pre>
|
||||||
* }</pre>
|
|
||||||
*
|
*
|
||||||
* except that the action is performed atomically.
|
* except that the action is performed atomically.
|
||||||
*
|
*
|
||||||
@ -147,18 +155,19 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
* @throws IllegalArgumentException if some property of the specified key
|
* @throws IllegalArgumentException if some property of the specified key
|
||||||
* or value prevents it from being stored in this map
|
* or value prevents it from being stored in this map
|
||||||
*/
|
*/
|
||||||
V putIfAbsent(K key, V value);
|
V putIfAbsent(K key, V value);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes the entry for a key only if currently mapped to a given value.
|
* Removes the entry for a key only if currently mapped to a given value.
|
||||||
* This is equivalent to
|
* This is equivalent to, for this {@code map}:
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* if (map.containsKey(key) && Objects.equals(map.get(key), value)) {
|
* if (map.containsKey(key)
|
||||||
|
* && Objects.equals(map.get(key), value)) {
|
||||||
* map.remove(key);
|
* map.remove(key);
|
||||||
* return true;
|
* return true;
|
||||||
* } else
|
* } else {
|
||||||
* return false;
|
* return false;
|
||||||
* }</pre>
|
* }}</pre>
|
||||||
*
|
*
|
||||||
* except that the action is performed atomically.
|
* except that the action is performed atomically.
|
||||||
*
|
*
|
||||||
@ -181,14 +190,15 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Replaces the entry for a key only if currently mapped to a given value.
|
* Replaces the entry for a key only if currently mapped to a given value.
|
||||||
* This is equivalent to
|
* This is equivalent to, for this {@code map}:
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* if (map.containsKey(key) && Objects.equals(map.get(key), oldValue)) {
|
* if (map.containsKey(key)
|
||||||
|
* && Objects.equals(map.get(key), oldValue)) {
|
||||||
* map.put(key, newValue);
|
* map.put(key, newValue);
|
||||||
* return true;
|
* return true;
|
||||||
* } else
|
* } else {
|
||||||
* return false;
|
* return false;
|
||||||
* }</pre>
|
* }}</pre>
|
||||||
*
|
*
|
||||||
* except that the action is performed atomically.
|
* except that the action is performed atomically.
|
||||||
*
|
*
|
||||||
@ -212,13 +222,12 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Replaces the entry for a key only if currently mapped to some value.
|
* Replaces the entry for a key only if currently mapped to some value.
|
||||||
* This is equivalent to
|
* This is equivalent to, for this {@code map}:
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* if (map.containsKey(key)) {
|
* if (map.containsKey(key))
|
||||||
* return map.put(key, value);
|
* return map.put(key, value);
|
||||||
* } else
|
* else
|
||||||
* return null;
|
* return null;}</pre>
|
||||||
* }</pre>
|
|
||||||
*
|
*
|
||||||
* except that the action is performed atomically.
|
* except that the action is performed atomically.
|
||||||
*
|
*
|
||||||
@ -249,12 +258,14 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
* @implSpec
|
* @implSpec
|
||||||
* <p>The default implementation is equivalent to, for this {@code map}:
|
* <p>The default implementation is equivalent to, for this {@code map}:
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* for ((Map.Entry<K, V> entry : map.entrySet())
|
* for (Map.Entry<K,V> entry : map.entrySet()) {
|
||||||
* do {
|
* K k;
|
||||||
* K k = entry.getKey();
|
* V v;
|
||||||
* V v = entry.getValue();
|
* do {
|
||||||
* } while(!replace(k, v, function.apply(k, v)));
|
* k = entry.getKey();
|
||||||
* }</pre>
|
* v = entry.getValue();
|
||||||
|
* } while (!map.replace(k, v, function.apply(k, v)));
|
||||||
|
* }}</pre>
|
||||||
*
|
*
|
||||||
* The default implementation may retry these steps when multiple
|
* The default implementation may retry these steps when multiple
|
||||||
* threads attempt updates including potentially calling the function
|
* threads attempt updates including potentially calling the function
|
||||||
@ -275,7 +286,7 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
default void replaceAll(BiFunction<? super K, ? super V, ? extends V> function) {
|
default void replaceAll(BiFunction<? super K, ? super V, ? extends V> function) {
|
||||||
Objects.requireNonNull(function);
|
Objects.requireNonNull(function);
|
||||||
forEach((k,v) -> {
|
forEach((k,v) -> {
|
||||||
while(!replace(k, v, function.apply(k, v))) {
|
while (!replace(k, v, function.apply(k, v))) {
|
||||||
// v changed or k is gone
|
// v changed or k is gone
|
||||||
if ( (v = get(k)) == null) {
|
if ( (v = get(k)) == null) {
|
||||||
// k is no longer in the map.
|
// k is no longer in the map.
|
||||||
@ -295,11 +306,10 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
*
|
*
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* if (map.get(key) == null) {
|
* if (map.get(key) == null) {
|
||||||
* V newValue = mappingFunction.apply(key);
|
* V newValue = mappingFunction.apply(key);
|
||||||
* if (newValue != null)
|
* if (newValue != null)
|
||||||
* return map.putIfAbsent(key, newValue);
|
* return map.putIfAbsent(key, newValue);
|
||||||
* }
|
* }}</pre>
|
||||||
* }</pre>
|
|
||||||
*
|
*
|
||||||
* The default implementation may retry these steps when multiple
|
* The default implementation may retry these steps when multiple
|
||||||
* threads attempt updates including potentially calling the mapping
|
* threads attempt updates including potentially calling the mapping
|
||||||
@ -331,18 +341,17 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
* @implSpec
|
* @implSpec
|
||||||
* The default implementation is equivalent to performing the following
|
* The default implementation is equivalent to performing the following
|
||||||
* steps for this {@code map}, then returning the current value or
|
* steps for this {@code map}, then returning the current value or
|
||||||
* {@code null} if now absent. :
|
* {@code null} if now absent:
|
||||||
*
|
*
|
||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* if (map.get(key) != null) {
|
* if (map.get(key) != null) {
|
||||||
* V oldValue = map.get(key);
|
* V oldValue = map.get(key);
|
||||||
* V newValue = remappingFunction.apply(key, oldValue);
|
* V newValue = remappingFunction.apply(key, oldValue);
|
||||||
* if (newValue != null)
|
* if (newValue != null)
|
||||||
* map.replace(key, oldValue, newValue);
|
* map.replace(key, oldValue, newValue);
|
||||||
* else
|
* else
|
||||||
* map.remove(key, oldValue);
|
* map.remove(key, oldValue);
|
||||||
* }
|
* }}</pre>
|
||||||
* }</pre>
|
|
||||||
*
|
*
|
||||||
* The default implementation may retry these steps when multiple threads
|
* The default implementation may retry these steps when multiple threads
|
||||||
* attempt updates including potentially calling the remapping function
|
* attempt updates including potentially calling the remapping function
|
||||||
@ -363,13 +372,13 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
BiFunction<? super K, ? super V, ? extends V> remappingFunction) {
|
BiFunction<? super K, ? super V, ? extends V> remappingFunction) {
|
||||||
Objects.requireNonNull(remappingFunction);
|
Objects.requireNonNull(remappingFunction);
|
||||||
V oldValue;
|
V oldValue;
|
||||||
while((oldValue = get(key)) != null) {
|
while ((oldValue = get(key)) != null) {
|
||||||
V newValue = remappingFunction.apply(key, oldValue);
|
V newValue = remappingFunction.apply(key, oldValue);
|
||||||
if (newValue != null) {
|
if (newValue != null) {
|
||||||
if (replace(key, oldValue, newValue))
|
if (replace(key, oldValue, newValue))
|
||||||
return newValue;
|
return newValue;
|
||||||
} else if (remove(key, oldValue))
|
} else if (remove(key, oldValue))
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return oldValue;
|
return oldValue;
|
||||||
}
|
}
|
||||||
@ -386,17 +395,16 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
* V oldValue = map.get(key);
|
* V oldValue = map.get(key);
|
||||||
* V newValue = remappingFunction.apply(key, oldValue);
|
* V newValue = remappingFunction.apply(key, oldValue);
|
||||||
* if (oldValue != null ) {
|
* if (oldValue != null ) {
|
||||||
* if (newValue != null)
|
* if (newValue != null)
|
||||||
* map.replace(key, oldValue, newValue);
|
* map.replace(key, oldValue, newValue);
|
||||||
* else
|
* else
|
||||||
* map.remove(key, oldValue);
|
* map.remove(key, oldValue);
|
||||||
* } else {
|
* } else {
|
||||||
* if (newValue != null)
|
* if (newValue != null)
|
||||||
* map.putIfAbsent(key, newValue);
|
* map.putIfAbsent(key, newValue);
|
||||||
* else
|
* else
|
||||||
* return null;
|
* return null;
|
||||||
* }
|
* }}</pre>
|
||||||
* }</pre>
|
|
||||||
*
|
*
|
||||||
* The default implementation may retry these steps when multiple
|
* The default implementation may retry these steps when multiple
|
||||||
* threads attempt updates including potentially calling the remapping
|
* threads attempt updates including potentially calling the remapping
|
||||||
@ -417,7 +425,7 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
BiFunction<? super K, ? super V, ? extends V> remappingFunction) {
|
BiFunction<? super K, ? super V, ? extends V> remappingFunction) {
|
||||||
Objects.requireNonNull(remappingFunction);
|
Objects.requireNonNull(remappingFunction);
|
||||||
V oldValue = get(key);
|
V oldValue = get(key);
|
||||||
for(;;) {
|
for (;;) {
|
||||||
V newValue = remappingFunction.apply(key, oldValue);
|
V newValue = remappingFunction.apply(key, oldValue);
|
||||||
if (newValue == null) {
|
if (newValue == null) {
|
||||||
// delete mapping
|
// delete mapping
|
||||||
@ -458,7 +466,6 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*
|
*
|
||||||
@ -470,12 +477,11 @@ public interface ConcurrentMap<K, V> extends Map<K, V> {
|
|||||||
* <pre> {@code
|
* <pre> {@code
|
||||||
* V oldValue = map.get(key);
|
* V oldValue = map.get(key);
|
||||||
* V newValue = (oldValue == null) ? value :
|
* V newValue = (oldValue == null) ? value :
|
||||||
* remappingFunction.apply(oldValue, value);
|
* remappingFunction.apply(oldValue, value);
|
||||||
* if (newValue == null)
|
* if (newValue == null)
|
||||||
* map.remove(key);
|
* map.remove(key);
|
||||||
* else
|
* else
|
||||||
* map.put(key, newValue);
|
* map.put(key, newValue);}</pre>
|
||||||
* }</pre>
|
|
||||||
*
|
*
|
||||||
* <p>The default implementation may retry these steps when multiple
|
* <p>The default implementation may retry these steps when multiple
|
||||||
* threads attempt updates including potentially calling the remapping
|
* threads attempt updates including potentially calling the remapping
|
||||||
|
@ -58,6 +58,7 @@ import java.util.function.BiFunction;
|
|||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.BiConsumer;
|
import java.util.function.BiConsumer;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
|
import java.util.function.Predicate;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A scalable concurrent {@link ConcurrentNavigableMap} implementation.
|
* A scalable concurrent {@link ConcurrentNavigableMap} implementation.
|
||||||
@ -2492,6 +2493,22 @@ public class ConcurrentSkipListMap<K,V> extends AbstractMap<K,V>
|
|||||||
else
|
else
|
||||||
return (Spliterator<E>)((SubMap<?,E>)m).valueIterator();
|
return (Spliterator<E>)((SubMap<?,E>)m).valueIterator();
|
||||||
}
|
}
|
||||||
|
public boolean removeIf(Predicate<? super E> filter) {
|
||||||
|
if (filter == null) throw new NullPointerException();
|
||||||
|
if (m instanceof ConcurrentSkipListMap)
|
||||||
|
return ((ConcurrentSkipListMap<?,E>)m).removeValueIf(filter);
|
||||||
|
// else use iterator
|
||||||
|
@SuppressWarnings("unchecked") Iterator<Map.Entry<Object,E>> it =
|
||||||
|
((SubMap<Object,E>)m).entryIterator();
|
||||||
|
boolean removed = false;
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Map.Entry<Object,E> e = it.next();
|
||||||
|
E v = e.getValue();
|
||||||
|
if (filter.test(v) && m.remove(e.getKey(), v))
|
||||||
|
removed = true;
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static final class EntrySet<K1,V1> extends AbstractSet<Map.Entry<K1,V1>> {
|
static final class EntrySet<K1,V1> extends AbstractSet<Map.Entry<K1,V1>> {
|
||||||
@ -2554,6 +2571,20 @@ public class ConcurrentSkipListMap<K,V> extends AbstractMap<K,V>
|
|||||||
return (Spliterator<Map.Entry<K1,V1>>)
|
return (Spliterator<Map.Entry<K1,V1>>)
|
||||||
((SubMap<K1,V1>)m).entryIterator();
|
((SubMap<K1,V1>)m).entryIterator();
|
||||||
}
|
}
|
||||||
|
public boolean removeIf(Predicate<? super Entry<K1, V1>> filter) {
|
||||||
|
if (filter == null) throw new NullPointerException();
|
||||||
|
if (m instanceof ConcurrentSkipListMap)
|
||||||
|
return ((ConcurrentSkipListMap<K1,V1>)m).removeEntryIf(filter);
|
||||||
|
// else use iterator
|
||||||
|
Iterator<Map.Entry<K1,V1>> it = ((SubMap<K1,V1>)m).entryIterator();
|
||||||
|
boolean removed = false;
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Map.Entry<K1,V1> e = it.next();
|
||||||
|
if (filter.test(e) && m.remove(e.getKey(), e.getValue()))
|
||||||
|
removed = true;
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -3266,6 +3297,41 @@ public class ConcurrentSkipListMap<K,V> extends AbstractMap<K,V>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper method for EntrySet.removeIf
|
||||||
|
*/
|
||||||
|
boolean removeEntryIf(Predicate<? super Entry<K, V>> function) {
|
||||||
|
if (function == null) throw new NullPointerException();
|
||||||
|
boolean removed = false;
|
||||||
|
for (Node<K,V> n = findFirst(); n != null; n = n.next) {
|
||||||
|
V v;
|
||||||
|
if ((v = n.getValidValue()) != null) {
|
||||||
|
K k = n.key;
|
||||||
|
Map.Entry<K,V> e = new AbstractMap.SimpleImmutableEntry<>(k, v);
|
||||||
|
if (function.test(e) && remove(k, v))
|
||||||
|
removed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper method for Values.removeIf
|
||||||
|
*/
|
||||||
|
boolean removeValueIf(Predicate<? super V> function) {
|
||||||
|
if (function == null) throw new NullPointerException();
|
||||||
|
boolean removed = false;
|
||||||
|
for (Node<K,V> n = findFirst(); n != null; n = n.next) {
|
||||||
|
V v;
|
||||||
|
if ((v = n.getValidValue()) != null) {
|
||||||
|
K k = n.key;
|
||||||
|
if (function.test(v) && remove(k, v))
|
||||||
|
removed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return removed;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Base class providing common structure for Spliterators.
|
* Base class providing common structure for Spliterators.
|
||||||
* (Although not all that much common functionality; as usual for
|
* (Although not all that much common functionality; as usual for
|
||||||
|
@ -1522,17 +1522,20 @@ public final class Subject implements java.io.Serializable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public int size() {
|
public int size() {
|
||||||
return set.size();
|
return set.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Iterator<T> iterator() {
|
public Iterator<T> iterator() {
|
||||||
return set.iterator();
|
return set.iterator();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public boolean add(T o) {
|
public boolean add(T o) {
|
||||||
|
|
||||||
if (!o.getClass().isAssignableFrom(c)) {
|
if (!c.isAssignableFrom(o.getClass())) {
|
||||||
MessageFormat form = new MessageFormat(ResourcesMgr.getString
|
MessageFormat form = new MessageFormat(ResourcesMgr.getString
|
||||||
("attempting.to.add.an.object.which.is.not.an.instance.of.class"));
|
("attempting.to.add.an.object.which.is.not.an.instance.of.class"));
|
||||||
Object[] source = {c.toString()};
|
Object[] source = {c.toString()};
|
||||||
|
@ -67,10 +67,6 @@ import java.security.*;
|
|||||||
* in RFC 5280. The ValidationAlgorithm attribute notes the
|
* in RFC 5280. The ValidationAlgorithm attribute notes the
|
||||||
* specification that this provider implements.
|
* specification that this provider implements.
|
||||||
*
|
*
|
||||||
* - LDAP is the CertStore type for LDAP repositories. The
|
|
||||||
* LDAPSchema attribute notes the specification defining the
|
|
||||||
* schema that this provider uses to find certificates and CRLs.
|
|
||||||
*
|
|
||||||
* - JavaPolicy is the default file-based Policy type.
|
* - JavaPolicy is the default file-based Policy type.
|
||||||
*
|
*
|
||||||
* - JavaLoginConfig is the default file-based LoginModule Configuration type.
|
* - JavaLoginConfig is the default file-based LoginModule Configuration type.
|
||||||
@ -275,9 +271,6 @@ final class SunEntries {
|
|||||||
/*
|
/*
|
||||||
* CertStores
|
* CertStores
|
||||||
*/
|
*/
|
||||||
map.put("CertStore.LDAP",
|
|
||||||
"sun.security.provider.certpath.ldap.LDAPCertStore");
|
|
||||||
map.put("CertStore.LDAP LDAPSchema", "RFC2587");
|
|
||||||
map.put("CertStore.Collection",
|
map.put("CertStore.Collection",
|
||||||
"sun.security.provider.certpath.CollectionCertStore");
|
"sun.security.provider.certpath.CollectionCertStore");
|
||||||
map.put("CertStore.com.sun.security.IndexedCollection",
|
map.put("CertStore.com.sun.security.IndexedCollection",
|
||||||
@ -310,7 +303,6 @@ final class SunEntries {
|
|||||||
map.put("KeyStore.JKS ImplementedIn", "Software");
|
map.put("KeyStore.JKS ImplementedIn", "Software");
|
||||||
map.put("CertPathValidator.PKIX ImplementedIn", "Software");
|
map.put("CertPathValidator.PKIX ImplementedIn", "Software");
|
||||||
map.put("CertPathBuilder.PKIX ImplementedIn", "Software");
|
map.put("CertPathBuilder.PKIX ImplementedIn", "Software");
|
||||||
map.put("CertStore.LDAP ImplementedIn", "Software");
|
|
||||||
map.put("CertStore.Collection ImplementedIn", "Software");
|
map.put("CertStore.Collection ImplementedIn", "Software");
|
||||||
map.put("CertStore.com.sun.security.IndexedCollection ImplementedIn",
|
map.put("CertStore.com.sun.security.IndexedCollection ImplementedIn",
|
||||||
"Software");
|
"Software");
|
||||||
|
@ -1,148 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation. Oracle designates this
|
|
||||||
* particular file as subject to the "Classpath" exception as provided
|
|
||||||
* by Oracle in the LICENSE file that accompanied this code.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package sun.security.provider.certpath;
|
|
||||||
|
|
||||||
import java.net.URI;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.security.AccessController;
|
|
||||||
import java.security.NoSuchAlgorithmException;
|
|
||||||
import java.security.InvalidAlgorithmParameterException;
|
|
||||||
import java.security.PrivilegedActionException;
|
|
||||||
import java.security.PrivilegedExceptionAction;
|
|
||||||
import java.security.cert.CertStore;
|
|
||||||
import java.security.cert.CertStoreException;
|
|
||||||
import java.security.cert.X509CertSelector;
|
|
||||||
import java.security.cert.X509CRLSelector;
|
|
||||||
import javax.security.auth.x500.X500Principal;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import sun.security.util.Cache;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Helper used by URICertStore and others when delegating to another CertStore
|
|
||||||
* to fetch certs and CRLs.
|
|
||||||
*/
|
|
||||||
|
|
||||||
public abstract class CertStoreHelper {
|
|
||||||
|
|
||||||
private static final int NUM_TYPES = 2;
|
|
||||||
private final static Map<String,String> classMap = new HashMap<>(NUM_TYPES);
|
|
||||||
static {
|
|
||||||
classMap.put(
|
|
||||||
"LDAP",
|
|
||||||
"sun.security.provider.certpath.ldap.LDAPCertStoreHelper");
|
|
||||||
classMap.put(
|
|
||||||
"SSLServer",
|
|
||||||
"sun.security.provider.certpath.ssl.SSLServerCertStoreHelper");
|
|
||||||
};
|
|
||||||
private static Cache<String, CertStoreHelper> cache
|
|
||||||
= Cache.newSoftMemoryCache(NUM_TYPES);
|
|
||||||
|
|
||||||
public static CertStoreHelper getInstance(final String type)
|
|
||||||
throws NoSuchAlgorithmException
|
|
||||||
{
|
|
||||||
CertStoreHelper helper = cache.get(type);
|
|
||||||
if (helper != null) {
|
|
||||||
return helper;
|
|
||||||
}
|
|
||||||
final String cl = classMap.get(type);
|
|
||||||
if (cl == null) {
|
|
||||||
throw new NoSuchAlgorithmException(type + " not available");
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
helper = AccessController.doPrivileged(
|
|
||||||
new PrivilegedExceptionAction<CertStoreHelper>() {
|
|
||||||
public CertStoreHelper run() throws ClassNotFoundException {
|
|
||||||
try {
|
|
||||||
Class<?> c = Class.forName(cl, true, null);
|
|
||||||
CertStoreHelper csh
|
|
||||||
= (CertStoreHelper)c.newInstance();
|
|
||||||
cache.put(type, csh);
|
|
||||||
return csh;
|
|
||||||
} catch (InstantiationException |
|
|
||||||
IllegalAccessException e) {
|
|
||||||
throw new AssertionError(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return helper;
|
|
||||||
} catch (PrivilegedActionException e) {
|
|
||||||
throw new NoSuchAlgorithmException(type + " not available",
|
|
||||||
e.getException());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static boolean isCausedByNetworkIssue(String type, CertStoreException cse) {
|
|
||||||
switch (type) {
|
|
||||||
case "LDAP":
|
|
||||||
case "SSLServer":
|
|
||||||
try {
|
|
||||||
CertStoreHelper csh = CertStoreHelper.getInstance(type);
|
|
||||||
return csh.isCausedByNetworkIssue(cse);
|
|
||||||
} catch (NoSuchAlgorithmException nsae) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
case "URI":
|
|
||||||
Throwable t = cse.getCause();
|
|
||||||
return (t != null && t instanceof IOException);
|
|
||||||
default:
|
|
||||||
// we don't know about any other remote CertStore types
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a CertStore using the given URI as parameters.
|
|
||||||
*/
|
|
||||||
public abstract CertStore getCertStore(URI uri)
|
|
||||||
throws NoSuchAlgorithmException, InvalidAlgorithmParameterException;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Wraps an existing X509CertSelector when needing to avoid DN matching
|
|
||||||
* issues.
|
|
||||||
*/
|
|
||||||
public abstract X509CertSelector wrap(X509CertSelector selector,
|
|
||||||
X500Principal certSubject,
|
|
||||||
String dn)
|
|
||||||
throws IOException;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Wraps an existing X509CRLSelector when needing to avoid DN matching
|
|
||||||
* issues.
|
|
||||||
*/
|
|
||||||
public abstract X509CRLSelector wrap(X509CRLSelector selector,
|
|
||||||
Collection<X500Principal> certIssuers,
|
|
||||||
String dn)
|
|
||||||
throws IOException;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if the cause of the CertStoreException is a network
|
|
||||||
* related issue.
|
|
||||||
*/
|
|
||||||
public abstract boolean isCausedByNetworkIssue(CertStoreException e);
|
|
||||||
}
|
|
@ -466,6 +466,34 @@ class RevocationChecker extends PKIXRevocationChecker {
|
|||||||
stackedCerts, params.trustAnchors());
|
stackedCerts, params.trustAnchors());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static boolean isCausedByNetworkIssue(String type, CertStoreException cse) {
|
||||||
|
boolean result;
|
||||||
|
Throwable t = cse.getCause();
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case "LDAP":
|
||||||
|
if (t != null) {
|
||||||
|
// These two exception classes are inside java.naming module
|
||||||
|
String cn = t.getClass().getName();
|
||||||
|
result = (cn.equals("javax.naming.ServiceUnavailableException") ||
|
||||||
|
cn.equals("javax.naming.CommunicationException"));
|
||||||
|
} else {
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case "SSLServer":
|
||||||
|
result = (t != null && t instanceof IOException);
|
||||||
|
break;
|
||||||
|
case "URI":
|
||||||
|
result = (t != null && t instanceof IOException);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// we don't know about any other remote CertStore types
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
private void checkCRLs(X509Certificate cert, PublicKey prevKey,
|
private void checkCRLs(X509Certificate cert, PublicKey prevKey,
|
||||||
X509Certificate prevCert, boolean signFlag,
|
X509Certificate prevCert, boolean signFlag,
|
||||||
boolean allowSeparateKey,
|
boolean allowSeparateKey,
|
||||||
@ -510,7 +538,7 @@ class RevocationChecker extends PKIXRevocationChecker {
|
|||||||
"CertStoreException: " + e.getMessage());
|
"CertStoreException: " + e.getMessage());
|
||||||
}
|
}
|
||||||
if (networkFailureException == null &&
|
if (networkFailureException == null &&
|
||||||
CertStoreHelper.isCausedByNetworkIssue(store.getType(),e)) {
|
isCausedByNetworkIssue(store.getType(),e)) {
|
||||||
// save this exception, we may need to throw it later
|
// save this exception, we may need to throw it later
|
||||||
networkFailureException = new CertPathValidatorException(
|
networkFailureException = new CertPathValidatorException(
|
||||||
"Unable to determine revocation status due to " +
|
"Unable to determine revocation status due to " +
|
||||||
@ -557,8 +585,7 @@ class RevocationChecker extends PKIXRevocationChecker {
|
|||||||
} catch (CertStoreException e) {
|
} catch (CertStoreException e) {
|
||||||
if (e instanceof CertStoreTypeException) {
|
if (e instanceof CertStoreTypeException) {
|
||||||
CertStoreTypeException cste = (CertStoreTypeException)e;
|
CertStoreTypeException cste = (CertStoreTypeException)e;
|
||||||
if (CertStoreHelper.isCausedByNetworkIssue(cste.getType(),
|
if (isCausedByNetworkIssue(cste.getType(), e)) {
|
||||||
e)) {
|
|
||||||
throw new CertPathValidatorException(
|
throw new CertPathValidatorException(
|
||||||
"Unable to determine revocation status due to " +
|
"Unable to determine revocation status due to " +
|
||||||
"network error", e, null, -1,
|
"network error", e, null, -1,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2006, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,6 +42,7 @@ import java.security.cert.CertStoreParameters;
|
|||||||
import java.security.cert.CertStoreSpi;
|
import java.security.cert.CertStoreSpi;
|
||||||
import java.security.cert.CRLException;
|
import java.security.cert.CRLException;
|
||||||
import java.security.cert.CRLSelector;
|
import java.security.cert.CRLSelector;
|
||||||
|
import java.security.cert.URICertStoreParameters;
|
||||||
import java.security.cert.X509Certificate;
|
import java.security.cert.X509Certificate;
|
||||||
import java.security.cert.X509CertSelector;
|
import java.security.cert.X509CertSelector;
|
||||||
import java.security.cert.X509CRL;
|
import java.security.cert.X509CRL;
|
||||||
@ -118,9 +119,7 @@ class URICertStore extends CertStoreSpi {
|
|||||||
|
|
||||||
// true if URI is ldap
|
// true if URI is ldap
|
||||||
private boolean ldap = false;
|
private boolean ldap = false;
|
||||||
private CertStoreHelper ldapHelper;
|
|
||||||
private CertStore ldapCertStore;
|
private CertStore ldapCertStore;
|
||||||
private String ldapPath;
|
|
||||||
|
|
||||||
// Default maximum connect timeout in milliseconds (15 seconds)
|
// Default maximum connect timeout in milliseconds (15 seconds)
|
||||||
// allowed when downloading CRLs
|
// allowed when downloading CRLs
|
||||||
@ -165,13 +164,8 @@ class URICertStore extends CertStoreSpi {
|
|||||||
// if ldap URI, use an LDAPCertStore to fetch certs and CRLs
|
// if ldap URI, use an LDAPCertStore to fetch certs and CRLs
|
||||||
if (uri.getScheme().toLowerCase(Locale.ENGLISH).equals("ldap")) {
|
if (uri.getScheme().toLowerCase(Locale.ENGLISH).equals("ldap")) {
|
||||||
ldap = true;
|
ldap = true;
|
||||||
ldapHelper = CertStoreHelper.getInstance("LDAP");
|
URICertStoreParameters lparams = new URICertStoreParameters(uri);
|
||||||
ldapCertStore = ldapHelper.getCertStore(uri);
|
ldapCertStore = CertStore.getInstance("LDAP", lparams);
|
||||||
ldapPath = uri.getPath();
|
|
||||||
// strip off leading '/'
|
|
||||||
if (ldapPath.charAt(0) == '/') {
|
|
||||||
ldapPath = ldapPath.substring(1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
factory = CertificateFactory.getInstance("X.509");
|
factory = CertificateFactory.getInstance("X.509");
|
||||||
@ -246,20 +240,10 @@ class URICertStore extends CertStoreSpi {
|
|||||||
public synchronized Collection<X509Certificate> engineGetCertificates
|
public synchronized Collection<X509Certificate> engineGetCertificates
|
||||||
(CertSelector selector) throws CertStoreException {
|
(CertSelector selector) throws CertStoreException {
|
||||||
|
|
||||||
// if ldap URI we wrap the CertSelector in an LDAPCertSelector to
|
|
||||||
// avoid LDAP DN matching issues (see LDAPCertSelector for more info)
|
|
||||||
if (ldap) {
|
if (ldap) {
|
||||||
X509CertSelector xsel = (X509CertSelector) selector;
|
|
||||||
try {
|
|
||||||
xsel = ldapHelper.wrap(xsel, xsel.getSubject(), ldapPath);
|
|
||||||
} catch (IOException ioe) {
|
|
||||||
throw new CertStoreException(ioe);
|
|
||||||
}
|
|
||||||
// Fetch the certificates via LDAP. LDAPCertStore has its own
|
|
||||||
// caching mechanism, see the class description for more info.
|
// caching mechanism, see the class description for more info.
|
||||||
// Safe cast since xsel is an X509 certificate selector.
|
|
||||||
return (Collection<X509Certificate>)
|
return (Collection<X509Certificate>)
|
||||||
ldapCertStore.getCertificates(xsel);
|
ldapCertStore.getCertificates(selector);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return the Certificates for this entry. It returns the cached value
|
// Return the Certificates for this entry. It returns the cached value
|
||||||
@ -356,20 +340,11 @@ class URICertStore extends CertStoreSpi {
|
|||||||
public synchronized Collection<X509CRL> engineGetCRLs(CRLSelector selector)
|
public synchronized Collection<X509CRL> engineGetCRLs(CRLSelector selector)
|
||||||
throws CertStoreException {
|
throws CertStoreException {
|
||||||
|
|
||||||
// if ldap URI we wrap the CRLSelector in an LDAPCRLSelector to
|
|
||||||
// avoid LDAP DN matching issues (see LDAPCRLSelector for more info)
|
|
||||||
if (ldap) {
|
if (ldap) {
|
||||||
X509CRLSelector xsel = (X509CRLSelector) selector;
|
|
||||||
try {
|
|
||||||
xsel = ldapHelper.wrap(xsel, null, ldapPath);
|
|
||||||
} catch (IOException ioe) {
|
|
||||||
throw new CertStoreException(ioe);
|
|
||||||
}
|
|
||||||
// Fetch the CRLs via LDAP. LDAPCertStore has its own
|
// Fetch the CRLs via LDAP. LDAPCertStore has its own
|
||||||
// caching mechanism, see the class description for more info.
|
// caching mechanism, see the class description for more info.
|
||||||
// Safe cast since xsel is an X509 certificate selector.
|
|
||||||
try {
|
try {
|
||||||
return (Collection<X509CRL>) ldapCertStore.getCRLs(xsel);
|
return (Collection<X509CRL>) ldapCertStore.getCRLs(selector);
|
||||||
} catch (CertStoreException cse) {
|
} catch (CertStoreException cse) {
|
||||||
throw new PKIX.CertStoreTypeException("LDAP", cse);
|
throw new PKIX.CertStoreTypeException("LDAP", cse);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -153,7 +153,7 @@ public final class SSLServerCertStore extends CertStoreSpi {
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
static CertStore getInstance(URI uri)
|
public static CertStore getInstance(URI uri)
|
||||||
throws InvalidAlgorithmParameterException
|
throws InvalidAlgorithmParameterException
|
||||||
{
|
{
|
||||||
return new CS(new SSLServerCertStore(uri), null, "SSLServer", null);
|
return new CS(new SSLServerCertStore(uri), null, "SSLServer", null);
|
||||||
|
@ -1,76 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation. Oracle designates this
|
|
||||||
* particular file as subject to the "Classpath" exception as provided
|
|
||||||
* by Oracle in the LICENSE file that accompanied this code.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package sun.security.provider.certpath.ssl;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.net.URI;
|
|
||||||
import java.security.NoSuchAlgorithmException;
|
|
||||||
import java.security.InvalidAlgorithmParameterException;
|
|
||||||
import java.security.cert.CertStore;
|
|
||||||
import java.security.cert.CertStoreException;
|
|
||||||
import java.security.cert.X509CertSelector;
|
|
||||||
import java.security.cert.X509CRLSelector;
|
|
||||||
import java.util.Collection;
|
|
||||||
import javax.security.auth.x500.X500Principal;
|
|
||||||
|
|
||||||
import sun.security.provider.certpath.CertStoreHelper;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* SSL implementation of CertStoreHelper.
|
|
||||||
*/
|
|
||||||
public final class SSLServerCertStoreHelper extends CertStoreHelper {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public CertStore getCertStore(URI uri)
|
|
||||||
throws NoSuchAlgorithmException, InvalidAlgorithmParameterException
|
|
||||||
{
|
|
||||||
return SSLServerCertStore.getInstance(uri);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public X509CertSelector wrap(X509CertSelector selector,
|
|
||||||
X500Principal certSubject,
|
|
||||||
String ldapDN)
|
|
||||||
throws IOException
|
|
||||||
{
|
|
||||||
throw new UnsupportedOperationException();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public X509CRLSelector wrap(X509CRLSelector selector,
|
|
||||||
Collection<X500Principal> certIssuers,
|
|
||||||
String ldapDN)
|
|
||||||
throws IOException
|
|
||||||
{
|
|
||||||
throw new UnsupportedOperationException();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isCausedByNetworkIssue(CertStoreException e) {
|
|
||||||
Throwable t = e.getCause();
|
|
||||||
return (t != null && t instanceof IOException);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,6 +46,9 @@ import java.security.cert.CertStoreException;
|
|||||||
import java.security.cert.CRL;
|
import java.security.cert.CRL;
|
||||||
import java.security.cert.X509Certificate;
|
import java.security.cert.X509Certificate;
|
||||||
import java.security.cert.CertificateException;
|
import java.security.cert.CertificateException;
|
||||||
|
import java.security.cert.URICertStoreParameters;
|
||||||
|
|
||||||
|
|
||||||
import java.text.Collator;
|
import java.text.Collator;
|
||||||
import java.text.MessageFormat;
|
import java.text.MessageFormat;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -69,7 +72,7 @@ import sun.security.util.ObjectIdentifier;
|
|||||||
import sun.security.pkcs10.PKCS10;
|
import sun.security.pkcs10.PKCS10;
|
||||||
import sun.security.pkcs10.PKCS10Attribute;
|
import sun.security.pkcs10.PKCS10Attribute;
|
||||||
import sun.security.provider.X509Factory;
|
import sun.security.provider.X509Factory;
|
||||||
import sun.security.provider.certpath.CertStoreHelper;
|
import sun.security.provider.certpath.ssl.SSLServerCertStore;
|
||||||
import sun.security.util.Password;
|
import sun.security.util.Password;
|
||||||
import javax.crypto.KeyGenerator;
|
import javax.crypto.KeyGenerator;
|
||||||
import javax.crypto.SecretKey;
|
import javax.crypto.SecretKey;
|
||||||
@ -2208,14 +2211,10 @@ public final class Main {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else { // must be LDAP, and uri is not null
|
} else { // must be LDAP, and uri is not null
|
||||||
// Lazily load LDAPCertStoreHelper if present
|
URICertStoreParameters params =
|
||||||
CertStoreHelper helper = CertStoreHelper.getInstance("LDAP");
|
new URICertStoreParameters(uri);
|
||||||
String path = uri.getPath();
|
CertStore s = CertStore.getInstance("LDAP", params);
|
||||||
if (path.charAt(0) == '/') path = path.substring(1);
|
return s.getCRLs(new X509CRLSelector());
|
||||||
CertStore s = helper.getCertStore(uri);
|
|
||||||
X509CRLSelector sel =
|
|
||||||
helper.wrap(new X509CRLSelector(), null, path);
|
|
||||||
return s.getCRLs(sel);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2463,9 +2462,7 @@ public final class Main {
|
|||||||
out.println(rb.getString("Not.a.signed.jar.file"));
|
out.println(rb.getString("Not.a.signed.jar.file"));
|
||||||
}
|
}
|
||||||
} else if (sslserver != null) {
|
} else if (sslserver != null) {
|
||||||
// Lazily load SSLCertStoreHelper if present
|
CertStore cs = SSLServerCertStore.getInstance(new URI("https://" + sslserver));
|
||||||
CertStoreHelper helper = CertStoreHelper.getInstance("SSLServer");
|
|
||||||
CertStore cs = helper.getCertStore(new URI("https://" + sslserver));
|
|
||||||
Collection<? extends Certificate> chain;
|
Collection<? extends Certificate> chain;
|
||||||
try {
|
try {
|
||||||
chain = cs.getCertificates(null);
|
chain = cs.getCertificates(null);
|
||||||
|
@ -78,6 +78,7 @@ security.provider.tbd=sun.security.jgss.SunProvider
|
|||||||
security.provider.tbd=com.sun.security.sasl.Provider
|
security.provider.tbd=com.sun.security.sasl.Provider
|
||||||
security.provider.tbd=org.jcp.xml.dsig.internal.dom.XMLDSigRI
|
security.provider.tbd=org.jcp.xml.dsig.internal.dom.XMLDSigRI
|
||||||
security.provider.tbd=sun.security.smartcardio.SunPCSC
|
security.provider.tbd=sun.security.smartcardio.SunPCSC
|
||||||
|
security.provider.tbd=sun.security.provider.certpath.ldap.JdkLDAP
|
||||||
#ifdef windows
|
#ifdef windows
|
||||||
security.provider.tbd=sun.security.mscapi.SunMSCAPI
|
security.provider.tbd=sun.security.mscapi.SunMSCAPI
|
||||||
#endif
|
#endif
|
||||||
@ -156,7 +157,8 @@ login.configuration.provider=sun.security.provider.ConfigFile
|
|||||||
|
|
||||||
#
|
#
|
||||||
# Class to instantiate as the system Policy. This is the name of the class
|
# Class to instantiate as the system Policy. This is the name of the class
|
||||||
# that will be used as the Policy object.
|
# that will be used as the Policy object. The system class loader is used to
|
||||||
|
# locate this class.
|
||||||
#
|
#
|
||||||
policy.provider=sun.security.provider.PolicyFile
|
policy.provider=sun.security.provider.PolicyFile
|
||||||
|
|
||||||
|
@ -194,7 +194,7 @@ void InitLauncher(jboolean javaw);
|
|||||||
* For MacOSX and Windows/Unix compatibility we require these
|
* For MacOSX and Windows/Unix compatibility we require these
|
||||||
* entry points, some of them may be stubbed out on Windows/Unixes.
|
* entry points, some of them may be stubbed out on Windows/Unixes.
|
||||||
*/
|
*/
|
||||||
void PostJVMInit(JNIEnv *env, jstring mainClass, JavaVM *vm);
|
void PostJVMInit(JNIEnv *env, jclass mainClass, JavaVM *vm);
|
||||||
void ShowSplashScreen();
|
void ShowSplashScreen();
|
||||||
void RegisterThread();
|
void RegisterThread();
|
||||||
/*
|
/*
|
||||||
|
@ -1206,7 +1206,7 @@ ZIP_GetEntry2(jzfile *zip, char *name, jint ulen, jboolean addSlash)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Slash is already there? */
|
/* Slash is already there? */
|
||||||
if (name[ulen-1] == '/') {
|
if (ulen > 0 && name[ulen - 1] == '/') {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2014 Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -938,7 +938,7 @@ JVMInit(InvocationFunctions* ifn, jlong threadStackSize,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
PostJVMInit(JNIEnv *env, jstring mainClass, JavaVM *vm)
|
PostJVMInit(JNIEnv *env, jclass mainClass, JavaVM *vm)
|
||||||
{
|
{
|
||||||
// stubbed out for windows and *nixes.
|
// stubbed out for windows and *nixes.
|
||||||
}
|
}
|
||||||
|
@ -970,7 +970,7 @@ JVMInit(InvocationFunctions* ifn, jlong threadStackSize,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
PostJVMInit(JNIEnv *env, jstring mainClass, JavaVM *vm)
|
PostJVMInit(JNIEnv *env, jclass mainClass, JavaVM *vm)
|
||||||
{
|
{
|
||||||
// stubbed out for windows and *nixes.
|
// stubbed out for windows and *nixes.
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -25,14 +25,18 @@
|
|||||||
|
|
||||||
package com.apple.eawt;
|
package com.apple.eawt;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.Image;
|
||||||
import java.awt.peer.*;
|
import java.awt.Point;
|
||||||
|
import java.awt.PopupMenu;
|
||||||
|
import java.awt.Toolkit;
|
||||||
|
import java.awt.Window;
|
||||||
import java.beans.Beans;
|
import java.beans.Beans;
|
||||||
|
|
||||||
import javax.swing.JMenuBar;
|
import javax.swing.JMenuBar;
|
||||||
|
|
||||||
import sun.lwawt.*;
|
import sun.awt.AWTAccessor;
|
||||||
import sun.lwawt.macosx.*;
|
import sun.lwawt.LWWindowPeer;
|
||||||
|
import sun.lwawt.macosx.CPlatformWindow;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The <code>Application</code> class allows you to integrate your Java application with the native Mac OS X environment.
|
* The <code>Application</code> class allows you to integrate your Java application with the native Mac OS X environment.
|
||||||
@ -385,10 +389,8 @@ public class Application {
|
|||||||
*
|
*
|
||||||
* @since Java for Mac OS X 10.7 Update 1
|
* @since Java for Mac OS X 10.7 Update 1
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void requestToggleFullScreen(final Window window) {
|
public void requestToggleFullScreen(final Window window) {
|
||||||
final ComponentPeer peer = window.getPeer();
|
final Object peer = AWTAccessor.getComponentAccessor().getPeer(window);
|
||||||
|
|
||||||
if (!(peer instanceof LWWindowPeer)) return;
|
if (!(peer instanceof LWWindowPeer)) return;
|
||||||
Object platformWindow = ((LWWindowPeer) peer).getPlatformWindow();
|
Object platformWindow = ((LWWindowPeer) peer).getPlatformWindow();
|
||||||
if (!(platformWindow instanceof CPlatformWindow)) return;
|
if (!(platformWindow instanceof CPlatformWindow)) return;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -28,6 +28,7 @@ package com.apple.eawt;
|
|||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.lang.reflect.*;
|
import java.lang.reflect.*;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.lwawt.macosx.*;
|
import sun.lwawt.macosx.*;
|
||||||
import sun.lwawt.macosx.CImage.Creator;
|
import sun.lwawt.macosx.CImage.Creator;
|
||||||
|
|
||||||
@ -41,7 +42,6 @@ class _AppDockIconHandler {
|
|||||||
|
|
||||||
_AppDockIconHandler() { }
|
_AppDockIconHandler() { }
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setDockMenu(final PopupMenu menu) {
|
public void setDockMenu(final PopupMenu menu) {
|
||||||
fDockMenu = menu;
|
fDockMenu = menu;
|
||||||
|
|
||||||
@ -61,8 +61,8 @@ class _AppDockIconHandler {
|
|||||||
|
|
||||||
// instantiate the menu peer and set the native fDockMenu ivar
|
// instantiate the menu peer and set the native fDockMenu ivar
|
||||||
menu.addNotify();
|
menu.addNotify();
|
||||||
final long nsMenuPtr = ((CMenu)fDockMenu.getPeer()).getNativeMenu();
|
CMenu peer = AWTAccessor.getMenuComponentAccessor().getPeer(fDockMenu);
|
||||||
nativeSetDockMenu(nsMenuPtr);
|
nativeSetDockMenu(peer.getNativeMenu());
|
||||||
}
|
}
|
||||||
|
|
||||||
public PopupMenu getDockMenu() {
|
public PopupMenu getDockMenu() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -32,6 +32,7 @@ import javax.swing.*;
|
|||||||
import javax.swing.plaf.MenuBarUI;
|
import javax.swing.plaf.MenuBarUI;
|
||||||
|
|
||||||
import com.apple.laf.ScreenMenuBar;
|
import com.apple.laf.ScreenMenuBar;
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.lwawt.macosx.CMenuBar;
|
import sun.lwawt.macosx.CMenuBar;
|
||||||
|
|
||||||
import com.apple.laf.AquaMenuBarUI;
|
import com.apple.laf.AquaMenuBarUI;
|
||||||
@ -49,7 +50,10 @@ class _AppMenuBarHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// callback from the native delegate -init function
|
// callback from the native delegate -init function
|
||||||
private static void initMenuStates(final boolean aboutMenuItemVisible, final boolean aboutMenuItemEnabled, final boolean prefsMenuItemVisible, final boolean prefsMenuItemEnabled) {
|
private static void initMenuStates(final boolean aboutMenuItemVisible,
|
||||||
|
final boolean aboutMenuItemEnabled,
|
||||||
|
final boolean prefsMenuItemVisible,
|
||||||
|
final boolean prefsMenuItemEnabled) {
|
||||||
synchronized (instance) {
|
synchronized (instance) {
|
||||||
instance.aboutMenuItemVisible = aboutMenuItemVisible;
|
instance.aboutMenuItemVisible = aboutMenuItemVisible;
|
||||||
instance.aboutMenuItemEnabled = aboutMenuItemEnabled;
|
instance.aboutMenuItemEnabled = aboutMenuItemEnabled;
|
||||||
@ -92,7 +96,6 @@ class _AppMenuBarHandler {
|
|||||||
return (frame.getExtendedState() & Frame.ICONIFIED) != 0;
|
return (frame.getExtendedState() & Frame.ICONIFIED) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
static void installDefaultMenuBar(final JMenuBar menuBar) {
|
static void installDefaultMenuBar(final JMenuBar menuBar) {
|
||||||
if (menuBar == null) {
|
if (menuBar == null) {
|
||||||
// intentionally clearing the default menu
|
// intentionally clearing the default menu
|
||||||
@ -114,7 +117,7 @@ class _AppMenuBarHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
screenMenuBar.addNotify();
|
screenMenuBar.addNotify();
|
||||||
final MenuComponentPeer peer = screenMenuBar.getPeer();
|
final Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(screenMenuBar);
|
||||||
if (!(peer instanceof CMenuBar)) {
|
if (!(peer instanceof CMenuBar)) {
|
||||||
// such a thing should not be possible
|
// such a thing should not be possible
|
||||||
throw new IllegalStateException("Unable to determine native menu bar from provided JMenuBar");
|
throw new IllegalStateException("Unable to determine native menu bar from provided JMenuBar");
|
||||||
|
@ -151,20 +151,6 @@ public class AquaComboBoxUI extends BasicComboBoxUI implements Sizeable {
|
|||||||
editor.getDocument().addDocumentListener(this);
|
editor.getDocument().addDocumentListener(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void focusGained(final FocusEvent e) {
|
|
||||||
if (arrowButton != null) {
|
|
||||||
arrowButton.repaint();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void focusLost(final FocusEvent e) {
|
|
||||||
if (arrowButton != null) {
|
|
||||||
arrowButton.repaint();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void changedUpdate(final DocumentEvent e) {
|
public void changedUpdate(final DocumentEvent e) {
|
||||||
editorTextChanged();
|
editorTextChanged();
|
||||||
@ -252,6 +238,16 @@ public class AquaComboBoxUI extends BasicComboBoxUI implements Sizeable {
|
|||||||
*/
|
*/
|
||||||
protected FocusListener createFocusListener() {
|
protected FocusListener createFocusListener() {
|
||||||
return new BasicComboBoxUI.FocusHandler() {
|
return new BasicComboBoxUI.FocusHandler() {
|
||||||
|
@Override
|
||||||
|
public void focusGained(FocusEvent e) {
|
||||||
|
super.focusGained(e);
|
||||||
|
|
||||||
|
if (arrowButton != null) {
|
||||||
|
arrowButton.repaint();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void focusLost(final FocusEvent e) {
|
public void focusLost(final FocusEvent e) {
|
||||||
hasFocus = false;
|
hasFocus = false;
|
||||||
if (!e.isTemporary()) {
|
if (!e.isTemporary()) {
|
||||||
@ -264,6 +260,10 @@ public class AquaComboBoxUI extends BasicComboBoxUI implements Sizeable {
|
|||||||
if (ac != null) {
|
if (ac != null) {
|
||||||
ac.firePropertyChange(AccessibleContext.ACCESSIBLE_STATE_PROPERTY, AccessibleState.FOCUSED, null);
|
ac.firePropertyChange(AccessibleContext.ACCESSIBLE_STATE_PROPERTY, AccessibleState.FOCUSED, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (arrowButton != null) {
|
||||||
|
arrowButton.repaint();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -438,6 +438,7 @@ public class AquaComboBoxUI extends BasicComboBoxUI implements Sizeable {
|
|||||||
if (editor != null) {
|
if (editor != null) {
|
||||||
final Rectangle editorRect = rectangleForCurrentValue();
|
final Rectangle editorRect = rectangleForCurrentValue();
|
||||||
editorRect.width += 4;
|
editorRect.width += 4;
|
||||||
|
editorRect.height += 1;
|
||||||
editor.setBounds(editorRect);
|
editor.setBounds(editorRect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -124,7 +124,7 @@ public class AquaTextFieldBorder extends AquaBorder {
|
|||||||
|
|
||||||
public Insets getBorderInsets(final Component c) {
|
public Insets getBorderInsets(final Component c) {
|
||||||
if (!(c instanceof JTextComponent) || c.isOpaque()) return new InsetsUIResource(3, 7, 3, 7);
|
if (!(c instanceof JTextComponent) || c.isOpaque()) return new InsetsUIResource(3, 7, 3, 7);
|
||||||
return new InsetsUIResource(6, 7, 6, 7);
|
return new InsetsUIResource(5, 5, 5, 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static State getStateFor(final JTextComponent jc) {
|
protected static State getStateFor(final JTextComponent jc) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,11 +27,11 @@ package com.apple.laf;
|
|||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.awt.peer.MenuComponentPeer;
|
|
||||||
import java.util.Hashtable;
|
import java.util.Hashtable;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.SunToolkit;
|
import sun.awt.SunToolkit;
|
||||||
import sun.lwawt.LWToolkit;
|
import sun.lwawt.LWToolkit;
|
||||||
import sun.lwawt.macosx.*;
|
import sun.lwawt.macosx.*;
|
||||||
@ -212,24 +212,36 @@ final class ScreenMenu extends Menu
|
|||||||
// Send a mouseExited to the previously hilited item, if it wasn't 0.
|
// Send a mouseExited to the previously hilited item, if it wasn't 0.
|
||||||
if (target != fLastMouseEventTarget) {
|
if (target != fLastMouseEventTarget) {
|
||||||
if (fLastMouseEventTarget != null) {
|
if (fLastMouseEventTarget != null) {
|
||||||
LWToolkit.postEvent(new MouseEvent(fLastMouseEventTarget, MouseEvent.MOUSE_EXITED, when, modifiers, x - fLastTargetRect.x, y - fLastTargetRect.y, 0, false));
|
LWToolkit.postEvent(
|
||||||
|
new MouseEvent(fLastMouseEventTarget,
|
||||||
|
MouseEvent.MOUSE_EXITED, when,
|
||||||
|
modifiers, x - fLastTargetRect.x,
|
||||||
|
y - fLastTargetRect.y, 0,
|
||||||
|
false));
|
||||||
}
|
}
|
||||||
// Send a mouseEntered to the current hilited item, if it wasn't 0.
|
// Send a mouseEntered to the current hilited item, if it
|
||||||
|
// wasn't 0.
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
LWToolkit.postEvent(new MouseEvent(target, MouseEvent.MOUSE_ENTERED, when, modifiers, x - targetRect.x, y - targetRect.y, 0, false));
|
LWToolkit.postEvent(
|
||||||
|
new MouseEvent(target, MouseEvent.MOUSE_ENTERED,
|
||||||
|
when, modifiers,
|
||||||
|
x - targetRect.x,
|
||||||
|
y - targetRect.y, 0, false));
|
||||||
}
|
}
|
||||||
fLastMouseEventTarget = target;
|
fLastMouseEventTarget = target;
|
||||||
fLastTargetRect = targetRect;
|
fLastTargetRect = targetRect;
|
||||||
}
|
}
|
||||||
// Post a mouse event to the current item.
|
// Post a mouse event to the current item.
|
||||||
if (target == null) return;
|
if (target == null) return;
|
||||||
LWToolkit.postEvent(new MouseEvent(target, kind, when, modifiers, x - targetRect.x, y - targetRect.y, 0, false));
|
LWToolkit.postEvent(
|
||||||
|
new MouseEvent(target, kind, when, modifiers,
|
||||||
|
x - targetRect.x, y - targetRect.y, 0,
|
||||||
|
false));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
@ -248,7 +260,8 @@ final class ScreenMenu extends Menu
|
|||||||
if (tooltipText != null) {
|
if (tooltipText != null) {
|
||||||
setToolTipText(tooltipText);
|
setToolTipText(tooltipText);
|
||||||
}
|
}
|
||||||
final MenuComponentPeer peer = getPeer();
|
final Object peer = AWTAccessor.getMenuComponentAccessor()
|
||||||
|
.getPeer(this);
|
||||||
if (peer instanceof CMenu) {
|
if (peer instanceof CMenu) {
|
||||||
final CMenu menu = (CMenu) peer;
|
final CMenu menu = (CMenu) peer;
|
||||||
final long nativeMenu = menu.getNativeMenu();
|
final long nativeMenu = menu.getNativeMenu();
|
||||||
@ -355,9 +368,8 @@ final class ScreenMenu extends Menu
|
|||||||
public void setIndeterminate(boolean indeterminate) { }
|
public void setIndeterminate(boolean indeterminate) { }
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setToolTipText(final String text) {
|
public void setToolTipText(final String text) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (!(peer instanceof CMenuItem)) return;
|
if (!(peer instanceof CMenuItem)) return;
|
||||||
|
|
||||||
final CMenuItem cmi = (CMenuItem)peer;
|
final CMenuItem cmi = (CMenuItem)peer;
|
||||||
@ -365,9 +377,8 @@ final class ScreenMenu extends Menu
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setIcon(final Icon i) {
|
public void setIcon(final Icon i) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (!(peer instanceof CMenuItem)) return;
|
if (!(peer instanceof CMenuItem)) return;
|
||||||
|
|
||||||
final CMenuItem cmi = (CMenuItem)peer;
|
final CMenuItem cmi = (CMenuItem)peer;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -25,19 +25,21 @@
|
|||||||
|
|
||||||
package com.apple.laf;
|
package com.apple.laf;
|
||||||
|
|
||||||
import sun.awt.AWTAccessor;
|
|
||||||
import sun.lwawt.macosx.CMenuBar;
|
import sun.lwawt.macosx.CMenuBar;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.lang.reflect.*;
|
|
||||||
import java.security.*;
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
|
||||||
|
import static sun.awt.AWTAccessor.*;
|
||||||
|
|
||||||
@SuppressWarnings("serial") // JDK implementation class
|
@SuppressWarnings("serial") // JDK implementation class
|
||||||
public class ScreenMenuBar extends MenuBar implements ContainerListener, ScreenMenuPropertyHandler, ComponentListener {
|
public class ScreenMenuBar extends MenuBar
|
||||||
|
implements ContainerListener, ScreenMenuPropertyHandler,
|
||||||
|
ComponentListener {
|
||||||
|
|
||||||
static boolean sJMenuBarHasHelpMenus = false; //$ could check by calling getHelpMenu in a try block
|
static boolean sJMenuBarHasHelpMenus = false; //$ could check by calling getHelpMenu in a try block
|
||||||
|
|
||||||
JMenuBar fSwingBar;
|
JMenuBar fSwingBar;
|
||||||
@ -246,22 +248,23 @@ public class ScreenMenuBar extends MenuBar implements ContainerListener, ScreenM
|
|||||||
fSubmenus.remove(menu);
|
fSubmenus.remove(menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public Menu add(final Menu m, final int index) {
|
public Menu add(final Menu m, final int index) {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (m.getParent() != null) {
|
if (m.getParent() != null) {
|
||||||
m.getParent().remove(m);
|
m.getParent().remove(m);
|
||||||
}
|
}
|
||||||
|
|
||||||
final Vector<Menu> menus = AWTAccessor.getMenuBarAccessor().getMenus(this);
|
final Vector<Menu> menus = getMenuBarAccessor().getMenus(this);
|
||||||
menus.insertElementAt(m, index);
|
menus.insertElementAt(m, index);
|
||||||
AWTAccessor.getMenuComponentAccessor().setParent(m, this);
|
final MenuComponentAccessor acc = getMenuComponentAccessor();
|
||||||
|
acc.setParent(m, this);
|
||||||
|
|
||||||
final CMenuBar peer = (CMenuBar)getPeer();
|
final CMenuBar peer = acc.getPeer(this);
|
||||||
if (peer == null) return m;
|
if (peer == null) return m;
|
||||||
|
|
||||||
peer.setNextInsertionIndex(index);
|
peer.setNextInsertionIndex(index);
|
||||||
if (m.getPeer() == null) {
|
final CMenuBar mPeer = acc.getPeer(m);
|
||||||
|
if (mPeer == null) {
|
||||||
m.addNotify();
|
m.addNotify();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,15 +27,18 @@ package com.apple.laf;
|
|||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.awt.peer.MenuComponentPeer;
|
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.plaf.ComponentUI;
|
import javax.swing.plaf.ComponentUI;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.lwawt.macosx.CMenuItem;
|
import sun.lwawt.macosx.CMenuItem;
|
||||||
|
|
||||||
@SuppressWarnings("serial") // JDK implementation class
|
@SuppressWarnings("serial") // JDK implementation class
|
||||||
final class ScreenMenuItem extends MenuItem implements ActionListener, ComponentListener, ScreenMenuPropertyHandler {
|
final class ScreenMenuItem extends MenuItem
|
||||||
|
implements ActionListener, ComponentListener,
|
||||||
|
ScreenMenuPropertyHandler {
|
||||||
|
|
||||||
ScreenMenuPropertyListener fListener;
|
ScreenMenuPropertyListener fListener;
|
||||||
JMenuItem fMenuItem;
|
JMenuItem fMenuItem;
|
||||||
|
|
||||||
@ -97,9 +100,8 @@ final class ScreenMenuItem extends MenuItem implements ActionListener, Component
|
|||||||
fMenuItem.removeComponentListener(this);
|
fMenuItem.removeComponentListener(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
static void syncLabelAndKS(MenuItem menuItem, String label, KeyStroke ks) {
|
static void syncLabelAndKS(MenuItem menuItem, String label, KeyStroke ks) {
|
||||||
final MenuComponentPeer peer = menuItem.getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(menuItem);
|
||||||
if (!(peer instanceof CMenuItem)) {
|
if (!(peer instanceof CMenuItem)) {
|
||||||
//Is it possible?
|
//Is it possible?
|
||||||
return;
|
return;
|
||||||
@ -166,18 +168,16 @@ final class ScreenMenuItem extends MenuItem implements ActionListener, Component
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setToolTipText(final String text) {
|
public void setToolTipText(final String text) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (!(peer instanceof CMenuItem)) return;
|
if (!(peer instanceof CMenuItem)) return;
|
||||||
|
|
||||||
final CMenuItem cmi = (CMenuItem)peer;
|
final CMenuItem cmi = (CMenuItem)peer;
|
||||||
cmi.setToolTipText(text);
|
cmi.setToolTipText(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setIcon(final Icon i) {
|
public void setIcon(final Icon i) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (!(peer instanceof CMenuItem)) return;
|
if (!(peer instanceof CMenuItem)) return;
|
||||||
|
|
||||||
final CMenuItem cmi = (CMenuItem)peer;
|
final CMenuItem cmi = (CMenuItem)peer;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,17 +27,20 @@ package com.apple.laf;
|
|||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.awt.peer.MenuComponentPeer;
|
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.plaf.ButtonUI;
|
import javax.swing.plaf.ButtonUI;
|
||||||
|
|
||||||
import com.apple.laf.AquaMenuItemUI.IndeterminateListener;
|
import com.apple.laf.AquaMenuItemUI.IndeterminateListener;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.lwawt.macosx.*;
|
import sun.lwawt.macosx.*;
|
||||||
|
|
||||||
@SuppressWarnings("serial") // JDK implementation class
|
@SuppressWarnings("serial") // JDK implementation class
|
||||||
final class ScreenMenuItemCheckbox extends CheckboxMenuItem implements ActionListener, ComponentListener, ScreenMenuPropertyHandler, ItemListener {
|
final class ScreenMenuItemCheckbox extends CheckboxMenuItem
|
||||||
|
implements ActionListener, ComponentListener, ScreenMenuPropertyHandler,
|
||||||
|
ItemListener {
|
||||||
|
|
||||||
JMenuItem fMenuItem;
|
JMenuItem fMenuItem;
|
||||||
MenuContainer fParent;
|
MenuContainer fParent;
|
||||||
|
|
||||||
@ -57,12 +60,12 @@ final class ScreenMenuItemCheckbox extends CheckboxMenuItem implements ActionLis
|
|||||||
}
|
}
|
||||||
|
|
||||||
ScreenMenuPropertyListener fPropertyListener;
|
ScreenMenuPropertyListener fPropertyListener;
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
|
|
||||||
// Avoid the Auto toggle behavior of AWT CheckBoxMenuItem
|
// Avoid the Auto toggle behavior of AWT CheckBoxMenuItem
|
||||||
CCheckboxMenuItem ccb = (CCheckboxMenuItem) getPeer();
|
CCheckboxMenuItem ccb = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
ccb.setAutoToggle(false);
|
ccb.setAutoToggle(false);
|
||||||
|
|
||||||
fMenuItem.addComponentListener(this);
|
fMenuItem.addComponentListener(this);
|
||||||
@ -155,17 +158,15 @@ final class ScreenMenuItemCheckbox extends CheckboxMenuItem implements ActionLis
|
|||||||
setVisible(false);
|
setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setToolTipText(final String text) {
|
public void setToolTipText(final String text) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (!(peer instanceof CMenuItem)) return;
|
if (!(peer instanceof CMenuItem)) return;
|
||||||
|
|
||||||
((CMenuItem)peer).setToolTipText(text);
|
((CMenuItem)peer).setToolTipText(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setIcon(final Icon i) {
|
public void setIcon(final Icon i) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (!(peer instanceof CMenuItem)) return;
|
if (!(peer instanceof CMenuItem)) return;
|
||||||
|
|
||||||
final CMenuItem cmi = (CMenuItem)peer;
|
final CMenuItem cmi = (CMenuItem)peer;
|
||||||
@ -208,9 +209,8 @@ final class ScreenMenuItemCheckbox extends CheckboxMenuItem implements ActionLis
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setIndeterminate(final boolean indeterminate) {
|
public void setIndeterminate(final boolean indeterminate) {
|
||||||
final MenuComponentPeer peer = getPeer();
|
Object peer = AWTAccessor.getMenuComponentAccessor().getPeer(this);
|
||||||
if (peer instanceof CCheckboxMenuItem) {
|
if (peer instanceof CCheckboxMenuItem) {
|
||||||
((CCheckboxMenuItem)peer).setIsIndeterminate(indeterminate);
|
((CCheckboxMenuItem)peer).setIsIndeterminate(indeterminate);
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,8 @@ public abstract class CGraphicsConfig extends GraphicsConfiguration
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AffineTransform getDefaultTransform() {
|
public AffineTransform getDefaultTransform() {
|
||||||
return new AffineTransform();
|
double scaleFactor = device.getScaleFactor();
|
||||||
|
return AffineTransform.getScaleInstance(scaleFactor, scaleFactor);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -206,17 +206,15 @@ public final class CGraphicsDevice extends GraphicsDevice
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
private static void enterFullScreenExclusive(Window w) {
|
private static void enterFullScreenExclusive(Window w) {
|
||||||
FullScreenCapable peer = (FullScreenCapable)w.getPeer();
|
FullScreenCapable peer = AWTAccessor.getComponentAccessor().getPeer(w);
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.enterFullScreenMode();
|
peer.enterFullScreenMode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
private static void exitFullScreenExclusive(Window w) {
|
private static void exitFullScreenExclusive(Window w) {
|
||||||
FullScreenCapable peer = (FullScreenCapable)w.getPeer();
|
FullScreenCapable peer = AWTAccessor.getComponentAccessor().getPeer(w);
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.exitFullScreenMode();
|
peer.exitFullScreenMode();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -33,13 +33,14 @@ import java.awt.Transparency;
|
|||||||
import java.awt.image.ColorModel;
|
import java.awt.image.ColorModel;
|
||||||
import java.awt.peer.ComponentPeer;
|
import java.awt.peer.ComponentPeer;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
|
import sun.awt.AWTAccessor.ComponentAccessor;
|
||||||
import sun.awt.image.SunVolatileImage;
|
import sun.awt.image.SunVolatileImage;
|
||||||
import sun.awt.image.VolatileSurfaceManager;
|
import sun.awt.image.VolatileSurfaceManager;
|
||||||
import sun.java2d.BackBufferCapsProvider;
|
import sun.java2d.BackBufferCapsProvider;
|
||||||
import sun.java2d.SurfaceData;
|
import sun.java2d.SurfaceData;
|
||||||
import static sun.java2d.opengl.OGLContext.OGLContextCaps.*;
|
import static sun.java2d.opengl.OGLContext.OGLContextCaps.*;
|
||||||
import sun.java2d.pipe.hw.ExtendedBufferCapabilities;
|
import sun.java2d.pipe.hw.ExtendedBufferCapabilities;
|
||||||
import static sun.java2d.pipe.hw.AccelSurface.*;
|
|
||||||
import static sun.java2d.pipe.hw.ExtendedBufferCapabilities.VSyncType.*;
|
import static sun.java2d.pipe.hw.ExtendedBufferCapabilities.VSyncType.*;
|
||||||
|
|
||||||
public class CGLVolatileSurfaceManager extends VolatileSurfaceManager {
|
public class CGLVolatileSurfaceManager extends VolatileSurfaceManager {
|
||||||
@ -74,11 +75,11 @@ public class CGLVolatileSurfaceManager extends VolatileSurfaceManager {
|
|||||||
* Create a pbuffer-based SurfaceData object (or init the backbuffer
|
* Create a pbuffer-based SurfaceData object (or init the backbuffer
|
||||||
* of an existing window if this is a double buffered GraphicsConfig)
|
* of an existing window if this is a double buffered GraphicsConfig)
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
protected SurfaceData initAcceleratedSurface() {
|
protected SurfaceData initAcceleratedSurface() {
|
||||||
SurfaceData sData = null;
|
SurfaceData sData = null;
|
||||||
Component comp = vImg.getComponent();
|
Component comp = vImg.getComponent();
|
||||||
final ComponentPeer peer = (comp != null) ? comp.getPeer() : null;
|
final ComponentAccessor acc = AWTAccessor.getComponentAccessor();
|
||||||
|
final ComponentPeer peer = (comp != null) ? acc.getPeer(comp) : null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
boolean createVSynced = false;
|
boolean createVSynced = false;
|
||||||
|
@ -930,8 +930,8 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
final LWWindowPeer parentPeer =
|
final LWWindowPeer parentPeer =
|
||||||
(LWWindowPeer) AWTAccessor.getComponentAccessor()
|
AWTAccessor.getComponentAccessor()
|
||||||
.getPeer(parentWindow);
|
.getPeer(parentWindow);
|
||||||
if (parentPeer == null) {
|
if (parentPeer == null) {
|
||||||
focusLog.fine("request rejected, parentPeer is null");
|
focusLog.fine("request rejected, parentPeer is null");
|
||||||
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
LWKeyboardFocusManagerPeer.removeLastFocusRequest(getTarget());
|
||||||
|
@ -33,6 +33,7 @@ import java.util.List;
|
|||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
|
||||||
import sun.awt.*;
|
import sun.awt.*;
|
||||||
|
import sun.awt.AWTAccessor.ComponentAccessor;
|
||||||
import sun.java2d.*;
|
import sun.java2d.*;
|
||||||
import sun.java2d.loops.Blit;
|
import sun.java2d.loops.Blit;
|
||||||
import sun.java2d.loops.CompositeType;
|
import sun.java2d.loops.CompositeType;
|
||||||
@ -505,7 +506,7 @@ public class LWWindowPeer
|
|||||||
@Override
|
@Override
|
||||||
public void repositionSecurityWarning() {
|
public void repositionSecurityWarning() {
|
||||||
if (warningWindow != null) {
|
if (warningWindow != null) {
|
||||||
AWTAccessor.ComponentAccessor compAccessor = AWTAccessor.getComponentAccessor();
|
ComponentAccessor compAccessor = AWTAccessor.getComponentAccessor();
|
||||||
Window target = getTarget();
|
Window target = getTarget();
|
||||||
int x = compAccessor.getX(target);
|
int x = compAccessor.getX(target);
|
||||||
int y = compAccessor.getY(target);
|
int y = compAccessor.getY(target);
|
||||||
@ -563,8 +564,7 @@ public class LWWindowPeer
|
|||||||
public void blockWindows(List<Window> windows) {
|
public void blockWindows(List<Window> windows) {
|
||||||
//TODO: LWX will probably need some collectJavaToplevels to speed this up
|
//TODO: LWX will probably need some collectJavaToplevels to speed this up
|
||||||
for (Window w : windows) {
|
for (Window w : windows) {
|
||||||
WindowPeer wp =
|
WindowPeer wp = AWTAccessor.getComponentAccessor().getPeer(w);
|
||||||
(WindowPeer) AWTAccessor.getComponentAccessor().getPeer(w);
|
|
||||||
if (wp != null) {
|
if (wp != null) {
|
||||||
wp.setModalBlocked((Dialog)getTarget(), true);
|
wp.setModalBlocked((Dialog)getTarget(), true);
|
||||||
}
|
}
|
||||||
@ -1247,7 +1247,8 @@ public class LWWindowPeer
|
|||||||
private boolean isOneOfOwnersOf(LWWindowPeer peer) {
|
private boolean isOneOfOwnersOf(LWWindowPeer peer) {
|
||||||
Window owner = (peer != null ? peer.getTarget().getOwner() : null);
|
Window owner = (peer != null ? peer.getTarget().getOwner() : null);
|
||||||
while (owner != null) {
|
while (owner != null) {
|
||||||
if ((LWWindowPeer)owner.getPeer() == this) {
|
final ComponentAccessor acc = AWTAccessor.getComponentAccessor();
|
||||||
|
if (acc.getPeer(owner) == this) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
owner = owner.getOwner();
|
owner = owner.getOwner();
|
||||||
@ -1321,8 +1322,8 @@ public class LWWindowPeer
|
|||||||
while (owner != null && !(owner instanceof Frame || owner instanceof Dialog)) {
|
while (owner != null && !(owner instanceof Frame || owner instanceof Dialog)) {
|
||||||
owner = owner.getOwner();
|
owner = owner.getOwner();
|
||||||
}
|
}
|
||||||
return owner == null ? null :
|
return owner == null ? null : AWTAccessor.getComponentAccessor()
|
||||||
(LWWindowPeer) AWTAccessor.getComponentAccessor().getPeer(owner);
|
.getPeer(owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -39,6 +39,7 @@ import javax.accessibility.*;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.dnd.*;
|
import sun.awt.dnd.*;
|
||||||
import sun.lwawt.LWComponentPeer;
|
import sun.lwawt.LWComponentPeer;
|
||||||
import sun.lwawt.LWWindowPeer;
|
import sun.lwawt.LWWindowPeer;
|
||||||
@ -88,7 +89,6 @@ public final class CDragSourceContextPeer extends SunDragSourceContextPeer {
|
|||||||
super.startDrag(dsc, cursor, dragImage, dragImageOffset);
|
super.startDrag(dsc, cursor, dragImage, dragImageOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
protected void startDrag(Transferable transferable, long[] formats, Map<Long, DataFlavor> formatMap) {
|
protected void startDrag(Transferable transferable, long[] formats, Map<Long, DataFlavor> formatMap) {
|
||||||
DragGestureEvent trigger = getTrigger();
|
DragGestureEvent trigger = getTrigger();
|
||||||
InputEvent triggerEvent = trigger.getTriggerEvent();
|
InputEvent triggerEvent = trigger.getTriggerEvent();
|
||||||
@ -135,7 +135,9 @@ public final class CDragSourceContextPeer extends SunDragSourceContextPeer {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
//It sure will be LWComponentPeer instance as rootComponent is a Window
|
//It sure will be LWComponentPeer instance as rootComponent is a Window
|
||||||
PlatformWindow platformWindow = ((LWComponentPeer)rootComponent.getPeer()).getPlatformWindow();
|
LWComponentPeer<?, ?> peer = AWTAccessor.getComponentAccessor()
|
||||||
|
.getPeer(rootComponent);
|
||||||
|
PlatformWindow platformWindow = peer.getPlatformWindow();
|
||||||
long nativeViewPtr = CPlatformWindow.getNativeViewPtr(platformWindow);
|
long nativeViewPtr = CPlatformWindow.getNativeViewPtr(platformWindow);
|
||||||
if (nativeViewPtr == 0L) throw new InvalidDnDOperationException("Unsupported platform window implementation");
|
if (nativeViewPtr == 0L) throw new InvalidDnDOperationException("Unsupported platform window implementation");
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,6 +30,7 @@ import java.awt.AWTKeyStroke;
|
|||||||
import java.awt.Point;
|
import java.awt.Point;
|
||||||
import java.awt.Toolkit;
|
import java.awt.Toolkit;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.EmbeddedFrame;
|
import sun.awt.EmbeddedFrame;
|
||||||
import sun.lwawt.LWWindowPeer;
|
import sun.lwawt.LWWindowPeer;
|
||||||
|
|
||||||
@ -46,9 +47,8 @@ public class CEmbeddedFrame extends EmbeddedFrame {
|
|||||||
show();
|
show();
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
if (getPeer() == null) {
|
if (!isDisplayable()) {
|
||||||
LWCToolkit toolkit = (LWCToolkit)Toolkit.getDefaultToolkit();
|
LWCToolkit toolkit = (LWCToolkit)Toolkit.getDefaultToolkit();
|
||||||
LWWindowPeer peer = toolkit.createEmbeddedFrame(this);
|
LWWindowPeer peer = toolkit.createEmbeddedFrame(this);
|
||||||
setPeer(peer);
|
setPeer(peer);
|
||||||
@ -61,10 +61,9 @@ public class CEmbeddedFrame extends EmbeddedFrame {
|
|||||||
|
|
||||||
public void unregisterAccelerator(AWTKeyStroke stroke) {}
|
public void unregisterAccelerator(AWTKeyStroke stroke) {}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
protected long getLayerPtr() {
|
protected long getLayerPtr() {
|
||||||
LWWindowPeer peer = (LWWindowPeer)getPeer();
|
return AWTAccessor.getComponentAccessor().<LWWindowPeer>getPeer(this)
|
||||||
return peer.getLayerPtr();
|
.getLayerPtr();
|
||||||
}
|
}
|
||||||
|
|
||||||
// -----------------------------------------------------------------------
|
// -----------------------------------------------------------------------
|
||||||
|
@ -138,17 +138,6 @@ public class CImage extends CFRetainedResource {
|
|||||||
return ((DataBufferInt)bimg.getRaster().getDataBuffer()).getData();
|
return ((DataBufferInt)bimg.getRaster().getDataBuffer()).getData();
|
||||||
}
|
}
|
||||||
|
|
||||||
public CImage createFromImageImmediately(final Image image) {
|
|
||||||
int[] buffer = imageToArray(image, false);
|
|
||||||
|
|
||||||
if (buffer == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new CImage(nativeCreateNSImageFromArray(buffer, image.getWidth(null),
|
|
||||||
image.getHeight(null)));
|
|
||||||
}
|
|
||||||
|
|
||||||
public byte[] getPlatformImageBytes(final Image image) {
|
public byte[] getPlatformImageBytes(final Image image) {
|
||||||
int[] buffer = imageToArray(image, false);
|
int[] buffer = imageToArray(image, false);
|
||||||
|
|
||||||
@ -168,20 +157,33 @@ public class CImage extends CFRetainedResource {
|
|||||||
|
|
||||||
// This is used to create a CImage from a Image
|
// This is used to create a CImage from a Image
|
||||||
public CImage createFromImage(final Image image) {
|
public CImage createFromImage(final Image image) {
|
||||||
|
return createFromImage(image, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CImage createFromImageImmediately(final Image image) {
|
||||||
|
return createFromImage(image, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
// This is used to create a CImage from a Image
|
||||||
|
private CImage createFromImage(final Image image, final boolean prepareImage) {
|
||||||
if (image instanceof MultiResolutionImage) {
|
if (image instanceof MultiResolutionImage) {
|
||||||
List<Image> resolutionVariants
|
List<Image> resolutionVariants
|
||||||
= ((MultiResolutionImage) image).getResolutionVariants();
|
= ((MultiResolutionImage) image).getResolutionVariants();
|
||||||
return createFromImages(resolutionVariants);
|
return createFromImages(resolutionVariants, prepareImage);
|
||||||
}
|
}
|
||||||
|
|
||||||
int[] buffer = imageToArray(image, true);
|
int[] buffer = imageToArray(image, prepareImage);
|
||||||
if (buffer == null) {
|
if (buffer == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return new CImage(nativeCreateNSImageFromArray(buffer, image.getWidth(null), image.getHeight(null)));
|
return new CImage(nativeCreateNSImageFromArray(buffer, image.getWidth(null), image.getHeight(null)));
|
||||||
}
|
}
|
||||||
|
|
||||||
public CImage createFromImages(List<Image> images) {
|
public CImage createFromImages(final List<Image> images) {
|
||||||
|
return createFromImages(images, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
private CImage createFromImages(final List<Image> images, final boolean prepareImage) {
|
||||||
if (images == null || images.isEmpty()) {
|
if (images == null || images.isEmpty()) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -194,8 +196,8 @@ public class CImage extends CFRetainedResource {
|
|||||||
|
|
||||||
num = 0;
|
num = 0;
|
||||||
|
|
||||||
for (Image img : images) {
|
for (final Image img : images) {
|
||||||
buffers[num] = imageToArray(img, true);
|
buffers[num] = imageToArray(img, prepareImage);
|
||||||
if (buffers[num] == null) {
|
if (buffers[num] == null) {
|
||||||
// Unable to process the image
|
// Unable to process the image
|
||||||
continue;
|
continue;
|
||||||
@ -210,9 +212,9 @@ public class CImage extends CFRetainedResource {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return new CImage(nativeCreateNSImageFromArrays(
|
return new CImage(nativeCreateNSImageFromArrays(
|
||||||
Arrays.copyOf(buffers, num),
|
Arrays.copyOf(buffers, num),
|
||||||
Arrays.copyOf(w, num),
|
Arrays.copyOf(w, num),
|
||||||
Arrays.copyOf(h, num)));
|
Arrays.copyOf(h, num)));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int getSelectorAsInt(final String fromString) {
|
static int getSelectorAsInt(final String fromString) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,9 +38,12 @@ import java.text.AttributedCharacterIterator.Attribute;
|
|||||||
import java.text.*;
|
import java.text.*;
|
||||||
import javax.swing.text.JTextComponent;
|
import javax.swing.text.JTextComponent;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.im.InputMethodAdapter;
|
import sun.awt.im.InputMethodAdapter;
|
||||||
import sun.lwawt.*;
|
import sun.lwawt.*;
|
||||||
|
|
||||||
|
import static sun.awt.AWTAccessor.ComponentAccessor;
|
||||||
|
|
||||||
public class CInputMethod extends InputMethodAdapter {
|
public class CInputMethod extends InputMethodAdapter {
|
||||||
private InputMethodContext fIMContext;
|
private InputMethodContext fIMContext;
|
||||||
private Component fAwtFocussedComponent;
|
private Component fAwtFocussedComponent;
|
||||||
@ -385,12 +388,11 @@ public class CInputMethod extends InputMethodAdapter {
|
|||||||
|
|
||||||
// java.awt.Toolkit#getNativeContainer() is not available
|
// java.awt.Toolkit#getNativeContainer() is not available
|
||||||
// from this package
|
// from this package
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
private LWComponentPeer<?, ?> getNearestNativePeer(Component comp) {
|
private LWComponentPeer<?, ?> getNearestNativePeer(Component comp) {
|
||||||
if (comp==null)
|
if (comp==null)
|
||||||
return null;
|
return null;
|
||||||
|
final ComponentAccessor acc = AWTAccessor.getComponentAccessor();
|
||||||
ComponentPeer peer = comp.getPeer();
|
ComponentPeer peer = acc.getPeer(comp);
|
||||||
if (peer==null)
|
if (peer==null)
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
@ -398,7 +400,7 @@ public class CInputMethod extends InputMethodAdapter {
|
|||||||
comp = comp.getParent();
|
comp = comp.getParent();
|
||||||
if (comp==null)
|
if (comp==null)
|
||||||
return null;
|
return null;
|
||||||
peer = comp.getPeer();
|
peer = acc.getPeer(comp);
|
||||||
if (peer==null)
|
if (peer==null)
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -29,6 +29,8 @@ import java.awt.Menu;
|
|||||||
import java.awt.MenuBar;
|
import java.awt.MenuBar;
|
||||||
import java.awt.peer.MenuBarPeer;
|
import java.awt.peer.MenuBarPeer;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
|
|
||||||
public class CMenuBar extends CMenuComponent implements MenuBarPeer {
|
public class CMenuBar extends CMenuComponent implements MenuBarPeer {
|
||||||
|
|
||||||
private int nextInsertionIndex = -1;
|
private int nextInsertionIndex = -1;
|
||||||
@ -43,9 +45,8 @@ public class CMenuBar extends CMenuComponent implements MenuBarPeer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void addHelpMenu(Menu m) {
|
public void addHelpMenu(Menu m) {
|
||||||
CMenu cMenu = (CMenu)m.getPeer();
|
CMenu cMenu = AWTAccessor.getMenuComponentAccessor().getPeer(m);
|
||||||
nativeSetHelpMenu(getModel(), cMenu.getModel());
|
nativeSetHelpMenu(getModel(), cMenu.getModel());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,12 +31,11 @@ import java.awt.event.*;
|
|||||||
import java.awt.peer.WindowPeer;
|
import java.awt.peer.WindowPeer;
|
||||||
import java.beans.*;
|
import java.beans.*;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
|
||||||
import sun.awt.*;
|
import sun.awt.*;
|
||||||
|
import sun.awt.AWTAccessor.ComponentAccessor;
|
||||||
import sun.java2d.SurfaceData;
|
import sun.java2d.SurfaceData;
|
||||||
import sun.java2d.opengl.CGLSurfaceData;
|
import sun.java2d.opengl.CGLSurfaceData;
|
||||||
import sun.lwawt.*;
|
import sun.lwawt.*;
|
||||||
@ -193,8 +192,9 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
public CPlatformWindow convertJComponentToTarget(final JRootPane p) {
|
public CPlatformWindow convertJComponentToTarget(final JRootPane p) {
|
||||||
Component root = SwingUtilities.getRoot(p);
|
Component root = SwingUtilities.getRoot(p);
|
||||||
if (root == null || (LWWindowPeer)root.getPeer() == null) return null;
|
final ComponentAccessor acc = AWTAccessor.getComponentAccessor();
|
||||||
return (CPlatformWindow)((LWWindowPeer)root.getPeer()).getPlatformWindow();
|
if (root == null || acc.getPeer(root) == null) return null;
|
||||||
|
return (CPlatformWindow)((LWWindowPeer)acc.getPeer(root)).getPlatformWindow();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -523,15 +523,15 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override // PlatformWindow
|
@Override // PlatformWindow
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void setVisible(boolean visible) {
|
public void setVisible(boolean visible) {
|
||||||
final long nsWindowPtr = getNSWindowPtr();
|
final long nsWindowPtr = getNSWindowPtr();
|
||||||
|
|
||||||
// Process parent-child relationship when hiding
|
// Process parent-child relationship when hiding
|
||||||
|
final ComponentAccessor acc = AWTAccessor.getComponentAccessor();
|
||||||
if (!visible) {
|
if (!visible) {
|
||||||
// Unparent my children
|
// Unparent my children
|
||||||
for (Window w : target.getOwnedWindows()) {
|
for (Window w : target.getOwnedWindows()) {
|
||||||
WindowPeer p = (WindowPeer)w.getPeer();
|
WindowPeer p = acc.getPeer(w);
|
||||||
if (p instanceof LWWindowPeer) {
|
if (p instanceof LWWindowPeer) {
|
||||||
CPlatformWindow pw = (CPlatformWindow)((LWWindowPeer)p).getPlatformWindow();
|
CPlatformWindow pw = (CPlatformWindow)((LWWindowPeer)p).getPlatformWindow();
|
||||||
if (pw != null && pw.isVisible()) {
|
if (pw != null && pw.isVisible()) {
|
||||||
@ -627,7 +627,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
|
|
||||||
// Add my own children to myself
|
// Add my own children to myself
|
||||||
for (Window w : target.getOwnedWindows()) {
|
for (Window w : target.getOwnedWindows()) {
|
||||||
WindowPeer p = (WindowPeer)w.getPeer();
|
final Object p = acc.getPeer(w);
|
||||||
if (p instanceof LWWindowPeer) {
|
if (p instanceof LWWindowPeer) {
|
||||||
CPlatformWindow pw = (CPlatformWindow)((LWWindowPeer)p).getPlatformWindow();
|
CPlatformWindow pw = (CPlatformWindow)((LWWindowPeer)p).getPlatformWindow();
|
||||||
if (pw != null && pw.isVisible()) {
|
if (pw != null && pw.isVisible()) {
|
||||||
@ -679,13 +679,13 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override // PlatformWindow
|
@Override // PlatformWindow
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void toFront() {
|
public void toFront() {
|
||||||
final long nsWindowPtr = getNSWindowPtr();
|
final long nsWindowPtr = getNSWindowPtr();
|
||||||
LWCToolkit lwcToolkit = (LWCToolkit) Toolkit.getDefaultToolkit();
|
LWCToolkit lwcToolkit = (LWCToolkit) Toolkit.getDefaultToolkit();
|
||||||
Window w = DefaultKeyboardFocusManager.getCurrentKeyboardFocusManager().getActiveWindow();
|
Window w = DefaultKeyboardFocusManager.getCurrentKeyboardFocusManager().getActiveWindow();
|
||||||
if( w != null && w.getPeer() != null
|
final ComponentAccessor acc = AWTAccessor.getComponentAccessor();
|
||||||
&& ((LWWindowPeer)w.getPeer()).getPeerType() == LWWindowPeer.PeerType.EMBEDDED_FRAME
|
if( w != null && acc.getPeer(w) != null
|
||||||
|
&& ((LWWindowPeer)acc.getPeer(w)).getPeerType() == LWWindowPeer.PeerType.EMBEDDED_FRAME
|
||||||
&& !lwcToolkit.isApplicationActive()) {
|
&& !lwcToolkit.isApplicationActive()) {
|
||||||
lwcToolkit.activateApplicationIgnoringOtherApps();
|
lwcToolkit.activateApplicationIgnoringOtherApps();
|
||||||
}
|
}
|
||||||
|
@ -36,6 +36,10 @@ import java.security.PrivilegedAction;
|
|||||||
import javax.print.*;
|
import javax.print.*;
|
||||||
import javax.print.attribute.PrintRequestAttributeSet;
|
import javax.print.attribute.PrintRequestAttributeSet;
|
||||||
import javax.print.attribute.HashPrintRequestAttributeSet;
|
import javax.print.attribute.HashPrintRequestAttributeSet;
|
||||||
|
import javax.print.attribute.standard.Media;
|
||||||
|
import javax.print.attribute.standard.MediaPrintableArea;
|
||||||
|
import javax.print.attribute.standard.MediaSize;
|
||||||
|
import javax.print.attribute.standard.MediaSizeName;
|
||||||
import javax.print.attribute.standard.PageRanges;
|
import javax.print.attribute.standard.PageRanges;
|
||||||
|
|
||||||
import sun.java2d.*;
|
import sun.java2d.*;
|
||||||
@ -745,4 +749,34 @@ public final class CPrinterJob extends RasterPrinterJob {
|
|||||||
protected void startPage(PageFormat arg0, Printable arg1, int arg2, boolean arg3) throws PrinterException {
|
protected void startPage(PageFormat arg0, Printable arg1, int arg2, boolean arg3) throws PrinterException {
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected MediaSize getMediaSize(Media media, PrintService service,
|
||||||
|
PageFormat page) {
|
||||||
|
if (media == null || !(media instanceof MediaSizeName)) {
|
||||||
|
return getDefaultMediaSize(page);
|
||||||
|
}
|
||||||
|
MediaSize size = MediaSize.getMediaSizeForName((MediaSizeName) media);
|
||||||
|
return size != null ? size : getDefaultMediaSize(page);
|
||||||
|
}
|
||||||
|
|
||||||
|
private MediaSize getDefaultMediaSize(PageFormat page){
|
||||||
|
final int inch = 72;
|
||||||
|
Paper paper = page.getPaper();
|
||||||
|
float width = (float) (paper.getWidth() / inch);
|
||||||
|
float height = (float) (paper.getHeight() / inch);
|
||||||
|
return new MediaSize(width, height, MediaSize.INCH);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected MediaPrintableArea getDefaultPrintableArea(PageFormat page, double w, double h) {
|
||||||
|
final float dpi = 72.0f;
|
||||||
|
Paper paper = page.getPaper();
|
||||||
|
return new MediaPrintableArea(
|
||||||
|
(float) (paper.getImageableX() / dpi),
|
||||||
|
(float) (paper.getImageableY() / dpi),
|
||||||
|
(float) (paper.getImageableWidth() / dpi),
|
||||||
|
(float) (paper.getImageableHeight() / dpi),
|
||||||
|
MediaPrintableArea.INCH);
|
||||||
|
}
|
||||||
}
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -37,6 +37,8 @@ import java.awt.peer.TrayIconPeer;
|
|||||||
import java.beans.PropertyChangeEvent;
|
import java.beans.PropertyChangeEvent;
|
||||||
import java.beans.PropertyChangeListener;
|
import java.beans.PropertyChangeListener;
|
||||||
|
|
||||||
|
import static sun.awt.AWTAccessor.*;
|
||||||
|
|
||||||
public class CTrayIcon extends CFRetainedResource implements TrayIconPeer {
|
public class CTrayIcon extends CFRetainedResource implements TrayIconPeer {
|
||||||
private TrayIcon target;
|
private TrayIcon target;
|
||||||
private PopupMenu popup;
|
private PopupMenu popup;
|
||||||
@ -68,15 +70,15 @@ public class CTrayIcon extends CFRetainedResource implements TrayIconPeer {
|
|||||||
updateImage();
|
updateImage();
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
private CPopupMenu checkAndCreatePopupPeer() {
|
private CPopupMenu checkAndCreatePopupPeer() {
|
||||||
CPopupMenu menuPeer = null;
|
CPopupMenu menuPeer = null;
|
||||||
if (popup != null) {
|
if (popup != null) {
|
||||||
try {
|
try {
|
||||||
menuPeer = (CPopupMenu)popup.getPeer();
|
final MenuComponentAccessor acc = getMenuComponentAccessor();
|
||||||
|
menuPeer = acc.getPeer(popup);
|
||||||
if (menuPeer == null) {
|
if (menuPeer == null) {
|
||||||
popup.addNotify();
|
popup.addNotify();
|
||||||
menuPeer = (CPopupMenu)popup.getPeer();
|
menuPeer = acc.getPeer(popup);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,6 +30,7 @@ import java.awt.AWTKeyStroke;
|
|||||||
import java.awt.Toolkit;
|
import java.awt.Toolkit;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.EmbeddedFrame;
|
import sun.awt.EmbeddedFrame;
|
||||||
import sun.lwawt.LWWindowPeer;
|
import sun.lwawt.LWWindowPeer;
|
||||||
|
|
||||||
@ -48,10 +49,9 @@ public class CViewEmbeddedFrame extends EmbeddedFrame {
|
|||||||
this.nsViewPtr = nsViewPtr;
|
this.nsViewPtr = nsViewPtr;
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
@Override
|
@Override
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
if (getPeer() == null) {
|
if (!isDisplayable()) {
|
||||||
LWCToolkit toolkit = (LWCToolkit) Toolkit.getDefaultToolkit();
|
LWCToolkit toolkit = (LWCToolkit) Toolkit.getDefaultToolkit();
|
||||||
setPeer(toolkit.createEmbeddedFrame(this));
|
setPeer(toolkit.createEmbeddedFrame(this));
|
||||||
}
|
}
|
||||||
@ -78,11 +78,12 @@ public class CViewEmbeddedFrame extends EmbeddedFrame {
|
|||||||
* Synthetic event delivery for focus management
|
* Synthetic event delivery for focus management
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void synthesizeWindowActivation(boolean activated) {
|
public void synthesizeWindowActivation(boolean activated) {
|
||||||
if (isActive != activated) {
|
if (isActive != activated) {
|
||||||
isActive = activated;
|
isActive = activated;
|
||||||
((LWWindowPeer)getPeer()).notifyActivation(activated, null);
|
final LWWindowPeer peer = AWTAccessor.getComponentAccessor()
|
||||||
|
.getPeer(this);
|
||||||
|
peer.notifyActivation(activated, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,13 +92,14 @@ public class CViewEmbeddedFrame extends EmbeddedFrame {
|
|||||||
* Designed to be called from the main thread
|
* Designed to be called from the main thread
|
||||||
* This method should be called once from the initialization of the SWT_AWT Bridge
|
* This method should be called once from the initialization of the SWT_AWT Bridge
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void validateWithBounds(final int x, final int y, final int width, final int height) {
|
public void validateWithBounds(final int x, final int y, final int width, final int height) {
|
||||||
try {
|
try {
|
||||||
|
final LWWindowPeer peer = AWTAccessor.getComponentAccessor()
|
||||||
|
.getPeer(this);
|
||||||
LWCToolkit.invokeAndWait(new Runnable() {
|
LWCToolkit.invokeAndWait(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
((LWWindowPeer) getPeer()).setBoundsPrivate(0, 0, width, height);
|
peer.setBoundsPrivate(0, 0, width, height);
|
||||||
validate();
|
validate();
|
||||||
setVisible(true);
|
setVisible(true);
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -293,7 +293,7 @@ public final class LWCToolkit extends LWToolkit {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected DesktopPeer createDesktopPeer(Desktop target) {
|
public DesktopPeer createDesktopPeer(Desktop target) {
|
||||||
return new CDesktopPeer();
|
return new CDesktopPeer();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -575,7 +575,8 @@ public final class LWCToolkit extends LWToolkit {
|
|||||||
|
|
||||||
final boolean[] ret = new boolean[1];
|
final boolean[] ret = new boolean[1];
|
||||||
|
|
||||||
try { invokeAndWait(new Runnable() { public void run() { synchronized(ret) {
|
try { invokeAndWait(new Runnable() { @Override
|
||||||
|
public void run() { synchronized(ret) {
|
||||||
ret[0] = a.equals(b);
|
ret[0] = a.equals(b);
|
||||||
}}}, c); } catch (Exception e) { e.printStackTrace(); }
|
}}}, c); } catch (Exception e) { e.printStackTrace(); }
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -168,13 +168,12 @@ public class Button extends Component implements Accessible {
|
|||||||
* application to change the look of the button without changing
|
* application to change the look of the button without changing
|
||||||
* its functionality.
|
* its functionality.
|
||||||
*
|
*
|
||||||
* @see java.awt.Toolkit#createButton(java.awt.Button)
|
|
||||||
* @see java.awt.Component#getToolkit()
|
* @see java.awt.Component#getToolkit()
|
||||||
*/
|
*/
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized(getTreeLock()) {
|
synchronized(getTreeLock()) {
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = getToolkit().createButton(this);
|
peer = getComponentFactory().createButton(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -58,11 +58,13 @@ public class Canvas extends Component implements Accessible {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a new Canvas given a GraphicsConfiguration object.
|
* Constructs a new Canvas given a GraphicsConfiguration object. If null is
|
||||||
|
* passed, then the default GraphicsConfiguration will be used.
|
||||||
*
|
*
|
||||||
* @param config a reference to a GraphicsConfiguration object.
|
* @param config a reference to a GraphicsConfiguration object or null
|
||||||
*
|
*
|
||||||
* @see GraphicsConfiguration
|
* @see GraphicsConfiguration
|
||||||
|
* @see Component#getGraphicsConfiguration()
|
||||||
*/
|
*/
|
||||||
public Canvas(GraphicsConfiguration config) {
|
public Canvas(GraphicsConfiguration config) {
|
||||||
this();
|
this();
|
||||||
@ -70,10 +72,9 @@ public class Canvas extends Component implements Accessible {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
void setGraphicsConfiguration(GraphicsConfiguration gc) {
|
void setGraphicsConfiguration(GraphicsConfiguration gc) {
|
||||||
synchronized(getTreeLock()) {
|
synchronized(getTreeLock()) {
|
||||||
CanvasPeer peer = (CanvasPeer)getPeer();
|
CanvasPeer peer = (CanvasPeer) this.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
gc = peer.getAppropriateGraphicsConfiguration(gc);
|
gc = peer.getAppropriateGraphicsConfiguration(gc);
|
||||||
}
|
}
|
||||||
@ -94,13 +95,12 @@ public class Canvas extends Component implements Accessible {
|
|||||||
/**
|
/**
|
||||||
* Creates the peer of the canvas. This peer allows you to change the
|
* Creates the peer of the canvas. This peer allows you to change the
|
||||||
* user interface of the canvas without changing its functionality.
|
* user interface of the canvas without changing its functionality.
|
||||||
* @see java.awt.Toolkit#createCanvas(java.awt.Canvas)
|
|
||||||
* @see java.awt.Component#getToolkit()
|
* @see java.awt.Component#getToolkit()
|
||||||
*/
|
*/
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = getToolkit().createCanvas(this);
|
peer = getComponentFactory().createCanvas(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -239,13 +239,12 @@ public class Checkbox extends Component implements ItemSelectable, Accessible {
|
|||||||
* Creates the peer of the Checkbox. The peer allows you to change the
|
* Creates the peer of the Checkbox. The peer allows you to change the
|
||||||
* look of the Checkbox without changing its functionality.
|
* look of the Checkbox without changing its functionality.
|
||||||
*
|
*
|
||||||
* @see java.awt.Toolkit#createCheckbox(java.awt.Checkbox)
|
|
||||||
* @see java.awt.Component#getToolkit()
|
* @see java.awt.Component#getToolkit()
|
||||||
*/
|
*/
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = getToolkit().createCheckbox(this);
|
peer = getComponentFactory().createCheckbox(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -155,13 +155,12 @@ public class CheckboxMenuItem extends MenuItem implements ItemSelectable, Access
|
|||||||
* change the look of the checkbox item without changing its
|
* change the look of the checkbox item without changing its
|
||||||
* functionality.
|
* functionality.
|
||||||
* Most applications do not call this method directly.
|
* Most applications do not call this method directly.
|
||||||
* @see java.awt.Toolkit#createCheckboxMenuItem(java.awt.CheckboxMenuItem)
|
|
||||||
* @see java.awt.Component#getToolkit()
|
* @see java.awt.Component#getToolkit()
|
||||||
*/
|
*/
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = Toolkit.getDefaultToolkit().createCheckboxMenuItem(this);
|
peer = getComponentFactory().createCheckboxMenuItem(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -143,13 +143,12 @@ public class Choice extends Component implements ItemSelectable, Accessible {
|
|||||||
* Creates the <code>Choice</code>'s peer. This peer allows us
|
* Creates the <code>Choice</code>'s peer. This peer allows us
|
||||||
* to change the look
|
* to change the look
|
||||||
* of the <code>Choice</code> without changing its functionality.
|
* of the <code>Choice</code> without changing its functionality.
|
||||||
* @see java.awt.Toolkit#createChoice(java.awt.Choice)
|
|
||||||
* @see java.awt.Component#getToolkit()
|
* @see java.awt.Component#getToolkit()
|
||||||
*/
|
*/
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = getToolkit().createChoice(this);
|
peer = getComponentFactory().createChoice(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -61,6 +61,7 @@ import java.security.AccessControlContext;
|
|||||||
import javax.accessibility.*;
|
import javax.accessibility.*;
|
||||||
import java.applet.Applet;
|
import java.applet.Applet;
|
||||||
|
|
||||||
|
import sun.awt.ComponentFactory;
|
||||||
import sun.security.action.GetPropertyAction;
|
import sun.security.action.GetPropertyAction;
|
||||||
import sun.awt.AppContext;
|
import sun.awt.AppContext;
|
||||||
import sun.awt.AWTAccessor;
|
import sun.awt.AWTAccessor;
|
||||||
@ -198,7 +199,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
* @see #addNotify
|
* @see #addNotify
|
||||||
* @see #removeNotify
|
* @see #removeNotify
|
||||||
*/
|
*/
|
||||||
transient ComponentPeer peer;
|
transient volatile ComponentPeer peer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The parent of the object. It may be <code>null</code>
|
* The parent of the object. It may be <code>null</code>
|
||||||
@ -924,8 +925,9 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
public Cursor getCursor(Component comp) {
|
public Cursor getCursor(Component comp) {
|
||||||
return comp.getCursor_NoClientCode();
|
return comp.getCursor_NoClientCode();
|
||||||
}
|
}
|
||||||
public ComponentPeer getPeer(Component comp) {
|
@SuppressWarnings("unchecked")
|
||||||
return comp.peer;
|
public <T extends ComponentPeer> T getPeer(Component comp) {
|
||||||
|
return (T) comp.peer;
|
||||||
}
|
}
|
||||||
public void setPeer(Component comp, ComponentPeer peer) {
|
public void setPeer(Component comp, ComponentPeer peer) {
|
||||||
comp.peer = peer;
|
comp.peer = peer;
|
||||||
@ -1068,17 +1070,6 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
return getParent_NoClientCode();
|
return getParent_NoClientCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated As of JDK version 1.1,
|
|
||||||
* programs should not directly manipulate peers;
|
|
||||||
* replaced by <code>boolean isDisplayable()</code>.
|
|
||||||
* @return the peer for this component
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public ComponentPeer getPeer() {
|
|
||||||
return peer;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Associate a <code>DropTarget</code> with this component.
|
* Associate a <code>DropTarget</code> with this component.
|
||||||
* The <code>Component</code> will receive drops only if it
|
* The <code>Component</code> will receive drops only if it
|
||||||
@ -1095,7 +1086,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
DropTarget old;
|
DropTarget old;
|
||||||
|
|
||||||
if ((old = dropTarget) != null) {
|
if ((old = dropTarget) != null) {
|
||||||
if (peer != null) dropTarget.removeNotify(peer);
|
dropTarget.removeNotify();
|
||||||
|
|
||||||
DropTarget t = dropTarget;
|
DropTarget t = dropTarget;
|
||||||
|
|
||||||
@ -1113,12 +1104,12 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
if ((dropTarget = dt) != null) {
|
if ((dropTarget = dt) != null) {
|
||||||
try {
|
try {
|
||||||
dropTarget.setComponent(this);
|
dropTarget.setComponent(this);
|
||||||
if (peer != null) dropTarget.addNotify(peer);
|
dropTarget.addNotify();
|
||||||
} catch (IllegalArgumentException iae) {
|
} catch (IllegalArgumentException iae) {
|
||||||
if (old != null) {
|
if (old != null) {
|
||||||
try {
|
try {
|
||||||
old.setComponent(this);
|
old.setComponent(this);
|
||||||
if (peer != null) dropTarget.addNotify(peer);
|
dropTarget.addNotify();
|
||||||
} catch (IllegalArgumentException iae1) {
|
} catch (IllegalArgumentException iae1) {
|
||||||
// ignore it!
|
// ignore it!
|
||||||
}
|
}
|
||||||
@ -1179,7 +1170,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
|
|
||||||
graphicsConfig = gc;
|
graphicsConfig = gc;
|
||||||
|
|
||||||
ComponentPeer peer = getPeer();
|
ComponentPeer peer = this.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
return peer.updateGraphicsData(gc);
|
return peer.updateGraphicsData(gc);
|
||||||
}
|
}
|
||||||
@ -1239,6 +1230,14 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
return Toolkit.getDefaultToolkit();
|
return Toolkit.getDefaultToolkit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final ComponentFactory getComponentFactory() {
|
||||||
|
final Toolkit toolkit = getToolkit();
|
||||||
|
if (toolkit instanceof ComponentFactory) {
|
||||||
|
return (ComponentFactory) toolkit;
|
||||||
|
}
|
||||||
|
throw new AWTError("UI components are unsupported by: " + toolkit);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determines whether this component is valid. A component is valid
|
* Determines whether this component is valid. A component is valid
|
||||||
* when it is correctly sized and positioned within its parent
|
* when it is correctly sized and positioned within its parent
|
||||||
@ -1281,7 +1280,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
* @since 1.2
|
* @since 1.2
|
||||||
*/
|
*/
|
||||||
public boolean isDisplayable() {
|
public boolean isDisplayable() {
|
||||||
return getPeer() != null;
|
return peer != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1336,7 +1335,11 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
Window win = getContainingWindow();
|
Window win = getContainingWindow();
|
||||||
if (!Toolkit.getDefaultToolkit().getMouseInfoPeer().isWindowUnderMouse(win)) {
|
Toolkit toolkit = Toolkit.getDefaultToolkit();
|
||||||
|
if (!(toolkit instanceof ComponentFactory)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if (!((ComponentFactory) toolkit).getMouseInfoPeer().isWindowUnderMouse(win)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
final boolean INCLUDE_DISABLED = true;
|
final boolean INCLUDE_DISABLED = true;
|
||||||
@ -2582,7 +2585,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
* @since 1.2
|
* @since 1.2
|
||||||
*/
|
*/
|
||||||
public boolean isOpaque() {
|
public boolean isOpaque() {
|
||||||
if (getPeer() == null) {
|
if (peer == null) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -2608,7 +2611,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
* @since 1.2
|
* @since 1.2
|
||||||
*/
|
*/
|
||||||
public boolean isLightweight() {
|
public boolean isLightweight() {
|
||||||
return getPeer() instanceof LightweightPeer;
|
return peer instanceof LightweightPeer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -3126,7 +3129,6 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
* obtained
|
* obtained
|
||||||
* @return the font metrics for <code>font</code>
|
* @return the font metrics for <code>font</code>
|
||||||
* @see #getFont
|
* @see #getFont
|
||||||
* @see #getPeer
|
|
||||||
* @see java.awt.peer.ComponentPeer#getFontMetrics(Font)
|
* @see java.awt.peer.ComponentPeer#getFontMetrics(Font)
|
||||||
* @see Toolkit#getFontMetrics(Font)
|
* @see Toolkit#getFontMetrics(Font)
|
||||||
* @since 1.0
|
* @since 1.0
|
||||||
@ -3186,7 +3188,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
|
|
||||||
if (nativeContainer == null) return;
|
if (nativeContainer == null) return;
|
||||||
|
|
||||||
ComponentPeer cPeer = nativeContainer.getPeer();
|
ComponentPeer cPeer = nativeContainer.peer;
|
||||||
|
|
||||||
if (cPeer != null) {
|
if (cPeer != null) {
|
||||||
cPeer.updateCursorImmediately();
|
cPeer.updateCursorImmediately();
|
||||||
@ -5019,7 +5021,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
if (source != null) {
|
if (source != null) {
|
||||||
Container target = source.getNativeContainer();
|
Container target = source.getNativeContainer();
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
tpeer = target.getPeer();
|
tpeer = target.peer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6972,7 +6974,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
if (peer == null) {
|
if (peer == null) {
|
||||||
// Update both the Component's peer variable and the local
|
// Update both the Component's peer variable and the local
|
||||||
// variable we use for thread safety.
|
// variable we use for thread safety.
|
||||||
this.peer = peer = getToolkit().createComponent(this);
|
this.peer = peer = getComponentFactory().createComponent(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is a lightweight component which means it won't be
|
// This is a lightweight component which means it won't be
|
||||||
@ -7022,7 +7024,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
popup.addNotify();
|
popup.addNotify();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dropTarget != null) dropTarget.addNotify(peer);
|
if (dropTarget != null) dropTarget.addNotify();
|
||||||
|
|
||||||
peerFont = getFont();
|
peerFont = getFont();
|
||||||
|
|
||||||
@ -7109,7 +7111,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
((FlipBufferStrategy)bufferStrategy).destroyBuffers();
|
((FlipBufferStrategy)bufferStrategy).destroyBuffers();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dropTarget != null) dropTarget.removeNotify(peer);
|
if (dropTarget != null) dropTarget.removeNotify();
|
||||||
|
|
||||||
// Hide peer first to stop system events such as cursor moves.
|
// Hide peer first to stop system events such as cursor moves.
|
||||||
if (visible) {
|
if (visible) {
|
||||||
@ -9851,7 +9853,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!isLightweight()) {
|
if (!isLightweight()) {
|
||||||
ComponentPeer peer = getPeer();
|
ComponentPeer peer = this.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
// The Region class has some optimizations. That's why
|
// The Region class has some optimizations. That's why
|
||||||
// we should manually check whether it's empty and
|
// we should manually check whether it's empty and
|
||||||
@ -9975,7 +9977,7 @@ public abstract class Component implements ImageObserver, MenuContainer,
|
|||||||
for (int i = indexAbove; i > -1; i--) {
|
for (int i = indexAbove; i > -1; i--) {
|
||||||
Component comp = cont.getComponent(i);
|
Component comp = cont.getComponent(i);
|
||||||
if (comp != null && comp.isDisplayable() && !comp.isLightweight()) {
|
if (comp != null && comp.isDisplayable() && !comp.isLightweight()) {
|
||||||
return comp.getPeer();
|
return comp.peer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// traversing the hierarchy up to the closest HW container;
|
// traversing the hierarchy up to the closest HW container;
|
||||||
|
@ -820,7 +820,7 @@ public class Container extends Component {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Q: Need to update NativeInLightFixer?
|
// Q: Need to update NativeInLightFixer?
|
||||||
comp.getPeer().reparent(parentPeer);
|
comp.peer.reparent(parentPeer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -840,10 +840,10 @@ public class Container extends Component {
|
|||||||
// If component is lightweight container we need to reparent all its explicit heavyweight children
|
// If component is lightweight container we need to reparent all its explicit heavyweight children
|
||||||
if (comp instanceof Container) {
|
if (comp instanceof Container) {
|
||||||
// Traverse component's tree till depth-first until encountering heavyweight component
|
// Traverse component's tree till depth-first until encountering heavyweight component
|
||||||
reparentTraverse((ContainerPeer)getPeer(), (Container)comp);
|
reparentTraverse((ContainerPeer)peer, (Container)comp);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
comp.getPeer().reparent((ContainerPeer)getPeer());
|
comp.peer.reparent((ContainerPeer) peer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4195,7 +4195,7 @@ public class Container extends Component {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (comp.isVisible()) {
|
if (comp.isVisible()) {
|
||||||
ComponentPeer peer = comp.getPeer();
|
ComponentPeer peer = comp.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.setVisible(true);
|
peer.setVisible(true);
|
||||||
}
|
}
|
||||||
@ -4217,7 +4217,7 @@ public class Container extends Component {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (comp.isVisible()) {
|
if (comp.isVisible()) {
|
||||||
ComponentPeer peer = comp.getPeer();
|
ComponentPeer peer = comp.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.setVisible(false);
|
peer.setVisible(false);
|
||||||
}
|
}
|
||||||
@ -4239,7 +4239,7 @@ public class Container extends Component {
|
|||||||
((Container)comp).recursiveRelocateHeavyweightChildren(newOrigin);
|
((Container)comp).recursiveRelocateHeavyweightChildren(newOrigin);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ComponentPeer peer = comp.getPeer();
|
ComponentPeer peer = comp.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.setBounds(origin.x + comp.getX(), origin.y + comp.getY(),
|
peer.setBounds(origin.x + comp.getX(), origin.y + comp.getY(),
|
||||||
comp.getWidth(), comp.getHeight(),
|
comp.getWidth(), comp.getHeight(),
|
||||||
|
@ -504,7 +504,10 @@ public class ContainerOrderFocusTraversalPolicy extends FocusTraversalPolicy
|
|||||||
} else if (comp instanceof Container && comp != aContainer) {
|
} else if (comp instanceof Container && comp != aContainer) {
|
||||||
Container cont = (Container)comp;
|
Container cont = (Container)comp;
|
||||||
if (cont.isFocusTraversalPolicyProvider()) {
|
if (cont.isFocusTraversalPolicyProvider()) {
|
||||||
return cont.getFocusTraversalPolicy().getLastComponent(cont);
|
Component retComp = cont.getFocusTraversalPolicy().getLastComponent(cont);
|
||||||
|
if (retComp != null) {
|
||||||
|
return retComp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -93,7 +93,6 @@ public class DefaultFocusTraversalPolicy
|
|||||||
* @return <code>true</code> if aComponent meets the above requirements;
|
* @return <code>true</code> if aComponent meets the above requirements;
|
||||||
* <code>false</code> otherwise
|
* <code>false</code> otherwise
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
protected boolean accept(Component aComponent) {
|
protected boolean accept(Component aComponent) {
|
||||||
if (!(aComponent.isVisible() && aComponent.isDisplayable() &&
|
if (!(aComponent.isVisible() && aComponent.isDisplayable() &&
|
||||||
aComponent.isEnabled()))
|
aComponent.isEnabled()))
|
||||||
@ -123,7 +122,7 @@ public class DefaultFocusTraversalPolicy
|
|||||||
return focusable;
|
return focusable;
|
||||||
}
|
}
|
||||||
|
|
||||||
ComponentPeer peer = aComponent.getPeer();
|
ComponentPeer peer = aComponent.peer;
|
||||||
return (peer != null && peer.isFocusable());
|
return (peer != null && peer.isFocusable());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -796,7 +796,6 @@ public class DefaultKeyboardFocusManager extends KeyboardFocusManager {
|
|||||||
* @return <code>true</code>
|
* @return <code>true</code>
|
||||||
* @see Component#dispatchEvent
|
* @see Component#dispatchEvent
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public boolean dispatchKeyEvent(KeyEvent e) {
|
public boolean dispatchKeyEvent(KeyEvent e) {
|
||||||
Component focusOwner = (((AWTEvent)e).isPosted) ? getFocusOwner() : e.getComponent();
|
Component focusOwner = (((AWTEvent)e).isPosted) ? getFocusOwner() : e.getComponent();
|
||||||
|
|
||||||
@ -824,14 +823,14 @@ public class DefaultKeyboardFocusManager extends KeyboardFocusManager {
|
|||||||
|
|
||||||
// Allow the peer to process KeyEvent
|
// Allow the peer to process KeyEvent
|
||||||
Component source = e.getComponent();
|
Component source = e.getComponent();
|
||||||
ComponentPeer peer = source.getPeer();
|
ComponentPeer peer = source.peer;
|
||||||
|
|
||||||
if (peer == null || peer instanceof LightweightPeer) {
|
if (peer == null || peer instanceof LightweightPeer) {
|
||||||
// if focus owner is lightweight then its native container
|
// if focus owner is lightweight then its native container
|
||||||
// processes event
|
// processes event
|
||||||
Container target = source.getNativeContainer();
|
Container target = source.getNativeContainer();
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
peer = target.getPeer();
|
peer = target.peer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
@ -1049,7 +1048,7 @@ public class DefaultKeyboardFocusManager extends KeyboardFocusManager {
|
|||||||
Component source = (Component)ke.getSource();
|
Component source = (Component)ke.getSource();
|
||||||
Container target = source.getNativeContainer();
|
Container target = source.getNativeContainer();
|
||||||
if (target != null) {
|
if (target != null) {
|
||||||
ComponentPeer peer = target.getPeer();
|
ComponentPeer peer = target.peer;
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.handleEvent(ke);
|
peer.handleEvent(ke);
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2006, 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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -25,19 +25,16 @@
|
|||||||
|
|
||||||
package java.awt;
|
package java.awt;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.net.URISyntaxException;
|
|
||||||
import java.net.URI;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.net.MalformedURLException;
|
|
||||||
import java.awt.AWTPermission;
|
|
||||||
import java.awt.GraphicsEnvironment;
|
|
||||||
import java.awt.HeadlessException;
|
|
||||||
import java.awt.peer.DesktopPeer;
|
import java.awt.peer.DesktopPeer;
|
||||||
import sun.awt.SunToolkit;
|
import java.io.File;
|
||||||
import sun.awt.HeadlessToolkit;
|
|
||||||
import java.io.FilePermission;
|
import java.io.FilePermission;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URI;
|
||||||
|
import java.net.URISyntaxException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import sun.awt.SunToolkit;
|
||||||
import sun.security.util.SecurityConstants;
|
import sun.security.util.SecurityConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -122,7 +119,11 @@ public class Desktop {
|
|||||||
* Suppresses default constructor for noninstantiability.
|
* Suppresses default constructor for noninstantiability.
|
||||||
*/
|
*/
|
||||||
private Desktop() {
|
private Desktop() {
|
||||||
peer = Toolkit.getDefaultToolkit().createDesktopPeer(this);
|
Toolkit defaultToolkit = Toolkit.getDefaultToolkit();
|
||||||
|
// same cast as in isDesktopSupported()
|
||||||
|
if (defaultToolkit instanceof SunToolkit) {
|
||||||
|
peer = ((SunToolkit) defaultToolkit).createDesktopPeer(this);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -36,11 +36,9 @@ import javax.accessibility.*;
|
|||||||
import sun.awt.AppContext;
|
import sun.awt.AppContext;
|
||||||
import sun.awt.AWTPermissions;
|
import sun.awt.AWTPermissions;
|
||||||
import sun.awt.SunToolkit;
|
import sun.awt.SunToolkit;
|
||||||
import sun.awt.PeerEvent;
|
|
||||||
import sun.awt.util.IdentityArrayList;
|
import sun.awt.util.IdentityArrayList;
|
||||||
import sun.awt.util.IdentityLinkedList;
|
import sun.awt.util.IdentityLinkedList;
|
||||||
import java.security.AccessControlException;
|
import java.security.AccessControlException;
|
||||||
import java.util.function.BooleanSupplier;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A Dialog is a top-level window with a title and a border
|
* A Dialog is a top-level window with a title and a border
|
||||||
@ -749,15 +747,14 @@ public class Dialog extends Window {
|
|||||||
* @see Component#isDisplayable
|
* @see Component#isDisplayable
|
||||||
* @see #removeNotify
|
* @see #removeNotify
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (parent != null && parent.getPeer() == null) {
|
if (parent != null && parent.peer == null) {
|
||||||
parent.addNotify();
|
parent.addNotify();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (peer == null) {
|
if (peer == null) {
|
||||||
peer = getToolkit().createDialog(this);
|
peer = getComponentFactory().createDialog(this);
|
||||||
}
|
}
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -314,14 +314,13 @@ public class FileDialog extends Dialog {
|
|||||||
* Creates the file dialog's peer. The peer allows us to change the look
|
* Creates the file dialog's peer. The peer allows us to change the look
|
||||||
* of the file dialog without changing its functionality.
|
* of the file dialog without changing its functionality.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized(getTreeLock()) {
|
synchronized(getTreeLock()) {
|
||||||
if (parent != null && parent.getPeer() == null) {
|
if (parent != null && parent.peer == null) {
|
||||||
parent.addNotify();
|
parent.addNotify();
|
||||||
}
|
}
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = getToolkit().createFileDialog(this);
|
peer = getComponentFactory().createFileDialog(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,10 +41,11 @@ import java.security.AccessController;
|
|||||||
import java.security.PrivilegedExceptionAction;
|
import java.security.PrivilegedExceptionAction;
|
||||||
import java.text.AttributedCharacterIterator.Attribute;
|
import java.text.AttributedCharacterIterator.Attribute;
|
||||||
import java.text.CharacterIterator;
|
import java.text.CharacterIterator;
|
||||||
import java.text.StringCharacterIterator;
|
|
||||||
import java.util.Hashtable;
|
import java.util.Hashtable;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import sun.awt.ComponentFactory;
|
||||||
import sun.font.StandardGlyphVector;
|
import sun.font.StandardGlyphVector;
|
||||||
|
|
||||||
import sun.font.AttributeMap;
|
import sun.font.AttributeMap;
|
||||||
@ -239,6 +240,11 @@ public class Font implements java.io.Serializable
|
|||||||
public boolean isCreatedFont(Font font) {
|
public boolean isCreatedFont(Font font) {
|
||||||
return font.createdFont;
|
return font.createdFont;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FontPeer getFontPeer(final Font font) {
|
||||||
|
return font.getFontPeer();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static {
|
static {
|
||||||
@ -434,24 +440,16 @@ public class Font implements java.io.Serializable
|
|||||||
private static final long serialVersionUID = -4206021311591459213L;
|
private static final long serialVersionUID = -4206021311591459213L;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the peer of this <code>Font</code>.
|
* Gets the peer of this {@code Font}.
|
||||||
* @return the peer of the <code>Font</code>.
|
*
|
||||||
* @since 1.1
|
* @return the peer of the {@code Font}.
|
||||||
* @deprecated Font rendering is now platform independent.
|
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
private FontPeer getFontPeer() {
|
||||||
public FontPeer getPeer(){
|
|
||||||
return getPeer_NoClientCode();
|
|
||||||
}
|
|
||||||
// NOTE: This method is called by privileged threads.
|
|
||||||
// We implement this functionality in a package-private method
|
|
||||||
// to insure that it cannot be overridden by client subclasses.
|
|
||||||
// DO NOT INVOKE CLIENT CODE ON THIS THREAD!
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
final FontPeer getPeer_NoClientCode() {
|
|
||||||
if(peer == null) {
|
if(peer == null) {
|
||||||
Toolkit tk = Toolkit.getDefaultToolkit();
|
Toolkit tk = Toolkit.getDefaultToolkit();
|
||||||
this.peer = tk.getFontPeer(name, style);
|
if (tk instanceof ComponentFactory) {
|
||||||
|
peer = ((ComponentFactory) tk).getFontPeer(name, style);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return peer;
|
return peer;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -24,21 +24,23 @@
|
|||||||
*/
|
*/
|
||||||
package java.awt;
|
package java.awt;
|
||||||
|
|
||||||
|
import java.awt.event.KeyEvent;
|
||||||
|
import java.awt.event.WindowEvent;
|
||||||
import java.awt.peer.FramePeer;
|
import java.awt.peer.FramePeer;
|
||||||
import java.awt.event.*;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Vector;
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.io.ObjectOutputStream;
|
|
||||||
import java.io.ObjectInputStream;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import sun.awt.AppContext;
|
import java.io.ObjectInputStream;
|
||||||
import sun.awt.SunToolkit;
|
import java.io.ObjectOutputStream;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import javax.accessibility.AccessibleContext;
|
||||||
|
import javax.accessibility.AccessibleRole;
|
||||||
|
import javax.accessibility.AccessibleState;
|
||||||
|
import javax.accessibility.AccessibleStateSet;
|
||||||
|
|
||||||
import sun.awt.AWTAccessor;
|
import sun.awt.AWTAccessor;
|
||||||
import java.lang.ref.WeakReference;
|
import sun.awt.SunToolkit;
|
||||||
import javax.accessibility.*;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A <code>Frame</code> is a top-level window with a title and a border.
|
* A <code>Frame</code> is a top-level window with a title and a border.
|
||||||
@ -474,7 +476,7 @@ public class Frame extends Window implements MenuContainer {
|
|||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (peer == null) {
|
if (peer == null) {
|
||||||
peer = getToolkit().createFrame(this);
|
peer = getComponentFactory().createFrame(this);
|
||||||
}
|
}
|
||||||
FramePeer p = (FramePeer)peer;
|
FramePeer p = (FramePeer)peer;
|
||||||
MenuBar menuBar = this.menuBar;
|
MenuBar menuBar = this.menuBar;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -3054,11 +3054,10 @@ public abstract class KeyboardFocusManager
|
|||||||
return (wto != wfrom);
|
return (wto != wfrom);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
static Component getHeavyweight(Component comp) {
|
static Component getHeavyweight(Component comp) {
|
||||||
if (comp == null || comp.getPeer() == null) {
|
if (comp == null || comp.peer == null) {
|
||||||
return null;
|
return null;
|
||||||
} else if (comp.getPeer() instanceof LightweightPeer) {
|
} else if (comp.peer instanceof LightweightPeer) {
|
||||||
return comp.getNativeContainer();
|
return comp.getNativeContainer();
|
||||||
} else {
|
} else {
|
||||||
return comp;
|
return comp;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1995, 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -184,7 +184,7 @@ public class Label extends Component implements Accessible {
|
|||||||
public void addNotify() {
|
public void addNotify() {
|
||||||
synchronized (getTreeLock()) {
|
synchronized (getTreeLock()) {
|
||||||
if (peer == null)
|
if (peer == null)
|
||||||
peer = getToolkit().createLabel(this);
|
peer = getComponentFactory().createLabel(this);
|
||||||
super.addNotify();
|
super.addNotify();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
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