Merge
This commit is contained in:
commit
1478582041
2
.hgtags
2
.hgtags
@ -41,3 +41,5 @@ dfd8506f74c3731bb169ce93c72612d78ee0413b jdk7-b63
|
|||||||
d22867c5f1b295a0a2b3b4bc8999a2676f6e20c3 jdk7-b64
|
d22867c5f1b295a0a2b3b4bc8999a2676f6e20c3 jdk7-b64
|
||||||
7d3bf00f3cc4f8125de1842521e7567f37dc84b8 jdk7-b65
|
7d3bf00f3cc4f8125de1842521e7567f37dc84b8 jdk7-b65
|
||||||
62109d1b9e7310f29ab51ca6f1d71b899c0ce6b0 jdk7-b66
|
62109d1b9e7310f29ab51ca6f1d71b899c0ce6b0 jdk7-b66
|
||||||
|
eb24af1404aec8aa140c4cd4d13d2839b150dd41 jdk7-b67
|
||||||
|
bca2225b66d78c4bf4d9801f54cac7715a598650 jdk7-b68
|
||||||
|
@ -41,3 +41,5 @@ c7ed15ab92ce36a09d264a5e34025884b2d7607f jdk7-b62
|
|||||||
269c1ec4435dfb7b452ae6e3bdde005d55c5c830 jdk7-b64
|
269c1ec4435dfb7b452ae6e3bdde005d55c5c830 jdk7-b64
|
||||||
e01380cd1de4ce048b87d059d238e5ab5e341947 jdk7-b65
|
e01380cd1de4ce048b87d059d238e5ab5e341947 jdk7-b65
|
||||||
6bad5e3fe50337d95b1416d744780d65bc570da6 jdk7-b66
|
6bad5e3fe50337d95b1416d744780d65bc570da6 jdk7-b66
|
||||||
|
c4523c6f82048f420bf0d57c4cd47976753b7d2c jdk7-b67
|
||||||
|
e1b972ff53cd58f825791f8ed9b2deffd16e768c jdk7-b68
|
||||||
|
@ -41,3 +41,5 @@ d20e45cd539f20405ff843652069cfd7550c5ab3 jdk7-b63
|
|||||||
047dd27fddb607f8135296b3754131f6e13cb8c7 jdk7-b64
|
047dd27fddb607f8135296b3754131f6e13cb8c7 jdk7-b64
|
||||||
97fd9b42f5c2d342b90d18f0a2b57e4117e39415 jdk7-b65
|
97fd9b42f5c2d342b90d18f0a2b57e4117e39415 jdk7-b65
|
||||||
a821e059a961bcb02830280d51f6dd030425c066 jdk7-b66
|
a821e059a961bcb02830280d51f6dd030425c066 jdk7-b66
|
||||||
|
a12ea7c7b497b4ba7830550095ef633bd6f43971 jdk7-b67
|
||||||
|
5182bcc9c60cac429d1f7988676cec7320752be3 jdk7-b68
|
||||||
|
@ -110,7 +110,7 @@ BOOTSTRAP_TARGET_LEVEL = 5
|
|||||||
ifdef TARGET_CLASS_VERSION
|
ifdef TARGET_CLASS_VERSION
|
||||||
TARGET_LEVEL = $(TARGET_CLASS_VERSION)
|
TARGET_LEVEL = $(TARGET_CLASS_VERSION)
|
||||||
else
|
else
|
||||||
TARGET_LEVEL = 6
|
TARGET_LEVEL = 7
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifndef TARGET_JAVA
|
ifndef TARGET_JAVA
|
||||||
|
@ -107,12 +107,12 @@ endif
|
|||||||
NO_PROPRIETARY_API_WARNINGS = -XDignore.symbol.file=true
|
NO_PROPRIETARY_API_WARNINGS = -XDignore.symbol.file=true
|
||||||
JAVACFLAGS += $(NO_PROPRIETARY_API_WARNINGS)
|
JAVACFLAGS += $(NO_PROPRIETARY_API_WARNINGS)
|
||||||
|
|
||||||
# Add the source level (currently all source is 1.5, should this be 1.6?)
|
# Add the source level
|
||||||
LANGUAGE_VERSION = -source 1.5
|
LANGUAGE_VERSION = -source 7
|
||||||
JAVACFLAGS += $(LANGUAGE_VERSION)
|
JAVACFLAGS += $(LANGUAGE_VERSION)
|
||||||
|
|
||||||
# Add the class version we want (currently this is 5, should it be 6 or even 7?)
|
# Add the class version we want
|
||||||
TARGET_CLASS_VERSION = 5
|
TARGET_CLASS_VERSION = 7
|
||||||
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
CLASS_VERSION = -target $(TARGET_CLASS_VERSION)
|
||||||
JAVACFLAGS += $(CLASS_VERSION)
|
JAVACFLAGS += $(CLASS_VERSION)
|
||||||
JAVACFLAGS += -encoding ascii
|
JAVACFLAGS += -encoding ascii
|
||||||
|
@ -41,3 +41,5 @@ a88386380bdaaa5ab4ffbedf22c57bac5dbec034 jdk7-b62
|
|||||||
ba36394eb84b949b31212bdb32a518a8f92bab5b jdk7-b64
|
ba36394eb84b949b31212bdb32a518a8f92bab5b jdk7-b64
|
||||||
ba313800759b678979434d6da8ed3bf49eb8bea4 jdk7-b65
|
ba313800759b678979434d6da8ed3bf49eb8bea4 jdk7-b65
|
||||||
57c71ad0341b8b64ed20f81151eb7f06324f8894 jdk7-b66
|
57c71ad0341b8b64ed20f81151eb7f06324f8894 jdk7-b66
|
||||||
|
18f526145aea355a9320b724373386fc2170f183 jdk7-b67
|
||||||
|
d07e68298d4e17ebf93d8299e43fcc3ded26472a jdk7-b68
|
||||||
|
@ -41,3 +41,5 @@ ae449e9c04c1fe651bd30f0f4d4cc24ba794e0c4 jdk7-b63
|
|||||||
a10eec7a1edf536f39b5828d8623054dbc62c2b7 jdk7-b64
|
a10eec7a1edf536f39b5828d8623054dbc62c2b7 jdk7-b64
|
||||||
008c662e0ee9a91aebb75e46b97de979083d5c1c jdk7-b65
|
008c662e0ee9a91aebb75e46b97de979083d5c1c jdk7-b65
|
||||||
22f9d5d5b5fe0f47048f41e6c6e54fee5edad0ec jdk7-b66
|
22f9d5d5b5fe0f47048f41e6c6e54fee5edad0ec jdk7-b66
|
||||||
|
a033af8d824a408d3ac602205ecdefc128749e1e jdk7-b67
|
||||||
|
83b2a9331383f9db7a49350d4cb13b7635f6b861 jdk7-b68
|
||||||
|
@ -30,8 +30,8 @@
|
|||||||
# one of the standard user build.properties files (see build.xml)
|
# one of the standard user build.properties files (see build.xml)
|
||||||
|
|
||||||
# options for the <javac> tasks used to compile the tools
|
# options for the <javac> tasks used to compile the tools
|
||||||
javac.source = 5
|
javac.source = 7
|
||||||
javac.target = 5
|
javac.target = 7
|
||||||
javac.debug = true
|
javac.debug = true
|
||||||
javac.no.jdk.warnings = -XDignore.symbol.file=true
|
javac.no.jdk.warnings = -XDignore.symbol.file=true
|
||||||
# set the following to -version to verify the versions of javac being used
|
# set the following to -version to verify the versions of javac being used
|
||||||
|
@ -41,3 +41,5 @@ b8a6e883c0a6708f6d818815040525d472262495 jdk7-b63
|
|||||||
aaa25dfd3de68c6f1a1d3ef8c45fd99f76bca6dd jdk7-b64
|
aaa25dfd3de68c6f1a1d3ef8c45fd99f76bca6dd jdk7-b64
|
||||||
aa22a1be5866a6608ba17a7a443945559409ae0f jdk7-b65
|
aa22a1be5866a6608ba17a7a443945559409ae0f jdk7-b65
|
||||||
fa8712c099edd5c9a6b3ed9729353738004d388f jdk7-b66
|
fa8712c099edd5c9a6b3ed9729353738004d388f jdk7-b66
|
||||||
|
faa13cd4d6cdcfb155da5ed23b0da6e0ed0f9ea8 jdk7-b67
|
||||||
|
845fa487f0f72a9f232ead8315c0087a477a5a31 jdk7-b68
|
||||||
|
@ -30,8 +30,8 @@
|
|||||||
# one of the standard user build.properties files (see build.xml)
|
# one of the standard user build.properties files (see build.xml)
|
||||||
|
|
||||||
# options for the <javac> tasks used to compile the tools
|
# options for the <javac> tasks used to compile the tools
|
||||||
javac.source = 5
|
javac.source = 7
|
||||||
javac.target = 5
|
javac.target = 7
|
||||||
javac.debug = true
|
javac.debug = true
|
||||||
javac.no.jdk.warnings = -XDignore.symbol.file=true
|
javac.no.jdk.warnings = -XDignore.symbol.file=true
|
||||||
# set the following to -version to verify the versions of javac being used
|
# set the following to -version to verify the versions of javac being used
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
^build/
|
^build/
|
||||||
^dist/
|
^dist/
|
||||||
^nbproject/private/
|
^nbproject/private/
|
||||||
|
^make/netbeans/.*/nbproject/private/
|
||||||
|
^make/netbeans/.*/build/
|
||||||
|
^make/netbeans/.*/dist/
|
||||||
|
@ -42,3 +42,5 @@ a50217eb3ee10b9f9547e0708e5c9625405083ef jdk7-b64
|
|||||||
382a27aa78d3236fa123c60577797a887fe93e09 jdk7-b65
|
382a27aa78d3236fa123c60577797a887fe93e09 jdk7-b65
|
||||||
bd31b30a5b21f20e42965b1633f18a5c7946d398 jdk7-b66
|
bd31b30a5b21f20e42965b1633f18a5c7946d398 jdk7-b66
|
||||||
a952aafd5181af953b0ef3010dbd2fcc28460e8a jdk7-b67
|
a952aafd5181af953b0ef3010dbd2fcc28460e8a jdk7-b67
|
||||||
|
b23d905cb5d3b382295240d28ab0bfb266b4503c jdk7-b68
|
||||||
|
226b20019b1f020c09ea97d137d98e011ce65d76 jdk7-b69
|
||||||
|
@ -32,7 +32,7 @@ USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|||||||
|
|
||||||
--- end of LICENSE file ---
|
--- end of LICENSE file ---
|
||||||
%% This notice is provided with respect to ASM, which may be included with this software:
|
%% 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.
|
All rights reserved.
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -45,54 +45,49 @@
|
|||||||
# For OpenJDK, the jar files built here are installed directly into the
|
# For OpenJDK, the jar files built here are installed directly into the
|
||||||
# OpenJDK.
|
# OpenJDK.
|
||||||
#
|
#
|
||||||
# For JDK, the binaries use pre-built/pre-signed/pre-obfuscated binary
|
# For JDK, the binaries use pre-built/pre-signed binary files stored in
|
||||||
# files stored in the closed workspace that are not shipped in the
|
# the closed workspace that are not shipped in the OpenJDK workspaces.
|
||||||
# OpenJDK workspaces. We still build the JDK files here to verify the
|
# We still build the JDK files here to verify the files compile, and in
|
||||||
# files compile, and in preparation for possible signing and
|
# preparation for possible signing. Developers working on JCE in JDK
|
||||||
# obfuscation. Developers working on JCE in JDK must sign the JCE files
|
# must sign the JCE files before testing. The JCE signing key is kept
|
||||||
# before testing: obfuscation is optional during development. The JCE
|
# separate from the JDK workspace to prevent its disclosure.
|
||||||
# signing key is kept separate from the JDK workspace to prevent its
|
#
|
||||||
# disclosure. The obfuscation tool has not been licensed for general
|
|
||||||
# usage.
|
|
||||||
#
|
|
||||||
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
||||||
# be built, obfuscated, signed, and then the resulting jar files MUST BE
|
# be built and signed, and the resulting jar files MUST BE CHECKED INTO
|
||||||
# CHECKED INTO THE CLOSED PART OF THE WORKSPACE*. This separate step
|
# THE CLOSED PART OF THE WORKSPACE*. This separate step *MUST NOT BE
|
||||||
# *MUST NOT BE FORGOTTEN*, otherwise a bug fixed in the source code will
|
# FORGOTTEN*, otherwise a bug fixed in the source code will not be
|
||||||
# not be reflected in the shipped binaries. The "release" target should be
|
# reflected in the shipped binaries. The "release" target should be
|
||||||
# used to generate the required files.
|
# used to generate the required files.
|
||||||
#
|
#
|
||||||
# There are a number of targets to help both JDK/OpenJDK developers.
|
# There are a number of targets to help both JDK/OpenJDK developers.
|
||||||
#
|
#
|
||||||
# Main Targets (JDK/OPENJDK):
|
# Main Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# all/clobber/clean The usual.
|
# all/clobber/clean The usual.
|
||||||
# If OpenJDK, installs sunjce_provider.jar.
|
# If OpenJDK, installs sunjce_provider.jar.
|
||||||
# If JDK, installs prebuilt
|
# If JDK, installs prebuilt
|
||||||
# sunjce_provider.jar.
|
# sunjce_provider.jar.
|
||||||
#
|
#
|
||||||
# jar Builds/installs sunjce_provider.jar
|
# jar Builds/installs sunjce_provider.jar
|
||||||
# If OpenJDK, does not sign.
|
# If OpenJDK, does not sign.
|
||||||
# If JDK, tries to sign.
|
# If JDK, tries to sign.
|
||||||
#
|
#
|
||||||
# Other lesser-used Targets (JDK/OPENJDK):
|
# Other lesser-used Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# build-jar Builds sunjce_provider.jar
|
# build-jar Builds sunjce_provider.jar
|
||||||
# (does not sign/install)
|
# (does not sign/install)
|
||||||
#
|
#
|
||||||
# install-jar Alias for "jar" above.
|
# install-jar Alias for "jar" above.
|
||||||
#
|
#
|
||||||
# Other targets (JDK only):
|
# Other targets (JDK only):
|
||||||
#
|
#
|
||||||
# sign Alias for sign-jar
|
# sign Alias for sign-jar
|
||||||
# sign-jar Builds/signs sunjce_provider.jar (no install)
|
# 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
|
# install-prebuilt Installs the pre-built jar files
|
||||||
# for workspace integration.
|
|
||||||
#
|
|
||||||
# install-prebuilt Installs the pre-built jar files
|
|
||||||
#
|
#
|
||||||
# This makefile was written to support parallel target execution.
|
# 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
|
# 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.
|
# isn't writable, the build currently crashes out.
|
||||||
#
|
#
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
@ -158,8 +153,8 @@ endif # OPENJDK
|
|||||||
#
|
#
|
||||||
# We use a variety of subdirectories in the $(TEMPDIR) depending on what
|
# 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
|
# 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,
|
# done in the unsigned area. When files are signed in JDK, they will be
|
||||||
# they will be placed in the appropriate areas.
|
# placed in the appropriate areas.
|
||||||
#
|
#
|
||||||
UNSIGNED_DIR = $(TEMPDIR)/unsigned
|
UNSIGNED_DIR = $(TEMPDIR)/unsigned
|
||||||
|
|
||||||
@ -223,62 +218,15 @@ $(SIGNED_DIR)/sunjce_provider.jar:
|
|||||||
endif
|
endif
|
||||||
$(call sign-file, $(UNSIGNED_DIR)/sunjce_provider.jar)
|
$(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
|
$(RM) $(JCE_BUILD_DIR)/release/sunjce_provider.jar
|
||||||
$(MKDIR) -p $(JCE_BUILD_DIR)/release
|
$(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)
|
$(release-warning)
|
||||||
|
|
||||||
endif # OPENJDK
|
endif # OPENJDK
|
||||||
@ -320,5 +268,5 @@ clobber clean::
|
|||||||
|
|
||||||
.PHONY: build-jar jar install-jar
|
.PHONY: build-jar jar install-jar
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
.PHONY: sign sign-jar obfus release install-prebuilt
|
.PHONY: sign sign-jar release install-prebuilt
|
||||||
endif
|
endif
|
||||||
|
@ -77,6 +77,7 @@ JAVA_JAVA_java = \
|
|||||||
java/lang/Compiler.java \
|
java/lang/Compiler.java \
|
||||||
java/lang/Throwable.java \
|
java/lang/Throwable.java \
|
||||||
java/lang/Exception.java \
|
java/lang/Exception.java \
|
||||||
|
java/lang/ReflectiveOperationException.java \
|
||||||
java/lang/IllegalAccessException.java \
|
java/lang/IllegalAccessException.java \
|
||||||
java/lang/InstantiationException.java \
|
java/lang/InstantiationException.java \
|
||||||
java/lang/ClassNotFoundException.java \
|
java/lang/ClassNotFoundException.java \
|
||||||
|
@ -160,7 +160,6 @@ FILES_src = \
|
|||||||
\
|
\
|
||||||
sun/nio/ByteBuffered.java \
|
sun/nio/ByteBuffered.java \
|
||||||
\
|
\
|
||||||
sun/nio/ch/AbstractFuture.java \
|
|
||||||
sun/nio/ch/AbstractPollArrayWrapper.java \
|
sun/nio/ch/AbstractPollArrayWrapper.java \
|
||||||
sun/nio/ch/AllocatedNativeObject.java \
|
sun/nio/ch/AllocatedNativeObject.java \
|
||||||
sun/nio/ch/AsynchronousChannelGroupImpl.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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -61,7 +61,7 @@ SIGNING_PASSPHRASE = $(SIGNING_KEY_DIR)/passphrase.txt
|
|||||||
SIGNING_ALIAS = jce_rsa
|
SIGNING_ALIAS = jce_rsa
|
||||||
|
|
||||||
#
|
#
|
||||||
# Defines for signing/obfuscating the various jar files.
|
# Defines for signing the various jar files.
|
||||||
#
|
#
|
||||||
|
|
||||||
define presign
|
define presign
|
||||||
@ -100,19 +100,4 @@ define sign-file
|
|||||||
$(sign-target)
|
$(sign-target)
|
||||||
endef
|
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
|
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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -44,64 +44,65 @@
|
|||||||
# For OpenJDK, the jar files built here are installed directly into the
|
# For OpenJDK, the jar files built here are installed directly into the
|
||||||
# OpenJDK.
|
# OpenJDK.
|
||||||
#
|
#
|
||||||
# For JDK, the binaries use pre-built/pre-signed/pre-obfuscated binary
|
# For JDK, the binaries use pre-built/pre-signed binary files stored in
|
||||||
# files stored in the closed workspace that are not shipped in the
|
# the closed workspace that are not shipped in the OpenJDK workspaces.
|
||||||
# OpenJDK workspaces. We still build the JDK files here to verify the
|
# We still build the JDK files here to verify the files compile, and in
|
||||||
# files compile, and in preparation for possible signing and
|
# preparation for possible signing. Developers working on JCE in JDK
|
||||||
# obfuscation. Developers working on JCE in JDK must sign the JCE files
|
# must sign the JCE files before testing. The JCE signing key is kept
|
||||||
# before testing: obfuscation is optional during development. The JCE
|
# separate from the JDK workspace to prevent its disclosure.
|
||||||
# signing key is kept separate from the JDK workspace to prevent its
|
|
||||||
# disclosure. The obfuscation tool has not been licensed for general
|
|
||||||
# usage.
|
|
||||||
#
|
#
|
||||||
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
# SPECIAL NOTE TO JCE/JDK developers: The source files must eventually
|
||||||
# be built, obfuscated, signed, and the resulting jar files *MUST BE
|
# be built and signed, and the resulting jar files *MUST BE CHECKED INTO
|
||||||
# CHECKED INTO THE CLOSED PART OF THE WORKSPACE*. This separate step
|
# THE CLOSED PART OF THE WORKSPACE*. This separate step *MUST NOT BE
|
||||||
# *MUST NOT BE FORGOTTEN*, otherwise a bug fixed in the source code will
|
# FORGOTTEN*, otherwise a bug fixed in the source code will not be
|
||||||
# not be reflected in the shipped binaries. The "release" target should
|
# reflected in the shipped binaries. The "release" target should be
|
||||||
# be used to generate the required files.
|
# used to generate the required files.
|
||||||
#
|
#
|
||||||
# There are a number of targets to help both JDK/OpenJDK developers.
|
# There are a number of targets to help both JDK/OpenJDK developers.
|
||||||
#
|
#
|
||||||
# Main Targets (JDK/OPENJDK):
|
# Main Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# all/clobber/clean The usual.
|
# all/clobber/clean The usual.
|
||||||
# If OpenJDK, installs
|
# If OpenJDK: builds/installs the
|
||||||
# jce.jar/limited policy files.
|
# jce.jar/limited policy files.
|
||||||
# If JDK, installs prebuilt
|
# If JDK: builds but does not install.
|
||||||
# jce.jar/limited policy files.
|
# 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
|
# jar Builds/installs jce.jar
|
||||||
# If OpenJDK, does not sign
|
# If OpenJDK, does not sign
|
||||||
# If JDK, tries to sign
|
# If JDK, tries to sign
|
||||||
#
|
#
|
||||||
# Other lesser-used Targets (JDK/OPENJDK):
|
# 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
|
# install-limited Builds/installs limited policy files
|
||||||
# If OpenJDK, does not sign
|
# If OpenJDK, does not sign
|
||||||
# If JDK, tries to sign
|
# If JDK, tries to sign
|
||||||
# install-unlimited Builds/nstalls unlimited policy files
|
# install-unlimited Builds/nstalls unlimited policy files
|
||||||
# If OpenJDK, does not sign
|
# If OpenJDK, does not sign
|
||||||
# If JDK, tries to sign
|
# If JDK, tries to sign
|
||||||
#
|
#
|
||||||
# Other targets (JDK only):
|
# Other targets (JDK only):
|
||||||
#
|
#
|
||||||
# sign Alias for sign-jar and sign-policy
|
# sign Alias for sign-jar and sign-policy
|
||||||
# sign-jar Builds/signs jce.jar file (no install)
|
# sign-jar Builds/signs jce.jar file (no install)
|
||||||
# sign-policy Builds/signs policy files (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
|
# install-prebuilt Installs the pre-built jar files
|
||||||
# for workspace integration.
|
|
||||||
#
|
|
||||||
# install-prebuilt Installs the pre-built jar files
|
|
||||||
#
|
#
|
||||||
# This makefile was written to support parallel target execution.
|
# 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
|
# 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.
|
# isn't writable, the build currently crashes out.
|
||||||
#
|
#
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
@ -169,8 +170,8 @@ endif # OPENJDK
|
|||||||
#
|
#
|
||||||
# We use a variety of subdirectories in the $(TEMPDIR) depending on what
|
# 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
|
# 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,
|
# done in the unsigned area. When files are signed in JDK, they will be
|
||||||
# they will be placed in the appropriate areas.
|
# placed in the appropriate areas.
|
||||||
#
|
#
|
||||||
UNSIGNED_DIR = $(TEMPDIR)/unsigned
|
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
|
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.
|
# Create the Release Engineering files. Signed builds,
|
||||||
#
|
|
||||||
|
|
||||||
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,
|
|
||||||
# unlimited policy file distribution, etc.
|
# 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
|
$(CLOSED_DIR)/doc/README.txt
|
||||||
$(RM) -r \
|
$(RM) -r \
|
||||||
$(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy \
|
$(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/local_policy.jar \
|
||||||
$(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy.zip
|
$(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy.zip
|
||||||
$(MKDIR) -p $(JCE_BUILD_DIR)/release/UnlimitedJCEPolicy
|
$(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) \
|
$(CP) \
|
||||||
$(SIGNED_POLICY_BUILDDIR)/limited/US_export_policy.jar \
|
$(SIGNED_POLICY_BUILDDIR)/limited/US_export_policy.jar \
|
||||||
$(SIGNED_POLICY_BUILDDIR)/limited/local_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 \
|
.PHONY: build-jar jar build-policy unlimited limited install-jar \
|
||||||
install-limited install-unlimited
|
install-limited install-unlimited
|
||||||
ifndef OPENJDK
|
ifndef OPENJDK
|
||||||
.PHONY: sign sign-jar sign-policy obfus release install-prebuilt
|
.PHONY: sign sign-jar sign-policy release install-prebuilt
|
||||||
endif
|
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/NetProperties.java \
|
||||||
sun/net/NetHooks.java \
|
sun/net/NetHooks.java \
|
||||||
sun/net/util/IPAddressUtil.java \
|
sun/net/util/IPAddressUtil.java \
|
||||||
|
sun/net/util/URLUtil.java \
|
||||||
sun/net/dns/ResolverConfiguration.java \
|
sun/net/dns/ResolverConfiguration.java \
|
||||||
sun/net/dns/ResolverConfigurationImpl.java \
|
sun/net/dns/ResolverConfigurationImpl.java \
|
||||||
sun/net/ftp/FtpClient.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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -60,7 +60,7 @@ ifeq ($(PLATFORM), windows)
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
SUBDIRS = other action util tools jgss krb5 smartcardio $(PKCS11) \
|
SUBDIRS = ec other action util tools jgss krb5 smartcardio $(PKCS11) \
|
||||||
$(JGSS_WRAPPER) $(MSCAPI)
|
$(JGSS_WRAPPER) $(MSCAPI)
|
||||||
|
|
||||||
all build clean clobber::
|
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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -59,31 +59,31 @@
|
|||||||
#
|
#
|
||||||
# Main Targets (JDK/OPENJDK):
|
# Main Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# all/clobber/clean The usual, plus the native libraries.
|
# all/clobber/clean The usual, plus the native libraries.
|
||||||
# If OpenJDK, installs sunmscapi.jar.
|
# If OpenJDK, installs sunmscapi.jar.
|
||||||
# If JDK, installs prebuilt
|
# If JDK, installs prebuilt
|
||||||
# sunmscapi.jar.
|
# sunmscapi.jar.
|
||||||
#
|
#
|
||||||
# jar Builds/installs sunmscapi.jar
|
# jar Builds/installs sunmscapi.jar
|
||||||
# If OpenJDK, does not sign.
|
# If OpenJDK, does not sign.
|
||||||
# If JDK, tries to sign.
|
# If JDK, tries to sign.
|
||||||
#
|
#
|
||||||
# Other lesser-used Targets (JDK/OPENJDK):
|
# Other lesser-used Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# build-jar Builds sunmscapi.jar
|
# build-jar Builds sunmscapi.jar
|
||||||
# (does not sign/install)
|
# (does not sign/install)
|
||||||
#
|
#
|
||||||
# install-jar Alias for "jar" above.
|
# install-jar Alias for "jar" above.
|
||||||
#
|
#
|
||||||
# Other targets (JDK only):
|
# Other targets (JDK only):
|
||||||
#
|
#
|
||||||
# sign Alias for sign-jar
|
# sign Alias for sign-jar
|
||||||
# sign-jar Builds/signs sunmscapi.jar (no install)
|
# sign-jar Builds/signs sunmscapi.jar (no install)
|
||||||
#
|
#
|
||||||
# release Builds all targets in preparation
|
# release Builds all targets in preparation
|
||||||
# for workspace integration.
|
# 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.
|
# 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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -33,7 +33,6 @@ include $(BUILDDIR)/common/Defs.gmk
|
|||||||
#
|
#
|
||||||
AUTO_FILES_JAVA_DIRS = \
|
AUTO_FILES_JAVA_DIRS = \
|
||||||
sun/security/acl \
|
sun/security/acl \
|
||||||
sun/security/ec \
|
|
||||||
sun/security/jca \
|
sun/security/jca \
|
||||||
sun/security/pkcs \
|
sun/security/pkcs \
|
||||||
sun/security/pkcs12 \
|
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.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -59,31 +59,31 @@
|
|||||||
#
|
#
|
||||||
# Main Targets (JDK/OPENJDK):
|
# Main Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# all/clobber/clean The usual, plus the native libraries.
|
# all/clobber/clean The usual, plus the native libraries.
|
||||||
# If OpenJDK, installs sunpkcs11.jar.
|
# If OpenJDK, installs sunpkcs11.jar.
|
||||||
# If JDK, installs prebuilt
|
# If JDK, installs prebuilt
|
||||||
# sunpkcs11.jar.
|
# sunpkcs11.jar.
|
||||||
#
|
#
|
||||||
# jar Builds/installs sunpkcs11.jar
|
# jar Builds/installs sunpkcs11.jar
|
||||||
# If OpenJDK, does not sign.
|
# If OpenJDK, does not sign.
|
||||||
# If JDK, tries to sign.
|
# If JDK, tries to sign.
|
||||||
#
|
#
|
||||||
# Other lesser-used Targets (JDK/OPENJDK):
|
# Other lesser-used Targets (JDK/OPENJDK):
|
||||||
#
|
#
|
||||||
# build-jar Builds sunpkcs11.jar
|
# build-jar Builds sunpkcs11.jar
|
||||||
# (does not sign/install)
|
# (does not sign/install)
|
||||||
#
|
#
|
||||||
# install-jar Alias for "jar" above.
|
# install-jar Alias for "jar" above.
|
||||||
#
|
#
|
||||||
# Other targets (JDK only):
|
# Other targets (JDK only):
|
||||||
#
|
#
|
||||||
# sign Alias for sign-jar
|
# sign Alias for sign-jar
|
||||||
# sign-jar Builds/signs sunpkcs11.jar (no install)
|
# sign-jar Builds/signs sunpkcs11.jar (no install)
|
||||||
#
|
#
|
||||||
# release Builds all targets in preparation
|
# release Builds all targets in preparation
|
||||||
# for workspace integration.
|
# 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.
|
# This makefile was written to support parallel target execution.
|
||||||
#
|
#
|
||||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
|||||||
|
|
||||||
abstract class AbstractNamedNode extends Node {
|
abstract class AbstractNamedNode extends Node {
|
||||||
|
|
||||||
NameNode nameNode;
|
NameNode nameNode = null;
|
||||||
String name;
|
String name;
|
||||||
|
|
||||||
public String name() {
|
public String name() {
|
||||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
|||||||
|
|
||||||
class AltNode extends AbstractGroupNode implements TypeNode {
|
class AltNode extends AbstractGroupNode implements TypeNode {
|
||||||
|
|
||||||
SelectNode select;
|
SelectNode select = null;
|
||||||
|
|
||||||
void constrain(Context ctx) {
|
void constrain(Context ctx) {
|
||||||
super.constrain(ctx);
|
super.constrain(ctx);
|
||||||
|
@ -33,13 +33,7 @@ class ConstantSetNode extends AbstractNamedNode {
|
|||||||
/**
|
/**
|
||||||
* The mapping between a constant and its value.
|
* The mapping between a constant and its value.
|
||||||
*/
|
*/
|
||||||
protected static Map<String, String> constantMap;
|
protected static final Map<String, String> constantMap = new HashMap<String, String>();
|
||||||
|
|
||||||
ConstantSetNode(){
|
|
||||||
if (constantMap == null) {
|
|
||||||
constantMap = new HashMap<String, String>();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void prune() {
|
void prune() {
|
||||||
List<Node> addons = new ArrayList<Node>();
|
List<Node> addons = new ArrayList<Node>();
|
||||||
@ -95,9 +89,6 @@ class ConstantSetNode extends AbstractNamedNode {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static String getConstant(String key){
|
public static String getConstant(String key){
|
||||||
if (constantMap == null) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
String com = constantMap.get(key);
|
String com = constantMap.get(key);
|
||||||
if(com == null){
|
if(com == null){
|
||||||
return "";
|
return "";
|
||||||
|
@ -25,13 +25,11 @@
|
|||||||
|
|
||||||
package build.tools.jdwpgen;
|
package build.tools.jdwpgen;
|
||||||
|
|
||||||
import java.util.*;
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
|
|
||||||
class Main {
|
class Main {
|
||||||
|
|
||||||
static String specSource;
|
static String specSource;
|
||||||
static Map nameMap = new HashMap();
|
|
||||||
static boolean genDebug = true;
|
static boolean genDebug = true;
|
||||||
|
|
||||||
static void usage() {
|
static void usage() {
|
||||||
@ -43,7 +41,6 @@ class Main {
|
|||||||
System.err.println("-doc <doc_output>");
|
System.err.println("-doc <doc_output>");
|
||||||
System.err.println("-jdi <java_output>");
|
System.err.println("-jdi <java_output>");
|
||||||
System.err.println("-include <include_file_output>");
|
System.err.println("-include <include_file_output>");
|
||||||
System.exit(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void main(String args[]) throws IOException {
|
public static void main(String args[]) throws IOException {
|
||||||
@ -66,6 +63,7 @@ class Main {
|
|||||||
} else {
|
} else {
|
||||||
System.err.println("Invalid option: " + arg);
|
System.err.println("Invalid option: " + arg);
|
||||||
usage();
|
usage();
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
specSource = arg;
|
specSource = arg;
|
||||||
@ -75,6 +73,7 @@ class Main {
|
|||||||
if (reader == null) {
|
if (reader == null) {
|
||||||
System.err.println("<spec_input> must be specified");
|
System.err.println("<spec_input> must be specified");
|
||||||
usage();
|
usage();
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Parse parse = new Parse(reader);
|
Parse parse = new Parse(reader);
|
||||||
|
@ -36,7 +36,7 @@ abstract class Node {
|
|||||||
int lineno;
|
int lineno;
|
||||||
List<String> commentList = new ArrayList<String>();
|
List<String> commentList = new ArrayList<String>();
|
||||||
Node parent = null;
|
Node parent = null;
|
||||||
Context context;
|
Context context = null;
|
||||||
|
|
||||||
static final int maxStructIndent = 5;
|
static final int maxStructIndent = 5;
|
||||||
static int structIndent = 0; // horrible hack
|
static int structIndent = 0; // horrible hack
|
||||||
@ -82,7 +82,7 @@ abstract class Node {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void indent(PrintWriter writer, int depth) {
|
void indent(PrintWriter writer, int depth) {
|
||||||
for (int i = depth; i > 0; --i) {
|
for (int i = 0; i < depth; i++) {
|
||||||
writer.print(" ");
|
writer.print(" ");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -195,6 +195,6 @@ abstract class Node {
|
|||||||
System.err.println(Main.specSource + ":" + lineno + ": " +
|
System.err.println(Main.specSource + ":" + lineno + ": " +
|
||||||
kind + " - " + errmsg);
|
kind + " - " + errmsg);
|
||||||
System.err.println();
|
System.err.println();
|
||||||
System.exit(1);
|
throw new RuntimeException("Error: " + errmsg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -146,8 +146,12 @@ class Parse {
|
|||||||
Node node = (Node)proto.getClass().newInstance();
|
Node node = (Node)proto.getClass().newInstance();
|
||||||
node.set(kind, list, izer.lineno());
|
node.set(kind, list, izer.lineno());
|
||||||
return node;
|
return node;
|
||||||
} catch (Exception exc) {
|
} catch (InstantiationException exc) {
|
||||||
error(exc.toString());
|
error(exc.toString());
|
||||||
|
return null;
|
||||||
|
} catch (IllegalAccessException exc) {
|
||||||
|
error(exc.toString());
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -166,6 +170,6 @@ class Parse {
|
|||||||
void error(String errmsg) {
|
void error(String errmsg) {
|
||||||
System.err.println(Main.specSource + ":" + izer.lineno() +
|
System.err.println(Main.specSource + ":" + izer.lineno() +
|
||||||
": " + errmsg);
|
": " + errmsg);
|
||||||
System.exit(1);
|
throw new RuntimeException("Error: " + errmsg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
|||||||
|
|
||||||
class RepeatNode extends AbstractTypeNode {
|
class RepeatNode extends AbstractTypeNode {
|
||||||
|
|
||||||
Node member;
|
Node member = null;
|
||||||
|
|
||||||
void constrain(Context ctx) {
|
void constrain(Context ctx) {
|
||||||
super.constrain(ctx);
|
super.constrain(ctx);
|
||||||
|
@ -30,7 +30,7 @@ import java.io.*;
|
|||||||
|
|
||||||
class SelectNode extends AbstractGroupNode implements TypeNode {
|
class SelectNode extends AbstractGroupNode implements TypeNode {
|
||||||
|
|
||||||
AbstractSimpleTypeNode typeNode;
|
AbstractSimpleTypeNode typeNode = null;
|
||||||
|
|
||||||
void prune() {
|
void prune() {
|
||||||
super.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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -56,12 +56,8 @@ public final class AESCipher extends CipherSpi {
|
|||||||
/**
|
/**
|
||||||
* Creates an instance of AES cipher with default ECB mode and
|
* Creates an instance of AES cipher with default ECB mode and
|
||||||
* PKCS5Padding.
|
* PKCS5Padding.
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public AESCipher() {
|
public AESCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new CipherCore(new AESCrypt(), AESConstants.AES_BLOCK_SIZE);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,16 +48,9 @@ public final class AESKeyGenerator extends KeyGeneratorSpi {
|
|||||||
private int keySize = 16; // default keysize (in number of bytes)
|
private int keySize = 16; // default keysize (in number of bytes)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor.
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public AESKeyGenerator() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -65,12 +65,8 @@ public final class AESWrapCipher extends CipherSpi {
|
|||||||
/**
|
/**
|
||||||
* Creates an instance of AES KeyWrap cipher with default
|
* Creates an instance of AES KeyWrap cipher with default
|
||||||
* mode, i.e. "ECB" and padding scheme, i.e. "NoPadding".
|
* mode, i.e. "ECB" and padding scheme, i.e. "NoPadding".
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public AESWrapCipher() {
|
public AESWrapCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
cipher = new AESCrypt();
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -62,7 +62,6 @@ public final class ARCFOURCipher extends CipherSpi {
|
|||||||
|
|
||||||
// called by the JCE framework
|
// called by the JCE framework
|
||||||
public ARCFOURCipher() {
|
public ARCFOURCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
S = new int[256];
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -60,12 +60,8 @@ public final class BlowfishCipher extends CipherSpi {
|
|||||||
/**
|
/**
|
||||||
* Creates an instance of Blowfish cipher with default ECB mode and
|
* Creates an instance of Blowfish cipher with default ECB mode and
|
||||||
* PKCS5Padding.
|
* PKCS5Padding.
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public BlowfishCipher() {
|
public BlowfishCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new CipherCore(new BlowfishCrypt(),
|
core = new CipherCore(new BlowfishCrypt(),
|
||||||
BlowfishConstants.BLOWFISH_BLOCK_SIZE);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,16 +46,9 @@ public final class BlowfishKeyGenerator extends KeyGeneratorSpi {
|
|||||||
private int keysize = 16; // default keysize (in number of bytes)
|
private int keysize = 16; // default keysize (in number of bytes)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public BlowfishKeyGenerator() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -56,12 +56,8 @@ public final class DESCipher extends CipherSpi {
|
|||||||
/**
|
/**
|
||||||
* Creates an instance of DES cipher with default ECB mode and
|
* Creates an instance of DES cipher with default ECB mode and
|
||||||
* PKCS5Padding.
|
* PKCS5Padding.
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DESCipher() {
|
public DESCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new CipherCore(new DESCrypt(), DESConstants.DES_BLOCK_SIZE);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,17 +42,11 @@ import java.security.spec.InvalidKeySpecException;
|
|||||||
public final class DESKeyFactory extends SecretKeyFactorySpi {
|
public final class DESKeyFactory extends SecretKeyFactorySpi {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DESKeyFactory() {
|
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
|
* Generates a <code>SecretKey</code> object from the provided key
|
||||||
* specification (key material).
|
* 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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,16 +46,9 @@ public final class DESKeyGenerator extends KeyGeneratorSpi {
|
|||||||
private SecureRandom random = null;
|
private SecureRandom random = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DESKeyGenerator() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -53,12 +53,8 @@ public final class DESedeCipher extends CipherSpi {
|
|||||||
/**
|
/**
|
||||||
* Creates an instance of DESede cipher with default ECB mode and
|
* Creates an instance of DESede cipher with default ECB mode and
|
||||||
* PKCS5Padding.
|
* PKCS5Padding.
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DESedeCipher() {
|
public DESedeCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new CipherCore(new DESedeCrypt(), DESConstants.DES_BLOCK_SIZE);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,16 +42,9 @@ import java.security.spec.InvalidKeySpecException;
|
|||||||
public final class DESedeKeyFactory extends SecretKeyFactorySpi {
|
public final class DESedeKeyFactory extends SecretKeyFactorySpi {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DESedeKeyFactory() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -47,16 +47,9 @@ public final class DESedeKeyGenerator extends KeyGeneratorSpi {
|
|||||||
private int keysize = 168;
|
private int keysize = 168;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DESedeKeyGenerator() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -74,12 +74,8 @@ public final class DESedeWrapCipher extends CipherSpi {
|
|||||||
/**
|
/**
|
||||||
* Creates an instance of CMS DESede KeyWrap cipher with default
|
* Creates an instance of CMS DESede KeyWrap cipher with default
|
||||||
* mode, i.e. "CBC" and padding scheme, i.e. "NoPadding".
|
* mode, i.e. "CBC" and padding scheme, i.e. "NoPadding".
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity.
|
|
||||||
*/
|
*/
|
||||||
public DESedeWrapCipher() {
|
public DESedeWrapCipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
cipher = new CipherBlockChaining(new DESedeCrypt());
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -58,16 +58,9 @@ extends KeyAgreementSpi {
|
|||||||
private BigInteger y = BigInteger.ZERO;
|
private BigInteger y = BigInteger.ZERO;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DHKeyAgreement() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -49,16 +49,9 @@ import javax.crypto.spec.DHParameterSpec;
|
|||||||
public final class DHKeyFactory extends KeyFactorySpi {
|
public final class DHKeyFactory extends KeyFactorySpi {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public DHKeyFactory() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -241,7 +241,6 @@ final class HmacCore implements Cloneable {
|
|||||||
public static final class HmacSHA256 extends MacSpi implements Cloneable {
|
public static final class HmacSHA256 extends MacSpi implements Cloneable {
|
||||||
private final HmacCore core;
|
private final HmacCore core;
|
||||||
public HmacSHA256() throws NoSuchAlgorithmException {
|
public HmacSHA256() throws NoSuchAlgorithmException {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new HmacCore("SHA-256", 64);
|
core = new HmacCore("SHA-256", 64);
|
||||||
}
|
}
|
||||||
private HmacSHA256(HmacSHA256 base) throws CloneNotSupportedException {
|
private HmacSHA256(HmacSHA256 base) throws CloneNotSupportedException {
|
||||||
@ -278,7 +277,6 @@ final class HmacCore implements Cloneable {
|
|||||||
public static final class HmacSHA384 extends MacSpi implements Cloneable {
|
public static final class HmacSHA384 extends MacSpi implements Cloneable {
|
||||||
private final HmacCore core;
|
private final HmacCore core;
|
||||||
public HmacSHA384() throws NoSuchAlgorithmException {
|
public HmacSHA384() throws NoSuchAlgorithmException {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new HmacCore("SHA-384", 128);
|
core = new HmacCore("SHA-384", 128);
|
||||||
}
|
}
|
||||||
private HmacSHA384(HmacSHA384 base) throws CloneNotSupportedException {
|
private HmacSHA384(HmacSHA384 base) throws CloneNotSupportedException {
|
||||||
@ -315,7 +313,6 @@ final class HmacCore implements Cloneable {
|
|||||||
public static final class HmacSHA512 extends MacSpi implements Cloneable {
|
public static final class HmacSHA512 extends MacSpi implements Cloneable {
|
||||||
private final HmacCore core;
|
private final HmacCore core;
|
||||||
public HmacSHA512() throws NoSuchAlgorithmException {
|
public HmacSHA512() throws NoSuchAlgorithmException {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new HmacCore("SHA-512", 128);
|
core = new HmacCore("SHA-512", 128);
|
||||||
}
|
}
|
||||||
private HmacSHA512(HmacSHA512 base) throws CloneNotSupportedException {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -44,16 +44,8 @@ public final class HmacMD5 extends MacSpi implements Cloneable {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard constructor, creates a new HmacMD5 instance.
|
* 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 {
|
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"),
|
hmac = new HmacCore(MessageDigest.getInstance("MD5"),
|
||||||
MD5_BLOCK_LENGTH);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,16 +46,9 @@ public final class HmacMD5KeyGenerator extends KeyGeneratorSpi {
|
|||||||
private int keysize = 64; // default keysize (in number of bytes)
|
private int keysize = 64; // default keysize (in number of bytes)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public HmacMD5KeyGenerator() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,13 +48,8 @@ public final class HmacPKCS12PBESHA1 extends MacSpi implements Cloneable {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard constructor, creates a new HmacSHA1 instance.
|
* 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 {
|
public HmacPKCS12PBESHA1() throws NoSuchAlgorithmException {
|
||||||
SunJCE.ensureIntegrity(this.getClass());
|
|
||||||
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
||||||
SHA1_BLOCK_LENGTH);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -44,16 +44,8 @@ public final class HmacSHA1 extends MacSpi implements Cloneable {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Standard constructor, creates a new HmacSHA1 instance.
|
* 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 {
|
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"),
|
this.hmac = new HmacCore(MessageDigest.getInstance("SHA1"),
|
||||||
SHA1_BLOCK_LENGTH);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,16 +46,9 @@ public final class HmacSHA1KeyGenerator extends KeyGeneratorSpi {
|
|||||||
private int keysize = 64; // default keysize (in number of bytes)
|
private int keysize = 64; // default keysize (in number of bytes)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public HmacSHA1KeyGenerator() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -109,7 +109,6 @@ final class KeyGeneratorCore {
|
|||||||
public static final class HmacSHA256KG extends KeyGeneratorSpi {
|
public static final class HmacSHA256KG extends KeyGeneratorSpi {
|
||||||
private final KeyGeneratorCore core;
|
private final KeyGeneratorCore core;
|
||||||
public HmacSHA256KG() {
|
public HmacSHA256KG() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new KeyGeneratorCore("HmacSHA256", 256);
|
core = new KeyGeneratorCore("HmacSHA256", 256);
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
protected void engineInit(SecureRandom random) {
|
||||||
@ -131,7 +130,6 @@ final class KeyGeneratorCore {
|
|||||||
public static final class HmacSHA384KG extends KeyGeneratorSpi {
|
public static final class HmacSHA384KG extends KeyGeneratorSpi {
|
||||||
private final KeyGeneratorCore core;
|
private final KeyGeneratorCore core;
|
||||||
public HmacSHA384KG() {
|
public HmacSHA384KG() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new KeyGeneratorCore("HmacSHA384", 384);
|
core = new KeyGeneratorCore("HmacSHA384", 384);
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
protected void engineInit(SecureRandom random) {
|
||||||
@ -153,7 +151,6 @@ final class KeyGeneratorCore {
|
|||||||
public static final class HmacSHA512KG extends KeyGeneratorSpi {
|
public static final class HmacSHA512KG extends KeyGeneratorSpi {
|
||||||
private final KeyGeneratorCore core;
|
private final KeyGeneratorCore core;
|
||||||
public HmacSHA512KG() {
|
public HmacSHA512KG() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new KeyGeneratorCore("HmacSHA512", 512);
|
core = new KeyGeneratorCore("HmacSHA512", 512);
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
protected void engineInit(SecureRandom random) {
|
||||||
@ -175,7 +172,6 @@ final class KeyGeneratorCore {
|
|||||||
public static final class RC2KeyGenerator extends KeyGeneratorSpi {
|
public static final class RC2KeyGenerator extends KeyGeneratorSpi {
|
||||||
private final KeyGeneratorCore core;
|
private final KeyGeneratorCore core;
|
||||||
public RC2KeyGenerator() {
|
public RC2KeyGenerator() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new KeyGeneratorCore("RC2", 128);
|
core = new KeyGeneratorCore("RC2", 128);
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
protected void engineInit(SecureRandom random) {
|
||||||
@ -201,7 +197,6 @@ final class KeyGeneratorCore {
|
|||||||
public static final class ARCFOURKeyGenerator extends KeyGeneratorSpi {
|
public static final class ARCFOURKeyGenerator extends KeyGeneratorSpi {
|
||||||
private final KeyGeneratorCore core;
|
private final KeyGeneratorCore core;
|
||||||
public ARCFOURKeyGenerator() {
|
public ARCFOURKeyGenerator() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
core = new KeyGeneratorCore("ARCFOUR", 128);
|
core = new KeyGeneratorCore("ARCFOUR", 128);
|
||||||
}
|
}
|
||||||
protected void engineInit(SecureRandom random) {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -49,16 +49,9 @@ abstract class PBEKeyFactory extends SecretKeyFactorySpi {
|
|||||||
private static HashSet<String> validTypes;
|
private static HashSet<String> validTypes;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Simple constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
private PBEKeyFactory(String keytype) {
|
private PBEKeyFactory(String keytype) {
|
||||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
|
||||||
throw new SecurityException("The SunJCE provider may have " +
|
|
||||||
"been tampered.");
|
|
||||||
}
|
|
||||||
type = keytype;
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -55,16 +55,9 @@ public final class PBEWithMD5AndDESCipher extends CipherSpi {
|
|||||||
* unavailable
|
* unavailable
|
||||||
* @exception NoSuchPaddingException if the required padding mechanism
|
* @exception NoSuchPaddingException if the required padding mechanism
|
||||||
* (PKCS5Padding) is unavailable
|
* (PKCS5Padding) is unavailable
|
||||||
*
|
|
||||||
* @exception SecurityException if this constructor fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public PBEWithMD5AndDESCipher()
|
public PBEWithMD5AndDESCipher()
|
||||||
throws NoSuchAlgorithmException, NoSuchPaddingException {
|
throws NoSuchAlgorithmException, NoSuchPaddingException {
|
||||||
if (!SunJCE.verifySelfIntegrity(this.getClass())) {
|
|
||||||
throw new SecurityException("The SunJCE provider may have " +
|
|
||||||
"been tampered.");
|
|
||||||
}
|
|
||||||
core = new PBECipherCore("DES");
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -61,23 +61,14 @@ public final class PBEWithMD5AndTripleDESCipher extends CipherSpi {
|
|||||||
* Creates an instance of this cipher, and initializes its mode (CBC) and
|
* Creates an instance of this cipher, and initializes its mode (CBC) and
|
||||||
* padding (PKCS5).
|
* padding (PKCS5).
|
||||||
*
|
*
|
||||||
* Verify the SunJCE provider in the constructor.
|
|
||||||
*
|
|
||||||
* @exception NoSuchAlgorithmException if the required cipher mode (CBC) is
|
* @exception NoSuchAlgorithmException if the required cipher mode (CBC) is
|
||||||
* unavailable
|
* unavailable
|
||||||
* @exception NoSuchPaddingException if the required padding mechanism
|
* @exception NoSuchPaddingException if the required padding mechanism
|
||||||
* (PKCS5Padding) is unavailable
|
* (PKCS5Padding) is unavailable
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public PBEWithMD5AndTripleDESCipher()
|
public PBEWithMD5AndTripleDESCipher()
|
||||||
throws NoSuchAlgorithmException, NoSuchPaddingException
|
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
|
// set the encapsulated cipher to do triple DES
|
||||||
core = new PBECipherCore("DESede");
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -45,16 +45,9 @@ import javax.crypto.spec.SecretKeySpec;
|
|||||||
public final class PBKDF2HmacSHA1Factory extends SecretKeyFactorySpi {
|
public final class PBKDF2HmacSHA1Factory extends SecretKeyFactorySpi {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verify the SunJCE provider in the constructor.
|
* Empty constructor
|
||||||
*
|
|
||||||
* @exception SecurityException if fails to verify
|
|
||||||
* its own integrity
|
|
||||||
*/
|
*/
|
||||||
public PBKDF2HmacSHA1Factory() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -370,7 +370,6 @@ final class PKCS12PBECipherCore {
|
|||||||
public static final class PBEWithSHA1AndDESede extends CipherSpi {
|
public static final class PBEWithSHA1AndDESede extends CipherSpi {
|
||||||
private final PKCS12PBECipherCore core;
|
private final PKCS12PBECipherCore core;
|
||||||
public PBEWithSHA1AndDESede() throws NoSuchAlgorithmException {
|
public PBEWithSHA1AndDESede() throws NoSuchAlgorithmException {
|
||||||
SunJCE.ensureIntegrity(this.getClass());
|
|
||||||
core = new PKCS12PBECipherCore("DESede", 24);
|
core = new PKCS12PBECipherCore("DESede", 24);
|
||||||
}
|
}
|
||||||
protected byte[] engineDoFinal(byte[] in, int inOff, int inLen)
|
protected byte[] engineDoFinal(byte[] in, int inOff, int inLen)
|
||||||
@ -446,7 +445,6 @@ final class PKCS12PBECipherCore {
|
|||||||
public static final class PBEWithSHA1AndRC2_40 extends CipherSpi {
|
public static final class PBEWithSHA1AndRC2_40 extends CipherSpi {
|
||||||
private final PKCS12PBECipherCore core;
|
private final PKCS12PBECipherCore core;
|
||||||
public PBEWithSHA1AndRC2_40() throws NoSuchAlgorithmException {
|
public PBEWithSHA1AndRC2_40() throws NoSuchAlgorithmException {
|
||||||
SunJCE.ensureIntegrity(this.getClass());
|
|
||||||
core = new PKCS12PBECipherCore("RC2", 5);
|
core = new PKCS12PBECipherCore("RC2", 5);
|
||||||
}
|
}
|
||||||
protected byte[] engineDoFinal(byte[] in, int inOff, int inLen)
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -45,7 +45,6 @@ public final class RC2Cipher extends CipherSpi {
|
|||||||
private final RC2Crypt embeddedCipher;
|
private final RC2Crypt embeddedCipher;
|
||||||
|
|
||||||
public RC2Cipher() {
|
public RC2Cipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
embeddedCipher = new RC2Crypt();
|
embeddedCipher = new RC2Crypt();
|
||||||
core = new CipherCore(embeddedCipher, 8);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -111,7 +111,6 @@ public final class RSACipher extends CipherSpi {
|
|||||||
private String oaepHashAlgorithm = "SHA-1";
|
private String oaepHashAlgorithm = "SHA-1";
|
||||||
|
|
||||||
public RSACipher() {
|
public RSACipher() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
paddingType = PAD_PKCS1;
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -226,9 +226,6 @@ final class SslMacCore {
|
|||||||
|
|
||||||
static final byte[] md5Pad1 = genPad((byte)0x36, 48);
|
static final byte[] md5Pad1 = genPad((byte)0x36, 48);
|
||||||
static final byte[] md5Pad2 = genPad((byte)0x5c, 48);
|
static final byte[] md5Pad2 = genPad((byte)0x5c, 48);
|
||||||
static {
|
|
||||||
SunJCE.ensureIntegrity(SslMacMD5.class);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// nested static class for the SslMacMD5 implementation
|
// 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[] shaPad1 = genPad((byte)0x36, 40);
|
||||||
static final byte[] shaPad2 = genPad((byte)0x5c, 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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -93,10 +93,6 @@ public final class SunJCE extends Provider {
|
|||||||
|
|
||||||
static final SecureRandom RANDOM = new SecureRandom();
|
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() {
|
public SunJCE() {
|
||||||
/* We are the "SunJCE" provider */
|
/* We are the "SunJCE" provider */
|
||||||
super("SunJCE", 1.7d, info);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -52,7 +52,6 @@ public final class TlsKeyMaterialGenerator extends KeyGeneratorSpi {
|
|||||||
private int protocolVersion;
|
private int protocolVersion;
|
||||||
|
|
||||||
public TlsKeyMaterialGenerator() {
|
public TlsKeyMaterialGenerator() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void engineInit(SecureRandom random) {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -51,7 +51,6 @@ public final class TlsMasterSecretGenerator extends KeyGeneratorSpi {
|
|||||||
private int protocolVersion;
|
private int protocolVersion;
|
||||||
|
|
||||||
public TlsMasterSecretGenerator() {
|
public TlsMasterSecretGenerator() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void engineInit(SecureRandom random) {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -109,7 +109,6 @@ public final class TlsPrfGenerator extends KeyGeneratorSpi {
|
|||||||
private TlsPrfParameterSpec spec;
|
private TlsPrfParameterSpec spec;
|
||||||
|
|
||||||
public TlsPrfGenerator() {
|
public TlsPrfGenerator() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void engineInit(SecureRandom random) {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,7 +48,6 @@ public final class TlsRsaPremasterSecretGenerator extends KeyGeneratorSpi {
|
|||||||
private SecureRandom random;
|
private SecureRandom random;
|
||||||
|
|
||||||
public TlsRsaPremasterSecretGenerator() {
|
public TlsRsaPremasterSecretGenerator() {
|
||||||
SunJCE.ensureIntegrity(getClass());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void engineInit(SecureRandom random) {
|
protected void engineInit(SecureRandom random) {
|
||||||
|
@ -51,7 +51,7 @@ public class BMPImageReaderSpi extends ImageReaderSpi {
|
|||||||
entensions,
|
entensions,
|
||||||
mimeType,
|
mimeType,
|
||||||
"com.sun.imageio.plugins.bmp.BMPImageReader",
|
"com.sun.imageio.plugins.bmp.BMPImageReader",
|
||||||
STANDARD_INPUT_TYPE,
|
new Class[] { ImageInputStream.class },
|
||||||
writerSpiNames,
|
writerSpiNames,
|
||||||
false,
|
false,
|
||||||
null, null, null, null,
|
null, null, null, null,
|
||||||
|
@ -32,6 +32,7 @@ import java.awt.image.SinglePixelPackedSampleModel;
|
|||||||
import javax.imageio.spi.ImageWriterSpi;
|
import javax.imageio.spi.ImageWriterSpi;
|
||||||
import javax.imageio.spi.ServiceRegistry;
|
import javax.imageio.spi.ServiceRegistry;
|
||||||
import javax.imageio.spi.IIORegistry;
|
import javax.imageio.spi.IIORegistry;
|
||||||
|
import javax.imageio.stream.ImageOutputStream;
|
||||||
import javax.imageio.ImageWriter;
|
import javax.imageio.ImageWriter;
|
||||||
import javax.imageio.ImageTypeSpecifier;
|
import javax.imageio.ImageTypeSpecifier;
|
||||||
import javax.imageio.IIOException;
|
import javax.imageio.IIOException;
|
||||||
@ -55,7 +56,7 @@ public class BMPImageWriterSpi extends ImageWriterSpi {
|
|||||||
entensions,
|
entensions,
|
||||||
mimeType,
|
mimeType,
|
||||||
"com.sun.imageio.plugins.bmp.BMPImageWriter",
|
"com.sun.imageio.plugins.bmp.BMPImageWriter",
|
||||||
STANDARD_OUTPUT_TYPE,
|
new Class[] { ImageOutputStream.class },
|
||||||
readerSpiNames,
|
readerSpiNames,
|
||||||
false,
|
false,
|
||||||
null, null, null, null,
|
null, null, null, null,
|
||||||
|
@ -60,7 +60,7 @@ public class GIFImageReaderSpi extends ImageReaderSpi {
|
|||||||
suffixes,
|
suffixes,
|
||||||
MIMETypes,
|
MIMETypes,
|
||||||
readerClassName,
|
readerClassName,
|
||||||
STANDARD_INPUT_TYPE,
|
new Class[] { ImageInputStream.class },
|
||||||
writerSpiNames,
|
writerSpiNames,
|
||||||
true,
|
true,
|
||||||
GIFStreamMetadata.nativeMetadataFormatName,
|
GIFStreamMetadata.nativeMetadataFormatName,
|
||||||
|
@ -31,6 +31,7 @@ import java.util.Locale;
|
|||||||
import javax.imageio.ImageTypeSpecifier;
|
import javax.imageio.ImageTypeSpecifier;
|
||||||
import javax.imageio.ImageWriter;
|
import javax.imageio.ImageWriter;
|
||||||
import javax.imageio.spi.ImageWriterSpi;
|
import javax.imageio.spi.ImageWriterSpi;
|
||||||
|
import javax.imageio.stream.ImageOutputStream;
|
||||||
import com.sun.imageio.plugins.common.PaletteBuilder;
|
import com.sun.imageio.plugins.common.PaletteBuilder;
|
||||||
|
|
||||||
public class GIFImageWriterSpi extends ImageWriterSpi {
|
public class GIFImageWriterSpi extends ImageWriterSpi {
|
||||||
@ -59,7 +60,7 @@ public class GIFImageWriterSpi extends ImageWriterSpi {
|
|||||||
suffixes,
|
suffixes,
|
||||||
MIMETypes,
|
MIMETypes,
|
||||||
writerClassName,
|
writerClassName,
|
||||||
STANDARD_OUTPUT_TYPE,
|
new Class[] { ImageOutputStream.class },
|
||||||
readerSpiNames,
|
readerSpiNames,
|
||||||
true,
|
true,
|
||||||
GIFWritableStreamMetadata.NATIVE_FORMAT_NAME,
|
GIFWritableStreamMetadata.NATIVE_FORMAT_NAME,
|
||||||
|
@ -46,7 +46,7 @@ public class JPEGImageReaderSpi extends ImageReaderSpi {
|
|||||||
JPEG.suffixes,
|
JPEG.suffixes,
|
||||||
JPEG.MIMETypes,
|
JPEG.MIMETypes,
|
||||||
"com.sun.imageio.plugins.jpeg.JPEGImageReader",
|
"com.sun.imageio.plugins.jpeg.JPEGImageReader",
|
||||||
STANDARD_INPUT_TYPE,
|
new Class[] { ImageInputStream.class },
|
||||||
writerSpiNames,
|
writerSpiNames,
|
||||||
true,
|
true,
|
||||||
JPEG.nativeStreamMetadataFormatName,
|
JPEG.nativeStreamMetadataFormatName,
|
||||||
|
@ -28,6 +28,7 @@ package com.sun.imageio.plugins.jpeg;
|
|||||||
import javax.imageio.spi.ImageWriterSpi;
|
import javax.imageio.spi.ImageWriterSpi;
|
||||||
import javax.imageio.spi.ServiceRegistry;
|
import javax.imageio.spi.ServiceRegistry;
|
||||||
import javax.imageio.spi.IIORegistry;
|
import javax.imageio.spi.IIORegistry;
|
||||||
|
import javax.imageio.stream.ImageOutputStream;
|
||||||
import javax.imageio.ImageWriter;
|
import javax.imageio.ImageWriter;
|
||||||
import javax.imageio.ImageTypeSpecifier;
|
import javax.imageio.ImageTypeSpecifier;
|
||||||
import javax.imageio.IIOException;
|
import javax.imageio.IIOException;
|
||||||
@ -49,7 +50,7 @@ public class JPEGImageWriterSpi extends ImageWriterSpi {
|
|||||||
JPEG.suffixes,
|
JPEG.suffixes,
|
||||||
JPEG.MIMETypes,
|
JPEG.MIMETypes,
|
||||||
"com.sun.imageio.plugins.jpeg.JPEGImageWriter",
|
"com.sun.imageio.plugins.jpeg.JPEGImageWriter",
|
||||||
STANDARD_OUTPUT_TYPE,
|
new Class[] { ImageOutputStream.class },
|
||||||
readerSpiNames,
|
readerSpiNames,
|
||||||
true,
|
true,
|
||||||
JPEG.nativeStreamMetadataFormatName,
|
JPEG.nativeStreamMetadataFormatName,
|
||||||
|
@ -60,7 +60,7 @@ public class PNGImageReaderSpi extends ImageReaderSpi {
|
|||||||
suffixes,
|
suffixes,
|
||||||
MIMETypes,
|
MIMETypes,
|
||||||
readerClassName,
|
readerClassName,
|
||||||
STANDARD_INPUT_TYPE,
|
new Class[] { ImageInputStream.class },
|
||||||
writerSpiNames,
|
writerSpiNames,
|
||||||
false,
|
false,
|
||||||
null, null,
|
null, null,
|
||||||
|
@ -34,6 +34,7 @@ import javax.imageio.ImageTypeSpecifier;
|
|||||||
import javax.imageio.metadata.IIOMetadataFormat;
|
import javax.imageio.metadata.IIOMetadataFormat;
|
||||||
import javax.imageio.metadata.IIOMetadataFormatImpl;
|
import javax.imageio.metadata.IIOMetadataFormatImpl;
|
||||||
import javax.imageio.spi.ImageWriterSpi;
|
import javax.imageio.spi.ImageWriterSpi;
|
||||||
|
import javax.imageio.stream.ImageOutputStream;
|
||||||
|
|
||||||
public class PNGImageWriterSpi extends ImageWriterSpi {
|
public class PNGImageWriterSpi extends ImageWriterSpi {
|
||||||
|
|
||||||
@ -61,7 +62,7 @@ public class PNGImageWriterSpi extends ImageWriterSpi {
|
|||||||
suffixes,
|
suffixes,
|
||||||
MIMETypes,
|
MIMETypes,
|
||||||
writerClassName,
|
writerClassName,
|
||||||
STANDARD_OUTPUT_TYPE,
|
new Class[] { ImageOutputStream.class },
|
||||||
readerSpiNames,
|
readerSpiNames,
|
||||||
false,
|
false,
|
||||||
null, null,
|
null, null,
|
||||||
|
@ -55,7 +55,7 @@ public class WBMPImageReaderSpi extends ImageReaderSpi {
|
|||||||
entensions,
|
entensions,
|
||||||
mimeType,
|
mimeType,
|
||||||
"com.sun.imageio.plugins.wbmp.WBMPImageReader",
|
"com.sun.imageio.plugins.wbmp.WBMPImageReader",
|
||||||
STANDARD_INPUT_TYPE,
|
new Class[] { ImageInputStream.class },
|
||||||
writerSpiNames,
|
writerSpiNames,
|
||||||
true,
|
true,
|
||||||
null, null, null, null,
|
null, null, null, null,
|
||||||
|
@ -28,6 +28,7 @@ package com.sun.imageio.plugins.wbmp;
|
|||||||
import javax.imageio.spi.ImageWriterSpi;
|
import javax.imageio.spi.ImageWriterSpi;
|
||||||
import javax.imageio.spi.ServiceRegistry;
|
import javax.imageio.spi.ServiceRegistry;
|
||||||
import javax.imageio.spi.IIORegistry;
|
import javax.imageio.spi.IIORegistry;
|
||||||
|
import javax.imageio.stream.ImageOutputStream;
|
||||||
import javax.imageio.ImageWriter;
|
import javax.imageio.ImageWriter;
|
||||||
import javax.imageio.ImageTypeSpecifier;
|
import javax.imageio.ImageTypeSpecifier;
|
||||||
import javax.imageio.IIOException;
|
import javax.imageio.IIOException;
|
||||||
@ -54,7 +55,7 @@ public class WBMPImageWriterSpi extends ImageWriterSpi {
|
|||||||
entensions,
|
entensions,
|
||||||
mimeType,
|
mimeType,
|
||||||
"com.sun.imageio.plugins.wbmp.WBMPImageWriter",
|
"com.sun.imageio.plugins.wbmp.WBMPImageWriter",
|
||||||
STANDARD_OUTPUT_TYPE,
|
new Class[] { ImageOutputStream.class },
|
||||||
readerSpiNames,
|
readerSpiNames,
|
||||||
true,
|
true,
|
||||||
null, null, null, null,
|
null, null, null, null,
|
||||||
|
@ -43,35 +43,35 @@ import javax.imageio.stream.ImageInputStream;
|
|||||||
*/
|
*/
|
||||||
public class StreamCloser {
|
public class StreamCloser {
|
||||||
|
|
||||||
private static WeakHashMap<ImageInputStream, Object> toCloseQueue;
|
private static WeakHashMap<CloseAction, Object> toCloseQueue;
|
||||||
private static Thread streamCloser;
|
private static Thread streamCloser;
|
||||||
|
|
||||||
public static void addToQueue(ImageInputStream iis) {
|
public static void addToQueue(CloseAction ca) {
|
||||||
synchronized (StreamCloser.class) {
|
synchronized (StreamCloser.class) {
|
||||||
if (toCloseQueue == null) {
|
if (toCloseQueue == null) {
|
||||||
toCloseQueue =
|
toCloseQueue =
|
||||||
new WeakHashMap<ImageInputStream, Object>();
|
new WeakHashMap<CloseAction, Object>();
|
||||||
}
|
}
|
||||||
|
|
||||||
toCloseQueue.put(iis, null);
|
toCloseQueue.put(ca, null);
|
||||||
|
|
||||||
if (streamCloser == null) {
|
if (streamCloser == null) {
|
||||||
final Runnable streamCloserRunnable = new Runnable() {
|
final Runnable streamCloserRunnable = new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
if (toCloseQueue != null) {
|
if (toCloseQueue != null) {
|
||||||
synchronized (StreamCloser.class) {
|
synchronized (StreamCloser.class) {
|
||||||
Set<ImageInputStream> set =
|
Set<CloseAction> set =
|
||||||
toCloseQueue.keySet();
|
toCloseQueue.keySet();
|
||||||
// Make a copy of the set in order to avoid
|
// Make a copy of the set in order to avoid
|
||||||
// concurrent modification (the is.close()
|
// concurrent modification (the is.close()
|
||||||
// will in turn call removeFromQueue())
|
// will in turn call removeFromQueue())
|
||||||
ImageInputStream[] streams =
|
CloseAction[] actions =
|
||||||
new ImageInputStream[set.size()];
|
new CloseAction[set.size()];
|
||||||
streams = set.toArray(streams);
|
actions = set.toArray(actions);
|
||||||
for (ImageInputStream is : streams) {
|
for (CloseAction ca : actions) {
|
||||||
if (is != null) {
|
if (ca != null) {
|
||||||
try {
|
try {
|
||||||
is.close();
|
ca.performAction();
|
||||||
} catch (IOException e) {
|
} 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) {
|
synchronized (StreamCloser.class) {
|
||||||
if (toCloseQueue != null) {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -922,7 +922,7 @@ public class DnsContext extends ComponentDirContext {
|
|||||||
|
|
||||||
//---------- Debugging
|
//---------- Debugging
|
||||||
|
|
||||||
public static boolean debug = false;
|
private static final boolean debug = false;
|
||||||
|
|
||||||
private static final void dprint(String msg) {
|
private static final void dprint(String msg) {
|
||||||
if (debug) {
|
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;
|
nodes = null;
|
||||||
if (ctx != null) {
|
ctx = null;
|
||||||
ctx.close();
|
|
||||||
ctx = null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasMore() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,6 +41,15 @@ import javax.sound.midi.spi.MidiFileWriter;
|
|||||||
import javax.sound.midi.spi.SoundbankReader;
|
import javax.sound.midi.spi.SoundbankReader;
|
||||||
import javax.sound.midi.spi.MidiDeviceProvider;
|
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
|
* 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.
|
If the property is not set, null is returned.
|
||||||
*/
|
*/
|
||||||
private static synchronized String getDefaultProvider(Class typeClass) {
|
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 value;
|
||||||
String propertyName = typeClass.getName();
|
String propertyName = typeClass.getName();
|
||||||
value = JSSecurityManager.getProperty(propertyName);
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -283,28 +283,37 @@ class JSSecurityManager {
|
|||||||
|
|
||||||
|
|
||||||
static List getProviders(final Class providerClass) {
|
static List getProviders(final Class providerClass) {
|
||||||
PrivilegedAction action = new PrivilegedAction() {
|
List p = new ArrayList();
|
||||||
public Object run() {
|
// Service.providers(Class) just creates "lazy" iterator instance,
|
||||||
List p = new ArrayList();
|
// so it doesn't require do be called from privileged section
|
||||||
Iterator ps = Service.providers(providerClass);
|
final Iterator ps = Service.providers(providerClass);
|
||||||
while (ps.hasNext()) {
|
|
||||||
try {
|
// the iterator's hasNext() method looks through classpath for
|
||||||
Object provider = ps.next();
|
// the provider class names, so it requires read permissions
|
||||||
if (providerClass.isInstance(provider)) {
|
PrivilegedAction<Boolean> hasNextAction = new PrivilegedAction<Boolean>() {
|
||||||
// $$mp 2003-08-22
|
public Boolean run() {
|
||||||
// Always adding at the beginning reverses the
|
return ps.hasNext();
|
||||||
// order of the providers. So we no longer have
|
}
|
||||||
// to do this in AudioSystem and MidiSystem.
|
};
|
||||||
p.add(0, provider);
|
|
||||||
}
|
while (AccessController.doPrivileged(hasNextAction)) {
|
||||||
} catch (Throwable t) {
|
try {
|
||||||
//$$fb 2002-11-07: do not fail on SPI not found
|
// the iterator's next() method creates instances of the
|
||||||
if (Printer.err) t.printStackTrace();
|
// providers and it should be called in the current security
|
||||||
} }
|
// context
|
||||||
return p;
|
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) {
|
||||||
List providers = (List) AccessController.doPrivileged(action);
|
//$$fb 2002-11-07: do not fail on SPI not found
|
||||||
return providers;
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -82,7 +82,7 @@ public class StandardMidiFileWriter extends MidiFileWriter {
|
|||||||
/**
|
/**
|
||||||
* MIDI parser types
|
* MIDI parser types
|
||||||
*/
|
*/
|
||||||
public static final int types[] = {
|
private static final int types[] = {
|
||||||
MIDI_TYPE_0,
|
MIDI_TYPE_0,
|
||||||
MIDI_TYPE_1
|
MIDI_TYPE_1
|
||||||
};
|
};
|
||||||
|
@ -60,8 +60,14 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
*/
|
*/
|
||||||
public abstract String engineGetURI();
|
public abstract String engineGetURI();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the output length of the hash/digest.
|
||||||
|
*/
|
||||||
|
abstract int getDigestLength();
|
||||||
|
|
||||||
/** Field _macAlgorithm */
|
/** Field _macAlgorithm */
|
||||||
private Mac _macAlgorithm = null;
|
private Mac _macAlgorithm = null;
|
||||||
|
private boolean _HMACOutputLengthSet = false;
|
||||||
|
|
||||||
/** Field _HMACOutputLength */
|
/** Field _HMACOutputLength */
|
||||||
int _HMACOutputLength = 0;
|
int _HMACOutputLength = 0;
|
||||||
@ -100,7 +106,9 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void reset() {
|
public void reset() {
|
||||||
_HMACOutputLength=0;
|
_HMACOutputLength=0;
|
||||||
|
_HMACOutputLengthSet = false;
|
||||||
|
_macAlgorithm.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -115,14 +123,16 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
throws XMLSignatureException {
|
throws XMLSignatureException {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
byte[] completeResult = this._macAlgorithm.doFinal();
|
if (this._HMACOutputLengthSet && this._HMACOutputLength < getDigestLength()) {
|
||||||
|
if (log.isLoggable(java.util.logging.Level.FINE)) {
|
||||||
if ((this._HMACOutputLength == 0) || (this._HMACOutputLength >= 160)) {
|
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);
|
return MessageDigestAlgorithm.isEqual(completeResult, signature);
|
||||||
}
|
}
|
||||||
byte[] stripped = IntegrityHmac.reduceBitLength(completeResult,
|
|
||||||
this._HMACOutputLength);
|
|
||||||
return MessageDigestAlgorithm.isEqual(stripped, signature);
|
|
||||||
} catch (IllegalStateException ex) {
|
} catch (IllegalStateException ex) {
|
||||||
throw new XMLSignatureException("empty", ex);
|
throw new XMLSignatureException("empty", ex);
|
||||||
}
|
}
|
||||||
@ -176,14 +186,15 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
protected byte[] engineSign() throws XMLSignatureException {
|
protected byte[] engineSign() throws XMLSignatureException {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
byte[] completeResult = this._macAlgorithm.doFinal();
|
if (this._HMACOutputLengthSet && this._HMACOutputLength < getDigestLength()) {
|
||||||
|
if (log.isLoggable(java.util.logging.Level.FINE)) {
|
||||||
if ((this._HMACOutputLength == 0) || (this._HMACOutputLength >= 160)) {
|
log.log(java.util.logging.Level.FINE,
|
||||||
return completeResult;
|
"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) {
|
} catch (IllegalStateException ex) {
|
||||||
throw new XMLSignatureException("empty", ex);
|
throw new XMLSignatureException("empty", ex);
|
||||||
}
|
}
|
||||||
@ -361,6 +372,7 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
*/
|
*/
|
||||||
protected void engineSetHMACOutputLength(int HMACOutputLength) {
|
protected void engineSetHMACOutputLength(int HMACOutputLength) {
|
||||||
this._HMACOutputLength = HMACOutputLength;
|
this._HMACOutputLength = HMACOutputLength;
|
||||||
|
this._HMACOutputLengthSet = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -376,12 +388,13 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
throw new IllegalArgumentException("element null");
|
throw new IllegalArgumentException("element null");
|
||||||
}
|
}
|
||||||
|
|
||||||
Text hmaclength =XMLUtils.selectDsNodeText(element.getFirstChild(),
|
Text hmaclength =XMLUtils.selectDsNodeText(element.getFirstChild(),
|
||||||
Constants._TAG_HMACOUTPUTLENGTH,0);
|
Constants._TAG_HMACOUTPUTLENGTH,0);
|
||||||
|
|
||||||
if (hmaclength != null) {
|
if (hmaclength != null) {
|
||||||
this._HMACOutputLength = Integer.parseInt(hmaclength.getData());
|
this._HMACOutputLength = Integer.parseInt(hmaclength.getData());
|
||||||
}
|
this._HMACOutputLengthSet = true;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -390,14 +403,13 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
*
|
*
|
||||||
* @param element
|
* @param element
|
||||||
*/
|
*/
|
||||||
public void engineAddContextToElement(Element element)
|
public void engineAddContextToElement(Element element) {
|
||||||
{
|
|
||||||
|
|
||||||
if (element == null) {
|
if (element == null) {
|
||||||
throw new IllegalArgumentException("null element");
|
throw new IllegalArgumentException("null element");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this._HMACOutputLength != 0) {
|
if (this._HMACOutputLengthSet) {
|
||||||
Document doc = element.getOwnerDocument();
|
Document doc = element.getOwnerDocument();
|
||||||
Element HMElem = XMLUtils.createElementInSignatureSpace(doc,
|
Element HMElem = XMLUtils.createElementInSignatureSpace(doc,
|
||||||
Constants._TAG_HMACOUTPUTLENGTH);
|
Constants._TAG_HMACOUTPUTLENGTH);
|
||||||
@ -436,6 +448,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
public String engineGetURI() {
|
public String engineGetURI() {
|
||||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA1;
|
return XMLSignature.ALGO_ID_MAC_HMAC_SHA1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getDigestLength() {
|
||||||
|
return 160;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -463,6 +479,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
public String engineGetURI() {
|
public String engineGetURI() {
|
||||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA256;
|
return XMLSignature.ALGO_ID_MAC_HMAC_SHA256;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getDigestLength() {
|
||||||
|
return 256;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -490,6 +510,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
public String engineGetURI() {
|
public String engineGetURI() {
|
||||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA384;
|
return XMLSignature.ALGO_ID_MAC_HMAC_SHA384;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getDigestLength() {
|
||||||
|
return 384;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -517,6 +541,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
public String engineGetURI() {
|
public String engineGetURI() {
|
||||||
return XMLSignature.ALGO_ID_MAC_HMAC_SHA512;
|
return XMLSignature.ALGO_ID_MAC_HMAC_SHA512;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getDigestLength() {
|
||||||
|
return 512;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -544,6 +572,10 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
public String engineGetURI() {
|
public String engineGetURI() {
|
||||||
return XMLSignature.ALGO_ID_MAC_HMAC_RIPEMD160;
|
return XMLSignature.ALGO_ID_MAC_HMAC_RIPEMD160;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getDigestLength() {
|
||||||
|
return 160;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -571,5 +603,9 @@ public abstract class IntegrityHmac extends SignatureAlgorithmSpi {
|
|||||||
public String engineGetURI() {
|
public String engineGetURI() {
|
||||||
return XMLSignature.ALGO_ID_MAC_HMAC_NOT_RECOMMENDED_MD5;
|
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.print(pc.getPrompt());
|
||||||
System.err.flush();
|
System.err.flush();
|
||||||
|
|
||||||
pc.setPassword(Password.readPassword(System.in));
|
pc.setPassword(Password.readPassword(System.in, pc.isEchoOn()));
|
||||||
|
|
||||||
} else if (callbacks[i] instanceof ConfirmationCallback) {
|
} else if (callbacks[i] instanceof ConfirmationCallback) {
|
||||||
confirmation = (ConfirmationCallback) callbacks[i];
|
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)";
|
" server mechanisms for: DIGEST-MD5, GSSAPI, CRAM-MD5)";
|
||||||
|
|
||||||
public Provider() {
|
public Provider() {
|
||||||
super("SunSASL", 1.5, info);
|
super("SunSASL", 1.7d, info);
|
||||||
|
|
||||||
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
AccessController.doPrivileged(new PrivilegedAction<Void>() {
|
||||||
public Void run() {
|
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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,10 +48,6 @@ import sun.misc.HexDumpEncoder;
|
|||||||
* @author Rosanna Lee
|
* @author Rosanna Lee
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractSaslImpl {
|
public abstract class AbstractSaslImpl {
|
||||||
/**
|
|
||||||
* Logger for debug messages
|
|
||||||
*/
|
|
||||||
protected static Logger logger; // set in initLogger(); lazily loads logger
|
|
||||||
|
|
||||||
protected boolean completed = false;
|
protected boolean completed = false;
|
||||||
protected boolean privacy = false;
|
protected boolean privacy = false;
|
||||||
@ -68,7 +64,6 @@ public abstract class AbstractSaslImpl {
|
|||||||
protected String myClassName;
|
protected String myClassName;
|
||||||
|
|
||||||
protected AbstractSaslImpl(Map props, String className) throws SaslException {
|
protected AbstractSaslImpl(Map props, String className) throws SaslException {
|
||||||
initLogger();
|
|
||||||
myClassName = className;
|
myClassName = className;
|
||||||
|
|
||||||
// Parse properties to set desired context options
|
// 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 -----------------
|
// ---------------- Constants -----------------
|
||||||
private static final String SASL_LOGGER_NAME = "javax.security.sasl";
|
private static final String SASL_LOGGER_NAME = "javax.security.sasl";
|
||||||
protected static final String MAX_SEND_BUF = "javax.security.sasl.sendmaxbuffer";
|
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)
|
// default 0 (no protection); 1 (integrity only)
|
||||||
protected static final byte NO_PROTECTION = (byte)1;
|
protected static final byte NO_PROTECTION = (byte)1;
|
||||||
protected static final byte INTEGRITY_ONLY_PROTECTION = (byte)2;
|
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…
x
Reference in New Issue
Block a user