Merge
This commit is contained in:
commit
1478582041
2
.hgtags
2
.hgtags
@ -41,3 +41,5 @@ dfd8506f74c3731bb169ce93c72612d78ee0413b jdk7-b63
|
||||
d22867c5f1b295a0a2b3b4bc8999a2676f6e20c3 jdk7-b64
|
||||
7d3bf00f3cc4f8125de1842521e7567f37dc84b8 jdk7-b65
|
||||
62109d1b9e7310f29ab51ca6f1d71b899c0ce6b0 jdk7-b66
|
||||
eb24af1404aec8aa140c4cd4d13d2839b150dd41 jdk7-b67
|
||||
bca2225b66d78c4bf4d9801f54cac7715a598650 jdk7-b68
|
||||
|
@ -41,3 +41,5 @@ c7ed15ab92ce36a09d264a5e34025884b2d7607f jdk7-b62
|
||||
269c1ec4435dfb7b452ae6e3bdde005d55c5c830 jdk7-b64
|
||||
e01380cd1de4ce048b87d059d238e5ab5e341947 jdk7-b65
|
||||
6bad5e3fe50337d95b1416d744780d65bc570da6 jdk7-b66
|
||||
c4523c6f82048f420bf0d57c4cd47976753b7d2c jdk7-b67
|
||||
e1b972ff53cd58f825791f8ed9b2deffd16e768c jdk7-b68
|
||||
|
@ -41,3 +41,5 @@ d20e45cd539f20405ff843652069cfd7550c5ab3 jdk7-b63
|
||||
047dd27fddb607f8135296b3754131f6e13cb8c7 jdk7-b64
|
||||
97fd9b42f5c2d342b90d18f0a2b57e4117e39415 jdk7-b65
|
||||
a821e059a961bcb02830280d51f6dd030425c066 jdk7-b66
|
||||
a12ea7c7b497b4ba7830550095ef633bd6f43971 jdk7-b67
|
||||
5182bcc9c60cac429d1f7988676cec7320752be3 jdk7-b68
|
||||
|
@ -110,7 +110,7 @@ BOOTSTRAP_TARGET_LEVEL = 5
|
||||
ifdef TARGET_CLASS_VERSION
|
||||
TARGET_LEVEL = $(TARGET_CLASS_VERSION)
|
||||
else
|
||||
TARGET_LEVEL = 6
|
||||
TARGET_LEVEL = 7
|
||||
endif
|
||||
|
||||
ifndef TARGET_JAVA
|
||||
|
@ -107,12 +107,12 @@ endif
|
||||
NO_PROPRIETARY_API_WARNINGS = -XDignore.symbol.file=true
|
||||
JAVACFLAGS += $(NO_PROPRIETARY_API_WARNINGS)
|
||||
|
||||
# Add the source level (currently all source is 1.5, should this be 1.6?)
|
||||
LANGUAGE_VERSION = -source 1.5
|
||||
# Add the source level
|
||||
LANGUAGE_VERSION = -source 7
|
||||
JAVACFLAGS += $(LANGUAGE_VERSION)
|
||||
|
||||
# Add the class version we want (currently this is 5, should it be 6 or even 7?)
|
||||
TARGET_CLASS_VERSION = 5
|
||||
# Add the class version we want
|
||||
TARGET_CLASS_VERSION = 7
|
||||
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
||||
JAVACFLAGS += $(CLASS_VERSION)
|
||||
JAVACFLAGS += -encoding ascii
|
||||
|
@ -41,3 +41,5 @@ a88386380bdaaa5ab4ffbedf22c57bac5dbec034 jdk7-b62
|
||||
ba36394eb84b949b31212bdb32a518a8f92bab5b jdk7-b64
|
||||
ba313800759b678979434d6da8ed3bf49eb8bea4 jdk7-b65
|
||||
57c71ad0341b8b64ed20f81151eb7f06324f8894 jdk7-b66
|
||||
18f526145aea355a9320b724373386fc2170f183 jdk7-b67
|
||||
d07e68298d4e17ebf93d8299e43fcc3ded26472a jdk7-b68
|
||||
|
@ -41,3 +41,5 @@ ae449e9c04c1fe651bd30f0f4d4cc24ba794e0c4 jdk7-b63
|
||||
a10eec7a1edf536f39b5828d8623054dbc62c2b7 jdk7-b64
|
||||
008c662e0ee9a91aebb75e46b97de979083d5c1c jdk7-b65
|
||||
22f9d5d5b5fe0f47048f41e6c6e54fee5edad0ec jdk7-b66
|
||||
a033af8d824a408d3ac602205ecdefc128749e1e jdk7-b67
|
||||
83b2a9331383f9db7a49350d4cb13b7635f6b861 jdk7-b68
|
||||
|
@ -30,8 +30,8 @@
|
||||
# one of the standard user build.properties files (see build.xml)
|
||||
|
||||
# options for the <javac> tasks used to compile the tools
|
||||
javac.source = 5
|
||||
javac.target = 5
|
||||
javac.source = 7
|
||||
javac.target = 7
|
||||
javac.debug = true
|
||||
javac.no.jdk.warnings = -XDignore.symbol.file=true
|
||||
# set the following to -version to verify the versions of javac being used
|
||||
|
@ -41,3 +41,5 @@ b8a6e883c0a6708f6d818815040525d472262495 jdk7-b63
|
||||
aaa25dfd3de68c6f1a1d3ef8c45fd99f76bca6dd jdk7-b64
|
||||
aa22a1be5866a6608ba17a7a443945559409ae0f jdk7-b65
|
||||
fa8712c099edd5c9a6b3ed9729353738004d388f jdk7-b66
|
||||
faa13cd4d6cdcfb155da5ed23b0da6e0ed0f9ea8 jdk7-b67
|
||||
845fa487f0f72a9f232ead8315c0087a477a5a31 jdk7-b68
|
||||
|
@ -30,8 +30,8 @@
|
||||
# one of the standard user build.properties files (see build.xml)
|
||||
|
||||
# options for the <javac> tasks used to compile the tools
|
||||
javac.source = 5
|
||||
javac.target = 5
|
||||
javac.source = 7
|
||||
javac.target = 7
|
||||
javac.debug = true
|
||||
javac.no.jdk.warnings = -XDignore.symbol.file=true
|
||||
# set the following to -version to verify the versions of javac being used
|
||||
|
@ -1,3 +1,6 @@
|
||||
^build/
|
||||
^dist/
|
||||
^nbproject/private/
|
||||
^make/netbeans/.*/nbproject/private/
|
||||
^make/netbeans/.*/build/
|
||||
^make/netbeans/.*/dist/
|
||||
|
@ -42,3 +42,5 @@ a50217eb3ee10b9f9547e0708e5c9625405083ef jdk7-b64
|
||||
382a27aa78d3236fa123c60577797a887fe93e09 jdk7-b65
|
||||
bd31b30a5b21f20e42965b1633f18a5c7946d398 jdk7-b66
|
||||
a952aafd5181af953b0ef3010dbd2fcc28460e8a jdk7-b67
|
||||
b23d905cb5d3b382295240d28ab0bfb266b4503c jdk7-b68
|
||||
226b20019b1f020c09ea97d137d98e011ce65d76 jdk7-b69
|
||||
|
@ -32,7 +32,7 @@ USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
--- end of LICENSE file ---
|
||||
%% This notice is provided with respect to ASM, which may be included with this software:
|
||||
Copyright (c) 2000-2005 INRIA, France Telecom
|
||||
Copyright (c) 2000-2007 INRIA, France Telecom
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 2007-2008 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 2007-2009 Sun Microsystems, Inc. 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
|
||||
@ -45,54 +45,49 @@
|
||||
# For OpenJDK, the jar files built here are installed directly into the
|
||||
# OpenJDK.
|
||||
#
|
||||
# For JDK, the binaries use pre-built/pre-signed/pre-obfuscated binary
|
||||
# files stored in the closed workspace that are not shipped in the
|
||||
# OpenJDK workspaces. We still build the JDK files here to verify the
|
||||
# files compile, and in preparation for possible signing and
|
||||
# obfuscation. Developers working on JCE in JDK must sign the JCE files
|
||||
# before testing: obfuscation is optional during development. The JCE
|
||||
# signing key is kept separate from the JDK workspace to prevent its
|
||||
# disclosure. The obfuscation tool has not been licensed for general
|
||||
# usage.
|
||||
#
|
||||
# For JDK, the binaries use pre-built/pre-signed binary files stored in
|
||||
# the closed workspace that are not shipped in the OpenJDK workspaces.
|
||||
# We still build the JDK files here to verify the files compile, and in
|
||||
# preparation for possible signing. Developers working on JCE in JDK
|
||||
# must sign the JCE files before testing. The JCE signing key is kept
|
||||
# separate from the JDK workspace to prevent its disclosure.
|
||||
#
|
||||
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
||||
# be built, obfuscated, signed, and then the resulting jar files MUST BE
|
||||
# CHECKED INTO THE CLOSED PART OF THE WORKSPACE*. This separate step
|
||||
# *MUST NOT BE FORGOTTEN*, otherwise a bug fixed in the source code will
|
||||
# not be reflected in the shipped binaries. The "release" target should be
|
||||
# be built and signed, and the resulting jar files MUST BE CHECKED INTO
|
||||
# THE CLOSED PART OF THE WORKSPACE*. This separate step *MUST NOT BE
|
||||
# FORGOTTEN*, otherwise a bug fixed in the source code will not be
|
||||
# reflected in the shipped binaries. The "release" target should be
|
||||
# used to generate the required files.
|
||||
#
|
||||
# There are a number of targets to help both JDK/OpenJDK developers.
|
||||
#
|
||||
# Main Targets (JDK/OPENJDK):
|
||||
#
|
||||
# all/clobber/clean The usual.
|
||||
# If OpenJDK, installs sunjce_provider.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunjce_provider.jar.
|
||||
# all/clobber/clean The usual.
|
||||
# If OpenJDK, installs sunjce_provider.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunjce_provider.jar.
|
||||
#
|
||||
# jar Builds/installs sunjce_provider.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
# jar Builds/installs sunjce_provider.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
#
|
||||
# Other lesser-used Targets (JDK/OPENJDK):
|
||||
#
|
||||
# build-jar Builds sunjce_provider.jar
|
||||
# (does not sign/install)
|
||||
# build-jar Builds sunjce_provider.jar
|
||||
# (does not sign/install)
|
||||
#
|
||||
# install-jar Alias for "jar" above.
|
||||
# install-jar Alias for "jar" above.
|
||||
#
|
||||
# Other targets (JDK only):
|
||||
#
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunjce_provider.jar (no install)
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunjce_provider.jar (no install)
|
||||
#
|
||||
# obfus Builds/obfuscates/signs sunjce_provider.jar
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
#
|
||||
# This makefile was written to support parallel target execution.
|
||||
#
|
||||
@ -103,7 +98,7 @@ PRODUCT = sun
|
||||
|
||||
#
|
||||
# The following is for when we need to do postprocessing
|
||||
# (signing/obfuscation) against a read-only build. If the OUTPUTDIR
|
||||
# (signing) against a read-only build. If the OUTPUTDIR
|
||||
# isn't writable, the build currently crashes out.
|
||||
#
|
||||
ifndef OPENJDK
|
||||
@ -158,8 +153,8 @@ endif # OPENJDK
|
||||
#
|
||||
# We use a variety of subdirectories in the $(TEMPDIR) depending on what
|
||||
# part of the build we're doing. Both OPENJDK/JDK builds are initially
|
||||
# done in the unsigned area. When files are signed or obfuscated in JDK,
|
||||
# they will be placed in the appropriate areas.
|
||||
# done in the unsigned area. When files are signed in JDK, they will be
|
||||
# placed in the appropriate areas.
|
||||
#
|
||||
UNSIGNED_DIR = $(TEMPDIR)/unsigned
|
||||
|
||||
@ -223,62 +218,15 @@ $(SIGNED_DIR)/sunjce_provider.jar:
|
||||
endif
|
||||
$(call sign-file, $(UNSIGNED_DIR)/sunjce_provider.jar)
|
||||
|
||||
# =====================================================
|
||||
# Obfuscate/sign/install the JDK build. Not needed for OpenJDK.
|
||||
#
|
||||
|
||||
OBFUS_DIR = $(JCE_BUILD_DIR)/obfus/sunjce
|
||||
|
||||
CLOSED_DIR = $(BUILDDIR)/closed/com/sun/crypto/provider
|
||||
|
||||
obfus: $(OBFUS_DIR)/sunjce_provider.jar
|
||||
$(release-warning)
|
||||
|
||||
ifndef ALT_JCE_BUILD_DIR
|
||||
$(OBFUS_DIR)/sunjce_provider.jar: build-jar $(JCE_MANIFEST_FILE) \
|
||||
$(OBFUS_DIR)/sunjce.dox
|
||||
else
|
||||
$(OBFUS_DIR)/sunjce_provider.jar: $(JCE_MANIFEST_FILE) $(OBFUS_DIR)/sunjce.dox
|
||||
@if [ ! -d $(CLASSDESTDIR) ] ; then \
|
||||
$(ECHO) "Couldn't find $(CLASSDESTDIR)"; \
|
||||
exit 1; \
|
||||
fi
|
||||
endif
|
||||
@$(ECHO) ">>>Obfuscating SunJCE Provider..."
|
||||
$(presign)
|
||||
$(preobfus)
|
||||
$(prep-target)
|
||||
$(CD) $(OBFUS_DIR); \
|
||||
$(OBFUSCATOR) -fv sunjce.dox
|
||||
@$(CD) $(OBFUS_DIR); $(java-vm-cleanup)
|
||||
$(BOOT_JAR_CMD) cmf $(JCE_MANIFEST_FILE) $@ \
|
||||
-C $(OBFUS_DIR)/build com \
|
||||
$(BOOT_JAR_JFLAGS)
|
||||
$(sign-target)
|
||||
@$(java-vm-cleanup)
|
||||
|
||||
$(OBFUS_DIR)/sunjce.dox: $(CLOSED_DIR)/obfus/sunjce.dox
|
||||
@$(ECHO) ">>>Creating sunjce.dox"
|
||||
$(prep-target)
|
||||
$(SED) "s:@@TEMPDIR@@:$(ABS_TEMPDIR):" $< > $@
|
||||
|
||||
#
|
||||
# The current obfuscator has a limitation in that it currently only
|
||||
# supports up to v49 class file format. Force v49 classfiles in our
|
||||
# builds for now.
|
||||
#
|
||||
SOURCE_LANGUAGE_VERSION = 5
|
||||
TARGET_CLASS_VERSION = 5
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Create the Release Engineering files. Obfuscated builds, etc.
|
||||
# Create the Release Engineering files. Signed builds, etc.
|
||||
#
|
||||
|
||||
release: $(OBFUS_DIR)/sunjce_provider.jar
|
||||
release: $(SIGNED_DIR)/sunjce_provider.jar
|
||||
$(RM) $(JCE_BUILD_DIR)/release/sunjce_provider.jar
|
||||
$(MKDIR) -p $(JCE_BUILD_DIR)/release
|
||||
$(CP) $(OBFUS_DIR)/sunjce_provider.jar $(JCE_BUILD_DIR)/release
|
||||
$(CP) $(SIGNED_DIR)/sunjce_provider.jar $(JCE_BUILD_DIR)/release
|
||||
$(release-warning)
|
||||
|
||||
endif # OPENJDK
|
||||
@ -320,5 +268,5 @@ clobber clean::
|
||||
|
||||
.PHONY: build-jar jar install-jar
|
||||
ifndef OPENJDK
|
||||
.PHONY: sign sign-jar obfus release install-prebuilt
|
||||
.PHONY: sign sign-jar release install-prebuilt
|
||||
endif
|
||||
|
@ -77,6 +77,7 @@ JAVA_JAVA_java = \
|
||||
java/lang/Compiler.java \
|
||||
java/lang/Throwable.java \
|
||||
java/lang/Exception.java \
|
||||
java/lang/ReflectiveOperationException.java \
|
||||
java/lang/IllegalAccessException.java \
|
||||
java/lang/InstantiationException.java \
|
||||
java/lang/ClassNotFoundException.java \
|
||||
|
@ -160,7 +160,6 @@ FILES_src = \
|
||||
\
|
||||
sun/nio/ByteBuffered.java \
|
||||
\
|
||||
sun/nio/ch/AbstractFuture.java \
|
||||
sun/nio/ch/AbstractPollArrayWrapper.java \
|
||||
sun/nio/ch/AllocatedNativeObject.java \
|
||||
sun/nio/ch/AsynchronousChannelGroupImpl.java \
|
||||
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 2007-2008 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 2007-2009 Sun Microsystems, Inc. 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
|
||||
@ -61,7 +61,7 @@ SIGNING_PASSPHRASE = $(SIGNING_KEY_DIR)/passphrase.txt
|
||||
SIGNING_ALIAS = jce_rsa
|
||||
|
||||
#
|
||||
# Defines for signing/obfuscating the various jar files.
|
||||
# Defines for signing the various jar files.
|
||||
#
|
||||
|
||||
define presign
|
||||
@ -100,19 +100,4 @@ define sign-file
|
||||
$(sign-target)
|
||||
endef
|
||||
|
||||
#
|
||||
# Location for the Obfuscation product. JDK currently has
|
||||
# the requirement that we obfuscate our JCE jars.
|
||||
#
|
||||
OBFUSCATOR = /security/tools/bin/obfus
|
||||
OBFUS_DIR = $(TEMPDIR)/obfus
|
||||
|
||||
define preobfus
|
||||
@if [ ! -f $(OBFUSCATOR) ]; then \
|
||||
$(ECHO) "\n$(OBFUSCATOR): Obfuscator *NOT* available..." \
|
||||
$(README-MAKEFILE_WARNING); \
|
||||
exit 2; \
|
||||
fi
|
||||
endef
|
||||
|
||||
endif # !OPENJDK
|
||||
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 2007-2008 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 2007-2009 Sun Microsystems, Inc. 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
|
||||
@ -44,64 +44,65 @@
|
||||
# For OpenJDK, the jar files built here are installed directly into the
|
||||
# OpenJDK.
|
||||
#
|
||||
# For JDK, the binaries use pre-built/pre-signed/pre-obfuscated binary
|
||||
# files stored in the closed workspace that are not shipped in the
|
||||
# OpenJDK workspaces. We still build the JDK files here to verify the
|
||||
# files compile, and in preparation for possible signing and
|
||||
# obfuscation. Developers working on JCE in JDK must sign the JCE files
|
||||
# before testing: obfuscation is optional during development. The JCE
|
||||
# signing key is kept separate from the JDK workspace to prevent its
|
||||
# disclosure. The obfuscation tool has not been licensed for general
|
||||
# usage.
|
||||
# For JDK, the binaries use pre-built/pre-signed binary files stored in
|
||||
# the closed workspace that are not shipped in the OpenJDK workspaces.
|
||||
# We still build the JDK files here to verify the files compile, and in
|
||||
# preparation for possible signing. Developers working on JCE in JDK
|
||||
# must sign the JCE files before testing. The JCE signing key is kept
|
||||
# separate from the JDK workspace to prevent its disclosure.
|
||||
#
|
||||
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
||||
# be built, obfuscated, signed, and the resulting jar files *MUST BE
|
||||
# CHECKED INTO THE CLOSED PART OF THE WORKSPACE*. This separate step
|
||||
# *MUST NOT BE FORGOTTEN*, otherwise a bug fixed in the source code will
|
||||
# not be reflected in the shipped binaries. The "release" target should
|
||||
# be used to generate the required files.
|
||||
# be built and signed, and the resulting jar files *MUST BE CHECKED INTO
|
||||
# THE CLOSED PART OF THE WORKSPACE*. This separate step *MUST NOT BE
|
||||
# FORGOTTEN*, otherwise a bug fixed in the source code will not be
|
||||
# reflected in the shipped binaries. The "release" target should be
|
||||
# used to generate the required files.
|
||||
#
|
||||
# There are a number of targets to help both JDK/OpenJDK developers.
|
||||
#
|
||||
# Main Targets (JDK/OPENJDK):
|
||||
#
|
||||
# all/clobber/clean The usual.
|
||||
# If OpenJDK, installs
|
||||
# jce.jar/limited policy files.
|
||||
# If JDK, installs prebuilt
|
||||
# jce.jar/limited policy files.
|
||||
# all/clobber/clean The usual.
|
||||
# If OpenJDK: builds/installs the
|
||||
# jce.jar/limited policy files.
|
||||
# If JDK: builds but does not install.
|
||||
# During full tops-down builds,
|
||||
# prebuilt/presigned jce.jar &
|
||||
# limited policy files are copied
|
||||
# in by make/java/redist/Makefile.
|
||||
# If you are working in this directory
|
||||
# and want to install the prebuilts,
|
||||
# use the "install-prebuilt" target.
|
||||
#
|
||||
# jar Builds/installs jce.jar
|
||||
# If OpenJDK, does not sign
|
||||
# If JDK, tries to sign
|
||||
# jar Builds/installs jce.jar
|
||||
# If OpenJDK, does not sign
|
||||
# If JDK, tries to sign
|
||||
#
|
||||
# Other lesser-used Targets (JDK/OPENJDK):
|
||||
#
|
||||
# build-jar Builds jce.jar (does not sign/install)
|
||||
# build-jar Builds jce.jar (does not sign/install)
|
||||
#
|
||||
# build-policy Builds policy files (does not sign/install)
|
||||
# build-policy Builds policy files (does not sign/install)
|
||||
#
|
||||
# install-jar Alias for "jar" above
|
||||
# install-jar Alias for "jar" above
|
||||
#
|
||||
# install-limited Builds/installs limited policy files
|
||||
# If OpenJDK, does not sign
|
||||
# If JDK, tries to sign
|
||||
# install-unlimited Builds/nstalls unlimited policy files
|
||||
# If OpenJDK, does not sign
|
||||
# If JDK, tries to sign
|
||||
# install-limited Builds/installs limited policy files
|
||||
# If OpenJDK, does not sign
|
||||
# If JDK, tries to sign
|
||||
# install-unlimited Builds/nstalls unlimited policy files
|
||||
# If OpenJDK, does not sign
|
||||
# If JDK, tries to sign
|
||||
#
|
||||
# Other targets (JDK only):
|
||||
#
|
||||
# sign Alias for sign-jar and sign-policy
|
||||
# sign-jar Builds/signs jce.jar file (no install)
|
||||
# sign-policy Builds/signs policy files (no install)
|
||||
# sign Alias for sign-jar and sign-policy
|
||||
# sign-jar Builds/signs jce.jar file (no install)
|
||||
# sign-policy Builds/signs policy files (no install)
|
||||
#
|
||||
# obfus Builds/obfuscates/signs jce.jar
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
#
|
||||
# This makefile was written to support parallel target execution.
|
||||
#
|
||||
@ -112,7 +113,7 @@ PRODUCT = sun
|
||||
|
||||
#
|
||||
# The following is for when we need to do postprocessing
|
||||
# (signing/obfuscation) against a read-only build. If the OUTPUTDIR
|
||||
# (signing) against a read-only build. If the OUTPUTDIR
|
||||
# isn't writable, the build currently crashes out.
|
||||
#
|
||||
ifndef OPENJDK
|
||||
@ -169,8 +170,8 @@ endif # OPENJDK
|
||||
#
|
||||
# We use a variety of subdirectories in the $(TEMPDIR) depending on what
|
||||
# part of the build we're doing. Both OPENJDK/JDK builds are initially
|
||||
# done in the unsigned area. When files are signed or obfuscated in JDK,
|
||||
# they will be placed in the appropriate areas.
|
||||
# done in the unsigned area. When files are signed in JDK, they will be
|
||||
# placed in the appropriate areas.
|
||||
#
|
||||
UNSIGNED_DIR = $(TEMPDIR)/unsigned
|
||||
|
||||
@ -178,7 +179,7 @@ include Defs-jce.gmk
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Build the unsigned jce.jar file. Signing/obfuscation comes later.
|
||||
# Build the unsigned jce.jar file. Signing comes later.
|
||||
#
|
||||
|
||||
JAR_DESTFILE = $(LIBDIR)/jce.jar
|
||||
@ -363,69 +364,13 @@ $(SIGNED_POLICY_BUILDDIR)/limited/local_policy.jar: \
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Obfuscate/sign/install the JDK build. Not needed for OpenJDK.
|
||||
#
|
||||
|
||||
OBFUS_DIR = $(JCE_BUILD_DIR)/obfus/jce
|
||||
|
||||
CLOSED_DIR = $(BUILDDIR)/closed/javax/crypto
|
||||
|
||||
obfus: $(OBFUS_DIR)/jce.jar
|
||||
$(release-warning)
|
||||
|
||||
ifndef ALT_JCE_BUILD_DIR
|
||||
$(OBFUS_DIR)/jce.jar: build-jar $(JCE_MANIFEST_FILE) $(OBFUS_DIR)/framework.dox
|
||||
else
|
||||
#
|
||||
# We have to remove the build dependency, otherwise, we'll try to rebuild it
|
||||
# which we can't do on a read-only filesystem.
|
||||
#
|
||||
$(OBFUS_DIR)/jce.jar: $(JCE_MANIFEST_FILE) $(OBFUS_DIR)/framework.dox
|
||||
@if [ ! -d $(CLASSDESTDIR) ] ; then \
|
||||
$(ECHO) "Couldn't find $(CLASSDESTDIR)"; \
|
||||
exit 1; \
|
||||
fi
|
||||
endif
|
||||
@$(ECHO) ">>>Obfuscating JCE framework..."
|
||||
$(presign)
|
||||
$(preobfus)
|
||||
$(prep-target)
|
||||
$(CD) $(OBFUS_DIR); \
|
||||
$(OBFUSCATOR) -fv framework.dox
|
||||
@$(CD) $(OBFUS_DIR); $(java-vm-cleanup)
|
||||
@#
|
||||
@# The sun.security.internal classes are currently not obfuscated
|
||||
@# due to an obfus problem. Manually copy them to the build directory
|
||||
@# so that they are included in the jce.jar file.
|
||||
@#
|
||||
$(CP) -r $(CLASSDESTDIR)/sun $(OBFUS_DIR)/build
|
||||
$(BOOT_JAR_CMD) cmf $(JCE_MANIFEST_FILE) $@ \
|
||||
-C $(OBFUS_DIR)/build javax \
|
||||
-C $(OBFUS_DIR)/build sun \
|
||||
$(BOOT_JAR_JFLAGS)
|
||||
$(sign-target)
|
||||
@$(java-vm-cleanup)
|
||||
|
||||
$(OBFUS_DIR)/framework.dox: $(CLOSED_DIR)/obfus/framework.dox
|
||||
@$(ECHO) ">>>Creating framework.dox"
|
||||
$(prep-target)
|
||||
$(SED) "s:@@TEMPDIR@@:$(ABS_TEMPDIR):" $< > $@
|
||||
|
||||
#
|
||||
# The current obfuscator has a limitation in that it currently only
|
||||
# supports up to v49 class file format. Force v49 classfiles in our
|
||||
# builds for now.
|
||||
#
|
||||
SOURCE_LANGUAGE_VERSION = 5
|
||||
TARGET_CLASS_VERSION = 5
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Create the Release Engineering files. Obfuscated builds,
|
||||
# Create the Release Engineering files. Signed builds,
|
||||
# unlimited policy file distribution, etc.
|
||||
#
|
||||
|
||||
release: $(OBFUS_DIR)/jce.jar sign-policy $(CLOSED_DIR)/doc/COPYRIGHT.html \
|
||||
CLOSED_DIR = $(BUILDDIR)/closed/javax/crypto
|
||||
|
||||
release: $(SIGNED_DIR)/jce.jar sign-policy $(CLOSED_DIR)/doc/COPYRIGHT.html \
|
||||
$(CLOSED_DIR)/doc/README.txt
|
||||
$(RM) -r \
|
||||
$(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy \
|
||||
@ -434,7 +379,7 @@ release: $(OBFUS_DIR)/jce.jar sign-policy $(CLOSED_DIR)/doc/COPYRIGHT.html \
|
||||
$(JCE_BUILD_DIR)/release/local_policy.jar \
|
||||
$(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy.zip
|
||||
$(MKDIR) -p $(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy
|
||||
$(CP) $(OBFUS_DIR)/jce.jar $(JCE_BUILD_DIR)/release
|
||||
$(CP) $(SIGNED_DIR)/jce.jar $(JCE_BUILD_DIR)/release
|
||||
$(CP) \
|
||||
$(SIGNED_POLICY_BUILDDIR)/limited/US_export_policy.jar \
|
||||
$(SIGNED_POLICY_BUILDDIR)/limited/local_policy.jar \
|
||||
@ -530,5 +475,5 @@ clobber clean::
|
||||
.PHONY: build-jar jar build-policy unlimited limited install-jar \
|
||||
install-limited install-unlimited
|
||||
ifndef OPENJDK
|
||||
.PHONY: sign sign-jar sign-policy obfus release install-prebuilt
|
||||
.PHONY: sign sign-jar sign-policy release install-prebuilt
|
||||
endif
|
||||
|
74
jdk/make/netbeans/jdwpgen/build.xml
Normal file
74
jdk/make/netbeans/jdwpgen/build.xml
Normal file
@ -0,0 +1,74 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!-- You may freely edit this file. See commented blocks below for -->
|
||||
<!-- some examples of how to customize the build. -->
|
||||
<!-- (If you delete it and reopen the project it will be recreated.) -->
|
||||
<!-- By default, only the Clean and Build commands use this build script. -->
|
||||
<!-- Commands such as Run, Debug, and Test only use this build script if -->
|
||||
<!-- the Compile on Save feature is turned off for the project. -->
|
||||
<!-- You can turn off the Compile on Save (or Deploy on Save) setting -->
|
||||
<!-- in the project's Project Properties dialog box.-->
|
||||
<project name="jdwpgen" default="default" basedir=".">
|
||||
<description>Builds, tests, and runs the project jdwpgen.</description>
|
||||
<import file="nbproject/build-impl.xml"/>
|
||||
<!--
|
||||
|
||||
There exist several targets which are by default empty and which can be
|
||||
used for execution of your tasks. These targets are usually executed
|
||||
before and after some main targets. They are:
|
||||
|
||||
-pre-init: called before initialization of project properties
|
||||
-post-init: called after initialization of project properties
|
||||
-pre-compile: called before javac compilation
|
||||
-post-compile: called after javac compilation
|
||||
-pre-compile-single: called before javac compilation of single file
|
||||
-post-compile-single: called after javac compilation of single file
|
||||
-pre-compile-test: called before javac compilation of JUnit tests
|
||||
-post-compile-test: called after javac compilation of JUnit tests
|
||||
-pre-compile-test-single: called before javac compilation of single JUnit test
|
||||
-post-compile-test-single: called after javac compilation of single JUunit test
|
||||
-pre-jar: called before JAR building
|
||||
-post-jar: called after JAR building
|
||||
-post-clean: called after cleaning build products
|
||||
|
||||
(Targets beginning with '-' are not intended to be called on their own.)
|
||||
|
||||
Example of inserting an obfuscator after compilation could look like this:
|
||||
|
||||
<target name="-post-compile">
|
||||
<obfuscate>
|
||||
<fileset dir="${build.classes.dir}"/>
|
||||
</obfuscate>
|
||||
</target>
|
||||
|
||||
For list of available properties check the imported
|
||||
nbproject/build-impl.xml file.
|
||||
|
||||
|
||||
Another way to customize the build is by overriding existing main targets.
|
||||
The targets of interest are:
|
||||
|
||||
-init-macrodef-javac: defines macro for javac compilation
|
||||
-init-macrodef-junit: defines macro for junit execution
|
||||
-init-macrodef-debug: defines macro for class debugging
|
||||
-init-macrodef-java: defines macro for class execution
|
||||
-do-jar-with-manifest: JAR building (if you are using a manifest)
|
||||
-do-jar-without-manifest: JAR building (if you are not using a manifest)
|
||||
run: execution of project
|
||||
-javadoc-build: Javadoc generation
|
||||
test-report: JUnit report generation
|
||||
|
||||
An example of overriding the target for project execution could look like this:
|
||||
|
||||
<target name="run" depends="jdwpgen-impl.jar">
|
||||
<exec dir="bin" executable="launcher.exe">
|
||||
<arg file="${dist.jar}"/>
|
||||
</exec>
|
||||
</target>
|
||||
|
||||
Notice that the overridden target depends on the jar target and not only on
|
||||
the compile target as the regular run target does. Again, for a list of available
|
||||
properties which you can use, check the target you are overriding in the
|
||||
nbproject/build-impl.xml file.
|
||||
|
||||
-->
|
||||
</project>
|
642
jdk/make/netbeans/jdwpgen/nbproject/build-impl.xml
Normal file
642
jdk/make/netbeans/jdwpgen/nbproject/build-impl.xml
Normal file
@ -0,0 +1,642 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
*** GENERATED FROM project.xml - DO NOT EDIT ***
|
||||
*** EDIT ../build.xml INSTEAD ***
|
||||
|
||||
For the purpose of easier reading the script
|
||||
is divided into following sections:
|
||||
|
||||
- initialization
|
||||
- compilation
|
||||
- jar
|
||||
- execution
|
||||
- debugging
|
||||
- javadoc
|
||||
- junit compilation
|
||||
- junit execution
|
||||
- junit debugging
|
||||
- applet
|
||||
- cleanup
|
||||
|
||||
-->
|
||||
<project xmlns:j2seproject1="http://www.netbeans.org/ns/j2se-project/1" xmlns:j2seproject3="http://www.netbeans.org/ns/j2se-project/3" xmlns:jaxrpc="http://www.netbeans.org/ns/j2se-project/jax-rpc" basedir=".." default="default" name="jdwpgen-impl">
|
||||
<target depends="test,jar,javadoc" description="Build and test whole project." name="default"/>
|
||||
<!--
|
||||
======================
|
||||
INITIALIZATION SECTION
|
||||
======================
|
||||
-->
|
||||
<target name="-pre-init">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="-pre-init" name="-init-private">
|
||||
<property file="nbproject/private/config.properties"/>
|
||||
<property file="nbproject/private/configs/${config}.properties"/>
|
||||
<property file="nbproject/private/private.properties"/>
|
||||
</target>
|
||||
<target depends="-pre-init,-init-private" name="-init-user">
|
||||
<property file="${user.properties.file}"/>
|
||||
<!-- The two properties below are usually overridden -->
|
||||
<!-- by the active platform. Just a fallback. -->
|
||||
<property name="default.javac.source" value="1.4"/>
|
||||
<property name="default.javac.target" value="1.4"/>
|
||||
</target>
|
||||
<target depends="-pre-init,-init-private,-init-user" name="-init-project">
|
||||
<property file="nbproject/configs/${config}.properties"/>
|
||||
<property file="nbproject/project.properties"/>
|
||||
</target>
|
||||
<target depends="-pre-init,-init-private,-init-user,-init-project,-init-macrodef-property" name="-do-init">
|
||||
<available file="${manifest.file}" property="manifest.available"/>
|
||||
<condition property="manifest.available+main.class">
|
||||
<and>
|
||||
<isset property="manifest.available"/>
|
||||
<isset property="main.class"/>
|
||||
<not>
|
||||
<equals arg1="${main.class}" arg2="" trim="true"/>
|
||||
</not>
|
||||
</and>
|
||||
</condition>
|
||||
<condition property="manifest.available+main.class+mkdist.available">
|
||||
<and>
|
||||
<istrue value="${manifest.available+main.class}"/>
|
||||
<isset property="libs.CopyLibs.classpath"/>
|
||||
</and>
|
||||
</condition>
|
||||
<condition property="have.tests">
|
||||
<or>
|
||||
<available file="${test.src.dir}"/>
|
||||
</or>
|
||||
</condition>
|
||||
<condition property="have.sources">
|
||||
<or>
|
||||
<available file="${src.src.dir}"/>
|
||||
</or>
|
||||
</condition>
|
||||
<condition property="netbeans.home+have.tests">
|
||||
<and>
|
||||
<isset property="netbeans.home"/>
|
||||
<isset property="have.tests"/>
|
||||
</and>
|
||||
</condition>
|
||||
<condition property="no.javadoc.preview">
|
||||
<and>
|
||||
<isset property="javadoc.preview"/>
|
||||
<isfalse value="${javadoc.preview}"/>
|
||||
</and>
|
||||
</condition>
|
||||
<property name="run.jvmargs" value=""/>
|
||||
<property name="javac.compilerargs" value=""/>
|
||||
<property name="work.dir" value="${basedir}"/>
|
||||
<condition property="no.deps">
|
||||
<and>
|
||||
<istrue value="${no.dependencies}"/>
|
||||
</and>
|
||||
</condition>
|
||||
<property name="javac.debug" value="true"/>
|
||||
<property name="javadoc.preview" value="true"/>
|
||||
<property name="application.args" value=""/>
|
||||
<property name="source.encoding" value="${file.encoding}"/>
|
||||
<condition property="javadoc.encoding.used" value="${javadoc.encoding}">
|
||||
<and>
|
||||
<isset property="javadoc.encoding"/>
|
||||
<not>
|
||||
<equals arg1="${javadoc.encoding}" arg2=""/>
|
||||
</not>
|
||||
</and>
|
||||
</condition>
|
||||
<property name="javadoc.encoding.used" value="${source.encoding}"/>
|
||||
<property name="includes" value="**"/>
|
||||
<property name="excludes" value=""/>
|
||||
<property name="do.depend" value="false"/>
|
||||
<condition property="do.depend.true">
|
||||
<istrue value="${do.depend}"/>
|
||||
</condition>
|
||||
<condition else="" property="javac.compilerargs.jaxws" value="-Djava.endorsed.dirs='${jaxws.endorsed.dir}'">
|
||||
<and>
|
||||
<isset property="jaxws.endorsed.dir"/>
|
||||
<available file="nbproject/jaxws-build.xml"/>
|
||||
</and>
|
||||
</condition>
|
||||
</target>
|
||||
<target name="-post-init">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="-pre-init,-init-private,-init-user,-init-project,-do-init" name="-init-check">
|
||||
<fail unless="src.src.dir">Must set src.src.dir</fail>
|
||||
<fail unless="test.src.dir">Must set test.src.dir</fail>
|
||||
<fail unless="build.dir">Must set build.dir</fail>
|
||||
<fail unless="dist.dir">Must set dist.dir</fail>
|
||||
<fail unless="build.classes.dir">Must set build.classes.dir</fail>
|
||||
<fail unless="dist.javadoc.dir">Must set dist.javadoc.dir</fail>
|
||||
<fail unless="build.test.classes.dir">Must set build.test.classes.dir</fail>
|
||||
<fail unless="build.test.results.dir">Must set build.test.results.dir</fail>
|
||||
<fail unless="build.classes.excludes">Must set build.classes.excludes</fail>
|
||||
<fail unless="dist.jar">Must set dist.jar</fail>
|
||||
</target>
|
||||
<target name="-init-macrodef-property">
|
||||
<macrodef name="property" uri="http://www.netbeans.org/ns/j2se-project/1">
|
||||
<attribute name="name"/>
|
||||
<attribute name="value"/>
|
||||
<sequential>
|
||||
<property name="@{name}" value="${@{value}}"/>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
</target>
|
||||
<target name="-init-macrodef-javac">
|
||||
<macrodef name="javac" uri="http://www.netbeans.org/ns/j2se-project/3">
|
||||
<attribute default="${src.src.dir}" name="srcdir"/>
|
||||
<attribute default="${build.classes.dir}" name="destdir"/>
|
||||
<attribute default="${javac.classpath}" name="classpath"/>
|
||||
<attribute default="${includes}" name="includes"/>
|
||||
<attribute default="${excludes}" name="excludes"/>
|
||||
<attribute default="${javac.debug}" name="debug"/>
|
||||
<attribute default="/does/not/exist" name="sourcepath"/>
|
||||
<element name="customize" optional="true"/>
|
||||
<sequential>
|
||||
<javac debug="@{debug}" deprecation="${javac.deprecation}" destdir="@{destdir}" encoding="${source.encoding}" excludes="@{excludes}" includeantruntime="false" includes="@{includes}" source="${javac.source}" sourcepath="@{sourcepath}" srcdir="@{srcdir}" target="${javac.target}">
|
||||
<classpath>
|
||||
<path path="@{classpath}"/>
|
||||
</classpath>
|
||||
<compilerarg line="${javac.compilerargs} ${javac.compilerargs.jaxws}"/>
|
||||
<customize/>
|
||||
</javac>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
<macrodef name="depend" uri="http://www.netbeans.org/ns/j2se-project/3">
|
||||
<attribute default="${src.src.dir}" name="srcdir"/>
|
||||
<attribute default="${build.classes.dir}" name="destdir"/>
|
||||
<attribute default="${javac.classpath}" name="classpath"/>
|
||||
<sequential>
|
||||
<depend cache="${build.dir}/depcache" destdir="@{destdir}" excludes="${excludes}" includes="${includes}" srcdir="@{srcdir}">
|
||||
<classpath>
|
||||
<path path="@{classpath}"/>
|
||||
</classpath>
|
||||
</depend>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
<macrodef name="force-recompile" uri="http://www.netbeans.org/ns/j2se-project/3">
|
||||
<attribute default="${build.classes.dir}" name="destdir"/>
|
||||
<sequential>
|
||||
<fail unless="javac.includes">Must set javac.includes</fail>
|
||||
<pathconvert pathsep="," property="javac.includes.binary">
|
||||
<path>
|
||||
<filelist dir="@{destdir}" files="${javac.includes}"/>
|
||||
</path>
|
||||
<globmapper from="*.java" to="*.class"/>
|
||||
</pathconvert>
|
||||
<delete>
|
||||
<files includes="${javac.includes.binary}"/>
|
||||
</delete>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
</target>
|
||||
<target name="-init-macrodef-junit">
|
||||
<macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-project/3">
|
||||
<attribute default="${includes}" name="includes"/>
|
||||
<attribute default="${excludes}" name="excludes"/>
|
||||
<attribute default="**" name="testincludes"/>
|
||||
<sequential>
|
||||
<junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" showoutput="true">
|
||||
<batchtest todir="${build.test.results.dir}">
|
||||
<fileset dir="${test.src.dir}" excludes="@{excludes},${excludes}" includes="@{includes}">
|
||||
<filename name="@{testincludes}"/>
|
||||
</fileset>
|
||||
</batchtest>
|
||||
<classpath>
|
||||
<path path="${run.test.classpath}"/>
|
||||
</classpath>
|
||||
<syspropertyset>
|
||||
<propertyref prefix="test-sys-prop."/>
|
||||
<mapper from="test-sys-prop.*" to="*" type="glob"/>
|
||||
</syspropertyset>
|
||||
<formatter type="brief" usefile="false"/>
|
||||
<formatter type="xml"/>
|
||||
<jvmarg line="${run.jvmargs}"/>
|
||||
</junit>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
</target>
|
||||
<target depends="-init-debug-args" name="-init-macrodef-nbjpda">
|
||||
<macrodef name="nbjpdastart" uri="http://www.netbeans.org/ns/j2se-project/1">
|
||||
<attribute default="${main.class}" name="name"/>
|
||||
<attribute default="${debug.classpath}" name="classpath"/>
|
||||
<attribute default="" name="stopclassname"/>
|
||||
<sequential>
|
||||
<nbjpdastart addressproperty="jpda.address" name="@{name}" stopclassname="@{stopclassname}" transport="${debug-transport}">
|
||||
<classpath>
|
||||
<path path="@{classpath}"/>
|
||||
</classpath>
|
||||
</nbjpdastart>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
<macrodef name="nbjpdareload" uri="http://www.netbeans.org/ns/j2se-project/1">
|
||||
<attribute default="${build.classes.dir}" name="dir"/>
|
||||
<sequential>
|
||||
<nbjpdareload>
|
||||
<fileset dir="@{dir}" includes="${fix.classes}">
|
||||
<include name="${fix.includes}*.class"/>
|
||||
</fileset>
|
||||
</nbjpdareload>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
</target>
|
||||
<target name="-init-debug-args">
|
||||
<property name="version-output" value="java version "${ant.java.version}"/>
|
||||
<condition property="have-jdk-older-than-1.4">
|
||||
<or>
|
||||
<contains string="${version-output}" substring="java version "1.0"/>
|
||||
<contains string="${version-output}" substring="java version "1.1"/>
|
||||
<contains string="${version-output}" substring="java version "1.2"/>
|
||||
<contains string="${version-output}" substring="java version "1.3"/>
|
||||
</or>
|
||||
</condition>
|
||||
<condition else="-Xdebug" property="debug-args-line" value="-Xdebug -Xnoagent -Djava.compiler=none">
|
||||
<istrue value="${have-jdk-older-than-1.4}"/>
|
||||
</condition>
|
||||
<condition else="dt_socket" property="debug-transport-by-os" value="dt_shmem">
|
||||
<os family="windows"/>
|
||||
</condition>
|
||||
<condition else="${debug-transport-by-os}" property="debug-transport" value="${debug.transport}">
|
||||
<isset property="debug.transport"/>
|
||||
</condition>
|
||||
</target>
|
||||
<target depends="-init-debug-args" name="-init-macrodef-debug">
|
||||
<macrodef name="debug" uri="http://www.netbeans.org/ns/j2se-project/3">
|
||||
<attribute default="${main.class}" name="classname"/>
|
||||
<attribute default="${debug.classpath}" name="classpath"/>
|
||||
<element name="customize" optional="true"/>
|
||||
<sequential>
|
||||
<java classname="@{classname}" dir="${work.dir}" fork="true">
|
||||
<jvmarg line="${debug-args-line}"/>
|
||||
<jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/>
|
||||
<jvmarg line="${run.jvmargs}"/>
|
||||
<classpath>
|
||||
<path path="@{classpath}"/>
|
||||
</classpath>
|
||||
<syspropertyset>
|
||||
<propertyref prefix="run-sys-prop."/>
|
||||
<mapper from="run-sys-prop.*" to="*" type="glob"/>
|
||||
</syspropertyset>
|
||||
<customize/>
|
||||
</java>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
</target>
|
||||
<target name="-init-macrodef-java">
|
||||
<macrodef name="java" uri="http://www.netbeans.org/ns/j2se-project/1">
|
||||
<attribute default="${main.class}" name="classname"/>
|
||||
<element name="customize" optional="true"/>
|
||||
<sequential>
|
||||
<java classname="@{classname}" dir="${work.dir}" fork="true">
|
||||
<jvmarg line="${run.jvmargs}"/>
|
||||
<classpath>
|
||||
<path path="${run.classpath}"/>
|
||||
</classpath>
|
||||
<syspropertyset>
|
||||
<propertyref prefix="run-sys-prop."/>
|
||||
<mapper from="run-sys-prop.*" to="*" type="glob"/>
|
||||
</syspropertyset>
|
||||
<customize/>
|
||||
</java>
|
||||
</sequential>
|
||||
</macrodef>
|
||||
</target>
|
||||
<target name="-init-presetdef-jar">
|
||||
<presetdef name="jar" uri="http://www.netbeans.org/ns/j2se-project/1">
|
||||
<jar compress="${jar.compress}" jarfile="${dist.jar}">
|
||||
<j2seproject1:fileset dir="${build.classes.dir}"/>
|
||||
</jar>
|
||||
</presetdef>
|
||||
</target>
|
||||
<target depends="-pre-init,-init-private,-init-user,-init-project,-do-init,-post-init,-init-check,-init-macrodef-property,-init-macrodef-javac,-init-macrodef-junit,-init-macrodef-nbjpda,-init-macrodef-debug,-init-macrodef-java,-init-presetdef-jar" name="init"/>
|
||||
<!--
|
||||
===================
|
||||
COMPILATION SECTION
|
||||
===================
|
||||
-->
|
||||
<target depends="init" name="deps-jar" unless="no.deps"/>
|
||||
<target depends="init,-check-automatic-build,-clean-after-automatic-build" name="-verify-automatic-build"/>
|
||||
<target depends="init" name="-check-automatic-build">
|
||||
<available file="${build.classes.dir}/.netbeans_automatic_build" property="netbeans.automatic.build"/>
|
||||
</target>
|
||||
<target depends="init" if="netbeans.automatic.build" name="-clean-after-automatic-build">
|
||||
<antcall target="clean"/>
|
||||
</target>
|
||||
<target depends="init,deps-jar" name="-pre-pre-compile">
|
||||
<mkdir dir="${build.classes.dir}"/>
|
||||
</target>
|
||||
<target name="-pre-compile">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target if="do.depend.true" name="-compile-depend">
|
||||
<j2seproject3:depend/>
|
||||
</target>
|
||||
<target depends="init,deps-jar,-pre-pre-compile,-pre-compile,-compile-depend" if="have.sources" name="-do-compile">
|
||||
<j2seproject3:javac/>
|
||||
<copy todir="${build.classes.dir}">
|
||||
<fileset dir="${src.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
|
||||
</copy>
|
||||
</target>
|
||||
<target name="-post-compile">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,deps-jar,-verify-automatic-build,-pre-pre-compile,-pre-compile,-do-compile,-post-compile" description="Compile project." name="compile"/>
|
||||
<target name="-pre-compile-single">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,deps-jar,-pre-pre-compile" name="-do-compile-single">
|
||||
<fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail>
|
||||
<j2seproject3:force-recompile/>
|
||||
<j2seproject3:javac excludes="" includes="${javac.includes}" sourcepath="${src.src.dir}"/>
|
||||
</target>
|
||||
<target name="-post-compile-single">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,deps-jar,-verify-automatic-build,-pre-pre-compile,-pre-compile-single,-do-compile-single,-post-compile-single" name="compile-single"/>
|
||||
<!--
|
||||
====================
|
||||
JAR BUILDING SECTION
|
||||
====================
|
||||
-->
|
||||
<target depends="init" name="-pre-pre-jar">
|
||||
<dirname file="${dist.jar}" property="dist.jar.dir"/>
|
||||
<mkdir dir="${dist.jar.dir}"/>
|
||||
</target>
|
||||
<target name="-pre-jar">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-jar,-pre-jar" name="-do-jar-without-manifest" unless="manifest.available">
|
||||
<j2seproject1:jar/>
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-jar,-pre-jar" if="manifest.available" name="-do-jar-with-manifest" unless="manifest.available+main.class">
|
||||
<j2seproject1:jar manifest="${manifest.file}"/>
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-jar,-pre-jar" if="manifest.available+main.class" name="-do-jar-with-mainclass" unless="manifest.available+main.class+mkdist.available">
|
||||
<j2seproject1:jar manifest="${manifest.file}">
|
||||
<j2seproject1:manifest>
|
||||
<j2seproject1:attribute name="Main-Class" value="${main.class}"/>
|
||||
</j2seproject1:manifest>
|
||||
</j2seproject1:jar>
|
||||
<echo>To run this application from the command line without Ant, try:</echo>
|
||||
<property location="${build.classes.dir}" name="build.classes.dir.resolved"/>
|
||||
<property location="${dist.jar}" name="dist.jar.resolved"/>
|
||||
<pathconvert property="run.classpath.with.dist.jar">
|
||||
<path path="${run.classpath}"/>
|
||||
<map from="${build.classes.dir.resolved}" to="${dist.jar.resolved}"/>
|
||||
</pathconvert>
|
||||
<echo>java -cp "${run.classpath.with.dist.jar}" ${main.class}</echo>
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-jar,-pre-jar" if="manifest.available+main.class+mkdist.available" name="-do-jar-with-libraries">
|
||||
<property location="${build.classes.dir}" name="build.classes.dir.resolved"/>
|
||||
<pathconvert property="run.classpath.without.build.classes.dir">
|
||||
<path path="${run.classpath}"/>
|
||||
<map from="${build.classes.dir.resolved}" to=""/>
|
||||
</pathconvert>
|
||||
<pathconvert pathsep=" " property="jar.classpath">
|
||||
<path path="${run.classpath.without.build.classes.dir}"/>
|
||||
<chainedmapper>
|
||||
<flattenmapper/>
|
||||
<globmapper from="*" to="lib/*"/>
|
||||
</chainedmapper>
|
||||
</pathconvert>
|
||||
<taskdef classname="org.netbeans.modules.java.j2seproject.copylibstask.CopyLibs" classpath="${libs.CopyLibs.classpath}" name="copylibs"/>
|
||||
<copylibs compress="${jar.compress}" jarfile="${dist.jar}" manifest="${manifest.file}" runtimeclasspath="${run.classpath.without.build.classes.dir}">
|
||||
<fileset dir="${build.classes.dir}"/>
|
||||
<manifest>
|
||||
<attribute name="Main-Class" value="${main.class}"/>
|
||||
<attribute name="Class-Path" value="${jar.classpath}"/>
|
||||
</manifest>
|
||||
</copylibs>
|
||||
<echo>To run this application from the command line without Ant, try:</echo>
|
||||
<property location="${dist.jar}" name="dist.jar.resolved"/>
|
||||
<echo>java -jar "${dist.jar.resolved}"</echo>
|
||||
</target>
|
||||
<target name="-post-jar">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,compile,-pre-jar,-do-jar-with-manifest,-do-jar-without-manifest,-do-jar-with-mainclass,-do-jar-with-libraries,-post-jar" description="Build JAR." name="jar"/>
|
||||
<!--
|
||||
=================
|
||||
EXECUTION SECTION
|
||||
=================
|
||||
-->
|
||||
<target depends="init,compile" description="Run a main class." name="run">
|
||||
<j2seproject1:java>
|
||||
<customize>
|
||||
<arg line="${application.args}"/>
|
||||
</customize>
|
||||
</j2seproject1:java>
|
||||
</target>
|
||||
<target name="-do-not-recompile">
|
||||
<property name="javac.includes.binary" value=""/>
|
||||
</target>
|
||||
<target depends="init,-do-not-recompile,compile-single" name="run-single">
|
||||
<fail unless="run.class">Must select one file in the IDE or set run.class</fail>
|
||||
<j2seproject1:java classname="${run.class}"/>
|
||||
</target>
|
||||
<!--
|
||||
=================
|
||||
DEBUGGING SECTION
|
||||
=================
|
||||
-->
|
||||
<target depends="init" if="netbeans.home" name="-debug-start-debugger">
|
||||
<j2seproject1:nbjpdastart name="${debug.class}"/>
|
||||
</target>
|
||||
<target depends="init,compile" name="-debug-start-debuggee">
|
||||
<j2seproject3:debug>
|
||||
<customize>
|
||||
<arg line="${application.args}"/>
|
||||
</customize>
|
||||
</j2seproject3:debug>
|
||||
</target>
|
||||
<target depends="init,compile,-debug-start-debugger,-debug-start-debuggee" description="Debug project in IDE." if="netbeans.home" name="debug"/>
|
||||
<target depends="init" if="netbeans.home" name="-debug-start-debugger-stepinto">
|
||||
<j2seproject1:nbjpdastart stopclassname="${main.class}"/>
|
||||
</target>
|
||||
<target depends="init,compile,-debug-start-debugger-stepinto,-debug-start-debuggee" if="netbeans.home" name="debug-stepinto"/>
|
||||
<target depends="init,compile-single" if="netbeans.home" name="-debug-start-debuggee-single">
|
||||
<fail unless="debug.class">Must select one file in the IDE or set debug.class</fail>
|
||||
<j2seproject3:debug classname="${debug.class}"/>
|
||||
</target>
|
||||
<target depends="init,-do-not-recompile,compile-single,-debug-start-debugger,-debug-start-debuggee-single" if="netbeans.home" name="debug-single"/>
|
||||
<target depends="init" name="-pre-debug-fix">
|
||||
<fail unless="fix.includes">Must set fix.includes</fail>
|
||||
<property name="javac.includes" value="${fix.includes}.java"/>
|
||||
</target>
|
||||
<target depends="init,-pre-debug-fix,compile-single" if="netbeans.home" name="-do-debug-fix">
|
||||
<j2seproject1:nbjpdareload/>
|
||||
</target>
|
||||
<target depends="init,-pre-debug-fix,-do-debug-fix" if="netbeans.home" name="debug-fix"/>
|
||||
<!--
|
||||
===============
|
||||
JAVADOC SECTION
|
||||
===============
|
||||
-->
|
||||
<target depends="init" name="-javadoc-build">
|
||||
<mkdir dir="${dist.javadoc.dir}"/>
|
||||
<javadoc additionalparam="${javadoc.additionalparam}" author="${javadoc.author}" charset="UTF-8" destdir="${dist.javadoc.dir}" docencoding="UTF-8" encoding="${javadoc.encoding.used}" failonerror="true" noindex="${javadoc.noindex}" nonavbar="${javadoc.nonavbar}" notree="${javadoc.notree}" private="${javadoc.private}" source="${javac.source}" splitindex="${javadoc.splitindex}" use="${javadoc.use}" useexternalfile="true" version="${javadoc.version}" windowtitle="${javadoc.windowtitle}">
|
||||
<classpath>
|
||||
<path path="${javac.classpath}"/>
|
||||
</classpath>
|
||||
<fileset dir="${src.src.dir}" excludes="${excludes}" includes="${includes}">
|
||||
<filename name="**/*.java"/>
|
||||
</fileset>
|
||||
</javadoc>
|
||||
</target>
|
||||
<target depends="init,-javadoc-build" if="netbeans.home" name="-javadoc-browse" unless="no.javadoc.preview">
|
||||
<nbbrowse file="${dist.javadoc.dir}/index.html"/>
|
||||
</target>
|
||||
<target depends="init,-javadoc-build,-javadoc-browse" description="Build Javadoc." name="javadoc"/>
|
||||
<!--
|
||||
=========================
|
||||
JUNIT COMPILATION SECTION
|
||||
=========================
|
||||
-->
|
||||
<target depends="init,compile" if="have.tests" name="-pre-pre-compile-test">
|
||||
<mkdir dir="${build.test.classes.dir}"/>
|
||||
</target>
|
||||
<target name="-pre-compile-test">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target if="do.depend.true" name="-compile-test-depend">
|
||||
<j2seproject3:depend classpath="${javac.test.classpath}" destdir="${build.test.classes.dir}" srcdir="${test.src.dir}"/>
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-compile-test,-pre-compile-test,-compile-test-depend" if="have.tests" name="-do-compile-test">
|
||||
<j2seproject3:javac classpath="${javac.test.classpath}" debug="true" destdir="${build.test.classes.dir}" srcdir="${test.src.dir}"/>
|
||||
<copy todir="${build.test.classes.dir}">
|
||||
<fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
|
||||
</copy>
|
||||
</target>
|
||||
<target name="-post-compile-test">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-compile-test,-pre-compile-test,-do-compile-test,-post-compile-test" name="compile-test"/>
|
||||
<target name="-pre-compile-test-single">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-compile-test,-pre-compile-test-single" if="have.tests" name="-do-compile-test-single">
|
||||
<fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail>
|
||||
<j2seproject3:force-recompile destdir="${build.test.classes.dir}"/>
|
||||
<j2seproject3:javac classpath="${javac.test.classpath}" debug="true" destdir="${build.test.classes.dir}" excludes="" includes="${javac.includes}" sourcepath="${test.src.dir}" srcdir="${test.src.dir}"/>
|
||||
<copy todir="${build.test.classes.dir}">
|
||||
<fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
|
||||
</copy>
|
||||
</target>
|
||||
<target name="-post-compile-test-single">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,compile,-pre-pre-compile-test,-pre-compile-test-single,-do-compile-test-single,-post-compile-test-single" name="compile-test-single"/>
|
||||
<!--
|
||||
=======================
|
||||
JUNIT EXECUTION SECTION
|
||||
=======================
|
||||
-->
|
||||
<target depends="init" if="have.tests" name="-pre-test-run">
|
||||
<mkdir dir="${build.test.results.dir}"/>
|
||||
</target>
|
||||
<target depends="init,compile-test,-pre-test-run" if="have.tests" name="-do-test-run">
|
||||
<j2seproject3:junit testincludes="**/*Test.java"/>
|
||||
</target>
|
||||
<target depends="init,compile-test,-pre-test-run,-do-test-run" if="have.tests" name="-post-test-run">
|
||||
<fail if="tests.failed">Some tests failed; see details above.</fail>
|
||||
</target>
|
||||
<target depends="init" if="have.tests" name="test-report"/>
|
||||
<target depends="init" if="netbeans.home+have.tests" name="-test-browse"/>
|
||||
<target depends="init,compile-test,-pre-test-run,-do-test-run,test-report,-post-test-run,-test-browse" description="Run unit tests." name="test"/>
|
||||
<target depends="init" if="have.tests" name="-pre-test-run-single">
|
||||
<mkdir dir="${build.test.results.dir}"/>
|
||||
</target>
|
||||
<target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-do-test-run-single">
|
||||
<fail unless="test.includes">Must select some files in the IDE or set test.includes</fail>
|
||||
<j2seproject3:junit excludes="" includes="${test.includes}"/>
|
||||
</target>
|
||||
<target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single" if="have.tests" name="-post-test-run-single">
|
||||
<fail if="tests.failed">Some tests failed; see details above.</fail>
|
||||
</target>
|
||||
<target depends="init,-do-not-recompile,compile-test-single,-pre-test-run-single,-do-test-run-single,-post-test-run-single" description="Run single unit test." name="test-single"/>
|
||||
<!--
|
||||
=======================
|
||||
JUNIT DEBUGGING SECTION
|
||||
=======================
|
||||
-->
|
||||
<target depends="init,compile-test" if="have.tests" name="-debug-start-debuggee-test">
|
||||
<fail unless="test.class">Must select one file in the IDE or set test.class</fail>
|
||||
<property location="${build.test.results.dir}/TEST-${test.class}.xml" name="test.report.file"/>
|
||||
<delete file="${test.report.file}"/>
|
||||
<mkdir dir="${build.test.results.dir}"/>
|
||||
<j2seproject3:debug classname="org.apache.tools.ant.taskdefs.optional.junit.JUnitTestRunner" classpath="${ant.home}/lib/ant.jar:${ant.home}/lib/ant-junit.jar:${debug.test.classpath}">
|
||||
<customize>
|
||||
<syspropertyset>
|
||||
<propertyref prefix="test-sys-prop."/>
|
||||
<mapper from="test-sys-prop.*" to="*" type="glob"/>
|
||||
</syspropertyset>
|
||||
<arg value="${test.class}"/>
|
||||
<arg value="showoutput=true"/>
|
||||
<arg value="formatter=org.apache.tools.ant.taskdefs.optional.junit.BriefJUnitResultFormatter"/>
|
||||
<arg value="formatter=org.apache.tools.ant.taskdefs.optional.junit.XMLJUnitResultFormatter,${test.report.file}"/>
|
||||
</customize>
|
||||
</j2seproject3:debug>
|
||||
</target>
|
||||
<target depends="init,compile-test" if="netbeans.home+have.tests" name="-debug-start-debugger-test">
|
||||
<j2seproject1:nbjpdastart classpath="${debug.test.classpath}" name="${test.class}"/>
|
||||
</target>
|
||||
<target depends="init,-do-not-recompile,compile-test-single,-debug-start-debugger-test,-debug-start-debuggee-test" name="debug-test"/>
|
||||
<target depends="init,-pre-debug-fix,compile-test-single" if="netbeans.home" name="-do-debug-fix-test">
|
||||
<j2seproject1:nbjpdareload dir="${build.test.classes.dir}"/>
|
||||
</target>
|
||||
<target depends="init,-pre-debug-fix,-do-debug-fix-test" if="netbeans.home" name="debug-fix-test"/>
|
||||
<!--
|
||||
=========================
|
||||
APPLET EXECUTION SECTION
|
||||
=========================
|
||||
-->
|
||||
<target depends="init,compile-single" name="run-applet">
|
||||
<fail unless="applet.url">Must select one file in the IDE or set applet.url</fail>
|
||||
<j2seproject1:java classname="sun.applet.AppletViewer">
|
||||
<customize>
|
||||
<arg value="${applet.url}"/>
|
||||
</customize>
|
||||
</j2seproject1:java>
|
||||
</target>
|
||||
<!--
|
||||
=========================
|
||||
APPLET DEBUGGING SECTION
|
||||
=========================
|
||||
-->
|
||||
<target depends="init,compile-single" if="netbeans.home" name="-debug-start-debuggee-applet">
|
||||
<fail unless="applet.url">Must select one file in the IDE or set applet.url</fail>
|
||||
<j2seproject3:debug classname="sun.applet.AppletViewer">
|
||||
<customize>
|
||||
<arg value="${applet.url}"/>
|
||||
</customize>
|
||||
</j2seproject3:debug>
|
||||
</target>
|
||||
<target depends="init,compile-single,-debug-start-debugger,-debug-start-debuggee-applet" if="netbeans.home" name="debug-applet"/>
|
||||
<!--
|
||||
===============
|
||||
CLEANUP SECTION
|
||||
===============
|
||||
-->
|
||||
<target depends="init" name="deps-clean" unless="no.deps"/>
|
||||
<target depends="init" name="-do-clean">
|
||||
<delete dir="${build.dir}"/>
|
||||
<delete dir="${dist.dir}"/>
|
||||
</target>
|
||||
<target name="-post-clean">
|
||||
<!-- Empty placeholder for easier customization. -->
|
||||
<!-- You can override this target in the ../build.xml file. -->
|
||||
</target>
|
||||
<target depends="init,deps-clean,-do-clean,-post-clean" description="Clean build products." name="clean"/>
|
||||
</project>
|
72
jdk/make/netbeans/jdwpgen/nbproject/findbugs.settings
Normal file
72
jdk/make/netbeans/jdwpgen/nbproject/findbugs.settings
Normal file
@ -0,0 +1,72 @@
|
||||
#FindBugs User Preferences
|
||||
#Mon Jun 15 13:37:16 PDT 2009
|
||||
detectorAbnormalFinallyBlockReturn=AbnormalFinallyBlockReturn|false
|
||||
detectorAbstractClassEmptyMethods=AbstractClassEmptyMethods|false
|
||||
detectorAbstractOverriddenMethod=AbstractOverriddenMethod|false
|
||||
detectorArrayBasedCollections=ArrayBasedCollections|false
|
||||
detectorArrayWrappedCallByReference=ArrayWrappedCallByReference|false
|
||||
detectorBloatedAssignmentScope=BloatedAssignmentScope|false
|
||||
detectorBloatedSynchronizedBlock=BloatedSynchronizedBlock|false
|
||||
detectorClassEnvy=ClassEnvy|false
|
||||
detectorCollectStatistics=CollectStatistics|false
|
||||
detectorConfusingAutoboxedOverloading=ConfusingAutoboxedOverloading|false
|
||||
detectorConstantListIndex=ConstantListIndex|false
|
||||
detectorCopiedOverriddenMethod=CopiedOverriddenMethod|false
|
||||
detectorCustomBuiltXML=CustomBuiltXML|false
|
||||
detectorCyclomaticComplexity=CyclomaticComplexity|false
|
||||
detectorDateComparison=DateComparison|false
|
||||
detectorDeclaredRuntimeException=DeclaredRuntimeException|false
|
||||
detectorDeletingWhileIterating=DeletingWhileIterating|false
|
||||
detectorDubiousListCollection=DubiousListCollection|false
|
||||
detectorFieldCouldBeLocal=FieldCouldBeLocal|false
|
||||
detectorFinalParameters=FinalParameters|false
|
||||
detectorFloatingPointLoops=FloatingPointLoops|false
|
||||
detectorInefficientStringBuffering=InefficientStringBuffering|false
|
||||
detectorInheritanceTypeChecking=InheritanceTypeChecking|false
|
||||
detectorJDBCVendorReliance=JDBCVendorReliance|false
|
||||
detectorListIndexedIterating=ListIndexedIterating|false
|
||||
detectorLiteralStringComparison=LiteralStringComparison|false
|
||||
detectorLocalSynchronizedCollection=LocalSynchronizedCollection|false
|
||||
detectorLostExceptionStackTrace=LostExceptionStackTrace|false
|
||||
detectorManualArrayCopy=ManualArrayCopy|false
|
||||
detectorMethodReturnsConstant=MethodReturnsConstant|false
|
||||
detectorNeedlessAutoboxing=NeedlessAutoboxing|false
|
||||
detectorNeedlessCustomSerialization=NeedlessCustomSerialization|false
|
||||
detectorNeedlessInstanceRetrieval=NeedlessInstanceRetrieval|false
|
||||
detectorNeedlessMemberCollectionSynchronization=NeedlessMemberCollectionSynchronization|false
|
||||
detectorNonCollectionMethodUse=NonCollectionMethodUse|false
|
||||
detectorNonOwnedSynchronization=NonOwnedSynchronization|false
|
||||
detectorNonRecycleableTaglibs=NonRecycleableTaglibs|false
|
||||
detectorOrphanedDOMNode=OrphanedDOMNode|false
|
||||
detectorOverlyConcreteParameter=OverlyConcreteParameter|false
|
||||
detectorParallelLists=ParallelLists|false
|
||||
detectorPartiallyConstructedObjectAccess=PartiallyConstructedObjectAccess|false
|
||||
detectorPossibleIncompleteSerialization=PossibleIncompleteSerialization|false
|
||||
detectorPossibleMemoryBloat=PossibleMemoryBloat|false
|
||||
detectorPossiblyRedundantMethodCalls=PossiblyRedundantMethodCalls|false
|
||||
detectorSQLInLoop=SQLInLoop|false
|
||||
detectorSection508Compliance=Section508Compliance|false
|
||||
detectorSillynessPotPourri=SillynessPotPourri|false
|
||||
detectorSloppyClassReflection=SloppyClassReflection|false
|
||||
detectorSluggishGui=SluggishGui|false
|
||||
detectorSpoiledChildInterfaceImplementor=SpoiledChildInterfaceImplementor|false
|
||||
detectorSpuriousThreadStates=SpuriousThreadStates|false
|
||||
detectorStaticArrayCreatedInMethod=StaticArrayCreatedInMethod|false
|
||||
detectorStaticMethodInstanceInvocation=StaticMethodInstanceInvocation|false
|
||||
detectorSuspiciousComparatorReturnValues=SuspiciousComparatorReturnValues|false
|
||||
detectorSuspiciousJDKVersionUse=SuspiciousJDKVersionUse|false
|
||||
detectorSuspiciousWaitOnConcurrentObject=SuspiciousWaitOnConcurrentObject|false
|
||||
detectorSyncCollectionIterators=SyncCollectionIterators|false
|
||||
detectorTailRecursion=TailRecursion|false
|
||||
detectorUnnecessaryStoreBeforeReturn=UnnecessaryStoreBeforeReturn|false
|
||||
detectorUnrelatedCollectionContents=UnrelatedCollectionContents|false
|
||||
detectorUnrelatedReturnValues=UnrelatedReturnValues|false
|
||||
detectorUseAddAll=UseAddAll|false
|
||||
detectorUseCharacterParameterizedMethod=UseCharacterParameterizedMethod|false
|
||||
detectorUseEnumCollections=UseEnumCollections|false
|
||||
detectorUseSplit=UseSplit|false
|
||||
detectorUseToArray=UseToArray|false
|
||||
detector_threshold=2
|
||||
effort=default
|
||||
filter_settings=Medium|BAD_PRACTICE,CORRECTNESS,I18N,MALICIOUS_CODE,MT_CORRECTNESS,PERFORMANCE,SECURITY,STYLE|false
|
||||
filter_settings_neg=|
|
8
jdk/make/netbeans/jdwpgen/nbproject/genfiles.properties
Normal file
8
jdk/make/netbeans/jdwpgen/nbproject/genfiles.properties
Normal file
@ -0,0 +1,8 @@
|
||||
build.xml.data.CRC32=b40e775f
|
||||
build.xml.script.CRC32=af8dc3cb
|
||||
build.xml.stylesheet.CRC32=958a1d3e
|
||||
# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml.
|
||||
# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you.
|
||||
nbproject/build-impl.xml.data.CRC32=b40e775f
|
||||
nbproject/build-impl.xml.script.CRC32=624d12c5
|
||||
nbproject/build-impl.xml.stylesheet.CRC32=65b8de21
|
65
jdk/make/netbeans/jdwpgen/nbproject/project.properties
Normal file
65
jdk/make/netbeans/jdwpgen/nbproject/project.properties
Normal file
@ -0,0 +1,65 @@
|
||||
application.title=jdwpgen
|
||||
application.vendor=sun
|
||||
build.classes.dir=${build.dir}/classes
|
||||
build.classes.excludes=**/*.java,**/*.form
|
||||
# This directory is removed when the project is cleaned:
|
||||
build.dir=build
|
||||
build.generated.dir=${build.dir}/generated
|
||||
# Only compile against the classpath explicitly listed here:
|
||||
build.sysclasspath=ignore
|
||||
build.test.classes.dir=${build.dir}/test/classes
|
||||
build.test.results.dir=${build.dir}/test/results
|
||||
# Uncomment to specify the preferred debugger connection transport:
|
||||
#debug.transport=dt_socket
|
||||
debug.classpath=\
|
||||
${run.classpath}
|
||||
debug.test.classpath=\
|
||||
${run.test.classpath}
|
||||
# This directory is removed when the project is cleaned:
|
||||
dist.dir=dist
|
||||
dist.jar=${dist.dir}/jdwpgen.jar
|
||||
dist.javadoc.dir=${dist.dir}/javadoc
|
||||
excludes=
|
||||
file.reference.tools-jdwpgen=../../tools/src/build/tools/jdwpgen
|
||||
file.reference.tools-src=../../tools/src
|
||||
includes=build/tools/jdwpgen/**
|
||||
jar.compress=false
|
||||
javac.classpath=
|
||||
# Space-separated list of extra javac options
|
||||
javac.compilerargs=-Xlint:all
|
||||
javac.deprecation=false
|
||||
javac.source=1.5
|
||||
javac.target=1.5
|
||||
javac.test.classpath=\
|
||||
${javac.classpath}:\
|
||||
${build.classes.dir}:\
|
||||
${libs.junit.classpath}:\
|
||||
${libs.junit_4.classpath}
|
||||
javadoc.additionalparam=
|
||||
javadoc.author=false
|
||||
javadoc.encoding=${source.encoding}
|
||||
javadoc.noindex=true
|
||||
javadoc.nonavbar=true
|
||||
javadoc.notree=true
|
||||
javadoc.private=true
|
||||
javadoc.splitindex=false
|
||||
javadoc.use=false
|
||||
javadoc.version=false
|
||||
javadoc.windowtitle=
|
||||
main.class=jdwpgen.Main
|
||||
manifest.file=manifest.mf
|
||||
meta.inf.dir=${src.dir}/META-INF
|
||||
platform.active=default_platform
|
||||
run.classpath=\
|
||||
${javac.classpath}:\
|
||||
${build.classes.dir}
|
||||
# Space-separated list of JVM arguments used when running the project
|
||||
# (you may also define separate properties like run-sys-prop.name=value instead of -Dname=value
|
||||
# or test-sys-prop.name=value to set system properties for unit tests):
|
||||
run.jvmargs=
|
||||
run.test.classpath=\
|
||||
${javac.test.classpath}:\
|
||||
${build.test.classes.dir}
|
||||
source.encoding=UTF-8
|
||||
src.src.dir=${file.reference.tools-src}
|
||||
test.src.dir=test
|
16
jdk/make/netbeans/jdwpgen/nbproject/project.xml
Normal file
16
jdk/make/netbeans/jdwpgen/nbproject/project.xml
Normal file
@ -0,0 +1,16 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://www.netbeans.org/ns/project/1">
|
||||
<type>org.netbeans.modules.java.j2seproject</type>
|
||||
<configuration>
|
||||
<data xmlns="http://www.netbeans.org/ns/j2se-project/3">
|
||||
<name>jdwpgen</name>
|
||||
<minimum-ant-version>1.6.5</minimum-ant-version>
|
||||
<source-roots>
|
||||
<root id="src.src.dir"/>
|
||||
</source-roots>
|
||||
<test-roots>
|
||||
<root id="test.src.dir"/>
|
||||
</test-roots>
|
||||
</data>
|
||||
</configuration>
|
||||
</project>
|
2
jdk/make/netbeans/jdwpgen/nbproject/sqe.properties
Normal file
2
jdk/make/netbeans/jdwpgen/nbproject/sqe.properties
Normal file
@ -0,0 +1,2 @@
|
||||
#Path to FindbugsSettingsFile (relative)
|
||||
findbugs.settings.file=findbugs.settings
|
@ -41,6 +41,7 @@ FILES_java = \
|
||||
sun/net/NetProperties.java \
|
||||
sun/net/NetHooks.java \
|
||||
sun/net/util/IPAddressUtil.java \
|
||||
sun/net/util/URLUtil.java \
|
||||
sun/net/dns/ResolverConfiguration.java \
|
||||
sun/net/dns/ResolverConfigurationImpl.java \
|
||||
sun/net/ftp/FtpClient.java \
|
||||
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 1996-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 1996-2009 Sun Microsystems, Inc. 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
|
||||
@ -60,7 +60,7 @@ ifeq ($(PLATFORM), windows)
|
||||
endif
|
||||
endif
|
||||
|
||||
SUBDIRS = other action util tools jgss krb5 smartcardio $(PKCS11) \
|
||||
SUBDIRS = ec other action util tools jgss krb5 smartcardio $(PKCS11) \
|
||||
$(JGSS_WRAPPER) $(MSCAPI)
|
||||
|
||||
all build clean clobber::
|
||||
|
54
jdk/make/sun/security/ec/FILES_c.gmk
Normal file
54
jdk/make/sun/security/ec/FILES_c.gmk
Normal file
@ -0,0 +1,54 @@
|
||||
#
|
||||
# Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
# particular file as subject to the "Classpath" exception as provided
|
||||
# by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
# CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
# have any questions.
|
||||
#
|
||||
|
||||
FILES_c = \
|
||||
ec.c \
|
||||
ec2_163.c \
|
||||
ec2_193.c \
|
||||
ec2_233.c \
|
||||
ec2_aff.c \
|
||||
ec2_mont.c \
|
||||
ecdecode.c \
|
||||
ecl.c \
|
||||
ecl_curve.c \
|
||||
ecl_gf.c \
|
||||
ecl_mult.c \
|
||||
ec_naf.c \
|
||||
ecp_192.c \
|
||||
ecp_224.c \
|
||||
ecp_256.c \
|
||||
ecp_384.c \
|
||||
ecp_521.c \
|
||||
ecp_aff.c \
|
||||
ecp_jac.c \
|
||||
ecp_jm.c \
|
||||
ecp_mont.c \
|
||||
mp_gf2m.c \
|
||||
mpi.c \
|
||||
mplogic.c \
|
||||
mpmontg.c \
|
||||
oid.c \
|
||||
secitem.c
|
||||
|
319
jdk/make/sun/security/ec/Makefile
Normal file
319
jdk/make/sun/security/ec/Makefile
Normal file
@ -0,0 +1,319 @@
|
||||
#
|
||||
# Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
# particular file as subject to the "Classpath" exception as provided
|
||||
# by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
# CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
# have any questions.
|
||||
#
|
||||
|
||||
#
|
||||
# Makefile for building sunec.jar and sunecc native library.
|
||||
#
|
||||
# This file was derived from make/com/sun/crypto/provider/Makefile.
|
||||
#
|
||||
|
||||
#
|
||||
# (The terms "OpenJDK" and "JDK" below refer to OpenJDK and Sun JDK builds
|
||||
# respectively.)
|
||||
#
|
||||
# JCE builds are very different between OpenJDK and JDK. The OpenJDK JCE
|
||||
# jar files do not require signing, but those for JDK do. If an unsigned
|
||||
# jar file is installed into JDK, things will break when the crypto
|
||||
# routines are called.
|
||||
#
|
||||
# This Makefile does the "real" build of the JCE files. For OpenJDK,
|
||||
# the jar files built here are installed directly into the OpenJDK.
|
||||
#
|
||||
# For JDK, the binaries use pre-built/pre-signed binary files stored in
|
||||
# the closed workspace that are not shipped in the OpenJDK workspaces.
|
||||
# We still build the JDK files here to verify the files compile, and in
|
||||
# preparation for possible signing. Developers working on JCE in JDK
|
||||
# must sign the JCE files before testing. The JCE signing key is kept
|
||||
# separate from the JDK workspace to prevent its disclosure.
|
||||
#
|
||||
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
||||
# be built, signed, and then the resulting jar files MUST BE CHECKED
|
||||
# INTO THE CLOSED PART OF THE WORKSPACE*. This separate step *MUST NOT
|
||||
# BE FORGOTTEN*, otherwise a bug fixed in the source code will not be
|
||||
# reflected in the shipped binaries. The "release" target should be
|
||||
# used to generate the required files.
|
||||
#
|
||||
# There are a number of targets to help both JDK/OpenJDK developers.
|
||||
#
|
||||
# Main Targets (JDK/OPENJDK):
|
||||
#
|
||||
# all/clobber/clean The usual, plus the native libraries.
|
||||
# If OpenJDK, installs sunec.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunec.jar.
|
||||
#
|
||||
# jar Builds/installs sunec.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
#
|
||||
# Other lesser-used Targets (JDK/OPENJDK):
|
||||
#
|
||||
# build-jar Builds sunec.jar
|
||||
# (does not sign/install)
|
||||
#
|
||||
# install-jar Alias for "jar" above.
|
||||
#
|
||||
# Other targets (JDK only):
|
||||
#
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunec.jar (no install)
|
||||
#
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
#
|
||||
# This makefile was written to support parallel target execution.
|
||||
#
|
||||
|
||||
BUILDDIR = ../../..
|
||||
PACKAGE = sun.security.ec
|
||||
PRODUCT = sun
|
||||
|
||||
#
|
||||
# The following is for when we need to do postprocessing
|
||||
# (signing) against a read-only build. If the OUTPUTDIR
|
||||
# isn't writable, the build currently crashes out.
|
||||
#
|
||||
ifndef OPENJDK
|
||||
ifdef ALT_JCE_BUILD_DIR
|
||||
# =====================================================
|
||||
# Where to place the output, in case we're building from a read-only
|
||||
# build area. (e.g. a release engineering build.)
|
||||
JCE_BUILD_DIR=${ALT_JCE_BUILD_DIR}
|
||||
IGNORE_WRITABLE_OUTPUTDIR_TEST=true
|
||||
else
|
||||
JCE_BUILD_DIR=${TEMPDIR}
|
||||
endif
|
||||
endif
|
||||
|
||||
include $(BUILDDIR)/common/Defs.gmk
|
||||
|
||||
#
|
||||
# Location for the newly built classfiles.
|
||||
#
|
||||
CLASSDESTDIR = $(TEMPDIR)/classes
|
||||
|
||||
#
|
||||
# Java files
|
||||
#
|
||||
AUTO_FILES_JAVA_DIRS = $(PKGDIR)
|
||||
|
||||
include $(BUILDDIR)/common/Classes.gmk
|
||||
|
||||
#
|
||||
# Some licensees do not get the native ECC sources, but we still need to
|
||||
# be able to build "all" for them. Check here to see if the sources are
|
||||
# available. If not, then skip them.
|
||||
#
|
||||
|
||||
NATIVE_ECC_AVAILABLE := $(shell \
|
||||
if [ -d $(SHARE_SRC)/native/$(PKGDIR) ] ; then \
|
||||
$(ECHO) true; \
|
||||
else \
|
||||
$(ECHO) false; \
|
||||
fi)
|
||||
|
||||
ifeq ($(NATIVE_ECC_AVAILABLE), true)
|
||||
|
||||
LIBRARY = sunecc
|
||||
|
||||
#
|
||||
# Java files that define native methods
|
||||
#
|
||||
FILES_export = \
|
||||
$(PKGDIR)/ECDHKeyAgreement.java \
|
||||
$(PKGDIR)/ECDSASignature.java \
|
||||
$(PKGDIR)/ECKeyPairGenerator.java
|
||||
|
||||
JAVAHFLAGS += -classpath $(CLASSDESTDIR)
|
||||
|
||||
#
|
||||
# C and C++ files
|
||||
#
|
||||
include FILES_c.gmk
|
||||
|
||||
FILES_cpp = ECC_JNI.cpp
|
||||
|
||||
CPLUSPLUSLIBRARY=true
|
||||
|
||||
FILES_m = mapfile-vers
|
||||
|
||||
#
|
||||
# Find native code
|
||||
#
|
||||
vpath %.cpp $(SHARE_SRC)/native/$(PKGDIR)
|
||||
|
||||
vpath %.c $(SHARE_SRC)/native/$(PKGDIR)
|
||||
|
||||
#
|
||||
# Find include files
|
||||
#
|
||||
OTHER_INCLUDES += -I$(SHARE_SRC)/native/$(PKGDIR)
|
||||
|
||||
#
|
||||
# Compiler flags
|
||||
#
|
||||
OTHER_CFLAGS += -DMP_API_COMPATIBLE -DNSS_ECC_MORE_THAN_SUITE_B
|
||||
|
||||
#
|
||||
# Libraries to link
|
||||
#
|
||||
ifeq ($(PLATFORM), windows)
|
||||
OTHER_LDLIBS += $(JVMLIB)
|
||||
else
|
||||
OTHER_LDLIBS = -ldl $(JVMLIB) $(LIBCXX)
|
||||
endif
|
||||
|
||||
include $(BUILDDIR)/common/Mapfile-vers.gmk
|
||||
|
||||
include $(BUILDDIR)/common/Library.gmk
|
||||
|
||||
endif # NATIVE_ECC_AVAILABLE
|
||||
|
||||
#
|
||||
# We use a variety of subdirectories in the $(TEMPDIR) depending on what
|
||||
# part of the build we're doing. Both OPENJDK/JDK builds are initially
|
||||
# done in the unsigned area. When files are signed in JDK,
|
||||
# they will be placed in the appropriate area.
|
||||
#
|
||||
UNSIGNED_DIR = $(TEMPDIR)/unsigned
|
||||
|
||||
include $(BUILDDIR)/javax/crypto/Defs-jce.gmk
|
||||
|
||||
#
|
||||
# Rules
|
||||
#
|
||||
|
||||
ifdef OPENJDK
|
||||
all: build-jar install-jar
|
||||
else
|
||||
all: build-jar install-prebuilt
|
||||
$(build-warning)
|
||||
endif
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Build the unsigned sunec.jar file.
|
||||
#
|
||||
|
||||
JAR_DESTFILE = $(EXTDIR)/sunec.jar
|
||||
|
||||
#
|
||||
# Since the -C option to jar is used below, each directory entry must be
|
||||
# preceded with the appropriate directory to "cd" into.
|
||||
#
|
||||
JAR_DIRS = $(patsubst %, -C $(CLASSDESTDIR) %, $(AUTO_FILES_JAVA_DIRS))
|
||||
|
||||
build-jar: $(UNSIGNED_DIR)/sunec.jar
|
||||
|
||||
#
|
||||
# Build sunec.jar.
|
||||
#
|
||||
$(UNSIGNED_DIR)/sunec.jar: build
|
||||
$(prep-target)
|
||||
$(BOOT_JAR_CMD) cf $@ $(JAR_DIRS) \
|
||||
$(BOOT_JAR_JFLAGS)
|
||||
@$(java-vm-cleanup)
|
||||
|
||||
|
||||
ifndef OPENJDK
|
||||
# =====================================================
|
||||
# Sign the provider jar file. Not needed for OpenJDK.
|
||||
#
|
||||
|
||||
SIGNED_DIR = $(JCE_BUILD_DIR)/signed
|
||||
|
||||
sign: sign-jar
|
||||
|
||||
sign-jar: $(SIGNED_DIR)/sunec.jar
|
||||
|
||||
ifndef ALT_JCE_BUILD_DIR
|
||||
$(SIGNED_DIR)/sunec.jar: $(UNSIGNED_DIR)/sunec.jar
|
||||
else
|
||||
#
|
||||
# We have to remove the build dependency, otherwise, we'll try to rebuild it
|
||||
# which we can't do on a read-only filesystem.
|
||||
#
|
||||
$(SIGNED_DIR)/sunec.jar:
|
||||
@if [ ! -r $(UNSIGNED_DIR)/sunec.jar ] ; then \
|
||||
$(ECHO) "Couldn't find $(UNSIGNED_DIR)/sunec.jar"; \
|
||||
exit 1; \
|
||||
fi
|
||||
endif
|
||||
$(call sign-file, $(UNSIGNED_DIR)/sunec.jar)
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Create the Release Engineering files. Signed builds, etc.
|
||||
#
|
||||
|
||||
release: $(SIGNED_DIR)/sunec.jar
|
||||
$(RM) $(JCE_BUILD_DIR)/release/sunec.jar
|
||||
$(MKDIR) -p $(JCE_BUILD_DIR)/release
|
||||
$(CP) $(SIGNED_DIR)/sunec.jar $(JCE_BUILD_DIR)/release
|
||||
$(release-warning)
|
||||
|
||||
endif # OPENJDK
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Install routines.
|
||||
#
|
||||
|
||||
#
|
||||
# Install sunec.jar, depending on which type is requested.
|
||||
#
|
||||
install-jar jar: $(JAR_DESTFILE)
|
||||
ifndef OPENJDK
|
||||
$(release-warning)
|
||||
endif
|
||||
|
||||
ifdef OPENJDK
|
||||
$(JAR_DESTFILE): $(UNSIGNED_DIR)/sunec.jar
|
||||
else
|
||||
$(JAR_DESTFILE): $(SIGNED_DIR)/sunec.jar
|
||||
endif
|
||||
$(install-file)
|
||||
|
||||
ifndef OPENJDK
|
||||
install-prebuilt:
|
||||
@$(ECHO) "\n>>>Installing prebuilt SunEC provider..."
|
||||
$(RM) $(JAR_DESTFILE)
|
||||
$(CP) $(PREBUILT_DIR)/ec/sunec.jar $(JAR_DESTFILE)
|
||||
endif
|
||||
|
||||
|
||||
# =====================================================
|
||||
# Support routines.
|
||||
#
|
||||
|
||||
clobber clean::
|
||||
$(RM) -r $(JAR_DESTFILE) $(TEMPDIR) $(JCE_BUILD_DIR)
|
||||
|
||||
.PHONY: build-jar jar install-jar
|
||||
ifndef OPENJDK
|
||||
.PHONY: sign sign-jar release install-prebuilt
|
||||
endif
|
37
jdk/make/sun/security/ec/mapfile-vers
Normal file
37
jdk/make/sun/security/ec/mapfile-vers
Normal file
@ -0,0 +1,37 @@
|
||||
#
|
||||
# Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
# particular file as subject to the "Classpath" exception as provided
|
||||
# by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
# CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
# have any questions.
|
||||
#
|
||||
|
||||
# Define public interface.
|
||||
|
||||
SUNWprivate_1.1 {
|
||||
global:
|
||||
Java_sun_security_ec_ECKeyPairGenerator_generateECKeyPair;
|
||||
Java_sun_security_ec_ECKeyPairGenerator_getEncodedBytes;
|
||||
Java_sun_security_ec_ECDSASignature_signDigest;
|
||||
Java_sun_security_ec_ECDSASignature_verifySignedDigest;
|
||||
Java_sun_security_ec_ECDHKeyAgreement_deriveKey;
|
||||
local:
|
||||
*;
|
||||
};
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 2005-2008 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -59,31 +59,31 @@
|
||||
#
|
||||
# Main Targets (JDK/OPENJDK):
|
||||
#
|
||||
# all/clobber/clean The usual, plus the native libraries.
|
||||
# If OpenJDK, installs sunmscapi.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunmscapi.jar.
|
||||
# all/clobber/clean The usual, plus the native libraries.
|
||||
# If OpenJDK, installs sunmscapi.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunmscapi.jar.
|
||||
#
|
||||
# jar Builds/installs sunmscapi.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
# jar Builds/installs sunmscapi.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
#
|
||||
# Other lesser-used Targets (JDK/OPENJDK):
|
||||
#
|
||||
# build-jar Builds sunmscapi.jar
|
||||
# (does not sign/install)
|
||||
# build-jar Builds sunmscapi.jar
|
||||
# (does not sign/install)
|
||||
#
|
||||
# install-jar Alias for "jar" above.
|
||||
# install-jar Alias for "jar" above.
|
||||
#
|
||||
# Other targets (JDK only):
|
||||
#
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunmscapi.jar (no install)
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunmscapi.jar (no install)
|
||||
#
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
#
|
||||
# This makefile was written to support parallel target execution.
|
||||
#
|
||||
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 1996-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 1996-2009 Sun Microsystems, Inc. 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
|
||||
@ -33,7 +33,6 @@ include $(BUILDDIR)/common/Defs.gmk
|
||||
#
|
||||
AUTO_FILES_JAVA_DIRS = \
|
||||
sun/security/acl \
|
||||
sun/security/ec \
|
||||
sun/security/jca \
|
||||
sun/security/pkcs \
|
||||
sun/security/pkcs12 \
|
||||
|
@ -1,5 +1,5 @@
|
||||
#
|
||||
# Copyright 2003-2008 Sun Microsystems, Inc. All Rights Reserved.
|
||||
# Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -59,31 +59,31 @@
|
||||
#
|
||||
# Main Targets (JDK/OPENJDK):
|
||||
#
|
||||
# all/clobber/clean The usual, plus the native libraries.
|
||||
# If OpenJDK, installs sunpkcs11.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunpkcs11.jar.
|
||||
# all/clobber/clean The usual, plus the native libraries.
|
||||
# If OpenJDK, installs sunpkcs11.jar.
|
||||
# If JDK, installs prebuilt
|
||||
# sunpkcs11.jar.
|
||||
#
|
||||
# jar Builds/installs sunpkcs11.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
# jar Builds/installs sunpkcs11.jar
|
||||
# If OpenJDK, does not sign.
|
||||
# If JDK, tries to sign.
|
||||
#
|
||||
# Other lesser-used Targets (JDK/OPENJDK):
|
||||
#
|
||||
# build-jar Builds sunpkcs11.jar
|
||||
# (does not sign/install)
|
||||
# build-jar Builds sunpkcs11.jar
|
||||
# (does not sign/install)
|
||||
#
|
||||
# install-jar Alias for "jar" above.
|
||||
# install-jar Alias for "jar" above.
|
||||
#
|
||||
# Other targets (JDK only):
|
||||
#
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunpkcs11.jar (no install)
|
||||
# sign Alias for sign-jar
|
||||
# sign-jar Builds/signs sunpkcs11.jar (no install)
|
||||
#
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
# release Builds all targets in preparation
|
||||
# for workspace integration.
|
||||
#
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
# install-prebuilt Installs the pre-built jar files
|
||||
#
|
||||
# This makefile was written to support parallel target execution.
|
||||
#
|
||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
||||
|
||||
abstract class AbstractNamedNode extends Node {
|
||||
|
||||
NameNode nameNode;
|
||||
NameNode nameNode = null;
|
||||
String name;
|
||||
|
||||
public String name() {
|
||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
||||
|
||||
class AltNode extends AbstractGroupNode implements TypeNode {
|
||||
|
||||
SelectNode select;
|
||||
SelectNode select = null;
|
||||
|
||||
void constrain(Context ctx) {
|
||||
super.constrain(ctx);
|
||||
|
@ -33,13 +33,7 @@ class ConstantSetNode extends AbstractNamedNode {
|
||||
/**
|
||||
* The mapping between a constant and its value.
|
||||
*/
|
||||
protected static Map<String, String> constantMap;
|
||||
|
||||
ConstantSetNode(){
|
||||
if (constantMap == null) {
|
||||
constantMap = new HashMap<String, String>();
|
||||
}
|
||||
}
|
||||
protected static final Map<String, String> constantMap = new HashMap<String, String>();
|
||||
|
||||
void prune() {
|
||||
List<Node> addons = new ArrayList<Node>();
|
||||
@ -95,9 +89,6 @@ class ConstantSetNode extends AbstractNamedNode {
|
||||
}
|
||||
|
||||
public static String getConstant(String key){
|
||||
if (constantMap == null) {
|
||||
return "";
|
||||
}
|
||||
String com = constantMap.get(key);
|
||||
if(com == null){
|
||||
return "";
|
||||
|
@ -25,13 +25,11 @@
|
||||
|
||||
package build.tools.jdwpgen;
|
||||
|
||||
import java.util.*;
|
||||
import java.io.*;
|
||||
|
||||
class Main {
|
||||
|
||||
static String specSource;
|
||||
static Map nameMap = new HashMap();
|
||||
static boolean genDebug = true;
|
||||
|
||||
static void usage() {
|
||||
@ -43,7 +41,6 @@ class Main {
|
||||
System.err.println("-doc <doc_output>");
|
||||
System.err.println("-jdi <java_output>");
|
||||
System.err.println("-include <include_file_output>");
|
||||
System.exit(1);
|
||||
}
|
||||
|
||||
public static void main(String args[]) throws IOException {
|
||||
@ -66,6 +63,7 @@ class Main {
|
||||
} else {
|
||||
System.err.println("Invalid option: " + arg);
|
||||
usage();
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
specSource = arg;
|
||||
@ -75,6 +73,7 @@ class Main {
|
||||
if (reader == null) {
|
||||
System.err.println("<spec_input> must be specified");
|
||||
usage();
|
||||
return;
|
||||
}
|
||||
|
||||
Parse parse = new Parse(reader);
|
||||
|
@ -36,7 +36,7 @@ abstract class Node {
|
||||
int lineno;
|
||||
List<String> commentList = new ArrayList<String>();
|
||||
Node parent = null;
|
||||
Context context;
|
||||
Context context = null;
|
||||
|
||||
static final int maxStructIndent = 5;
|
||||
static int structIndent = 0; // horrible hack
|
||||
@ -82,7 +82,7 @@ abstract class Node {
|
||||
}
|
||||
|
||||
void indent(PrintWriter writer, int depth) {
|
||||
for (int i = depth; i > 0; --i) {
|
||||
for (int i = 0; i < depth; i++) {
|
||||
writer.print(" ");
|
||||
}
|
||||
}
|
||||
@ -195,6 +195,6 @@ abstract class Node {
|
||||
System.err.println(Main.specSource + ":" + lineno + ": " +
|
||||
kind + " - " + errmsg);
|
||||
System.err.println();
|
||||
System.exit(1);
|
||||
throw new RuntimeException("Error: " + errmsg);
|
||||
}
|
||||
}
|
||||
|
@ -146,8 +146,12 @@ class Parse {
|
||||
Node node = (Node)proto.getClass().newInstance();
|
||||
node.set(kind, list, izer.lineno());
|
||||
return node;
|
||||
} catch (Exception exc) {
|
||||
} catch (InstantiationException exc) {
|
||||
error(exc.toString());
|
||||
return null;
|
||||
} catch (IllegalAccessException exc) {
|
||||
error(exc.toString());
|
||||
return null;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
@ -166,6 +170,6 @@ class Parse {
|
||||
void error(String errmsg) {
|
||||
System.err.println(Main.specSource + ":" + izer.lineno() +
|
||||
": " + errmsg);
|
||||
System.exit(1);
|
||||
throw new RuntimeException("Error: " + errmsg);
|
||||
}
|
||||
}
|
||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
||||
|
||||
class RepeatNode extends AbstractTypeNode {
|
||||
|
||||
Node member;
|
||||
Node member = null;
|
||||
|
||||
void constrain(Context ctx) {
|
||||
super.constrain(ctx);
|
||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
||||
|
||||
class SelectNode extends AbstractGroupNode implements TypeNode {
|
||||
|
||||
AbstractSimpleTypeNode typeNode;
|
||||
AbstractSimpleTypeNode typeNode = null;
|
||||
|
||||
void prune() {
|
||||
super.prune();
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2002-2009 Sun Microsystems, Inc. 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
|
||||
@ -56,12 +56,8 @@ public final class AESCipher extends CipherSpi {
|
||||
/**
|
||||
* Creates an instance of AES cipher with default ECB mode and
|
||||
* PKCS5Padding.
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public AESCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new CipherCore(new AESCrypt(), AESConstants.AES_BLOCK_SIZE);
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2002-2009 Sun Microsystems, Inc. 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
|
||||
@ -48,16 +48,9 @@ public final class AESKeyGenerator extends KeyGeneratorSpi {
|
||||
private int keySize = 16; // default keysize (in number of bytes)
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor.
|
||||
*/
|
||||
public AESKeyGenerator() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2004-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2004-2009 Sun Microsystems, Inc. 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
|
||||
@ -65,12 +65,8 @@ public final class AESWrapCipher extends CipherSpi {
|
||||
/**
|
||||
* Creates an instance of AES KeyWrap cipher with default
|
||||
* mode, i.e. "ECB" and padding scheme, i.e. "NoPadding".
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public AESWrapCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
cipher = new AESCrypt();
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -62,7 +62,6 @@ public final class ARCFOURCipher extends CipherSpi {
|
||||
|
||||
// called by the JCE framework
|
||||
public ARCFOURCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
S = new int[256];
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1998-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1998-2009 Sun Microsystems, Inc. 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
|
||||
@ -60,12 +60,8 @@ public final class BlowfishCipher extends CipherSpi {
|
||||
/**
|
||||
* Creates an instance of Blowfish cipher with default ECB mode and
|
||||
* PKCS5Padding.
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public BlowfishCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new CipherCore(new BlowfishCrypt(),
|
||||
BlowfishConstants.BLOWFISH_BLOCK_SIZE);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1998-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1998-2009 Sun Microsystems, Inc. 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
|
||||
@ -46,16 +46,9 @@ public final class BlowfishKeyGenerator extends KeyGeneratorSpi {
|
||||
private int keysize = 16; // default keysize (in number of bytes)
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public BlowfishKeyGenerator() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -56,12 +56,8 @@ public final class DESCipher extends CipherSpi {
|
||||
/**
|
||||
* Creates an instance of DES cipher with default ECB mode and
|
||||
* PKCS5Padding.
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public DESCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new CipherCore(new DESCrypt(), DESConstants.DES_BLOCK_SIZE);
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -42,17 +42,11 @@ import java.security.spec.InvalidKeySpecException;
|
||||
public final class DESKeyFactory extends SecretKeyFactorySpi {
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public DESKeyFactory() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates a <code>SecretKey</code> object from the provided key
|
||||
* specification (key material).
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -46,16 +46,9 @@ public final class DESKeyGenerator extends KeyGeneratorSpi {
|
||||
private SecureRandom random = null;
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public DESKeyGenerator() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -53,12 +53,8 @@ public final class DESedeCipher extends CipherSpi {
|
||||
/**
|
||||
* Creates an instance of DESede cipher with default ECB mode and
|
||||
* PKCS5Padding.
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public DESedeCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new CipherCore(new DESedeCrypt(), DESConstants.DES_BLOCK_SIZE);
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -42,16 +42,9 @@ import java.security.spec.InvalidKeySpecException;
|
||||
public final class DESedeKeyFactory extends SecretKeyFactorySpi {
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public DESedeKeyFactory() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have been " +
|
||||
"tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -47,16 +47,9 @@ public final class DESedeKeyGenerator extends KeyGeneratorSpi {
|
||||
private int keysize = 168;
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public DESedeKeyGenerator() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have been " +
|
||||
"tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2004-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2004-2009 Sun Microsystems, Inc. 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
|
||||
@ -74,12 +74,8 @@ public final class DESedeWrapCipher extends CipherSpi {
|
||||
/**
|
||||
* Creates an instance of CMS DESede KeyWrap cipher with default
|
||||
* mode, i.e. "CBC" and padding scheme, i.e. "NoPadding".
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity.
|
||||
*/
|
||||
public DESedeWrapCipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
cipher = new CipherBlockChaining(new DESedeCrypt());
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -58,16 +58,9 @@ extends KeyAgreementSpi {
|
||||
private BigInteger y = BigInteger.ZERO;
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public DHKeyAgreement() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have been " +
|
||||
"tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -49,16 +49,9 @@ import javax.crypto.spec.DHParameterSpec;
|
||||
public final class DHKeyFactory extends KeyFactorySpi {
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public DHKeyFactory() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2002-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2002-2009 Sun Microsystems, Inc. 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
|
||||
@ -241,7 +241,6 @@ final class HmacCore implements Cloneable {
|
||||
public static final class HmacSHA256 extends MacSpi implements Cloneable {
|
||||
private final HmacCore core;
|
||||
public HmacSHA256() throws NoSuchAlgorithmException {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new HmacCore("SHA-256", 64);
|
||||
}
|
||||
private HmacSHA256(HmacSHA256 base) throws CloneNotSupportedException {
|
||||
@ -278,7 +277,6 @@ final class HmacCore implements Cloneable {
|
||||
public static final class HmacSHA384 extends MacSpi implements Cloneable {
|
||||
private final HmacCore core;
|
||||
public HmacSHA384() throws NoSuchAlgorithmException {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new HmacCore("SHA-384", 128);
|
||||
}
|
||||
private HmacSHA384(HmacSHA384 base) throws CloneNotSupportedException {
|
||||
@ -315,7 +313,6 @@ final class HmacCore implements Cloneable {
|
||||
public static final class HmacSHA512 extends MacSpi implements Cloneable {
|
||||
private final HmacCore core;
|
||||
public HmacSHA512() throws NoSuchAlgorithmException {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new HmacCore("SHA-512", 128);
|
||||
}
|
||||
private HmacSHA512(HmacSHA512 base) throws CloneNotSupportedException {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1998-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1998-2009 Sun Microsystems, Inc. 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
|
||||
@ -44,16 +44,8 @@ public final class HmacMD5 extends MacSpi implements Cloneable {
|
||||
|
||||
/**
|
||||
* Standard constructor, creates a new HmacMD5 instance.
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public HmacMD5() throws NoSuchAlgorithmException {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
hmac = new HmacCore(MessageDigest.getInstance("MD5"),
|
||||
MD5_BLOCK_LENGTH);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1999-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1999-2009 Sun Microsystems, Inc. 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
|
||||
@ -46,16 +46,9 @@ public final class HmacMD5KeyGenerator extends KeyGeneratorSpi {
|
||||
private int keysize = 64; // default keysize (in number of bytes)
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public HmacMD5KeyGenerator() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -48,13 +48,8 @@ public final class HmacPKCS12PBESHA1 extends MacSpi implements Cloneable {
|
||||
|
||||
/**
|
||||
* Standard constructor, creates a new HmacSHA1 instance.
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public HmacPKCS12PBESHA1() throws NoSuchAlgorithmException {
|
||||
SunJCE.ensureIntegrity(this.getClass());
|
||||
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
||||
SHA1_BLOCK_LENGTH);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1998-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1998-2009 Sun Microsystems, Inc. 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
|
||||
@ -44,16 +44,8 @@ public final class HmacSHA1 extends MacSpi implements Cloneable {
|
||||
|
||||
/**
|
||||
* Standard constructor, creates a new HmacSHA1 instance.
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public HmacSHA1() throws NoSuchAlgorithmException {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
||||
SHA1_BLOCK_LENGTH);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1999-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1999-2009 Sun Microsystems, Inc. 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
|
||||
@ -46,16 +46,9 @@ public final class HmacSHA1KeyGenerator extends KeyGeneratorSpi {
|
||||
private int keysize = 64; // default keysize (in number of bytes)
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public HmacSHA1KeyGenerator() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,72 +0,0 @@
|
||||
/*
|
||||
* Copyright 2007 Sun Microsystems, Inc. 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. Sun designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
package com.sun.crypto.provider;
|
||||
|
||||
// NOTE: this class is duplicated amongst SunJCE, SunPKCS11, and SunMSCAPI.
|
||||
// All files should be kept in sync.
|
||||
|
||||
import java.io.*;
|
||||
import java.util.*;
|
||||
import java.util.jar.*;
|
||||
import java.net.URL;
|
||||
import java.net.JarURLConnection;
|
||||
import java.net.MalformedURLException;
|
||||
|
||||
import java.security.*;
|
||||
import java.security.cert.*;
|
||||
import java.security.cert.Certificate;
|
||||
|
||||
/**
|
||||
* This class verifies JAR files (and any supporting JAR files), and
|
||||
* determines whether they may be used in this implementation.
|
||||
*
|
||||
* The JCE in OpenJDK has an open cryptographic interface, meaning it
|
||||
* does not restrict which providers can be used. Compliance with
|
||||
* United States export controls and with local law governing the
|
||||
* import/export of products incorporating the JCE in the OpenJDK is
|
||||
* the responsibility of the licensee.
|
||||
*
|
||||
* @since 1.7
|
||||
*/
|
||||
final class JarVerifier {
|
||||
|
||||
private static final boolean debug = false;
|
||||
|
||||
/**
|
||||
* Verify the JAR file is signed by an entity which has a certificate
|
||||
* issued by a trusted CA.
|
||||
*
|
||||
* Note: this is a temporary method and will change soon to use the
|
||||
* exception chaining mechanism, which can provide more details
|
||||
* as to why the verification failed.
|
||||
*
|
||||
* @param c the class to be verified.
|
||||
* @return true if verification is successful.
|
||||
*/
|
||||
static boolean verify(final Class c) {
|
||||
return true;
|
||||
}
|
||||
}
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -109,7 +109,6 @@ final class KeyGeneratorCore {
|
||||
public static final class HmacSHA256KG extends KeyGeneratorSpi {
|
||||
private final KeyGeneratorCore core;
|
||||
public HmacSHA256KG() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new KeyGeneratorCore("HmacSHA256", 256);
|
||||
}
|
||||
protected void engineInit(SecureRandom random) {
|
||||
@ -131,7 +130,6 @@ final class KeyGeneratorCore {
|
||||
public static final class HmacSHA384KG extends KeyGeneratorSpi {
|
||||
private final KeyGeneratorCore core;
|
||||
public HmacSHA384KG() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new KeyGeneratorCore("HmacSHA384", 384);
|
||||
}
|
||||
protected void engineInit(SecureRandom random) {
|
||||
@ -153,7 +151,6 @@ final class KeyGeneratorCore {
|
||||
public static final class HmacSHA512KG extends KeyGeneratorSpi {
|
||||
private final KeyGeneratorCore core;
|
||||
public HmacSHA512KG() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new KeyGeneratorCore("HmacSHA512", 512);
|
||||
}
|
||||
protected void engineInit(SecureRandom random) {
|
||||
@ -175,7 +172,6 @@ final class KeyGeneratorCore {
|
||||
public static final class RC2KeyGenerator extends KeyGeneratorSpi {
|
||||
private final KeyGeneratorCore core;
|
||||
public RC2KeyGenerator() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new KeyGeneratorCore("RC2", 128);
|
||||
}
|
||||
protected void engineInit(SecureRandom random) {
|
||||
@ -201,7 +197,6 @@ final class KeyGeneratorCore {
|
||||
public static final class ARCFOURKeyGenerator extends KeyGeneratorSpi {
|
||||
private final KeyGeneratorCore core;
|
||||
public ARCFOURKeyGenerator() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
core = new KeyGeneratorCore("ARCFOUR", 128);
|
||||
}
|
||||
protected void engineInit(SecureRandom random) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
@ -49,16 +49,9 @@ abstract class PBEKeyFactory extends SecretKeyFactorySpi {
|
||||
private static HashSet<String> validTypes;
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Simple constructor
|
||||
*/
|
||||
private PBEKeyFactory(String keytype) {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
type = keytype;
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -55,16 +55,9 @@ public final class PBEWithMD5AndDESCipher extends CipherSpi {
|
||||
* unavailable
|
||||
* @exception NoSuchPaddingException if the required padding mechanism
|
||||
* (PKCS5Padding) is unavailable
|
||||
*
|
||||
* @exception SecurityException if this constructor fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public PBEWithMD5AndDESCipher()
|
||||
throws NoSuchAlgorithmException, NoSuchPaddingException {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
core = new PBECipherCore("DES");
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1998-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1998-2009 Sun Microsystems, Inc. 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
|
||||
@ -61,23 +61,14 @@ public final class PBEWithMD5AndTripleDESCipher extends CipherSpi {
|
||||
* Creates an instance of this cipher, and initializes its mode (CBC) and
|
||||
* padding (PKCS5).
|
||||
*
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception NoSuchAlgorithmException if the required cipher mode (CBC) is
|
||||
* unavailable
|
||||
* @exception NoSuchPaddingException if the required padding mechanism
|
||||
* (PKCS5Padding) is unavailable
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
*/
|
||||
public PBEWithMD5AndTripleDESCipher()
|
||||
throws NoSuchAlgorithmException, NoSuchPaddingException
|
||||
{
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
|
||||
// set the encapsulated cipher to do triple DES
|
||||
core = new PBECipherCore("DESede");
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -45,16 +45,9 @@ import javax.crypto.spec.SecretKeySpec;
|
||||
public final class PBKDF2HmacSHA1Factory extends SecretKeyFactorySpi {
|
||||
|
||||
/**
|
||||
* Verify the SunJCE provider in the constructor.
|
||||
*
|
||||
* @exception SecurityException if fails to verify
|
||||
* its own integrity
|
||||
* Empty constructor
|
||||
*/
|
||||
public PBKDF2HmacSHA1Factory() {
|
||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -370,7 +370,6 @@ final class PKCS12PBECipherCore {
|
||||
public static final class PBEWithSHA1AndDESede extends CipherSpi {
|
||||
private final PKCS12PBECipherCore core;
|
||||
public PBEWithSHA1AndDESede() throws NoSuchAlgorithmException {
|
||||
SunJCE.ensureIntegrity(this.getClass());
|
||||
core = new PKCS12PBECipherCore("DESede", 24);
|
||||
}
|
||||
protected byte[] engineDoFinal(byte[] in, int inOff, int inLen)
|
||||
@ -446,7 +445,6 @@ final class PKCS12PBECipherCore {
|
||||
public static final class PBEWithSHA1AndRC2_40 extends CipherSpi {
|
||||
private final PKCS12PBECipherCore core;
|
||||
public PBEWithSHA1AndRC2_40() throws NoSuchAlgorithmException {
|
||||
SunJCE.ensureIntegrity(this.getClass());
|
||||
core = new PKCS12PBECipherCore("RC2", 5);
|
||||
}
|
||||
protected byte[] engineDoFinal(byte[] in, int inOff, int inLen)
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -45,7 +45,6 @@ public final class RC2Cipher extends CipherSpi {
|
||||
private final RC2Crypt embeddedCipher;
|
||||
|
||||
public RC2Cipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
embeddedCipher = new RC2Crypt();
|
||||
core = new CipherCore(embeddedCipher, 8);
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2003-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2003-2009 Sun Microsystems, Inc. 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
|
||||
@ -111,7 +111,6 @@ public final class RSACipher extends CipherSpi {
|
||||
private String oaepHashAlgorithm = "SHA-1";
|
||||
|
||||
public RSACipher() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
paddingType = PAD_PKCS1;
|
||||
}
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -226,9 +226,6 @@ final class SslMacCore {
|
||||
|
||||
static final byte[] md5Pad1 = genPad((byte)0x36, 48);
|
||||
static final byte[] md5Pad2 = genPad((byte)0x5c, 48);
|
||||
static {
|
||||
SunJCE.ensureIntegrity(SslMacMD5.class);
|
||||
}
|
||||
}
|
||||
|
||||
// nested static class for the SslMacMD5 implementation
|
||||
@ -262,9 +259,6 @@ final class SslMacCore {
|
||||
|
||||
static final byte[] shaPad1 = genPad((byte)0x36, 40);
|
||||
static final byte[] shaPad2 = genPad((byte)0x5c, 40);
|
||||
static {
|
||||
SunJCE.ensureIntegrity(SslMacSHA1.class);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1997-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1997-2009 Sun Microsystems, Inc. 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
|
||||
@ -93,10 +93,6 @@ public final class SunJCE extends Provider {
|
||||
|
||||
static final SecureRandom RANDOM = new SecureRandom();
|
||||
|
||||
// After the SunJCE passed self-integrity checking,
|
||||
// verifiedSelfIntegrity will be set to true.
|
||||
private static boolean verifiedSelfIntegrity = false;
|
||||
|
||||
public SunJCE() {
|
||||
/* We are the "SunJCE" provider */
|
||||
super("SunJCE", 1.7d, info);
|
||||
@ -441,21 +437,4 @@ public final class SunJCE extends Provider {
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// set to true once self verification is complete
|
||||
private static volatile boolean integrityVerified;
|
||||
|
||||
static void ensureIntegrity(Class c) {
|
||||
if (verifySelfIntegrity(c) == false) {
|
||||
throw new SecurityException("The SunJCE provider may have " +
|
||||
"been tampered.");
|
||||
}
|
||||
}
|
||||
|
||||
static final boolean verifySelfIntegrity(Class c) {
|
||||
if (verifiedSelfIntegrity) {
|
||||
return true;
|
||||
}
|
||||
return (integrityVerified = JarVerifier.verify(c));
|
||||
}
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -52,7 +52,6 @@ public final class TlsKeyMaterialGenerator extends KeyGeneratorSpi {
|
||||
private int protocolVersion;
|
||||
|
||||
public TlsKeyMaterialGenerator() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
}
|
||||
|
||||
protected void engineInit(SecureRandom random) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -51,7 +51,6 @@ public final class TlsMasterSecretGenerator extends KeyGeneratorSpi {
|
||||
private int protocolVersion;
|
||||
|
||||
public TlsMasterSecretGenerator() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
}
|
||||
|
||||
protected void engineInit(SecureRandom random) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -109,7 +109,6 @@ public final class TlsPrfGenerator extends KeyGeneratorSpi {
|
||||
private TlsPrfParameterSpec spec;
|
||||
|
||||
public TlsPrfGenerator() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
}
|
||||
|
||||
protected void engineInit(SecureRandom random) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2005-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2005-2009 Sun Microsystems, Inc. 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
|
||||
@ -48,7 +48,6 @@ public final class TlsRsaPremasterSecretGenerator extends KeyGeneratorSpi {
|
||||
private SecureRandom random;
|
||||
|
||||
public TlsRsaPremasterSecretGenerator() {
|
||||
SunJCE.ensureIntegrity(getClass());
|
||||
}
|
||||
|
||||
protected void engineInit(SecureRandom random) {
|
||||
|
@ -51,7 +51,7 @@ public class BMPImageReaderSpi extends ImageReaderSpi {
|
||||
entensions,
|
||||
mimeType,
|
||||
"com.sun.imageio.plugins.bmp.BMPImageReader",
|
||||
STANDARD_INPUT_TYPE,
|
||||
new Class[] { ImageInputStream.class },
|
||||
writerSpiNames,
|
||||
false,
|
||||
null, null, null, null,
|
||||
|
@ -32,6 +32,7 @@ import java.awt.image.SinglePixelPackedSampleModel;
|
||||
import javax.imageio.spi.ImageWriterSpi;
|
||||
import javax.imageio.spi.ServiceRegistry;
|
||||
import javax.imageio.spi.IIORegistry;
|
||||
import javax.imageio.stream.ImageOutputStream;
|
||||
import javax.imageio.ImageWriter;
|
||||
import javax.imageio.ImageTypeSpecifier;
|
||||
import javax.imageio.IIOException;
|
||||
@ -55,7 +56,7 @@ public class BMPImageWriterSpi extends ImageWriterSpi {
|
||||
entensions,
|
||||
mimeType,
|
||||
"com.sun.imageio.plugins.bmp.BMPImageWriter",
|
||||
STANDARD_OUTPUT_TYPE,
|
||||
new Class[] { ImageOutputStream.class },
|
||||
readerSpiNames,
|
||||
false,
|
||||
null, null, null, null,
|
||||
|
@ -60,7 +60,7 @@ public class GIFImageReaderSpi extends ImageReaderSpi {
|
||||
suffixes,
|
||||
MIMETypes,
|
||||
readerClassName,
|
||||
STANDARD_INPUT_TYPE,
|
||||
new Class[] { ImageInputStream.class },
|
||||
writerSpiNames,
|
||||
true,
|
||||
GIFStreamMetadata.nativeMetadataFormatName,
|
||||
|
@ -31,6 +31,7 @@ import java.util.Locale;
|
||||
import javax.imageio.ImageTypeSpecifier;
|
||||
import javax.imageio.ImageWriter;
|
||||
import javax.imageio.spi.ImageWriterSpi;
|
||||
import javax.imageio.stream.ImageOutputStream;
|
||||
import com.sun.imageio.plugins.common.PaletteBuilder;
|
||||
|
||||
public class GIFImageWriterSpi extends ImageWriterSpi {
|
||||
@ -59,7 +60,7 @@ public class GIFImageWriterSpi extends ImageWriterSpi {
|
||||
suffixes,
|
||||
MIMETypes,
|
||||
writerClassName,
|
||||
STANDARD_OUTPUT_TYPE,
|
||||
new Class[] { ImageOutputStream.class },
|
||||
readerSpiNames,
|
||||
true,
|
||||
GIFWritableStreamMetadata.NATIVE_FORMAT_NAME,
|
||||
|
@ -46,7 +46,7 @@ public class JPEGImageReaderSpi extends ImageReaderSpi {
|
||||
JPEG.suffixes,
|
||||
JPEG.MIMETypes,
|
||||
"com.sun.imageio.plugins.jpeg.JPEGImageReader",
|
||||
STANDARD_INPUT_TYPE,
|
||||
new Class[] { ImageInputStream.class },
|
||||
writerSpiNames,
|
||||
true,
|
||||
JPEG.nativeStreamMetadataFormatName,
|
||||
|
@ -28,6 +28,7 @@ package com.sun.imageio.plugins.jpeg;
|
||||
import javax.imageio.spi.ImageWriterSpi;
|
||||
import javax.imageio.spi.ServiceRegistry;
|
||||
import javax.imageio.spi.IIORegistry;
|
||||
import javax.imageio.stream.ImageOutputStream;
|
||||
import javax.imageio.ImageWriter;
|
||||
import javax.imageio.ImageTypeSpecifier;
|
||||
import javax.imageio.IIOException;
|
||||
@ -49,7 +50,7 @@ public class JPEGImageWriterSpi extends ImageWriterSpi {
|
||||
JPEG.suffixes,
|
||||
JPEG.MIMETypes,
|
||||
"com.sun.imageio.plugins.jpeg.JPEGImageWriter",
|
||||
STANDARD_OUTPUT_TYPE,
|
||||
new Class[] { ImageOutputStream.class },
|
||||
readerSpiNames,
|
||||
true,
|
||||
JPEG.nativeStreamMetadataFormatName,
|
||||
|
@ -60,7 +60,7 @@ public class PNGImageReaderSpi extends ImageReaderSpi {
|
||||
suffixes,
|
||||
MIMETypes,
|
||||
readerClassName,
|
||||
STANDARD_INPUT_TYPE,
|
||||
new Class[] { ImageInputStream.class },
|
||||
writerSpiNames,
|
||||
false,
|
||||
null, null,
|
||||
|
@ -34,6 +34,7 @@ import javax.imageio.ImageTypeSpecifier;
|
||||
import javax.imageio.metadata.IIOMetadataFormat;
|
||||
import javax.imageio.metadata.IIOMetadataFormatImpl;
|
||||
import javax.imageio.spi.ImageWriterSpi;
|
||||
import javax.imageio.stream.ImageOutputStream;
|
||||
|
||||
public class PNGImageWriterSpi extends ImageWriterSpi {
|
||||
|
||||
@ -61,7 +62,7 @@ public class PNGImageWriterSpi extends ImageWriterSpi {
|
||||
suffixes,
|
||||
MIMETypes,
|
||||
writerClassName,
|
||||
STANDARD_OUTPUT_TYPE,
|
||||
new Class[] { ImageOutputStream.class },
|
||||
readerSpiNames,
|
||||
false,
|
||||
null, null,
|
||||
|
@ -55,7 +55,7 @@ public class WBMPImageReaderSpi extends ImageReaderSpi {
|
||||
entensions,
|
||||
mimeType,
|
||||
"com.sun.imageio.plugins.wbmp.WBMPImageReader",
|
||||
STANDARD_INPUT_TYPE,
|
||||
new Class[] { ImageInputStream.class },
|
||||
writerSpiNames,
|
||||
true,
|
||||
null, null, null, null,
|
||||
|
@ -28,6 +28,7 @@ package com.sun.imageio.plugins.wbmp;
|
||||
import javax.imageio.spi.ImageWriterSpi;
|
||||
import javax.imageio.spi.ServiceRegistry;
|
||||
import javax.imageio.spi.IIORegistry;
|
||||
import javax.imageio.stream.ImageOutputStream;
|
||||
import javax.imageio.ImageWriter;
|
||||
import javax.imageio.ImageTypeSpecifier;
|
||||
import javax.imageio.IIOException;
|
||||
@ -54,7 +55,7 @@ public class WBMPImageWriterSpi extends ImageWriterSpi {
|
||||
entensions,
|
||||
mimeType,
|
||||
"com.sun.imageio.plugins.wbmp.WBMPImageWriter",
|
||||
STANDARD_OUTPUT_TYPE,
|
||||
new Class[] { ImageOutputStream.class },
|
||||
readerSpiNames,
|
||||
true,
|
||||
null, null, null, null,
|
||||
|
@ -43,35 +43,35 @@ import javax.imageio.stream.ImageInputStream;
|
||||
*/
|
||||
public class StreamCloser {
|
||||
|
||||
private static WeakHashMap<ImageInputStream, Object> toCloseQueue;
|
||||
private static WeakHashMap<CloseAction, Object> toCloseQueue;
|
||||
private static Thread streamCloser;
|
||||
|
||||
public static void addToQueue(ImageInputStream iis) {
|
||||
public static void addToQueue(CloseAction ca) {
|
||||
synchronized (StreamCloser.class) {
|
||||
if (toCloseQueue == null) {
|
||||
toCloseQueue =
|
||||
new WeakHashMap<ImageInputStream, Object>();
|
||||
new WeakHashMap<CloseAction, Object>();
|
||||
}
|
||||
|
||||
toCloseQueue.put(iis, null);
|
||||
toCloseQueue.put(ca, null);
|
||||
|
||||
if (streamCloser == null) {
|
||||
final Runnable streamCloserRunnable = new Runnable() {
|
||||
public void run() {
|
||||
if (toCloseQueue != null) {
|
||||
synchronized (StreamCloser.class) {
|
||||
Set<ImageInputStream> set =
|
||||
Set<CloseAction> set =
|
||||
toCloseQueue.keySet();
|
||||
// Make a copy of the set in order to avoid
|
||||
// concurrent modification (the is.close()
|
||||
// will in turn call removeFromQueue())
|
||||
ImageInputStream[] streams =
|
||||
new ImageInputStream[set.size()];
|
||||
streams = set.toArray(streams);
|
||||
for (ImageInputStream is : streams) {
|
||||
if (is != null) {
|
||||
CloseAction[] actions =
|
||||
new CloseAction[set.size()];
|
||||
actions = set.toArray(actions);
|
||||
for (CloseAction ca : actions) {
|
||||
if (ca != null) {
|
||||
try {
|
||||
is.close();
|
||||
ca.performAction();
|
||||
} catch (IOException e) {
|
||||
}
|
||||
}
|
||||
@ -106,10 +106,28 @@ public class StreamCloser {
|
||||
}
|
||||
}
|
||||
|
||||
public static void removeFromQueue(ImageInputStream iis) {
|
||||
public static void removeFromQueue(CloseAction ca) {
|
||||
synchronized (StreamCloser.class) {
|
||||
if (toCloseQueue != null) {
|
||||
toCloseQueue.remove(iis);
|
||||
toCloseQueue.remove(ca);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static CloseAction createCloseAction(ImageInputStream iis) {
|
||||
return new CloseAction(iis);
|
||||
}
|
||||
|
||||
public static final class CloseAction {
|
||||
private ImageInputStream iis;
|
||||
|
||||
private CloseAction(ImageInputStream iis) {
|
||||
this.iis = iis;
|
||||
}
|
||||
|
||||
public void performAction() throws IOException {
|
||||
if (iis != null) {
|
||||
iis.close();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2000-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2000-2009 Sun Microsystems, Inc. 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
|
||||
@ -922,7 +922,7 @@ public class DnsContext extends ComponentDirContext {
|
||||
|
||||
//---------- Debugging
|
||||
|
||||
public static boolean debug = false;
|
||||
private static final boolean debug = false;
|
||||
|
||||
private static final void dprint(String msg) {
|
||||
if (debug) {
|
||||
@ -972,14 +972,11 @@ class NameClassPairEnumeration implements NamingEnumeration {
|
||||
}
|
||||
|
||||
/*
|
||||
* ctx will be closed when no longer needed by the enumeration.
|
||||
* ctx will be set to null when no longer needed by the enumeration.
|
||||
*/
|
||||
public void close () {
|
||||
public void close() {
|
||||
nodes = null;
|
||||
if (ctx != null) {
|
||||
ctx.close();
|
||||
ctx = null;
|
||||
}
|
||||
ctx = null;
|
||||
}
|
||||
|
||||
public boolean hasMore() {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1999-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1999-2009 Sun Microsystems, Inc. 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
|
||||
@ -41,6 +41,15 @@ import javax.sound.midi.spi.MidiFileWriter;
|
||||
import javax.sound.midi.spi.SoundbankReader;
|
||||
import javax.sound.midi.spi.MidiDeviceProvider;
|
||||
|
||||
import javax.sound.midi.Receiver;
|
||||
import javax.sound.midi.Sequencer;
|
||||
import javax.sound.midi.Synthesizer;
|
||||
import javax.sound.midi.Transmitter;
|
||||
import javax.sound.sampled.Clip;
|
||||
import javax.sound.sampled.Port;
|
||||
import javax.sound.sampled.SourceDataLine;
|
||||
import javax.sound.sampled.TargetDataLine;
|
||||
|
||||
|
||||
/**
|
||||
* JDK13Services uses the Service class in JDK 1.3
|
||||
@ -186,6 +195,16 @@ public class JDK13Services {
|
||||
If the property is not set, null is returned.
|
||||
*/
|
||||
private static synchronized String getDefaultProvider(Class typeClass) {
|
||||
if (!SourceDataLine.class.equals(typeClass)
|
||||
&& !TargetDataLine.class.equals(typeClass)
|
||||
&& !Clip.class.equals(typeClass)
|
||||
&& !Port.class.equals(typeClass)
|
||||
&& !Receiver.class.equals(typeClass)
|
||||
&& !Transmitter.class.equals(typeClass)
|
||||
&& !Synthesizer.class.equals(typeClass)
|
||||
&& !Sequencer.class.equals(typeClass)) {
|
||||
return null;
|
||||
}
|
||||
String value;
|
||||
String propertyName = typeClass.getName();
|
||||
value = JSSecurityManager.getProperty(propertyName);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1999-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1999-2009 Sun Microsystems, Inc. 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
|
||||
@ -283,28 +283,37 @@ class JSSecurityManager {
|
||||
|
||||
|
||||
static List getProviders(final Class providerClass) {
|
||||
PrivilegedAction action = new PrivilegedAction() {
|
||||
public Object run() {
|
||||
List p = new ArrayList();
|
||||
Iterator ps = Service.providers(providerClass);
|
||||
while (ps.hasNext()) {
|
||||
try {
|
||||
Object provider = ps.next();
|
||||
if (providerClass.isInstance(provider)) {
|
||||
// $$mp 2003-08-22
|
||||
// Always adding at the beginning reverses the
|
||||
// order of the providers. So we no longer have
|
||||
// to do this in AudioSystem and MidiSystem.
|
||||
p.add(0, provider);
|
||||
}
|
||||
} catch (Throwable t) {
|
||||
//$$fb 2002-11-07: do not fail on SPI not found
|
||||
if (Printer.err) t.printStackTrace();
|
||||
} }
|
||||
return p;
|
||||
List p = new ArrayList();
|
||||
// Service.providers(Class) just creates "lazy" iterator instance,
|
||||
// so it doesn't require do be called from privileged section
|
||||
final Iterator ps = Service.providers(providerClass);
|
||||
|
||||
// the iterator's hasNext() method looks through classpath for
|
||||
// the provider class names, so it requires read permissions
|
||||
PrivilegedAction<Boolean> hasNextAction = new PrivilegedAction<Boolean>() {
|
||||
public Boolean run() {
|
||||
return ps.hasNext();
|
||||
}
|
||||
};
|
||||
|
||||
while (AccessController.doPrivileged(hasNextAction)) {
|
||||
try {
|
||||
// the iterator's next() method creates instances of the
|
||||
// providers and it should be called in the current security
|
||||
// context
|
||||
Object provider = ps.next();
|
||||
if (providerClass.isInstance(provider)) {
|
||||
// $$mp 2003-08-22
|
||||
// Always adding at the beginning reverses the
|
||||
// order of the providers. So we no longer have
|
||||
// to do this in AudioSystem and MidiSystem.
|
||||
p.add(0, provider);
|
||||
}
|
||||
};
|
||||
List providers = (List) AccessController.doPrivileged(action);
|
||||
return providers;
|
||||
} catch (Throwable t) {
|
||||
//$$fb 2002-11-07: do not fail on SPI not found
|
||||
if (Printer.err) t.printStackTrace();
|
||||
}
|
||||
}
|
||||
return p;
|
||||
}
|
||||
}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 1999-2007 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 1999-2009 Sun Microsystems, Inc. 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
|
||||
@ -82,7 +82,7 @@ public class StandardMidiFileWriter extends MidiFileWriter {
|
||||
/**
|
||||
* MIDI parser types
|
||||
*/
|
||||
public static final int types[] = {
|
||||
private static final int types[] = {
|
||||
MIDI_TYPE_0,
|
||||
MIDI_TYPE_1
|
||||
};
|
||||
|
@ -60,8 +60,14 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
*/
|
||||
public abstract String engineGetURI();
|
||||
|
||||
/**
|
||||
* Returns the output length of the hash/digest.
|
||||
*/
|
||||
abstract int getDigestLength();
|
||||
|
||||
/** Field _macAlgorithm */
|
||||
private Mac _macAlgorithm = null;
|
||||
private boolean _HMACOutputLengthSet = false;
|
||||
|
||||
/** Field _HMACOutputLength */
|
||||
int _HMACOutputLength = 0;
|
||||
@ -100,7 +106,9 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
}
|
||||
|
||||
public void reset() {
|
||||
_HMACOutputLength=0;
|
||||
_HMACOutputLength=0;
|
||||
_HMACOutputLengthSet = false;
|
||||
_macAlgorithm.reset();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -115,14 +123,16 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
throws XMLSignatureException {
|
||||
|
||||
try {
|
||||
byte[] completeResult = this._macAlgorithm.doFinal();
|
||||
|
||||
if ((this._HMACOutputLength == 0) || (this._HMACOutputLength >= 160)) {
|
||||
if (this._HMACOutputLengthSet && this._HMACOutputLength < getDigestLength()) {
|
||||
if (log.isLoggable(java.util.logging.Level.FINE)) {
|
||||
log.log(java.util.logging.Level.FINE,
|
||||
"HMACOutputLength must not be less than " + getDigestLength());
|
||||
}
|
||||
throw new XMLSignatureException("errorMessages.XMLSignatureException");
|
||||
} else {
|
||||
byte[] completeResult = this._macAlgorithm.doFinal();
|
||||
return MessageDigestAlgorithm.isEqual(completeResult, signature);
|
||||
}
|
||||
byte[] stripped = IntegrityHmac.reduceBitLength(completeResult,
|
||||
this._HMACOutputLength);
|
||||
return MessageDigestAlgorithm.isEqual(stripped, signature);
|
||||
} catch (IllegalStateException ex) {
|
||||
throw new XMLSignatureException("empty", ex);
|
||||
}
|
||||
@ -176,14 +186,15 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
protected byte[] engineSign() throws XMLSignatureException {
|
||||
|
||||
try {
|
||||
byte[] completeResult = this._macAlgorithm.doFinal();
|
||||
|
||||
if ((this._HMACOutputLength == 0) || (this._HMACOutputLength >= 160)) {
|
||||
return completeResult;
|
||||
if (this._HMACOutputLengthSet && this._HMACOutputLength < getDigestLength()) {
|
||||
if (log.isLoggable(java.util.logging.Level.FINE)) {
|
||||
log.log(java.util.logging.Level.FINE,
|
||||
"HMACOutputLength must not be less than " + getDigestLength());
|
||||
}
|
||||
throw new XMLSignatureException("errorMessages.XMLSignatureException");
|
||||
} else {
|
||||
return this._macAlgorithm.doFinal();
|
||||
}
|
||||
return IntegrityHmac.reduceBitLength(completeResult,
|
||||
this._HMACOutputLength);
|
||||
|
||||
} catch (IllegalStateException ex) {
|
||||
throw new XMLSignatureException("empty", ex);
|
||||
}
|
||||
@ -361,6 +372,7 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
*/
|
||||
protected void engineSetHMACOutputLength(int HMACOutputLength) {
|
||||
this._HMACOutputLength = HMACOutputLength;
|
||||
this._HMACOutputLengthSet = true;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -376,12 +388,13 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
throw new IllegalArgumentException("element null");
|
||||
}
|
||||
|
||||
Text hmaclength =XMLUtils.selectDsNodeText(element.getFirstChild(),
|
||||
Constants._TAG_HMACOUTPUTLENGTH,0);
|
||||
Text hmaclength =XMLUtils.selectDsNodeText(element.getFirstChild(),
|
||||
Constants._TAG_HMACOUTPUTLENGTH,0);
|
||||
|
||||
if (hmaclength != null) {
|
||||
this._HMACOutputLength = Integer.parseInt(hmaclength.getData());
|
||||
}
|
||||
if (hmaclength != null) {
|
||||
this._HMACOutputLength = Integer.parseInt(hmaclength.getData());
|
||||
this._HMACOutputLengthSet = true;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -390,14 +403,13 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
*
|
||||
* @param element
|
||||
*/
|
||||
public void engineAddContextToElement(Element element)
|
||||
{
|
||||
public void engineAddContextToElement(Element element) {
|
||||
|
||||
if (element == null) {
|
||||
throw new IllegalArgumentException("null element");
|
||||
}
|
||||
|
||||
if (this._HMACOutputLength != 0) {
|
||||
if (this._HMACOutputLengthSet) {
|
||||
Document doc = element.getOwnerDocument();
|
||||
Element HMElem = XMLUtils.createElementInSignatureSpace(doc,
|
||||
Constants._TAG_HMACOUTPUTLENGTH);
|
||||
@ -436,6 +448,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
public String engineGetURI() {
|
||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA1;
|
||||
}
|
||||
|
||||
int getDigestLength() {
|
||||
return 160;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -463,6 +479,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
public String engineGetURI() {
|
||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA256;
|
||||
}
|
||||
|
||||
int getDigestLength() {
|
||||
return 256;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -490,6 +510,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
public String engineGetURI() {
|
||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA384;
|
||||
}
|
||||
|
||||
int getDigestLength() {
|
||||
return 384;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -517,6 +541,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
public String engineGetURI() {
|
||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA512;
|
||||
}
|
||||
|
||||
int getDigestLength() {
|
||||
return 512;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -544,6 +572,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
public String engineGetURI() {
|
||||
return XMLSignature.ALGO_ID_MAC_HMAC_RIPEMD160;
|
||||
}
|
||||
|
||||
int getDigestLength() {
|
||||
return 160;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -571,5 +603,9 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
||||
public String engineGetURI() {
|
||||
return XMLSignature.ALGO_ID_MAC_HMAC_NOT_RECOMMENDED_MD5;
|
||||
}
|
||||
|
||||
int getDigestLength() {
|
||||
return 128;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -129,7 +129,7 @@ public class TextCallbackHandler implements CallbackHandler {
|
||||
System.err.print(pc.getPrompt());
|
||||
System.err.flush();
|
||||
|
||||
pc.setPassword(Password.readPassword(System.in));
|
||||
pc.setPassword(Password.readPassword(System.in, pc.isEchoOn()));
|
||||
|
||||
} else if (callbacks[i] instanceof ConfirmationCallback) {
|
||||
confirmation = (ConfirmationCallback) callbacks[i];
|
||||
|
@ -0,0 +1,68 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
package com.sun.security.jgss;
|
||||
|
||||
/**
|
||||
* Kerberos 5 AuthorizationData entry.
|
||||
*/
|
||||
final public class AuthorizationDataEntry {
|
||||
|
||||
private final int type;
|
||||
private final byte[] data;
|
||||
|
||||
/**
|
||||
* Create an AuthorizationDataEntry object.
|
||||
* @param type the ad-type
|
||||
* @param data the ad-data, a copy of the data will be saved
|
||||
* inside the object.
|
||||
*/
|
||||
public AuthorizationDataEntry(int type, byte[] data) {
|
||||
this.type = type;
|
||||
this.data = data.clone();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the ad-type field.
|
||||
* @return ad-type
|
||||
*/
|
||||
public int getType() {
|
||||
return type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a copy of the ad-data field.
|
||||
* @return ad-data
|
||||
*/
|
||||
public byte[] getData() {
|
||||
return data.clone();
|
||||
}
|
||||
|
||||
public String toString() {
|
||||
return "AuthorizationDataEntry: type="+type+", data=" +
|
||||
data.length + " bytes:\n" +
|
||||
new sun.misc.HexDumpEncoder().encode(data);
|
||||
}
|
||||
}
|
@ -0,0 +1,102 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
package com.sun.security.jgss;
|
||||
|
||||
import org.ietf.jgss.*;
|
||||
|
||||
/**
|
||||
* The extended GSSContext interface for supporting additional
|
||||
* functionalities not defined by {@code org.ietf.jgss.GSSContext},
|
||||
* such as querying context-specific attributes.
|
||||
*/
|
||||
public interface ExtendedGSSContext extends GSSContext {
|
||||
/**
|
||||
* Return the mechanism-specific attribute associated with {@code type}.
|
||||
* <br><br>
|
||||
* For each supported attribute type, the type for the output are
|
||||
* defined below.
|
||||
* <ol>
|
||||
* <li>{@code KRB5_GET_TKT_FLAGS}:
|
||||
* the returned object is a boolean array for the service ticket flags,
|
||||
* which is long enough to contain all true bits. This means if
|
||||
* the user wants to get the <em>n</em>'th bit but the length of the
|
||||
* returned array is less than <em>n</em>, it is regarded as false.
|
||||
* <li>{@code KRB5_GET_SESSION_KEY}:
|
||||
* the returned object is an instance of {@link java.security.Key},
|
||||
* which has the following properties:
|
||||
* <ul>
|
||||
* <li>Algorithm: enctype as a string, where
|
||||
* enctype is defined in RFC 3961, section 8.
|
||||
* <li>Format: "RAW"
|
||||
* <li>Encoded form: the raw key bytes, not in any ASN.1 encoding
|
||||
* </ul>
|
||||
* <li>{@code KRB5_GET_AUTHZ_DATA}:
|
||||
* the returned object is an array of
|
||||
* {@link com.sun.security.jgss.AuthorizationDataEntry}, or null if the
|
||||
* optional field is missing in the service ticket.
|
||||
* <li>{@code KRB5_GET_AUTHTIME}:
|
||||
* the returned object is a String object in the standard KerberosTime
|
||||
* format defined in RFC 4120 5.2.3
|
||||
* </ol>
|
||||
*
|
||||
* If there is a security manager, an {@link InquireSecContextPermission}
|
||||
* with the name {@code type.mech} must be granted. Otherwise, this could
|
||||
* result in a {@link SecurityException}.<p>
|
||||
*
|
||||
* Example:
|
||||
* <pre>
|
||||
* GSSContext ctxt = m.createContext(...)
|
||||
* // Establishing the context
|
||||
* if (ctxt instanceof ExtendedGSSContext) {
|
||||
* ExtendedGSSContext ex = (ExtendedGSSContext)ctxt;
|
||||
* try {
|
||||
* Key key = (key)ex.inquireSecContext(
|
||||
* InquireType.KRB5_GET_SESSION_KEY);
|
||||
* // read key info
|
||||
* } catch (GSSException gsse) {
|
||||
* // deal with exception
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
* @param type the type of the attribute requested
|
||||
* @return the attribute, see the method documentation for details.
|
||||
* @throws GSSException containing the following
|
||||
* major error codes:
|
||||
* {@link GSSException#BAD_MECH GSSException.BAD_MECH} if the mechanism
|
||||
* does not support this method,
|
||||
* {@link GSSException#UNAVAILABLE GSSException.UNAVAILABLE} if the
|
||||
* type specified is not supported,
|
||||
* {@link GSSException#NO_CONTEXT GSSException.NO_CONTEXT} if the
|
||||
* security context is invalid,
|
||||
* {@link GSSException#FAILURE GSSException.FAILURE} for other
|
||||
* unspecified failures.
|
||||
* @throws SecurityException if a security manager exists and a proper
|
||||
* {@link InquireSecContextPermission} is not granted.
|
||||
* @see InquireSecContextPermission
|
||||
*/
|
||||
public Object inquireSecContext(InquireType type)
|
||||
throws GSSException;
|
||||
}
|
@ -0,0 +1,54 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
package com.sun.security.jgss;
|
||||
|
||||
import java.security.BasicPermission;
|
||||
|
||||
/**
|
||||
* This class is used to protect various attributes of an established
|
||||
* GSS security context that can be accessed using the
|
||||
* {@link com.sun.security.jgss.ExtendedGSSContext#inquireSecContext}
|
||||
* method.
|
||||
*
|
||||
* <p>The target name is the {@link InquireType} allowed.
|
||||
*/
|
||||
public final class InquireSecContextPermission extends BasicPermission {
|
||||
|
||||
/**
|
||||
* Constructs a new {@code InquireSecContextPermission} object with
|
||||
* the specified name. The name is the symbolic name of the
|
||||
* {@link InquireType} allowed.
|
||||
*
|
||||
* @param name the {@link InquireType} allowed by this
|
||||
* permission. "*" means all {@link InquireType}s are allowed.
|
||||
*
|
||||
* @throws NullPointerException if <code>name</code> is <code>null</code>.
|
||||
* @throws IllegalArgumentException if <code>name</code> is empty.
|
||||
*/
|
||||
public InquireSecContextPermission(String name) {
|
||||
super(name);
|
||||
}
|
||||
}
|
54
jdk/src/share/classes/com/sun/security/jgss/InquireType.java
Normal file
54
jdk/src/share/classes/com/sun/security/jgss/InquireType.java
Normal file
@ -0,0 +1,54 @@
|
||||
/*
|
||||
* Copyright 2009 Sun Microsystems, Inc. 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. Sun designates this
|
||||
* particular file as subject to the "Classpath" exception as provided
|
||||
* by Sun 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||
* have any questions.
|
||||
*/
|
||||
|
||||
package com.sun.security.jgss;
|
||||
|
||||
/**
|
||||
* Attribute types that can be specified as an argument of
|
||||
* {@link com.sun.security.jgss.ExtendedGSSContext#inquireSecContext}
|
||||
*/
|
||||
public enum InquireType {
|
||||
/**
|
||||
* Attribute type for retrieving the session key of an
|
||||
* established Kerberos 5 security context.
|
||||
*/
|
||||
KRB5_GET_SESSION_KEY,
|
||||
/**
|
||||
* Attribute type for retrieving the service ticket flags of an
|
||||
* established Kerberos 5 security context.
|
||||
*/
|
||||
KRB5_GET_TKT_FLAGS,
|
||||
/**
|
||||
* Attribute type for retrieving the authorization data in the
|
||||
* service ticket of an established Kerberos 5 security context.
|
||||
* Only supported on the acceptor side.
|
||||
*/
|
||||
KRB5_GET_AUTHZ_DATA,
|
||||
/**
|
||||
* Attribute type for retrieving the authtime in the service ticket
|
||||
* of an established Kerberos 5 security context.
|
||||
*/
|
||||
KRB5_GET_AUTHTIME
|
||||
}
|
@ -51,7 +51,7 @@ public final class Provider extends java.security.Provider {
|
||||
" server mechanisms for: DIGEST-MD5, GSSAPI, CRAM-MD5)";
|
||||
|
||||
public Provider() {
|
||||
super("SunSASL", 1.5, info);
|
||||
super("SunSASL", 1.7d, info);
|
||||
|
||||
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
||||
public Void run() {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright 2000-2003 Sun Microsystems, Inc. All Rights Reserved.
|
||||
* Copyright 2000-2009 Sun Microsystems, Inc. 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
|
||||
@ -48,10 +48,6 @@ import sun.misc.HexDumpEncoder;
|
||||
* @author Rosanna Lee
|
||||
*/
|
||||
public abstract class AbstractSaslImpl {
|
||||
/**
|
||||
* Logger for debug messages
|
||||
*/
|
||||
protected static Logger logger; // set in initLogger(); lazily loads logger
|
||||
|
||||
protected boolean completed = false;
|
||||
protected boolean privacy = false;
|
||||
@ -68,7 +64,6 @@ public abstract class AbstractSaslImpl {
|
||||
protected String myClassName;
|
||||
|
||||
protected AbstractSaslImpl(Map props, String className) throws SaslException {
|
||||
initLogger();
|
||||
myClassName = className;
|
||||
|
||||
// Parse properties to set desired context options
|
||||
@ -325,19 +320,15 @@ public abstract class AbstractSaslImpl {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets logger field.
|
||||
*/
|
||||
private static synchronized void initLogger() {
|
||||
if (logger == null) {
|
||||
logger = Logger.getLogger(SASL_LOGGER_NAME);
|
||||
}
|
||||
}
|
||||
|
||||
// ---------------- Constants -----------------
|
||||
private static final String SASL_LOGGER_NAME = "javax.security.sasl";
|
||||
protected static final String MAX_SEND_BUF = "javax.security.sasl.sendmaxbuffer";
|
||||
|
||||
/**
|
||||
* Logger for debug messages
|
||||
*/
|
||||
protected static final Logger logger = Logger.getLogger(SASL_LOGGER_NAME);
|
||||
|
||||
// default 0 (no protection); 1 (integrity only)
|
||||
protected static final byte NO_PROTECTION = (byte)1;
|
||||
protected static final byte INTEGRITY_ONLY_PROTECTION = (byte)2;
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user