Merge
This commit is contained in:
commit
0e46853dd6
1
.hgtags
1
.hgtags
@ -285,3 +285,4 @@ b409bc51bc23cfd51f2bd04ea919ec83535af9d0 jdk9-b37
|
|||||||
82f4cb44b2d7af2352f48568a64b7b6a5ae960cd jdk9-b40
|
82f4cb44b2d7af2352f48568a64b7b6a5ae960cd jdk9-b40
|
||||||
9fffb959eb4197ff806e4ac12244761815b4deee jdk9-b41
|
9fffb959eb4197ff806e4ac12244761815b4deee jdk9-b41
|
||||||
3107be2ba9c6e208a0b86bc7100a141abbc5b5fb jdk9-b42
|
3107be2ba9c6e208a0b86bc7100a141abbc5b5fb jdk9-b42
|
||||||
|
6494b13f88a867026ee316b444d9a4fa589dd6bd jdk9-b43
|
||||||
|
@ -285,3 +285,4 @@ d42c0a90afc3c66ca87543076ec9aafd4b4680de jdk9-b38
|
|||||||
cf136458ee747e151a27aa9ea0c1492ea55ef3e7 jdk9-b40
|
cf136458ee747e151a27aa9ea0c1492ea55ef3e7 jdk9-b40
|
||||||
67395f7ca2db3b52e3a62a84888487de5cb9210a jdk9-b41
|
67395f7ca2db3b52e3a62a84888487de5cb9210a jdk9-b41
|
||||||
f7c11da0b0481d49cc7a65a453336c108191e821 jdk9-b42
|
f7c11da0b0481d49cc7a65a453336c108191e821 jdk9-b42
|
||||||
|
02ee8c65622e8bd97496d584e22fc7dcf0edc4ae jdk9-b43
|
||||||
|
@ -4329,7 +4329,7 @@ TOOLCHAIN_DESCRIPTION_xlc="IBM XL C/C++"
|
|||||||
#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=1418036274
|
DATE_WHEN_GENERATED=1418395009
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
@ -13965,7 +13965,8 @@ $as_echo "$COMPILE_TYPE" >&6; }
|
|||||||
|
|
||||||
# ZERO_ARCHDEF is used to enable architecture-specific code
|
# ZERO_ARCHDEF is used to enable architecture-specific code
|
||||||
case "${OPENJDK_TARGET_CPU}" in
|
case "${OPENJDK_TARGET_CPU}" in
|
||||||
ppc*) ZERO_ARCHDEF=PPC ;;
|
ppc) ZERO_ARCHDEF=PPC32 ;;
|
||||||
|
ppc64) ZERO_ARCHDEF=PPC64 ;;
|
||||||
s390*) ZERO_ARCHDEF=S390 ;;
|
s390*) ZERO_ARCHDEF=S390 ;;
|
||||||
sparc*) ZERO_ARCHDEF=SPARC ;;
|
sparc*) ZERO_ARCHDEF=SPARC ;;
|
||||||
x86_64*) ZERO_ARCHDEF=AMD64 ;;
|
x86_64*) ZERO_ARCHDEF=AMD64 ;;
|
||||||
|
@ -367,7 +367,8 @@ AC_DEFUN([PLATFORM_SETUP_LEGACY_VARS],
|
|||||||
|
|
||||||
# ZERO_ARCHDEF is used to enable architecture-specific code
|
# ZERO_ARCHDEF is used to enable architecture-specific code
|
||||||
case "${OPENJDK_TARGET_CPU}" in
|
case "${OPENJDK_TARGET_CPU}" in
|
||||||
ppc*) ZERO_ARCHDEF=PPC ;;
|
ppc) ZERO_ARCHDEF=PPC32 ;;
|
||||||
|
ppc64) ZERO_ARCHDEF=PPC64 ;;
|
||||||
s390*) ZERO_ARCHDEF=S390 ;;
|
s390*) ZERO_ARCHDEF=S390 ;;
|
||||||
sparc*) ZERO_ARCHDEF=SPARC ;;
|
sparc*) ZERO_ARCHDEF=SPARC ;;
|
||||||
x86_64*) ZERO_ARCHDEF=AMD64 ;;
|
x86_64*) ZERO_ARCHDEF=AMD64 ;;
|
||||||
|
@ -106,12 +106,15 @@ if [ ${vflag} = "true" ] ; then
|
|||||||
echo "# Mercurial command: ${command}" > ${status_output}
|
echo "# Mercurial command: ${command}" > ${status_output}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# At this point all command options and args are in "$@".
|
||||||
# capture command options and arguments (if any)
|
# Always use "$@" (within double quotes) to avoid breaking
|
||||||
command_args="${@:-}"
|
# args with spaces into separate args.
|
||||||
|
|
||||||
if [ ${vflag} = "true" ] ; then
|
if [ ${vflag} = "true" ] ; then
|
||||||
echo "# Mercurial command arguments: ${command_args}" > ${status_output}
|
echo "# Mercurial command argument count: $#" > ${status_output}
|
||||||
|
for cmdarg in "$@" ; do
|
||||||
|
echo "# Mercurial command argument: ${cmdarg}" > ${status_output}
|
||||||
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Clean out the temporary directory that stores the pid files.
|
# Clean out the temporary directory that stores the pid files.
|
||||||
@ -205,13 +208,14 @@ if [ "${command}" = "clone" -o "${command}" = "fclone" -o "${command}" = "tclone
|
|||||||
|
|
||||||
pull_default_tail=`echo ${pull_default} | sed -e 's@^.*://[^/]*/\(.*\)@\1@'`
|
pull_default_tail=`echo ${pull_default} | sed -e 's@^.*://[^/]*/\(.*\)@\1@'`
|
||||||
|
|
||||||
if [ -n "${command_args}" ] ; then
|
if [ $# -gt 0 ] ; then
|
||||||
# if there is an "extra sources" path then reparent "extra" repos to that path
|
# if there is an "extra sources" path then reparent "extra" repos to that path
|
||||||
if [ "x${pull_default}" = "x${pull_default_tail}" ] ; then
|
if [ "x${pull_default}" = "x${pull_default_tail}" ] ; then
|
||||||
echo "ERROR: Need initial clone from non-local source" > ${status_output}
|
echo "ERROR: Need initial clone from non-local source" > ${status_output}
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
pull_extra="${command_args}/${pull_default_tail}"
|
# assume that "extra sources" path is the first arg
|
||||||
|
pull_extra="${1}/${pull_default_tail}"
|
||||||
|
|
||||||
# determine which extra subrepos need to be cloned.
|
# determine which extra subrepos need to be cloned.
|
||||||
for i in ${subrepos_extra} ; do
|
for i in ${subrepos_extra} ; do
|
||||||
@ -356,8 +360,8 @@ else
|
|||||||
(PYTHONUNBUFFERED=true hg${global_opts} clone ${clone_newrepo} ${i}; echo "$?" > ${tmp}/${repopidfile}.pid.rc ) 2>&1 &
|
(PYTHONUNBUFFERED=true hg${global_opts} clone ${clone_newrepo} ${i}; echo "$?" > ${tmp}/${repopidfile}.pid.rc ) 2>&1 &
|
||||||
else
|
else
|
||||||
# run the command.
|
# run the command.
|
||||||
echo "cd ${i} && hg${global_opts} ${command} ${command_args}" > ${status_output}
|
echo "cd ${i} && hg${global_opts} ${command} ${@}" > ${status_output}
|
||||||
cd ${i} && (PYTHONUNBUFFERED=true hg${global_opts} ${command} ${command_args}; echo "$?" > ${tmp}/${repopidfile}.pid.rc ) 2>&1 &
|
cd ${i} && (PYTHONUNBUFFERED=true hg${global_opts} ${command} "${@}"; echo "$?" > ${tmp}/${repopidfile}.pid.rc ) 2>&1 &
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo $! > ${tmp}/${repopidfile}.pid
|
echo $! > ${tmp}/${repopidfile}.pid
|
||||||
|
@ -285,3 +285,4 @@ ffd90c81d4ef9d94d880fc852e2fc482ecd9b374 jdk9-b36
|
|||||||
e27c725d6c9d155667b35255f442d4ceb8c3c084 jdk9-b40
|
e27c725d6c9d155667b35255f442d4ceb8c3c084 jdk9-b40
|
||||||
1908b886ba1eda46fa725cf1160fe5d30fd1a7e5 jdk9-b41
|
1908b886ba1eda46fa725cf1160fe5d30fd1a7e5 jdk9-b41
|
||||||
078bb11af876fe528d4b516f33ad4dd9bb60549e jdk9-b42
|
078bb11af876fe528d4b516f33ad4dd9bb60549e jdk9-b42
|
||||||
|
9645e35616b60c5c07b4fdf11a132afc8081dfa8 jdk9-b43
|
||||||
|
@ -445,3 +445,4 @@ c363a8b87e477ee45d6d3cb2a36cb365141bc596 jdk9-b38
|
|||||||
6b09b3193d731e3288e2a240c504a20d0a06c766 jdk9-b40
|
6b09b3193d731e3288e2a240c504a20d0a06c766 jdk9-b40
|
||||||
1d29b13e8a515a7ea3b882f140576d5d675bc11f jdk9-b41
|
1d29b13e8a515a7ea3b882f140576d5d675bc11f jdk9-b41
|
||||||
38cb4fbd47e3472bd1b5ebac83bda96fe4869c4f jdk9-b42
|
38cb4fbd47e3472bd1b5ebac83bda96fe4869c4f jdk9-b42
|
||||||
|
65a9747147b8090037541040ba67156ec914db6a jdk9-b43
|
||||||
|
@ -285,3 +285,4 @@ a12d347f84176200593999f4da91ae2bb86865b2 jdk9-b39
|
|||||||
3f46e2196498de33e7c65efa7b372e46f1faba01 jdk9-b40
|
3f46e2196498de33e7c65efa7b372e46f1faba01 jdk9-b40
|
||||||
71dd8f7649428efd3a56ca5fefc80e59d37b8434 jdk9-b41
|
71dd8f7649428efd3a56ca5fefc80e59d37b8434 jdk9-b41
|
||||||
47b0d3fa4118b9d56870cf4004987438c501f5c0 jdk9-b42
|
47b0d3fa4118b9d56870cf4004987438c501f5c0 jdk9-b42
|
||||||
|
40b242363040229a05224fbc5dc203a3f46a8f8f jdk9-b43
|
||||||
|
325
jaxp/test/Makefile
Normal file
325
jaxp/test/Makefile
Normal file
@ -0,0 +1,325 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 1995, 2014, 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.
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Makefile to run various JAXP tests
|
||||||
|
#
|
||||||
|
|
||||||
|
.DEFAULT : all
|
||||||
|
|
||||||
|
# Empty these to get rid of some default rules
|
||||||
|
.SUFFIXES:
|
||||||
|
.SUFFIXES: .java
|
||||||
|
CO=
|
||||||
|
GET=
|
||||||
|
|
||||||
|
# Utilities used
|
||||||
|
AWK = awk
|
||||||
|
CAT = cat
|
||||||
|
CD = cd
|
||||||
|
CHMOD = chmod
|
||||||
|
CP = cp
|
||||||
|
CUT = cut
|
||||||
|
DIRNAME = dirname
|
||||||
|
ECHO = echo
|
||||||
|
EGREP = egrep
|
||||||
|
EXPAND = expand
|
||||||
|
FIND = find
|
||||||
|
MKDIR = mkdir
|
||||||
|
PWD = pwd
|
||||||
|
SED = sed
|
||||||
|
SORT = sort
|
||||||
|
TEE = tee
|
||||||
|
UNAME = uname
|
||||||
|
UNIQ = uniq
|
||||||
|
WC = wc
|
||||||
|
ZIP = zip
|
||||||
|
|
||||||
|
# Get OS name from uname (Cygwin inexplicably adds _NT-5.1)
|
||||||
|
UNAME_S := $(shell $(UNAME) -s | $(CUT) -f1 -d_)
|
||||||
|
|
||||||
|
# Commands to run on paths to make mixed paths for java on windows
|
||||||
|
ifeq ($(UNAME_S), CYGWIN)
|
||||||
|
# Location of developer shared files
|
||||||
|
SLASH_JAVA = J:
|
||||||
|
GETMIXEDPATH = cygpath -m
|
||||||
|
else
|
||||||
|
# Location of developer shared files
|
||||||
|
SLASH_JAVA = /java
|
||||||
|
|
||||||
|
GETMIXEDPATH=$(ECHO)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Root of this test area (important to use full paths in some places)
|
||||||
|
TEST_ROOT := $(shell $(PWD))
|
||||||
|
|
||||||
|
# Root of all test results
|
||||||
|
ifdef ALT_OUTPUTDIR
|
||||||
|
ABS_OUTPUTDIR = $(shell $(CD) $(ALT_OUTPUTDIR) && $(PWD))
|
||||||
|
else
|
||||||
|
ABS_OUTPUTDIR = $(shell $(CD) $(TEST_ROOT)/.. && $(PWD))
|
||||||
|
endif
|
||||||
|
|
||||||
|
ABS_PLATFORM_BUILD_ROOT = $(ABS_OUTPUTDIR)
|
||||||
|
ABS_TEST_OUTPUT_DIR := $(ABS_PLATFORM_BUILD_ROOT)/testoutput/$(UNIQUE_DIR)
|
||||||
|
|
||||||
|
# Expect JPRT to set PRODUCT_HOME (the product or jdk in this case to test)
|
||||||
|
ifndef PRODUCT_HOME
|
||||||
|
# Try to use j2sdk-image if it exists
|
||||||
|
ABS_JDK_IMAGE = $(ABS_PLATFORM_BUILD_ROOT)/images/j2sdk-image
|
||||||
|
PRODUCT_HOME := \
|
||||||
|
$(shell \
|
||||||
|
if [ -d $(ABS_JDK_IMAGE) ] ; then \
|
||||||
|
$(ECHO) "$(ABS_JDK_IMAGE)"; \
|
||||||
|
else \
|
||||||
|
$(ECHO) "$(ABS_PLATFORM_BUILD_ROOT)"; \
|
||||||
|
fi)
|
||||||
|
PRODUCT_HOME := $(PRODUCT_HOME)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Expect JPRT to set JPRT_PRODUCT_ARGS (e.g. -server etc.)
|
||||||
|
# Should be passed into 'java' only.
|
||||||
|
# Could include: -d64 -server -client OR any java option
|
||||||
|
ifdef JPRT_PRODUCT_ARGS
|
||||||
|
JAVA_ARGS = $(JPRT_PRODUCT_ARGS)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Expect JPRT to set JPRT_PRODUCT_VM_ARGS (e.g. -Xcomp etc.)
|
||||||
|
# Should be passed into anything running the vm (java, javac, javadoc, ...).
|
||||||
|
ifdef JPRT_PRODUCT_VM_ARGS
|
||||||
|
JAVA_VM_ARGS = $(JPRT_PRODUCT_VM_ARGS)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results)
|
||||||
|
ifdef JPRT_ARCHIVE_BUNDLE
|
||||||
|
ARCHIVE_BUNDLE = $(JPRT_ARCHIVE_BUNDLE)
|
||||||
|
else
|
||||||
|
ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip
|
||||||
|
endif
|
||||||
|
|
||||||
|
# How to create the test bundle (pass or fail, we want to create this)
|
||||||
|
# Follow command with ";$(BUNDLE_UP_AND_EXIT)", so it always gets executed.
|
||||||
|
ZIP_UP_RESULTS = ( $(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)` \
|
||||||
|
&& $(CD) $(ABS_TEST_OUTPUT_DIR) \
|
||||||
|
&& $(CHMOD) -R a+r . \
|
||||||
|
&& $(ZIP) -q -r $(ARCHIVE_BUNDLE) . )
|
||||||
|
|
||||||
|
# important results files
|
||||||
|
SUMMARY_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport/text/summary.txt")
|
||||||
|
STATS_TXT_NAME = Stats.txt
|
||||||
|
STATS_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/$(STATS_TXT_NAME)")
|
||||||
|
RUNLIST = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/runlist.txt")
|
||||||
|
PASSLIST = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/passlist.txt")
|
||||||
|
FAILLIST = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/faillist.txt")
|
||||||
|
EXITCODE = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/exitcode.txt")
|
||||||
|
|
||||||
|
TESTEXIT = \
|
||||||
|
if [ ! -s $(EXITCODE) ] ; then \
|
||||||
|
$(ECHO) "ERROR: EXITCODE file not filled in."; \
|
||||||
|
$(ECHO) "1" > $(EXITCODE); \
|
||||||
|
fi ; \
|
||||||
|
testExitCode=`$(CAT) $(EXITCODE)`; \
|
||||||
|
$(ECHO) "EXIT CODE: $${testExitCode}"; \
|
||||||
|
exit $${testExitCode}
|
||||||
|
|
||||||
|
BUNDLE_UP_AND_EXIT = \
|
||||||
|
( \
|
||||||
|
jtregExitCode=$$? && \
|
||||||
|
_summary="$(SUMMARY_TXT)"; \
|
||||||
|
$(RM) -f $(STATS_TXT) $(RUNLIST) $(PASSLIST) $(FAILLIST) $(EXITCODE); \
|
||||||
|
$(ECHO) "$${jtregExitCode}" > $(EXITCODE); \
|
||||||
|
if [ -r "$${_summary}" ] ; then \
|
||||||
|
$(ECHO) "Summary: $(UNIQUE_DIR)" > $(STATS_TXT); \
|
||||||
|
$(EXPAND) $${_summary} | $(EGREP) -v ' Not run\.' > $(RUNLIST); \
|
||||||
|
$(EGREP) ' Passed\.' $(RUNLIST) \
|
||||||
|
| $(EGREP) -v ' Error\.' \
|
||||||
|
| $(EGREP) -v ' Failed\.' > $(PASSLIST); \
|
||||||
|
( $(EGREP) ' Failed\.' $(RUNLIST); \
|
||||||
|
$(EGREP) ' Error\.' $(RUNLIST); \
|
||||||
|
$(EGREP) -v ' Passed\.' $(RUNLIST) ) \
|
||||||
|
| $(SORT) | $(UNIQ) > $(FAILLIST); \
|
||||||
|
if [ $${jtregExitCode} != 0 -o -s $(FAILLIST) ] ; then \
|
||||||
|
$(EXPAND) $(FAILLIST) \
|
||||||
|
| $(CUT) -d' ' -f1 \
|
||||||
|
| $(SED) -e 's@^@FAILED: @' >> $(STATS_TXT); \
|
||||||
|
if [ $${jtregExitCode} = 0 ] ; then \
|
||||||
|
jtregExitCode=1; \
|
||||||
|
fi; \
|
||||||
|
fi; \
|
||||||
|
runc="`$(CAT) $(RUNLIST) | $(WC) -l | $(AWK) '{print $$1;}'`"; \
|
||||||
|
passc="`$(CAT) $(PASSLIST) | $(WC) -l | $(AWK) '{print $$1;}'`"; \
|
||||||
|
failc="`$(CAT) $(FAILLIST) | $(WC) -l | $(AWK) '{print $$1;}'`"; \
|
||||||
|
exclc="FIXME CODETOOLS-7900176"; \
|
||||||
|
$(ECHO) "TEST STATS: name=$(UNIQUE_DIR) run=$${runc} pass=$${passc} fail=$${failc}" \
|
||||||
|
>> $(STATS_TXT); \
|
||||||
|
else \
|
||||||
|
$(ECHO) "Missing file: $${_summary}" >> $(STATS_TXT); \
|
||||||
|
fi; \
|
||||||
|
if [ -f $(STATS_TXT) ] ; then \
|
||||||
|
$(CAT) $(STATS_TXT); \
|
||||||
|
fi; \
|
||||||
|
$(ZIP_UP_RESULTS) ; \
|
||||||
|
$(TESTEXIT) \
|
||||||
|
)
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
# Default make rule (runs default JAXP tests)
|
||||||
|
all: jaxp_all
|
||||||
|
@$(ECHO) "Testing completed successfully"
|
||||||
|
|
||||||
|
# Prep for output
|
||||||
|
# Change execute permissions on shared library files.
|
||||||
|
# Files in repositories should never have execute permissions, but
|
||||||
|
# there are some tests that have pre-built shared libraries, and these
|
||||||
|
# windows dll files must have execute permission. Adding execute
|
||||||
|
# permission may happen automatically on windows when using certain
|
||||||
|
# versions of mercurial but it cannot be guaranteed. And blindly
|
||||||
|
# adding execute permission might be seen as a mercurial 'change', so
|
||||||
|
# we avoid adding execute permission to repository files. But testing
|
||||||
|
# from a plain source tree needs the chmod a+rx. Applying the chmod to
|
||||||
|
# all shared libraries not just dll files. And with CYGWIN and sshd
|
||||||
|
# service, you may need CYGWIN=ntsec for this to work.
|
||||||
|
prep:
|
||||||
|
@$(MKDIR) -p $(ABS_TEST_OUTPUT_DIR)
|
||||||
|
@$(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)`
|
||||||
|
@if [ ! -d $(TEST_ROOT)/../.hg ] ; then \
|
||||||
|
$(FIND) $(TEST_ROOT) \( -name \*.dll -o -name \*.DLL -o -name \*.so \) \
|
||||||
|
-exec $(CHMOD) a+rx {} \; ; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Cleanup
|
||||||
|
clean:
|
||||||
|
@$(RM) -r $(ABS_TEST_OUTPUT_DIR)
|
||||||
|
@$(RM) $(ARCHIVE_BUNDLE)
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
# jtreg tests
|
||||||
|
|
||||||
|
# Expect JT_HOME to be set for jtreg tests. (home for jtreg)
|
||||||
|
ifndef JT_HOME
|
||||||
|
JT_HOME = $(SLASH_JAVA)/re/jtreg/4.1/promoted/latest/binaries/jtreg
|
||||||
|
ifdef JPRT_JTREG_HOME
|
||||||
|
JT_HOME = $(JPRT_JTREG_HOME)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Problematic tests to be excluded
|
||||||
|
PROBLEM_LISTS=$(call MixedDirs,$(wildcard ProblemList.txt closed/ProblemList.txt))
|
||||||
|
|
||||||
|
# Create exclude list for this platform and arch
|
||||||
|
ifdef NO_EXCLUDES
|
||||||
|
JTREG_EXCLUSIONS =
|
||||||
|
else
|
||||||
|
JTREG_EXCLUSIONS = $(PROBLEM_LISTS:%=-exclude:%)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# convert list of directories to dos paths
|
||||||
|
define MixedDirs
|
||||||
|
$(foreach i,$1,$(shell $(GETMIXEDPATH) "${i}"))
|
||||||
|
endef
|
||||||
|
|
||||||
|
define SummaryInfo
|
||||||
|
$(ECHO) "########################################################"
|
||||||
|
$(CAT) $(?:%=$(ABS_TEST_OUTPUT_DIR)/%/$(STATS_TXT_NAME))
|
||||||
|
$(ECHO) "########################################################"
|
||||||
|
endef
|
||||||
|
|
||||||
|
# ------------------------------------------------------------------
|
||||||
|
|
||||||
|
jaxp_%:
|
||||||
|
$(ECHO) "Running tests: $@"
|
||||||
|
for each in $@; do \
|
||||||
|
$(MAKE) -j 1 TEST_SELECTION=":$$each" UNIQUE_DIR=$$each jtreg_tests; \
|
||||||
|
done
|
||||||
|
|
||||||
|
# ------------------------------------------------------------------
|
||||||
|
|
||||||
|
ifdef CONCURRENCY
|
||||||
|
EXTRA_JTREG_OPTIONS += -concurrency:$(CONCURRENCY)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Default JTREG to run (win32 script works for everybody)
|
||||||
|
JTREG = $(JT_HOME)/win32/bin/jtreg
|
||||||
|
# run in agentvm mode
|
||||||
|
JTREG_BASIC_OPTIONS += -agentvm
|
||||||
|
# Only run automatic tests
|
||||||
|
JTREG_BASIC_OPTIONS += -a
|
||||||
|
# Always turn on assertions
|
||||||
|
JTREG_ASSERT_OPTION = -ea -esa
|
||||||
|
JTREG_BASIC_OPTIONS += $(JTREG_ASSERT_OPTION)
|
||||||
|
# Report details on all failed or error tests, times too
|
||||||
|
JTREG_BASIC_OPTIONS += -v:fail,error,time
|
||||||
|
# Retain all files for failing tests
|
||||||
|
JTREG_BASIC_OPTIONS += -retain:fail,error
|
||||||
|
# Ignore tests are not run and completely silent about it
|
||||||
|
JTREG_IGNORE_OPTION = -ignore:quiet
|
||||||
|
JTREG_BASIC_OPTIONS += $(JTREG_IGNORE_OPTION)
|
||||||
|
# Multiple by 4 the timeout numbers
|
||||||
|
JTREG_TIMEOUT_OPTION = -timeoutFactor:4
|
||||||
|
JTREG_BASIC_OPTIONS += $(JTREG_TIMEOUT_OPTION)
|
||||||
|
# Set the max memory for jtreg control vm
|
||||||
|
JTREG_MEMORY_OPTION = -J-Xmx512m
|
||||||
|
JTREG_BASIC_OPTIONS += $(JTREG_MEMORY_OPTION)
|
||||||
|
# Add any extra options
|
||||||
|
JTREG_BASIC_OPTIONS += $(EXTRA_JTREG_OPTIONS)
|
||||||
|
# Set other vm and test options
|
||||||
|
JTREG_TEST_OPTIONS = $(JAVA_ARGS:%=-javaoptions:%) $(JAVA_VM_ARGS:%=-vmoption:%)
|
||||||
|
# Set the GC options for test vms
|
||||||
|
#JTREG_GC_OPTION = -vmoption:-XX:+UseSerialGC
|
||||||
|
#JTREG_TEST_OPTIONS += $(JTREG_GC_OPTION)
|
||||||
|
# Set the max memory for jtreg target test vms
|
||||||
|
JTREG_TESTVM_MEMORY_OPTION = -vmoption:-Xmx512m
|
||||||
|
JTREG_TEST_OPTIONS += $(JTREG_TESTVM_MEMORY_OPTION)
|
||||||
|
|
||||||
|
# Make sure jtreg exists
|
||||||
|
$(JTREG): $(JT_HOME)
|
||||||
|
|
||||||
|
# Run jtreg
|
||||||
|
jtreg_tests: prep $(PRODUCT_HOME) $(JTREG)
|
||||||
|
( \
|
||||||
|
( JT_HOME=$(shell $(GETMIXEDPATH) "$(JT_HOME)"); \
|
||||||
|
export JT_HOME; \
|
||||||
|
$(shell $(GETMIXEDPATH) "$(JTREG)") \
|
||||||
|
$(JTREG_BASIC_OPTIONS) \
|
||||||
|
-r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport") \
|
||||||
|
-w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTwork") \
|
||||||
|
-jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)") \
|
||||||
|
$(JTREG_EXCLUSIONS) \
|
||||||
|
$(JTREG_TEST_OPTIONS) \
|
||||||
|
$(TEST_SELECTION) \
|
||||||
|
) ; \
|
||||||
|
$(BUNDLE_UP_AND_EXIT) \
|
||||||
|
) 2>&1 | $(TEE) $(ABS_TEST_OUTPUT_DIR)/output.txt ; $(TESTEXIT)
|
||||||
|
|
||||||
|
PHONY_LIST += jtreg_tests
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
# Phony targets (e.g. these are not filenames)
|
||||||
|
.PHONY: all clean prep $(PHONY_LIST)
|
||||||
|
|
||||||
|
################################################################
|
@ -2,5 +2,7 @@
|
|||||||
# It also contains test-suite configuration information.
|
# It also contains test-suite configuration information.
|
||||||
|
|
||||||
# Tests that must run in othervm mode
|
# Tests that must run in othervm mode
|
||||||
othervm.dirs=javax/xml/jaxp/unittest
|
othervm.dirs=javax/xml/jaxp
|
||||||
|
|
||||||
|
# Group definitions
|
||||||
|
groups=TEST.groups
|
||||||
|
24
jaxp/test/TEST.groups
Normal file
24
jaxp/test/TEST.groups
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
# Copyright (c) 2013, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
jaxp_all = \
|
||||||
|
javax/xml/jaxp
|
@ -288,3 +288,4 @@ dd4ba422dba858b1c3c4b38f49a3e514be4e2790 jdk9-b38
|
|||||||
5455969de31f3083bcfd779b7acc3ab758ecb308 jdk9-b40
|
5455969de31f3083bcfd779b7acc3ab758ecb308 jdk9-b40
|
||||||
4f785187377fe4c7ff388a7026dd72fcccdcfe7a jdk9-b41
|
4f785187377fe4c7ff388a7026dd72fcccdcfe7a jdk9-b41
|
||||||
301ddb4478fb36d1f025d14e7e48c2a434e9e6ff jdk9-b42
|
301ddb4478fb36d1f025d14e7e48c2a434e9e6ff jdk9-b42
|
||||||
|
edc13d27dc871be57d7ca77eef77e6d04972fee2 jdk9-b43
|
||||||
|
@ -285,3 +285,4 @@ ca6edf957fe1c6ea818530b503578e872cea7239 jdk9-b39
|
|||||||
f1ed1540da70a066527fd043413107e47721edbf jdk9-b40
|
f1ed1540da70a066527fd043413107e47721edbf jdk9-b40
|
||||||
e336cbd8b15e959e70ed02f0f5e93fa76ebd4c07 jdk9-b41
|
e336cbd8b15e959e70ed02f0f5e93fa76ebd4c07 jdk9-b41
|
||||||
6b2314173433467245261364a52fb8e347fe6342 jdk9-b42
|
6b2314173433467245261364a52fb8e347fe6342 jdk9-b42
|
||||||
|
8c6ad41974f9ab6c33d544b088648314963f2a50 jdk9-b43
|
||||||
|
@ -227,10 +227,12 @@ public class ModuleArchive implements Archive {
|
|||||||
|
|
||||||
private static String nativeDir(String filename) {
|
private static String nativeDir(String filename) {
|
||||||
if (System.getProperty("os.name").startsWith("Windows")) {
|
if (System.getProperty("os.name").startsWith("Windows")) {
|
||||||
if (filename.endsWith(".dll"))
|
if (filename.endsWith(".dll") || filename.endsWith(".diz")
|
||||||
|
|| filename.endsWith(".pdb") || filename.endsWith(".map")) {
|
||||||
return "bin";
|
return "bin";
|
||||||
else
|
} else {
|
||||||
return "lib";
|
return "lib";
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
return "lib";
|
return "lib";
|
||||||
}
|
}
|
||||||
|
@ -758,8 +758,8 @@ class TzdbZoneRulesProvider {
|
|||||||
if (endYear == Year.MAX_VALUE) {
|
if (endYear == Year.MAX_VALUE) {
|
||||||
endYear = startYear;
|
endYear = startYear;
|
||||||
lastRules.add(new TransRule(endYear, rule));
|
lastRules.add(new TransRule(endYear, rule));
|
||||||
lastRulesStartYear = Math.max(startYear, lastRulesStartYear);
|
|
||||||
}
|
}
|
||||||
|
lastRulesStartYear = Math.max(startYear, lastRulesStartYear);
|
||||||
} else {
|
} else {
|
||||||
if (endYear == Year.MAX_VALUE) {
|
if (endYear == Year.MAX_VALUE) {
|
||||||
//endYear = zoneEnd.getYear();
|
//endYear = zoneEnd.getYear();
|
||||||
|
@ -5,33 +5,53 @@ global.env.outputheight=480
|
|||||||
global.env.runcount=5
|
global.env.runcount=5
|
||||||
global.env.repcount=0
|
global.env.repcount=0
|
||||||
global.env.testtime=2500
|
global.env.testtime=2500
|
||||||
|
global.results.workunits=units
|
||||||
|
global.results.timeunits=sec
|
||||||
|
global.results.ratio=unitspersec
|
||||||
global.dest.screen=disabled
|
global.dest.screen=disabled
|
||||||
global.dest.offscreen=disabled
|
global.dest.offscreen=disabled
|
||||||
global.dest.compatimg.compatimg=disabled
|
global.dest.compatimg.compatimg=disabled
|
||||||
global.dest.compatimg.opqcompatimg=disabled
|
global.dest.compatimg.opqcompatimg=disabled
|
||||||
global.dest.compatimg.bmcompatimg=disabled
|
global.dest.compatimg.bmcompatimg=disabled
|
||||||
global.dest.compatimg.transcompatimg=disabled
|
global.dest.compatimg.transcompatimg=disabled
|
||||||
global.dest.volimg=enabled
|
global.dest.volimg.volimg=enabled
|
||||||
|
global.dest.volimg.opqvolimg=disabled
|
||||||
|
global.dest.volimg.bmvolimg=disabled
|
||||||
|
global.dest.volimg.transvolimg=disabled
|
||||||
global.dest.bufimg.IntXrgb=disabled
|
global.dest.bufimg.IntXrgb=disabled
|
||||||
global.dest.bufimg.IntArgb=disabled
|
global.dest.bufimg.IntArgb=disabled
|
||||||
|
global.dest.bufimg.IntArgbPre=disabled
|
||||||
|
global.dest.bufimg.3ByteBgr=disabled
|
||||||
global.dest.bufimg.ByteIndexed=disabled
|
global.dest.bufimg.ByteIndexed=disabled
|
||||||
global.dest.bufimg.ByteGray=disabled
|
global.dest.bufimg.ByteGray=disabled
|
||||||
|
global.dest.bufimg.4ByteAbgr=disabled
|
||||||
|
global.dest.bufimg.4ByteAbgrPre=disabled
|
||||||
|
global.dest.bufimg.custom=disabled
|
||||||
graphics.opts.anim=2
|
graphics.opts.anim=2
|
||||||
graphics.opts.sizes=20,250
|
graphics.opts.sizes=20,250
|
||||||
graphics.opts.alpharule=SrcOver
|
graphics.opts.alpharule=SrcOver
|
||||||
|
graphics.opts.transform=ident
|
||||||
graphics.opts.extraalpha=Both
|
graphics.opts.extraalpha=Both
|
||||||
graphics.opts.xormode=Off
|
graphics.opts.xormode=Off
|
||||||
graphics.opts.clip=Both
|
graphics.opts.clip=Both
|
||||||
graphics.opts.renderhint=Default
|
graphics.opts.renderhint=Default
|
||||||
graphics.render.opts.randomcolor=Both
|
graphics.render.opts.paint=single,random
|
||||||
graphics.render.opts.alphacolor=Off
|
graphics.render.opts.alphacolor=Off
|
||||||
graphics.render.opts.antialias=Both
|
graphics.render.opts.antialias=Both
|
||||||
|
graphics.render.opts.stroke=width1
|
||||||
graphics.render.tests.drawLine=enabled
|
graphics.render.tests.drawLine=enabled
|
||||||
|
graphics.render.tests.drawLineHoriz=disabled
|
||||||
|
graphics.render.tests.drawLineVert=disabled
|
||||||
graphics.render.tests.fillRect=enabled
|
graphics.render.tests.fillRect=enabled
|
||||||
|
graphics.render.tests.drawRect=disabled
|
||||||
graphics.render.tests.fillOval=enabled
|
graphics.render.tests.fillOval=enabled
|
||||||
|
graphics.render.tests.drawOval=disabled
|
||||||
graphics.render.tests.fillPoly=disabled
|
graphics.render.tests.fillPoly=disabled
|
||||||
graphics.render.tests.drawPoly=disabled
|
graphics.render.tests.drawPoly=disabled
|
||||||
graphics.render.tests.shape.fillCubic=enabled
|
graphics.render.tests.shape.fillCubic=enabled
|
||||||
|
graphics.render.tests.shape.drawCubic=disabled
|
||||||
|
graphics.render.tests.shape.fillEllipse2D=disabled
|
||||||
|
graphics.render.tests.shape.drawEllipse2D=disabled
|
||||||
graphics.imaging.src.offscr.opaque=disabled
|
graphics.imaging.src.offscr.opaque=disabled
|
||||||
graphics.imaging.src.offscr.bitmask=disabled
|
graphics.imaging.src.offscr.bitmask=disabled
|
||||||
graphics.imaging.src.offscr.translucent=disabled
|
graphics.imaging.src.offscr.translucent=disabled
|
||||||
@ -44,33 +64,98 @@ graphics.imaging.src.bmcompatimg.translucent=disabled
|
|||||||
graphics.imaging.src.transcompatimg.opaque=disabled
|
graphics.imaging.src.transcompatimg.opaque=disabled
|
||||||
graphics.imaging.src.transcompatimg.bitmask=disabled
|
graphics.imaging.src.transcompatimg.bitmask=disabled
|
||||||
graphics.imaging.src.transcompatimg.translucent=enabled
|
graphics.imaging.src.transcompatimg.translucent=enabled
|
||||||
graphics.imaging.src.volimg.opaque=disabled
|
graphics.imaging.src.opqvolimg.opaque=disabled
|
||||||
graphics.imaging.src.volimg.bitmask=disabled
|
graphics.imaging.src.opqvolimg.bitmask=disabled
|
||||||
graphics.imaging.src.volimg.translucent=disabled
|
graphics.imaging.src.opqvolimg.translucent=disabled
|
||||||
|
graphics.imaging.src.bmvolimg.opaque=disabled
|
||||||
|
graphics.imaging.src.bmvolimg.bitmask=disabled
|
||||||
|
graphics.imaging.src.bmvolimg.translucent=disabled
|
||||||
|
graphics.imaging.src.transvolimg.opaque=disabled
|
||||||
|
graphics.imaging.src.transvolimg.bitmask=disabled
|
||||||
|
graphics.imaging.src.transvolimg.translucent=disabled
|
||||||
graphics.imaging.src.bufimg.IntXrgb.opaque=enabled
|
graphics.imaging.src.bufimg.IntXrgb.opaque=enabled
|
||||||
graphics.imaging.src.bufimg.IntXrgb.bitmask=disabled
|
graphics.imaging.src.bufimg.IntXrgb.bitmask=disabled
|
||||||
graphics.imaging.src.bufimg.IntXrgb.translucent=disabled
|
graphics.imaging.src.bufimg.IntXrgb.translucent=disabled
|
||||||
graphics.imaging.src.bufimg.IntArgb.opaque=disabled
|
graphics.imaging.src.bufimg.IntArgb.opaque=disabled
|
||||||
graphics.imaging.src.bufimg.IntArgb.bitmask=disabled
|
graphics.imaging.src.bufimg.IntArgb.bitmask=disabled
|
||||||
graphics.imaging.src.bufimg.IntArgb.translucent=enabled
|
graphics.imaging.src.bufimg.IntArgb.translucent=enabled
|
||||||
|
graphics.imaging.src.bufimg.IntArgbPre.opaque=disabled
|
||||||
|
graphics.imaging.src.bufimg.IntArgbPre.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.IntArgbPre.translucent=disabled
|
||||||
graphics.imaging.src.bufimg.ByteGray.opaque=disabled
|
graphics.imaging.src.bufimg.ByteGray.opaque=disabled
|
||||||
graphics.imaging.src.bufimg.ByteGray.bitmask=disabled
|
graphics.imaging.src.bufimg.ByteGray.bitmask=disabled
|
||||||
graphics.imaging.src.bufimg.ByteGray.translucent=disabled
|
graphics.imaging.src.bufimg.ByteGray.translucent=disabled
|
||||||
|
graphics.imaging.src.bufimg.3ByteBgr.opaque=disabled
|
||||||
|
graphics.imaging.src.bufimg.3ByteBgr.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.3ByteBgr.translucent=disabled
|
||||||
|
graphics.imaging.src.bufimg.4ByteAbgr.opaque=disabled
|
||||||
|
graphics.imaging.src.bufimg.4ByteAbgr.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.4ByteAbgr.translucent=disabled
|
||||||
|
graphics.imaging.src.bufimg.4ByteAbgrPre.opaque=disabled
|
||||||
|
graphics.imaging.src.bufimg.4ByteAbgrPre.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.4ByteAbgrPre.translucent=disabled
|
||||||
graphics.imaging.src.bufimg.ByteIndexedBm.opaque=disabled
|
graphics.imaging.src.bufimg.ByteIndexedBm.opaque=disabled
|
||||||
graphics.imaging.src.bufimg.ByteIndexedBm.bitmask=disabled
|
graphics.imaging.src.bufimg.ByteIndexedBm.bitmask=disabled
|
||||||
graphics.imaging.src.bufimg.ByteIndexedBm.translucent=disabled
|
graphics.imaging.src.bufimg.ByteIndexedBm.translucent=disabled
|
||||||
graphics.imaging.tests.drawimage=enabled
|
graphics.imaging.src.bufimg.unmanagedIntXrgb.opaque=disabled
|
||||||
graphics.imaging.tests.drawimagebg=disabled
|
graphics.imaging.src.bufimg.unmanagedIntXrgb.bitmask=disabled
|
||||||
graphics.imaging.tests.drawimagescaleup=enabled
|
graphics.imaging.src.bufimg.unmanagedIntXrgb.translucent=disabled
|
||||||
graphics.imaging.tests.drawimagescaledown=disabled
|
graphics.imaging.src.bufimg.unmanagedIntArgb.opaque=disabled
|
||||||
graphics.imaging.tests.drawimagetxform=enabled
|
graphics.imaging.src.bufimg.unmanagedIntArgb.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanagedIntArgb.translucent=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanagedIntArgbPre.opaque=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanagedIntArgbPre.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanagedIntArgbPre.translucent=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanaged3ByteBgr.opaque=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanaged3ByteBgr.bitmask=disabled
|
||||||
|
graphics.imaging.src.bufimg.unmanaged3ByteBgr.translucent=disabled
|
||||||
|
graphics.imaging.benchmarks.opts.interpolation=Nearest neighbor
|
||||||
|
graphics.imaging.benchmarks.opts.touchsrc=Off
|
||||||
|
graphics.imaging.benchmarks.tests.drawimage=enabled
|
||||||
|
graphics.imaging.benchmarks.tests.drawimagebg=disabled
|
||||||
|
graphics.imaging.benchmarks.tests.drawimagescaleup=enabled
|
||||||
|
graphics.imaging.benchmarks.tests.drawimagescaledown=disabled
|
||||||
|
graphics.imaging.benchmarks.tests.drawimagescalesplit=disabled
|
||||||
|
graphics.imaging.benchmarks.tests.drawimagetxform=enabled
|
||||||
|
graphics.imaging.imageops.opts.op=convolve3x3zero
|
||||||
|
graphics.imaging.imageops.tests.graphics2d.drawimageop=disabled
|
||||||
|
graphics.imaging.imageops.tests.bufimgop.filternull=disabled
|
||||||
|
graphics.imaging.imageops.tests.bufimgop.filtercached=disabled
|
||||||
|
graphics.imaging.imageops.tests.rasterop.filternull=disabled
|
||||||
|
graphics.imaging.imageops.tests.rasterop.filtercached=disabled
|
||||||
|
graphics.misc.copytests.copyAreaVert=disabled
|
||||||
|
graphics.misc.copytests.copyAreaHoriz=disabled
|
||||||
|
graphics.misc.copytests.copyAreaDiag=disabled
|
||||||
|
pixel.opts.renderto=Off
|
||||||
|
pixel.opts.renderfrom=Off
|
||||||
|
pixel.src.1BitBinary=disabled
|
||||||
|
pixel.src.2BitBinary=disabled
|
||||||
|
pixel.src.4BitBinary=disabled
|
||||||
|
pixel.src.ByteIndexed=disabled
|
||||||
|
pixel.src.ByteGray=disabled
|
||||||
|
pixel.src.Short555=disabled
|
||||||
|
pixel.src.Short565=disabled
|
||||||
|
pixel.src.ShortGray=disabled
|
||||||
|
pixel.src.3ByteBgr=disabled
|
||||||
|
pixel.src.4ByteAbgr=disabled
|
||||||
|
pixel.src.IntXrgb=disabled
|
||||||
|
pixel.src.IntXbgr=disabled
|
||||||
|
pixel.src.IntArgb=disabled
|
||||||
|
pixel.bimgtests.getrgb=disabled
|
||||||
|
pixel.bimgtests.setrgb=disabled
|
||||||
|
pixel.rastests.getdataelem=disabled
|
||||||
|
pixel.rastests.setdataelem=disabled
|
||||||
|
pixel.rastests.getpixel=disabled
|
||||||
|
pixel.rastests.setpixel=disabled
|
||||||
|
pixel.dbtests.getelem=disabled
|
||||||
|
pixel.dbtests.setelem=disabled
|
||||||
text.opts.data.tlength=32
|
text.opts.data.tlength=32
|
||||||
text.opts.data.tscript=english
|
text.opts.data.tscript=english
|
||||||
text.opts.font.fname=lucida
|
text.opts.font.fname=lucida
|
||||||
text.opts.font.fstyle=0
|
text.opts.font.fstyle=0
|
||||||
text.opts.font.fsize=13.0
|
text.opts.font.fsize=13.0
|
||||||
text.opts.font.ftx=Identity
|
text.opts.font.ftx=Identity
|
||||||
text.opts.graphics.taa=Both
|
text.opts.graphics.textaa=Off,On
|
||||||
text.opts.graphics.tfm=Off
|
text.opts.graphics.tfm=Off
|
||||||
text.opts.graphics.gaa=Off
|
text.opts.graphics.gaa=Off
|
||||||
text.opts.graphics.gtx=Identity
|
text.opts.graphics.gtx=Identity
|
||||||
@ -114,3 +199,66 @@ text.construction.tests.gvfromfontglyphs=disabled
|
|||||||
text.construction.tests.gvfromfontlayout=disabled
|
text.construction.tests.gvfromfontlayout=disabled
|
||||||
text.construction.tests.tlfromfont=disabled
|
text.construction.tests.tlfromfont=disabled
|
||||||
text.construction.tests.tlfrommap=disabled
|
text.construction.tests.tlfrommap=disabled
|
||||||
|
imageio.opts.size=250
|
||||||
|
imageio.opts.content=photo
|
||||||
|
imageio.input.opts.general.source.file=disabled
|
||||||
|
imageio.input.opts.general.source.url=disabled
|
||||||
|
imageio.input.opts.general.source.byteArray=disabled
|
||||||
|
imageio.input.opts.imageio.useCache=Off
|
||||||
|
imageio.input.image.toolkit.opts.format=
|
||||||
|
imageio.input.image.toolkit.tests.createImage=disabled
|
||||||
|
imageio.input.image.imageio.opts.format=
|
||||||
|
imageio.input.image.imageio.tests.imageioRead=disabled
|
||||||
|
imageio.input.image.imageio.reader.opts.seekForwardOnly=On
|
||||||
|
imageio.input.image.imageio.reader.opts.ignoreMetadata=On
|
||||||
|
imageio.input.image.imageio.reader.opts.installListener=Off
|
||||||
|
imageio.input.image.imageio.reader.tests.read=disabled
|
||||||
|
imageio.input.image.imageio.reader.tests.getImageMetadata=disabled
|
||||||
|
imageio.input.stream.tests.construct=disabled
|
||||||
|
imageio.input.stream.tests.read=disabled
|
||||||
|
imageio.input.stream.tests.readByteArray=disabled
|
||||||
|
imageio.input.stream.tests.readFullyByteArray=disabled
|
||||||
|
imageio.input.stream.tests.readBit=disabled
|
||||||
|
imageio.input.stream.tests.readByte=disabled
|
||||||
|
imageio.input.stream.tests.readUnsignedByte=disabled
|
||||||
|
imageio.input.stream.tests.readShort=disabled
|
||||||
|
imageio.input.stream.tests.readUnsignedShort=disabled
|
||||||
|
imageio.input.stream.tests.readInt=disabled
|
||||||
|
imageio.input.stream.tests.readUnsignedInt=disabled
|
||||||
|
imageio.input.stream.tests.readFloat=disabled
|
||||||
|
imageio.input.stream.tests.readLong=disabled
|
||||||
|
imageio.input.stream.tests.readDouble=disabled
|
||||||
|
imageio.input.stream.tests.skipBytes=disabled
|
||||||
|
imageio.output.opts.general.dest.file=disabled
|
||||||
|
imageio.output.opts.general.dest.byteArray=disabled
|
||||||
|
imageio.output.opts.imageio.useCache=Off
|
||||||
|
imageio.output.image.imageio.opts.format=
|
||||||
|
imageio.output.image.imageio.tests.imageioWrite=disabled
|
||||||
|
imageio.output.image.imageio.writer.opts.installListener=Off
|
||||||
|
imageio.output.image.imageio.writer.tests.write=disabled
|
||||||
|
imageio.output.stream.tests.construct=disabled
|
||||||
|
imageio.output.stream.tests.write=disabled
|
||||||
|
imageio.output.stream.tests.writeByteArray=disabled
|
||||||
|
imageio.output.stream.tests.writeBit=disabled
|
||||||
|
imageio.output.stream.tests.writeByte=disabled
|
||||||
|
imageio.output.stream.tests.writeShort=disabled
|
||||||
|
imageio.output.stream.tests.writeInt=disabled
|
||||||
|
imageio.output.stream.tests.writeFloat=disabled
|
||||||
|
imageio.output.stream.tests.writeLong=disabled
|
||||||
|
imageio.output.stream.tests.writeDouble=disabled
|
||||||
|
cmm.opts.profiles=1001
|
||||||
|
cmm.colorconv.data.fromRGB=disabled
|
||||||
|
cmm.colorconv.data.toRGB=disabled
|
||||||
|
cmm.colorconv.data.fromCIEXYZ=disabled
|
||||||
|
cmm.colorconv.data.toCIEXYZ=disabled
|
||||||
|
cmm.colorconv.ccop.ccopOptions.size=250
|
||||||
|
cmm.colorconv.ccop.ccopOptions.content=photo
|
||||||
|
cmm.colorconv.ccop.ccopOptions.srcType=INT_ARGB
|
||||||
|
cmm.colorconv.ccop.ccopOptions.dstType=INT_ARGB
|
||||||
|
cmm.colorconv.ccop.op_img=disabled
|
||||||
|
cmm.colorconv.ccop.op_rst=disabled
|
||||||
|
cmm.colorconv.ccop.op_draw=disabled
|
||||||
|
cmm.colorconv.embed.embedOptions.Images=512x512
|
||||||
|
cmm.colorconv.embed.embd_img_read=disabled
|
||||||
|
cmm.profiles.getHeader=disabled
|
||||||
|
cmm.profiles.getNumComponents=disabled
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@ -57,6 +57,7 @@ public abstract class Destinations extends Option.Enable {
|
|||||||
public static Group.EnableSet destroot;
|
public static Group.EnableSet destroot;
|
||||||
public static Group bufimgdestroot;
|
public static Group bufimgdestroot;
|
||||||
public static Group compatimgdestroot;
|
public static Group compatimgdestroot;
|
||||||
|
public static Group volimgdestroot;
|
||||||
|
|
||||||
public static void init() {
|
public static void init() {
|
||||||
destroot = new Group.EnableSet(TestEnvironment.globaloptroot,
|
destroot = new Group.EnableSet(TestEnvironment.globaloptroot,
|
||||||
@ -79,7 +80,16 @@ public abstract class Destinations extends Option.Enable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ImageTests.hasVolatileImage) {
|
if (ImageTests.hasVolatileImage) {
|
||||||
|
volimgdestroot = new Group.EnableSet(destroot, "volimg",
|
||||||
|
"Output to Volatile Image");
|
||||||
|
|
||||||
|
volimgdestroot.setHorizontal();
|
||||||
new VolatileImg();
|
new VolatileImg();
|
||||||
|
if (ImageTests.hasTransparentVolatileImage) {
|
||||||
|
new VolatileImg(Transparency.OPAQUE);
|
||||||
|
new VolatileImg(Transparency.BITMASK);
|
||||||
|
new VolatileImg(Transparency.TRANSLUCENT);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bufimgdestroot = new Group.EnableSet(destroot, "bufimg",
|
bufimgdestroot = new Group.EnableSet(destroot, "bufimg",
|
||||||
@ -91,6 +101,8 @@ public abstract class Destinations extends Option.Enable {
|
|||||||
new BufImg(BufferedImage.TYPE_3BYTE_BGR);
|
new BufImg(BufferedImage.TYPE_3BYTE_BGR);
|
||||||
new BufImg(BufferedImage.TYPE_BYTE_INDEXED);
|
new BufImg(BufferedImage.TYPE_BYTE_INDEXED);
|
||||||
new BufImg(BufferedImage.TYPE_BYTE_GRAY);
|
new BufImg(BufferedImage.TYPE_BYTE_GRAY);
|
||||||
|
new BufImg(BufferedImage.TYPE_4BYTE_ABGR);
|
||||||
|
new BufImg(BufferedImage.TYPE_4BYTE_ABGR_PRE);
|
||||||
new CustomImg();
|
new CustomImg();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -206,18 +218,62 @@ public abstract class Destinations extends Option.Enable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class VolatileImg extends Destinations {
|
public static class VolatileImg extends Destinations {
|
||||||
|
private final int transparency;
|
||||||
|
|
||||||
|
public static final String[] ShortNames = {
|
||||||
|
"volimg",
|
||||||
|
"opqvolimg",
|
||||||
|
"bmvolimg",
|
||||||
|
"transvolimg",
|
||||||
|
};
|
||||||
|
|
||||||
|
public static final String[] ShortDescriptions = {
|
||||||
|
"Default",
|
||||||
|
"Opaque",
|
||||||
|
"Bitmask",
|
||||||
|
"Translucent",
|
||||||
|
};
|
||||||
|
|
||||||
|
public static final String[] LongDescriptions = {
|
||||||
|
"Default VolatileImg Image",
|
||||||
|
"Opaque VolatileImg Image",
|
||||||
|
"Bitmask VolatileImg Image",
|
||||||
|
"Translucent VolatileImg Image",
|
||||||
|
};
|
||||||
|
|
||||||
|
public static final String[] ModifierNames = {
|
||||||
|
"VolatileImg()",
|
||||||
|
"VolatileImg(Opaque)",
|
||||||
|
"VolatileImg(Bitmask)",
|
||||||
|
"VolatileImg(Translucent)",
|
||||||
|
};
|
||||||
|
|
||||||
public VolatileImg() {
|
public VolatileImg() {
|
||||||
super(destroot, "volimg", "Output to Volatile Image", false);
|
this(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getModifierValueName(Object val) {
|
public VolatileImg(final int transparency) {
|
||||||
return "VolatileImg";
|
super(volimgdestroot,
|
||||||
|
ShortNames[transparency],
|
||||||
|
ShortDescriptions[transparency],
|
||||||
|
false);
|
||||||
|
this.transparency = transparency;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDestination(TestEnvironment env) {
|
public String getModifierValueName(final Object val) {
|
||||||
|
return ModifierNames[transparency];
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDestination(final TestEnvironment env) {
|
||||||
Component c = env.getCanvas();
|
Component c = env.getCanvas();
|
||||||
env.setTestImage(c.createVolatileImage(env.getWidth(),
|
GraphicsConfiguration gc = c.getGraphicsConfiguration();
|
||||||
env.getHeight()));
|
int w = env.getWidth();
|
||||||
|
int h = env.getHeight();
|
||||||
|
if (transparency == 0) {
|
||||||
|
env.setTestImage(gc.createCompatibleVolatileImage(w, h));
|
||||||
|
} else {
|
||||||
|
env.setTestImage(gc.createCompatibleVolatileImage(w, h, transparency));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@ -44,6 +44,7 @@ import java.io.PrintWriter;
|
|||||||
import javax.swing.BoxLayout;
|
import javax.swing.BoxLayout;
|
||||||
import javax.swing.JComponent;
|
import javax.swing.JComponent;
|
||||||
import javax.swing.JPanel;
|
import javax.swing.JPanel;
|
||||||
|
import javax.swing.JScrollPane;
|
||||||
import javax.swing.JTabbedPane;
|
import javax.swing.JTabbedPane;
|
||||||
import javax.swing.border.TitledBorder;
|
import javax.swing.border.TitledBorder;
|
||||||
import java.util.NoSuchElementException;
|
import java.util.NoSuchElementException;
|
||||||
@ -199,7 +200,7 @@ public class Group extends Node {
|
|||||||
p.add(comp);
|
p.add(comp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return p;
|
return new JScrollPane(p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@ -60,6 +60,8 @@ import javax.swing.JPanel;
|
|||||||
import javax.swing.BoxLayout;
|
import javax.swing.BoxLayout;
|
||||||
import javax.swing.JFileChooser;
|
import javax.swing.JFileChooser;
|
||||||
import javax.swing.JOptionPane;
|
import javax.swing.JOptionPane;
|
||||||
|
import javax.swing.SwingUtilities;
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
@ -376,7 +378,11 @@ public class J2DBench {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (gui) {
|
if (gui) {
|
||||||
startGUI();
|
SwingUtilities.invokeLater(new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
startGUI();
|
||||||
|
}
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
@ -772,6 +778,7 @@ public class J2DBench {
|
|||||||
|
|
||||||
f.getContentPane().add(p, BorderLayout.SOUTH);
|
f.getContentPane().add(p, BorderLayout.SOUTH);
|
||||||
f.pack();
|
f.pack();
|
||||||
|
f.setLocationRelativeTo(null);
|
||||||
f.show();
|
f.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@ -112,10 +112,10 @@ public abstract class GraphicsTests extends Test {
|
|||||||
|
|
||||||
sizeList = new Option.IntList(groptroot, "sizes",
|
sizeList = new Option.IntList(groptroot, "sizes",
|
||||||
"Size of Operations to perform",
|
"Size of Operations to perform",
|
||||||
new int[] {1, 20, 100, 250, 1000},
|
new int[] {1, 20, 100, 250, 1000, 4000},
|
||||||
new String[] {
|
new String[] {
|
||||||
"1x1", "20x20", "100x100", "250x250",
|
"1x1", "20x20", "100x100", "250x250",
|
||||||
"1000x1000",
|
"1000x1000", "4000x4000",
|
||||||
},
|
},
|
||||||
new String[] {
|
new String[] {
|
||||||
"Tiny Shapes (1x1)",
|
"Tiny Shapes (1x1)",
|
||||||
@ -123,6 +123,7 @@ public abstract class GraphicsTests extends Test {
|
|||||||
"Medium Shapes (100x100)",
|
"Medium Shapes (100x100)",
|
||||||
"Large Shapes (250x250)",
|
"Large Shapes (250x250)",
|
||||||
"X-Large Shapes (1000x1000)",
|
"X-Large Shapes (1000x1000)",
|
||||||
|
"Huge Shapes (4000x4000)",
|
||||||
}, 0xa);
|
}, 0xa);
|
||||||
if (hasGraphics2D) {
|
if (hasGraphics2D) {
|
||||||
String rulenames[] = {
|
String rulenames[] = {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@ -53,6 +53,7 @@ import java.awt.Canvas;
|
|||||||
import java.awt.AlphaComposite;
|
import java.awt.AlphaComposite;
|
||||||
import java.awt.Dimension;
|
import java.awt.Dimension;
|
||||||
import java.awt.GraphicsConfiguration;
|
import java.awt.GraphicsConfiguration;
|
||||||
|
import java.awt.RenderingHints;
|
||||||
import java.awt.image.BufferedImage;
|
import java.awt.image.BufferedImage;
|
||||||
import java.awt.image.BufferedImageOp;
|
import java.awt.image.BufferedImageOp;
|
||||||
import java.awt.image.ByteLookupTable;
|
import java.awt.image.ByteLookupTable;
|
||||||
@ -77,6 +78,7 @@ import javax.swing.JComponent;
|
|||||||
|
|
||||||
public abstract class ImageTests extends GraphicsTests {
|
public abstract class ImageTests extends GraphicsTests {
|
||||||
public static boolean hasVolatileImage;
|
public static boolean hasVolatileImage;
|
||||||
|
public static boolean hasTransparentVolatileImage;
|
||||||
public static boolean hasCompatImage;
|
public static boolean hasCompatImage;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
@ -89,14 +91,20 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
hasCompatImage = true;
|
hasCompatImage = true;
|
||||||
} catch (NoSuchMethodError e) {
|
} catch (NoSuchMethodError e) {
|
||||||
}
|
}
|
||||||
|
try {
|
||||||
|
new Canvas().getMousePosition();
|
||||||
|
hasTransparentVolatileImage = true;
|
||||||
|
} catch (NoSuchMethodError e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static Group imageroot;
|
static Group imageroot;
|
||||||
static Group.EnableSet imgsrcroot;
|
static Group.EnableSet imgsrcroot;
|
||||||
static Group.EnableSet bufimgsrcroot;
|
static Group.EnableSet bufimgsrcroot;
|
||||||
|
|
||||||
|
static Group imgbenchroot;
|
||||||
static Group imgtestroot;
|
static Group imgtestroot;
|
||||||
static Group imgoptionsroot;
|
static Group imgtestOptRoot;
|
||||||
|
|
||||||
static Group imageOpRoot;
|
static Group imageOpRoot;
|
||||||
static Group imageOpOptRoot;
|
static Group imageOpOptRoot;
|
||||||
@ -106,6 +114,7 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
static Group rasterOpTestRoot;
|
static Group rasterOpTestRoot;
|
||||||
static Option opList;
|
static Option opList;
|
||||||
static Option doTouchSrc;
|
static Option doTouchSrc;
|
||||||
|
static Option interpolation;
|
||||||
|
|
||||||
static String transNodeNames[] = {
|
static String transNodeNames[] = {
|
||||||
null, "opaque", "bitmask", "translucent",
|
null, "opaque", "bitmask", "translucent",
|
||||||
@ -122,19 +131,9 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
|
|
||||||
imgsrcroot = new Group.EnableSet(imageroot, "src",
|
imgsrcroot = new Group.EnableSet(imageroot, "src",
|
||||||
"Image Rendering Sources");
|
"Image Rendering Sources");
|
||||||
imgsrcroot.setBordered(true);
|
imgbenchroot = new Group(imageroot, "benchmarks",
|
||||||
|
"Image Rendering Benchmarks");
|
||||||
imgoptionsroot = new Group(imgsrcroot, "options",
|
imgtestOptRoot = new Group(imgbenchroot, "opts", "Options");
|
||||||
"Image Source Options");
|
|
||||||
imgoptionsroot.setBordered(true);
|
|
||||||
doTouchSrc =
|
|
||||||
new Option.Toggle(imgoptionsroot, "touchsrc",
|
|
||||||
"Touch src image before every operation",
|
|
||||||
Option.Toggle.Off);
|
|
||||||
|
|
||||||
imgtestroot = new Group(imageroot, "tests",
|
|
||||||
"Image Rendering Tests");
|
|
||||||
imgtestroot.setBordered(true);
|
|
||||||
|
|
||||||
new OffScreen();
|
new OffScreen();
|
||||||
|
|
||||||
@ -144,9 +143,14 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
new CompatImg(Transparency.BITMASK);
|
new CompatImg(Transparency.BITMASK);
|
||||||
new CompatImg(Transparency.TRANSLUCENT);
|
new CompatImg(Transparency.TRANSLUCENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hasVolatileImage) {
|
if (hasVolatileImage) {
|
||||||
new VolatileImg();
|
if (hasTransparentVolatileImage) {
|
||||||
|
new VolatileImg(Transparency.OPAQUE);
|
||||||
|
new VolatileImg(Transparency.BITMASK);
|
||||||
|
new VolatileImg(Transparency.TRANSLUCENT);
|
||||||
|
} else {
|
||||||
|
new VolatileImg();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bufimgsrcroot =
|
bufimgsrcroot =
|
||||||
@ -154,11 +158,15 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
"BufferedImage Rendering Sources");
|
"BufferedImage Rendering Sources");
|
||||||
new BufImg(BufferedImage.TYPE_INT_RGB);
|
new BufImg(BufferedImage.TYPE_INT_RGB);
|
||||||
new BufImg(BufferedImage.TYPE_INT_ARGB);
|
new BufImg(BufferedImage.TYPE_INT_ARGB);
|
||||||
|
new BufImg(BufferedImage.TYPE_INT_ARGB_PRE);
|
||||||
new BufImg(BufferedImage.TYPE_BYTE_GRAY);
|
new BufImg(BufferedImage.TYPE_BYTE_GRAY);
|
||||||
new BufImg(BufferedImage.TYPE_3BYTE_BGR);
|
new BufImg(BufferedImage.TYPE_3BYTE_BGR);
|
||||||
|
new BufImg(BufferedImage.TYPE_4BYTE_ABGR);
|
||||||
|
new BufImg(BufferedImage.TYPE_4BYTE_ABGR_PRE);
|
||||||
new BmByteIndexBufImg();
|
new BmByteIndexBufImg();
|
||||||
new BufImg(BufferedImage.TYPE_INT_RGB, true);
|
new BufImg(BufferedImage.TYPE_INT_RGB, true);
|
||||||
new BufImg(BufferedImage.TYPE_INT_ARGB, true);
|
new BufImg(BufferedImage.TYPE_INT_ARGB, true);
|
||||||
|
new BufImg(BufferedImage.TYPE_INT_ARGB_PRE, true);
|
||||||
new BufImg(BufferedImage.TYPE_3BYTE_BGR, true);
|
new BufImg(BufferedImage.TYPE_3BYTE_BGR, true);
|
||||||
|
|
||||||
imageOpRoot = new Group(imageroot, "imageops",
|
imageOpRoot = new Group(imageroot, "imageops",
|
||||||
@ -211,12 +219,31 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
new BufImgOpFilter(true);
|
new BufImgOpFilter(true);
|
||||||
new RasterOpFilter(false);
|
new RasterOpFilter(false);
|
||||||
new RasterOpFilter(true);
|
new RasterOpFilter(true);
|
||||||
|
|
||||||
|
String interpolationnames[] = {"Nearest neighbor", "Bilinear",
|
||||||
|
"Bicubic",};
|
||||||
|
interpolation =
|
||||||
|
new ObjectList(imgtestOptRoot, "interpolation",
|
||||||
|
"Interpolation",
|
||||||
|
interpolationnames, new Object[] {
|
||||||
|
RenderingHints.VALUE_INTERPOLATION_NEAREST_NEIGHBOR,
|
||||||
|
RenderingHints.VALUE_INTERPOLATION_BILINEAR,
|
||||||
|
RenderingHints.VALUE_INTERPOLATION_BICUBIC,
|
||||||
|
}, interpolationnames, interpolationnames, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
doTouchSrc =
|
||||||
|
new Option.Toggle(imgtestOptRoot, "touchsrc",
|
||||||
|
"Touch source image before every operation",
|
||||||
|
Option.Toggle.Off);
|
||||||
|
|
||||||
|
imgtestroot = new Group(imgbenchroot, "tests", "Image Rendering Tests");
|
||||||
|
|
||||||
new DrawImage();
|
new DrawImage();
|
||||||
new DrawImageBg();
|
new DrawImageBg();
|
||||||
new DrawImageScale("up", 1.5f);
|
new DrawImageScale("up", 1.5f);
|
||||||
new DrawImageScale("down", .75f);
|
new DrawImageScale("down", .75f);
|
||||||
|
new DrawImageScale("split", .5f);
|
||||||
new DrawImageTransform();
|
new DrawImageTransform();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -236,6 +263,7 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
super(parent, nodeName, description);
|
super(parent, nodeName, description);
|
||||||
addDependency(imgsrcroot, srcFilter);
|
addDependency(imgsrcroot, srcFilter);
|
||||||
addDependency(doTouchSrc);
|
addDependency(doTouchSrc);
|
||||||
|
addDependency(interpolation);
|
||||||
}
|
}
|
||||||
|
|
||||||
public GraphicsTests.Context createContext() {
|
public GraphicsTests.Context createContext() {
|
||||||
@ -248,6 +276,11 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
|
|
||||||
ictx.src = env.getSrcImage();
|
ictx.src = env.getSrcImage();
|
||||||
ictx.touchSrc = env.isEnabled(doTouchSrc);
|
ictx.touchSrc = env.isEnabled(doTouchSrc);
|
||||||
|
if (hasGraphics2D) {
|
||||||
|
Graphics2D g2d = (Graphics2D) ctx.graphics;
|
||||||
|
final Object modifier = env.getModifier(interpolation);
|
||||||
|
g2d.setRenderingHint(RenderingHints.KEY_INTERPOLATION, modifier);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract static class TriStateImageType extends Group {
|
public abstract static class TriStateImageType extends Group {
|
||||||
@ -290,13 +323,27 @@ public abstract class ImageTests extends GraphicsTests {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class VolatileImg extends TriStateImageType {
|
public static class VolatileImg extends TriStateImageType {
|
||||||
|
private final int transparency;
|
||||||
|
|
||||||
public VolatileImg() {
|
public VolatileImg() {
|
||||||
super(imgsrcroot, "volimg", "Volatile Image", Transparency.OPAQUE);
|
this(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public VolatileImg(int transparency) {
|
||||||
|
super(imgsrcroot, Destinations.VolatileImg.ShortNames[transparency],
|
||||||
|
Destinations.VolatileImg.LongDescriptions[transparency],
|
||||||
|
transparency);
|
||||||
|
this.transparency = transparency;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Image makeImage(TestEnvironment env, int w, int h) {
|
public Image makeImage(TestEnvironment env, int w, int h) {
|
||||||
Canvas c = env.getCanvas();
|
Canvas c = env.getCanvas();
|
||||||
return c.createVolatileImage(w, h);
|
GraphicsConfiguration gc = c.getGraphicsConfiguration();
|
||||||
|
if (transparency == 0) {
|
||||||
|
return gc.createCompatibleVolatileImage(w, h);
|
||||||
|
} else {
|
||||||
|
return gc.createCompatibleVolatileImage(w, h, transparency);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ import j2dbench.tests.iio.IIOTests;
|
|||||||
public class ColorConvertOpTests extends ColorConversionTests {
|
public class ColorConvertOpTests extends ColorConversionTests {
|
||||||
|
|
||||||
private static class ImageContent {
|
private static class ImageContent {
|
||||||
static ImageContent BLANK = new ImageContent("bank", "Blank (opaque black)");
|
static ImageContent BLANK = new ImageContent("blank", "Blank (opaque black)");
|
||||||
static ImageContent RANDOM = new ImageContent("random", "Random");
|
static ImageContent RANDOM = new ImageContent("random", "Random");
|
||||||
static ImageContent VECTOR = new ImageContent("vector", "Vector Art");
|
static ImageContent VECTOR = new ImageContent("vector", "Vector Art");
|
||||||
static ImageContent PHOTO= new ImageContent("photo", "Photograph");
|
static ImageContent PHOTO= new ImageContent("photo", "Photograph");
|
||||||
@ -83,7 +83,7 @@ public class ColorConvertOpTests extends ColorConversionTests {
|
|||||||
static ImageType INT_RGB = new ImageType(BufferedImage.TYPE_INT_RGB, "INT_RGB", "TYPE_INT_RGB");
|
static ImageType INT_RGB = new ImageType(BufferedImage.TYPE_INT_RGB, "INT_RGB", "TYPE_INT_RGB");
|
||||||
static ImageType INT_BGR = new ImageType(BufferedImage.TYPE_INT_BGR, "INT_BGR", "TYPE_INT_BGR");
|
static ImageType INT_BGR = new ImageType(BufferedImage.TYPE_INT_BGR, "INT_BGR", "TYPE_INT_BGR");
|
||||||
static ImageType BYTE_3BYTE_BGR = new ImageType(BufferedImage.TYPE_3BYTE_BGR, "3BYTE_BGR", "TYPE_3BYTE_BGR");
|
static ImageType BYTE_3BYTE_BGR = new ImageType(BufferedImage.TYPE_3BYTE_BGR, "3BYTE_BGR", "TYPE_3BYTE_BGR");
|
||||||
static ImageType BYTE_4BYTE_ABGR = new ImageType(BufferedImage.TYPE_4BYTE_ABGR, "4BYTE_BGR", "TYPE_4BYTE_BGR");
|
static ImageType BYTE_4BYTE_ABGR = new ImageType(BufferedImage.TYPE_4BYTE_ABGR, "4BYTE_ABGR", "TYPE_4BYTE_ABGR");
|
||||||
static ImageType COMPATIBLE_DST = new ImageType(0, "Compatible", "Compatible destination");
|
static ImageType COMPATIBLE_DST = new ImageType(0, "Compatible", "Compatible destination");
|
||||||
|
|
||||||
private ImageType(int type, String abbr, String descr) {
|
private ImageType(int type, String abbr, String descr) {
|
||||||
@ -130,7 +130,7 @@ public class ColorConvertOpTests extends ColorConversionTests {
|
|||||||
|
|
||||||
for (int i = 0; i < num; i++) {
|
for (int i = 0; i < num; i++) {
|
||||||
t[i] = allTypes[i];
|
t[i] = allTypes[i];
|
||||||
names[i] = t[i].toString();
|
names[i] = t[i].abbrev;
|
||||||
abbrev[i] = t[i].abbrev;
|
abbrev[i] = t[i].abbrev;
|
||||||
descr[i] = t[i].descr;
|
descr[i] = t[i].descr;
|
||||||
}
|
}
|
||||||
|
@ -100,7 +100,7 @@ public class EmbeddedProfileTests extends ColorConversionTests {
|
|||||||
String[] descr = new String[num];
|
String[] descr = new String[num];
|
||||||
|
|
||||||
for (int i = 0; i < num; i++) {
|
for (int i = 0; i < num; i++) {
|
||||||
names[i] = images[i].toString();
|
names[i] = images[i].abbrev;
|
||||||
abbrev[i] = images[i].abbrev;
|
abbrev[i] = images[i].abbrev;
|
||||||
descr[i] = images[i].description;
|
descr[i] = images[i].description;
|
||||||
}
|
}
|
||||||
@ -153,7 +153,7 @@ public class EmbeddedProfileTests extends ColorConversionTests {
|
|||||||
iis = ImageIO.createImageInputStream(url.openStream());
|
iis = ImageIO.createImageInputStream(url.openStream());
|
||||||
reader = (ImageReader) ImageIO.getImageReaders(iis).next();
|
reader = (ImageReader) ImageIO.getImageReaders(iis).next();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new RuntimeException("Unable to run the becnhmark", e);
|
throw new RuntimeException("Unable to run the benchmark", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
@ -267,7 +267,7 @@ public final class TableSorter extends TableMap {
|
|||||||
than assigned otherwise sister calls in the recursion might
|
than assigned otherwise sister calls in the recursion might
|
||||||
get out of sinc. When the number of elements is three they
|
get out of sinc. When the number of elements is three they
|
||||||
are partitioned so that the first set, [low, mid), has one
|
are partitioned so that the first set, [low, mid), has one
|
||||||
element and and the second, [mid, high), has two. We skip the
|
element and the second, [mid, high), has two. We skip the
|
||||||
optimisation when the number of elements is three or less as
|
optimisation when the number of elements is three or less as
|
||||||
the first compare in the normal merge will produce the same
|
the first compare in the normal merge will produce the same
|
||||||
sequence of steps. This optimisation seems to be worthwhile
|
sequence of steps. This optimisation seems to be worthwhile
|
||||||
|
@ -497,7 +497,7 @@ class ClassReader {
|
|||||||
code.max_locals >= TOO_BIG ||
|
code.max_locals >= TOO_BIG ||
|
||||||
code.getLength() >= TOO_BIG ||
|
code.getLength() >= TOO_BIG ||
|
||||||
name.endsWith("X")) {
|
name.endsWith("X")) {
|
||||||
// No, we don't really know what to do this this one.
|
// No, we don't really know what to do with this one.
|
||||||
// Do not compress the rare and strange "u4" and "X" cases.
|
// Do not compress the rare and strange "u4" and "X" cases.
|
||||||
a = null;
|
a = null;
|
||||||
}
|
}
|
||||||
|
@ -95,7 +95,7 @@ class Coding implements Comparable<Coding>, CodingMethod, Histogram.BitMetric {
|
|||||||
If S>0, the unsigned value of a byte sequence is regarded as a binary
|
If S>0, the unsigned value of a byte sequence is regarded as a binary
|
||||||
integer. If any of the S low-order bits are zero, the corresponding
|
integer. If any of the S low-order bits are zero, the corresponding
|
||||||
signed value will be non-negative. If all of the S low-order bits
|
signed value will be non-negative. If all of the S low-order bits
|
||||||
(S>0) are one, the the corresponding signed value will be negative.
|
(S>0) are one, the corresponding signed value will be negative.
|
||||||
|
|
||||||
The non-negative signed values are compact and monotonically increasing
|
The non-negative signed values are compact and monotonically increasing
|
||||||
(from 0) in the ordering of the corresponding unsigned values.
|
(from 0) in the ordering of the corresponding unsigned values.
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
package java.io;
|
package java.io;
|
||||||
|
|
||||||
import java.nio.channels.FileChannel;
|
import java.nio.channels.FileChannel;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import sun.nio.ch.FileChannelImpl;
|
import sun.nio.ch.FileChannelImpl;
|
||||||
|
|
||||||
|
|
||||||
@ -57,10 +58,9 @@ class FileInputStream extends InputStream
|
|||||||
*/
|
*/
|
||||||
private final String path;
|
private final String path;
|
||||||
|
|
||||||
private FileChannel channel = null;
|
private volatile FileChannel channel;
|
||||||
|
|
||||||
private final Object closeLock = new Object();
|
private final AtomicBoolean closed = new AtomicBoolean(false);
|
||||||
private volatile boolean closed = false;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a <code>FileInputStream</code> by
|
* Creates a <code>FileInputStream</code> by
|
||||||
@ -313,14 +313,14 @@ class FileInputStream extends InputStream
|
|||||||
* @spec JSR-51
|
* @spec JSR-51
|
||||||
*/
|
*/
|
||||||
public void close() throws IOException {
|
public void close() throws IOException {
|
||||||
synchronized (closeLock) {
|
if (!closed.compareAndSet(false, true)) {
|
||||||
if (closed) {
|
// if compareAndSet() returns false closed was already true
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
closed = true;
|
|
||||||
}
|
}
|
||||||
if (channel != null) {
|
|
||||||
channel.close();
|
FileChannel fc = channel;
|
||||||
|
if (fc != null) {
|
||||||
|
fc.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
fd.closeAll(new Closeable() {
|
fd.closeAll(new Closeable() {
|
||||||
@ -364,12 +364,23 @@ class FileInputStream extends InputStream
|
|||||||
* @spec JSR-51
|
* @spec JSR-51
|
||||||
*/
|
*/
|
||||||
public FileChannel getChannel() {
|
public FileChannel getChannel() {
|
||||||
synchronized (this) {
|
FileChannel fc = this.channel;
|
||||||
if (channel == null) {
|
if (fc == null) {
|
||||||
channel = FileChannelImpl.open(fd, path, true, false, this);
|
synchronized (this) {
|
||||||
|
fc = this.channel;
|
||||||
|
if (fc == null) {
|
||||||
|
this.channel = fc = FileChannelImpl.open(fd, path, true, false, this);
|
||||||
|
if (closed.get()) {
|
||||||
|
try {
|
||||||
|
fc.close();
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
throw new InternalError(ioe); // should not happen
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return channel;
|
|
||||||
}
|
}
|
||||||
|
return fc;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static native void initIDs();
|
private static native void initIDs();
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
package java.io;
|
package java.io;
|
||||||
|
|
||||||
import java.nio.channels.FileChannel;
|
import java.nio.channels.FileChannel;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import sun.misc.SharedSecrets;
|
import sun.misc.SharedSecrets;
|
||||||
import sun.misc.JavaIOFileDescriptorAccess;
|
import sun.misc.JavaIOFileDescriptorAccess;
|
||||||
import sun.nio.ch.FileChannelImpl;
|
import sun.nio.ch.FileChannelImpl;
|
||||||
@ -68,7 +69,7 @@ class FileOutputStream extends OutputStream
|
|||||||
/**
|
/**
|
||||||
* The associated channel, initialized lazily.
|
* The associated channel, initialized lazily.
|
||||||
*/
|
*/
|
||||||
private FileChannel channel;
|
private volatile FileChannel channel;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The path of the referenced file
|
* The path of the referenced file
|
||||||
@ -76,8 +77,7 @@ class FileOutputStream extends OutputStream
|
|||||||
*/
|
*/
|
||||||
private final String path;
|
private final String path;
|
||||||
|
|
||||||
private final Object closeLock = new Object();
|
private final AtomicBoolean closed = new AtomicBoolean(false);
|
||||||
private volatile boolean closed = false;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a file output stream to write to the file with the
|
* Creates a file output stream to write to the file with the
|
||||||
@ -341,15 +341,14 @@ class FileOutputStream extends OutputStream
|
|||||||
* @spec JSR-51
|
* @spec JSR-51
|
||||||
*/
|
*/
|
||||||
public void close() throws IOException {
|
public void close() throws IOException {
|
||||||
synchronized (closeLock) {
|
if (!closed.compareAndSet(false, true)) {
|
||||||
if (closed) {
|
// if compareAndSet() returns false closed was already true
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
closed = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (channel != null) {
|
FileChannel fc = channel;
|
||||||
channel.close();
|
if (fc != null) {
|
||||||
|
fc.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
fd.closeAll(new Closeable() {
|
fd.closeAll(new Closeable() {
|
||||||
@ -394,12 +393,23 @@ class FileOutputStream extends OutputStream
|
|||||||
* @spec JSR-51
|
* @spec JSR-51
|
||||||
*/
|
*/
|
||||||
public FileChannel getChannel() {
|
public FileChannel getChannel() {
|
||||||
synchronized (this) {
|
FileChannel fc = this.channel;
|
||||||
if (channel == null) {
|
if (fc == null) {
|
||||||
channel = FileChannelImpl.open(fd, path, false, true, this);
|
synchronized (this) {
|
||||||
|
fc = this.channel;
|
||||||
|
if (fc == null) {
|
||||||
|
this.channel = fc = FileChannelImpl.open(fd, path, false, true, this);
|
||||||
|
if (closed.get()) {
|
||||||
|
try {
|
||||||
|
fc.close();
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
throw new InternalError(ioe); // should not happen
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return channel;
|
|
||||||
}
|
}
|
||||||
|
return fc;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -25,6 +25,8 @@
|
|||||||
|
|
||||||
package java.io;
|
package java.io;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This abstract class is the superclass of all classes representing
|
* This abstract class is the superclass of all classes representing
|
||||||
* an input stream of bytes.
|
* an input stream of bytes.
|
||||||
@ -48,6 +50,8 @@ public abstract class InputStream implements Closeable {
|
|||||||
// use when skipping.
|
// use when skipping.
|
||||||
private static final int MAX_SKIP_BUFFER_SIZE = 2048;
|
private static final int MAX_SKIP_BUFFER_SIZE = 2048;
|
||||||
|
|
||||||
|
private static final int TRANSFER_BUFFER_SIZE = 8192;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reads the next byte of data from the input stream. The value byte is
|
* Reads the next byte of data from the input stream. The value byte is
|
||||||
* returned as an <code>int</code> in the range <code>0</code> to
|
* returned as an <code>int</code> in the range <code>0</code> to
|
||||||
@ -364,4 +368,40 @@ public abstract class InputStream implements Closeable {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reads all bytes from this input stream and writes the bytes to the
|
||||||
|
* given output stream in the order that they are read. On return, this
|
||||||
|
* input stream will be at end of stream. This method does not close either
|
||||||
|
* stream.
|
||||||
|
* <p>
|
||||||
|
* This method may block indefinitely reading from the input stream, or
|
||||||
|
* writing to the output stream. The behavior for the case where the input
|
||||||
|
* and/or output stream is <i>asynchronously closed</i>, or the thread
|
||||||
|
* interrupted during the transfer, is highly input and output stream
|
||||||
|
* specific, and therefore not specified.
|
||||||
|
* <p>
|
||||||
|
* If an I/O error occurs reading from the input stream or writing to the
|
||||||
|
* output stream, then it may do so after some bytes have been read or
|
||||||
|
* written. Consequently the input stream may not be at end of stream and
|
||||||
|
* one, or both, streams may be in an inconsistent state. It is strongly
|
||||||
|
* recommended that both streams be promptly closed if an I/O error occurs.
|
||||||
|
*
|
||||||
|
* @param out the output stream, non-null
|
||||||
|
* @return the number of bytes transferred
|
||||||
|
* @throws IOException if an I/O error occurs when reading or writing
|
||||||
|
* @throws NullPointerException if {@code out} is {@code null}
|
||||||
|
*
|
||||||
|
* @since 1.9
|
||||||
|
*/
|
||||||
|
public long transferTo(OutputStream out) throws IOException {
|
||||||
|
Objects.requireNonNull(out, "out");
|
||||||
|
long transferred = 0;
|
||||||
|
byte[] buffer = new byte[TRANSFER_BUFFER_SIZE];
|
||||||
|
int read;
|
||||||
|
while ((read = this.read(buffer, 0, TRANSFER_BUFFER_SIZE)) >= 0) {
|
||||||
|
out.write(buffer, 0, read);
|
||||||
|
transferred += read;
|
||||||
|
}
|
||||||
|
return transferred;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -2345,7 +2345,7 @@ public class ObjectInputStream
|
|||||||
skipped++;
|
skipped++;
|
||||||
n--;
|
n--;
|
||||||
}
|
}
|
||||||
return skipped + skip(n);
|
return skipped + in.skip(n);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int available() throws IOException {
|
public int available() throws IOException {
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
package java.io;
|
package java.io;
|
||||||
|
|
||||||
import java.nio.channels.FileChannel;
|
import java.nio.channels.FileChannel;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
import sun.nio.ch.FileChannelImpl;
|
import sun.nio.ch.FileChannelImpl;
|
||||||
|
|
||||||
|
|
||||||
@ -59,7 +60,7 @@ import sun.nio.ch.FileChannelImpl;
|
|||||||
public class RandomAccessFile implements DataOutput, DataInput, Closeable {
|
public class RandomAccessFile implements DataOutput, DataInput, Closeable {
|
||||||
|
|
||||||
private FileDescriptor fd;
|
private FileDescriptor fd;
|
||||||
private FileChannel channel = null;
|
private volatile FileChannel channel;
|
||||||
private boolean rw;
|
private boolean rw;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -68,8 +69,7 @@ public class RandomAccessFile implements DataOutput, DataInput, Closeable {
|
|||||||
*/
|
*/
|
||||||
private final String path;
|
private final String path;
|
||||||
|
|
||||||
private Object closeLock = new Object();
|
private final AtomicBoolean closed = new AtomicBoolean(false);
|
||||||
private volatile boolean closed = false;
|
|
||||||
|
|
||||||
private static final int O_RDONLY = 1;
|
private static final int O_RDONLY = 1;
|
||||||
private static final int O_RDWR = 2;
|
private static final int O_RDWR = 2;
|
||||||
@ -276,13 +276,24 @@ public class RandomAccessFile implements DataOutput, DataInput, Closeable {
|
|||||||
* @since 1.4
|
* @since 1.4
|
||||||
* @spec JSR-51
|
* @spec JSR-51
|
||||||
*/
|
*/
|
||||||
public final FileChannel getChannel() {
|
public FileChannel getChannel() {
|
||||||
synchronized (this) {
|
FileChannel fc = this.channel;
|
||||||
if (channel == null) {
|
if (fc == null) {
|
||||||
channel = FileChannelImpl.open(fd, path, true, rw, this);
|
synchronized (this) {
|
||||||
|
fc = this.channel;
|
||||||
|
if (fc == null) {
|
||||||
|
this.channel = fc = FileChannelImpl.open(fd, path, true, rw, this);
|
||||||
|
if (closed.get()) {
|
||||||
|
try {
|
||||||
|
fc.close();
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
throw new InternalError(ioe); // should not happen
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return channel;
|
|
||||||
}
|
}
|
||||||
|
return fc;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -604,14 +615,14 @@ public class RandomAccessFile implements DataOutput, DataInput, Closeable {
|
|||||||
* @spec JSR-51
|
* @spec JSR-51
|
||||||
*/
|
*/
|
||||||
public void close() throws IOException {
|
public void close() throws IOException {
|
||||||
synchronized (closeLock) {
|
if (!closed.compareAndSet(false, true)) {
|
||||||
if (closed) {
|
// if compareAndSet() returns false closed was already true
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
closed = true;
|
|
||||||
}
|
}
|
||||||
if (channel != null) {
|
|
||||||
channel.close();
|
FileChannel fc = channel;
|
||||||
|
if (fc != null) {
|
||||||
|
fc.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
fd.closeAll(new Closeable() {
|
fd.closeAll(new Closeable() {
|
||||||
|
@ -1529,7 +1529,7 @@ public final class Class<T> implements java.io.Serializable,
|
|||||||
* the accessible public fields of the class or interface represented by
|
* the accessible public fields of the class or interface represented by
|
||||||
* this {@code Class} object.
|
* this {@code Class} object.
|
||||||
*
|
*
|
||||||
* <p> If this {@code Class} object represents a class or interface with no
|
* <p> If this {@code Class} object represents a class or interface with
|
||||||
* no accessible public fields, then this method returns an array of length
|
* no accessible public fields, then this method returns an array of length
|
||||||
* 0.
|
* 0.
|
||||||
*
|
*
|
||||||
|
@ -162,7 +162,7 @@ public abstract class ClassValue<T> {
|
|||||||
* observe the time-dependent states as it computes {@code V1}, etc.
|
* observe the time-dependent states as it computes {@code V1}, etc.
|
||||||
* This does not remove the threat of a stale value, since there is a window of time
|
* This does not remove the threat of a stale value, since there is a window of time
|
||||||
* between the return of {@code computeValue} in {@code T} and the installation
|
* between the return of {@code computeValue} in {@code T} and the installation
|
||||||
* of the the new value. No user synchronization is possible during this time.
|
* of the new value. No user synchronization is possible during this time.
|
||||||
*
|
*
|
||||||
* @param type the type whose class value must be removed
|
* @param type the type whose class value must be removed
|
||||||
* @throws NullPointerException if the argument is null
|
* @throws NullPointerException if the argument is null
|
||||||
@ -285,7 +285,7 @@ public abstract class ClassValue<T> {
|
|||||||
* will receive the notification without delay.
|
* will receive the notification without delay.
|
||||||
* <p>
|
* <p>
|
||||||
* If version were not volatile, one thread T1 could persistently hold onto
|
* If version were not volatile, one thread T1 could persistently hold onto
|
||||||
* a stale value this.value == V1, while while another thread T2 advances
|
* a stale value this.value == V1, while another thread T2 advances
|
||||||
* (under a lock) to this.value == V2. This will typically be harmless,
|
* (under a lock) to this.value == V2. This will typically be harmless,
|
||||||
* but if T1 and T2 interact causally via some other channel, such that
|
* but if T1 and T2 interact causally via some other channel, such that
|
||||||
* T1's further actions are constrained (in the JMM) to happen after
|
* T1's further actions are constrained (in the JMM) to happen after
|
||||||
|
@ -840,7 +840,7 @@ public final class Integer extends Number implements Comparable<Integer> {
|
|||||||
/**
|
/**
|
||||||
* Parses the string argument as an unsigned decimal integer. The
|
* Parses the string argument as an unsigned decimal integer. The
|
||||||
* characters in the string must all be decimal digits, except
|
* characters in the string must all be decimal digits, except
|
||||||
* that the first character may be an an ASCII plus sign {@code
|
* that the first character may be an ASCII plus sign {@code
|
||||||
* '+'} ({@code '\u005Cu002B'}). The resulting integer value
|
* '+'} ({@code '\u005Cu002B'}). The resulting integer value
|
||||||
* is returned, exactly as if the argument and the radix 10 were
|
* is returned, exactly as if the argument and the radix 10 were
|
||||||
* given as arguments to the {@link
|
* given as arguments to the {@link
|
||||||
|
@ -971,7 +971,7 @@ public final class Long extends Number implements Comparable<Long> {
|
|||||||
/**
|
/**
|
||||||
* Parses the string argument as an unsigned decimal {@code long}. The
|
* Parses the string argument as an unsigned decimal {@code long}. The
|
||||||
* characters in the string must all be decimal digits, except
|
* characters in the string must all be decimal digits, except
|
||||||
* that the first character may be an an ASCII plus sign {@code
|
* that the first character may be an ASCII plus sign {@code
|
||||||
* '+'} ({@code '\u005Cu002B'}). The resulting integer value
|
* '+'} ({@code '\u005Cu002B'}). The resulting integer value
|
||||||
* is returned, exactly as if the argument and the radix 10 were
|
* is returned, exactly as if the argument and the radix 10 were
|
||||||
* given as arguments to the {@link
|
* given as arguments to the {@link
|
||||||
|
@ -2224,7 +2224,7 @@ public final class Math {
|
|||||||
* multiply-store result is subnormal, the next multiply will
|
* multiply-store result is subnormal, the next multiply will
|
||||||
* round it away to zero. This is done by first multiplying
|
* round it away to zero. This is done by first multiplying
|
||||||
* by 2 ^ (scaleFactor % n) and then multiplying several
|
* by 2 ^ (scaleFactor % n) and then multiplying several
|
||||||
* times by by 2^n as needed where n is the exponent of number
|
* times by 2^n as needed where n is the exponent of number
|
||||||
* that is a covenient power of two. In this way, at most one
|
* that is a covenient power of two. In this way, at most one
|
||||||
* real rounding error occurs. If the double value set is
|
* real rounding error occurs. If the double value set is
|
||||||
* being used exclusively, the rounding will occur on a
|
* being used exclusively, the rounding will occur on a
|
||||||
@ -2249,7 +2249,7 @@ public final class Math {
|
|||||||
|
|
||||||
// magnitude of a power of two so large that scaling a finite
|
// magnitude of a power of two so large that scaling a finite
|
||||||
// nonzero value by it would be guaranteed to over or
|
// nonzero value by it would be guaranteed to over or
|
||||||
// underflow; due to rounding, scaling down takes takes an
|
// underflow; due to rounding, scaling down takes an
|
||||||
// additional power of two which is reflected here
|
// additional power of two which is reflected here
|
||||||
final int MAX_SCALE = DoubleConsts.MAX_EXPONENT + -DoubleConsts.MIN_EXPONENT +
|
final int MAX_SCALE = DoubleConsts.MAX_EXPONENT + -DoubleConsts.MIN_EXPONENT +
|
||||||
DoubleConsts.SIGNIFICAND_WIDTH + 1;
|
DoubleConsts.SIGNIFICAND_WIDTH + 1;
|
||||||
@ -2318,7 +2318,7 @@ public final class Math {
|
|||||||
public static float scalb(float f, int scaleFactor) {
|
public static float scalb(float f, int scaleFactor) {
|
||||||
// magnitude of a power of two so large that scaling a finite
|
// magnitude of a power of two so large that scaling a finite
|
||||||
// nonzero value by it would be guaranteed to over or
|
// nonzero value by it would be guaranteed to over or
|
||||||
// underflow; due to rounding, scaling down takes takes an
|
// underflow; due to rounding, scaling down takes an
|
||||||
// additional power of two which is reflected here
|
// additional power of two which is reflected here
|
||||||
final int MAX_SCALE = FloatConsts.MAX_EXPONENT + -FloatConsts.MIN_EXPONENT +
|
final int MAX_SCALE = FloatConsts.MAX_EXPONENT + -FloatConsts.MIN_EXPONENT +
|
||||||
FloatConsts.SIGNIFICAND_WIDTH + 1;
|
FloatConsts.SIGNIFICAND_WIDTH + 1;
|
||||||
|
@ -750,7 +750,7 @@ public final class ProcessBuilder
|
|||||||
* {@link Process#getErrorStream()} will return a
|
* {@link Process#getErrorStream()} will return a
|
||||||
* <a href="#redirect-output">null input stream</a>.
|
* <a href="#redirect-output">null input stream</a>.
|
||||||
*
|
*
|
||||||
* <p>If the {@link #redirectErrorStream redirectErrorStream}
|
* <p>If the {@link #redirectErrorStream() redirectErrorStream}
|
||||||
* attribute has been set {@code true}, then the redirection set
|
* attribute has been set {@code true}, then the redirection set
|
||||||
* by this method has no effect.
|
* by this method has no effect.
|
||||||
*
|
*
|
||||||
|
@ -202,7 +202,7 @@ public class Throwable implements Serializable {
|
|||||||
* The field is initialized to a zero-length array. A {@code
|
* The field is initialized to a zero-length array. A {@code
|
||||||
* null} value of this field indicates subsequent calls to {@link
|
* null} value of this field indicates subsequent calls to {@link
|
||||||
* #setStackTrace(StackTraceElement[])} and {@link
|
* #setStackTrace(StackTraceElement[])} and {@link
|
||||||
* #fillInStackTrace()} will be be no-ops.
|
* #fillInStackTrace()} will be no-ops.
|
||||||
*
|
*
|
||||||
* @serial
|
* @serial
|
||||||
* @since 1.4
|
* @since 1.4
|
||||||
|
@ -116,7 +116,7 @@ class MethodType implements java.io.Serializable {
|
|||||||
/**
|
/**
|
||||||
* Construct a temporary unchecked instance of MethodType for use only as a key to the intern table.
|
* Construct a temporary unchecked instance of MethodType for use only as a key to the intern table.
|
||||||
* Does not check the given parameters for validity, and must be discarded after it is used as a searching key.
|
* Does not check the given parameters for validity, and must be discarded after it is used as a searching key.
|
||||||
* The parameters are reversed for this constructor, so that is is not accidentally used.
|
* The parameters are reversed for this constructor, so that it is not accidentally used.
|
||||||
*/
|
*/
|
||||||
private MethodType(Class<?>[] ptypes, Class<?> rtype) {
|
private MethodType(Class<?>[] ptypes, Class<?> rtype) {
|
||||||
this.rtype = rtype;
|
this.rtype = rtype;
|
||||||
@ -1006,7 +1006,7 @@ class MethodType implements java.io.Serializable {
|
|||||||
* Therefore, the number returned is the number of arguments
|
* Therefore, the number returned is the number of arguments
|
||||||
* <em>including</em> and <em>after</em> the given parameter,
|
* <em>including</em> and <em>after</em> the given parameter,
|
||||||
* <em>plus</em> the number of long or double arguments
|
* <em>plus</em> the number of long or double arguments
|
||||||
* at or after after the argument for the given parameter.
|
* at or after the argument for the given parameter.
|
||||||
* <p>
|
* <p>
|
||||||
* This method is included for the benefit of applications that must
|
* This method is included for the benefit of applications that must
|
||||||
* generate bytecodes that process method handles and invokedynamic.
|
* generate bytecodes that process method handles and invokedynamic.
|
||||||
|
@ -92,7 +92,7 @@ public interface DomainCombiner {
|
|||||||
* @param currentDomains the ProtectionDomains associated with the
|
* @param currentDomains the ProtectionDomains associated with the
|
||||||
* current execution Thread, up to the most recent
|
* current execution Thread, up to the most recent
|
||||||
* privileged {@code ProtectionDomain}.
|
* privileged {@code ProtectionDomain}.
|
||||||
* The ProtectionDomains are are listed in order of execution,
|
* The ProtectionDomains are listed in order of execution,
|
||||||
* with the most recently executing {@code ProtectionDomain}
|
* with the most recently executing {@code ProtectionDomain}
|
||||||
* residing at the beginning of the array. This parameter may
|
* residing at the beginning of the array. This parameter may
|
||||||
* be {@code null} if the current execution Thread
|
* be {@code null} if the current execution Thread
|
||||||
|
@ -1711,7 +1711,7 @@ public abstract class Provider extends Properties {
|
|||||||
*
|
*
|
||||||
* @param parameter the parameter to test
|
* @param parameter the parameter to test
|
||||||
*
|
*
|
||||||
* @return false if this this service cannot use the specified
|
* @return false if this service cannot use the specified
|
||||||
* parameter; true if it can possibly use the parameter
|
* parameter; true if it can possibly use the parameter
|
||||||
*
|
*
|
||||||
* @throws InvalidParameterException if the value of parameter is
|
* @throws InvalidParameterException if the value of parameter is
|
||||||
|
@ -776,7 +776,7 @@ public abstract class Signature extends SignatureSpi {
|
|||||||
/**
|
/**
|
||||||
* Updates the data to be signed or verified using the specified
|
* Updates the data to be signed or verified using the specified
|
||||||
* ByteBuffer. Processes the {@code data.remaining()} bytes
|
* ByteBuffer. Processes the {@code data.remaining()} bytes
|
||||||
* starting at at {@code data.position()}.
|
* starting at {@code data.position()}.
|
||||||
* Upon return, the buffer's position will be equal to its limit;
|
* Upon return, the buffer's position will be equal to its limit;
|
||||||
* its limit will not have changed.
|
* its limit will not have changed.
|
||||||
*
|
*
|
||||||
|
@ -131,7 +131,7 @@ public abstract class SignatureSpi {
|
|||||||
/**
|
/**
|
||||||
* Updates the data to be signed or verified using the specified
|
* Updates the data to be signed or verified using the specified
|
||||||
* ByteBuffer. Processes the {@code data.remaining()} bytes
|
* ByteBuffer. Processes the {@code data.remaining()} bytes
|
||||||
* starting at at {@code data.position()}.
|
* starting at {@code data.position()}.
|
||||||
* Upon return, the buffer's position will be equal to its limit;
|
* Upon return, the buffer's position will be equal to its limit;
|
||||||
* its limit will not have changed.
|
* its limit will not have changed.
|
||||||
*
|
*
|
||||||
|
@ -54,7 +54,7 @@ import java.security.*;
|
|||||||
*
|
*
|
||||||
* </ol>
|
* </ol>
|
||||||
*
|
*
|
||||||
* <p>Note: it is not always necessary to do do algorithm-specific
|
* <p>Note: it is not always necessary to do algorithm-specific
|
||||||
* initialization for a DSA key pair generator. That is, it is not always
|
* initialization for a DSA key pair generator. That is, it is not always
|
||||||
* necessary to call an {@code initialize} method in this interface.
|
* necessary to call an {@code initialize} method in this interface.
|
||||||
* Algorithm-independent initialization using the {@code initialize} method
|
* Algorithm-independent initialization using the {@code initialize} method
|
||||||
|
@ -1097,7 +1097,7 @@ public final class DateTimeFormatter {
|
|||||||
* This returns an immutable formatter capable of formatting and parsing
|
* This returns an immutable formatter capable of formatting and parsing
|
||||||
* the ISO-8601 instant format.
|
* the ISO-8601 instant format.
|
||||||
* When formatting, the second-of-minute is always output.
|
* When formatting, the second-of-minute is always output.
|
||||||
* The nano-of-second outputs zero, three, six or nine digits digits as necessary.
|
* The nano-of-second outputs zero, three, six or nine digits as necessary.
|
||||||
* When parsing, time to at least the seconds field is required.
|
* When parsing, time to at least the seconds field is required.
|
||||||
* Fractional seconds from zero to nine are parsed.
|
* Fractional seconds from zero to nine are parsed.
|
||||||
* The localized decimal style is not used.
|
* The localized decimal style is not used.
|
||||||
|
@ -793,7 +793,7 @@ public final class DateTimeFormatterBuilder {
|
|||||||
* They are converted to a date-time with a zone-offset of UTC and formatted
|
* They are converted to a date-time with a zone-offset of UTC and formatted
|
||||||
* using the standard ISO-8601 format.
|
* using the standard ISO-8601 format.
|
||||||
* With this method, formatting nano-of-second outputs zero, three, six
|
* With this method, formatting nano-of-second outputs zero, three, six
|
||||||
* or nine digits digits as necessary.
|
* or nine digits as necessary.
|
||||||
* The localized decimal style is not used.
|
* The localized decimal style is not used.
|
||||||
* <p>
|
* <p>
|
||||||
* The instant is obtained using {@link ChronoField#INSTANT_SECONDS INSTANT_SECONDS}
|
* The instant is obtained using {@link ChronoField#INSTANT_SECONDS INSTANT_SECONDS}
|
||||||
|
@ -1221,7 +1221,7 @@ public class Arrays {
|
|||||||
*
|
*
|
||||||
* <p>The implementation takes equal advantage of ascending and
|
* <p>The implementation takes equal advantage of ascending and
|
||||||
* descending order in its input array, and can take advantage of
|
* descending order in its input array, and can take advantage of
|
||||||
* ascending and descending order in different parts of the the same
|
* ascending and descending order in different parts of the same
|
||||||
* input array. It is well-suited to merging two or more sorted arrays:
|
* input array. It is well-suited to merging two or more sorted arrays:
|
||||||
* simply concatenate the arrays and sort the resulting array.
|
* simply concatenate the arrays and sort the resulting array.
|
||||||
*
|
*
|
||||||
@ -1280,7 +1280,7 @@ public class Arrays {
|
|||||||
*
|
*
|
||||||
* <p>The implementation takes equal advantage of ascending and
|
* <p>The implementation takes equal advantage of ascending and
|
||||||
* descending order in its input array, and can take advantage of
|
* descending order in its input array, and can take advantage of
|
||||||
* ascending and descending order in different parts of the the same
|
* ascending and descending order in different parts of the same
|
||||||
* input array. It is well-suited to merging two or more sorted arrays:
|
* input array. It is well-suited to merging two or more sorted arrays:
|
||||||
* simply concatenate the arrays and sort the resulting array.
|
* simply concatenate the arrays and sort the resulting array.
|
||||||
*
|
*
|
||||||
@ -1407,7 +1407,7 @@ public class Arrays {
|
|||||||
*
|
*
|
||||||
* <p>The implementation takes equal advantage of ascending and
|
* <p>The implementation takes equal advantage of ascending and
|
||||||
* descending order in its input array, and can take advantage of
|
* descending order in its input array, and can take advantage of
|
||||||
* ascending and descending order in different parts of the the same
|
* ascending and descending order in different parts of the same
|
||||||
* input array. It is well-suited to merging two or more sorted arrays:
|
* input array. It is well-suited to merging two or more sorted arrays:
|
||||||
* simply concatenate the arrays and sort the resulting array.
|
* simply concatenate the arrays and sort the resulting array.
|
||||||
*
|
*
|
||||||
@ -1473,7 +1473,7 @@ public class Arrays {
|
|||||||
*
|
*
|
||||||
* <p>The implementation takes equal advantage of ascending and
|
* <p>The implementation takes equal advantage of ascending and
|
||||||
* descending order in its input array, and can take advantage of
|
* descending order in its input array, and can take advantage of
|
||||||
* ascending and descending order in different parts of the the same
|
* ascending and descending order in different parts of the same
|
||||||
* input array. It is well-suited to merging two or more sorted arrays:
|
* input array. It is well-suited to merging two or more sorted arrays:
|
||||||
* simply concatenate the arrays and sort the resulting array.
|
* simply concatenate the arrays and sort the resulting array.
|
||||||
*
|
*
|
||||||
|
@ -556,7 +556,7 @@ public class Base64 {
|
|||||||
*
|
*
|
||||||
* <p> It is the responsibility of the invoker of this method to make
|
* <p> It is the responsibility of the invoker of this method to make
|
||||||
* sure the output byte array {@code dst} has enough space for decoding
|
* sure the output byte array {@code dst} has enough space for decoding
|
||||||
* all bytes from the input byte array. No bytes will be be written to
|
* all bytes from the input byte array. No bytes will be written to
|
||||||
* the output byte array if the output byte array is not big enough.
|
* the output byte array if the output byte array is not big enough.
|
||||||
*
|
*
|
||||||
* <p> If the input byte array is not in valid Base64 encoding scheme
|
* <p> If the input byte array is not in valid Base64 encoding scheme
|
||||||
|
@ -2993,7 +2993,7 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable<Ca
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the date of this {@code Calendar} with the the given date
|
* Sets the date of this {@code Calendar} with the given date
|
||||||
* specifiers - week year, week of year, and day of week.
|
* specifiers - week year, week of year, and day of week.
|
||||||
*
|
*
|
||||||
* <p>Unlike the {@code set} method, all of the calendar fields
|
* <p>Unlike the {@code set} method, all of the calendar fields
|
||||||
|
@ -95,7 +95,7 @@ import sun.util.locale.provider.ResourceBundleBasedAdapter;
|
|||||||
* <code>Locale</code> always canonicalizes to lower case.</dd>
|
* <code>Locale</code> always canonicalizes to lower case.</dd>
|
||||||
*
|
*
|
||||||
* <dd>Well-formed language values have the form
|
* <dd>Well-formed language values have the form
|
||||||
* <code>[a-zA-Z]{2,8}</code>. Note that this is not the the full
|
* <code>[a-zA-Z]{2,8}</code>. Note that this is not the full
|
||||||
* BCP47 language production, since it excludes extlang. They are
|
* BCP47 language production, since it excludes extlang. They are
|
||||||
* not needed since modern three-letter language codes replace
|
* not needed since modern three-letter language codes replace
|
||||||
* them.</dd>
|
* them.</dd>
|
||||||
@ -1691,7 +1691,7 @@ public final class Locale implements Cloneable, Serializable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a name for the the locale's script that is appropriate for display to
|
* Returns a name for the locale's script that is appropriate for display to
|
||||||
* the user. If possible, the name will be localized for the default
|
* the user. If possible, the name will be localized for the default
|
||||||
* {@link Locale.Category#DISPLAY DISPLAY} locale. Returns
|
* {@link Locale.Category#DISPLAY DISPLAY} locale. Returns
|
||||||
* the empty string if this locale doesn't specify a script code.
|
* the empty string if this locale doesn't specify a script code.
|
||||||
|
@ -994,7 +994,7 @@ public abstract class ResourceBundle {
|
|||||||
* bundle is found, the default control's {@link Control#getFallbackLocale
|
* bundle is found, the default control's {@link Control#getFallbackLocale
|
||||||
* getFallbackLocale} method is called, which returns the current default
|
* getFallbackLocale} method is called, which returns the current default
|
||||||
* locale. A new sequence of candidate locale names is generated using this
|
* locale. A new sequence of candidate locale names is generated using this
|
||||||
* locale and and searched again, as above.
|
* locale and searched again, as above.
|
||||||
*
|
*
|
||||||
* <p>If still no result bundle is found, the base name alone is looked up. If
|
* <p>If still no result bundle is found, the base name alone is looked up. If
|
||||||
* this still fails, a <code>MissingResourceException</code> is thrown.
|
* this still fails, a <code>MissingResourceException</code> is thrown.
|
||||||
|
@ -84,7 +84,7 @@ import java.util.function.LongConsumer;
|
|||||||
* via the {@link #estimateSize} method. Ideally, as reflected in characteristic
|
* via the {@link #estimateSize} method. Ideally, as reflected in characteristic
|
||||||
* {@link #SIZED}, this value corresponds exactly to the number of elements
|
* {@link #SIZED}, this value corresponds exactly to the number of elements
|
||||||
* that would be encountered in a successful traversal. However, even when not
|
* that would be encountered in a successful traversal. However, even when not
|
||||||
* exactly known, an estimated value value may still be useful to operations
|
* exactly known, an estimated value may still be useful to operations
|
||||||
* being performed on the source, such as helping to determine whether it is
|
* being performed on the source, such as helping to determine whether it is
|
||||||
* preferable to split further or traverse the remaining elements sequentially.
|
* preferable to split further or traverse the remaining elements sequentially.
|
||||||
*
|
*
|
||||||
|
@ -132,7 +132,7 @@ public final class Spliterators {
|
|||||||
* @param array The array, assumed to be unmodified during use
|
* @param array The array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @see Arrays#spliterator(Object[])
|
* @see Arrays#spliterator(Object[])
|
||||||
@ -164,7 +164,7 @@ public final class Spliterators {
|
|||||||
* @param toIndex One past the greatest index to cover
|
* @param toIndex One past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
||||||
@ -196,7 +196,7 @@ public final class Spliterators {
|
|||||||
* @param array The array, assumed to be unmodified during use
|
* @param array The array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @see Arrays#spliterator(int[])
|
* @see Arrays#spliterator(int[])
|
||||||
@ -226,7 +226,7 @@ public final class Spliterators {
|
|||||||
* @param toIndex One past the greatest index to cover
|
* @param toIndex One past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
||||||
@ -258,7 +258,7 @@ public final class Spliterators {
|
|||||||
* @param array The array, assumed to be unmodified during use
|
* @param array The array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @see Arrays#spliterator(long[])
|
* @see Arrays#spliterator(long[])
|
||||||
@ -282,7 +282,7 @@ public final class Spliterators {
|
|||||||
* {@code SIZED} and {@code SUBSIZED}. The caller may provide additional
|
* {@code SIZED} and {@code SUBSIZED}. The caller may provide additional
|
||||||
* characteristics for the spliterator to report. (For example, if it is
|
* characteristics for the spliterator to report. (For example, if it is
|
||||||
* known the array will not be further modified, specify {@code IMMUTABLE};
|
* known the array will not be further modified, specify {@code IMMUTABLE};
|
||||||
* if the array data is considered to have an an encounter order, specify
|
* if the array data is considered to have an encounter order, specify
|
||||||
* {@code ORDERED}). The method {@link Arrays#spliterator(long[], int, int)} can
|
* {@code ORDERED}). The method {@link Arrays#spliterator(long[], int, int)} can
|
||||||
* often be used instead, which returns a spliterator that reports
|
* often be used instead, which returns a spliterator that reports
|
||||||
* {@code SIZED}, {@code SUBSIZED}, {@code IMMUTABLE}, and {@code ORDERED}.
|
* {@code SIZED}, {@code SUBSIZED}, {@code IMMUTABLE}, and {@code ORDERED}.
|
||||||
@ -292,7 +292,7 @@ public final class Spliterators {
|
|||||||
* @param toIndex One past the greatest index to cover
|
* @param toIndex One past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
||||||
@ -324,7 +324,7 @@ public final class Spliterators {
|
|||||||
* @param array The array, assumed to be unmodified during use
|
* @param array The array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @see Arrays#spliterator(double[])
|
* @see Arrays#spliterator(double[])
|
||||||
@ -348,7 +348,7 @@ public final class Spliterators {
|
|||||||
* {@code SIZED} and {@code SUBSIZED}. The caller may provide additional
|
* {@code SIZED} and {@code SUBSIZED}. The caller may provide additional
|
||||||
* characteristics for the spliterator to report. (For example, if it is
|
* characteristics for the spliterator to report. (For example, if it is
|
||||||
* known the array will not be further modified, specify {@code IMMUTABLE};
|
* known the array will not be further modified, specify {@code IMMUTABLE};
|
||||||
* if the array data is considered to have an an encounter order, specify
|
* if the array data is considered to have an encounter order, specify
|
||||||
* {@code ORDERED}). The method {@link Arrays#spliterator(long[], int, int)} can
|
* {@code ORDERED}). The method {@link Arrays#spliterator(long[], int, int)} can
|
||||||
* often be used instead, which returns a spliterator that reports
|
* often be used instead, which returns a spliterator that reports
|
||||||
* {@code SIZED}, {@code SUBSIZED}, {@code IMMUTABLE}, and {@code ORDERED}.
|
* {@code SIZED}, {@code SUBSIZED}, {@code IMMUTABLE}, and {@code ORDERED}.
|
||||||
@ -358,7 +358,7 @@ public final class Spliterators {
|
|||||||
* @param toIndex One past the greatest index to cover
|
* @param toIndex One past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
* @return A spliterator for an array
|
* @return A spliterator for an array
|
||||||
* @throws NullPointerException if the given array is {@code null}
|
* @throws NullPointerException if the given array is {@code null}
|
||||||
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
* @throws ArrayIndexOutOfBoundsException if {@code fromIndex} is negative,
|
||||||
@ -907,7 +907,7 @@ public final class Spliterators {
|
|||||||
* @param array the array, assumed to be unmodified during use
|
* @param array the array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public ArraySpliterator(Object[] array, int additionalCharacteristics) {
|
public ArraySpliterator(Object[] array, int additionalCharacteristics) {
|
||||||
this(array, 0, array.length, additionalCharacteristics);
|
this(array, 0, array.length, additionalCharacteristics);
|
||||||
@ -920,7 +920,7 @@ public final class Spliterators {
|
|||||||
* @param fence one past the greatest index to cover
|
* @param fence one past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public ArraySpliterator(Object[] array, int origin, int fence, int additionalCharacteristics) {
|
public ArraySpliterator(Object[] array, int origin, int fence, int additionalCharacteristics) {
|
||||||
this.array = array;
|
this.array = array;
|
||||||
@ -992,7 +992,7 @@ public final class Spliterators {
|
|||||||
* @param array the array, assumed to be unmodified during use
|
* @param array the array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public IntArraySpliterator(int[] array, int additionalCharacteristics) {
|
public IntArraySpliterator(int[] array, int additionalCharacteristics) {
|
||||||
this(array, 0, array.length, additionalCharacteristics);
|
this(array, 0, array.length, additionalCharacteristics);
|
||||||
@ -1005,7 +1005,7 @@ public final class Spliterators {
|
|||||||
* @param fence one past the greatest index to cover
|
* @param fence one past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public IntArraySpliterator(int[] array, int origin, int fence, int additionalCharacteristics) {
|
public IntArraySpliterator(int[] array, int origin, int fence, int additionalCharacteristics) {
|
||||||
this.array = array;
|
this.array = array;
|
||||||
@ -1075,7 +1075,7 @@ public final class Spliterators {
|
|||||||
* @param array the array, assumed to be unmodified during use
|
* @param array the array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public LongArraySpliterator(long[] array, int additionalCharacteristics) {
|
public LongArraySpliterator(long[] array, int additionalCharacteristics) {
|
||||||
this(array, 0, array.length, additionalCharacteristics);
|
this(array, 0, array.length, additionalCharacteristics);
|
||||||
@ -1088,7 +1088,7 @@ public final class Spliterators {
|
|||||||
* @param fence one past the greatest index to cover
|
* @param fence one past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public LongArraySpliterator(long[] array, int origin, int fence, int additionalCharacteristics) {
|
public LongArraySpliterator(long[] array, int origin, int fence, int additionalCharacteristics) {
|
||||||
this.array = array;
|
this.array = array;
|
||||||
@ -1158,7 +1158,7 @@ public final class Spliterators {
|
|||||||
* @param array the array, assumed to be unmodified during use
|
* @param array the array, assumed to be unmodified during use
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public DoubleArraySpliterator(double[] array, int additionalCharacteristics) {
|
public DoubleArraySpliterator(double[] array, int additionalCharacteristics) {
|
||||||
this(array, 0, array.length, additionalCharacteristics);
|
this(array, 0, array.length, additionalCharacteristics);
|
||||||
@ -1171,7 +1171,7 @@ public final class Spliterators {
|
|||||||
* @param fence one past the greatest index to cover
|
* @param fence one past the greatest index to cover
|
||||||
* @param additionalCharacteristics Additional spliterator characteristics
|
* @param additionalCharacteristics Additional spliterator characteristics
|
||||||
* of this spliterator's source or elements beyond {@code SIZED} and
|
* of this spliterator's source or elements beyond {@code SIZED} and
|
||||||
* {@code SUBSIZED} which are are always reported
|
* {@code SUBSIZED} which are always reported
|
||||||
*/
|
*/
|
||||||
public DoubleArraySpliterator(double[] array, int origin, int fence, int additionalCharacteristics) {
|
public DoubleArraySpliterator(double[] array, int origin, int fence, int additionalCharacteristics) {
|
||||||
this.array = array;
|
this.array = array;
|
||||||
@ -1698,7 +1698,7 @@ public final class Spliterators {
|
|||||||
private int batch; // batch size for splits
|
private int batch; // batch size for splits
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a spliterator using the given given
|
* Creates a spliterator using the given
|
||||||
* collection's {@link java.util.Collection#iterator()) for traversal,
|
* collection's {@link java.util.Collection#iterator()) for traversal,
|
||||||
* and reporting its {@link java.util.Collection#size()) as its initial
|
* and reporting its {@link java.util.Collection#size()) as its initial
|
||||||
* size.
|
* size.
|
||||||
|
@ -43,9 +43,8 @@ import java.util.Locale;
|
|||||||
* supported by the Java runtime environment itself.
|
* supported by the Java runtime environment itself.
|
||||||
*
|
*
|
||||||
* <h3>Packaging of Locale Sensitive Service Provider Implementations</h3>
|
* <h3>Packaging of Locale Sensitive Service Provider Implementations</h3>
|
||||||
* Implementations of these locale sensitive services are packaged using the
|
* Implementations of these locale sensitive services can be made available
|
||||||
* <a href="../../../../technotes/guides/extensions/index.html">Java Extension Mechanism</a>
|
* by adding them to the application's class path. A provider identifies itself with a
|
||||||
* as installed extensions. A provider identifies itself with a
|
|
||||||
* provider-configuration file in the resource directory META-INF/services,
|
* provider-configuration file in the resource directory META-INF/services,
|
||||||
* using the fully qualified provider interface class name as the file name.
|
* using the fully qualified provider interface class name as the file name.
|
||||||
* The file should contain a list of fully-qualified concrete provider class names,
|
* The file should contain a list of fully-qualified concrete provider class names,
|
||||||
|
@ -204,7 +204,6 @@ public final class CRC32C implements Checksum {
|
|||||||
/**
|
/**
|
||||||
* Updates the CRC-32C checksum with the specified array of bytes.
|
* Updates the CRC-32C checksum with the specified array of bytes.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation") // Unsafe.{getInt, getLong}
|
|
||||||
private static int updateBytes(int crc, byte[] b, int off, int end) {
|
private static int updateBytes(int crc, byte[] b, int off, int end) {
|
||||||
|
|
||||||
// Do only byte reads for arrays so short they can't be aligned
|
// Do only byte reads for arrays so short they can't be aligned
|
||||||
@ -228,11 +227,11 @@ public final class CRC32C implements Checksum {
|
|||||||
int secondHalf;
|
int secondHalf;
|
||||||
if (Unsafe.ADDRESS_SIZE == 4) {
|
if (Unsafe.ADDRESS_SIZE == 4) {
|
||||||
// On 32 bit platforms read two ints instead of a single 64bit long
|
// On 32 bit platforms read two ints instead of a single 64bit long
|
||||||
firstHalf = UNSAFE.getInt(b, Unsafe.ARRAY_BYTE_BASE_OFFSET + off);
|
firstHalf = UNSAFE.getInt(b, (long)Unsafe.ARRAY_BYTE_BASE_OFFSET + off);
|
||||||
secondHalf = UNSAFE.getInt(b, Unsafe.ARRAY_BYTE_BASE_OFFSET + off
|
secondHalf = UNSAFE.getInt(b, (long)Unsafe.ARRAY_BYTE_BASE_OFFSET + off
|
||||||
+ Integer.BYTES);
|
+ Integer.BYTES);
|
||||||
} else {
|
} else {
|
||||||
long value = UNSAFE.getLong(b, Unsafe.ARRAY_BYTE_BASE_OFFSET + off);
|
long value = UNSAFE.getLong(b, (long)Unsafe.ARRAY_BYTE_BASE_OFFSET + off);
|
||||||
if (ByteOrder.nativeOrder() == ByteOrder.LITTLE_ENDIAN) {
|
if (ByteOrder.nativeOrder() == ByteOrder.LITTLE_ENDIAN) {
|
||||||
firstHalf = (int) value;
|
firstHalf = (int) value;
|
||||||
secondHalf = (int) (value >>> 32);
|
secondHalf = (int) (value >>> 32);
|
||||||
|
@ -76,7 +76,7 @@ import sun.security.util.Debug;
|
|||||||
* </pre>
|
* </pre>
|
||||||
*
|
*
|
||||||
* The CodeBase and Signedby components of the triplet name/value pairs
|
* The CodeBase and Signedby components of the triplet name/value pairs
|
||||||
* are optional. If they are not present, then any any codebase will match,
|
* are optional. If they are not present, then any codebase will match,
|
||||||
* and any signer (including unsigned code) will match.
|
* and any signer (including unsigned code) will match.
|
||||||
* For Example,
|
* For Example,
|
||||||
*
|
*
|
||||||
|
@ -137,7 +137,7 @@ public class SubjectDomainCombiner implements java.security.DomainCombiner {
|
|||||||
* @param currentDomains the ProtectionDomains associated with the
|
* @param currentDomains the ProtectionDomains associated with the
|
||||||
* current execution Thread, up to the most recent
|
* current execution Thread, up to the most recent
|
||||||
* privileged {@code ProtectionDomain}.
|
* privileged {@code ProtectionDomain}.
|
||||||
* The ProtectionDomains are are listed in order of execution,
|
* The ProtectionDomains are listed in order of execution,
|
||||||
* with the most recently executing {@code ProtectionDomain}
|
* with the most recently executing {@code ProtectionDomain}
|
||||||
* residing at the beginning of the array. This parameter may
|
* residing at the beginning of the array. This parameter may
|
||||||
* be {@code null} if the current execution Thread
|
* be {@code null} if the current execution Thread
|
||||||
|
@ -192,7 +192,7 @@ final class Frame {
|
|||||||
private static final int LOCAL = 0x2000000;
|
private static final int LOCAL = 0x2000000;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Kind of the the types that are relative to the stack of an input stack
|
* Kind of the types that are relative to the stack of an input stack
|
||||||
* map frame. The value of such types is a position relatively to the top of
|
* map frame. The value of such types is a position relatively to the top of
|
||||||
* this stack.
|
* this stack.
|
||||||
*/
|
*/
|
||||||
|
@ -116,7 +116,7 @@ public interface XMLStreamWriter {
|
|||||||
public void writeStartDocument() throws XMLStreamException;
|
public void writeStartDocument() throws XMLStreamException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Write the XML Declaration. Defaults the the encoding to utf-8
|
* Write the XML Declaration. Defaults the encoding to utf-8
|
||||||
* @param version version of the xml document
|
* @param version version of the xml document
|
||||||
* @throws XMLStreamException
|
* @throws XMLStreamException
|
||||||
*/
|
*/
|
||||||
|
@ -80,7 +80,7 @@ public class VerifyAccess {
|
|||||||
* @param defc the class in which the proposed member is actually defined
|
* @param defc the class in which the proposed member is actually defined
|
||||||
* @param mods modifier flags for the proposed member
|
* @param mods modifier flags for the proposed member
|
||||||
* @param lookupClass the class for which the access check is being made
|
* @param lookupClass the class for which the access check is being made
|
||||||
* @return true iff the the accessing class can access such a member
|
* @return true iff the accessing class can access such a member
|
||||||
*/
|
*/
|
||||||
public static boolean isMemberAccessible(Class<?> refc, // symbolic ref class
|
public static boolean isMemberAccessible(Class<?> refc, // symbolic ref class
|
||||||
Class<?> defc, // actual def class
|
Class<?> defc, // actual def class
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2007, 2013, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2007, 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
|
||||||
@ -46,11 +46,7 @@ java.launcher.opt.footer =\ -cp <class search path of directories and zip
|
|||||||
\ -verbose:[class|gc|jni]\n\
|
\ -verbose:[class|gc|jni]\n\
|
||||||
\ enable verbose output\n\
|
\ enable verbose output\n\
|
||||||
\ -version print product version and exit\n\
|
\ -version print product version and exit\n\
|
||||||
\ -version:<value>\n\
|
|
||||||
\ require the specified version to run\n\
|
|
||||||
\ -showversion print product version and continue\n\
|
\ -showversion print product version and continue\n\
|
||||||
\ -jre-restrict-search | -no-jre-restrict-search\n\
|
|
||||||
\ include/exclude user private JREs in the version search\n\
|
|
||||||
\ -? -help print this help message\n\
|
\ -? -help print this help message\n\
|
||||||
\ -X print help on non-standard options\n\
|
\ -X print help on non-standard options\n\
|
||||||
\ -ea[:<packagename>...|:<classname>]\n\
|
\ -ea[:<packagename>...|:<classname>]\n\
|
||||||
|
@ -42,7 +42,7 @@ public interface JavaNioAccess {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a direct ByteBuffer referring to the block of memory starting
|
* Constructs a direct ByteBuffer referring to the block of memory starting
|
||||||
* at the given memory address and and extending {@code cap} bytes.
|
* at the given memory address and extending {@code cap} bytes.
|
||||||
* The {@code ob} parameter is an arbitrary object that is attached
|
* The {@code ob} parameter is an arbitrary object that is attached
|
||||||
* to the resulting buffer.
|
* to the resulting buffer.
|
||||||
*/
|
*/
|
||||||
|
@ -958,6 +958,8 @@ public final class Unsafe {
|
|||||||
* other threads. This method is generally only useful if the
|
* other threads. This method is generally only useful if the
|
||||||
* underlying field is a Java volatile (or if an array cell, one
|
* underlying field is a Java volatile (or if an array cell, one
|
||||||
* that is otherwise only accessed using volatile accesses).
|
* that is otherwise only accessed using volatile accesses).
|
||||||
|
*
|
||||||
|
* Corresponds to C11 atomic_store_explicit(..., memory_order_release).
|
||||||
*/
|
*/
|
||||||
public native void putOrderedObject(Object o, long offset, Object x);
|
public native void putOrderedObject(Object o, long offset, Object x);
|
||||||
|
|
||||||
@ -1111,22 +1113,40 @@ public final class Unsafe {
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensures lack of reordering of loads before the fence
|
* Ensures that loads before the fence will not be reordered with loads and
|
||||||
* with loads or stores after the fence.
|
* stores after the fence; a "LoadLoad plus LoadStore barrier".
|
||||||
|
*
|
||||||
|
* Corresponds to C11 atomic_thread_fence(memory_order_acquire)
|
||||||
|
* (an "acquire fence").
|
||||||
|
*
|
||||||
|
* A pure LoadLoad fence is not provided, since the addition of LoadStore
|
||||||
|
* is almost always desired, and most current hardware instructions that
|
||||||
|
* provide a LoadLoad barrier also provide a LoadStore barrier for free.
|
||||||
* @since 1.8
|
* @since 1.8
|
||||||
*/
|
*/
|
||||||
public native void loadFence();
|
public native void loadFence();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensures lack of reordering of stores before the fence
|
* Ensures that loads and stores before the fence will not be reordered with
|
||||||
* with loads or stores after the fence.
|
* stores after the fence; a "StoreStore plus LoadStore barrier".
|
||||||
|
*
|
||||||
|
* Corresponds to C11 atomic_thread_fence(memory_order_release)
|
||||||
|
* (a "release fence").
|
||||||
|
*
|
||||||
|
* A pure StoreStore fence is not provided, since the addition of LoadStore
|
||||||
|
* is almost always desired, and most current hardware instructions that
|
||||||
|
* provide a StoreStore barrier also provide a LoadStore barrier for free.
|
||||||
* @since 1.8
|
* @since 1.8
|
||||||
*/
|
*/
|
||||||
public native void storeFence();
|
public native void storeFence();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensures lack of reordering of loads or stores before the fence
|
* Ensures that loads and stores before the fence will not be reordered
|
||||||
* with loads or stores after the fence.
|
* with loads and stores after the fence. Implies the effects of both
|
||||||
|
* loadFence() and storeFence(), and in addition, the effect of a StoreLoad
|
||||||
|
* barrier.
|
||||||
|
*
|
||||||
|
* Corresponds to C11 atomic_thread_fence(memory_order_seq_cst).
|
||||||
* @since 1.8
|
* @since 1.8
|
||||||
*/
|
*/
|
||||||
public native void fullFence();
|
public native void fullFence();
|
||||||
|
@ -150,7 +150,7 @@ public class VM {
|
|||||||
private static volatile boolean booted = false;
|
private static volatile boolean booted = false;
|
||||||
private static final Object lock = new Object();
|
private static final Object lock = new Object();
|
||||||
|
|
||||||
// Invoked by by System.initializeSystemClass just before returning.
|
// Invoked by System.initializeSystemClass just before returning.
|
||||||
// Subsystems that are invoked during initialization can check this
|
// Subsystems that are invoked during initialization can check this
|
||||||
// property in order to avoid doing things that should wait until the
|
// property in order to avoid doing things that should wait until the
|
||||||
// application class loader has been set up.
|
// application class loader has been set up.
|
||||||
|
@ -2187,7 +2187,7 @@ public class FtpClient extends sun.net.ftp.FtpClient {
|
|||||||
return resp.get(0).substring(4);
|
return resp.get(0).substring(4);
|
||||||
}
|
}
|
||||||
// on multiple lines answers, like the ones above, remove 1st and last
|
// on multiple lines answers, like the ones above, remove 1st and last
|
||||||
// line, concat the the others.
|
// line, concat the others.
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
for (int i = 1; i < resp.size() - 1; i++) {
|
for (int i = 1; i < resp.size() - 1; i++) {
|
||||||
sb.append(resp.get(i).substring(3));
|
sb.append(resp.get(i).substring(3));
|
||||||
|
@ -110,6 +110,9 @@ public class FileChannelImpl
|
|||||||
// -- Standard channel operations --
|
// -- Standard channel operations --
|
||||||
|
|
||||||
protected void implCloseChannel() throws IOException {
|
protected void implCloseChannel() throws IOException {
|
||||||
|
if (!fd.valid())
|
||||||
|
return; // nothing to do
|
||||||
|
|
||||||
// Release and invalidate any locks that we still hold
|
// Release and invalidate any locks that we still hold
|
||||||
if (fileLockTable != null) {
|
if (fileLockTable != null) {
|
||||||
for (FileLock fl: fileLockTable.removeAll()) {
|
for (FileLock fl: fileLockTable.removeAll()) {
|
||||||
|
@ -52,7 +52,7 @@ class Label {
|
|||||||
final short patchBCI;
|
final short patchBCI;
|
||||||
final int stackDepth;
|
final int stackDepth;
|
||||||
}
|
}
|
||||||
private List<PatchInfo> patches = new ArrayList<>();
|
private final List<PatchInfo> patches = new ArrayList<>();
|
||||||
|
|
||||||
public Label() {
|
public Label() {
|
||||||
}
|
}
|
||||||
|
@ -135,7 +135,7 @@ public class ReflectionFactory {
|
|||||||
* be initialized and therefore must not be called until the
|
* be initialized and therefore must not be called until the
|
||||||
* first get/set of this field.
|
* first get/set of this field.
|
||||||
* @param field the field
|
* @param field the field
|
||||||
* @param override true if caller has overridden aaccessibility
|
* @param override true if caller has overridden accessibility
|
||||||
*/
|
*/
|
||||||
public FieldAccessor newFieldAccessor(Field field, boolean override) {
|
public FieldAccessor newFieldAccessor(Field field, boolean override) {
|
||||||
checkInitted();
|
checkInitted();
|
||||||
|
@ -280,19 +280,25 @@ class AnnotationInvocationHandler implements InvocationHandler, Serializable {
|
|||||||
* be rare).
|
* be rare).
|
||||||
*/
|
*/
|
||||||
private Method[] getMemberMethods() {
|
private Method[] getMemberMethods() {
|
||||||
if (memberMethods == null) {
|
Method[] value = memberMethods;
|
||||||
memberMethods = AccessController.doPrivileged(
|
if (value == null) {
|
||||||
new PrivilegedAction<Method[]>() {
|
value = computeMemberMethods();
|
||||||
public Method[] run() {
|
memberMethods = value;
|
||||||
final Method[] mm = type.getDeclaredMethods();
|
|
||||||
validateAnnotationMethods(mm);
|
|
||||||
AccessibleObject.setAccessible(mm, true);
|
|
||||||
return mm;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
return memberMethods;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Method[] computeMemberMethods() {
|
||||||
|
return AccessController.doPrivileged(
|
||||||
|
new PrivilegedAction<Method[]>() {
|
||||||
|
public Method[] run() {
|
||||||
|
final Method[] methods = type.getDeclaredMethods();
|
||||||
|
validateAnnotationMethods(methods);
|
||||||
|
AccessibleObject.setAccessible(methods, true);
|
||||||
|
return methods;
|
||||||
|
}});
|
||||||
|
}
|
||||||
|
|
||||||
private transient volatile Method[] memberMethods = null;
|
private transient volatile Method[] memberMethods = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -772,7 +772,7 @@ public class AnnotationParser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return an appropriate exception proxy for a mismatching array
|
* Returns an appropriate exception proxy for a mismatching array
|
||||||
* annotation where the erroneous array has the specified tag.
|
* annotation where the erroneous array has the specified tag.
|
||||||
*/
|
*/
|
||||||
private static ExceptionProxy exceptionProxy(int tag) {
|
private static ExceptionProxy exceptionProxy(int tag) {
|
||||||
|
@ -115,7 +115,7 @@ public final class AnnotationSupport {
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Figures out if conatiner class comes before containee class among the
|
* Figures out if container class comes before containee class among the
|
||||||
* keys of the given map.
|
* keys of the given map.
|
||||||
*
|
*
|
||||||
* @return true if container class is found before containee class when
|
* @return true if container class is found before containee class when
|
||||||
|
@ -55,7 +55,7 @@ public class AnnotationType {
|
|||||||
private final Map<String, Object> memberDefaults;
|
private final Map<String, Object> memberDefaults;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Member name -> Method object mapping. This (and its assoicated
|
* Member name -> Method object mapping. This (and its associated
|
||||||
* accessor) are used only to generate AnnotationTypeMismatchExceptions.
|
* accessor) are used only to generate AnnotationTypeMismatchExceptions.
|
||||||
*/
|
*/
|
||||||
private final Map<String, Method> members;
|
private final Map<String, Method> members;
|
||||||
@ -117,7 +117,7 @@ public class AnnotationType {
|
|||||||
memberDefaults = new HashMap<String, Object>(0);
|
memberDefaults = new HashMap<String, Object>(0);
|
||||||
members = new HashMap<String, Method>(methods.length+1, 1.0f);
|
members = new HashMap<String, Method>(methods.length+1, 1.0f);
|
||||||
|
|
||||||
for (Method method : methods) {
|
for (Method method : methods) {
|
||||||
if (method.getParameterTypes().length != 0)
|
if (method.getParameterTypes().length != 0)
|
||||||
throw new IllegalArgumentException(method + " has params");
|
throw new IllegalArgumentException(method + " has params");
|
||||||
String name = method.getName();
|
String name = method.getName();
|
||||||
@ -213,7 +213,7 @@ public class AnnotationType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true if this this annotation type is inherited.
|
* Returns true if this annotation type is inherited.
|
||||||
*/
|
*/
|
||||||
public boolean isInherited() {
|
public boolean isInherited() {
|
||||||
return inherited;
|
return inherited;
|
||||||
|
@ -36,7 +36,7 @@ import java.lang.reflect.Method;
|
|||||||
class AnnotationTypeMismatchExceptionProxy extends ExceptionProxy {
|
class AnnotationTypeMismatchExceptionProxy extends ExceptionProxy {
|
||||||
private static final long serialVersionUID = 7844069490309503934L;
|
private static final long serialVersionUID = 7844069490309503934L;
|
||||||
private Method member;
|
private Method member;
|
||||||
private String foundType;
|
private final String foundType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* It turns out to be convenient to construct these proxies in
|
* It turns out to be convenient to construct these proxies in
|
||||||
|
@ -33,8 +33,8 @@ package sun.reflect.annotation;
|
|||||||
*/
|
*/
|
||||||
public class EnumConstantNotPresentExceptionProxy extends ExceptionProxy {
|
public class EnumConstantNotPresentExceptionProxy extends ExceptionProxy {
|
||||||
private static final long serialVersionUID = -604662101303187330L;
|
private static final long serialVersionUID = -604662101303187330L;
|
||||||
Class<? extends Enum<?>> enumType;
|
final Class<? extends Enum<?>> enumType;
|
||||||
String constName;
|
final String constName;
|
||||||
|
|
||||||
public EnumConstantNotPresentExceptionProxy(Class<? extends Enum<?>> enumType,
|
public EnumConstantNotPresentExceptionProxy(Class<? extends Enum<?>> enumType,
|
||||||
String constName) {
|
String constName) {
|
||||||
|
@ -34,8 +34,8 @@ import java.lang.annotation.*;
|
|||||||
*/
|
*/
|
||||||
public class TypeNotPresentExceptionProxy extends ExceptionProxy {
|
public class TypeNotPresentExceptionProxy extends ExceptionProxy {
|
||||||
private static final long serialVersionUID = 5565925172427947573L;
|
private static final long serialVersionUID = 5565925172427947573L;
|
||||||
String typeName;
|
final String typeName;
|
||||||
Throwable cause;
|
final Throwable cause;
|
||||||
|
|
||||||
public TypeNotPresentExceptionProxy(String typeName, Throwable cause) {
|
public TypeNotPresentExceptionProxy(String typeName, Throwable cause) {
|
||||||
this.typeName = typeName;
|
this.typeName = typeName;
|
||||||
|
@ -76,11 +76,11 @@ public class CoreReflectionFactory implements GenericsFactory {
|
|||||||
* kind. Classes produced will be those that would be loaded by the
|
* kind. Classes produced will be those that would be loaded by the
|
||||||
* defining class loader of the declaration <tt>d</tt> (if <tt>d</tt>
|
* defining class loader of the declaration <tt>d</tt> (if <tt>d</tt>
|
||||||
* is a type declaration, or by the defining loader of the declaring
|
* is a type declaration, or by the defining loader of the declaring
|
||||||
* class of <tt>d</tt> otherwise.
|
* class of <tt>d</tt> otherwise.
|
||||||
* <p> Type variables will be created or lookup as necessary in the
|
* <p> Type variables will be created or lookup as necessary in the
|
||||||
* scope <tt> s</tt>.
|
* scope <tt> s</tt>.
|
||||||
* @param d - the generic declaration (class, interface, method or
|
* @param d - the generic declaration (class, interface, method or
|
||||||
* constructor) that thsi factory services
|
* constructor) that this factory services
|
||||||
* @param s the scope in which the factory will allocate and search for
|
* @param s the scope in which the factory will allocate and search for
|
||||||
* type variables
|
* type variables
|
||||||
* @return an instance of <tt>CoreReflectionFactory</tt>
|
* @return an instance of <tt>CoreReflectionFactory</tt>
|
||||||
|
@ -42,7 +42,7 @@ import sun.reflect.generics.tree.FieldTypeSignature;
|
|||||||
* of a specific implementation by using this interface. For example,
|
* of a specific implementation by using this interface. For example,
|
||||||
* repositories of generic type information are initialized with a
|
* repositories of generic type information are initialized with a
|
||||||
* factory conforming to this interface, and use it to generate the
|
* factory conforming to this interface, and use it to generate the
|
||||||
* tpe information they are required to provide. As a result, such
|
* type information they are required to provide. As a result, such
|
||||||
* repository code can be shared across different reflective systems.
|
* repository code can be shared across different reflective systems.
|
||||||
*/
|
*/
|
||||||
public interface GenericsFactory {
|
public interface GenericsFactory {
|
||||||
@ -60,7 +60,7 @@ public interface GenericsFactory {
|
|||||||
TypeVariable<?> makeTypeVariable(String name,
|
TypeVariable<?> makeTypeVariable(String name,
|
||||||
FieldTypeSignature[] bounds);
|
FieldTypeSignature[] bounds);
|
||||||
/**
|
/**
|
||||||
* Return an instance of the <tt>ParameterizedType</tt> interface
|
* Returns an instance of the <tt>ParameterizedType</tt> interface
|
||||||
* that corresponds to a generic type instantiation of the
|
* that corresponds to a generic type instantiation of the
|
||||||
* generic declaration <tt>declaration</tt> with actual type arguments
|
* generic declaration <tt>declaration</tt> with actual type arguments
|
||||||
* <tt>typeArgs</tt>.
|
* <tt>typeArgs</tt>.
|
||||||
@ -123,7 +123,7 @@ public interface GenericsFactory {
|
|||||||
/**
|
/**
|
||||||
* Returns a (possibly generic) array type.
|
* Returns a (possibly generic) array type.
|
||||||
* If the component type is a parameterized type, it must
|
* If the component type is a parameterized type, it must
|
||||||
* only have unbounded wildcard arguemnts, otherwise
|
* only have unbounded wildcard arguments, otherwise
|
||||||
* a MalformedParameterizedTypeException is thrown.
|
* a MalformedParameterizedTypeException is thrown.
|
||||||
* @param componentType - the component type of the array
|
* @param componentType - the component type of the array
|
||||||
* @return a (possibly generic) array type.
|
* @return a (possibly generic) array type.
|
||||||
|
@ -227,7 +227,7 @@ public class SignatureParser {
|
|||||||
* "<" FormalTypeParameter+ ">"
|
* "<" FormalTypeParameter+ ">"
|
||||||
*/
|
*/
|
||||||
private FormalTypeParameter[] parseFormalTypeParameters(){
|
private FormalTypeParameter[] parseFormalTypeParameters(){
|
||||||
List<FormalTypeParameter> ftps = new ArrayList<>(3);
|
List<FormalTypeParameter> ftps = new ArrayList<>(3);
|
||||||
assert(current() == '<'); // should not have been called at all
|
assert(current() == '<'); // should not have been called at all
|
||||||
if (current() != '<') { throw error("expected '<'");}
|
if (current() != '<') { throw error("expected '<'");}
|
||||||
advance();
|
advance();
|
||||||
|
@ -53,10 +53,10 @@ public class GenericArrayTypeImpl
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a <tt>Type</tt> object representing the component type
|
* Returns a <tt>Type</tt> object representing the component type
|
||||||
* of this array.
|
* of this array.
|
||||||
*
|
*
|
||||||
* @return a <tt>Type</tt> object representing the component type
|
* @return a <tt>Type</tt> object representing the component type
|
||||||
* of this array
|
* of this array
|
||||||
* @since 1.5
|
* @since 1.5
|
||||||
*/
|
*/
|
||||||
|
@ -25,7 +25,9 @@
|
|||||||
|
|
||||||
package sun.reflect.generics.reflectiveObjects;
|
package sun.reflect.generics.reflectiveObjects;
|
||||||
|
|
||||||
|
import java.lang.reflect.Type;
|
||||||
import sun.reflect.generics.factory.GenericsFactory;
|
import sun.reflect.generics.factory.GenericsFactory;
|
||||||
|
import sun.reflect.generics.tree.FieldTypeSignature;
|
||||||
import sun.reflect.generics.visitor.Reifier;
|
import sun.reflect.generics.visitor.Reifier;
|
||||||
|
|
||||||
|
|
||||||
@ -54,4 +56,16 @@ public abstract class LazyReflectiveObjectGenerator {
|
|||||||
// produce a reifying visitor (could this be typed as a TypeTreeVisitor?
|
// produce a reifying visitor (could this be typed as a TypeTreeVisitor?
|
||||||
protected Reifier getReifier(){return Reifier.make(getFactory());}
|
protected Reifier getReifier(){return Reifier.make(getFactory());}
|
||||||
|
|
||||||
|
Type[] reifyBounds(FieldTypeSignature[] boundASTs) {
|
||||||
|
final int length = boundASTs.length;
|
||||||
|
final Type[] bounds = new Type[length];
|
||||||
|
// iterate over bound trees, reifying each in turn
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
Reifier r = getReifier();
|
||||||
|
boundASTs[i].accept(r);
|
||||||
|
bounds[i] = r.getResult();
|
||||||
|
}
|
||||||
|
return bounds;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -51,17 +51,16 @@ import sun.reflect.misc.ReflectUtil;
|
|||||||
*/
|
*/
|
||||||
public class TypeVariableImpl<D extends GenericDeclaration>
|
public class TypeVariableImpl<D extends GenericDeclaration>
|
||||||
extends LazyReflectiveObjectGenerator implements TypeVariable<D> {
|
extends LazyReflectiveObjectGenerator implements TypeVariable<D> {
|
||||||
D genericDeclaration;
|
private final D genericDeclaration;
|
||||||
private String name;
|
private final String name;
|
||||||
// upper bounds - evaluated lazily
|
|
||||||
private Type[] bounds;
|
|
||||||
|
|
||||||
// The ASTs for the bounds. We are required to evaluate the bounds
|
/**
|
||||||
// lazily, so we store these at least until we are first asked
|
* The upper bounds. Lazily converted from FieldTypeSignature[] to Type[].
|
||||||
// for the bounds. This also neatly solves the
|
* We are required to evaluate the bounds lazily, so we store them as ASTs
|
||||||
// problem with F-bounds - you can't reify them before the formal
|
* until we are first asked for them. This also neatly solves the problem
|
||||||
// is defined.
|
* with F-bounds - you can't reify them before the formal is defined.
|
||||||
private FieldTypeSignature[] boundASTs;
|
*/
|
||||||
|
private volatile Object[] bounds;
|
||||||
|
|
||||||
// constructor is private to enforce access through static factory
|
// constructor is private to enforce access through static factory
|
||||||
private TypeVariableImpl(D decl, String n, FieldTypeSignature[] bs,
|
private TypeVariableImpl(D decl, String n, FieldTypeSignature[] bs,
|
||||||
@ -69,18 +68,7 @@ public class TypeVariableImpl<D extends GenericDeclaration>
|
|||||||
super(f);
|
super(f);
|
||||||
genericDeclaration = decl;
|
genericDeclaration = decl;
|
||||||
name = n;
|
name = n;
|
||||||
boundASTs = bs;
|
bounds = bs;
|
||||||
}
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
|
|
||||||
// accessor for ASTs for bounds. Must not be called after
|
|
||||||
// bounds have been evaluated, because we might throw the ASTs
|
|
||||||
// away (but that is not thread-safe, is it?)
|
|
||||||
private FieldTypeSignature[] getBoundASTs() {
|
|
||||||
// check that bounds were not evaluated yet
|
|
||||||
assert(bounds == null);
|
|
||||||
return boundASTs;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -123,7 +111,7 @@ public class TypeVariableImpl<D extends GenericDeclaration>
|
|||||||
* <li>Otherwise, B is resolved.
|
* <li>Otherwise, B is resolved.
|
||||||
* </ul>
|
* </ul>
|
||||||
*
|
*
|
||||||
* @throws <tt>TypeNotPresentException</tt> if any of the
|
* @throws <tt>TypeNotPresentException</tt> if any of the
|
||||||
* bounds refers to a non-existent type declaration
|
* bounds refers to a non-existent type declaration
|
||||||
* @throws <tt>MalformedParameterizedTypeException</tt> if any of the
|
* @throws <tt>MalformedParameterizedTypeException</tt> if any of the
|
||||||
* bounds refer to a parameterized type that cannot be instantiated
|
* bounds refer to a parameterized type that cannot be instantiated
|
||||||
@ -132,34 +120,23 @@ public class TypeVariableImpl<D extends GenericDeclaration>
|
|||||||
* type variable
|
* type variable
|
||||||
*/
|
*/
|
||||||
public Type[] getBounds() {
|
public Type[] getBounds() {
|
||||||
// lazily initialize bounds if necessary
|
Object[] value = bounds;
|
||||||
if (bounds == null) {
|
if (value instanceof FieldTypeSignature[]) {
|
||||||
FieldTypeSignature[] fts = getBoundASTs(); // get AST
|
value = reifyBounds((FieldTypeSignature[])value);
|
||||||
// allocate result array; note that
|
bounds = value;
|
||||||
// keeping ts and bounds separate helps with threads
|
|
||||||
Type[] ts = new Type[fts.length];
|
|
||||||
// iterate over bound trees, reifying each in turn
|
|
||||||
for ( int j = 0; j < fts.length; j++) {
|
|
||||||
Reifier r = getReifier();
|
|
||||||
fts[j].accept(r);
|
|
||||||
ts[j] = r.getResult();
|
|
||||||
}
|
|
||||||
// cache result
|
|
||||||
bounds = ts;
|
|
||||||
// could throw away bound ASTs here; thread safety?
|
|
||||||
}
|
}
|
||||||
return bounds.clone(); // return cached bounds
|
return (Type[])value.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the <tt>GenericDeclaration</tt> object representing the
|
* Returns the <tt>GenericDeclaration</tt> object representing the
|
||||||
* generic declaration that declared this type variable.
|
* generic declaration that declared this type variable.
|
||||||
*
|
*
|
||||||
* @return the generic declaration that declared this type variable.
|
* @return the generic declaration that declared this type variable.
|
||||||
*
|
*
|
||||||
* @since 1.5
|
* @since 1.5
|
||||||
*/
|
*/
|
||||||
public D getGenericDeclaration(){
|
public D getGenericDeclaration() {
|
||||||
if (genericDeclaration instanceof Class)
|
if (genericDeclaration instanceof Class)
|
||||||
ReflectUtil.checkPackageAccess((Class)genericDeclaration);
|
ReflectUtil.checkPackageAccess((Class)genericDeclaration);
|
||||||
else if ((genericDeclaration instanceof Method) ||
|
else if ((genericDeclaration instanceof Method) ||
|
||||||
|
@ -39,25 +39,26 @@ import java.util.Arrays;
|
|||||||
*/
|
*/
|
||||||
public class WildcardTypeImpl extends LazyReflectiveObjectGenerator
|
public class WildcardTypeImpl extends LazyReflectiveObjectGenerator
|
||||||
implements WildcardType {
|
implements WildcardType {
|
||||||
// upper bounds - evaluated lazily
|
|
||||||
private Type[] upperBounds;
|
/*
|
||||||
// lower bounds - evaluated lazily
|
* We are required to evaluate the bounds lazily, so we store them as ASTs
|
||||||
private Type[] lowerBounds;
|
* until we are first asked for them. This also neatly solves the problem
|
||||||
// The ASTs for the bounds. We are required to evaluate the bounds
|
* with F-bounds - you can't reify them before the formal is defined.
|
||||||
// lazily, so we store these at least until we are first asked
|
*/
|
||||||
// for the bounds. This also neatly solves the
|
|
||||||
// problem with F-bounds - you can't reify them before the formal
|
/** The upper bounds. Lazily converted from FieldTypeSignature[] to Type[]. */
|
||||||
// is defined.
|
private volatile Object[] upperBounds;
|
||||||
private FieldTypeSignature[] upperBoundASTs;
|
|
||||||
private FieldTypeSignature[] lowerBoundASTs;
|
/** The lower bounds. Lazily converted from FieldTypeSignature[] to Type[]. */
|
||||||
|
private volatile Object[] lowerBounds;
|
||||||
|
|
||||||
// constructor is private to enforce access through static factory
|
// constructor is private to enforce access through static factory
|
||||||
private WildcardTypeImpl(FieldTypeSignature[] ubs,
|
private WildcardTypeImpl(FieldTypeSignature[] ubs,
|
||||||
FieldTypeSignature[] lbs,
|
FieldTypeSignature[] lbs,
|
||||||
GenericsFactory f) {
|
GenericsFactory f) {
|
||||||
super(f);
|
super(f);
|
||||||
upperBoundASTs = ubs;
|
upperBounds = ubs;
|
||||||
lowerBoundASTs = lbs;
|
lowerBounds = lbs;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -76,27 +77,8 @@ public class WildcardTypeImpl extends LazyReflectiveObjectGenerator
|
|||||||
return new WildcardTypeImpl(ubs, lbs, f);
|
return new WildcardTypeImpl(ubs, lbs, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Accessors
|
|
||||||
|
|
||||||
// accessor for ASTs for upper bounds. Must not be called after upper
|
|
||||||
// bounds have been evaluated, because we might throw the ASTs
|
|
||||||
// away (but that is not thread-safe, is it?)
|
|
||||||
private FieldTypeSignature[] getUpperBoundASTs() {
|
|
||||||
// check that upper bounds were not evaluated yet
|
|
||||||
assert(upperBounds == null);
|
|
||||||
return upperBoundASTs;
|
|
||||||
}
|
|
||||||
// accessor for ASTs for lower bounds. Must not be called after lower
|
|
||||||
// bounds have been evaluated, because we might throw the ASTs
|
|
||||||
// away (but that is not thread-safe, is it?)
|
|
||||||
private FieldTypeSignature[] getLowerBoundASTs() {
|
|
||||||
// check that lower bounds were not evaluated yet
|
|
||||||
assert(lowerBounds == null);
|
|
||||||
return lowerBoundASTs;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns an array of <tt>Type</tt> objects representing the upper
|
* Returns an array of <tt>Type</tt> objects representing the upper
|
||||||
* bound(s) of this type variable. Note that if no upper bound is
|
* bound(s) of this type variable. Note that if no upper bound is
|
||||||
* explicitly declared, the upper bound is <tt>Object</tt>.
|
* explicitly declared, the upper bound is <tt>Object</tt>.
|
||||||
*
|
*
|
||||||
@ -117,24 +99,12 @@ public class WildcardTypeImpl extends LazyReflectiveObjectGenerator
|
|||||||
* for any reason
|
* for any reason
|
||||||
*/
|
*/
|
||||||
public Type[] getUpperBounds() {
|
public Type[] getUpperBounds() {
|
||||||
// lazily initialize bounds if necessary
|
Object[] value = upperBounds;
|
||||||
if (upperBounds == null) {
|
if (value instanceof FieldTypeSignature[]) {
|
||||||
FieldTypeSignature[] fts = getUpperBoundASTs(); // get AST
|
value = reifyBounds((FieldTypeSignature[])value);
|
||||||
|
upperBounds = value;
|
||||||
// allocate result array; note that
|
|
||||||
// keeping ts and bounds separate helps with threads
|
|
||||||
Type[] ts = new Type[fts.length];
|
|
||||||
// iterate over bound trees, reifying each in turn
|
|
||||||
for ( int j = 0; j < fts.length; j++) {
|
|
||||||
Reifier r = getReifier();
|
|
||||||
fts[j].accept(r);
|
|
||||||
ts[j] = r.getResult();
|
|
||||||
}
|
|
||||||
// cache result
|
|
||||||
upperBounds = ts;
|
|
||||||
// could throw away upper bound ASTs here; thread safety?
|
|
||||||
}
|
}
|
||||||
return upperBounds.clone(); // return cached bounds
|
return (Type[])value.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -160,23 +130,12 @@ public class WildcardTypeImpl extends LazyReflectiveObjectGenerator
|
|||||||
* for any reason
|
* for any reason
|
||||||
*/
|
*/
|
||||||
public Type[] getLowerBounds() {
|
public Type[] getLowerBounds() {
|
||||||
// lazily initialize bounds if necessary
|
Object[] value = lowerBounds;
|
||||||
if (lowerBounds == null) {
|
if (value instanceof FieldTypeSignature[]) {
|
||||||
FieldTypeSignature[] fts = getLowerBoundASTs(); // get AST
|
value = reifyBounds((FieldTypeSignature[])value);
|
||||||
// allocate result array; note that
|
lowerBounds = value;
|
||||||
// keeping ts and bounds separate helps with threads
|
|
||||||
Type[] ts = new Type[fts.length];
|
|
||||||
// iterate over bound trees, reifying each in turn
|
|
||||||
for ( int j = 0; j < fts.length; j++) {
|
|
||||||
Reifier r = getReifier();
|
|
||||||
fts[j].accept(r);
|
|
||||||
ts[j] = r.getResult();
|
|
||||||
}
|
|
||||||
// cache result
|
|
||||||
lowerBounds = ts;
|
|
||||||
// could throw away lower bound ASTs here; thread safety?
|
|
||||||
}
|
}
|
||||||
return lowerBounds.clone(); // return cached bounds
|
return (Type[])value.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
|
@ -56,7 +56,7 @@ public abstract class AbstractRepository<T extends Tree> {
|
|||||||
/**
|
/**
|
||||||
* Returns a <tt>Reifier</tt> used to convert parts of the
|
* Returns a <tt>Reifier</tt> used to convert parts of the
|
||||||
* AST into reflective objects.
|
* AST into reflective objects.
|
||||||
* @return a <tt>Reifier</tt> used to convert parts of the
|
* @return a <tt>Reifier</tt> used to convert parts of the
|
||||||
* AST into reflective objects
|
* AST into reflective objects
|
||||||
*/
|
*/
|
||||||
protected Reifier getReifier(){return Reifier.make(getFactory());}
|
protected Reifier getReifier(){return Reifier.make(getFactory());}
|
||||||
@ -76,7 +76,7 @@ public abstract class AbstractRepository<T extends Tree> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the AST for the genric type info of this entity.
|
* Returns the AST for the generic type info of this entity.
|
||||||
* @param s - a string representing the generic signature of this
|
* @param s - a string representing the generic signature of this
|
||||||
* entity
|
* entity
|
||||||
* @return the AST for the generic type info of this entity.
|
* @return the AST for the generic type info of this entity.
|
||||||
|
@ -25,12 +25,12 @@
|
|||||||
|
|
||||||
package sun.reflect.generics.repository;
|
package sun.reflect.generics.repository;
|
||||||
|
|
||||||
|
import java.lang.reflect.Type;
|
||||||
import sun.reflect.generics.factory.GenericsFactory;
|
import sun.reflect.generics.factory.GenericsFactory;
|
||||||
import sun.reflect.generics.tree.ClassSignature;
|
import sun.reflect.generics.tree.ClassSignature;
|
||||||
import sun.reflect.generics.tree.TypeTree;
|
import sun.reflect.generics.tree.TypeTree;
|
||||||
import sun.reflect.generics.visitor.Reifier;
|
import sun.reflect.generics.visitor.Reifier;
|
||||||
import sun.reflect.generics.parser.SignatureParser;
|
import sun.reflect.generics.parser.SignatureParser;
|
||||||
import java.lang.reflect.Type;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -70,47 +70,54 @@ public class ClassRepository extends GenericDeclRepository<ClassSignature> {
|
|||||||
return new ClassRepository(rawSig, f);
|
return new ClassRepository(rawSig, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
// public API
|
|
||||||
/*
|
/*
|
||||||
* When queried for a particular piece of type information, the
|
* When queried for a particular piece of type information, the
|
||||||
* general pattern is to consult the corresponding cached value.
|
* general pattern is to consult the corresponding cached value.
|
||||||
* If the corresponding field is non-null, it is returned.
|
* If the corresponding field is non-null, it is returned.
|
||||||
* If not, it is created lazily. This is done by selecting the appropriate
|
* If not, it is created lazily. This is done by selecting the appropriate
|
||||||
* part of the tree and transforming it into a reflective object
|
* part of the tree and transforming it into a reflective object
|
||||||
* using a visitor.
|
* using a visitor, which is created by feeding it the factory
|
||||||
* a visitor, which is created by feeding it the factory
|
|
||||||
* with which the repository was created.
|
* with which the repository was created.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public Type getSuperclass() {
|
public Type getSuperclass() {
|
||||||
Type superclass = this.superclass;
|
Type value = superclass;
|
||||||
if (superclass == null) { // lazily initialize superclass
|
if (value == null) {
|
||||||
Reifier r = getReifier(); // obtain visitor
|
value = computeSuperclass();
|
||||||
// Extract superclass subtree from AST and reify
|
superclass = value;
|
||||||
getTree().getSuperclass().accept(r);
|
|
||||||
// extract result from visitor and cache it
|
|
||||||
superclass = r.getResult();
|
|
||||||
this.superclass = superclass;
|
|
||||||
}
|
}
|
||||||
return superclass; // return cached result
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Type[] getSuperInterfaces() {
|
public Type[] getSuperInterfaces() {
|
||||||
Type[] superInterfaces = this.superInterfaces;
|
Type[] value = superInterfaces;
|
||||||
if (superInterfaces == null) { // lazily initialize super interfaces
|
if (value == null) {
|
||||||
// first, extract super interface subtree(s) from AST
|
value = computeSuperInterfaces();
|
||||||
TypeTree[] ts = getTree().getSuperInterfaces();
|
superInterfaces = value;
|
||||||
// create array to store reified subtree(s)
|
|
||||||
superInterfaces = new Type[ts.length];
|
|
||||||
// reify all subtrees
|
|
||||||
for (int i = 0; i < ts.length; i++) {
|
|
||||||
Reifier r = getReifier(); // obtain visitor
|
|
||||||
ts[i].accept(r);// reify subtree
|
|
||||||
// extract result from visitor and store it
|
|
||||||
superInterfaces[i] = r.getResult();
|
|
||||||
}
|
|
||||||
this.superInterfaces = superInterfaces;
|
|
||||||
}
|
}
|
||||||
return superInterfaces.clone(); // return cached result
|
return value.clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Type computeSuperclass() {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
// Extract superclass subtree from AST and reify
|
||||||
|
getTree().getSuperclass().accept(r);
|
||||||
|
return r.getResult();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Type[] computeSuperInterfaces() {
|
||||||
|
// first, extract super interface subtree(s) from AST
|
||||||
|
TypeTree[] ts = getTree().getSuperInterfaces();
|
||||||
|
// create array to store reified subtree(s)
|
||||||
|
int length = ts.length;
|
||||||
|
Type[] superInterfaces = new Type[length];
|
||||||
|
// reify all subtrees
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
ts[i].accept(r);// reify subtree
|
||||||
|
// extract result from visitor and store it
|
||||||
|
superInterfaces[i] = r.getResult();
|
||||||
|
}
|
||||||
|
return superInterfaces;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,8 +43,11 @@ import sun.reflect.generics.visitor.Reifier;
|
|||||||
public class ConstructorRepository
|
public class ConstructorRepository
|
||||||
extends GenericDeclRepository<MethodTypeSignature> {
|
extends GenericDeclRepository<MethodTypeSignature> {
|
||||||
|
|
||||||
private Type[] paramTypes; // caches the generic parameter types info
|
/** The generic parameter types. Lazily initialized. */
|
||||||
private Type[] exceptionTypes; // caches the generic exception types info
|
private volatile Type[] parameterTypes;
|
||||||
|
|
||||||
|
/** The generic exception types. Lazily initialized. */
|
||||||
|
private volatile Type[] exceptionTypes;
|
||||||
|
|
||||||
// protected, to enforce use of static factory yet allow subclassing
|
// protected, to enforce use of static factory yet allow subclassing
|
||||||
protected ConstructorRepository(String rawSig, GenericsFactory f) {
|
protected ConstructorRepository(String rawSig, GenericsFactory f) {
|
||||||
@ -64,57 +67,67 @@ public class ConstructorRepository
|
|||||||
* @return a <tt>ConstructorRepository</tt> that manages the generic type
|
* @return a <tt>ConstructorRepository</tt> that manages the generic type
|
||||||
* information represented in the signature <tt>rawSig</tt>
|
* information represented in the signature <tt>rawSig</tt>
|
||||||
*/
|
*/
|
||||||
public static ConstructorRepository make(String rawSig,
|
public static ConstructorRepository make(String rawSig, GenericsFactory f) {
|
||||||
GenericsFactory f) {
|
|
||||||
return new ConstructorRepository(rawSig, f);
|
return new ConstructorRepository(rawSig, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
// public API
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* When queried for a particular piece of type information, the
|
* When queried for a particular piece of type information, the
|
||||||
* general pattern is to consult the corresponding cached value.
|
* general pattern is to consult the corresponding cached value.
|
||||||
* If the corresponding field is non-null, it is returned.
|
* If the corresponding field is non-null, it is returned.
|
||||||
* If not, it is created lazily. This is done by selecting the appropriate
|
* If not, it is created lazily. This is done by selecting the appropriate
|
||||||
* part of the tree and transforming it into a reflective object
|
* part of the tree and transforming it into a reflective object
|
||||||
* using a visitor.
|
* using a visitor, which is created by feeding it the factory
|
||||||
* a visitor, which is created by feeding it the factory
|
|
||||||
* with which the repository was created.
|
* with which the repository was created.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public Type[] getParameterTypes(){
|
public Type[] getParameterTypes() {
|
||||||
if (paramTypes == null) { // lazily initialize parameter types
|
Type[] value = parameterTypes;
|
||||||
// first, extract parameter type subtree(s) from AST
|
if (value == null) {
|
||||||
TypeSignature[] pts = getTree().getParameterTypes();
|
value = computeParameterTypes();
|
||||||
// create array to store reified subtree(s)
|
parameterTypes = value;
|
||||||
Type[] ps = new Type[pts.length];
|
|
||||||
// reify all subtrees
|
|
||||||
for (int i = 0; i < pts.length; i++) {
|
|
||||||
Reifier r = getReifier(); // obtain visitor
|
|
||||||
pts[i].accept(r); // reify subtree
|
|
||||||
// extract result from visitor and store it
|
|
||||||
ps[i] = r.getResult();
|
|
||||||
}
|
|
||||||
paramTypes = ps; // cache overall result
|
|
||||||
}
|
}
|
||||||
return paramTypes.clone(); // return cached result
|
return value.clone();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Type[] getExceptionTypes(){
|
public Type[] getExceptionTypes() {
|
||||||
if (exceptionTypes == null) { // lazily initialize exception types
|
Type[] value = exceptionTypes;
|
||||||
// first, extract exception type subtree(s) from AST
|
if (value == null) {
|
||||||
FieldTypeSignature[] ets = getTree().getExceptionTypes();
|
value = computeExceptionTypes();
|
||||||
// create array to store reified subtree(s)
|
exceptionTypes = value;
|
||||||
Type[] es = new Type[ets.length];
|
|
||||||
// reify all subtrees
|
|
||||||
for (int i = 0; i < ets.length; i++) {
|
|
||||||
Reifier r = getReifier(); // obtain visitor
|
|
||||||
ets[i].accept(r); // reify subtree
|
|
||||||
// extract result from visitor and store it
|
|
||||||
es[i] = r.getResult();
|
|
||||||
}
|
|
||||||
exceptionTypes = es; // cache overall result
|
|
||||||
}
|
}
|
||||||
return exceptionTypes.clone(); // return cached result
|
return value.clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Type[] computeParameterTypes() {
|
||||||
|
// first, extract parameter type subtree(s) from AST
|
||||||
|
TypeSignature[] pts = getTree().getParameterTypes();
|
||||||
|
// create array to store reified subtree(s)
|
||||||
|
int length = pts.length;
|
||||||
|
Type[] parameterTypes = new Type[length];
|
||||||
|
// reify all subtrees
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
pts[i].accept(r); // reify subtree
|
||||||
|
// extract result from visitor and store it
|
||||||
|
parameterTypes[i] = r.getResult();
|
||||||
|
}
|
||||||
|
return parameterTypes;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Type[] computeExceptionTypes() {
|
||||||
|
// first, extract exception type subtree(s) from AST
|
||||||
|
FieldTypeSignature[] ets = getTree().getExceptionTypes();
|
||||||
|
// create array to store reified subtree(s)
|
||||||
|
int length = ets.length;
|
||||||
|
Type[] exceptionTypes = new Type[length];
|
||||||
|
// reify all subtrees
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
ets[i].accept(r); // reify subtree
|
||||||
|
// extract result from visitor and store it
|
||||||
|
exceptionTypes[i] = r.getResult();
|
||||||
|
}
|
||||||
|
return exceptionTypes;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,7 +41,8 @@ import sun.reflect.generics.visitor.Reifier;
|
|||||||
*/
|
*/
|
||||||
public class FieldRepository extends AbstractRepository<TypeSignature> {
|
public class FieldRepository extends AbstractRepository<TypeSignature> {
|
||||||
|
|
||||||
private Type genericType; // caches the generic type info
|
/** The generic type info. Lazily initialized. */
|
||||||
|
private volatile Type genericType;
|
||||||
|
|
||||||
// protected, to enforce use of static factory yet allow subclassing
|
// protected, to enforce use of static factory yet allow subclassing
|
||||||
protected FieldRepository(String rawSig, GenericsFactory f) {
|
protected FieldRepository(String rawSig, GenericsFactory f) {
|
||||||
@ -61,31 +62,32 @@ public class FieldRepository extends AbstractRepository<TypeSignature> {
|
|||||||
* @return a <tt>FieldRepository</tt> that manages the generic type
|
* @return a <tt>FieldRepository</tt> that manages the generic type
|
||||||
* information represented in the signature <tt>rawSig</tt>
|
* information represented in the signature <tt>rawSig</tt>
|
||||||
*/
|
*/
|
||||||
public static FieldRepository make(String rawSig,
|
public static FieldRepository make(String rawSig, GenericsFactory f) {
|
||||||
GenericsFactory f) {
|
|
||||||
return new FieldRepository(rawSig, f);
|
return new FieldRepository(rawSig, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
// public API
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* When queried for a particular piece of type information, the
|
* When queried for a particular piece of type information, the
|
||||||
* general pattern is to consult the corresponding cached value.
|
* general pattern is to consult the corresponding cached value.
|
||||||
* If the corresponding field is non-null, it is returned.
|
* If the corresponding field is non-null, it is returned.
|
||||||
* If not, it is created lazily. This is done by selecting the appropriate
|
* If not, it is created lazily. This is done by selecting the appropriate
|
||||||
* part of the tree and transforming it into a reflective object
|
* part of the tree and transforming it into a reflective object
|
||||||
* using a visitor.
|
* using a visitor, which is created by feeding it the factory
|
||||||
* a visitor, which is created by feeding it the factory
|
|
||||||
* with which the repository was created.
|
* with which the repository was created.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public Type getGenericType(){
|
public Type getGenericType() {
|
||||||
if (genericType == null) { // lazily initialize generic type
|
Type value = genericType;
|
||||||
Reifier r = getReifier(); // obtain visitor
|
if (value == null) {
|
||||||
getTree().accept(r); // reify subtree
|
value = computeGenericType();
|
||||||
// extract result from visitor and cache it
|
genericType = value;
|
||||||
genericType = r.getResult();
|
|
||||||
}
|
}
|
||||||
return genericType; // return cached result
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Type computeGenericType() {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
getTree().accept(r); // reify subtree
|
||||||
|
return r.getResult(); // extract result from visitor
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,13 +43,12 @@ public abstract class GenericDeclRepository<S extends Signature>
|
|||||||
extends AbstractRepository<S> {
|
extends AbstractRepository<S> {
|
||||||
|
|
||||||
/** The formal type parameters. Lazily initialized. */
|
/** The formal type parameters. Lazily initialized. */
|
||||||
private volatile TypeVariable<?>[] typeParams;
|
private volatile TypeVariable<?>[] typeParameters;
|
||||||
|
|
||||||
protected GenericDeclRepository(String rawSig, GenericsFactory f) {
|
protected GenericDeclRepository(String rawSig, GenericsFactory f) {
|
||||||
super(rawSig, f);
|
super(rawSig, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
// public API
|
|
||||||
/*
|
/*
|
||||||
* When queried for a particular piece of type information, the
|
* When queried for a particular piece of type information, the
|
||||||
* general pattern is to consult the corresponding cached value.
|
* general pattern is to consult the corresponding cached value.
|
||||||
@ -61,25 +60,31 @@ public abstract class GenericDeclRepository<S extends Signature>
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the formal type parameters of this generic declaration.
|
* Returns the formal type parameters of this generic declaration.
|
||||||
* @return the formal type parameters of this generic declaration
|
* @return the formal type parameters of this generic declaration
|
||||||
*/
|
*/
|
||||||
public TypeVariable<?>[] getTypeParameters() {
|
public TypeVariable<?>[] getTypeParameters() {
|
||||||
TypeVariable<?>[] typeParams = this.typeParams;
|
TypeVariable<?>[] value = typeParameters;
|
||||||
if (typeParams == null) { // lazily initialize type parameters
|
if (value == null) {
|
||||||
// first, extract type parameter subtree(s) from AST
|
value = computeTypeParameters();
|
||||||
FormalTypeParameter[] ftps = getTree().getFormalTypeParameters();
|
typeParameters = value;
|
||||||
// create array to store reified subtree(s)
|
|
||||||
typeParams = new TypeVariable<?>[ftps.length];
|
|
||||||
// reify all subtrees
|
|
||||||
for (int i = 0; i < ftps.length; i++) {
|
|
||||||
Reifier r = getReifier(); // obtain visitor
|
|
||||||
ftps[i].accept(r); // reify subtree
|
|
||||||
// extract result from visitor and store it
|
|
||||||
typeParams[i] = (TypeVariable<?>) r.getResult();
|
|
||||||
}
|
|
||||||
this.typeParams = typeParams; // cache overall result
|
|
||||||
}
|
}
|
||||||
return typeParams.clone(); // return cached result
|
return value.clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
private TypeVariable<?>[] computeTypeParameters() {
|
||||||
|
// first, extract type parameter subtree(s) from AST
|
||||||
|
FormalTypeParameter[] ftps = getTree().getFormalTypeParameters();
|
||||||
|
// create array to store reified subtree(s)
|
||||||
|
int length = ftps.length;
|
||||||
|
TypeVariable<?>[] typeParameters = new TypeVariable<?>[length];
|
||||||
|
// reify all subtrees
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
ftps[i].accept(r); // reify subtree
|
||||||
|
// extract result from visitor and store it
|
||||||
|
typeParameters[i] = (TypeVariable<?>) r.getResult();
|
||||||
|
}
|
||||||
|
return typeParameters;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,8 @@ import sun.reflect.generics.visitor.Reifier;
|
|||||||
*/
|
*/
|
||||||
public class MethodRepository extends ConstructorRepository {
|
public class MethodRepository extends ConstructorRepository {
|
||||||
|
|
||||||
private Type returnType; // caches the generic return type info
|
/** The generic return type info. Lazily initialized. */
|
||||||
|
private volatile Type returnType;
|
||||||
|
|
||||||
// private, to enforce use of static factory
|
// private, to enforce use of static factory
|
||||||
private MethodRepository(String rawSig, GenericsFactory f) {
|
private MethodRepository(String rawSig, GenericsFactory f) {
|
||||||
@ -59,18 +60,21 @@ public class MethodRepository extends ConstructorRepository {
|
|||||||
return new MethodRepository(rawSig, f);
|
return new MethodRepository(rawSig, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
// public API
|
|
||||||
|
|
||||||
public Type getReturnType() {
|
public Type getReturnType() {
|
||||||
if (returnType == null) { // lazily initialize return type
|
Type value = returnType;
|
||||||
Reifier r = getReifier(); // obtain visitor
|
if (value == null) {
|
||||||
// Extract return type subtree from AST and reify
|
value = computeReturnType();
|
||||||
getTree().getReturnType().accept(r);
|
returnType = value;
|
||||||
// extract result from visitor and cache it
|
}
|
||||||
returnType = r.getResult();
|
return value;
|
||||||
}
|
|
||||||
return returnType; // return cached result
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Type computeReturnType() {
|
||||||
|
Reifier r = getReifier(); // obtain visitor
|
||||||
|
// Extract return type subtree from AST and reify
|
||||||
|
getTree().getReturnType().accept(r);
|
||||||
|
// extract result from visitor and cache it
|
||||||
|
return r.getResult();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -29,7 +29,6 @@ import java.lang.reflect.GenericDeclaration;
|
|||||||
import java.lang.reflect.TypeVariable;
|
import java.lang.reflect.TypeVariable;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Abstract superclass for lazy scope objects, used when building
|
* Abstract superclass for lazy scope objects, used when building
|
||||||
* factories for generic information repositories.
|
* factories for generic information repositories.
|
||||||
@ -49,7 +48,7 @@ public abstract class AbstractScope<D extends GenericDeclaration>
|
|||||||
/**
|
/**
|
||||||
* Constructor. Takes a reflective object whose scope the newly
|
* Constructor. Takes a reflective object whose scope the newly
|
||||||
* constructed instance will represent.
|
* constructed instance will represent.
|
||||||
* @param D - A generic declaration whose scope the newly
|
* @param decl - A generic declaration whose scope the newly
|
||||||
* constructed instance will represent
|
* constructed instance will represent
|
||||||
*/
|
*/
|
||||||
protected AbstractScope(D decl){ recvr = decl;}
|
protected AbstractScope(D decl){ recvr = decl;}
|
||||||
@ -63,7 +62,7 @@ public abstract class AbstractScope<D extends GenericDeclaration>
|
|||||||
|
|
||||||
/** This method must be implemented by any concrete subclass.
|
/** This method must be implemented by any concrete subclass.
|
||||||
* It must return the enclosing scope of this scope. If this scope
|
* It must return the enclosing scope of this scope. If this scope
|
||||||
* is a top-level scope, an instance of DummyScope must be returned.
|
* is a top-level scope, an instance of DummyScope must be returned.
|
||||||
* @return The enclosing scope of this scope
|
* @return The enclosing scope of this scope
|
||||||
*/
|
*/
|
||||||
protected abstract Scope computeEnclosingScope();
|
protected abstract Scope computeEnclosingScope();
|
||||||
@ -72,13 +71,13 @@ public abstract class AbstractScope<D extends GenericDeclaration>
|
|||||||
* Accessor for the enclosing scope, which is computed lazily and cached.
|
* Accessor for the enclosing scope, which is computed lazily and cached.
|
||||||
* @return the enclosing scope
|
* @return the enclosing scope
|
||||||
*/
|
*/
|
||||||
protected Scope getEnclosingScope(){
|
protected Scope getEnclosingScope() {
|
||||||
Scope enclosingScope = this.enclosingScope;
|
Scope value = enclosingScope;
|
||||||
if (enclosingScope == null) {
|
if (value == null) {
|
||||||
enclosingScope = computeEnclosingScope();
|
value = computeEnclosingScope();
|
||||||
this.enclosingScope = enclosingScope;
|
enclosingScope = value;
|
||||||
}
|
}
|
||||||
return enclosingScope;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -27,7 +27,7 @@ package sun.reflect.generics.tree;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Common superinterface for generic signatures. These are the signatures
|
* Common superinterface for generic signatures. These are the signatures
|
||||||
* of complete class and method/constructor delcarations.
|
* of complete class and method/constructor declarations.
|
||||||
*/
|
*/
|
||||||
public interface Signature extends Tree{
|
public interface Signature extends Tree{
|
||||||
FormalTypeParameter[] getFormalTypeParameters();
|
FormalTypeParameter[] getFormalTypeParameters();
|
||||||
|
@ -28,8 +28,8 @@ package sun.reflect.generics.tree;
|
|||||||
import sun.reflect.generics.visitor.TypeTreeVisitor;
|
import sun.reflect.generics.visitor.TypeTreeVisitor;
|
||||||
|
|
||||||
public class Wildcard implements TypeArgument {
|
public class Wildcard implements TypeArgument {
|
||||||
private FieldTypeSignature[] upperBounds;
|
private final FieldTypeSignature[] upperBounds;
|
||||||
private FieldTypeSignature[] lowerBounds;
|
private final FieldTypeSignature[] lowerBounds;
|
||||||
|
|
||||||
private Wildcard(FieldTypeSignature[] ubs, FieldTypeSignature[] lbs) {
|
private Wildcard(FieldTypeSignature[] ubs, FieldTypeSignature[] lbs) {
|
||||||
upperBounds = ubs;
|
upperBounds = ubs;
|
||||||
@ -43,11 +43,11 @@ public class Wildcard implements TypeArgument {
|
|||||||
return new Wildcard(ubs, lbs);
|
return new Wildcard(ubs, lbs);
|
||||||
}
|
}
|
||||||
|
|
||||||
public FieldTypeSignature[] getUpperBounds(){
|
public FieldTypeSignature[] getUpperBounds() {
|
||||||
return upperBounds;
|
return upperBounds;
|
||||||
}
|
}
|
||||||
|
|
||||||
public FieldTypeSignature[] getLowerBounds(){
|
public FieldTypeSignature[] getLowerBounds() {
|
||||||
if (lowerBounds.length == 1 &&
|
if (lowerBounds.length == 1 &&
|
||||||
lowerBounds[0] == BottomSignature.make())
|
lowerBounds[0] == BottomSignature.make())
|
||||||
return emptyBounds;
|
return emptyBounds;
|
||||||
|
@ -39,7 +39,7 @@ import sun.reflect.generics.factory.*;
|
|||||||
*/
|
*/
|
||||||
public class Reifier implements TypeTreeVisitor<Type> {
|
public class Reifier implements TypeTreeVisitor<Type> {
|
||||||
private Type resultType;
|
private Type resultType;
|
||||||
private GenericsFactory factory;
|
private final GenericsFactory factory;
|
||||||
|
|
||||||
private Reifier(GenericsFactory f){
|
private Reifier(GenericsFactory f){
|
||||||
factory = f;
|
factory = f;
|
||||||
|
@ -40,6 +40,7 @@ import java.lang.reflect.Method;
|
|||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.lang.reflect.AccessibleObject;
|
import java.lang.reflect.AccessibleObject;
|
||||||
import java.lang.reflect.Modifier;
|
import java.lang.reflect.Modifier;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import sun.misc.IOUtils;
|
import sun.misc.IOUtils;
|
||||||
@ -216,17 +217,21 @@ public final class MethodUtil extends SecureClassLoader {
|
|||||||
* key in the method cache.
|
* key in the method cache.
|
||||||
*/
|
*/
|
||||||
private static class Signature {
|
private static class Signature {
|
||||||
private String methodName;
|
private final String methodName;
|
||||||
private Class<?>[] argClasses;
|
private final Class<?>[] argClasses;
|
||||||
|
private final int hashCode;
|
||||||
private volatile int hashCode = 0;
|
|
||||||
|
|
||||||
Signature(Method m) {
|
Signature(Method m) {
|
||||||
this.methodName = m.getName();
|
this.methodName = m.getName();
|
||||||
this.argClasses = m.getParameterTypes();
|
this.argClasses = m.getParameterTypes();
|
||||||
|
this.hashCode = methodName.hashCode() + Arrays.hashCode(argClasses);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean equals(Object o2) {
|
@Override public int hashCode() {
|
||||||
|
return hashCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override public boolean equals(Object o2) {
|
||||||
if (this == o2) {
|
if (this == o2) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -244,25 +249,6 @@ public final class MethodUtil extends SecureClassLoader {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Hash code computed using algorithm suggested in
|
|
||||||
* Effective Java, Item 8.
|
|
||||||
*/
|
|
||||||
public int hashCode() {
|
|
||||||
if (hashCode == 0) {
|
|
||||||
int result = 17;
|
|
||||||
result = 37 * result + methodName.hashCode();
|
|
||||||
if (argClasses != null) {
|
|
||||||
for (int i = 0; i < argClasses.length; i++) {
|
|
||||||
result = 37 * result + ((argClasses[i] == null) ? 0 :
|
|
||||||
argClasses[i].hashCode());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
hashCode = result;
|
|
||||||
}
|
|
||||||
return hashCode;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -319,7 +319,7 @@ public final class ReflectUtil {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// disallow any method not declared in one of the proxy intefaces
|
// disallow any method not declared in one of the proxy interfaces
|
||||||
throw new IllegalArgumentException("Can't handle: " + method);
|
throw new IllegalArgumentException("Can't handle: " + method);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1040,7 +1040,7 @@ public class PolicyFile extends java.security.Policy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Evaluates the the global policy for the permissions granted to
|
* Evaluates the global policy for the permissions granted to
|
||||||
* the ProtectionDomain and tests whether the permission is
|
* the ProtectionDomain and tests whether the permission is
|
||||||
* granted.
|
* granted.
|
||||||
*
|
*
|
||||||
|
@ -41,7 +41,7 @@ final class EphemeralKeyManager {
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Current cached RSA KeyPairs. Elements are never null.
|
* Current cached RSA KeyPairs. Elements are never null.
|
||||||
* Indexed via the the constants above.
|
* Indexed via the constants above.
|
||||||
*/
|
*/
|
||||||
private final EphemeralKeyPair[] keys = new EphemeralKeyPair[] {
|
private final EphemeralKeyPair[] keys = new EphemeralKeyPair[] {
|
||||||
new EphemeralKeyPair(null),
|
new EphemeralKeyPair(null),
|
||||||
|
@ -120,7 +120,7 @@ final class MAC extends Authenticator {
|
|||||||
* @param buf compressed record on which the MAC is computed
|
* @param buf compressed record on which the MAC is computed
|
||||||
* @param offset start of compressed record data
|
* @param offset start of compressed record data
|
||||||
* @param len the size of the compressed record
|
* @param len the size of the compressed record
|
||||||
* @param isSimulated if true, simulate the the MAC computation
|
* @param isSimulated if true, simulate the MAC computation
|
||||||
*/
|
*/
|
||||||
final byte[] compute(byte type, byte buf[],
|
final byte[] compute(byte type, byte buf[],
|
||||||
int offset, int len, boolean isSimulated) {
|
int offset, int len, boolean isSimulated) {
|
||||||
@ -147,7 +147,7 @@ final class MAC extends Authenticator {
|
|||||||
* @param type record type
|
* @param type record type
|
||||||
* @param bb a ByteBuffer in which the position and limit
|
* @param bb a ByteBuffer in which the position and limit
|
||||||
* demarcate the data to be MAC'd.
|
* demarcate the data to be MAC'd.
|
||||||
* @param isSimulated if true, simulate the the MAC computation
|
* @param isSimulated if true, simulate the MAC computation
|
||||||
*/
|
*/
|
||||||
final byte[] compute(byte type, ByteBuffer bb, boolean isSimulated) {
|
final byte[] compute(byte type, ByteBuffer bb, boolean isSimulated) {
|
||||||
if (macAlg.size == 0) {
|
if (macAlg.size == 0) {
|
||||||
|
@ -77,7 +77,7 @@ import javax.net.ssl.SSLEngineResult.*;
|
|||||||
* All data is routed through
|
* All data is routed through
|
||||||
* EngineInputRecord/EngineOutputRecord. However, all handshake
|
* EngineInputRecord/EngineOutputRecord. However, all handshake
|
||||||
* data (ct_alert/ct_change_cipher_spec/ct_handshake) are passed
|
* data (ct_alert/ct_change_cipher_spec/ct_handshake) are passed
|
||||||
* through to the the underlying InputRecord/OutputRecord, and
|
* through to the underlying InputRecord/OutputRecord, and
|
||||||
* the data uses the internal buffers.
|
* the data uses the internal buffers.
|
||||||
*
|
*
|
||||||
* Application data is handled slightly different, we copy the data
|
* Application data is handled slightly different, we copy the data
|
||||||
@ -158,7 +158,7 @@ final public class SSLEngineImpl extends SSLEngine {
|
|||||||
* v |
|
* v |
|
||||||
* ERROR>------>----->CLOSED<--------<----+
|
* ERROR>------>----->CLOSED<--------<----+
|
||||||
*
|
*
|
||||||
* ALSO, note that the the purpose of handshaking (renegotiation is
|
* ALSO, note that the purpose of handshaking (renegotiation is
|
||||||
* included) is to assign a different, and perhaps new, session to
|
* included) is to assign a different, and perhaps new, session to
|
||||||
* the connection. The SSLv3 spec is a bit confusing on that new
|
* the connection. The SSLv3 spec is a bit confusing on that new
|
||||||
* protocol feature.
|
* protocol feature.
|
||||||
|
@ -144,7 +144,7 @@ final public class SSLSocketImpl extends BaseSSLSocketImpl {
|
|||||||
* v
|
* v
|
||||||
* APP_CLOSED
|
* APP_CLOSED
|
||||||
*
|
*
|
||||||
* ALSO, note that the the purpose of handshaking (renegotiation is
|
* ALSO, note that the purpose of handshaking (renegotiation is
|
||||||
* included) is to assign a different, and perhaps new, session to
|
* included) is to assign a different, and perhaps new, session to
|
||||||
* the connection. The SSLv3 spec is a bit confusing on that new
|
* the connection. The SSLv3 spec is a bit confusing on that new
|
||||||
* protocol feature.
|
* protocol feature.
|
||||||
@ -2190,7 +2190,7 @@ final public class SSLSocketImpl extends BaseSSLSocketImpl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the the SSL Session in use by this connection. These can
|
* Returns the SSL Session in use by this connection. These can
|
||||||
* be long lived, and frequently correspond to an entire login session
|
* be long lived, and frequently correspond to an entire login session
|
||||||
* for some user.
|
* for some user.
|
||||||
*/
|
*/
|
||||||
|
@ -1467,7 +1467,7 @@ final class ServerHandshaker extends Handshaker {
|
|||||||
if (serverPrincipal != null) {
|
if (serverPrincipal != null) {
|
||||||
// When service is bound, we check ASAP. Otherwise,
|
// When service is bound, we check ASAP. Otherwise,
|
||||||
// will check after client request is received
|
// will check after client request is received
|
||||||
// in in Kerberos ClientKeyExchange
|
// in Kerberos ClientKeyExchange
|
||||||
SecurityManager sm = System.getSecurityManager();
|
SecurityManager sm = System.getSecurityManager();
|
||||||
try {
|
try {
|
||||||
if (sm != null) {
|
if (sm != null) {
|
||||||
|
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