diff options
author | Jung-uk Kim <jkim@FreeBSD.org> | 2013-12-04 23:20:35 +0000 |
---|---|---|
committer | Jung-uk Kim <jkim@FreeBSD.org> | 2013-12-04 23:20:35 +0000 |
commit | fffab58da85dfb88fe6dc70ab603b2d29b41cc1b (patch) | |
tree | 8241b8a874c4cce2b9c0f9fba0552cd92b0c8d2d | |
parent | 18953f8188cb3fbf937e07382d3430c8969bdd79 (diff) |
Add multiple security patches and improvements from IcedTea6.
http://icedtea.classpath.org/hg/icedtea6/rev/e98b0ef70b26
Obtained from: IcedTea Project
Notes
Notes:
svn path=/head/; revision=335646
105 files changed, 41264 insertions, 3 deletions
diff --git a/java/openjdk6-jre/Makefile b/java/openjdk6-jre/Makefile index 79e0fb0672a7..6e946bb69acf 100644 --- a/java/openjdk6-jre/Makefile +++ b/java/openjdk6-jre/Makefile @@ -1,6 +1,6 @@ # $FreeBSD$ -PORTREVISION= 5 +PORTREVISION= 6 CATEGORIES= java devel PKGNAMESUFFIX= -jre diff --git a/java/openjdk6/Makefile b/java/openjdk6/Makefile index 96c077d2bed6..3d82a95dc75e 100644 --- a/java/openjdk6/Makefile +++ b/java/openjdk6/Makefile @@ -3,7 +3,7 @@ PORTNAME= openjdk6 PORTVERSION= b28 -PORTREVISION?= 5 +PORTREVISION?= 6 CATEGORIES= java devel MASTER_SITES= ${MASTER_SITE_APACHE:S,%SUBDIR%/,ant/binaries/:ant,} \ http://download.java.net/openjdk/jtreg/promoted/4.1/b05/:jtreg \ diff --git a/java/openjdk6/Makefile.icedtea b/java/openjdk6/Makefile.icedtea index 7f82e65ff79e..00046b304ed5 100644 --- a/java/openjdk6/Makefile.icedtea +++ b/java/openjdk6/Makefile.icedtea @@ -1,6 +1,108 @@ # $FreeBSD$ -_PATCHES= +_PATCHES= \ + openjdk/8017196-ensure_proxies_are_handled_appropriately.patch \ + openjdk/8011157-improve_corba_portability.patch \ + openjdk/8022940-enhance_corba_translations.patch \ + openjdk/8013503-improve_stream_factories.patch \ + openjdk/8012425-transform_transformfactory.patch \ + openjdk/8017298-better_xml_support.patch \ + openjdk/8014530-better_dsp.patch \ + openjdk/8021366-jaxp_test_fix-01.patch \ + openjdk/8021933-jaxp_test_fix-02.patch \ + openjdk/8022682-supporting_xom.patch \ + openjdk/8015978-incorrect_transformation.patch \ + openjdk/oj6-20-merge.patch \ + openjdk/8024914-swapped_usage.patch \ + openjdk/8017505-better_client_service.patch \ + openjdk/8015614-update_build.patch \ + openjdk/8016256-finalization_final.patch \ + openjdk/8023683-enhance_class_file_parsing.patch \ + openjdk/8023457-tracing_mutex.patch \ + openjdk/8020943-memory_leak.patch \ + openjdk/8023478-hs_crash.patch \ + openjdk/4075303-javap_update.patch \ + openjdk/6819246-javap_instruction_decoding.patch \ + openjdk/6715767-javap_crash.patch \ + openjdk/6841420-classfile_methods.patch \ + openjdk/6841419-classfile_iterator.patch \ + openjdk/4111861-static_fields.patch \ + openjdk/4884240-javap_additional_option.patch \ + openjdk/6852856-javap_subclasses.patch \ + openjdk/6867671-javap_whitespace.patch \ + openjdk/6868539-constant_pool_tags.patch \ + openjdk/4501661-disallow_mixing.patch \ + openjdk/6824493-experimental.patch \ + openjdk/6843013-missing_experimental.patch \ + openjdk/6902264-fix_indentation.patch \ + openjdk/8016675-robust_javadoc.patch \ + openjdk/8016653-ignoreable_characters.patch \ + openjdk/7196533-timezone_bottleneck.patch \ + openjdk/8006900-new_date_time.patch \ + openjdk/8008589-better_mbean_permission_validation.patch \ + openjdk/8011071-better_crypto_provider_handling.patch \ + openjdk/8011081-improve_jhat.patch \ + openjdk/8011157-improve_corba_portability-jdk.patch \ + openjdk/8012071-better_bean_building.patch \ + openjdk/8012147-improve_tool.patch \ + openjdk/8012277-improve_dataflavour.patch \ + openjdk/8013506-better_pack200.patch \ + openjdk/8013510-augment_image_writing.patch \ + openjdk/8013514-improve_cmap_stability.patch \ + openjdk/8013744-better_tabling.patch \ + openjdk/8014085-better_serialization.patch \ + openjdk/8014093-improve_image_parsing.patch \ + openjdk/8014102-improve_image_conversion.patch \ + openjdk/8014341-better_kerberos_service.patch \ + openjdk/8014534-better_profiling.patch \ + openjdk/8014987-augment_serialization.patch \ + openjdk/8015731-auth_improvements.patch \ + openjdk/8015743-address_internet_addresses.patch \ + openjdk/8016357-update_hs_diagnostic_class.patch \ + openjdk/8002070-remove_logger_stack_search.patch \ + openjdk/6708729-javap_makefile_update.patch \ + openjdk/8010118-caller_sensitive.patch \ + openjdk/oj6-19-fix_8010118_test_cases.patch \ + openjdk/8010727-empty_logger_name.patch \ + openjdk/8010939-logmanager_deadlock.patch \ + openjdk/8011990-logger_test_urls.patch \ + openjdk/8013380-logger_stack_walk_glassfish.patch \ + openjdk/8014745-logger_stack_walk_switch.patch \ + openjdk/8012243-serial_regression.patch \ + openjdk/8014718-remove_logging_suntoolkit.patch \ + openjdk/8011139-revise_checking_getenclosingclass.patch \ + openjdk/8017196-ensure_proxies_are_handled_appropriately-jdk.patch \ + openjdk/8017287-better_resource_disposal.patch \ + openjdk/8017291-cast_proxies_aside.patch \ + openjdk/7146431-java.security_files.patch \ + openjdk/8006882-jmockit.patch \ + openjdk/8000450-restrict_access.patch \ + openjdk/8019979-better_access_test.patch \ + openjdk/8004188-rename_java.security.patch \ + openjdk/8017566-backout_part_of_8000450.patch \ + openjdk/8017300-improve_interface_implementation.patch \ + openjdk/8019292-better_attribute_value_exceptions.patch \ + openjdk/8019617-better_view_of_objects.patch \ + openjdk/8012617-arrayindexoutofbounds_linebreakmeasurer.patch \ + openjdk/8020293-jvm_crash.patch \ + openjdk/8013739-better_ldap_resource_management.patch \ + openjdk/8014349-getdeclaredclass_fix.patch \ + openjdk/6954275-big_xml_signatures.patch \ + openjdk/8021290-signature_validation.patch \ + openjdk/8012453-runtime.exec.patch \ + openjdk/8015965-typo_in_property_name.patch \ + openjdk/8015144-performance_regression.patch \ + openjdk/8019969-inet6_test_case_fix.patch \ + openjdk/8019584-invalid_notification_fix.patch \ + openjdk/8021577-bean_serialization_fix.patch \ + openjdk/8021969-jnlp_load_failure.patch \ + openjdk/8021355-splashscreen_regression.patch \ + openjdk/8022661-writeobject_flush.patch \ + openjdk/8023964-ignore_test.patch \ + openjdk/8003992-embedded_nulls.patch \ + openjdk/8013827-createtempfile_hang.patch \ + openjdk/8025128-createtempfile_absolute_prefix.patch \ + openjdk/oj6-21-overrides.patch .if ${PORT_OPTIONS:MICEDTEA} _PATCHES+= \ diff --git a/java/openjdk6/files/icedtea/openjdk/4075303-javap_update.patch b/java/openjdk6/files/icedtea/openjdk/4075303-javap_update.patch new file mode 100644 index 000000000000..5123d6cf1e59 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/4075303-javap_update.patch @@ -0,0 +1,12081 @@ +# HG changeset patch +# User jjg +# Date 1382400229 -3600 +# Tue Oct 22 01:03:49 2013 +0100 +# Node ID bfd7bb4218253bac4f57abbc90b987f16e4b7f6c +# Parent 8e38c8fe0a0beaef943e754071be0358c34e76dd +4075303: Use javap to enquire about a specific inner class +4348375: Javap is not internationalized +4459541: "javap -l" shows line numbers as signed short; they should be unsigned +4501660: change diagnostic of -help as 'print this help message and exit' +4776241: unused source file in javap... +4870651: javap should recognize generics, varargs, enum +4876942: javap invoked without args does not print help screen +4880663: javap could output whitespace between class name and opening brace +4975569: javap doesn't print new flag bits +6271787: javap dumps LocalVariableTypeTable attribute in hex, needs to print a table +6305779: javap: support annotations +6439940: Clean up javap implementation +6469569: wrong check of searchpath in JavapEnvironment +6474890: javap does not open .zip files in -classpath +6587786: Javap throws error : "ERROR:Could not find <classname>" for JRE classes +6622215: javap ignores certain relevant access flags +6622216: javap names some attributes incorrectly +6622232: javap gets whitespace confused +6622260: javap prints negative bytes incorrectly in hex +Reviewed-by: ksrini + +diff -r 8e38c8fe0a0b -r bfd7bb421825 make/build.properties +--- langtools/make/build.properties Fri Oct 04 12:22:34 2013 -0400 ++++ langtools/make/build.properties Tue Oct 22 01:03:49 2013 +0100 +@@ -130,6 +130,8 @@ + # + + javap.includes = \ ++ com/sun/tools/classfile/ \ ++ com/sun/tools/javap/ \ + sun/tools/javap/ + + javap.tests = \ +diff -r 8e38c8fe0a0b -r bfd7bb421825 make/build.xml +--- langtools/make/build.xml Fri Oct 04 12:22:34 2013 -0400 ++++ langtools/make/build.xml Tue Oct 22 01:03:49 2013 +0100 +@@ -316,14 +316,15 @@ + jarmainclass="sun.tools.javap.Main"/> + </target> + +- <target name="build-classes-javap" depends="build-bootstrap-javac"> ++ <target name="build-classes-javap" depends="build-classes-javac"> + <build-classes name="javap" includes="${javap.includes}"/> + </target> + +- <target name="build-javap" depends="build-bootstrap-javac"> ++ <target name="build-javap" depends="build-javac"> + <build-tool name="javap" + includes="${javap.includes}" +- jarmainclass="sun.tools.javap.Main"/> ++ jarmainclass="sun.tools.javap.Main" ++ jarclasspath="javac.jar"/> + </target> + + <!-- (no javadoc for javap) --> +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/AccessFlags.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/AccessFlags.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,254 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++import java.util.LinkedHashSet; ++import java.util.Set; ++ ++/** ++ * See JVMS3, sections 4.2, 4.6, 4.7. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class AccessFlags { ++ public static final int ACC_PUBLIC = 0x0001; // class, inner, field, method ++ public static final int ACC_PRIVATE = 0x0002; // inner, field, method ++ public static final int ACC_PROTECTED = 0x0004; // inner, field, method ++ public static final int ACC_STATIC = 0x0008; // inner, field, method ++ public static final int ACC_FINAL = 0x0010; // class, inner, field, method ++ public static final int ACC_SUPER = 0x0020; // class ++ public static final int ACC_SYNCHRONIZED = 0x0020; // method ++ public static final int ACC_VOLATILE = 0x0040; // field ++ public static final int ACC_BRIDGE = 0x0040; // method ++ public static final int ACC_TRANSIENT = 0x0080; // field ++ public static final int ACC_VARARGS = 0x0080; // method ++ public static final int ACC_NATIVE = 0x0100; // method ++ public static final int ACC_INTERFACE = 0x0200; // class, inner ++ public static final int ACC_ABSTRACT = 0x0400; // class, inner, method ++ public static final int ACC_STRICT = 0x0800; // method ++ public static final int ACC_SYNTHETIC = 0x1000; // class, inner, field, method ++ public static final int ACC_ANNOTATION = 0x2000; // class, inner ++ public static final int ACC_ENUM = 0x4000; // class, inner, field ++ public static final int ACC_MODULE = 0x8000; // class, inner, field, method ++ ++ private static enum Type { Class, InnerClass, Field, Method}; ++ ++ AccessFlags(ClassReader cr) throws IOException { ++ this(cr.readUnsignedShort()); ++ } ++ ++ public AccessFlags(int flags) { ++ this.flags = flags; ++ } ++ ++ public AccessFlags ignore(int mask) { ++ return new AccessFlags(flags & ~mask); ++ } ++ ++ public boolean is(int mask) { ++ return (flags & mask) != 0; ++ } ++ ++ private static final int[] classModifiers = { ++ ACC_PUBLIC, ACC_FINAL, ACC_ABSTRACT, ACC_MODULE ++ }; ++ ++ private static final int[] classFlags = { ++ ACC_PUBLIC, ACC_FINAL, ACC_SUPER, ACC_INTERFACE, ACC_ABSTRACT, ++ ACC_SYNTHETIC, ACC_ANNOTATION, ACC_ENUM, ACC_MODULE ++ }; ++ ++ public Set<String> getClassModifiers() { ++ int f = ((flags & ACC_INTERFACE) != 0 ? flags & ~ACC_ABSTRACT : flags); ++ return getModifiers(f, classModifiers, Type.Class); ++ } ++ ++ public Set<String> getClassFlags() { ++ return getFlags(classFlags, Type.Class); ++ } ++ ++ private static final int[] innerClassModifiers = { ++ ACC_PUBLIC, ACC_PRIVATE, ACC_PROTECTED, ACC_STATIC, ACC_FINAL, ++ ACC_ABSTRACT, ACC_MODULE ++ }; ++ ++ private static final int[] innerClassFlags = { ++ ACC_PUBLIC, ACC_PRIVATE, ACC_PROTECTED, ACC_STATIC, ACC_FINAL, ACC_SUPER, ++ ACC_INTERFACE, ACC_ABSTRACT, ACC_SYNTHETIC, ACC_ANNOTATION, ACC_ENUM, ACC_MODULE ++ }; ++ ++ public Set<String> getInnerClassModifiers() { ++ int f = ((flags & ACC_INTERFACE) != 0 ? flags & ~ACC_ABSTRACT : flags); ++ return getModifiers(f, innerClassModifiers, Type.InnerClass); ++ } ++ ++ public Set<String> getInnerClassFlags() { ++ return getFlags(innerClassFlags, Type.InnerClass); ++ } ++ ++ private static final int[] fieldModifiers = { ++ ACC_PUBLIC, ACC_PRIVATE, ACC_PROTECTED, ACC_STATIC, ACC_FINAL, ++ ACC_VOLATILE, ACC_TRANSIENT, ACC_MODULE ++ }; ++ ++ private static final int[] fieldFlags = { ++ ACC_PUBLIC, ACC_PRIVATE, ACC_PROTECTED, ACC_STATIC, ACC_FINAL, ++ ACC_VOLATILE, ACC_TRANSIENT, ACC_SYNTHETIC, ACC_ENUM, ACC_MODULE ++ }; ++ ++ public Set<String> getFieldModifiers() { ++ return getModifiers(fieldModifiers, Type.Field); ++ } ++ ++ public Set<String> getFieldFlags() { ++ return getFlags(fieldFlags, Type.Field); ++ } ++ ++ private static final int[] methodModifiers = { ++ ACC_PUBLIC, ACC_PRIVATE, ACC_PROTECTED, ACC_STATIC, ACC_FINAL, ++ ACC_SYNCHRONIZED, ACC_NATIVE, ACC_ABSTRACT, ACC_STRICT, ACC_MODULE ++ }; ++ ++ private static final int[] methodFlags = { ++ ACC_PUBLIC, ACC_PRIVATE, ACC_PROTECTED, ACC_STATIC, ACC_FINAL, ++ ACC_SYNCHRONIZED, ACC_BRIDGE, ACC_VARARGS, ACC_NATIVE, ACC_ABSTRACT, ++ ACC_STRICT, ACC_SYNTHETIC, ACC_MODULE ++ }; ++ ++ public Set<String> getMethodModifiers() { ++ return getModifiers(methodModifiers, Type.Method); ++ } ++ ++ public Set<String> getMethodFlags() { ++ return getFlags(methodFlags, Type.Method); ++ } ++ ++ private Set<String> getModifiers(int[] modifierFlags, Type t) { ++ return getModifiers(flags, modifierFlags, t); ++ } ++ ++ private static Set<String> getModifiers(int flags, int[] modifierFlags, Type t) { ++ Set<String> s = new LinkedHashSet<String>(); ++ for (int m: modifierFlags) { ++ if ((flags & m) != 0) ++ s.add(flagToModifier(m, t)); ++ } ++ return s; ++ } ++ ++ private Set<String> getFlags(int[] expectedFlags, Type t) { ++ Set<String> s = new LinkedHashSet<String>(); ++ int f = flags; ++ for (int e: expectedFlags) { ++ if ((f & e) != 0) { ++ s.add(flagToName(e, t)); ++ f = f & ~e; ++ } ++ } ++ while (f != 0) { ++ int bit = Integer.highestOneBit(f); ++ s.add("0x" + Integer.toHexString(bit)); ++ f = f & ~bit; ++ } ++ return s; ++ } ++ ++ private static String flagToModifier(int flag, Type t) { ++ switch (flag) { ++ case ACC_PUBLIC: ++ return "public"; ++ case ACC_PRIVATE: ++ return "private"; ++ case ACC_PROTECTED: ++ return "protected"; ++ case ACC_STATIC: ++ return "static"; ++ case ACC_FINAL: ++ return "final"; ++ case ACC_SYNCHRONIZED: ++ return "synchronized"; ++ case 0x80: ++ return (t == Type.Field ? "transient" : null); ++ case ACC_VOLATILE: ++ return "volatile"; ++ case ACC_NATIVE: ++ return "native"; ++ case ACC_ABSTRACT: ++ return "abstract"; ++ case ACC_STRICT: ++ return "strictfp"; ++ case ACC_MODULE: ++ return "module"; ++ default: ++ return null; ++ } ++ } ++ ++ private static String flagToName(int flag, Type t) { ++ switch (flag) { ++ case ACC_PUBLIC: ++ return "ACC_PUBLIC"; ++ case ACC_PRIVATE: ++ return "ACC_PRIVATE"; ++ case ACC_PROTECTED: ++ return "ACC_PROTECTED"; ++ case ACC_STATIC: ++ return "ACC_STATIC"; ++ case ACC_FINAL: ++ return "ACC_FINAL"; ++ case 0x20: ++ return (t == Type.Class ? "ACC_SUPER" : "ACC_SYNCHRONIZED"); ++ case 0x40: ++ return (t == Type.Field ? "ACC_VOLATILE" : "ACC_BRIDGE"); ++ case 0x80: ++ return (t == Type.Field ? "ACC_TRANSIENT" : "ACC_VARARGS"); ++ case ACC_NATIVE: ++ return "ACC_NATIVE"; ++ case ACC_INTERFACE: ++ return "ACC_INTERFACE"; ++ case ACC_ABSTRACT: ++ return "ACC_ABSTRACT"; ++ case ACC_STRICT: ++ return "ACC_STRICT"; ++ case ACC_SYNTHETIC: ++ return "ACC_SYNTHETIC"; ++ case ACC_ANNOTATION: ++ return "ACC_ANNOTATION"; ++ case ACC_ENUM: ++ return "ACC_ENUM"; ++ case ACC_MODULE: ++ return "ACC_MODULE"; ++ default: ++ return null; ++ } ++ } ++ ++ final int flags; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Annotation.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Annotation.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,243 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.16. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Annotation { ++ static class InvalidAnnotation extends AttributeException { ++ InvalidAnnotation(String msg) { ++ super(msg); ++ } ++ } ++ ++ Annotation(ClassReader cr) throws IOException, InvalidAnnotation { ++ type_index = cr.readUnsignedShort(); ++ num_element_value_pairs = cr.readUnsignedShort(); ++ element_value_pairs = new element_value_pair[num_element_value_pairs]; ++ for (int i = 0; i < element_value_pairs.length; i++) ++ element_value_pairs[i] = new element_value_pair(cr); ++ } ++ ++ public Annotation(ConstantPool constant_pool, ++ int type_index, ++ element_value_pair[] element_value_pairs) { ++ this.type_index = type_index; ++ num_element_value_pairs = element_value_pairs.length; ++ this.element_value_pairs = element_value_pairs; ++ } ++ ++ public int length() { ++ int n = 2 /*type_index*/ + 2 /*num_element_value_pairs*/; ++ for (element_value_pair pair: element_value_pairs) ++ n += pair.length(); ++ return n; ++ } ++ ++ public final int type_index; ++ public final int num_element_value_pairs; ++ public final element_value_pair element_value_pairs[]; ++ ++ /** ++ * See JVMS3, section 4.8.16.1. ++ */ ++ public static abstract class element_value { ++ public static element_value read(ClassReader cr) ++ throws IOException, InvalidAnnotation { ++ int tag = cr.readUnsignedByte(); ++ switch (tag) { ++ case 'B': ++ case 'C': ++ case 'D': ++ case 'F': ++ case 'I': ++ case 'J': ++ case 'S': ++ case 'Z': ++ case 's': ++ return new Primitive_element_value(cr, tag); ++ ++ case 'e': ++ return new Enum_element_value(cr, tag); ++ ++ case 'c': ++ return new Class_element_value(cr, tag); ++ ++ case '@': ++ return new Annotation_element_value(cr, tag); ++ ++ case '[': ++ return new Array_element_value(cr, tag); ++ ++ default: ++ throw new InvalidAnnotation("unrecognized tag: " + tag); ++ } ++ } ++ ++ protected element_value(int tag) { ++ this.tag = tag; ++ } ++ ++ public abstract int length(); ++ ++ public abstract <R,P> R accept(Visitor<R,P> visitor, P p); ++ ++ public interface Visitor<R,P> { ++ R visitPrimitive(Primitive_element_value ev, P p); ++ R visitEnum(Enum_element_value ev, P p); ++ R visitClass(Class_element_value ev, P p); ++ R visitAnnotation(Annotation_element_value ev, P p); ++ R visitArray(Array_element_value ev, P p); ++ } ++ ++ public final int tag; ++ } ++ ++ public static class Primitive_element_value extends element_value { ++ Primitive_element_value(ClassReader cr, int tag) throws IOException { ++ super(tag); ++ const_value_index = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return 2; ++ } ++ ++ public <R,P> R accept(Visitor<R,P> visitor, P p) { ++ return visitor.visitPrimitive(this, p); ++ } ++ ++ public final int const_value_index; ++ ++ } ++ ++ public static class Enum_element_value extends element_value { ++ Enum_element_value(ClassReader cr, int tag) throws IOException { ++ super(tag); ++ type_name_index = cr.readUnsignedShort(); ++ const_name_index = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return 4; ++ } ++ ++ public <R,P> R accept(Visitor<R,P> visitor, P p) { ++ return visitor.visitEnum(this, p); ++ } ++ ++ public final int type_name_index; ++ public final int const_name_index; ++ } ++ ++ public static class Class_element_value extends element_value { ++ Class_element_value(ClassReader cr, int tag) throws IOException { ++ super(tag); ++ class_info_index = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return 2; ++ } ++ ++ public <R,P> R accept(Visitor<R,P> visitor, P p) { ++ return visitor.visitClass(this, p); ++ } ++ ++ public final int class_info_index; ++ } ++ ++ public static class Annotation_element_value extends element_value { ++ Annotation_element_value(ClassReader cr, int tag) ++ throws IOException, InvalidAnnotation { ++ super(tag); ++ annotation_value = new Annotation(cr); ++ } ++ ++ @Override ++ public int length() { ++ return annotation_value.length(); ++ } ++ ++ public <R,P> R accept(Visitor<R,P> visitor, P p) { ++ return visitor.visitAnnotation(this, p); ++ } ++ ++ public final Annotation annotation_value; ++ } ++ ++ public static class Array_element_value extends element_value { ++ Array_element_value(ClassReader cr, int tag) ++ throws IOException, InvalidAnnotation { ++ super(tag); ++ num_values = cr.readUnsignedShort(); ++ values = new element_value[num_values]; ++ for (int i = 0; i < values.length; i++) ++ values[i] = element_value.read(cr); ++ } ++ ++ @Override ++ public int length() { ++ int n = 2; ++ for (int i = 0; i < values.length; i++) ++ n += values[i].length(); ++ return n; ++ } ++ ++ public <R,P> R accept(Visitor<R,P> visitor, P p) { ++ return visitor.visitArray(this, p); ++ } ++ ++ public final int num_values; ++ public final element_value[] values; ++ } ++ ++ public static class element_value_pair { ++ element_value_pair(ClassReader cr) ++ throws IOException, InvalidAnnotation { ++ element_name_index = cr.readUnsignedShort(); ++ value = element_value.read(cr); ++ } ++ ++ public int length() { ++ return 2 + value.length(); ++ } ++ ++ public final int element_name_index; ++ public final element_value value; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/AnnotationDefault_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/AnnotationDefault_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,61 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.15. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class AnnotationDefault_attribute extends Attribute { ++ AnnotationDefault_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, Annotation.InvalidAnnotation { ++ super(name_index, length); ++ default_value = Annotation.element_value.read(cr); ++ } ++ ++ public AnnotationDefault_attribute(ConstantPool constant_pool, Annotation.element_value default_value) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.AnnotationDefault), default_value); ++ } ++ ++ public AnnotationDefault_attribute(int name_index, Annotation.element_value default_value) { ++ super(name_index, default_value.length()); ++ this.default_value = default_value; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitAnnotationDefault(this, data); ++ } ++ ++ public final Annotation.element_value default_value; ++} ++ +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,199 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++import java.lang.reflect.Constructor; ++import java.util.HashMap; ++import java.util.Map; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++ ++public abstract class Attribute { ++ public static final String AnnotationDefault = "AnnotationDefault"; ++ public static final String CharacterRangeTable = "CharacterRangeTable"; ++ public static final String Code = "Code"; ++ public static final String ConstantValue = "ConstantValue"; ++ public static final String CompilationID = "CompilationID"; ++ public static final String Deprecated = "Deprecated"; ++ public static final String EnclosingMethod = "EnclosingMethod"; ++ public static final String Exceptions = "Exceptions"; ++ public static final String InnerClasses = "InnerClasses"; ++ public static final String LineNumberTable = "LineNumberTable"; ++ public static final String LocalVariableTable = "LocalVariableTable"; ++ public static final String LocalVariableTypeTable = "LocalVariableTypeTable"; ++ public static final String RuntimeVisibleAnnotations = "RuntimeVisibleAnnotations"; ++ public static final String RuntimeInvisibleAnnotations = "RuntimeInvisibleAnnotations"; ++ public static final String RuntimeVisibleParameterAnnotations = "RuntimeVisibleParameterAnnotations"; ++ public static final String RuntimeInvisibleParameterAnnotations = "RuntimeInvisibleParameterAnnotations"; ++ public static final String Signature = "Signature"; ++ public static final String SourceDebugExtension = "SourceDebugExtension"; ++ public static final String SourceFile = "SourceFile"; ++ public static final String SourceID = "SourceID"; ++ public static final String StackMap = "StackMap"; ++ public static final String StackMapTable = "StackMapTable"; ++ public static final String Synthetic = "Synthetic"; ++ ++ // JSR 277/294 ++ public static final String Module = "Module"; ++ public static final String ModuleExportTable = "ModuleExportTable"; ++ public static final String ModuleMemberTable = "ModuleMemberTable"; ++ ++ public static class Factory { ++ public Factory() { ++ // defer init of standardAttributeClasses until after options set up ++ } ++ ++ public void setCompat(boolean compat) { ++ this.compat = compat; ++ } ++ ++ public void setJSR277(boolean jsr277) { ++ this.jsr277 = jsr277; ++ } ++ ++ public Attribute createAttribute(ClassReader cr, int name_index, byte[] data) ++ throws IOException { ++ if (standardAttributes == null) ++ init(); ++ ++ ConstantPool cp = cr.getConstantPool(); ++ try { ++ String name = cp.getUTF8Value(name_index); ++ Class<? extends Attribute> attrClass = standardAttributes.get(name); ++ if (attrClass != null) { ++ try { ++ Class<?>[] constrArgTypes = {ClassReader.class, int.class, int.class}; ++ Constructor<? extends Attribute> constr = attrClass.getDeclaredConstructor(constrArgTypes); ++ return constr.newInstance(new Object[] { cr, name_index, data.length }); ++ } catch (Throwable t) { ++ // fall through and use DefaultAttribute ++ // t.printStackTrace(); ++ } ++ } ++ } catch (ConstantPoolException e) { ++ // fall through and use DefaultAttribute ++ } ++ return new DefaultAttribute(cr, name_index, data); ++ } ++ ++ protected void init() { ++ standardAttributes = new HashMap<String,Class<? extends Attribute>>(); ++ standardAttributes.put(AnnotationDefault, AnnotationDefault_attribute.class); ++ standardAttributes.put(CharacterRangeTable, CharacterRangeTable_attribute.class); ++ standardAttributes.put(Code, Code_attribute.class); ++ standardAttributes.put(ConstantValue, ConstantValue_attribute.class); ++ standardAttributes.put(Deprecated, Deprecated_attribute.class); ++ standardAttributes.put(EnclosingMethod, EnclosingMethod_attribute.class); ++ standardAttributes.put(Exceptions, Exceptions_attribute.class); ++ standardAttributes.put(InnerClasses, InnerClasses_attribute.class); ++ standardAttributes.put(LineNumberTable, LineNumberTable_attribute.class); ++ standardAttributes.put(LocalVariableTable, LocalVariableTable_attribute.class); ++ standardAttributes.put(LocalVariableTypeTable, LocalVariableTypeTable_attribute.class); ++ ++ if (jsr277) { ++ standardAttributes.put(Module, Module_attribute.class); ++ standardAttributes.put(ModuleExportTable, ModuleExportTable_attribute.class); ++ standardAttributes.put(ModuleMemberTable, ModuleMemberTable_attribute.class); ++ } ++ ++ if (!compat) { // old javap does not recognize recent attributes ++ standardAttributes.put(CompilationID, CompilationID_attribute.class); ++ standardAttributes.put(RuntimeInvisibleAnnotations, RuntimeInvisibleAnnotations_attribute.class); ++ standardAttributes.put(RuntimeInvisibleParameterAnnotations, RuntimeInvisibleParameterAnnotations_attribute.class); ++ standardAttributes.put(RuntimeVisibleAnnotations, RuntimeVisibleAnnotations_attribute.class); ++ standardAttributes.put(RuntimeVisibleParameterAnnotations, RuntimeVisibleParameterAnnotations_attribute.class); ++ standardAttributes.put(Signature, Signature_attribute.class); ++ standardAttributes.put(SourceID, SourceID_attribute.class); ++ } ++ ++ standardAttributes.put(SourceDebugExtension, SourceDebugExtension_attribute.class); ++ standardAttributes.put(SourceFile, SourceFile_attribute.class); ++ standardAttributes.put(StackMap, StackMap_attribute.class); ++ standardAttributes.put(StackMapTable, StackMapTable_attribute.class); ++ standardAttributes.put(Synthetic, Synthetic_attribute.class); ++ } ++ ++ private Map<String,Class<? extends Attribute>> standardAttributes; ++ private boolean compat; // don't support recent attrs in compatibility mode ++ private boolean jsr277; // support new jsr277 attrs ++ } ++ ++ public static Attribute read(ClassReader cr) throws IOException { ++ return cr.readAttribute(); ++ } ++ ++ protected Attribute(int name_index, int length) { ++ attribute_name_index = name_index; ++ attribute_length = length; ++ } ++ ++ public String getName(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(attribute_name_index); ++ } ++ ++ public abstract <R,D> R accept(Attribute.Visitor<R,D> visitor, D data); ++ ++ public final int attribute_name_index; ++ public final int attribute_length; ++ ++ ++ public interface Visitor<R,P> { ++ R visitDefault(DefaultAttribute attr, P p); ++ R visitAnnotationDefault(AnnotationDefault_attribute attr, P p); ++ R visitCharacterRangeTable(CharacterRangeTable_attribute attr, P p); ++ R visitCode(Code_attribute attr, P p); ++ R visitCompilationID(CompilationID_attribute attr, P p); ++ R visitConstantValue(ConstantValue_attribute attr, P p); ++ R visitDeprecated(Deprecated_attribute attr, P p); ++ R visitEnclosingMethod(EnclosingMethod_attribute attr, P p); ++ R visitExceptions(Exceptions_attribute attr, P p); ++ R visitInnerClasses(InnerClasses_attribute attr, P p); ++ R visitLineNumberTable(LineNumberTable_attribute attr, P p); ++ R visitLocalVariableTable(LocalVariableTable_attribute attr, P p); ++ R visitLocalVariableTypeTable(LocalVariableTypeTable_attribute attr, P p); ++ R visitRuntimeVisibleAnnotations(RuntimeVisibleAnnotations_attribute attr, P p); ++ R visitRuntimeInvisibleAnnotations(RuntimeInvisibleAnnotations_attribute attr, P p); ++ R visitRuntimeVisibleParameterAnnotations(RuntimeVisibleParameterAnnotations_attribute attr, P p); ++ R visitRuntimeInvisibleParameterAnnotations(RuntimeInvisibleParameterAnnotations_attribute attr, P p); ++ R visitSignature(Signature_attribute attr, P p); ++ R visitSourceDebugExtension(SourceDebugExtension_attribute attr, P p); ++ R visitSourceFile(SourceFile_attribute attr, P p); ++ R visitSourceID(SourceID_attribute attr, P p); ++ R visitStackMap(StackMap_attribute attr, P p); ++ R visitStackMapTable(StackMapTable_attribute attr, P p); ++ R visitSynthetic(Synthetic_attribute attr, P p); ++ ++ R visitModule(Module_attribute attr, P p); ++ R visitModuleExportTable(ModuleExportTable_attribute attr, P p); ++ R visitModuleMemberTable(ModuleMemberTable_attribute attr, P p); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/AttributeException.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/AttributeException.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,40 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class AttributeException extends Exception { ++ AttributeException() { } ++ ++ AttributeException(String msg) { ++ super(msg); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Attributes.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Attributes.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,87 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++import java.util.Arrays; ++import java.util.HashMap; ++import java.util.Iterator; ++import java.util.Map; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Attributes implements Iterable<Attribute> { ++ Attributes(ClassReader cr) throws IOException { ++ map = new HashMap<String,Attribute>(); ++ int attrs_count = cr.readUnsignedShort(); ++ attrs = new Attribute[attrs_count]; ++ for (int i = 0; i < attrs_count; i++) { ++ Attribute attr = Attribute.read(cr); ++ attrs[i] = attr; ++ try { ++ map.put(attr.getName(cr.getConstantPool()), attr); ++ } catch (ConstantPoolException e) { ++ // don't enter invalid names in map ++ } ++ } ++ } ++ ++ public Attributes(ConstantPool constant_pool, Attribute[] attrs) { ++ this.attrs = attrs; ++ map = new HashMap<String,Attribute>(); ++ for (int i = 0; i < attrs.length; i++) { ++ Attribute attr = attrs[i]; ++ try { ++ map.put(attr.getName(constant_pool), attr); ++ } catch (ConstantPoolException e) { ++ // don't enter invalid names in map ++ } ++ } ++ } ++ ++ public Iterator<Attribute> iterator() { ++ return Arrays.asList(attrs).iterator(); ++ } ++ ++ public Attribute get(int index) { ++ return attrs[index]; ++ } ++ ++ public Attribute get(String name) { ++ return map.get(name); ++ } ++ ++ public int size() { ++ return attrs.length; ++ } ++ ++ public final Attribute[] attrs; ++ public final Map<String, Attribute> map; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/CharacterRangeTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/CharacterRangeTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,90 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class CharacterRangeTable_attribute extends Attribute { ++ public static final int CRT_STATEMENT = 0x0001; ++ public static final int CRT_BLOCK = 0x0002; ++ public static final int CRT_ASSIGNMENT = 0x0004; ++ public static final int CRT_FLOW_CONTROLLER = 0x0008; ++ public static final int CRT_FLOW_TARGET = 0x0010; ++ public static final int CRT_INVOKE = 0x0020; ++ public static final int CRT_CREATE = 0x0040; ++ public static final int CRT_BRANCH_TRUE = 0x0080; ++ public static final int CRT_BRANCH_FALSE = 0x0100; ++ ++ CharacterRangeTable_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ int character_range_table_length = cr.readUnsignedShort(); ++ character_range_table = new Entry[character_range_table_length]; ++ for (int i = 0; i < character_range_table_length; i++) ++ character_range_table[i] = new Entry(cr); ++ } ++ ++ public CharacterRangeTable_attribute(ConstantPool constant_pool, Entry[] character_range_table) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.CharacterRangeTable), character_range_table); ++ } ++ ++ public CharacterRangeTable_attribute(int name_index, Entry[] character_range_table) { ++ super(name_index, character_range_table.length * Entry.length()); ++ this.character_range_table = character_range_table; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitCharacterRangeTable(this, data); ++ } ++ ++ public final Entry[] character_range_table; ++ ++ public static class Entry { ++ Entry(ClassReader cr) throws IOException { ++ start_pc = cr.readUnsignedShort(); ++ end_pc = cr.readUnsignedShort(); ++ character_range_start = cr.readInt(); ++ character_range_end = cr.readInt(); ++ flags = cr.readUnsignedShort(); ++ } ++ ++ public static int length() { ++ return 14; ++ } ++ ++ public final int start_pc; ++ public final int end_pc; ++ public final int character_range_start; ++ public final int character_range_end; ++ public final int flags; ++ }; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ClassFile.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ClassFile.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,153 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.File; ++import java.io.FileInputStream; ++import java.io.IOException; ++import java.io.InputStream; ++ ++import static com.sun.tools.classfile.AccessFlags.*; ++ ++/** ++ * See JVMS3, section 4.2. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ClassFile { ++ public static ClassFile read(File file) ++ throws IOException, ConstantPoolException { ++ return read(file, new Attribute.Factory()); ++ } ++ ++ public static ClassFile read(File file, Attribute.Factory attributeFactory) ++ throws IOException, ConstantPoolException { ++ FileInputStream in = new FileInputStream(file); ++ try { ++ return new ClassFile(in, attributeFactory); ++ } finally { ++ try { ++ in.close(); ++ } catch (IOException e) { ++ // ignore ++ } ++ } ++ } ++ ++ public static ClassFile read(InputStream in) ++ throws IOException, ConstantPoolException { ++ return new ClassFile(in, new Attribute.Factory()); ++ } ++ ++ public static ClassFile read(InputStream in, Attribute.Factory attributeFactory) ++ throws IOException, ConstantPoolException { ++ return new ClassFile(in, attributeFactory); ++ } ++ ++ ClassFile(InputStream in, Attribute.Factory attributeFactory) throws IOException, ConstantPoolException { ++ ClassReader cr = new ClassReader(this, in, attributeFactory); ++ magic = cr.readInt(); ++ minor_version = cr.readUnsignedShort(); ++ major_version = cr.readUnsignedShort(); ++ constant_pool = new ConstantPool(cr); ++ access_flags = new AccessFlags(cr); ++ this_class = cr.readUnsignedShort(); ++ super_class = cr.readUnsignedShort(); ++ ++ int interfaces_count = cr.readUnsignedShort(); ++ interfaces = new int[interfaces_count]; ++ for (int i = 0; i < interfaces_count; i++) ++ interfaces[i] = cr.readUnsignedShort(); ++ ++ int fields_count = cr.readUnsignedShort(); ++ fields = new Field[fields_count]; ++ for (int i = 0; i < fields_count; i++) ++ fields[i] = new Field(cr); ++ ++ int methods_count = cr.readUnsignedShort(); ++ methods = new Method[methods_count]; ++ for (int i = 0; i < methods_count; i++) ++ methods[i] = new Method(cr); ++ ++ attributes = new Attributes(cr); ++ } ++ ++ public ClassFile(int magic, int minor_version, int major_version, ++ ConstantPool constant_pool, AccessFlags access_flags, ++ int this_class, int super_class, int[] interfaces, ++ Field[] fields, Method[] methods, Attributes attributes) { ++ this.magic = magic; ++ this.minor_version = minor_version; ++ this.major_version = major_version; ++ this.constant_pool = constant_pool; ++ this.access_flags = access_flags; ++ this.this_class = this_class; ++ this.super_class = super_class; ++ this.interfaces = interfaces; ++ this.fields = fields; ++ this.methods = methods; ++ this.attributes = attributes; ++ } ++ ++ public String getName() throws ConstantPoolException { ++ return constant_pool.getClassInfo(this_class).getName(); ++ } ++ ++ public String getSuperclassName() throws ConstantPoolException { ++ return constant_pool.getClassInfo(super_class).getName(); ++ } ++ ++ public String getInterfaceName(int i) throws ConstantPoolException { ++ return constant_pool.getClassInfo(interfaces[i]).getName(); ++ } ++ ++ public Attribute getAttribute(String name) { ++ return attributes.get(name); ++ } ++ ++ public boolean isClass() { ++ return !isInterface(); ++ } ++ ++ public boolean isInterface() { ++ return access_flags.is(ACC_INTERFACE); ++ } ++ ++ public final int magic; ++ public final int minor_version; ++ public final int major_version; ++ public final ConstantPool constant_pool; ++ public final AccessFlags access_flags; ++ public final int this_class; ++ public final int super_class; ++ public final int[] interfaces; ++ public final Field[] fields; ++ public final Method[] methods; ++ public final Attributes attributes; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ClassReader.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ClassReader.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,109 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.BufferedInputStream; ++import java.io.ByteArrayInputStream; ++import java.io.DataInputStream; ++import java.io.IOException; ++import java.io.InputStream; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ClassReader { ++ ClassReader(ClassFile classFile, InputStream in, Attribute.Factory attributeFactory) throws IOException { ++ // null checks ++ classFile.getClass(); ++ attributeFactory.getClass(); ++ ++ this.classFile = classFile; ++ this.in = new DataInputStream(new BufferedInputStream(in)); ++ this.attributeFactory = attributeFactory; ++ } ++ ++ ClassFile getClassFile() { ++ return classFile; ++ } ++ ++ ConstantPool getConstantPool() { ++ return classFile.constant_pool; ++ } ++ ++ public Attribute readAttribute() throws IOException { ++ int name_index = readUnsignedShort(); ++ int length = readInt(); ++ byte[] data = new byte[length]; ++ readFully(data); ++ ++ DataInputStream prev = in; ++ in = new DataInputStream(new ByteArrayInputStream(data)); ++ try { ++ return attributeFactory.createAttribute(this, name_index, data); ++ } finally { ++ in = prev; ++ } ++ } ++ ++ public void readFully(byte[] b) throws IOException { ++ in.readFully(b); ++ } ++ ++ public int readUnsignedByte() throws IOException { ++ return in.readUnsignedByte(); ++ } ++ ++ public int readUnsignedShort() throws IOException { ++ return in.readUnsignedShort(); ++ } ++ ++ public int readInt() throws IOException { ++ return in.readInt(); ++ } ++ ++ public long readLong() throws IOException { ++ return in.readLong(); ++ } ++ ++ public float readFloat() throws IOException { ++ return in.readFloat(); ++ } ++ ++ public double readDouble() throws IOException { ++ return in.readDouble(); ++ } ++ ++ public String readUTF() throws IOException { ++ return in.readUTF(); ++ } ++ ++ private DataInputStream in; ++ private ClassFile classFile; ++ private Attribute.Factory attributeFactory; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ClassTranslator.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ClassTranslator.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,368 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Class_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Double_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Fieldref_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Float_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Integer_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_InterfaceMethodref_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Long_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Methodref_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_NameAndType_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_String_info; ++import com.sun.tools.classfile.ConstantPool.CONSTANT_Utf8_info; ++import com.sun.tools.classfile.ConstantPool.CPInfo; ++import java.util.Map; ++ ++/** ++ * Rewrites a class file using a map of translations. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ClassTranslator ++ implements ConstantPool.Visitor<ConstantPool.CPInfo,Map<Object,Object>> { ++ /** ++ * Create a new ClassFile from {@code cf}, such that for all entries ++ * {@code k -\> v} in {@code translations}, ++ * each occurrence of {@code k} in {@code cf} will be replaced by {@code v}. ++ * in ++ * @param cf the class file to be processed ++ * @param translations the set of translations to be applied ++ * @return a copy of {@code} with the values in {@code translations} substituted ++ */ ++ public ClassFile translate(ClassFile cf, Map<Object,Object> translations) { ++ ClassFile cf2 = (ClassFile) translations.get(cf); ++ if (cf2 == null) { ++ ConstantPool constant_pool2 = translate(cf.constant_pool, translations); ++ Field[] fields2 = translate(cf.fields, cf.constant_pool, translations); ++ Method[] methods2 = translateMethods(cf.methods, cf.constant_pool, translations); ++ Attributes attributes2 = translateAttributes(cf.attributes, cf.constant_pool, ++ translations); ++ ++ if (constant_pool2 == cf.constant_pool && ++ fields2 == cf.fields && ++ methods2 == cf.methods && ++ attributes2 == cf.attributes) ++ cf2 = cf; ++ else ++ cf2 = new ClassFile( ++ cf.magic, ++ cf.minor_version, ++ cf.major_version, ++ constant_pool2, ++ cf.access_flags, ++ cf.this_class, ++ cf.super_class, ++ cf.interfaces, ++ fields2, ++ methods2, ++ attributes2); ++ translations.put(cf, cf2); ++ } ++ return cf2; ++ } ++ ++ ConstantPool translate(ConstantPool cp, Map<Object,Object> translations) { ++ ConstantPool cp2 = (ConstantPool) translations.get(cp); ++ if (cp2 == null) { ++ ConstantPool.CPInfo[] pool2 = new ConstantPool.CPInfo[cp.size()]; ++ boolean eq = true; ++ for (int i = 0; i < cp.size(); i++) { ++ ConstantPool.CPInfo cpInfo; ++ try { ++ cpInfo = cp.get(i); ++ } catch (ConstantPool.InvalidIndex e) { ++ throw new IllegalStateException(e); ++ } ++ ConstantPool.CPInfo cpInfo2 = translate(cpInfo, translations); ++ eq &= (cpInfo == cpInfo2); ++ pool2[i] = cpInfo2; ++ if (cpInfo.getTag() != cpInfo2.getTag()) ++ throw new IllegalStateException(); ++ switch (cpInfo.getTag()) { ++ case ConstantPool.CONSTANT_Double: ++ case ConstantPool.CONSTANT_Long: ++ i += 1; ++ } ++ } ++ ++ if (eq) ++ cp2 = cp; ++ else ++ cp2 = new ConstantPool(pool2); ++ ++ translations.put(cp, cp2); ++ } ++ return cp2; ++ } ++ ++ ConstantPool.CPInfo translate(ConstantPool.CPInfo cpInfo, Map<Object,Object> translations) { ++ ConstantPool.CPInfo cpInfo2 = (ConstantPool.CPInfo) translations.get(cpInfo); ++ if (cpInfo2 == null) { ++ cpInfo2 = cpInfo.accept(this, translations); ++ translations.put(cpInfo, cpInfo2); ++ } ++ return cpInfo2; ++ } ++ ++ Field[] translate(Field[] fields, ConstantPool constant_pool, Map<Object,Object> translations) { ++ Field[] fields2 = (Field[]) translations.get(fields); ++ if (fields2 == null) { ++ fields2 = new Field[fields.length]; ++ for (int i = 0; i < fields.length; i++) ++ fields2[i] = translate(fields[i], constant_pool, translations); ++ if (equal(fields, fields2)) ++ fields2 = fields; ++ translations.put(fields, fields2); ++ } ++ return fields2; ++ } ++ ++ Field translate(Field field, ConstantPool constant_pool, Map<Object,Object> translations) { ++ Field field2 = (Field) translations.get(field); ++ if (field2 == null) { ++ Attributes attributes2 = translateAttributes(field.attributes, constant_pool, ++ translations); ++ ++ if (attributes2 == field.attributes) ++ field2 = field; ++ else ++ field2 = new Field( ++ field.access_flags, ++ field.name_index, ++ field.descriptor, ++ attributes2); ++ translations.put(field, field2); ++ } ++ return field2; ++ } ++ ++ Method[] translateMethods(Method[] methods, ConstantPool constant_pool, Map<Object,Object> translations) { ++ Method[] methods2 = (Method[]) translations.get(methods); ++ if (methods2 == null) { ++ methods2 = new Method[methods.length]; ++ for (int i = 0; i < methods.length; i++) ++ methods2[i] = translate(methods[i], constant_pool, translations); ++ if (equal(methods, methods2)) ++ methods2 = methods; ++ translations.put(methods, methods2); ++ } ++ return methods2; ++ } ++ ++ Method translate(Method method, ConstantPool constant_pool, Map<Object,Object> translations) { ++ Method method2 = (Method) translations.get(method); ++ if (method2 == null) { ++ Attributes attributes2 = translateAttributes(method.attributes, constant_pool, ++ translations); ++ ++ if (attributes2 == method.attributes) ++ method2 = method; ++ else ++ method2 = new Method( ++ method.access_flags, ++ method.name_index, ++ method.descriptor, ++ attributes2); ++ translations.put(method, method2); ++ } ++ return method2; ++ } ++ ++ Attributes translateAttributes(Attributes attributes, ++ ConstantPool constant_pool, Map<Object,Object> translations) { ++ Attributes attributes2 = (Attributes) translations.get(attributes); ++ if (attributes2 == null) { ++ Attribute[] attrArray2 = new Attribute[attributes.size()]; ++ ConstantPool constant_pool2 = translate(constant_pool, translations); ++ boolean attrsEqual = true; ++ for (int i = 0; i < attributes.size(); i++) { ++ Attribute attr = attributes.get(i); ++ Attribute attr2 = translate(attr, translations); ++ if (attr2 != attr) ++ attrsEqual = false; ++ attrArray2[i] = attr2; ++ } ++ if ((constant_pool2 == constant_pool) && attrsEqual) ++ attributes2 = attributes; ++ else ++ attributes2 = new Attributes(constant_pool2, attrArray2); ++ translations.put(attributes, attributes2); ++ } ++ return attributes2; ++ } ++ ++ Attribute translate(Attribute attribute, Map<Object,Object> translations) { ++ Attribute attribute2 = (Attribute) translations.get(attribute); ++ if (attribute2 == null) { ++ attribute2 = attribute; // don't support translation within attributes yet ++ // (what about Code attribute) ++ translations.put(attribute, attribute2); ++ } ++ return attribute2; ++ } ++ ++ private static <T> boolean equal(T[] a1, T[] a2) { ++ if (a1 == null || a2 == null) ++ return (a1 == a2); ++ if (a1.length != a2.length) ++ return false; ++ for (int i = 0; i < a1.length; i++) { ++ if (a1[i] != a2[i]) ++ return false; ++ } ++ return true; ++ } ++ ++ public CPInfo visitClass(CONSTANT_Class_info info, Map<Object, Object> translations) { ++ CONSTANT_Class_info info2 = (CONSTANT_Class_info) translations.get(info); ++ if (info2 == null) { ++ ConstantPool cp2 = translate(info.cp, translations); ++ if (cp2 == info.cp) ++ info2 = info; ++ else ++ info2 = new CONSTANT_Class_info(cp2, info.name_index); ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitDouble(CONSTANT_Double_info info, Map<Object, Object> translations) { ++ CONSTANT_Double_info info2 = (CONSTANT_Double_info) translations.get(info); ++ if (info2 == null) { ++ info2 = info; ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitFieldref(CONSTANT_Fieldref_info info, Map<Object, Object> translations) { ++ CONSTANT_Fieldref_info info2 = (CONSTANT_Fieldref_info) translations.get(info); ++ if (info2 == null) { ++ ConstantPool cp2 = translate(info.cp, translations); ++ if (cp2 == info.cp) ++ info2 = info; ++ else ++ info2 = new CONSTANT_Fieldref_info(cp2, info.class_index, info.name_and_type_index); ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitFloat(CONSTANT_Float_info info, Map<Object, Object> translations) { ++ CONSTANT_Float_info info2 = (CONSTANT_Float_info) translations.get(info); ++ if (info2 == null) { ++ info2 = info; ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitInteger(CONSTANT_Integer_info info, Map<Object, Object> translations) { ++ CONSTANT_Integer_info info2 = (CONSTANT_Integer_info) translations.get(info); ++ if (info2 == null) { ++ info2 = info; ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, Map<Object, Object> translations) { ++ CONSTANT_InterfaceMethodref_info info2 = (CONSTANT_InterfaceMethodref_info) translations.get(info); ++ if (info2 == null) { ++ ConstantPool cp2 = translate(info.cp, translations); ++ if (cp2 == info.cp) ++ info2 = info; ++ else ++ info2 = new CONSTANT_InterfaceMethodref_info(cp2, info.class_index, info.name_and_type_index); ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitLong(CONSTANT_Long_info info, Map<Object, Object> translations) { ++ CONSTANT_Long_info info2 = (CONSTANT_Long_info) translations.get(info); ++ if (info2 == null) { ++ info2 = info; ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitNameAndType(CONSTANT_NameAndType_info info, Map<Object, Object> translations) { ++ CONSTANT_NameAndType_info info2 = (CONSTANT_NameAndType_info) translations.get(info); ++ if (info2 == null) { ++ ConstantPool cp2 = translate(info.cp, translations); ++ if (cp2 == info.cp) ++ info2 = info; ++ else ++ info2 = new CONSTANT_NameAndType_info(cp2, info.name_index, info.type_index); ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitMethodref(CONSTANT_Methodref_info info, Map<Object, Object> translations) { ++ CONSTANT_Methodref_info info2 = (CONSTANT_Methodref_info) translations.get(info); ++ if (info2 == null) { ++ ConstantPool cp2 = translate(info.cp, translations); ++ if (cp2 == info.cp) ++ info2 = info; ++ else ++ info2 = new CONSTANT_Methodref_info(cp2, info.class_index, info.name_and_type_index); ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitString(CONSTANT_String_info info, Map<Object, Object> translations) { ++ CONSTANT_String_info info2 = (CONSTANT_String_info) translations.get(info); ++ if (info2 == null) { ++ ConstantPool cp2 = translate(info.cp, translations); ++ if (cp2 == info.cp) ++ info2 = info; ++ else ++ info2 = new CONSTANT_String_info(cp2, info.string_index); ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++ public CPInfo visitUtf8(CONSTANT_Utf8_info info, Map<Object, Object> translations) { ++ CONSTANT_Utf8_info info2 = (CONSTANT_Utf8_info) translations.get(info); ++ if (info2 == null) { ++ info2 = info; ++ translations.put(info, info2); ++ } ++ return info; ++ } ++ ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ClassWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ClassWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,689 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++import java.io.ByteArrayOutputStream; ++import java.io.DataOutputStream; ++import java.io.File; ++import java.io.FileOutputStream; ++import java.io.IOException; ++import java.io.OutputStream; ++ ++import static com.sun.tools.classfile.Annotation.*; ++import static com.sun.tools.classfile.ConstantPool.*; ++import static com.sun.tools.classfile.StackMapTable_attribute.*; ++import static com.sun.tools.classfile.StackMapTable_attribute.verification_type_info.*; ++ ++/** ++ * Write a ClassFile data structure to a file or stream. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ClassWriter { ++ public ClassWriter() { ++ attributeWriter = new AttributeWriter(); ++ constantPoolWriter = new ConstantPoolWriter(); ++ out = new ClassOutputStream(); ++ } ++ ++ /** ++ * Write a ClassFile data structure to a file. ++ */ ++ public void write(ClassFile classFile, File f) throws IOException { ++ FileOutputStream f_out = new FileOutputStream(f); ++ try { ++ write(classFile, f_out); ++ } finally { ++ f_out.close(); ++ } ++ } ++ ++ /** ++ * Write a ClassFile data structure to a stream. ++ */ ++ public void write(ClassFile classFile, OutputStream s) throws IOException { ++ this.classFile = classFile; ++ out.reset(); ++ write(); ++ out.writeTo(s); ++ } ++ ++ protected void write() throws IOException { ++ writeHeader(); ++ writeConstantPool(); ++ writeAccessFlags(classFile.access_flags); ++ writeClassInfo(); ++ writeFields(); ++ writeMethods(); ++ writeAttributes(classFile.attributes); ++ } ++ ++ protected void writeHeader() { ++ out.writeInt(classFile.magic); ++ out.writeShort(classFile.minor_version); ++ out.writeShort(classFile.major_version); ++ } ++ ++ protected void writeAccessFlags(AccessFlags flags) { ++ out.writeShort(flags.flags); ++ } ++ ++ protected void writeAttributes(Attributes attributes) { ++ int size = attributes.size(); ++ out.writeShort(size); ++ for (Attribute attr: attributes) ++ attributeWriter.write(attr, out); ++ } ++ ++ protected void writeClassInfo() { ++ out.writeShort(classFile.this_class); ++ out.writeShort(classFile.super_class); ++ int[] interfaces = classFile.interfaces; ++ out.writeShort(interfaces.length); ++ for (int i: interfaces) ++ out.writeShort(i); ++ } ++ ++ protected void writeDescriptor(Descriptor d) { ++ out.writeShort(d.index); ++ } ++ ++ protected void writeConstantPool() { ++ ConstantPool pool = classFile.constant_pool; ++ int size = pool.size(); ++ out.writeShort(size); ++ try { ++ for (int i = 1; i < size; ) { ++ i += constantPoolWriter.write(pool.get(i), out); ++ } ++ } catch (ConstantPoolException e) { ++ throw new Error(e); // ?? ++ } ++ } ++ ++ protected void writeFields() throws IOException { ++ Field[] fields = classFile.fields; ++ out.writeShort(fields.length); ++ for (Field f: fields) ++ writeField(f); ++ } ++ ++ protected void writeField(Field f) throws IOException { ++ writeAccessFlags(f.access_flags); ++ out.writeShort(f.name_index); ++ writeDescriptor(f.descriptor); ++ writeAttributes(f.attributes); ++ } ++ ++ protected void writeMethods() throws IOException { ++ Method[] methods = classFile.methods; ++ out.writeShort(methods.length); ++ for (Method m: methods) { ++ writeMethod(m); ++ } ++ } ++ ++ protected void writeMethod(Method m) throws IOException { ++ writeAccessFlags(m.access_flags); ++ out.writeShort(m.name_index); ++ writeDescriptor(m.descriptor); ++ writeAttributes(m.attributes); ++ } ++ ++ protected ClassFile classFile; ++ protected ClassOutputStream out; ++ protected AttributeWriter attributeWriter; ++ protected ConstantPoolWriter constantPoolWriter; ++ ++ /** ++ * Subtype of ByteArrayOutputStream with the convenience methods of ++ * a DataOutputStream. Since ByteArrayOutputStream does not throw ++ * IOException, there are no exceptions from the additional ++ * convenience methods either, ++ */ ++ protected static class ClassOutputStream extends ByteArrayOutputStream { ++ public ClassOutputStream() { ++ d = new DataOutputStream(this); ++ } ++ ++ public void writeByte(int value) { ++ try { ++ d.writeByte(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeShort(int value) { ++ try { ++ d.writeShort(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeInt(int value) { ++ try { ++ d.writeInt(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeLong(long value) { ++ try { ++ d.writeLong(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeFloat(float value) { ++ try { ++ d.writeFloat(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeDouble(double value) { ++ try { ++ d.writeDouble(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeUTF(String value) { ++ try { ++ d.writeUTF(value); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ public void writeTo(ClassOutputStream s) { ++ try { ++ super.writeTo(s); ++ } catch (IOException ignore) { ++ } ++ } ++ ++ private DataOutputStream d; ++ } ++ ++ /** ++ * Writer for the entries in the constant pool. ++ */ ++ protected static class ConstantPoolWriter ++ implements ConstantPool.Visitor<Integer,ClassOutputStream> { ++ protected int write(CPInfo info, ClassOutputStream out) { ++ out.writeByte(info.getTag()); ++ return info.accept(this, out); ++ } ++ ++ public Integer visitClass(CONSTANT_Class_info info, ClassOutputStream out) { ++ out.writeShort(info.name_index); ++ return 1; ++ } ++ ++ public Integer visitDouble(CONSTANT_Double_info info, ClassOutputStream out) { ++ out.writeDouble(info.value); ++ return 2; ++ } ++ ++ public Integer visitFieldref(CONSTANT_Fieldref_info info, ClassOutputStream out) { ++ writeRef(info, out); ++ return 1; ++ } ++ ++ public Integer visitFloat(CONSTANT_Float_info info, ClassOutputStream out) { ++ out.writeFloat(info.value); ++ return 1; ++ } ++ ++ public Integer visitInteger(CONSTANT_Integer_info info, ClassOutputStream out) { ++ out.writeInt(info.value); ++ return 1; ++ } ++ ++ public Integer visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, ClassOutputStream out) { ++ writeRef(info, out); ++ return 1; ++ } ++ ++ public Integer visitLong(CONSTANT_Long_info info, ClassOutputStream out) { ++ out.writeLong(info.value); ++ return 2; ++ } ++ ++ public Integer visitNameAndType(CONSTANT_NameAndType_info info, ClassOutputStream out) { ++ out.writeShort(info.name_index); ++ out.writeShort(info.type_index); ++ return 1; ++ } ++ ++ public Integer visitMethodref(CONSTANT_Methodref_info info, ClassOutputStream out) { ++ return writeRef(info, out); ++ } ++ ++ public Integer visitString(CONSTANT_String_info info, ClassOutputStream out) { ++ out.writeShort(info.string_index); ++ return 1; ++ } ++ ++ public Integer visitUtf8(CONSTANT_Utf8_info info, ClassOutputStream out) { ++ out.writeUTF(info.value); ++ return 1; ++ } ++ ++ protected Integer writeRef(CPRefInfo info, ClassOutputStream out) { ++ out.writeShort(info.class_index); ++ out.writeShort(info.name_and_type_index); ++ return 1; ++ } ++ } ++ ++ /** ++ * Writer for the different types of attribute. ++ */ ++ protected static class AttributeWriter implements Attribute.Visitor<Void,ClassOutputStream> { ++ public void write(Attributes attributes, ClassOutputStream out) { ++ int size = attributes.size(); ++ out.writeShort(size); ++ for (Attribute a: attributes) ++ write(a, out); ++ } ++ ++ // Note: due to the use of shared resources, this method is not reentrant. ++ public void write(Attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.attribute_name_index); ++ sharedOut.reset(); ++ attr.accept(this, sharedOut); ++ out.writeInt(sharedOut.size()); ++ sharedOut.writeTo(out); ++ } ++ ++ protected ClassOutputStream sharedOut = new ClassOutputStream(); ++ protected AnnotationWriter annotationWriter = new AnnotationWriter(); ++ ++ public Void visitDefault(DefaultAttribute attr, ClassOutputStream out) { ++ out.write(attr.info, 0, attr.info.length); ++ return null; ++ } ++ ++ public Void visitAnnotationDefault(AnnotationDefault_attribute attr, ClassOutputStream out) { ++ annotationWriter.write(attr.default_value, out); ++ return null; ++ } ++ ++ public Void visitCharacterRangeTable(CharacterRangeTable_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.character_range_table.length); ++ for (CharacterRangeTable_attribute.Entry e: attr.character_range_table) ++ writeCharacterRangeTableEntry(e, out); ++ return null; ++ } ++ ++ protected void writeCharacterRangeTableEntry(CharacterRangeTable_attribute.Entry entry, ClassOutputStream out) { ++ out.writeShort(entry.start_pc); ++ out.writeShort(entry.end_pc); ++ out.writeInt(entry.character_range_start); ++ out.writeInt(entry.character_range_end); ++ out.writeShort(entry.flags); ++ } ++ ++ public Void visitCode(Code_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.max_stack); ++ out.writeShort(attr.max_locals); ++ out.writeInt(attr.code.length); ++ out.write(attr.code, 0, attr.code.length); ++ out.writeShort(attr.exception_table.length); ++ for (Code_attribute.Exception_data e: attr.exception_table) ++ writeExceptionTableEntry(e, out); ++ new AttributeWriter().write(attr.attributes, out); ++ return null; ++ } ++ ++ protected void writeExceptionTableEntry(Code_attribute.Exception_data exception_data, ClassOutputStream out) { ++ out.writeShort(exception_data.start_pc); ++ out.writeShort(exception_data.end_pc); ++ out.writeShort(exception_data.handler_pc); ++ out.writeShort(exception_data.catch_type); ++ } ++ ++ public Void visitCompilationID(CompilationID_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.compilationID_index); ++ return null; ++ } ++ ++ public Void visitConstantValue(ConstantValue_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.constantvalue_index); ++ return null; ++ } ++ ++ public Void visitDeprecated(Deprecated_attribute attr, ClassOutputStream out) { ++ return null; ++ } ++ ++ public Void visitEnclosingMethod(EnclosingMethod_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.class_index); ++ out.writeShort(attr.method_index); ++ return null; ++ } ++ ++ public Void visitExceptions(Exceptions_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.exception_index_table.length); ++ for (int i: attr.exception_index_table) ++ out.writeShort(i); ++ return null; ++ } ++ ++ public Void visitInnerClasses(InnerClasses_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.classes.length); ++ for (InnerClasses_attribute.Info info: attr.classes) ++ writeInnerClassesInfo(info, out); ++ return null; ++ } ++ ++ protected void writeInnerClassesInfo(InnerClasses_attribute.Info info, ClassOutputStream out) { ++ out.writeShort(info.inner_class_info_index); ++ out.writeShort(info.outer_class_info_index); ++ out.writeShort(info.inner_name_index); ++ writeAccessFlags(info.inner_class_access_flags, out); ++ } ++ ++ public Void visitLineNumberTable(LineNumberTable_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.line_number_table.length); ++ for (LineNumberTable_attribute.Entry e: attr.line_number_table) ++ writeLineNumberTableEntry(e, out); ++ return null; ++ } ++ ++ protected void writeLineNumberTableEntry(LineNumberTable_attribute.Entry entry, ClassOutputStream out) { ++ out.writeShort(entry.start_pc); ++ out.writeShort(entry.line_number); ++ } ++ ++ public Void visitLocalVariableTable(LocalVariableTable_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.local_variable_table.length); ++ for (LocalVariableTable_attribute.Entry e: attr.local_variable_table) ++ writeLocalVariableTableEntry(e, out); ++ return null; ++ } ++ ++ protected void writeLocalVariableTableEntry(LocalVariableTable_attribute.Entry entry, ClassOutputStream out) { ++ out.writeShort(entry.start_pc); ++ out.writeShort(entry.length); ++ out.writeShort(entry.name_index); ++ out.writeShort(entry.descriptor_index); ++ out.writeShort(entry.index); ++ } ++ ++ public Void visitLocalVariableTypeTable(LocalVariableTypeTable_attribute attr, ClassOutputStream out) { ++ out.writeByte(attr.local_variable_table.length); ++ for (LocalVariableTypeTable_attribute.Entry e: attr.local_variable_table) ++ writeLocalVariableTypeTableEntry(e, out); ++ return null; ++ } ++ ++ protected void writeLocalVariableTypeTableEntry(LocalVariableTypeTable_attribute.Entry entry, ClassOutputStream out) { ++ out.writeShort(entry.start_pc); ++ out.writeShort(entry.length); ++ out.writeShort(entry.name_index); ++ out.writeShort(entry.signature_index); ++ out.writeShort(entry.index); ++ } ++ ++ public Void visitModule(Module_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.module_name); ++ return null; ++ } ++ ++ public Void visitModuleExportTable(ModuleExportTable_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.export_type_table.length); ++ for (int i: attr.export_type_table) ++ out.writeShort(i); ++ return null; ++ } ++ ++ public Void visitModuleMemberTable(ModuleMemberTable_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.package_member_table.length); ++ for (int i: attr.package_member_table) ++ out.writeShort(i); ++ return null; ++ } ++ ++ public Void visitRuntimeVisibleAnnotations(RuntimeVisibleAnnotations_attribute attr, ClassOutputStream out) { ++ annotationWriter.write(attr.annotations, out); ++ return null; ++ } ++ ++ public Void visitRuntimeInvisibleAnnotations(RuntimeInvisibleAnnotations_attribute attr, ClassOutputStream out) { ++ annotationWriter.write(attr.annotations, out); ++ return null; ++ } ++ ++ public Void visitRuntimeVisibleParameterAnnotations(RuntimeVisibleParameterAnnotations_attribute attr, ClassOutputStream out) { ++ out.writeByte(attr.parameter_annotations.length); ++ for (Annotation[] annos: attr.parameter_annotations) ++ annotationWriter.write(annos, out); ++ return null; ++ } ++ ++ public Void visitRuntimeInvisibleParameterAnnotations(RuntimeInvisibleParameterAnnotations_attribute attr, ClassOutputStream out) { ++ out.writeByte(attr.parameter_annotations.length); ++ for (Annotation[] annos: attr.parameter_annotations) ++ annotationWriter.write(annos, out); ++ return null; ++ } ++ ++ public Void visitSignature(Signature_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.signature_index); ++ return null; ++ } ++ ++ public Void visitSourceDebugExtension(SourceDebugExtension_attribute attr, ClassOutputStream out) { ++ out.write(attr.debug_extension, 0, attr.debug_extension.length); ++ return null; ++ } ++ ++ public Void visitSourceFile(SourceFile_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.sourcefile_index); ++ return null; ++ } ++ ++ public Void visitSourceID(SourceID_attribute attr, ClassOutputStream out) { ++ out.writeShort(attr.sourceID_index); ++ return null; ++ } ++ ++ public Void visitStackMap(StackMap_attribute attr, ClassOutputStream out) { ++ if (stackMapWriter == null) ++ stackMapWriter = new StackMapTableWriter(); ++ ++ out.writeShort(attr.entries.length); ++ for (stack_map_frame f: attr.entries) ++ stackMapWriter.write(f, out); ++ return null; ++ } ++ ++ public Void visitStackMapTable(StackMapTable_attribute attr, ClassOutputStream out) { ++ if (stackMapWriter == null) ++ stackMapWriter = new StackMapTableWriter(); ++ ++ out.writeShort(attr.entries.length); ++ for (stack_map_frame f: attr.entries) ++ stackMapWriter.write(f, out); ++ return null; ++ } ++ ++ public Void visitSynthetic(Synthetic_attribute attr, ClassOutputStream out) { ++ return null; ++ } ++ ++ protected void writeAccessFlags(AccessFlags flags, ClassOutputStream p) { ++ sharedOut.writeShort(flags.flags); ++ } ++ ++ protected StackMapTableWriter stackMapWriter; ++ } ++ ++ /** ++ * Writer for the frames of StackMap and StackMapTable attributes. ++ */ ++ protected static class StackMapTableWriter ++ implements stack_map_frame.Visitor<Void,ClassOutputStream> { ++ ++ public void write(stack_map_frame frame, ClassOutputStream out) { ++ out.write(frame.frame_type); ++ frame.accept(this, out); ++ } ++ ++ public Void visit_same_frame(same_frame frame, ClassOutputStream p) { ++ return null; ++ } ++ ++ public Void visit_same_locals_1_stack_item_frame(same_locals_1_stack_item_frame frame, ClassOutputStream out) { ++ writeVerificationTypeInfo(frame.stack[0], out); ++ return null; ++ } ++ ++ public Void visit_same_locals_1_stack_item_frame_extended(same_locals_1_stack_item_frame_extended frame, ClassOutputStream out) { ++ out.writeShort(frame.offset_delta); ++ writeVerificationTypeInfo(frame.stack[0], out); ++ return null; ++ } ++ ++ public Void visit_chop_frame(chop_frame frame, ClassOutputStream out) { ++ out.writeShort(frame.offset_delta); ++ return null; ++ } ++ ++ public Void visit_same_frame_extended(same_frame_extended frame, ClassOutputStream out) { ++ out.writeShort(frame.offset_delta); ++ return null; ++ } ++ ++ public Void visit_append_frame(append_frame frame, ClassOutputStream out) { ++ out.writeShort(frame.offset_delta); ++ for (verification_type_info l: frame.locals) ++ writeVerificationTypeInfo(l, out); ++ return null; ++ } ++ ++ public Void visit_full_frame(full_frame frame, ClassOutputStream out) { ++ out.writeShort(frame.offset_delta); ++ out.writeShort(frame.locals.length); ++ for (verification_type_info l: frame.locals) ++ writeVerificationTypeInfo(l, out); ++ out.writeShort(frame.stack.length); ++ for (verification_type_info s: frame.stack) ++ writeVerificationTypeInfo(s, out); ++ return null; ++ } ++ ++ protected void writeVerificationTypeInfo(verification_type_info info, ++ ClassOutputStream out) { ++ out.write(info.tag); ++ switch (info.tag) { ++ case ITEM_Top: ++ case ITEM_Integer: ++ case ITEM_Float: ++ case ITEM_Long: ++ case ITEM_Double: ++ case ITEM_Null: ++ case ITEM_UninitializedThis: ++ break; ++ ++ case ITEM_Object: ++ Object_variable_info o = (Object_variable_info) info; ++ out.writeShort(o.cpool_index); ++ break; ++ ++ case ITEM_Uninitialized: ++ Uninitialized_variable_info u = (Uninitialized_variable_info) info; ++ out.writeShort(u.offset); ++ break; ++ ++ default: ++ throw new Error(); ++ } ++ } ++ } ++ ++ /** ++ * Writer for annotations and the values they contain. ++ */ ++ protected static class AnnotationWriter ++ implements Annotation.element_value.Visitor<Void,ClassOutputStream> { ++ public void write(Annotation[] annos, ClassOutputStream out) { ++ out.writeShort(annos.length); ++ for (Annotation anno: annos) ++ write(anno, out); ++ } ++ ++ public void write(Annotation anno, ClassOutputStream out) { ++ out.writeShort(anno.type_index); ++ out.writeShort(anno.element_value_pairs.length); ++ for (element_value_pair p: anno.element_value_pairs) ++ write(p, out); ++ } ++ ++ public void write(element_value_pair pair, ClassOutputStream out) { ++ out.writeShort(pair.element_name_index); ++ write(pair.value, out); ++ } ++ ++ public void write(element_value ev, ClassOutputStream out) { ++ out.writeByte(ev.tag); ++ ev.accept(this, out); ++ } ++ ++ public Void visitPrimitive(Primitive_element_value ev, ClassOutputStream out) { ++ out.writeShort(ev.const_value_index); ++ return null; ++ } ++ ++ public Void visitEnum(Enum_element_value ev, ClassOutputStream out) { ++ out.writeShort(ev.type_name_index); ++ out.writeShort(ev.const_name_index); ++ return null; ++ } ++ ++ public Void visitClass(Class_element_value ev, ClassOutputStream out) { ++ out.writeShort(ev.class_info_index); ++ return null; ++ } ++ ++ public Void visitAnnotation(Annotation_element_value ev, ClassOutputStream out) { ++ write(ev.annotation_value, out); ++ return null; ++ } ++ ++ public Void visitArray(Array_element_value ev, ClassOutputStream out) { ++ out.writeShort(ev.num_values); ++ for (element_value v: ev.values) ++ write(v, out); ++ return null; ++ } ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Code_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Code_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,123 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.3. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Code_attribute extends Attribute { ++ public class InvalidIndex extends AttributeException { ++ InvalidIndex(int index) { ++ this.index = index; ++ } ++ ++ @Override ++ public String getMessage() { ++ // i18n ++ return "invalid index " + index + " in Code attribute"; ++ } ++ ++ public final int index; ++ } ++ ++ Code_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, ConstantPoolException { ++ super(name_index, length); ++ max_stack = cr.readUnsignedShort(); ++ max_locals = cr.readUnsignedShort(); ++ code_length = cr.readInt(); ++ code = new byte[code_length]; ++ cr.readFully(code); ++ exception_table_langth = cr.readUnsignedShort(); ++ exception_table = new Exception_data[exception_table_langth]; ++ for (int i = 0; i < exception_table_langth; i++) ++ exception_table[i] = new Exception_data(cr); ++ attributes = new Attributes(cr); ++ } ++ ++ public int getByte(int offset) throws InvalidIndex { ++ if (offset < 0 || offset >= code.length) ++ throw new InvalidIndex(offset); ++ return code[offset]; ++ } ++ ++ public int getUnsignedByte(int offset) throws InvalidIndex { ++ if (offset < 0 || offset >= code.length) ++ throw new InvalidIndex(offset); ++ return code[offset] & 0xff; ++ } ++ ++ public int getShort(int offset) throws InvalidIndex { ++ if (offset < 0 || offset + 1 >= code.length) ++ throw new InvalidIndex(offset); ++ return (code[offset] << 8) | (code[offset + 1] & 0xFF); ++ } ++ ++ public int getUnsignedShort(int offset) throws InvalidIndex { ++ if (offset < 0 || offset + 1 >= code.length) ++ throw new InvalidIndex(offset); ++ return ((code[offset] << 8) | (code[offset + 1] & 0xFF)) & 0xFFFF; ++ } ++ ++ public int getInt(int offset) throws InvalidIndex { ++ if (offset < 0 || offset + 3 >= code.length) ++ throw new InvalidIndex(offset); ++ return (getShort(offset) << 16) | (getShort(offset + 2) & 0xFFFF); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitCode(this, data); ++ } ++ ++ public final int max_stack; ++ public final int max_locals; ++ public final int code_length; ++ public final byte[] code; ++ public final int exception_table_langth; ++ public final Exception_data[] exception_table; ++ public final Attributes attributes; ++ ++ public class Exception_data { ++ Exception_data(ClassReader cr) throws IOException { ++ start_pc = cr.readUnsignedShort(); ++ end_pc = cr.readUnsignedShort(); ++ handler_pc = cr.readUnsignedShort(); ++ catch_type = cr.readUnsignedShort(); ++ } ++ ++ public final int start_pc; ++ public final int end_pc; ++ public final int handler_pc; ++ public final int catch_type; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/CompilationID_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/CompilationID_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,62 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class CompilationID_attribute extends Attribute { ++ ++ CompilationID_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ compilationID_index = cr.readUnsignedShort(); ++ } ++ ++ public CompilationID_attribute(ConstantPool constant_pool, int compilationID_index) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.CompilationID), compilationID_index); ++ } ++ ++ public CompilationID_attribute(int name_index, int compilationID_index) { ++ super(name_index, 2); ++ this.compilationID_index = compilationID_index; ++ } ++ ++ String getCompilationID(ConstantPool constant_pool) ++ throws ConstantPoolException { ++ return constant_pool.getUTF8Value(compilationID_index); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitCompilationID(this, data); ++ } ++ ++ public final int compilationID_index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ConstantPool.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,562 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.5. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ConstantPool { ++ ++ public class InvalidIndex extends ConstantPoolException { ++ InvalidIndex(int index) { ++ super(index); ++ } ++ ++ @Override ++ public String getMessage() { ++ // i18n ++ return "invalid index #" + index; ++ } ++ } ++ ++ public class UnexpectedEntry extends ConstantPoolException { ++ UnexpectedEntry(int index, int expected_tag, int found_tag) { ++ super(index); ++ this.expected_tag = expected_tag; ++ this.found_tag = found_tag; ++ } ++ ++ @Override ++ public String getMessage() { ++ // i18n? ++ return "unexpected entry at #" + index + " -- expected tag " + expected_tag + ", found " + found_tag; ++ } ++ ++ public final int expected_tag; ++ public final int found_tag; ++ } ++ ++ public class InvalidEntry extends ConstantPoolException { ++ InvalidEntry(int index, int tag) { ++ super(index); ++ this.tag = tag; ++ } ++ ++ @Override ++ public String getMessage() { ++ // i18n? ++ return "unexpected tag at #" + index + ": " + tag; ++ } ++ ++ public final int tag; ++ } ++ ++ public class EntryNotFound extends ConstantPoolException { ++ EntryNotFound(Object value) { ++ super(-1); ++ this.value = value; ++ } ++ ++ @Override ++ public String getMessage() { ++ // i18n? ++ return "value not found: " + value; ++ } ++ ++ public final Object value; ++ } ++ ++ public static final int CONSTANT_Utf8 = 1; ++ public static final int CONSTANT_Integer = 3; ++ public static final int CONSTANT_Float = 4; ++ public static final int CONSTANT_Long = 5; ++ public static final int CONSTANT_Double = 6; ++ public static final int CONSTANT_Class = 7; ++ public static final int CONSTANT_String = 8; ++ public static final int CONSTANT_Fieldref = 9; ++ public static final int CONSTANT_Methodref = 10; ++ public static final int CONSTANT_InterfaceMethodref = 11; ++ public static final int CONSTANT_NameAndType = 12; ++ ++ ConstantPool(ClassReader cr) throws IOException, InvalidEntry { ++ int count = cr.readUnsignedShort(); ++ pool = new CPInfo[count]; ++ for (int i = 1; i < count; i++) { ++ int tag = cr.readUnsignedByte(); ++ switch (tag) { ++ case CONSTANT_Class: ++ pool[i] = new CONSTANT_Class_info(this, cr); ++ break; ++ ++ case CONSTANT_Double: ++ pool[i] = new CONSTANT_Double_info(cr); ++ i++; ++ break; ++ ++ case CONSTANT_Fieldref: ++ pool[i] = new CONSTANT_Fieldref_info(this, cr); ++ break; ++ ++ case CONSTANT_Float: ++ pool[i] = new CONSTANT_Float_info(cr); ++ break; ++ ++ case CONSTANT_Integer: ++ pool[i] = new CONSTANT_Integer_info(cr); ++ break; ++ ++ case CONSTANT_InterfaceMethodref: ++ pool[i] = new CONSTANT_InterfaceMethodref_info(this, cr); ++ break; ++ ++ case CONSTANT_Long: ++ pool[i] = new CONSTANT_Long_info(cr); ++ i++; ++ break; ++ ++ case CONSTANT_Methodref: ++ pool[i] = new CONSTANT_Methodref_info(this, cr); ++ break; ++ ++ case CONSTANT_NameAndType: ++ pool[i] = new CONSTANT_NameAndType_info(this, cr); ++ break; ++ ++ case CONSTANT_String: ++ pool[i] = new CONSTANT_String_info(cr); ++ break; ++ ++ case CONSTANT_Utf8: ++ pool[i] = new CONSTANT_Utf8_info(cr); ++ break; ++ ++ default: ++ throw new InvalidEntry(i, tag); ++ } ++ } ++ } ++ ++ public ConstantPool(CPInfo[] pool) { ++ this.pool = pool; ++ } ++ ++ public int size() { ++ return pool.length; ++ } ++ ++ public CPInfo get(int index) throws InvalidIndex { ++ if (index <= 0 || index >= pool.length) ++ throw new InvalidIndex(index); ++ CPInfo info = pool[index]; ++ if (info == null) { ++ // this occurs for indices referencing the "second half" of an ++ // 8 byte constant, such as CONSTANT_Double or CONSTANT_Long ++ throw new InvalidIndex(index); ++ } ++ return pool[index]; ++ } ++ ++ private CPInfo get(int index, int expected_type) throws InvalidIndex, UnexpectedEntry { ++ CPInfo info = get(index); ++ if (info.getTag() != expected_type) ++ throw new UnexpectedEntry(index, expected_type, info.getTag()); ++ return info; ++ } ++ ++ public CONSTANT_Utf8_info getUTF8Info(int index) throws InvalidIndex, UnexpectedEntry { ++ return ((CONSTANT_Utf8_info) get(index, CONSTANT_Utf8)); ++ } ++ ++ public CONSTANT_Class_info getClassInfo(int index) throws InvalidIndex, UnexpectedEntry { ++ return ((CONSTANT_Class_info) get(index, CONSTANT_Class)); ++ } ++ ++ public CONSTANT_NameAndType_info getNameAndTypeInfo(int index) throws InvalidIndex, UnexpectedEntry { ++ return ((CONSTANT_NameAndType_info) get(index, CONSTANT_NameAndType)); ++ } ++ ++ public String getUTF8Value(int index) throws InvalidIndex, UnexpectedEntry { ++ return getUTF8Info(index).value; ++ } ++ ++ public int getUTF8Index(String value) throws EntryNotFound { ++ for (int i = 1; i < pool.length; i++) { ++ CPInfo info = pool[i]; ++ if (info instanceof CONSTANT_Utf8_info && ++ ((CONSTANT_Utf8_info) info).value.equals(value)) ++ return i; ++ } ++ throw new EntryNotFound(value); ++ } ++ ++ private CPInfo[] pool; ++ ++ public interface Visitor<R,P> { ++ R visitClass(CONSTANT_Class_info info, P p); ++ R visitDouble(CONSTANT_Double_info info, P p); ++ R visitFieldref(CONSTANT_Fieldref_info info, P p); ++ R visitFloat(CONSTANT_Float_info info, P p); ++ R visitInteger(CONSTANT_Integer_info info, P p); ++ R visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, P p); ++ R visitLong(CONSTANT_Long_info info, P p); ++ R visitNameAndType(CONSTANT_NameAndType_info info, P p); ++ R visitMethodref(CONSTANT_Methodref_info info, P p); ++ R visitString(CONSTANT_String_info info, P p); ++ R visitUtf8(CONSTANT_Utf8_info info, P p); ++ } ++ ++ public static abstract class CPInfo { ++ CPInfo() { ++ this.cp = null; ++ } ++ ++ CPInfo(ConstantPool cp) { ++ this.cp = cp; ++ } ++ ++ public abstract int getTag(); ++ ++ public abstract <R,D> R accept(Visitor<R,D> visitor, D data); ++ ++ protected final ConstantPool cp; ++ } ++ ++ public static abstract class CPRefInfo extends CPInfo { ++ protected CPRefInfo(ConstantPool cp, ClassReader cr, int tag) throws IOException { ++ super(cp); ++ this.tag = tag; ++ class_index = cr.readUnsignedShort(); ++ name_and_type_index = cr.readUnsignedShort(); ++ } ++ ++ protected CPRefInfo(ConstantPool cp, int tag, int class_index, int name_and_type_index) { ++ super(cp); ++ this.tag = tag; ++ this.class_index = class_index; ++ this.name_and_type_index = name_and_type_index; ++ } ++ ++ public int getTag() { ++ return tag; ++ } ++ ++ public CONSTANT_Class_info getClassInfo() throws ConstantPoolException { ++ return cp.getClassInfo(class_index); ++ } ++ ++ public String getClassName() throws ConstantPoolException { ++ return cp.getClassInfo(class_index).getName(); ++ } ++ ++ public CONSTANT_NameAndType_info getNameAndTypeInfo() throws ConstantPoolException { ++ return cp.getNameAndTypeInfo(name_and_type_index); ++ } ++ ++ public final int tag; ++ public final int class_index; ++ public final int name_and_type_index; ++ } ++ ++ public static class CONSTANT_Class_info extends CPInfo { ++ CONSTANT_Class_info(ConstantPool cp, ClassReader cr) throws IOException { ++ super(cp); ++ name_index = cr.readUnsignedShort(); ++ } ++ ++ public CONSTANT_Class_info(ConstantPool cp, int name_index) { ++ super(cp); ++ this.name_index = name_index; ++ } ++ ++ public int getTag() { ++ return CONSTANT_Class; ++ } ++ ++ public String getName() throws ConstantPoolException { ++ return cp.getUTF8Value(name_index); ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Class_info[name_index: " + name_index + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitClass(this, data); ++ } ++ ++ public final int name_index; ++ } ++ ++ public static class CONSTANT_Double_info extends CPInfo { ++ CONSTANT_Double_info(ClassReader cr) throws IOException { ++ value = cr.readDouble(); ++ } ++ ++ public CONSTANT_Double_info(double value) { ++ this.value = value; ++ } ++ ++ public int getTag() { ++ return CONSTANT_Double; ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Double_info[value: " + value + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitDouble(this, data); ++ } ++ ++ public final double value; ++ } ++ ++ public static class CONSTANT_Fieldref_info extends CPRefInfo { ++ CONSTANT_Fieldref_info(ConstantPool cp, ClassReader cr) throws IOException { ++ super(cp, cr, CONSTANT_Fieldref); ++ } ++ ++ public CONSTANT_Fieldref_info(ConstantPool cp, int class_index, int name_and_type_index) { ++ super(cp, CONSTANT_Fieldref, class_index, name_and_type_index); ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Fieldref_info[class_index: " + class_index + ", name_and_type_index: " + name_and_type_index + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitFieldref(this, data); ++ } ++ } ++ ++ public static class CONSTANT_Float_info extends CPInfo { ++ CONSTANT_Float_info(ClassReader cr) throws IOException { ++ value = cr.readFloat(); ++ } ++ ++ public CONSTANT_Float_info(float value) { ++ this.value = value; ++ } ++ ++ public int getTag() { ++ return CONSTANT_Float; ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Float_info[value: " + value + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitFloat(this, data); ++ } ++ ++ public final float value; ++ } ++ ++ public static class CONSTANT_Integer_info extends CPInfo { ++ CONSTANT_Integer_info(ClassReader cr) throws IOException { ++ value = cr.readInt(); ++ } ++ ++ public CONSTANT_Integer_info(int value) { ++ this.value = value; ++ } ++ ++ public int getTag() { ++ return CONSTANT_Integer; ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Integer_info[value: " + value + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitInteger(this, data); ++ } ++ ++ public final int value; ++ } ++ ++ public static class CONSTANT_InterfaceMethodref_info extends CPRefInfo { ++ CONSTANT_InterfaceMethodref_info(ConstantPool cp, ClassReader cr) throws IOException { ++ super(cp, cr, CONSTANT_InterfaceMethodref); ++ } ++ ++ public CONSTANT_InterfaceMethodref_info(ConstantPool cp, int class_index, int name_and_type_index) { ++ super(cp, CONSTANT_InterfaceMethodref, class_index, name_and_type_index); ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_InterfaceMethodref_info[class_index: " + class_index + ", name_and_type_index: " + name_and_type_index + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitInterfaceMethodref(this, data); ++ } ++ } ++ ++ public static class CONSTANT_Long_info extends CPInfo { ++ CONSTANT_Long_info(ClassReader cr) throws IOException { ++ value = cr.readLong(); ++ } ++ ++ public CONSTANT_Long_info(long value) { ++ this.value = value; ++ } ++ ++ public int getTag() { ++ return CONSTANT_Long; ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Long_info[value: " + value + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitLong(this, data); ++ } ++ ++ public final long value; ++ } ++ ++ public static class CONSTANT_Methodref_info extends CPRefInfo { ++ CONSTANT_Methodref_info(ConstantPool cp, ClassReader cr) throws IOException { ++ super(cp, cr, CONSTANT_Methodref); ++ } ++ ++ public CONSTANT_Methodref_info(ConstantPool cp, int class_index, int name_and_type_index) { ++ super(cp, CONSTANT_Methodref, class_index, name_and_type_index); ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Methodref_info[class_index: " + class_index + ", name_and_type_index: " + name_and_type_index + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitMethodref(this, data); ++ } ++ } ++ ++ public static class CONSTANT_NameAndType_info extends CPInfo { ++ CONSTANT_NameAndType_info(ConstantPool cp, ClassReader cr) throws IOException { ++ super(cp); ++ name_index = cr.readUnsignedShort(); ++ type_index = cr.readUnsignedShort(); ++ } ++ ++ public CONSTANT_NameAndType_info(ConstantPool cp, int name_index, int type_index) { ++ super(cp); ++ this.name_index = name_index; ++ this.type_index = type_index; ++ } ++ ++ public int getTag() { ++ return CONSTANT_NameAndType; ++ } ++ ++ public String getName() throws ConstantPoolException { ++ return cp.getUTF8Value(name_index); ++ } ++ ++ public String getType() throws ConstantPoolException { ++ return cp.getUTF8Value(type_index); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitNameAndType(this, data); ++ } ++ ++ public final int name_index; ++ public final int type_index; ++ } ++ ++ public static class CONSTANT_String_info extends CPInfo { ++ CONSTANT_String_info(ClassReader cr) throws IOException { ++ string_index = cr.readUnsignedShort(); ++ } ++ ++ public CONSTANT_String_info(ConstantPool cp, int string_index) { ++ super(cp); ++ this.string_index = string_index; ++ } ++ ++ public int getTag() { ++ return CONSTANT_String; ++ } ++ ++ public String getString() throws ConstantPoolException { ++ return cp.getUTF8Value(string_index); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitString(this, data); ++ } ++ ++ public final int string_index; ++ } ++ ++ public static class CONSTANT_Utf8_info extends CPInfo { ++ CONSTANT_Utf8_info(ClassReader cr) throws IOException { ++ value = cr.readUTF(); ++ } ++ ++ public CONSTANT_Utf8_info(String value) { ++ this.value = value; ++ } ++ ++ public int getTag() { ++ return CONSTANT_Utf8; ++ } ++ ++ @Override ++ public String toString() { ++ return "CONSTANT_Utf8_info[value: " + value + "]"; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitUtf8(this, data); ++ } ++ ++ public final String value; ++ } ++ ++ ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ConstantPoolException.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantPoolException.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,41 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ConstantPoolException extends Exception { ++ ConstantPoolException(int index) { ++ this.index = index; ++ } ++ ++ public final int index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ConstantValue_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantValue_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,59 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.2. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ConstantValue_attribute extends Attribute { ++ ConstantValue_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ constantvalue_index = cr.readUnsignedShort(); ++ } ++ ++ public ConstantValue_attribute(ConstantPool constant_pool, int constantvalue_index) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.ConstantValue), constantvalue_index); ++ } ++ ++ public ConstantValue_attribute(int name_index, int constantvalue_index) { ++ super(name_index, 2); ++ this.constantvalue_index = constantvalue_index; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitConstantValue(this, data); ++ } ++ ++ public final int constantvalue_index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/DefaultAttribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/DefaultAttribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,50 @@ ++/* ++ * 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.tools.classfile; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class DefaultAttribute extends Attribute { ++ DefaultAttribute(ClassReader cr, int name_index, byte[] data) { ++ super(name_index, data.length); ++ info = data; ++ } ++ ++ public DefaultAttribute(ConstantPool constant_pool, int name_index, byte[] info) { ++ super(name_index, info.length); ++ this.info = info; ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitDefault(this, p); ++ } ++ ++ public final byte[] info; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Deprecated_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Deprecated_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,55 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.15. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Deprecated_attribute extends Attribute { ++ Deprecated_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ } ++ ++ public Deprecated_attribute(ConstantPool constant_pool) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.Deprecated)); ++ } ++ ++ public Deprecated_attribute(int name_index) { ++ super(name_index, 0); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitDeprecated(this, data); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Descriptor.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Descriptor.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,198 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.4. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Descriptor { ++ public class InvalidDescriptor extends DescriptorException { ++ InvalidDescriptor(String desc) { ++ this.desc = desc; ++ this.index = -1; ++ } ++ ++ InvalidDescriptor(String desc, int index) { ++ this.desc = desc; ++ this.index = index; ++ } ++ ++ @Override ++ public String getMessage() { ++ // i18n ++ if (index == -1) ++ return "invalid descriptor \"" + desc + "\""; ++ else ++ return "descriptor is invalid at offset " + index + " in \"" + desc + "\""; ++ } ++ ++ public final String desc; ++ public final int index; ++ ++ } ++ ++ public Descriptor(ClassReader cr) throws IOException { ++ this(cr.readUnsignedShort()); ++ } ++ ++ public Descriptor(int index) { ++ this.index = index; ++ ++ } ++ ++ public String getValue(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(index); ++ } ++ ++ public int getParameterCount(ConstantPool constant_pool) ++ throws ConstantPoolException, InvalidDescriptor { ++ String desc = getValue(constant_pool); ++ int end = desc.indexOf(")"); ++ if (end == -1) ++ throw new InvalidDescriptor(desc); ++ parse(desc, 0, end + 1); ++ return count; ++ ++ } ++ ++ public String getParameterTypes(ConstantPool constant_pool) ++ throws ConstantPoolException, InvalidDescriptor { ++ String desc = getValue(constant_pool); ++ int end = desc.indexOf(")"); ++ if (end == -1) ++ throw new InvalidDescriptor(desc); ++ return parse(desc, 0, end + 1); ++ } ++ ++ public String getReturnType(ConstantPool constant_pool) ++ throws ConstantPoolException, InvalidDescriptor { ++ String desc = getValue(constant_pool); ++ int end = desc.indexOf(")"); ++ if (end == -1) ++ throw new InvalidDescriptor(desc); ++ return parse(desc, end + 1, desc.length()); ++ } ++ ++ public String getFieldType(ConstantPool constant_pool) ++ throws ConstantPoolException, InvalidDescriptor { ++ String desc = getValue(constant_pool); ++ return parse(desc, 0, desc.length()); ++ } ++ ++ private String parse(String desc, int start, int end) ++ throws InvalidDescriptor { ++ int p = start; ++ StringBuffer sb = new StringBuffer(); ++ int dims = 0; ++ count = 0; ++ ++ while (p < end) { ++ String type; ++ char ch; ++ switch (ch = desc.charAt(p++)) { ++ case '(': ++ sb.append('('); ++ continue; ++ ++ case ')': ++ sb.append(')'); ++ continue; ++ ++ case '[': ++ dims++; ++ continue; ++ ++ case 'B': ++ type = "byte"; ++ break; ++ ++ case 'C': ++ type = "char"; ++ break; ++ ++ case 'D': ++ type = "double"; ++ break; ++ ++ case 'F': ++ type = "float"; ++ break; ++ ++ case 'I': ++ type = "int"; ++ break; ++ ++ case 'J': ++ type = "long"; ++ break; ++ ++ case 'L': ++ int sep = desc.indexOf(';', p); ++ if (sep == -1) ++ throw new InvalidDescriptor(desc, p - 1); ++ type = desc.substring(p, sep).replace('/', '.'); ++ p = sep + 1; ++ break; ++ ++ case 'S': ++ type = "short"; ++ break; ++ ++ case 'Z': ++ type = "boolean"; ++ break; ++ ++ case 'V': ++ type = "void"; ++ break; ++ ++ default: ++ throw new InvalidDescriptor(desc, p - 1); ++ } ++ ++ if (sb.length() > 1 && sb.charAt(0) == '(') ++ sb.append(", "); ++ sb.append(type); ++ for ( ; dims > 0; dims-- ) ++ sb.append("[]"); ++ ++ count++; ++ } ++ ++ return sb.toString(); ++ } ++ ++ public final int index; ++ private int count; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/DescriptorException.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/DescriptorException.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,36 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class DescriptorException extends Exception { ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/EnclosingMethod_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/EnclosingMethod_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,73 @@ ++ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.7. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class EnclosingMethod_attribute extends Attribute { ++ EnclosingMethod_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ class_index = cr.readUnsignedShort(); ++ method_index = cr.readUnsignedShort(); ++ } ++ ++ public EnclosingMethod_attribute(ConstantPool constant_pool, int class_index, int method_index) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.EnclosingMethod), class_index, method_index); ++ } ++ ++ public EnclosingMethod_attribute(int name_index, int class_index, int method_index) { ++ super(name_index, 4); ++ this.class_index = class_index; ++ this.method_index = method_index; ++ } ++ ++ public String getClassName(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getClassInfo(class_index).getName(); ++ } ++ ++ public String getMethodName(ConstantPool constant_pool) throws ConstantPoolException { ++ if (method_index == 0) ++ return ""; ++ return constant_pool.getNameAndTypeInfo(method_index).getName(); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitEnclosingMethod(this, data); ++ } ++ ++ public final int class_index; ++ public final int method_index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Exceptions_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Exceptions_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,69 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.5. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Exceptions_attribute extends Attribute { ++ Exceptions_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ number_of_exceptions = cr.readUnsignedShort(); ++ exception_index_table = new int[number_of_exceptions]; ++ for (int i = 0; i < number_of_exceptions; i++) ++ exception_index_table[i] = cr.readUnsignedShort(); ++ } ++ ++ public Exceptions_attribute(ConstantPool constant_pool, int[] exception_index_table) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.Exceptions), exception_index_table); ++ } ++ ++ public Exceptions_attribute(int name_index, int[] exception_index_table) { ++ super(name_index, 2 + 2 * exception_index_table.length); ++ this.number_of_exceptions = exception_index_table.length; ++ this.exception_index_table = exception_index_table; ++ } ++ ++ public String getException(int index, ConstantPool constant_pool) throws ConstantPoolException { ++ int exception_index = exception_index_table[index]; ++ return constant_pool.getClassInfo(exception_index).getName(); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitExceptions(this, data); ++ } ++ ++ public final int number_of_exceptions; ++ public final int[] exception_index_table; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Field.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Field.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,61 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Field { ++ Field(ClassReader cr) throws IOException { ++ access_flags = new AccessFlags(cr); ++ name_index = cr.readUnsignedShort(); ++ descriptor = new Descriptor(cr); ++ attributes = new Attributes(cr); ++ } ++ ++ public Field(AccessFlags access_flags, ++ int name_index, Descriptor descriptor, ++ Attributes attributes) { ++ this.access_flags = access_flags; ++ this.name_index = name_index; ++ this.descriptor = descriptor; ++ this.attributes = attributes; ++ } ++ ++ public String getName(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(name_index); ++ } ++ ++ public final AccessFlags access_flags; ++ public final int name_index; ++ public final Descriptor descriptor; ++ public final Attributes attributes; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/InnerClasses_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/InnerClasses_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,102 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++import com.sun.tools.classfile.ConstantPool.*; ++ ++/** ++ * See JVMS3, section 4.8.6. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class InnerClasses_attribute extends Attribute { ++ InnerClasses_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ number_of_classes = cr.readUnsignedShort(); ++ classes = new Info[number_of_classes]; ++ for (int i = 0; i < number_of_classes; i++) ++ classes[i] = new Info(cr); ++ } ++ ++ public InnerClasses_attribute(ConstantPool constant_pool, Info[] classes) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.InnerClasses), classes); ++ } ++ ++ public InnerClasses_attribute(int name_index, Info[] classes) { ++ super(name_index, 2 + Info.length() * classes.length); ++ this.number_of_classes = classes.length; ++ this.classes = classes; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitInnerClasses(this, data); ++ } ++ ++ public final int number_of_classes; ++ public final Info[] classes; ++ ++ public static class Info { ++ Info(ClassReader cr) throws IOException { ++ inner_class_info_index = cr.readUnsignedShort(); ++ outer_class_info_index = cr.readUnsignedShort(); ++ inner_name_index = cr.readUnsignedShort(); ++ inner_class_access_flags = new AccessFlags(cr.readUnsignedShort()); ++ } ++ ++ public CONSTANT_Class_info getInnerClassInfo(ConstantPool constant_pool) throws ConstantPoolException { ++ if (inner_class_info_index == 0) ++ return null; ++ return constant_pool.getClassInfo(inner_class_info_index); ++ } ++ ++ public CONSTANT_Class_info getOuterClassInfo(ConstantPool constant_pool) throws ConstantPoolException { ++ if (outer_class_info_index == 0) ++ return null; ++ return constant_pool.getClassInfo(outer_class_info_index); ++ } ++ ++ public String getInnerName(ConstantPool constant_pool) throws ConstantPoolException { ++ if (inner_name_index == 0) ++ return null; ++ return constant_pool.getUTF8Value(inner_name_index); ++ } ++ ++ public static int length() { ++ return 8; ++ } ++ ++ public final int inner_class_info_index; ++ public final int outer_class_info_index; ++ public final int inner_name_index; ++ public final AccessFlags inner_class_access_flags; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/LineNumberTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/LineNumberTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,78 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.12. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class LineNumberTable_attribute extends Attribute { ++ LineNumberTable_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ line_number_table_length = cr.readUnsignedShort(); ++ line_number_table = new Entry[line_number_table_length]; ++ for (int i = 0; i < line_number_table_length; i++) ++ line_number_table[i] = new Entry(cr); ++ } ++ ++ public LineNumberTable_attribute(ConstantPool constant_pool, Entry[] line_number_table) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.LineNumberTable), line_number_table); ++ } ++ ++ public LineNumberTable_attribute(int name_index, Entry[] line_number_table) { ++ super(name_index, line_number_table.length * Entry.length()); ++ this.line_number_table_length = line_number_table.length; ++ this.line_number_table = line_number_table; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitLineNumberTable(this, data); ++ } ++ ++ public final int line_number_table_length; ++ public final Entry[] line_number_table; ++ ++ public static class Entry { ++ Entry(ClassReader cr) throws IOException { ++ start_pc = cr.readUnsignedShort(); ++ line_number = cr.readUnsignedShort(); ++ } ++ ++ public static int length() { ++ return 4; ++ } ++ ++ public final int start_pc; ++ public final int line_number; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/LocalVariableTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/LocalVariableTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,84 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.13. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class LocalVariableTable_attribute extends Attribute { ++ LocalVariableTable_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ local_variable_table_length = cr.readUnsignedShort(); ++ local_variable_table = new Entry[local_variable_table_length]; ++ for (int i = 0; i < local_variable_table_length; i++) ++ local_variable_table[i] = new Entry(cr); ++ } ++ ++ public LocalVariableTable_attribute(ConstantPool constant_pool, Entry[] local_variable_table) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.LocalVariableTable), local_variable_table); ++ } ++ ++ public LocalVariableTable_attribute(int name_index, Entry[] local_variable_table) { ++ super(name_index, local_variable_table.length * Entry.length()); ++ this.local_variable_table_length = local_variable_table.length; ++ this.local_variable_table = local_variable_table; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitLocalVariableTable(this, data); ++ } ++ ++ public final int local_variable_table_length; ++ public final Entry[] local_variable_table; ++ ++ public static class Entry { ++ Entry(ClassReader cr) throws IOException { ++ start_pc = cr.readUnsignedShort(); ++ length = cr.readUnsignedShort(); ++ name_index = cr.readUnsignedShort(); ++ descriptor_index = cr.readUnsignedShort(); ++ index = cr.readUnsignedShort(); ++ } ++ ++ public static int length() { ++ return 10; ++ } ++ ++ public final int start_pc; ++ public final int length; ++ public final int name_index; ++ public final int descriptor_index; ++ public final int index; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/LocalVariableTypeTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/LocalVariableTypeTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,84 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.14. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class LocalVariableTypeTable_attribute extends Attribute { ++ LocalVariableTypeTable_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ local_variable_table_length = cr.readUnsignedShort(); ++ local_variable_table = new Entry[local_variable_table_length]; ++ for (int i = 0; i < local_variable_table_length; i++) ++ local_variable_table[i] = new Entry(cr); ++ } ++ ++ public LocalVariableTypeTable_attribute(ConstantPool constant_pool, Entry[] local_variable_table) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.LocalVariableTypeTable), local_variable_table); ++ } ++ ++ public LocalVariableTypeTable_attribute(int name_index, Entry[] local_variable_table) { ++ super(name_index, local_variable_table.length * Entry.length()); ++ this.local_variable_table_length = local_variable_table.length; ++ this.local_variable_table = local_variable_table; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitLocalVariableTypeTable(this, data); ++ } ++ ++ public final int local_variable_table_length; ++ public final Entry[] local_variable_table; ++ ++ public static class Entry { ++ Entry(ClassReader cr) throws IOException { ++ start_pc = cr.readUnsignedShort(); ++ length = cr.readUnsignedShort(); ++ name_index = cr.readUnsignedShort(); ++ signature_index = cr.readUnsignedShort(); ++ index = cr.readUnsignedShort(); ++ } ++ ++ public static int length() { ++ return 10; ++ } ++ ++ public final int start_pc; ++ public final int length; ++ public final int name_index; ++ public final int signature_index; ++ public final int index; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Method.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Method.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,61 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Method { ++ Method(ClassReader cr) throws IOException { ++ access_flags = new AccessFlags(cr); ++ name_index = cr.readUnsignedShort(); ++ descriptor = new Descriptor(cr); ++ attributes = new Attributes(cr); ++ } ++ ++ public Method(AccessFlags access_flags, ++ int name_index, Descriptor descriptor, ++ Attributes attributes) { ++ this.access_flags = access_flags; ++ this.name_index = name_index; ++ this.descriptor = descriptor; ++ this.attributes = attributes; ++ } ++ ++ public String getName(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(name_index); ++ } ++ ++ public final AccessFlags access_flags; ++ public final int name_index; ++ public final Descriptor descriptor; ++ public final Attributes attributes; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ModuleExportTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ModuleExportTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,70 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JSR 277. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ModuleExportTable_attribute extends Attribute { ++ ModuleExportTable_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ int export_type_length = cr.readUnsignedShort(); ++ export_type_table = new int[export_type_length]; ++ for (int i = 0; i < export_type_table.length; i++) ++ export_type_table[i] = cr.readUnsignedShort(); ++ } ++ ++ public ModuleExportTable_attribute(ConstantPool cp, int[] export_type_table) ++ throws ConstantPoolException { ++ this(cp.getUTF8Index(Attribute.ModuleExportTable), export_type_table); ++ } ++ ++ public ModuleExportTable_attribute(int name_index, int[] export_type_table) { ++ super(name_index, 2 * export_type_table.length); ++ this.export_type_table = export_type_table; ++ } ++ ++ public int getExportTypeCount() { ++ return export_type_table.length; ++ } ++ ++ public String getExportTypeName(int index, ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(export_type_table[index]); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitModuleExportTable(this, p); ++ } ++ ++ public final int[] export_type_table; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/ModuleMemberTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/ModuleMemberTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,69 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JSR 277. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ModuleMemberTable_attribute extends Attribute { ++ ModuleMemberTable_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ int package_member_length = cr.readUnsignedShort(); ++ package_member_table = new int[package_member_length]; ++ for (int i = 0; i < package_member_table.length; i++) ++ package_member_table[i] = cr.readUnsignedShort(); ++ } ++ ++ public ModuleMemberTable_attribute(ConstantPool cp, int[] package_member_table) ++ throws ConstantPoolException { ++ this(cp.getUTF8Index(Attribute.ModuleMemberTable), package_member_table); ++ } ++ ++ public ModuleMemberTable_attribute(int name_index, int[] package_member_table) { ++ super(name_index, 2 * package_member_table.length); ++ this.package_member_table = package_member_table; ++ } ++ ++ public int getPackageMemberCount() { ++ return package_member_table.length; ++ } ++ ++ public String getPackageMemberName(int index, ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(package_member_table[index]); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitModuleMemberTable(this, p); ++ } ++ ++ public final int[] package_member_table; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Module_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Module_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,64 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JSR 277. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Module_attribute extends Attribute { ++ Module_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ module_name = cr.readUnsignedShort(); ++ } ++ ++ public Module_attribute(ConstantPool constant_pool, int module_name) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.Module), module_name); ++ } ++ ++ public Module_attribute(int name_index, int module_name) { ++ super(name_index, 2); ++ this.module_name = module_name; ++ } ++ ++ public String getModuleName(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(module_name); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitModule(this, data); ++ } ++ ++ public final int module_name; ++ ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/OpCodes.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/OpCodes.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,868 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.util.HashMap; ++ ++/** ++ * See JVMS3, section 6. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class OpCodes { ++ ++ public static int opcLength(int opc) throws IllegalArgumentException { ++ switch (opc >> 8) { ++ case 0: ++ return opcLengthsTab[opc]; ++ case opc_wide: ++ switch (opc & 0xFF) { ++ case opc_aload: ++ case opc_astore: ++ case opc_fload: ++ case opc_fstore: ++ case opc_iload: ++ case opc_istore: ++ case opc_lload: ++ case opc_lstore: ++ case opc_dload: ++ case opc_dstore: ++ case opc_ret: ++ return 4; ++ case opc_iinc: ++ return 6; ++ default: ++ throw new IllegalArgumentException(); ++ } ++ case opc_nonpriv: ++ case opc_priv: ++ return 2; ++ default: ++ throw new IllegalArgumentException(); ++ } ++ } ++ ++ public static String opcName(int opc) { ++ try { ++ switch (opc >> 8) { ++ case 0: ++ return opcNamesTab[opc]; ++ case opc_wide: ++ { ++ String mnem = opcNamesTab[opc & 0xFF] + "_w"; ++ if (mnemocodes.get(mnem) == null) { ++ return null; // non-existent opcode ++ } ++ return mnem; ++ } ++ case opc_nonpriv: ++ return opcExtNamesTab[opc & 0xFF]; ++ case opc_priv: ++ return opcPrivExtNamesTab[opc & 0xFF]; ++ default: ++ return null; ++ } ++ } catch (ArrayIndexOutOfBoundsException e) { ++ switch (opc) { ++ case opc_nonpriv: ++ return "nonpriv"; ++ case opc_priv: ++ return "priv"; ++ default: ++ return null; ++ } ++ } ++ } ++ ++ /* Opcodes */ ++ public static final int opc_dead = -2; ++ public static final int opc_label = -1; ++ public static final int opc_nop = 0; ++ public static final int opc_aconst_null = 1; ++ public static final int opc_iconst_m1 = 2; ++ public static final int opc_iconst_0 = 3; ++ public static final int opc_iconst_1 = 4; ++ public static final int opc_iconst_2 = 5; ++ public static final int opc_iconst_3 = 6; ++ public static final int opc_iconst_4 = 7; ++ public static final int opc_iconst_5 = 8; ++ public static final int opc_lconst_0 = 9; ++ public static final int opc_lconst_1 = 10; ++ public static final int opc_fconst_0 = 11; ++ public static final int opc_fconst_1 = 12; ++ public static final int opc_fconst_2 = 13; ++ public static final int opc_dconst_0 = 14; ++ public static final int opc_dconst_1 = 15; ++ public static final int opc_bipush = 16; ++ public static final int opc_sipush = 17; ++ public static final int opc_ldc = 18; ++ public static final int opc_ldc_w = 19; ++ public static final int opc_ldc2_w = 20; ++ public static final int opc_iload = 21; ++ public static final int opc_lload = 22; ++ public static final int opc_fload = 23; ++ public static final int opc_dload = 24; ++ public static final int opc_aload = 25; ++ public static final int opc_iload_0 = 26; ++ public static final int opc_iload_1 = 27; ++ public static final int opc_iload_2 = 28; ++ public static final int opc_iload_3 = 29; ++ public static final int opc_lload_0 = 30; ++ public static final int opc_lload_1 = 31; ++ public static final int opc_lload_2 = 32; ++ public static final int opc_lload_3 = 33; ++ public static final int opc_fload_0 = 34; ++ public static final int opc_fload_1 = 35; ++ public static final int opc_fload_2 = 36; ++ public static final int opc_fload_3 = 37; ++ public static final int opc_dload_0 = 38; ++ public static final int opc_dload_1 = 39; ++ public static final int opc_dload_2 = 40; ++ public static final int opc_dload_3 = 41; ++ public static final int opc_aload_0 = 42; ++ public static final int opc_aload_1 = 43; ++ public static final int opc_aload_2 = 44; ++ public static final int opc_aload_3 = 45; ++ public static final int opc_iaload = 46; ++ public static final int opc_laload = 47; ++ public static final int opc_faload = 48; ++ public static final int opc_daload = 49; ++ public static final int opc_aaload = 50; ++ public static final int opc_baload = 51; ++ public static final int opc_caload = 52; ++ public static final int opc_saload = 53; ++ public static final int opc_istore = 54; ++ public static final int opc_lstore = 55; ++ public static final int opc_fstore = 56; ++ public static final int opc_dstore = 57; ++ public static final int opc_astore = 58; ++ public static final int opc_istore_0 = 59; ++ public static final int opc_istore_1 = 60; ++ public static final int opc_istore_2 = 61; ++ public static final int opc_istore_3 = 62; ++ public static final int opc_lstore_0 = 63; ++ public static final int opc_lstore_1 = 64; ++ public static final int opc_lstore_2 = 65; ++ public static final int opc_lstore_3 = 66; ++ public static final int opc_fstore_0 = 67; ++ public static final int opc_fstore_1 = 68; ++ public static final int opc_fstore_2 = 69; ++ public static final int opc_fstore_3 = 70; ++ public static final int opc_dstore_0 = 71; ++ public static final int opc_dstore_1 = 72; ++ public static final int opc_dstore_2 = 73; ++ public static final int opc_dstore_3 = 74; ++ public static final int opc_astore_0 = 75; ++ public static final int opc_astore_1 = 76; ++ public static final int opc_astore_2 = 77; ++ public static final int opc_astore_3 = 78; ++ public static final int opc_iastore = 79; ++ public static final int opc_lastore = 80; ++ public static final int opc_fastore = 81; ++ public static final int opc_dastore = 82; ++ public static final int opc_aastore = 83; ++ public static final int opc_bastore = 84; ++ public static final int opc_castore = 85; ++ public static final int opc_sastore = 86; ++ public static final int opc_pop = 87; ++ public static final int opc_pop2 = 88; ++ public static final int opc_dup = 89; ++ public static final int opc_dup_x1 = 90; ++ public static final int opc_dup_x2 = 91; ++ public static final int opc_dup2 = 92; ++ public static final int opc_dup2_x1 = 93; ++ public static final int opc_dup2_x2 = 94; ++ public static final int opc_swap = 95; ++ public static final int opc_iadd = 96; ++ public static final int opc_ladd = 97; ++ public static final int opc_fadd = 98; ++ public static final int opc_dadd = 99; ++ public static final int opc_isub = 100; ++ public static final int opc_lsub = 101; ++ public static final int opc_fsub = 102; ++ public static final int opc_dsub = 103; ++ public static final int opc_imul = 104; ++ public static final int opc_lmul = 105; ++ public static final int opc_fmul = 106; ++ public static final int opc_dmul = 107; ++ public static final int opc_idiv = 108; ++ public static final int opc_ldiv = 109; ++ public static final int opc_fdiv = 110; ++ public static final int opc_ddiv = 111; ++ public static final int opc_irem = 112; ++ public static final int opc_lrem = 113; ++ public static final int opc_frem = 114; ++ public static final int opc_drem = 115; ++ public static final int opc_ineg = 116; ++ public static final int opc_lneg = 117; ++ public static final int opc_fneg = 118; ++ public static final int opc_dneg = 119; ++ public static final int opc_ishl = 120; ++ public static final int opc_lshl = 121; ++ public static final int opc_ishr = 122; ++ public static final int opc_lshr = 123; ++ public static final int opc_iushr = 124; ++ public static final int opc_lushr = 125; ++ public static final int opc_iand = 126; ++ public static final int opc_land = 127; ++ public static final int opc_ior = 128; ++ public static final int opc_lor = 129; ++ public static final int opc_ixor = 130; ++ public static final int opc_lxor = 131; ++ public static final int opc_iinc = 132; ++ public static final int opc_i2l = 133; ++ public static final int opc_i2f = 134; ++ public static final int opc_i2d = 135; ++ public static final int opc_l2i = 136; ++ public static final int opc_l2f = 137; ++ public static final int opc_l2d = 138; ++ public static final int opc_f2i = 139; ++ public static final int opc_f2l = 140; ++ public static final int opc_f2d = 141; ++ public static final int opc_d2i = 142; ++ public static final int opc_d2l = 143; ++ public static final int opc_d2f = 144; ++ public static final int opc_i2b = 145; ++ public static final int opc_int2byte = 145; ++ public static final int opc_i2c = 146; ++ public static final int opc_int2char = 146; ++ public static final int opc_i2s = 147; ++ public static final int opc_int2short = 147; ++ public static final int opc_lcmp = 148; ++ public static final int opc_fcmpl = 149; ++ public static final int opc_fcmpg = 150; ++ public static final int opc_dcmpl = 151; ++ public static final int opc_dcmpg = 152; ++ public static final int opc_ifeq = 153; ++ public static final int opc_ifne = 154; ++ public static final int opc_iflt = 155; ++ public static final int opc_ifge = 156; ++ public static final int opc_ifgt = 157; ++ public static final int opc_ifle = 158; ++ public static final int opc_if_icmpeq = 159; ++ public static final int opc_if_icmpne = 160; ++ public static final int opc_if_icmplt = 161; ++ public static final int opc_if_icmpge = 162; ++ public static final int opc_if_icmpgt = 163; ++ public static final int opc_if_icmple = 164; ++ public static final int opc_if_acmpeq = 165; ++ public static final int opc_if_acmpne = 166; ++ public static final int opc_goto = 167; ++ public static final int opc_jsr = 168; ++ public static final int opc_ret = 169; ++ public static final int opc_tableswitch = 170; ++ public static final int opc_lookupswitch = 171; ++ public static final int opc_ireturn = 172; ++ public static final int opc_lreturn = 173; ++ public static final int opc_freturn = 174; ++ public static final int opc_dreturn = 175; ++ public static final int opc_areturn = 176; ++ public static final int opc_return = 177; ++ public static final int opc_getstatic = 178; ++ public static final int opc_putstatic = 179; ++ public static final int opc_getfield = 180; ++ public static final int opc_putfield = 181; ++ public static final int opc_invokevirtual = 182; ++ public static final int opc_invokenonvirtual = 183; ++ public static final int opc_invokespecial = 183; ++ public static final int opc_invokestatic = 184; ++ public static final int opc_invokeinterface = 185; ++// public static final int opc_xxxunusedxxx = 186; ++ public static final int opc_new = 187; ++ public static final int opc_newarray = 188; ++ public static final int opc_anewarray = 189; ++ public static final int opc_arraylength = 190; ++ public static final int opc_athrow = 191; ++ public static final int opc_checkcast = 192; ++ public static final int opc_instanceof = 193; ++ public static final int opc_monitorenter = 194; ++ public static final int opc_monitorexit = 195; ++ public static final int opc_wide = 196; ++ public static final int opc_multianewarray = 197; ++ public static final int opc_ifnull = 198; ++ public static final int opc_ifnonnull = 199; ++ public static final int opc_goto_w = 200; ++ public static final int opc_jsr_w = 201; ++ ++ /* Pseudo-instructions */ ++ public static final int opc_bytecode = 203; ++ public static final int opc_try = 204; ++ public static final int opc_endtry = 205; ++ public static final int opc_catch = 206; ++ public static final int opc_var = 207; ++ public static final int opc_endvar = 208; ++ public static final int opc_localsmap = 209; ++ public static final int opc_stackmap = 210; ++ ++ /* PicoJava prefixes */ ++ public static final int opc_nonpriv = 254; ++ public static final int opc_priv = 255; ++ ++ /* Wide instructions */ ++ public static final int opc_iload_w = (opc_wide << 8 ) | opc_iload; ++ public static final int opc_lload_w = (opc_wide << 8 ) | opc_lload; ++ public static final int opc_fload_w = (opc_wide << 8 ) | opc_fload; ++ public static final int opc_dload_w = (opc_wide << 8 ) | opc_dload; ++ public static final int opc_aload_w = (opc_wide << 8 ) | opc_aload; ++ public static final int opc_istore_w = (opc_wide << 8 ) | opc_istore; ++ public static final int opc_lstore_w = (opc_wide << 8 ) | opc_lstore; ++ public static final int opc_fstore_w = (opc_wide << 8 ) | opc_fstore; ++ public static final int opc_dstore_w = (opc_wide << 8 ) | opc_dstore; ++ public static final int opc_astore_w = (opc_wide << 8 ) | opc_astore; ++ public static final int opc_ret_w = (opc_wide << 8 ) | opc_ret; ++ public static final int opc_iinc_w = (opc_wide << 8 ) | opc_iinc; ++ ++ /* Opcode Names */ ++ private static final String opcNamesTab[] = { ++ "nop", ++ "aconst_null", ++ "iconst_m1", ++ "iconst_0", ++ "iconst_1", ++ "iconst_2", ++ "iconst_3", ++ "iconst_4", ++ "iconst_5", ++ "lconst_0", ++ "lconst_1", ++ "fconst_0", ++ "fconst_1", ++ "fconst_2", ++ "dconst_0", ++ "dconst_1", ++ "bipush", ++ "sipush", ++ "ldc", ++ "ldc_w", ++ "ldc2_w", ++ "iload", ++ "lload", ++ "fload", ++ "dload", ++ "aload", ++ "iload_0", ++ "iload_1", ++ "iload_2", ++ "iload_3", ++ "lload_0", ++ "lload_1", ++ "lload_2", ++ "lload_3", ++ "fload_0", ++ "fload_1", ++ "fload_2", ++ "fload_3", ++ "dload_0", ++ "dload_1", ++ "dload_2", ++ "dload_3", ++ "aload_0", ++ "aload_1", ++ "aload_2", ++ "aload_3", ++ "iaload", ++ "laload", ++ "faload", ++ "daload", ++ "aaload", ++ "baload", ++ "caload", ++ "saload", ++ "istore", ++ "lstore", ++ "fstore", ++ "dstore", ++ "astore", ++ "istore_0", ++ "istore_1", ++ "istore_2", ++ "istore_3", ++ "lstore_0", ++ "lstore_1", ++ "lstore_2", ++ "lstore_3", ++ "fstore_0", ++ "fstore_1", ++ "fstore_2", ++ "fstore_3", ++ "dstore_0", ++ "dstore_1", ++ "dstore_2", ++ "dstore_3", ++ "astore_0", ++ "astore_1", ++ "astore_2", ++ "astore_3", ++ "iastore", ++ "lastore", ++ "fastore", ++ "dastore", ++ "aastore", ++ "bastore", ++ "castore", ++ "sastore", ++ "pop", ++ "pop2", ++ "dup", ++ "dup_x1", ++ "dup_x2", ++ "dup2", ++ "dup2_x1", ++ "dup2_x2", ++ "swap", ++ "iadd", ++ "ladd", ++ "fadd", ++ "dadd", ++ "isub", ++ "lsub", ++ "fsub", ++ "dsub", ++ "imul", ++ "lmul", ++ "fmul", ++ "dmul", ++ "idiv", ++ "ldiv", ++ "fdiv", ++ "ddiv", ++ "irem", ++ "lrem", ++ "frem", ++ "drem", ++ "ineg", ++ "lneg", ++ "fneg", ++ "dneg", ++ "ishl", ++ "lshl", ++ "ishr", ++ "lshr", ++ "iushr", ++ "lushr", ++ "iand", ++ "land", ++ "ior", ++ "lor", ++ "ixor", ++ "lxor", ++ "iinc", ++ "i2l", ++ "i2f", ++ "i2d", ++ "l2i", ++ "l2f", ++ "l2d", ++ "f2i", ++ "f2l", ++ "f2d", ++ "d2i", ++ "d2l", ++ "d2f", ++ "i2b", ++ "i2c", ++ "i2s", ++ "lcmp", ++ "fcmpl", ++ "fcmpg", ++ "dcmpl", ++ "dcmpg", ++ "ifeq", ++ "ifne", ++ "iflt", ++ "ifge", ++ "ifgt", ++ "ifle", ++ "if_icmpeq", ++ "if_icmpne", ++ "if_icmplt", ++ "if_icmpge", ++ "if_icmpgt", ++ "if_icmple", ++ "if_acmpeq", ++ "if_acmpne", ++ "goto", ++ "jsr", ++ "ret", ++ "tableswitch", ++ "lookupswitch", ++ "ireturn", ++ "lreturn", ++ "freturn", ++ "dreturn", ++ "areturn", ++ "return", ++ "getstatic", ++ "putstatic", ++ "getfield", ++ "putfield", ++ "invokevirtual", ++ "invokespecial", // was "invokenonvirtual", ++ "invokestatic", ++ "invokeinterface", ++ "bytecode 186", //"xxxunusedxxx", ++ "new", ++ "newarray", ++ "anewarray", ++ "arraylength", ++ "athrow", ++ "checkcast", ++ "instanceof", ++ "monitorenter", ++ "monitorexit", ++ null, // "wide", ++ "multianewarray", ++ "ifnull", ++ "ifnonnull", ++ "goto_w", ++ "jsr_w", ++ "bytecode 202", // "breakpoint", ++ "bytecode", ++ "try", ++ "endtry", ++ "catch", ++ "var", ++ "endvar", ++ "locals_map", ++ "stack_map" ++ }; ++ ++ /* Opcode Lengths */ ++ private static final int opcLengthsTab[] = { ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 2, ++ 3, ++ 2, ++ 3, ++ 3, ++ 2, ++ 2, ++ 2, ++ 2, ++ 2, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 2, ++ 2, ++ 2, ++ 2, ++ 2, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 3, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 2, ++ 99, ++ 99, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 1, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 3, ++ 5, ++ 0, ++ 3, ++ 2, ++ 3, ++ 1, ++ 1, ++ 3, ++ 3, ++ 1, ++ 1, ++ 0, // wide ++ 4, ++ 3, ++ 3, ++ 5, ++ 5, ++ 1, ++ 1, 0, 0, 0, 0, 0 // pseudo ++ }; ++ ++ /* Type codes, used in newarray opcode */ ++ public static final int T_CLASS = 0x00000002; ++ public static final int T_BOOLEAN = 0x00000004; ++ public static final int T_CHAR = 0x00000005; ++ public static final int T_FLOAT = 0x00000006; ++ public static final int T_DOUBLE = 0x00000007; ++ public static final int T_BYTE = 0x00000008; ++ public static final int T_SHORT = 0x00000009; ++ public static final int T_INT = 0x0000000a; ++ public static final int T_LONG = 0x0000000b; ++ ++ private static HashMap<String,Integer> mnemocodes = new HashMap<String,Integer>(301, 0.5f); ++ private static String opcExtNamesTab[]=new String[128]; ++ private static String opcPrivExtNamesTab[]=new String[128]; ++ ++ private static void defineNonPriv(int opc, String mnem) { ++ mnemocodes.put(opcExtNamesTab[opc] = mnem, opc_nonpriv * 256 + opc); ++ } ++ ++ private static void definePriv(int opc, String mnem) { ++ mnemocodes.put(opcPrivExtNamesTab[opc] = "priv_" + mnem, opc_priv * 256 + opc); ++ } ++ ++ private static void defineExt(int opc, String mnem) { ++ defineNonPriv(opc, mnem); ++ definePriv(opc, mnem); ++ } ++ ++ static { ++ for (int i = 0; i < opc_wide; i++) { ++ mnemocodes.put(opcNamesTab[i], i); ++ } ++ for (int i = opc_wide + 1; i < opcNamesTab.length; i++) { ++ mnemocodes.put(opcNamesTab[i], i); ++ } ++ mnemocodes.put("invokenonvirtual", opc_invokespecial); ++ ++ mnemocodes.put("iload_w", opc_iload_w); ++ mnemocodes.put("lload_w", opc_lload_w); ++ mnemocodes.put("fload_w", opc_fload_w); ++ mnemocodes.put("dload_w", opc_dload_w); ++ mnemocodes.put("aload_w", opc_aload_w); ++ mnemocodes.put("istore_w", opc_istore_w); ++ mnemocodes.put("lstore_w", opc_lstore_w); ++ mnemocodes.put("fstore_w", opc_fstore_w); ++ mnemocodes.put("dstore_w", opc_dstore_w); ++ mnemocodes.put("astore_w", opc_astore_w); ++ mnemocodes.put("ret_w", opc_ret_w); ++ mnemocodes.put("iinc_w", opc_iinc_w); ++ ++ mnemocodes.put("nonpriv", opc_nonpriv); ++ mnemocodes.put("priv", opc_priv); ++ ++ defineExt(0, "load_ubyte"); ++ defineExt(1, "load_byte"); ++ defineExt(2, "load_char"); ++ defineExt(3, "load_short"); ++ defineExt(4, "load_word"); ++ defineExt(10, "load_char_oe"); ++ defineExt(11, "load_short_oe"); ++ defineExt(12, "load_word_oe"); ++ defineExt(16, "ncload_ubyte"); ++ defineExt(17, "ncload_byte"); ++ defineExt(18, "ncload_char"); ++ defineExt(19, "ncload_short"); ++ defineExt(20, "ncload_word"); ++ defineExt(26, "ncload_char_oe"); ++ defineExt(27, "ncload_short_oe"); ++ defineExt(28, "ncload_word_oe"); ++ defineExt(30, "cache_flush"); ++ defineExt(32, "store_byte"); ++ defineExt(34, "store_short"); ++ defineExt(36, "store_word"); ++ defineExt(42, "store_short_oe"); ++ defineExt(44, "store_word_oe"); ++ defineExt(48, "ncstore_byte"); ++ defineExt(50, "ncstore_short"); ++ defineExt(52, "ncstore_word"); ++ defineExt(58, "ncstore_short_oe"); ++ defineExt(60, "ncstore_word_oe"); ++ defineExt(62, "zero_line"); ++ defineNonPriv(5, "ret_from_sub"); ++ defineNonPriv(63, "enter_sync_method"); ++ definePriv(5, "ret_from_trap"); ++ definePriv(6, "read_dcache_tag"); ++ definePriv(7, "read_dcache_data"); ++ definePriv(14, "read_icache_tag"); ++ definePriv(15, "read_icache_data"); ++ definePriv(22, "powerdown"); ++ definePriv(23, "read_scache_data"); ++ definePriv(31, "cache_index_flush"); ++ definePriv(38, "write_dcache_tag"); ++ definePriv(39, "write_dcache_data"); ++ definePriv(46, "write_icache_tag"); ++ definePriv(47, "write_icache_data"); ++ definePriv(54, "reset"); ++ definePriv(55, "write_scache_data"); ++ for (int i = 0; i < 32; i++) { ++ definePriv(i + 64, "read_reg_" + i); ++ } ++ for (int i = 0; i < 32; i++) { ++ definePriv(i + 96, "write_reg_" + i); ++ } ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/RuntimeAnnotations_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/RuntimeAnnotations_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,61 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.16 and 4.8.17. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public abstract class RuntimeAnnotations_attribute extends Attribute { ++ protected RuntimeAnnotations_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, Annotation.InvalidAnnotation { ++ super(name_index, length); ++ int num_annotations = cr.readUnsignedShort(); ++ annotations = new Annotation[num_annotations]; ++ for (int i = 0; i < annotations.length; i++) ++ annotations[i] = new Annotation(cr); ++ } ++ ++ protected RuntimeAnnotations_attribute(int name_index, Annotation[] annotations) { ++ super(name_index, length(annotations)); ++ this.annotations = annotations; ++ } ++ ++ private static int length(Annotation[] annos) { ++ int n = 2; ++ for (Annotation anno: annos) ++ n += anno.length(); ++ return n; ++ } ++ ++ public final Annotation[] annotations; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/RuntimeInvisibleAnnotations_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/RuntimeInvisibleAnnotations_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,56 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.17. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class RuntimeInvisibleAnnotations_attribute extends RuntimeAnnotations_attribute { ++ RuntimeInvisibleAnnotations_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, AttributeException { ++ super(cr, name_index, length); ++ } ++ ++ public RuntimeInvisibleAnnotations_attribute(ConstantPool cp, Annotation[] annotations) ++ throws ConstantPoolException { ++ this(cp.getUTF8Index(Attribute.RuntimeInvisibleAnnotations), annotations); ++ } ++ ++ public RuntimeInvisibleAnnotations_attribute(int name_index, Annotation[] annotations) { ++ super(name_index, annotations); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitRuntimeInvisibleAnnotations(this, p); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/RuntimeInvisibleParameterAnnotations_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/RuntimeInvisibleParameterAnnotations_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,56 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.18. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class RuntimeInvisibleParameterAnnotations_attribute extends RuntimeParameterAnnotations_attribute { ++ RuntimeInvisibleParameterAnnotations_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, Annotation.InvalidAnnotation { ++ super(cr, name_index, length); ++ } ++ ++ public RuntimeInvisibleParameterAnnotations_attribute(ConstantPool cp, Annotation[][] parameter_annotations) ++ throws ConstantPoolException { ++ this(cp.getUTF8Index(Attribute.RuntimeInvisibleParameterAnnotations), parameter_annotations); ++ } ++ ++ public RuntimeInvisibleParameterAnnotations_attribute(int name_index, Annotation[][] parameter_annotations) { ++ super(name_index, parameter_annotations); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitRuntimeInvisibleParameterAnnotations(this, p); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/RuntimeParameterAnnotations_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/RuntimeParameterAnnotations_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,70 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.18 and 4.8.19. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public abstract class RuntimeParameterAnnotations_attribute extends Attribute { ++ RuntimeParameterAnnotations_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, Annotation.InvalidAnnotation { ++ super(name_index, length); ++ int num_parameters = cr.readUnsignedByte(); ++ parameter_annotations = new Annotation[num_parameters][]; ++ for (int p = 0; p < parameter_annotations.length; p++) { ++ int num_annotations = cr.readUnsignedShort(); ++ Annotation[] annotations = new Annotation[num_annotations]; ++ for (int i = 0; i < num_annotations; i++) ++ annotations[i] = new Annotation(cr); ++ parameter_annotations[p] = annotations; ++ } ++ } ++ ++ protected RuntimeParameterAnnotations_attribute(int name_index, Annotation[][] parameter_annotations) { ++ super(name_index, length(parameter_annotations)); ++ this.parameter_annotations = parameter_annotations; ++ } ++ ++ private static int length(Annotation[][] anno_arrays) { ++ int n = 1; ++ for (Annotation[] anno_array: anno_arrays) { ++ n += 2; ++ for (Annotation anno: anno_array) ++ n += anno.length(); ++ } ++ return n; ++ } ++ ++ public final Annotation[][] parameter_annotations; ++} ++ +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/RuntimeVisibleAnnotations_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/RuntimeVisibleAnnotations_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,56 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.16. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class RuntimeVisibleAnnotations_attribute extends RuntimeAnnotations_attribute { ++ RuntimeVisibleAnnotations_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, Annotation.InvalidAnnotation { ++ super(cr, name_index, length); ++ } ++ ++ public RuntimeVisibleAnnotations_attribute(ConstantPool cp, Annotation[] annotations) ++ throws ConstantPoolException { ++ this(cp.getUTF8Index(Attribute.RuntimeVisibleAnnotations), annotations); ++ } ++ ++ public RuntimeVisibleAnnotations_attribute(int name_index, Annotation[] annotations) { ++ super(name_index, annotations); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitRuntimeVisibleAnnotations(this, p); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/RuntimeVisibleParameterAnnotations_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/RuntimeVisibleParameterAnnotations_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,56 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.18. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class RuntimeVisibleParameterAnnotations_attribute extends RuntimeParameterAnnotations_attribute { ++ RuntimeVisibleParameterAnnotations_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, Annotation.InvalidAnnotation { ++ super(cr, name_index, length); ++ } ++ ++ public RuntimeVisibleParameterAnnotations_attribute(ConstantPool cp, Annotation[][] parameter_annotations) ++ throws ConstantPoolException { ++ this(cp.getUTF8Index(Attribute.RuntimeVisibleParameterAnnotations), parameter_annotations); ++ } ++ ++ public RuntimeVisibleParameterAnnotations_attribute(int name_index, Annotation[][] parameter_annotations) { ++ super(name_index, parameter_annotations); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitRuntimeVisibleParameterAnnotations(this, p); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Signature.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Signature.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,275 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.util.ArrayList; ++import java.util.List; ++ ++/** ++ * See JVMS3 4.4.4. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Signature extends Descriptor { ++ ++ public Signature(int index) { ++ super(index); ++ } ++ ++ public Type getType(ConstantPool constant_pool) throws ConstantPoolException { ++ if (type == null) ++ type = parse(getValue(constant_pool)); ++ return type; ++ } ++ ++ @Override ++ public int getParameterCount(ConstantPool constant_pool) throws ConstantPoolException { ++ Type.MethodType m = (Type.MethodType) getType(constant_pool); ++ return m.argTypes.size(); ++ } ++ ++ @Override ++ public String getParameterTypes(ConstantPool constant_pool) throws ConstantPoolException { ++ Type.MethodType m = (Type.MethodType) getType(constant_pool); ++ StringBuilder sb = new StringBuilder(); ++ sb.append("("); ++ String sep = ""; ++ for (Type argType: m.argTypes) { ++ sb.append(sep); ++ sb.append(argType); ++ sep = ", "; ++ } ++ sb.append(")"); ++ return sb.toString(); ++ } ++ ++ @Override ++ public String getReturnType(ConstantPool constant_pool) throws ConstantPoolException { ++ Type.MethodType m = (Type.MethodType) getType(constant_pool); ++ return m.returnType.toString(); ++ } ++ ++ @Override ++ public String getFieldType(ConstantPool constant_pool) throws ConstantPoolException { ++ return getType(constant_pool).toString(); ++ } ++ ++ private Type parse(String sig) { ++ this.sig = sig; ++ sigp = 0; ++ ++ List<Type> typeArgTypes = null; ++ if (sig.charAt(sigp) == '<') ++ typeArgTypes = parseTypeArgTypes(); ++ ++ if (sig.charAt(sigp) == '(') { ++ List<Type> argTypes = parseTypeSignatures(')'); ++ Type returnType = parseTypeSignature(); ++ List<Type> throwsTypes = null; ++ while (sigp < sig.length() && sig.charAt(sigp) == '^') { ++ sigp++; ++ if (throwsTypes == null) ++ throwsTypes = new ArrayList<Type>(); ++ throwsTypes.add(parseTypeSignature()); ++ } ++ return new Type.MethodType(typeArgTypes, argTypes, returnType, throwsTypes); ++ } else { ++ Type t = parseTypeSignature(); ++ if (typeArgTypes == null && sigp == sig.length()) ++ return t; ++ Type superclass = t; ++ List<Type> superinterfaces = new ArrayList<Type>(); ++ while (sigp < sig.length()) ++ superinterfaces.add(parseTypeSignature()); ++ return new Type.ClassSigType(typeArgTypes, superclass, superinterfaces); ++ ++ } ++ } ++ ++ private Type parseTypeSignature() { ++ switch (sig.charAt(sigp)) { ++ case 'B': ++ sigp++; ++ return new Type.SimpleType("byte"); ++ ++ case 'C': ++ sigp++; ++ return new Type.SimpleType("char"); ++ ++ case 'D': ++ sigp++; ++ return new Type.SimpleType("double"); ++ ++ case 'F': ++ sigp++; ++ return new Type.SimpleType("float"); ++ ++ case 'I': ++ sigp++; ++ return new Type.SimpleType("int"); ++ ++ case 'J': ++ sigp++; ++ return new Type.SimpleType("long"); ++ ++ case 'L': ++ return parseClassTypeSignature(); ++ ++ case 'S': ++ sigp++; ++ return new Type.SimpleType("short"); ++ ++ case 'T': ++ return parseTypeVariableSignature(); ++ ++ case 'V': ++ sigp++; ++ return new Type.SimpleType("void"); ++ ++ case 'Z': ++ sigp++; ++ return new Type.SimpleType("boolean"); ++ ++ case '[': ++ sigp++; ++ return new Type.ArrayType(parseTypeSignature()); ++ ++ case '*': ++ sigp++; ++ return new Type.WildcardType(); ++ ++ case '+': ++ sigp++; ++ return new Type.WildcardType("extends", parseTypeSignature()); ++ ++ case '-': ++ sigp++; ++ return new Type.WildcardType("super", parseTypeSignature()); ++ ++ default: ++ throw new IllegalStateException(debugInfo()); ++ } ++ } ++ ++ private List<Type> parseTypeSignatures(char term) { ++ sigp++; ++ List<Type> types = new ArrayList<Type>(); ++ while (sig.charAt(sigp) != term) ++ types.add(parseTypeSignature()); ++ sigp++; ++ return types; ++ } ++ ++ private Type parseClassTypeSignature() { ++ assert sig.charAt(sigp) == 'L'; ++ sigp++; ++ return parseClassTypeSignatureRest(); ++ } ++ ++ private Type parseClassTypeSignatureRest() { ++ StringBuilder sb = new StringBuilder(); ++ Type t = null; ++ char sigch; ++ while (true) { ++ switch (sigch = sig.charAt(sigp)) { ++ case '/': ++ sigp++; ++ sb.append("."); ++ break; ++ ++ case '.': ++ sigp++; ++ if (t == null) ++ t = new Type.SimpleType(sb.toString()); ++ return new Type.InnerClassType(t, parseClassTypeSignatureRest()); ++ ++ case ';': ++ sigp++; ++ if (t == null) ++ t = new Type.SimpleType(sb.toString()); ++ return t; ++ ++ case '<': ++ List<Type> argTypes = parseTypeSignatures('>'); ++ t = new Type.ClassType(sb.toString(), argTypes); ++ break; ++ ++ default: ++ sigp++; ++ sb.append(sigch); ++ break; ++ } ++ } ++ } ++ ++ private List<Type> parseTypeArgTypes() { ++ assert sig.charAt(sigp) == '<'; ++ sigp++; ++ List<Type> types = null; ++ types = new ArrayList<Type>(); ++ while (sig.charAt(sigp) != '>') ++ types.add(parseTypeArgType()); ++ sigp++; ++ return types; ++ } ++ ++ private Type parseTypeArgType() { ++ int sep = sig.indexOf(":", sigp); ++ String name = sig.substring(sigp, sep); ++ Type classBound = null; ++ List<Type> interfaceBounds = null; ++ sigp = sep + 1; ++ if (sig.charAt(sigp) != ':') ++ classBound = parseTypeSignature(); ++ while (sig.charAt(sigp) == ':') { ++ sigp++; ++ if (interfaceBounds == null) ++ interfaceBounds = new ArrayList<Type>(); ++ interfaceBounds.add(parseTypeSignature()); ++ } ++ return new Type.TypeArgType(name, classBound, interfaceBounds); ++ } ++ ++ private Type parseTypeVariableSignature() { ++ sigp++; ++ int sep = sig.indexOf(';', sigp); ++ Type t = new Type.SimpleType(sig.substring(sigp, sep)); ++ sigp = sep + 1; ++ return t; ++ } ++ ++ private String debugInfo() { ++ return sig.substring(0, sigp) + "!" + sig.charAt(sigp) + "!" + sig.substring(sigp+1); ++ } ++ ++ private String sig; ++ private int sigp; ++ ++ private Type type; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Signature_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Signature_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,67 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.9. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Signature_attribute extends Attribute { ++ Signature_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ signature_index = cr.readUnsignedShort(); ++ } ++ ++ public Signature_attribute(ConstantPool constant_pool, int signature_index) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.Signature), signature_index); ++ } ++ ++ public Signature_attribute(int name_index, int signature_index) { ++ super(name_index, 2); ++ this.signature_index = signature_index; ++ } ++ ++ public String getSignature(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(signature_index); ++ } ++ ++ public Signature getParsedSignature() { ++ return new Signature(signature_index); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitSignature(this, data); ++ } ++ ++ public final int signature_index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/SourceDebugExtension_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/SourceDebugExtension_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,71 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.ByteArrayInputStream; ++import java.io.DataInputStream; ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.15. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class SourceDebugExtension_attribute extends Attribute { ++ SourceDebugExtension_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ debug_extension = new byte[attribute_length]; ++ cr.readFully(debug_extension); ++ } ++ ++ public SourceDebugExtension_attribute(ConstantPool constant_pool, byte[] debug_extension) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.SourceDebugExtension), debug_extension); ++ } ++ ++ public SourceDebugExtension_attribute(int name_index, byte[] debug_extension) { ++ super(name_index, debug_extension.length); ++ this.debug_extension = debug_extension; ++ } ++ ++ public String getValue() { ++ DataInputStream d = new DataInputStream(new ByteArrayInputStream(debug_extension)); ++ try { ++ return d.readUTF(); ++ } catch (IOException e) { ++ return null; ++ } ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitSourceDebugExtension(this, data); ++ } ++ ++ public final byte[] debug_extension; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/SourceFile_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/SourceFile_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,63 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.10. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class SourceFile_attribute extends Attribute { ++ SourceFile_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ sourcefile_index = cr.readUnsignedShort(); ++ } ++ ++ public SourceFile_attribute(ConstantPool constant_pool, int sourcefile_index) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.SourceFile), sourcefile_index); ++ } ++ ++ public SourceFile_attribute(int name_index, int sourcefile_index) { ++ super(name_index, 2); ++ this.sourcefile_index = sourcefile_index; ++ } ++ ++ public String getSourceFile(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(sourcefile_index); ++ } ++ ++ public <R, P> R accept(Visitor<R, P> visitor, P p) { ++ return visitor.visitSourceFile(this, p); ++ } ++ ++ public final int sourcefile_index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/SourceID_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/SourceID_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,61 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class SourceID_attribute extends Attribute { ++ ++ SourceID_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ sourceID_index = cr.readUnsignedShort(); ++ } ++ ++ public SourceID_attribute(ConstantPool constant_pool, int sourceID_index) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.SourceID), sourceID_index); ++ } ++ ++ public SourceID_attribute(int name_index, int sourceID_index) { ++ super(name_index, 2); ++ this.sourceID_index = sourceID_index; ++ } ++ ++ String getSourceID(ConstantPool constant_pool) throws ConstantPoolException { ++ return constant_pool.getUTF8Value(sourceID_index); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitSourceID(this, data); ++ } ++ ++ public final int sourceID_index; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/StackMapTable_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/StackMapTable_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,349 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.4. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class StackMapTable_attribute extends Attribute { ++ static class InvalidStackMap extends AttributeException { ++ InvalidStackMap(String msg) { ++ super(msg); ++ } ++ } ++ ++ StackMapTable_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, InvalidStackMap { ++ super(name_index, length); ++ number_of_entries = cr.readUnsignedShort(); ++ entries = new stack_map_frame[number_of_entries]; ++ for (int i = 0; i < number_of_entries; i++) ++ entries[i] = stack_map_frame.read(cr); ++ } ++ ++ public StackMapTable_attribute(ConstantPool constant_pool, stack_map_frame[] entries) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.StackMapTable), entries); ++ } ++ ++ public StackMapTable_attribute(int name_index, stack_map_frame[] entries) { ++ super(name_index, length(entries)); ++ this.number_of_entries = entries.length; ++ this.entries = entries; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitStackMapTable(this, data); ++ } ++ ++ static int length(stack_map_frame[] entries) { ++ int n = 2; ++ for (stack_map_frame entry: entries) ++ n += entry.length(); ++ return n; ++ } ++ ++ public final int number_of_entries; ++ public final stack_map_frame entries[]; ++ ++ public static abstract class stack_map_frame { ++ static stack_map_frame read(ClassReader cr) ++ throws IOException, InvalidStackMap { ++ int frame_type = cr.readUnsignedByte(); ++ if (frame_type <= 63) ++ return new same_frame(frame_type); ++ else if (frame_type <= 127) ++ return new same_locals_1_stack_item_frame(frame_type, cr); ++ else if (frame_type <= 246) ++ throw new Error("unknown frame_type " + frame_type); ++ else if (frame_type == 247) ++ return new same_locals_1_stack_item_frame_extended(frame_type, cr); ++ else if (frame_type <= 250) ++ return new chop_frame(frame_type, cr); ++ else if (frame_type == 251) ++ return new same_frame_extended(frame_type, cr); ++ else if (frame_type <= 254) ++ return new append_frame(frame_type, cr); ++ else ++ return new full_frame(frame_type, cr); ++ } ++ ++ protected stack_map_frame(int frame_type) { ++ this.frame_type = frame_type; ++ } ++ ++ public int length() { ++ return 1; ++ } ++ ++ public abstract <R,D> R accept(Visitor<R,D> visitor, D data); ++ ++ public final int frame_type; ++ ++ public static interface Visitor<R,P> { ++ R visit_same_frame(same_frame frame, P p); ++ R visit_same_locals_1_stack_item_frame(same_locals_1_stack_item_frame frame, P p); ++ R visit_same_locals_1_stack_item_frame_extended(same_locals_1_stack_item_frame_extended frame, P p); ++ R visit_chop_frame(chop_frame frame, P p); ++ R visit_same_frame_extended(same_frame_extended frame, P p); ++ R visit_append_frame(append_frame frame, P p); ++ R visit_full_frame(full_frame frame, P p); ++ } ++ } ++ ++ public static class same_frame extends stack_map_frame { ++ same_frame(int frame_type) { ++ super(frame_type); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_same_frame(this, data); ++ } ++ } ++ ++ public static class same_locals_1_stack_item_frame extends stack_map_frame { ++ same_locals_1_stack_item_frame(int frame_type, ClassReader cr) ++ throws IOException, InvalidStackMap { ++ super(frame_type); ++ stack = new verification_type_info[1]; ++ stack[0] = verification_type_info.read(cr); ++ } ++ ++ @Override ++ public int length() { ++ return super.length() + stack[0].length(); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_same_locals_1_stack_item_frame(this, data); ++ } ++ ++ public final verification_type_info[] stack; ++ } ++ ++ public static class same_locals_1_stack_item_frame_extended extends stack_map_frame { ++ same_locals_1_stack_item_frame_extended(int frame_type, ClassReader cr) ++ throws IOException, InvalidStackMap { ++ super(frame_type); ++ offset_delta = cr.readUnsignedShort(); ++ stack = new verification_type_info[1]; ++ stack[0] = verification_type_info.read(cr); ++ } ++ ++ @Override ++ public int length() { ++ return super.length() + 2 + stack[0].length(); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_same_locals_1_stack_item_frame_extended(this, data); ++ } ++ ++ public final int offset_delta; ++ public final verification_type_info[] stack; ++ } ++ ++ public static class chop_frame extends stack_map_frame { ++ chop_frame(int frame_type, ClassReader cr) throws IOException { ++ super(frame_type); ++ offset_delta = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return super.length() + 2; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_chop_frame(this, data); ++ } ++ ++ public final int offset_delta; ++ } ++ ++ public static class same_frame_extended extends stack_map_frame { ++ same_frame_extended(int frame_type, ClassReader cr) throws IOException { ++ super(frame_type); ++ offset_delta = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return super.length() + 2; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_same_frame_extended(this, data); ++ } ++ ++ public final int offset_delta; ++ } ++ ++ public static class append_frame extends stack_map_frame { ++ append_frame(int frame_type, ClassReader cr) ++ throws IOException, InvalidStackMap { ++ super(frame_type); ++ offset_delta = cr.readUnsignedShort(); ++ locals = new verification_type_info[frame_type - 251]; ++ for (int i = 0; i < locals.length; i++) ++ locals[i] = verification_type_info.read(cr); ++ } ++ ++ @Override ++ public int length() { ++ int n = super.length() + 2; ++ for (verification_type_info local: locals) ++ n += local.length(); ++ return n; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_append_frame(this, data); ++ } ++ ++ public final int offset_delta; ++ public final verification_type_info[] locals; ++ } ++ ++ public static class full_frame extends stack_map_frame { ++ full_frame(int frame_type, ClassReader cr) ++ throws IOException, InvalidStackMap { ++ super(frame_type); ++ offset_delta = cr.readUnsignedShort(); ++ number_of_locals = cr.readUnsignedShort(); ++ locals = new verification_type_info[number_of_locals]; ++ for (int i = 0; i < locals.length; i++) ++ locals[i] = verification_type_info.read(cr); ++ number_of_stack_items = cr.readUnsignedShort(); ++ stack = new verification_type_info[number_of_stack_items]; ++ for (int i = 0; i < stack.length; i++) ++ stack[i] = verification_type_info.read(cr); ++ } ++ ++ @Override ++ public int length() { ++ int n = super.length() + 2; ++ for (verification_type_info local: locals) ++ n += local.length(); ++ n += 2; ++ for (verification_type_info item: stack) ++ n += item.length(); ++ return n; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visit_full_frame(this, data); ++ } ++ ++ public final int offset_delta; ++ public final int number_of_locals; ++ public final verification_type_info[] locals; ++ public final int number_of_stack_items; ++ public final verification_type_info[] stack; ++ } ++ ++ public static class verification_type_info { ++ public static final int ITEM_Top = 0; ++ public static final int ITEM_Integer = 1; ++ public static final int ITEM_Float = 2; ++ public static final int ITEM_Long = 4; ++ public static final int ITEM_Double = 3; ++ public static final int ITEM_Null = 5; ++ public static final int ITEM_UninitializedThis = 6; ++ public static final int ITEM_Object = 7; ++ public static final int ITEM_Uninitialized = 8; ++ ++ static verification_type_info read(ClassReader cr) ++ throws IOException, InvalidStackMap { ++ int tag = cr.readUnsignedByte(); ++ switch (tag) { ++ case ITEM_Top: ++ case ITEM_Integer: ++ case ITEM_Float: ++ case ITEM_Long: ++ case ITEM_Double: ++ case ITEM_Null: ++ case ITEM_UninitializedThis: ++ return new verification_type_info(tag); ++ ++ case ITEM_Object: ++ return new Object_variable_info(cr); ++ ++ case ITEM_Uninitialized: ++ return new Uninitialized_variable_info(cr); ++ ++ default: ++ throw new InvalidStackMap("unrecognized verification_type_info tag"); ++ } ++ } ++ ++ verification_type_info(int tag) { ++ this.tag = tag; ++ } ++ ++ public int length() { ++ return 1; ++ } ++ ++ public final int tag; ++ } ++ ++ public static class Object_variable_info extends verification_type_info { ++ Object_variable_info(ClassReader cr) throws IOException { ++ super(ITEM_Object); ++ cpool_index = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return super.length() + 2; ++ } ++ ++ public final int cpool_index; ++ } ++ ++ public static class Uninitialized_variable_info extends verification_type_info { ++ Uninitialized_variable_info(ClassReader cr) throws IOException { ++ super(ITEM_Uninitialized); ++ offset = cr.readUnsignedShort(); ++ } ++ ++ @Override ++ public int length() { ++ return super.length() + 2; ++ } ++ ++ public final int offset; ++ ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/StackMap_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/StackMap_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,70 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class StackMap_attribute extends Attribute { ++ StackMap_attribute(ClassReader cr, int name_index, int length) ++ throws IOException, StackMapTable_attribute.InvalidStackMap { ++ super(name_index, length); ++ number_of_entries = cr.readUnsignedShort(); ++ entries = new stack_map_frame[number_of_entries]; ++ for (int i = 0; i < number_of_entries; i++) ++ entries[i] = new stack_map_frame(cr); ++ } ++ ++ public StackMap_attribute(ConstantPool constant_pool, stack_map_frame[] entries) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.StackMap), entries); ++ } ++ ++ public StackMap_attribute(int name_index, stack_map_frame[] entries) { ++ super(name_index, StackMapTable_attribute.length(entries)); ++ this.number_of_entries = entries.length; ++ this.entries = entries; ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitStackMap(this, data); ++ } ++ ++ public final int number_of_entries; ++ public final stack_map_frame entries[]; ++ ++ public static class stack_map_frame extends StackMapTable_attribute.full_frame { ++ stack_map_frame(ClassReader cr) ++ throws IOException, StackMapTable_attribute.InvalidStackMap { ++ super(255, cr); ++ } ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Synthetic_attribute.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Synthetic_attribute.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,55 @@ ++/* ++ * 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.tools.classfile; ++ ++import java.io.IOException; ++ ++/** ++ * See JVMS3, section 4.8.8. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Synthetic_attribute extends Attribute { ++ Synthetic_attribute(ClassReader cr, int name_index, int length) throws IOException { ++ super(name_index, length); ++ } ++ ++ public Synthetic_attribute(ConstantPool constant_pool) ++ throws ConstantPoolException { ++ this(constant_pool.getUTF8Index(Attribute.Synthetic)); ++ } ++ ++ public Synthetic_attribute(int name_index) { ++ super(name_index, 0); ++ } ++ ++ public <R, D> R accept(Visitor<R, D> visitor, D data) { ++ return visitor.visitSynthetic(this, data); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/Type.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Type.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,232 @@ ++/* ++ * Copyright 2008 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.tools.classfile; ++ ++import java.util.List; ++ ++/* ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Type { ++ protected Type() { } ++ ++ public boolean isObject() { ++ return false; ++ } ++ ++ protected static void append(StringBuilder sb, String prefix, List<? extends Type> types, String suffix) { ++ sb.append(prefix); ++ String sep = ""; ++ for (Type t: types) { ++ sb.append(sep); ++ sb.append(t); ++ sep = ", "; ++ } ++ sb.append(suffix); ++ } ++ ++ protected static void appendIfNotEmpty(StringBuilder sb, String prefix, List<? extends Type> types, String suffix) { ++ if (types != null && types.size() > 0) ++ append(sb, prefix, types, suffix); ++ } ++ ++ public static class SimpleType extends Type { ++ public SimpleType(String name) { ++ this.name = name; ++ } ++ ++ @Override ++ public String toString() { ++ return name; ++ } ++ ++ @Override ++ public boolean isObject() { ++ return name.equals("java.lang.Object"); ++ } ++ ++ public final String name; ++ } ++ ++ public static class ArrayType extends Type { ++ public ArrayType(Type elemType) { ++ this.elemType = elemType; ++ } ++ ++ @Override ++ public String toString() { ++ return elemType + "[]"; ++ } ++ ++ public final Type elemType; ++ } ++ ++ public static class MethodType extends Type { ++ public MethodType(List<? extends Type> argTypes, Type resultType) { ++ this(null, argTypes, resultType, null); ++ } ++ ++ public MethodType(List<? extends Type> typeArgTypes, ++ List<? extends Type> argTypes, ++ Type returnType, ++ List<? extends Type> throwsTypes) { ++ this.typeArgTypes = typeArgTypes; ++ this.argTypes = argTypes; ++ this.returnType = returnType; ++ this.throwsTypes = throwsTypes; ++ } ++ ++ @Override ++ public String toString() { ++ StringBuilder sb = new StringBuilder(); ++ appendIfNotEmpty(sb, "<", typeArgTypes, "> "); ++ sb.append(returnType); ++ append(sb, " (", argTypes, ")"); ++ appendIfNotEmpty(sb, " throws ", throwsTypes, ""); ++ return sb.toString(); ++ } ++ ++ public final List<? extends Type> typeArgTypes; ++ public final List<? extends Type> argTypes; ++ public final Type returnType; ++ public final List<? extends Type> throwsTypes; ++ } ++ ++ public static class ClassSigType extends Type { ++ public ClassSigType(List<Type> typeArgTypes, Type superclassType, List<Type> superinterfaceTypes) { ++ this.typeArgTypes = typeArgTypes; ++ this.superclassType = superclassType; ++ this.superinterfaceTypes = superinterfaceTypes; ++ } ++ ++ @Override ++ public String toString() { ++ StringBuilder sb = new StringBuilder(); ++ appendIfNotEmpty(sb, "<", typeArgTypes, ">"); ++ if (superclassType != null && !superclassType.isObject()) { ++ sb.append(" extends "); ++ sb.append(superclassType); ++ } ++ appendIfNotEmpty(sb, " implements ", superinterfaceTypes, ""); ++ return sb.toString(); ++ } ++ ++ public final List<Type> typeArgTypes; ++ public final Type superclassType; ++ public final List<Type> superinterfaceTypes; ++ } ++ ++ public static class ClassType extends Type { ++ public ClassType(String name, List<Type> typeArgs) { ++ this.name = name; ++ this.typeArgs = typeArgs; ++ } ++ ++ @Override ++ public String toString() { ++ StringBuilder sb = new StringBuilder(); ++ sb.append(name); ++ appendIfNotEmpty(sb, "<", typeArgs, ">"); ++ return sb.toString(); ++ } ++ ++ public final String name; ++ public final List<Type> typeArgs; ++ } ++ ++ ++ public static class InnerClassType extends Type { ++ public InnerClassType(Type outerType, Type innerType) { ++ this.outerType = outerType; ++ this.innerType = innerType; ++ } ++ ++ @Override ++ public String toString() { ++ return outerType + "." + innerType; ++ } ++ ++ public final Type outerType; ++ public final Type innerType; ++ } ++ ++ public static class TypeArgType extends Type { ++ public TypeArgType(String name, Type classBound, List<Type> interfaceBounds) { ++ this.name = name; ++ this.classBound = classBound; ++ this.interfaceBounds = interfaceBounds; ++ } ++ ++ @Override ++ public String toString() { ++ StringBuilder sb = new StringBuilder(); ++ sb.append(name); ++ String sep = " extends "; ++ if (classBound != null && !classBound.isObject()) { ++ sb.append(sep); ++ sb.append(classBound); ++ sep = " & "; ++ } ++ if (interfaceBounds != null) { ++ for (Type bound: interfaceBounds) { ++ sb.append(sep); ++ sb.append(bound); ++ sep = " & "; ++ } ++ } ++ return sb.toString(); ++ } ++ ++ public final String name; ++ public final Type classBound; ++ public final List<Type> interfaceBounds; ++ } ++ ++ public static class WildcardType extends Type { ++ public WildcardType() { ++ this(null, null); ++ } ++ ++ public WildcardType(String kind, Type boundType) { ++ this.kind = kind; ++ this.boundType = boundType; ++ } ++ ++ @Override ++ public String toString() { ++ if (kind == null) ++ return "?"; ++ else ++ return "? " + kind + " " + boundType; ++ } ++ ++ public final String kind; ++ public final Type boundType; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/classfile/package.html +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/package.html Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,12 @@ ++<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> ++<html> ++ <head> ++ <title></title> ++ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> ++ </head> ++ <body> ++ A minimalist library to read and write class files into objects closely ++ based on the corresponding definitions in the Java Virtual Machine ++ Specification (JVMS). ++ </body> ++</html> +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/AnnotationWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/AnnotationWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,114 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.Annotation; ++import com.sun.tools.classfile.Annotation.Annotation_element_value; ++import com.sun.tools.classfile.Annotation.Array_element_value; ++import com.sun.tools.classfile.Annotation.Class_element_value; ++import com.sun.tools.classfile.Annotation.Enum_element_value; ++import com.sun.tools.classfile.Annotation.Primitive_element_value; ++ ++/** ++ * A writer for writing annotations as text. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class AnnotationWriter extends BasicWriter { ++ static AnnotationWriter instance(Context context) { ++ AnnotationWriter instance = context.get(AnnotationWriter.class); ++ if (instance == null) ++ instance = new AnnotationWriter(context); ++ return instance; ++ } ++ ++ protected AnnotationWriter(Context context) { ++ super(context); ++ } ++ ++ public void write(Annotation annot) { ++ print("#" + annot.type_index + "("); ++ for (int i = 0; i < annot.num_element_value_pairs; i++) { ++ if (i > 0) ++ print(","); ++ write(annot.element_value_pairs[i]); ++ } ++ print(")"); ++ } ++ ++ public void write(Annotation.element_value_pair pair) { ++ print("#" + pair.element_name_index + ":"); ++ write(pair.value); ++ } ++ ++ public void write(Annotation.element_value value) { ++ ev_writer.write(value); ++ } ++ ++ element_value_Writer ev_writer = new element_value_Writer(); ++ ++ class element_value_Writer implements Annotation.element_value.Visitor<Void,Void> { ++ public void write(Annotation.element_value value) { ++ value.accept(this, null); ++ } ++ ++ public Void visitPrimitive(Primitive_element_value ev, Void p) { ++ print(((char) ev.tag) + "#" + ev.const_value_index); ++ return null; ++ } ++ ++ public Void visitEnum(Enum_element_value ev, Void p) { ++ print(((char) ev.tag) + "#" + ev.type_name_index + ".#" + ev.const_name_index); ++ return null; ++ } ++ ++ public Void visitClass(Class_element_value ev, Void p) { ++ print(((char) ev.tag) + "#" + ev.class_info_index); ++ return null; ++ } ++ ++ public Void visitAnnotation(Annotation_element_value ev, Void p) { ++ print((char) ev.tag); ++ AnnotationWriter.this.write(ev.annotation_value); ++ return null; ++ } ++ ++ public Void visitArray(Array_element_value ev, Void p) { ++ print("["); ++ for (int i = 0; i < ev.num_values; i++) { ++ if (i > 0) ++ print(","); ++ write(ev.values[i]); ++ } ++ print("]"); ++ return null; ++ } ++ ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/AttributeWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,679 @@ ++/* ++ * 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.tools.javap; ++ ++import java.util.Formatter; ++ ++import com.sun.tools.classfile.AccessFlags; ++import com.sun.tools.classfile.AnnotationDefault_attribute; ++import com.sun.tools.classfile.Attribute; ++import com.sun.tools.classfile.Attributes; ++import com.sun.tools.classfile.CharacterRangeTable_attribute; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.CompilationID_attribute; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.ConstantValue_attribute; ++import com.sun.tools.classfile.DefaultAttribute; ++import com.sun.tools.classfile.Deprecated_attribute; ++import com.sun.tools.classfile.EnclosingMethod_attribute; ++import com.sun.tools.classfile.Exceptions_attribute; ++import com.sun.tools.classfile.Field; ++import com.sun.tools.classfile.InnerClasses_attribute; ++import com.sun.tools.classfile.LineNumberTable_attribute; ++import com.sun.tools.classfile.LocalVariableTable_attribute; ++import com.sun.tools.classfile.LocalVariableTypeTable_attribute; ++import com.sun.tools.classfile.ModuleExportTable_attribute; ++import com.sun.tools.classfile.ModuleMemberTable_attribute; ++import com.sun.tools.classfile.Module_attribute; ++import com.sun.tools.classfile.RuntimeInvisibleAnnotations_attribute; ++import com.sun.tools.classfile.RuntimeInvisibleParameterAnnotations_attribute; ++import com.sun.tools.classfile.RuntimeVisibleAnnotations_attribute; ++import com.sun.tools.classfile.RuntimeVisibleParameterAnnotations_attribute; ++import com.sun.tools.classfile.Signature_attribute; ++import com.sun.tools.classfile.SourceDebugExtension_attribute; ++import com.sun.tools.classfile.SourceFile_attribute; ++import com.sun.tools.classfile.SourceID_attribute; ++import com.sun.tools.classfile.StackMapTable_attribute; ++import com.sun.tools.classfile.StackMap_attribute; ++import com.sun.tools.classfile.Synthetic_attribute; ++ ++import static com.sun.tools.classfile.AccessFlags.*; ++ ++/* ++ * A writer for writing Attributes as text. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class AttributeWriter extends BasicWriter ++ implements Attribute.Visitor<Void,Void> ++{ ++ static AttributeWriter instance(Context context) { ++ AttributeWriter instance = context.get(AttributeWriter.class); ++ if (instance == null) ++ instance = new AttributeWriter(context); ++ return instance; ++ } ++ ++ protected AttributeWriter(Context context) { ++ super(context); ++ context.put(AttributeWriter.class, this); ++ annotationWriter = AnnotationWriter.instance(context); ++ codeWriter = CodeWriter.instance(context); ++ constantWriter = ConstantWriter.instance(context); ++ options = Options.instance(context); ++ } ++ ++ public void write(Object owner, Attribute attr, ConstantPool constant_pool) { ++ if (attr != null) { ++ // null checks ++ owner.getClass(); ++ constant_pool.getClass(); ++ this.constant_pool = constant_pool; ++ this.owner = owner; ++ attr.accept(this, null); ++ } ++ } ++ ++ public void write(Object owner, Attributes attrs, ConstantPool constant_pool) { ++ if (attrs != null) { ++ // null checks ++ owner.getClass(); ++ constant_pool.getClass(); ++ this.constant_pool = constant_pool; ++ this.owner = owner; ++ for (Attribute attr: attrs) ++ attr.accept(this, null); ++ } ++ } ++ ++ public Void visitDefault(DefaultAttribute attr, Void ignore) { ++ byte[] data = attr.info; ++ int i = 0; ++ int j = 0; ++ print(" "); ++ try { ++ print(attr.getName(constant_pool)); ++ } catch (ConstantPoolException e) { ++ report(e); ++ print("attribute name = #" + attr.attribute_name_index); ++ } ++ print(": "); ++ println("length = 0x" + toHex(attr.info.length)); ++ ++ print(" "); ++ ++ while (i < data.length) { ++ print(toHex(data[i], 2)); ++ ++ j++; ++ if (j == 16) { ++ println(); ++ print(" "); ++ j = 0; ++ } else { ++ print(" "); ++ } ++ i++; ++ } ++ println(); ++ return null; ++ } ++ ++ public Void visitAnnotationDefault(AnnotationDefault_attribute attr, Void ignore) { ++ println(" AnnotationDefault: "); ++ print(" default_value: "); ++ annotationWriter.write(attr.default_value); ++ return null; ++ } ++ ++ public Void visitCharacterRangeTable(CharacterRangeTable_attribute attr, Void ignore) { ++ print(" CharacterRangeTable: "); ++ for (int i = 0; i < attr.character_range_table.length; i++) { ++ CharacterRangeTable_attribute.Entry e = attr.character_range_table[i]; ++ print(" " + e.start_pc + ", " + ++ e.end_pc + ", " + ++ Integer.toHexString(e.character_range_start) + ", " + ++ Integer.toHexString(e.character_range_end) + ", " + ++ Integer.toHexString(e.flags) + ++ "\t// "); ++ print(e.start_pc + ", " + ++ e.end_pc + ", " + ++ (e.character_range_start >> 10) + ":" + (e.character_range_start & 0x3ff) + ", " + ++ (e.character_range_end >> 10) + ":" + (e.character_range_end & 0x3ff)); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_STATEMENT) != 0) ++ print(", statement"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_BLOCK) != 0) ++ print(", block"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_ASSIGNMENT) != 0) ++ print(", assignment"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_FLOW_CONTROLLER) != 0) ++ print(", flow-controller"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_FLOW_TARGET) != 0) ++ print(", flow-target"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_INVOKE) != 0) ++ print(", invoke"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_CREATE) != 0) ++ print(", create"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_BRANCH_TRUE) != 0) ++ print(", branch-true"); ++ if ((e.flags & CharacterRangeTable_attribute.CRT_BRANCH_FALSE) != 0) ++ print(", branch-false"); ++ ++ ++ ++ } ++ return null; ++ } ++ ++ public Void visitCode(Code_attribute attr, Void ignore) { ++ codeWriter.write(attr, constant_pool); ++ println(); ++ return null; ++ } ++ ++ public Void visitCompilationID(CompilationID_attribute attr, Void ignore) { ++ constantWriter.write(attr.compilationID_index); ++ return null; ++ } ++ ++ public Void visitConstantValue(ConstantValue_attribute attr, Void ignore) { ++ if (options.compat) // BUG 6622216 javap names some attributes incorrectly ++ print(" Constant value: "); ++ else ++ print(" ConstantValue: "); ++ constantWriter.write(attr.constantvalue_index); ++ if (!options.compat) // BUG 6622232 javap gets whitespace confused ++ println(); ++ return null; ++ } ++ ++ public Void visitDeprecated(Deprecated_attribute attr, Void ignore) { ++ if (!(options.compat && owner instanceof Field)) // BUG 6622232 javap gets whitespace confused ++ print(" "); ++ println("Deprecated: true"); ++ return null; ++ } ++ ++ public Void visitEnclosingMethod(EnclosingMethod_attribute attr, Void ignore) { ++ print(" EnclosingMethod: #" + attr.class_index + ".#" + attr.method_index ++ + "\t// " + getJavaClassName(attr)); ++ if (attr.method_index != 0) ++ print("." + getMethodName(attr)); ++ println(); ++ return null; ++ } ++ ++ private String getJavaClassName(EnclosingMethod_attribute a) { ++ try { ++ return getJavaName(a.getClassName(constant_pool)); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ private String getMethodName(EnclosingMethod_attribute a) { ++ try { ++ return a.getMethodName(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitExceptions(Exceptions_attribute attr, Void ignore) { ++ println(" Exceptions: "); ++ print(" throws "); ++ for (int i = 0; i < attr.number_of_exceptions; i++) { ++ if (i > 0) ++ print(", "); ++ print(getJavaException(attr, i)); ++ } ++ if (!options.compat) // BUG 6622232 javap gets whitespace confused ++ println(); ++ return null; ++ } ++ ++ String getJavaException(Exceptions_attribute attr, int index) { ++ try { ++ return getJavaName(attr.getException(index, constant_pool)); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitInnerClasses(InnerClasses_attribute attr, Void ignore) { ++ boolean first = true; ++ if (options.compat) { ++ writeInnerClassHeader(); ++ first = false; ++ } ++ for (int i = 0 ; i < attr.classes.length; i++) { ++ InnerClasses_attribute.Info info = attr.classes[i]; ++ //access ++ AccessFlags access_flags = info.inner_class_access_flags; ++ if (options.compat) { ++ // BUG 6622215: javap ignores certain relevant access flags ++ access_flags = access_flags.ignore(ACC_STATIC | ACC_PROTECTED | ACC_PRIVATE | ACC_INTERFACE | ACC_SYNTHETIC | ACC_ENUM); ++ // BUG 6622232: javap gets whitespace confused ++ print(" "); ++ } ++ if (options.checkAccess(access_flags)) { ++ if (first) { ++ writeInnerClassHeader(); ++ first = false; ++ } ++ if (!options.compat) // BUG 6622232: javap gets whitespace confused ++ print(" "); ++ for (String name: access_flags.getInnerClassModifiers()) ++ print(name + " "); ++ if (info.inner_name_index!=0) { ++ print("#" + info.inner_name_index + "= "); ++ } ++ print("#" + info.inner_class_info_index); ++ if (info.outer_class_info_index != 0) { ++ print(" of #" + info.outer_class_info_index); ++ } ++ print("; //"); ++ if (info.inner_name_index != 0) { ++ print(getInnerName(constant_pool, info) + "="); ++ } ++ constantWriter.write(info.inner_class_info_index); ++ if (info.outer_class_info_index != 0) { ++ print(" of "); ++ constantWriter.write(info.outer_class_info_index); ++ } ++ println(); ++ } ++ } ++ return null; ++ } ++ ++ String getInnerName(ConstantPool constant_pool, InnerClasses_attribute.Info info) { ++ try { ++ return info.getInnerName(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ private void writeInnerClassHeader() { ++ print(" "); ++ if (options.compat) // BUG 6622216: javap names some attributes incorrectly ++ print("InnerClass"); ++ else ++ print("InnerClasses"); ++ println(": "); ++ } ++ ++ public Void visitLineNumberTable(LineNumberTable_attribute attr, Void ignore) { ++ println(" LineNumberTable: "); ++ for (LineNumberTable_attribute.Entry entry: attr.line_number_table) { ++ println(" line " + entry.line_number + ": " + entry.start_pc); ++ } ++ return null; ++ } ++ ++ public Void visitLocalVariableTable(LocalVariableTable_attribute attr, Void ignore) { ++ println(" LocalVariableTable: "); ++ println(" Start Length Slot Name Signature"); ++ ++ for (LocalVariableTable_attribute.Entry entry : attr.local_variable_table) { ++ Formatter formatter = new Formatter(); ++ println(formatter.format("%8d %7d %5d %5s %s", ++ entry.start_pc, entry.length, entry.index, ++ constantWriter.stringValue(entry.name_index), ++ constantWriter.stringValue(entry.descriptor_index))); ++ } ++ return null; ++ } ++ ++ public Void visitLocalVariableTypeTable(LocalVariableTypeTable_attribute attr, Void ignore) { ++ println(" LocalVariableTypeTable: "); ++ println(" Start Length Slot Name Signature"); ++ ++ for (LocalVariableTypeTable_attribute.Entry entry : attr.local_variable_table) { ++ Formatter formatter = new Formatter(); ++ println(formatter.format("%8d %7d %5d %5s %s", ++ entry.start_pc, entry.length, entry.index, ++ constantWriter.stringValue(entry.name_index), ++ constantWriter.stringValue(entry.signature_index))); ++ } ++ return null; ++ } ++ ++ public Void visitModule(Module_attribute attr, Void ignore) { ++ println(" Module: #" + attr.module_name + "\t// " + getModuleName(attr)); ++ return null; ++ } ++ ++ String getModuleName(Module_attribute attr) { ++ try { ++ return attr.getModuleName(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitModuleExportTable(ModuleExportTable_attribute attr, Void ignore) { ++ println(" ModuleExportTable:"); ++ println(" Types: (" + attr.export_type_table.length + ")"); ++ for (int i = 0; i < attr.export_type_table.length; i++) { ++ println(" #" + attr.export_type_table[i] + "\t// " + getExportTypeName(attr, i)); ++ } ++ return null; ++ } ++ ++ String getExportTypeName(ModuleExportTable_attribute attr, int index) { ++ try { ++ return attr.getExportTypeName(index, constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitModuleMemberTable(ModuleMemberTable_attribute attr, Void ignore) { ++ println(" ModuleMemberTable:"); ++ println(" Packages: (" + attr.package_member_table.length + ")"); ++ for (int i = 0; i < attr.package_member_table.length; i++) { ++ println(" #" + attr.package_member_table[i] + "\t// " + getPackageMemberName(attr, i)); ++ } ++ return null; ++ } ++ ++ String getPackageMemberName(ModuleMemberTable_attribute attr, int index) { ++ try { ++ return attr.getPackageMemberName(index, constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitRuntimeVisibleAnnotations(RuntimeVisibleAnnotations_attribute attr, Void ignore) { ++ println(" RuntimeVisibleAnnotations: "); ++ for (int i = 0; i < attr.annotations.length; i++) { ++ print(" " + i + ": "); ++ annotationWriter.write(attr.annotations[i]); ++ println(); ++ } ++ return null; ++ } ++ ++ public Void visitRuntimeInvisibleAnnotations(RuntimeInvisibleAnnotations_attribute attr, Void ignore) { ++ println(" RuntimeInvisibleAnnotations: "); ++ for (int i = 0; i < attr.annotations.length; i++) { ++ print(" " + i + ": "); ++ annotationWriter.write(attr.annotations[i]); ++ println(); ++ } ++ return null; ++ } ++ ++ public Void visitRuntimeVisibleParameterAnnotations(RuntimeVisibleParameterAnnotations_attribute attr, Void ignore) { ++ println(" RuntimeVisibleParameterAnnotations: "); ++ for (int param = 0; param < attr.parameter_annotations.length; param++) { ++ println(" parameter " + param + ": "); ++ for (int i = 0; i < attr.parameter_annotations[param].length; i++) { ++ print(" " + i + ": "); ++ annotationWriter.write(attr.parameter_annotations[param][i]); ++ println(); ++ } ++ } ++ return null; ++ } ++ ++ public Void visitRuntimeInvisibleParameterAnnotations(RuntimeInvisibleParameterAnnotations_attribute attr, Void ignore) { ++ println(" RuntimeInvisibleParameterAnnotations: "); ++ for (int param = 0; param < attr.parameter_annotations.length; param++) { ++ println(" " + param + ": "); ++ for (int i = 0; i < attr.parameter_annotations[param].length; i++) { ++ print(" " + i + ": "); ++ annotationWriter.write(attr.parameter_annotations[param][i]); ++ println(); ++ } ++ } ++ return null; ++ } ++ ++ public Void visitSignature(Signature_attribute attr, Void ignore) { ++ println(" Signature: #" + attr.signature_index + "\t// " + getSignature(attr)); ++ return null; ++ } ++ ++ String getSignature(Signature_attribute info) { ++ try { ++ return info.getSignature(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitSourceDebugExtension(SourceDebugExtension_attribute attr, Void ignore) { ++ println(" SourceDebugExtension: " + attr.getValue()); ++ return null; ++ } ++ ++ public Void visitSourceFile(SourceFile_attribute attr, Void ignore) { ++ println(" SourceFile: \"" + getSourceFile(attr) + "\""); ++ return null; ++ } ++ ++ private String getSourceFile(SourceFile_attribute attr) { ++ try { ++ return attr.getSourceFile(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public Void visitSourceID(SourceID_attribute attr, Void ignore) { ++ constantWriter.write(attr.sourceID_index); ++ return null; ++ } ++ ++ public Void visitStackMap(StackMap_attribute attr, Void ignore) { ++ println(" StackMap: number_of_entries = " + attr.number_of_entries); ++ ++ StackMapTableWriter w = new StackMapTableWriter(); ++ for (StackMapTable_attribute.stack_map_frame entry : attr.entries) { ++ w.write(entry); ++ } ++ println(); ++ return null; ++ } ++ ++ public Void visitStackMapTable(StackMapTable_attribute attr, Void ignore) { ++ println(" StackMapTable: number_of_entries = " + attr.number_of_entries); ++ ++ StackMapTableWriter w = new StackMapTableWriter(); ++ for (StackMapTable_attribute.stack_map_frame entry : attr.entries) { ++ w.write(entry); ++ } ++ println(); ++ return null; ++ } ++ ++ class StackMapTableWriter // also handles CLDC StackMap attributes ++ implements StackMapTable_attribute.stack_map_frame.Visitor<Void,Void> { ++ public void write(StackMapTable_attribute.stack_map_frame frame) { ++ frame.accept(this, null); ++ } ++ ++ public Void visit_same_frame(StackMapTable_attribute.same_frame frame, Void p) { ++ printHeader(frame); ++ println(" /* same */"); ++ return null; ++ } ++ ++ public Void visit_same_locals_1_stack_item_frame(StackMapTable_attribute.same_locals_1_stack_item_frame frame, Void p) { ++ printHeader(frame); ++ println(" /* same_locals_1_stack_item */"); ++ printMap("stack", frame.stack); ++ return null; ++ } ++ ++ public Void visit_same_locals_1_stack_item_frame_extended(StackMapTable_attribute.same_locals_1_stack_item_frame_extended frame, Void p) { ++ printHeader(frame); ++ println(" /* same_locals_1_stack_item_frame_extended */"); ++ println(" offset_delta = " + frame.offset_delta); ++ printMap("stack", frame.stack); ++ return null; ++ } ++ ++ public Void visit_chop_frame(StackMapTable_attribute.chop_frame frame, Void p) { ++ printHeader(frame); ++ println(" /* chop */"); ++ println(" offset_delta = " + frame.offset_delta); ++ return null; ++ } ++ ++ public Void visit_same_frame_extended(StackMapTable_attribute.same_frame_extended frame, Void p) { ++ printHeader(frame); ++ println(" /* same_frame_extended */"); ++ println(" offset_delta = " + frame.offset_delta); ++ return null; ++ } ++ ++ public Void visit_append_frame(StackMapTable_attribute.append_frame frame, Void p) { ++ printHeader(frame); ++ println(" /* append */"); ++ println(" offset_delta = " + frame.offset_delta); ++ printMap("locals", frame.locals); ++ return null; ++ } ++ ++ public Void visit_full_frame(StackMapTable_attribute.full_frame frame, Void p) { ++ printHeader(frame); ++ if (frame instanceof StackMap_attribute.stack_map_frame) { ++ println(" offset = " + frame.offset_delta); ++ } else { ++ println(" /* full_frame */"); ++ println(" offset_delta = " + frame.offset_delta); ++ } ++ printMap("locals", frame.locals); ++ printMap("stack", frame.stack); ++ return null; ++ } ++ ++ void printHeader(StackMapTable_attribute.stack_map_frame frame) { ++ print(" frame_type = " + frame.frame_type); ++ } ++ ++ void printMap(String name, StackMapTable_attribute.verification_type_info[] map) { ++ print(" " + name + " = ["); ++ for (int i = 0; i < map.length; i++) { ++ StackMapTable_attribute.verification_type_info info = map[i]; ++ int tag = info.tag; ++ switch (tag) { ++ case StackMapTable_attribute.verification_type_info.ITEM_Object: ++ print(" "); ++ constantWriter.write(((StackMapTable_attribute.Object_variable_info) info).cpool_index); ++ break; ++ case StackMapTable_attribute.verification_type_info.ITEM_Uninitialized: ++ print(" " + mapTypeName(tag)); ++ print(" " + ((StackMapTable_attribute.Uninitialized_variable_info) info).offset); ++ break; ++ default: ++ print(" " + mapTypeName(tag)); ++ } ++ print(i == (map.length - 1) ? " " : ","); ++ } ++ println("]"); ++ } ++ ++ String mapTypeName(int tag) { ++ switch (tag) { ++ case StackMapTable_attribute.verification_type_info.ITEM_Top: ++ return "top"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Integer: ++ return "int"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Float: ++ return "float"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Long: ++ return "long"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Double: ++ return "double"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Null: ++ return "null"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_UninitializedThis: ++ return "this"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Object: ++ return "CP"; ++ ++ case StackMapTable_attribute.verification_type_info.ITEM_Uninitialized: ++ return "uninitialized"; ++ ++ default: ++ report("unrecognized verification_type_info tag: " + tag); ++ return "[tag:" + tag + "]"; ++ } ++ } ++ } ++ ++ public Void visitSynthetic(Synthetic_attribute attr, Void ignore) { ++ println("Synthetic: true"); ++ return null; ++ } ++ ++ static String getJavaName(String name) { ++ return name.replace('/', '.'); ++ } ++ ++ String toHex(byte b, int w) { ++ if (options.compat) // BUG 6622260: javap prints negative bytes incorrectly in hex ++ return toHex((int) b, w); ++ else ++ return toHex(b & 0xff, w); ++ } ++ ++ static String toHex(int i) { ++ return Integer.toString(i, 16).toUpperCase(); ++ } ++ ++ static String toHex(int i, int w) { ++ String s = Integer.toHexString(i).toUpperCase(); ++ while (s.length() < w) ++ s = "0" + s; ++ return s.toUpperCase(); ++ } ++ ++ private AnnotationWriter annotationWriter; ++ private CodeWriter codeWriter; ++ private ConstantWriter constantWriter; ++ private Options options; ++ ++ private ConstantPool constant_pool; ++ private Object owner; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/BasicWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/BasicWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,131 @@ ++/* ++ * 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.tools.javap; ++ ++import java.io.PrintWriter; ++ ++import com.sun.tools.classfile.AttributeException; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.DescriptorException; ++ ++/* ++ * A writer similar to a PrintWriter but which does not hide exceptions. ++ * The standard print calls are line-buffered; report calls write messages directly. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class BasicWriter { ++ protected BasicWriter(Context context) { ++ lineWriter = LineWriter.instance(context); ++ out = context.get(PrintWriter.class); ++ } ++ ++ protected void print(String s) { ++ lineWriter.print(s); ++ } ++ ++ protected void print(Object o) { ++ lineWriter.print(o == null ? null : o.toString()); ++ } ++ ++ protected void println() { ++ lineWriter.println(); ++ } ++ ++ protected void println(String s) { ++ lineWriter.print(s); ++ lineWriter.println(); ++ } ++ ++ protected void println(Object o) { ++ lineWriter.print(o == null ? null : o.toString()); ++ lineWriter.println(); ++ } ++ ++ protected String report(AttributeException e) { ++ out.println("Error: " + e.getMessage()); // i18n? ++ return "???"; ++ } ++ ++ protected String report(ConstantPoolException e) { ++ out.println("Error: " + e.getMessage()); // i18n? ++ return "???"; ++ } ++ ++ protected String report(DescriptorException e) { ++ out.println("Error: " + e.getMessage()); // i18n? ++ return "???"; ++ } ++ ++ protected String report(String msg) { ++ out.println("Error: " + msg); // i18n? ++ return "???"; ++ } ++ ++ private LineWriter lineWriter; ++ private PrintWriter out; ++ ++ private static class LineWriter { ++ static LineWriter instance(Context context) { ++ LineWriter instance = context.get(LineWriter.class); ++ if (instance == null) ++ instance = new LineWriter(context); ++ return instance; ++ } ++ ++ protected LineWriter(Context context) { ++ context.put(LineWriter.class, this); ++ out = context.get(PrintWriter.class); ++ buffer = new StringBuilder(); ++ } ++ ++ protected void print(String s) { ++ if (s == null) ++ s = "null"; ++ for (int i = 0; i < s.length(); i++) { ++ char c = s.charAt(i); ++ if (c == '\n') { ++ println(); ++ } else { ++ buffer.append(c); ++ } ++ } ++ ++ } ++ ++ protected void println() { ++ out.println(buffer); ++ buffer.setLength(0); ++ } ++ ++ private PrintWriter out; ++ private StringBuilder buffer; ++ } ++} ++ +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/ClassWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,488 @@ ++/* ++ * 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.tools.javap; ++ ++import java.util.Collection; ++import java.util.List; ++ ++import com.sun.tools.classfile.AccessFlags; ++import com.sun.tools.classfile.Attribute; ++import com.sun.tools.classfile.Attributes; ++import com.sun.tools.classfile.ClassFile; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.Descriptor; ++import com.sun.tools.classfile.DescriptorException; ++import com.sun.tools.classfile.Exceptions_attribute; ++import com.sun.tools.classfile.Field; ++import com.sun.tools.classfile.Method; ++import com.sun.tools.classfile.Signature; ++import com.sun.tools.classfile.Signature_attribute; ++import com.sun.tools.classfile.SourceFile_attribute; ++import com.sun.tools.classfile.Type; ++ ++import static com.sun.tools.classfile.AccessFlags.*; ++ ++/* ++ * The main javap class to write the contents of a class file as text. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ClassWriter extends BasicWriter { ++ static ClassWriter instance(Context context) { ++ ClassWriter instance = context.get(ClassWriter.class); ++ if (instance == null) ++ instance = new ClassWriter(context); ++ return instance; ++ } ++ ++ protected ClassWriter(Context context) { ++ super(context); ++ context.put(ClassWriter.class, this); ++ options = Options.instance(context); ++ attrWriter = AttributeWriter.instance(context); ++ codeWriter = CodeWriter.instance(context); ++ constantWriter = ConstantWriter.instance(context); ++ } ++ ++ ClassFile getClassFile() { ++ return classFile; ++ } ++ ++ Method getMethod() { ++ return method; ++ } ++ ++ public void write(ClassFile cf) { ++ classFile = cf; ++ constant_pool = classFile.constant_pool; ++ ++ Attribute sfa = cf.getAttribute(Attribute.SourceFile); ++ if (sfa instanceof SourceFile_attribute) { ++ println("Compiled from \"" + getSourceFile((SourceFile_attribute) sfa) + "\""); ++ } ++ ++ String name = getJavaName(classFile); ++ AccessFlags flags = cf.access_flags; ++ ++ writeModifiers(flags.getClassModifiers()); ++ ++ if (classFile.isClass()) ++ print("class "); ++ else if (classFile.isInterface()) ++ print("interface "); ++ ++ print(name); ++ ++ Signature_attribute sigAttr = getSignature(cf.attributes); ++ if (sigAttr == null) { ++ // use info from class file header ++ if (classFile.isClass()) { ++ if (classFile.super_class != 0 ) { ++ String sn = getJavaSuperclassName(cf); ++ if (!sn.equals("java.lang.Object") || options.compat) { // BUG XXXXXXXX ++ print(" extends "); ++ print(sn); ++ } ++ } ++ } ++ for (int i = 0; i < classFile.interfaces.length; i++) { ++ print(i == 0 ? (classFile.isClass() ? " implements " : " extends ") : ","); ++ print(getJavaInterfaceName(classFile, i)); ++ } ++ } else { ++ try { ++ Type t = sigAttr.getParsedSignature().getType(constant_pool); ++ // The signature parser cannot disambiguate between a ++ // FieldType and a ClassSignatureType that only contains a superclass type. ++ if (t instanceof Type.ClassSigType) ++ print(t); ++ else if (!t.isObject()) { ++ print(" extends "); ++ print(t); ++ } ++ } catch (ConstantPoolException e) { ++ print(report(e)); ++ } ++ } ++ ++ if (options.verbose) { ++ println(); ++ attrWriter.write(cf, cf.attributes, constant_pool); ++ println(" minor version: " + cf.minor_version); ++ println(" major version: " + cf.major_version); ++ if (!options.compat) ++ writeList(" flags: ", flags.getClassFlags(), NEWLINE); ++ constantWriter.writeConstantPool(); ++ println(); ++ } else { ++ if (!options.compat) ++ print(" "); ++ } ++ ++ println("{"); ++ writeFields(); ++ writeMethods(); ++ println("}"); ++ println(); ++ } ++ ++ void writeFields() { ++ for (Field f: classFile.fields) { ++ writeField(f); ++ } ++ } ++ ++ void writeField(Field f) { ++ if (!options.checkAccess(f.access_flags)) ++ return; ++ ++ if (!(options.showLineAndLocalVariableTables ++ || options.showDisassembled ++ || options.verbose ++ || options.showInternalSignatures ++ || options.showAllAttrs)) { ++ print(" "); ++ } ++ ++ AccessFlags flags = f.access_flags; ++ writeModifiers(flags.getFieldModifiers()); ++ Signature_attribute sigAttr = getSignature(f.attributes); ++ if (sigAttr == null) ++ print(getFieldType(f.descriptor)); ++ else { ++ try { ++ Type t = sigAttr.getParsedSignature().getType(constant_pool); ++ print(t); ++ } catch (ConstantPoolException e) { ++ // report error? ++ // fall back on non-generic descriptor ++ print(getFieldType(f.descriptor)); ++ } ++ } ++ print(" "); ++ print(getFieldName(f)); ++ print(";"); ++ println(); ++ ++ if (options.showInternalSignatures) ++ println(" Signature: " + getValue(f.descriptor)); ++ ++ if (options.verbose && !options.compat) ++ writeList(" flags: ", flags.getFieldFlags(), NEWLINE); ++ ++ if (options.showAllAttrs) { ++ for (Attribute attr: f.attributes) ++ attrWriter.write(f, attr, constant_pool); ++ println(); ++ } ++ ++ if (options.showDisassembled || options.showLineAndLocalVariableTables) ++ println(); ++ } ++ ++ void writeMethods() { ++ for (Method m: classFile.methods) ++ writeMethod(m); ++ } ++ ++ void writeMethod(Method m) { ++ if (!options.checkAccess(m.access_flags)) ++ return; ++ ++ method = m; ++ ++ if (!(options.showLineAndLocalVariableTables ++ || options.showDisassembled ++ || options.verbose ++ || options.showInternalSignatures ++ || options.showAllAttrs)) { ++ print(" "); ++ } ++ ++ AccessFlags flags = m.access_flags; ++ ++ Descriptor d; ++ Type.MethodType methodType; ++ List<? extends Type> methodExceptions; ++ ++ Signature_attribute sigAttr = getSignature(m.attributes); ++ if (sigAttr == null) { ++ d = m.descriptor; ++ methodType = null; ++ methodExceptions = null; ++ } else { ++ Signature methodSig = sigAttr.getParsedSignature(); ++ d = methodSig; ++ try { ++ methodType = (Type.MethodType) methodSig.getType(constant_pool); ++ methodExceptions = methodType.throwsTypes; ++ if (methodExceptions != null && methodExceptions.size() == 0) ++ methodExceptions = null; ++ } catch (ConstantPoolException e) { ++ // report error? ++ // fall back on standard descriptor ++ methodType = null; ++ methodExceptions = null; ++ } ++ } ++ ++ writeModifiers(flags.getMethodModifiers()); ++ if (methodType != null) { ++ writeListIfNotEmpty("<", methodType.typeArgTypes, "> "); ++ } ++ if (getName(m).equals("<init>")) { ++ print(getJavaName(classFile)); ++ print(getParameterTypes(d, flags)); ++ } else if (getName(m).equals("<clinit>")) { ++ print("{}"); ++ } else { ++ print(getReturnType(d)); ++ print(" "); ++ print(getName(m)); ++ print(getParameterTypes(d, flags)); ++ } ++ ++ Attribute e_attr = m.attributes.get(Attribute.Exceptions); ++ if (e_attr != null) { // if there are generic exceptions, there must be erased exceptions ++ if (e_attr instanceof Exceptions_attribute) { ++ Exceptions_attribute exceptions = (Exceptions_attribute) e_attr; ++ if (options.compat) { // Bug XXXXXXX whitespace ++ if (!(options.showLineAndLocalVariableTables ++ || options.showDisassembled ++ || options.verbose ++ || options.showInternalSignatures ++ || options.showAllAttrs)) { ++ print(" "); ++ } ++ print(" "); ++ } ++ print(" throws "); ++ if (methodExceptions != null) { // use generic list if available ++ writeList("", methodExceptions, ""); ++ } else { ++ for (int i = 0; i < exceptions.number_of_exceptions; i++) { ++ if (i > 0) ++ print(", "); ++ print(attrWriter.getJavaException(exceptions, i)); ++ } ++ } ++ } else { ++ report("Unexpected or invalid value for Exceptions attribute"); ++ } ++ } ++ ++ print(";"); ++ println(); ++ ++ if (options.showInternalSignatures) ++ println(" Signature: " + getValue(m.descriptor)); ++ ++ if (options.verbose && !options.compat) ++ writeList(" flags: ", flags.getMethodFlags(), NEWLINE); ++ ++ Code_attribute code = null; ++ Attribute c_attr = m.attributes.get(Attribute.Code); ++ if (c_attr != null) { ++ if (c_attr instanceof Code_attribute) ++ code = (Code_attribute) c_attr; ++ else ++ report("Unexpected or invalid value for Code attribute"); ++ } ++ ++ if (options.showDisassembled && !options.showAllAttrs) { ++ if (code != null) { ++ println(" Code:"); ++ codeWriter.writeInstrs(code); ++ codeWriter.writeExceptionTable(code); ++ } ++ println(); ++ } ++ ++ if (options.showLineAndLocalVariableTables) { ++ if (code != null) ++ attrWriter.write(code, code.attributes.get(Attribute.LineNumberTable), constant_pool); ++ println(); ++ if (code != null) ++ attrWriter.write(code, code.attributes.get(Attribute.LocalVariableTable), constant_pool); ++ println(); ++ println(); ++ } ++ ++ if (options.showAllAttrs) { ++ Attribute[] attrs = m.attributes.attrs; ++ for (Attribute attr: attrs) ++ attrWriter.write(m, attr, constant_pool); ++ ++// // the following condition is to mimic old javap ++// if (!(attrs.length > 0 && ++// attrs[attrs.length - 1] instanceof Exceptions_attribute)) ++ println(); ++ } ++ } ++ ++ void writeModifiers(Collection<String> items) { ++ for (Object item: items) { ++ print(item); ++ print(" "); ++ } ++ } ++ ++ void writeList(String prefix, Collection<?> items, String suffix) { ++ print(prefix); ++ String sep = ""; ++ for (Object item: items) { ++ print(sep); ++ print(item); ++ sep = ", "; ++ } ++ print(suffix); ++ } ++ ++ void writeListIfNotEmpty(String prefix, List<?> items, String suffix) { ++ if (items != null && items.size() > 0) ++ writeList(prefix, items, suffix); ++ } ++ ++ Signature_attribute getSignature(Attributes attributes) { ++ if (options.compat) // javap does not recognize recent attributes ++ return null; ++ return (Signature_attribute) attributes.get(Attribute.Signature); ++ } ++ ++ String adjustVarargs(AccessFlags flags, String params) { ++ if (flags.is(ACC_VARARGS) && !options.compat) { ++ int i = params.lastIndexOf("[]"); ++ if (i > 0) ++ return params.substring(0, i) + "..." + params.substring(i+2); ++ } ++ ++ return params; ++ } ++ ++ String getJavaName(ClassFile cf) { ++ try { ++ return getJavaName(cf.getName()); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ String getJavaSuperclassName(ClassFile cf) { ++ try { ++ return getJavaName(cf.getSuperclassName()); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ String getJavaInterfaceName(ClassFile cf, int index) { ++ try { ++ return getJavaName(cf.getInterfaceName(index)); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ String getFieldType(Descriptor d) { ++ try { ++ return d.getFieldType(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } catch (DescriptorException e) { ++ return report(e); ++ } ++ } ++ ++ String getReturnType(Descriptor d) { ++ try { ++ return d.getReturnType(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } catch (DescriptorException e) { ++ return report(e); ++ } ++ } ++ ++ String getParameterTypes(Descriptor d, AccessFlags flags) { ++ try { ++ return adjustVarargs(flags, d.getParameterTypes(constant_pool)); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } catch (DescriptorException e) { ++ return report(e); ++ } ++ } ++ ++ String getValue(Descriptor d) { ++ try { ++ return d.getValue(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ String getFieldName(Field f) { ++ try { ++ return f.getName(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ String getName(Method m) { ++ try { ++ return m.getName(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ static String getJavaName(String name) { ++ return name.replace('/', '.'); ++ } ++ ++ String getSourceFile(SourceFile_attribute attr) { ++ try { ++ return attr.getSourceFile(constant_pool); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ private Options options; ++ private AttributeWriter attrWriter; ++ private CodeWriter codeWriter; ++ private ConstantWriter constantWriter; ++ private ClassFile classFile; ++ private ConstantPool constant_pool; ++ private Method method; ++ private static final String NEWLINE = System.getProperty("line.separator", "\n"); ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/CodeWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,344 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.AccessFlags; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.DescriptorException; ++import com.sun.tools.classfile.Method; ++ ++import static com.sun.tools.classfile.OpCodes.*; ++ ++/* ++ * Write the contents of a Code attribute. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++class CodeWriter extends BasicWriter { ++ static CodeWriter instance(Context context) { ++ CodeWriter instance = context.get(CodeWriter.class); ++ if (instance == null) ++ instance = new CodeWriter(context); ++ return instance; ++ } ++ ++ protected CodeWriter(Context context) { ++ super(context); ++ context.put(CodeWriter.class, this); ++ attrWriter = AttributeWriter.instance(context); ++ classWriter = ClassWriter.instance(context); ++ constantWriter = ConstantWriter.instance(context); ++ } ++ ++ void write(Code_attribute attr, ConstantPool constant_pool) { ++ println(" Code:"); ++ writeVerboseHeader(attr, constant_pool); ++ writeInstrs(attr); ++ writeExceptionTable(attr); ++ attrWriter.write(attr, attr.attributes, constant_pool); ++ } ++ ++ public void writeVerboseHeader(Code_attribute attr, ConstantPool constant_pool) { ++ Method method = classWriter.getMethod(); ++ String argCount; ++ try { ++ int n = method.descriptor.getParameterCount(constant_pool); ++ if (!method.access_flags.is(AccessFlags.ACC_STATIC)) ++ ++n; // for 'this' ++ argCount = Integer.toString(n); ++ } catch (ConstantPoolException e) { ++ argCount = report(e); ++ } catch (DescriptorException e) { ++ argCount = report(e); ++ } ++ ++ println(" Stack=" + attr.max_stack + ++ ", Locals=" + attr.max_locals + ++ ", Args_size=" + argCount); ++ ++ } ++ ++ public void writeInstrs(Code_attribute attr) { ++ try { ++ for (int pc = 0; pc < attr.code_length;) { ++ print(" " + pc + ":\t"); ++ pc += writeInstr(attr, pc); ++ println(); ++ } ++ } catch (Code_attribute.InvalidIndex e) { ++ println(report(e)); ++ } ++ } ++ ++ public int writeInstr(Code_attribute attr, int pc) ++ throws Code_attribute.InvalidIndex { ++ String lP = ""; ++ int opcode = attr.getUnsignedByte(pc); ++ int opcode2; ++ String mnem; ++ switch (opcode) { ++ case opc_nonpriv: ++ case opc_priv: { ++ opcode2 = attr.getUnsignedByte(pc + 1); ++ mnem = opcName((opcode << 8) + opcode2); ++ if (mnem == null) { ++ mnem = opcName(opcode) + " " + opcode2; ++ } ++ print(mnem); ++ return 2; ++ } ++ case opc_wide: { ++ opcode2 = attr.getUnsignedByte(pc + 1); ++ mnem = opcName((opcode << 8) + opcode2); ++ if (mnem == null) { ++ print("bytecode " + opcode); ++ return 1; ++ } ++ print(mnem + " " + attr.getUnsignedShort(pc + 2)); ++ if (opcode2 == opc_iinc) { ++ print(", " + attr.getShort(pc + 4)); ++ return 6; ++ } ++ return 4; ++ } ++ } ++ mnem = opcName(opcode); ++ if (mnem == null) { ++ print("bytecode " + opcode); ++ return 1; ++ } ++ if (opcode > opc_jsr_w) { ++ print("bytecode " + opcode); ++ return 1; ++ } ++ print(opcName(opcode)); ++ switch (opcode) { ++ case opc_aload: ++ case opc_astore: ++ case opc_fload: ++ case opc_fstore: ++ case opc_iload: ++ case opc_istore: ++ case opc_lload: ++ case opc_lstore: ++ case opc_dload: ++ case opc_dstore: ++ case opc_ret: ++ print("\t" + attr.getUnsignedByte(pc + 1)); ++ return 2; ++ case opc_iinc: ++ print("\t" + attr.getUnsignedByte(pc + 1) + ", " + attr.getByte(pc + 2)); ++ return 3; ++ case opc_tableswitch: ++ { ++ int tb = align(pc + 1); ++ int default_skip = attr.getInt(tb); ++ int low = attr.getInt(tb + 4); ++ int high = attr.getInt(tb + 8); ++ int count = high - low; ++ print("{ //" + low + " to " + high); ++ for (int i = 0; i <= count; i++) { ++ print("\n\t\t" + (i + low) + ": " + lP + (pc + attr.getInt(tb + 12 + 4 * i)) + ";"); ++ } ++ print("\n\t\tdefault: " + lP + (default_skip + pc) + " }"); ++ return tb - pc + 16 + count * 4; ++ } ++ case opc_lookupswitch: ++ { ++ int tb = align(pc + 1); ++ int default_skip = attr.getInt(tb); ++ int npairs = attr.getInt(tb + 4); ++ print("{ //" + npairs); ++ for (int i = 1; i <= npairs; i++) { ++ print("\n\t\t" + attr.getInt(tb + i * 8) + ": " + lP + (pc + attr.getInt(tb + 4 + i * 8)) + ";"); ++ } ++ print("\n\t\tdefault: " + lP + (default_skip + pc) + " }"); ++ return tb - pc + (npairs + 1) * 8; ++ } ++ case opc_newarray: ++ int type = attr.getUnsignedByte(pc + 1); ++ switch (type) { ++ case T_BOOLEAN: ++ print(" boolean"); ++ break; ++ case T_BYTE: ++ print(" byte"); ++ break; ++ case T_CHAR: ++ print(" char"); ++ break; ++ case T_SHORT: ++ print(" short"); ++ break; ++ case T_INT: ++ print(" int"); ++ break; ++ case T_LONG: ++ print(" long"); ++ break; ++ case T_FLOAT: ++ print(" float"); ++ break; ++ case T_DOUBLE: ++ print(" double"); ++ break; ++ case T_CLASS: ++ print(" class"); ++ break; ++ default: ++ print(" BOGUS TYPE:" + type); ++ } ++ return 2; ++ case opc_anewarray: ++ { ++ int index = attr.getUnsignedShort(pc + 1); ++ print("\t#" + index + "; //"); ++ printConstant(index); ++ return 3; ++ } ++ case opc_sipush: ++ print("\t" + attr.getShort(pc + 1)); ++ return 3; ++ case opc_bipush: ++ print("\t" + attr.getByte(pc + 1)); ++ return 2; ++ case opc_ldc: ++ { ++ int index = attr.getUnsignedByte(pc + 1); ++ print("\t#" + index + "; //"); ++ printConstant(index); ++ return 2; ++ } ++ case opc_ldc_w: ++ case opc_ldc2_w: ++ case opc_instanceof: ++ case opc_checkcast: ++ case opc_new: ++ case opc_putstatic: ++ case opc_getstatic: ++ case opc_putfield: ++ case opc_getfield: ++ case opc_invokevirtual: ++ case opc_invokespecial: ++ case opc_invokestatic: ++ { ++ int index = attr.getUnsignedShort(pc + 1); ++ print("\t#" + index + "; //"); ++ printConstant(index); ++ return 3; ++ } ++ case opc_invokeinterface: ++ { ++ int index = attr.getUnsignedShort(pc + 1); ++ int nargs = attr.getUnsignedByte(pc + 3); ++ print("\t#" + index + ", " + nargs + "; //"); ++ printConstant(index); ++ return 5; ++ } ++ case opc_multianewarray: ++ { ++ int index = attr.getUnsignedShort(pc + 1); ++ int dimensions = attr.getUnsignedByte(pc + 3); ++ print("\t#" + index + ", " + dimensions + "; //"); ++ printConstant(index); ++ return 4; ++ } ++ case opc_jsr: ++ case opc_goto: ++ case opc_ifeq: ++ case opc_ifge: ++ case opc_ifgt: ++ case opc_ifle: ++ case opc_iflt: ++ case opc_ifne: ++ case opc_if_icmpeq: ++ case opc_if_icmpne: ++ case opc_if_icmpge: ++ case opc_if_icmpgt: ++ case opc_if_icmple: ++ case opc_if_icmplt: ++ case opc_if_acmpeq: ++ case opc_if_acmpne: ++ case opc_ifnull: ++ case opc_ifnonnull: ++ print("\t" + lP + (pc + attr.getShort(pc + 1))); ++ return 3; ++ case opc_jsr_w: ++ case opc_goto_w: ++ print("\t" + lP + (pc + attr.getInt(pc + 1))); ++ return 5; ++ default: ++ return 1; ++ } ++ } ++ ++ public void writeExceptionTable(Code_attribute attr) { ++ if (attr.exception_table_langth > 0) { ++ println(" Exception table:"); ++ println(" from to target type"); ++ for (int i = 0; i < attr.exception_table.length; i++) { ++ Code_attribute.Exception_data handler = attr.exception_table[i]; ++ printFixedWidthInt(handler.start_pc, 6); ++ printFixedWidthInt(handler.end_pc, 6); ++ printFixedWidthInt(handler.handler_pc, 6); ++ print(" "); ++ int catch_type = handler.catch_type; ++ if (catch_type == 0) { ++ println("any"); ++ } else { ++ print("Class "); ++ println(constantWriter.stringValue(catch_type)); ++ println(""); ++ } ++ } ++ } ++ ++ } ++ ++ private void printConstant(int index) { ++ constantWriter.write(index); ++ } ++ ++ private void printFixedWidthInt(int n, int width) { ++ String s = String.valueOf(n); ++ for (int i = s.length(); i < width; i++) ++ print(" "); ++ print(s); ++ } ++ ++ private static int align(int n) { ++ return (n + 3) & ~3; ++ } ++ ++ private AttributeWriter attrWriter; ++ private ClassWriter classWriter; ++ private ConstantWriter constantWriter; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/ConstantWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,352 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.ClassFile; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++ ++import static com.sun.tools.classfile.ConstantPool.*; ++ ++/* ++ * Write a constant pool entry. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class ConstantWriter extends BasicWriter { ++ static ConstantWriter instance(Context context) { ++ ConstantWriter instance = context.get(ConstantWriter.class); ++ if (instance == null) ++ instance = new ConstantWriter(context); ++ return instance; ++ } ++ ++ protected ConstantWriter(Context context) { ++ super(context); ++ context.put(ConstantWriter.class, this); ++ classWriter = ClassWriter.instance(context); ++ options = Options.instance(context); ++ } ++ ++ void writeConstantPool() { ++ ConstantPool.Visitor<Integer, Void> v = new ConstantPool.Visitor<Integer,Void>() { ++ public Integer visitClass(CONSTANT_Class_info info, Void p) { ++ println("#" + info.name_index + ";\t// " + stringValue(info)); ++ return 1; ++ } ++ ++ public Integer visitDouble(CONSTANT_Double_info info, Void p) { ++ println(stringValue(info) + ";"); ++ return 2; ++ } ++ ++ public Integer visitFieldref(CONSTANT_Fieldref_info info, Void p) { ++ println("#" + info.class_index + ".#" + info.name_and_type_index + ";\t// " + stringValue(info)); ++ return 1; ++ } ++ ++ public Integer visitFloat(CONSTANT_Float_info info, Void p) { ++ println(stringValue(info) + ";"); ++ return 1; ++ } ++ ++ public Integer visitInteger(CONSTANT_Integer_info info, Void p) { ++ println(stringValue(info) + ";"); ++ return 1; ++ } ++ ++ public Integer visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, Void p) { ++ println("#" + info.class_index + ".#" + info.name_and_type_index + ";\t// " + stringValue(info)); ++ return 1; ++ } ++ ++ public Integer visitLong(CONSTANT_Long_info info, Void p) { ++ println(stringValue(info) + ";"); ++ return 2; ++ } ++ ++ public Integer visitNameAndType(CONSTANT_NameAndType_info info, Void p) { ++ String tab = (options.compat ? "" : "\t"); // BUG 6622232 javap gets whitespace confused ++ println("#" + info.name_index + ":#" + info.type_index + ";" + tab + "// " + stringValue(info)); ++ return 1; ++ } ++ ++ public Integer visitMethodref(CONSTANT_Methodref_info info, Void p) { ++ println("#" + info.class_index + ".#" + info.name_and_type_index + ";\t// " + stringValue(info)); ++ return 1; ++ } ++ ++ public Integer visitString(CONSTANT_String_info info, Void p) { ++ println("#" + info.string_index + ";\t// " + stringValue(info)); ++ return 1; ++ } ++ ++ public Integer visitUtf8(CONSTANT_Utf8_info info, Void p) { ++ println(stringValue(info) + ";"); ++ return 1; ++ } ++ ++ }; ++ println(" Constant pool:"); ++ ConstantPool constant_pool = classWriter.getClassFile().constant_pool; ++ int cpx = 1; ++ while (cpx < constant_pool.size()) { ++ try { ++ CPInfo cpInfo = constant_pool.get(cpx); ++ print("const #" + cpx + " = " + tagName(cpInfo.getTag()) + "\t"); ++ cpx += cpInfo.accept(v, null); ++ } catch (ConstantPool.InvalidIndex ex) { ++ print("const #" + cpx); // should not happen ++ } ++ } ++ } ++ ++ void write(int cpx) { ++ ClassFile classFile = classWriter.getClassFile(); ++ if (cpx == 0) { ++ print("#0"); ++ return; ++ } ++ ++ CPInfo cpInfo; ++ try { ++ cpInfo = classFile.constant_pool.get(cpx); ++ } catch (ConstantPoolException e) { ++ print("#" + cpx); ++ return; ++ } ++ ++ int tag = cpInfo.getTag(); ++ switch (tag) { ++ case CONSTANT_Methodref: ++ case CONSTANT_InterfaceMethodref: ++ case CONSTANT_Fieldref: ++ // simplify references within this class ++ CPRefInfo ref = (CPRefInfo) cpInfo; ++ try { ++ if (ref.class_index == classFile.this_class) ++ cpInfo = classFile.constant_pool.get(ref.name_and_type_index); ++ } catch (ConstantPool.InvalidIndex e) { ++ // ignore, for now ++ } ++ } ++ print(tagName(tag) + " " + stringValue(cpInfo)); ++ } ++ ++ String tagName(int tag) { ++ switch (tag) { ++ case CONSTANT_Utf8: ++ return "Asciz"; ++ case CONSTANT_Integer: ++ return "int"; ++ case CONSTANT_Float: ++ return "float"; ++ case CONSTANT_Long: ++ return "long"; ++ case CONSTANT_Double: ++ return "double"; ++ case CONSTANT_Class: ++ return "class"; ++ case CONSTANT_String: ++ return "String"; ++ case CONSTANT_Fieldref: ++ return "Field"; ++ case CONSTANT_Methodref: ++ return "Method"; ++ case CONSTANT_InterfaceMethodref: ++ return "InterfaceMethod"; ++ case CONSTANT_NameAndType: ++ return "NameAndType"; ++ default: ++ return "unknown tag"; ++ } ++ } ++ ++ String stringValue(int constant_pool_index) { ++ ClassFile classFile = classWriter.getClassFile(); ++ try { ++ return stringValue(classFile.constant_pool.get(constant_pool_index)); ++ } catch (ConstantPool.InvalidIndex e) { ++ return report(e); ++ } ++ } ++ ++ String stringValue(CPInfo cpInfo) { ++ return stringValueVisitor.visit(cpInfo); ++ } ++ ++ StringValueVisitor stringValueVisitor = new StringValueVisitor(); ++ ++ private class StringValueVisitor implements ConstantPool.Visitor<String, Void> { ++ public String visit(CPInfo info) { ++ return info.accept(this, null); ++ } ++ ++ public String visitClass(CONSTANT_Class_info info, Void p) { ++ return getCheckedName(info); ++ } ++ ++ String getCheckedName(CONSTANT_Class_info info) { ++ try { ++ return checkName(info.getName()); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public String visitDouble(CONSTANT_Double_info info, Void p) { ++ return info.value + "d"; ++ } ++ ++ public String visitFieldref(CONSTANT_Fieldref_info info, Void p) { ++ return visitRef(info, p); ++ } ++ ++ public String visitFloat(CONSTANT_Float_info info, Void p) { ++ return info.value + "f"; ++ } ++ ++ public String visitInteger(CONSTANT_Integer_info info, Void p) { ++ return String.valueOf(info.value); ++ } ++ ++ public String visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, Void p) { ++ return visitRef(info, p); ++ } ++ ++ public String visitLong(CONSTANT_Long_info info, Void p) { ++ return info.value + "l"; ++ } ++ ++ public String visitNameAndType(CONSTANT_NameAndType_info info, Void p) { ++ return getCheckedName(info) + ":" + getType(info); ++ } ++ ++ String getCheckedName(CONSTANT_NameAndType_info info) { ++ try { ++ return checkName(info.getName()); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ String getType(CONSTANT_NameAndType_info info) { ++ try { ++ return info.getType(); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public String visitMethodref(CONSTANT_Methodref_info info, Void p) { ++ return visitRef(info, p); ++ } ++ ++ public String visitString(CONSTANT_String_info info, Void p) { ++ try { ++ ClassFile classFile = classWriter.getClassFile(); ++ int string_index = info.string_index; ++ return stringValue(classFile.constant_pool.getUTF8Info(string_index)); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ ++ public String visitUtf8(CONSTANT_Utf8_info info, Void p) { ++ String s = info.value; ++ StringBuilder sb = new StringBuilder(); ++ for (int i = 0; i < s.length(); i++) { ++ char c = s.charAt(i); ++ switch (c) { ++ case '\t': ++ sb.append('\\').append('t'); ++ break; ++ case '\n': ++ sb.append('\\').append('n'); ++ break; ++ case '\r': ++ sb.append('\\').append('r'); ++ break; ++ case '\"': ++ sb.append('\\').append('\"'); ++ break; ++ default: ++ sb.append(c); ++ } ++ } ++ return sb.toString(); ++ } ++ ++ String visitRef(CPRefInfo info, Void p) { ++ String cn = getCheckedClassName(info); ++ String nat; ++ try { ++ nat = stringValue(info.getNameAndTypeInfo()); ++ } catch (ConstantPoolException e) { ++ nat = report(e); ++ } ++ return cn + "." + nat; ++ } ++ ++ String getCheckedClassName(CPRefInfo info) { ++ try { ++ return checkName(info.getClassName()); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ } ++ ++ ++ /* If name is a valid binary name, return it; otherwise quote it. */ ++ private static String checkName(String name) { ++ if (name == null) ++ return "null"; ++ ++ int len = name.length(); ++ if (len == 0) ++ return "\"\""; ++ ++ int cc = '/'; ++ int cp; ++ for (int k = 0; k < len; k += Character.charCount(cp)) { ++ cp = name.codePointAt(k); ++ if ((cc == '/' && !Character.isJavaIdentifierStart(cp)) ++ || (cp != '/' && !Character.isJavaIdentifierPart(cp))) { ++ return "\"" + name + "\""; ++ } ++ cc = cp; ++ } ++ ++ return name; ++ } ++ ++ private ClassWriter classWriter; ++ private Options options; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/Context.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/Context.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,55 @@ ++/* ++ * 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.tools.javap; ++ ++import java.util.HashMap; ++import java.util.Map; ++ ++/* ++ * Class from which to put/get shared resources. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Context { ++ public Context() { ++ map = new HashMap<Class<?>, Object>(); ++ } ++ ++ @SuppressWarnings("unchecked") ++ public <T> T get(Class<T> key) { ++ return (T) map.get(key); ++ } ++ ++ @SuppressWarnings("unchecked") ++ public <T> T put(Class<T> key, T value) { ++ return (T) map.put(key, value); ++ } ++ ++ Map<Class<?>, Object> map; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/DisassemblerTool.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/DisassemblerTool.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,150 @@ ++/* ++ * Copyright 2005-2006 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.tools.javap; //javax.tools; ++ ++import java.io.Writer; ++import java.nio.charset.Charset; ++import java.util.Locale; ++import java.util.concurrent.Callable; ++import javax.tools.DiagnosticListener; ++import javax.tools.JavaFileManager; ++import javax.tools.JavaFileObject; ++import javax.tools.OptionChecker; ++import javax.tools.StandardJavaFileManager; ++import javax.tools.Tool; ++ ++/** ++ * This class is intended to be put in javax.tools. ++ * ++ * @see DiagnosticListener ++ * @see Diagnostic ++ * @see JavaFileManager ++ * @since 1.6 ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public interface DisassemblerTool extends Tool, OptionChecker { ++ ++ /** ++ * Creates a future for a disassembly task with the given ++ * components and arguments. The task might not have ++ * completed as described in the DissemblerTask interface. ++ * ++ * <p>If a file manager is provided, it must be able to handle all ++ * locations defined in {@link StandardLocation}. ++ * ++ * @param out a Writer for additional output from the compiler; ++ * use {@code System.err} if {@code null} ++ * @param fileManager a file manager; if {@code null} use the ++ * compiler's standard filemanager ++ * @param diagnosticListener a diagnostic listener; if {@code ++ * null} use the compiler's default method for reporting ++ * diagnostics ++ * @param options compiler options, {@code null} means no options ++ * @param classes class names (for annotation processing), {@code ++ * null} means no class names ++ * @param compilationUnits the compilation units to compile, {@code ++ * null} means no compilation units ++ * @return an object representing the compilation ++ * @throws RuntimeException if an unrecoverable error ++ * occurred in a user supplied component. The ++ * {@linkplain Throwable#getCause() cause} will be the error in ++ * user code. ++ * @throws IllegalArgumentException if any of the given ++ * compilation units are of other kind than ++ * {@linkplain JavaFileObject.Kind#SOURCE source} ++ */ ++ DisassemblerTask getTask(Writer out, ++ JavaFileManager fileManager, ++ DiagnosticListener<? super JavaFileObject> diagnosticListener, ++ Iterable<String> options, ++ Iterable<String> classes); ++ ++ /** ++ * Gets a new instance of the standard file manager implementation ++ * for this tool. The file manager will use the given diagnostic ++ * listener for producing any non-fatal diagnostics. Fatal errors ++ * will be signalled with the appropriate exceptions. ++ * ++ * <p>The standard file manager will be automatically reopened if ++ * it is accessed after calls to {@code flush} or {@code close}. ++ * The standard file manager must be usable with other tools. ++ * ++ * @param diagnosticListener a diagnostic listener for non-fatal ++ * diagnostics; if {@code null} use the compiler's default method ++ * for reporting diagnostics ++ * @param locale the locale to apply when formatting diagnostics; ++ * {@code null} means the {@linkplain Locale#getDefault() default locale}. ++ * @param charset the character set used for decoding bytes; if ++ * {@code null} use the platform default ++ * @return the standard file manager ++ */ ++ StandardJavaFileManager getStandardFileManager( ++ DiagnosticListener<? super JavaFileObject> diagnosticListener, ++ Locale locale, ++ Charset charset); ++ ++ /** ++ * Interface representing a future for a disassembly task. The ++ * task has not yet started. To start the task, call ++ * the {@linkplain #call call} method. ++ * ++ * <p>Before calling the call method, additional aspects of the ++ * task can be configured, for example, by calling the ++ * {@linkplain #setLocale setLocale} method. ++ */ ++ interface DisassemblerTask extends Callable<Boolean> { ++ ++ /** ++ * Set the locale to be applied when formatting diagnostics and ++ * other localized data. ++ * ++ * @param locale the locale to apply; {@code null} means apply no ++ * locale ++ * @throws IllegalStateException if the task has started ++ */ ++ void setLocale(Locale locale); ++ ++ /** ++ * Performs this compilation task. The compilation may only ++ * be performed once. Subsequent calls to this method throw ++ * IllegalStateException. ++ * ++ * @return true if and only all the files compiled without errors; ++ * false otherwise ++ * ++ * @throws RuntimeException if an unrecoverable error occurred ++ * in a user-supplied component. The ++ * {@linkplain Throwable#getCause() cause} will be the error ++ * in user code. ++ * @throws IllegalStateException if called more than once ++ */ ++ Boolean call(); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/InternalError.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/InternalError.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,46 @@ ++/* ++ * 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.tools.javap; ++ ++/** ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class InternalError extends Error { ++ InternalError(Throwable t, Object... args) { ++ super("Internal error", t); ++ this.args = args; ++ } ++ ++ InternalError(Object... args) { ++ super("Internal error"); ++ this.args = args; ++ } ++ ++ public final Object[] args; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/JavapFileManager.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapFileManager.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,86 @@ ++/* ++ * 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.tools.javap; ++ ++import java.io.File; ++import java.io.PrintWriter; ++import java.nio.charset.Charset; ++import javax.tools.Diagnostic; ++import javax.tools.DiagnosticListener; ++import javax.tools.JavaFileObject; ++ ++import com.sun.tools.javac.file.JavacFileManager; ++import com.sun.tools.javac.util.Context; ++import com.sun.tools.javac.util.JCDiagnostic; ++ ++/** ++ * javap's implementation of JavaFileManager. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++class JavapFileManager extends JavacFileManager { ++ private JavapFileManager(Context context, Charset charset) { ++ super(context, true, charset); ++ } ++ ++ static JavapFileManager create(final DiagnosticListener<? super JavaFileObject> dl, PrintWriter log, Options options) { ++ Context javac_context = new Context(); ++ ++ if (dl != null) { ++ // Workaround bug 6625520: javac handles missing entries on classpath badly ++ // Ignore spurious errors for missing files ++ DiagnosticListener<JavaFileObject> wrapper = new DiagnosticListener<JavaFileObject>() { ++ public void report(Diagnostic<? extends JavaFileObject> diagnostic) { ++ if (diagnostic instanceof JCDiagnostic) { ++ JCDiagnostic jcd = (JCDiagnostic) diagnostic; ++ if (jcd.getCode().equals("compiler.err.error.reading.file")) { ++ Object[] args = jcd.getArgs(); ++ if (args.length > 0 && args[0] != null && args[0].toString().length() > 0) { ++ File f = new File(args[0].toString()); ++ if (!f.exists()) ++ return; ++ } ++ } ++ ++ } ++ dl.report(diagnostic); ++ } ++ }; ++ javac_context.put(DiagnosticListener.class, wrapper); ++ } ++ ++ javac_context.put(com.sun.tools.javac.util.Log.outKey, log); ++ ++ return new JavapFileManager(javac_context, null); ++ } ++ ++ void setIgnoreSymbolFile(boolean b) { ++ ignoreSymbolFile = b; ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/JavapTask.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,624 @@ ++/* ++ * 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-15301 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.tools.javap; ++ ++import java.io.EOFException; ++import java.io.FileNotFoundException; ++import java.io.IOException; ++import java.io.OutputStream; ++import java.io.PrintWriter; ++import java.io.StringWriter; ++import java.io.Writer; ++import java.text.MessageFormat; ++import java.util.ArrayList; ++import java.util.Arrays; ++import java.util.HashMap; ++import java.util.Iterator; ++import java.util.List; ++import java.util.Locale; ++import java.util.Map; ++import java.util.MissingResourceException; ++import java.util.ResourceBundle; ++ ++import javax.tools.Diagnostic; ++import javax.tools.DiagnosticListener; ++import javax.tools.JavaFileManager; ++import javax.tools.JavaFileObject; ++import javax.tools.StandardJavaFileManager; ++import javax.tools.StandardLocation; ++ ++import com.sun.tools.classfile.*; ++ ++/** ++ * "Main" class for javap, normally accessed from the command line ++ * via Main, or from JSR199 via DisassemblerTool. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class JavapTask implements DisassemblerTool.DisassemblerTask { ++ public class BadArgs extends Exception { ++ static final long serialVersionUID = 8765093759964640721L; ++ BadArgs(String key, Object... args) { ++ super(JavapTask.this.getMessage(key, args)); ++ this.key = key; ++ this.args = args; ++ } ++ ++ BadArgs showUsage(boolean b) { ++ showUsage = b; ++ return this; ++ } ++ ++ final String key; ++ final Object[] args; ++ boolean showUsage; ++ } ++ ++ static abstract class Option { ++ Option(boolean hasArg, String... aliases) { ++ this.hasArg = hasArg; ++ this.aliases = aliases; ++ } ++ ++ boolean matches(String opt) { ++ for (String a: aliases) { ++ if (a.equals(opt)) ++ return true; ++ } ++ return false; ++ } ++ ++ boolean ignoreRest() { ++ return false; ++ } ++ ++ abstract void process(JavapTask task, String opt, String arg) throws BadArgs; ++ ++ final boolean hasArg; ++ final String[] aliases; ++ } ++ ++ static Option[] recognizedOptions = { ++ ++ new Option(false, "-help", "--help", "-?") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.help = true; ++ } ++ }, ++ ++ new Option(false, "-version") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.version = true; ++ } ++ }, ++ ++ new Option(false, "-fullversion") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.fullVersion = true; ++ } ++ }, ++ ++ new Option(false, "-v", "-verbose", "-all") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.verbose = true; ++ task.options.showFlags = true; ++ task.options.showAllAttrs = true; ++ } ++ }, ++ ++ new Option(false, "-l") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showLineAndLocalVariableTables = true; ++ } ++ }, ++ ++ new Option(false, "-public") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showAccess = AccessFlags.ACC_PUBLIC; ++ } ++ }, ++ ++ new Option(false, "-protected") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showAccess = AccessFlags.ACC_PROTECTED; ++ } ++ }, ++ ++ new Option(false, "-package") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showAccess = 0; ++ } ++ }, ++ ++ new Option(false, "-p", "-private") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showAccess = AccessFlags.ACC_PRIVATE; ++ } ++ }, ++ ++ new Option(false, "-c") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showDisassembled = true; ++ } ++ }, ++ ++ new Option(false, "-s") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showInternalSignatures = true; ++ } ++ }, ++ ++// new Option(false, "-all") { ++// void process(JavapTask task, String opt, String arg) { ++// task.options.showAllAttrs = true; ++// } ++// }, ++ ++ new Option(false, "-h") { ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ throw task.new BadArgs("err.h.not.supported"); ++ } ++ }, ++ ++ new Option(false, "-verify", "-verify-verbose") { ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ throw task.new BadArgs("err.verify.not.supported"); ++ } ++ }, ++ ++ new Option(false, "-Xold") { ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ // -Xold is only supported as first arg when invoked from ++ // command line; this is handled in Main,main ++ throw task.new BadArgs("err.Xold.not.supported.here"); ++ } ++ }, ++ ++ new Option(false, "-Xnew") { ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ // ignore: this _is_ the new version ++ } ++ }, ++ ++ new Option(false, "-XDcompat") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.compat = true; ++ } ++ }, ++ ++ new Option(false, "-XDjsr277") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.jsr277 = true; ++ } ++ }, ++ ++ new Option(false, "-XDignore.symbol.file") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.ignoreSymbolFile = true; ++ } ++ } ++ ++ }; ++ ++ JavapTask() { ++ context = new Context(); ++ options = Options.instance(context); ++ } ++ ++ JavapTask(Writer out, ++ JavaFileManager fileManager, ++ DiagnosticListener<? super JavaFileObject> diagnosticListener, ++ Iterable<String> options, ++ Iterable<String> classes) { ++ this(); ++ this.log = getPrintWriterForWriter(out); ++ this.fileManager = fileManager; ++ this.diagnosticListener = diagnosticListener; ++ ++ try { ++ handleOptions(options, false); ++ } catch (BadArgs e) { ++ throw new IllegalArgumentException(e.getMessage()); ++ } ++ ++ this.classes = new ArrayList<String>(); ++ for (String classname: classes) { ++ classname.getClass(); // null-check ++ this.classes.add(classname); ++ } ++ } ++ ++ public void setLocale(Locale locale) { ++ if (locale == null) ++ locale = Locale.getDefault(); ++ task_locale = locale; ++ } ++ ++ public void setLog(PrintWriter log) { ++ this.log = log; ++ } ++ ++ public void setLog(OutputStream s) { ++ setLog(getPrintWriterForStream(s)); ++ } ++ ++ private static PrintWriter getPrintWriterForStream(OutputStream s) { ++ return new PrintWriter(s, true); ++ } ++ ++ private static PrintWriter getPrintWriterForWriter(Writer w) { ++ if (w == null) ++ return getPrintWriterForStream(null); ++ else if (w instanceof PrintWriter) ++ return (PrintWriter) w; ++ else ++ return new PrintWriter(w, true); ++ } ++ ++ public void setDiagnosticListener(DiagnosticListener<? super JavaFileObject> dl) { ++ diagnosticListener = dl; ++ } ++ ++ public void setDiagnosticListener(OutputStream s) { ++ setDiagnosticListener(getDiagnosticListenerForStream(s)); ++ } ++ ++ private DiagnosticListener<JavaFileObject> getDiagnosticListenerForStream(OutputStream s) { ++ return getDiagnosticListenerForWriter(getPrintWriterForStream(s)); ++ } ++ ++ private DiagnosticListener<JavaFileObject> getDiagnosticListenerForWriter(Writer w) { ++ final PrintWriter pw = getPrintWriterForWriter(w); ++ return new DiagnosticListener<JavaFileObject> () { ++ public void report(Diagnostic<? extends JavaFileObject> diagnostic) { ++ if (diagnostic.getKind() == Diagnostic.Kind.ERROR) { ++ pw.print(getMessage("err.prefix")); ++ pw.print(" "); ++ } ++ pw.println(diagnostic.getMessage(null)); ++ } ++ }; ++ } ++ ++ int run(String[] args) { ++ try { ++ handleOptions(args); ++ boolean ok = run(); ++ return ok ? 0 : 1; ++ } catch (BadArgs e) { ++ diagnosticListener.report(createDiagnostic(e.key, e.args)); ++ return 1; ++ } catch (InternalError e) { ++ Object[] e_args; ++ if (e.getCause() == null) ++ e_args = e.args; ++ else { ++ e_args = new Object[e.args.length + 1]; ++ e_args[0] = e.getCause(); ++ System.arraycopy(e.args, 0, e_args, 1, e.args.length); ++ } ++ diagnosticListener.report(createDiagnostic("err.internal.error", e_args)); ++ return 1; ++ } finally { ++ log.flush(); ++ } ++ } ++ ++ public void handleOptions(String[] args) throws BadArgs { ++ handleOptions(Arrays.asList(args), true); ++ } ++ ++ private void handleOptions(Iterable<String> args, boolean allowClasses) throws BadArgs { ++ if (log == null) { ++ log = getPrintWriterForStream(System.out); ++ if (diagnosticListener == null) ++ diagnosticListener = getDiagnosticListenerForStream(System.err); ++ } else { ++ if (diagnosticListener == null) ++ diagnosticListener = getDiagnosticListenerForWriter(log); ++ } ++ ++ ++ if (fileManager == null) ++ fileManager = getDefaultFileManager(diagnosticListener, log); ++ ++ Iterator<String> iter = args.iterator(); ++ if (!iter.hasNext()) ++ options.help = true; ++ ++ while (iter.hasNext()) { ++ String arg = iter.next(); ++ if (arg.startsWith("-")) ++ handleOption(arg, iter); ++ else if (allowClasses) { ++ if (classes == null) ++ classes = new ArrayList<String>(); ++ classes.add(arg); ++ while (iter.hasNext()) ++ classes.add(iter.next()); ++ } else ++ throw new BadArgs("err.unknown.option", arg).showUsage(true); ++ } ++ ++ if (options.ignoreSymbolFile && fileManager instanceof JavapFileManager) ++ ((JavapFileManager) fileManager).setIgnoreSymbolFile(true); ++ ++ if ((classes == null || classes.size() == 0) && ++ !(options.help || options.version || options.fullVersion)) { ++ throw new BadArgs("err.no.classes.specified"); ++ } ++ } ++ ++ private void handleOption(String name, Iterator<String> rest) throws BadArgs { ++ for (Option o: recognizedOptions) { ++ if (o.matches(name)) { ++ if (o.hasArg) { ++ if (rest.hasNext()) ++ o.process(this, name, rest.next()); ++ else ++ throw new BadArgs("err.missing.arg", name).showUsage(true); ++ } else ++ o.process(this, name, null); ++ ++ if (o.ignoreRest()) { ++ while (rest.hasNext()) ++ rest.next(); ++ } ++ return; ++ } ++ } ++ ++ if (fileManager.handleOption(name, rest)) ++ return; ++ ++ throw new BadArgs("err.unknown.option", name).showUsage(true); ++ } ++ ++ public Boolean call() { ++ return run(); ++ } ++ ++ public boolean run() { ++ if (options.help) ++ showHelp(); ++ ++ if (options.version || options.fullVersion) ++ showVersion(options.fullVersion); ++ ++ if (classes == null || classes.size() == 0) ++ return true; ++ ++ context.put(PrintWriter.class, log); ++ ClassWriter classWriter = ClassWriter.instance(context); ++ ++ boolean ok = true; ++ ++ for (String className: classes) { ++ JavaFileObject fo; ++ try { ++ if (className.endsWith(".class")) { ++ if (fileManager instanceof StandardJavaFileManager) { ++ StandardJavaFileManager sfm = (StandardJavaFileManager) fileManager; ++ fo = sfm.getJavaFileObjects(className).iterator().next(); ++ } else { ++ diagnosticListener.report(createDiagnostic("err.not.standard.file.manager", className)); ++ ok = false; ++ continue; ++ } ++ } else { ++ fo = getClassFileObject(className); ++ if (fo == null) { ++ // see if it is an inner class, by replacing dots to $, starting from the right ++ String cn = className; ++ int lastDot; ++ while (fo == null && (lastDot = cn.lastIndexOf(".")) != -1) { ++ cn = cn.substring(0, lastDot) + "$" + cn.substring(lastDot + 1); ++ fo = getClassFileObject(cn); ++ } ++ } ++ if (fo == null) { ++ diagnosticListener.report(createDiagnostic("err.class.not.found", className)); ++ ok = false; ++ continue; ++ } ++ } ++ Attribute.Factory attributeFactory = new Attribute.Factory(); ++ attributeFactory.setCompat(options.compat); ++ attributeFactory.setJSR277(options.jsr277); ++ ClassFile cf = ClassFile.read(fo.openInputStream(), attributeFactory); ++ classWriter.write(cf); ++ } catch (ConstantPoolException e) { ++ diagnosticListener.report(createDiagnostic("err.bad.constant.pool", className, e.getLocalizedMessage())); ++ ok = false; ++ } catch (EOFException e) { ++ diagnosticListener.report(createDiagnostic("err.end.of.file", className)); ++ ok = false; ++ } catch (FileNotFoundException e) { ++ diagnosticListener.report(createDiagnostic("err.file.not.found", e.getLocalizedMessage())); ++ ok = false; ++ } catch (IOException e) { ++ //e.printStackTrace(); ++ Object msg = e.getLocalizedMessage(); ++ if (msg == null) ++ msg = e; ++ diagnosticListener.report(createDiagnostic("err.ioerror", className, msg)); ++ ok = false; ++ } catch (Throwable t) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ t.printStackTrace(pw); ++ pw.close(); ++ diagnosticListener.report(createDiagnostic("err.crash", t.toString(), sw.toString())); ++ } ++ } ++ ++ return ok; ++ } ++ ++ private JavaFileManager getDefaultFileManager(final DiagnosticListener<? super JavaFileObject> dl, PrintWriter log) { ++ return JavapFileManager.create(dl, log, options); ++ } ++ ++ private JavaFileObject getClassFileObject(String className) throws IOException { ++ JavaFileObject fo; ++ fo = fileManager.getJavaFileForInput(StandardLocation.PLATFORM_CLASS_PATH, className, JavaFileObject.Kind.CLASS); ++ if (fo == null) ++ fo = fileManager.getJavaFileForInput(StandardLocation.CLASS_PATH, className, JavaFileObject.Kind.CLASS); ++ return fo; ++ } ++ ++ private void showHelp() { ++ log.println(getMessage("main.usage", progname)); ++ for (Option o: recognizedOptions) { ++ String name = o.aliases[0].substring(1); // there must always be at least one name ++ if (name.startsWith("X") || name.equals("fullversion") || name.equals("h") || name.equals("verify")) ++ continue; ++ log.println(getMessage("main.opt." + name)); ++ } ++ String[] fmOptions = { "-classpath", "-bootclasspath" }; ++ for (String o: fmOptions) { ++ if (fileManager.isSupportedOption(o) == -1) ++ continue; ++ String name = o.substring(1); ++ log.println(getMessage("main.opt." + name)); ++ } ++ ++ } ++ ++ private void showVersion(boolean full) { ++ log.println(version(full ? "full" : "release")); ++ } ++ ++ private static final String versionRBName = "com.sun.tools.javap.resources.version"; ++ private static ResourceBundle versionRB; ++ ++ private String version(String key) { ++ // key=version: mm.nn.oo[-milestone] ++ // key=full: mm.mm.oo[-milestone]-build ++ if (versionRB == null) { ++ try { ++ versionRB = ResourceBundle.getBundle(versionRBName); ++ } catch (MissingResourceException e) { ++ return getMessage("version.resource.missing", System.getProperty("java.version")); ++ } ++ } ++ try { ++ return versionRB.getString(key); ++ } ++ catch (MissingResourceException e) { ++ return getMessage("version.unknown", System.getProperty("java.version")); ++ } ++ } ++ ++ private Diagnostic<JavaFileObject> createDiagnostic(final String key, final Object... args) { ++ return new Diagnostic<JavaFileObject>() { ++ public Kind getKind() { ++ return Diagnostic.Kind.ERROR; ++ } ++ ++ public JavaFileObject getSource() { ++ return null; ++ } ++ ++ public long getPosition() { ++ return Diagnostic.NOPOS; ++ } ++ ++ public long getStartPosition() { ++ return Diagnostic.NOPOS; ++ } ++ ++ public long getEndPosition() { ++ return Diagnostic.NOPOS; ++ } ++ ++ public long getLineNumber() { ++ return Diagnostic.NOPOS; ++ } ++ ++ public long getColumnNumber() { ++ return Diagnostic.NOPOS; ++ } ++ ++ public String getCode() { ++ return key; ++ } ++ ++ public String getMessage(Locale locale) { ++ return JavapTask.this.getMessage(locale, key, args); ++ } ++ ++ }; ++ ++ } ++ ++ private String getMessage(String key, Object... args) { ++ return getMessage(task_locale, key, args); ++ } ++ ++ private String getMessage(Locale locale, String key, Object... args) { ++ if (bundles == null) { ++ // could make this a HashMap<Locale,SoftReference<ResourceBundle>> ++ // and for efficiency, keep a hard reference to the bundle for the task ++ // locale ++ bundles = new HashMap<Locale, ResourceBundle>(); ++ } ++ ++ if (locale == null) ++ locale = Locale.getDefault(); ++ ++ ResourceBundle b = bundles.get(locale); ++ if (b == null) { ++ try { ++ b = ResourceBundle.getBundle("com.sun.tools.javap.resources.javap", locale); ++ bundles.put(locale, b); ++ } catch (MissingResourceException e) { ++ throw new InternalError("Cannot find javap resource bundle for locale " + locale); ++ } ++ } ++ ++ try { ++ return MessageFormat.format(b.getString(key), args); ++ } catch (MissingResourceException e) { ++ throw new InternalError(e, key); ++ } ++ } ++ ++ Context context; ++ JavaFileManager fileManager; ++ PrintWriter log; ++ DiagnosticListener<? super JavaFileObject> diagnosticListener; ++ List<String> classes; ++ Options options; ++ //ResourceBundle bundle; ++ Locale task_locale; ++ Map<Locale, ResourceBundle> bundles; ++ ++ private static final String progname = "javap"; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/Main.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/Main.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,68 @@ ++/* ++ * 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.tools.javap; ++ ++import java.io.PrintWriter; ++ ++/** ++ * Main entry point. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Main { ++ /** ++ * Main entry point for the launcher. ++ * Note: This method calls System.exit. ++ * @param args command line arguments ++ */ ++ public static void main(String[] args) { ++ if (args.length >= 1 && args[0].equals("-Xold")) { ++ String[] nArgs = new String[args.length - 1]; ++ System.arraycopy(args, 1, nArgs, 0, nArgs.length); ++ sun.tools.javap.Main.main(args); // calls System.exit ++ System.exit(1); ++ } ++ ++ JavapTask t = new JavapTask(); ++ int rc = t.run(args); ++ System.exit(rc); ++ } ++ ++ /** ++ * Entry point that does <i>not</i> call System.exit. ++ * @param args command line arguments ++ * @param out output stream ++ * @return an exit code. 0 means success, non-zero means an error occurred. ++ */ ++ public static int run(String[] args, PrintWriter out) { ++ JavapTask t = new JavapTask(); ++ t.setLog(out); ++ return t.run(args); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/Options.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/Options.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,84 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.AccessFlags; ++ ++/* ++ * Provides access to javap's options, set via the command line ++ * or JSR 199 API. ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class Options { ++ public static Options instance(Context context) { ++ Options instance = context.get(Options.class); ++ if (instance == null) ++ instance = new Options(context); ++ return instance; ++ } ++ ++ protected Options(Context context) { ++ context.put(Options.class, this); ++ } ++ ++ /** ++ * Checks access of class, field or method. ++ */ ++ public boolean checkAccess(AccessFlags flags){ ++ ++ boolean isPublic = flags.is(AccessFlags.ACC_PUBLIC); ++ boolean isProtected = flags.is(AccessFlags.ACC_PROTECTED); ++ boolean isPrivate = flags.is(AccessFlags.ACC_PRIVATE); ++ boolean isPackage = !(isPublic || isProtected || isPrivate); ++ ++ if ((showAccess == AccessFlags.ACC_PUBLIC) && (isProtected || isPrivate || isPackage)) ++ return false; ++ else if ((showAccess == AccessFlags.ACC_PROTECTED) && (isPrivate || isPackage)) ++ return false; ++ else if ((showAccess == 0) && (isPrivate)) ++ return false; ++ else ++ return true; ++ } ++ ++ public boolean help; ++ public boolean verbose; ++ public boolean version; ++ public boolean fullVersion; ++ public boolean showFlags; ++ public boolean showLineAndLocalVariableTables; ++ public int showAccess; ++ public boolean showDisassembled; ++ public boolean showInternalSignatures; ++ public boolean showAllAttrs; ++ ++ public boolean compat; // bug-for-bug compatibility mode with old javap ++ public boolean jsr277; ++ public boolean ignoreSymbolFile; // file manager should ignore ct.sym ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/overview.html +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/overview.html Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,10 @@ ++<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> ++<html> ++ <head> ++ <title>javap: class file disassembler</title> ++ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> ++ </head> ++ <body> ++ Javap is a class file disassembler. ++ </body> ++</html> +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/package.html +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/package.html Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,10 @@ ++<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> ++<html> ++ <head> ++ <title></title> ++ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> ++ </head> ++ <body> ++ Classes to dump class files in text format. ++ </body> ++</html> +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/resources/javap.properties +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,62 @@ ++ ++err.prefix=Error: ++ ++err.bad.constant.pool=error while reading constant pool for {0}: {1} ++err.class.not.found=class not found: {0} ++err.crash=A serious internal error has occurred: {0}\nPlease file a bug report, and include the following information:\n{1} ++err.end.of.file=unexpected end of file while reading {0} ++err.file.not.found=file not found: {0} ++err.h.not.supported=-h is no longer available - use the 'javah' program ++err.internal.error=internal error: {0} {1} {2} ++err.ioerror=IO error reading {0}: {1} ++err.missing.arg=no value given for {0} ++err.no.classes.specified=no classes specified ++err.not.standard.file.manager=can only specify class files when using a standard file manager ++err.unknown.option=unknown option: {0} ++err.verify.not.supported=-verify not supported ++err.Xold.not.supported.here=-Xold must be given as the first option ++ ++main.usage=\ ++Usage: {0} <options> <classes>\n\ ++where possible options include: ++ ++ ++main.opt.help=\ ++\ -help --help -? Print this usage message ++ ++main.opt.version=\ ++\ -version Version information ++ ++main.opt.v=\ ++\ -v -verbose Print additional information ++ ++main.opt.l=\ ++\ -l Print line number and local variable tables ++ ++main.opt.public=\ ++\ -public Show only public classes and members ++ ++main.opt.protected=\ ++\ -protected Show protected/public classes and members ++ ++main.opt.package=\ ++\ -package Show package/protected/public classes\n\ ++\ and members (default) ++ ++main.opt.p=\ ++\ -p -private Show all classes and members ++ ++main.opt.c=\ ++\ -c Disassemble the code ++ ++main.opt.s=\ ++\ -s Print internal type signatures ++ ++main.opt.classpath=\ ++\ -classpath <path> Specify where to find user class files ++ ++main.opt.bootclasspath=\ ++\ -bootclasspath <path> Override location of bootstrap class files ++ ++ ++ +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/com/sun/tools/javap/resources/version.properties-template +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/resources/version.properties-template Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,28 @@ ++# ++# Copyright 2007-2008 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. ++# ++ ++jdk=$(JDK_VERSION) ++full=$(FULL_VERSION) ++release=$(RELEASE) +diff -r 8e38c8fe0a0b -r bfd7bb421825 src/share/classes/sun/tools/javap/Main.java +--- langtools/src/share/classes/sun/tools/javap/Main.java Fri Oct 04 12:22:34 2013 -0400 ++++ langtools/src/share/classes/sun/tools/javap/Main.java Tue Oct 22 01:03:49 2013 +0100 +@@ -49,6 +49,12 @@ + } + + public static void main(String argv[]) { ++ // unless first arg is -Xold, use new javap ++ if (!(argv.length >= 1 && argv[0].equals("-Xold"))) { ++ com.sun.tools.javap.Main.main(argv); ++ return; ++ } ++ + entry(argv); + if (errorOccurred) { + System.exit(1); +@@ -178,6 +184,8 @@ + } + } else if (arg.equals("-all")) { + env.showallAttr = true; ++ } else if (arg.equals("-Xold")) { ++ // ignore: this is old javap + } else { + error("invalid flag: " + arg); + usage(); +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/4870651/T4870651.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/4870651/T4870651.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,81 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4870651 ++ * @summary javap should recognize generics, varargs, enum ++ * @build T4870651 Test ++ * @run main T4870651 ++ */ ++ ++import java.io.*; ++ ++public class T4870651 { ++ public static void main(String[] args) throws Exception { ++ new T4870651().run(); ++ } ++ ++ public void run() throws IOException { ++ verify("Test", ++ "class Test<T, E extends java.lang.Exception & java.lang.Comparable<T>, U extends java.lang.Comparable>", ++ "v1(java.lang.String...)"); ++ ++ verify("Test$Enum", ++ "flags: ACC_FINAL, ACC_SUPER, ACC_ENUM", ++ "flags: ACC_PUBLIC, ACC_STATIC, ACC_FINAL, ACC_ENUM"); ++ ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ String javap(String className) { ++ String testClasses = System.getProperty("test.classes", "."); ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ String[] args = { "-classpath", testClasses, "-v", className }; ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ String output = sw.toString(); ++ System.out.println("class " + className); ++ System.out.println(output); ++ return output; ++ } ++ ++ void verify(String className, String... expects) { ++ String output = javap(className); ++ for (String expect: expects) { ++ if (output.indexOf(expect)< 0) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/4870651/Test.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/4870651/Test.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,76 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++import java.util.*; ++ ++abstract class Test<T,E extends Exception & Comparable<T>,U extends Comparable> { ++ T t; ++ ++ Test(T t) { } ++ <G> Test(G g, int i) { } ++ ++ Test(String... args) { } ++ Test(int i, Object[]... args) { } ++ abstract void v1(String... args); ++ abstract void v2(int i, String[]... args); ++ ++ abstract void a1(int x); ++ abstract void a2(int[] x); ++ abstract void a3(T x); ++ abstract void a4(T[] x); ++ ++ abstract int r1(); ++ abstract int[] r2(); ++ abstract T r3(); ++ abstract T[] r4(); ++ ++ abstract <G> void ga1(int x); ++ abstract <G> void ga2(int[] x); ++ abstract <G> void ga3(G x); ++ abstract <G> void ga4(G[] x); ++ ++ abstract <G> int gr1(); ++ abstract <G> int[] gr2(); ++ abstract <G> G gr3(); ++ abstract <G> G[] gr4(); ++ ++ abstract <G extends Exception> void ge() throws G; ++ ++ abstract void w(List<?> l); ++ abstract void we(List<? extends T> l); ++ abstract void ws(List<? super T> l); ++ ++ abstract void t1() throws Error; ++ abstract void t2() throws E; ++ abstract void t3() throws E,Error; ++ ++ abstract void i1(Test<T, E, Comparable> x); ++ abstract void i3(Test<T, E, Comparable>.Inner<String> x); ++ ++ class Inner<Q> { } ++ class Inner2<Q> extends Inner<Q> { } ++ ++ class Simple { } ++ ++ enum Enum { e1, e2, e3 } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/ListTest.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/ListTest.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,147 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++import java.io.*; ++import java.util.*; ++import javax.tools.*; ++ ++/* ++ * @test ++ * @bug 6439940 ++ * @summary Cleanup javap implementation ++ * @run main/othervm ListTest ++ */ ++public class ListTest { ++ public static void main(String[] args) throws Exception { ++ new ListTest().run(); ++ } ++ ++ ListTest() { ++ String v = System.getProperty("view.cmd"); ++ // v = "/opt/teamware/7.7/bin/filemerge -r"; ++ if (v != null) { ++ viewResults = true; ++ viewCmd = Arrays.asList(v.split(" +")); ++ } ++ } ++ ++ void run() throws Exception { ++ StandardLocation[] locs = new StandardLocation[] { ++ StandardLocation.PLATFORM_CLASS_PATH, ++ StandardLocation.CLASS_PATH, ++ }; ++ ++ int count = 0; ++ int pass = 0; ++ for (StandardLocation loc: locs) { ++ for (String testClassName: list(loc)) { ++ count++; ++ if (test(testClassName)) ++ pass++; ++ } ++ } ++ ++ if (pass < count) ++ throw new Error(pass + "/" + count + " test cases passed"); ++ } ++ ++ Iterable<String> list(StandardLocation loc) throws IOException { ++ JavaCompiler compiler = ToolProvider.getSystemJavaCompiler(); ++ StandardJavaFileManager sfm = compiler.getStandardFileManager(null, null, null); ++ Set<JavaFileObject.Kind> kinds = Collections.singleton(JavaFileObject.Kind.CLASS); ++ ++ List<String> list = new ArrayList<String>(); ++ for (JavaFileObject fo: sfm.list(loc, testPackage, kinds, true)) { ++ //System.err.println(com.sun.tools.javac.util.Old199.getPath(fo)); ++ list.add(sfm.inferBinaryName(loc, fo)); ++ } ++ return list; ++ } ++ ++ boolean test(String testClassName) throws Exception { ++ String[] args = new String[options.size() + 1]; ++ options.toArray(args); ++ args[args.length - 1] = testClassName; ++ String oldOut = runOldJavap(args); ++ String newOut = runNewJavap(args); ++ boolean ok = oldOut.equals(newOut); ++ System.err.println((ok ? "pass" : "FAIL") + ": " + testClassName); ++ if (!ok && viewResults) ++ view(oldOut, newOut); ++ return ok; ++ } ++ ++ String runOldJavap(String[] args) { ++ //System.err.println("OLD: " + Arrays.asList(args)); ++ PrintStream oldOut = System.out; ++ ByteArrayOutputStream out = new ByteArrayOutputStream(); ++ System.setOut(new PrintStream(out)); ++ try { ++ sun.tools.javap.Main.entry(args); ++ } finally { ++ System.setOut(oldOut); ++ } ++ return out.toString(); ++ } ++ ++ String runNewJavap(String[] args) { ++ String[] nArgs = new String[args.length + 2]; ++ nArgs[0] = "-XDcompat"; ++ nArgs[1] = "-XDignore.symbol.file"; ++ System.arraycopy(args, 0, nArgs, 2, args.length); ++ //System.err.println("NEW: " + Arrays.asList(nArgs)); ++ StringWriter out = new StringWriter(); ++ com.sun.tools.javap.Main.run(nArgs, new PrintWriter(out, true)); ++ return out.toString(); ++ } ++ ++ File write(String text, String suffix) throws IOException { ++ File f = File.createTempFile("ListTest", suffix); ++ FileWriter out = new FileWriter(f); ++ out.write(text); ++ out.close(); ++ return f; ++ } ++ ++ void view(String oldOut, String newOut) throws Exception { ++ File oldFile = write(oldOut, "old"); ++ File newFile = write(newOut, "new"); ++ List<String> cmd = new ArrayList<String>(); ++ cmd.addAll(viewCmd); ++ cmd.add(oldFile.getPath()); ++ cmd.add(newFile.getPath()); ++ Process p = new ProcessBuilder(cmd).redirectErrorStream(true).start(); ++ p.getOutputStream().close(); ++ String line; ++ BufferedReader in = new BufferedReader(new InputStreamReader(p.getInputStream())); ++ while ((line = in.readLine()) != null) ++ System.err.println(line); ++ in.close(); ++ p.waitFor(); ++ } ++ ++ String testPackage = "java.lang"; ++ List<String> options = Arrays.asList("-v"); ++ boolean viewResults; ++ List<String> viewCmd; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/OptionTest.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/OptionTest.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,143 @@ ++/* ++ * 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. ++ * ++ * 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. ++ */ ++ ++import java.io.*; ++import java.util.*; ++ ++/* ++ * @test ++ * @bug 6439940 ++ * @summary Cleanup javap implementation ++ * @run main/othervm OptionTest ++ */ ++public class OptionTest { ++ public static void main(String[] args) throws Exception { ++ new OptionTest().run(); ++ } ++ ++ OptionTest() { ++ String v = System.getProperty("view.cmd"); ++ if (v != null) { ++ viewResults = true; ++ viewCmd = Arrays.asList(v.split(" +")); ++ } ++ } ++ ++ ++ void run() throws Exception { ++ int count = 0; ++ int pass = 0; ++ // try combinations of options and compare old javap against new javap ++ for (int i = 0; i < (1<<8); i++) { ++ List<String> options = new ArrayList<String>(); ++ if ((i & 0x01) != 0) ++ options.add("-c"); ++ if ((i & 0x02) != 0) ++ options.add("-l"); ++ if ((i & 0x04) != 0) ++ options.add("-public"); ++ if ((i & 0x08) != 0) ++ options.add("-protected"); ++ if ((i & 0x10) != 0) ++ options.add("-package"); ++ if ((i & 0x20) != 0) ++ options.add("-private"); ++ if ((i & 0x40) != 0) ++ options.add("-s"); ++ if ((i & 0x80) != 0) ++ options.add("-verbose"); ++ count++; ++ if (test(options)) ++ pass++; ++ } ++ ++ if (pass < count) ++ throw new Error(pass + "/" + count + " test cases passed"); ++ } ++ ++ boolean test(List<String> options) throws Exception { ++ String[] args = new String[options.size() + 1]; ++ options.toArray(args); ++ args[args.length - 1] = testClassName; ++ String oldOut = runOldJavap(args); ++ String newOut = runNewJavap(args); ++ boolean ok = oldOut.equals(newOut); ++ System.err.println((ok ? "pass" : "FAIL") + ": " + options); ++ if (!ok && viewResults) ++ view(oldOut, newOut); ++ return ok; ++ } ++ ++ String runOldJavap(String[] args) { ++ //System.err.println("OLD: " + Arrays.asList(args)); ++ PrintStream oldOut = System.out; ++ ByteArrayOutputStream out = new ByteArrayOutputStream(); ++ System.setOut(new PrintStream(out)); ++ try { ++ sun.tools.javap.Main.entry(args); ++ } finally { ++ System.setOut(oldOut); ++ } ++ return out.toString(); ++ } ++ ++ String runNewJavap(String[] args) { ++ String[] nArgs = new String[args.length + 2]; ++ nArgs[0] = "-XDcompat"; ++ nArgs[1] = "-XDignore.symbol.file"; ++ System.arraycopy(args, 0, nArgs, 2, args.length); ++ //System.err.println("NEW: " + Arrays.asList(nArgs)); ++ StringWriter out = new StringWriter(); ++ com.sun.tools.javap.Main.run(nArgs, new PrintWriter(out, true)); ++ return out.toString(); ++ } ++ ++ File write(String text, String suffix) throws IOException { ++ File f = File.createTempFile("OptionTest", suffix); ++ FileWriter out = new FileWriter(f); ++ out.write(text); ++ out.close(); ++ return f; ++ } ++ ++ void view(String oldOut, String newOut) throws Exception { ++ File oldFile = write(oldOut, "old"); ++ File newFile = write(newOut, "new"); ++ List<String> cmd = new ArrayList<String>(); ++ cmd.addAll(viewCmd); ++ cmd.add(oldFile.getPath()); ++ cmd.add(newFile.getPath()); ++ Process p = new ProcessBuilder(cmd).redirectErrorStream(true).start(); ++ p.getOutputStream().close(); ++ String line; ++ BufferedReader in = new BufferedReader(new InputStreamReader(p.getInputStream())); ++ while ((line = in.readLine()) != null) ++ System.err.println(line); ++ in.close(); ++ p.waitFor(); ++ } ++ ++ String testClassName = "java.lang.SecurityManager"; ++ boolean viewResults; ++ List<String> viewCmd; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T4075403.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4075403.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,73 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4075403 ++ * @summary Use javap to inquire about a specific inner class ++ */ ++ ++ ++import java.io.*; ++ ++public class T4075403 { ++ public static void main(String[] args) throws Exception { ++ new T4075403().run(); ++ } ++ ++ public void run() throws IOException { ++ ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ javap("Outer.Inner"); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Outer.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("class Outer { "); ++ out.println(" class Inner { }"); ++ out.println("}"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { "-g", f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(String className) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { "-classpath", ".", className }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ System.out.println(sw.toString()); ++ return sw.toString(); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T4459541.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4459541.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,112 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4459541 ++ * @summary "javap -l" shows line numbers as signed short; they should be unsigned. ++ */ ++ ++import java.io.*; ++ ++public class T4459541 { ++ public static void main(String[] args) throws Exception { ++ new T4459541().run(); ++ } ++ ++ public void run() throws IOException { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ String output = javap(classFile); ++ verify(output); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Test.java"); ++ out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ println("class Test {"); ++ println("void begin(int i) {"); ++ println("i++;"); ++ println("i++;"); ++ println("}"); ++ while (line < 32750) ++ println("// " + line); ++ println("void before_32767(int i) {"); ++ println("i++;"); ++ println("i++;"); ++ println("}"); ++ while (line < 32768-4) ++ println("// " + line); ++ println("void straddle_32768(int i) {"); ++ while (line < 32768+4) ++ println("i++;"); ++ println("}"); ++ while (line < 65520) ++ println("// " + line); ++ println("void between_32768_and_65536(int i) {"); ++ println("i++;"); ++ println("i++;"); ++ println("}"); ++ while (line < 65536-4) ++ println("// " + line); ++ println("void straddle_65536(int i) {"); ++ while (line < 65536+4) ++ println("i++;"); ++ println("}"); ++ println("}"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(File f) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { "-l", f.getPath() }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ return sw.toString(); ++ } ++ ++ void verify(String output) { ++ System.out.println(output); ++ if (output.indexOf("-") >= 0) ++ throw new Error("- found in output"); ++ } ++ ++ void println(String text) { ++ out.println(text); ++ line++; ++ } ++ ++ PrintWriter out; ++ int line = 1; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T4501660.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4501660.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,76 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4501660 ++ * @summary change diagnostic of -help as 'print this help message and exit' ++ * (actually, verify -help does not cause premature exit) ++ */ ++ ++import java.io.*; ++import java.util.zip.*; ++ ++public class T4501660 { ++ public static void main(String[] args) throws Exception { ++ new T4501660().run(); ++ } ++ ++ public void run() throws IOException { ++ String testClasses = System.getProperty("test.classes", "."); ++ String output = javap("-classpath", testClasses, "-help", "T4501660"); ++ verify(output, ++ "-public", "-protected", "-private", // check -help output is present ++ "class T4501660" // check class output is present ++ ); ++ ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ String javap(String... args) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ //sun.tools.javap.Main.entry(args); ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ System.out.println(sw); ++ return sw.toString(); ++ } ++ ++ void verify(String output, String... expects) { ++ for (String expect: expects) { ++ if (output.indexOf(expect)< 0) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T4876942.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4876942.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,70 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4876942 ++ * @summary javap invoked without args does not print help screen ++ */ ++ ++import java.io.*; ++import java.util.zip.*; ++ ++public class T4876942 { ++ public static void main(String[] args) throws Exception { ++ new T4876942().run(); ++ } ++ ++ public void run() throws IOException { ++ String output = javap(); ++ verify(output, "-public", "-protected", "-private"); // check that some of the options are listed ++ ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ String javap(String... args) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ //sun.tools.javap.Main.entry(args); ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ return sw.toString(); ++ } ++ ++ void verify(String output, String... expects) { ++ for (String expect: expects) { ++ if (output.indexOf(expect)< 0) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T4880663.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4880663.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,88 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4880663 ++ * @summary javap could output whitespace between class name and opening brace ++ */ ++ ++ ++import java.io.*; ++ ++public class T4880663 { ++ public static void main(String[] args) throws Exception { ++ new T4880663().run(); ++ } ++ ++ public void run() throws IOException { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ verify(classFile, "class Test {"); ++ ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Test.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("class Test { }"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { "-g", f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(File classFile) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { classFile.getPath() }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ System.out.println(sw.toString()); ++ return sw.toString(); ++ } ++ ++ void verify(File classFile, String... expects) { ++ String output = javap(classFile); ++ for (String expect: expects) { ++ if (output.indexOf(expect)< 0) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T4975569.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4975569.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,94 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4975569 6622215 ++ * @summary javap doesn't print new flag bits ++ */ ++ ++import java.io.*; ++import java.util.*; ++ ++public class T4975569 ++{ ++ public static void main(String... args) { ++ new T4975569().run(); ++ } ++ ++ void run() { ++ verify("T4975569$Anno", "flags: ACC_INTERFACE, ACC_ABSTRACT, ACC_ANNOTATION"); ++ verify("T4975569$E", "flags: ACC_FINAL, ACC_SUPER, ACC_ENUM"); ++ verify("T4975569$S", "flags: ACC_BRIDGE, ACC_SYNTHETIC", ++ "InnerClasses: \n static"); ++ verify("T4975569$V", "void m(java.lang.String...)", ++ "flags: ACC_VARARGS"); ++ verify("T4975569$Prot", "InnerClasses: \n protected"); ++ //verify("T4975569$Priv", "InnerClasses"); ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ void verify(String className, String... expects) { ++ String output = javap(className); ++ for (String expect: expects) { ++ if (output.indexOf(expect)< 0) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++ ++ String javap(String className) { ++ String testClasses = System.getProperty("test.classes", "."); ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ String[] args = { "-v", "-classpath", testClasses, className }; ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ String output = sw.toString(); ++ System.out.println("class " + className); ++ System.out.println(output); ++ return output; ++ } ++ ++ List x() { return null; }; ++ ++ class V { void m(String... args) { } } ++ enum E { e; } ++ @interface Anno { } ++ static class S extends T4975569 { ++ ArrayList x() { return null; } ++ } ++ ++ protected class Prot { } ++ //private class Priv { int i; } ++} ++ +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T6271787.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6271787.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,90 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6271787 ++ * @summary javap dumps LocalVariableTypeTable attribute in hex, needs to print a table ++ */ ++ ++import java.io.*; ++ ++public class T6271787 { ++ public static void main(String[] args) throws Exception { ++ new T6271787().run(); ++ } ++ ++ public void run() throws IOException { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ ++ verify(classFile, ++ "LocalVariableTypeTable:", ++ "0 5 0 this LTest<TT;>;" // should consider decoding this in javap ++ ); ++ ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Test.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("class Test<T> { }"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { "-g", f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(File f) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { "-v", f.getPath() }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ return sw.toString(); ++ } ++ ++ void verify(File classFile, String... expects) { ++ String output = javap(classFile); ++ for (String expect: expects) { ++ if (output.indexOf(expect)< 0) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T6474890.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6474890.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,95 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6474890 ++ * @summary javap does not open .zip files in -classpath ++ */ ++ ++import java.io.*; ++import java.util.zip.*; ++ ++public class T6474890 { ++ public static void main(String[] args) throws Exception { ++ new T6474890().run(); ++ } ++ ++ public void run() throws IOException { ++ File classDir = new File("classes"); ++ classDir.mkdir(); ++ ++ String className = "Test"; ++ File javaFile = writeTestFile(className); ++ compileTestFile(classDir, javaFile); ++ ++ File zipFile = zip(classDir, new File(classDir + ".zip")); ++ javap("-classpath", zipFile.getPath(), className); ++ ++ File jarFile = zip(classDir, new File(classDir + ".jar")); ++ javap("-classpath", zipFile.getPath(), className); ++ } ++ ++ File writeTestFile(String name) throws IOException { ++ File f = new File(name + ".java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("class " + name + " { }"); ++ out.close(); ++ return f; ++ } ++ ++ void compileTestFile(File classDir, File file) { ++ int rc = com.sun.tools.javac.Main.compile( ++ new String[] { "-d", classDir.getPath(), file.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ } ++ ++ File zip(File dir, File zipFile) throws IOException { ++ ZipOutputStream zipOut = new ZipOutputStream(new FileOutputStream(zipFile)); ++ for (File file: dir.listFiles()) { ++ if (file.isFile()) { ++ byte[] data = new byte[(int) file.length()]; ++ DataInputStream in = new DataInputStream(new FileInputStream(file)); ++ in.readFully(data); ++ in.close(); ++ zipOut.putNextEntry(new ZipEntry(file.getName())); ++ zipOut.write(data, 0, data.length); ++ zipOut.closeEntry(); ++ } ++ } ++ zipOut.close(); ++ return zipFile; ++ } ++ ++ String javap(String... args) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ //sun.tools.javap.Main.entry(args); ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ return sw.toString(); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T6587786.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6587786.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,52 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6587786 ++ * @summary Javap throws error : "ERROR:Could not find <classname>" for JRE classes ++ */ ++ ++import java.io.*; ++ ++public class T6587786 { ++ public static void main(String[] args) throws Exception { ++ new T6587786().run(); ++ } ++ ++ public void run() throws IOException { ++ javap("com.sun.javadoc.Doc", "com.sun.crypto.provider.ai"); ++ javap("com.sun.crypto.provider.ai", "com.sun.javadoc.ClassDoc"); ++ } ++ ++ void javap(String... args) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ //sun.tools.javap.Main.entry(args); ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ System.out.println(sw.toString()); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T6622216.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6622216.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,77 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6622216 ++ * @summary javap names some attributes incorrectly ++ */ ++ ++import java.io.*; ++ ++public class T6622216 { ++ public static void main(String[] args) throws Exception { ++ new T6622216().run(); ++ } ++ ++ public void run() throws IOException { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ String output = javap(classFile); ++ verify(output); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Outer.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("class Outer {"); ++ out.println(" class Inner { }"); ++ out.println("}"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(File f) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { "-v", f.getPath() }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ return sw.toString(); ++ } ++ ++ void verify(String output) { ++ System.out.println(output); ++ if (output.indexOf("InnerClasses") == -1) ++ throw new Error("InnerClasses not found in output"); ++ } ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T6622232.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6622232.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,97 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6622232 ++ * @summary javap gets whitespace confused ++ */ ++ ++import java.io.*; ++ ++public class T6622232 { ++ public static void main(String[] args) throws Exception { ++ new T6622232().run(); ++ } ++ ++ public void run() throws IOException { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ String output = javap(classFile); ++ ++ // these are all examples of bad whitespace from old javap ++ verifyNot(output, ++ "\\Q Constant value: int 3Deprecated: true\\E", ++ "^Deprecated: true", ++ "\\Q throws java.lang.Exception, java.lang.Error Deprecated: true\\E" ++ ); ++ ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Test.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("class Test { "); ++ out.println(" @Deprecated static final int f1 = 3;"); ++ out.println(" @Deprecated int f2;"); ++ out.println(" @Deprecated void m() throws Exception, Error { }"); ++ out.println("}"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { "-g", f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(File f) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { "-v", f.getPath() }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ System.out.println(sw.toString()); ++ return sw.toString(); ++ } ++ ++ void verifyNot(String output, String... unexpects) { ++ for (String unexpect: unexpects) { ++ if (output.matches(unexpect)) ++ error(unexpect + " unexpectedly found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++} +diff -r 8e38c8fe0a0b -r bfd7bb421825 test/tools/javap/T6622260.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6622260.java Tue Oct 22 01:03:49 2013 +0100 +@@ -0,0 +1,197 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6622260 ++ * @summary javap prints negative bytes incorrectly in hex ++ */ ++ ++import java.io.*; ++ ++public class T6622260 { ++ public static void main(String[] args) throws Exception { ++ new T6622260().run(); ++ } ++ ++ public void run() throws IOException { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ modifyClassFile(classFile); ++ String output = javap(classFile); ++ verify(output); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Test.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("@Deprecated class Test { int f; void m() { } }"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ void modifyClassFile(File f) throws IOException { ++ String newAttributeName = "NonstandardAttribute"; ++ byte[] newAttributeData = { 0, 1, 2, 127, (byte)128, (byte)129, (byte)254, (byte)255 }; ++ ++ DataInputStream in = new DataInputStream(new FileInputStream(f)); ++ byte[] data = new byte[(int) f.length()]; ++ in.readFully(data); ++ in.close(); ++ ++ in = new DataInputStream(new ByteArrayInputStream(data)); ++ in.skipBytes(4); // magic ++ in.skipBytes(2); // minor ++ in.skipBytes(2); // minor ++ ++ int constantPoolPos = data.length - in.available(); ++ int constant_pool_count = skipConstantPool(in); ++ ++ int flagsPos = data.length - in.available(); ++ in.skipBytes(2); // access_flags ++ in.skipBytes(2); // this_class ++ in.skipBytes(2); // super_class ++ ++ int interfaces_count = in.readUnsignedShort(); ++ in.skipBytes(interfaces_count * 2); ++ ++ int field_count = in.readUnsignedShort(); ++ for (int i = 0; i < field_count; i++) { ++ in.skipBytes(6); // access_flags, name_index, descriptor_index ++ skipAttributes(in); ++ } ++ ++ int method_count = in.readUnsignedShort(); ++ for (int i = 0; i < method_count; i++) { ++ in.skipBytes(6); // access_flags, name_index, descriptor_index ++ skipAttributes(in); ++ } ++ ++ int classAttributesPos = data.length - in.available(); ++ int attributes_count = in.readUnsignedShort(); ++ ++ f.renameTo(new File(f.getPath() + ".BAK")); ++ DataOutputStream out = new DataOutputStream(new FileOutputStream(f)); ++ ++ // copy head ++ out.write(data, 0, constantPoolPos); ++ ++ // copy constant pool, adding in name of new attribute ++ out.writeShort(constant_pool_count + 1); ++ out.write(data, constantPoolPos + 2, flagsPos - constantPoolPos - 2); ++ out.write(1); // CONSTANT_Utf8 ++ out.writeUTF(newAttributeName); ++ ++ // copy flags, class, superclass, interfaces, fields and methods ++ out.write(data, flagsPos, classAttributesPos - flagsPos); ++ ++ // copy class attributes, adding in new attribute ++ out.writeShort(attributes_count + 1); ++ out.write(data, classAttributesPos + 2, data.length - classAttributesPos - 2); ++ out.writeShort(constant_pool_count); // index of new attribute name ++ out.writeInt(newAttributeData.length); ++ out.write(newAttributeData); ++ out.close(); ++ } ++ ++ int skipConstantPool(DataInputStream in) throws IOException { ++ int constant_pool_count = in.readUnsignedShort(); ++ for (int i = 1; i < constant_pool_count; i++) { ++ int tag = in.readUnsignedByte(); ++ switch (tag) { ++ case 1: // CONSTANT_Utf8 ++ int length = in.readUnsignedShort(); ++ in.skipBytes(length); // bytes ++ break; ++ ++ case 3: // CONSTANT_Integer ++ case 4: // CONSTANT_Float ++ in.skipBytes(4); // bytes ++ break; ++ ++ case 5: // CONSTANT_Long ++ case 6: // CONSTANT_Double ++ in.skipBytes(8); // high_bytes, low_bytes ++ break; ++ ++ case 7: // CONSTANT_Class ++ in.skipBytes(2); // name_index ++ break; ++ ++ case 8: // CONSTANT_String ++ in.skipBytes(2); // string_index ++ break; ++ ++ case 9: // CONSTANT_FieldRef ++ case 10: // CONSTANT_Methodref ++ case 11: // CONSTANT_InterfaceMethodref ++ in.skipBytes(4); // class_index, name_and_type_index ++ break; ++ ++ case 12: // CONSTANT_NameAndType ++ in.skipBytes(4); // name_index, descriptor_index ++ break; ++ ++ default: ++ throw new Error("constant pool tag: " + tag); ++ } ++ } ++ return constant_pool_count; ++ } ++ ++ int skipAttributes(DataInputStream in) throws IOException { ++ int attributes_count = in.readUnsignedShort(); ++ for (int i = 0; i < attributes_count; i++) { ++ in.skipBytes(2); // attribute_name_index; ++ int length = in.readInt(); ++ in.skipBytes(length); // info ++ } ++ return attributes_count; ++ } ++ ++ String javap(File f) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(new String[] { "-v", f.getPath() }, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ return sw.toString(); ++ } ++ ++ void verify(String output) { ++ System.out.println(output); ++ if (output.indexOf("-") >= 0) ++ throw new Error("- found in output"); ++ if (output.indexOf("FFFFFF") >= 0) ++ throw new Error("FFFFFF found in output"); ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/4111861-static_fields.patch b/java/openjdk6/files/icedtea/openjdk/4111861-static_fields.patch new file mode 100644 index 000000000000..9612d7b0b577 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/4111861-static_fields.patch @@ -0,0 +1,280 @@ +# HG changeset patch +# User jjg +# Date 1217887742 25200 +# Mon Aug 04 15:09:02 2008 -0700 +# Node ID 6134c146043a3e9dd12ee73ca32ce56ac1c95e3a +# Parent 17dfaebe23044c48bcd5ed0730ce2358543ac459 +4111861: static final field contents are not displayed +Reviewed-by: ksrini + +diff -r 17dfaebe2304 -r 6134c146043a src/share/classes/com/sun/tools/javap/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Tue May 19 11:43:50 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Mon Aug 04 15:09:02 2008 -0700 +@@ -35,6 +35,7 @@ + import com.sun.tools.classfile.Code_attribute; + import com.sun.tools.classfile.ConstantPool; + import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.ConstantValue_attribute; + import com.sun.tools.classfile.Descriptor; + import com.sun.tools.classfile.DescriptorException; + import com.sun.tools.classfile.Exceptions_attribute; +@@ -189,6 +190,14 @@ + } + print(" "); + print(getFieldName(f)); ++ if (options.showConstants && !options.compat) { // BUG 4111861 print static final field contents ++ Attribute a = f.attributes.get(Attribute.ConstantValue); ++ if (a instanceof ConstantValue_attribute) { ++ print(" = "); ++ ConstantValue_attribute cv = (ConstantValue_attribute) a; ++ print(getConstantValue(f.descriptor, cv.constantvalue_index)); ++ } ++ } + print(";"); + println(); + +@@ -485,6 +494,81 @@ + } + } + ++ /** ++ * Get the value of an entry in the constant pool as a Java constant. ++ * Characters and booleans are represented by CONSTANT_Intgere entries. ++ * Character and string values are processed to escape characters outside ++ * the basic printable ASCII set. ++ * @param d the descriptor, giving the expected type of the constant ++ * @param index the index of the value in the constant pool ++ * @return a printable string containing the value of the constant. ++ */ ++ String getConstantValue(Descriptor d, int index) { ++ try { ++ ConstantPool.CPInfo cpInfo = constant_pool.get(index); ++ ++ switch (cpInfo.getTag()) { ++ case ConstantPool.CONSTANT_Integer: { ++ ConstantPool.CONSTANT_Integer_info info = ++ (ConstantPool.CONSTANT_Integer_info) cpInfo; ++ String t = d.getValue(constant_pool); ++ if (t.equals("C")) { // character ++ return getConstantCharValue((char) info.value); ++ } else if (t.equals("Z")) { // boolean ++ return String.valueOf(info.value == 1); ++ } else { // other: assume integer ++ return String.valueOf(info.value); ++ } ++ } ++ ++ case ConstantPool.CONSTANT_String: { ++ ConstantPool.CONSTANT_String_info info = ++ (ConstantPool.CONSTANT_String_info) cpInfo; ++ return getConstantStringValue(info.getString()); ++ } ++ ++ default: ++ return constantWriter.stringValue(cpInfo); ++ } ++ } catch (ConstantPoolException e) { ++ return "#" + index; ++ } ++ } ++ ++ private String getConstantCharValue(char c) { ++ StringBuilder sb = new StringBuilder(); ++ sb.append('\''); ++ sb.append(esc(c, '\'')); ++ sb.append('\''); ++ return sb.toString(); ++ } ++ ++ private String getConstantStringValue(String s) { ++ StringBuilder sb = new StringBuilder(); ++ sb.append("\""); ++ for (int i = 0; i < s.length(); i++) { ++ sb.append(esc(s.charAt(i), '"')); ++ } ++ sb.append("\""); ++ return sb.toString(); ++ } ++ ++ private String esc(char c, char quote) { ++ if (32 <= c && c <= 126 && c != quote) ++ return String.valueOf(c); ++ else switch (c) { ++ case '\b': return "\\b"; ++ case '\n': return "\\n"; ++ case '\t': return "\\t"; ++ case '\f': return "\\f"; ++ case '\r': return "\\r"; ++ case '\\': return "\\\\"; ++ case '\'': return "\\'"; ++ case '\"': return "\\\""; ++ default: return String.format("\\u%04x", (int) c); ++ } ++ } ++ + private Options options; + private AttributeWriter attrWriter; + private CodeWriter codeWriter; +diff -r 17dfaebe2304 -r 6134c146043a src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Tue May 19 11:43:50 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Mon Aug 04 15:09:02 2008 -0700 +@@ -222,6 +222,12 @@ + void process(JavapTask task, String opt, String arg) { + task.options.ignoreSymbolFile = true; + } ++ }, ++ ++ new Option(false, "-constants") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.showConstants = true; ++ } + } + + }; +diff -r 17dfaebe2304 -r 6134c146043a src/share/classes/com/sun/tools/javap/Options.java +--- langtools/src/share/classes/com/sun/tools/javap/Options.java Tue May 19 11:43:50 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/Options.java Mon Aug 04 15:09:02 2008 -0700 +@@ -77,6 +77,7 @@ + public boolean showDisassembled; + public boolean showInternalSignatures; + public boolean showAllAttrs; ++ public boolean showConstants; + + public boolean compat; // bug-for-bug compatibility mode with old javap + public boolean jsr277; +diff -r 17dfaebe2304 -r 6134c146043a src/share/classes/com/sun/tools/javap/resources/javap.properties +--- langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Tue May 19 11:43:50 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Mon Aug 04 15:09:02 2008 -0700 +@@ -58,5 +58,9 @@ + main.opt.bootclasspath=\ + \ -bootclasspath <path> Override location of bootstrap class files + ++main.opt.constants=\ ++\ -constants Show static final constants + + ++ ++ +diff -r 17dfaebe2304 -r 6134c146043a test/tools/javap/4111861/A.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/4111861/A.java Mon Aug 04 15:09:02 2008 -0700 +@@ -0,0 +1,14 @@ ++class A { ++ public static final int i = 42; ++ public static final boolean b = true; ++ public static final float f = 1.0f; ++ public static final double d = 1.0d; ++ public static final short s = 1; ++ public static final long l = 1l; ++ public static final char cA = 'A'; ++ public static final char c0 = '\u0000'; ++ public static final char cn = '\n'; ++ public static final char cq1 = '\''; ++ public static final char cq2 = '"'; ++ public static final java.lang.String t1 = "abc \u0000 \f\n\r\t'\""; ++} +diff -r 17dfaebe2304 -r 6134c146043a test/tools/javap/4111861/T4111861.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/4111861/T4111861.java Mon Aug 04 15:09:02 2008 -0700 +@@ -0,0 +1,101 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++import java.io.*; ++ ++/* ++ * @test ++ * @bug 4111861 ++ * @summary static final field contents are not displayed ++ */ ++public class T4111861 { ++ public static void main(String... args) throws Exception { ++ new T4111861().run(); ++ } ++ ++ void run() throws Exception { ++ File testSrc = new File(System.getProperty("test.src", ".")); ++ File a_java = new File(testSrc, "A.java"); ++ javac("-d", ".", a_java.getPath()); ++ ++ String out = javap("-classpath", ".", "-constants", "A"); ++ ++ String a = read(a_java); ++ ++ if (!filter(out).equals(filter(read(a_java)))) { ++ System.out.println(out); ++ throw new Exception("unexpected output"); ++ } ++ } ++ ++ String javac(String... args) throws Exception { ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ int rc = com.sun.tools.javac.Main.compile(args, pw); ++ if (rc != 0) ++ throw new Exception("javac failed, rc=" + rc); ++ return sw.toString(); ++ } ++ ++ String javap(String... args) throws Exception { ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(args, pw); ++ if (rc != 0) ++ throw new Exception("javap failed, rc=" + rc); ++ return sw.toString(); ++ } ++ ++ String read(File f) throws IOException { ++ StringBuilder sb = new StringBuilder(); ++ BufferedReader in = new BufferedReader(new FileReader(f)); ++ try { ++ String line; ++ while ((line = in.readLine()) != null) { ++ sb.append(line); ++ sb.append('\n'); ++ } ++ } finally { ++ in.close(); ++ } ++ return sb.toString(); ++ } ++ ++ // return those lines beginning "public static final" ++ String filter(String s) throws IOException { ++ StringBuilder sb = new StringBuilder(); ++ BufferedReader in = new BufferedReader(new StringReader(s)); ++ try { ++ String line; ++ while ((line = in.readLine()) != null) { ++ if (line.indexOf("public static final") > 0) { ++ sb.append(line); ++ sb.append('\n'); ++ } ++ } ++ } finally { ++ in.close(); ++ } ++ return sb.toString(); ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/4501661-disallow_mixing.patch b/java/openjdk6/files/icedtea/openjdk/4501661-disallow_mixing.patch new file mode 100644 index 000000000000..41bcd24728dd --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/4501661-disallow_mixing.patch @@ -0,0 +1,222 @@ +# HG changeset patch +# User jjg +# Date 1215565579 25200 +# Tue Jul 08 18:06:19 2008 -0700 +# Node ID 8f5d8429b3f18ee4c9820ac1fb597f63c55911f3 +# Parent 4f38abed863c89ee101a3af495e7293df04a4a0e +4501661: disallow mixing -public, -private, and -protected options at the same time +Reviewed-by: ksrini + +diff -r 4f38abed863c -r 8f5d8429b3f1 src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Sat Aug 08 17:56:37 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Tue Jul 08 18:06:19 2008 -0700 +@@ -145,24 +145,31 @@ + + new Option(false, "-public") { + void process(JavapTask task, String opt, String arg) { ++ task.options.accessOptions.add(opt); + task.options.showAccess = AccessFlags.ACC_PUBLIC; + } + }, + + new Option(false, "-protected") { + void process(JavapTask task, String opt, String arg) { ++ task.options.accessOptions.add(opt); + task.options.showAccess = AccessFlags.ACC_PROTECTED; + } + }, + + new Option(false, "-package") { + void process(JavapTask task, String opt, String arg) { ++ task.options.accessOptions.add(opt); + task.options.showAccess = 0; + } + }, + + new Option(false, "-p", "-private") { + void process(JavapTask task, String opt, String arg) { ++ if (!task.options.accessOptions.contains("-p") && ++ !task.options.accessOptions.contains("-private")) { ++ task.options.accessOptions.add(opt); ++ } + task.options.showAccess = AccessFlags.ACC_PRIVATE; + } + }, +@@ -422,6 +429,16 @@ + throw new BadArgs("err.unknown.option", arg).showUsage(true); + } + ++ if (!options.compat && options.accessOptions.size() > 1) { ++ StringBuilder sb = new StringBuilder(); ++ for (String opt: options.accessOptions) { ++ if (sb.length() > 0) ++ sb.append(" "); ++ sb.append(opt); ++ } ++ throw new BadArgs("err.incompatible.options", sb); ++ } ++ + if (options.ignoreSymbolFile && fileManager instanceof JavapFileManager) + ((JavapFileManager) fileManager).setIgnoreSymbolFile(true); + +diff -r 4f38abed863c -r 8f5d8429b3f1 src/share/classes/com/sun/tools/javap/Options.java +--- langtools/src/share/classes/com/sun/tools/javap/Options.java Sat Aug 08 17:56:37 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/Options.java Tue Jul 08 18:06:19 2008 -0700 +@@ -25,6 +25,8 @@ + + package com.sun.tools.javap; + ++import java.util.HashSet; ++import java.util.Set; + import com.sun.tools.classfile.AccessFlags; + + /* +@@ -74,6 +76,7 @@ + public boolean showFlags; + public boolean showLineAndLocalVariableTables; + public int showAccess; ++ public Set<String> accessOptions = new HashSet<String>(); + public boolean showDisassembled; + public boolean showInternalSignatures; + public boolean showAllAttrs; +diff -r 4f38abed863c -r 8f5d8429b3f1 src/share/classes/com/sun/tools/javap/resources/javap.properties +--- langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Sat Aug 08 17:56:37 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Tue Jul 08 18:06:19 2008 -0700 +@@ -7,6 +7,7 @@ + err.end.of.file=unexpected end of file while reading {0} + err.file.not.found=file not found: {0} + err.h.not.supported=-h is no longer available - use the 'javah' program ++err.incompatible.options=bad combination of options: {0} + err.internal.error=internal error: {0} {1} {2} + err.ioerror=IO error reading {0}: {1} + err.missing.arg=no value given for {0} +diff -r 4f38abed863c -r 8f5d8429b3f1 test/tools/javap/T4501661.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4501661.java Tue Jul 08 18:06:19 2008 -0700 +@@ -0,0 +1,126 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++import java.io.*; ++import java.util.*; ++ ++/* ++ * @test ++ * @bug 4501661 ++ * @summary disallow mixing -public, -private, and -protected ++ */ ++public class T4501661 { ++ public static void main(String... args) throws Exception { ++ new T4501661().run(); ++ } ++ ++ void run() throws Exception { ++ File javaFile = writeTestFile(); ++ File classFile = compileTestFile(javaFile); ++ boolean[] values = { false, true }; ++ for (boolean priv: values) { ++ for (boolean prot: values) { ++ for (boolean publ: values) { ++ test(priv, prot, publ, classFile); ++ } ++ } ++ } ++ ++ if (errors > 0) ++ throw new Exception(errors + " errors found"); ++ } ++ ++ void test(boolean priv, boolean prot, boolean publ, File classFile) { ++ List<String> args = new ArrayList<String>(); ++ if (priv) ++ args.add("-private"); ++ if (prot) ++ args.add("-protected"); ++ if (publ) ++ args.add("-public"); ++ boolean expectOK = (args.size() <= 1); ++ args.add(classFile.getPath()); ++ String out = javap(args, expectOK); ++ if (out == null) ++ return; ++ if (!priv && !prot && !publ) ++ checkNone(out, "private"); ++ if (prot) ++ checkNone(out, "private", "package"); ++ if (publ) ++ checkNone(out, "private", "package", "protected"); ++ } ++ ++ File writeTestFile() throws IOException { ++ File f = new File("Test.java"); ++ PrintWriter out = new PrintWriter(new BufferedWriter(new FileWriter(f))); ++ out.println("abstract class Test { "); ++ out.println(" public void public_m() { }"); ++ out.println(" protected void protected_m() { }"); ++ out.println(" private void private_m() { }"); ++ out.println(" void package_m() { }"); ++ out.println("}"); ++ out.close(); ++ return f; ++ } ++ ++ File compileTestFile(File f) { ++ int rc = com.sun.tools.javac.Main.compile(new String[] { "-g", f.getPath() }); ++ if (rc != 0) ++ throw new Error("compilation failed. rc=" + rc); ++ String path = f.getPath(); ++ return new File(path.substring(0, path.length() - 5) + ".class"); ++ } ++ ++ String javap(List<String> args, boolean expectOK) { ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(args.toArray(new String[args.size()]), pw); ++ System.err.println(args); ++ System.err.println(sw); ++ if (expectOK) { ++ if (rc == 0) ++ return sw.toString(); ++ else ++ error("javap failed unexpectedly; rc=" + rc + "\n" + sw); ++ } else { ++ if (rc == 0) ++ error("javap succeeded unexpectedly"); ++ } ++ return null; ++ } ++ ++ void checkNone(String log, String... words) { ++ for (String word: words) { ++ if (log.indexOf(word) != -1) ++ error("\"" + word + "\" unexpectedly found in output"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println("error: " + msg); ++ errors++; ++ } ++ ++ int errors; ++} diff --git a/java/openjdk6/files/icedtea/openjdk/4884240-javap_additional_option.patch b/java/openjdk6/files/icedtea/openjdk/4884240-javap_additional_option.patch new file mode 100644 index 000000000000..aada7a068f00 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/4884240-javap_additional_option.patch @@ -0,0 +1,288 @@ +# HG changeset patch +# User jjg +# Date 1217897655 25200 +# Mon Aug 04 17:54:15 2008 -0700 +# Node ID dca34170f5f80bf30228c12a647b3f1a492b3eeb +# Parent 6134c146043a3e9dd12ee73ca32ce56ac1c95e3a +4884240: additional option required for javap +Reviewed-by: ksrini + +diff -r 6134c146043a -r dca34170f5f8 src/share/classes/com/sun/tools/javap/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Mon Aug 04 15:09:02 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Mon Aug 04 17:54:15 2008 -0700 +@@ -25,6 +25,7 @@ + + package com.sun.tools.javap; + ++import java.net.URI; + import java.util.Collection; + import java.util.List; + +@@ -46,6 +47,8 @@ + import com.sun.tools.classfile.SourceFile_attribute; + import com.sun.tools.classfile.Type; + ++import java.text.DateFormat; ++import java.util.Date; + import static com.sun.tools.classfile.AccessFlags.*; + + /* +@@ -73,6 +76,23 @@ + constantWriter = ConstantWriter.instance(context); + } + ++ void setDigest(String name, byte[] digest) { ++ this.digestName = name; ++ this.digest = digest; ++ } ++ ++ void setFile(URI uri) { ++ this.uri = uri; ++ } ++ ++ void setFileSize(int size) { ++ this.size = size; ++ } ++ ++ void setLastModified(long lastModified) { ++ this.lastModified = lastModified; ++ } ++ + ClassFile getClassFile() { + return classFile; + } +@@ -85,6 +105,32 @@ + classFile = cf; + constant_pool = classFile.constant_pool; + ++ if ((options.sysInfo || options.verbose) && !options.compat) { ++ if (uri != null) { ++ if (uri.getScheme().equals("file")) ++ println("Classfile " + uri.getPath()); ++ else ++ println("Classfile " + uri); ++ } ++ if (lastModified != -1) { ++ Date lm = new Date(lastModified); ++ DateFormat df = DateFormat.getDateInstance(); ++ if (size > 0) { ++ println("Last modified " + df.format(lm) + "; size " + size + " bytes"); ++ } else { ++ println("Last modified " + df.format(lm)); ++ } ++ } else if (size > 0) { ++ println("Size " + size + " bytes"); ++ } ++ if (digestName != null && digest != null) { ++ StringBuilder sb = new StringBuilder(); ++ for (byte b: digest) ++ sb.append(String.format("%02x", b)); ++ println(digestName + " checksum " + sb); ++ } ++ } ++ + Attribute sfa = cf.getAttribute(Attribute.SourceFile); + if (sfa instanceof SourceFile_attribute) { + println("Compiled from \"" + getSourceFile((SourceFile_attribute) sfa) + "\""); +@@ -574,6 +620,11 @@ + private CodeWriter codeWriter; + private ConstantWriter constantWriter; + private ClassFile classFile; ++ private URI uri; ++ private long lastModified; ++ private String digestName; ++ private byte[] digest; ++ private int size; + private ConstantPool constant_pool; + private Method method; + private static final String NEWLINE = System.getProperty("line.separator", "\n"); +diff -r 6134c146043a -r dca34170f5f8 src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Mon Aug 04 15:09:02 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Mon Aug 04 17:54:15 2008 -0700 +@@ -27,11 +27,15 @@ + + import java.io.EOFException; + import java.io.FileNotFoundException; ++import java.io.FilterInputStream; ++import java.io.InputStream; + import java.io.IOException; + import java.io.OutputStream; + import java.io.PrintWriter; + import java.io.StringWriter; + import java.io.Writer; ++import java.security.DigestInputStream; ++import java.security.MessageDigest; + import java.text.MessageFormat; + import java.util.ArrayList; + import java.util.Arrays; +@@ -192,6 +196,12 @@ + } + }, + ++ new Option(false, "-sysinfo") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.sysInfo = true; ++ } ++ }, ++ + new Option(false, "-Xold") { + void process(JavapTask task, String opt, String arg) throws BadArgs { + // -Xold is only supported as first arg when invoked from +@@ -457,8 +467,27 @@ + Attribute.Factory attributeFactory = new Attribute.Factory(); + attributeFactory.setCompat(options.compat); + attributeFactory.setJSR277(options.jsr277); +- ClassFile cf = ClassFile.read(fo.openInputStream(), attributeFactory); ++ ++ InputStream in = fo.openInputStream(); ++ SizeInputStream sizeIn = null; ++ MessageDigest md = null; ++ if (options.sysInfo || options.verbose) { ++ md = MessageDigest.getInstance("MD5"); ++ in = new DigestInputStream(in, md); ++ in = sizeIn = new SizeInputStream(in); ++ } ++ ++ ClassFile cf = ClassFile.read(in, attributeFactory); ++ ++ if (options.sysInfo || options.verbose) { ++ classWriter.setFile(fo.toUri()); ++ classWriter.setLastModified(fo.getLastModified()); ++ classWriter.setDigest("MD5", md.digest()); ++ classWriter.setFileSize(sizeIn.size()); ++ } ++ + classWriter.write(cf); ++ + } catch (ConstantPoolException e) { + diagnosticListener.report(createDiagnostic("err.bad.constant.pool", className, e.getLocalizedMessage())); + ok = false; +@@ -628,4 +657,31 @@ + Map<Locale, ResourceBundle> bundles; + + private static final String progname = "javap"; ++ ++ private static class SizeInputStream extends FilterInputStream { ++ SizeInputStream(InputStream in) { ++ super(in); ++ } ++ ++ int size() { ++ return size; ++ } ++ ++ @Override ++ public int read(byte[] buf, int offset, int length) throws IOException { ++ int n = super.read(buf, offset, length); ++ if (n > 0) ++ size += n; ++ return n; ++ } ++ ++ @Override ++ public int read() throws IOException { ++ int b = super.read(); ++ size += 1; ++ return b; ++ } ++ ++ private int size; ++ } + } +diff -r 6134c146043a -r dca34170f5f8 src/share/classes/com/sun/tools/javap/Options.java +--- langtools/src/share/classes/com/sun/tools/javap/Options.java Mon Aug 04 15:09:02 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/Options.java Mon Aug 04 17:54:15 2008 -0700 +@@ -78,6 +78,7 @@ + public boolean showInternalSignatures; + public boolean showAllAttrs; + public boolean showConstants; ++ public boolean sysInfo; + + public boolean compat; // bug-for-bug compatibility mode with old javap + public boolean jsr277; +diff -r 6134c146043a -r dca34170f5f8 src/share/classes/com/sun/tools/javap/resources/javap.properties +--- langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Mon Aug 04 15:09:02 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Mon Aug 04 17:54:15 2008 -0700 +@@ -62,5 +62,6 @@ + \ -constants Show static final constants + + +- +- ++main.opt.sysinfo=\ ++\ -sysinfo Show system info (path, size, date, MD5 hash)\n\ ++\ of class being processed +diff -r 6134c146043a -r dca34170f5f8 test/tools/javap/T4884240.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T4884240.java Mon Aug 04 17:54:15 2008 -0700 +@@ -0,0 +1,56 @@ ++/* ++ * Copyright 2008 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-15301 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. ++ */ ++ ++/* ++ * @test ++ * @bug 4884240 ++ * @summary additional option required for javap ++ */ ++ ++import java.io.*; ++ ++public class T4884240 { ++ public static void main(String... args) throws Exception { ++ new T4884240().run(); ++ } ++ ++ public void run() throws Exception { ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ String[] args = { "-sysinfo", "java.lang.Object" }; ++ int rc = com.sun.tools.javap.Main.run(args, pw); ++ if (rc != 0) ++ throw new Exception("unexpected return code: " + rc); ++ pw.close(); ++ String[] lines = sw.toString().split("\n"); ++ if (lines.length < 3 ++ || !lines[0].startsWith("Classfile") ++ || !lines[1].startsWith("Last modified") ++ || !lines[2].startsWith("MD5")) { ++ System.out.println(sw); ++ throw new Exception("unexpected output"); ++ } ++ } ++} +diff -r 6134c146043a -r dca34170f5f8 test/tools/javap/T6622260.java +--- langtools/test/tools/javap/T6622260.java Mon Aug 04 15:09:02 2008 -0700 ++++ langtools/test/tools/javap/T6622260.java Mon Aug 04 17:54:15 2008 -0700 +@@ -189,6 +189,10 @@ + + void verify(String output) { + System.out.println(output); ++ if (output.startsWith("Classfile")) { ++ // make sure to ignore filename ++ output = output.substring(output.indexOf('\n')); ++ } + if (output.indexOf("-") >= 0) + throw new Error("- found in output"); + if (output.indexOf("FFFFFF") >= 0) diff --git a/java/openjdk6/files/icedtea/openjdk/6708729-javap_makefile_update.patch b/java/openjdk6/files/icedtea/openjdk/6708729-javap_makefile_update.patch new file mode 100644 index 000000000000..5851532b415c --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6708729-javap_makefile_update.patch @@ -0,0 +1,59 @@ +# HG changeset patch +# User jjg +# Date 1212524896 25200 +# Tue Jun 03 13:28:16 2008 -0700 +# Node ID 566f427de7079a0ed32c2f625c952dcc45c348e3 +# Parent d206cb658a9907c7842c8920f141b3c4eb5efc1f +6708729: update jdk Makefiles for new javap +Reviewed-by: ohair + +diff -r d206cb658a99 -r 566f427de707 make/common/Release.gmk +--- jdk/make/common/Release.gmk Mon Oct 21 18:05:56 2013 +0100 ++++ jdk/make/common/Release.gmk Tue Jun 03 13:28:16 2008 -0700 +@@ -357,6 +357,7 @@ + com/sun/jarsigner \ + com/sun/mirror \ + com/sun/source \ ++ com/sun/tools/classfile \ + com/sun/tools/doclets \ + com/sun/tools/example/debug/expr \ + com/sun/tools/example/debug/tty \ +@@ -366,6 +367,7 @@ + com/sun/tools/javadoc \ + com/sun/tools/apt \ + com/sun/tools/javah \ ++ com/sun/tools/javap \ + com/sun/tools/corba \ + com/sun/tools/internal/xjc \ + com/sun/tools/internal/ws \ +@@ -558,6 +560,8 @@ + $(ECHO) "sun/tools/java/" >> $@ + $(ECHO) "sun/tools/javac/" >> $@ + $(ECHO) "sun/tools/javap/" >> $@ ++ $(ECHO) "com/sun/tools/classfile/" >> $@ ++ $(ECHO) "com/sun/tools/javap/" >> $@ + $(ECHO) "sun/tools/jconsole/" >> $@ + $(ECHO) "sun/tools/jps/" >> $@ + $(ECHO) "sun/tools/jstat/" >> $@ +diff -r d206cb658a99 -r 566f427de707 make/common/internal/Defs-langtools.gmk +--- jdk/make/common/internal/Defs-langtools.gmk Mon Oct 21 18:05:56 2013 +0100 ++++ jdk/make/common/internal/Defs-langtools.gmk Tue Jun 03 13:28:16 2008 -0700 +@@ -31,13 +31,15 @@ + javax/tools + + IMPORT_TOOLS_PACKAGES += \ ++ com/sun/javadoc \ + com/sun/mirror \ + com/sun/source \ + com/sun/tools/apt \ ++ com/sun/tools/classfile \ ++ com/sun/tools/doclets \ + com/sun/tools/javac \ ++ com/sun/tools/javadoc \ + com/sun/tools/javah \ +- com/sun/tools/javadoc \ +- com/sun/tools/doclets \ +- com/sun/javadoc \ ++ com/sun/tools/javap \ + sun/tools/javap + diff --git a/java/openjdk6/files/icedtea/openjdk/6715767-javap_crash.patch b/java/openjdk6/files/icedtea/openjdk/6715767-javap_crash.patch new file mode 100644 index 000000000000..37713f727176 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6715767-javap_crash.patch @@ -0,0 +1,135 @@ +# HG changeset patch +# User jjg +# Date 1213833188 25200 +# Wed Jun 18 16:53:08 2008 -0700 +# Node ID c9b0fee44d446f902102462387c40ca9d1020b6e +# Parent 3cbaa3d49584846d4fd8459edeb696b02de5499b +6715767: javap on java.lang.ClassLoader crashes +Reviewed-by: ksrini + +diff -r 3cbaa3d49584 -r c9b0fee44d44 src/share/classes/com/sun/tools/classfile/ConstantPool.java +--- langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Thu Oct 24 02:40:06 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Wed Jun 18 16:53:08 2008 -0700 +@@ -153,7 +153,7 @@ + break; + + case CONSTANT_String: +- pool[i] = new CONSTANT_String_info(cr); ++ pool[i] = new CONSTANT_String_info(this, cr); + break; + + case CONSTANT_Utf8: +@@ -509,7 +509,8 @@ + } + + public static class CONSTANT_String_info extends CPInfo { +- CONSTANT_String_info(ClassReader cr) throws IOException { ++ CONSTANT_String_info(ConstantPool cp, ClassReader cr) throws IOException { ++ super(cp); + string_index = cr.readUnsignedShort(); + } + +diff -r 3cbaa3d49584 -r c9b0fee44d44 src/share/classes/com/sun/tools/javap/AttributeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Thu Oct 24 02:40:06 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Wed Jun 18 16:53:08 2008 -0700 +@@ -259,7 +259,7 @@ + return null; + } + +- String getJavaException(Exceptions_attribute attr, int index) { ++ private String getJavaException(Exceptions_attribute attr, int index) { + try { + return getJavaName(attr.getException(index, constant_pool)); + } catch (ConstantPoolException e) { +diff -r 3cbaa3d49584 -r c9b0fee44d44 src/share/classes/com/sun/tools/javap/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Thu Oct 24 02:40:06 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Wed Jun 18 16:53:08 2008 -0700 +@@ -291,7 +291,7 @@ + for (int i = 0; i < exceptions.number_of_exceptions; i++) { + if (i > 0) + print(", "); +- print(attrWriter.getJavaException(exceptions, i)); ++ print(getJavaException(exceptions, i)); + } + } + } else { +@@ -441,6 +441,14 @@ + } + } + ++ String getJavaException(Exceptions_attribute attr, int index) { ++ try { ++ return getJavaName(attr.getException(index, constant_pool)); ++ } catch (ConstantPoolException e) { ++ return report(e); ++ } ++ } ++ + String getValue(Descriptor d) { + try { + return d.getValue(constant_pool); +diff -r 3cbaa3d49584 -r c9b0fee44d44 src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Thu Oct 24 02:40:06 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Wed Jun 18 16:53:08 2008 -0700 +@@ -475,6 +475,7 @@ + t.printStackTrace(pw); + pw.close(); + diagnosticListener.report(createDiagnostic("err.crash", t.toString(), sw.toString())); ++ ok = false; + } + } + +diff -r 3cbaa3d49584 -r c9b0fee44d44 test/tools/javap/T6715767.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6715767.java Wed Jun 18 16:53:08 2008 -0700 +@@ -0,0 +1,50 @@ ++/* ++ * Copyright 2008 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6715767 ++ * @summary javap on java.lang.ClassLoader crashes ++ */ ++ ++import java.io.*; ++ ++public class T6715767 { ++ public static void main(String... args) throws Exception { ++ new T6715767().run(); ++ } ++ ++ void run() throws Exception { ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ String[] args = { "java.lang.ClassLoader" }; ++ int rc = com.sun.tools.javap.Main.run(args, pw); ++ if (rc != 0 || ++ sw.toString().indexOf("at com.sun.tools.javap.JavapTask.run") != -1) { ++ System.err.println("rc: " + rc); ++ System.err.println("log:\n" + sw); ++ throw new Exception("unexpected result"); ++ } ++ } ++} ++ diff --git a/java/openjdk6/files/icedtea/openjdk/6819246-javap_instruction_decoding.patch b/java/openjdk6/files/icedtea/openjdk/6819246-javap_instruction_decoding.patch new file mode 100644 index 000000000000..70b7d6cc2eae --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6819246-javap_instruction_decoding.patch @@ -0,0 +1,2065 @@ +# HG changeset patch +# User jjg +# Date 1382578806 -3600 +# Thu Oct 24 02:40:06 2013 +0100 +# Node ID 3cbaa3d49584846d4fd8459edeb696b02de5499b +# Parent bfd7bb4218253bac4f57abbc90b987f16e4b7f6c +6819246: improve support for decoding instructions in classfile library +Reviewed-by: ksrini + +diff -r bfd7bb421825 -r 3cbaa3d49584 src/share/classes/com/sun/tools/classfile/Code_attribute.java +--- langtools/src/share/classes/com/sun/tools/classfile/Code_attribute.java Tue Oct 22 01:03:49 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/classfile/Code_attribute.java Thu Oct 24 02:40:06 2013 +0100 +@@ -26,6 +26,8 @@ + package com.sun.tools.classfile; + + import java.io.IOException; ++import java.util.Iterator; ++import java.util.NoSuchElementException; + + /** + * See JVMS3, section 4.8.3. +@@ -99,6 +101,39 @@ + return visitor.visitCode(this, data); + } + ++ public Iterable<Instruction> getInstructions() { ++ return new Iterable<Instruction>() { ++ public Iterator<Instruction> iterator() { ++ return new Iterator<Instruction>() { ++ ++ public boolean hasNext() { ++ return (next != null); ++ } ++ ++ public Instruction next() { ++ if (next == null) ++ throw new NoSuchElementException(); ++ ++ current = next; ++ pc += current.length(); ++ next = (pc < code.length ? new Instruction(code, pc) : null); ++ return current; ++ } ++ ++ public void remove() { ++ throw new UnsupportedOperationException("Not supported."); ++ } ++ ++ Instruction current = null; ++ int pc = 0; ++ Instruction next = new Instruction(code, pc); ++ ++ }; ++ } ++ ++ }; ++ } ++ + public final int max_stack; + public final int max_locals; + public final int code_length; +diff -r bfd7bb421825 -r 3cbaa3d49584 src/share/classes/com/sun/tools/classfile/Instruction.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Instruction.java Thu Oct 24 02:40:06 2013 +0100 +@@ -0,0 +1,339 @@ ++/* ++ * 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.tools.classfile; ++ ++/** ++ * See JVMS3, chapter 6. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ * ++ * @see Code_attribute#getInstructions ++ */ ++public class Instruction { ++ /** The kind of an instruction, as determined by the position, size and ++ * types of its operands. */ ++ public static enum Kind { ++ /** Opcode is not followed by any operands. */ ++ NO_OPERANDS(1), ++ /** Opcode is followed by a byte indicating a type. */ ++ ATYPE(2), ++ /** Opcode is followed by a 2-byte branch offset. */ ++ BRANCH(3), ++ /** Opcode is followed by a 4-byte branch offset. */ ++ BRANCH_W(5), ++ /** Opcode is followed by a signed byte value. */ ++ BYTE(2), ++ /** Opcode is followed by a 1-byte index into the constant pool. */ ++ CPREF(2), ++ /** Opcode is followed by a 2-byte index into the constant pool. */ ++ CPREF_W(3), ++ /** Opcode is followed by a 2-byte index into the constant pool, ++ * an unsigned byte value. */ ++ CPREF_W_UBYTE(4), ++ /** Opcode is followed by a 2-byte index into the constant pool., ++ * an unsigned byte value, and a zero byte. */ ++ CPREF_W_UBYTE_ZERO(5), ++ /** Opcode is followed by variable number of operands, depending ++ * on the instruction.*/ ++ DYNAMIC(-1), ++ /** Opcode is followed by a 1-byte reference to a local variable. */ ++ LOCAL(2), ++ /** Opcode is followed by a 1-byte reference to a local variable, ++ * and a signed byte value. */ ++ LOCAL_BYTE(3), ++ /** Opcode is followed by a signed short value. */ ++ SHORT(3), ++ /** Wide opcode is not followed by any operands. */ ++ WIDE_NO_OPERANDS(2), ++ /** Wide opcode is followed by a 2-byte index into the constant pool. */ ++ WIDE_CPREF_W(4), ++ /** Wide opcode is followed by a 2-byte index into the constant pool, ++ * and a signed short value. */ ++ WIDE_CPREF_W_SHORT(6), ++ /** Opcode was not recognized. */ ++ UNKNOWN(1); ++ ++ Kind(int length) { ++ this.length = length; ++ } ++ ++ /** The length, in bytes, of this kind of instruction, or -1 is the ++ * length depends on the specific instruction. */ ++ public final int length; ++ }; ++ ++ /** A utility visitor to help decode the operands of an instruction. ++ * @see Instruction#accept */ ++ public interface KindVisitor<R,P> { ++ /** See {@link Kind#NO_OPERANDS}, {@link Kind#WIDE_NO_OPERANDS}. */ ++ R visitNoOperands(Instruction instr, P p); ++ /** See {@link Kind#ATYPE}. */ ++ R visitArrayType(Instruction instr, TypeKind kind, P p); ++ /** See {@link Kind#BRANCH}, {@link Kind#BRANCH_W}. */ ++ R visitBranch(Instruction instr, int offset, P p); ++ /** See {@link Kind#CPREF}, {@link Kind#CPREF_W}, {@link Kind#WIDE_CPREF_W}. */ ++ R visitConstantPoolRef(Instruction instr, int index, P p); ++ /** See {@link Kind#CPREF_W_UBYTE}, {@link Kind#CPREF_W_UBYTE_ZERO}, {@link Kind#WIDE_CPREF_W_SHORT}. */ ++ R visitConstantPoolRefAndValue(Instruction instr, int index, int value, P p); ++ /** See {@link Kind#LOCAL}. */ ++ R visitLocal(Instruction instr, int index, P p); ++ /** See {@link Kind#LOCAL_UBYTE}. */ ++ R visitLocalAndValue(Instruction instr, int index, int value, P p); ++ /** See {@link Kind#DYNAMIC}. */ ++ R visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets); ++ /** See {@link Kind#DYNAMIC}. */ ++ R visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets); ++ /** See {@link Kind#BYTE}, {@link Kind#SHORT}. */ ++ R visitValue(Instruction instr, int value, P p); ++ /** Instruction is unrecognized. */ ++ R visitUnknown(Instruction instr, P p); ++ ++ } ++ ++ /** The kind of primitive array type to create. ++ * See JVMS chapter 6, newarray. */ ++ public static enum TypeKind { ++ T_BOOLEAN(4, "boolean"), ++ T_CHAR(5, "char"), ++ T_FLOAT(6, "float"), ++ T_DOUBLE(7, "double"), ++ T_BYTE(8, "byte"), ++ T_SHORT(9, "short"), ++ T_INT (10, "int"), ++ T_LONG (11, "long"); ++ TypeKind(int value, String name) { ++ this.value = value; ++ this.name = name; ++ } ++ ++ public static TypeKind get(int value) { ++ switch (value) { ++ case 4: return T_BOOLEAN; ++ case 5: return T_CHAR; ++ case 6: return T_FLOAT; ++ case 7: return T_DOUBLE; ++ case 8: return T_BYTE; ++ case 9: return T_SHORT; ++ case 10: return T_INT; ++ case 11: return T_LONG; ++ default: return null; ++ } ++ } ++ ++ public final int value; ++ public final String name; ++ } ++ ++ /** An instruction is defined by its position in a bytecode array. */ ++ public Instruction(byte[] bytes, int pc) { ++ this.bytes = bytes; ++ this.pc = pc; ++ } ++ ++ /** Get the position of the instruction within the bytecode array. */ ++ public int getPC() { ++ return pc; ++ } ++ ++ /** Get a byte value, relative to the start of this instruction. */ ++ public int getByte(int offset) { ++ return bytes[pc + offset]; ++ } ++ ++ /** Get an unsigned byte value, relative to the start of this instruction. */ ++ public int getUnsignedByte(int offset) { ++ return getByte(offset) & 0xff; ++ } ++ ++ /** Get a 2-byte value, relative to the start of this instruction. */ ++ public int getShort(int offset) { ++ return (getByte(offset) << 8) | getUnsignedByte(offset + 1); ++ } ++ ++ /** Get a unsigned 2-byte value, relative to the start of this instruction. */ ++ public int getUnsignedShort(int offset) { ++ return getShort(offset) & 0xFFFF; ++ } ++ ++ /** Get a 4-byte value, relative to the start of this instruction. */ ++ public int getInt(int offset) { ++ return (getShort(offset) << 16) | (getUnsignedShort(offset + 2)); ++ } ++ ++ /** Get the Opcode for this instruction, or null if the instruction is ++ * unrecognized. */ ++ public Opcode getOpcode() { ++ int b = getUnsignedByte(0); ++ switch (b) { ++ case Opcode.NONPRIV: ++ case Opcode.PRIV: ++ case Opcode.WIDE: ++ return Opcode.get(b, getUnsignedByte(1)); ++ } ++ return Opcode.get(b); ++ } ++ ++ /** Get the mnemonic for this instruction, or a default string if the ++ * instruction is unrecognized. */ ++ public String getMnemonic() { ++ Opcode opcode = getOpcode(); ++ if (opcode == null) ++ return "bytecode " + getUnsignedByte(0); ++ else ++ return opcode.toString().toLowerCase(); ++ } ++ ++ /** Get the length, in bytes, of this instruction, including the opcode ++ * and all its operands. */ ++ public int length() { ++ Opcode opcode = getOpcode(); ++ if (opcode == null) ++ return 1; ++ ++ switch (opcode) { ++ case TABLESWITCH: { ++ int pad = align(pc + 1) - pc; ++ int low = getInt(pad + 4); ++ int high = getInt(pad + 8); ++ return pad + 12 + 4 * (high - low + 1); ++ } ++ case LOOKUPSWITCH: { ++ int pad = align(pc + 1) - pc; ++ int npairs = getInt(pad + 4); ++ return pad + 8 + 8 * npairs; ++ ++ } ++ default: ++ return opcode.kind.length; ++ } ++ } ++ ++ /** Get the {@link Kind} of this instruction. */ ++ public Kind getKind() { ++ Opcode opcode = getOpcode(); ++ return (opcode != null ? opcode.kind : Kind.UNKNOWN); ++ } ++ ++ /** Invoke a method on the visitor according to the kind of this ++ * instruction, passing in the decoded operands for the instruction. */ ++ public <R,P> R accept(KindVisitor<R,P> visitor, P p) { ++ switch (getKind()) { ++ case NO_OPERANDS: ++ return visitor.visitNoOperands(this, p); ++ ++ case ATYPE: ++ return visitor.visitArrayType( ++ this, TypeKind.get(getUnsignedByte(1)), p); ++ ++ case BRANCH: ++ return visitor.visitBranch(this, getShort(1), p); ++ ++ case BRANCH_W: ++ return visitor.visitBranch(this, getInt(1), p); ++ ++ case BYTE: ++ return visitor.visitValue(this, getByte(1), p); ++ ++ case CPREF: ++ return visitor.visitConstantPoolRef(this, getUnsignedByte(1), p); ++ ++ case CPREF_W: ++ return visitor.visitConstantPoolRef(this, getUnsignedShort(1), p); ++ ++ case CPREF_W_UBYTE: ++ case CPREF_W_UBYTE_ZERO: ++ return visitor.visitConstantPoolRefAndValue( ++ this, getUnsignedShort(1), getUnsignedByte(3), p); ++ ++ case DYNAMIC: { ++ switch (getOpcode()) { ++ case TABLESWITCH: { ++ int pad = align(pc + 1) - pc; ++ int default_ = getInt(pad); ++ int low = getInt(pad + 4); ++ int high = getInt(pad + 8); ++ int[] values = new int[high - low + 1]; ++ for (int i = 0; i < values.length; i++) ++ values[i] = getInt(pad + 12 + 4 * i); ++ return visitor.visitTableSwitch( ++ this, default_, low, high, values); ++ } ++ case LOOKUPSWITCH: { ++ int pad = align(pc + 1) - pc; ++ int default_ = getInt(pad); ++ int npairs = getInt(pad + 4); ++ int[] matches = new int[npairs]; ++ int[] offsets = new int[npairs]; ++ for (int i = 0; i < npairs; i++) { ++ matches[i] = getInt(pad + 8 + i * 8); ++ offsets[i] = getInt(pad + 12 + i * 8); ++ } ++ return visitor.visitLookupSwitch( ++ this, default_, npairs, matches, offsets); ++ } ++ default: ++ throw new IllegalStateException(); ++ } ++ } ++ ++ case LOCAL: ++ return visitor.visitLocal(this, getUnsignedByte(1), p); ++ ++ case LOCAL_BYTE: ++ return visitor.visitLocalAndValue( ++ this, getUnsignedByte(1), getByte(2), p); ++ ++ case SHORT: ++ return visitor.visitValue(this, getShort(1), p); ++ ++ case WIDE_NO_OPERANDS: ++ return visitor.visitNoOperands(this, p); ++ ++ case WIDE_CPREF_W: ++ return visitor.visitConstantPoolRef(this, getUnsignedShort(2), p); ++ ++ case WIDE_CPREF_W_SHORT: ++ return visitor.visitConstantPoolRefAndValue( ++ this, getUnsignedShort(2), getUnsignedByte(4), p); ++ ++ case UNKNOWN: ++ return visitor.visitUnknown(this, p); ++ ++ default: ++ throw new IllegalStateException(); ++ } ++ } ++ ++ private static int align(int n) { ++ return (n + 3) & ~3; ++ } ++ ++ private byte[] bytes; ++ private int pc; ++} +diff -r bfd7bb421825 -r 3cbaa3d49584 src/share/classes/com/sun/tools/classfile/OpCodes.java +--- langtools/src/share/classes/com/sun/tools/classfile/OpCodes.java Tue Oct 22 01:03:49 2013 +0100 ++++ /dev/null Thu Jan 01 00:00:00 1970 +0000 +@@ -1,868 +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.tools.classfile; +- +-import java.util.HashMap; +- +-/** +- * See JVMS3, section 6. +- * +- * <p><b>This is NOT part of any API supported by Sun Microsystems. If +- * you write code that depends on this, you do so at your own risk. +- * This code and its internal interfaces are subject to change or +- * deletion without notice.</b> +- */ +-public class OpCodes { +- +- public static int opcLength(int opc) throws IllegalArgumentException { +- switch (opc >> 8) { +- case 0: +- return opcLengthsTab[opc]; +- case opc_wide: +- switch (opc & 0xFF) { +- case opc_aload: +- case opc_astore: +- case opc_fload: +- case opc_fstore: +- case opc_iload: +- case opc_istore: +- case opc_lload: +- case opc_lstore: +- case opc_dload: +- case opc_dstore: +- case opc_ret: +- return 4; +- case opc_iinc: +- return 6; +- default: +- throw new IllegalArgumentException(); +- } +- case opc_nonpriv: +- case opc_priv: +- return 2; +- default: +- throw new IllegalArgumentException(); +- } +- } +- +- public static String opcName(int opc) { +- try { +- switch (opc >> 8) { +- case 0: +- return opcNamesTab[opc]; +- case opc_wide: +- { +- String mnem = opcNamesTab[opc & 0xFF] + "_w"; +- if (mnemocodes.get(mnem) == null) { +- return null; // non-existent opcode +- } +- return mnem; +- } +- case opc_nonpriv: +- return opcExtNamesTab[opc & 0xFF]; +- case opc_priv: +- return opcPrivExtNamesTab[opc & 0xFF]; +- default: +- return null; +- } +- } catch (ArrayIndexOutOfBoundsException e) { +- switch (opc) { +- case opc_nonpriv: +- return "nonpriv"; +- case opc_priv: +- return "priv"; +- default: +- return null; +- } +- } +- } +- +- /* Opcodes */ +- public static final int opc_dead = -2; +- public static final int opc_label = -1; +- public static final int opc_nop = 0; +- public static final int opc_aconst_null = 1; +- public static final int opc_iconst_m1 = 2; +- public static final int opc_iconst_0 = 3; +- public static final int opc_iconst_1 = 4; +- public static final int opc_iconst_2 = 5; +- public static final int opc_iconst_3 = 6; +- public static final int opc_iconst_4 = 7; +- public static final int opc_iconst_5 = 8; +- public static final int opc_lconst_0 = 9; +- public static final int opc_lconst_1 = 10; +- public static final int opc_fconst_0 = 11; +- public static final int opc_fconst_1 = 12; +- public static final int opc_fconst_2 = 13; +- public static final int opc_dconst_0 = 14; +- public static final int opc_dconst_1 = 15; +- public static final int opc_bipush = 16; +- public static final int opc_sipush = 17; +- public static final int opc_ldc = 18; +- public static final int opc_ldc_w = 19; +- public static final int opc_ldc2_w = 20; +- public static final int opc_iload = 21; +- public static final int opc_lload = 22; +- public static final int opc_fload = 23; +- public static final int opc_dload = 24; +- public static final int opc_aload = 25; +- public static final int opc_iload_0 = 26; +- public static final int opc_iload_1 = 27; +- public static final int opc_iload_2 = 28; +- public static final int opc_iload_3 = 29; +- public static final int opc_lload_0 = 30; +- public static final int opc_lload_1 = 31; +- public static final int opc_lload_2 = 32; +- public static final int opc_lload_3 = 33; +- public static final int opc_fload_0 = 34; +- public static final int opc_fload_1 = 35; +- public static final int opc_fload_2 = 36; +- public static final int opc_fload_3 = 37; +- public static final int opc_dload_0 = 38; +- public static final int opc_dload_1 = 39; +- public static final int opc_dload_2 = 40; +- public static final int opc_dload_3 = 41; +- public static final int opc_aload_0 = 42; +- public static final int opc_aload_1 = 43; +- public static final int opc_aload_2 = 44; +- public static final int opc_aload_3 = 45; +- public static final int opc_iaload = 46; +- public static final int opc_laload = 47; +- public static final int opc_faload = 48; +- public static final int opc_daload = 49; +- public static final int opc_aaload = 50; +- public static final int opc_baload = 51; +- public static final int opc_caload = 52; +- public static final int opc_saload = 53; +- public static final int opc_istore = 54; +- public static final int opc_lstore = 55; +- public static final int opc_fstore = 56; +- public static final int opc_dstore = 57; +- public static final int opc_astore = 58; +- public static final int opc_istore_0 = 59; +- public static final int opc_istore_1 = 60; +- public static final int opc_istore_2 = 61; +- public static final int opc_istore_3 = 62; +- public static final int opc_lstore_0 = 63; +- public static final int opc_lstore_1 = 64; +- public static final int opc_lstore_2 = 65; +- public static final int opc_lstore_3 = 66; +- public static final int opc_fstore_0 = 67; +- public static final int opc_fstore_1 = 68; +- public static final int opc_fstore_2 = 69; +- public static final int opc_fstore_3 = 70; +- public static final int opc_dstore_0 = 71; +- public static final int opc_dstore_1 = 72; +- public static final int opc_dstore_2 = 73; +- public static final int opc_dstore_3 = 74; +- public static final int opc_astore_0 = 75; +- public static final int opc_astore_1 = 76; +- public static final int opc_astore_2 = 77; +- public static final int opc_astore_3 = 78; +- public static final int opc_iastore = 79; +- public static final int opc_lastore = 80; +- public static final int opc_fastore = 81; +- public static final int opc_dastore = 82; +- public static final int opc_aastore = 83; +- public static final int opc_bastore = 84; +- public static final int opc_castore = 85; +- public static final int opc_sastore = 86; +- public static final int opc_pop = 87; +- public static final int opc_pop2 = 88; +- public static final int opc_dup = 89; +- public static final int opc_dup_x1 = 90; +- public static final int opc_dup_x2 = 91; +- public static final int opc_dup2 = 92; +- public static final int opc_dup2_x1 = 93; +- public static final int opc_dup2_x2 = 94; +- public static final int opc_swap = 95; +- public static final int opc_iadd = 96; +- public static final int opc_ladd = 97; +- public static final int opc_fadd = 98; +- public static final int opc_dadd = 99; +- public static final int opc_isub = 100; +- public static final int opc_lsub = 101; +- public static final int opc_fsub = 102; +- public static final int opc_dsub = 103; +- public static final int opc_imul = 104; +- public static final int opc_lmul = 105; +- public static final int opc_fmul = 106; +- public static final int opc_dmul = 107; +- public static final int opc_idiv = 108; +- public static final int opc_ldiv = 109; +- public static final int opc_fdiv = 110; +- public static final int opc_ddiv = 111; +- public static final int opc_irem = 112; +- public static final int opc_lrem = 113; +- public static final int opc_frem = 114; +- public static final int opc_drem = 115; +- public static final int opc_ineg = 116; +- public static final int opc_lneg = 117; +- public static final int opc_fneg = 118; +- public static final int opc_dneg = 119; +- public static final int opc_ishl = 120; +- public static final int opc_lshl = 121; +- public static final int opc_ishr = 122; +- public static final int opc_lshr = 123; +- public static final int opc_iushr = 124; +- public static final int opc_lushr = 125; +- public static final int opc_iand = 126; +- public static final int opc_land = 127; +- public static final int opc_ior = 128; +- public static final int opc_lor = 129; +- public static final int opc_ixor = 130; +- public static final int opc_lxor = 131; +- public static final int opc_iinc = 132; +- public static final int opc_i2l = 133; +- public static final int opc_i2f = 134; +- public static final int opc_i2d = 135; +- public static final int opc_l2i = 136; +- public static final int opc_l2f = 137; +- public static final int opc_l2d = 138; +- public static final int opc_f2i = 139; +- public static final int opc_f2l = 140; +- public static final int opc_f2d = 141; +- public static final int opc_d2i = 142; +- public static final int opc_d2l = 143; +- public static final int opc_d2f = 144; +- public static final int opc_i2b = 145; +- public static final int opc_int2byte = 145; +- public static final int opc_i2c = 146; +- public static final int opc_int2char = 146; +- public static final int opc_i2s = 147; +- public static final int opc_int2short = 147; +- public static final int opc_lcmp = 148; +- public static final int opc_fcmpl = 149; +- public static final int opc_fcmpg = 150; +- public static final int opc_dcmpl = 151; +- public static final int opc_dcmpg = 152; +- public static final int opc_ifeq = 153; +- public static final int opc_ifne = 154; +- public static final int opc_iflt = 155; +- public static final int opc_ifge = 156; +- public static final int opc_ifgt = 157; +- public static final int opc_ifle = 158; +- public static final int opc_if_icmpeq = 159; +- public static final int opc_if_icmpne = 160; +- public static final int opc_if_icmplt = 161; +- public static final int opc_if_icmpge = 162; +- public static final int opc_if_icmpgt = 163; +- public static final int opc_if_icmple = 164; +- public static final int opc_if_acmpeq = 165; +- public static final int opc_if_acmpne = 166; +- public static final int opc_goto = 167; +- public static final int opc_jsr = 168; +- public static final int opc_ret = 169; +- public static final int opc_tableswitch = 170; +- public static final int opc_lookupswitch = 171; +- public static final int opc_ireturn = 172; +- public static final int opc_lreturn = 173; +- public static final int opc_freturn = 174; +- public static final int opc_dreturn = 175; +- public static final int opc_areturn = 176; +- public static final int opc_return = 177; +- public static final int opc_getstatic = 178; +- public static final int opc_putstatic = 179; +- public static final int opc_getfield = 180; +- public static final int opc_putfield = 181; +- public static final int opc_invokevirtual = 182; +- public static final int opc_invokenonvirtual = 183; +- public static final int opc_invokespecial = 183; +- public static final int opc_invokestatic = 184; +- public static final int opc_invokeinterface = 185; +-// public static final int opc_xxxunusedxxx = 186; +- public static final int opc_new = 187; +- public static final int opc_newarray = 188; +- public static final int opc_anewarray = 189; +- public static final int opc_arraylength = 190; +- public static final int opc_athrow = 191; +- public static final int opc_checkcast = 192; +- public static final int opc_instanceof = 193; +- public static final int opc_monitorenter = 194; +- public static final int opc_monitorexit = 195; +- public static final int opc_wide = 196; +- public static final int opc_multianewarray = 197; +- public static final int opc_ifnull = 198; +- public static final int opc_ifnonnull = 199; +- public static final int opc_goto_w = 200; +- public static final int opc_jsr_w = 201; +- +- /* Pseudo-instructions */ +- public static final int opc_bytecode = 203; +- public static final int opc_try = 204; +- public static final int opc_endtry = 205; +- public static final int opc_catch = 206; +- public static final int opc_var = 207; +- public static final int opc_endvar = 208; +- public static final int opc_localsmap = 209; +- public static final int opc_stackmap = 210; +- +- /* PicoJava prefixes */ +- public static final int opc_nonpriv = 254; +- public static final int opc_priv = 255; +- +- /* Wide instructions */ +- public static final int opc_iload_w = (opc_wide << 8 ) | opc_iload; +- public static final int opc_lload_w = (opc_wide << 8 ) | opc_lload; +- public static final int opc_fload_w = (opc_wide << 8 ) | opc_fload; +- public static final int opc_dload_w = (opc_wide << 8 ) | opc_dload; +- public static final int opc_aload_w = (opc_wide << 8 ) | opc_aload; +- public static final int opc_istore_w = (opc_wide << 8 ) | opc_istore; +- public static final int opc_lstore_w = (opc_wide << 8 ) | opc_lstore; +- public static final int opc_fstore_w = (opc_wide << 8 ) | opc_fstore; +- public static final int opc_dstore_w = (opc_wide << 8 ) | opc_dstore; +- public static final int opc_astore_w = (opc_wide << 8 ) | opc_astore; +- public static final int opc_ret_w = (opc_wide << 8 ) | opc_ret; +- public static final int opc_iinc_w = (opc_wide << 8 ) | opc_iinc; +- +- /* Opcode Names */ +- private static final String opcNamesTab[] = { +- "nop", +- "aconst_null", +- "iconst_m1", +- "iconst_0", +- "iconst_1", +- "iconst_2", +- "iconst_3", +- "iconst_4", +- "iconst_5", +- "lconst_0", +- "lconst_1", +- "fconst_0", +- "fconst_1", +- "fconst_2", +- "dconst_0", +- "dconst_1", +- "bipush", +- "sipush", +- "ldc", +- "ldc_w", +- "ldc2_w", +- "iload", +- "lload", +- "fload", +- "dload", +- "aload", +- "iload_0", +- "iload_1", +- "iload_2", +- "iload_3", +- "lload_0", +- "lload_1", +- "lload_2", +- "lload_3", +- "fload_0", +- "fload_1", +- "fload_2", +- "fload_3", +- "dload_0", +- "dload_1", +- "dload_2", +- "dload_3", +- "aload_0", +- "aload_1", +- "aload_2", +- "aload_3", +- "iaload", +- "laload", +- "faload", +- "daload", +- "aaload", +- "baload", +- "caload", +- "saload", +- "istore", +- "lstore", +- "fstore", +- "dstore", +- "astore", +- "istore_0", +- "istore_1", +- "istore_2", +- "istore_3", +- "lstore_0", +- "lstore_1", +- "lstore_2", +- "lstore_3", +- "fstore_0", +- "fstore_1", +- "fstore_2", +- "fstore_3", +- "dstore_0", +- "dstore_1", +- "dstore_2", +- "dstore_3", +- "astore_0", +- "astore_1", +- "astore_2", +- "astore_3", +- "iastore", +- "lastore", +- "fastore", +- "dastore", +- "aastore", +- "bastore", +- "castore", +- "sastore", +- "pop", +- "pop2", +- "dup", +- "dup_x1", +- "dup_x2", +- "dup2", +- "dup2_x1", +- "dup2_x2", +- "swap", +- "iadd", +- "ladd", +- "fadd", +- "dadd", +- "isub", +- "lsub", +- "fsub", +- "dsub", +- "imul", +- "lmul", +- "fmul", +- "dmul", +- "idiv", +- "ldiv", +- "fdiv", +- "ddiv", +- "irem", +- "lrem", +- "frem", +- "drem", +- "ineg", +- "lneg", +- "fneg", +- "dneg", +- "ishl", +- "lshl", +- "ishr", +- "lshr", +- "iushr", +- "lushr", +- "iand", +- "land", +- "ior", +- "lor", +- "ixor", +- "lxor", +- "iinc", +- "i2l", +- "i2f", +- "i2d", +- "l2i", +- "l2f", +- "l2d", +- "f2i", +- "f2l", +- "f2d", +- "d2i", +- "d2l", +- "d2f", +- "i2b", +- "i2c", +- "i2s", +- "lcmp", +- "fcmpl", +- "fcmpg", +- "dcmpl", +- "dcmpg", +- "ifeq", +- "ifne", +- "iflt", +- "ifge", +- "ifgt", +- "ifle", +- "if_icmpeq", +- "if_icmpne", +- "if_icmplt", +- "if_icmpge", +- "if_icmpgt", +- "if_icmple", +- "if_acmpeq", +- "if_acmpne", +- "goto", +- "jsr", +- "ret", +- "tableswitch", +- "lookupswitch", +- "ireturn", +- "lreturn", +- "freturn", +- "dreturn", +- "areturn", +- "return", +- "getstatic", +- "putstatic", +- "getfield", +- "putfield", +- "invokevirtual", +- "invokespecial", // was "invokenonvirtual", +- "invokestatic", +- "invokeinterface", +- "bytecode 186", //"xxxunusedxxx", +- "new", +- "newarray", +- "anewarray", +- "arraylength", +- "athrow", +- "checkcast", +- "instanceof", +- "monitorenter", +- "monitorexit", +- null, // "wide", +- "multianewarray", +- "ifnull", +- "ifnonnull", +- "goto_w", +- "jsr_w", +- "bytecode 202", // "breakpoint", +- "bytecode", +- "try", +- "endtry", +- "catch", +- "var", +- "endvar", +- "locals_map", +- "stack_map" +- }; +- +- /* Opcode Lengths */ +- private static final int opcLengthsTab[] = { +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 2, +- 3, +- 2, +- 3, +- 3, +- 2, +- 2, +- 2, +- 2, +- 2, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 2, +- 2, +- 2, +- 2, +- 2, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 3, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 2, +- 99, +- 99, +- 1, +- 1, +- 1, +- 1, +- 1, +- 1, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 3, +- 5, +- 0, +- 3, +- 2, +- 3, +- 1, +- 1, +- 3, +- 3, +- 1, +- 1, +- 0, // wide +- 4, +- 3, +- 3, +- 5, +- 5, +- 1, +- 1, 0, 0, 0, 0, 0 // pseudo +- }; +- +- /* Type codes, used in newarray opcode */ +- public static final int T_CLASS = 0x00000002; +- public static final int T_BOOLEAN = 0x00000004; +- public static final int T_CHAR = 0x00000005; +- public static final int T_FLOAT = 0x00000006; +- public static final int T_DOUBLE = 0x00000007; +- public static final int T_BYTE = 0x00000008; +- public static final int T_SHORT = 0x00000009; +- public static final int T_INT = 0x0000000a; +- public static final int T_LONG = 0x0000000b; +- +- private static HashMap<String,Integer> mnemocodes = new HashMap<String,Integer>(301, 0.5f); +- private static String opcExtNamesTab[]=new String[128]; +- private static String opcPrivExtNamesTab[]=new String[128]; +- +- private static void defineNonPriv(int opc, String mnem) { +- mnemocodes.put(opcExtNamesTab[opc] = mnem, opc_nonpriv * 256 + opc); +- } +- +- private static void definePriv(int opc, String mnem) { +- mnemocodes.put(opcPrivExtNamesTab[opc] = "priv_" + mnem, opc_priv * 256 + opc); +- } +- +- private static void defineExt(int opc, String mnem) { +- defineNonPriv(opc, mnem); +- definePriv(opc, mnem); +- } +- +- static { +- for (int i = 0; i < opc_wide; i++) { +- mnemocodes.put(opcNamesTab[i], i); +- } +- for (int i = opc_wide + 1; i < opcNamesTab.length; i++) { +- mnemocodes.put(opcNamesTab[i], i); +- } +- mnemocodes.put("invokenonvirtual", opc_invokespecial); +- +- mnemocodes.put("iload_w", opc_iload_w); +- mnemocodes.put("lload_w", opc_lload_w); +- mnemocodes.put("fload_w", opc_fload_w); +- mnemocodes.put("dload_w", opc_dload_w); +- mnemocodes.put("aload_w", opc_aload_w); +- mnemocodes.put("istore_w", opc_istore_w); +- mnemocodes.put("lstore_w", opc_lstore_w); +- mnemocodes.put("fstore_w", opc_fstore_w); +- mnemocodes.put("dstore_w", opc_dstore_w); +- mnemocodes.put("astore_w", opc_astore_w); +- mnemocodes.put("ret_w", opc_ret_w); +- mnemocodes.put("iinc_w", opc_iinc_w); +- +- mnemocodes.put("nonpriv", opc_nonpriv); +- mnemocodes.put("priv", opc_priv); +- +- defineExt(0, "load_ubyte"); +- defineExt(1, "load_byte"); +- defineExt(2, "load_char"); +- defineExt(3, "load_short"); +- defineExt(4, "load_word"); +- defineExt(10, "load_char_oe"); +- defineExt(11, "load_short_oe"); +- defineExt(12, "load_word_oe"); +- defineExt(16, "ncload_ubyte"); +- defineExt(17, "ncload_byte"); +- defineExt(18, "ncload_char"); +- defineExt(19, "ncload_short"); +- defineExt(20, "ncload_word"); +- defineExt(26, "ncload_char_oe"); +- defineExt(27, "ncload_short_oe"); +- defineExt(28, "ncload_word_oe"); +- defineExt(30, "cache_flush"); +- defineExt(32, "store_byte"); +- defineExt(34, "store_short"); +- defineExt(36, "store_word"); +- defineExt(42, "store_short_oe"); +- defineExt(44, "store_word_oe"); +- defineExt(48, "ncstore_byte"); +- defineExt(50, "ncstore_short"); +- defineExt(52, "ncstore_word"); +- defineExt(58, "ncstore_short_oe"); +- defineExt(60, "ncstore_word_oe"); +- defineExt(62, "zero_line"); +- defineNonPriv(5, "ret_from_sub"); +- defineNonPriv(63, "enter_sync_method"); +- definePriv(5, "ret_from_trap"); +- definePriv(6, "read_dcache_tag"); +- definePriv(7, "read_dcache_data"); +- definePriv(14, "read_icache_tag"); +- definePriv(15, "read_icache_data"); +- definePriv(22, "powerdown"); +- definePriv(23, "read_scache_data"); +- definePriv(31, "cache_index_flush"); +- definePriv(38, "write_dcache_tag"); +- definePriv(39, "write_dcache_data"); +- definePriv(46, "write_icache_tag"); +- definePriv(47, "write_icache_data"); +- definePriv(54, "reset"); +- definePriv(55, "write_scache_data"); +- for (int i = 0; i < 32; i++) { +- definePriv(i + 64, "read_reg_" + i); +- } +- for (int i = 0; i < 32; i++) { +- definePriv(i + 96, "write_reg_" + i); +- } +- } +-} +diff -r bfd7bb421825 -r 3cbaa3d49584 src/share/classes/com/sun/tools/classfile/Opcode.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/classfile/Opcode.java Thu Oct 24 02:40:06 2013 +0100 +@@ -0,0 +1,472 @@ ++/* ++ * 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.tools.classfile; ++ ++import static com.sun.tools.classfile.Instruction.Kind.*; ++import static com.sun.tools.classfile.Opcode.Set.*; ++ ++/** ++ * See JVMS3, chapter 6. ++ * ++ * <p>In addition to providing all the standard opcodes defined in JVMS, ++ * this class also provides legacy support for the PicoJava extensions. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public enum Opcode { ++ NOP(0x0), ++ ACONST_NULL(0x1), ++ ICONST_M1(0x2), ++ ICONST_0(0x3), ++ ICONST_1(0x4), ++ ICONST_2(0x5), ++ ICONST_3(0x6), ++ ICONST_4(0x7), ++ ICONST_5(0x8), ++ LCONST_0(0x9), ++ LCONST_1(0xa), ++ FCONST_0(0xb), ++ FCONST_1(0xc), ++ FCONST_2(0xd), ++ DCONST_0(0xe), ++ DCONST_1(0xf), ++ BIPUSH(0x10, BYTE), ++ SIPUSH(0x11, SHORT), ++ LDC(0x12, CPREF), ++ LDC_W(0x13, CPREF_W), ++ LDC2_W(0x14, CPREF_W), ++ ILOAD(0x15, LOCAL), ++ LLOAD(0x16, LOCAL), ++ FLOAD(0x17, LOCAL), ++ DLOAD(0x18, LOCAL), ++ ALOAD(0x19, LOCAL), ++ ILOAD_0(0x1a), ++ ILOAD_1(0x1b), ++ ILOAD_2(0x1c), ++ ILOAD_3(0x1d), ++ LLOAD_0(0x1e), ++ LLOAD_1(0x1f), ++ LLOAD_2(0x20), ++ LLOAD_3(0x21), ++ FLOAD_0(0x22), ++ FLOAD_1(0x23), ++ FLOAD_2(0x24), ++ FLOAD_3(0x25), ++ DLOAD_0(0x26), ++ DLOAD_1(0x27), ++ DLOAD_2(0x28), ++ DLOAD_3(0x29), ++ ALOAD_0(0x2a), ++ ALOAD_1(0x2b), ++ ALOAD_2(0x2c), ++ ALOAD_3(0x2d), ++ IALOAD(0x2e), ++ LALOAD(0x2f), ++ FALOAD(0x30), ++ DALOAD(0x31), ++ AALOAD(0x32), ++ BALOAD(0x33), ++ CALOAD(0x34), ++ SALOAD(0x35), ++ ISTORE(0x36, LOCAL), ++ LSTORE(0x37, LOCAL), ++ FSTORE(0x38, LOCAL), ++ DSTORE(0x39, LOCAL), ++ ASTORE(0x3a, LOCAL), ++ ISTORE_0(0x3b), ++ ISTORE_1(0x3c), ++ ISTORE_2(0x3d), ++ ISTORE_3(0x3e), ++ LSTORE_0(0x3f), ++ LSTORE_1(0x40), ++ LSTORE_2(0x41), ++ LSTORE_3(0x42), ++ FSTORE_0(0x43), ++ FSTORE_1(0x44), ++ FSTORE_2(0x45), ++ FSTORE_3(0x46), ++ DSTORE_0(0x47), ++ DSTORE_1(0x48), ++ DSTORE_2(0x49), ++ DSTORE_3(0x4a), ++ ASTORE_0(0x4b), ++ ASTORE_1(0x4c), ++ ASTORE_2(0x4d), ++ ASTORE_3(0x4e), ++ IASTORE(0x4f), ++ LASTORE(0x50), ++ FASTORE(0x51), ++ DASTORE(0x52), ++ AASTORE(0x53), ++ BASTORE(0x54), ++ CASTORE(0x55), ++ SASTORE(0x56), ++ POP(0x57), ++ POP2(0x58), ++ DUP(0x59), ++ DUP_X1(0x5a), ++ DUP_X2(0x5b), ++ DUP2(0x5c), ++ DUP2_X1(0x5d), ++ DUP2_X2(0x5e), ++ SWAP(0x5f), ++ IADD(0x60), ++ LADD(0x61), ++ FADD(0x62), ++ DADD(0x63), ++ ISUB(0x64), ++ LSUB(0x65), ++ FSUB(0x66), ++ DSUB(0x67), ++ IMUL(0x68), ++ LMUL(0x69), ++ FMUL(0x6a), ++ DMUL(0x6b), ++ IDIV(0x6c), ++ LDIV(0x6d), ++ FDIV(0x6e), ++ DDIV(0x6f), ++ IREM(0x70), ++ LREM(0x71), ++ FREM(0x72), ++ DREM(0x73), ++ INEG(0x74), ++ LNEG(0x75), ++ FNEG(0x76), ++ DNEG(0x77), ++ ISHL(0x78), ++ LSHL(0x79), ++ ISHR(0x7a), ++ LSHR(0x7b), ++ IUSHR(0x7c), ++ LUSHR(0x7d), ++ IAND(0x7e), ++ LAND(0x7f), ++ IOR(0x80), ++ LOR(0x81), ++ IXOR(0x82), ++ LXOR(0x83), ++ IINC(0x84, LOCAL_BYTE), ++ I2L(0x85), ++ I2F(0x86), ++ I2D(0x87), ++ L2I(0x88), ++ L2F(0x89), ++ L2D(0x8a), ++ F2I(0x8b), ++ F2L(0x8c), ++ F2D(0x8d), ++ D2I(0x8e), ++ D2L(0x8f), ++ D2F(0x90), ++ I2B(0x91), ++ I2C(0x92), ++ I2S(0x93), ++ LCMP(0x94), ++ FCMPL(0x95), ++ FCMPG(0x96), ++ DCMPL(0x97), ++ DCMPG(0x98), ++ IFEQ(0x99, BRANCH), ++ IFNE(0x9a, BRANCH), ++ IFLT(0x9b, BRANCH), ++ IFGE(0x9c, BRANCH), ++ IFGT(0x9d, BRANCH), ++ IFLE(0x9e, BRANCH), ++ IF_ICMPEQ(0x9f, BRANCH), ++ IF_ICMPNE(0xa0, BRANCH), ++ IF_ICMPLT(0xa1, BRANCH), ++ IF_ICMPGE(0xa2, BRANCH), ++ IF_ICMPGT(0xa3, BRANCH), ++ IF_ICMPLE(0xa4, BRANCH), ++ IF_ACMPEQ(0xa5, BRANCH), ++ IF_ACMPNE(0xa6, BRANCH), ++ GOTO(0xa7, BRANCH), ++ JSR(0xa8, BRANCH), ++ RET(0xa9, LOCAL), ++ TABLESWITCH(0xaa, DYNAMIC), ++ LOOKUPSWITCH(0xab, DYNAMIC), ++ IRETURN(0xac), ++ LRETURN(0xad), ++ FRETURN(0xae), ++ DRETURN(0xaf), ++ ARETURN(0xb0), ++ RETURN(0xb1), ++ GETSTATIC(0xb2, CPREF_W), ++ PUTSTATIC(0xb3, CPREF_W), ++ GETFIELD(0xb4, CPREF_W), ++ PUTFIELD(0xb5, CPREF_W), ++ INVOKEVIRTUAL(0xb6, CPREF_W), ++ INVOKESPECIAL(0xb7, CPREF_W), ++ INVOKESTATIC(0xb8, CPREF_W), ++ INVOKEINTERFACE(0xb9, CPREF_W_UBYTE_ZERO), ++ // unused 0xba ++ NEW(0xbb, CPREF_W), ++ NEWARRAY(0xbc, ATYPE), ++ ANEWARRAY(0xbd, CPREF_W), ++ ARRAYLENGTH(0xbe), ++ ATHROW(0xbf), ++ CHECKCAST(0xc0, CPREF_W), ++ INSTANCEOF(0xc1, CPREF_W), ++ MONITORENTER(0xc2), ++ MONITOREXIT(0xc3), ++ // wide 0xc4 ++ MULTIANEWARRAY(0xc5, CPREF_W_UBYTE), ++ IFNULL(0xc6, BRANCH), ++ IFNONNULL(0xc7, BRANCH), ++ GOTO_W(0xc8, BRANCH_W), ++ JSR_W(0xc9, BRANCH_W), ++ // impdep 0xfe: PicoJava nonpriv ++ // impdep 0xff: Picojava priv ++ ++ // wide opcodes ++ ILOAD_W(0xc415, WIDE_CPREF_W), ++ LLOAD_W(0xc416, WIDE_CPREF_W), ++ FLOAD_W(0xc417, WIDE_CPREF_W), ++ DLOAD_W(0xc418, WIDE_CPREF_W), ++ ALOAD_W(0xc419, WIDE_CPREF_W), ++ ISTORE_W(0xc436, WIDE_CPREF_W), ++ LSTORE_W(0xc437, WIDE_CPREF_W), ++ FSTORE_W(0xc438, WIDE_CPREF_W), ++ DSTORE_W(0xc439, WIDE_CPREF_W), ++ ASTORE_W(0xc43a, WIDE_CPREF_W), ++ IINC_W(0xc484, WIDE_CPREF_W_SHORT), ++ RET_W(0xc4a9, WIDE_CPREF_W), ++ ++ // PicoJava nonpriv instructions ++ LOAD_UBYTE(PICOJAVA, 0xfe00), ++ LOAD_BYTE(PICOJAVA, 0xfe01), ++ LOAD_CHAR(PICOJAVA, 0xfe02), ++ LOAD_SHORT(PICOJAVA, 0xfe03), ++ LOAD_WORD(PICOJAVA, 0xfe04), ++ RET_FROM_SUB(PICOJAVA, 0xfe05), ++ LOAD_CHAR_OE(PICOJAVA, 0xfe0a), ++ LOAD_SHORT_OE(PICOJAVA, 0xfe0b), ++ LOAD_WORD_OE(PICOJAVA, 0xfe0c), ++ NCLOAD_UBYTE(PICOJAVA, 0xfe10), ++ NCLOAD_BYTE(PICOJAVA, 0xfe11), ++ NCLOAD_CHAR(PICOJAVA, 0xfe12), ++ NCLOAD_SHORT(PICOJAVA, 0xfe13), ++ NCLOAD_WORD(PICOJAVA, 0xfe14), ++ NCLOAD_CHAR_OE(PICOJAVA, 0xfe1a), ++ NCLOAD_SHORT_OE(PICOJAVA, 0xfe1b), ++ NCLOAD_WORD_OE(PICOJAVA, 0xfe1c), ++ CACHE_FLUSH(PICOJAVA, 0xfe1e), ++ STORE_BYTE(PICOJAVA, 0xfe20), ++ STORE_SHORT(PICOJAVA, 0xfe22), ++ STORE_WORD(PICOJAVA, 0xfe24), ++ STORE_SHORT_OE(PICOJAVA, 0xfe2a), ++ STORE_WORD_OE(PICOJAVA, 0xfe2c), ++ NCSTORE_BYTE(PICOJAVA, 0xfe30), ++ NCSTORE_SHORT(PICOJAVA, 0xfe32), ++ NCSTORE_WORD(PICOJAVA, 0xfe34), ++ NCSTORE_SHORT_OE(PICOJAVA, 0xfe3a), ++ NCSTORE_WORD_OE(PICOJAVA, 0xfe3c), ++ ZERO_LINE(PICOJAVA, 0xfe3e), ++ ENTER_SYNC_METHOD(PICOJAVA, 0xfe3f), ++ ++ // PicoJava priv instructions ++ PRIV_LOAD_UBYTE(PICOJAVA, 0xff00), ++ PRIV_LOAD_BYTE(PICOJAVA, 0xff01), ++ PRIV_LOAD_CHAR(PICOJAVA, 0xff02), ++ PRIV_LOAD_SHORT(PICOJAVA, 0xff03), ++ PRIV_LOAD_WORD(PICOJAVA, 0xff04), ++ PRIV_RET_FROM_TRAP(PICOJAVA, 0xff05), ++ PRIV_READ_DCACHE_TAG(PICOJAVA, 0xff06), ++ PRIV_READ_DCACHE_DATA(PICOJAVA, 0xff07), ++ PRIV_LOAD_CHAR_OE(PICOJAVA, 0xff0a), ++ PRIV_LOAD_SHORT_OE(PICOJAVA, 0xff0b), ++ PRIV_LOAD_WORD_OE(PICOJAVA, 0xff0c), ++ PRIV_READ_ICACHE_TAG(PICOJAVA, 0xff0e), ++ PRIV_READ_ICACHE_DATA(PICOJAVA, 0xff0f), ++ PRIV_NCLOAD_UBYTE(PICOJAVA, 0xff10), ++ PRIV_NCLOAD_BYTE(PICOJAVA, 0xff11), ++ PRIV_NCLOAD_CHAR(PICOJAVA, 0xff12), ++ PRIV_NCLOAD_SHORT(PICOJAVA, 0xff13), ++ PRIV_NCLOAD_WORD(PICOJAVA, 0xff14), ++ PRIV_POWERDOWN(PICOJAVA, 0xff16), ++ PRIV_READ_SCACHE_DATA(PICOJAVA, 0xff17), ++ PRIV_NCLOAD_CHAR_OE(PICOJAVA, 0xff1a), ++ PRIV_NCLOAD_SHORT_OE(PICOJAVA, 0xff1b), ++ PRIV_NCLOAD_WORD_OE(PICOJAVA, 0xff1c), ++ PRIV_CACHE_FLUSH(PICOJAVA, 0xff1e), ++ PRIV_CACHE_INDEX_FLUSH(PICOJAVA, 0xff1f), ++ PRIV_STORE_BYTE(PICOJAVA, 0xff20), ++ PRIV_STORE_SHORT(PICOJAVA, 0xff22), ++ PRIV_STORE_WORD(PICOJAVA, 0xff24), ++ PRIV_WRITE_DCACHE_TAG(PICOJAVA, 0xff26), ++ PRIV_WRITE_DCACHE_DATA(PICOJAVA, 0xff27), ++ PRIV_STORE_SHORT_OE(PICOJAVA, 0xff2a), ++ PRIV_STORE_WORD_OE(PICOJAVA, 0xff2c), ++ PRIV_WRITE_ICACHE_TAG(PICOJAVA, 0xff2e), ++ PRIV_WRITE_ICACHE_DATA(PICOJAVA, 0xff2f), ++ PRIV_NCSTORE_BYTE(PICOJAVA, 0xff30), ++ PRIV_NCSTORE_SHORT(PICOJAVA, 0xff32), ++ PRIV_NCSTORE_WORD(PICOJAVA, 0xff34), ++ PRIV_RESET(PICOJAVA, 0xff36), ++ PRIV_WRITE_SCACHE_DATA(PICOJAVA, 0xff37), ++ PRIV_NCSTORE_SHORT_OE(PICOJAVA, 0xff3a), ++ PRIV_NCSTORE_WORD_OE(PICOJAVA, 0xff3c), ++ PRIV_ZERO_LINE(PICOJAVA, 0xff3e), ++ PRIV_READ_REG_0(PICOJAVA, 0xff40), ++ PRIV_READ_REG_1(PICOJAVA, 0xff41), ++ PRIV_READ_REG_2(PICOJAVA, 0xff42), ++ PRIV_READ_REG_3(PICOJAVA, 0xff43), ++ PRIV_READ_REG_4(PICOJAVA, 0xff44), ++ PRIV_READ_REG_5(PICOJAVA, 0xff45), ++ PRIV_READ_REG_6(PICOJAVA, 0xff46), ++ PRIV_READ_REG_7(PICOJAVA, 0xff47), ++ PRIV_READ_REG_8(PICOJAVA, 0xff48), ++ PRIV_READ_REG_9(PICOJAVA, 0xff49), ++ PRIV_READ_REG_10(PICOJAVA, 0xff4a), ++ PRIV_READ_REG_11(PICOJAVA, 0xff4b), ++ PRIV_READ_REG_12(PICOJAVA, 0xff4c), ++ PRIV_READ_REG_13(PICOJAVA, 0xff4d), ++ PRIV_READ_REG_14(PICOJAVA, 0xff4e), ++ PRIV_READ_REG_15(PICOJAVA, 0xff4f), ++ PRIV_READ_REG_16(PICOJAVA, 0xff50), ++ PRIV_READ_REG_17(PICOJAVA, 0xff51), ++ PRIV_READ_REG_18(PICOJAVA, 0xff52), ++ PRIV_READ_REG_19(PICOJAVA, 0xff53), ++ PRIV_READ_REG_20(PICOJAVA, 0xff54), ++ PRIV_READ_REG_21(PICOJAVA, 0xff55), ++ PRIV_READ_REG_22(PICOJAVA, 0xff56), ++ PRIV_READ_REG_23(PICOJAVA, 0xff57), ++ PRIV_READ_REG_24(PICOJAVA, 0xff58), ++ PRIV_READ_REG_25(PICOJAVA, 0xff59), ++ PRIV_READ_REG_26(PICOJAVA, 0xff5a), ++ PRIV_READ_REG_27(PICOJAVA, 0xff5b), ++ PRIV_READ_REG_28(PICOJAVA, 0xff5c), ++ PRIV_READ_REG_29(PICOJAVA, 0xff5d), ++ PRIV_READ_REG_30(PICOJAVA, 0xff5e), ++ PRIV_READ_REG_31(PICOJAVA, 0xff5f), ++ PRIV_WRITE_REG_0(PICOJAVA, 0xff60), ++ PRIV_WRITE_REG_1(PICOJAVA, 0xff61), ++ PRIV_WRITE_REG_2(PICOJAVA, 0xff62), ++ PRIV_WRITE_REG_3(PICOJAVA, 0xff63), ++ PRIV_WRITE_REG_4(PICOJAVA, 0xff64), ++ PRIV_WRITE_REG_5(PICOJAVA, 0xff65), ++ PRIV_WRITE_REG_6(PICOJAVA, 0xff66), ++ PRIV_WRITE_REG_7(PICOJAVA, 0xff67), ++ PRIV_WRITE_REG_8(PICOJAVA, 0xff68), ++ PRIV_WRITE_REG_9(PICOJAVA, 0xff69), ++ PRIV_WRITE_REG_10(PICOJAVA, 0xff6a), ++ PRIV_WRITE_REG_11(PICOJAVA, 0xff6b), ++ PRIV_WRITE_REG_12(PICOJAVA, 0xff6c), ++ PRIV_WRITE_REG_13(PICOJAVA, 0xff6d), ++ PRIV_WRITE_REG_14(PICOJAVA, 0xff6e), ++ PRIV_WRITE_REG_15(PICOJAVA, 0xff6f), ++ PRIV_WRITE_REG_16(PICOJAVA, 0xff70), ++ PRIV_WRITE_REG_17(PICOJAVA, 0xff71), ++ PRIV_WRITE_REG_18(PICOJAVA, 0xff72), ++ PRIV_WRITE_REG_19(PICOJAVA, 0xff73), ++ PRIV_WRITE_REG_20(PICOJAVA, 0xff74), ++ PRIV_WRITE_REG_21(PICOJAVA, 0xff75), ++ PRIV_WRITE_REG_22(PICOJAVA, 0xff76), ++ PRIV_WRITE_REG_23(PICOJAVA, 0xff77), ++ PRIV_WRITE_REG_24(PICOJAVA, 0xff78), ++ PRIV_WRITE_REG_25(PICOJAVA, 0xff79), ++ PRIV_WRITE_REG_26(PICOJAVA, 0xff7a), ++ PRIV_WRITE_REG_27(PICOJAVA, 0xff7b), ++ PRIV_WRITE_REG_28(PICOJAVA, 0xff7c), ++ PRIV_WRITE_REG_29(PICOJAVA, 0xff7d), ++ PRIV_WRITE_REG_30(PICOJAVA, 0xff7e), ++ PRIV_WRITE_REG_31(PICOJAVA, 0xff7f); ++ ++ Opcode(int opcode) { ++ this(STANDARD, opcode, NO_OPERANDS); ++ } ++ ++ Opcode(int opcode, Instruction.Kind kind) { ++ this(STANDARD, opcode, kind); ++ } ++ ++ Opcode(Set set, int opcode) { ++ this(set, opcode, (set == STANDARD ? NO_OPERANDS : WIDE_NO_OPERANDS)); ++ } ++ ++ Opcode(Set set, int opcode, Instruction.Kind kind) { ++ this.set = set; ++ this.opcode = opcode; ++ this.kind = kind; ++ } ++ ++ public final Set set; ++ public final int opcode; ++ public final Instruction.Kind kind; ++ ++ /** Get the Opcode for a simple standard 1-byte opcode. */ ++ public static Opcode get(int opcode) { ++ return stdOpcodes[opcode]; ++ } ++ ++ /** Get the Opcode for 1- or 2-byte opcode. */ ++ public static Opcode get(int opcodePrefix, int opcode) { ++ Opcode[] block = getOpcodeBlock(opcodePrefix); ++ return (block == null ? null : block[opcode]); ++ } ++ ++ private static Opcode[] getOpcodeBlock(int opcodePrefix) { ++ switch (opcodePrefix) { ++ case 0: ++ return stdOpcodes; ++ case WIDE: ++ return wideOpcodes; ++ case NONPRIV: ++ return nonPrivOpcodes; ++ case PRIV: ++ return privOpcodes; ++ default: ++ return null; ++ } ++ ++ } ++ ++ private static Opcode[] stdOpcodes = new Opcode[256]; ++ private static Opcode[] wideOpcodes = new Opcode[256]; ++ private static Opcode[] nonPrivOpcodes = new Opcode[256]; ++ private static Opcode[] privOpcodes = new Opcode[256]; ++ static { ++ for (Opcode o: values()) ++ getOpcodeBlock(o.opcode >> 8)[o.opcode & 0xff] = o; ++ } ++ ++ /** The byte prefix for the wide instructions. */ ++ public static final int WIDE = 0xc4; ++ /** The byte prefix for the PicoJava nonpriv instructions. */ ++ public static final int NONPRIV = 0xfe; ++ /** The byte prefix for the PicoJava priv instructions. */ ++ public static final int PRIV = 0xff; ++ ++ public enum Set { ++ /** Standard opcodes. */ ++ STANDARD, ++ /** Legacy support for PicoJava opcodes. */ ++ PICOJAVA }; ++} +diff -r bfd7bb421825 -r 3cbaa3d49584 src/share/classes/com/sun/tools/javap/CodeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Tue Oct 22 01:03:49 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Thu Oct 24 02:40:06 2013 +0100 +@@ -30,9 +30,12 @@ + import com.sun.tools.classfile.ConstantPool; + import com.sun.tools.classfile.ConstantPoolException; + import com.sun.tools.classfile.DescriptorException; ++import com.sun.tools.classfile.Instruction; ++import com.sun.tools.classfile.Instruction.TypeKind; + import com.sun.tools.classfile.Method; ++import com.sun.tools.classfile.Opcode; + +-import static com.sun.tools.classfile.OpCodes.*; ++//import static com.sun.tools.classfile.OpCodes.*; + + /* + * Write the contents of a Code attribute. +@@ -87,218 +90,92 @@ + } + + public void writeInstrs(Code_attribute attr) { +- try { +- for (int pc = 0; pc < attr.code_length;) { +- print(" " + pc + ":\t"); +- pc += writeInstr(attr, pc); +- println(); ++ for (Instruction instr: attr.getInstructions()) { ++ try { ++ writeInstr(instr); ++ } catch (ArrayIndexOutOfBoundsException e) { ++ println(report("error at or after byte " + instr.getPC())); ++ break; + } +- } catch (Code_attribute.InvalidIndex e) { +- println(report(e)); + } + } + +- public int writeInstr(Code_attribute attr, int pc) +- throws Code_attribute.InvalidIndex { +- String lP = ""; +- int opcode = attr.getUnsignedByte(pc); +- int opcode2; +- String mnem; +- switch (opcode) { +- case opc_nonpriv: +- case opc_priv: { +- opcode2 = attr.getUnsignedByte(pc + 1); +- mnem = opcName((opcode << 8) + opcode2); +- if (mnem == null) { +- mnem = opcName(opcode) + " " + opcode2; +- } +- print(mnem); +- return 2; ++ public void writeInstr(Instruction instr) { ++ print(" " + instr.getPC() + ":\t"); ++ print(instr.getMnemonic()); ++ instr.accept(instructionPrinter, null); ++ println(); ++ } ++ // where ++ Instruction.KindVisitor<Void,Void> instructionPrinter = ++ new Instruction.KindVisitor<Void,Void>() { ++ ++ public Void visitNoOperands(Instruction instr, Void p) { ++ return null; ++ } ++ ++ public Void visitArrayType(Instruction instr, TypeKind kind, Void p) { ++ print(" " + kind.name); ++ return null; ++ } ++ ++ public Void visitBranch(Instruction instr, int offset, Void p) { ++ print("\t" + (instr.getPC() + offset)); ++ return null; ++ } ++ ++ public Void visitConstantPoolRef(Instruction instr, int index, Void p) { ++ print("\t#" + index + "; //"); ++ printConstant(index); ++ return null; ++ } ++ ++ public Void visitConstantPoolRefAndValue(Instruction instr, int index, int value, Void p) { ++ print("\t#" + index + ", " + value + "; //"); ++ printConstant(index); ++ return null; ++ } ++ ++ public Void visitLocal(Instruction instr, int index, Void p) { ++ print("\t" + index); ++ return null; ++ } ++ ++ public Void visitLocalAndValue(Instruction instr, int index, int value, Void p) { ++ print("\t" + index + ", " + value); ++ return null; ++ } ++ ++ public Void visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets) { ++ int pc = instr.getPC(); ++ print("{ //" + npairs); ++ for (int i = 0; i < npairs; i++) { ++ print("\n\t\t" + matches[i] + ": " + (pc + offsets[i]) + ";"); + } +- case opc_wide: { +- opcode2 = attr.getUnsignedByte(pc + 1); +- mnem = opcName((opcode << 8) + opcode2); +- if (mnem == null) { +- print("bytecode " + opcode); +- return 1; +- } +- print(mnem + " " + attr.getUnsignedShort(pc + 2)); +- if (opcode2 == opc_iinc) { +- print(", " + attr.getShort(pc + 4)); +- return 6; +- } +- return 4; ++ print("\n\t\tdefault: " + (pc + default_) + " }"); ++ return null; ++ } ++ ++ public Void visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets) { ++ int pc = instr.getPC(); ++ print("{ //" + low + " to " + high); ++ for (int i = 0; i < offsets.length; i++) { ++ print("\n\t\t" + (low + i) + ": " + (pc + offsets[i]) + ";"); + } ++ print("\n\t\tdefault: " + (pc + default_) + " }"); ++ return null; + } +- mnem = opcName(opcode); +- if (mnem == null) { +- print("bytecode " + opcode); +- return 1; ++ ++ public Void visitValue(Instruction instr, int value, Void p) { ++ print("\t" + value); ++ return null; + } +- if (opcode > opc_jsr_w) { +- print("bytecode " + opcode); +- return 1; ++ ++ public Void visitUnknown(Instruction instr, Void p) { ++ return null; + } +- print(opcName(opcode)); +- switch (opcode) { +- case opc_aload: +- case opc_astore: +- case opc_fload: +- case opc_fstore: +- case opc_iload: +- case opc_istore: +- case opc_lload: +- case opc_lstore: +- case opc_dload: +- case opc_dstore: +- case opc_ret: +- print("\t" + attr.getUnsignedByte(pc + 1)); +- return 2; +- case opc_iinc: +- print("\t" + attr.getUnsignedByte(pc + 1) + ", " + attr.getByte(pc + 2)); +- return 3; +- case opc_tableswitch: +- { +- int tb = align(pc + 1); +- int default_skip = attr.getInt(tb); +- int low = attr.getInt(tb + 4); +- int high = attr.getInt(tb + 8); +- int count = high - low; +- print("{ //" + low + " to " + high); +- for (int i = 0; i <= count; i++) { +- print("\n\t\t" + (i + low) + ": " + lP + (pc + attr.getInt(tb + 12 + 4 * i)) + ";"); +- } +- print("\n\t\tdefault: " + lP + (default_skip + pc) + " }"); +- return tb - pc + 16 + count * 4; +- } +- case opc_lookupswitch: +- { +- int tb = align(pc + 1); +- int default_skip = attr.getInt(tb); +- int npairs = attr.getInt(tb + 4); +- print("{ //" + npairs); +- for (int i = 1; i <= npairs; i++) { +- print("\n\t\t" + attr.getInt(tb + i * 8) + ": " + lP + (pc + attr.getInt(tb + 4 + i * 8)) + ";"); +- } +- print("\n\t\tdefault: " + lP + (default_skip + pc) + " }"); +- return tb - pc + (npairs + 1) * 8; +- } +- case opc_newarray: +- int type = attr.getUnsignedByte(pc + 1); +- switch (type) { +- case T_BOOLEAN: +- print(" boolean"); +- break; +- case T_BYTE: +- print(" byte"); +- break; +- case T_CHAR: +- print(" char"); +- break; +- case T_SHORT: +- print(" short"); +- break; +- case T_INT: +- print(" int"); +- break; +- case T_LONG: +- print(" long"); +- break; +- case T_FLOAT: +- print(" float"); +- break; +- case T_DOUBLE: +- print(" double"); +- break; +- case T_CLASS: +- print(" class"); +- break; +- default: +- print(" BOGUS TYPE:" + type); +- } +- return 2; +- case opc_anewarray: +- { +- int index = attr.getUnsignedShort(pc + 1); +- print("\t#" + index + "; //"); +- printConstant(index); +- return 3; +- } +- case opc_sipush: +- print("\t" + attr.getShort(pc + 1)); +- return 3; +- case opc_bipush: +- print("\t" + attr.getByte(pc + 1)); +- return 2; +- case opc_ldc: +- { +- int index = attr.getUnsignedByte(pc + 1); +- print("\t#" + index + "; //"); +- printConstant(index); +- return 2; +- } +- case opc_ldc_w: +- case opc_ldc2_w: +- case opc_instanceof: +- case opc_checkcast: +- case opc_new: +- case opc_putstatic: +- case opc_getstatic: +- case opc_putfield: +- case opc_getfield: +- case opc_invokevirtual: +- case opc_invokespecial: +- case opc_invokestatic: +- { +- int index = attr.getUnsignedShort(pc + 1); +- print("\t#" + index + "; //"); +- printConstant(index); +- return 3; +- } +- case opc_invokeinterface: +- { +- int index = attr.getUnsignedShort(pc + 1); +- int nargs = attr.getUnsignedByte(pc + 3); +- print("\t#" + index + ", " + nargs + "; //"); +- printConstant(index); +- return 5; +- } +- case opc_multianewarray: +- { +- int index = attr.getUnsignedShort(pc + 1); +- int dimensions = attr.getUnsignedByte(pc + 3); +- print("\t#" + index + ", " + dimensions + "; //"); +- printConstant(index); +- return 4; +- } +- case opc_jsr: +- case opc_goto: +- case opc_ifeq: +- case opc_ifge: +- case opc_ifgt: +- case opc_ifle: +- case opc_iflt: +- case opc_ifne: +- case opc_if_icmpeq: +- case opc_if_icmpne: +- case opc_if_icmpge: +- case opc_if_icmpgt: +- case opc_if_icmple: +- case opc_if_icmplt: +- case opc_if_acmpeq: +- case opc_if_acmpne: +- case opc_ifnull: +- case opc_ifnonnull: +- print("\t" + lP + (pc + attr.getShort(pc + 1))); +- return 3; +- case opc_jsr_w: +- case opc_goto_w: +- print("\t" + lP + (pc + attr.getInt(pc + 1))); +- return 5; +- default: +- return 1; +- } +- } ++ }; ++ + + public void writeExceptionTable(Code_attribute attr) { + if (attr.exception_table_langth > 0) { diff --git a/java/openjdk6/files/icedtea/openjdk/6824493-experimental.patch b/java/openjdk6/files/icedtea/openjdk/6824493-experimental.patch new file mode 100644 index 000000000000..2e415affb7e1 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6824493-experimental.patch @@ -0,0 +1,1304 @@ +# HG changeset patch +# User jjg +# Date 1242759054 25200 +# Tue May 19 11:50:54 2009 -0700 +# Node ID 4b55db11179d066331b829ca5c4722c33287deea +# Parent 8f5d8429b3f18ee4c9820ac1fb597f63c55911f3 +6824493: experimental support for additional info for instructions +Reviewed-by: mcimadamore + +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/classfile/StackMapTable_attribute.java +--- langtools/src/share/classes/com/sun/tools/classfile/StackMapTable_attribute.java Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/StackMapTable_attribute.java Tue May 19 11:50:54 2009 -0700 +@@ -106,6 +106,8 @@ + return 1; + } + ++ public abstract int getOffsetDelta(); ++ + public abstract <R,D> R accept(Visitor<R,D> visitor, D data); + + public final int frame_type; +@@ -129,6 +131,10 @@ + public <R, D> R accept(Visitor<R, D> visitor, D data) { + return visitor.visit_same_frame(this, data); + } ++ ++ public int getOffsetDelta() { ++ return frame_type; ++ } + } + + public static class same_locals_1_stack_item_frame extends stack_map_frame { +@@ -148,6 +154,10 @@ + return visitor.visit_same_locals_1_stack_item_frame(this, data); + } + ++ public int getOffsetDelta() { ++ return frame_type - 64; ++ } ++ + public final verification_type_info[] stack; + } + +@@ -169,6 +179,10 @@ + return visitor.visit_same_locals_1_stack_item_frame_extended(this, data); + } + ++ public int getOffsetDelta() { ++ return offset_delta; ++ } ++ + public final int offset_delta; + public final verification_type_info[] stack; + } +@@ -188,6 +202,10 @@ + return visitor.visit_chop_frame(this, data); + } + ++ public int getOffsetDelta() { ++ return offset_delta; ++ } ++ + public final int offset_delta; + } + +@@ -206,6 +224,10 @@ + return visitor.visit_same_frame_extended(this, data); + } + ++ public int getOffsetDelta() { ++ return offset_delta; ++ } ++ + public final int offset_delta; + } + +@@ -231,6 +253,10 @@ + return visitor.visit_append_frame(this, data); + } + ++ public int getOffsetDelta() { ++ return offset_delta; ++ } ++ + public final int offset_delta; + public final verification_type_info[] locals; + } +@@ -265,6 +291,10 @@ + return visitor.visit_full_frame(this, data); + } + ++ public int getOffsetDelta() { ++ return offset_delta; ++ } ++ + public final int offset_delta; + public final int number_of_locals; + public final verification_type_info[] locals; +@@ -307,7 +337,7 @@ + } + } + +- verification_type_info(int tag) { ++ protected verification_type_info(int tag) { + this.tag = tag; + } + +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/BasicWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/BasicWriter.java Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/BasicWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -44,6 +44,9 @@ + protected BasicWriter(Context context) { + lineWriter = LineWriter.instance(context); + out = context.get(PrintWriter.class); ++ messages = context.get(Messages.class); ++ if (messages == null) ++ throw new AssertionError(); + } + + protected void print(String s) { +@@ -100,8 +103,26 @@ + return "???"; + } + ++ protected String space(int w) { ++ if (w < spaces.length && spaces[w] != null) ++ return spaces[w]; ++ ++ StringBuilder sb = new StringBuilder(); ++ for (int i = 0; i < w; i++) ++ sb.append(" "); ++ ++ String s = sb.toString(); ++ if (w < spaces.length) ++ spaces[w] = s; ++ ++ return s; ++ } ++ ++ private String[] spaces = new String[80]; ++ + private LineWriter lineWriter; + private PrintWriter out; ++ protected Messages messages; + + private static class LineWriter { + static LineWriter instance(Context context) { +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -26,7 +26,9 @@ + package com.sun.tools.javap; + + import java.net.URI; ++import java.text.DateFormat; + import java.util.Collection; ++import java.util.Date; + import java.util.List; + + import com.sun.tools.classfile.AccessFlags; +@@ -47,8 +49,6 @@ + import com.sun.tools.classfile.SourceFile_attribute; + import com.sun.tools.classfile.Type; + +-import java.text.DateFormat; +-import java.util.Date; + import static com.sun.tools.classfile.AccessFlags.*; + + /* +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/CodeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -25,6 +25,9 @@ + + package com.sun.tools.javap; + ++import java.util.ArrayList; ++import java.util.List; ++ + import com.sun.tools.classfile.AccessFlags; + import com.sun.tools.classfile.Code_attribute; + import com.sun.tools.classfile.ConstantPool; +@@ -33,9 +36,6 @@ + import com.sun.tools.classfile.Instruction; + import com.sun.tools.classfile.Instruction.TypeKind; + import com.sun.tools.classfile.Method; +-import com.sun.tools.classfile.Opcode; +- +-//import static com.sun.tools.classfile.OpCodes.*; + + /* + * Write the contents of a Code attribute. +@@ -59,6 +59,12 @@ + attrWriter = AttributeWriter.instance(context); + classWriter = ClassWriter.instance(context); + constantWriter = ConstantWriter.instance(context); ++ sourceWriter = SourceWriter.instance(context); ++ tryBlockWriter = TryBlockWriter.instance(context); ++ stackMapWriter = StackMapWriter.instance(context); ++ localVariableTableWriter = LocalVariableTableWriter.instance(context); ++ localVariableTypeTableWriter = LocalVariableTypeTableWriter.instance(context); ++ options = Options.instance(context); + } + + void write(Code_attribute attr, ConstantPool constant_pool) { +@@ -92,14 +98,21 @@ + } + + public void writeInstrs(Code_attribute attr) { ++ List<InstructionDetailWriter> detailWriters = getDetailWriters(attr); ++ + for (Instruction instr: attr.getInstructions()) { + try { ++ for (InstructionDetailWriter w: detailWriters) ++ w.writeDetails(instr); + writeInstr(instr); + } catch (ArrayIndexOutOfBoundsException e) { + println(report("error at or after byte " + instr.getPC())); + break; + } + } ++ ++ for (InstructionDetailWriter w: detailWriters) ++ w.flush(); + } + + public void writeInstr(Instruction instr) { +@@ -213,11 +226,45 @@ + constantWriter.write(index); + } + +- private static int align(int n) { +- return (n + 3) & ~3; ++ private List<InstructionDetailWriter> getDetailWriters(Code_attribute attr) { ++ List<InstructionDetailWriter> detailWriters = ++ new ArrayList<InstructionDetailWriter>(); ++ if (options.details.contains(InstructionDetailWriter.Kind.SOURCE)) { ++ sourceWriter.reset(classWriter.getClassFile(), attr); ++ detailWriters.add(sourceWriter); ++ } ++ ++ if (options.details.contains(InstructionDetailWriter.Kind.LOCAL_VARS)) { ++ localVariableTableWriter.reset(attr); ++ detailWriters.add(localVariableTableWriter); ++ } ++ ++ if (options.details.contains(InstructionDetailWriter.Kind.LOCAL_VAR_TYPES)) { ++ localVariableTypeTableWriter.reset(attr); ++ detailWriters.add(localVariableTypeTableWriter); ++ } ++ ++ if (options.details.contains(InstructionDetailWriter.Kind.STACKMAPS)) { ++ stackMapWriter.reset(attr); ++ stackMapWriter.writeInitialDetails(); ++ detailWriters.add(stackMapWriter); ++ } ++ ++ if (options.details.contains(InstructionDetailWriter.Kind.TRY_BLOCKS)) { ++ tryBlockWriter.reset(attr); ++ detailWriters.add(tryBlockWriter); ++ } ++ ++ return detailWriters; + } + + private AttributeWriter attrWriter; + private ClassWriter classWriter; + private ConstantWriter constantWriter; ++ private LocalVariableTableWriter localVariableTableWriter; ++ private LocalVariableTypeTableWriter localVariableTypeTableWriter; ++ private SourceWriter sourceWriter; ++ private StackMapWriter stackMapWriter; ++ private TryBlockWriter tryBlockWriter; ++ private Options options; + } +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/InstructionDetailWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/InstructionDetailWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -0,0 +1,57 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.Instruction; ++ ++ ++/* ++ * Write additional details for an instruction. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public abstract class InstructionDetailWriter extends BasicWriter { ++ public enum Kind { ++ LOCAL_VARS("localVariables"), ++ LOCAL_VAR_TYPES("localVariableTypes"), ++ SOURCE("source"), ++ STACKMAPS("stackMaps"), ++ TRY_BLOCKS("tryBlocks"); ++ Kind(String option) { ++ this.option = option; ++ } ++ final String option; ++ } ++ InstructionDetailWriter(Context context) { ++ super(context); ++ } ++ ++ abstract void writeDetails(Instruction instr); ++ void flush() { } ++} +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Tue May 19 11:50:54 2009 -0700 +@@ -40,6 +40,7 @@ + import java.text.MessageFormat; + import java.util.ArrayList; + import java.util.Arrays; ++import java.util.EnumSet; + import java.util.HashMap; + import java.util.Iterator; + import java.util.List; +@@ -66,7 +67,7 @@ + * This code and its internal interfaces are subject to change or + * deletion without notice.</b> + */ +-public class JavapTask implements DisassemblerTool.DisassemblerTask { ++public class JavapTask implements DisassemblerTool.DisassemblerTask, Messages { + public class BadArgs extends Exception { + static final long serialVersionUID = 8765093759964640721L; + BadArgs(String key, Object... args) { +@@ -242,6 +243,56 @@ + } + }, + ++ new Option(false, "-XDdetails") { ++ void process(JavapTask task, String opt, String arg) { ++ task.options.details = EnumSet.allOf(InstructionDetailWriter.Kind.class); ++ } ++ ++ }, ++ ++ new Option(false, "-XDdetails:") { ++ @Override ++ boolean matches(String opt) { ++ int sep = opt.indexOf(":"); ++ return sep != -1 && super.matches(opt.substring(0, sep + 1)); ++ } ++ ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ int sep = opt.indexOf(":"); ++ for (String v: opt.substring(sep + 1).split("[,: ]+")) { ++ if (!handleArg(task, v)) ++ throw task.new BadArgs("err.invalid.arg.for.option", v); ++ } ++ } ++ ++ boolean handleArg(JavapTask task, String arg) { ++ if (arg.length() == 0) ++ return true; ++ ++ if (arg.equals("all")) { ++ task.options.details = EnumSet.allOf(InstructionDetailWriter.Kind.class); ++ return true; ++ } ++ ++ boolean on = true; ++ if (arg.startsWith("-")) { ++ on = false; ++ arg = arg.substring(1); ++ } ++ ++ for (InstructionDetailWriter.Kind k: InstructionDetailWriter.Kind.values()) { ++ if (arg.equalsIgnoreCase(k.option)) { ++ if (on) ++ task.options.details.add(k); ++ else ++ task.options.details.remove(k); ++ return true; ++ } ++ } ++ return false; ++ } ++ }, ++ + new Option(false, "-constants") { + void process(JavapTask task, String opt, String arg) { + task.options.showConstants = true; +@@ -284,6 +335,7 @@ + + public JavapTask() { + context = new Context(); ++ context.put(Messages.class, this); + options = Options.instance(context); + attributeFactory = new Attribute.Factory(); + } +@@ -489,6 +541,8 @@ + + context.put(PrintWriter.class, log); + ClassWriter classWriter = ClassWriter.instance(context); ++ SourceWriter sourceWriter = SourceWriter.instance(context); ++ sourceWriter.setFileManager(fileManager); + + boolean ok = true; + +@@ -749,11 +803,11 @@ + + } + +- private String getMessage(String key, Object... args) { ++ public String getMessage(String key, Object... args) { + return getMessage(task_locale, key, args); + } + +- private String getMessage(Locale locale, String key, Object... args) { ++ public String getMessage(Locale locale, String key, Object... args) { + if (bundles == null) { + // could make this a HashMap<Locale,SoftReference<ResourceBundle>> + // and for efficiency, keep a hard reference to the bundle for the task +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/Messages.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/Messages.java Tue May 19 11:50:54 2009 -0700 +@@ -0,0 +1,42 @@ ++/* ++ * Copyright 2007-2009 Sun Microsystems, Inc. All Rights Reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * 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.tools.javap; ++ ++import java.util.Locale; ++ ++/** ++ * Access to javap messages. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public interface Messages { ++ String getMessage(String key, Object... args); ++ ++ String getMessage(Locale locale, String key, Object... args); ++} +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/Options.java +--- langtools/src/share/classes/com/sun/tools/javap/Options.java Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/Options.java Tue May 19 11:50:54 2009 -0700 +@@ -25,8 +25,10 @@ + + package com.sun.tools.javap; + ++import java.util.EnumSet; + import java.util.HashSet; + import java.util.Set; ++ + import com.sun.tools.classfile.AccessFlags; + + /* +@@ -77,6 +79,7 @@ + public boolean showLineAndLocalVariableTables; + public int showAccess; + public Set<String> accessOptions = new HashSet<String>(); ++ public Set<InstructionDetailWriter.Kind> details = EnumSet.noneOf(InstructionDetailWriter.Kind.class); + public boolean showDisassembled; + public boolean showInternalSignatures; + public boolean showAllAttrs; +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/SourceWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/SourceWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -0,0 +1,207 @@ ++/* ++ * 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.tools.javap; ++ ++import java.io.BufferedReader; ++import java.io.IOException; ++import java.io.StringReader; ++import java.util.ArrayList; ++import java.util.List; ++import java.util.Set; ++import java.util.SortedMap; ++import java.util.SortedSet; ++import java.util.TreeMap; ++import java.util.TreeSet; ++import javax.tools.JavaFileManager; ++import javax.tools.JavaFileManager.Location; ++import javax.tools.JavaFileObject; ++import javax.tools.StandardLocation; ++ ++import com.sun.tools.classfile.Attribute; ++import com.sun.tools.classfile.ClassFile; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.Instruction; ++import com.sun.tools.classfile.LineNumberTable_attribute; ++import com.sun.tools.classfile.SourceFile_attribute; ++ ++ ++/** ++ * Annotate instructions with source code. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class SourceWriter extends InstructionDetailWriter { ++ static SourceWriter instance(Context context) { ++ SourceWriter instance = context.get(SourceWriter.class); ++ if (instance == null) ++ instance = new SourceWriter(context); ++ return instance; ++ } ++ ++ protected SourceWriter(Context context) { ++ super(context); ++ context.put(SourceWriter.class, this); ++ } ++ ++ void setFileManager(JavaFileManager fileManager) { ++ this.fileManager = fileManager; ++ } ++ ++ public void reset(ClassFile cf, Code_attribute attr) { ++ setSource(cf); ++ setLineMap(attr); ++ } ++ ++ public void writeDetails(Instruction instr) { ++ String indent = space(40); // could get from Options? ++ Set<Integer> lines = lineMap.get(instr.getPC()); ++ if (lines != null) { ++ for (int line: lines) { ++ print(indent); ++ print(String.format(" %4d ", line)); ++ if (line < sourceLines.length) ++ print(sourceLines[line]); ++ println(); ++ int nextLine = nextLine(line); ++ for (int i = line + 1; i < nextLine; i++) { ++ print(indent); ++ print(String.format("(%4d)", i)); ++ if (i < sourceLines.length) ++ print(sourceLines[i]); ++ println(); ++ } ++ } ++ } ++ ++ } ++ ++ private void setLineMap(Code_attribute attr) { ++ SortedMap<Integer, SortedSet<Integer>> map = ++ new TreeMap<Integer, SortedSet<Integer>>(); ++ SortedSet<Integer> allLines = new TreeSet<Integer>(); ++ for (Attribute a: attr.attributes) { ++ if (a instanceof LineNumberTable_attribute) { ++ LineNumberTable_attribute t = (LineNumberTable_attribute) a; ++ for (LineNumberTable_attribute.Entry e: t.line_number_table) { ++ int start_pc = e.start_pc; ++ int line = e.line_number; ++ SortedSet<Integer> pcLines = map.get(start_pc); ++ if (pcLines == null) { ++ pcLines = new TreeSet<Integer>(); ++ map.put(start_pc, pcLines); ++ } ++ pcLines.add(line); ++ allLines.add(line); ++ } ++ } ++ } ++ lineMap = map; ++ lineList = new ArrayList<Integer>(allLines); ++ } ++ ++ private void setSource(ClassFile cf) { ++ if (cf != classFile) { ++ classFile = cf; ++ sourceLines = splitLines(readSource(cf)); ++ } ++ } ++ ++ private String readSource(ClassFile cf) { ++ Location location; ++ if (fileManager.hasLocation((StandardLocation.SOURCE_PATH))) ++ location = StandardLocation.SOURCE_PATH; ++ else ++ location = StandardLocation.CLASS_PATH; ++ ++ // Guess the source file for a class from the package name for this ++ // class and the base of the source file. This avoids having to read ++ // additional classes to determine the outmost class from any ++ // InnerClasses and EnclosingMethod attributes. ++ try { ++ String className = cf.getName(); ++ SourceFile_attribute sf = ++ (SourceFile_attribute) cf.attributes.get(Attribute.SourceFile); ++ if (sf == null) { ++ report(messages.getMessage("err.no.SourceFile.attribute")); ++ return null; ++ } ++ String sourceFile = sf.getSourceFile(cf.constant_pool); ++ String fileBase = sourceFile.endsWith(".java") ++ ? sourceFile.substring(0, sourceFile.length() - 5) : sourceFile; ++ int sep = className.lastIndexOf("/"); ++ String pkgName = (sep == -1 ? "" : className.substring(0, sep+1)); ++ String topClassName = (pkgName + fileBase).replace('/', '.'); ++ JavaFileObject fo = ++ fileManager.getJavaFileForInput(location, ++ topClassName, ++ JavaFileObject.Kind.SOURCE); ++ if (fo == null) { ++ report(messages.getMessage("err.source.file.not.found")); ++ return null; ++ } ++ return fo.getCharContent(true).toString(); ++ } catch (ConstantPoolException e) { ++ report(e); ++ return null; ++ } catch (IOException e) { ++ report(e.getLocalizedMessage()); ++ return null; ++ } ++ } ++ ++ private static String[] splitLines(String text) { ++ if (text == null) ++ return new String[0]; ++ ++ List<String> lines = new ArrayList<String>(); ++ lines.add(""); // dummy line 0 ++ try { ++ BufferedReader r = new BufferedReader(new StringReader(text)); ++ String line; ++ while ((line = r.readLine()) != null) ++ lines.add(line); ++ } catch (IOException ignore) { ++ } ++ return lines.toArray(new String[lines.size()]); ++ } ++ ++ private int nextLine(int line) { ++ int i = lineList.indexOf(line); ++ if (i == -1 || i == lineList.size() - 1) ++ return - 1; ++ return lineList.get(i + 1); ++ } ++ ++ private JavaFileManager fileManager; ++ private ClassFile classFile; ++ private SortedMap<Integer, SortedSet<Integer>> lineMap; ++ private List<Integer> lineList; ++ private String[] sourceLines; ++} +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/StackMapWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/StackMapWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -0,0 +1,291 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.AccessFlags; ++import java.util.HashMap; ++import java.util.Map; ++ ++import com.sun.tools.classfile.Attribute; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.Descriptor; ++import com.sun.tools.classfile.Descriptor.InvalidDescriptor; ++import com.sun.tools.classfile.Instruction; ++import com.sun.tools.classfile.Method; ++import com.sun.tools.classfile.StackMapTable_attribute; ++import com.sun.tools.classfile.StackMapTable_attribute.*; ++ ++import static com.sun.tools.classfile.StackMapTable_attribute.verification_type_info.*; ++ ++/** ++ * Annotate instructions with stack map. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class StackMapWriter extends InstructionDetailWriter { ++ static StackMapWriter instance(Context context) { ++ StackMapWriter instance = context.get(StackMapWriter.class); ++ if (instance == null) ++ instance = new StackMapWriter(context); ++ return instance; ++ } ++ ++ protected StackMapWriter(Context context) { ++ super(context); ++ context.put(StackMapWriter.class, this); ++ classWriter = ClassWriter.instance(context); ++ } ++ ++ public void reset(Code_attribute attr) { ++ setStackMap((StackMapTable_attribute) attr.attributes.get(Attribute.StackMapTable)); ++ } ++ ++ void setStackMap(StackMapTable_attribute attr) { ++ if (attr == null) { ++ map = null; ++ return; ++ } ++ ++ Method m = classWriter.getMethod(); ++ Descriptor d = m.descriptor; ++ String[] args; ++ try { ++ ConstantPool cp = classWriter.getClassFile().constant_pool; ++ String argString = d.getParameterTypes(cp); ++ args = argString.substring(1, argString.length() - 1).split("[, ]+"); ++ } catch (ConstantPoolException e) { ++ return; ++ } catch (InvalidDescriptor e) { ++ return; ++ } ++ boolean isStatic = m.access_flags.is(AccessFlags.ACC_STATIC); ++ ++ verification_type_info[] initialLocals = new verification_type_info[(isStatic ? 0 : 1) + args.length]; ++ if (!isStatic) ++ initialLocals[0] = new CustomVerificationTypeInfo("this"); ++ for (int i = 0; i < args.length; i++) { ++ initialLocals[(isStatic ? 0 : 1) + i] = ++ new CustomVerificationTypeInfo(args[i].replace(".", "/")); ++ } ++ ++ map = new HashMap<Integer, StackMap>(); ++ StackMapBuilder builder = new StackMapBuilder(); ++ ++ // using -1 as the pc for the initial frame effectively compensates for ++ // the difference in behavior for the first stack map frame (where the ++ // pc offset is just offset_delta) compared to subsequent frames (where ++ // the pc offset is always offset_delta+1). ++ int pc = -1; ++ ++ map.put(pc, new StackMap(initialLocals, empty)); ++ ++ for (int i = 0; i < attr.entries.length; i++) ++ pc = attr.entries[i].accept(builder, pc); ++ } ++ ++ public void writeInitialDetails() { ++ writeDetails(-1); ++ } ++ ++ public void writeDetails(Instruction instr) { ++ writeDetails(instr.getPC()); ++ } ++ ++ private void writeDetails(int pc) { ++ if (map == null) ++ return; ++ ++ StackMap m = map.get(pc); ++ if (m != null) { ++ print("StackMap locals: ", m.locals); ++ print("StackMap stack: ", m.stack); ++ } ++ ++ } ++ ++ void print(String label, verification_type_info[] entries) { ++ print(label); ++ for (int i = 0; i < entries.length; i++) { ++ print(" "); ++ print(entries[i]); ++ } ++ println(); ++ } ++ ++ void print(verification_type_info entry) { ++ if (entry == null) { ++ print("ERROR"); ++ return; ++ } ++ ++ switch (entry.tag) { ++ case -1: ++ print(((CustomVerificationTypeInfo) entry).text); ++ break; ++ ++ case ITEM_Top: ++ print("top"); ++ break; ++ ++ case ITEM_Integer: ++ print("int"); ++ break; ++ ++ case ITEM_Float: ++ print("float"); ++ break; ++ ++ case ITEM_Long: ++ print("long"); ++ break; ++ ++ case ITEM_Double: ++ print("double"); ++ break; ++ ++ case ITEM_Null: ++ print("null"); ++ break; ++ ++ case ITEM_UninitializedThis: ++ print("uninit_this"); ++ break; ++ ++ case ITEM_Object: ++ try { ++ ConstantPool cp = classWriter.getClassFile().constant_pool; ++ ConstantPool.CONSTANT_Class_info class_info = cp.getClassInfo(((Object_variable_info) entry).cpool_index); ++ print(cp.getUTF8Value(class_info.name_index)); ++ } catch (ConstantPoolException e) { ++ print("??"); ++ } ++ break; ++ ++ case ITEM_Uninitialized: ++ print(((Uninitialized_variable_info) entry).offset); ++ break; ++ } ++ ++ } ++ ++ private Map<Integer, StackMap> map; ++ private ClassWriter classWriter; ++ ++ class StackMapBuilder ++ implements StackMapTable_attribute.stack_map_frame.Visitor<Integer, Integer> { ++ ++ public Integer visit_same_frame(same_frame frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta() + 1; ++ StackMap m = map.get(pc); ++ assert (m != null); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ public Integer visit_same_locals_1_stack_item_frame(same_locals_1_stack_item_frame frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta() + 1; ++ StackMap prev = map.get(pc); ++ assert (prev != null); ++ StackMap m = new StackMap(prev.locals, frame.stack); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ public Integer visit_same_locals_1_stack_item_frame_extended(same_locals_1_stack_item_frame_extended frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta() + 1; ++ StackMap prev = map.get(pc); ++ assert (prev != null); ++ StackMap m = new StackMap(prev.locals, frame.stack); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ public Integer visit_chop_frame(chop_frame frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta() + 1; ++ StackMap prev = map.get(pc); ++ assert (prev != null); ++ int k = 251 - frame.frame_type; ++ verification_type_info[] new_locals = new verification_type_info[prev.locals.length - k]; ++ System.arraycopy(prev.locals, 0, new_locals, 0, new_locals.length); ++ StackMap m = new StackMap(new_locals, empty); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ public Integer visit_same_frame_extended(same_frame_extended frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta(); ++ StackMap m = map.get(pc); ++ assert (m != null); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ public Integer visit_append_frame(append_frame frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta() + 1; ++ StackMap prev = map.get(pc); ++ assert (prev != null); ++ verification_type_info[] new_locals = new verification_type_info[prev.locals.length + frame.locals.length]; ++ System.arraycopy(prev.locals, 0, new_locals, 0, prev.locals.length); ++ System.arraycopy(frame.locals, 0, new_locals, prev.locals.length, frame.locals.length); ++ StackMap m = new StackMap(new_locals, empty); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ public Integer visit_full_frame(full_frame frame, Integer pc) { ++ int new_pc = pc + frame.getOffsetDelta() + 1; ++ StackMap m = new StackMap(frame.locals, frame.stack); ++ map.put(new_pc, m); ++ return new_pc; ++ } ++ ++ } ++ ++ class StackMap { ++ StackMap(verification_type_info[] locals, verification_type_info[] stack) { ++ this.locals = locals; ++ this.stack = stack; ++ } ++ ++ private final verification_type_info[] locals; ++ private final verification_type_info[] stack; ++ } ++ ++ class CustomVerificationTypeInfo extends verification_type_info { ++ public CustomVerificationTypeInfo(String text) { ++ super(-1); ++ this.text = text; ++ } ++ private String text; ++ } ++ ++ private final verification_type_info[] empty = { }; ++} +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/TryBlockWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/TryBlockWriter.java Tue May 19 11:50:54 2009 -0700 +@@ -0,0 +1,142 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.Code_attribute.Exception_data; ++import com.sun.tools.classfile.Instruction; ++import java.util.ArrayList; ++import java.util.HashMap; ++import java.util.List; ++import java.util.ListIterator; ++import java.util.Map; ++ ++/** ++ * Annotate instructions with details about try blocks. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class TryBlockWriter extends InstructionDetailWriter { ++ public enum NoteKind { ++ START("try") { ++ public boolean match(Exception_data entry, int pc) { ++ return (pc == entry.start_pc); ++ } ++ }, ++ END("end try") { ++ public boolean match(Exception_data entry, int pc) { ++ return (pc == entry.end_pc); ++ } ++ }, ++ HANDLER("catch") { ++ public boolean match(Exception_data entry, int pc) { ++ return (pc == entry.handler_pc); ++ } ++ }; ++ NoteKind(String text) { ++ this.text = text; ++ } ++ public abstract boolean match(Exception_data entry, int pc); ++ public final String text; ++ }; ++ ++ static TryBlockWriter instance(Context context) { ++ TryBlockWriter instance = context.get(TryBlockWriter.class); ++ if (instance == null) ++ instance = new TryBlockWriter(context); ++ return instance; ++ } ++ ++ protected TryBlockWriter(Context context) { ++ super(context); ++ context.put(TryBlockWriter.class, this); ++ constantWriter = ConstantWriter.instance(context); ++ } ++ ++ public void reset(Code_attribute attr) { ++ indexMap = new HashMap<Exception_data, Integer>(); ++ pcMap = new HashMap<Integer, List<Exception_data>>(); ++ for (int i = 0; i < attr.exception_table.length; i++) { ++ Exception_data entry = attr.exception_table[i]; ++ indexMap.put(entry, i); ++ put(entry.start_pc, entry); ++ put(entry.end_pc, entry); ++ put(entry.handler_pc, entry); ++ } ++ } ++ ++ public void writeDetails(Instruction instr) { ++ writeTrys(instr, NoteKind.END); ++ writeTrys(instr, NoteKind.START); ++ writeTrys(instr, NoteKind.HANDLER); ++ } ++ ++ public void writeTrys(Instruction instr, NoteKind kind) { ++ String indent = space(2); // get from Options? ++ int pc = instr.getPC(); ++ List<Exception_data> entries = pcMap.get(pc); ++ if (entries != null) { ++ for (ListIterator<Exception_data> iter = ++ entries.listIterator(kind == NoteKind.END ? entries.size() : 0); ++ kind == NoteKind.END ? iter.hasPrevious() : iter.hasNext() ; ) { ++ Exception_data entry = ++ kind == NoteKind.END ? iter.previous() : iter.next(); ++ if (kind.match(entry, pc)) { ++ print(indent); ++ print(kind.text); ++ print("["); ++ print(indexMap.get(entry)); ++ print("] "); ++ if (entry.catch_type == 0) ++ print("finally"); ++ else { ++ print("#" + entry.catch_type); ++ print(" // "); ++ constantWriter.write(entry.catch_type); ++ } ++ println(); ++ } ++ } ++ } ++ } ++ ++ private void put(int pc, Exception_data entry) { ++ List<Exception_data> list = pcMap.get(pc); ++ if (list == null) { ++ list = new ArrayList<Exception_data>(); ++ pcMap.put(pc, list); ++ } ++ if (!list.contains(entry)) ++ list.add(entry); ++ } ++ ++ private Map<Integer, List<Exception_data>> pcMap; ++ private Map<Exception_data, Integer> indexMap; ++ private ConstantWriter constantWriter; ++} +diff -r 8f5d8429b3f1 -r 4b55db11179d src/share/classes/com/sun/tools/javap/resources/javap.properties +--- langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Tue Jul 08 18:06:19 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/resources/javap.properties Tue May 19 11:50:54 2009 -0700 +@@ -9,6 +9,7 @@ + err.h.not.supported=-h is no longer available - use the 'javah' program + err.incompatible.options=bad combination of options: {0} + err.internal.error=internal error: {0} {1} {2} ++err.invalid.arg.for.option=invalid argument for option: {0} + err.ioerror=IO error reading {0}: {1} + err.missing.arg=no value given for {0} + err.no.classes.specified=no classes specified +@@ -16,6 +17,8 @@ + err.unknown.option=unknown option: {0} + err.verify.not.supported=-verify not supported + err.Xold.not.supported.here=-Xold must be given as the first option ++err.no.SourceFile.attribute=no SourceFile attribute ++err.source.file.not.found=source file not found + + main.usage=\ + Usage: {0} <options> <classes>\n\ +diff -r 8f5d8429b3f1 -r 4b55db11179d test/tools/javap/T6824493.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6824493.java Tue May 19 11:50:54 2009 -0700 +@@ -0,0 +1,116 @@ ++/* ++ * 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. ++ * ++ * 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. ++ */ ++ ++import java.io.*; ++import java.util.*; ++ ++/* ++ * @test ++ * @bug 6824493 ++ * @summary experimental support for additional info for instructions ++ * @compile -g T6824493.java ++ * @run main T6824493 ++ */ ++public class T6824493 { ++ public static void main(String... args) { ++ new T6824493().run(); ++ } ++ ++ void run() { ++ // for each of the options, we run javap and check for some ++ // marker strings in the output that generally indicate the ++ // presence of the expected output, without being as specific ++ // as a full golden file test. ++ test("-XDdetails:source", ++ "for (int i = 0; i < 10; i++) {", ++ "System.out.println(s + i);"); ++ ++ test("-XDdetails:tryBlocks", ++ "try[0]", ++ "end try[0]", ++ "catch[0]"); ++ ++ test("-XDdetails:stackMaps", ++ "StackMap locals: this java/lang/String int", ++ "StackMap stack: java/lang/Throwable"); ++ ++ test("-XDdetails:localVariables", ++ "start local 3 // java.util.List list", ++ "end local 3 // java.util.List list"); ++ ++ test("-XDdetails:localVariableTypes", ++ "start generic local 3 // java.util.List<java.lang.String> list", ++ "end generic local 3 // java.util.List<java.lang.String> list"); ++ ++ if (errors > 0) ++ throw new Error(errors + " errors found"); ++ } ++ ++ void test(String option, String... expect) { ++ String[] args = { ++ "-c", ++ "-classpath", ++ testSrc + File.pathSeparator + testClasses, ++ option, ++ "Test" ++ }; ++ StringWriter sw = new StringWriter(); ++ PrintWriter pw = new PrintWriter(sw); ++ int rc = com.sun.tools.javap.Main.run(args, pw); ++ if (rc != 0) { ++ error("unexpected return code from javap: " + rc); ++ return; ++ } ++ ++ String out = sw.toString(); ++ System.out.println(out); ++ for (String e: expect) { ++ if (!out.contains(e)) ++ error("Not found: " + e); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println("Error: " + msg); ++ errors++; ++ } ++ ++ private int errors; ++ private String testSrc = System.getProperty("test.src", "."); ++ private String testClasses = System.getProperty("test.classes", "."); ++} ++ ++class Test { ++ void m(String s) { ++ for (int i = 0; i < 10; i++) { ++ try { ++ List<String> list = null; ++ System.out.println(s + i); ++ } catch (NullPointerException e) { ++ System.out.println("catch NPE"); ++ } finally { ++ System.out.println("finally"); ++ } ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/6841419-classfile_iterator.patch b/java/openjdk6/files/icedtea/openjdk/6841419-classfile_iterator.patch new file mode 100644 index 000000000000..f728ad179600 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6841419-classfile_iterator.patch @@ -0,0 +1,142 @@ +# HG changeset patch +# User jjg +# Date 1242758630 25200 +# Tue May 19 11:43:50 2009 -0700 +# Node ID 17dfaebe23044c48bcd5ed0730ce2358543ac459 +# Parent 00870be9028f778a169bf9b843a994ec44258c22 +6841419: classfile: add constant pool iterator +Reviewed-by: mcimadamore + +diff -r 00870be9028f -r 17dfaebe2304 src/share/classes/com/sun/tools/classfile/ClassTranslator.java +--- langtools/src/share/classes/com/sun/tools/classfile/ClassTranslator.java Tue May 19 11:33:13 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/ClassTranslator.java Tue May 19 11:43:50 2009 -0700 +@@ -95,7 +95,7 @@ + if (cp2 == null) { + ConstantPool.CPInfo[] pool2 = new ConstantPool.CPInfo[cp.size()]; + boolean eq = true; +- for (int i = 0; i < cp.size(); i++) { ++ for (int i = 0; i < cp.size(); ) { + ConstantPool.CPInfo cpInfo; + try { + cpInfo = cp.get(i); +@@ -107,11 +107,7 @@ + pool2[i] = cpInfo2; + if (cpInfo.getTag() != cpInfo2.getTag()) + throw new IllegalStateException(); +- switch (cpInfo.getTag()) { +- case ConstantPool.CONSTANT_Double: +- case ConstantPool.CONSTANT_Long: +- i += 1; +- } ++ i += cpInfo.size(); + } + + if (eq) +diff -r 00870be9028f -r 17dfaebe2304 src/share/classes/com/sun/tools/classfile/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/classfile/ClassWriter.java Tue May 19 11:33:13 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/ClassWriter.java Tue May 19 11:43:50 2009 -0700 +@@ -118,13 +118,8 @@ + ConstantPool pool = classFile.constant_pool; + int size = pool.size(); + out.writeShort(size); +- try { +- for (int i = 1; i < size; ) { +- i += constantPoolWriter.write(pool.get(i), out); +- } +- } catch (ConstantPoolException e) { +- throw new Error(e); // ?? +- } ++ for (CPInfo cpInfo: pool.entries()) ++ constantPoolWriter.write(cpInfo, out); + } + + protected void writeFields() throws IOException { +diff -r 00870be9028f -r 17dfaebe2304 src/share/classes/com/sun/tools/classfile/ConstantPool.java +--- langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Tue May 19 11:33:13 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Tue May 19 11:43:50 2009 -0700 +@@ -26,6 +26,7 @@ + package com.sun.tools.classfile; + + import java.io.IOException; ++import java.util.Iterator; + + /** + * See JVMS3, section 4.5. +@@ -219,6 +220,40 @@ + throw new EntryNotFound(value); + } + ++ public Iterable<CPInfo> entries() { ++ return new Iterable<CPInfo>() { ++ public Iterator<CPInfo> iterator() { ++ return new Iterator<CPInfo>() { ++ ++ public boolean hasNext() { ++ return next < pool.length; ++ } ++ ++ public CPInfo next() { ++ current = pool[next]; ++ switch (current.getTag()) { ++ case CONSTANT_Double: ++ case CONSTANT_Long: ++ next += 2; ++ break; ++ default: ++ next += 1; ++ } ++ return current; ++ } ++ ++ public void remove() { ++ throw new UnsupportedOperationException(); ++ } ++ ++ private CPInfo current; ++ private int next = 1; ++ ++ }; ++ } ++ }; ++ } ++ + private CPInfo[] pool; + + public interface Visitor<R,P> { +@@ -246,6 +281,12 @@ + + public abstract int getTag(); + ++ /** The number of slots in the constant pool used by this entry. ++ * 2 for CONSTANT_Double and CONSTANT_Long; 1 for everything else. */ ++ public int size() { ++ return 1; ++ } ++ + public abstract <R,D> R accept(Visitor<R,D> visitor, D data); + + protected final ConstantPool cp; +@@ -346,6 +387,11 @@ + } + + @Override ++ public int size() { ++ return 2; ++ } ++ ++ @Override + public String toString() { + return "CONSTANT_Double_info[value: " + value + "]"; + } +@@ -459,6 +505,11 @@ + } + + @Override ++ public int size() { ++ return 2; ++ } ++ ++ @Override + public String toString() { + return "CONSTANT_Long_info[value: " + value + "]"; + } diff --git a/java/openjdk6/files/icedtea/openjdk/6841420-classfile_methods.patch b/java/openjdk6/files/icedtea/openjdk/6841420-classfile_methods.patch new file mode 100644 index 000000000000..340286a63187 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6841420-classfile_methods.patch @@ -0,0 +1,34 @@ +# HG changeset patch +# User jjg +# Date 1242757993 25200 +# Tue May 19 11:33:13 2009 -0700 +# Node ID 00870be9028f778a169bf9b843a994ec44258c22 +# Parent c9b0fee44d446f902102462387c40ca9d1020b6e +6841420: classfile: add new methods to ConstantClassInfo +Reviewed-by: mcimadamore +Contributed-by: kevin.t.looney@sun.com + +diff -r c9b0fee44d44 -r 00870be9028f src/share/classes/com/sun/tools/classfile/ConstantPool.java +--- langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Wed Jun 18 16:53:08 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Tue May 19 11:33:13 2009 -0700 +@@ -306,6 +306,20 @@ + return cp.getUTF8Value(name_index); + } + ++ public String getBaseName() throws ConstantPoolException { ++ String name = getName(); ++ int index = name.indexOf("[L") + 1; ++ return name.substring(index); ++ } ++ ++ public int getDimensionCount() throws ConstantPoolException { ++ String name = getName(); ++ int count = 0; ++ while (name.charAt(count) == '[') ++ count++; ++ return count; ++ } ++ + @Override + public String toString() { + return "CONSTANT_Class_info[name_index: " + name_index + "]"; diff --git a/java/openjdk6/files/icedtea/openjdk/6843013-missing_experimental.patch b/java/openjdk6/files/icedtea/openjdk/6843013-missing_experimental.patch new file mode 100644 index 000000000000..b4f5c1dcfc01 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6843013-missing_experimental.patch @@ -0,0 +1,334 @@ +# HG changeset patch +# User jjg +# Date 1242766380 25200 +# Tue May 19 13:53:00 2009 -0700 +# Node ID a7567fdabf3eae2c495726e6c25e2364e175261f +# Parent 4b55db11179d066331b829ca5c4722c33287deea +6843013: missing files in fix for 6824493 +Reviewed-by: darcy + +diff -r 4b55db11179d -r a7567fdabf3e src/share/classes/com/sun/tools/javap/LocalVariableTableWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/LocalVariableTableWriter.java Tue May 19 13:53:00 2009 -0700 +@@ -0,0 +1,158 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.Attribute; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.Descriptor; ++import com.sun.tools.classfile.Descriptor.InvalidDescriptor; ++import com.sun.tools.classfile.Instruction; ++import com.sun.tools.classfile.LocalVariableTable_attribute; ++import java.util.ArrayList; ++import java.util.HashMap; ++import java.util.List; ++import java.util.ListIterator; ++import java.util.Map; ++ ++/** ++ * Annotate instructions with details about local variables. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class LocalVariableTableWriter extends InstructionDetailWriter { ++ public enum NoteKind { ++ START("start") { ++ public boolean match(LocalVariableTable_attribute.Entry entry, int pc) { ++ return (pc == entry.start_pc); ++ } ++ }, ++ END("end") { ++ public boolean match(LocalVariableTable_attribute.Entry entry, int pc) { ++ return (pc == entry.start_pc + entry.length); ++ } ++ }; ++ NoteKind(String text) { ++ this.text = text; ++ } ++ public abstract boolean match(LocalVariableTable_attribute.Entry entry, int pc); ++ public final String text; ++ }; ++ ++ static LocalVariableTableWriter instance(Context context) { ++ LocalVariableTableWriter instance = context.get(LocalVariableTableWriter.class); ++ if (instance == null) ++ instance = new LocalVariableTableWriter(context); ++ return instance; ++ } ++ ++ protected LocalVariableTableWriter(Context context) { ++ super(context); ++ context.put(LocalVariableTableWriter.class, this); ++ classWriter = ClassWriter.instance(context); ++ } ++ ++ public void reset(Code_attribute attr) { ++ codeAttr = attr; ++ pcMap = new HashMap<Integer, List<LocalVariableTable_attribute.Entry>>(); ++ LocalVariableTable_attribute lvt = ++ (LocalVariableTable_attribute) (attr.attributes.get(Attribute.LocalVariableTable)); ++ if (lvt == null) ++ return; ++ ++ for (int i = 0; i < lvt.local_variable_table.length; i++) { ++ LocalVariableTable_attribute.Entry entry = lvt.local_variable_table[i]; ++ put(entry.start_pc, entry); ++ put(entry.start_pc + entry.length, entry); ++ } ++ } ++ ++ public void writeDetails(Instruction instr) { ++ int pc = instr.getPC(); ++ writeLocalVariables(pc, NoteKind.END); ++ writeLocalVariables(pc, NoteKind.START); ++ } ++ ++ @Override ++ public void flush() { ++ int pc = codeAttr.code_length; ++ writeLocalVariables(pc, NoteKind.END); ++ } ++ ++ public void writeLocalVariables(int pc, NoteKind kind) { ++ ConstantPool constant_pool = classWriter.getClassFile().constant_pool; ++ String indent = space(2); // get from Options? ++ List<LocalVariableTable_attribute.Entry> entries = pcMap.get(pc); ++ if (entries != null) { ++ for (ListIterator<LocalVariableTable_attribute.Entry> iter = ++ entries.listIterator(kind == NoteKind.END ? entries.size() : 0); ++ kind == NoteKind.END ? iter.hasPrevious() : iter.hasNext() ; ) { ++ LocalVariableTable_attribute.Entry entry = ++ kind == NoteKind.END ? iter.previous() : iter.next(); ++ if (kind.match(entry, pc)) { ++ print(indent); ++ print(kind.text); ++ print(" local "); ++ print(entry.index); ++ print(" // "); ++ Descriptor d = new Descriptor(entry.descriptor_index); ++ try { ++ print(d.getFieldType(constant_pool)); ++ } catch (InvalidDescriptor e) { ++ print(report(e)); ++ } catch (ConstantPoolException e) { ++ print(report(e)); ++ } ++ print(" "); ++ try { ++ print(constant_pool.getUTF8Value(entry.name_index)); ++ } catch (ConstantPoolException e) { ++ print(report(e)); ++ } ++ println(); ++ } ++ } ++ } ++ } ++ ++ private void put(int pc, LocalVariableTable_attribute.Entry entry) { ++ List<LocalVariableTable_attribute.Entry> list = pcMap.get(pc); ++ if (list == null) { ++ list = new ArrayList<LocalVariableTable_attribute.Entry>(); ++ pcMap.put(pc, list); ++ } ++ if (!list.contains(entry)) ++ list.add(entry); ++ } ++ ++ private ClassWriter classWriter; ++ private Code_attribute codeAttr; ++ private Map<Integer, List<LocalVariableTable_attribute.Entry>> pcMap; ++} +diff -r 4b55db11179d -r a7567fdabf3e src/share/classes/com/sun/tools/javap/LocalVariableTypeTableWriter.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/src/share/classes/com/sun/tools/javap/LocalVariableTypeTableWriter.java Tue May 19 13:53:00 2009 -0700 +@@ -0,0 +1,159 @@ ++/* ++ * 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.tools.javap; ++ ++import com.sun.tools.classfile.Attribute; ++import com.sun.tools.classfile.Code_attribute; ++import com.sun.tools.classfile.ConstantPool; ++import com.sun.tools.classfile.ConstantPoolException; ++import com.sun.tools.classfile.Descriptor; ++import com.sun.tools.classfile.Descriptor.InvalidDescriptor; ++import com.sun.tools.classfile.Instruction; ++import com.sun.tools.classfile.LocalVariableTypeTable_attribute; ++import com.sun.tools.classfile.Signature; ++import java.util.ArrayList; ++import java.util.HashMap; ++import java.util.List; ++import java.util.ListIterator; ++import java.util.Map; ++ ++/** ++ * Annotate instructions with details about local variables. ++ * ++ * <p><b>This is NOT part of any API supported by Sun Microsystems. If ++ * you write code that depends on this, you do so at your own risk. ++ * This code and its internal interfaces are subject to change or ++ * deletion without notice.</b> ++ */ ++public class LocalVariableTypeTableWriter extends InstructionDetailWriter { ++ public enum NoteKind { ++ START("start") { ++ public boolean match(LocalVariableTypeTable_attribute.Entry entry, int pc) { ++ return (pc == entry.start_pc); ++ } ++ }, ++ END("end") { ++ public boolean match(LocalVariableTypeTable_attribute.Entry entry, int pc) { ++ return (pc == entry.start_pc + entry.length); ++ } ++ }; ++ NoteKind(String text) { ++ this.text = text; ++ } ++ public abstract boolean match(LocalVariableTypeTable_attribute.Entry entry, int pc); ++ public final String text; ++ }; ++ ++ static LocalVariableTypeTableWriter instance(Context context) { ++ LocalVariableTypeTableWriter instance = context.get(LocalVariableTypeTableWriter.class); ++ if (instance == null) ++ instance = new LocalVariableTypeTableWriter(context); ++ return instance; ++ } ++ ++ protected LocalVariableTypeTableWriter(Context context) { ++ super(context); ++ context.put(LocalVariableTypeTableWriter.class, this); ++ classWriter = ClassWriter.instance(context); ++ } ++ ++ public void reset(Code_attribute attr) { ++ codeAttr = attr; ++ pcMap = new HashMap<Integer, List<LocalVariableTypeTable_attribute.Entry>>(); ++ LocalVariableTypeTable_attribute lvt = ++ (LocalVariableTypeTable_attribute) (attr.attributes.get(Attribute.LocalVariableTypeTable)); ++ if (lvt == null) ++ return; ++ ++ for (int i = 0; i < lvt.local_variable_table.length; i++) { ++ LocalVariableTypeTable_attribute.Entry entry = lvt.local_variable_table[i]; ++ put(entry.start_pc, entry); ++ put(entry.start_pc + entry.length, entry); ++ } ++ } ++ ++ public void writeDetails(Instruction instr) { ++ int pc = instr.getPC(); ++ writeLocalVariables(pc, NoteKind.END); ++ writeLocalVariables(pc, NoteKind.START); ++ } ++ ++ @Override ++ public void flush() { ++ int pc = codeAttr.code_length; ++ writeLocalVariables(pc, NoteKind.END); ++ } ++ ++ public void writeLocalVariables(int pc, NoteKind kind) { ++ ConstantPool constant_pool = classWriter.getClassFile().constant_pool; ++ String indent = space(2); // get from Options? ++ List<LocalVariableTypeTable_attribute.Entry> entries = pcMap.get(pc); ++ if (entries != null) { ++ for (ListIterator<LocalVariableTypeTable_attribute.Entry> iter = ++ entries.listIterator(kind == NoteKind.END ? entries.size() : 0); ++ kind == NoteKind.END ? iter.hasPrevious() : iter.hasNext() ; ) { ++ LocalVariableTypeTable_attribute.Entry entry = ++ kind == NoteKind.END ? iter.previous() : iter.next(); ++ if (kind.match(entry, pc)) { ++ print(indent); ++ print(kind.text); ++ print(" generic local "); ++ print(entry.index); ++ print(" // "); ++ Descriptor d = new Signature(entry.signature_index); ++ try { ++ print(d.getFieldType(constant_pool)); ++ } catch (InvalidDescriptor e) { ++ print(report(e)); ++ } catch (ConstantPoolException e) { ++ print(report(e)); ++ } ++ print(" "); ++ try { ++ print(constant_pool.getUTF8Value(entry.name_index)); ++ } catch (ConstantPoolException e) { ++ print(report(e)); ++ } ++ println(); ++ } ++ } ++ } ++ } ++ ++ private void put(int pc, LocalVariableTypeTable_attribute.Entry entry) { ++ List<LocalVariableTypeTable_attribute.Entry> list = pcMap.get(pc); ++ if (list == null) { ++ list = new ArrayList<LocalVariableTypeTable_attribute.Entry>(); ++ pcMap.put(pc, list); ++ } ++ if (!list.contains(entry)) ++ list.add(entry); ++ } ++ ++ private ClassWriter classWriter; ++ private Code_attribute codeAttr; ++ private Map<Integer, List<LocalVariableTypeTable_attribute.Entry>> pcMap; ++} diff --git a/java/openjdk6/files/icedtea/openjdk/6852856-javap_subclasses.patch b/java/openjdk6/files/icedtea/openjdk/6852856-javap_subclasses.patch new file mode 100644 index 000000000000..60b1405cd011 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6852856-javap_subclasses.patch @@ -0,0 +1,508 @@ +# HG changeset patch +# User jjg +# Date 1382677646 -3600 +# Fri Oct 25 06:07:26 2013 +0100 +# Node ID a22d1b683f15e7f67d7d3de84f7c866a65c42552 +# Parent dca34170f5f80bf30228c12a647b3f1a492b3eeb +6852856: javap changes to facilitate subclassing javap for variants +Reviewed-by: mcimadamore + +diff -r dca34170f5f8 -r a22d1b683f15 src/share/classes/com/sun/tools/classfile/AccessFlags.java +--- langtools/src/share/classes/com/sun/tools/classfile/AccessFlags.java Mon Aug 04 17:54:15 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/AccessFlags.java Fri Oct 25 06:07:26 2013 +0100 +@@ -58,7 +58,7 @@ + public static final int ACC_ENUM = 0x4000; // class, inner, field + public static final int ACC_MODULE = 0x8000; // class, inner, field, method + +- private static enum Type { Class, InnerClass, Field, Method}; ++ public static enum Kind { Class, InnerClass, Field, Method}; + + AccessFlags(ClassReader cr) throws IOException { + this(cr.readUnsignedShort()); +@@ -87,11 +87,11 @@ + + public Set<String> getClassModifiers() { + int f = ((flags & ACC_INTERFACE) != 0 ? flags & ~ACC_ABSTRACT : flags); +- return getModifiers(f, classModifiers, Type.Class); ++ return getModifiers(f, classModifiers, Kind.Class); + } + + public Set<String> getClassFlags() { +- return getFlags(classFlags, Type.Class); ++ return getFlags(classFlags, Kind.Class); + } + + private static final int[] innerClassModifiers = { +@@ -106,11 +106,11 @@ + + public Set<String> getInnerClassModifiers() { + int f = ((flags & ACC_INTERFACE) != 0 ? flags & ~ACC_ABSTRACT : flags); +- return getModifiers(f, innerClassModifiers, Type.InnerClass); ++ return getModifiers(f, innerClassModifiers, Kind.InnerClass); + } + + public Set<String> getInnerClassFlags() { +- return getFlags(innerClassFlags, Type.InnerClass); ++ return getFlags(innerClassFlags, Kind.InnerClass); + } + + private static final int[] fieldModifiers = { +@@ -124,11 +124,11 @@ + }; + + public Set<String> getFieldModifiers() { +- return getModifiers(fieldModifiers, Type.Field); ++ return getModifiers(fieldModifiers, Kind.Field); + } + + public Set<String> getFieldFlags() { +- return getFlags(fieldFlags, Type.Field); ++ return getFlags(fieldFlags, Kind.Field); + } + + private static final int[] methodModifiers = { +@@ -143,18 +143,18 @@ + }; + + public Set<String> getMethodModifiers() { +- return getModifiers(methodModifiers, Type.Method); ++ return getModifiers(methodModifiers, Kind.Method); + } + + public Set<String> getMethodFlags() { +- return getFlags(methodFlags, Type.Method); ++ return getFlags(methodFlags, Kind.Method); + } + +- private Set<String> getModifiers(int[] modifierFlags, Type t) { ++ private Set<String> getModifiers(int[] modifierFlags, Kind t) { + return getModifiers(flags, modifierFlags, t); + } + +- private static Set<String> getModifiers(int flags, int[] modifierFlags, Type t) { ++ private static Set<String> getModifiers(int flags, int[] modifierFlags, Kind t) { + Set<String> s = new LinkedHashSet<String>(); + for (int m: modifierFlags) { + if ((flags & m) != 0) +@@ -163,7 +163,7 @@ + return s; + } + +- private Set<String> getFlags(int[] expectedFlags, Type t) { ++ private Set<String> getFlags(int[] expectedFlags, Kind t) { + Set<String> s = new LinkedHashSet<String>(); + int f = flags; + for (int e: expectedFlags) { +@@ -180,7 +180,7 @@ + return s; + } + +- private static String flagToModifier(int flag, Type t) { ++ private static String flagToModifier(int flag, Kind t) { + switch (flag) { + case ACC_PUBLIC: + return "public"; +@@ -195,7 +195,7 @@ + case ACC_SYNCHRONIZED: + return "synchronized"; + case 0x80: +- return (t == Type.Field ? "transient" : null); ++ return (t == Kind.Field ? "transient" : null); + case ACC_VOLATILE: + return "volatile"; + case ACC_NATIVE: +@@ -211,7 +211,7 @@ + } + } + +- private static String flagToName(int flag, Type t) { ++ private static String flagToName(int flag, Kind t) { + switch (flag) { + case ACC_PUBLIC: + return "ACC_PUBLIC"; +@@ -224,11 +224,11 @@ + case ACC_FINAL: + return "ACC_FINAL"; + case 0x20: +- return (t == Type.Class ? "ACC_SUPER" : "ACC_SYNCHRONIZED"); ++ return (t == Kind.Class ? "ACC_SUPER" : "ACC_SYNCHRONIZED"); + case 0x40: +- return (t == Type.Field ? "ACC_VOLATILE" : "ACC_BRIDGE"); ++ return (t == Kind.Field ? "ACC_VOLATILE" : "ACC_BRIDGE"); + case 0x80: +- return (t == Type.Field ? "ACC_TRANSIENT" : "ACC_VARARGS"); ++ return (t == Kind.Field ? "ACC_TRANSIENT" : "ACC_VARARGS"); + case ACC_NATIVE: + return "ACC_NATIVE"; + case ACC_INTERFACE: +@@ -250,5 +250,5 @@ + } + } + +- final int flags; ++ public final int flags; + } +diff -r dca34170f5f8 -r a22d1b683f15 src/share/classes/com/sun/tools/classfile/ConstantPool.java +--- langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Mon Aug 04 17:54:15 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/ConstantPool.java Fri Oct 25 06:07:26 2013 +0100 +@@ -569,6 +569,11 @@ + return visitor.visitNameAndType(this, data); + } + ++ @Override ++ public String toString() { ++ return "CONSTANT_NameAndType_info[name_index: " + name_index + ", type_index: " + type_index + "]"; ++ } ++ + public final int name_index; + public final int type_index; + } +@@ -596,6 +601,11 @@ + return visitor.visitString(this, data); + } + ++ @Override ++ public String toString() { ++ return "CONSTANT_String_info[class_index: " + string_index + "]"; ++ } ++ + public final int string_index; + } + +@@ -614,7 +624,19 @@ + + @Override + public String toString() { +- return "CONSTANT_Utf8_info[value: " + value + "]"; ++ if (value.length() < 32 && isPrintableAscii(value)) ++ return "CONSTANT_Utf8_info[value: \"" + value + "\"]"; ++ else ++ return "CONSTANT_Utf8_info[value: (" + value.length() + " chars)]"; ++ } ++ ++ static boolean isPrintableAscii(String s) { ++ for (int i = 0; i < s.length(); i++) { ++ char c = s.charAt(i); ++ if (c < 32 || c >= 127) ++ return false; ++ } ++ return true; + } + + public <R, D> R accept(Visitor<R, D> visitor, D data) { +diff -r dca34170f5f8 -r a22d1b683f15 src/share/classes/com/sun/tools/javap/AttributeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Mon Aug 04 17:54:15 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Fri Oct 25 06:07:26 2013 +0100 +@@ -74,7 +74,7 @@ + public class AttributeWriter extends BasicWriter + implements Attribute.Visitor<Void,Void> + { +- static AttributeWriter instance(Context context) { ++ public static AttributeWriter instance(Context context) { + AttributeWriter instance = context.get(AttributeWriter.class); + if (instance == null) + instance = new AttributeWriter(context); +diff -r dca34170f5f8 -r a22d1b683f15 src/share/classes/com/sun/tools/javap/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Mon Aug 04 17:54:15 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Fri Oct 25 06:07:26 2013 +0100 +@@ -93,17 +93,25 @@ + this.lastModified = lastModified; + } + +- ClassFile getClassFile() { ++ protected ClassFile getClassFile() { + return classFile; + } + +- Method getMethod() { ++ protected void setClassFile(ClassFile cf) { ++ classFile = cf; ++ constant_pool = classFile.constant_pool; ++ } ++ ++ protected Method getMethod() { + return method; + } + ++ protected void setMethod(Method m) { ++ method = m; ++ } ++ + public void write(ClassFile cf) { +- classFile = cf; +- constant_pool = classFile.constant_pool; ++ setClassFile(cf); + + if ((options.sysInfo || options.verbose) && !options.compat) { + if (uri != null) { +@@ -201,13 +209,13 @@ + println(); + } + +- void writeFields() { ++ protected void writeFields() { + for (Field f: classFile.fields) { + writeField(f); + } + } + +- void writeField(Field f) { ++ protected void writeField(Field f) { + if (!options.checkAccess(f.access_flags)) + return; + +@@ -263,12 +271,12 @@ + println(); + } + +- void writeMethods() { ++ protected void writeMethods() { + for (Method m: classFile.methods) + writeMethod(m); + } + +- void writeMethod(Method m) { ++ protected void writeMethod(Method m) { + if (!options.checkAccess(m.access_flags)) + return; + +diff -r dca34170f5f8 -r a22d1b683f15 src/share/classes/com/sun/tools/javap/ConstantWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Mon Aug 04 17:54:15 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Fri Oct 25 06:07:26 2013 +0100 +@@ -40,7 +40,7 @@ + * deletion without notice.</b> + */ + public class ConstantWriter extends BasicWriter { +- static ConstantWriter instance(Context context) { ++ public static ConstantWriter instance(Context context) { + ConstantWriter instance = context.get(ConstantWriter.class); + if (instance == null) + instance = new ConstantWriter(context); +@@ -54,7 +54,12 @@ + options = Options.instance(context); + } + +- void writeConstantPool() { ++ protected void writeConstantPool() { ++ ConstantPool constant_pool = classWriter.getClassFile().constant_pool; ++ writeConstantPool(constant_pool); ++ } ++ ++ protected void writeConstantPool(ConstantPool constant_pool) { + ConstantPool.Visitor<Integer, Void> v = new ConstantPool.Visitor<Integer,Void>() { + public Integer visitClass(CONSTANT_Class_info info, Void p) { + println("#" + info.name_index + ";\t// " + stringValue(info)); +@@ -114,7 +119,6 @@ + + }; + println(" Constant pool:"); +- ConstantPool constant_pool = classWriter.getClassFile().constant_pool; + int cpx = 1; + while (cpx < constant_pool.size()) { + try { +@@ -127,7 +131,7 @@ + } + } + +- void write(int cpx) { ++ protected void write(int cpx) { + ClassFile classFile = classWriter.getClassFile(); + if (cpx == 0) { + print("#0"); +diff -r dca34170f5f8 -r a22d1b683f15 src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Mon Aug 04 17:54:15 2008 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Fri Oct 25 06:07:26 2013 +0100 +@@ -36,6 +36,7 @@ + import java.io.Writer; + import java.security.DigestInputStream; + import java.security.MessageDigest; ++import java.security.NoSuchAlgorithmException; + import java.text.MessageFormat; + import java.util.ArrayList; + import java.util.Arrays; +@@ -242,20 +243,27 @@ + + }; + +- JavapTask() { ++ public JavapTask() { + context = new Context(); + options = Options.instance(context); ++ attributeFactory = new Attribute.Factory(); + } + +- JavapTask(Writer out, ++ public JavapTask(Writer out, ++ JavaFileManager fileManager, ++ DiagnosticListener<? super JavaFileObject> diagnosticListener) { ++ this(); ++ this.log = getPrintWriterForWriter(out); ++ this.fileManager = fileManager; ++ this.diagnosticListener = diagnosticListener; ++ } ++ ++ public JavapTask(Writer out, + JavaFileManager fileManager, + DiagnosticListener<? super JavaFileObject> diagnosticListener, + Iterable<String> options, + Iterable<String> classes) { +- this(); +- this.log = getPrintWriterForWriter(out); +- this.fileManager = fileManager; +- this.diagnosticListener = diagnosticListener; ++ this(out, fileManager, diagnosticListener); + + try { + handleOptions(options, false); +@@ -464,29 +472,10 @@ + continue; + } + } +- Attribute.Factory attributeFactory = new Attribute.Factory(); + attributeFactory.setCompat(options.compat); + attributeFactory.setJSR277(options.jsr277); + +- InputStream in = fo.openInputStream(); +- SizeInputStream sizeIn = null; +- MessageDigest md = null; +- if (options.sysInfo || options.verbose) { +- md = MessageDigest.getInstance("MD5"); +- in = new DigestInputStream(in, md); +- in = sizeIn = new SizeInputStream(in); +- } +- +- ClassFile cf = ClassFile.read(in, attributeFactory); +- +- if (options.sysInfo || options.verbose) { +- classWriter.setFile(fo.toUri()); +- classWriter.setLastModified(fo.getLastModified()); +- classWriter.setDigest("MD5", md.digest()); +- classWriter.setFileSize(sizeIn.size()); +- } +- +- classWriter.write(cf); ++ write(read(fo)); + + } catch (ConstantPoolException e) { + diagnosticListener.report(createDiagnostic("err.bad.constant.pool", className, e.getLocalizedMessage())); +@@ -517,6 +506,103 @@ + return ok; + } + ++ public static class ClassFileInfo { ++ ClassFileInfo(JavaFileObject fo, ClassFile cf, byte[] digest, int size) { ++ this.fo = fo; ++ this.cf = cf; ++ this.digest = digest; ++ this.size = size; ++ } ++ public final JavaFileObject fo; ++ public final ClassFile cf; ++ public final byte[] digest; ++ public final int size; ++ } ++ ++ public ClassFileInfo read(JavaFileObject fo) throws IOException, ConstantPoolException { ++ InputStream in = fo.openInputStream(); ++ try { ++ SizeInputStream sizeIn = null; ++ MessageDigest md = null; ++ if (options.sysInfo || options.verbose) { ++ try { ++ md = MessageDigest.getInstance("MD5"); ++ } catch (NoSuchAlgorithmException ignore) { ++ } ++ in = new DigestInputStream(in, md); ++ in = sizeIn = new SizeInputStream(in); ++ } ++ ++ ClassFile cf = ClassFile.read(in, attributeFactory); ++ byte[] digest = (md == null) ? null : md.digest(); ++ int size = (sizeIn == null) ? -1 : sizeIn.size(); ++ return new ClassFileInfo(fo, cf, digest, size); ++ } finally { ++ in.close(); ++ } ++ } ++ ++ public void write(ClassFileInfo info) { ++ ClassWriter classWriter = ClassWriter.instance(context); ++ if (options.sysInfo || options.verbose) { ++ classWriter.setFile(info.fo.toUri()); ++ classWriter.setLastModified(info.fo.getLastModified()); ++ classWriter.setDigest("MD5", info.digest); ++ classWriter.setFileSize(info.size); ++ } ++ ++ classWriter.write(info.cf); ++ } ++ ++ protected void setClassFile(ClassFile classFile) { ++ ClassWriter classWriter = ClassWriter.instance(context); ++ classWriter.setClassFile(classFile); ++ } ++ ++ protected void setMethod(Method enclosingMethod) { ++ ClassWriter classWriter = ClassWriter.instance(context); ++ classWriter.setMethod(enclosingMethod); ++ } ++ ++ protected void write(Attribute value) { ++ AttributeWriter attrWriter = AttributeWriter.instance(context); ++ ClassWriter classWriter = ClassWriter.instance(context); ++ ClassFile cf = classWriter.getClassFile(); ++ attrWriter.write(cf, value, cf.constant_pool); ++ } ++ ++ protected void write(Attributes attrs) { ++ AttributeWriter attrWriter = AttributeWriter.instance(context); ++ ClassWriter classWriter = ClassWriter.instance(context); ++ ClassFile cf = classWriter.getClassFile(); ++ attrWriter.write(cf, attrs, cf.constant_pool); ++ } ++ ++ protected void write(ConstantPool constant_pool) { ++ ConstantWriter constantWriter = ConstantWriter.instance(context); ++ constantWriter.writeConstantPool(constant_pool); ++ } ++ ++ protected void write(ConstantPool constant_pool, int value) { ++ ConstantWriter constantWriter = ConstantWriter.instance(context); ++ constantWriter.write(value); ++ } ++ ++ protected void write(ConstantPool.CPInfo value) { ++ ConstantWriter constantWriter = ConstantWriter.instance(context); ++ constantWriter.println(value); ++ } ++ ++ protected void write(Field value) { ++ ClassWriter classWriter = ClassWriter.instance(context); ++ classWriter.writeField(value); ++ } ++ ++ protected void write(Method value) { ++ ClassWriter classWriter = ClassWriter.instance(context); ++ classWriter.writeMethod(value); ++ } ++ + private JavaFileManager getDefaultFileManager(final DiagnosticListener<? super JavaFileObject> dl, PrintWriter log) { + return JavapFileManager.create(dl, log, options); + } +@@ -646,7 +732,7 @@ + } + } + +- Context context; ++ protected Context context; + JavaFileManager fileManager; + PrintWriter log; + DiagnosticListener<? super JavaFileObject> diagnosticListener; +@@ -655,6 +741,7 @@ + //ResourceBundle bundle; + Locale task_locale; + Map<Locale, ResourceBundle> bundles; ++ protected Attribute.Factory attributeFactory; + + private static final String progname = "javap"; + diff --git a/java/openjdk6/files/icedtea/openjdk/6867671-javap_whitespace.patch b/java/openjdk6/files/icedtea/openjdk/6867671-javap_whitespace.patch new file mode 100644 index 000000000000..2c5b0d72d658 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6867671-javap_whitespace.patch @@ -0,0 +1,1041 @@ +# HG changeset patch +# User jjg +# Date 1382678228 -3600 +# Fri Oct 25 06:17:08 2013 +0100 +# Node ID db86275eb3f82caf87fbe6c162dc776cb5ed85dc +# Parent a22d1b683f15e7f67d7d3de84f7c866a65c42552 +6867671: javap whitespace formatting issues +Reviewed-by: mcimadamore + +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/AttributeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/AttributeWriter.java Fri Oct 25 06:17:08 2013 +0100 +@@ -41,7 +41,6 @@ + import com.sun.tools.classfile.Deprecated_attribute; + import com.sun.tools.classfile.EnclosingMethod_attribute; + import com.sun.tools.classfile.Exceptions_attribute; +-import com.sun.tools.classfile.Field; + import com.sun.tools.classfile.InnerClasses_attribute; + import com.sun.tools.classfile.LineNumberTable_attribute; + import com.sun.tools.classfile.LocalVariableTable_attribute; +@@ -147,22 +146,26 @@ + } + + public Void visitAnnotationDefault(AnnotationDefault_attribute attr, Void ignore) { +- println(" AnnotationDefault: "); +- print(" default_value: "); ++ println("AnnotationDefault:"); ++ indent(+1); ++ print("default_value: "); + annotationWriter.write(attr.default_value); ++ indent(-1); + return null; + } + + public Void visitCharacterRangeTable(CharacterRangeTable_attribute attr, Void ignore) { +- print(" CharacterRangeTable: "); ++ println("CharacterRangeTable:"); ++ indent(+1); + for (int i = 0; i < attr.character_range_table.length; i++) { + CharacterRangeTable_attribute.Entry e = attr.character_range_table[i]; + print(" " + e.start_pc + ", " + + e.end_pc + ", " + + Integer.toHexString(e.character_range_start) + ", " + + Integer.toHexString(e.character_range_end) + ", " + +- Integer.toHexString(e.flags) + +- "\t// "); ++ Integer.toHexString(e.flags)); ++ tab(); ++ print("// "); + print(e.start_pc + ", " + + e.end_pc + ", " + + (e.character_range_start >> 10) + ":" + (e.character_range_start & 0x3ff) + ", " + +@@ -185,16 +188,13 @@ + print(", branch-true"); + if ((e.flags & CharacterRangeTable_attribute.CRT_BRANCH_FALSE) != 0) + print(", branch-false"); +- +- +- + } ++ indent(-1); + return null; + } + + public Void visitCode(Code_attribute attr, Void ignore) { + codeWriter.write(attr, constant_pool); +- println(); + return null; + } + +@@ -205,25 +205,23 @@ + + public Void visitConstantValue(ConstantValue_attribute attr, Void ignore) { + if (options.compat) // BUG 6622216 javap names some attributes incorrectly +- print(" Constant value: "); ++ print("Constant value: "); + else +- print(" ConstantValue: "); ++ print("ConstantValue: "); + constantWriter.write(attr.constantvalue_index); +- if (!options.compat) // BUG 6622232 javap gets whitespace confused +- println(); ++ println(); + return null; + } + + public Void visitDeprecated(Deprecated_attribute attr, Void ignore) { +- if (!(options.compat && owner instanceof Field)) // BUG 6622232 javap gets whitespace confused +- print(" "); + println("Deprecated: true"); + return null; + } + + public Void visitEnclosingMethod(EnclosingMethod_attribute attr, Void ignore) { +- print(" EnclosingMethod: #" + attr.class_index + ".#" + attr.method_index +- + "\t// " + getJavaClassName(attr)); ++ print("EnclosingMethod: #" + attr.class_index + ".#" + attr.method_index); ++ tab(); ++ print("// " + getJavaClassName(attr)); + if (attr.method_index != 0) + print("." + getMethodName(attr)); + println(); +@@ -247,15 +245,16 @@ + } + + public Void visitExceptions(Exceptions_attribute attr, Void ignore) { +- println(" Exceptions: "); +- print(" throws "); ++ println("Exceptions:"); ++ indent(+1); ++ print("throws "); + for (int i = 0; i < attr.number_of_exceptions; i++) { + if (i > 0) + print(", "); + print(getJavaException(attr, i)); + } +- if (!options.compat) // BUG 6622232 javap gets whitespace confused +- println(); ++ println(); ++ indent(-1); + return null; + } + +@@ -288,8 +287,7 @@ + writeInnerClassHeader(); + first = false; + } +- if (!options.compat) // BUG 6622232: javap gets whitespace confused +- print(" "); ++ print(" "); + for (String name: access_flags.getInnerClassModifiers()) + print(name + " "); + if (info.inner_name_index!=0) { +@@ -311,6 +309,8 @@ + println(); + } + } ++ if (!first) ++ indent(-1); + return null; + } + +@@ -323,26 +323,28 @@ + } + + private void writeInnerClassHeader() { +- print(" "); + if (options.compat) // BUG 6622216: javap names some attributes incorrectly + print("InnerClass"); + else + print("InnerClasses"); + println(": "); ++ indent(+1); + } + + public Void visitLineNumberTable(LineNumberTable_attribute attr, Void ignore) { +- println(" LineNumberTable: "); ++ println("LineNumberTable:"); ++ indent(+1); + for (LineNumberTable_attribute.Entry entry: attr.line_number_table) { +- println(" line " + entry.line_number + ": " + entry.start_pc); ++ println("line " + entry.line_number + ": " + entry.start_pc); + } ++ indent(-1); + return null; + } + + public Void visitLocalVariableTable(LocalVariableTable_attribute attr, Void ignore) { +- println(" LocalVariableTable: "); +- println(" Start Length Slot Name Signature"); +- ++ println("LocalVariableTable:"); ++ indent(+1); ++ println("Start Length Slot Name Signature"); + for (LocalVariableTable_attribute.Entry entry : attr.local_variable_table) { + Formatter formatter = new Formatter(); + println(formatter.format("%8d %7d %5d %5s %s", +@@ -350,25 +352,28 @@ + constantWriter.stringValue(entry.name_index), + constantWriter.stringValue(entry.descriptor_index))); + } ++ indent(-1); + return null; + } + + public Void visitLocalVariableTypeTable(LocalVariableTypeTable_attribute attr, Void ignore) { +- println(" LocalVariableTypeTable: "); +- println(" Start Length Slot Name Signature"); +- ++ println("LocalVariableTypeTable:"); ++ indent(+1); ++ println("Start Length Slot Name Signature"); + for (LocalVariableTypeTable_attribute.Entry entry : attr.local_variable_table) { +- Formatter formatter = new Formatter(); +- println(formatter.format("%8d %7d %5d %5s %s", ++ println(String.format("%5d %7d %5d %5s %s", + entry.start_pc, entry.length, entry.index, + constantWriter.stringValue(entry.name_index), + constantWriter.stringValue(entry.signature_index))); + } ++ indent(-1); + return null; + } + + public Void visitModule(Module_attribute attr, Void ignore) { +- println(" Module: #" + attr.module_name + "\t// " + getModuleName(attr)); ++ print("Module: #" + attr.module_name); ++ tab(); ++ println("// " + getModuleName(attr)); + return null; + } + +@@ -381,11 +386,15 @@ + } + + public Void visitModuleExportTable(ModuleExportTable_attribute attr, Void ignore) { +- println(" ModuleExportTable:"); +- println(" Types: (" + attr.export_type_table.length + ")"); ++ println("ModuleExportTable:"); ++ indent(+1); ++ println("Types: (" + attr.export_type_table.length + ")"); + for (int i = 0; i < attr.export_type_table.length; i++) { +- println(" #" + attr.export_type_table[i] + "\t// " + getExportTypeName(attr, i)); ++ print("#" + attr.export_type_table[i]); ++ tab(); ++ println("// " + getExportTypeName(attr, i)); + } ++ indent(-1); + return null; + } + +@@ -398,11 +407,15 @@ + } + + public Void visitModuleMemberTable(ModuleMemberTable_attribute attr, Void ignore) { +- println(" ModuleMemberTable:"); +- println(" Packages: (" + attr.package_member_table.length + ")"); ++ println("ModuleMemberTable:"); ++ indent(+1); ++ println("Packages: (" + attr.package_member_table.length + ")"); + for (int i = 0; i < attr.package_member_table.length; i++) { +- println(" #" + attr.package_member_table[i] + "\t// " + getPackageMemberName(attr, i)); ++ print("#" + attr.package_member_table[i]); ++ tab(); ++ println("// " + getPackageMemberName(attr, i)); + } ++ indent(-1); + return null; + } + +@@ -415,53 +428,67 @@ + } + + public Void visitRuntimeVisibleAnnotations(RuntimeVisibleAnnotations_attribute attr, Void ignore) { +- println(" RuntimeVisibleAnnotations: "); ++ println("RuntimeVisibleAnnotations:"); ++ indent(+1); + for (int i = 0; i < attr.annotations.length; i++) { +- print(" " + i + ": "); ++ print(i + ": "); + annotationWriter.write(attr.annotations[i]); + println(); + } ++ indent(-1); + return null; + } + + public Void visitRuntimeInvisibleAnnotations(RuntimeInvisibleAnnotations_attribute attr, Void ignore) { +- println(" RuntimeInvisibleAnnotations: "); ++ println("RuntimeInvisibleAnnotations:"); ++ indent(+1); + for (int i = 0; i < attr.annotations.length; i++) { +- print(" " + i + ": "); ++ print(i + ": "); + annotationWriter.write(attr.annotations[i]); + println(); + } ++ indent(-1); + return null; + } + + public Void visitRuntimeVisibleParameterAnnotations(RuntimeVisibleParameterAnnotations_attribute attr, Void ignore) { +- println(" RuntimeVisibleParameterAnnotations: "); ++ println("RuntimeVisibleParameterAnnotations:"); ++ indent(+1); + for (int param = 0; param < attr.parameter_annotations.length; param++) { +- println(" parameter " + param + ": "); ++ println("parameter " + param + ": "); ++ indent(+1); + for (int i = 0; i < attr.parameter_annotations[param].length; i++) { +- print(" " + i + ": "); ++ print(i + ": "); + annotationWriter.write(attr.parameter_annotations[param][i]); + println(); + } ++ indent(-1); + } ++ indent(-1); + return null; + } + + public Void visitRuntimeInvisibleParameterAnnotations(RuntimeInvisibleParameterAnnotations_attribute attr, Void ignore) { +- println(" RuntimeInvisibleParameterAnnotations: "); ++ println("RuntimeInvisibleParameterAnnotations:"); ++ indent(+1); + for (int param = 0; param < attr.parameter_annotations.length; param++) { +- println(" " + param + ": "); ++ println(param + ": "); ++ indent(+1); + for (int i = 0; i < attr.parameter_annotations[param].length; i++) { +- print(" " + i + ": "); ++ print(i + ": "); + annotationWriter.write(attr.parameter_annotations[param][i]); + println(); + } ++ indent(-1); + } ++ indent(-1); + return null; + } + + public Void visitSignature(Signature_attribute attr, Void ignore) { +- println(" Signature: #" + attr.signature_index + "\t// " + getSignature(attr)); ++ print("Signature: #" + attr.signature_index); ++ tab(); ++ println("// " + getSignature(attr)); + return null; + } + +@@ -474,12 +501,12 @@ + } + + public Void visitSourceDebugExtension(SourceDebugExtension_attribute attr, Void ignore) { +- println(" SourceDebugExtension: " + attr.getValue()); ++ println("SourceDebugExtension: " + attr.getValue()); + return null; + } + + public Void visitSourceFile(SourceFile_attribute attr, Void ignore) { +- println(" SourceFile: \"" + getSourceFile(attr) + "\""); ++ println("SourceFile: \"" + getSourceFile(attr) + "\""); + return null; + } + +@@ -497,24 +524,26 @@ + } + + public Void visitStackMap(StackMap_attribute attr, Void ignore) { +- println(" StackMap: number_of_entries = " + attr.number_of_entries); +- ++ println("StackMap: number_of_entries = " + attr.number_of_entries); ++ indent(+1); + StackMapTableWriter w = new StackMapTableWriter(); + for (StackMapTable_attribute.stack_map_frame entry : attr.entries) { + w.write(entry); + } + println(); ++ indent(-1); + return null; + } + + public Void visitStackMapTable(StackMapTable_attribute attr, Void ignore) { +- println(" StackMapTable: number_of_entries = " + attr.number_of_entries); +- ++ println("StackMapTable: number_of_entries = " + attr.number_of_entries); ++ indent(+1); + StackMapTableWriter w = new StackMapTableWriter(); + for (StackMapTable_attribute.stack_map_frame entry : attr.entries) { + w.write(entry); + } + println(); ++ indent(-1); + return null; + } + +@@ -533,29 +562,37 @@ + public Void visit_same_locals_1_stack_item_frame(StackMapTable_attribute.same_locals_1_stack_item_frame frame, Void p) { + printHeader(frame); + println(" /* same_locals_1_stack_item */"); ++ indent(+1); + printMap("stack", frame.stack); ++ indent(-1); + return null; + } + + public Void visit_same_locals_1_stack_item_frame_extended(StackMapTable_attribute.same_locals_1_stack_item_frame_extended frame, Void p) { + printHeader(frame); + println(" /* same_locals_1_stack_item_frame_extended */"); +- println(" offset_delta = " + frame.offset_delta); ++ indent(+1); ++ println("offset_delta = " + frame.offset_delta); + printMap("stack", frame.stack); ++ indent(-1); + return null; + } + + public Void visit_chop_frame(StackMapTable_attribute.chop_frame frame, Void p) { + printHeader(frame); + println(" /* chop */"); +- println(" offset_delta = " + frame.offset_delta); ++ indent(+1); ++ println("offset_delta = " + frame.offset_delta); ++ indent(-1); + return null; + } + + public Void visit_same_frame_extended(StackMapTable_attribute.same_frame_extended frame, Void p) { + printHeader(frame); + println(" /* same_frame_extended */"); +- println(" offset_delta = " + frame.offset_delta); ++ indent(+1); ++ println("offset_delta = " + frame.offset_delta); ++ indent(-1); + return null; + } + +@@ -570,13 +607,16 @@ + public Void visit_full_frame(StackMapTable_attribute.full_frame frame, Void p) { + printHeader(frame); + if (frame instanceof StackMap_attribute.stack_map_frame) { +- println(" offset = " + frame.offset_delta); ++ indent(+1); ++ println(" offset = " + frame.offset_delta); + } else { + println(" /* full_frame */"); +- println(" offset_delta = " + frame.offset_delta); ++ indent(+1); ++ println("offset_delta = " + frame.offset_delta); + } + printMap("locals", frame.locals); + printMap("stack", frame.stack); ++ indent(-1); + return null; + } + +@@ -585,7 +625,7 @@ + } + + void printMap(String name, StackMapTable_attribute.verification_type_info[] map) { +- print(" " + name + " = ["); ++ print(name + " = ["); + for (int i = 0; i < map.length; i++) { + StackMapTable_attribute.verification_type_info info = map[i]; + int tag = info.tag; +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/BasicWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/BasicWriter.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/BasicWriter.java Fri Oct 25 06:17:08 2013 +0100 +@@ -68,6 +68,18 @@ + lineWriter.println(); + } + ++ protected void indent(int delta) { ++ lineWriter.indent(delta); ++ } ++ ++ protected void tab() { ++ lineWriter.tab(); ++ } ++ ++ protected void setPendingNewline(boolean b) { ++ lineWriter.pendingNewline = b; ++ } ++ + protected String report(AttributeException e) { + out.println("Error: " + e.getMessage()); // i18n? + return "???"; +@@ -101,19 +113,30 @@ + + protected LineWriter(Context context) { + context.put(LineWriter.class, this); ++ Options options = Options.instance(context); ++ indentWidth = options.indentWidth; ++ tabColumn = options.tabColumn; + out = context.get(PrintWriter.class); + buffer = new StringBuilder(); + } + + protected void print(String s) { ++ if (pendingNewline) { ++ println(); ++ pendingNewline = false; ++ } + if (s == null) + s = "null"; + for (int i = 0; i < s.length(); i++) { + char c = s.charAt(i); +- if (c == '\n') { +- println(); +- } else { +- buffer.append(c); ++ switch (c) { ++ case '\n': ++ println(); ++ break; ++ default: ++ if (buffer.length() == 0) ++ indent(); ++ buffer.append(c); + } + } + +@@ -124,8 +147,31 @@ + buffer.setLength(0); + } + ++ protected void indent(int delta) { ++ indentCount += delta; ++ } ++ ++ protected void tab() { ++ if (buffer.length() == 0) ++ indent(); ++ space(indentCount * indentWidth + tabColumn - buffer.length()); ++ } ++ ++ private void indent() { ++ space(indentCount * indentWidth); ++ } ++ ++ private void space(int n) { ++ for (int i = 0; i < n; i++) ++ buffer.append(' '); ++ } ++ + private PrintWriter out; + private StringBuilder buffer; ++ private int indentCount; ++ private int indentWidth; ++ private int tabColumn; ++ private boolean pendingNewline; + } + } + +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/ClassWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/ClassWriter.java Fri Oct 25 06:17:08 2013 +0100 +@@ -120,6 +120,7 @@ + else + println("Classfile " + uri); + } ++ indent(+1); + if (lastModified != -1) { + Date lm = new Date(lastModified); + DateFormat df = DateFormat.getDateInstance(); +@@ -144,6 +145,10 @@ + println("Compiled from \"" + getSourceFile((SourceFile_attribute) sfa) + "\""); + } + ++ if ((options.sysInfo || options.verbose) && !options.compat) { ++ indent(-1); ++ } ++ + String name = getJavaName(classFile); + AccessFlags flags = cf.access_flags; + +@@ -190,23 +195,24 @@ + + if (options.verbose) { + println(); ++ indent(+1); + attrWriter.write(cf, cf.attributes, constant_pool); +- println(" minor version: " + cf.minor_version); +- println(" major version: " + cf.major_version); ++ println("minor version: " + cf.minor_version); ++ println("major version: " + cf.major_version); + if (!options.compat) +- writeList(" flags: ", flags.getClassFlags(), NEWLINE); ++ writeList("flags: ", flags.getClassFlags(), NEWLINE); ++ indent(-1); + constantWriter.writeConstantPool(); +- println(); + } else { +- if (!options.compat) +- print(" "); ++ print(" "); + } + + println("{"); ++ indent(+1); + writeFields(); + writeMethods(); ++ indent(-1); + println("}"); +- println(); + } + + protected void writeFields() { +@@ -219,14 +225,6 @@ + if (!options.checkAccess(f.access_flags)) + return; + +- if (!(options.showLineAndLocalVariableTables +- || options.showDisassembled +- || options.verbose +- || options.showInternalSignatures +- || options.showAllAttrs)) { +- print(" "); +- } +- + AccessFlags flags = f.access_flags; + writeModifiers(flags.getFieldModifiers()); + Signature_attribute sigAttr = getSignature(f.attributes); +@@ -255,11 +253,13 @@ + print(";"); + println(); + ++ indent(+1); ++ + if (options.showInternalSignatures) +- println(" Signature: " + getValue(f.descriptor)); ++ println("Signature: " + getValue(f.descriptor)); + + if (options.verbose && !options.compat) +- writeList(" flags: ", flags.getFieldFlags(), NEWLINE); ++ writeList("flags: ", flags.getFieldFlags(), NEWLINE); + + if (options.showAllAttrs) { + for (Attribute attr: f.attributes) +@@ -267,6 +267,8 @@ + println(); + } + ++ indent(-1); ++ + if (options.showDisassembled || options.showLineAndLocalVariableTables) + println(); + } +@@ -274,6 +276,7 @@ + protected void writeMethods() { + for (Method m: classFile.methods) + writeMethod(m); ++ setPendingNewline(false); + } + + protected void writeMethod(Method m) { +@@ -282,14 +285,6 @@ + + method = m; + +- if (!(options.showLineAndLocalVariableTables +- || options.showDisassembled +- || options.verbose +- || options.showInternalSignatures +- || options.showAllAttrs)) { +- print(" "); +- } +- + AccessFlags flags = m.access_flags; + + Descriptor d; +@@ -337,16 +332,6 @@ + if (e_attr != null) { // if there are generic exceptions, there must be erased exceptions + if (e_attr instanceof Exceptions_attribute) { + Exceptions_attribute exceptions = (Exceptions_attribute) e_attr; +- if (options.compat) { // Bug XXXXXXX whitespace +- if (!(options.showLineAndLocalVariableTables +- || options.showDisassembled +- || options.verbose +- || options.showInternalSignatures +- || options.showAllAttrs)) { +- print(" "); +- } +- print(" "); +- } + print(" throws "); + if (methodExceptions != null) { // use generic list if available + writeList("", methodExceptions, ""); +@@ -362,14 +347,17 @@ + } + } + +- print(";"); +- println(); ++ println(";"); + +- if (options.showInternalSignatures) +- println(" Signature: " + getValue(m.descriptor)); ++ indent(+1); + +- if (options.verbose && !options.compat) +- writeList(" flags: ", flags.getMethodFlags(), NEWLINE); ++ if (options.showInternalSignatures) { ++ println("Signature: " + getValue(m.descriptor)); ++ } ++ ++ if (options.verbose && !options.compat) { ++ writeList("flags: ", flags.getMethodFlags(), NEWLINE); ++ } + + Code_attribute code = null; + Attribute c_attr = m.attributes.get(Attribute.Code); +@@ -382,33 +370,35 @@ + + if (options.showDisassembled && !options.showAllAttrs) { + if (code != null) { +- println(" Code:"); ++ println("Code:"); + codeWriter.writeInstrs(code); + codeWriter.writeExceptionTable(code); + } +- println(); + } + + if (options.showLineAndLocalVariableTables) { +- if (code != null) ++ if (code != null) { + attrWriter.write(code, code.attributes.get(Attribute.LineNumberTable), constant_pool); +- println(); +- if (code != null) + attrWriter.write(code, code.attributes.get(Attribute.LocalVariableTable), constant_pool); +- println(); +- println(); ++ } + } + + if (options.showAllAttrs) { + Attribute[] attrs = m.attributes.attrs; + for (Attribute attr: attrs) + attrWriter.write(m, attr, constant_pool); ++ } + +-// // the following condition is to mimic old javap +-// if (!(attrs.length > 0 && +-// attrs[attrs.length - 1] instanceof Exceptions_attribute)) +- println(); +- } ++ indent(-1); ++ ++ // set pendingNewline to write a newline before the next method (if any) ++ // if a separator is desired ++ setPendingNewline( ++ options.showDisassembled || ++ options.showAllAttrs || ++ options.showInternalSignatures || ++ options.showLineAndLocalVariableTables || ++ options.verbose); + } + + void writeModifiers(Collection<String> items) { +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/CodeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Fri Oct 25 06:17:08 2013 +0100 +@@ -62,11 +62,13 @@ + } + + void write(Code_attribute attr, ConstantPool constant_pool) { +- println(" Code:"); ++ println("Code:"); ++ indent(+1); + writeVerboseHeader(attr, constant_pool); + writeInstrs(attr); + writeExceptionTable(attr); + attrWriter.write(attr, attr.attributes, constant_pool); ++ indent(-1); + } + + public void writeVerboseHeader(Code_attribute attr, ConstantPool constant_pool) { +@@ -83,9 +85,9 @@ + argCount = report(e); + } + +- println(" Stack=" + attr.max_stack + +- ", Locals=" + attr.max_locals + +- ", Args_size=" + argCount); ++ println("stack=" + attr.max_stack + ++ ", locals=" + attr.max_locals + ++ ", args_size=" + argCount); + + } + +@@ -101,8 +103,7 @@ + } + + public void writeInstr(Instruction instr) { +- print(" " + instr.getPC() + ":\t"); +- print(instr.getMnemonic()); ++ print(String.format("%4d: %-12s ", instr.getPC(), instr.getMnemonic())); + instr.accept(instructionPrinter, null); + println(); + } +@@ -120,54 +121,62 @@ + } + + public Void visitBranch(Instruction instr, int offset, Void p) { +- print("\t" + (instr.getPC() + offset)); ++ print((instr.getPC() + offset)); + return null; + } + + public Void visitConstantPoolRef(Instruction instr, int index, Void p) { +- print("\t#" + index + "; //"); ++ print("#" + index + ";"); ++ tab(); ++ print("// "); + printConstant(index); + return null; + } + + public Void visitConstantPoolRefAndValue(Instruction instr, int index, int value, Void p) { +- print("\t#" + index + ", " + value + "; //"); ++ print("#" + index + ", " + value + ";"); ++ tab(); ++ print("// "); + printConstant(index); + return null; + } + + public Void visitLocal(Instruction instr, int index, Void p) { +- print("\t" + index); ++ print(index); + return null; + } + + public Void visitLocalAndValue(Instruction instr, int index, int value, Void p) { +- print("\t" + index + ", " + value); ++ print(index + ", " + value); + return null; + } + + public Void visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets) { + int pc = instr.getPC(); +- print("{ //" + npairs); ++ print("{ // " + npairs); ++ indent(+1); + for (int i = 0; i < npairs; i++) { +- print("\n\t\t" + matches[i] + ": " + (pc + offsets[i]) + ";"); ++ print("\n" + matches[i] + ": " + (pc + offsets[i]) + ";"); + } +- print("\n\t\tdefault: " + (pc + default_) + " }"); ++ print("\ndefault: " + (pc + default_) + " }"); ++ indent(-1); + return null; + } + + public Void visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets) { + int pc = instr.getPC(); + print("{ //" + low + " to " + high); ++ indent(+1); + for (int i = 0; i < offsets.length; i++) { +- print("\n\t\t" + (low + i) + ": " + (pc + offsets[i]) + ";"); ++ print("\n" + (low + i) + ": " + (pc + offsets[i]) + ";"); + } +- print("\n\t\tdefault: " + (pc + default_) + " }"); ++ print("\ndefault: " + (pc + default_) + " }"); ++ indent(-1); + return null; + } + + public Void visitValue(Instruction instr, int value, Void p) { +- print("\t" + value); ++ print(value); + return null; + } + +@@ -179,13 +188,13 @@ + + public void writeExceptionTable(Code_attribute attr) { + if (attr.exception_table_langth > 0) { +- println(" Exception table:"); +- println(" from to target type"); ++ println("Exception table:"); ++ indent(+1); ++ println(" from to target type"); + for (int i = 0; i < attr.exception_table.length; i++) { + Code_attribute.Exception_data handler = attr.exception_table[i]; +- printFixedWidthInt(handler.start_pc, 6); +- printFixedWidthInt(handler.end_pc, 6); +- printFixedWidthInt(handler.handler_pc, 6); ++ print(String.format(" %5d %5d %5d", ++ handler.start_pc, handler.end_pc, handler.handler_pc)); + print(" "); + int catch_type = handler.catch_type; + if (catch_type == 0) { +@@ -193,9 +202,9 @@ + } else { + print("Class "); + println(constantWriter.stringValue(catch_type)); +- println(""); + } + } ++ indent(-1); + } + + } +@@ -204,13 +213,6 @@ + constantWriter.write(index); + } + +- private void printFixedWidthInt(int n, int width) { +- String s = String.valueOf(n); +- for (int i = s.length(); i < width; i++) +- print(" "); +- print(s); +- } +- + private static int align(int n) { + return (n + 3) & ~3; + } +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/ConstantWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Fri Oct 25 06:17:08 2013 +0100 +@@ -62,7 +62,9 @@ + protected void writeConstantPool(ConstantPool constant_pool) { + ConstantPool.Visitor<Integer, Void> v = new ConstantPool.Visitor<Integer,Void>() { + public Integer visitClass(CONSTANT_Class_info info, Void p) { +- println("#" + info.name_index + ";\t// " + stringValue(info)); ++ print("#" + info.name_index + ";"); ++ tab(); ++ println("// " + stringValue(info)); + return 1; + } + +@@ -72,7 +74,9 @@ + } + + public Integer visitFieldref(CONSTANT_Fieldref_info info, Void p) { +- println("#" + info.class_index + ".#" + info.name_and_type_index + ";\t// " + stringValue(info)); ++ print("#" + info.class_index + ".#" + info.name_and_type_index + ";"); ++ tab(); ++ println("// " + stringValue(info)); + return 1; + } + +@@ -87,7 +91,9 @@ + } + + public Integer visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, Void p) { +- println("#" + info.class_index + ".#" + info.name_and_type_index + ";\t// " + stringValue(info)); ++ print("#" + info.class_index + ".#" + info.name_and_type_index + ";"); ++ tab(); ++ println("// " + stringValue(info)); + return 1; + } + +@@ -97,18 +103,23 @@ + } + + public Integer visitNameAndType(CONSTANT_NameAndType_info info, Void p) { +- String tab = (options.compat ? "" : "\t"); // BUG 6622232 javap gets whitespace confused +- println("#" + info.name_index + ":#" + info.type_index + ";" + tab + "// " + stringValue(info)); ++ print("#" + info.name_index + ":#" + info.type_index + ";"); ++ tab(); ++ println("// " + stringValue(info)); + return 1; + } + + public Integer visitMethodref(CONSTANT_Methodref_info info, Void p) { +- println("#" + info.class_index + ".#" + info.name_and_type_index + ";\t// " + stringValue(info)); ++ print("#" + info.class_index + ".#" + info.name_and_type_index + ";"); ++ tab(); ++ println("// " + stringValue(info)); + return 1; + } + + public Integer visitString(CONSTANT_String_info info, Void p) { +- println("#" + info.string_index + ";\t// " + stringValue(info)); ++ print("#" + info.string_index + ";"); ++ tab(); ++ println("// " + stringValue(info)); + return 1; + } + +@@ -118,17 +129,21 @@ + } + + }; +- println(" Constant pool:"); ++ println("Constant pool:"); ++ indent(+1); ++ int width = String.valueOf(constant_pool.size()).length() + 1; + int cpx = 1; + while (cpx < constant_pool.size()) { ++ print(String.format("const %" + width + "s", ("#" + cpx))); + try { + CPInfo cpInfo = constant_pool.get(cpx); +- print("const #" + cpx + " = " + tagName(cpInfo.getTag()) + "\t"); ++ print(String.format(" = %-15s ", tagName(cpInfo.getTag()))); + cpx += cpInfo.accept(v, null); + } catch (ConstantPool.InvalidIndex ex) { +- print("const #" + cpx); // should not happen ++ // should not happen + } + } ++ indent(-1); + } + + protected void write(int cpx) { +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/JavapTask.java +--- langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/JavapTask.java Fri Oct 25 06:17:08 2013 +0100 +@@ -239,6 +239,38 @@ + void process(JavapTask task, String opt, String arg) { + task.options.showConstants = true; + } ++ }, ++ ++ new Option(false, "-XDindent:") { ++ @Override ++ boolean matches(String opt) { ++ int sep = opt.indexOf(":"); ++ return sep != -1 && super.matches(opt.substring(0, sep + 1)); ++ } ++ ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ int sep = opt.indexOf(":"); ++ try { ++ task.options.indentWidth = Integer.valueOf(opt.substring(sep + 1)); ++ } catch (NumberFormatException e) { ++ } ++ } ++ }, ++ ++ new Option(false, "-XDtab:") { ++ @Override ++ boolean matches(String opt) { ++ int sep = opt.indexOf(":"); ++ return sep != -1 && super.matches(opt.substring(0, sep + 1)); ++ } ++ ++ void process(JavapTask task, String opt, String arg) throws BadArgs { ++ int sep = opt.indexOf(":"); ++ try { ++ task.options.tabColumn = Integer.valueOf(opt.substring(sep + 1)); ++ } catch (NumberFormatException e) { ++ } ++ } + } + + }; +diff -r a22d1b683f15 -r db86275eb3f8 src/share/classes/com/sun/tools/javap/Options.java +--- langtools/src/share/classes/com/sun/tools/javap/Options.java Fri Oct 25 06:07:26 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/Options.java Fri Oct 25 06:17:08 2013 +0100 +@@ -79,6 +79,8 @@ + public boolean showAllAttrs; + public boolean showConstants; + public boolean sysInfo; ++ public int indentWidth = 2; // #spaces per indentWidth level ++ public int tabColumn = 40; // column number for comments + + public boolean compat; // bug-for-bug compatibility mode with old javap + public boolean jsr277; diff --git a/java/openjdk6/files/icedtea/openjdk/6868539-constant_pool_tags.patch b/java/openjdk6/files/icedtea/openjdk/6868539-constant_pool_tags.patch new file mode 100644 index 000000000000..f70e8ef53609 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6868539-constant_pool_tags.patch @@ -0,0 +1,163 @@ +# HG changeset patch +# User jjg +# Date 1249779397 25200 +# Sat Aug 08 17:56:37 2009 -0700 +# Node ID 4f38abed863c89ee101a3af495e7293df04a4a0e +# Parent db86275eb3f82caf87fbe6c162dc776cb5ed85dc +6868539: javap should use current names for constant pool tags +Reviewed-by: ksrini + +diff -r db86275eb3f8 -r 4f38abed863c src/share/classes/com/sun/tools/javap/CodeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Fri Oct 25 06:17:08 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Sat Aug 08 17:56:37 2009 -0700 +@@ -103,7 +103,7 @@ + } + + public void writeInstr(Instruction instr) { +- print(String.format("%4d: %-12s ", instr.getPC(), instr.getMnemonic())); ++ print(String.format("%4d: %-13s ", instr.getPC(), instr.getMnemonic())); + instr.accept(instructionPrinter, null); + println(); + } +diff -r db86275eb3f8 -r 4f38abed863c src/share/classes/com/sun/tools/javap/ConstantWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Fri Oct 25 06:17:08 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/javap/ConstantWriter.java Sat Aug 08 17:56:37 2009 -0700 +@@ -134,10 +134,10 @@ + int width = String.valueOf(constant_pool.size()).length() + 1; + int cpx = 1; + while (cpx < constant_pool.size()) { +- print(String.format("const %" + width + "s", ("#" + cpx))); ++ print(String.format("%" + width + "s", ("#" + cpx))); + try { + CPInfo cpInfo = constant_pool.get(cpx); +- print(String.format(" = %-15s ", tagName(cpInfo.getTag()))); ++ print(String.format(" = %-18s ", cpTagName(cpInfo))); + cpx += cpInfo.accept(v, null); + } catch (ConstantPool.InvalidIndex ex) { + // should not happen +@@ -178,10 +178,15 @@ + print(tagName(tag) + " " + stringValue(cpInfo)); + } + ++ String cpTagName(CPInfo cpInfo) { ++ String n = cpInfo.getClass().getSimpleName(); ++ return n.replace("CONSTANT_", "").replace("_info", ""); ++ } ++ + String tagName(int tag) { + switch (tag) { + case CONSTANT_Utf8: +- return "Asciz"; ++ return "Utf8"; + case CONSTANT_Integer: + return "int"; + case CONSTANT_Float: +@@ -203,7 +208,7 @@ + case CONSTANT_NameAndType: + return "NameAndType"; + default: +- return "unknown tag"; ++ return "(unknown tag)"; + } + } + +diff -r db86275eb3f8 -r 4f38abed863c test/tools/javap/T6868539.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ langtools/test/tools/javap/T6868539.java Sat Aug 08 17:56:37 2009 -0700 +@@ -0,0 +1,96 @@ ++/* ++ * 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. ++ * ++ * 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. ++ */ ++ ++/* ++ * @test ++ * @bug 6868539 6868548 ++ * @summary javap should use current names for constant pool entries, ++ * remove spurious ';' from constant pool entries ++ */ ++ ++import java.io.*; ++import java.util.*; ++ ++public class T6868539 ++ ++{ ++ public static void main(String... args) { ++ new T6868539().run(); ++ } ++ ++ void run() { ++ verify("T6868539", "Utf8 +java/lang/String"); // 1: Utf8 ++ // 2: currently unused ++ verify("T6868539", "Integer +123456"); // 3: Integer ++ verify("T6868539", "Float +123456.0f"); // 4: Float ++ verify("T6868539", "Long +123456l"); // 5: Long ++ verify("T6868539", "Double +123456.0d"); // 6: Double ++ verify("T6868539", "Class +#[0-9]+ +// + T6868539"); // 7: Class ++ verify("T6868539", "String +#[0-9]+ +// + not found"); // 8: String ++ verify("T6868539", "Fieldref +#[0-9]+\\.#[0-9]+ +// +T6868539.errors:I"); // 9: Fieldref ++ verify("T6868539", "Methodref +#[0-9]+\\.#[0-9]+ +// +T6868539.run:\\(\\)V"); // 10: Methodref ++ verify("T6868539", "InterfaceMethodref +#[0-9]+\\.#[0-9]+ +// +java/lang/Runnable\\.run:\\(\\)V"); ++ // 11: InterfaceMethodref ++ verify("T6868539", "NameAndType +#[0-9]+:#[0-9]+ +// +run:\\(\\)V"); // 12: NameAndType ++ if (errors > 0) ++ throw new Error(errors + " found."); ++ } ++ ++ void verify(String className, String... expects) { ++ String output = javap(className); ++ for (String expect: expects) { ++ if (!output.matches("(?s).*" + expect + ".*")) ++ error(expect + " not found"); ++ } ++ } ++ ++ void error(String msg) { ++ System.err.println(msg); ++ errors++; ++ } ++ ++ int errors; ++ ++ String javap(String className) { ++ String testClasses = System.getProperty("test.classes", "."); ++ StringWriter sw = new StringWriter(); ++ PrintWriter out = new PrintWriter(sw); ++ String[] args = { "-v", "-classpath", testClasses, className }; ++ int rc = com.sun.tools.javap.Main.run(args, out); ++ if (rc != 0) ++ throw new Error("javap failed. rc=" + rc); ++ out.close(); ++ String output = sw.toString(); ++ System.out.println("class " + className); ++ System.out.println(output); ++ return output; ++ } ++ ++ int i = 123456; ++ float f = 123456.f; ++ double d = 123456.; ++ long l = 123456L; ++ ++ void m(Runnable r) { r.run(); } ++} ++ diff --git a/java/openjdk6/files/icedtea/openjdk/6902264-fix_indentation.patch b/java/openjdk6/files/icedtea/openjdk/6902264-fix_indentation.patch new file mode 100644 index 000000000000..9cd7541a1d04 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6902264-fix_indentation.patch @@ -0,0 +1,159 @@ +# HG changeset patch +# User jjg +# Date 1382713809 -3600 +# Fri Oct 25 16:10:09 2013 +0100 +# Node ID 9083313d5733ca9be66bc52cf64b9b5d4dd2e39a +# Parent a7567fdabf3eae2c495726e6c25e2364e175261f +6902264: fix indentation of tableswitch and lookupswitch +Reviewed-by: ksrini + +diff -r a7567fdabf3e -r 9083313d5733 src/share/classes/com/sun/tools/classfile/Instruction.java +--- langtools/src/share/classes/com/sun/tools/classfile/Instruction.java Tue May 19 13:53:00 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/classfile/Instruction.java Fri Oct 25 16:10:09 2013 +0100 +@@ -106,9 +106,9 @@ + /** See {@link Kind#LOCAL_UBYTE}. */ + R visitLocalAndValue(Instruction instr, int index, int value, P p); + /** See {@link Kind#DYNAMIC}. */ +- R visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets); ++ R visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets, P p); + /** See {@link Kind#DYNAMIC}. */ +- R visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets); ++ R visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets, P p); + /** See {@link Kind#BYTE}, {@link Kind#SHORT}. */ + R visitValue(Instruction instr, int value, P p); + /** Instruction is unrecognized. */ +@@ -282,7 +282,7 @@ + for (int i = 0; i < values.length; i++) + values[i] = getInt(pad + 12 + 4 * i); + return visitor.visitTableSwitch( +- this, default_, low, high, values); ++ this, default_, low, high, values, p); + } + case LOOKUPSWITCH: { + int pad = align(pc + 1) - pc; +@@ -295,7 +295,7 @@ + offsets[i] = getInt(pad + 12 + i * 8); + } + return visitor.visitLookupSwitch( +- this, default_, npairs, matches, offsets); ++ this, default_, npairs, matches, offsets, p); + } + default: + throw new IllegalStateException(); +diff -r a7567fdabf3e -r 9083313d5733 src/share/classes/com/sun/tools/javap/CodeWriter.java +--- langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Tue May 19 13:53:00 2009 -0700 ++++ langtools/src/share/classes/com/sun/tools/javap/CodeWriter.java Fri Oct 25 16:10:09 2013 +0100 +@@ -117,28 +117,33 @@ + + public void writeInstr(Instruction instr) { + print(String.format("%4d: %-13s ", instr.getPC(), instr.getMnemonic())); +- instr.accept(instructionPrinter, null); ++ // compute the number of indentations for the body of multi-line instructions ++ // This is 6 (the width of "%4d: "), divided by the width of each indentation level, ++ // and rounded up to the next integer. ++ int indentWidth = options.indentWidth; ++ int indent = (6 + indentWidth - 1) / indentWidth; ++ instr.accept(instructionPrinter, indent); + println(); + } + // where +- Instruction.KindVisitor<Void,Void> instructionPrinter = +- new Instruction.KindVisitor<Void,Void>() { ++ Instruction.KindVisitor<Void,Integer> instructionPrinter = ++ new Instruction.KindVisitor<Void,Integer>() { + +- public Void visitNoOperands(Instruction instr, Void p) { ++ public Void visitNoOperands(Instruction instr, Integer indent) { + return null; + } + +- public Void visitArrayType(Instruction instr, TypeKind kind, Void p) { ++ public Void visitArrayType(Instruction instr, TypeKind kind, Integer indent) { + print(" " + kind.name); + return null; + } + +- public Void visitBranch(Instruction instr, int offset, Void p) { ++ public Void visitBranch(Instruction instr, int offset, Integer indent) { + print((instr.getPC() + offset)); + return null; + } + +- public Void visitConstantPoolRef(Instruction instr, int index, Void p) { ++ public Void visitConstantPoolRef(Instruction instr, int index, Integer indent) { + print("#" + index + ";"); + tab(); + print("// "); +@@ -146,7 +151,7 @@ + return null; + } + +- public Void visitConstantPoolRefAndValue(Instruction instr, int index, int value, Void p) { ++ public Void visitConstantPoolRefAndValue(Instruction instr, int index, int value, Integer indent) { + print("#" + index + ", " + value + ";"); + tab(); + print("// "); +@@ -154,46 +159,48 @@ + return null; + } + +- public Void visitLocal(Instruction instr, int index, Void p) { ++ public Void visitLocal(Instruction instr, int index, Integer indent) { + print(index); + return null; + } + +- public Void visitLocalAndValue(Instruction instr, int index, int value, Void p) { ++ public Void visitLocalAndValue(Instruction instr, int index, int value, Integer indent) { + print(index + ", " + value); + return null; + } + +- public Void visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets) { ++ public Void visitLookupSwitch(Instruction instr, ++ int default_, int npairs, int[] matches, int[] offsets, Integer indent) { + int pc = instr.getPC(); + print("{ // " + npairs); +- indent(+1); ++ indent(indent); + for (int i = 0; i < npairs; i++) { +- print("\n" + matches[i] + ": " + (pc + offsets[i]) + ";"); ++ print(String.format("%n%12d: %d", matches[i], (pc + offsets[i]))); + } +- print("\ndefault: " + (pc + default_) + " }"); +- indent(-1); ++ print("\n default: " + (pc + default_) + "\n}"); ++ indent(-indent); + return null; + } + +- public Void visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets) { ++ public Void visitTableSwitch(Instruction instr, ++ int default_, int low, int high, int[] offsets, Integer indent) { + int pc = instr.getPC(); +- print("{ //" + low + " to " + high); +- indent(+1); ++ print("{ // " + low + " to " + high); ++ indent(indent); + for (int i = 0; i < offsets.length; i++) { +- print("\n" + (low + i) + ": " + (pc + offsets[i]) + ";"); ++ print(String.format("%n%12d: %d", (low + i), (pc + offsets[i]))); + } +- print("\ndefault: " + (pc + default_) + " }"); +- indent(-1); ++ print("\n default: " + (pc + default_) + "\n}"); ++ indent(-indent); + return null; + } + +- public Void visitValue(Instruction instr, int value, Void p) { ++ public Void visitValue(Instruction instr, int value, Integer indent) { + print(value); + return null; + } + +- public Void visitUnknown(Instruction instr, Void p) { ++ public Void visitUnknown(Instruction instr, Integer indent) { + return null; + } + }; diff --git a/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch b/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch new file mode 100644 index 000000000000..24420ccfb189 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/6954275-big_xml_signatures.patch @@ -0,0 +1,194 @@ +# HG changeset patch +# User mullan +# Date 1287154559 14400 +# Fri Oct 15 10:55:59 2010 -0400 +# Node ID 5e3c766d18092d498d9019827c1058a32f1c4e2a +# Parent e5a4a4ec7b21f3d092d0b29024ff903864d05543 +6954275: XML signatures with reference data larger 16KB and cacheRef on fails to validate +Reviewed-by: xuelei + +diff -r e5a4a4ec7b21 -r 5e3c766d1809 src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java +--- jdk/src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java Mon Oct 28 21:46:43 2013 +0000 ++++ jdk/src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java Fri Oct 15 10:55:59 2010 -0400 +@@ -3,7 +3,7 @@ + * DO NOT REMOVE OR ALTER! + */ + /* +- * Copyright 1999-2005 The Apache Software Foundation. ++ * Copyright 1999-2010 The Apache Software Foundation. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. +@@ -23,66 +23,70 @@ + import java.io.OutputStream; + + /** +- * A simple Unsynced ByteArryOutputStream ++ * A simple Unsynced ByteArrayOutputStream + * @author raul + * + */ + public class UnsyncByteArrayOutputStream extends OutputStream { +- private static ThreadLocal bufCahce = new ThreadLocal() { ++ private static final int INITIAL_SIZE = 8192; ++ private static ThreadLocal bufCache = new ThreadLocal() { + protected synchronized Object initialValue() { +- return new byte[8*1024]; ++ return new byte[INITIAL_SIZE]; + } + }; +- byte[] buf; +- int size=8*1024;//buf.length; +- int pos=0; +- public UnsyncByteArrayOutputStream() { +- buf=(byte[])bufCahce.get(); ++ ++ private byte[] buf; ++ private int size = INITIAL_SIZE; ++ private int pos = 0; ++ ++ public UnsyncByteArrayOutputStream() { ++ buf = (byte[])bufCache.get(); ++ } ++ ++ public void write(byte[] arg0) { ++ int newPos = pos + arg0.length; ++ if (newPos > size) { ++ expandSize(newPos); + } +- /** @inheritDoc */ +- public void write(byte[] arg0) { +- int newPos=pos+arg0.length; +- if (newPos>size) { +- expandSize(); +- } +- System.arraycopy(arg0,0,buf,pos,arg0.length); +- pos=newPos; ++ System.arraycopy(arg0, 0, buf, pos, arg0.length); ++ pos = newPos; ++ } ++ ++ public void write(byte[] arg0, int arg1, int arg2) { ++ int newPos = pos + arg2; ++ if (newPos > size) { ++ expandSize(newPos); + } +- /** @inheritDoc */ +- public void write(byte[] arg0, int arg1, int arg2) { +- int newPos=pos+arg2; +- if (newPos>size) { +- expandSize(); +- } +- System.arraycopy(arg0,arg1,buf,pos,arg2); +- pos=newPos; ++ System.arraycopy(arg0, arg1, buf, pos, arg2); ++ pos = newPos; ++ } ++ ++ public void write(int arg0) { ++ int newPos = pos + 1; ++ if (newPos > size) { ++ expandSize(newPos); + } +- /** @inheritDoc */ +- public void write(int arg0) { +- if (pos>=size) { +- expandSize(); +- } +- buf[pos++]=(byte)arg0; ++ buf[pos++] = (byte)arg0; ++ } ++ ++ public byte[] toByteArray() { ++ byte result[] = new byte[pos]; ++ System.arraycopy(buf, 0, result, 0, pos); ++ return result; ++ } ++ ++ public void reset() { ++ pos = 0; ++ } ++ ++ private void expandSize(int newPos) { ++ int newSize = size; ++ while (newPos > newSize) { ++ newSize = newSize<<2; + } +- /** @inheritDoc */ +- public byte[] toByteArray() { +- byte result[]=new byte[pos]; +- System.arraycopy(buf,0,result,0,pos); +- return result; +- } +- +- /** @inheritDoc */ +- public void reset() { +- pos=0; +- } +- +- /** @inheritDoc */ +- void expandSize() { +- int newSize=size<<2; +- byte newBuf[]=new byte[newSize]; +- System.arraycopy(buf,0,newBuf,0,pos); +- buf=newBuf; +- size=newSize; +- +- } ++ byte newBuf[] = new byte[newSize]; ++ System.arraycopy(buf, 0, newBuf, 0, pos); ++ buf = newBuf; ++ size = newSize; ++ } + } +diff -r e5a4a4ec7b21 -r 5e3c766d1809 test/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream/BufferOverflowTest.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream/BufferOverflowTest.java Fri Oct 15 10:55:59 2010 -0400 +@@ -0,0 +1,47 @@ ++/* ++ * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/** ++ * @test %I% %E% ++ * @bug 6954275 ++ * @summary Check that UnsyncByteArrayOutputStream does not ++ * throw ArrayIndexOutOfBoundsException ++ * @compile -XDignore.symbol.file BufferOverflowTest.java ++ * @run main BufferOverflowTest ++ */ ++ ++import com.sun.org.apache.xml.internal.security.utils.UnsyncByteArrayOutputStream; ++ ++public class BufferOverflowTest { ++ ++ public static void main(String[] args) throws Exception { ++ try { ++ UnsyncByteArrayOutputStream out = new UnsyncByteArrayOutputStream(); ++ out.write(new byte[(8192) << 2 + 1]); ++ System.out.println("PASSED"); ++ } catch (ArrayIndexOutOfBoundsException e) { ++ System.err.println("FAILED, got ArrayIndexOutOfBoundsException"); ++ throw new Exception(e); ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/7146431-java.security_files.patch b/java/openjdk6/files/icedtea/openjdk/7146431-java.security_files.patch new file mode 100644 index 000000000000..bdcf9789e648 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/7146431-java.security_files.patch @@ -0,0 +1,82 @@ +# HG changeset patch +# User mullan +# Date 1382735486 -3600 +# Fri Oct 25 22:11:26 2013 +0100 +# Node ID 5b485ecccea9064e5036e1bb040fc2af1f773c20 +# Parent 011d86bdcbf8d4fe0016351b775ff1f48f3620a1 +7146431: java.security files out-of-sync +Reviewed-by: vinnie, xuelei, wetmore + +diff -r 011d86bdcbf8 -r 5b485ecccea9 src/share/lib/security/java.security-solaris +--- jdk/src/share/lib/security/java.security-solaris Mon Jul 15 03:40:16 2013 -0700 ++++ jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:11:26 2013 +0100 +@@ -141,6 +141,7 @@ + com.sun.org.apache.xalan.internal.lib.,\ + com.sun.org.apache.xalan.internal.res.,\ + com.sun.org.apache.xalan.internal.templates.,\ ++ com.sun.org.apache.xalan.internal.utils.\ + com.sun.org.apache.xalan.internal.xslt.,\ + com.sun.org.apache.xalan.internal.xsltc.cmdline.,\ + com.sun.org.apache.xalan.internal.xsltc.compiler.,\ +diff -r 011d86bdcbf8 -r 5b485ecccea9 src/share/lib/security/java.security-windows +--- jdk/src/share/lib/security/java.security-windows Mon Jul 15 03:40:16 2013 -0700 ++++ jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:11:26 2013 +0100 +@@ -141,6 +141,7 @@ + com.sun.org.apache.xalan.internal.lib.,\ + com.sun.org.apache.xalan.internal.res.,\ + com.sun.org.apache.xalan.internal.templates.,\ ++ com.sun.org.apache.xalan.internal.utils.\ + com.sun.org.apache.xalan.internal.xslt.,\ + com.sun.org.apache.xalan.internal.xsltc.cmdline.,\ + com.sun.org.apache.xalan.internal.xsltc.compiler.,\ +diff -r 011d86bdcbf8 -r 5b485ecccea9 test/java/lang/SecurityManager/CheckPackageAccess.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Oct 25 22:11:26 2013 +0100 +@@ -0,0 +1,47 @@ ++/* ++ * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/* ++ * @test ++ * @bug 7146431 ++ * @summary Test that internal JAXP packages cannot be accessed ++ */ ++ ++public class CheckPackageAccess { ++ ++ public static void main(String[] args) throws Exception { ++ ++ String[] pkgs = new String[] { ++ "com.sun.org.apache.xerces.internal.utils.", ++ "com.sun.org.apache.xalan.internal.utils." }; ++ SecurityManager sm = new SecurityManager(); ++ System.setSecurityManager(sm); ++ for (String pkg : pkgs) { ++ System.out.println("Checking package access for " + pkg); ++ try { ++ sm.checkPackageAccess(pkg); ++ throw new Exception("Expected SecurityException not thrown"); ++ } catch (SecurityException se) { } ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/7196533-timezone_bottleneck.patch b/java/openjdk6/files/icedtea/openjdk/7196533-timezone_bottleneck.patch new file mode 100644 index 000000000000..c8b894073a74 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/7196533-timezone_bottleneck.patch @@ -0,0 +1,75 @@ +# HG changeset patch +# User coffeys +# Date 1381845864 -3600 +# Tue Oct 15 15:04:24 2013 +0100 +# Node ID 5d81a5f8a3791316367990b35b1ad5faef42d773 +# Parent 77af6e10b333347cd882027ab1bb9a3366278096 +7196533: TimeZone.getDefault() slow due to synchronization bottleneck +Reviewed-by: okutsu, omajid + +diff -r 77af6e10b333 -r 5d81a5f8a379 src/share/classes/java/util/TimeZone.java +--- jdk/src/share/classes/java/util/TimeZone.java Fri Oct 04 12:22:34 2013 -0400 ++++ jdk/src/share/classes/java/util/TimeZone.java Tue Oct 15 15:04:24 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1996, 2011, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -646,9 +646,15 @@ + * Returns the default TimeZone in an AppContext if any AppContext + * has ever used. null is returned if any AppContext hasn't been + * used or if the AppContext doesn't have the default TimeZone. ++ * ++ * Note that javaAWTAccess may be null if sun.awt.AppContext class hasn't ++ * been loaded. If so, it implies that AWTSecurityManager is not our ++ * SecurityManager and we can use a local static variable. ++ * This works around a build time issue. + */ +- private synchronized static TimeZone getDefaultInAppContext() { +- javaAWTAccess = SharedSecrets.getJavaAWTAccess(); ++ private static TimeZone getDefaultInAppContext() { ++ // JavaAWTAccess provides access implementation-private methods without using reflection. ++ JavaAWTAccess javaAWTAccess = SharedSecrets.getJavaAWTAccess(); + if (javaAWTAccess == null) { + return mainAppContextDefault; + } else { +@@ -670,9 +676,15 @@ + * tz. null is handled special: do nothing if any AppContext + * hasn't been used, remove the default TimeZone in the + * AppContext otherwise. ++ * ++ * Note that javaAWTAccess may be null if sun.awt.AppContext class hasn't ++ * been loaded. If so, it implies that AWTSecurityManager is not our ++ * SecurityManager and we can use a local static variable. ++ * This works around a build time issue. + */ +- private synchronized static void setDefaultInAppContext(TimeZone tz) { +- javaAWTAccess = SharedSecrets.getJavaAWTAccess(); ++ private static void setDefaultInAppContext(TimeZone tz) { ++ // JavaAWTAccess provides access implementation-private methods without using reflection. ++ JavaAWTAccess javaAWTAccess = SharedSecrets.getJavaAWTAccess(); + if (javaAWTAccess == null) { + mainAppContextDefault = tz; + } else { +@@ -736,18 +748,8 @@ + static final String GMT_ID = "GMT"; + private static final int GMT_ID_LENGTH = 3; + +- /* +- * Provides access implementation-private methods without using reflection +- * +- * Note that javaAWTAccess may be null if sun.awt.AppContext class hasn't +- * been loaded. If so, it implies that AWTSecurityManager is not our +- * SecurityManager and we can use a local static variable. +- * This works around a build time issue. +- */ +- private static JavaAWTAccess javaAWTAccess; +- + // a static TimeZone we can reference if no AppContext is in place +- private static TimeZone mainAppContextDefault; ++ private static volatile TimeZone mainAppContextDefault; + + + /** diff --git a/java/openjdk6/files/icedtea/openjdk/8000450-restrict_access.patch b/java/openjdk6/files/icedtea/openjdk/8000450-restrict_access.patch new file mode 100644 index 000000000000..41073719f276 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8000450-restrict_access.patch @@ -0,0 +1,108 @@ +# HG changeset patch +# User coffeys +# Date 1382735937 -3600 +# Fri Oct 25 22:18:57 2013 +0100 +# Node ID f7a7c7d70e4968eb99e42f812c59900f545d7fa7 +# Parent 695dd7ceb9e34fd4058374de63964c205f061002 +8000450: Restrict access to com/sun/corba/se/impl package +Reviewed-by: alanb, chegar, lancea + +diff -r 695dd7ceb9e3 -r f7a7c7d70e49 src/share/lib/security/java.security +--- jdk/src/share/lib/security/java.security Fri Oct 25 22:17:00 2013 +0100 ++++ jdk/src/share/lib/security/java.security Fri Oct 25 22:18:57 2013 +0100 +@@ -128,6 +128,7 @@ + # corresponding RuntimePermission ("accessClassInPackage."+package) has + # been granted. + package.access=sun.,\ ++ com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +@@ -164,6 +165,7 @@ + # checkPackageDefinition. + # + package.definition=sun.,\ ++ com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +diff -r 695dd7ceb9e3 -r f7a7c7d70e49 src/share/lib/security/java.security-solaris +--- jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:17:00 2013 +0100 ++++ jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:18:57 2013 +0100 +@@ -129,6 +129,7 @@ + # corresponding RuntimePermission ("accessClassInPackage."+package) has + # been granted. + package.access=sun.,\ ++ com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +@@ -166,6 +167,7 @@ + # checkPackageDefinition. + # + package.definition=sun.,\ ++ com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +diff -r 695dd7ceb9e3 -r f7a7c7d70e49 src/share/lib/security/java.security-windows +--- jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:17:00 2013 +0100 ++++ jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:18:57 2013 +0100 +@@ -129,6 +129,7 @@ + # corresponding RuntimePermission ("accessClassInPackage."+package) has + # been granted. + package.access=sun.,\ ++ com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +@@ -167,6 +168,7 @@ + # checkPackageDefinition. + # + package.definition=sun.,\ ++ com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +diff -r 695dd7ceb9e3 -r f7a7c7d70e49 test/java/lang/SecurityManager/CheckPackageAccess.java +--- jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Oct 25 22:17:00 2013 +0100 ++++ jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Oct 25 22:18:57 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -23,8 +23,8 @@ + + /* + * @test +- * @bug 7146431 +- * @summary Test that internal JAXP packages cannot be accessed ++ * @bug 7146431 8000450 ++ * @summary Test that internal packages cannot be accessed + */ + + public class CheckPackageAccess { +@@ -32,6 +32,7 @@ + public static void main(String[] args) throws Exception { + + String[] pkgs = new String[] { ++ "com.sun.corba.se.impl.", + "com.sun.org.apache.xerces.internal.utils.", + "com.sun.org.apache.xalan.internal.utils." }; + SecurityManager sm = new SecurityManager(); +@@ -40,7 +41,11 @@ + System.out.println("Checking package access for " + pkg); + try { + sm.checkPackageAccess(pkg); +- throw new Exception("Expected SecurityException not thrown"); ++ throw new Exception("Expected PackageAccess SecurityException not thrown"); ++ } catch (SecurityException se) { } ++ try { ++ sm.checkPackageDefinition(pkg); ++ throw new Exception("Expected PackageDefinition SecurityException not thrown"); + } catch (SecurityException se) { } + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8002070-remove_logger_stack_search.patch b/java/openjdk6/files/icedtea/openjdk/8002070-remove_logger_stack_search.patch new file mode 100644 index 000000000000..889b00a1da59 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8002070-remove_logger_stack_search.patch @@ -0,0 +1,658 @@ +# HG changeset patch +# User jgish +# Date 1381898393 -3600 +# Wed Oct 16 05:39:53 2013 +0100 +# Node ID e56220b54fe2d0f09ee151b28d6e8495cea2136f +# Parent 1ed7c9cea8c508e60d6df30c046ab48b1f1d3ab9 +8002070: Remove the stack search for a resource bundle for Logger to use +Summary: The fragile, vulnerable, stack crawling has been eliminated from findResourceBundle(String) +Reviewed-by: mchung + +diff -r 1ed7c9cea8c5 -r e56220b54fe2 src/share/classes/java/util/logging/Logger.java +--- jdk/src/share/classes/java/util/logging/Logger.java Wed Oct 16 05:10:54 2013 +0100 ++++ jdk/src/share/classes/java/util/logging/Logger.java Wed Oct 16 05:39:53 2013 +0100 +@@ -26,9 +26,17 @@ + + package java.util.logging; + +-import java.util.*; +-import java.security.*; + import java.lang.ref.WeakReference; ++import java.security.AccessController; ++import java.security.PrivilegedAction; ++import java.util.ArrayList; ++import java.util.Iterator; ++import java.util.Locale; ++import java.util.MissingResourceException; ++import java.util.ResourceBundle; ++import java.util.concurrent.CopyOnWriteArrayList; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * A Logger object is used to log messages for a specific +@@ -97,14 +105,8 @@ + * <p> + * When mapping ResourceBundle names to ResourceBundles, the Logger + * will first try to use the Thread's ContextClassLoader. If that +- * is null it will try the SystemClassLoader instead. As a temporary +- * transition feature in the initial implementation, if the Logger is +- * unable to locate a ResourceBundle from the ContextClassLoader or +- * SystemClassLoader the Logger will also search up the class stack +- * and use successive calling ClassLoaders to try to locate a ResourceBundle. +- * (This call stack search is to allow containers to transition to +- * using ContextClassLoaders and is likely to be removed in future +- * versions.) ++ * is null it will try the ++ * {@linkplain java.lang.ClassLoader#getSystemClassLoader() system ClassLoader} instead. + * <p> + * Formatting (including localization) is the responsibility of + * the output Handler, which will typically call a Formatter. +@@ -1297,12 +1299,6 @@ + return useParentHandlers; + } + +- // Private utility method to map a resource bundle name to an +- // actual resource bundle, using a simple one-entry cache. +- // Returns null for a null name. +- // May also return null if we can't find the resource bundle and +- // there is no suitable previous cached value. +- + static final String SYSTEM_LOGGER_RB_NAME = "sun.util.logging.resources.logging"; + + private static ResourceBundle findSystemResourceBundle(final Locale locale) { +@@ -1320,6 +1316,16 @@ + }); + } + ++ /** ++ * Private utility method to map a resource bundle name to an ++ * actual resource bundle, using a simple one-entry cache. ++ * Returns null for a null name. ++ * May also return null if we can't find the resource bundle and ++ * there is no suitable previous cached value. ++ * ++ * @param name the ResourceBundle to locate ++ * @return ResourceBundle specified by name or null if not found ++ */ + private synchronized ResourceBundle findResourceBundle(String name) { + // Return a null bundle for a null name. + if (name == null) { +@@ -1329,8 +1335,8 @@ + Locale currentLocale = Locale.getDefault(); + + // Normally we should hit on our simple one entry cache. +- if (catalog != null && currentLocale == catalogLocale +- && name == catalogName) { ++ if (catalog != null && currentLocale.equals(catalogLocale) ++ && name.equals(catalogName)) { + return catalog; + } + +@@ -1341,8 +1347,8 @@ + return catalog; + } + +- // Use the thread's context ClassLoader. If there isn't one, +- // use the SystemClassloader. ++ // Use the thread's context ClassLoader. If there isn't one, use the ++ // {@linkplain java.lang.ClassLoader#getSystemClassLoader() system ClassLoader}. + ClassLoader cl = Thread.currentThread().getContextClassLoader(); + if (cl == null) { + cl = ClassLoader.getSystemClassLoader(); +@@ -1353,45 +1359,8 @@ + catalogLocale = currentLocale; + return catalog; + } catch (MissingResourceException ex) { +- // Woops. We can't find the ResourceBundle in the default +- // ClassLoader. Drop through. ++ return null; + } +- +- +- // Fall back to searching up the call stack and trying each +- // calling ClassLoader. +- for (int ix = 0; ; ix++) { +- Class clz = sun.reflect.Reflection.getCallerClass(ix); +- if (clz == null) { +- break; +- } +- ClassLoader cl2 = clz.getClassLoader(); +- if (cl2 == null) { +- cl2 = ClassLoader.getSystemClassLoader(); +- } +- if (cl == cl2) { +- // We've already checked this classloader. +- continue; +- } +- cl = cl2; +- try { +- catalog = ResourceBundle.getBundle(name, currentLocale, cl); +- catalogName = name; +- catalogLocale = currentLocale; +- return catalog; +- } catch (MissingResourceException ex) { +- // Ok, this one didn't work either. +- // Drop through, and try the next one. +- } +- } +- +- if (name.equals(catalogName)) { +- // Return the previous cached value for that name. +- // This may be null. +- return catalog; +- } +- // Sorry, we're out of luck. +- return null; + } + + // Private utility method to initialize our one entry +@@ -1403,8 +1372,7 @@ + if (name == null) { + return; + } +- ResourceBundle rb = findResourceBundle(name); +- if (rb == null) { ++ if (findResourceBundle(name) == null) { + // We've failed to find an expected ResourceBundle. + throw new MissingResourceException("Can't find " + name + " bundle", name, ""); + } +diff -r 1ed7c9cea8c5 -r e56220b54fe2 test/java/util/logging/bundlesearch/ClassPathTestBundle_en.properties +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/ClassPathTestBundle_en.properties Wed Oct 16 05:39:53 2013 +0100 +@@ -0,0 +1,25 @@ ++# ++# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++# ++# This code is free software; you can redistribute it and/or modify it ++# under the terms of the GNU General Public License version 2 only, as ++# published by the Free Software Foundation. ++# ++# This code is distributed in the hope that it will be useful, but WITHOUT ++# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++# version 2 for more details (a copy is included in the LICENSE file that ++# accompanied this code). ++# ++# You should have received a copy of the GNU General Public License version ++# 2 along with this work; if not, write to the Free Software Foundation, ++# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++# ++# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++# or visit www.oracle.com if you need additional information or have any ++# questions. ++# ++sample1=translation #2 for sample1 ++sample2=translation #2 for sample2 ++supports-test=ResourceBundleSearchTest +diff -r 1ed7c9cea8c5 -r e56220b54fe2 test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java Wed Oct 16 05:39:53 2013 +0100 +@@ -0,0 +1,89 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.net.URL; ++import java.net.URLClassLoader; ++ ++/** ++ * This class is used to ensure that a resource bundle loadable by a classloader ++ * is on the caller's stack, but not on the classpath or TCCL to ensure that ++ * Logger.getLogger() can't load the bundle via a stack search ++ * ++ * @author Jim Gish ++ */ ++public class IndirectlyLoadABundle { ++ ++ private final static String rbName = "StackSearchableResource"; ++ ++ public boolean loadAndTest() throws Throwable { ++ // Find out where we are running from so we can setup the URLClassLoader URLs ++ // test.src and test.classes will be set if running in jtreg, but probably ++ // not otherwise ++ String testDir = System.getProperty("test.src", System.getProperty("user.dir")); ++ String testClassesDir = System.getProperty("test.classes", ++ System.getProperty("user.dir")); ++ String sep = System.getProperty("file.separator"); ++ URL[] urls = new URL[2]; ++ ++ // Allow for both jtreg and standalone cases here ++ urls[0] = new URL("file://" + testDir + sep + "resources" + sep); ++ urls[1] = new URL("file://" + testClassesDir + sep ); ++ System.out.println("INFO: urls[0] = " + urls[0]); ++ System.out.println("INFO: urls[1] = " + urls[1]); ++ ++ // Make sure we can find it via the URLClassLoader ++ URLClassLoader yetAnotherResourceCL = new URLClassLoader(urls, null); ++ if (!testForValidResourceSetup(yetAnotherResourceCL)) { ++ throw new Exception("Couldn't directly load bundle " + rbName ++ + " as expected. Test config problem"); ++ } ++ // But it shouldn't be available via the system classloader ++ ClassLoader myCL = this.getClass().getClassLoader(); ++ if (testForValidResourceSetup(myCL)) { ++ throw new Exception("Was able to directly load bundle " + rbName ++ + " from " + myCL + " but shouldn't have been" ++ + " able to. Test config problem"); ++ } ++ ++ Class<?> loadItUpClazz = Class.forName("LoadItUp", true, yetAnotherResourceCL); ++ ClassLoader actual = loadItUpClazz.getClassLoader(); ++ if (actual != yetAnotherResourceCL) { ++ throw new Exception("LoadItUp was loaded by an unexpected CL: " + actual); ++ } ++ Object loadItUp = loadItUpClazz.newInstance(); ++ Method testMethod = loadItUpClazz.getMethod("test", String.class); ++ try { ++ return (Boolean) testMethod.invoke(loadItUp, rbName); ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ } ++ ++ private boolean testForValidResourceSetup(ClassLoader cl) { ++ // First make sure the test environment is setup properly and the bundle actually ++ // exists ++ return ResourceBundleSearchTest.isOnClassPath(rbName, cl); ++ } ++} +diff -r 1ed7c9cea8c5 -r e56220b54fe2 test/java/util/logging/bundlesearch/LoadItUp.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/LoadItUp.java Wed Oct 16 05:39:53 2013 +0100 +@@ -0,0 +1,62 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++import java.util.MissingResourceException; ++import java.util.logging.Logger; ++ ++/* ++ * This class is loaded onto the call stack when the test method is called ++ * and then its classloader can be used to find a property bundle in the same ++ * directory as the class. However, Logger is not allowed ++ * to find the bundle by looking up the stack for this classloader. ++ * We verify that this cannot happen. ++ * ++ * @author Jim Gish ++ */ ++public class LoadItUp { ++ ++ private final static boolean DEBUG = false; ++ ++ public Boolean test(String rbName) throws Exception { ++ // we should not be able to find the resource in this directory via ++ // getLogger calls. The only way that would be possible given this setup ++ // is that if Logger.getLogger searched up the call stack ++ return lookupBundle(rbName); ++ } ++ ++ private boolean lookupBundle(String rbName) { ++ // See if Logger.getLogger can find the resource in this directory ++ try { ++ Logger aLogger = Logger.getLogger("NestedLogger", rbName); ++ } catch (MissingResourceException re) { ++ if (DEBUG) { ++ System.out.println( ++ "As expected, LoadItUp.lookupBundle() did not find the bundle " ++ + rbName); ++ } ++ return false; ++ } ++ System.out.println("FAILED: LoadItUp.lookupBundle() found the bundle " ++ + rbName + " using a stack search."); ++ return true; ++ } ++} +diff -r 1ed7c9cea8c5 -r e56220b54fe2 test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Wed Oct 16 05:39:53 2013 +0100 +@@ -0,0 +1,249 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/* ++ * @test ++ * @bug 8010127 ++ * @summary Remove the stack search for a resource bundle Logger to use ++ * @author Jim Gish ++ * @build ResourceBundleSearchTest IndirectlyLoadABundle LoadItUp ++ * @run main ResourceBundleSearchTest ++ */ ++import java.net.URL; ++import java.net.URLClassLoader; ++import java.util.ArrayList; ++import java.util.List; ++import java.util.Locale; ++import java.util.MissingResourceException; ++import java.util.ResourceBundle; ++import java.util.logging.Logger; ++ ++public class ResourceBundleSearchTest { ++ ++ private final static boolean DEBUG = false; ++ private final static String LOGGER_PREFIX = "myLogger."; ++ private static int loggerNum = 0; ++ private final static String PROP_RB_NAME = "ClassPathTestBundle"; ++ private final static String TCCL_TEST_BUNDLE = "ContextClassLoaderTestBundle"; ++ ++ private static int numPass = 0; ++ private static int numFail = 0; ++ private static List<String> msgs = new ArrayList<String>(); ++ ++ public static void main(String[] args) throws Throwable { ++ ResourceBundleSearchTest test = new ResourceBundleSearchTest(); ++ test.runTests(); ++ } ++ ++ private void runTests() throws Throwable { ++ // ensure we are using en as the default Locale so we can find the resource ++ Locale.setDefault(Locale.ENGLISH); ++ ++ String testClasses = System.getProperty("test.classes"); ++ System.out.println( "test.classes = " + testClasses ); ++ ++ ClassLoader myClassLoader = ClassLoader.getSystemClassLoader(); ++ ++ // Find out where we are running from so we can setup the URLClassLoader URL ++ String userDir = System.getProperty("user.dir"); ++ String testDir = System.getProperty("test.src", userDir); ++ String sep = System.getProperty("file.separator"); ++ ++ URL[] urls = new URL[1]; ++ urls[0] = new URL("file://" + testDir + sep + "resources" + sep); ++ URLClassLoader rbClassLoader = new URLClassLoader(urls); ++ ++ // Test 1 - can we find a Logger bundle from doing a stack search? ++ // We shouldn't be able to ++ assertFalse(testGetBundleFromStackSearch(), "testGetBundleFromStackSearch"); ++ ++ // Test 2 - can we find a Logger bundle off of the Thread context class ++ // loader? We should be able to. ++ assertTrue( ++ testGetBundleFromTCCL(TCCL_TEST_BUNDLE, rbClassLoader), ++ "testGetBundleFromTCCL"); ++ ++ // Test 3 - Can we find a Logger bundle from the classpath? We should be ++ // able to, but .... ++ // We check to see if the bundle is on the classpath or not so that this ++ // will work standalone. In the case of jtreg/samevm, ++ // the resource bundles are not on the classpath. Running standalone ++ // (or othervm), they are ++ if (isOnClassPath(PROP_RB_NAME, myClassLoader)) { ++ debug("We should be able to see " + PROP_RB_NAME + " on the classpath"); ++ assertTrue(testGetBundleFromSystemClassLoader(PROP_RB_NAME), ++ "testGetBundleFromSystemClassLoader"); ++ } else { ++ debug("We should not be able to see " + PROP_RB_NAME + " on the classpath"); ++ assertFalse(testGetBundleFromSystemClassLoader(PROP_RB_NAME), ++ "testGetBundleFromSystemClassLoader"); ++ } ++ ++ report(); ++ } ++ ++ private void report() throws Exception { ++ System.out.println("Num passed = " + numPass + " Num failed = " + numFail); ++ if (numFail > 0) { ++ // We only care about the messages if they were errors ++ for (String msg : msgs) { ++ System.out.println(msg); ++ } ++ throw new Exception(numFail + " out of " + (numPass + numFail) ++ + " tests failed."); ++ } ++ } ++ ++ public void assertTrue(boolean testResult, String testName) { ++ if (testResult) { ++ numPass++; ++ } else { ++ numFail++; ++ System.out.println("FAILED: " + testName ++ + " was supposed to return true but did NOT!"); ++ } ++ } ++ ++ public void assertFalse(boolean testResult, String testName) { ++ if (!testResult) { ++ numPass++; ++ } else { ++ numFail++; ++ System.out.println("FAILED: " + testName ++ + " was supposed to return false but did NOT!"); ++ } ++ } ++ ++ public boolean testGetBundleFromStackSearch() throws Throwable { ++ // This should fail. This was the old functionality to search up the ++ // caller's call stack ++ IndirectlyLoadABundle indirectLoader = new IndirectlyLoadABundle(); ++ return indirectLoader.loadAndTest(); ++ } ++ ++ public boolean testGetBundleFromTCCL(String bundleName, ++ ClassLoader setOnTCCL) throws InterruptedException { ++ // This should succeed. We should be able to get the bundle from the ++ // thread context class loader ++ debug("Looking for " + bundleName + " using TCCL"); ++ LoggingThread lr = new LoggingThread(bundleName, setOnTCCL); ++ lr.start(); ++ synchronized (lr) { ++ try { ++ lr.wait(); ++ } catch (InterruptedException ex) { ++ throw ex; ++ } ++ } ++ msgs.add(lr.msg); ++ return lr.foundBundle; ++ } ++ ++ /* ++ * @param String bundleClass ++ * @param ClassLoader to use for search ++ * @return true iff bundleClass is on system classpath ++ */ ++ public static boolean isOnClassPath(String baseName, ClassLoader cl) { ++ ResourceBundle rb = null; ++ try { ++ rb = ResourceBundle.getBundle(baseName, Locale.getDefault(), cl); ++ System.out.println("INFO: Found bundle " + baseName + " on " + cl); ++ } catch (MissingResourceException e) { ++ System.out.println("INFO: Could not find bundle " + baseName + " on " + cl); ++ return false; ++ } ++ return (rb != null); ++ } ++ ++ private static String newLoggerName() { ++ // we need a new logger name every time we attempt to find a bundle via ++ // the Logger.getLogger call, so we'll simply tack on an integer which ++ // we increment each time this is called ++ loggerNum++; ++ return LOGGER_PREFIX + loggerNum; ++ } ++ ++ public boolean testGetBundleFromSystemClassLoader(String bundleName) { ++ // this should succeed if the bundle is on the system classpath. ++ try { ++ Logger aLogger = Logger.getLogger(ResourceBundleSearchTest.newLoggerName(), ++ bundleName); ++ } catch (MissingResourceException re) { ++ msgs.add("INFO: testGetBundleFromSystemClassLoader() did not find bundle " ++ + bundleName); ++ return false; ++ } ++ msgs.add("INFO: testGetBundleFromSystemClassLoader() found the bundle " ++ + bundleName); ++ return true; ++ } ++ ++ public static class LoggingThread extends Thread { ++ ++ boolean foundBundle = false; ++ String msg = null; ++ ClassLoader clToSetOnTCCL = null; ++ String bundleName = null; ++ ++ public LoggingThread(String bundleName) { ++ this.bundleName = bundleName; ++ } ++ ++ public LoggingThread(String bundleName, ClassLoader setOnTCCL) { ++ this.clToSetOnTCCL = setOnTCCL; ++ this.bundleName = bundleName; ++ } ++ ++ public void run() { ++ boolean setTCCL = false; ++ try { ++ if (clToSetOnTCCL != null) { ++ Thread.currentThread().setContextClassLoader(clToSetOnTCCL); ++ setTCCL = true; ++ } ++ // this should succeed if the bundle is on the system classpath. ++ try { ++ Logger aLogger = Logger.getLogger(ResourceBundleSearchTest.newLoggerName(), ++ bundleName); ++ msg = "INFO: LoggingRunnable() found the bundle " + bundleName ++ + (setTCCL ? " with " : " without ") + "setting the TCCL"; ++ foundBundle = true; ++ } catch (MissingResourceException re) { ++ msg = "INFO: LoggingRunnable() did not find the bundle " + bundleName ++ + (setTCCL ? " with " : " without ") + "setting the TCCL"; ++ foundBundle = false; ++ } ++ } catch (Throwable e) { ++ e.printStackTrace(); ++ System.exit(1); ++ } ++ } ++ } ++ ++ private void debug(String msg) { ++ if (DEBUG) { ++ System.out.println(msg); ++ } ++ } ++} +diff -r 1ed7c9cea8c5 -r e56220b54fe2 test/java/util/logging/bundlesearch/resources/ContextClassLoaderTestBundle_en.properties +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/resources/ContextClassLoaderTestBundle_en.properties Wed Oct 16 05:39:53 2013 +0100 +@@ -0,0 +1,25 @@ ++# ++# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++# ++# This code is free software; you can redistribute it and/or modify it ++# under the terms of the GNU General Public License version 2 only, as ++# published by the Free Software Foundation. ++# ++# This code is distributed in the hope that it will be useful, but WITHOUT ++# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++# version 2 for more details (a copy is included in the LICENSE file that ++# accompanied this code). ++# ++# You should have received a copy of the GNU General Public License version ++# 2 along with this work; if not, write to the Free Software Foundation, ++# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++# ++# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++# or visit www.oracle.com if you need additional information or have any ++# questions. ++# ++sample1=translation #3 for sample1 ++sample2=translation #3 for sample2 ++supports-test=ResourceBundleSearchTest +diff -r 1ed7c9cea8c5 -r e56220b54fe2 test/java/util/logging/bundlesearch/resources/StackSearchableResource_en.properties +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/resources/StackSearchableResource_en.properties Wed Oct 16 05:39:53 2013 +0100 +@@ -0,0 +1,25 @@ ++# ++# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++# ++# This code is free software; you can redistribute it and/or modify it ++# under the terms of the GNU General Public License version 2 only, as ++# published by the Free Software Foundation. ++# ++# This code is distributed in the hope that it will be useful, but WITHOUT ++# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++# version 2 for more details (a copy is included in the LICENSE file that ++# accompanied this code). ++# ++# You should have received a copy of the GNU General Public License version ++# 2 along with this work; if not, write to the Free Software Foundation, ++# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++# ++# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++# or visit www.oracle.com if you need additional information or have any ++# questions. ++# ++sample1=translation #4 for sample1 ++sample2=translation #4 for sample2 ++supports-test=ResourceBundleSearchTest diff --git a/java/openjdk6/files/icedtea/openjdk/8003992-embedded_nulls.patch b/java/openjdk6/files/icedtea/openjdk/8003992-embedded_nulls.patch new file mode 100644 index 000000000000..88c94927c7dd --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8003992-embedded_nulls.patch @@ -0,0 +1,1026 @@ +# HG changeset patch +# User dxu +# Date 1383015918 0 +# Tue Oct 29 03:05:18 2013 +0000 +# Node ID 8ad2eb12bf42f2564fdf80a7236e4046046a4f4e +# Parent 44a49c18eba21f97222a2cde09f6536a7f365363 +8003992: File and other classes in java.io do not handle embedded nulls properly +Summary: Have every file operation done with File, FileInputStream, FileOutputStream, or RandomAccessFile that involves a file path containing NUL fail. Also reviewed by fweimer@redhat.com +Reviewed-by: alanb, sherman, ahgross, mduigou, dholmes, aph, plevart, martin + +diff -r 44a49c18eba2 -r 8ad2eb12bf42 src/share/classes/java/io/File.java +--- jdk/src/share/classes/java/io/File.java Fri Sep 06 09:38:10 2013 -0700 ++++ jdk/src/share/classes/java/io/File.java Tue Oct 29 03:05:18 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1994, 2012, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1994, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -153,6 +153,32 @@ + private String path; + + /** ++ * Enum type that indicates the status of a file path. ++ */ ++ private static enum PathStatus { INVALID, CHECKED }; ++ ++ /** ++ * The flag indicating whether the file path is invalid. ++ */ ++ private transient PathStatus status = null; ++ ++ /** ++ * Check if the file has an invalid path. Currently, the inspection of ++ * a file path is very limited, and it only covers Nul character check. ++ * Returning true means the path is definitely invalid/garbage. But ++ * returning false does not guarantee that the path is valid. ++ * ++ * @return true if the file path is invalid. ++ */ ++ final boolean isInvalid() { ++ if (status == null) { ++ status = (this.path.indexOf('\u0000') < 0) ? PathStatus.CHECKED ++ : PathStatus.INVALID; ++ } ++ return status == PathStatus.INVALID; ++ } ++ ++ /** + * The length of this abstract pathname's prefix, or zero if it has no + * prefix. + */ +@@ -573,6 +599,9 @@ + * @since JDK1.1 + */ + public String getCanonicalPath() throws IOException { ++ if (isInvalid()) { ++ throw new IOException("Invalid file path"); ++ } + return fs.canonicalize(fs.resolve(this)); + } + +@@ -637,6 +666,9 @@ + */ + @Deprecated + public URL toURL() throws MalformedURLException { ++ if (isInvalid()) { ++ throw new MalformedURLException("Invalid file path"); ++ } + return new URL("file", "", slashify(getAbsolutePath(), isDirectory())); + } + +@@ -705,6 +737,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.checkAccess(this, FileSystem.ACCESS_READ); + } + +@@ -727,6 +762,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.checkAccess(this, FileSystem.ACCESS_WRITE); + } + +@@ -747,6 +785,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return ((fs.getBooleanAttributes(this) & FileSystem.BA_EXISTS) != 0); + } + +@@ -768,6 +809,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return ((fs.getBooleanAttributes(this) & FileSystem.BA_DIRECTORY) + != 0); + } +@@ -792,6 +836,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return ((fs.getBooleanAttributes(this) & FileSystem.BA_REGULAR) != 0); + } + +@@ -818,6 +865,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return ((fs.getBooleanAttributes(this) & FileSystem.BA_HIDDEN) != 0); + } + +@@ -840,6 +890,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return 0L; ++ } + return fs.getLastModifiedTime(this); + } + +@@ -862,6 +915,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return 0L; ++ } + return fs.getLength(this); + } + +@@ -897,6 +953,9 @@ + public boolean createNewFile() throws IOException { + SecurityManager security = System.getSecurityManager(); + if (security != null) security.checkWrite(path); ++ if (isInvalid()) { ++ throw new IOException("Invalid file path"); ++ } + return fs.createFileExclusively(path, false); + } + +@@ -918,6 +977,9 @@ + if (security != null) { + security.checkDelete(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.delete(this); + } + +@@ -953,6 +1015,9 @@ + if (security != null) { + security.checkDelete(path); + } ++ if (isInvalid()) { ++ return; ++ } + DeleteOnExitHook.add(path); + } + +@@ -987,6 +1052,9 @@ + if (security != null) { + security.checkRead(path); + } ++ if (isInvalid()) { ++ return null; ++ } + return fs.list(this); + } + +@@ -1168,6 +1236,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.createDirectory(this); + } + +@@ -1239,6 +1310,12 @@ + security.checkWrite(path); + security.checkWrite(dest.path); + } ++ if (dest == null) { ++ throw new NullPointerException(); ++ } ++ if (this.isInvalid() || dest.isInvalid()) { ++ return false; ++ } + return fs.rename(this, dest); + } + +@@ -1274,6 +1351,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.setLastModifiedTime(this, time); + } + +@@ -1299,6 +1379,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.setReadOnly(this); + } + +@@ -1333,6 +1416,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.setPermission(this, FileSystem.ACCESS_WRITE, writable, ownerOnly); + } + +@@ -1399,6 +1485,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.setPermission(this, FileSystem.ACCESS_READ, readable, ownerOnly); + } + +@@ -1468,6 +1557,9 @@ + if (security != null) { + security.checkWrite(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.setPermission(this, FileSystem.ACCESS_EXECUTE, executable, ownerOnly); + } + +@@ -1522,6 +1614,9 @@ + if (security != null) { + security.checkExec(path); + } ++ if (isInvalid()) { ++ return false; ++ } + return fs.checkAccess(this, FileSystem.ACCESS_EXECUTE); + } + +@@ -1597,6 +1692,9 @@ + sm.checkPermission(new RuntimePermission("getFileSystemAttributes")); + sm.checkRead(path); + } ++ if (isInvalid()) { ++ return 0L; ++ } + return fs.getSpace(this, FileSystem.SPACE_TOTAL); + } + +@@ -1613,7 +1711,7 @@ + * makes no guarantee that write operations to this file system + * will succeed. + * +- * @return The number of unallocated bytes on the partition <tt>0L</tt> ++ * @return The number of unallocated bytes on the partition or <tt>0L</tt> + * if the abstract pathname does not name a partition. This + * value will be less than or equal to the total file system size + * returned by {@link #getTotalSpace}. +@@ -1632,6 +1730,9 @@ + sm.checkPermission(new RuntimePermission("getFileSystemAttributes")); + sm.checkRead(path); + } ++ if (isInvalid()) { ++ return 0L; ++ } + return fs.getSpace(this, FileSystem.SPACE_FREE); + } + +@@ -1670,6 +1771,9 @@ + sm.checkPermission(new RuntimePermission("getFileSystemAttributes")); + sm.checkRead(path); + } ++ if (isInvalid()) { ++ return 0L; ++ } + return fs.getSpace(this, FileSystem.SPACE_USABLE); + } + +@@ -1682,9 +1786,9 @@ + + static final String temporaryDirectory = temporaryDirectory(); + static String temporaryDirectory() { +- return fs.normalize( ++ return + AccessController.doPrivileged( +- new GetPropertyAction("java.io.tmpdir"))); ++ new GetPropertyAction("java.io.tmpdir")); + } + } + +@@ -1735,6 +1839,9 @@ + File f; + do { + f = generateFile(prefix, s, directory); ++ if (f.isInvalid()) { ++ throw new IOException("Unable to create temporary file"); ++ } + } while (!checkAndCreate(f.getPath(), sm, restrictive)); + return f; + } +diff -r 44a49c18eba2 -r 8ad2eb12bf42 src/share/classes/java/io/FileInputStream.java +--- jdk/src/share/classes/java/io/FileInputStream.java Fri Sep 06 09:38:10 2013 -0700 ++++ jdk/src/share/classes/java/io/FileInputStream.java Tue Oct 29 03:05:18 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1994, 2007, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1994, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -132,6 +132,9 @@ + if (name == null) { + throw new NullPointerException(); + } ++ if (file.isInvalid()) { ++ throw new FileNotFoundException("Invalid file path"); ++ } + fd = new FileDescriptor(); + fd.incrementAndGetUseCount(); + open(name); +diff -r 44a49c18eba2 -r 8ad2eb12bf42 src/share/classes/java/io/FileOutputStream.java +--- jdk/src/share/classes/java/io/FileOutputStream.java Fri Sep 06 09:38:10 2013 -0700 ++++ jdk/src/share/classes/java/io/FileOutputStream.java Tue Oct 29 03:05:18 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1994, 2007, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1994, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -200,6 +200,9 @@ + if (name == null) { + throw new NullPointerException(); + } ++ if (file.isInvalid()) { ++ throw new FileNotFoundException("Invalid file path"); ++ } + fd = new FileDescriptor(); + fd.incrementAndGetUseCount(); + this.append = append; +diff -r 44a49c18eba2 -r 8ad2eb12bf42 src/share/classes/java/io/RandomAccessFile.java +--- jdk/src/share/classes/java/io/RandomAccessFile.java Fri Sep 06 09:38:10 2013 -0700 ++++ jdk/src/share/classes/java/io/RandomAccessFile.java Tue Oct 29 03:05:18 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1994, 2007, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1994, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -228,6 +228,9 @@ + if (name == null) { + throw new NullPointerException(); + } ++ if (file.isInvalid()) { ++ throw new FileNotFoundException("Invalid file path"); ++ } + fd = new FileDescriptor(); + fd.incrementAndGetUseCount(); + open(name, imode); +diff -r 44a49c18eba2 -r 8ad2eb12bf42 test/java/io/File/NulFile.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/io/File/NulFile.java Tue Oct 29 03:05:18 2013 +0000 +@@ -0,0 +1,625 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/* @test ++ * @bug 8003992 ++ * @summary Test a file whose path name is embedded with NUL character, and ++ * ensure it is handled correctly. ++ * @author Dan Xu ++ */ ++ ++import java.io.File; ++import java.io.FileFilter; ++import java.io.FileInputStream; ++import java.io.FileOutputStream; ++import java.io.RandomAccessFile; ++import java.io.FileNotFoundException; ++import java.io.FilenameFilter; ++import java.io.IOException; ++import java.net.MalformedURLException; ++import java.nio.file.InvalidPathException; ++import java.io.ByteArrayInputStream; ++import java.io.ByteArrayOutputStream; ++import java.io.ObjectOutputStream; ++import java.io.ObjectInputStream; ++ ++public class NulFile { ++ ++ private static final char CHAR_NUL = '\u0000'; ++ ++ private static final String ExceptionMsg = "Invalid file path"; ++ ++ public static void main(String[] args) { ++ testFile(); ++ testFileInUnix(); ++ testFileInWindows(); ++ testTempFile(); ++ } ++ ++ private static void testFile() { ++ test(new File(new StringBuilder().append(CHAR_NUL).toString())); ++ test(new File( ++ new StringBuilder().append("").append(CHAR_NUL).toString())); ++ test(new File( ++ new StringBuilder().append(CHAR_NUL).append("").toString())); ++ } ++ ++ private static void testFileInUnix() { ++ String osName = System.getProperty("os.name"); ++ if (osName.startsWith("Windows")) ++ return; ++ ++ String unixFile = "/"; ++ test(unixFile); ++ ++ unixFile = "//"; ++ test(unixFile); ++ ++ unixFile = "data/info"; ++ test(unixFile); ++ ++ unixFile = "/data/info"; ++ test(unixFile); ++ ++ unixFile = "//data//info"; ++ test(unixFile); ++ } ++ ++ private static void testFileInWindows() { ++ String osName = System.getProperty("os.name"); ++ if (!osName.startsWith("Windows")) ++ return; ++ ++ String windowsFile = "\\"; ++ test(windowsFile); ++ ++ windowsFile = "\\\\"; ++ test(windowsFile); ++ ++ windowsFile = "/"; ++ test(windowsFile); ++ ++ windowsFile = "//"; ++ test(windowsFile); ++ ++ windowsFile = "/\\"; ++ test(windowsFile); ++ ++ windowsFile = "\\/"; ++ test(windowsFile); ++ ++ windowsFile = "data\\info"; ++ test(windowsFile); ++ ++ windowsFile = "\\data\\info"; ++ test(windowsFile); ++ ++ windowsFile = "\\\\server\\data\\info"; ++ test(windowsFile); ++ ++ windowsFile = "z:data\\info"; ++ test(windowsFile); ++ ++ windowsFile = "z:\\data\\info"; ++ test(windowsFile); ++ } ++ ++ private static void test(final String name) { ++ int length = name.length(); ++ ++ for (int i = 0; i <= length; i++) { ++ StringBuilder sbName = new StringBuilder(name); ++ sbName.insert(i, CHAR_NUL); ++ String curName = sbName.toString(); ++ ++ // test File(String parent, String child) ++ File testFile = new File(curName, "child"); ++ test(testFile); ++ testFile = new File("parent", curName); ++ test(testFile); ++ ++ // test File(String pathname) ++ testFile = new File(curName); ++ test(testFile); ++ ++ // test File(File parent, String child) ++ testFile = new File(new File(curName), "child"); ++ test(testFile); ++ testFile = new File(new File("parent"), curName); ++ test(testFile); ++ ++ // test FileInputStream ++ testFileInputStream(curName); ++ ++ // test FileOutputStream ++ testFileOutputStream(curName); ++ ++ // test RandomAccessFile ++ testRandomAccessFile(curName); ++ } ++ } ++ ++ private static void testFileInputStream(final String str) { ++ boolean exceptionThrown = false; ++ FileInputStream is = null; ++ try { ++ is = new FileInputStream(str); ++ } catch (FileNotFoundException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("FileInputStream constructor" ++ + " should throw FileNotFoundException"); ++ } ++ if (is != null) { ++ throw new RuntimeException("FileInputStream constructor" ++ + " should fail"); ++ } ++ ++ exceptionThrown = false; ++ is = null; ++ try { ++ is = new FileInputStream(new File(str)); ++ } catch (FileNotFoundException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("FileInputStream constructor" ++ + " should throw FileNotFoundException"); ++ } ++ if (is != null) { ++ throw new RuntimeException("FileInputStream constructor" ++ + " should fail"); ++ } ++ } ++ ++ private static void testFileOutputStream(final String str) { ++ boolean exceptionThrown = false; ++ FileOutputStream os = null; ++ try { ++ os = new FileOutputStream(str); ++ } catch (FileNotFoundException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("FileOutputStream constructor" ++ + " should throw FileNotFoundException"); ++ } ++ if (os != null) { ++ throw new RuntimeException("FileOutputStream constructor" ++ + " should fail"); ++ } ++ ++ exceptionThrown = false; ++ os = null; ++ try { ++ os = new FileOutputStream(new File(str)); ++ } catch (FileNotFoundException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("FileOutputStream constructor" ++ + " should throw FileNotFoundException"); ++ } ++ if (os != null) { ++ throw new RuntimeException("FileOutputStream constructor" ++ + " should fail"); ++ } ++ } ++ ++ private static void testRandomAccessFile(final String str) { ++ boolean exceptionThrown = false; ++ RandomAccessFile raf = null; ++ String[] modes = {"r", "rw", "rws", "rwd"}; ++ ++ for (String mode : modes) { ++ try { ++ raf = new RandomAccessFile(str, mode); ++ } catch (FileNotFoundException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("RandomAccessFile constructor" ++ + " should throw FileNotFoundException"); ++ } ++ if (raf != null) { ++ throw new RuntimeException("RandomAccessFile constructor" ++ + " should fail"); ++ } ++ ++ exceptionThrown = false; ++ raf = null; ++ try { ++ raf = new RandomAccessFile(new File(str), mode); ++ } catch (FileNotFoundException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("RandomAccessFile constructor" ++ + " should throw FileNotFoundException"); ++ } ++ if (raf != null) { ++ throw new RuntimeException("RandomAccessFile constructor" ++ + " should fail"); ++ } ++ } ++ } ++ ++ private static void test(File testFile) { ++ test(testFile, false); ++ // test serialization ++ testSerialization(testFile); ++ } ++ ++ @SuppressWarnings("deprecation") ++ private static void test(File testFile, boolean derived) { ++ boolean exceptionThrown = false; ++ ++ if (testFile == null) { ++ throw new RuntimeException("test file should not be null."); ++ } ++ ++ // getPath() ++ if (testFile.getPath().indexOf(CHAR_NUL) < 0) { ++ throw new RuntimeException( ++ "File path should contain Nul character"); ++ } ++ // getAbsolutePath() ++ if (testFile.getAbsolutePath().indexOf(CHAR_NUL) < 0) { ++ throw new RuntimeException( ++ "File absolute path should contain Nul character"); ++ } ++ // getAbsoluteFile() ++ File derivedAbsFile = testFile.getAbsoluteFile(); ++ if (derived) { ++ if (derivedAbsFile.getPath().indexOf(CHAR_NUL) < 0) { ++ throw new RuntimeException( ++ "Derived file path should also contain Nul character"); ++ } ++ } else { ++ test(derivedAbsFile, true); ++ } ++ // getCanonicalPath() ++ try { ++ exceptionThrown = false; ++ testFile.getCanonicalPath(); ++ } catch (IOException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException( ++ "getCanonicalPath() should throw IOException with" ++ + " message \"" + ExceptionMsg + "\""); ++ } ++ // getCanonicalFile() ++ try { ++ exceptionThrown = false; ++ testFile.getCanonicalFile(); ++ } catch (IOException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException( ++ "getCanonicalFile() should throw IOException with" ++ + " message \"" + ExceptionMsg + "\""); ++ } ++ // toURL() ++ try { ++ exceptionThrown = false; ++ testFile.toURL(); ++ } catch (MalformedURLException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("toURL() should throw IOException with" ++ + " message \"" + ExceptionMsg + "\""); ++ } ++ // canRead() ++ if (testFile.canRead()) ++ throw new RuntimeException("File should not be readable"); ++ // canWrite() ++ if (testFile.canWrite()) ++ throw new RuntimeException("File should not be writable"); ++ // exists() ++ if (testFile.exists()) ++ throw new RuntimeException("File should not be existed"); ++ // isDirectory() ++ if (testFile.isDirectory()) ++ throw new RuntimeException("File should not be a directory"); ++ // isFile() ++ if (testFile.isFile()) ++ throw new RuntimeException("File should not be a file"); ++ // isHidden() ++ if (testFile.isHidden()) ++ throw new RuntimeException("File should not be hidden"); ++ // lastModified() ++ if (testFile.lastModified() != 0L) ++ throw new RuntimeException("File last modified time should be 0L"); ++ // length() ++ if (testFile.length() != 0L) ++ throw new RuntimeException("File length should be 0L"); ++ // createNewFile() ++ try { ++ exceptionThrown = false; ++ testFile.createNewFile(); ++ } catch (IOException ex) { ++ if (ExceptionMsg.equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException( ++ "createNewFile() should throw IOException with" ++ + " message \"" + ExceptionMsg + "\""); ++ } ++ // delete() ++ if (testFile.delete()) ++ throw new RuntimeException("Delete operation should fail"); ++ // list() ++ if (testFile.list() != null) ++ throw new RuntimeException("File list() should return null"); ++ // list(FilenameFilter) ++ FilenameFilter fnFilter = new FilenameFilter() { ++ @Override ++ public boolean accept(File dir, String name) { ++ return false; ++ } ++ }; ++ if (testFile.list(fnFilter) != null) { ++ throw new RuntimeException("File list(FilenameFilter) should" ++ + " return null"); ++ } ++ // listFiles() ++ if (testFile.listFiles() != null) ++ throw new RuntimeException("File listFiles() should return null"); ++ // listFiles(FilenameFilter) ++ if (testFile.listFiles(fnFilter) != null) { ++ throw new RuntimeException("File listFiles(FilenameFilter)" ++ + " should return null"); ++ } ++ // listFiles(FileFilter) ++ FileFilter fFilter = new FileFilter() { ++ @Override ++ public boolean accept(File file) { ++ return false; ++ } ++ }; ++ if (testFile.listFiles(fFilter) != null) { ++ throw new RuntimeException("File listFiles(FileFilter)" ++ + " should return null"); ++ } ++ // mkdir() ++ if (testFile.mkdir()) { ++ throw new RuntimeException("File should not be able to" ++ + " create directory"); ++ } ++ // mkdirs() ++ if (testFile.mkdirs()) { ++ throw new RuntimeException("File should not be able to" ++ + " create directories"); ++ } ++ // renameTo(File) ++ if (testFile.renameTo(new File("dest"))) ++ throw new RuntimeException("File rename should fail"); ++ if (new File("dest").renameTo(testFile)) ++ throw new RuntimeException("File rename should fail"); ++ try { ++ exceptionThrown = false; ++ testFile.renameTo(null); ++ } catch (NullPointerException ex) { ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("File rename should thrown NPE"); ++ } ++ // setLastModified(long) ++ if (testFile.setLastModified(0L)) { ++ throw new RuntimeException("File should fail to set" ++ + " last modified time"); ++ } ++ try { ++ exceptionThrown = false; ++ testFile.setLastModified(-1); ++ } catch (IllegalArgumentException ex) { ++ if ("Negative time".equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("File should fail to set" ++ + " last modified time with message \"Negative time\""); ++ } ++ // setReadOnly() ++ if (testFile.setReadOnly()) ++ throw new RuntimeException("File should fail to set read-only"); ++ // setWritable(boolean writable, boolean ownerOnly) ++ if (testFile.setWritable(true, true)) ++ throw new RuntimeException("File should fail to set writable"); ++ if (testFile.setWritable(true, false)) ++ throw new RuntimeException("File should fail to set writable"); ++ if (testFile.setWritable(false, true)) ++ throw new RuntimeException("File should fail to set writable"); ++ if (testFile.setWritable(false, false)) ++ throw new RuntimeException("File should fail to set writable"); ++ // setWritable(boolean writable) ++ if (testFile.setWritable(false)) ++ throw new RuntimeException("File should fail to set writable"); ++ if (testFile.setWritable(true)) ++ throw new RuntimeException("File should fail to set writable"); ++ // setReadable(boolean readable, boolean ownerOnly) ++ if (testFile.setReadable(true, true)) ++ throw new RuntimeException("File should fail to set readable"); ++ if (testFile.setReadable(true, false)) ++ throw new RuntimeException("File should fail to set readable"); ++ if (testFile.setReadable(false, true)) ++ throw new RuntimeException("File should fail to set readable"); ++ if (testFile.setReadable(false, false)) ++ throw new RuntimeException("File should fail to set readable"); ++ // setReadable(boolean readable) ++ if (testFile.setReadable(false)) ++ throw new RuntimeException("File should fail to set readable"); ++ if (testFile.setReadable(true)) ++ throw new RuntimeException("File should fail to set readable"); ++ // setExecutable(boolean executable, boolean ownerOnly) ++ if (testFile.setExecutable(true, true)) ++ throw new RuntimeException("File should fail to set executable"); ++ if (testFile.setExecutable(true, false)) ++ throw new RuntimeException("File should fail to set executable"); ++ if (testFile.setExecutable(false, true)) ++ throw new RuntimeException("File should fail to set executable"); ++ if (testFile.setExecutable(false, false)) ++ throw new RuntimeException("File should fail to set executable"); ++ // setExecutable(boolean executable) ++ if (testFile.setExecutable(false)) ++ throw new RuntimeException("File should fail to set executable"); ++ if (testFile.setExecutable(true)) ++ throw new RuntimeException("File should fail to set executable"); ++ // canExecute() ++ if (testFile.canExecute()) ++ throw new RuntimeException("File should not be executable"); ++ // getTotalSpace() ++ if (testFile.getTotalSpace() != 0L) ++ throw new RuntimeException("The total space should be 0L"); ++ // getFreeSpace() ++ if (testFile.getFreeSpace() != 0L) ++ throw new RuntimeException("The free space should be 0L"); ++ // getUsableSpace() ++ if (testFile.getUsableSpace() != 0L) ++ throw new RuntimeException("The usable space should be 0L"); ++ // compareTo(File null) ++ try { ++ exceptionThrown = false; ++ testFile.compareTo(null); ++ } catch (NullPointerException ex) { ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("compareTo(null) should throw NPE"); ++ } ++ // toString() ++ if (testFile.toString().indexOf(CHAR_NUL) < 0) { ++ throw new RuntimeException( ++ "File path should contain Nul character"); ++ } ++ // toPath() ++ try { ++ exceptionThrown = false; ++ testFile.toPath(); ++ } catch (InvalidPathException ex) { ++ exceptionThrown = true; ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("toPath() should throw" ++ + " InvalidPathException"); ++ } ++ } ++ ++ private static void testSerialization(File testFile) { ++ String path = testFile.getPath(); ++ try { ++ // serialize test file ++ ByteArrayOutputStream baos = new ByteArrayOutputStream(); ++ ObjectOutputStream oos = new ObjectOutputStream(baos); ++ oos.writeObject(testFile); ++ oos.close(); ++ // deserialize test file ++ byte[] bytes = baos.toByteArray(); ++ ByteArrayInputStream is = new ByteArrayInputStream(bytes); ++ ObjectInputStream ois = new ObjectInputStream(is); ++ File newFile = (File) ois.readObject(); ++ // test ++ String newPath = newFile.getPath(); ++ if (!path.equals(newPath)) { ++ throw new RuntimeException( ++ "Serialization should not change file path"); ++ } ++ test(newFile, false); ++ } catch (IOException | ClassNotFoundException ex) { ++ System.err.println("Exception happens in testSerialization"); ++ System.err.println(ex.getMessage()); ++ } ++ } ++ ++ private static void testTempFile() { ++ final String[] names = {"x", "xx", "xxx", "xxxx"}; ++ final String shortPrefix = "sp"; ++ final String prefix = "prefix"; ++ final String suffix = "suffix"; ++ File tmpDir = new File("tmpDir"); ++ ++ for (String name : names) { ++ int length = name.length(); ++ for (int i = 0; i <= length; i++) { ++ StringBuilder sbName = new StringBuilder(name); ++ sbName.insert(i, CHAR_NUL); ++ String curName = sbName.toString(); ++ ++ // test prefix ++ testCreateTempFile(curName, suffix, tmpDir); ++ // test suffix ++ testCreateTempFile(shortPrefix, curName, tmpDir); ++ testCreateTempFile(prefix, curName, tmpDir); ++ // test directory ++ testCreateTempFile(shortPrefix, suffix, new File(curName)); ++ testCreateTempFile(prefix, suffix, new File(curName)); ++ } ++ } ++ } ++ ++ private static void testCreateTempFile(String prefix, String suffix, ++ File directory) { ++ // createTempFile(String prefix, String suffix, File directory) ++ boolean exceptionThrown = false; ++ boolean shortPrefix = (prefix.length() < 3); ++ if (shortPrefix) { ++ try { ++ File.createTempFile(prefix, suffix, directory); ++ } catch (IllegalArgumentException ex) { ++ if ("Prefix string too short".equals(ex.getMessage())) ++ exceptionThrown = true; ++ } catch (IOException ioe) { ++ System.err.println("IOException happens in testCreateTempFile"); ++ System.err.println(ioe.getMessage()); ++ } ++ } else { ++ try { ++ File.createTempFile(prefix, suffix, directory); ++ } catch (IOException ex) { ++ if ("Unable to create temporary file".equals(ex.getMessage())) ++ exceptionThrown = true; ++ } ++ } ++ if (!exceptionThrown) { ++ throw new RuntimeException("createTempFile() should throw" ++ + (shortPrefix ? " IllegalArgumentException" ++ : " IOException")); ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8004188-rename_java.security.patch b/java/openjdk6/files/icedtea/openjdk/8004188-rename_java.security.patch new file mode 100644 index 000000000000..10209ee5ecd3 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8004188-rename_java.security.patch @@ -0,0 +1,652 @@ +# HG changeset patch +# User juh +# Date 1382736906 -3600 +# Fri Oct 25 22:35:06 2013 +0100 +# Node ID 2a023db33371ce5ee42134cf0d860ab9f0adff92 +# Parent 3b6f55f02122398ba662fb581352c9c9b102c2e3 +8004188: Rename src/share/lib/security/java.security to java.security-linux +Reviewed-by: mullan, mchung + +diff -r 3b6f55f02122 -r 2a023db33371 make/java/security/Makefile +--- jdk/make/java/security/Makefile Fri Jul 12 11:36:15 2013 +0100 ++++ jdk/make/java/security/Makefile Fri Oct 25 22:35:06 2013 +0100 +@@ -37,7 +37,8 @@ + # Directories + # + +-PROPS_SRC = $(TOPDIR)/src/share/lib/security/java.security ++# The default security properties file is for linux ++PROPS_SRC = $(TOPDIR)/src/share/lib/security/java.security-linux + SUNPKCS11 = + + ifeq ($(PLATFORM), solaris) +diff -r 3b6f55f02122 -r 2a023db33371 src/share/lib/security/java.security +--- jdk/src/share/lib/security/java.security Fri Jul 12 11:36:15 2013 +0100 ++++ /dev/null Thu Jan 01 00:00:00 1970 +0000 +@@ -1,311 +0,0 @@ +-# +-# This is the "master security properties file". +-# +-# In this file, various security properties are set for use by +-# java.security classes. This is where users can statically register +-# Cryptography Package Providers ("providers" for short). The term +-# "provider" refers to a package or set of packages that supply a +-# concrete implementation of a subset of the cryptography aspects of +-# the Java Security API. A provider may, for example, implement one or +-# more digital signature algorithms or message digest algorithms. +-# +-# Each provider must implement a subclass of the Provider class. +-# To register a provider in this master security properties file, +-# specify the Provider subclass name and priority in the format +-# +-# security.provider.<n>=<className> +-# +-# This declares a provider, and specifies its preference +-# order n. The preference order is the order in which providers are +-# searched for requested algorithms (when no specific provider is +-# requested). The order is 1-based; 1 is the most preferred, followed +-# by 2, and so on. +-# +-# <className> must specify the subclass of the Provider class whose +-# constructor sets the values of various properties that are required +-# for the Java Security API to look up the algorithms or other +-# facilities implemented by the provider. +-# +-# There must be at least one provider specification in java.security. +-# There is a default provider that comes standard with the JDK. It +-# is called the "SUN" provider, and its Provider subclass +-# named Sun appears in the sun.security.provider package. Thus, the +-# "SUN" provider is registered via the following: +-# +-# security.provider.1=sun.security.provider.Sun +-# +-# (The number 1 is used for the default provider.) +-# +-# Note: Providers can be dynamically registered instead by calls to +-# either the addProvider or insertProviderAt method in the Security +-# class. +- +-# +-# List of providers and their preference orders (see above): +-# +-security.provider.1=sun.security.provider.Sun +-security.provider.2=sun.security.rsa.SunRsaSign +-security.provider.3=com.sun.net.ssl.internal.ssl.Provider +-security.provider.4=com.sun.crypto.provider.SunJCE +-security.provider.5=sun.security.jgss.SunProvider +-security.provider.6=com.sun.security.sasl.Provider +-security.provider.7=org.jcp.xml.dsig.internal.dom.XMLDSigRI +-security.provider.8=sun.security.smartcardio.SunPCSC +- +-# +-# Select the source of seed data for SecureRandom. By default an +-# attempt is made to use the entropy gathering device specified by +-# the securerandom.source property. If an exception occurs when +-# accessing the URL then the traditional system/thread activity +-# algorithm is used. +-# +-# On Solaris and Linux systems, if file:/dev/urandom is specified and it +-# exists, a special SecureRandom implementation is activated by default. +-# This "NativePRNG" reads random bytes directly from /dev/urandom. +-# +-# On Windows systems, the URLs file:/dev/random and file:/dev/urandom +-# enables use of the Microsoft CryptoAPI seed functionality. +-# +-securerandom.source=file:/dev/urandom +-# +-# The entropy gathering device is described as a URL and can also +-# be specified with the system property "java.security.egd". For example, +-# -Djava.security.egd=file:/dev/urandom +-# Specifying this system property will override the securerandom.source +-# setting. +- +-# +-# Class to instantiate as the javax.security.auth.login.Configuration +-# provider. +-# +-login.configuration.provider=com.sun.security.auth.login.ConfigFile +- +-# +-# Default login configuration file +-# +-#login.config.url.1=file:${user.home}/.java.login.config +- +-# +-# Class to instantiate as the system Policy. This is the name of the class +-# that will be used as the Policy object. +-# +-policy.provider=sun.security.provider.PolicyFile +- +-# The default is to have a single system-wide policy file, +-# and a policy file in the user's home directory. +-policy.url.1=file:${java.home}/lib/security/java.policy +-policy.url.2=file:${user.home}/.java.policy +- +-# whether or not we expand properties in the policy file +-# if this is set to false, properties (${...}) will not be expanded in policy +-# files. +-policy.expandProperties=true +- +-# whether or not we allow an extra policy to be passed on the command line +-# with -Djava.security.policy=somefile. Comment out this line to disable +-# this feature. +-policy.allowSystemProperty=true +- +-# whether or not we look into the IdentityScope for trusted Identities +-# when encountering a 1.1 signed JAR file. If the identity is found +-# and is trusted, we grant it AllPermission. +-policy.ignoreIdentityScope=false +- +-# +-# Default keystore type. +-# +-keystore.type=jks +- +-# +-# Class to instantiate as the system scope: +-# +-system.scope=sun.security.provider.IdentityDatabase +- +-# +-# List of comma-separated packages that start with or equal this string +-# will cause a security exception to be thrown when +-# passed to checkPackageAccess unless the +-# corresponding RuntimePermission ("accessClassInPackage."+package) has +-# been granted. +-package.access=sun.,\ +- com.sun.corba.se.impl.,\ +- com.sun.xml.internal.,\ +- com.sun.imageio.,\ +- com.sun.istack.internal.,\ +- com.sun.jmx.,\ +- com.sun.proxy.,\ +- com.sun.org.apache.bcel.internal.,\ +- com.sun.org.apache.regexp.internal.,\ +- com.sun.org.apache.xerces.internal.,\ +- com.sun.org.apache.xpath.internal.,\ +- com.sun.org.apache.xalan.internal.extensions.,\ +- com.sun.org.apache.xalan.internal.lib.,\ +- com.sun.org.apache.xalan.internal.res.,\ +- com.sun.org.apache.xalan.internal.templates.,\ +- com.sun.org.apache.xalan.internal.xslt.,\ +- com.sun.org.apache.xalan.internal.xsltc.cmdline.,\ +- com.sun.org.apache.xalan.internal.xsltc.compiler.,\ +- com.sun.org.apache.xalan.internal.xsltc.trax.,\ +- com.sun.org.apache.xalan.internal.xsltc.util.,\ +- com.sun.org.apache.xml.internal.res.,\ +- com.sun.org.apache.xml.internal.serializer.utils.,\ +- com.sun.org.apache.xml.internal.utils.,\ +- com.sun.org.apache.xml.internal.security.,\ +- com.sun.org.glassfish.,\ +- org.jcp.xml.dsig.internal. +- +-# +-# List of comma-separated packages that start with or equal this string +-# will cause a security exception to be thrown when +-# passed to checkPackageDefinition unless the +-# corresponding RuntimePermission ("defineClassInPackage."+package) has +-# been granted. +-# +-# by default, none of the class loaders supplied with the JDK call +-# checkPackageDefinition. +-# +-package.definition=sun.,\ +- com.sun.corba.se.impl.,\ +- com.sun.xml.internal.,\ +- com.sun.imageio.,\ +- com.sun.istack.internal.,\ +- com.sun.jmx.,\ +- com.sun.proxy.,\ +- com.sun.org.apache.bcel.internal.,\ +- com.sun.org.apache.regexp.internal.,\ +- com.sun.org.apache.xerces.internal.,\ +- com.sun.org.apache.xpath.internal.,\ +- com.sun.org.apache.xalan.internal.extensions.,\ +- com.sun.org.apache.xalan.internal.lib.,\ +- com.sun.org.apache.xalan.internal.res.,\ +- com.sun.org.apache.xalan.internal.templates.,\ +- com.sun.org.apache.xalan.internal.xslt.,\ +- com.sun.org.apache.xalan.internal.xsltc.cmdline.,\ +- com.sun.org.apache.xalan.internal.xsltc.compiler.,\ +- com.sun.org.apache.xalan.internal.xsltc.trax.,\ +- com.sun.org.apache.xalan.internal.xsltc.util.,\ +- com.sun.org.apache.xml.internal.res.,\ +- com.sun.org.apache.xml.internal.serializer.utils.,\ +- com.sun.org.apache.xml.internal.utils.,\ +- com.sun.org.apache.xml.internal.security.,\ +- com.sun.org.glassfish.,\ +- org.jcp.xml.dsig.internal. +- +-# +-# Determines whether this properties file can be appended to +-# or overridden on the command line via -Djava.security.properties +-# +-security.overridePropertiesFile=true +- +-# +-# Determines the default key and trust manager factory algorithms for +-# the javax.net.ssl package. +-# +-ssl.KeyManagerFactory.algorithm=SunX509 +-ssl.TrustManagerFactory.algorithm=PKIX +- +-# +-# The Java-level namelookup cache policy for successful lookups: +-# +-# any negative value: caching forever +-# any positive value: the number of seconds to cache an address for +-# zero: do not cache +-# +-# default value is forever (FOREVER). For security reasons, this +-# caching is made forever when a security manager is set. When a security +-# manager is not set, the default behavior in this implementation +-# is to cache for 30 seconds. +-# +-# NOTE: setting this to anything other than the default value can have +-# serious security implications. Do not set it unless +-# you are sure you are not exposed to DNS spoofing attack. +-# +-#networkaddress.cache.ttl=-1 +- +-# The Java-level namelookup cache policy for failed lookups: +-# +-# any negative value: cache forever +-# any positive value: the number of seconds to cache negative lookup results +-# zero: do not cache +-# +-# In some Microsoft Windows networking environments that employ +-# the WINS name service in addition to DNS, name service lookups +-# that fail may take a noticeably long time to return (approx. 5 seconds). +-# For this reason the default caching policy is to maintain these +-# results for 10 seconds. +-# +-# +-networkaddress.cache.negative.ttl=10 +- +-# +-# Properties to configure OCSP for certificate revocation checking +-# +- +-# Enable OCSP +-# +-# By default, OCSP is not used for certificate revocation checking. +-# This property enables the use of OCSP when set to the value "true". +-# +-# NOTE: SocketPermission is required to connect to an OCSP responder. +-# +-# Example, +-# ocsp.enable=true +- +-# +-# Location of the OCSP responder +-# +-# By default, the location of the OCSP responder is determined implicitly +-# from the certificate being validated. This property explicitly specifies +-# the location of the OCSP responder. The property is used when the +-# Authority Information Access extension (defined in RFC 3280) is absent +-# from the certificate or when it requires overriding. +-# +-# Example, +-# ocsp.responderURL=http://ocsp.example.net:80 +- +-# +-# Subject name of the OCSP responder's certificate +-# +-# By default, the certificate of the OCSP responder is that of the issuer +-# of the certificate being validated. This property identifies the certificate +-# of the OCSP responder when the default does not apply. Its value is a string +-# distinguished name (defined in RFC 2253) which identifies a certificate in +-# the set of certificates supplied during cert path validation. In cases where +-# the subject name alone is not sufficient to uniquely identify the certificate +-# then both the "ocsp.responderCertIssuerName" and +-# "ocsp.responderCertSerialNumber" properties must be used instead. When this +-# property is set then those two properties are ignored. +-# +-# Example, +-# ocsp.responderCertSubjectName="CN=OCSP Responder, O=XYZ Corp" +- +-# +-# Issuer name of the OCSP responder's certificate +-# +-# By default, the certificate of the OCSP responder is that of the issuer +-# of the certificate being validated. This property identifies the certificate +-# of the OCSP responder when the default does not apply. Its value is a string +-# distinguished name (defined in RFC 2253) which identifies a certificate in +-# the set of certificates supplied during cert path validation. When this +-# property is set then the "ocsp.responderCertSerialNumber" property must also +-# be set. When the "ocsp.responderCertSubjectName" property is set then this +-# property is ignored. +-# +-# Example, +-# ocsp.responderCertIssuerName="CN=Enterprise CA, O=XYZ Corp" +- +-# +-# Serial number of the OCSP responder's certificate +-# +-# By default, the certificate of the OCSP responder is that of the issuer +-# of the certificate being validated. This property identifies the certificate +-# of the OCSP responder when the default does not apply. Its value is a string +-# of hexadecimal digits (colon or space separators may be present) which +-# identifies a certificate in the set of certificates supplied during cert path +-# validation. When this property is set then the "ocsp.responderCertIssuerName" +-# property must also be set. When the "ocsp.responderCertSubjectName" property +-# is set then this property is ignored. +-# +-# Example, +-# ocsp.responderCertSerialNumber=2A:FF:00 +- +diff -r 3b6f55f02122 -r 2a023db33371 src/share/lib/security/java.security-linux +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/src/share/lib/security/java.security-linux Fri Oct 25 22:35:06 2013 +0100 +@@ -0,0 +1,311 @@ ++# ++# This is the "master security properties file". ++# ++# In this file, various security properties are set for use by ++# java.security classes. This is where users can statically register ++# Cryptography Package Providers ("providers" for short). The term ++# "provider" refers to a package or set of packages that supply a ++# concrete implementation of a subset of the cryptography aspects of ++# the Java Security API. A provider may, for example, implement one or ++# more digital signature algorithms or message digest algorithms. ++# ++# Each provider must implement a subclass of the Provider class. ++# To register a provider in this master security properties file, ++# specify the Provider subclass name and priority in the format ++# ++# security.provider.<n>=<className> ++# ++# This declares a provider, and specifies its preference ++# order n. The preference order is the order in which providers are ++# searched for requested algorithms (when no specific provider is ++# requested). The order is 1-based; 1 is the most preferred, followed ++# by 2, and so on. ++# ++# <className> must specify the subclass of the Provider class whose ++# constructor sets the values of various properties that are required ++# for the Java Security API to look up the algorithms or other ++# facilities implemented by the provider. ++# ++# There must be at least one provider specification in java.security. ++# There is a default provider that comes standard with the JDK. It ++# is called the "SUN" provider, and its Provider subclass ++# named Sun appears in the sun.security.provider package. Thus, the ++# "SUN" provider is registered via the following: ++# ++# security.provider.1=sun.security.provider.Sun ++# ++# (The number 1 is used for the default provider.) ++# ++# Note: Providers can be dynamically registered instead by calls to ++# either the addProvider or insertProviderAt method in the Security ++# class. ++ ++# ++# List of providers and their preference orders (see above): ++# ++security.provider.1=sun.security.provider.Sun ++security.provider.2=sun.security.rsa.SunRsaSign ++security.provider.3=com.sun.net.ssl.internal.ssl.Provider ++security.provider.4=com.sun.crypto.provider.SunJCE ++security.provider.5=sun.security.jgss.SunProvider ++security.provider.6=com.sun.security.sasl.Provider ++security.provider.7=org.jcp.xml.dsig.internal.dom.XMLDSigRI ++security.provider.8=sun.security.smartcardio.SunPCSC ++ ++# ++# Select the source of seed data for SecureRandom. By default an ++# attempt is made to use the entropy gathering device specified by ++# the securerandom.source property. If an exception occurs when ++# accessing the URL then the traditional system/thread activity ++# algorithm is used. ++# ++# On Solaris and Linux systems, if file:/dev/urandom is specified and it ++# exists, a special SecureRandom implementation is activated by default. ++# This "NativePRNG" reads random bytes directly from /dev/urandom. ++# ++# On Windows systems, the URLs file:/dev/random and file:/dev/urandom ++# enables use of the Microsoft CryptoAPI seed functionality. ++# ++securerandom.source=file:/dev/urandom ++# ++# The entropy gathering device is described as a URL and can also ++# be specified with the system property "java.security.egd". For example, ++# -Djava.security.egd=file:/dev/urandom ++# Specifying this system property will override the securerandom.source ++# setting. ++ ++# ++# Class to instantiate as the javax.security.auth.login.Configuration ++# provider. ++# ++login.configuration.provider=com.sun.security.auth.login.ConfigFile ++ ++# ++# Default login configuration file ++# ++#login.config.url.1=file:${user.home}/.java.login.config ++ ++# ++# Class to instantiate as the system Policy. This is the name of the class ++# that will be used as the Policy object. ++# ++policy.provider=sun.security.provider.PolicyFile ++ ++# The default is to have a single system-wide policy file, ++# and a policy file in the user's home directory. ++policy.url.1=file:${java.home}/lib/security/java.policy ++policy.url.2=file:${user.home}/.java.policy ++ ++# whether or not we expand properties in the policy file ++# if this is set to false, properties (${...}) will not be expanded in policy ++# files. ++policy.expandProperties=true ++ ++# whether or not we allow an extra policy to be passed on the command line ++# with -Djava.security.policy=somefile. Comment out this line to disable ++# this feature. ++policy.allowSystemProperty=true ++ ++# whether or not we look into the IdentityScope for trusted Identities ++# when encountering a 1.1 signed JAR file. If the identity is found ++# and is trusted, we grant it AllPermission. ++policy.ignoreIdentityScope=false ++ ++# ++# Default keystore type. ++# ++keystore.type=jks ++ ++# ++# Class to instantiate as the system scope: ++# ++system.scope=sun.security.provider.IdentityDatabase ++ ++# ++# List of comma-separated packages that start with or equal this string ++# will cause a security exception to be thrown when ++# passed to checkPackageAccess unless the ++# corresponding RuntimePermission ("accessClassInPackage."+package) has ++# been granted. ++package.access=sun.,\ ++ com.sun.corba.se.impl.,\ ++ com.sun.xml.internal.,\ ++ com.sun.imageio.,\ ++ com.sun.istack.internal.,\ ++ com.sun.jmx.,\ ++ com.sun.proxy.,\ ++ com.sun.org.apache.bcel.internal.,\ ++ com.sun.org.apache.regexp.internal.,\ ++ com.sun.org.apache.xerces.internal.,\ ++ com.sun.org.apache.xpath.internal.,\ ++ com.sun.org.apache.xalan.internal.extensions.,\ ++ com.sun.org.apache.xalan.internal.lib.,\ ++ com.sun.org.apache.xalan.internal.res.,\ ++ com.sun.org.apache.xalan.internal.templates.,\ ++ com.sun.org.apache.xalan.internal.xslt.,\ ++ com.sun.org.apache.xalan.internal.xsltc.cmdline.,\ ++ com.sun.org.apache.xalan.internal.xsltc.compiler.,\ ++ com.sun.org.apache.xalan.internal.xsltc.trax.,\ ++ com.sun.org.apache.xalan.internal.xsltc.util.,\ ++ com.sun.org.apache.xml.internal.res.,\ ++ com.sun.org.apache.xml.internal.serializer.utils.,\ ++ com.sun.org.apache.xml.internal.utils.,\ ++ com.sun.org.apache.xml.internal.security.,\ ++ com.sun.org.glassfish.,\ ++ org.jcp.xml.dsig.internal. ++ ++# ++# List of comma-separated packages that start with or equal this string ++# will cause a security exception to be thrown when ++# passed to checkPackageDefinition unless the ++# corresponding RuntimePermission ("defineClassInPackage."+package) has ++# been granted. ++# ++# by default, none of the class loaders supplied with the JDK call ++# checkPackageDefinition. ++# ++package.definition=sun.,\ ++ com.sun.corba.se.impl.,\ ++ com.sun.xml.internal.,\ ++ com.sun.imageio.,\ ++ com.sun.istack.internal.,\ ++ com.sun.jmx.,\ ++ com.sun.proxy.,\ ++ com.sun.org.apache.bcel.internal.,\ ++ com.sun.org.apache.regexp.internal.,\ ++ com.sun.org.apache.xerces.internal.,\ ++ com.sun.org.apache.xpath.internal.,\ ++ com.sun.org.apache.xalan.internal.extensions.,\ ++ com.sun.org.apache.xalan.internal.lib.,\ ++ com.sun.org.apache.xalan.internal.res.,\ ++ com.sun.org.apache.xalan.internal.templates.,\ ++ com.sun.org.apache.xalan.internal.xslt.,\ ++ com.sun.org.apache.xalan.internal.xsltc.cmdline.,\ ++ com.sun.org.apache.xalan.internal.xsltc.compiler.,\ ++ com.sun.org.apache.xalan.internal.xsltc.trax.,\ ++ com.sun.org.apache.xalan.internal.xsltc.util.,\ ++ com.sun.org.apache.xml.internal.res.,\ ++ com.sun.org.apache.xml.internal.serializer.utils.,\ ++ com.sun.org.apache.xml.internal.utils.,\ ++ com.sun.org.apache.xml.internal.security.,\ ++ com.sun.org.glassfish.,\ ++ org.jcp.xml.dsig.internal. ++ ++# ++# Determines whether this properties file can be appended to ++# or overridden on the command line via -Djava.security.properties ++# ++security.overridePropertiesFile=true ++ ++# ++# Determines the default key and trust manager factory algorithms for ++# the javax.net.ssl package. ++# ++ssl.KeyManagerFactory.algorithm=SunX509 ++ssl.TrustManagerFactory.algorithm=PKIX ++ ++# ++# The Java-level namelookup cache policy for successful lookups: ++# ++# any negative value: caching forever ++# any positive value: the number of seconds to cache an address for ++# zero: do not cache ++# ++# default value is forever (FOREVER). For security reasons, this ++# caching is made forever when a security manager is set. When a security ++# manager is not set, the default behavior in this implementation ++# is to cache for 30 seconds. ++# ++# NOTE: setting this to anything other than the default value can have ++# serious security implications. Do not set it unless ++# you are sure you are not exposed to DNS spoofing attack. ++# ++#networkaddress.cache.ttl=-1 ++ ++# The Java-level namelookup cache policy for failed lookups: ++# ++# any negative value: cache forever ++# any positive value: the number of seconds to cache negative lookup results ++# zero: do not cache ++# ++# In some Microsoft Windows networking environments that employ ++# the WINS name service in addition to DNS, name service lookups ++# that fail may take a noticeably long time to return (approx. 5 seconds). ++# For this reason the default caching policy is to maintain these ++# results for 10 seconds. ++# ++# ++networkaddress.cache.negative.ttl=10 ++ ++# ++# Properties to configure OCSP for certificate revocation checking ++# ++ ++# Enable OCSP ++# ++# By default, OCSP is not used for certificate revocation checking. ++# This property enables the use of OCSP when set to the value "true". ++# ++# NOTE: SocketPermission is required to connect to an OCSP responder. ++# ++# Example, ++# ocsp.enable=true ++ ++# ++# Location of the OCSP responder ++# ++# By default, the location of the OCSP responder is determined implicitly ++# from the certificate being validated. This property explicitly specifies ++# the location of the OCSP responder. The property is used when the ++# Authority Information Access extension (defined in RFC 3280) is absent ++# from the certificate or when it requires overriding. ++# ++# Example, ++# ocsp.responderURL=http://ocsp.example.net:80 ++ ++# ++# Subject name of the OCSP responder's certificate ++# ++# By default, the certificate of the OCSP responder is that of the issuer ++# of the certificate being validated. This property identifies the certificate ++# of the OCSP responder when the default does not apply. Its value is a string ++# distinguished name (defined in RFC 2253) which identifies a certificate in ++# the set of certificates supplied during cert path validation. In cases where ++# the subject name alone is not sufficient to uniquely identify the certificate ++# then both the "ocsp.responderCertIssuerName" and ++# "ocsp.responderCertSerialNumber" properties must be used instead. When this ++# property is set then those two properties are ignored. ++# ++# Example, ++# ocsp.responderCertSubjectName="CN=OCSP Responder, O=XYZ Corp" ++ ++# ++# Issuer name of the OCSP responder's certificate ++# ++# By default, the certificate of the OCSP responder is that of the issuer ++# of the certificate being validated. This property identifies the certificate ++# of the OCSP responder when the default does not apply. Its value is a string ++# distinguished name (defined in RFC 2253) which identifies a certificate in ++# the set of certificates supplied during cert path validation. When this ++# property is set then the "ocsp.responderCertSerialNumber" property must also ++# be set. When the "ocsp.responderCertSubjectName" property is set then this ++# property is ignored. ++# ++# Example, ++# ocsp.responderCertIssuerName="CN=Enterprise CA, O=XYZ Corp" ++ ++# ++# Serial number of the OCSP responder's certificate ++# ++# By default, the certificate of the OCSP responder is that of the issuer ++# of the certificate being validated. This property identifies the certificate ++# of the OCSP responder when the default does not apply. Its value is a string ++# of hexadecimal digits (colon or space separators may be present) which ++# identifies a certificate in the set of certificates supplied during cert path ++# validation. When this property is set then the "ocsp.responderCertIssuerName" ++# property must also be set. When the "ocsp.responderCertSubjectName" property ++# is set then this property is ignored. ++# ++# Example, ++# ocsp.responderCertSerialNumber=2A:FF:00 ++ diff --git a/java/openjdk6/files/icedtea/openjdk/8006882-jmockit.patch b/java/openjdk6/files/icedtea/openjdk/8006882-jmockit.patch new file mode 100644 index 000000000000..9b96efe8072e --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8006882-jmockit.patch @@ -0,0 +1,90 @@ +# HG changeset patch +# User mchung +# Date 1382735820 -3600 +# Fri Oct 25 22:17:00 2013 +0100 +# Node ID 695dd7ceb9e34fd4058374de63964c205f061002 +# Parent 5b485ecccea9064e5036e1bb040fc2af1f773c20 +8006882: Proxy generated classes in sun.proxy package breaks JMockit +Reviewed-by: alanb, ahgross + +diff -r 5b485ecccea9 -r 695dd7ceb9e3 src/share/classes/java/lang/reflect/Proxy.java +--- jdk/src/share/classes/java/lang/reflect/Proxy.java Fri Oct 25 22:11:26 2013 +0100 ++++ jdk/src/share/classes/java/lang/reflect/Proxy.java Fri Oct 25 22:17:00 2013 +0100 +@@ -609,7 +609,7 @@ + } + + if (proxyPkg == null) { +- // if no non-public proxy interfaces, use sun.proxy package ++ // if no non-public proxy interfaces, use com.sun.proxy package + proxyPkg = ReflectUtil.PROXY_PACKAGE + "."; + } + +diff -r 5b485ecccea9 -r 695dd7ceb9e3 src/share/classes/sun/reflect/misc/ReflectUtil.java +--- jdk/src/share/classes/sun/reflect/misc/ReflectUtil.java Fri Oct 25 22:11:26 2013 +0100 ++++ jdk/src/share/classes/sun/reflect/misc/ReflectUtil.java Fri Oct 25 22:17:00 2013 +0100 +@@ -246,7 +246,7 @@ + } + } + +- public static final String PROXY_PACKAGE = "sun.proxy"; ++ public static final String PROXY_PACKAGE = "com.sun.proxy"; + + /** + * Test if the given class is a proxy class that implements +diff -r 5b485ecccea9 -r 695dd7ceb9e3 src/share/lib/security/java.security +--- jdk/src/share/lib/security/java.security Fri Oct 25 22:11:26 2013 +0100 ++++ jdk/src/share/lib/security/java.security Fri Oct 25 22:17:00 2013 +0100 +@@ -132,6 +132,7 @@ + com.sun.imageio.,\ + com.sun.istack.internal.,\ + com.sun.jmx.,\ ++ com.sun.proxy.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +@@ -167,6 +168,7 @@ + com.sun.imageio.,\ + com.sun.istack.internal.,\ + com.sun.jmx.,\ ++ com.sun.proxy.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +diff -r 5b485ecccea9 -r 695dd7ceb9e3 src/share/lib/security/java.security-solaris +--- jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:11:26 2013 +0100 ++++ jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:17:00 2013 +0100 +@@ -133,6 +133,7 @@ + com.sun.imageio.,\ + com.sun.istack.internal.,\ + com.sun.jmx.,\ ++ com.sun.proxy.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +@@ -169,6 +170,7 @@ + com.sun.imageio.,\ + com.sun.istack.internal.,\ + com.sun.jmx.,\ ++ com.sun.proxy.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +diff -r 5b485ecccea9 -r 695dd7ceb9e3 src/share/lib/security/java.security-windows +--- jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:11:26 2013 +0100 ++++ jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:17:00 2013 +0100 +@@ -133,6 +133,7 @@ + com.sun.imageio.,\ + com.sun.istack.internal.,\ + com.sun.jmx.,\ ++ com.sun.proxy.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +@@ -170,6 +171,7 @@ + com.sun.imageio.,\ + com.sun.istack.internal.,\ + com.sun.jmx.,\ ++ com.sun.proxy.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ diff --git a/java/openjdk6/files/icedtea/openjdk/8006900-new_date_time.patch b/java/openjdk6/files/icedtea/openjdk/8006900-new_date_time.patch new file mode 100644 index 000000000000..921197ef51c3 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8006900-new_date_time.patch @@ -0,0 +1,115 @@ +# HG changeset patch +# User okutsu +# Date 1374215521 -32400 +# Fri Jul 19 15:32:01 2013 +0900 +# Node ID f38a3c5421df4697851a4b4d491071c3a30e5378 +# Parent 5d81a5f8a3791316367990b35b1ad5faef42d773 +8006900: Add new date/time capability +Reviewed-by: mchung, hawtin + +diff -r 5d81a5f8a379 -r f38a3c5421df src/share/classes/java/util/TimeZone.java +--- jdk/src/share/classes/java/util/TimeZone.java Tue Oct 15 15:04:24 2013 +0100 ++++ jdk/src/share/classes/java/util/TimeZone.java Fri Jul 19 15:32:01 2013 +0900 +@@ -170,6 +170,11 @@ + // Proclaim serialization compatibility with JDK 1.1 + static final long serialVersionUID = 3581463369166924961L; + ++ // TimeZone.setDefault maintains the compatible behavior of the AppContext-based ++ // default setting for untrusted code if allowSetDefault is true. ++ private static final boolean allowSetDefault = AccessController.doPrivileged( ++ new sun.security.action.GetPropertyAction("jdk.util.TimeZone.allowSetDefault")) != null; ++ + /** + * Gets the time zone offset, for current date, modified in case of + * daylight savings. This is the offset to add to UTC to get local time. +@@ -616,6 +621,9 @@ + sm.checkPermission(new PropertyPermission + ("user.timezone", "write")); + } catch (SecurityException e) { ++ if (!allowSetDefault) { ++ throw e; ++ } + hasPermission = false; + } + } +@@ -646,6 +654,7 @@ + * Returns the default TimeZone in an AppContext if any AppContext + * has ever used. null is returned if any AppContext hasn't been + * used or if the AppContext doesn't have the default TimeZone. ++ * null is also returned if allowSetDefault is false. + * + * Note that javaAWTAccess may be null if sun.awt.AppContext class hasn't + * been loaded. If so, it implies that AWTSecurityManager is not our +@@ -653,18 +662,20 @@ + * This works around a build time issue. + */ + private static TimeZone getDefaultInAppContext() { +- // JavaAWTAccess provides access implementation-private methods without using reflection. +- JavaAWTAccess javaAWTAccess = SharedSecrets.getJavaAWTAccess(); +- if (javaAWTAccess == null) { +- return mainAppContextDefault; +- } else { +- if (!javaAWTAccess.isDisposed()) { +- TimeZone tz = (TimeZone) +- javaAWTAccess.get(TimeZone.class); +- if (tz == null && javaAWTAccess.isMainAppContext()) { +- return mainAppContextDefault; +- } else { +- return tz; ++ if (allowSetDefault) { ++ // JavaAWTAccess provides access implementation-private methods without using reflection. ++ JavaAWTAccess javaAWTAccess = SharedSecrets.getJavaAWTAccess(); ++ if (javaAWTAccess == null) { ++ return mainAppContextDefault; ++ } else { ++ if (!javaAWTAccess.isDisposed()) { ++ TimeZone tz = (TimeZone) ++ javaAWTAccess.get(TimeZone.class); ++ if (tz == null && javaAWTAccess.isMainAppContext()) { ++ return mainAppContextDefault; ++ } else { ++ return tz; ++ } + } + } + } +@@ -672,9 +683,9 @@ + } + + /** +- * Sets the default TimeZone in the AppContext to the given +- * tz. null is handled special: do nothing if any AppContext +- * hasn't been used, remove the default TimeZone in the ++ * Sets the default TimeZone in the AppContext to the given tz if ++ * allowSetDefault is true. null is handled special: do nothing if any ++ * AppContext hasn't been used, remove the default TimeZone in the + * AppContext otherwise. + * + * Note that javaAWTAccess may be null if sun.awt.AppContext class hasn't +@@ -683,15 +694,17 @@ + * This works around a build time issue. + */ + private static void setDefaultInAppContext(TimeZone tz) { +- // JavaAWTAccess provides access implementation-private methods without using reflection. +- JavaAWTAccess javaAWTAccess = SharedSecrets.getJavaAWTAccess(); +- if (javaAWTAccess == null) { +- mainAppContextDefault = tz; +- } else { +- if (!javaAWTAccess.isDisposed()) { +- javaAWTAccess.put(TimeZone.class, tz); +- if (javaAWTAccess.isMainAppContext()) { +- mainAppContextDefault = null; ++ if (allowSetDefault) { ++ // JavaAWTAccess provides access implementation-private methods without using reflection. ++ JavaAWTAccess javaAWTAccess = SharedSecrets.getJavaAWTAccess(); ++ if (javaAWTAccess == null) { ++ mainAppContextDefault = tz; ++ } else { ++ if (!javaAWTAccess.isDisposed()) { ++ javaAWTAccess.put(TimeZone.class, tz); ++ if (javaAWTAccess.isMainAppContext()) { ++ mainAppContextDefault = null; ++ } + } + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8008589-better_mbean_permission_validation.patch b/java/openjdk6/files/icedtea/openjdk/8008589-better_mbean_permission_validation.patch new file mode 100644 index 000000000000..32666f739a6e --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8008589-better_mbean_permission_validation.patch @@ -0,0 +1,61 @@ +# HG changeset patch +# User dsamersoff +# Date 1373279676 -14400 +# Mon Jul 08 14:34:36 2013 +0400 +# Node ID db4712506571ae3ae2d37b91e63641b18c3258f2 +# Parent f38a3c5421df4697851a4b4d491071c3a30e5378 +8008589: Better MBean permission validation +Summary: Better MBean permission validation +Reviewed-by: skoivu, dfuchs, mchung, sjiang + +diff -r f38a3c5421df -r db4712506571 src/share/classes/javax/management/MBeanTrustPermission.java +--- jdk/src/share/classes/javax/management/MBeanTrustPermission.java Fri Jul 19 15:32:01 2013 +0900 ++++ jdk/src/share/classes/javax/management/MBeanTrustPermission.java Mon Jul 08 14:34:36 2013 +0400 +@@ -26,6 +26,9 @@ + package javax.management; + + import java.security.BasicPermission; ++import java.io.IOException; ++import java.io.InvalidObjectException; ++import java.io.ObjectInputStream; + + /** + * This permission represents "trust" in a signer or codebase. +@@ -75,15 +78,31 @@ + */ + public MBeanTrustPermission(String name, String actions) { + super(name, actions); ++ validate(name,actions); ++ } ++ ++ private static void validate(String name, String actions) { + /* Check that actions is a null empty string */ +- if (actions != null && actions.length() > 0) +- throw new IllegalArgumentException("MBeanTrustPermission " + +- "actions must be null: " + ++ if (actions != null && actions.length() > 0) { ++ throw new IllegalArgumentException("MBeanTrustPermission actions must be null: " + + actions); ++ } + +- if (!name.equals("register") && !name.equals("*")) +- throw new IllegalArgumentException("MBeanTrustPermission: " + +- "Unknown target name " + ++ if (!name.equals("register") && !name.equals("*")) { ++ throw new IllegalArgumentException("MBeanTrustPermission: Unknown target name " + + "[" + name + "]"); ++ } ++ } ++ ++ private void readObject(ObjectInputStream in) ++ throws IOException, ClassNotFoundException { ++ ++ // Reading private fields of base class ++ in.defaultReadObject(); ++ try { ++ validate(super.getName(),super.getActions()); ++ } catch (IllegalArgumentException e) { ++ throw new InvalidObjectException(e.getMessage()); ++ } + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8010118-caller_sensitive.patch b/java/openjdk6/files/icedtea/openjdk/8010118-caller_sensitive.patch new file mode 100644 index 000000000000..29ca05adfc00 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8010118-caller_sensitive.patch @@ -0,0 +1,2968 @@ +# HG changeset patch +# User mchung +# Date 1382375156 -3600 +# Mon Oct 21 18:05:56 2013 +0100 +# Node ID d206cb658a9907c7842c8920f141b3c4eb5efc1f +# Parent e56220b54fe2d0f09ee151b28d6e8495cea2136f +8010118: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive +Reviewed-by: alanb, twisti, jrose, kvn + +diff -r e56220b54fe2 -r d206cb658a99 make/java/java/FILES_c.gmk +--- jdk/make/java/java/FILES_c.gmk Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/make/java/java/FILES_c.gmk Mon Oct 21 18:05:56 2013 +0100 +@@ -48,7 +48,6 @@ + Proxy.c \ + RandomAccessFile.c \ + RandomAccessFile_md.c \ +- ResourceBundle.c \ + Runtime.c \ + SecurityManager.c \ + Shutdown.c \ +@@ -68,7 +67,6 @@ + jdk_util_md.c \ + check_version.c \ + java_props_md.c \ +- DriverManager.c \ + ConstantPool.c \ + MessageUtils.c \ + GC.c \ +diff -r e56220b54fe2 -r d206cb658a99 make/java/java/mapfile-vers +--- jdk/make/java/java/mapfile-vers Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/make/java/java/mapfile-vers Mon Oct 21 18:05:56 2013 +0100 +@@ -237,8 +237,6 @@ + Java_java_security_AccessController_doPrivileged__Ljava_security_PrivilegedExceptionAction_2Ljava_security_AccessControlContext_2; + Java_java_security_AccessController_getStackAccessControlContext; + Java_java_security_AccessController_getInheritedAccessControlContext; +- Java_java_sql_DriverManager_getCallerClassLoader; +- Java_java_util_ResourceBundle_getClassContext; + Java_java_util_TimeZone_getSystemTimeZoneID; + Java_java_util_TimeZone_getSystemGMTOffsetID; + Java_java_util_concurrent_atomic_AtomicLong_VMSupportsCS8; +diff -r e56220b54fe2 -r d206cb658a99 make/java/java/reorder-i586 +--- jdk/make/java/java/reorder-i586 Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/make/java/java/reorder-i586 Mon Oct 21 18:05:56 2013 +0100 +@@ -73,7 +73,6 @@ + # Test Sleep + # Test IntToString + # Test LoadToolkit +-text: .text%Java_java_util_ResourceBundle_getClassContext; + text: .text%Java_java_security_AccessController_doPrivileged__Ljava_security_PrivilegedAction_2Ljava_security_AccessControlContext_2; + text: .text%JNU_GetEnv; + text: .text%Java_java_io_UnixFileSystem_checkAccess; +diff -r e56220b54fe2 -r d206cb658a99 make/java/java/reorder-sparc +--- jdk/make/java/java/reorder-sparc Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/make/java/java/reorder-sparc Mon Oct 21 18:05:56 2013 +0100 +@@ -78,7 +78,6 @@ + # Test Sleep + # Test IntToString + # Test LoadToolkit +-text: .text%Java_java_util_ResourceBundle_getClassContext; + text: .text%Java_java_security_AccessController_doPrivileged__Ljava_security_PrivilegedAction_2Ljava_security_AccessControlContext_2; + text: .text%JNU_GetEnv; + text: .text%Java_java_io_UnixFileSystem_checkAccess; +diff -r e56220b54fe2 -r d206cb658a99 make/java/java/reorder-sparcv9 +--- jdk/make/java/java/reorder-sparcv9 Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/make/java/java/reorder-sparcv9 Mon Oct 21 18:05:56 2013 +0100 +@@ -74,7 +74,6 @@ + # Test Sleep + # Test IntToString + # Test LoadToolkit +-text: .text%Java_java_util_ResourceBundle_getClassContext; + text: .text%Java_java_security_AccessController_doPrivileged__Ljava_security_PrivilegedAction_2Ljava_security_AccessControlContext_2; + text: .text%JNU_GetEnv; + text: .text%Java_java_io_UnixFileSystem_checkAccess; +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/io/ObjectStreamClass.java +--- jdk/src/share/classes/java/io/ObjectStreamClass.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/io/ObjectStreamClass.java Mon Oct 21 18:05:56 2013 +0100 +@@ -49,6 +49,8 @@ + import java.util.concurrent.ConcurrentHashMap; + import java.util.concurrent.ConcurrentMap; + import sun.misc.Unsafe; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + import sun.reflect.ReflectionFactory; + import sun.reflect.misc.ReflectUtil; + +@@ -234,12 +236,13 @@ + * + * @return the <code>Class</code> instance that this descriptor represents + */ ++ @CallerSensitive + public Class<?> forClass() { + if (cl == null) { + return null; + } +- ClassLoader ccl = ObjectStreamField.getCallerClassLoader(); +- if (ReflectUtil.needsPackageAccessCheck(ccl, cl.getClassLoader())) { ++ Class<?> caller = Reflection.getCallerClass(); ++ if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), cl.getClassLoader())) { + ReflectUtil.checkPackageAccess(cl); + } + return cl; +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/io/ObjectStreamField.java +--- jdk/src/share/classes/java/io/ObjectStreamField.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/io/ObjectStreamField.java Mon Oct 21 18:05:56 2013 +0100 +@@ -26,6 +26,7 @@ + package java.io; + + import java.lang.reflect.Field; ++import sun.reflect.CallerSensitive; + import sun.reflect.Reflection; + import sun.reflect.misc.ReflectUtil; + +@@ -159,32 +160,15 @@ + * @return a <code>Class</code> object representing the type of the + * serializable field + */ ++ @CallerSensitive + public Class<?> getType() { +- ClassLoader ccl = getCallerClassLoader(); +- if (ReflectUtil.needsPackageAccessCheck(ccl, type.getClassLoader())) { ++ Class<?> caller = Reflection.getCallerClass(); ++ if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), type.getClassLoader())) { + ReflectUtil.checkPackageAccess(type); + } + return type; + } + +- // Returns the invoker's class loader. +- // This is package private because it is accessed from ObjectStreamClass. +- // NOTE: This must always be invoked when there is exactly one intervening +- // frame from the core libraries on the stack between this method's +- // invocation and the desired invoker. The frame count of 3 is determined +- // as follows: +- // +- // 0: Reflection.getCallerClass +- // 1: getCallerClassLoader() +- // 2: ObjectStreamField.getType() or ObjectStreamClass.forClass() +- // 3: the caller we want to check +- // +- // NOTE: copied from java.lang.ClassLoader and modified. +- static ClassLoader getCallerClassLoader() { +- Class caller = Reflection.getCallerClass(3); +- return caller.getClassLoader(); +- } +- + /** + * Returns character encoding of field type. The encoding is as follows: + * <blockquote><pre> +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/Class.java +--- jdk/src/share/classes/java/lang/Class.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/Class.java Mon Oct 21 18:05:56 2013 +0100 +@@ -53,6 +53,7 @@ + import java.util.Map; + import java.util.HashMap; + import sun.misc.Unsafe; ++import sun.reflect.CallerSensitive; + import sun.reflect.ConstantPool; + import sun.reflect.Reflection; + import sun.reflect.ReflectionFactory; +@@ -183,9 +184,11 @@ + * by this method fails + * @exception ClassNotFoundException if the class cannot be located + */ ++ @CallerSensitive + public static Class<?> forName(String className) + throws ClassNotFoundException { +- return forName0(className, true, ClassLoader.getCallerClassLoader()); ++ return forName0(className, true, ++ ClassLoader.getClassLoader(Reflection.getCallerClass())); + } + + +@@ -249,6 +252,7 @@ + * @see java.lang.ClassLoader + * @since 1.2 + */ ++ @CallerSensitive + public static Class<?> forName(String name, boolean initialize, + ClassLoader loader) + throws ClassNotFoundException +@@ -256,7 +260,7 @@ + if (loader == null) { + SecurityManager sm = System.getSecurityManager(); + if (sm != null) { +- ClassLoader ccl = ClassLoader.getCallerClassLoader(); ++ ClassLoader ccl = ClassLoader.getClassLoader(Reflection.getCallerClass()); + if (ccl != null) { + sm.checkPermission( + SecurityConstants.GET_CLASSLOADER_PERMISSION); +@@ -318,18 +322,14 @@ + * </ul> + * + */ ++ @CallerSensitive + public T newInstance() + throws InstantiationException, IllegalAccessException + { + if (System.getSecurityManager() != null) { +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), false); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), false); + } +- return newInstance0(); +- } + +- private T newInstance0() +- throws InstantiationException, IllegalAccessException +- { + // NOTE: the following code may not be strictly correct under + // the current Java memory model. + +@@ -363,7 +363,7 @@ + // Security check (same as in java.lang.reflect.Constructor) + int modifiers = tmpConstructor.getModifiers(); + if (!Reflection.quickCheckMemberAccess(this, modifiers)) { +- Class caller = Reflection.getCallerClass(3); ++ Class<?> caller = Reflection.getCallerClass(); + if (newInstanceCallerCache != caller) { + Reflection.ensureMemberAccess(caller, this, null, modifiers); + newInstanceCallerCache = caller; +@@ -602,16 +602,14 @@ + * @see SecurityManager#checkPermission + * @see java.lang.RuntimePermission + */ ++ @CallerSensitive + public ClassLoader getClassLoader() { + ClassLoader cl = getClassLoader0(); + if (cl == null) + return null; + SecurityManager sm = System.getSecurityManager(); + if (sm != null) { +- ClassLoader ccl = ClassLoader.getCallerClassLoader(); +- if (ccl != null && ccl != cl && !cl.isAncestor(ccl)) { +- sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); +- } ++ ClassLoader.checkClassLoaderPermission(cl, Reflection.getCallerClass()); + } + return cl; + } +@@ -891,6 +889,7 @@ + * that class is a local or anonymous class; otherwise {@code null}. + * @since 1.5 + */ ++ @CallerSensitive + public Method getEnclosingMethod() { + EnclosingMethodInfo enclosingInfo = getEnclosingMethodInfo(); + +@@ -920,7 +919,7 @@ + // + // Note that we need to do this on the enclosing class + enclosingCandidate.checkMemberAccess(Member.DECLARED, +- ClassLoader.getCallerClassLoader(), true); ++ Reflection.getCallerClass(), true); + /* + * Loop over all declared methods; match method name, + * number of and type of parameters, *and* return +@@ -1028,6 +1027,7 @@ + * that class is a local or anonymous class; otherwise {@code null}. + * @since 1.5 + */ ++ @CallerSensitive + public Constructor<?> getEnclosingConstructor() { + EnclosingMethodInfo enclosingInfo = getEnclosingMethodInfo(); + +@@ -1056,7 +1056,7 @@ + // + // Note that we need to do this on the enclosing class + enclosingCandidate.checkMemberAccess(Member.DECLARED, +- ClassLoader.getCallerClassLoader(), true); ++ Reflection.getCallerClass(), true); + /* + * Loop over all declared constructors; match number + * of and type of parameters. +@@ -1103,6 +1103,7 @@ + * @return the immediately enclosing class of the underlying class + * @since 1.5 + */ ++ @CallerSensitive + public Class<?> getEnclosingClass() { + // There are five kinds of classes (or interfaces): + // a) Top level classes +@@ -1135,7 +1136,7 @@ + // see java.lang.SecurityManager.checkMemberAccess + if (enclosingCandidate != null) { + enclosingCandidate.checkMemberAccess(Member.DECLARED, +- ClassLoader.getCallerClassLoader(), true); ++ Reflection.getCallerClass(), true); + } + return enclosingCandidate; + } +@@ -1320,11 +1321,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Class<?>[] getClasses() { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), false); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), false); + + // Privileged so this implementation can look at DECLARED classes, + // something the caller might not have privilege to do. The code here +@@ -1398,11 +1400,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Field[] getFields() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true); + return copyFields(privateGetPublicFields(null)); + } + +@@ -1449,11 +1452,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Method[] getMethods() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true); + return copyMethods(privateGetPublicMethods()); + } + +@@ -1498,11 +1502,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Constructor<?>[] getConstructors() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true); + return copyConstructors(privateGetDeclaredConstructors(true)); + } + +@@ -1556,12 +1561,13 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Field getField(String name) + throws NoSuchFieldException, SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true); + Field field = getField0(name); + if (field == null) { + throw new NoSuchFieldException(name); +@@ -1641,12 +1647,13 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Method getMethod(String name, Class<?>... parameterTypes) + throws NoSuchMethodException, SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true); + Method method = getMethod0(name, parameterTypes); + if (method == null) { + throw new NoSuchMethodException(getName() + "." + name + argumentTypesToString(parameterTypes)); +@@ -1695,12 +1702,13 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Constructor<T> getConstructor(Class<?>... parameterTypes) + throws NoSuchMethodException, SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.PUBLIC, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.PUBLIC, Reflection.getCallerClass(), true); + return getConstructor0(parameterTypes, Member.PUBLIC); + } + +@@ -1738,11 +1746,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Class<?>[] getDeclaredClasses() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), false); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), false); + return getDeclaredClasses0(); + } + +@@ -1782,11 +1791,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Field[] getDeclaredFields() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), true); + return copyFields(privateGetDeclaredFields(false)); + } + +@@ -1830,11 +1840,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Method[] getDeclaredMethods() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), true); + return copyMethods(privateGetDeclaredMethods(false)); + } + +@@ -1875,11 +1886,12 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Constructor<?>[] getDeclaredConstructors() throws SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), true); + return copyConstructors(privateGetDeclaredConstructors(false)); + } + +@@ -1918,12 +1930,13 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Field getDeclaredField(String name) + throws NoSuchFieldException, SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), true); + Field field = searchFields(privateGetDeclaredFields(false), name); + if (field == null) { + throw new NoSuchFieldException(name); +@@ -1973,12 +1986,13 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Method getDeclaredMethod(String name, Class<?>... parameterTypes) + throws NoSuchMethodException, SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), true); + Method method = searchMethods(privateGetDeclaredMethods(false), name, parameterTypes); + if (method == null) { + throw new NoSuchMethodException(getName() + "." + name + argumentTypesToString(parameterTypes)); +@@ -2023,12 +2037,13 @@ + * + * @since JDK1.1 + */ ++ @CallerSensitive + public Constructor<T> getDeclaredConstructor(Class<?>... parameterTypes) + throws NoSuchMethodException, SecurityException { + // be very careful not to change the stack depth of this + // checkMemberAccess call for security reasons + // see java.lang.SecurityManager.checkMemberAccess +- checkMemberAccess(Member.DECLARED, ClassLoader.getCallerClassLoader(), true); ++ checkMemberAccess(Member.DECLARED, Reflection.getCallerClass(), true); + return getConstructor0(parameterTypes, Member.DECLARED); + } + +@@ -2186,23 +2201,40 @@ + */ + static native Class getPrimitiveClass(String name); + ++ private static boolean isCheckMemberAccessOverridden(SecurityManager smgr) { ++ if (smgr.getClass() == SecurityManager.class) return false; ++ ++ Class<?>[] paramTypes = new Class<?>[] {Class.class, int.class}; ++ return smgr.getClass().getMethod0("checkMemberAccess", paramTypes). ++ getDeclaringClass() != SecurityManager.class; ++ } ++ + + /* + * Check if client is allowed to access members. If access is denied, + * throw a SecurityException. + * +- * Be very careful not to change the stack depth of this checkMemberAccess +- * call for security reasons. +- * See java.lang.SecurityManager.checkMemberAccess. +- * + * <p> Default policy: allow all clients access with normal Java access + * control. + */ +- private void checkMemberAccess(int which, ClassLoader ccl, boolean checkProxyInterfaces) { +- SecurityManager s = System.getSecurityManager(); ++ private void checkMemberAccess(int which, Class<?> caller, boolean checkProxyInterfaces) { ++ final SecurityManager s = System.getSecurityManager(); + if (s != null) { +- s.checkMemberAccess(this, which); +- ClassLoader cl = getClassLoader0(); ++ final ClassLoader ccl = ClassLoader.getClassLoader(caller); ++ final ClassLoader cl = getClassLoader0(); ++ if (!isCheckMemberAccessOverridden(s)) { ++ // Inlined SecurityManager.checkMemberAccess ++ if (which != Member.PUBLIC) { ++ if (ccl != cl) { ++ s.checkPermission(SecurityConstants.CHECK_MEMBER_ACCESS_PERMISSION); ++ } ++ } ++ } else { ++ // Don't refactor; otherwise break the stack depth for ++ // checkMemberAccess of subclasses of SecurityManager as specified. ++ s.checkMemberAccess(this, which); ++ } ++ + if (ReflectUtil.needsPackageAccessCheck(ccl, cl)) { + + String name = this.getName(); +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/ClassLoader.java +--- jdk/src/share/classes/java/lang/ClassLoader.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/ClassLoader.java Mon Oct 21 18:05:56 2013 +0100 +@@ -52,6 +52,7 @@ + import sun.misc.Resource; + import sun.misc.URLClassPath; + import sun.misc.VM; ++import sun.reflect.CallerSensitive; + import sun.reflect.Reflection; + import sun.security.util.SecurityConstants; + +@@ -1214,15 +1215,13 @@ + * + * @since 1.2 + */ ++ @CallerSensitive + public final ClassLoader getParent() { + if (parent == null) + return null; + SecurityManager sm = System.getSecurityManager(); + if (sm != null) { +- ClassLoader ccl = getCallerClassLoader(); +- if (ccl != null && !isAncestor(ccl)) { +- sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); +- } ++ checkClassLoaderPermission(parent, Reflection.getCallerClass()); + } + return parent; + } +@@ -1282,6 +1281,7 @@ + * + * @revised 1.4 + */ ++ @CallerSensitive + public static ClassLoader getSystemClassLoader() { + initSystemClassLoader(); + if (scl == null) { +@@ -1289,10 +1289,7 @@ + } + SecurityManager sm = System.getSecurityManager(); + if (sm != null) { +- ClassLoader ccl = getCallerClassLoader(); +- if (ccl != null && ccl != scl && !scl.isAncestor(ccl)) { +- sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); +- } ++ checkClassLoaderPermission(scl, Reflection.getCallerClass()); + } + return scl; + } +@@ -1341,13 +1338,25 @@ + return false; + } + +- // Returns the invoker's class loader, or null if none. +- // NOTE: This must always be invoked when there is exactly one intervening +- // frame from the core libraries on the stack between this method's +- // invocation and the desired invoker. +- static ClassLoader getCallerClassLoader() { +- // NOTE use of more generic Reflection.getCallerClass() +- Class caller = Reflection.getCallerClass(3); ++ // Tests if class loader access requires "getClassLoader" permission ++ // check. A class loader 'from' can access class loader 'to' if ++ // class loader 'from' is same as class loader 'to' or an ancestor ++ // of 'to'. The class loader in a system domain can access ++ // any class loader. ++ private static boolean needsClassLoaderPermissionCheck(ClassLoader from, ++ ClassLoader to) ++ { ++ if (from == to) ++ return false; ++ ++ if (from == null) ++ return false; ++ ++ return !to.isAncestor(from); ++ } ++ ++ // Returns the class's class loader, or null if none. ++ static ClassLoader getClassLoader(Class<?> caller) { + // This can be null if the VM is requesting it + if (caller == null) { + return null; +@@ -1356,6 +1365,17 @@ + return caller.getClassLoader0(); + } + ++ static void checkClassLoaderPermission(ClassLoader cl, Class<?> caller) { ++ SecurityManager sm = System.getSecurityManager(); ++ if (sm != null) { ++ // caller can be null if the VM is requesting it ++ ClassLoader ccl = getClassLoader(caller); ++ if (needsClassLoaderPermissionCheck(ccl, cl)) { ++ sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); ++ } ++ } ++ } ++ + // The class loader for the system + private static ClassLoader scl; + +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/Package.java +--- jdk/src/share/classes/java/lang/Package.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/Package.java Mon Oct 21 18:05:56 2013 +0100 +@@ -47,9 +47,10 @@ + import java.util.HashMap; + import java.util.Iterator; + ++import java.lang.annotation.Annotation; + import sun.net.www.ParseUtil; +- +-import java.lang.annotation.Annotation; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * {@code Package} objects contain version information +@@ -273,8 +274,9 @@ + * @return the package of the requested name. It may be null if no package + * information is available from the archive or codebase. + */ ++ @CallerSensitive + public static Package getPackage(String name) { +- ClassLoader l = ClassLoader.getCallerClassLoader(); ++ ClassLoader l = ClassLoader.getClassLoader(Reflection.getCallerClass()); + if (l != null) { + return l.getPackage(name); + } else { +@@ -294,8 +296,9 @@ + * @return a new array of packages known to the callers {@code ClassLoader} + * instance. An zero length array is returned if none are known. + */ ++ @CallerSensitive + public static Package[] getPackages() { +- ClassLoader l = ClassLoader.getCallerClassLoader(); ++ ClassLoader l = ClassLoader.getClassLoader(Reflection.getCallerClass()); + if (l != null) { + return l.getPackages(); + } else { +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/Runtime.java +--- jdk/src/share/classes/java/lang/Runtime.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/Runtime.java Mon Oct 21 18:05:56 2013 +0100 +@@ -27,6 +27,8 @@ + + import java.io.*; + import java.util.StringTokenizer; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * Every Java application has a single instance of class +@@ -771,8 +773,9 @@ + * @see java.lang.SecurityException + * @see java.lang.SecurityManager#checkLink(java.lang.String) + */ ++ @CallerSensitive + public void load(String filename) { +- load0(System.getCallerClass(), filename); ++ load0(Reflection.getCallerClass(), filename); + } + + synchronized void load0(Class fromClass, String filename) { +@@ -824,8 +827,9 @@ + * @see java.lang.SecurityException + * @see java.lang.SecurityManager#checkLink(java.lang.String) + */ ++ @CallerSensitive + public void loadLibrary(String libname) { +- loadLibrary0(System.getCallerClass(), libname); ++ loadLibrary0(Reflection.getCallerClass(), libname); + } + + synchronized void loadLibrary0(Class fromClass, String libname) { +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/System.java +--- jdk/src/share/classes/java/lang/System.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/System.java Mon Oct 21 18:05:56 2013 +0100 +@@ -35,6 +35,7 @@ + import java.nio.channels.spi.SelectorProvider; + import sun.nio.ch.Interruptible; + import sun.net.InetAddressCachePolicy; ++import sun.reflect.CallerSensitive; + import sun.reflect.Reflection; + import sun.security.util.SecurityConstants; + import sun.reflect.annotation.AnnotationType; +@@ -1018,8 +1019,9 @@ + * @see java.lang.Runtime#load(java.lang.String) + * @see java.lang.SecurityManager#checkLink(java.lang.String) + */ ++ @CallerSensitive + public static void load(String filename) { +- Runtime.getRuntime().load0(getCallerClass(), filename); ++ Runtime.getRuntime().load0(Reflection.getCallerClass(), filename); + } + + /** +@@ -1043,8 +1045,9 @@ + * @see java.lang.Runtime#loadLibrary(java.lang.String) + * @see java.lang.SecurityManager#checkLink(java.lang.String) + */ ++ @CallerSensitive + public static void loadLibrary(String libname) { +- Runtime.getRuntime().loadLibrary0(getCallerClass(), libname); ++ Runtime.getRuntime().loadLibrary0(Reflection.getCallerClass(), libname); + } + + /** +@@ -1157,10 +1160,4 @@ + } + }); + } +- +- /* returns the class of the caller. */ +- static Class getCallerClass() { +- // NOTE use of more generic Reflection.getCallerClass() +- return Reflection.getCallerClass(3); +- } + } +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/Thread.java +--- jdk/src/share/classes/java/lang/Thread.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/Thread.java Mon Oct 21 18:05:56 2013 +0100 +@@ -34,6 +34,8 @@ + import java.util.concurrent.locks.LockSupport; + import sun.misc.SoftCache; + import sun.nio.ch.Interruptible; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + import sun.security.util.SecurityConstants; + + +@@ -1370,16 +1372,15 @@ + * + * @since 1.2 + */ ++ @CallerSensitive + public ClassLoader getContextClassLoader() { + if (contextClassLoader == null) + return null; ++ + SecurityManager sm = System.getSecurityManager(); + if (sm != null) { +- ClassLoader ccl = ClassLoader.getCallerClassLoader(); +- if (ccl != null && ccl != contextClassLoader && +- !contextClassLoader.isAncestor(ccl)) { +- sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); +- } ++ ClassLoader.checkClassLoaderPermission(contextClassLoader, ++ Reflection.getCallerClass()); + } + return contextClassLoader; + } +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/reflect/Constructor.java +--- jdk/src/share/classes/java/lang/reflect/Constructor.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/reflect/Constructor.java Mon Oct 21 18:05:56 2013 +0100 +@@ -25,6 +25,7 @@ + + package java.lang.reflect; + ++import sun.reflect.CallerSensitive; + import sun.reflect.ConstructorAccessor; + import sun.reflect.Reflection; + import sun.reflect.generics.repository.ConstructorRepository; +@@ -513,13 +514,14 @@ + * @exception ExceptionInInitializerError if the initialization provoked + * by this method fails. + */ ++ @CallerSensitive + public T newInstance(Object ... initargs) + throws InstantiationException, IllegalAccessException, + IllegalArgumentException, InvocationTargetException + { + if (!override) { + if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { +- Class caller = Reflection.getCallerClass(2); ++ Class<?> caller = Reflection.getCallerClass(); + if (securityCheckCache != caller) { + Reflection.ensureMemberAccess(caller, clazz, null, modifiers); + securityCheckCache = caller; +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/reflect/Field.java +--- jdk/src/share/classes/java/lang/reflect/Field.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/reflect/Field.java Mon Oct 21 18:05:56 2013 +0100 +@@ -25,6 +25,7 @@ + + package java.lang.reflect; + ++import sun.reflect.CallerSensitive; + import sun.reflect.FieldAccessor; + import sun.reflect.Reflection; + import sun.reflect.generics.repository.FieldRepository; +@@ -370,9 +371,15 @@ + * @exception ExceptionInInitializerError if the initialization provoked + * by this method fails. + */ ++ @CallerSensitive + public Object get(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).get(obj); + } + +@@ -397,9 +404,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public boolean getBoolean(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getBoolean(obj); + } + +@@ -424,9 +437,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public byte getByte(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getByte(obj); + } + +@@ -453,9 +472,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public char getChar(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getChar(obj); + } + +@@ -482,9 +507,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public short getShort(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getShort(obj); + } + +@@ -511,9 +542,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public int getInt(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getInt(obj); + } + +@@ -540,9 +577,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public long getLong(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getLong(obj); + } + +@@ -569,9 +612,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public float getFloat(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getFloat(obj); + } + +@@ -598,9 +647,15 @@ + * by this method fails. + * @see Field#get + */ ++ @CallerSensitive + public double getDouble(Object obj) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + return getFieldAccessor(obj).getDouble(obj); + } + +@@ -669,9 +724,15 @@ + * @exception ExceptionInInitializerError if the initialization provoked + * by this method fails. + */ ++ @CallerSensitive + public void set(Object obj, Object value) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).set(obj, value); + } + +@@ -698,9 +759,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setBoolean(Object obj, boolean z) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setBoolean(obj, z); + } + +@@ -727,9 +794,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setByte(Object obj, byte b) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setByte(obj, b); + } + +@@ -756,9 +829,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setChar(Object obj, char c) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setChar(obj, c); + } + +@@ -785,9 +864,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setShort(Object obj, short s) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setShort(obj, s); + } + +@@ -814,9 +899,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setInt(Object obj, int i) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setInt(obj, i); + } + +@@ -843,9 +934,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setLong(Object obj, long l) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setLong(obj, l); + } + +@@ -872,9 +969,15 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setFloat(Object obj, float f) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setFloat(obj, f); + } + +@@ -901,20 +1004,25 @@ + * by this method fails. + * @see Field#set + */ ++ @CallerSensitive + public void setDouble(Object obj, double d) + throws IllegalArgumentException, IllegalAccessException + { ++ if (!override) { ++ if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { ++ checkAccess(Reflection.getCallerClass(), clazz, obj, modifiers); ++ } ++ } + getFieldAccessor(obj).setDouble(obj, d); + } + +- // Convenience routine which performs security checks ++ // security check is done before calling this method + private FieldAccessor getFieldAccessor(Object obj) + throws IllegalAccessException + { +- doSecurityCheck(obj); + boolean ov = override; +- FieldAccessor a = (ov)? overrideFieldAccessor : fieldAccessor; +- return (a != null)? a : acquireFieldAccessor(ov); ++ FieldAccessor a = (ov) ? overrideFieldAccessor : fieldAccessor; ++ return (a != null) ? a : acquireFieldAccessor(ov); + } + + // NOTE that there is no synchronization used here. It is correct +@@ -961,10 +1069,7 @@ + // NOTE: be very careful if you change the stack depth of this + // routine. The depth of the "getCallerClass" call is hardwired so + // that the compiler can have an easier time if this gets inlined. +- private void doSecurityCheck(Object obj) throws IllegalAccessException { +- if (!override) { +- if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { +- Class caller = Reflection.getCallerClass(4); ++ private void checkAccess(Class caller, Class clazz, Object obj, int modifiers) throws IllegalAccessException { + Class targetClass = ((obj == null || !Modifier.isProtected(modifiers)) + ? clazz + : obj.getClass()); +@@ -980,8 +1085,6 @@ + securityCheckCache = caller; + securityCheckTargetClassCache = targetClass; + } +- } +- } + } + + /* +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/reflect/Method.java +--- jdk/src/share/classes/java/lang/reflect/Method.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/reflect/Method.java Mon Oct 21 18:05:56 2013 +0100 +@@ -25,6 +25,7 @@ + + package java.lang.reflect; + ++import sun.reflect.CallerSensitive; + import sun.reflect.MethodAccessor; + import sun.reflect.Reflection; + import sun.reflect.generics.repository.MethodRepository; +@@ -587,13 +588,18 @@ + * @exception ExceptionInInitializerError if the initialization + * provoked by this method fails. + */ ++ @CallerSensitive + public Object invoke(Object obj, Object... args) + throws IllegalAccessException, IllegalArgumentException, + InvocationTargetException + { + if (!override) { + if (!Reflection.quickCheckMemberAccess(clazz, modifiers)) { +- Class caller = Reflection.getCallerClass(1); ++ // Until there is hotspot @CallerSensitive support ++ // can't call Reflection.getCallerClass() here ++ // Workaround for now: add a frame getCallerClass to ++ // make the caller at stack depth 2 ++ Class<?> caller = getCallerClass(); + Class targetClass = ((obj == null || !Modifier.isProtected(modifiers)) + ? clazz + : obj.getClass()); +@@ -616,6 +622,16 @@ + return methodAccessor.invoke(obj, args); + } + ++ /* ++ * This method makes the frame count to be 2 to find the caller ++ */ ++ @CallerSensitive ++ private Class<?> getCallerClass() { ++ // Reflection.getCallerClass() currently returns the frame at depth 2 ++ // before the hotspot support is in. ++ return Reflection.getCallerClass(); ++ } ++ + /** + * Returns {@code true} if this method is a bridge + * method; returns {@code false} otherwise. +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/lang/reflect/Proxy.java +--- jdk/src/share/classes/java/lang/reflect/Proxy.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/lang/reflect/Proxy.java Mon Oct 21 18:05:56 2013 +0100 +@@ -38,6 +38,7 @@ + import java.util.Set; + import java.util.WeakHashMap; + import sun.misc.ProxyGenerator; ++import sun.reflect.CallerSensitive; + import sun.reflect.Reflection; + import sun.reflect.misc.ReflectUtil; + import sun.security.util.SecurityConstants; +@@ -404,28 +405,21 @@ + * @throws NullPointerException if the {@code interfaces} array + * argument or any of its elements are {@code null} + */ ++ @CallerSensitive + public static Class<?> getProxyClass(ClassLoader loader, + Class<?>... interfaces) + throws IllegalArgumentException + { +- return getProxyClass0(loader, interfaces); // stack walk magic: do not refactor +- } +- +- private static void checkProxyLoader(ClassLoader ccl, +- ClassLoader loader) +- { + SecurityManager sm = System.getSecurityManager(); + if (sm != null) { +- if (loader == null && ccl != null) { +- if (!ProxyAccessHelper.allowNullLoader) { +- sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); +- } +- } ++ checkProxyAccess(Reflection.getCallerClass(), loader, interfaces); + } ++ ++ return getProxyClass0(loader, interfaces); + } + + /* +- * Generate a proxy class (caller-sensitive). ++ * Check permissions required to create a proxy class. + * + * To define a proxy class, it performs the access checks as in + * Class.forName (VM will invoke ClassLoader.checkPackageAccess): +@@ -442,16 +436,28 @@ + * will throw IllegalAccessError when the generated proxy class is + * being defined via the defineClass0 method. + */ ++ private static void checkProxyAccess(Class<?> caller, ++ ClassLoader loader, ++ Class<?>... interfaces) ++ { ++ SecurityManager sm = System.getSecurityManager(); ++ if (sm != null) { ++ ClassLoader ccl = caller.getClassLoader(); ++ if (loader == null && ccl != null) { ++ if (!ProxyAccessHelper.allowNullLoader) { ++ sm.checkPermission(SecurityConstants.GET_CLASSLOADER_PERMISSION); ++ } ++ } ++ ReflectUtil.checkProxyPackageAccess(ccl, interfaces); ++ } ++ } ++ ++ /** ++ * Generate a proxy class. Must call the checkProxyAccess method ++ * to perform permission checks before calling this. ++ */ + private static Class<?> getProxyClass0(ClassLoader loader, + Class<?>... interfaces) { +- SecurityManager sm = System.getSecurityManager(); +- if (sm != null) { +- final int CALLER_FRAME = 3; // 0: Reflection, 1: getProxyClass0 2: Proxy 3: caller +- final Class<?> caller = Reflection.getCallerClass(CALLER_FRAME); +- final ClassLoader ccl = caller.getClassLoader(); +- checkProxyLoader(ccl, loader); +- ReflectUtil.checkProxyPackageAccess(ccl, interfaces); +- } + if (interfaces.length > 65535) { + throw new IllegalArgumentException("interface limit exceeded"); + } +@@ -692,6 +698,7 @@ + * if the invocation handler, {@code h}, is + * {@code null} + */ ++ @CallerSensitive + public static Object newProxyInstance(ClassLoader loader, + Class<?>[] interfaces, + InvocationHandler h) +@@ -701,10 +708,15 @@ + throw new NullPointerException(); + } + ++ final SecurityManager sm = System.getSecurityManager(); ++ if (sm != null) { ++ checkProxyAccess(Reflection.getCallerClass(), loader, interfaces); ++ } ++ + /* + * Look up or generate the designated proxy class. + */ +- Class<?> cl = getProxyClass0(loader, interfaces); // stack walk magic: do not refactor ++ Class<?> cl = getProxyClass0(loader, interfaces); + + /* + * Invoke its constructor with the designated invocation handler. +@@ -712,7 +724,6 @@ + try { + final Constructor<?> cons = cl.getConstructor(constructorParams); + final InvocationHandler ih = h; +- SecurityManager sm = System.getSecurityManager(); + if (sm != null && ProxyAccessHelper.needsNewInstanceCheck(cl)) { + // create proxy instance with doPrivilege as the proxy class may + // implement non-public interfaces that requires a special permission +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/security/AccessController.java +--- jdk/src/share/classes/java/security/AccessController.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/security/AccessController.java Mon Oct 21 18:05:56 2013 +0100 +@@ -26,6 +26,8 @@ + package java.security; + + import sun.security.util.Debug; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * <p> The AccessController class is used for access control operations +@@ -264,6 +266,7 @@ + * @see java.security.DomainCombiner + */ + ++ @CallerSensitive + public static native <T> T doPrivileged(PrivilegedAction<T> action); + + /** +@@ -288,14 +291,14 @@ + * + * @since 1.6 + */ ++ @CallerSensitive + public static <T> T doPrivilegedWithCombiner(PrivilegedAction<T> action) { +- + AccessControlContext acc = getStackAccessControlContext(); + if (acc == null) { + return AccessController.doPrivileged(action); + } + DomainCombiner dc = acc.getAssignedCombiner(); +- return AccessController.doPrivileged(action, preserveCombiner(dc)); ++ return AccessController.doPrivileged(action, preserveCombiner(dc, Reflection.getCallerClass())); + } + + +@@ -326,6 +329,7 @@ + * @see #doPrivileged(PrivilegedAction) + * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) + */ ++ @CallerSensitive + public static native <T> T doPrivileged(PrivilegedAction<T> action, + AccessControlContext context); + +@@ -353,6 +357,7 @@ + * @see #doPrivilegedWithCombiner(PrivilegedExceptionAction) + * @see java.security.DomainCombiner + */ ++ @CallerSensitive + public static native <T> T + doPrivileged(PrivilegedExceptionAction<T> action) + throws PrivilegedActionException; +@@ -383,6 +388,7 @@ + * + * @since 1.6 + */ ++ @CallerSensitive + public static <T> T doPrivilegedWithCombiner + (PrivilegedExceptionAction<T> action) throws PrivilegedActionException { + +@@ -391,26 +397,18 @@ + return AccessController.doPrivileged(action); + } + DomainCombiner dc = acc.getAssignedCombiner(); +- return AccessController.doPrivileged(action, preserveCombiner(dc)); ++ return AccessController.doPrivileged(action, preserveCombiner(dc, Reflection.getCallerClass())); + } + + /** + * preserve the combiner across the doPrivileged call + */ +- private static AccessControlContext preserveCombiner +- (DomainCombiner combiner) { +- +- /** +- * callerClass[0] = Reflection.getCallerClass +- * callerClass[1] = AccessController.preserveCombiner +- * callerClass[2] = AccessController.doPrivileged +- * callerClass[3] = caller +- */ +- final Class callerClass = sun.reflect.Reflection.getCallerClass(3); ++ private static AccessControlContext preserveCombiner(DomainCombiner combiner, ++ final Class<?> caller) { + ProtectionDomain callerPd = doPrivileged + (new PrivilegedAction<ProtectionDomain>() { + public ProtectionDomain run() { +- return callerClass.getProtectionDomain(); ++ return caller.getProtectionDomain(); + } + }); + +@@ -455,6 +453,7 @@ + * @see #doPrivileged(PrivilegedAction) + * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) + */ ++ @CallerSensitive + public static native <T> T + doPrivileged(PrivilegedExceptionAction<T> action, + AccessControlContext context) +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/sql/DriverManager.java +--- jdk/src/share/classes/java/sql/DriverManager.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/sql/DriverManager.java Mon Oct 21 18:05:56 2013 +0100 +@@ -30,6 +30,8 @@ + import java.util.ServiceLoader; + import java.security.AccessController; + import java.security.PrivilegedAction; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + + /** +@@ -159,14 +161,10 @@ + * @return a Connection to the URL + * @exception SQLException if a database access error occurs + */ ++ @CallerSensitive + public static Connection getConnection(String url, + java.util.Properties info) throws SQLException { +- +- // Gets the classloader of the code that called this method, may +- // be null. +- ClassLoader callerCL = DriverManager.getCallerClassLoader(); +- +- return (getConnection(url, info, callerCL)); ++ return (getConnection(url, info, Reflection.getCallerClass())); + } + + /** +@@ -182,14 +180,11 @@ + * @return a connection to the URL + * @exception SQLException if a database access error occurs + */ ++ @CallerSensitive + public static Connection getConnection(String url, + String user, String password) throws SQLException { + java.util.Properties info = new java.util.Properties(); + +- // Gets the classloader of the code that called this method, may +- // be null. +- ClassLoader callerCL = DriverManager.getCallerClassLoader(); +- + if (user != null) { + info.put("user", user); + } +@@ -197,7 +192,7 @@ + info.put("password", password); + } + +- return (getConnection(url, info, callerCL)); ++ return (getConnection(url, info, Reflection.getCallerClass())); + } + + /** +@@ -210,16 +205,12 @@ + * @return a connection to the URL + * @exception SQLException if a database access error occurs + */ ++ @CallerSensitive + public static Connection getConnection(String url) + throws SQLException { + + java.util.Properties info = new java.util.Properties(); +- +- // Gets the classloader of the code that called this method, may +- // be null. +- ClassLoader callerCL = DriverManager.getCallerClassLoader(); +- +- return (getConnection(url, info, callerCL)); ++ return (getConnection(url, info, Reflection.getCallerClass())); + } + + /** +@@ -233,6 +224,7 @@ + * that can connect to the given URL + * @exception SQLException if a database access error occurs + */ ++ @CallerSensitive + public static Driver getDriver(String url) + throws SQLException { + java.util.Vector drivers = null; +@@ -248,9 +240,7 @@ + drivers = readDrivers; + } + +- // Gets the classloader of the code that called this method, may +- // be null. +- ClassLoader callerCL = DriverManager.getCallerClassLoader(); ++ Class<?> callerClass = Reflection.getCallerClass(); + + // Walk through the loaded drivers attempting to locate someone + // who understands the given URL. +@@ -258,7 +248,7 @@ + DriverInfo di = (DriverInfo)drivers.elementAt(i); + // If the caller does not have permission to load the driver then + // skip it. +- if ( getCallerClass(callerCL, di.driverClassName ) != ++ if ( getCallerClass(callerClass, di.driverClassName ) != + di.driverClass ) { + println(" skipping: " + di); + continue; +@@ -319,11 +309,10 @@ + * @param driver the JDBC Driver to drop + * @exception SQLException if a database access error occurs + */ ++ @CallerSensitive + public static synchronized void deregisterDriver(Driver driver) + throws SQLException { +- // Gets the classloader of the code that called this method, +- // may be null. +- ClassLoader callerCL = DriverManager.getCallerClassLoader(); ++ Class<?> callerClass = Reflection.getCallerClass(); + println("DriverManager.deregisterDriver: " + driver); + + // Walk through the loaded drivers. +@@ -343,7 +332,7 @@ + + // If the caller does not have permission to load the driver then + // throw a security exception. +- if (getCallerClass(callerCL, di.driverClassName ) != di.driverClass ) { ++ if (getCallerClass(callerClass, di.driverClassName ) != di.driverClass) { + throw new SecurityException(); + } + +@@ -363,6 +352,7 @@ + * + * @return the list of JDBC Drivers loaded by the caller's class loader + */ ++ @CallerSensitive + public static java.util.Enumeration<Driver> getDrivers() { + java.util.Vector<Driver> result = new java.util.Vector<Driver>(); + java.util.Vector drivers = null; +@@ -376,16 +366,14 @@ + drivers = readDrivers; + } + +- // Gets the classloader of the code that called this method, may +- // be null. +- ClassLoader callerCL = DriverManager.getCallerClassLoader(); ++ Class<?> callerClass = Reflection.getCallerClass(); + + // Walk through the loaded drivers. + for (int i = 0; i < drivers.size(); i++) { + DriverInfo di = (DriverInfo)drivers.elementAt(i); + // If the caller does not have permission to load the driver then + // skip it. +- if ( getCallerClass(callerCL, di.driverClassName ) != di.driverClass ) { ++ if ( getCallerClass(callerClass, di.driverClassName) != di.driverClass ) { + println(" skipping: " + di); + continue; + } +@@ -481,6 +469,12 @@ + + //------------------------------------------------------------------------ + ++ private static Class getCallerClass(Class<?> caller, ++ String driverClassName) { ++ ClassLoader callerCL = caller != null ? caller.getClassLoader() : null; ++ return getCallerClass(callerCL, driverClassName); ++ } ++ + // Returns the class object that would be created if the code calling the + // driver manager had loaded the driver class, or null if the class + // is inaccessible. +@@ -573,7 +567,7 @@ + + // Worker method called by the public getConnection() methods. + private static Connection getConnection( +- String url, java.util.Properties info, ClassLoader callerCL) throws SQLException { ++ String url, java.util.Properties info, Class<?> caller) throws SQLException { + java.util.Vector drivers = null; + /* + * When callerCl is null, we should check the application's +@@ -581,11 +575,12 @@ + * classloader, so that the JDBC driver class outside rt.jar + * can be loaded from here. + */ +- synchronized(DriverManager.class) { +- // synchronize loading of the correct classloader. +- if(callerCL == null) { +- callerCL = Thread.currentThread().getContextClassLoader(); +- } ++ ClassLoader callerCL = caller != null ? caller.getClassLoader() : null; ++ synchronized (DriverManager.class) { ++ // synchronize loading of the correct classloader. ++ if (callerCL == null) { ++ callerCL = Thread.currentThread().getContextClassLoader(); ++ } + } + + if(url == null) { +@@ -666,10 +661,6 @@ + private static boolean initialized = false; + + private static Object logSync = new Object(); +- +- /* Returns the caller's class loader, or null if none */ +- private static native ClassLoader getCallerClassLoader(); +- + } + + // DriverInfo is a package-private support class. +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/util/ResourceBundle.java +--- jdk/src/share/classes/java/util/ResourceBundle.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/util/ResourceBundle.java Mon Oct 21 18:05:56 2013 +0100 +@@ -56,6 +56,8 @@ + import java.util.concurrent.ConcurrentMap; + import java.util.jar.JarEntry; + ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * +@@ -421,14 +423,10 @@ + + /* + * Automatic determination of the ClassLoader to be used to load +- * resources on behalf of the client. N.B. The client is getLoader's +- * caller's caller. ++ * resources on behalf of the client. + */ +- private static ClassLoader getLoader() { +- Class[] stack = getClassContext(); +- /* Magic number 2 identifies our caller's caller */ +- Class c = stack[2]; +- ClassLoader cl = (c == null) ? null : c.getClassLoader(); ++ private static ClassLoader getLoader(Class<?> caller) { ++ ClassLoader cl = caller == null ? null : caller.getClassLoader(); + if (cl == null) { + // When the caller's loader is the boot class loader, cl is null + // here. In that case, ClassLoader.getSystemClassLoader() may +@@ -442,8 +440,6 @@ + return cl; + } + +- private static native Class[] getClassContext(); +- + /** + * A wrapper of ClassLoader.getSystemClassLoader(). + */ +@@ -728,11 +724,12 @@ + * if no resource bundle for the specified base name can be found + * @return a resource bundle for the given base name and the default locale + */ ++ @CallerSensitive + public static final ResourceBundle getBundle(String baseName) + { + return getBundleImpl(baseName, Locale.getDefault(), + /* must determine loader here, else we break stack invariant */ +- getLoader(), ++ getLoader(Reflection.getCallerClass()), + Control.INSTANCE); + } + +@@ -770,11 +767,12 @@ + * needed. + * @since 1.6 + */ ++ @CallerSensitive + public static final ResourceBundle getBundle(String baseName, + Control control) { + return getBundleImpl(baseName, Locale.getDefault(), + /* must determine loader here, else we break stack invariant */ +- getLoader(), ++ getLoader(Reflection.getCallerClass()), + control); + } + +@@ -799,12 +797,13 @@ + * if no resource bundle for the specified base name can be found + * @return a resource bundle for the given base name and locale + */ ++ @CallerSensitive + public static final ResourceBundle getBundle(String baseName, + Locale locale) + { + return getBundleImpl(baseName, locale, + /* must determine loader here, else we break stack invariant */ +- getLoader(), ++ getLoader(Reflection.getCallerClass()), + Control.INSTANCE); + } + +@@ -845,11 +844,12 @@ + * needed. + * @since 1.6 + */ ++ @CallerSensitive + public static final ResourceBundle getBundle(String baseName, Locale targetLocale, + Control control) { + return getBundleImpl(baseName, targetLocale, + /* must determine loader here, else we break stack invariant */ +- getLoader(), ++ getLoader(Reflection.getCallerClass()), + control); + } + +@@ -1716,8 +1716,9 @@ + * @since 1.6 + * @see ResourceBundle.Control#getTimeToLive(String,Locale) + */ ++ @CallerSensitive + public static final void clearCache() { +- clearCache(getLoader()); ++ clearCache(getLoader(Reflection.getCallerClass())); + } + + /** +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java +--- jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java Mon Oct 21 18:05:56 2013 +0100 +@@ -34,8 +34,10 @@ + */ + + package java.util.concurrent.atomic; ++import java.lang.reflect.*; + import sun.misc.Unsafe; +-import java.lang.reflect.*; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * A reflection-based utility that enables atomic updates to +@@ -69,8 +71,9 @@ + * @throws RuntimeException with a nested reflection-based + * exception if the class does not hold field or is the wrong type + */ ++ @CallerSensitive + public static <U> AtomicIntegerFieldUpdater<U> newUpdater(Class<U> tclass, String fieldName) { +- return new AtomicIntegerFieldUpdaterImpl<U>(tclass, fieldName); ++ return new AtomicIntegerFieldUpdaterImpl<U>(tclass, fieldName, Reflection.getCallerClass()); + } + + /** +@@ -268,13 +271,11 @@ + private final Class<T> tclass; + private final Class cclass; + +- AtomicIntegerFieldUpdaterImpl(Class<T> tclass, String fieldName) { ++ AtomicIntegerFieldUpdaterImpl(Class<T> tclass, String fieldName, Class<?> caller) { + Field field = null; +- Class caller = null; + int modifiers = 0; + try { + field = tclass.getDeclaredField(fieldName); +- caller = sun.reflect.Reflection.getCallerClass(3); + modifiers = field.getModifiers(); + sun.reflect.misc.ReflectUtil.ensureMemberAccess( + caller, tclass, null, modifiers); +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java +--- jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java Mon Oct 21 18:05:56 2013 +0100 +@@ -34,8 +34,10 @@ + */ + + package java.util.concurrent.atomic; ++import java.lang.reflect.*; + import sun.misc.Unsafe; +-import java.lang.reflect.*; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * A reflection-based utility that enables atomic updates to +@@ -69,11 +71,13 @@ + * @throws RuntimeException with a nested reflection-based + * exception if the class does not hold field or is the wrong type. + */ ++ @CallerSensitive + public static <U> AtomicLongFieldUpdater<U> newUpdater(Class<U> tclass, String fieldName) { ++ Class<?> caller = Reflection.getCallerClass(); + if (AtomicLong.VM_SUPPORTS_LONG_CAS) +- return new CASUpdater<U>(tclass, fieldName); ++ return new CASUpdater<U>(tclass, fieldName, caller); + else +- return new LockedUpdater<U>(tclass, fieldName); ++ return new LockedUpdater<U>(tclass, fieldName, caller); + } + + /** +@@ -267,13 +271,11 @@ + private final Class<T> tclass; + private final Class cclass; + +- CASUpdater(Class<T> tclass, String fieldName) { ++ CASUpdater(Class<T> tclass, String fieldName, Class<?> caller) { + Field field = null; +- Class caller = null; + int modifiers = 0; + try { + field = tclass.getDeclaredField(fieldName); +- caller = sun.reflect.Reflection.getCallerClass(3); + modifiers = field.getModifiers(); + sun.reflect.misc.ReflectUtil.ensureMemberAccess( + caller, tclass, null, modifiers); +@@ -350,13 +352,11 @@ + private final Class<T> tclass; + private final Class cclass; + +- LockedUpdater(Class<T> tclass, String fieldName) { ++ LockedUpdater(Class<T> tclass, String fieldName, Class<?> caller) { + Field field = null; +- Class caller = null; + int modifiers = 0; + try { + field = tclass.getDeclaredField(fieldName); +- caller = sun.reflect.Reflection.getCallerClass(3); + modifiers = field.getModifiers(); + sun.reflect.misc.ReflectUtil.ensureMemberAccess( + caller, tclass, null, modifiers); +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java +--- jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java Mon Oct 21 18:05:56 2013 +0100 +@@ -34,8 +34,10 @@ + */ + + package java.util.concurrent.atomic; ++import java.lang.reflect.*; + import sun.misc.Unsafe; +-import java.lang.reflect.*; ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; + + /** + * A reflection-based utility that enables atomic updates to +@@ -89,10 +91,12 @@ + * @throws RuntimeException with a nested reflection-based + * exception if the class does not hold field or is the wrong type. + */ ++ @CallerSensitive + public static <U, W> AtomicReferenceFieldUpdater<U,W> newUpdater(Class<U> tclass, Class<W> vclass, String fieldName) { + return new AtomicReferenceFieldUpdaterImpl<U,W>(tclass, + vclass, +- fieldName); ++ fieldName, ++ Reflection.getCallerClass()); + } + + /** +@@ -200,14 +204,13 @@ + + AtomicReferenceFieldUpdaterImpl(Class<T> tclass, + Class<V> vclass, +- String fieldName) { ++ String fieldName, ++ Class<?> caller) { + Field field = null; + Class fieldClass = null; +- Class caller = null; + int modifiers = 0; + try { + field = tclass.getDeclaredField(fieldName); +- caller = sun.reflect.Reflection.getCallerClass(3); + modifiers = field.getModifiers(); + sun.reflect.misc.ReflectUtil.ensureMemberAccess( + caller, tclass, null, modifiers); +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/java/util/logging/Logger.java +--- jdk/src/share/classes/java/util/logging/Logger.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/java/util/logging/Logger.java Mon Oct 21 18:05:56 2013 +0100 +@@ -298,13 +298,10 @@ + } + } + +- private static Logger demandLogger(String name, String resourceBundleName) { ++ private static Logger demandLogger(String name, String resourceBundleName, Class<?> caller) { + LogManager manager = LogManager.getLogManager(); + SecurityManager sm = System.getSecurityManager(); + if (sm != null && !SystemLoggerHelper.disableCallerCheck) { +- // 0: Reflection 1: Logger.getLoggerContext 2: Logger.getLogger 3: caller +- final int SKIP_FRAMES = 3; +- Class<?> caller = sun.reflect.Reflection.getCallerClass(SKIP_FRAMES); + if (caller.getClassLoader() == null) { + return manager.demandSystemLogger(name, resourceBundleName); + } +@@ -339,8 +336,9 @@ + * @return a suitable Logger + * @throws NullPointerException if the name is null. + */ ++ @CallerSensitive + public static synchronized Logger getLogger(String name) { +- return demandLogger(name, null); ++ return demandLogger(name, null, Reflection.getCallerClass()); + } + + /** +@@ -382,8 +380,9 @@ + * a different resource bundle name. + * @throws NullPointerException if the name is null. + */ ++ @CallerSensitive + public static synchronized Logger getLogger(String name, String resourceBundleName) { +- Logger result = demandLogger(name, resourceBundleName); ++ Logger result = demandLogger(name, resourceBundleName, Reflection.getCallerClass()); + if (result.resourceBundleName == null) { + // Note: we may get a MissingResourceException here. + result.setupResourceInfo(resourceBundleName); +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java +--- jdk/src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java Mon Oct 21 18:05:56 2013 +0100 +@@ -30,6 +30,8 @@ + import java.util.Map; + import java.lang.reflect.*; + import javax.sql.rowset.RowSetWarning; ++import sun.reflect.CallerSensitive; ++import sun.reflect.misc.ReflectUtil; + + /** + * A serializable mapping in the Java programming language of an SQL +@@ -137,6 +139,7 @@ + * @throws SerialException if an error is encountered accessing + * the serialized object + */ ++ @CallerSensitive + public Field[] getFields() throws SerialException { + if (fields != null) { + Class c = this.obj.getClass(); +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/sun/misc/Unsafe.java +--- jdk/src/share/classes/sun/misc/Unsafe.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/sun/misc/Unsafe.java Mon Oct 21 18:05:56 2013 +0100 +@@ -28,6 +28,9 @@ + import java.security.*; + import java.lang.reflect.*; + ++import sun.reflect.CallerSensitive; ++import sun.reflect.Reflection; ++ + + /** + * A collection of methods for performing low-level, unsafe operations. +@@ -80,8 +83,9 @@ + * <code>checkPropertiesAccess</code> method doesn't allow + * access to the system properties. + */ ++ @CallerSensitive + public static Unsafe getUnsafe() { +- Class cc = sun.reflect.Reflection.getCallerClass(2); ++ Class cc = Reflection.getCallerClass(); + if (cc.getClassLoader() != null) + throw new SecurityException("Unsafe"); + return theUnsafe; +@@ -708,6 +712,12 @@ + ClassLoader loader, + ProtectionDomain protectionDomain); + ++ /** ++ * @deprecated Use defineClass(String, byte[], int, int, ClassLoader, ProtectionDomain) ++ * instead. This method will be removed in JDK 8. ++ */ ++ @Deprecated ++ @CallerSensitive + public native Class defineClass(String name, byte[] b, int off, int len); + + /** Allocate an instance but do not run any constructor. +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/sun/reflect/CallerSensitive.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/src/share/classes/sun/reflect/CallerSensitive.java Mon Oct 21 18:05:56 2013 +0100 +@@ -0,0 +1,41 @@ ++/* ++ * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. Oracle designates this ++ * particular file as subject to the "Classpath" exception as provided ++ * by Oracle in the LICENSE file that accompanied this code. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++package sun.reflect; ++ ++import java.lang.annotation.*; ++import static java.lang.annotation.ElementType.*; ++ ++/** ++ * A method annotated @CallerSensitive is sensitive to its calling class, ++ * via {@link sun.reflect.Reflection#getCallerClass Reflection.getCallerClass}, ++ * or via some equivalent. ++ * ++ * @author John R. Rose ++ */ ++@Retention(RetentionPolicy.RUNTIME) ++@Target({METHOD}) ++public @interface CallerSensitive { ++} +diff -r e56220b54fe2 -r d206cb658a99 src/share/classes/sun/reflect/Reflection.java +--- jdk/src/share/classes/sun/reflect/Reflection.java Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/classes/sun/reflect/Reflection.java Mon Oct 21 18:05:56 2013 +0100 +@@ -52,16 +52,11 @@ + methodFilterMap = new HashMap<Class,String[]>(); + } + +- /** Returns the class of the method <code>realFramesToSkip</code> +- frames up the stack (zero-based), ignoring frames associated +- with java.lang.reflect.Method.invoke() and its implementation. +- The first frame is that associated with this method, so +- <code>getCallerClass(0)</code> returns the Class object for +- sun.reflect.Reflection. Frames associated with +- java.lang.reflect.Method.invoke() and its implementation are +- completely ignored and do not count toward the number of "real" +- frames skipped. */ +- public static native Class getCallerClass(int realFramesToSkip); ++ /** Returns the class of the caller of the method calling this method, ++ ignoring frames associated with java.lang.reflect.Method.invoke() ++ and its implementation. */ ++ @CallerSensitive ++ public static native Class getCallerClass(); + + /** Retrieves the access flags written to the class file. For + inner classes these flags may differ from those returned by +@@ -322,4 +317,27 @@ + } + return newMembers; + } ++ ++ /** ++ * Tests if the given method is caller-sensitive and the declaring class ++ * is defined by either the bootstrap class loader or extension class loader. ++ */ ++ public static boolean isCallerSensitive(Method m) { ++ final ClassLoader loader = m.getDeclaringClass().getClassLoader(); ++ if (loader == null || isExtClassLoader(loader)) { ++ return m.isAnnotationPresent(CallerSensitive.class); ++ } ++ return false; ++ } ++ ++ private static boolean isExtClassLoader(ClassLoader loader) { ++ ClassLoader cl = ClassLoader.getSystemClassLoader(); ++ while (cl != null) { ++ if (cl.getParent() == null && cl == loader) { ++ return true; ++ } ++ cl = cl.getParent(); ++ } ++ return false; ++ } + } +diff -r e56220b54fe2 -r d206cb658a99 src/share/native/java/lang/SecurityManager.c +--- jdk/src/share/native/java/lang/SecurityManager.c Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/native/java/lang/SecurityManager.c Mon Oct 21 18:05:56 2013 +0100 +@@ -29,7 +29,6 @@ + + #include "java_lang_SecurityManager.h" + #include "java_lang_ClassLoader.h" +-#include "java_util_ResourceBundle.h" + + /* + * Make sure a security manager instance is initialized. +diff -r e56220b54fe2 -r d206cb658a99 src/share/native/sun/reflect/Reflection.c +--- jdk/src/share/native/sun/reflect/Reflection.c Wed Oct 16 05:39:53 2013 +0100 ++++ jdk/src/share/native/sun/reflect/Reflection.c Mon Oct 21 18:05:56 2013 +0100 +@@ -27,9 +27,11 @@ + #include "sun_reflect_Reflection.h" + + JNIEXPORT jclass JNICALL Java_sun_reflect_Reflection_getCallerClass +-(JNIEnv *env, jclass unused, jint depth) ++(JNIEnv *env, jclass unused) + { +- return JVM_GetCallerClass(env, depth); ++ // Until there is hotspot @CallerSensitive support, ++ // depth must always be 2 to get the immediate caller ++ return JVM_GetCallerClass(env, 2); + } + + JNIEXPORT jint JNICALL Java_sun_reflect_Reflection_getClassAccessFlags +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/sun/reflect/CallerSensitive/CallerSensitiveFinder.java Mon Oct 21 18:05:56 2013 +0100 +@@ -0,0 +1,248 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++import com.sun.tools.classfile.*; ++import static com.sun.tools.classfile.ConstantPool.*; ++import java.io.File; ++import java.io.IOException; ++import java.lang.reflect.InvocationTargetException; ++import java.nio.file.FileVisitResult; ++import java.nio.file.Files; ++import java.nio.file.Path; ++import java.nio.file.Paths; ++import java.nio.file.SimpleFileVisitor; ++import java.nio.file.attribute.BasicFileAttributes; ++import java.util.ArrayList; ++import java.util.List; ++import java.util.Set; ++import java.util.concurrent.Callable; ++import java.util.concurrent.ExecutionException; ++import java.util.concurrent.ExecutorService; ++import java.util.concurrent.Executors; ++import java.util.concurrent.FutureTask; ++ ++/* ++ * @test ++ * @bug 8010117 ++ * @summary Verify if CallerSensitive methods are annotated with ++ * sun.reflect.CallerSensitive annotation ++ * @build CallerSensitiveFinder MethodFinder ClassFileReader ++ * @run main/othervm/timeout=900 -mx800m CallerSensitiveFinder ++ */ ++public class CallerSensitiveFinder extends MethodFinder { ++ private static int numThreads = 3; ++ private static boolean verbose = false; ++ public static void main(String[] args) throws Exception { ++ List<Path> classes = new ArrayList<>(); ++ String testclasses = System.getProperty("test.classes", "."); ++ int i = 0; ++ while (i < args.length) { ++ String arg = args[i++]; ++ if (arg.equals("-v")) { ++ verbose = true; ++ } else { ++ Path p = Paths.get(testclasses, arg); ++ if (!p.toFile().exists()) { ++ throw new IllegalArgumentException(arg + " does not exist"); ++ } ++ classes.add(p); ++ } ++ } ++ if (classes.isEmpty()) { ++ classes.addAll(PlatformClassPath.getJREClasses()); ++ } ++ final String method = "sun/reflect/Reflection.getCallerClass"; ++ CallerSensitiveFinder csfinder = new CallerSensitiveFinder(method); ++ ++ List<String> errors = csfinder.run(classes); ++ if (!errors.isEmpty()) { ++ throw new RuntimeException(errors.size() + ++ " caller-sensitive methods are missing @CallerSensitive annotation"); ++ } ++ } ++ ++ private final List<String> csMethodsMissingAnnotation = new ArrayList<>(); ++ private final java.lang.reflect.Method mhnCallerSensitiveMethod; ++ public CallerSensitiveFinder(String... methods) throws Exception { ++ super(methods); ++ this.mhnCallerSensitiveMethod = getIsCallerSensitiveMethod(); ++ } ++ ++ static java.lang.reflect.Method getIsCallerSensitiveMethod() ++ throws ClassNotFoundException, NoSuchMethodException ++ { ++ Class<?> cls = Class.forName("java.lang.invoke.MethodHandleNatives"); ++ java.lang.reflect.Method m = cls.getDeclaredMethod("isCallerSensitiveMethod", Class.class, String.class); ++ m.setAccessible(true); ++ return m; ++ } ++ ++ boolean inMethodHandlesList(String classname, String method) { ++ Class<?> cls; ++ try { ++ cls = Class.forName(classname.replace('/', '.'), ++ false, ++ ClassLoader.getSystemClassLoader()); ++ return (Boolean) mhnCallerSensitiveMethod.invoke(null, cls, method); ++ } catch (ClassNotFoundException|IllegalAccessException e) { ++ throw new RuntimeException(e); ++ } catch (InvocationTargetException e) { ++ throw new RuntimeException(e.getCause()); ++ } ++ } ++ ++ public List<String> run(List<Path> classes) throws IOException, InterruptedException, ++ ExecutionException, ConstantPoolException ++ { ++ ExecutorService pool = Executors.newFixedThreadPool(numThreads); ++ for (Path path : classes) { ++ ClassFileReader reader = ClassFileReader.newInstance(path.toFile()); ++ for (ClassFile cf : reader.getClassFiles()) { ++ String classFileName = cf.getName(); ++ // for each ClassFile ++ // parse constant pool to find matching method refs ++ // parse each method (caller) ++ // - visit and find method references matching the given method name ++ pool.submit(getTask(cf)); ++ } ++ } ++ waitForCompletion(); ++ pool.shutdown(); ++ return csMethodsMissingAnnotation; ++ } ++ ++ private static final String CALLER_SENSITIVE_ANNOTATION = "Lsun/reflect/CallerSensitive;"; ++ private static boolean isCallerSensitive(Method m, ConstantPool cp) ++ throws ConstantPoolException ++ { ++ RuntimeAnnotations_attribute attr = ++ (RuntimeAnnotations_attribute)m.attributes.get(Attribute.RuntimeVisibleAnnotations); ++ int index = 0; ++ if (attr != null) { ++ for (int i = 0; i < attr.annotations.length; i++) { ++ Annotation ann = attr.annotations[i]; ++ String annType = cp.getUTF8Value(ann.type_index); ++ if (CALLER_SENSITIVE_ANNOTATION.equals(annType)) { ++ return true; ++ } ++ } ++ } ++ return false; ++ } ++ ++ public void referenceFound(ClassFile cf, Method m, Set<Integer> refs) ++ throws ConstantPoolException ++ { ++ String name = String.format("%s#%s %s", cf.getName(), ++ m.getName(cf.constant_pool), ++ m.descriptor.getValue(cf.constant_pool)); ++ if (!CallerSensitiveFinder.isCallerSensitive(m, cf.constant_pool)) { ++ csMethodsMissingAnnotation.add(name); ++ System.err.println(" Missing @CallerSensitive: " + name); ++ } else if (verbose) { ++ System.out.format("Caller found: %s%n", name); ++ } ++ if (m.access_flags.is(AccessFlags.ACC_PUBLIC)) { ++ if (!inMethodHandlesList(cf.getName(), m.getName(cf.constant_pool))) { ++ csMethodsMissingAnnotation.add(name); ++ System.err.println(" Missing in MethodHandleNatives list: " + name); ++ } else if (verbose) { ++ System.out.format("Caller found in MethodHandleNatives list: %s%n", name); ++ ++ } ++ } ++ } ++ ++ private final List<FutureTask<String>> tasks = new ArrayList<FutureTask<String>>(); ++ private FutureTask<String> getTask(final ClassFile cf) { ++ FutureTask<String> task = new FutureTask<String>(new Callable<String>() { ++ public String call() throws Exception { ++ return parse(cf); ++ } ++ }); ++ tasks.add(task); ++ return task; ++ } ++ ++ private void waitForCompletion() throws InterruptedException, ExecutionException { ++ for (FutureTask<String> t : tasks) { ++ String s = t.get(); ++ } ++ System.out.println("Parsed " + tasks.size() + " classfiles"); ++ } ++ ++ static class PlatformClassPath { ++ static List<Path> getJREClasses() throws IOException { ++ List<Path> result = new ArrayList<Path>(); ++ Path home = Paths.get(System.getProperty("java.home")); ++ ++ if (home.endsWith("jre")) { ++ // jar files in <javahome>/jre/lib ++ // skip <javahome>/lib ++ result.addAll(addJarFiles(home.resolve("lib"))); ++ } else if (home.resolve("lib").toFile().exists()) { ++ // either a JRE or a jdk build image ++ File classes = home.resolve("classes").toFile(); ++ if (classes.exists() && classes.isDirectory()) { ++ // jdk build outputdir ++ result.add(classes.toPath()); ++ } ++ // add other JAR files ++ result.addAll(addJarFiles(home.resolve("lib"))); ++ } else { ++ throw new RuntimeException("\"" + home + "\" not a JDK home"); ++ } ++ return result; ++ } ++ ++ static List<Path> addJarFiles(final Path root) throws IOException { ++ final List<Path> result = new ArrayList<Path>(); ++ final Path ext = root.resolve("ext"); ++ Files.walkFileTree(root, new SimpleFileVisitor<Path>() { ++ @Override ++ public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) ++ throws IOException { ++ if (dir.equals(root) || dir.equals(ext)) { ++ return FileVisitResult.CONTINUE; ++ } else { ++ // skip other cobundled JAR files ++ return FileVisitResult.SKIP_SUBTREE; ++ } ++ } ++ ++ @Override ++ public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) ++ throws IOException { ++ File f = file.toFile(); ++ String fn = f.getName(); ++ // parse alt-rt.jar as well ++ if (fn.endsWith(".jar") && !fn.equals("jfxrt.jar")) { ++ result.add(file); ++ } ++ return FileVisitResult.CONTINUE; ++ } ++ }); ++ return result; ++ } ++ } ++} +diff -r e56220b54fe2 -r d206cb658a99 test/sun/reflect/CallerSensitive/ClassFileReader.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/sun/reflect/CallerSensitive/ClassFileReader.java Mon Oct 21 18:05:56 2013 +0100 +@@ -0,0 +1,338 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++import com.sun.tools.classfile.ClassFile; ++import com.sun.tools.classfile.ConstantPoolException; ++import java.io.*; ++import java.nio.file.FileVisitResult; ++import java.nio.file.Files; ++import java.nio.file.Path; ++import java.nio.file.SimpleFileVisitor; ++import java.nio.file.attribute.BasicFileAttributes; ++import java.util.*; ++import java.util.jar.JarEntry; ++import java.util.jar.JarFile; ++ ++/** ++ * ClassFileReader reads ClassFile(s) of a given path that can be ++ * a .class file, a directory, or a JAR file. ++ */ ++public class ClassFileReader { ++ /** ++ * Returns a ClassFileReader instance of a given path. ++ */ ++ public static ClassFileReader newInstance(File path) throws IOException { ++ if (!path.exists()) { ++ throw new FileNotFoundException(path.getAbsolutePath()); ++ } ++ ++ if (path.isDirectory()) { ++ return new DirectoryReader(path.toPath()); ++ } else if (path.getName().endsWith(".jar")) { ++ return new JarFileReader(path.toPath()); ++ } else { ++ return new ClassFileReader(path.toPath()); ++ } ++ } ++ ++ /** ++ * Returns a ClassFileReader instance of a given JarFile. ++ */ ++ public static ClassFileReader newInstance(Path path, JarFile jf) throws IOException { ++ return new JarFileReader(path, jf); ++ } ++ ++ protected final Path path; ++ protected final String baseFileName; ++ private ClassFileReader(Path path) { ++ this.path = path; ++ this.baseFileName = path.getFileName() != null ++ ? path.getFileName().toString() ++ : path.toString(); ++ } ++ ++ public String getFileName() { ++ return baseFileName; ++ } ++ ++ /** ++ * Returns the ClassFile matching the given binary name ++ * or a fully-qualified class name. ++ */ ++ public ClassFile getClassFile(String name) throws IOException { ++ if (name.indexOf('.') > 0) { ++ int i = name.lastIndexOf('.'); ++ String pathname = name.replace('.', File.separatorChar) + ".class"; ++ if (baseFileName.equals(pathname) || ++ baseFileName.equals(pathname.substring(0, i) + "$" + ++ pathname.substring(i+1, pathname.length()))) { ++ return readClassFile(path); ++ } ++ } else { ++ if (baseFileName.equals(name.replace('/', File.separatorChar) + ".class")) { ++ return readClassFile(path); ++ } ++ } ++ return null; ++ } ++ ++ public Iterable<ClassFile> getClassFiles() throws IOException { ++ return new Iterable<ClassFile>() { ++ public Iterator<ClassFile> iterator() { ++ return new FileIterator(); ++ } ++ }; ++ } ++ ++ protected ClassFile readClassFile(Path p) throws IOException { ++ InputStream is = null; ++ try { ++ is = Files.newInputStream(p); ++ return ClassFile.read(is); ++ } catch (ConstantPoolException e) { ++ throw new ClassFileError(e); ++ } finally { ++ if (is != null) { ++ is.close(); ++ } ++ } ++ } ++ ++ class FileIterator implements Iterator<ClassFile> { ++ int count; ++ FileIterator() { ++ this.count = 0; ++ } ++ public boolean hasNext() { ++ return count == 0 && baseFileName.endsWith(".class"); ++ } ++ ++ public ClassFile next() { ++ if (!hasNext()) { ++ throw new NoSuchElementException(); ++ } ++ try { ++ ClassFile cf = readClassFile(path); ++ count++; ++ return cf; ++ } catch (IOException e) { ++ throw new ClassFileError(e); ++ } ++ } ++ ++ public void remove() { ++ throw new UnsupportedOperationException("Not supported yet."); ++ } ++ } ++ ++ public String toString() { ++ return path.toString(); ++ } ++ ++ private static class DirectoryReader extends ClassFileReader { ++ DirectoryReader(Path path) throws IOException { ++ super(path); ++ } ++ ++ public ClassFile getClassFile(String name) throws IOException { ++ if (name.indexOf('.') > 0) { ++ int i = name.lastIndexOf('.'); ++ String pathname = name.replace('.', File.separatorChar) + ".class"; ++ Path p = path.resolve(pathname); ++ if (!p.toFile().exists()) { ++ p = path.resolve(pathname.substring(0, i) + "$" + ++ pathname.substring(i+1, pathname.length())); ++ } ++ if (p.toFile().exists()) { ++ return readClassFile(p); ++ } ++ } else { ++ Path p = path.resolve(name + ".class"); ++ if (p.toFile().exists()) { ++ return readClassFile(p); ++ } ++ } ++ return null; ++ } ++ ++ public Iterable<ClassFile> getClassFiles() throws IOException { ++ final Iterator<ClassFile> iter = new DirectoryIterator(); ++ return new Iterable<ClassFile>() { ++ public Iterator<ClassFile> iterator() { ++ return iter; ++ } ++ }; ++ } ++ ++ private List<Path> walkTree(Path dir) throws IOException { ++ final List<Path> files = new ArrayList<Path>(); ++ Files.walkFileTree(dir, new SimpleFileVisitor<Path>() { ++ public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) ++ throws IOException { ++ if (file.toFile().getName().endsWith(".class")) { ++ files.add(file); ++ } ++ return FileVisitResult.CONTINUE; ++ } ++ }); ++ return files; ++ } ++ ++ class DirectoryIterator implements Iterator<ClassFile> { ++ private List<Path> entries; ++ private int index = 0; ++ DirectoryIterator() throws IOException { ++ entries = walkTree(path); ++ index = 0; ++ } ++ ++ public boolean hasNext() { ++ return index != entries.size(); ++ } ++ ++ public ClassFile next() { ++ if (!hasNext()) { ++ throw new NoSuchElementException(); ++ } ++ Path path = entries.get(index++); ++ try { ++ return readClassFile(path); ++ } catch (IOException e) { ++ throw new ClassFileError(e); ++ } ++ } ++ ++ public void remove() { ++ throw new UnsupportedOperationException("Not supported yet."); ++ } ++ } ++ } ++ ++ private static class JarFileReader extends ClassFileReader { ++ final JarFile jarfile; ++ JarFileReader(Path path) throws IOException { ++ this(path, new JarFile(path.toFile())); ++ } ++ JarFileReader(Path path, JarFile jf) throws IOException { ++ super(path); ++ this.jarfile = jf; ++ } ++ ++ public ClassFile getClassFile(String name) throws IOException { ++ if (name.indexOf('.') > 0) { ++ int i = name.lastIndexOf('.'); ++ String entryName = name.replace('.', '/') + ".class"; ++ JarEntry e = jarfile.getJarEntry(entryName); ++ if (e == null) { ++ e = jarfile.getJarEntry(entryName.substring(0, i) + "$" ++ + entryName.substring(i + 1, entryName.length())); ++ } ++ if (e != null) { ++ return readClassFile(e); ++ } ++ } else { ++ JarEntry e = jarfile.getJarEntry(name + ".class"); ++ if (e != null) { ++ return readClassFile(e); ++ } ++ } ++ return null; ++ } ++ ++ private ClassFile readClassFile(JarEntry e) throws IOException { ++ InputStream is = null; ++ try { ++ is = jarfile.getInputStream(e); ++ return ClassFile.read(is); ++ } catch (ConstantPoolException ex) { ++ throw new IOException(ex); ++ } finally { ++ if (is != null) ++ is.close(); ++ } ++ } ++ ++ public Iterable<ClassFile> getClassFiles() throws IOException { ++ final Iterator<ClassFile> iter = new JarFileIterator(); ++ return new Iterable<ClassFile>() { ++ public Iterator<ClassFile> iterator() { ++ return iter; ++ } ++ }; ++ } ++ ++ class JarFileIterator implements Iterator<ClassFile> { ++ private Enumeration<JarEntry> entries; ++ private JarEntry nextEntry; ++ JarFileIterator() { ++ this.entries = jarfile.entries(); ++ while (entries.hasMoreElements()) { ++ JarEntry e = entries.nextElement(); ++ String name = e.getName(); ++ if (name.endsWith(".class")) { ++ this.nextEntry = e; ++ break; ++ } ++ } ++ } ++ ++ public boolean hasNext() { ++ return nextEntry != null; ++ } ++ ++ public ClassFile next() { ++ if (!hasNext()) { ++ throw new NoSuchElementException(); ++ } ++ ++ ClassFile cf; ++ try { ++ cf = readClassFile(nextEntry); ++ } catch (IOException e) { ++ throw new ClassFileError(e); ++ } ++ JarEntry entry = nextEntry; ++ nextEntry = null; ++ while (entries.hasMoreElements()) { ++ JarEntry e = entries.nextElement(); ++ String name = e.getName(); ++ if (name.endsWith(".class")) { ++ nextEntry = e; ++ break; ++ } ++ } ++ return cf; ++ } ++ ++ public void remove() { ++ throw new UnsupportedOperationException("Not supported yet."); ++ } ++ } ++ } ++ ++ public static class ClassFileError extends Error { ++ public ClassFileError(Throwable t) { ++ super(t); ++ } ++ } ++} +diff -r e56220b54fe2 -r d206cb658a99 test/sun/reflect/CallerSensitive/MethodFinder.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/sun/reflect/CallerSensitive/MethodFinder.java Mon Oct 21 18:05:56 2013 +0100 +@@ -0,0 +1,201 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++import java.util.*; ++import com.sun.tools.classfile.*; ++import static com.sun.tools.classfile.ConstantPool.*; ++import com.sun.tools.classfile.Instruction.TypeKind; ++ ++/** ++ * MethodFinder utility class to find references to the given methods. ++ */ ++public abstract class MethodFinder { ++ final List<String> methods; ++ public MethodFinder(String... methods) { ++ this.methods = Arrays.asList(methods); ++ } ++ ++ /** ++ * A callback method will be invoked when a method referencing ++ * any of the lookup methods. ++ * ++ * @param cf ClassFile ++ * @param m Method ++ * @param refs Set of constant pool indices that reference the methods ++ * matching the given lookup method names ++ */ ++ public abstract void referenceFound(ClassFile cf, Method m, Set<Integer> refs) ++ throws ConstantPoolException; ++ ++ public String parse(ClassFile cf) throws ConstantPoolException { ++ List<Integer> cprefs = new ArrayList<Integer>(); ++ int index = 1; ++ for (ConstantPool.CPInfo cpInfo : cf.constant_pool.entries()) { ++ if (cpInfo.accept(cpVisitor, null)) { ++ cprefs.add(index); ++ } ++ index += cpInfo.size(); ++ } ++ ++ if (!cprefs.isEmpty()) { ++ for (Method m : cf.methods) { ++ Set<Integer> refs = new HashSet<Integer>(); ++ Code_attribute c_attr = (Code_attribute) m.attributes.get(Attribute.Code); ++ if (c_attr != null) { ++ for (Instruction instr : c_attr.getInstructions()) { ++ int idx = instr.accept(codeVisitor, cprefs); ++ if (idx > 0) { ++ refs.add(idx); ++ } ++ } ++ } ++ if (refs.size() > 0) { ++ referenceFound(cf, m, refs); ++ } ++ } ++ } ++ return cprefs.isEmpty() ? "" : cf.getName(); ++ } ++ ++ private ConstantPool.Visitor<Boolean,Void> cpVisitor = ++ new ConstantPool.Visitor<Boolean,Void>() ++ { ++ private boolean matches(CPRefInfo info) { ++ try { ++ CONSTANT_NameAndType_info nat = info.getNameAndTypeInfo(); ++ return matches(info.getClassName(), nat.getName(), nat.getType()); ++ } catch (ConstantPoolException ex) { ++ return false; ++ } ++ } ++ ++ private boolean matches(String cn, String name, String type) { ++ return methods.contains(cn + "." + name); ++ } ++ ++ public Boolean visitClass(CONSTANT_Class_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitInterfaceMethodref(CONSTANT_InterfaceMethodref_info info, Void p) { ++ return matches(info); ++ } ++ ++ public Boolean visitMethodref(CONSTANT_Methodref_info info, Void p) { ++ return matches(info); ++ } ++ ++ public Boolean visitDouble(CONSTANT_Double_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitFieldref(CONSTANT_Fieldref_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitFloat(CONSTANT_Float_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitInteger(CONSTANT_Integer_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitInvokeDynamic(CONSTANT_InvokeDynamic_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitLong(CONSTANT_Long_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitNameAndType(CONSTANT_NameAndType_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitMethodHandle(CONSTANT_MethodHandle_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitMethodType(CONSTANT_MethodType_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitString(CONSTANT_String_info info, Void p) { ++ return false; ++ } ++ ++ public Boolean visitUtf8(CONSTANT_Utf8_info info, Void p) { ++ return false; ++ } ++ }; ++ ++ private Instruction.KindVisitor<Integer, List<Integer>> codeVisitor = ++ new Instruction.KindVisitor<Integer, List<Integer>>() ++ { ++ public Integer visitNoOperands(Instruction instr, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitArrayType(Instruction instr, TypeKind kind, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitBranch(Instruction instr, int offset, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitConstantPoolRef(Instruction instr, int index, List<Integer> p) { ++ return p.contains(index) ? index : 0; ++ } ++ ++ public Integer visitConstantPoolRefAndValue(Instruction instr, int index, int value, List<Integer> p) { ++ return p.contains(index) ? index : 0; ++ } ++ ++ public Integer visitLocal(Instruction instr, int index, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitLocalAndValue(Instruction instr, int index, int value, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitLookupSwitch(Instruction instr, int default_, int npairs, int[] matches, int[] offsets, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitTableSwitch(Instruction instr, int default_, int low, int high, int[] offsets, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitValue(Instruction instr, int value, List<Integer> p) { ++ return 0; ++ } ++ ++ public Integer visitUnknown(Instruction instr, List<Integer> p) { ++ return 0; ++ } ++ }; ++} ++ +diff -r e56220b54fe2 -r d206cb658a99 test/sun/reflect/CallerSensitive/MissingCallerSensitive.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/sun/reflect/CallerSensitive/MissingCallerSensitive.java Mon Oct 21 18:05:56 2013 +0100 +@@ -0,0 +1,73 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/* ++ * @test ++ * @bug 8010117 ++ * @summary Test CallerSensitiveFinder to find missing annotation ++ * @compile -XDignore.symbol.file MissingCallerSensitive.java ++ * @build CallerSensitiveFinder MethodFinder ClassFileReader ++ * @run main/othervm MissingCallerSensitive ++ */ ++ ++import java.nio.file.Path; ++import java.nio.file.Paths; ++import java.util.*; ++public class MissingCallerSensitive { ++ public static void main(String[] args) throws Exception { ++ String testclasses = System.getProperty("test.classes", "."); ++ List<Path> classes = new ArrayList<>(); ++ classes.add(Paths.get(testclasses, "MissingCallerSensitive.class")); ++ ++ final String method = "sun/reflect/Reflection.getCallerClass"; ++ CallerSensitiveFinder csfinder = new CallerSensitiveFinder(method); ++ List<String> errors = csfinder.run(classes); ++ /* ++ * Expected 1 method missing @CallerSenitive and 2 methods not in ++ * the MethodHandleNatives CS list ++ */ ++ if (errors.size() != 3) { ++ throw new RuntimeException("Unexpected number of methods found: " + errors.size()); ++ } ++ int count=0; ++ for (String e : errors) { ++ if (e.startsWith("MissingCallerSensitive#missingCallerSensitiveAnnotation ")) { ++ count++; ++ } ++ } ++ if (count != 2) { ++ throw new RuntimeException("Error: expected 1 method missing annotation & missing in the list"); ++ } ++ } ++ ++ @sun.reflect.CallerSensitive ++ public ClassLoader getCallerLoader() { ++ Class<?> c = sun.reflect.Reflection.getCallerClass(); ++ return c.getClassLoader(); ++ } ++ ++ public ClassLoader missingCallerSensitiveAnnotation() { ++ Class<?> c = sun.reflect.Reflection.getCallerClass(); ++ return c.getClassLoader(); ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8010727-empty_logger_name.patch b/java/openjdk6/files/icedtea/openjdk/8010727-empty_logger_name.patch new file mode 100644 index 000000000000..307cd6877ba6 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8010727-empty_logger_name.patch @@ -0,0 +1,101 @@ +# HG changeset patch +# User mchung +# Date 1368544028 25200 +# Tue May 14 08:07:08 2013 -0700 +# Node ID e3eae7996a478cd07125110456836a42c8a504c6 +# Parent d4fca2113b280a7db03b67caae22e0ceafb51b89 +8010727: WLS fails to add a logger with "" in its own LogManager subclass instance +Reviewed-by: alanb, jgish + +diff -r d4fca2113b28 -r e3eae7996a47 src/share/classes/java/util/logging/LogManager.java +--- jdk/src/share/classes/java/util/logging/LogManager.java Fri Oct 25 17:51:03 2013 +0100 ++++ jdk/src/share/classes/java/util/logging/LogManager.java Tue May 14 08:07:08 2013 -0700 +@@ -486,7 +486,7 @@ + } + + synchronized void ensureRootLogger(Logger logger) { +- if (logger == manager.rootLogger) ++ if (logger.getName().isEmpty()) + return; + + // during initialization, rootLogger is null when +diff -r d4fca2113b28 -r e3eae7996a47 test/java/util/logging/LogManagerInstanceTest.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/LogManagerInstanceTest.java Tue May 14 08:07:08 2013 -0700 +@@ -0,0 +1,76 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++import java.util.logging.*; ++ ++/* ++ * @test ++ * @bug 8010727 ++ * @summary LogManager.addLogger should succeed to add a logger named "" ++ * if LogManager.getLogger("") returns null. ++ * ++ * @run main LogManagerInstanceTest ++ */ ++ ++public class LogManagerInstanceTest { ++ public static void main(String[] argv) { ++ LogManager mgr = LogManager.getLogManager(); ++ if (getRootLogger(mgr) == null) { ++ throw new RuntimeException("Root logger not exist"); ++ } ++ ++ SecondLogManager mgr2 = new SecondLogManager(); ++ Logger root = getRootLogger(mgr2); ++ if (mgr2.base != root) { ++ throw new RuntimeException(mgr2.base + " is not the root logger"); ++ } ++ } ++ ++ private static Logger getRootLogger(LogManager mgr) { ++ Logger l = mgr.getLogger(""); ++ if (l != null && !l.getName().isEmpty()) { ++ throw new RuntimeException(l.getName() + " is not an invalid root logger"); ++ } ++ return l; ++ } ++ ++ static class SecondLogManager extends LogManager { ++ final Logger base; ++ private SecondLogManager() { ++ Logger root = getLogger(""); ++ if (root == null) { ++ root = new BaseLogger("", null); ++ if (!super.addLogger(root)) ++ throw new RuntimeException("Fail to addLogger " + root); ++ } else { ++ System.out.println("Root logger already exists"); ++ } ++ this.base = root; ++ } ++ } ++ static class BaseLogger extends Logger { ++ BaseLogger(String name, String rbname) { ++ super(name, rbname); ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8010939-logmanager_deadlock.patch b/java/openjdk6/files/icedtea/openjdk/8010939-logmanager_deadlock.patch new file mode 100644 index 000000000000..5bf8a341ebf8 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8010939-logmanager_deadlock.patch @@ -0,0 +1,266 @@ +# HG changeset patch +# User jgish +# Date 1366415410 25200 +# Fri Apr 19 16:50:10 2013 -0700 +# Node ID ed410e3d08fe7792e6c08e411580564d2562c03e +# Parent e3eae7996a478cd07125110456836a42c8a504c6 +8010939: Deadlock in LogManager +Summary: re-order locks to avoid deadlock +Reviewed-by: mchung, alanb + +diff -r e3eae7996a47 -r ed410e3d08fe src/share/classes/java/util/logging/LogManager.java +--- jdk/src/share/classes/java/util/logging/LogManager.java Tue May 14 08:07:08 2013 -0700 ++++ jdk/src/share/classes/java/util/logging/LogManager.java Fri Apr 19 16:50:10 2013 -0700 +@@ -33,10 +33,8 @@ + import java.lang.ref.WeakReference; + import java.beans.PropertyChangeListener; + import java.beans.PropertyChangeSupport; +-import java.net.URL; + import sun.misc.JavaAWTAccess; + import sun.misc.SharedSecrets; +-import sun.security.action.GetPropertyAction; + + /** + * There is a single global LogManager object that is used to +@@ -151,7 +149,6 @@ + // The global LogManager object + private static LogManager manager; + +- private final static Handler[] emptyHandlers = { }; + private Properties props = new Properties(); + private PropertyChangeSupport changes + = new PropertyChangeSupport(LogManager.class); +@@ -506,14 +503,11 @@ + throw new NullPointerException(); + } + +- // cleanup some Loggers that have been GC'ed +- manager.drainLoggerRefQueueBounded(); +- + LoggerWeakRef ref = namedLoggers.get(name); + if (ref != null) { + if (ref.get() == null) { +- // It's possible that the Logger was GC'ed after the +- // drainLoggerRefQueueBounded() call above so allow ++ // It's possible that the Logger was GC'ed after a ++ // drainLoggerRefQueueBounded() call so allow + // a new one to be registered. + removeLogger(name); + } else { +@@ -561,6 +555,8 @@ + return true; + } + ++ // note: all calls to removeLogger are synchronized on LogManager's ++ // intrinsic lock + void removeLogger(String name) { + namedLoggers.remove(name); + } +@@ -845,6 +841,7 @@ + if (name == null) { + throw new NullPointerException(); + } ++ drainLoggerRefQueueBounded(); + LoggerContext cx = getUserContext(); + if (cx.addLocalLogger(logger)) { + // Do we have a per logger handler too? +diff -r e3eae7996a47 -r ed410e3d08fe test/java/util/logging/DrainFindDeadlockTest.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/DrainFindDeadlockTest.java Fri Apr 19 16:50:10 2013 -0700 +@@ -0,0 +1,196 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++import java.lang.management.ThreadInfo; ++import java.lang.management.ThreadMXBean; ++import java.lang.Thread.State; ++import java.io.IOException; ++import java.lang.management.ManagementFactory; ++import java.util.logging.LogManager; ++import java.util.logging.Logger; ++import java.util.Map; ++ ++/** ++ * @test ++ * @bug 8010939 ++ * @summary check for deadlock between findLogger() and drainLoggerRefQueueBounded() ++ * @author jim.gish@oracle.com ++ * @build DrainFindDeadlockTest ++ * @run main/othervm/timeout=10 DrainFindDeadlockTest ++ */ ++ ++/** ++ * This test is checking for a deadlock between ++ * LogManager$LoggerContext.findLogger() and ++ * LogManager.drainLoggerRefQueueBounded() (which could happen by calling ++ * Logger.getLogger() and LogManager.readConfiguration() in different threads) ++ */ ++public class DrainFindDeadlockTest { ++ private LogManager mgr = LogManager.getLogManager(); ++ private final static int MAX_ITERATIONS = 100; ++ ++ // Get a ThreadMXBean so we can check for deadlock. N.B. this may ++ // not be supported on all platforms, which means we will have to ++ // resort to the traditional test timeout method. However, if ++ // we have the support we'll get the deadlock details if one ++ // is detected. ++ private final static ThreadMXBean threadMXBean = ++ ManagementFactory.getThreadMXBean(); ++ private final boolean threadMXBeanDeadlockSupported = ++ threadMXBean.isSynchronizerUsageSupported(); ++ ++ public static void main(String... args) throws IOException, Exception { ++ new DrainFindDeadlockTest().testForDeadlock(); ++ } ++ ++ public static void randomDelay() { ++ int runs = (int) Math.random() * 1000000; ++ int c = 0; ++ ++ for (int i=0; i<runs; ++i) { ++ c=c+i; ++ } ++ } ++ ++ public void testForDeadlock() throws IOException, Exception { ++ System.out.println("Deadlock detection " ++ + (threadMXBeanDeadlockSupported ? "is" : "is not") + ++ " available."); ++ Thread setup = new Thread(new SetupLogger(), "SetupLogger"); ++ Thread readConfig = new Thread(new ReadConfig(), "ReadConfig"); ++ Thread check = new Thread(new DeadlockChecker(setup, readConfig), ++ "DeadlockChecker"); ++ ++ // make the threads daemon threads so they will go away when the ++ // test exits ++ setup.setDaemon(true); ++ readConfig.setDaemon(true); ++ check.setDaemon(true); ++ ++ check.start(); setup.start(); readConfig.start(); ++ try { ++ check.join(); ++ } catch (InterruptedException ex) { ++ ex.printStackTrace(); ++ } ++ try { ++ readConfig.join(); ++ setup.join(); ++ } catch (InterruptedException ex) { ++ ex.printStackTrace(); ++ } ++ System.out.println("Test passed"); ++ } ++ ++ class SetupLogger implements Runnable { ++ Logger logger = null; ++ ++ @Override ++ public void run() { ++ System.out.println("Running " + Thread.currentThread().getName()); ++ ++ for (int i=0; i < MAX_ITERATIONS; i++) { ++ logger = Logger.getLogger("DrainFindDeadlockTest"+i); ++ DrainFindDeadlockTest.randomDelay(); ++ } ++ } ++ } ++ ++ class ReadConfig implements Runnable { ++ @Override ++ public void run() { ++ System.out.println("Running " + Thread.currentThread().getName()); ++ for (int i=0; i < MAX_ITERATIONS; i++) { ++ try { ++ mgr.readConfiguration(); ++ } catch (IOException | SecurityException ex) { ++ throw new RuntimeException("FAILED: test setup problem", ex); ++ } ++ DrainFindDeadlockTest.randomDelay(); ++ } ++ } ++ } ++ ++ class DeadlockChecker implements Runnable { ++ Thread t1, t2; ++ ++ DeadlockChecker(Thread t1, Thread t2) { ++ this.t1 = t1; ++ this.t2 = t2; ++ } ++ ++ void checkState(Thread x, Thread y) { ++ // System.out.println("checkstate"); ++ boolean isXblocked = x.getState().equals(State.BLOCKED); ++ boolean isYblocked = y.getState().equals(State.BLOCKED); ++ long[] deadlockedThreads = null; ++ ++ if (isXblocked && isYblocked) { ++ System.out.println("threads blocked"); ++ // they are both blocked, but this doesn't necessarily mean ++ // they are deadlocked ++ if (threadMXBeanDeadlockSupported) { ++ System.out.println("checking for deadlock"); ++ deadlockedThreads = threadMXBean.findDeadlockedThreads(); ++ } else { ++ System.out.println("Can't check for deadlock"); ++ } ++ if (deadlockedThreads != null) { ++ System.out.println("We detected a deadlock! "); ++ ThreadInfo[] threadInfos = threadMXBean.getThreadInfo( ++ deadlockedThreads, true, true); ++ for (ThreadInfo threadInfo: threadInfos) { ++ System.out.println(threadInfo); ++ } ++ throw new RuntimeException("TEST FAILED: Deadlock detected"); ++ } ++ System.out.println("We may have a deadlock"); ++ Map<Thread, StackTraceElement[]> threadMap = ++ Thread.getAllStackTraces(); ++ dumpStack(threadMap.get(x), x); ++ dumpStack(threadMap.get(y), y); ++ } ++ } ++ ++ private void dumpStack(StackTraceElement[] aStackElt, Thread aThread) { ++ if (aStackElt != null) { ++ System.out.println("Thread:" + aThread.getName() + ": " + ++ aThread.getState()); ++ for (StackTraceElement element: aStackElt) { ++ System.out.println(" " + element); ++ } ++ } ++ } ++ ++ @Override ++ public void run() { ++ System.out.println("Running " + Thread.currentThread().getName()); ++ for (int i=0; i < MAX_ITERATIONS*2; i++) { ++ checkState(t1, t2); ++ try { ++ Thread.sleep(10); ++ } catch (InterruptedException ex) { ++ }; ++ } ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8011071-better_crypto_provider_handling.patch b/java/openjdk6/files/icedtea/openjdk/8011071-better_crypto_provider_handling.patch new file mode 100644 index 000000000000..223355f35f53 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8011071-better_crypto_provider_handling.patch @@ -0,0 +1,287 @@ +# HG changeset patch +# User ascarpino +# Date 1381846341 -3600 +# Tue Oct 15 15:12:21 2013 +0100 +# Node ID df887df12ad1543894fe79f753983754ceef5c73 +# Parent db4712506571ae3ae2d37b91e63641b18c3258f2 +8011071: Better crypto provider handling +Reviewed-by: hawtin, valeriep + +diff -r db4712506571 -r df887df12ad1 src/share/classes/com/sun/crypto/provider/DHPrivateKey.java +--- jdk/src/share/classes/com/sun/crypto/provider/DHPrivateKey.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/com/sun/crypto/provider/DHPrivateKey.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1997, 2007, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -279,22 +279,6 @@ + return new DHParameterSpec(this.p, this.g); + } + +- public String toString() { +- String LINE_SEP = System.getProperty("line.separator"); +- +- StringBuffer strbuf +- = new StringBuffer("SunJCE Diffie-Hellman Private Key:" +- + LINE_SEP + "x:" + LINE_SEP +- + Debug.toHexString(this.x) +- + LINE_SEP + "p:" + LINE_SEP +- + Debug.toHexString(this.p) +- + LINE_SEP + "g:" + LINE_SEP +- + Debug.toHexString(this.g)); +- if (this.l != 0) +- strbuf.append(LINE_SEP + "l:" + LINE_SEP + " " + this.l); +- return strbuf.toString(); +- } +- + private void parseKeyBits() throws InvalidKeyException { + try { + DerInputStream in = new DerInputStream(this.key); +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/ec/ECPrivateKeyImpl.java +--- jdk/src/share/classes/sun/security/ec/ECPrivateKeyImpl.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/ec/ECPrivateKeyImpl.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2006, 2013 Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -153,12 +153,4 @@ + throw new InvalidKeyException("Invalid EC private key", e); + } + } +- +- // return a string representation of this key for debugging +- public String toString() { +- return "Sun EC private key, " + params.getCurve().getField().getFieldSize() +- + " bits\n private value: " +- + s + "\n parameters: " + params; +- } +- + } +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/jgss/GSSCredentialImpl.java +--- jdk/src/share/classes/sun/security/jgss/GSSCredentialImpl.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/jgss/GSSCredentialImpl.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -630,7 +630,7 @@ + buffer.append(element.isAcceptorCredential() ? + " Accept" : ""); + buffer.append(" ["); +- buffer.append(element.toString()); ++ buffer.append(element.getClass()); + buffer.append(']'); + } catch (GSSException e) { + // skip to next element +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/pkcs/PKCS8Key.java +--- jdk/src/share/classes/sun/security/pkcs/PKCS8Key.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/pkcs/PKCS8Key.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1996, 2004, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -304,17 +304,6 @@ + return encodedKey.clone(); + } + +- /* +- * Returns a printable representation of the key +- */ +- public String toString () +- { +- HexDumpEncoder encoder = new HexDumpEncoder (); +- +- return "algorithm = " + algid.toString () +- + ", unparsed keybits = \n" + encoder.encodeBuffer (key); +- } +- + /** + * Initialize an PKCS8Key object from an input stream. The data + * on that input stream must be encoded using DER, obeying the +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/pkcs11/P11Key.java +--- jdk/src/share/classes/sun/security/pkcs11/P11Key.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/pkcs11/P11Key.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -542,27 +542,6 @@ + fetchValues(); + return coeff; + } +- public String toString() { +- fetchValues(); +- StringBuilder sb = new StringBuilder(super.toString()); +- sb.append("\n modulus: "); +- sb.append(n); +- sb.append("\n public exponent: "); +- sb.append(e); +- sb.append("\n private exponent: "); +- sb.append(d); +- sb.append("\n prime p: "); +- sb.append(p); +- sb.append("\n prime q: "); +- sb.append(q); +- sb.append("\n prime exponent p: "); +- sb.append(pe); +- sb.append("\n prime exponent q: "); +- sb.append(qe); +- sb.append("\n crt coefficient: "); +- sb.append(coeff); +- return sb.toString(); +- } + } + + // RSA non-CRT private key +@@ -616,15 +595,6 @@ + fetchValues(); + return d; + } +- public String toString() { +- fetchValues(); +- StringBuilder sb = new StringBuilder(super.toString()); +- sb.append("\n modulus: "); +- sb.append(n); +- sb.append("\n private exponent: "); +- sb.append(d); +- return sb.toString(); +- } + } + + private static final class P11RSAPublicKey extends P11Key +@@ -794,11 +764,6 @@ + fetchValues(); + return params; + } +- public String toString() { +- fetchValues(); +- return super.toString() + "\n x: " + x + "\n p: " + params.getP() +- + "\n q: " + params.getQ() + "\n g: " + params.getG(); +- } + } + + private static final class P11DHPrivateKey extends P11Key +@@ -856,11 +821,6 @@ + fetchValues(); + return params; + } +- public String toString() { +- fetchValues(); +- return super.toString() + "\n x: " + x + "\n p: " + params.getP() +- + "\n g: " + params.getG(); +- } + } + + private static final class P11DHPublicKey extends P11Key +@@ -977,12 +937,6 @@ + fetchValues(); + return params; + } +- public String toString() { +- fetchValues(); +- return super.toString() +- + "\n private value: " + s +- + "\n parameters: " + params; +- } + } + + private static final class P11ECPublicKey extends P11Key +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/provider/DSAPrivateKey.java +--- jdk/src/share/classes/sun/security/provider/DSAPrivateKey.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/provider/DSAPrivateKey.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1996, 2002, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -142,11 +142,6 @@ + } + } + +- public String toString() { +- return "Sun DSA Private Key \nparameters:" + algid + "\nx: " + +- Debug.toHexString(x) + "\n"; +- } +- + protected void parseKeyBits() throws InvalidKeyException { + try { + DerInputStream in = new DerInputStream(key); +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/rsa/RSAPrivateCrtKeyImpl.java +--- jdk/src/share/classes/sun/security/rsa/RSAPrivateCrtKeyImpl.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/rsa/RSAPrivateCrtKeyImpl.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2003, 2008, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -225,29 +225,4 @@ + } + return b; + } +- +- // return a string representation of this key for debugging +- public String toString() { +- StringBuffer sb = new StringBuffer(); +- sb.append("Sun RSA private CRT key, "); +- sb.append(n.bitLength()); +- sb.append(" bits\n modulus: "); +- sb.append(n); +- sb.append("\n public exponent: "); +- sb.append(e); +- sb.append("\n private exponent: "); +- sb.append(d); +- sb.append("\n prime p: "); +- sb.append(p); +- sb.append("\n prime q: "); +- sb.append(q); +- sb.append("\n prime exponent p: "); +- sb.append(pe); +- sb.append("\n prime exponent q: "); +- sb.append(qe); +- sb.append("\n crt coefficient: "); +- sb.append(coeff); +- return sb.toString(); +- } +- + } +diff -r db4712506571 -r df887df12ad1 src/share/classes/sun/security/rsa/RSAPrivateKeyImpl.java +--- jdk/src/share/classes/sun/security/rsa/RSAPrivateKeyImpl.java Mon Jul 08 14:34:36 2013 +0400 ++++ jdk/src/share/classes/sun/security/rsa/RSAPrivateKeyImpl.java Tue Oct 15 15:12:21 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2003, 2008, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -98,11 +98,4 @@ + public BigInteger getPrivateExponent() { + return d; + } +- +- // return a string representation of this key for debugging +- public String toString() { +- return "Sun RSA private key, " + n.bitLength() + " bits\n modulus: " +- + n + "\n private exponent: " + d; +- } +- + } diff --git a/java/openjdk6/files/icedtea/openjdk/8011081-improve_jhat.patch b/java/openjdk6/files/icedtea/openjdk/8011081-improve_jhat.patch new file mode 100644 index 000000000000..1c73a4b5df09 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8011081-improve_jhat.patch @@ -0,0 +1,267 @@ +# HG changeset patch +# User jbachorik +# Date 1366702651 -7200 +# Tue Apr 23 09:37:31 2013 +0200 +# Node ID de77043ae6b9c9693ae149d0ab9bae4d5007ce19 +# Parent df887df12ad1543894fe79f753983754ceef5c73 +8011081: Improve jhat +Summary: Properly escape HTML output +Reviewed-by: alanb, mschoene, sundar + +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/AllClassesQuery.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/AllClassesQuery.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/AllClassesQuery.java Tue Apr 23 09:37:31 2013 +0200 +@@ -84,7 +84,7 @@ + lastPackage = pkg; + printClass(clazz); + if (clazz.getId() != -1) { +- out.print(" [" + clazz.getIdString() + "]"); ++ print(" [" + clazz.getIdString() + "]"); + } + out.println("<br>"); + } +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/ClassQuery.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/ClassQuery.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/ClassQuery.java Tue Apr 23 09:37:31 2013 +0200 +@@ -112,12 +112,12 @@ + out.println("<h2>Instances</h2>"); + + printAnchorStart(); +- out.print("instances/" + encodeForURL(clazz)); ++ print("instances/" + encodeForURL(clazz)); + out.print("\">"); + out.println("Exclude subclasses</a><br>"); + + printAnchorStart(); +- out.print("allInstances/" + encodeForURL(clazz)); ++ print("allInstances/" + encodeForURL(clazz)); + out.print("\">"); + out.println("Include subclasses</a><br>"); + +@@ -126,19 +126,19 @@ + out.println("<h2>New Instances</h2>"); + + printAnchorStart(); +- out.print("newInstances/" + encodeForURL(clazz)); ++ print("newInstances/" + encodeForURL(clazz)); + out.print("\">"); + out.println("Exclude subclasses</a><br>"); + + printAnchorStart(); +- out.print("allNewInstances/" + encodeForURL(clazz)); ++ print("allNewInstances/" + encodeForURL(clazz)); + out.print("\">"); + out.println("Include subclasses</a><br>"); + } + + out.println("<h2>References summary by Type</h2>"); + printAnchorStart(); +- out.print("refsByType/" + encodeForURL(clazz)); ++ print("refsByType/" + encodeForURL(clazz)); + out.print("\">"); + out.println("References summary by type</a>"); + +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/HttpReader.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/HttpReader.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/HttpReader.java Tue Apr 23 09:37:31 2013 +0200 +@@ -41,21 +41,17 @@ + + + import java.net.Socket; +-import java.net.ServerSocket; +-import java.net.InetAddress; + + import java.io.InputStream; + import java.io.BufferedInputStream; + import java.io.IOException; +-import java.io.Writer; + import java.io.BufferedWriter; + import java.io.PrintWriter; +-import java.io.OutputStream; + import java.io.OutputStreamWriter; +-import java.io.BufferedOutputStream; + + import com.sun.tools.hat.internal.model.Snapshot; + import com.sun.tools.hat.internal.oql.OQLEngine; ++import com.sun.tools.hat.internal.util.Misc; + + public class HttpReader implements Runnable { + +@@ -87,7 +83,7 @@ + outputError("Protocol error"); + } + int data; +- StringBuffer queryBuf = new StringBuffer(); ++ StringBuilder queryBuf = new StringBuilder(); + while ((data = in.read()) != -1 && data != ' ') { + char ch = (char) data; + queryBuf.append(ch); +@@ -217,7 +213,7 @@ + private void outputError(String msg) { + out.println(); + out.println("<html><body bgcolor=\"#ffffff\">"); +- out.println(msg); ++ out.println(Misc.encodeHtml(msg)); + out.println("</body></html>"); + } + +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/InstancesCountQuery.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/InstancesCountQuery.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/InstancesCountQuery.java Tue Apr 23 09:37:31 2013 +0200 +@@ -102,7 +102,7 @@ + int count = clazz.getInstancesCount(false); + print("" + count); + printAnchorStart(); +- out.print("instances/" + encodeForURL(classes[i])); ++ print("instances/" + encodeForURL(classes[i])); + out.print("\"> "); + if (count == 1) { + print("instance"); +@@ -121,7 +121,7 @@ + } + print("("); + printAnchorStart(); +- out.print("newInstances/" + encodeForURL(classes[i])); ++ print("newInstances/" + encodeForURL(classes[i])); + out.print("\">"); + print("" + newInst + " new"); + out.print("</a>) "); +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/OQLHelp.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/OQLHelp.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/OQLHelp.java Tue Apr 23 09:37:31 2013 +0200 +@@ -54,10 +54,7 @@ + out.print((char)ch); + } + } catch (Exception exp) { +- out.println(exp.getMessage()); +- out.println("<pre>"); +- exp.printStackTrace(out); +- out.println("</pre>"); ++ printException(exp); + } + } + } +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/OQLQuery.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/OQLQuery.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/OQLQuery.java Tue Apr 23 09:37:31 2013 +0200 +@@ -32,10 +32,7 @@ + + package com.sun.tools.hat.internal.server; + +-import com.sun.tools.hat.internal.model.*; + import com.sun.tools.hat.internal.oql.*; +-import com.sun.tools.hat.internal.util.ArraySorter; +-import com.sun.tools.hat.internal.util.Comparer; + + /** + * This handles Object Query Language (OQL) queries. +@@ -68,7 +65,7 @@ + out.println("<p align='center'>"); + out.println("<textarea name='query' cols=80 rows=10>"); + if (oql != null) { +- out.println(oql); ++ println(oql); + } + out.println("</textarea>"); + out.println("</p>"); +@@ -91,10 +88,7 @@ + try { + out.println(engine.toHtml(o)); + } catch (Exception e) { +- out.println(e.getMessage()); +- out.println("<pre>"); +- e.printStackTrace(out); +- out.println("</pre>"); ++ printException(e); + } + out.println("</td></tr>"); + return false; +@@ -102,10 +96,7 @@ + }); + out.println("</table>"); + } catch (OQLException exp) { +- out.println(exp.getMessage()); +- out.println("<pre>"); +- exp.printStackTrace(out); +- out.println("</pre>"); ++ printException(exp); + } + } + +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/QueryHandler.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/QueryHandler.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/QueryHandler.java Tue Apr 23 09:37:31 2013 +0200 +@@ -36,6 +36,7 @@ + + import com.sun.tools.hat.internal.model.*; + import com.sun.tools.hat.internal.util.Misc; ++import java.io.StringWriter; + + import java.net.URLEncoder; + import java.io.UnsupportedEncodingException; +@@ -96,7 +97,7 @@ + } + + protected void error(String msg) { +- out.println(msg); ++ println(msg); + } + + protected void printAnchorStart() { +@@ -160,7 +161,6 @@ + out.println("null"); + return; + } +- String name = clazz.getName(); + printAnchorStart(); + out.print("class/"); + print(encodeForURL(clazz)); +@@ -208,6 +208,15 @@ + } + } + ++ protected void printException(Throwable t) { ++ println(t.getMessage()); ++ out.println("<pre>"); ++ StringWriter sw = new StringWriter(); ++ t.printStackTrace(new PrintWriter(sw)); ++ print(sw.toString()); ++ out.println("</pre>"); ++ } ++ + protected void printHex(long addr) { + if (snapshot.getIdentifierSize() == 4) { + out.print(Misc.toHex((int)addr)); +@@ -223,4 +232,8 @@ + protected void print(String str) { + out.print(Misc.encodeHtml(str)); + } ++ ++ protected void println(String str) { ++ out.println(Misc.encodeHtml(str)); ++ } + } +diff -r df887df12ad1 -r de77043ae6b9 src/share/classes/com/sun/tools/hat/internal/server/RefsByTypeQuery.java +--- jdk/src/share/classes/com/sun/tools/hat/internal/server/RefsByTypeQuery.java Tue Oct 15 15:12:21 2013 +0100 ++++ jdk/src/share/classes/com/sun/tools/hat/internal/server/RefsByTypeQuery.java Tue Apr 23 09:37:31 2013 +0200 +@@ -89,7 +89,7 @@ + out.println("<p align='center'>"); + printClass(clazz); + if (clazz.getId() != -1) { +- out.println("[" + clazz.getIdString() + "]"); ++ println("[" + clazz.getIdString() + "]"); + } + out.println("</p>"); + +@@ -125,9 +125,9 @@ + JavaClass clazz = classes[i]; + out.println("<tr><td>"); + out.print("<a href='/refsByType/"); +- out.print(clazz.getIdString()); ++ print(clazz.getIdString()); + out.print("'>"); +- out.print(clazz.getName()); ++ print(clazz.getName()); + out.println("</a>"); + out.println("</td><td>"); + out.println(map.get(clazz)); diff --git a/java/openjdk6/files/icedtea/openjdk/8011139-revise_checking_getenclosingclass.patch b/java/openjdk6/files/icedtea/openjdk/8011139-revise_checking_getenclosingclass.patch new file mode 100644 index 000000000000..90f89ce09c19 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8011139-revise_checking_getenclosingclass.patch @@ -0,0 +1,58 @@ +# HG changeset patch +# User jfranck +# Date 1382726704 -3600 +# Fri Oct 25 19:45:04 2013 +0100 +# Node ID a2b63addc0633a5ef8d196d1019d78b920cb4b1a +# Parent e7ed5dad88eefc49130ae02bcbf329d72f18f12e +8011139: (reflect) Revise checking in getEnclosingClass +Reviewed-by: darcy, mchung, ahgross + +diff -r e7ed5dad88ee -r a2b63addc063 src/share/classes/java/lang/Class.java +--- jdk/src/share/classes/java/lang/Class.java Fri Oct 25 19:37:20 2013 +0100 ++++ jdk/src/share/classes/java/lang/Class.java Fri Oct 25 19:45:04 2013 +0100 +@@ -1131,13 +1131,9 @@ + enclosingCandidate = enclosingClass; + } + +- // be very careful not to change the stack depth of this +- // checkMemberAccess call for security reasons +- // see java.lang.SecurityManager.checkMemberAccess +- if (enclosingCandidate != null) { +- enclosingCandidate.checkMemberAccess(Member.DECLARED, +- Reflection.getCallerClass(), true); +- } ++ if (enclosingCandidate != null) ++ enclosingCandidate.checkPackageAccess( ++ ClassLoader.getClassLoader(Reflection.getCallerClass()), true); + return enclosingCandidate; + } + +@@ -2214,6 +2210,8 @@ + * Check if client is allowed to access members. If access is denied, + * throw a SecurityException. + * ++ * This method also enforces package access. ++ * + * <p> Default policy: allow all clients access with normal Java access + * control. + */ +@@ -2234,7 +2232,19 @@ + // checkMemberAccess of subclasses of SecurityManager as specified. + s.checkMemberAccess(this, which); + } ++ this.checkPackageAccess(ccl, checkProxyInterfaces); ++ } ++ } + ++ /* ++ * Checks if a client loaded in ClassLoader ccl is allowed to access this ++ * class under the current package access policy. If access is denied, ++ * throw a SecurityException. ++ */ ++ private void checkPackageAccess(final ClassLoader ccl, boolean checkProxyInterfaces) { ++ final SecurityManager s = System.getSecurityManager(); ++ if (s != null) { ++ final ClassLoader cl = getClassLoader0(); + if (ReflectUtil.needsPackageAccessCheck(ccl, cl)) { + + String name = this.getName(); diff --git a/java/openjdk6/files/icedtea/openjdk/8011157-improve_corba_portability-jdk.patch b/java/openjdk6/files/icedtea/openjdk/8011157-improve_corba_portability-jdk.patch new file mode 100644 index 000000000000..575da017a7e2 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8011157-improve_corba_portability-jdk.patch @@ -0,0 +1,125 @@ +# HG changeset patch +# User msheppar +# Date 1381849187 -3600 +# Tue Oct 15 15:59:47 2013 +0100 +# Node ID 468ec57a684409e4c7ed97be8ffa36322fb8a36b +# Parent de77043ae6b9c9693ae149d0ab9bae4d5007ce19 +8011157: Improve CORBA portablility +Summary: fix also reviewed by Alexander Fomin +Reviewed-by: alanb, coffeys, skoivu + +diff -r de77043ae6b9 -r 468ec57a6844 make/com/sun/jmx/Makefile +--- jdk/make/com/sun/jmx/Makefile Tue Apr 23 09:37:31 2013 +0200 ++++ jdk/make/com/sun/jmx/Makefile Tue Oct 15 15:59:47 2013 +0100 +@@ -1,5 +1,5 @@ + # +-# Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. ++# Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + # + # This code is free software; you can redistribute it and/or modify it +@@ -126,11 +126,13 @@ + $(RMIC) -classpath "$(CLASSDESTDIR)" \ + -d $(CLASSDESTDIR) \ + -iiop -v1.2 \ ++ -emitPermissionCheck \ + $(subst /,.,$(<:$(CLASSDESTDIR)/%.class=%)) + $(RMIC) $(HOTSPOT_INTERPRETER_FLAG) -classpath "$(CLASSDESTDIR)" \ + -d $(CLASSDESTDIR) \ + -iiop -v1.2 \ + -standardPackage \ ++ -emitPermissionCheck \ + $(subst /,.,$(<:$(CLASSDESTDIR)/%.class=%)) + @$(java-vm-cleanup) + +diff -r de77043ae6b9 -r 468ec57a6844 src/share/classes/javax/management/modelmbean/RequiredModelMBean.java +--- jdk/src/share/classes/javax/management/modelmbean/RequiredModelMBean.java Tue Apr 23 09:37:31 2013 +0200 ++++ jdk/src/share/classes/javax/management/modelmbean/RequiredModelMBean.java Tue Oct 15 15:59:47 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -299,11 +299,15 @@ + RequiredModelMBean.class.getName(), + "setModelMBeanInfo(ModelMBeanInfo)", + "Setting ModelMBeanInfo to " + printModelMBeanInfo(mbi)); ++ int noOfNotifications = 0; ++ if (mbi.getNotifications() != null) { ++ noOfNotifications = mbi.getNotifications().length; ++ } + MODELMBEAN_LOGGER.logp(Level.FINER, + RequiredModelMBean.class.getName(), + "setModelMBeanInfo(ModelMBeanInfo)", + "ModelMBeanInfo notifications has " + +- (mbi.getNotifications()).length + " elements"); ++ noOfNotifications + " elements"); + } + + modelMBeanInfo = (ModelMBeanInfo)mbi.clone(); +@@ -3001,4 +3005,5 @@ + Void.class.getName() + }; + } ++ + } +diff -r de77043ae6b9 -r 468ec57a6844 src/share/classes/javax/management/remote/rmi/RMIConnector.java +--- jdk/src/share/classes/javax/management/remote/rmi/RMIConnector.java Tue Apr 23 09:37:31 2013 +0200 ++++ jdk/src/share/classes/javax/management/remote/rmi/RMIConnector.java Tue Oct 15 15:59:47 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2002, 2007, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2002, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -60,6 +60,7 @@ + import java.security.AccessController; + import java.security.PrivilegedAction; + import java.security.PrivilegedExceptionAction; ++import java.security.PrivilegedActionException; + import java.security.ProtectionDomain; + import java.util.Arrays; + import java.util.Collections; +@@ -241,10 +242,21 @@ + //-------------------------------------------------------------------- + // implements JMXConnector interface + //-------------------------------------------------------------------- ++ ++ /** ++ * @throws IOException if the connection could not be made because of a ++ * communication problem, or in the case of the {@code iiop} protocol, ++ * that RMI/IIOP is not supported ++ */ + public void connect() throws IOException { + connect(null); + } + ++ /** ++ * @throws IOException if the connection could not be made because of a ++ * communication problem, or in the case of the {@code iiop} protocol, ++ * that RMI/IIOP is not supported ++ */ + public synchronized void connect(Map<String,?> environment) + throws IOException { + final boolean tracing = logger.traceOn(); +@@ -2334,7 +2346,16 @@ + + private static RMIConnection shadowIiopStub(Stub stub) + throws InstantiationException, IllegalAccessException { +- Stub proxyStub = (Stub) proxyStubClass.newInstance(); ++ Stub proxyStub = null; ++ try { ++ proxyStub = AccessController.doPrivileged(new PrivilegedExceptionAction<Stub>() { ++ public Stub run() throws Exception { ++ return (Stub) proxyStubClass.newInstance(); ++ } ++ }); ++ } catch (PrivilegedActionException e) { ++ throw new InternalError(); ++ } + proxyStub._set_delegate(stub._get_delegate()); + return (RMIConnection) proxyStub; + } diff --git a/java/openjdk6/files/icedtea/openjdk/8011157-improve_corba_portability.patch b/java/openjdk6/files/icedtea/openjdk/8011157-improve_corba_portability.patch new file mode 100644 index 000000000000..361cd4c5a25d --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8011157-improve_corba_portability.patch @@ -0,0 +1,183 @@ +# HG changeset patch +# User msheppar +# Date 1381847065 -3600 +# Tue Oct 15 15:24:25 2013 +0100 +# Node ID 9e7e1b6ab5cdf0096c9c16d991e6a982771a15f1 +# Parent 14308db8214e69d7cad09a8f4d49d421b5b13ba0 +8011157: Improve CORBA portablility +Summary: fix also reviewed by Alexander Fomin +Reviewed-by: alanb, coffeys, skoivu + +diff -r 14308db8214e -r 9e7e1b6ab5cd src/share/classes/com/sun/corba/se/impl/transport/SelectorImpl.java +--- corba/src/share/classes/com/sun/corba/se/impl/transport/SelectorImpl.java Mon Jun 17 19:01:08 2013 +0200 ++++ corba/src/share/classes/com/sun/corba/se/impl/transport/SelectorImpl.java Tue Oct 15 15:24:25 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -54,7 +54,7 @@ + /** + * @author Harold Carr + */ +-public class SelectorImpl ++class SelectorImpl + extends + Thread + implements +diff -r 14308db8214e -r 9e7e1b6ab5cd src/share/classes/sun/rmi/rmic/iiop/StubGenerator.java +--- corba/src/share/classes/sun/rmi/rmic/iiop/StubGenerator.java Mon Jun 17 19:01:08 2013 +0200 ++++ corba/src/share/classes/sun/rmi/rmic/iiop/StubGenerator.java Tue Oct 15 15:24:25 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -34,6 +34,9 @@ + + import java.io.File; + import java.io.IOException; ++import java.io.SerializablePermission; ++import java.security.AccessController; ++import java.security.PrivilegedAction; + import java.util.Vector; + import java.util.Hashtable; + import java.util.Enumeration; +@@ -49,6 +52,7 @@ + import com.sun.corba.se.impl.util.PackagePrefixChecker; + import sun.rmi.rmic.Main; + ++ + /** + * An IIOP stub/tie generator for rmic. + * +@@ -78,6 +82,7 @@ + protected boolean castArray = false; + protected Hashtable transactionalObjects = new Hashtable() ; + protected boolean POATie = false ; ++ protected boolean emitPermissionCheck = false; + + /** + * Default constructor for Main to use. +@@ -193,6 +198,9 @@ + } else if (argv[i].equals("-standardPackage")) { + standardPackage = true; + argv[i] = null; ++ } else if (argv[i].equals("-emitPermissionCheck")) { ++ emitPermissionCheck = true; ++ argv[i] = null; + } else if (arg.equals("-xstubbase")) { + argv[i] = null; + if (++i < argv.length && argv[i] != null && !argv[i].startsWith("-")) { +@@ -390,9 +398,22 @@ + + writePackageAndImports(p); + ++// generate ++// import java.security.AccessController; ++// import java.security.PrivilegedAction; ++// import java.io.SerializablePermission; ++ if (emitPermissionCheck) { ++ p.pln("import java.security.AccessController;"); ++ p.pln("import java.security.PrivilegedAction;"); ++ p.pln("import java.io.SerializablePermission;"); ++ p.pln(); ++ p.pln(); ++ } ++ + // Declare the stub class; implement all remote interfaces. + + p.p("public class " + currentClass); ++ + p.p(" extends " + getName(stubBaseClass)); + p.p(" implements "); + if (remoteInterfaces.length > 0) { +@@ -422,6 +443,56 @@ + writeIds( p, theType, false ); + p.pln(); + ++ if (emitPermissionCheck) { ++ ++ // produce the following generated code ++ // private static Void checkPermission() { ++ // SecurityManager sm = System.getSecurityManager(); ++ // if (sm != null) { ++ // sm.checkPermission(new SerializablePermission( ++ // "enableSubclassImplementation")); // testing ++ // } ++ // return null; ++ // } ++ // ++ // private _XXXXXX_Stub(Void ignore) { ++ // } ++ // ++ // public _XXXXXX_Stub() { ++ // this(checkPermission()); ++ // } ++ // where XXXXXX is the name of the remote interface ++ ++ p.pln(); ++ p.plnI("private static Void checkPermission() {"); ++ p.plnI("SecurityManager sm = System.getSecurityManager();"); ++ p.pln("if (sm != null) {"); ++ p.pI(); ++ p.plnI("sm.checkPermission(new SerializablePermission("); ++ p.plnI("\"enableSubclassImplementation\"));"); ++ p.pO(); ++ p.pO(); ++ p.pOln("}"); ++ p.pln("return null;"); ++ p.pO(); ++ p.pOln("}"); ++ p.pln(); ++ p.pO(); ++ ++ p.pI(); ++ p.pln("private " + currentClass + "(Void ignore) { }"); ++ p.pln(); ++ ++ p.plnI("public " + currentClass + "() { "); ++ p.pln("this(checkPermission());"); ++ p.pOln("}"); ++ p.pln(); ++ } ++ ++ if (!emitPermissionCheck) { ++ p.pI(); ++ } ++ + // Write the _ids() method... + + p.plnI("public String[] _ids() { "); +@@ -815,7 +886,6 @@ + CompoundType theType) throws IOException { + + // Wtite the method declaration and opening brace... +- + String methodName = method.getName(); + String methodIDLName = method.getIDLName(); + +@@ -1631,7 +1701,7 @@ + + // Write data members... + p.pln(); +- p.pln("private " + getName(theType) + " target = null;"); ++ p.pln("volatile private " + getName(theType) + " target = null;"); + p.pln(); + + // Write the ids... +@@ -1695,6 +1765,10 @@ + + if (remoteMethods.length > 0) { + p.plnI("try {"); ++ p.pln(getName(theType) + " target = this.target;"); ++ p.plnI("if (target == null) {"); ++ p.pln("throw new java.io.IOException();"); ++ p.pOln("}"); + p.plnI(idExtInputStream + " "+in+" = "); + p.pln("(" + idExtInputStream + ") "+_in+";"); + p.pO(); diff --git a/java/openjdk6/files/icedtea/openjdk/8011990-logger_test_urls.patch b/java/openjdk6/files/icedtea/openjdk/8011990-logger_test_urls.patch new file mode 100644 index 000000000000..fa7fa70f6942 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8011990-logger_test_urls.patch @@ -0,0 +1,58 @@ +# HG changeset patch +# User jgish +# Date 1366144454 14400 +# Tue Apr 16 16:34:14 2013 -0400 +# Node ID a7048970934a1425d5486e6acd0b07558be038c4 +# Parent ed410e3d08fe7792e6c08e411580564d2562c03e +8011990: TEST_BUG: java/util/logging/bundlesearch/ResourceBundleSearchTest.java fails on Windows +Summary: Fix URL to reliably work on all platforms +Reviewed-by: duke + +diff -r ed410e3d08fe -r a7048970934a test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java +--- jdk/test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java Fri Apr 19 16:50:10 2013 -0700 ++++ jdk/test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java Tue Apr 16 16:34:14 2013 -0400 +@@ -21,6 +21,7 @@ + * questions. + */ + ++import java.io.File; + import java.lang.reflect.InvocationTargetException; + import java.lang.reflect.Method; + import java.net.URL; +@@ -45,11 +46,13 @@ + String testClassesDir = System.getProperty("test.classes", + System.getProperty("user.dir")); + String sep = System.getProperty("file.separator"); ++ + URL[] urls = new URL[2]; + + // Allow for both jtreg and standalone cases here +- urls[0] = new URL("file://" + testDir + sep + "resources" + sep); +- urls[1] = new URL("file://" + testClassesDir + sep ); ++ urls[0] = new File( testDir + sep + "resources" + sep ).toURI().toURL(); ++ urls[1] = new File( testClassesDir + sep ).toURI().toURL(); ++ + System.out.println("INFO: urls[0] = " + urls[0]); + System.out.println("INFO: urls[1] = " + urls[1]); + +diff -r ed410e3d08fe -r a7048970934a test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java +--- jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Fri Apr 19 16:50:10 2013 -0700 ++++ jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Tue Apr 16 16:34:14 2013 -0400 +@@ -29,6 +29,7 @@ + * @build ResourceBundleSearchTest IndirectlyLoadABundle LoadItUp + * @run main ResourceBundleSearchTest + */ ++import java.io.File; + import java.net.URL; + import java.net.URLClassLoader; + import java.util.ArrayList; +@@ -70,7 +71,8 @@ + String sep = System.getProperty("file.separator"); + + URL[] urls = new URL[1]; +- urls[0] = new URL("file://" + testDir + sep + "resources" + sep); ++ ++ urls[0] = new File( testDir + sep + "resources" + sep ).toURI().toURL(); + URLClassLoader rbClassLoader = new URLClassLoader(urls); + + // Test 1 - can we find a Logger bundle from doing a stack search? diff --git a/java/openjdk6/files/icedtea/openjdk/8012071-better_bean_building.patch b/java/openjdk6/files/icedtea/openjdk/8012071-better_bean_building.patch new file mode 100644 index 000000000000..4fdce36704ba --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012071-better_bean_building.patch @@ -0,0 +1,87 @@ +# HG changeset patch +# User malenkov +# Date 1381850636 -3600 +# Tue Oct 15 16:23:56 2013 +0100 +# Node ID 7a6de63e89636f3bfb5b32e2a8d1ea3df1fe2d79 +# Parent 468ec57a684409e4c7ed97be8ffa36322fb8a36b +8012071: Better Building of Beans +Reviewed-by: art, skoivu + +diff -r 468ec57a6844 -r 7a6de63e8963 src/share/classes/java/beans/Beans.java +--- jdk/src/share/classes/java/beans/Beans.java Tue Oct 15 15:59:47 2013 +0100 ++++ jdk/src/share/classes/java/beans/Beans.java Tue Oct 15 16:23:56 2013 +0100 +@@ -42,6 +42,8 @@ + import java.io.ObjectStreamClass; + import java.io.StreamCorruptedException; + ++import java.lang.reflect.Modifier; ++ + import java.net.URL; + + import java.security.AccessController; +@@ -222,6 +224,10 @@ + throw ex; + } + ++ if (!Modifier.isPublic(cl.getModifiers())) { ++ throw new ClassNotFoundException("" + cl + " : no public access"); ++ } ++ + /* + * Try to instantiate the class. + */ +diff -r 468ec57a6844 -r 7a6de63e8963 src/share/classes/java/beans/DefaultPersistenceDelegate.java +--- jdk/src/share/classes/java/beans/DefaultPersistenceDelegate.java Tue Oct 15 15:59:47 2013 +0100 ++++ jdk/src/share/classes/java/beans/DefaultPersistenceDelegate.java Tue Oct 15 16:23:56 2013 +0100 +@@ -235,6 +235,9 @@ + for(int i = 0; i < a.length; i = i + 3) { + try { + Field f = type.getField((String)a[i]); ++ if (!ReflectUtil.isPackageAccessible(f.getDeclaringClass())) { ++ continue; ++ } + if (f.get(null).equals(oldValue)) { + out.remove(oldValue); + out.writeExpression(new Expression(oldValue, f, "get", new Object[]{null})); +diff -r 468ec57a6844 -r 7a6de63e8963 src/share/classes/java/beans/MetaData.java +--- jdk/src/share/classes/java/beans/MetaData.java Tue Oct 15 15:59:47 2013 +0100 ++++ jdk/src/share/classes/java/beans/MetaData.java Tue Oct 15 16:23:56 2013 +0100 +@@ -40,6 +40,7 @@ + import java.lang.reflect.Constructor; + import java.lang.reflect.Field; + import java.lang.reflect.Method; ++import java.lang.reflect.Modifier; + + import java.security.AccessController; + import java.security.PrivilegedAction; +@@ -47,6 +48,7 @@ + import java.sql.Timestamp; + + import java.util.*; ++import static sun.reflect.misc.ReflectUtil.isPackageAccessible; + + import javax.swing.Box; + import javax.swing.JLayeredPane; +@@ -907,13 +909,15 @@ + + class StaticFieldsPersistenceDelegate extends PersistenceDelegate { + protected void installFields(Encoder out, Class<?> cls) { +- Field fields[] = cls.getFields(); +- for(int i = 0; i < fields.length; i++) { +- Field field = fields[i]; +- // Don't install primitives, their identity will not be preserved +- // by wrapping. +- if (Object.class.isAssignableFrom(field.getType())) { +- out.writeExpression(new Expression(field, "get", new Object[]{null})); ++ if (Modifier.isPublic(cls.getModifiers()) && isPackageAccessible(cls)) { ++ Field fields[] = cls.getFields(); ++ for(int i = 0; i < fields.length; i++) { ++ Field field = fields[i]; ++ // Don't install primitives, their identity will not be preserved ++ // by wrapping. ++ if (Object.class.isAssignableFrom(field.getType())) { ++ out.writeExpression(new Expression(field, "get", new Object[]{null})); ++ } + } + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8012147-improve_tool.patch b/java/openjdk6/files/icedtea/openjdk/8012147-improve_tool.patch new file mode 100644 index 000000000000..efa0d2a4f753 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012147-improve_tool.patch @@ -0,0 +1,55 @@ +# HG changeset patch +# User erikj +# Date 1381850834 -3600 +# Tue Oct 15 16:27:14 2013 +0100 +# Node ID 8521d2f3d9640e6516d8b71aa2f553bc4028362f +# Parent 7a6de63e89636f3bfb5b32e2a8d1ea3df1fe2d79 +8012147: Improve tool support +Summary: Adding libjli to jdk lib dir and removing now redundant rpath entries from executables +Reviewed-by: alanb, dholmes, ksrini, ahgross + +diff -r 7a6de63e8963 -r 8521d2f3d964 make/common/Program.gmk +--- jdk/make/common/Program.gmk Tue Oct 15 16:23:56 2013 +0100 ++++ jdk/make/common/Program.gmk Tue Oct 15 16:27:14 2013 +0100 +@@ -78,17 +78,14 @@ + ifeq ($(PLATFORM), solaris) + ifeq ($(ARCH_DATA_MODEL), 32) + LDFLAGS += -R \$$ORIGIN/../lib/$(LIBARCH)/jli +- LDFLAGS += -R \$$ORIGIN/../jre/lib/$(LIBARCH)/jli + else + LDFLAGS += -R \$$ORIGIN/../../lib/$(LIBARCH)/jli +- LDFLAGS += -R \$$ORIGIN/../../jre/lib/$(LIBARCH)/jli + endif + endif + ifeq ($(PLATFORM), linux) + LDFLAGS += -Wl,-z -Wl,origin + LDFLAGS += -Wl,--allow-shlib-undefined + LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../lib/$(LIBARCH)/jli +- LDFLAGS += -Wl,-rpath -Wl,\$$ORIGIN/../jre/lib/$(LIBARCH)/jli + endif + endif + ifeq ($(PLATFORM), windows) +diff -r 7a6de63e8963 -r 8521d2f3d964 make/common/Release.gmk +--- jdk/make/common/Release.gmk Tue Oct 15 16:23:56 2013 +0100 ++++ jdk/make/common/Release.gmk Tue Oct 15 16:27:14 2013 +0100 +@@ -855,6 +855,11 @@ + | $(CPIO) -pdum $(JDK_IMAGE_DIR)/jre ) + $(RM) -rf $(JDK_IMAGE_DIR)/jre/man + $(CHMOD) a+rx `$(FIND) $(JDK_IMAGE_DIR) -type d` ++ ifneq (,$(findstring $(PLATFORM), linux solaris)) # If linux or solaris ++ ($(CD) $(LIBDIR)/.. && $(TAR) cf - \ ++ `$(FIND) lib -name $(LIB_PREFIX)jli.$(LIB_SUFFIX) -print `) | \ ++ ($(CD) $(JDK_IMAGE_DIR) && $(TAR) xf -) ++ endif # PLATFORM + + initial-image-jdk64-bindemos: + for dir in bin demo ; do \ +@@ -891,7 +896,7 @@ + initial-image-jdk:: initial-image-jdk-setup \ + initial-image-jdk-db \ + $(JDK_LICENSES) $(JDK_DOCFILES) +- $(MKDIR) $(JDK_IMAGE_DIR)/lib ++ $(MKDIR) -p $(JDK_IMAGE_DIR)/lib + @# + @# Copy in the jars in lib that only belong in the JDK + @# diff --git a/java/openjdk6/files/icedtea/openjdk/8012243-serial_regression.patch b/java/openjdk6/files/icedtea/openjdk/8012243-serial_regression.patch new file mode 100644 index 000000000000..1cffb35a587b --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012243-serial_regression.patch @@ -0,0 +1,45 @@ +# HG changeset patch +# User dfuchs +# Date 1367362161 -7200 +# Wed May 01 00:49:21 2013 +0200 +# Node ID 47c881c5439a4542b19ab85f376e94fc2c0a5a57 +# Parent 0bf55b4c8a7bbea02a9d848b2a5451adbd6a6ac4 +8012243: about 30% regression on specjvm2008.serial on 7u25 comparing 7u21 +Reviewed-by: alanb, skoivu, smarks, mchung + +diff -r 0bf55b4c8a7b -r 47c881c5439a src/share/classes/java/io/ObjectStreamClass.java +--- jdk/src/share/classes/java/io/ObjectStreamClass.java Fri May 17 14:29:51 2013 -0700 ++++ jdk/src/share/classes/java/io/ObjectStreamClass.java Wed May 01 00:49:21 2013 +0200 +@@ -241,9 +241,11 @@ + if (cl == null) { + return null; + } +- Class<?> caller = Reflection.getCallerClass(); +- if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), cl.getClassLoader())) { +- ReflectUtil.checkPackageAccess(cl); ++ if (System.getSecurityManager() != null) { ++ Class<?> caller = Reflection.getCallerClass(); ++ if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), cl.getClassLoader())) { ++ ReflectUtil.checkPackageAccess(cl); ++ } + } + return cl; + } +diff -r 0bf55b4c8a7b -r 47c881c5439a src/share/classes/java/io/ObjectStreamField.java +--- jdk/src/share/classes/java/io/ObjectStreamField.java Fri May 17 14:29:51 2013 -0700 ++++ jdk/src/share/classes/java/io/ObjectStreamField.java Wed May 01 00:49:21 2013 +0200 +@@ -162,9 +162,11 @@ + */ + @CallerSensitive + public Class<?> getType() { +- Class<?> caller = Reflection.getCallerClass(); +- if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), type.getClassLoader())) { +- ReflectUtil.checkPackageAccess(type); ++ if (System.getSecurityManager() != null) { ++ Class<?> caller = Reflection.getCallerClass(); ++ if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), type.getClassLoader())) { ++ ReflectUtil.checkPackageAccess(type); ++ } + } + return type; + } diff --git a/java/openjdk6/files/icedtea/openjdk/8012277-improve_dataflavour.patch b/java/openjdk6/files/icedtea/openjdk/8012277-improve_dataflavour.patch new file mode 100644 index 000000000000..d2606de4cb21 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012277-improve_dataflavour.patch @@ -0,0 +1,83 @@ +# HG changeset patch +# User malenkov +# Date 1370018612 -14400 +# Fri May 31 20:43:32 2013 +0400 +# Node ID 337232ddaec36c6d9843ff35906e6160446844eb +# Parent 8521d2f3d9640e6516d8b71aa2f553bc4028362f +8012277: Improve AWT DataFlavor +Reviewed-by: art, skoivu + +diff -r 8521d2f3d964 -r 337232ddaec3 src/share/classes/java/awt/datatransfer/DataFlavor.java +--- jdk/src/share/classes/java/awt/datatransfer/DataFlavor.java Tue Oct 15 16:27:14 2013 +0100 ++++ jdk/src/share/classes/java/awt/datatransfer/DataFlavor.java Fri May 31 20:43:32 2013 +0400 +@@ -25,12 +25,14 @@ + + package java.awt.datatransfer; + +-import java.awt.Toolkit; + import java.io.*; + import java.nio.*; + import java.util.*; + + import sun.awt.datatransfer.DataTransferer; ++import sun.reflect.misc.ReflectUtil; ++ ++import static sun.security.util.SecurityConstants.GET_CLASSLOADER_PERMISSION; + + /** + * A {@code DataFlavor} provides meta information about data. {@code DataFlavor} +@@ -117,26 +119,36 @@ + ClassLoader fallback) + throws ClassNotFoundException + { +- ClassLoader systemClassLoader = (ClassLoader) +- java.security.AccessController.doPrivileged( +- new java.security.PrivilegedAction() { +- public Object run() { +- ClassLoader cl = Thread.currentThread(). +- getContextClassLoader(); +- return (cl != null) +- ? cl +- : ClassLoader.getSystemClassLoader(); ++ ReflectUtil.checkPackageAccess(className); ++ try { ++ SecurityManager sm = System.getSecurityManager(); ++ if (sm != null) { ++ sm.checkPermission(GET_CLASSLOADER_PERMISSION); ++ } ++ ClassLoader loader = ClassLoader.getSystemClassLoader(); ++ try { ++ // bootstrap class loader and system class loader if present ++ return Class.forName(className, true, loader); ++ } ++ catch (ClassNotFoundException exception) { ++ // thread context class loader if and only if present ++ loader = Thread.currentThread().getContextClassLoader(); ++ if (loader != null) { ++ try { ++ return Class.forName(className, true, loader); + } +- }); +- +- try { +- return Class.forName(className, true, systemClassLoader); +- } catch (ClassNotFoundException e2) { +- if (fallback != null) { +- return Class.forName(className, true, fallback); +- } else { +- throw new ClassNotFoundException(className); ++ catch (ClassNotFoundException e) { ++ // fallback to user's class loader ++ } ++ } + } ++ } catch (SecurityException exception) { ++ // ignore secured class loaders ++ } ++ if (fallback != null) { ++ return Class.forName(className, true, fallback); ++ } else { ++ throw new ClassNotFoundException(className); + } + } + diff --git a/java/openjdk6/files/icedtea/openjdk/8012425-transform_transformfactory.patch b/java/openjdk6/files/icedtea/openjdk/8012425-transform_transformfactory.patch new file mode 100644 index 000000000000..d2249f820043 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012425-transform_transformfactory.patch @@ -0,0 +1,380 @@ +# HG changeset patch +# User joehw +# Date 1383025844 0 +# Tue Oct 29 05:50:44 2013 +0000 +# Node ID 7799c3bd00f5a4fda6448cb8bcd7768c66ec166d +# Parent b5b1d1fa4bb4fcd8bc0602fd4f3523fe24d9f00b +8012425: Transform TransformerFactory +Reviewed-by: alanb, dfuchs, mullan + +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerImpl.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerImpl.java Tue Oct 29 05:50:44 2013 +0000 +@@ -40,6 +40,7 @@ + import java.util.Vector; + import java.lang.reflect.Constructor; + ++import javax.xml.XMLConstants; + import javax.xml.parsers.DocumentBuilder; + import javax.xml.parsers.DocumentBuilderFactory; + import javax.xml.parsers.ParserConfigurationException; +@@ -251,6 +252,7 @@ + _propertiesClone = (Properties) _properties.clone(); + _indentNumber = indentNumber; + _tfactory = tfactory; ++ _readerManager.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, _isSecureProcessing); + //_isIncremental = tfactory._incremental; + } + +@@ -266,6 +268,7 @@ + */ + public void setSecureProcessing(boolean flag) { + _isSecureProcessing = flag; ++ _readerManager.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, _isSecureProcessing); + } + + /** +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/Util.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/Util.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/Util.java Tue Oct 29 05:50:44 2013 +0000 +@@ -104,6 +104,13 @@ + if (reader == null) { + try { + reader= XMLReaderFactory.createXMLReader(); ++ try { ++ reader.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, ++ xsltc.isSecureProcessing()); ++ } catch (SAXNotRecognizedException e) { ++ System.err.println("Warning: " + reader.getClass().getName() + ": " ++ + e.getMessage()); ++ } + } catch (Exception e ) { + try { + +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java Tue Oct 29 05:50:44 2013 +0000 +@@ -20,9 +20,18 @@ + + package com.sun.org.apache.xerces.internal.jaxp.validation; + ++import com.sun.org.apache.xerces.internal.impl.Constants; ++import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter; ++import com.sun.org.apache.xerces.internal.impl.msg.XMLMessageFormatter; ++import com.sun.org.apache.xerces.internal.parsers.XML11Configuration; ++import com.sun.org.apache.xerces.internal.util.SecurityManager; ++import com.sun.org.apache.xerces.internal.xni.XNIException; ++import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; ++import com.sun.org.apache.xerces.internal.xni.parser.XMLParseException; ++import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; + import java.lang.ref.SoftReference; + import java.io.IOException; +- ++import javax.xml.XMLConstants; + import javax.xml.transform.Result; + import javax.xml.transform.Source; + import javax.xml.transform.sax.SAXTransformerFactory; +@@ -32,15 +41,6 @@ + import javax.xml.transform.TransformerConfigurationException; + import javax.xml.transform.TransformerException; + import javax.xml.transform.TransformerFactoryConfigurationError; +- +-import com.sun.org.apache.xerces.internal.impl.Constants; +-import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter; +-import com.sun.org.apache.xerces.internal.impl.msg.XMLMessageFormatter; +-import com.sun.org.apache.xerces.internal.parsers.XML11Configuration; +-import com.sun.org.apache.xerces.internal.xni.XNIException; +-import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; +-import com.sun.org.apache.xerces.internal.xni.parser.XMLParseException; +-import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; + import org.xml.sax.SAXException; + + /** +@@ -84,6 +84,11 @@ + private static final String VALIDATION_MANAGER = + Constants.XERCES_PROPERTY_PREFIX + Constants.VALIDATION_MANAGER_PROPERTY; + ++ ++ /** Property id: security manager. */ ++ private static final String SECURITY_MANAGER = ++ Constants.XERCES_PROPERTY_PREFIX + Constants.SECURITY_MANAGER_PROPERTY; ++ + // + // Data + // +@@ -161,6 +166,9 @@ + + private XMLParserConfiguration initialize() { + XML11Configuration config = new XML11Configuration(); ++ if (fComponentManager.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING)) { ++ config.setProperty(SECURITY_MANAGER, new SecurityManager()); ++ } + config.setProperty(ENTITY_RESOLVER, fComponentManager.getProperty(ENTITY_RESOLVER)); + config.setProperty(ERROR_HANDLER, fComponentManager.getProperty(ERROR_HANDLER)); + XMLErrorReporter errorReporter = (XMLErrorReporter) fComponentManager.getProperty(ERROR_REPORTER); +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/ValidatorHandlerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/ValidatorHandlerImpl.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/ValidatorHandlerImpl.java Tue Oct 29 05:50:44 2013 +0000 +@@ -672,6 +672,8 @@ + SAXParserFactory spf = SAXParserFactory.newInstance(); + spf.setNamespaceAware(true); + try { ++ spf.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, ++ fComponentManager.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING)); + reader = spf.newSAXParser().getXMLReader(); + // If this is a Xerces SAX parser, set the security manager if there is one + if (reader instanceof com.sun.org.apache.xerces.internal.parsers.SAXParser) { +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/AbstractSAXParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/AbstractSAXParser.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/AbstractSAXParser.java Tue Oct 29 05:50:44 2013 +0000 +@@ -20,15 +20,12 @@ + + package com.sun.org.apache.xerces.internal.parsers; + +-import java.io.IOException; +-import java.util.Locale; +- + import com.sun.org.apache.xerces.internal.impl.Constants; +-import com.sun.org.apache.xerces.internal.xs.PSVIProvider; ++import com.sun.org.apache.xerces.internal.util.EntityResolver2Wrapper; + import com.sun.org.apache.xerces.internal.util.EntityResolverWrapper; +-import com.sun.org.apache.xerces.internal.util.EntityResolver2Wrapper; + import com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper; + import com.sun.org.apache.xerces.internal.util.SAXMessageFormatter; ++import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.SymbolHash; + import com.sun.org.apache.xerces.internal.util.XMLSymbols; + import com.sun.org.apache.xerces.internal.xni.Augmentations; +@@ -47,15 +44,17 @@ + import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; + import com.sun.org.apache.xerces.internal.xs.AttributePSVI; + import com.sun.org.apache.xerces.internal.xs.ElementPSVI; ++import com.sun.org.apache.xerces.internal.xs.PSVIProvider; ++import java.io.IOException; ++import java.util.Locale; ++import javax.xml.XMLConstants; + import org.xml.sax.AttributeList; +-import org.xml.sax.Attributes; + import org.xml.sax.ContentHandler; + import org.xml.sax.DTDHandler; + import org.xml.sax.DocumentHandler; + import org.xml.sax.EntityResolver; + import org.xml.sax.ErrorHandler; + import org.xml.sax.InputSource; +-import org.xml.sax.Locator; + import org.xml.sax.Parser; + import org.xml.sax.SAXException; + import org.xml.sax.SAXNotRecognizedException; +@@ -129,6 +128,10 @@ + protected static final String DOM_NODE = + Constants.SAX_PROPERTY_PREFIX + Constants.DOM_NODE_PROPERTY; + ++ /** Property id: security manager. */ ++ private static final String SECURITY_MANAGER = ++ Constants.XERCES_PROPERTY_PREFIX + Constants.SECURITY_MANAGER_PROPERTY; ++ + /** Recognized properties. */ + private static final String[] RECOGNIZED_PROPERTIES = { + LEXICAL_HANDLER, +@@ -1643,19 +1646,13 @@ + // Drop through and perform default processing + // + } +- +- // +- // Xerces Features +- // +- +- /* +- else if (featureId.startsWith(XERCES_FEATURES_PREFIX)) { +- String feature = featureId.substring(XERCES_FEATURES_PREFIX.length()); +- // +- // Drop through and perform default processing +- // ++ else if (featureId.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { ++ if (state) { ++ if (fConfiguration.getProperty(SECURITY_MANAGER )==null) { ++ fConfiguration.setProperty(SECURITY_MANAGER, new SecurityManager()); ++ } ++ } + } +- */ + + // + // Default handling +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java Tue Oct 29 05:50:44 2013 +0000 +@@ -20,11 +20,6 @@ + + package com.sun.org.apache.xerces.internal.parsers; + +-import java.io.IOException; +-import java.util.ArrayList; +-import java.util.HashMap; +-import java.util.Locale; +- + import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.impl.XML11DTDScannerImpl; + import com.sun.org.apache.xerces.internal.impl.XML11DocumentScannerImpl; +@@ -65,6 +60,11 @@ + import com.sun.org.apache.xerces.internal.xni.parser.XMLErrorHandler; + import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; + import com.sun.org.apache.xerces.internal.xni.parser.XMLPullParserConfiguration; ++import java.io.IOException; ++import java.util.ArrayList; ++import java.util.HashMap; ++import java.util.Locale; ++import javax.xml.XMLConstants; + + /** + * This class is the configuration used to parse XML 1.0 and XML 1.1 documents. +@@ -428,30 +428,30 @@ + XMLGrammarPool grammarPool, + XMLComponentManager parentSettings) { + +- super(parentSettings); ++ super(parentSettings); + +- // create a vector to hold all the components in use +- // XML 1.0 specialized components +- fComponents = new ArrayList(); +- // XML 1.1 specialized components +- fXML11Components = new ArrayList(); +- // Common components for XML 1.1. and XML 1.0 +- fCommonComponents = new ArrayList(); ++ // create a vector to hold all the components in use ++ // XML 1.0 specialized components ++ fComponents = new ArrayList(); ++ // XML 1.1 specialized components ++ fXML11Components = new ArrayList(); ++ // Common components for XML 1.1. and XML 1.0 ++ fCommonComponents = new ArrayList(); + +- // create storage for recognized features and properties +- fRecognizedFeatures = new ArrayList(); +- fRecognizedProperties = new ArrayList(); +- +- // create table for features and properties +- fFeatures = new HashMap(); +- fProperties = new HashMap(); ++ // create storage for recognized features and properties ++ fRecognizedFeatures = new ArrayList(); ++ fRecognizedProperties = new ArrayList(); ++ ++ // create table for features and properties ++ fFeatures = new HashMap(); ++ fProperties = new HashMap(); + + // add default recognized features + final String[] recognizedFeatures = + { + CONTINUE_AFTER_FATAL_ERROR, LOAD_EXTERNAL_DTD, // from XMLDTDScannerImpl +- VALIDATION, +- NAMESPACES, ++ VALIDATION, ++ NAMESPACES, + NORMALIZE_DATA, SCHEMA_ELEMENT_DEFAULT, SCHEMA_AUGMENT_PSVI, + GENERATE_SYNTHETIC_ANNOTATIONS, VALIDATE_ANNOTATIONS, + HONOUR_ALL_SCHEMALOCATIONS, USE_GRAMMAR_POOL_ONLY, +@@ -460,26 +460,29 @@ + // features might not have been set and it would cause a + // not-recognized exception to be thrown. -Ac + XMLSCHEMA_VALIDATION, XMLSCHEMA_FULL_CHECKING, +- EXTERNAL_GENERAL_ENTITIES, +- EXTERNAL_PARAMETER_ENTITIES, +- PARSER_SETTINGS ++ EXTERNAL_GENERAL_ENTITIES, ++ EXTERNAL_PARAMETER_ENTITIES, ++ PARSER_SETTINGS, ++ XMLConstants.FEATURE_SECURE_PROCESSING + }; ++ + addRecognizedFeatures(recognizedFeatures); + // set state for default features +- fFeatures.put(VALIDATION, Boolean.FALSE); +- fFeatures.put(NAMESPACES, Boolean.TRUE); +- fFeatures.put(EXTERNAL_GENERAL_ENTITIES, Boolean.TRUE); +- fFeatures.put(EXTERNAL_PARAMETER_ENTITIES, Boolean.TRUE); +- fFeatures.put(CONTINUE_AFTER_FATAL_ERROR, Boolean.FALSE); +- fFeatures.put(LOAD_EXTERNAL_DTD, Boolean.TRUE); +- fFeatures.put(SCHEMA_ELEMENT_DEFAULT, Boolean.TRUE); +- fFeatures.put(NORMALIZE_DATA, Boolean.TRUE); +- fFeatures.put(SCHEMA_AUGMENT_PSVI, Boolean.TRUE); ++ fFeatures.put(VALIDATION, Boolean.FALSE); ++ fFeatures.put(NAMESPACES, Boolean.TRUE); ++ fFeatures.put(EXTERNAL_GENERAL_ENTITIES, Boolean.TRUE); ++ fFeatures.put(EXTERNAL_PARAMETER_ENTITIES, Boolean.TRUE); ++ fFeatures.put(CONTINUE_AFTER_FATAL_ERROR, Boolean.FALSE); ++ fFeatures.put(LOAD_EXTERNAL_DTD, Boolean.TRUE); ++ fFeatures.put(SCHEMA_ELEMENT_DEFAULT, Boolean.TRUE); ++ fFeatures.put(NORMALIZE_DATA, Boolean.TRUE); ++ fFeatures.put(SCHEMA_AUGMENT_PSVI, Boolean.TRUE); + fFeatures.put(GENERATE_SYNTHETIC_ANNOTATIONS, Boolean.FALSE); + fFeatures.put(VALIDATE_ANNOTATIONS, Boolean.FALSE); + fFeatures.put(HONOUR_ALL_SCHEMALOCATIONS, Boolean.FALSE); + fFeatures.put(USE_GRAMMAR_POOL_ONLY, Boolean.FALSE); +- fFeatures.put(PARSER_SETTINGS, Boolean.TRUE); ++ fFeatures.put(PARSER_SETTINGS, Boolean.TRUE); ++ fFeatures.put(XMLConstants.FEATURE_SECURE_PROCESSING, Boolean.TRUE); + + // add default recognized properties + final String[] recognizedProperties = +diff -r b5b1d1fa4bb4 -r 7799c3bd00f5 drop_included/jaxp_src/src/com/sun/org/apache/xml/internal/utils/XMLReaderManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xml/internal/utils/XMLReaderManager.java Thu Oct 10 16:18:30 2013 +0100 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xml/internal/utils/XMLReaderManager.java Tue Oct 29 05:50:44 2013 +0000 +@@ -24,6 +24,7 @@ + + import java.util.HashMap; + ++import javax.xml.XMLConstants; + import javax.xml.parsers.FactoryConfigurationError; + import javax.xml.parsers.ParserConfigurationException; + import javax.xml.parsers.SAXParserFactory; +@@ -31,6 +32,7 @@ + import org.xml.sax.XMLReader; + import org.xml.sax.helpers.XMLReaderFactory; + import org.xml.sax.SAXException; ++import org.xml.sax.SAXNotRecognizedException; + + /** + * Creates XMLReader objects and caches them for re-use. +@@ -60,6 +62,8 @@ + */ + private HashMap m_inUse; + ++ ++ private boolean _secureProcessing; + /** + * Hidden constructor + */ +@@ -109,7 +113,12 @@ + // TransformerFactory creates a reader via the + // XMLReaderFactory if setXMLReader is not used + reader = XMLReaderFactory.createXMLReader(); +- ++ try { ++ reader.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, _secureProcessing); ++ } catch (SAXNotRecognizedException e) { ++ System.err.println("Warning: " + reader.getClass().getName() + ": " ++ + e.getMessage()); ++ } + } catch (Exception e) { + try { + // If unable to create an instance, let's try to use +@@ -150,6 +159,15 @@ + return reader; + } + ++ /** ++ * Set feature ++ */ ++ public void setFeature(String name, boolean value) { ++ if (name.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { ++ _secureProcessing = value; ++ } ++ } ++ + /** + * Mark the cached XMLReader as available. If the reader was not + * actually in the cache, do nothing. diff --git a/java/openjdk6/files/icedtea/openjdk/8012453-runtime.exec.patch b/java/openjdk6/files/icedtea/openjdk/8012453-runtime.exec.patch new file mode 100644 index 000000000000..143a0c1f286d --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012453-runtime.exec.patch @@ -0,0 +1,383 @@ +# HG changeset patch +# User uta +# Date 1383008821 0 +# Tue Oct 29 01:07:01 2013 +0000 +# Node ID 20c88fd14959c6a4df2e0f36bd759b56efa6f2cb +# Parent 3e758b40337ef9da5ad030d0ac60ab4407357277 +8012453: (process) Runtime.exec(String) fails if command contains spaces [win] +Reviewed-by: alanb + +diff -r 3e758b40337e -r 20c88fd14959 src/share/classes/java/lang/ProcessBuilder.java +--- jdk/src/share/classes/java/lang/ProcessBuilder.java Tue Jul 30 17:20:22 2013 -0400 ++++ jdk/src/share/classes/java/lang/ProcessBuilder.java Tue Oct 29 01:07:01 2013 +0000 +@@ -490,6 +490,15 @@ + + (dir == null ? "" : " (in directory \"" + dir + "\")") + + exceptionInfo, + cause); ++ } catch (IllegalArgumentException e) { ++ String exceptionInfo = ": " + e.getMessage(); ++ // It's much easier for us to create a high-quality error ++ // message than the low-level C code which found the problem. ++ throw new IOException( ++ "Cannot run program \"" + prog + "\"" ++ + (dir == null ? "" : " (in directory \"" + dir + "\")") ++ + exceptionInfo, ++ e); + } + } + } +diff -r 3e758b40337e -r 20c88fd14959 src/windows/classes/java/lang/ProcessImpl.java +--- jdk/src/windows/classes/java/lang/ProcessImpl.java Tue Jul 30 17:20:22 2013 -0400 ++++ jdk/src/windows/classes/java/lang/ProcessImpl.java Tue Oct 29 01:07:01 2013 +0000 +@@ -26,6 +26,9 @@ + package java.lang; + + import java.io.*; ++import java.util.ArrayList; ++import java.util.regex.Matcher; ++import java.util.regex.Pattern; + + /* This class is for the exclusive use of ProcessBuilder.start() to + * create new processes. +@@ -47,6 +50,66 @@ + return new ProcessImpl(cmdarray, envblock, dir, redirectErrorStream); + } + ++ private static class LazyPattern { ++ // Escape-support version: ++ // "(\")((?:\\\\\\1|.)+?)\\1|([^\\s\"]+)"; ++ private static final Pattern PATTERN = ++ Pattern.compile("[^\\s\"]+|\"[^\"]*\""); ++ }; ++ ++ /* Parses the command string parameter into the executable name and ++ * program arguments. ++ * ++ * The command string is broken into tokens. The token separator is a space ++ * or quota character. The space inside quotation is not a token separator. ++ * There are no escape sequences. ++ */ ++ private static String[] getTokensFromCommand(String command) { ++ ArrayList<String> matchList = new ArrayList<String>(8); ++ Matcher regexMatcher = LazyPattern.PATTERN.matcher(command); ++ while (regexMatcher.find()) ++ matchList.add(regexMatcher.group()); ++ return matchList.toArray(new String[matchList.size()]); ++ } ++ ++ private static String createCommandLine(boolean isCmdFile, ++ final String executablePath, ++ final String cmd[]) ++ { ++ StringBuilder cmdbuf = new StringBuilder(80); ++ ++ cmdbuf.append(executablePath); ++ ++ for (int i = 1; i < cmd.length; ++i) { ++ cmdbuf.append(' '); ++ String s = cmd[i]; ++ if (needsEscaping(isCmdFile, s)) { ++ cmdbuf.append('"'); ++ cmdbuf.append(s); ++ ++ // The code protects the [java.exe] and console command line ++ // parser, that interprets the [\"] combination as an escape ++ // sequence for the ["] char. ++ // http://msdn.microsoft.com/en-us/library/17w5ykft.aspx ++ // ++ // If the argument is an FS path, doubling of the tail [\] ++ // char is not a problem for non-console applications. ++ // ++ // The [\"] sequence is not an escape sequence for the [cmd.exe] ++ // command line parser. The case of the [""] tail escape ++ // sequence could not be realized due to the argument validation ++ // procedure. ++ if (!isCmdFile && s.endsWith("\\")) { ++ cmdbuf.append('\\'); ++ } ++ cmdbuf.append('"'); ++ } else { ++ cmdbuf.append(s); ++ } ++ } ++ return cmdbuf.toString(); ++ } ++ + // We guarantee the only command file execution for implicit [cmd.exe] run. + // http://technet.microsoft.com/en-us/library/bb490954.aspx + private static final char CMD_BAT_ESCAPE[] = {' ', '\t', '<', '>', '&', '|', '^'}; +@@ -128,6 +191,16 @@ + return fileToRun.getPath(); + } + ++ private boolean isShellFile(String executablePath) { ++ String upPath = executablePath.toUpperCase(); ++ return (upPath.endsWith(".CMD") || upPath.endsWith(".BAT")); ++ } ++ ++ private String quoteString(String arg) { ++ StringBuilder argbuf = new StringBuilder(arg.length() + 2); ++ return argbuf.append('"').append(arg).append('"').toString(); ++ } ++ + + private long handle = 0; + private FileDescriptor stdin_fd; +@@ -143,36 +216,66 @@ + boolean redirectErrorStream) + throws IOException + { +- // The [executablePath] is not quoted for any case. +- String executablePath = getExecutablePath(cmd[0]); ++ String cmdstr; ++ SecurityManager security = System.getSecurityManager(); ++ boolean allowAmbigousCommands = false; ++ if (security == null) { ++ String value = System.getProperty("jdk.lang.Process.allowAmbigousCommands"); ++ if (value != null) ++ allowAmbigousCommands = !"false".equalsIgnoreCase(value); ++ } ++ if (allowAmbigousCommands) { ++ // Legacy mode. + +- // We need to extend the argument verification procedure +- // to guarantee the only command file execution for implicit [cmd.exe] +- // run. +- String upPath = executablePath.toUpperCase(); +- boolean isCmdFile = (upPath.endsWith(".CMD") || upPath.endsWith(".BAT")); ++ // Normalize path if possible. ++ String executablePath = new File(cmd[0]).getPath(); + +- StringBuilder cmdbuf = new StringBuilder(80); ++ // No worry about internal and unpaired ["] . ++ if (needsEscaping(false, executablePath) ) ++ executablePath = quoteString(executablePath); + +- // Quotation protects from interpretation of the [path] argument as +- // start of longer path with spaces. Quotation has no influence to +- // [.exe] extension heuristic. +- cmdbuf.append('"'); +- cmdbuf.append(executablePath); +- cmdbuf.append('"'); ++ cmdstr = createCommandLine( ++ false, //legacy mode doesn't worry about extended verification ++ executablePath, ++ cmd); ++ } else { ++ String executablePath; ++ try { ++ executablePath = getExecutablePath(cmd[0]); ++ } catch (IllegalArgumentException e) { ++ // Workaround for the calls like ++ // Runtime.getRuntime().exec("\"C:\\Program Files\\foo\" bar") + +- for (int i = 1; i < cmd.length; i++) { +- cmdbuf.append(' '); +- String s = cmd[i]; +- if (needsEscaping(isCmdFile, s)) { +- cmdbuf.append('"'); +- cmdbuf.append(s); +- cmdbuf.append('"'); +- } else { +- cmdbuf.append(s); ++ // No chance to avoid CMD/BAT injection, except to do the work ++ // right from the beginning. Otherwise we have too many corner ++ // cases from ++ // Runtime.getRuntime().exec(String[] cmd [, ...]) ++ // calls with internal ["] and escape sequences. ++ ++ // Restore original command line. ++ StringBuilder join = new StringBuilder(); ++ // terminal space in command line is ok ++ for (String s : cmd) ++ join.append(s).append(' '); ++ ++ // Parse the command line again. ++ cmd = getTokensFromCommand(join.toString()); ++ executablePath = getExecutablePath(cmd[0]); ++ ++ // Check new executable name once more ++ if (security != null) ++ security.checkExec(executablePath); + } ++ ++ // Quotation protects from interpretation of the [path] argument as ++ // start of longer path with spaces. Quotation has no influence to ++ // [.exe] extension heuristic. ++ cmdstr = createCommandLine( ++ // We need the extended verification procedure for CMD files. ++ isShellFile(executablePath), ++ quoteString(executablePath), ++ cmd); + } +- String cmdstr = cmdbuf.toString(); + + stdin_fd = new FileDescriptor(); + stdout_fd = new FileDescriptor(); +diff -r 3e758b40337e -r 20c88fd14959 test/java/lang/Runtime/exec/ExecCommand.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/lang/Runtime/exec/ExecCommand.java Tue Oct 29 01:07:01 2013 +0000 +@@ -0,0 +1,163 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++ ++/** ++ * @test ++ * @bug 8012453 ++ * @run main/othervm ExecCommand ++ * @summary workaround for legacy applications with Runtime.getRuntime().exec(String command) ++ */ ++ ++import java.io.BufferedWriter; ++import java.io.File; ++import java.io.FileWriter; ++import java.io.IOException; ++import java.security.AccessControlException; ++ ++public class ExecCommand { ++ static class SecurityMan extends SecurityManager { ++ public static String unquote(String str) ++ { ++ int length = (str == null) ++ ? 0 ++ : str.length(); ++ ++ if (length > 1 ++ && str.charAt(0) == '\"' ++ && str.charAt(length - 1) == '\"') ++ { ++ return str.substring(1, length - 1); ++ } ++ return str; ++ } ++ ++ @Override public void checkExec(String cmd) { ++ String ncmd = (new File(unquote(cmd))).getPath(); ++ if ( ncmd.equals(".\\Program") ++ || ncmd.equals("\".\\Program") ++ || ncmd.equals(".\\Program Files\\do.cmd") ++ || ncmd.equals(".\\Program.cmd")) ++ { ++ return; ++ } ++ super.checkExec(cmd); ++ } ++ } ++ ++ // Parameters for the Runtime.exec calls ++ private static final String TEST_RTE_ARG[] = { ++ ".\\Program Files\\do.cmd", ++ "\".\\Program Files\\doNot.cmd\" arg", ++ "\".\\Program Files\\do.cmd\" arg", ++ // compatibility ++ "\".\\Program.cmd\" arg", ++ ".\\Program.cmd arg", ++ }; ++ ++ private static final String doCmdCopy[] = { ++ ".\\Program.cmd", ++ ".\\Program Files\\doNot.cmd", ++ ".\\Program Files\\do.cmd", ++ }; ++ ++ // Golden image for results ++ private static final String TEST_RTE_GI[][] = { ++ //Pure system | Legacy mode | Legacy mode & SM ++ // [.\Program File\do.cmd] ++ new String[]{"IOException", // [.\Program] not found ++ "Success", ++ "IOException"}, //SM - no legacy mode [.\Program] - OK ++ ++ // [".\Program File\doNot.cmd" arg] ++ new String[]{"Success", ++ "Success", ++ "AccessControlException"}, //SM - [".\Program] - OK, ++ // [.\\Program Files\\doNot.cmd] - Fail ++ ++ // [".\Program File\do.cmd" arg] ++ // AccessControlException ++ new String[]{"Success", ++ "Success", ++ "Success"}, //SM - [".\Program] - OK, ++ // [.\\Program Files\\do.cmd] - OK ++ ++ // compatibility ++ new String[]{"Success", "Success", "Success"}, //[".\Program.cmd"] ++ new String[]{"Success", "Success", "Success"} //[.\Program.cmd] ++ }; ++ ++ public static void main(String[] _args) throws Exception { ++ if (!System.getProperty("os.name").startsWith("Windows")) { ++ return; ++ } ++ ++ // tear up ++ try { ++ new File(".\\Program Files").mkdirs(); ++ for (int i = 0; i < doCmdCopy.length; ++i) { ++ try (BufferedWriter outCmd = new BufferedWriter( ++ new FileWriter(doCmdCopy[i]))) { ++ outCmd.write("@echo %1"); ++ } ++ } ++ } catch (IOException e) { ++ throw new Error(e.getMessage()); ++ } ++ ++ // action ++ for (int k = 0; k < 3; ++k) { ++ switch (k) { ++ case 1: ++ System.setProperty("jdk.lang.Process.allowAmbigousCommands", ""); ++ break; ++ case 2: ++ System.setSecurityManager( new SecurityMan() ); ++ break; ++ } ++ for (int i = 0; i < TEST_RTE_ARG.length; ++i) { ++ String outRes; ++ try { ++ Process exec = Runtime.getRuntime().exec(TEST_RTE_ARG[i]); ++ exec.waitFor(); ++ outRes = "Success"; ++ } catch (IOException ioe) { ++ outRes = "IOException: " + ioe.getMessage(); ++ } catch (IllegalArgumentException iae) { ++ outRes = "IllegalArgumentException: " + iae.getMessage(); ++ } catch (AccessControlException se) { ++ outRes = "AccessControlException: " + se.getMessage(); ++ } ++ ++ if (!outRes.startsWith(TEST_RTE_GI[i][k])) { ++ throw new Error("Unexpected output! Step" + k + "" + i ++ + " \nArgument: " + TEST_RTE_ARG[i] ++ + "\nExpected: " + TEST_RTE_GI[i][k] ++ + "\n Output: " + outRes); ++ } else { ++ System.out.println("RTE OK:" + TEST_RTE_ARG[i]); ++ } ++ } ++ } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8012617-arrayindexoutofbounds_linebreakmeasurer.patch b/java/openjdk6/files/icedtea/openjdk/8012617-arrayindexoutofbounds_linebreakmeasurer.patch new file mode 100644 index 000000000000..2b9d41d8dae5 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8012617-arrayindexoutofbounds_linebreakmeasurer.patch @@ -0,0 +1,515 @@ +# HG changeset patch +# User prr +# Date 1382993769 0 +# Mon Oct 28 20:56:09 2013 +0000 +# Node ID 150e0c3e95ce6869f8e7b42c6d8683817433e124 +# Parent 9cfb9105241489a5fbc3fcfdea15a6aee15b2cfc +8012617: ArrayIndexOutOfBoundsException with some fonts using LineBreakMeasurer +Reviewed-by: bae, srl, omajid + +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/classes/sun/font/ExtendedTextSourceLabel.java +--- jdk/src/share/classes/sun/font/ExtendedTextSourceLabel.java Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/classes/sun/font/ExtendedTextSourceLabel.java Mon Oct 28 20:56:09 2013 +0000 +@@ -246,6 +246,10 @@ + float aw = 0f; + float ah = cm.ascent + cm.descent; + ++ if (charinfo == null || charinfo.length == 0) { ++ return new Rectangle2D.Float(al, at, aw, ah); ++ } ++ + boolean lineIsLTR = (source.getLayoutFlags() & 0x8) == 0; + int rn = info.length - numvals; + if (lineIsLTR) { +@@ -349,24 +353,42 @@ + + public float getCharX(int index) { + validate(index); +- return getCharinfo()[l2v(index) * numvals + posx]; ++ float[] charinfo = getCharinfo(); ++ int idx = l2v(index) * numvals + posx; ++ if (charinfo == null || idx >= charinfo.length) { ++ return 0f; ++ } else { ++ return charinfo[idx]; ++ } + } + + public float getCharY(int index) { + validate(index); +- return getCharinfo()[l2v(index) * numvals + posy]; ++ float[] charinfo = getCharinfo(); ++ int idx = l2v(index) * numvals + posy; ++ if (charinfo == null || idx >= charinfo.length) { ++ return 0f; ++ } else { ++ return charinfo[idx]; ++ } + } + + public float getCharAdvance(int index) { + validate(index); +- return getCharinfo()[l2v(index) * numvals + advx]; ++ float[] charinfo = getCharinfo(); ++ int idx = l2v(index) * numvals + advx; ++ if (charinfo == null || idx >= charinfo.length) { ++ return 0f; ++ } else { ++ return charinfo[idx]; ++ } + } + + public Rectangle2D handleGetCharVisualBounds(int index) { + validate(index); + float[] charinfo = getCharinfo(); + index = l2v(index) * numvals; +- if ((index+vish) >= charinfo.length) { ++ if (charinfo == null || (index+vish) >= charinfo.length) { + return new Rectangle2D.Float(); + } + return new Rectangle2D.Float( +@@ -462,7 +484,7 @@ + if (cidx >= charinfo.length) { + break; // layout bailed for some reason + } +- float adv = charinfo[l2v(start) * numvals + advx]; ++ float adv = charinfo[cidx]; + width -= adv; + } + +@@ -511,7 +533,13 @@ + // } + //} + +- return getCharinfo()[v * numvals + advx] != 0; ++ int idx = v * numvals + advx; ++ float[] charinfo = getCharinfo(); ++ if (charinfo == null || idx >= charinfo.length) { ++ return false; ++ } else { ++ return charinfo[idx] != 0; ++ } + } + + private final float[] getCharinfo() { +@@ -603,6 +631,9 @@ + */ + + int numGlyphs = gv.getNumGlyphs(); ++ if (numGlyphs == 0) { ++ return glyphinfo; ++ } + int[] indices = gv.getGlyphCharIndices(0, numGlyphs, null); + + boolean DEBUG = false; +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/classes/sun/font/GlyphLayout.java +--- jdk/src/share/classes/sun/font/GlyphLayout.java Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/classes/sun/font/GlyphLayout.java Mon Oct 28 20:56:09 2013 +0000 +@@ -76,9 +76,12 @@ + import java.awt.geom.Point2D; + import java.util.ArrayList; + import java.util.concurrent.ConcurrentHashMap; ++import java.util.logging.Logger; + + import static java.lang.Character.*; + ++import sun.java2d.SunGraphicsEnvironment; ++ + public final class GlyphLayout { + // data for glyph vector + private GVData _gvdata; +@@ -461,7 +464,12 @@ + break; + } + catch (IndexOutOfBoundsException e) { +- _gvdata.grow(); ++ if (_gvdata._count >=0) { ++ _gvdata.grow(); ++ } ++ } ++ if (_gvdata._count < 0) { ++ break; + } + } + } +@@ -470,7 +478,19 @@ + // _gvdata.adjustPositions(txinfo.invdtx); + // } + +- StandardGlyphVector gv = _gvdata.createGlyphVector(font, frc, result); ++ // If layout fails (negative glyph count) create an un-laid out GV instead. ++ // ie default positions. This will be a lot better than the alternative of ++ // a complete blank layout. ++ StandardGlyphVector gv; ++ if (_gvdata._count < 0) { ++ gv = new StandardGlyphVector(font, text, offset, count, frc); ++ if (SunGraphicsEnvironment.debugFonts) { ++ Logger.getLogger("sun.java2d").warning("OpenType layout failed on font: " + ++ font); ++ } ++ } else { ++ gv = _gvdata.createGlyphVector(font, frc, result); ++ } + // System.err.println("Layout returns: " + gv); + return gv; + } +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/ContextualSubstSubtables.cpp +--- jdk/src/share/native/sun/font/layout/ContextualSubstSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/ContextualSubstSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -218,6 +218,9 @@ + + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(lookupProcessor->getReference(), glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + le_uint16 srSetCount = SWAPW(subRuleSetCount); +@@ -267,6 +270,9 @@ + + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(lookupProcessor->getReference(), glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + const ClassDefinitionTable *classDefinitionTable = +@@ -395,6 +401,9 @@ + + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(lookupProcessor->getReference(), glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + le_uint16 srSetCount = SWAPW(chainSubRuleSetCount); +@@ -466,6 +475,9 @@ + + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(lookupProcessor->getReference(), glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + const ClassDefinitionTable *backtrackClassDefinitionTable = +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/CursiveAttachmentSubtables.cpp +--- jdk/src/share/native/sun/font/layout/CursiveAttachmentSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/CursiveAttachmentSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -45,7 +45,7 @@ + le_int32 coverageIndex = getGlyphCoverage(base, glyphID, success); + le_uint16 eeCount = SWAPW(entryExitCount); + +- if (coverageIndex < 0 || coverageIndex >= eeCount) { ++ if (coverageIndex < 0 || coverageIndex >= eeCount || LE_FAILURE(success)) { + glyphIterator->setCursiveGlyph(); + return 0; + } +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/ExtensionSubtables.cpp +--- jdk/src/share/native/sun/font/layout/ExtensionSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/ExtensionSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -44,10 +44,10 @@ + #define READ_LONG(code) (le_uint32)((SWAPW(*(le_uint16*)&code) << 16) + SWAPW(*(((le_uint16*)&code) + 1))) + + // FIXME: should look at the format too... maybe have a sub-class for it? +-le_uint32 ExtensionSubtable::process(const LookupProcessor *lookupProcessor, le_uint16 lookupType, ++le_uint32 ExtensionSubtable::process(const LEReferenceTo<ExtensionSubtable> &thisRef, ++ const LookupProcessor *lookupProcessor, le_uint16 lookupType, + GlyphIterator *glyphIterator, const LEFontInstance *fontInstance, LEErrorCode& success) const + { +- const LEReferenceTo<ExtensionSubtable> thisRef(lookupProcessor->getReference(), success); // create a reference to this + + if (LE_FAILURE(success)) { + return 0; +@@ -57,7 +57,7 @@ + + if (elt != lookupType) { + le_uint32 extOffset = READ_LONG(extensionOffset); +- LEReferenceTo<LookupSubtable> subtable(thisRef, success, extOffset); ++ LEReferenceTo<LookupSubtable> subtable(thisRef, success, extOffset); + + if(LE_SUCCESS(success)) { + return lookupProcessor->applySubtable(subtable, elt, glyphIterator, fontInstance, success); +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/ExtensionSubtables.h +--- jdk/src/share/native/sun/font/layout/ExtensionSubtables.h Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/ExtensionSubtables.h Mon Oct 28 20:56:09 2013 +0000 +@@ -52,7 +52,8 @@ + le_uint16 extensionLookupType; + le_uint32 extensionOffset; + +- le_uint32 process(const LookupProcessor *lookupProcessor, le_uint16 lookupType, ++ le_uint32 process(const LEReferenceTo<ExtensionSubtable> &extRef, ++ const LookupProcessor *lookupProcessor, le_uint16 lookupType, + GlyphIterator *glyphIterator, const LEFontInstance *fontInstance, LEErrorCode& success) const; + }; + +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/GlyphPosnLookupProc.cpp +--- jdk/src/share/native/sun/font/layout/GlyphPosnLookupProc.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/GlyphPosnLookupProc.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -168,7 +168,7 @@ + { + LEReferenceTo<ExtensionSubtable> subtable(lookupSubtable, success); + +- delta = subtable->process(this, lookupType, glyphIterator, fontInstance, success); ++ delta = subtable->process(subtable, this, lookupType, glyphIterator, fontInstance, success); + break; + } + +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/GlyphSubstLookupProc.cpp +--- jdk/src/share/native/sun/font/layout/GlyphSubstLookupProc.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/GlyphSubstLookupProc.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -139,7 +139,7 @@ + { + const LEReferenceTo<ExtensionSubtable> subtable(lookupSubtable, success); + +- delta = subtable->process(this, lookupType, glyphIterator, fontInstance, success); ++ delta = subtable->process(subtable, this, lookupType, glyphIterator, fontInstance, success); + break; + } + +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/LigatureSubstSubtables.cpp +--- jdk/src/share/native/sun/font/layout/LigatureSubstSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/LigatureSubstSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -45,6 +45,10 @@ + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(base, glyph, success); + ++ if (LE_FAILURE(success)) { ++ return 0; ++ } ++ + if (coverageIndex >= 0) { + Offset ligSetTableOffset = SWAPW(ligSetTableOffsetArray[coverageIndex]); + const LigatureSetTable *ligSetTable = (const LigatureSetTable *) ((char *) this + ligSetTableOffset); +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/MarkToBasePosnSubtables.cpp +--- jdk/src/share/native/sun/font/layout/MarkToBasePosnSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/MarkToBasePosnSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -56,6 +56,10 @@ + LEGlyphID markGlyph = glyphIterator->getCurrGlyphID(); + le_int32 markCoverage = getGlyphCoverage(base, (LEGlyphID) markGlyph, success); + ++ if (LE_FAILURE(success)) { ++ return 0; ++ } ++ + if (markCoverage < 0) { + // markGlyph isn't a covered mark glyph + return 0; +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/MarkToLigaturePosnSubtables.cpp +--- jdk/src/share/native/sun/font/layout/MarkToLigaturePosnSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/MarkToLigaturePosnSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -55,6 +55,10 @@ + LEGlyphID markGlyph = glyphIterator->getCurrGlyphID(); + le_int32 markCoverage = getGlyphCoverage(base, (LEGlyphID) markGlyph, success); + ++ if (LE_FAILURE(success)) { ++ return 0; ++ } ++ + if (markCoverage < 0) { + // markGlyph isn't a covered mark glyph + return 0; +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/MarkToMarkPosnSubtables.cpp +--- jdk/src/share/native/sun/font/layout/MarkToMarkPosnSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/MarkToMarkPosnSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -56,6 +56,10 @@ + LEGlyphID markGlyph = glyphIterator->getCurrGlyphID(); + le_int32 markCoverage = getGlyphCoverage(base, (LEGlyphID) markGlyph, success); + ++ if (LE_FAILURE(success)) { ++ return 0; ++ } ++ + if (markCoverage < 0) { + // markGlyph isn't a covered mark glyph + return 0; +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/MultipleSubstSubtables.cpp +--- jdk/src/share/native/sun/font/layout/MultipleSubstSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/MultipleSubstSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -61,6 +61,10 @@ + le_int32 coverageIndex = getGlyphCoverage(base, glyph, success); + le_uint16 seqCount = SWAPW(sequenceCount); + ++ if (LE_FAILURE(success)) { ++ return 0; ++ } ++ + if (coverageIndex >= 0 && coverageIndex < seqCount) { + Offset sequenceTableOffset = SWAPW(sequenceTableOffsetArray[coverageIndex]); + const SequenceTable *sequenceTable = (const SequenceTable *) ((char *) this + sequenceTableOffset); +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/PairPositioningSubtables.cpp +--- jdk/src/share/native/sun/font/layout/PairPositioningSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/PairPositioningSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -126,6 +126,11 @@ + { + LEGlyphID firstGlyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(base, firstGlyph, success); ++ ++ if (LE_FAILURE(success)) { ++ return 0; ++ } ++ + GlyphIterator tempIterator(*glyphIterator); + + if (coverageIndex >= 0 && glyphIterator->next()) { +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/SinglePositioningSubtables.cpp +--- jdk/src/share/native/sun/font/layout/SinglePositioningSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/SinglePositioningSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -70,6 +70,9 @@ + { + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(base, glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + valueRecord.adjustPosition(SWAPW(valueFormat), (const char *) this, *glyphIterator, fontInstance); +@@ -84,6 +87,9 @@ + { + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int16 coverageIndex = (le_int16) getGlyphCoverage(base, glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + valueRecordArray[0].adjustPosition(coverageIndex, SWAPW(valueFormat), (const char *) this, *glyphIterator, fontInstance); +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/SingleSubstitutionSubtables.cpp +--- jdk/src/share/native/sun/font/layout/SingleSubstitutionSubtables.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/SingleSubstitutionSubtables.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -69,6 +69,9 @@ + { + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(base, glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + TTGlyphID substitute = ((TTGlyphID) LE_GET_GLYPH(glyph)) + SWAPW(deltaGlyphID); +@@ -87,6 +90,9 @@ + { + LEGlyphID glyph = glyphIterator->getCurrGlyphID(); + le_int32 coverageIndex = getGlyphCoverage(base, glyph, success); ++ if (LE_FAILURE(success)) { ++ return 0; ++ } + + if (coverageIndex >= 0) { + TTGlyphID substitute = SWAPW(substituteArray[coverageIndex]); +diff -r 9cfb91052414 -r 150e0c3e95ce src/share/native/sun/font/layout/SunLayoutEngine.cpp +--- jdk/src/share/native/sun/font/layout/SunLayoutEngine.cpp Tue Jul 16 21:00:34 2013 +0400 ++++ jdk/src/share/native/sun/font/layout/SunLayoutEngine.cpp Mon Oct 28 20:56:09 2013 +0000 +@@ -203,16 +203,19 @@ + getFloat(env, pt, x, y); + jboolean rtl = (typo_flags & TYPO_RTL) != 0; + int glyphCount = engine->layoutChars(chars, start - min, limit - start, len, rtl, x, y, success); +- // fprintf(stderr, "sle nl len %d -> gc: %d\n", len, glyphCount); fflush(stderr); ++ // fprintf(stderr, "sle nl len %d -> gc: %d\n", len, glyphCount); fflush(stderr); + + engine->getGlyphPosition(glyphCount, x, y, success); + +- // fprintf(stderr, "layout glyphs: %d x: %g y: %g\n", glyphCount, x, y); fflush(stderr); +- +- if (putGV(env, gmask, baseIndex, gvdata, engine, glyphCount)) { +- // !!! hmmm, could use current value in positions array of GVData... +- putFloat(env, pt, x, y); +- } ++ // fprintf(stderr, "layout glyphs: %d x: %g y: %g\n", glyphCount, x, y); fflush(stderr); ++ if (LE_FAILURE(success)) { ++ env->SetIntField(gvdata, gvdCountFID, -1); // flag failure ++ } else { ++ if (putGV(env, gmask, baseIndex, gvdata, engine, glyphCount)) { ++ // !!! hmmm, could use current value in positions array of GVData... ++ putFloat(env, pt, x, y); ++ } ++ } + + if (chars != buffer) { + free(chars); +diff -r 9cfb91052414 -r 150e0c3e95ce test/java/awt/font/LineBreakMeasurer/AllFontsLBM.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/awt/font/LineBreakMeasurer/AllFontsLBM.java Mon Oct 28 20:56:09 2013 +0000 +@@ -0,0 +1,78 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/* ++ * @test ++ * @bug 8012617 ++ * @summary ArrayIndexOutOfBoundsException in LineBreakMeasurer ++ */ ++ ++import java.awt.*; ++import java.awt.image.*; ++import java.awt.font.*; ++import java.awt.geom.*; ++import java.text.*; ++import java.util.Hashtable; ++ ++public class AllFontsLBM { ++ ++ public static void main(String[] args) { ++ Font[] allFonts = GraphicsEnvironment.getLocalGraphicsEnvironment().getAllFonts(); ++ for (int i=0;i<allFonts.length; i++) { ++ try { ++ Font f = allFonts[i].deriveFont(Font.PLAIN, 20); ++ ++ if ( f.getFontName().startsWith("HiraKaku") ) { ++ continue; ++ } ++ ++ System.out.println("Try : " + f.getFontName()); ++ System.out.flush(); ++ breakLines(f); ++ } catch (Exception e) { ++ System.out.println(allFonts[i]); ++ } ++ } ++ } ++ ++ static void breakLines(Font font) { ++ AttributedString vanGogh = new AttributedString( ++ "Many people believe that Vincent van Gogh painted his best works " + ++ "during the two-year period he spent in Provence. Here is where he " + ++ "painted The Starry Night--which some consider to be his greatest " + ++ "work of all. However, as his artistic brilliance reached new " + ++ "heights in Provence, his physical and mental health plummeted. ", ++ new Hashtable()); ++ vanGogh.addAttribute(TextAttribute.FONT, font); ++ BufferedImage bi = new BufferedImage(100, 100, BufferedImage.TYPE_INT_RGB); ++ Graphics2D g2d = bi.createGraphics(); ++ AttributedCharacterIterator aci = vanGogh.getIterator(); ++ FontRenderContext frc = new FontRenderContext(null, false, false); ++ LineBreakMeasurer lbm = new LineBreakMeasurer(aci, frc); ++ lbm.setPosition(aci.getBeginIndex()); ++ while (lbm.getPosition() < aci.getEndIndex()) { ++ lbm.nextLayout(100f); ++ } ++ ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8013380-logger_stack_walk_glassfish.patch b/java/openjdk6/files/icedtea/openjdk/8013380-logger_stack_walk_glassfish.patch new file mode 100644 index 000000000000..3a688e8157cc --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013380-logger_stack_walk_glassfish.patch @@ -0,0 +1,941 @@ +# HG changeset patch +# User andrew +# Date 1372305047 18000 +# Wed Jun 26 22:50:47 2013 -0500 +# Node ID 8733761ca20bb4e46405e274c514bda0e0616a21 +# Parent a7048970934a1425d5486e6acd0b07558be038c4 +8013380: Removal of stack walk to find resource bundle breaks Glassfish startup +Summary: Use caller's classloader to load resource as an alternative to thread context classloader and system classloader +Reviewed-by: mchung, alanb + +diff -r a7048970934a -r 8733761ca20b src/share/classes/java/util/logging/LogManager.java +--- jdk/src/share/classes/java/util/logging/LogManager.java Tue Apr 16 16:34:14 2013 -0400 ++++ jdk/src/share/classes/java/util/logging/LogManager.java Wed Jun 26 22:50:47 2013 -0500 +@@ -377,11 +377,11 @@ + // add a new Logger or return the one that has been added previously + // as a LogManager subclass may override the addLogger, getLogger, + // readConfiguration, and other methods. +- Logger demandLogger(String name, String resourceBundleName) { ++ Logger demandLogger(String name, String resourceBundleName, Class<?> caller) { + Logger result = getLogger(name); + if (result == null) { + // only allocate the new logger once +- Logger newLogger = new Logger(name, resourceBundleName); ++ Logger newLogger = new Logger(name, resourceBundleName, caller); + do { + if (addLogger(newLogger)) { + // We successfully added the new Logger that we +@@ -465,7 +465,7 @@ + Logger demandLogger(String name, String resourceBundleName) { + // a LogManager subclass may have its own implementation to add and + // get a Logger. So delegate to the LogManager to do the work. +- return manager.demandLogger(name, resourceBundleName); ++ return manager.demandLogger(name, resourceBundleName, null); + } + + synchronized Logger findLogger(String name) { +diff -r a7048970934a -r 8733761ca20b src/share/classes/java/util/logging/Logger.java +--- jdk/src/share/classes/java/util/logging/Logger.java Tue Apr 16 16:34:14 2013 -0400 ++++ jdk/src/share/classes/java/util/logging/Logger.java Wed Jun 26 22:50:47 2013 -0500 +@@ -189,6 +189,7 @@ + private ArrayList<LogManager.LoggerWeakRef> kids; // WeakReferences to loggers that have us as parent + private Level levelObject; + private volatile int levelValue; // current effective level value ++ private WeakReference<ClassLoader> callersClassLoaderRef; + + /** + * GLOBAL_LOGGER_NAME is a name for the global logger. +@@ -244,15 +245,31 @@ + * no corresponding resource can be found. + */ + protected Logger(String name, String resourceBundleName) { ++ this(name, resourceBundleName, null); ++ } ++ ++ Logger(String name, String resourceBundleName, Class<?> caller) { + this.manager = LogManager.getLogManager(); +- if (resourceBundleName != null) { +- // Note: we may get a MissingResourceException here. +- setupResourceInfo(resourceBundleName); +- } ++ setupResourceInfo(resourceBundleName, caller); + this.name = name; + levelValue = Level.INFO.intValue(); + } + ++ private void setCallersClassLoaderRef(Class<?> caller) { ++ ClassLoader callersClassLoader = ((caller != null) ++ ? caller.getClassLoader() ++ : null); ++ if (callersClassLoader != null) { ++ this.callersClassLoaderRef = new WeakReference(callersClassLoader); ++ } ++ } ++ ++ private ClassLoader getCallersClassLoader() { ++ return (callersClassLoaderRef != null) ++ ? callersClassLoaderRef.get() ++ : null; ++ } ++ + // This constructor is used only to create the global Logger. + // It is needed to break a cyclic dependence between the LogManager + // and Logger static initializers causing deadlocks. +@@ -306,7 +323,9 @@ + return manager.demandSystemLogger(name, resourceBundleName); + } + } +- return manager.demandLogger(name, resourceBundleName); ++ return manager.demandLogger(name, resourceBundleName, caller); ++ // ends up calling new Logger(name, resourceBundleName, caller) ++ // iff the logger doesn't exist already + } + + /** +@@ -382,11 +401,24 @@ + */ + @CallerSensitive + public static synchronized Logger getLogger(String name, String resourceBundleName) { +- Logger result = demandLogger(name, resourceBundleName, Reflection.getCallerClass()); ++ Class<?> callerClass = Reflection.getCallerClass(); ++ Logger result = demandLogger(name, resourceBundleName, callerClass); ++ + if (result.resourceBundleName == null) { ++ // We haven't set a bundle name yet on the Logger, so it's ok to proceed. ++ ++ // We have to set the callers ClassLoader here in case demandLogger ++ // above found a previously created Logger. This can happen, for ++ // example, if Logger.getLogger(name) is called and subsequently ++ // Logger.getLogger(name, resourceBundleName) is called. In this case ++ // we won't necessarily have the correct classloader saved away, so ++ // we need to set it here, too. ++ + // Note: we may get a MissingResourceException here. +- result.setupResourceInfo(resourceBundleName); ++ result.setupResourceInfo(resourceBundleName, callerClass); + } else if (!result.resourceBundleName.equals(resourceBundleName)) { ++ // We already had a bundle name on the Logger and we're trying ++ // to change it here which is not allowed. + throw new IllegalArgumentException(result.resourceBundleName + + " != " + resourceBundleName); + } +@@ -441,11 +473,13 @@ + * @return a newly created private Logger + * @throws MissingResourceException if the named ResourceBundle cannot be found. + */ ++ @CallerSensitive + public static synchronized Logger getAnonymousLogger(String resourceBundleName) { + LogManager manager = LogManager.getLogManager(); + // cleanup some Loggers that have been GC'ed + manager.drainLoggerRefQueueBounded(); +- Logger result = new Logger(null, resourceBundleName); ++ Logger result = new Logger(null, resourceBundleName, ++ Reflection.getCallerClass()); + result.anonymous = true; + Logger root = manager.getLogger(""); + result.doSetParent(root); +@@ -461,7 +495,7 @@ + * @return localization bundle (may be null) + */ + public ResourceBundle getResourceBundle() { +- return findResourceBundle(getResourceBundleName()); ++ return findResourceBundle(getResourceBundleName(), true); + } + + /** +@@ -548,7 +582,7 @@ + String ebname = getEffectiveResourceBundleName(); + if (ebname != null && !ebname.equals(SYSTEM_LOGGER_RB_NAME)) { + lr.setResourceBundleName(ebname); +- lr.setResourceBundle(findResourceBundle(ebname)); ++ lr.setResourceBundle(findResourceBundle(ebname, true)); + } + log(lr); + } +@@ -765,7 +799,7 @@ + lr.setLoggerName(name); + if (rbname != null) { + lr.setResourceBundleName(rbname); +- lr.setResourceBundle(findResourceBundle(rbname)); ++ lr.setResourceBundle(findResourceBundle(rbname, false)); + } + log(lr); + } +@@ -789,7 +823,6 @@ + * can be null + * @param msg The string message (or a key in the message catalog) + */ +- + public void logrb(Level level, String sourceClass, String sourceMethod, + String bundleName, String msg) { + if (level.intValue() < levelValue || levelValue == offValue) { +@@ -1323,9 +1356,18 @@ + * there is no suitable previous cached value. + * + * @param name the ResourceBundle to locate ++ * @param userCallersClassLoader if true search using the caller's ClassLoader + * @return ResourceBundle specified by name or null if not found + */ +- private synchronized ResourceBundle findResourceBundle(String name) { ++ private synchronized ResourceBundle findResourceBundle(String name, ++ boolean useCallersClassLoader) { ++ // For all lookups, we first check the thread context class loader ++ // if it is set. If not, we use the system classloader. If we ++ // still haven't found it we use the callersClassLoaderRef if it ++ // is set and useCallersClassLoader is true. We set ++ // callersClassLoaderRef initially upon creating the logger with a ++ // non-null resource bundle name. ++ + // Return a null bundle for a null name. + if (name == null) { + return null; +@@ -1358,22 +1400,52 @@ + catalogLocale = currentLocale; + return catalog; + } catch (MissingResourceException ex) { ++ // We can't find the ResourceBundle in the default ++ // ClassLoader. Drop through. ++ } ++ ++ if (useCallersClassLoader) { ++ // Try with the caller's ClassLoader ++ ClassLoader callersClassLoader = getCallersClassLoader(); ++ ++ if (callersClassLoader == null || callersClassLoader == cl) { ++ return null; ++ } ++ ++ try { ++ catalog = ResourceBundle.getBundle(name, currentLocale, ++ callersClassLoader); ++ catalogName = name; ++ catalogLocale = currentLocale; ++ return catalog; ++ } catch (MissingResourceException ex) { ++ return null; // no luck ++ } ++ } else { + return null; + } + } + + // Private utility method to initialize our one entry +- // resource bundle cache. ++ // resource bundle name cache and the callers ClassLoader + // Note: for consistency reasons, we are careful to check + // that a suitable ResourceBundle exists before setting the +- // ResourceBundleName. +- private synchronized void setupResourceInfo(String name) { ++ // resourceBundleName field. ++ // Synchronized to prevent races in setting the fields. ++ private synchronized void setupResourceInfo(String name, ++ Class<?> callersClass) { + if (name == null) { + return; + } +- if (findResourceBundle(name) == null) { ++ ++ setCallersClassLoaderRef(callersClass); ++ if (findResourceBundle(name, true) == null) { + // We've failed to find an expected ResourceBundle. +- throw new MissingResourceException("Can't find " + name + " bundle", name, ""); ++ // unset the caller's ClassLoader since we were unable to find the ++ // the bundle using it ++ this.callersClassLoaderRef = null; ++ throw new MissingResourceException("Can't find " + name + " bundle", ++ name, ""); + } + resourceBundleName = name; + } +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java +--- jdk/test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java Tue Apr 16 16:34:14 2013 -0400 ++++ jdk/test/java/util/logging/bundlesearch/IndirectlyLoadABundle.java Wed Jun 26 22:50:47 2013 -0500 +@@ -21,43 +21,28 @@ + * questions. + */ + +-import java.io.File; + import java.lang.reflect.InvocationTargetException; + import java.lang.reflect.Method; ++import java.net.MalformedURLException; + import java.net.URL; + import java.net.URLClassLoader; ++import java.nio.file.Paths; ++import java.util.logging.Logger; + + /** + * This class is used to ensure that a resource bundle loadable by a classloader +- * is on the caller's stack, but not on the classpath or TCCL to ensure that +- * Logger.getLogger() can't load the bundle via a stack search ++ * is on the caller's stack, but not on the classpath or TCCL. It tests that ++ * Logger.getLogger() can load the bundle via the immediate caller's classloader + * + * @author Jim Gish + */ + public class IndirectlyLoadABundle { + +- private final static String rbName = "StackSearchableResource"; ++ private final static String rbName = "CallerSearchableResource"; + + public boolean loadAndTest() throws Throwable { +- // Find out where we are running from so we can setup the URLClassLoader URLs +- // test.src and test.classes will be set if running in jtreg, but probably +- // not otherwise +- String testDir = System.getProperty("test.src", System.getProperty("user.dir")); +- String testClassesDir = System.getProperty("test.classes", +- System.getProperty("user.dir")); +- String sep = System.getProperty("file.separator"); +- +- URL[] urls = new URL[2]; +- +- // Allow for both jtreg and standalone cases here +- urls[0] = new File( testDir + sep + "resources" + sep ).toURI().toURL(); +- urls[1] = new File( testClassesDir + sep ).toURI().toURL(); +- +- System.out.println("INFO: urls[0] = " + urls[0]); +- System.out.println("INFO: urls[1] = " + urls[1]); +- + // Make sure we can find it via the URLClassLoader +- URLClassLoader yetAnotherResourceCL = new URLClassLoader(urls, null); ++ URLClassLoader yetAnotherResourceCL = new URLClassLoader(getURLs(), null); + if (!testForValidResourceSetup(yetAnotherResourceCL)) { + throw new Exception("Couldn't directly load bundle " + rbName + + " as expected. Test config problem"); +@@ -70,23 +55,109 @@ + + " able to. Test config problem"); + } + +- Class<?> loadItUpClazz = Class.forName("LoadItUp", true, yetAnotherResourceCL); ++ Class<?> loadItUpClazz = Class.forName("LoadItUp1", true, ++ yetAnotherResourceCL); + ClassLoader actual = loadItUpClazz.getClassLoader(); + if (actual != yetAnotherResourceCL) { +- throw new Exception("LoadItUp was loaded by an unexpected CL: " + actual); ++ throw new Exception("LoadItUp1 was loaded by an unexpected CL: " + actual); + } + Object loadItUp = loadItUpClazz.newInstance(); +- Method testMethod = loadItUpClazz.getMethod("test", String.class); ++ Method testMethod = loadItUpClazz.getMethod("getLogger", String.class, String.class); + try { +- return (Boolean) testMethod.invoke(loadItUp, rbName); ++ return (Logger)testMethod.invoke(loadItUp, "NestedLogger1", rbName) != null; + } catch (InvocationTargetException ex) { + throw ex.getTargetException(); + } + } + ++ public boolean testGetAnonymousLogger() throws Throwable { ++ // Test getAnonymousLogger() ++ URLClassLoader loadItUpCL = new URLClassLoader(getURLs(), null); ++ Class<?> loadItUpClazz = Class.forName("LoadItUp1", true, loadItUpCL); ++ ClassLoader actual = loadItUpClazz.getClassLoader(); ++ if (actual != loadItUpCL) { ++ throw new Exception("LoadItUp1 was loaded by an unexpected CL: " ++ + actual); ++ } ++ Object loadItUpAnon = loadItUpClazz.newInstance(); ++ Method testAnonMethod = loadItUpClazz.getMethod("getAnonymousLogger", ++ String.class); ++ try { ++ return (Logger)testAnonMethod.invoke(loadItUpAnon, rbName) != null; ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ } ++ ++ ++ public boolean testGetLoggerGetLoggerWithBundle() throws Throwable { ++ // test getLogger("NestedLogger2"); followed by ++ // getLogger("NestedLogger2", rbName) to see if the bundle is found ++ // ++ URL[] urls = getURLs(); ++ if (getLoggerWithNewCL(urls, "NestedLogger2", null)) { ++ return getLoggerWithNewCL(urls, "NestedLogger2", rbName); ++ ++ } else { ++ throw new Exception("TEST FAILED: first call to getLogger() failed " ++ + " in IndirectlyLoadABundle." ++ + "testGetLoggerGetLoggerWithBundle"); ++ } ++ } ++ ++ private URL[] getURLs() throws MalformedURLException { ++ // Find out where we are running from so we can setup the URLClassLoader URLs ++ // test.src and test.classes will be set if running in jtreg, but probably ++ // not otherwise ++ String testDir = System.getProperty("test.src", System.getProperty("user.dir")); ++ String testClassesDir = System.getProperty("test.classes", ++ System.getProperty("user.dir")); ++ URL[] urls = new URL[2]; ++ // Allow for both jtreg and standalone cases here ++ urls[0] = Paths.get(testDir, "resources").toUri().toURL(); ++ urls[1] = Paths.get(testClassesDir).toUri().toURL(); ++ ++ return urls; ++ } ++ ++ private boolean getLoggerWithNewCL(URL[] urls, String loggerName, ++ String bundleName) throws Throwable { ++ Logger result = null;; ++ // Test getLogger("foo"); getLogger("foo", "rbName"); ++ // First do the getLogger() call with no bundle name ++ URLClassLoader getLoggerCL = new URLClassLoader(urls, null); ++ Class<?> loadItUpClazz1 = Class.forName("LoadItUp1", true, getLoggerCL); ++ ClassLoader actual = loadItUpClazz1.getClassLoader(); ++ if (actual != getLoggerCL) { ++ throw new Exception("LoadItUp1 was loaded by an unexpected CL: " ++ + actual); ++ } ++ Object loadItUp1 = loadItUpClazz1.newInstance(); ++ if (bundleName != null) { ++ Method getLoggerMethod = loadItUpClazz1.getMethod("getLogger", ++ String.class, ++ String.class); ++ try { ++ result = (Logger) getLoggerMethod.invoke(loadItUp1, loggerName, ++ bundleName); ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ } else { ++ Method getLoggerMethod = loadItUpClazz1.getMethod("getLogger", ++ String.class); ++ try { ++ result = (Logger) getLoggerMethod.invoke(loadItUp1, loggerName); ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ } ++ return result != null; ++ } ++ + private boolean testForValidResourceSetup(ClassLoader cl) { +- // First make sure the test environment is setup properly and the bundle actually +- // exists ++ // First make sure the test environment is setup properly and the bundle ++ // actually exists + return ResourceBundleSearchTest.isOnClassPath(rbName, cl); + } + } +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/LoadItUp.java +--- jdk/test/java/util/logging/bundlesearch/LoadItUp.java Tue Apr 16 16:34:14 2013 -0400 ++++ jdk/test/java/util/logging/bundlesearch/LoadItUp.java Wed Jun 26 22:50:47 2013 -0500 +@@ -20,43 +20,30 @@ + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +-import java.util.MissingResourceException; + import java.util.logging.Logger; + + /* +- * This class is loaded onto the call stack when the test method is called +- * and then its classloader can be used to find a property bundle in the same +- * directory as the class. However, Logger is not allowed ++ * This class is loaded onto the call stack when the getLogger methods are ++ * called and then the classes classloader can be used to find a bundle in ++ * the same directory as the class. However, Logger is not allowed + * to find the bundle by looking up the stack for this classloader. + * We verify that this cannot happen. + * + * @author Jim Gish + */ +-public class LoadItUp { +- +- private final static boolean DEBUG = false; +- +- public Boolean test(String rbName) throws Exception { ++public class LoadItUp1 { ++ public Logger getAnonymousLogger(String rbName) throws Exception { + // we should not be able to find the resource in this directory via + // getLogger calls. The only way that would be possible given this setup + // is that if Logger.getLogger searched up the call stack +- return lookupBundle(rbName); ++ return Logger.getAnonymousLogger(rbName); + } + +- private boolean lookupBundle(String rbName) { +- // See if Logger.getLogger can find the resource in this directory +- try { +- Logger aLogger = Logger.getLogger("NestedLogger", rbName); +- } catch (MissingResourceException re) { +- if (DEBUG) { +- System.out.println( +- "As expected, LoadItUp.lookupBundle() did not find the bundle " +- + rbName); +- } +- return false; +- } +- System.out.println("FAILED: LoadItUp.lookupBundle() found the bundle " +- + rbName + " using a stack search."); +- return true; ++ public Logger getLogger(String loggerName) { ++ return Logger.getLogger(loggerName); ++ } ++ ++ public Logger getLogger(String loggerName,String bundleName) { ++ return Logger.getLogger(loggerName, bundleName); + } + } +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/LoadItUp2.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/LoadItUp2.java Wed Jun 26 22:50:47 2013 -0500 +@@ -0,0 +1,62 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++import java.util.MissingResourceException; ++import java.util.logging.Logger; ++ ++/* ++ * This class is loaded onto the call stack by LoadItUp2Invoker from a separate ++ * classloader. LoadItUp2Invoker was loaded by a class loader that does have ++ * access to the bundle, but the class loader used to load this class does not. ++ * Thus the logging code should not be able to see the resource bundle unless ++ * it has more than a single level stack crawl, which is not allowed. ++ * ++ * @author Jim Gish ++ */ ++public class LoadItUp2 { ++ ++ private final static boolean DEBUG = false; ++ ++ public Boolean test(String rbName) throws Exception { ++ // we should not be able to find the resource in this directory via ++ // getLogger calls. The only way that would be possible given this setup ++ // is that if Logger.getLogger searched up the call stack ++ return lookupBundle(rbName); ++ } ++ ++ private boolean lookupBundle(String rbName) { ++ // See if Logger.getLogger can find the resource in this directory ++ try { ++ Logger aLogger = Logger.getLogger("NestedLogger2", rbName); ++ } catch (MissingResourceException re) { ++ if (DEBUG) { ++ System.out.println( ++ "As expected, LoadItUp2.lookupBundle() did not find the bundle " ++ + rbName); ++ } ++ return false; ++ } ++ System.out.println("FAILED: LoadItUp2.lookupBundle() found the bundle " ++ + rbName + " using a stack search."); ++ return true; ++ } ++} +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/LoadItUp2Invoker.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/LoadItUp2Invoker.java Wed Jun 26 22:50:47 2013 -0500 +@@ -0,0 +1,60 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.net.URL; ++import java.net.URLClassLoader; ++ ++/** ++ * This class is loaded by a class loader that can see the resource. It creates ++ * a new classloader for LoadItUp2 which cannot see the resource. So, 2 levels ++ * up the call chain we have a class/classloader that can see the resource, but ++ * 1 level up the class/classloader cannot. ++ * ++ * @author Jim Gish ++ */ ++public class LoadItUp2Invoker { ++ private URLClassLoader cl; ++ private String rbName; ++ private Object loadItUp2; ++ private Method testMethod; ++ ++ public void setup(URL[] urls, String rbName) throws ++ ReflectiveOperationException { ++ this.cl = new URLClassLoader(urls, null); ++ this.rbName = rbName; ++ // Using this new classloader, load the actual test class ++ // which is now two levels removed from the original caller ++ Class<?> loadItUp2Clazz = Class.forName("LoadItUp2", true , cl); ++ this.loadItUp2 = loadItUp2Clazz.newInstance(); ++ this.testMethod = loadItUp2Clazz.getMethod("test", String.class); ++ } ++ ++ public Boolean test() throws Throwable { ++ try { ++ return (Boolean) testMethod.invoke(loadItUp2, rbName); ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ } ++} +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java +--- jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Tue Apr 16 16:34:14 2013 -0400 ++++ jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Wed Jun 26 22:50:47 2013 -0500 +@@ -23,15 +23,15 @@ + + /* + * @test +- * @bug 8010127 ++ * @bug 8010127 8013380 + * @summary Remove the stack search for a resource bundle Logger to use + * @author Jim Gish +- * @build ResourceBundleSearchTest IndirectlyLoadABundle LoadItUp +- * @run main ResourceBundleSearchTest ++ * @build ResourceBundleSearchTest IndirectlyLoadABundle LoadItUp1 LoadItUp2 TwiceIndirectlyLoadABundle LoadItUp2Invoker ++ * @run main/othervm ResourceBundleSearchTest + */ +-import java.io.File; + import java.net.URL; + import java.net.URLClassLoader; ++import java.nio.file.Paths; + import java.util.ArrayList; + import java.util.List; + import java.util.Locale; +@@ -39,6 +39,12 @@ + import java.util.ResourceBundle; + import java.util.logging.Logger; + ++/** ++ * This class tests various scenarios of loading resource bundles from ++ * java.util.logging. Since jtreg uses the logging system, it is necessary to ++ * run these tests using othervm mode to ensure no interference from logging ++ * initialization by jtreg ++ */ + public class ResourceBundleSearchTest { + + private final static boolean DEBUG = false; +@@ -49,7 +55,7 @@ + + private static int numPass = 0; + private static int numFail = 0; +- private static List<String> msgs = new ArrayList<String>(); ++ private static List<String> msgs = new ArrayList<>(); + + public static void main(String[] args) throws Throwable { + ResourceBundleSearchTest test = new ResourceBundleSearchTest(); +@@ -60,47 +66,54 @@ + // ensure we are using en as the default Locale so we can find the resource + Locale.setDefault(Locale.ENGLISH); + +- String testClasses = System.getProperty("test.classes"); +- System.out.println( "test.classes = " + testClasses ); +- + ClassLoader myClassLoader = ClassLoader.getSystemClassLoader(); + + // Find out where we are running from so we can setup the URLClassLoader URL + String userDir = System.getProperty("user.dir"); + String testDir = System.getProperty("test.src", userDir); +- String sep = System.getProperty("file.separator"); + + URL[] urls = new URL[1]; + +- urls[0] = new File( testDir + sep + "resources" + sep ).toURI().toURL(); ++ urls[0] = Paths.get(testDir, "resources").toUri().toURL(); + URLClassLoader rbClassLoader = new URLClassLoader(urls); + + // Test 1 - can we find a Logger bundle from doing a stack search? + // We shouldn't be able to +- assertFalse(testGetBundleFromStackSearch(), "testGetBundleFromStackSearch"); ++ assertFalse(testGetBundleFromStackSearch(), "1-testGetBundleFromStackSearch"); + + // Test 2 - can we find a Logger bundle off of the Thread context class + // loader? We should be able to. +- assertTrue( +- testGetBundleFromTCCL(TCCL_TEST_BUNDLE, rbClassLoader), +- "testGetBundleFromTCCL"); ++ assertTrue(testGetBundleFromTCCL(TCCL_TEST_BUNDLE, rbClassLoader), ++ "2-testGetBundleFromTCCL"); + + // Test 3 - Can we find a Logger bundle from the classpath? We should be +- // able to, but .... +- // We check to see if the bundle is on the classpath or not so that this +- // will work standalone. In the case of jtreg/samevm, +- // the resource bundles are not on the classpath. Running standalone +- // (or othervm), they are ++ // able to. We'll first check to make sure the setup is correct and ++ // it actually is on the classpath before checking whether logging ++ // can see it there. + if (isOnClassPath(PROP_RB_NAME, myClassLoader)) { + debug("We should be able to see " + PROP_RB_NAME + " on the classpath"); + assertTrue(testGetBundleFromSystemClassLoader(PROP_RB_NAME), +- "testGetBundleFromSystemClassLoader"); ++ "3-testGetBundleFromSystemClassLoader"); + } else { +- debug("We should not be able to see " + PROP_RB_NAME + " on the classpath"); +- assertFalse(testGetBundleFromSystemClassLoader(PROP_RB_NAME), +- "testGetBundleFromSystemClassLoader"); ++ throw new Exception("TEST SETUP FAILURE: Cannot see " + PROP_RB_NAME ++ + " on the classpath"); + } + ++ // Test 4 - we should be able to find a bundle from the caller's ++ // classloader, but only one level up. ++ assertTrue(testGetBundleFromCallersClassLoader(), ++ "4-testGetBundleFromCallersClassLoader"); ++ ++ // Test 5 - this ensures that getAnonymousLogger(String rbName) ++ // can find the bundle from the caller's classloader ++ assertTrue(testGetAnonymousLogger(), "5-testGetAnonymousLogger"); ++ ++ // Test 6 - first call getLogger("myLogger"). ++ // Then call getLogger("myLogger","bundleName") from a different ClassLoader ++ // Make sure we find the bundle ++ assertTrue(testGetBundleFromSecondCallersClassLoader(), ++ "6-testGetBundleFromSecondCallersClassLoader"); ++ + report(); + } + +@@ -112,7 +125,7 @@ + System.out.println(msg); + } + throw new Exception(numFail + " out of " + (numPass + numFail) +- + " tests failed."); ++ + " tests failed."); + } + } + +@@ -122,7 +135,7 @@ + } else { + numFail++; + System.out.println("FAILED: " + testName +- + " was supposed to return true but did NOT!"); ++ + " was supposed to return true but did NOT!"); + } + } + +@@ -132,13 +145,20 @@ + } else { + numFail++; + System.out.println("FAILED: " + testName +- + " was supposed to return false but did NOT!"); ++ + " was supposed to return false but did NOT!"); + } + } + + public boolean testGetBundleFromStackSearch() throws Throwable { + // This should fail. This was the old functionality to search up the + // caller's call stack ++ TwiceIndirectlyLoadABundle indirectLoader = new TwiceIndirectlyLoadABundle(); ++ return indirectLoader.loadAndTest(); ++ } ++ ++ public boolean testGetBundleFromCallersClassLoader() throws Throwable { ++ // This should pass. This exercises getting the bundle using the ++ // class loader of the caller (one level up) + IndirectlyLoadABundle indirectLoader = new IndirectlyLoadABundle(); + return indirectLoader.loadAndTest(); + } +@@ -193,14 +213,29 @@ + bundleName); + } catch (MissingResourceException re) { + msgs.add("INFO: testGetBundleFromSystemClassLoader() did not find bundle " +- + bundleName); ++ + bundleName); + return false; + } + msgs.add("INFO: testGetBundleFromSystemClassLoader() found the bundle " +- + bundleName); ++ + bundleName); + return true; + } + ++ private boolean testGetAnonymousLogger() throws Throwable { ++ // This should pass. This exercises getting the bundle using the ++ // class loader of the caller (one level up) when calling ++ // Logger.getAnonymousLogger(String rbName) ++ IndirectlyLoadABundle indirectLoader = new IndirectlyLoadABundle(); ++ return indirectLoader.testGetAnonymousLogger(); ++ } ++ ++ private boolean testGetBundleFromSecondCallersClassLoader() throws Throwable { ++ // This should pass. This exercises getting the bundle using the ++ // class loader of the caller (one level up) ++ IndirectlyLoadABundle indirectLoader = new IndirectlyLoadABundle(); ++ return indirectLoader.testGetLoggerGetLoggerWithBundle(); ++ } ++ + public static class LoggingThread extends Thread { + + boolean foundBundle = false; +@@ -227,13 +262,13 @@ + // this should succeed if the bundle is on the system classpath. + try { + Logger aLogger = Logger.getLogger(ResourceBundleSearchTest.newLoggerName(), +- bundleName); +- msg = "INFO: LoggingRunnable() found the bundle " + bundleName +- + (setTCCL ? " with " : " without ") + "setting the TCCL"; ++ bundleName); ++ msg = "INFO: LoggingThread.run() found the bundle " + bundleName ++ + (setTCCL ? " with " : " without ") + "setting the TCCL"; + foundBundle = true; + } catch (MissingResourceException re) { +- msg = "INFO: LoggingRunnable() did not find the bundle " + bundleName +- + (setTCCL ? " with " : " without ") + "setting the TCCL"; ++ msg = "INFO: LoggingThread.run() did not find the bundle " + bundleName ++ + (setTCCL ? " with " : " without ") + "setting the TCCL"; + foundBundle = false; + } + } catch (Throwable e) { +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/TwiceIndirectlyLoadABundle.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/TwiceIndirectlyLoadABundle.java Wed Jun 26 22:50:47 2013 -0500 +@@ -0,0 +1,91 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.net.URL; ++import java.net.URLClassLoader; ++import java.nio.file.Paths; ++ ++/** ++ * This class constructs a scenario where a bundle is accessible on the call ++ * stack two levels up from the call to getLogger(), but not on the immediate ++ * caller. This tests that getLogger() isn't doing a stack crawl more than one ++ * level up to find a bundle. ++ * ++ * @author Jim Gish ++ */ ++public class TwiceIndirectlyLoadABundle { ++ ++ private final static String rbName = "StackSearchableResource"; ++ ++ public boolean loadAndTest() throws Throwable { ++ // Find out where we are running from so we can setup the URLClassLoader URLs ++ // test.src and test.classes will be set if running in jtreg, but probably ++ // not otherwise ++ String testDir = System.getProperty("test.src", System.getProperty("user.dir")); ++ String testClassesDir = System.getProperty("test.classes", ++ System.getProperty("user.dir")); ++ URL[] urls = new URL[2]; ++ ++ // Allow for both jtreg and standalone cases here ++ // Unlike the 1-level test where we can get the bundle from the caller's ++ // class loader, for this one we don't want to expose the resource directory ++ // to the next class. That way we're invoking the LoadItUp2Invoker class ++ // from this class that does have access to the resources (two levels ++ // up the call stack), but the Invoker itself won't have access to resource ++ urls[0] = Paths.get(testDir,"resources").toUri().toURL(); ++ urls[1] = Paths.get(testClassesDir).toUri().toURL(); ++ ++ // Make sure we can find it via the URLClassLoader ++ URLClassLoader yetAnotherResourceCL = new URLClassLoader(urls, null); ++ Class<?> loadItUp2InvokerClazz = Class.forName("LoadItUp2Invoker", true, ++ yetAnotherResourceCL); ++ ClassLoader actual = loadItUp2InvokerClazz.getClassLoader(); ++ if (actual != yetAnotherResourceCL) { ++ throw new Exception("LoadItUp2Invoker was loaded by an unexpected CL: " ++ + actual); ++ } ++ Object loadItUp2Invoker = loadItUp2InvokerClazz.newInstance(); ++ ++ Method setupMethod = loadItUp2InvokerClazz.getMethod("setup", ++ urls.getClass(), String.class); ++ try { ++ // For the next class loader we create, we want to leave off ++ // the resources. That way loadItUp2Invoker will have access to ++ // them, but the next class won't. ++ URL[] noResourceUrl = new URL[1]; ++ noResourceUrl[0] = urls[1]; // from above -- just the test classes ++ setupMethod.invoke(loadItUp2Invoker, noResourceUrl, rbName); ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ ++ Method testMethod = loadItUp2InvokerClazz.getMethod("test"); ++ try { ++ return (Boolean) testMethod.invoke(loadItUp2Invoker); ++ } catch (InvocationTargetException ex) { ++ throw ex.getTargetException(); ++ } ++ } ++} +diff -r a7048970934a -r 8733761ca20b test/java/util/logging/bundlesearch/resources/CallerSearchableResource_en.properties +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/util/logging/bundlesearch/resources/CallerSearchableResource_en.properties Wed Jun 26 22:50:47 2013 -0500 +@@ -0,0 +1,25 @@ ++# ++# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++# ++# This code is free software; you can redistribute it and/or modify it ++# under the terms of the GNU General Public License version 2 only, as ++# published by the Free Software Foundation. ++# ++# This code is distributed in the hope that it will be useful, but WITHOUT ++# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++# version 2 for more details (a copy is included in the LICENSE file that ++# accompanied this code). ++# ++# You should have received a copy of the GNU General Public License version ++# 2 along with this work; if not, write to the Free Software Foundation, ++# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++# ++# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++# or visit www.oracle.com if you need additional information or have any ++# questions. ++# ++sample1=translation #4 for sample1 ++sample2=translation #4 for sample2 ++supports-test=ResourceBundleSearchTest diff --git a/java/openjdk6/files/icedtea/openjdk/8013503-improve_stream_factories.patch b/java/openjdk6/files/icedtea/openjdk/8013503-improve_stream_factories.patch new file mode 100644 index 000000000000..bc60729ee668 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013503-improve_stream_factories.patch @@ -0,0 +1,224 @@ +# HG changeset patch +# User joehw +# Date 1381418310 -3600 +# Thu Oct 10 16:18:30 2013 +0100 +# Node ID b5b1d1fa4bb4fcd8bc0602fd4f3523fe24d9f00b +# Parent 7e2686f3328994b546b7a5d2f7ed5d994a9a724f +8013503: Improve stream factories +Reviewed-by: alanb, dfuchs, mullan + +diff -r 7e2686f33289 -r b5b1d1fa4bb4 drop_included/jaxp_src/src/javax/xml/stream/FactoryFinder.java +--- jaxp/drop_included/jaxp_src/src/javax/xml/stream/FactoryFinder.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxp/drop_included/jaxp_src/src/javax/xml/stream/FactoryFinder.java Thu Oct 10 16:18:30 2013 +0100 +@@ -204,13 +204,15 @@ + * a property name + * @param fallbackClassName Implementation class name, if nothing else + * is found. Use null to mean no fallback. ++ * @param standardId Indicate whether the factoryId is standard ++ * or user specified. + * + * Package private so this code can be shared. + */ +- static Object find(String factoryId, String fallbackClassName) ++ static Object find(String factoryId, String fallbackClassName, boolean standardId) + throws ConfigurationError + { +- return find(factoryId, null, fallbackClassName); ++ return find(factoryId, null, fallbackClassName, standardId); + } + + /** +@@ -227,23 +229,34 @@ + * @param fallbackClassName Implementation class name, if nothing else + * is found. Use null to mean no fallback. + * ++ * @param standardId Indicate whether the factoryId is standard ++ * or user specified. ++ * + * Package private so this code can be shared. + */ +- static Object find(String factoryId, ClassLoader cl, String fallbackClassName) ++ static Object find(String factoryId, ClassLoader cl, String fallbackClassName, ++ boolean standardId) + throws ConfigurationError + { + dPrint("find factoryId =" + factoryId); + + // Use the system property first + try { +- String systemProp = ss.getSystemProperty(factoryId); ++ String systemProp; ++ if (standardId) { ++ systemProp = ss.getSystemProperty(factoryId); ++ } else { ++ systemProp = System.getProperty(factoryId); ++ } ++ + if (systemProp != null) { + dPrint("found system property, value=" + systemProp); + return newInstance(systemProp, null, true); + } + } + catch (SecurityException se) { +- if (debug) se.printStackTrace(); ++ throw new ConfigurationError( ++ "Failed to read factoryId '" + factoryId + "'", se); + } + + // Try read $java.home/lib/stax.properties followed by +diff -r 7e2686f33289 -r b5b1d1fa4bb4 drop_included/jaxp_src/src/javax/xml/stream/XMLEventFactory.java +--- jaxp/drop_included/jaxp_src/src/javax/xml/stream/XMLEventFactory.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxp/drop_included/jaxp_src/src/javax/xml/stream/XMLEventFactory.java Thu Oct 10 16:18:30 2013 +0100 +@@ -47,6 +47,9 @@ + * @since 1.6 + */ + public abstract class XMLEventFactory { ++ ++ static final String JAXPFACTORYID = "javax.xml.stream.XMLEventFactory"; ++ + protected XMLEventFactory(){} + + /** +@@ -57,8 +60,7 @@ + throws FactoryConfigurationError + { + return (XMLEventFactory) FactoryFinder.find( +- "javax.xml.stream.XMLEventFactory", +- "com.sun.xml.internal.stream.events.XMLEventFactoryImpl"); ++ JAXPFACTORYID, "com.sun.xml.internal.stream.events.XMLEventFactoryImpl", true); + } + + /** +@@ -91,7 +93,7 @@ + { + return (XMLEventFactory) FactoryFinder.find( + "javax.xml.stream.XMLEventFactory", +- "com.sun.xml.internal.stream.events.XMLEventFactoryImpl"); ++ "com.sun.xml.internal.stream.events.XMLEventFactoryImpl", true); + } + + /** +@@ -114,7 +116,8 @@ + throws FactoryConfigurationError { + try { + //do not fallback if given classloader can't find the class, throw exception +- return (XMLEventFactory) FactoryFinder.newInstance(factoryId, classLoader, false); ++ return (XMLEventFactory) FactoryFinder.find(factoryId, classLoader, ++ null, factoryId.equals(JAXPFACTORYID) ? true : false); + } catch (FactoryFinder.ConfigurationError e) { + throw new FactoryConfigurationError(e.getException(), + e.getMessage()); +@@ -141,7 +144,8 @@ + throws FactoryConfigurationError { + try { + //do not fallback if given classloader can't find the class, throw exception +- return (XMLEventFactory) FactoryFinder.newInstance(factoryId, classLoader, false); ++ return (XMLEventFactory) FactoryFinder.find(factoryId, classLoader, ++ null, factoryId.equals(JAXPFACTORYID) ? true : false); + } catch (FactoryFinder.ConfigurationError e) { + throw new FactoryConfigurationError(e.getException(), + e.getMessage()); +diff -r 7e2686f33289 -r b5b1d1fa4bb4 drop_included/jaxp_src/src/javax/xml/stream/XMLInputFactory.java +--- jaxp/drop_included/jaxp_src/src/javax/xml/stream/XMLInputFactory.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxp/drop_included/jaxp_src/src/javax/xml/stream/XMLInputFactory.java Thu Oct 10 16:18:30 2013 +0100 +@@ -139,6 +139,7 @@ + public static final String ALLOCATOR= + "javax.xml.stream.allocator"; + ++ static final String JAXPFACTORYID = "javax.xml.stream.XMLInputFactory"; + static final String DEFAULIMPL = "com.sun.xml.internal.stream.XMLInputFactoryImpl"; + + protected XMLInputFactory(){} +@@ -150,9 +151,7 @@ + public static XMLInputFactory newInstance() + throws FactoryConfigurationError + { +- return (XMLInputFactory) FactoryFinder.find( +- "javax.xml.stream.XMLInputFactory", +- DEFAULIMPL); ++ return (XMLInputFactory) FactoryFinder.find(JAXPFACTORYID, DEFAULIMPL, true); + } + + /** +@@ -183,9 +182,7 @@ + public static XMLInputFactory newFactory() + throws FactoryConfigurationError + { +- return (XMLInputFactory) FactoryFinder.find( +- "javax.xml.stream.XMLInputFactory", +- DEFAULIMPL); ++ return (XMLInputFactory) FactoryFinder.find(JAXPFACTORYID, DEFAULIMPL, true); + } + + /** +@@ -208,7 +205,8 @@ + throws FactoryConfigurationError { + try { + //do not fallback if given classloader can't find the class, throw exception +- return (XMLInputFactory) FactoryFinder.find(factoryId, classLoader, null); ++ return (XMLInputFactory) FactoryFinder.find(factoryId, classLoader, ++ null, factoryId.equals(JAXPFACTORYID) ? true : false); + } catch (FactoryFinder.ConfigurationError e) { + throw new FactoryConfigurationError(e.getException(), + e.getMessage()); +@@ -235,7 +233,8 @@ + throws FactoryConfigurationError { + try { + //do not fallback if given classloader can't find the class, throw exception +- return (XMLInputFactory) FactoryFinder.find(factoryId, classLoader, null); ++ return (XMLInputFactory) FactoryFinder.find(factoryId, classLoader, ++ null, factoryId.equals(JAXPFACTORYID) ? true : false); + } catch (FactoryFinder.ConfigurationError e) { + throw new FactoryConfigurationError(e.getException(), + e.getMessage()); +diff -r 7e2686f33289 -r b5b1d1fa4bb4 drop_included/jaxp_src/src/javax/xml/stream/XMLOutputFactory.java +--- jaxp/drop_included/jaxp_src/src/javax/xml/stream/XMLOutputFactory.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxp/drop_included/jaxp_src/src/javax/xml/stream/XMLOutputFactory.java Thu Oct 10 16:18:30 2013 +0100 +@@ -115,6 +115,7 @@ + public static final String IS_REPAIRING_NAMESPACES= + "javax.xml.stream.isRepairingNamespaces"; + ++ static final String JAXPFACTORYID = "javax.xml.stream.XMLOutputFactory"; + static final String DEFAULIMPL = "com.sun.xml.internal.stream.XMLOutputFactoryImpl"; + + protected XMLOutputFactory(){} +@@ -126,8 +127,7 @@ + public static XMLOutputFactory newInstance() + throws FactoryConfigurationError + { +- return (XMLOutputFactory) FactoryFinder.find("javax.xml.stream.XMLOutputFactory", +- DEFAULIMPL); ++ return (XMLOutputFactory) FactoryFinder.find(JAXPFACTORYID, DEFAULIMPL, true); + } + + /** +@@ -158,8 +158,7 @@ + public static XMLOutputFactory newFactory() + throws FactoryConfigurationError + { +- return (XMLOutputFactory) FactoryFinder.find("javax.xml.stream.XMLOutputFactory", +- DEFAULIMPL); ++ return (XMLOutputFactory) FactoryFinder.find(JAXPFACTORYID, DEFAULIMPL, true); + } + + /** +@@ -181,7 +180,8 @@ + throws FactoryConfigurationError { + try { + //do not fallback if given classloader can't find the class, throw exception +- return (XMLInputFactory) FactoryFinder.find(factoryId, classLoader, null); ++ return (XMLInputFactory) FactoryFinder.find(factoryId, classLoader, ++ null, factoryId.equals(JAXPFACTORYID) ? true : false); + } catch (FactoryFinder.ConfigurationError e) { + throw new FactoryConfigurationError(e.getException(), + e.getMessage()); +@@ -210,7 +210,8 @@ + throws FactoryConfigurationError { + try { + //do not fallback if given classloader can't find the class, throw exception +- return (XMLOutputFactory) FactoryFinder.find(factoryId, classLoader, null); ++ return (XMLOutputFactory) FactoryFinder.find(factoryId, classLoader, ++ null, factoryId.equals(JAXPFACTORYID) ? true : false); + } catch (FactoryFinder.ConfigurationError e) { + throw new FactoryConfigurationError(e.getException(), + e.getMessage()); diff --git a/java/openjdk6/files/icedtea/openjdk/8013506-better_pack200.patch b/java/openjdk6/files/icedtea/openjdk/8013506-better_pack200.patch new file mode 100644 index 000000000000..b3696fc25fed --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013506-better_pack200.patch @@ -0,0 +1,39 @@ +# HG changeset patch +# User ksrini +# Date 1381851019 -3600 +# Tue Oct 15 16:30:19 2013 +0100 +# Node ID 8fb384d684f5b9bc76970bdc7e5603b9cd9944b8 +# Parent 337232ddaec36c6d9843ff35906e6160446844eb +8013506: Better Pack200 data handling +Reviewed-by: jrose, kizune, mschoene + +diff -r 337232ddaec3 -r 8fb384d684f5 src/share/native/com/sun/java/util/jar/pack/zip.cpp +--- jdk/src/share/native/com/sun/java/util/jar/pack/zip.cpp Fri May 31 20:43:32 2013 +0400 ++++ jdk/src/share/native/com/sun/java/util/jar/pack/zip.cpp Tue Oct 15 16:30:19 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2001, 2005, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -339,6 +339,10 @@ + time_t t = modtime; + struct tm sbuf; + struct tm* s = gmtime_r(&t, &sbuf); ++ if (s == NULL) { ++ fprintf(u->errstrm, "Error: gmtime failure, invalid input archive\n"); ++ exit(2); ++ } + modtime_cache = modtime; + dostime_cache = dostime(s->tm_year + 1900, s->tm_mon + 1, s->tm_mday, + s->tm_hour, s->tm_min, s->tm_sec); +@@ -383,7 +387,7 @@ + } + + deflated.empty(); +- zs.next_out = (uchar*) deflated.grow(len + (len/2)); ++ zs.next_out = (uchar*) deflated.grow(add_size(len, (len/2))); + zs.avail_out = deflated.size(); + + zs.next_in = (uchar*)head.ptr; diff --git a/java/openjdk6/files/icedtea/openjdk/8013510-augment_image_writing.patch b/java/openjdk6/files/icedtea/openjdk/8013510-augment_image_writing.patch new file mode 100644 index 000000000000..8c4946051687 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013510-augment_image_writing.patch @@ -0,0 +1,57 @@ +# HG changeset patch +# User jchen +# Date 1368123798 25200 +# Thu May 09 11:23:18 2013 -0700 +# Node ID c428e65fa8fd127058ea33ef728391887ea108e6 +# Parent 8fb384d684f5b9bc76970bdc7e5603b9cd9944b8 +8013510: Augment image writing code +Reviewed-by: bae, prr + +diff -r 8fb384d684f5 -r c428e65fa8fd src/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java +--- jdk/src/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java Tue Oct 15 16:30:19 2013 +0100 ++++ jdk/src/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageReader.java Thu May 09 11:23:18 2013 -0700 +@@ -1178,6 +1178,11 @@ + target = imRas; + } + int [] bandSizes = target.getSampleModel().getSampleSize(); ++ for (int i = 0; i < bandSizes.length; i++) { ++ if (bandSizes[i] <= 0 || bandSizes[i] > 8) { ++ throw new IIOException("Illegal band size: should be 0 < size <= 8"); ++ } ++ } + + /* + * If the process is sequential, and we have restart markers, +diff -r 8fb384d684f5 -r c428e65fa8fd src/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java +--- jdk/src/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java Tue Oct 15 16:30:19 2013 +0100 ++++ jdk/src/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java Thu May 09 11:23:18 2013 -0700 +@@ -490,8 +490,8 @@ + // handle <= 8-bit samples. We now check the band sizes and throw + // an exception for images, such as USHORT_GRAY, with > 8 bits + // per sample. +- if (bandSizes[i] > 8) { +- throw new IIOException("Sample size must be <= 8"); ++ if (bandSizes[i] <= 0 || bandSizes[i] > 8) { ++ throw new IIOException("Illegal band size: should be 0 < size <= 8"); + } + // 4450894 part 2: We expand IndexColorModel images to full 24- + // or 32-bit in grabPixels() for each scanline. For indexed +diff -r 8fb384d684f5 -r c428e65fa8fd src/share/native/sun/awt/image/jpeg/imageioJPEG.c +--- jdk/src/share/native/sun/awt/image/jpeg/imageioJPEG.c Tue Oct 15 16:30:19 2013 +0100 ++++ jdk/src/share/native/sun/awt/image/jpeg/imageioJPEG.c Thu May 09 11:23:18 2013 -0700 +@@ -2684,6 +2684,15 @@ + bandSize = (*env)->GetIntArrayElements(env, bandSizes, NULL); + + for (i = 0; i < numBands; i++) { ++ if (bandSize[i] <= 0 || bandSize[i] > JPEG_BAND_SIZE) { ++ (*env)->ReleaseIntArrayElements(env, bandSizes, ++ bandSize, JNI_ABORT); ++ JNU_ThrowByName(env, "javax/imageio/IIOException", "Invalid Image"); ++ return JNI_FALSE;; ++ } ++ } ++ ++ for (i = 0; i < numBands; i++) { + if (bandSize[i] != JPEG_BAND_SIZE) { + mustScale = TRUE; + break; diff --git a/java/openjdk6/files/icedtea/openjdk/8013514-improve_cmap_stability.patch b/java/openjdk6/files/icedtea/openjdk/8013514-improve_cmap_stability.patch new file mode 100644 index 000000000000..606d87fc139b --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013514-improve_cmap_stability.patch @@ -0,0 +1,51 @@ +# HG changeset patch +# User vadim +# Date 1381851333 -3600 +# Tue Oct 15 16:35:33 2013 +0100 +# Node ID a28b8ce4d90e7d7bc1fab599298831e0d62e171e +# Parent c428e65fa8fd127058ea33ef728391887ea108e6 +8013514: Improve stability of cmap class +Reviewed-by: mschoene, prr, bae + +diff -r c428e65fa8fd -r a28b8ce4d90e src/share/classes/sun/font/FileFont.java +--- jdk/src/share/classes/sun/font/FileFont.java Thu May 09 11:23:18 2013 -0700 ++++ jdk/src/share/classes/sun/font/FileFont.java Tue Oct 15 16:35:33 2013 +0100 +@@ -174,7 +174,9 @@ + } + } + } +- scaler.dispose(); ++ if (scaler != null) { ++ scaler.dispose(); ++ } + scaler = FontManager.getNullScaler(); + } + +diff -r c428e65fa8fd -r a28b8ce4d90e src/share/classes/sun/font/StandardGlyphVector.java +--- jdk/src/share/classes/sun/font/StandardGlyphVector.java Thu May 09 11:23:18 2013 -0700 ++++ jdk/src/share/classes/sun/font/StandardGlyphVector.java Tue Oct 15 16:35:33 2013 +0100 +@@ -1733,8 +1733,9 @@ + tx, + sgv.font.getStyle(), + aa, fm); +- +- FontStrike strike = sgv.font2D.getStrike(desc); // !!! getStrike(desc, false) ++ // Get the strike via the handle. Shouldn't matter ++ // if we've invalidated the font but its an extra precaution. ++ FontStrike strike = sgv.font2D.handle.font2D.getStrike(desc); // !!! getStrike(desc, false) + + return new GlyphStrike(sgv, strike, dx, dy); + } +diff -r c428e65fa8fd -r a28b8ce4d90e src/share/classes/sun/font/TrueTypeFont.java +--- jdk/src/share/classes/sun/font/TrueTypeFont.java Thu May 09 11:23:18 2013 -0700 ++++ jdk/src/share/classes/sun/font/TrueTypeFont.java Tue Oct 15 16:35:33 2013 +0100 +@@ -559,6 +559,9 @@ + if (head_Table != null && head_Table.capacity() >= 18) { + ShortBuffer sb = head_Table.asShortBuffer(); + upem = sb.get(9) & 0xffff; ++ if (upem < 16 || upem > 16384) { ++ upem = 2048; ++ } + } + setStrikethroughMetrics(os2_Table, upem); + diff --git a/java/openjdk6/files/icedtea/openjdk/8013739-better_ldap_resource_management.patch b/java/openjdk6/files/icedtea/openjdk/8013739-better_ldap_resource_management.patch new file mode 100644 index 000000000000..ce2e96356cd2 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013739-better_ldap_resource_management.patch @@ -0,0 +1,148 @@ +# HG changeset patch +# User weijun +# Date 1382990980 0 +# Mon Oct 28 20:09:40 2013 +0000 +# Node ID 42fd9f22ae5e9aea017af28a2b5ff7a498753e15 +# Parent 2adb9f71f6c0723acf40877f059d276557b71034 +8013739: Better LDAP resource management +Reviewed-by: ahgross, mchung, xuelei + +diff -r 2adb9f71f6c0 -r 42fd9f22ae5e src/share/classes/com/sun/jndi/ldap/VersionHelper12.java +--- jdk/src/share/classes/com/sun/jndi/ldap/VersionHelper12.java Mon Jul 22 14:06:39 2013 -0700 ++++ jdk/src/share/classes/com/sun/jndi/ldap/VersionHelper12.java Mon Oct 28 20:09:40 2013 +0000 +@@ -25,11 +25,12 @@ + + package com.sun.jndi.ldap; + +-import java.net.URL; + import java.net.URLClassLoader; + import java.net.MalformedURLException; ++import java.security.AccessControlContext; + import java.security.AccessController; + import java.security.PrivilegedAction; ++import sun.misc.SharedSecrets; + + final class VersionHelper12 extends VersionHelper { + +@@ -82,12 +83,16 @@ + } + + Thread createThread(final Runnable r) { +- return (Thread) AccessController.doPrivileged( +- new PrivilegedAction() { +- public Object run() { +- return new Thread(r); ++ final AccessControlContext acc = AccessController.getContext(); ++ // 4290486: doPrivileged is needed to create a thread in ++ // an environment that restricts "modifyThreadGroup". ++ return AccessController.doPrivileged( ++ new PrivilegedAction<Thread>() { ++ public Thread run() { ++ return SharedSecrets.getJavaLangAccess() ++ .newThreadWithAcc(r, acc); ++ } + } +- } + ); + } + } +diff -r 2adb9f71f6c0 -r 42fd9f22ae5e src/share/classes/java/lang/System.java +--- jdk/src/share/classes/java/lang/System.java Mon Jul 22 14:06:39 2013 -0700 ++++ jdk/src/share/classes/java/lang/System.java Mon Oct 28 20:09:40 2013 +0000 +@@ -25,6 +25,7 @@ + package java.lang; + + import java.io.*; ++import java.security.AccessControlContext; + import java.util.Properties; + import java.util.PropertyPermission; + import java.util.StringTokenizer; +@@ -1158,6 +1159,9 @@ + public void blockedOn(Thread t, Interruptible b) { + t.blockedOn(b); + } ++ public Thread newThreadWithAcc(Runnable target, AccessControlContext acc) { ++ return new Thread(target, acc); ++ } + }); + } + } +diff -r 2adb9f71f6c0 -r 42fd9f22ae5e src/share/classes/java/lang/Thread.java +--- jdk/src/share/classes/java/lang/Thread.java Mon Jul 22 14:06:39 2013 -0700 ++++ jdk/src/share/classes/java/lang/Thread.java Mon Oct 28 20:09:40 2013 +0000 +@@ -322,6 +322,15 @@ + } + + /** ++ * Initializes a Thread with the current AccessControlContext. ++ * @see #init(ThreadGroup,Runnable,String,long,AccessControlContext) ++ */ ++ private void init(ThreadGroup g, Runnable target, String name, ++ long stackSize) { ++ init(g, target, name, stackSize, null); ++ } ++ ++ /** + * Initializes a Thread. + * + * @param g the Thread group +@@ -329,9 +338,11 @@ + * @param name the name of the new Thread + * @param stackSize the desired stack size for the new thread, or + * zero to indicate that this parameter is to be ignored. ++ * @param acc the AccessControlContext to inherit, or ++ * AccessController.getContext() if null + */ + private void init(ThreadGroup g, Runnable target, String name, +- long stackSize) { ++ long stackSize, AccessControlContext acc) { + Thread parent = currentThread(); + SecurityManager security = System.getSecurityManager(); + if (g == null) { +@@ -374,7 +385,8 @@ + this.contextClassLoader = parent.getContextClassLoader(); + else + this.contextClassLoader = parent.contextClassLoader; +- this.inheritedAccessControlContext = AccessController.getContext(); ++ this.inheritedAccessControlContext = ++ acc != null ? acc : AccessController.getContext(); + this.target = target; + setPriority(priority); + if (parent.inheritableThreadLocals != null) +@@ -427,6 +439,14 @@ + } + + /** ++ * Creates a new Thread that inherits the given AccessControlContext. ++ * This is not a public constructor. ++ */ ++ Thread(Runnable target, AccessControlContext acc) { ++ init(null, target, "Thread-" + nextThreadNum(), 0, acc); ++ } ++ ++ /** + * Allocates a new <code>Thread</code> object. This constructor has + * the same effect as <code>Thread(null, null,</code> + * <i>gname</i><code>)</code>, where <b><i>gname</i></b> is +diff -r 2adb9f71f6c0 -r 42fd9f22ae5e src/share/classes/sun/misc/JavaLangAccess.java +--- jdk/src/share/classes/sun/misc/JavaLangAccess.java Mon Jul 22 14:06:39 2013 -0700 ++++ jdk/src/share/classes/sun/misc/JavaLangAccess.java Mon Oct 28 20:09:40 2013 +0000 +@@ -25,6 +25,7 @@ + + package sun.misc; + ++import java.security.AccessControlContext; + import sun.reflect.ConstantPool; + import sun.reflect.annotation.AnnotationType; + import sun.nio.ch.Interruptible; +@@ -54,4 +55,10 @@ + + /** Set thread's blocker field. */ + void blockedOn(Thread t, Interruptible b); ++ ++ /** ++ * Returns a new Thread with the given Runnable and an ++ * inherited AccessControlContext. ++ */ ++ Thread newThreadWithAcc(Runnable target, AccessControlContext acc); + } diff --git a/java/openjdk6/files/icedtea/openjdk/8013744-better_tabling.patch b/java/openjdk6/files/icedtea/openjdk/8013744-better_tabling.patch new file mode 100644 index 000000000000..ca81f04485fa --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013744-better_tabling.patch @@ -0,0 +1,196 @@ +# HG changeset patch +# User alexsch +# Date 1381852031 -3600 +# Tue Oct 15 16:47:11 2013 +0100 +# Node ID d10e47deb098d4af5d58a8bfe92dc8033e5ef6f7 +# Parent a28b8ce4d90e7d7bc1fab599298831e0d62e171e +8013744: Better tabling for AWT +Reviewed-by: art, malenkov, skoivu + +diff -r a28b8ce4d90e -r d10e47deb098 src/share/classes/javax/swing/JTable.java +--- jdk/src/share/classes/javax/swing/JTable.java Tue Oct 15 16:35:33 2013 +0100 ++++ jdk/src/share/classes/javax/swing/JTable.java Tue Oct 15 16:47:11 2013 +0100 +@@ -52,6 +52,7 @@ + + import javax.print.attribute.*; + import javax.print.PrintService; ++import sun.reflect.misc.ReflectUtil; + + import sun.swing.SwingUtilities2; + import sun.swing.SwingUtilities2.Section; +@@ -5461,14 +5462,15 @@ + // they have the option to replace the value with + // null or use escape to restore the original. + // For Strings, return "" for backward compatibility. +- if ("".equals(s)) { +- if (constructor.getDeclaringClass() == String.class) { +- value = s; +- } +- super.stopCellEditing(); +- } +- + try { ++ if ("".equals(s)) { ++ if (constructor.getDeclaringClass() == String.class) { ++ value = s; ++ } ++ super.stopCellEditing(); ++ } ++ ++ SwingUtilities2.checkAccess(constructor.getModifiers()); + value = constructor.newInstance(new Object[]{s}); + } + catch (Exception e) { +@@ -5492,6 +5494,8 @@ + if (type == Object.class) { + type = String.class; + } ++ ReflectUtil.checkPackageAccess(type); ++ SwingUtilities2.checkAccess(type.getModifiers()); + constructor = type.getConstructor(argTypes); + } + catch (Exception e) { +diff -r a28b8ce4d90e -r d10e47deb098 src/share/classes/javax/swing/UIDefaults.java +--- jdk/src/share/classes/javax/swing/UIDefaults.java Tue Oct 15 16:35:33 2013 +0100 ++++ jdk/src/share/classes/javax/swing/UIDefaults.java Tue Oct 15 16:47:11 2013 +0100 +@@ -53,6 +53,7 @@ + + import sun.reflect.misc.MethodUtil; + import sun.reflect.misc.ReflectUtil; ++import sun.swing.SwingUtilities2; + import sun.util.CoreResourceBundleControl; + + /** +@@ -1102,7 +1103,7 @@ + } + ReflectUtil.checkPackageAccess(className); + c = Class.forName(className, true, (ClassLoader)cl); +- checkAccess(c.getModifiers()); ++ SwingUtilities2.checkAccess(c.getModifiers()); + if (methodName != null) { + Class[] types = getClassArray(args); + Method m = c.getMethod(methodName, types); +@@ -1110,7 +1111,7 @@ + } else { + Class[] types = getClassArray(args); + Constructor constructor = c.getConstructor(types); +- checkAccess(constructor.getModifiers()); ++ SwingUtilities2.checkAccess(constructor.getModifiers()); + return constructor.newInstance(args); + } + } catch(Exception e) { +@@ -1125,13 +1126,6 @@ + }, acc); + } + +- private void checkAccess(int modifiers) { +- if(System.getSecurityManager() != null && +- !Modifier.isPublic(modifiers)) { +- throw new SecurityException("Resource is not accessible"); +- } +- } +- + /* + * Coerce the array of class types provided into one which + * looks the way the Reflection APIs expect. This is done +diff -r a28b8ce4d90e -r d10e47deb098 src/share/classes/javax/swing/text/DefaultFormatter.java +--- jdk/src/share/classes/javax/swing/text/DefaultFormatter.java Tue Oct 15 16:35:33 2013 +0100 ++++ jdk/src/share/classes/javax/swing/text/DefaultFormatter.java Tue Oct 15 16:47:11 2013 +0100 +@@ -24,7 +24,8 @@ + */ + package javax.swing.text; + +-import sun.reflect.misc.ConstructorUtil; ++import sun.reflect.misc.ReflectUtil; ++import sun.swing.SwingUtilities2; + + import java.io.Serializable; + import java.lang.reflect.*; +@@ -247,7 +248,9 @@ + Constructor cons; + + try { +- cons = ConstructorUtil.getConstructor(vc, new Class[]{String.class}); ++ ReflectUtil.checkPackageAccess(vc); ++ SwingUtilities2.checkAccess(vc.getModifiers()); ++ cons = vc.getConstructor(new Class[]{String.class}); + + } catch (NoSuchMethodException nsme) { + cons = null; +@@ -255,6 +258,7 @@ + + if (cons != null) { + try { ++ SwingUtilities2.checkAccess(cons.getModifiers()); + return cons.newInstance(new Object[] { string }); + } catch (Throwable ex) { + throw new ParseException("Error creating instance", 0); +diff -r a28b8ce4d90e -r d10e47deb098 src/share/classes/javax/swing/text/NumberFormatter.java +--- jdk/src/share/classes/javax/swing/text/NumberFormatter.java Tue Oct 15 16:35:33 2013 +0100 ++++ jdk/src/share/classes/javax/swing/text/NumberFormatter.java Tue Oct 15 16:47:11 2013 +0100 +@@ -28,6 +28,8 @@ + import java.text.*; + import java.util.*; + import javax.swing.text.*; ++import sun.reflect.misc.ReflectUtil; ++import sun.swing.SwingUtilities2; + + /** + * <code>NumberFormatter</code> subclasses <code>InternationalFormatter</code> +@@ -466,10 +468,12 @@ + valueClass = value.getClass(); + } + try { ++ ReflectUtil.checkPackageAccess(valueClass); ++ SwingUtilities2.checkAccess(valueClass.getModifiers()); + Constructor cons = valueClass.getConstructor( + new Class[] { String.class }); +- + if (cons != null) { ++ SwingUtilities2.checkAccess(cons.getModifiers()); + return cons.newInstance(new Object[]{string}); + } + } catch (Throwable ex) { } +diff -r a28b8ce4d90e -r d10e47deb098 src/share/classes/sun/swing/SwingLazyValue.java +--- jdk/src/share/classes/sun/swing/SwingLazyValue.java Tue Oct 15 16:35:33 2013 +0100 ++++ jdk/src/share/classes/sun/swing/SwingLazyValue.java Tue Oct 15 16:47:11 2013 +0100 +@@ -30,6 +30,7 @@ + import java.security.AccessController; + import java.security.PrivilegedAction; + import javax.swing.UIDefaults; ++import sun.reflect.misc.ReflectUtil; + + /** + * SwingLazyValue is a copy of ProxyLazyValue that does not snapshot the +@@ -64,7 +65,7 @@ + public Object createValue(final UIDefaults table) { + try { + Class c; +- Object cl; ++ ReflectUtil.checkPackageAccess(className); + c = Class.forName(className, true, null); + if (methodName != null) { + Class[] types = getClassArray(args); +diff -r a28b8ce4d90e -r d10e47deb098 src/share/classes/sun/swing/SwingUtilities2.java +--- jdk/src/share/classes/sun/swing/SwingUtilities2.java Tue Oct 15 16:35:33 2013 +0100 ++++ jdk/src/share/classes/sun/swing/SwingUtilities2.java Tue Oct 15 16:47:11 2013 +0100 +@@ -1319,6 +1319,19 @@ + } + + /** ++ * Utility method that throws SecurityException if SecurityManager is set ++ * and modifiers are not public ++ * ++ * @param modifiers a set of modifiers ++ */ ++ public static void checkAccess(int modifiers) { ++ if (System.getSecurityManager() != null ++ && !Modifier.isPublic(modifiers)) { ++ throw new SecurityException("Resource is not accessible"); ++ } ++ } ++ ++ /** + * Returns true if EventQueue.getCurrentEvent() has the permissions to + * access the system clipboard and if it is allowed gesture (if + * checkGesture true) diff --git a/java/openjdk6/files/icedtea/openjdk/8013827-createtempfile_hang.patch b/java/openjdk6/files/icedtea/openjdk/8013827-createtempfile_hang.patch new file mode 100644 index 000000000000..89db40974250 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8013827-createtempfile_hang.patch @@ -0,0 +1,176 @@ +# HG changeset patch +# User dxu +# Date 1383018580 0 +# Tue Oct 29 03:49:40 2013 +0000 +# Node ID 8459b68eb028734b2153266176538e1eddbb87be +# Parent 8ad2eb12bf42f2564fdf80a7236e4046046a4f4e +8013827: File.createTempFile hangs with temp file starting with 'com1.4' +8011950: java.io.File.createTempFile enters infinite loop when passed invalid data +Reviewed-by: alanb + +diff -r 8ad2eb12bf42 -r 8459b68eb028 src/share/classes/java/io/File.java +--- jdk/src/share/classes/java/io/File.java Tue Oct 29 03:05:18 2013 +0000 ++++ jdk/src/share/classes/java/io/File.java Tue Oct 29 03:49:40 2013 +0000 +@@ -1801,7 +1801,11 @@ + } else { + n = Math.abs(n); + } +- return new File(dir, prefix + Long.toString(n) + suffix); ++ String name = prefix + Long.toString(n) + suffix; ++ File f = new File(dir, name); ++ if (!name.equals(f.getName())) ++ throw new IOException("Unable to create temporary file"); ++ return f; + } + + private static boolean checkAndCreate(String filename, SecurityManager sm, +diff -r 8ad2eb12bf42 -r 8459b68eb028 src/windows/native/java/io/WinNTFileSystem_md.c +--- jdk/src/windows/native/java/io/WinNTFileSystem_md.c Tue Oct 29 03:05:18 2013 +0000 ++++ jdk/src/windows/native/java/io/WinNTFileSystem_md.c Tue Oct 29 03:49:40 2013 +0000 +@@ -356,6 +356,10 @@ + WCHAR *pathbuf = pathToNTPath(env, path, JNI_FALSE); + if (pathbuf == NULL) + return JNI_FALSE; ++ if (isReservedDeviceNameW(pathbuf)) { ++ free(pathbuf); ++ return JNI_FALSE; ++ } + h = CreateFileW( + pathbuf, /* Wide char path name */ + GENERIC_READ | GENERIC_WRITE, /* Read and write permission */ +diff -r 8ad2eb12bf42 -r 8459b68eb028 test/java/io/File/CreateNewFile.java +--- jdk/test/java/io/File/CreateNewFile.java Tue Oct 29 03:05:18 2013 +0000 ++++ jdk/test/java/io/File/CreateNewFile.java Tue Oct 29 03:49:40 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1998, 2001, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -22,7 +22,7 @@ + */ + + /* @test +- @bug 4130498 4391178 ++ @bug 4130498 4391178 6198547 + @summary Basic test for createNewFile method + */ + +@@ -51,5 +51,20 @@ + } catch (IOException e) { + // Exception expected + } ++ ++ testCreateExistingDir(); ++ } ++ ++ // Test JDK-6198547 ++ private static void testCreateExistingDir() throws IOException { ++ File tmpFile = new File("hugo"); ++ if (tmpFile.exists() && !tmpFile.delete()) ++ throw new RuntimeException("Cannot delete " + tmpFile); ++ if (!tmpFile.mkdir()) ++ throw new RuntimeException("Cannot create dir " + tmpFile); ++ if (!tmpFile.exists()) ++ throw new RuntimeException("Cannot see created dir " + tmpFile); ++ if (tmpFile.createNewFile()) ++ throw new RuntimeException("Should fail to create file " + tmpFile); + } + } +diff -r 8ad2eb12bf42 -r 8459b68eb028 test/java/io/File/NulFile.java +--- jdk/test/java/io/File/NulFile.java Tue Oct 29 03:05:18 2013 +0000 ++++ jdk/test/java/io/File/NulFile.java Tue Oct 29 03:49:40 2013 +0000 +@@ -612,7 +612,7 @@ + try { + File.createTempFile(prefix, suffix, directory); + } catch (IOException ex) { +- if ("Unable to create temporary file".equals(ex.getMessage())) ++ if (ExceptionMsg.equals(ex.getMessage())) + exceptionThrown = true; + } + } +diff -r 8ad2eb12bf42 -r 8459b68eb028 test/java/io/File/createTempFile/SpecialTempFile.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jdk/test/java/io/File/createTempFile/SpecialTempFile.java Tue Oct 29 03:49:40 2013 +0000 +@@ -0,0 +1,80 @@ ++/* ++ * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++/* ++ * @test ++ * @bug 8013827 8011950 ++ * @summary Check whether File.createTempFile can handle special parameters ++ * on Windows platforms ++ * @author Dan Xu ++ */ ++ ++import java.io.File; ++import java.io.IOException; ++ ++public class SpecialTempFile { ++ ++ private static void test(String name, String[] prefix, String[] suffix) { ++ if (prefix == null || suffix == null ++ || prefix.length != suffix.length) ++ { ++ return; ++ } ++ ++ final String exceptionMsg = "Unable to create temporary file"; ++ final String errMsg = "IOException is expected"; ++ ++ for (int i = 0; i < prefix.length; i++) { ++ boolean exceptionThrown = false; ++ File f = null; ++ System.out.println("In test " + name ++ + ", creating temp file with prefix, " ++ + prefix[i] + ", suffix, " + suffix[i]); ++ try { ++ f = File.createTempFile(prefix[i], suffix[i]); ++ } catch (IOException e) { ++ if (exceptionMsg.equals(e.getMessage())) ++ exceptionThrown = true; ++ else ++ System.out.println("Wrong error message:" + e.getMessage()); ++ } ++ if (!exceptionThrown || f != null) ++ throw new RuntimeException(errMsg); ++ } ++ } ++ ++ public static void main(String[] args) throws Exception { ++ if (!System.getProperty("os.name").startsWith("Windows")) ++ return; ++ ++ // Test JDK-8013827 ++ String[] resvPre = { "LPT1.package.zip", "com7.4.package.zip" }; ++ String[] resvSuf = { ".temp", ".temp" }; ++ test("ReservedName", resvPre, resvSuf); ++ ++ // Test JDK-8011950 ++ String[] slashPre = { "///..///", "temp", "///..///" }; ++ String[] slashSuf = { ".temp", "///..///..", "///..///.." }; ++ test("SlashedName", slashPre, slashSuf); ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8014085-better_serialization.patch b/java/openjdk6/files/icedtea/openjdk/8014085-better_serialization.patch new file mode 100644 index 000000000000..bdfc1b1c89ec --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014085-better_serialization.patch @@ -0,0 +1,412 @@ +# HG changeset patch +# User jbachorik +# Date 1371711107 -7200 +# Thu Jun 20 08:51:47 2013 +0200 +# Node ID a9be60a78488c7b261b92d927d1272afe2484e6b +# Parent d10e47deb098d4af5d58a8bfe92dc8033e5ef6f7 +8014085: Better serialization support in JMX classes +Reviewed-by: alanb, dfuchs, skoivu + +diff -r d10e47deb098 -r a9be60a78488 src/share/classes/javax/management/MBeanNotificationInfo.java +--- jdk/src/share/classes/javax/management/MBeanNotificationInfo.java Tue Oct 15 16:47:11 2013 +0100 ++++ jdk/src/share/classes/javax/management/MBeanNotificationInfo.java Thu Jun 20 08:51:47 2013 +0200 +@@ -25,6 +25,9 @@ + + package javax.management; + ++import java.io.IOException; ++import java.io.InvalidObjectException; ++import java.io.ObjectInputStream; + import java.util.Arrays; + + /** +@@ -67,7 +70,7 @@ + /** + * @serial The different types of the notification. + */ +- private final String[] types; ++ private String[] types; + + /** @see MBeanInfo#arrayGettersSafe */ + private final transient boolean arrayGettersSafe; +@@ -114,9 +117,8 @@ + notifType, though it doesn't explicitly allow it + either. */ + +- if (notifTypes == null) +- notifTypes = NO_TYPES; +- this.types = notifTypes; ++ this.types = (notifTypes != null && notifTypes.length > 0) ? ++ notifTypes.clone() : NO_TYPES; + this.arrayGettersSafe = + MBeanInfo.arrayGettersSafe(this.getClass(), + MBeanNotificationInfo.class); +@@ -203,4 +205,16 @@ + hash ^= types[i].hashCode(); + return hash; + } ++ ++ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ++ ObjectInputStream.GetField gf = ois.readFields(); ++ String[] t = (String[])gf.get("types", null); ++ ++ if (t == null) { ++ throw new InvalidObjectException("Trying to deserialize an invalid " + ++ "instance of " + MBeanNotificationInfo.class + ++ "[types=null]"); ++ } ++ types = t.length == 0 ? t : t.clone(); ++ } + } +diff -r d10e47deb098 -r a9be60a78488 src/share/classes/javax/management/remote/JMXPrincipal.java +--- jdk/src/share/classes/javax/management/remote/JMXPrincipal.java Tue Oct 15 16:47:11 2013 +0100 ++++ jdk/src/share/classes/javax/management/remote/JMXPrincipal.java Thu Jun 20 08:51:47 2013 +0200 +@@ -26,6 +26,9 @@ + + package javax.management.remote; + ++import java.io.IOException; ++import java.io.InvalidObjectException; ++import java.io.ObjectInputStream; + import java.io.Serializable; + import java.security.Principal; + +@@ -64,9 +67,7 @@ + * <code>null</code>. + */ + public JMXPrincipal(String name) { +- if (name == null) +- throw new NullPointerException("illegal null input"); +- ++ validate(name); + this.name = name; + } + +@@ -130,4 +131,20 @@ + public int hashCode() { + return name.hashCode(); + } ++ ++ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ++ ObjectInputStream.GetField gf = ois.readFields(); ++ String principalName = (String)gf.get("name", null); ++ try { ++ validate(principalName); ++ this.name = principalName; ++ } catch (NullPointerException e) { ++ throw new InvalidObjectException(e.getMessage()); ++ } ++ } ++ ++ private static void validate(String name) throws NullPointerException { ++ if (name == null) ++ throw new NullPointerException("illegal null input"); ++ } + } +diff -r d10e47deb098 -r a9be60a78488 src/share/classes/javax/management/remote/JMXServiceURL.java +--- jdk/src/share/classes/javax/management/remote/JMXServiceURL.java Tue Oct 15 16:47:11 2013 +0100 ++++ jdk/src/share/classes/javax/management/remote/JMXServiceURL.java Thu Jun 20 08:51:47 2013 +0200 +@@ -29,6 +29,9 @@ + + import com.sun.jmx.remote.util.ClassLogger; + import com.sun.jmx.remote.util.EnvHelp; ++import java.io.IOException; ++import java.io.InvalidObjectException; ++import java.io.ObjectInputStream; + + import java.io.Serializable; + import java.net.InetAddress; +@@ -299,7 +302,7 @@ + If we're given an explicit host name that is illegal we + have to reject it. (Bug 5057532.) */ + try { +- validateHost(host); ++ validateHost(host, port); + } catch (MalformedURLException e) { + if (logger.fineOn()) { + logger.fine("JMXServiceURL", +@@ -338,36 +341,82 @@ + validate(); + } + +- private void validate() throws MalformedURLException { ++ private static final String INVALID_INSTANCE_MSG = ++ "Trying to deserialize an invalid instance of JMXServiceURL"; ++ private void readObject(ObjectInputStream inputStream) throws IOException, ClassNotFoundException { ++ ObjectInputStream.GetField gf = inputStream.readFields(); ++ String h = (String)gf.get("host", null); ++ int p = (int)gf.get("port", -1); ++ String proto = (String)gf.get("protocol", null); ++ String url = (String)gf.get("urlPath", null); + ++ if (proto == null || url == null || h == null) { ++ StringBuilder sb = new StringBuilder(INVALID_INSTANCE_MSG).append('['); ++ boolean empty = true; ++ if (proto == null) { ++ sb.append("protocol=null"); ++ empty = false; ++ } ++ if (h == null) { ++ sb.append(empty ? "" : ",").append("host=null"); ++ empty = false; ++ } ++ if (url == null) { ++ sb.append(empty ? "" : ",").append("urlPath=null"); ++ } ++ sb.append(']'); ++ throw new InvalidObjectException(sb.toString()); ++ } ++ ++ if (h.contains("[") || h.contains("]")) { ++ throw new InvalidObjectException("Invalid host name: " + h); ++ } ++ ++ try { ++ validate(proto, h, p, url); ++ this.protocol = proto; ++ this.host = h; ++ this.port = p; ++ this.urlPath = url; ++ } catch (MalformedURLException e) { ++ throw new InvalidObjectException(INVALID_INSTANCE_MSG + ": " + ++ e.getMessage()); ++ } ++ ++ } ++ ++ private void validate(String proto, String h, int p, String url) ++ throws MalformedURLException { + // Check protocol +- +- final int protoEnd = indexOfFirstNotInSet(protocol, protocolBitSet, 0); +- if (protoEnd == 0 || protoEnd < protocol.length() +- || !alphaBitSet.get(protocol.charAt(0))) { ++ final int protoEnd = indexOfFirstNotInSet(proto, protocolBitSet, 0); ++ if (protoEnd == 0 || protoEnd < proto.length() ++ || !alphaBitSet.get(proto.charAt(0))) { + throw new MalformedURLException("Missing or invalid protocol " + +- "name: \"" + protocol + "\""); ++ "name: \"" + proto + "\""); + } + + // Check host +- +- validateHost(); ++ validateHost(h, p); + + // Check port +- +- if (port < 0) +- throw new MalformedURLException("Bad port: " + port); ++ if (p < 0) ++ throw new MalformedURLException("Bad port: " + p); + + // Check URL path +- +- if (urlPath.length() > 0) { +- if (!urlPath.startsWith("/") && !urlPath.startsWith(";")) +- throw new MalformedURLException("Bad URL path: " + urlPath); ++ if (url.length() > 0) { ++ if (!url.startsWith("/") && !url.startsWith(";")) ++ throw new MalformedURLException("Bad URL path: " + url); + } + } + +- private void validateHost() throws MalformedURLException { +- if (host.length() == 0) { ++ private void validate() throws MalformedURLException { ++ validate(this.protocol, this.host, this.port, this.urlPath); ++ } ++ ++ private static void validateHost(String h, int port) ++ throws MalformedURLException { ++ ++ if (h.length() == 0) { + if (port != 0) { + throw new MalformedURLException("Cannot give port number " + + "without host name"); +@@ -375,12 +424,6 @@ + return; + } + +- validateHost(host); +- } +- +- private static void validateHost(String h) +- throws MalformedURLException { +- + if (isNumericIPv6Address(h)) { + /* We assume J2SE >= 1.4 here. Otherwise you can't + use the address anyway. We can't call +@@ -670,22 +713,22 @@ + /** + * The value returned by {@link #getProtocol()}. + */ +- private final String protocol; ++ private String protocol; + + /** + * The value returned by {@link #getHost()}. + */ +- private final String host; ++ private String host; + + /** + * The value returned by {@link #getPort()}. + */ +- private final int port; ++ private int port; + + /** + * The value returned by {@link #getURLPath()}. + */ +- private final String urlPath; ++ private String urlPath; + + /** + * Cached result of {@link #toString()}. +diff -r d10e47deb098 -r a9be60a78488 src/share/classes/javax/management/remote/NotificationResult.java +--- jdk/src/share/classes/javax/management/remote/NotificationResult.java Tue Oct 15 16:47:11 2013 +0100 ++++ jdk/src/share/classes/javax/management/remote/NotificationResult.java Thu Jun 20 08:51:47 2013 +0200 +@@ -25,6 +25,9 @@ + + package javax.management.remote; + ++import java.io.IOException; ++import java.io.InvalidObjectException; ++import java.io.ObjectInputStream; + import java.io.Serializable; + + /** +@@ -76,17 +79,7 @@ + public NotificationResult(long earliestSequenceNumber, + long nextSequenceNumber, + TargetedNotification[] targetedNotifications) { +- if (targetedNotifications == null) { +- final String msg = "Notifications null"; +- throw new IllegalArgumentException(msg); +- } +- +- if (earliestSequenceNumber < 0 || nextSequenceNumber < 0) +- throw new IllegalArgumentException("Bad sequence numbers"); +- /* We used to check nextSequenceNumber >= earliestSequenceNumber +- here. But in fact the opposite can legitimately be true if +- notifications have been lost. */ +- ++ validate(targetedNotifications, earliestSequenceNumber, nextSequenceNumber); + this.earliestSequenceNumber = earliestSequenceNumber; + this.nextSequenceNumber = nextSequenceNumber; + this.targetedNotifications = (targetedNotifications.length == 0 ? targetedNotifications : targetedNotifications.clone()); +@@ -138,7 +131,39 @@ + getTargetedNotifications().length; + } + +- private final long earliestSequenceNumber; +- private final long nextSequenceNumber; +- private final TargetedNotification[] targetedNotifications; ++ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ++ ObjectInputStream.GetField gf = ois.readFields(); ++ TargetedNotification[] tNotifs = (TargetedNotification[])gf.get("targetedNotifications", null); ++ long snStart = gf.get("earliestSequenceNumber", -1L); ++ long snNext = gf.get("nextSequenceNumber", -1L); ++ try { ++ validate(tNotifs, snStart, snNext); ++ ++ this.targetedNotifications = tNotifs.length == 0 ? tNotifs : tNotifs.clone(); ++ this.earliestSequenceNumber = snStart; ++ this.nextSequenceNumber = snNext; ++ } catch (IllegalArgumentException e) { ++ throw new InvalidObjectException(e.getMessage()); ++ } ++ } ++ ++ private long earliestSequenceNumber; ++ private long nextSequenceNumber; ++ private TargetedNotification[] targetedNotifications; ++ ++ private static void validate(TargetedNotification[] targetedNotifications, ++ long earliestSequenceNumber, ++ long nextSequenceNumber) ++ throws IllegalArgumentException { ++ if (targetedNotifications == null) { ++ final String msg = "Notifications null"; ++ throw new IllegalArgumentException(msg); ++ } ++ ++ if (earliestSequenceNumber < 0 || nextSequenceNumber < 0) ++ throw new IllegalArgumentException("Bad sequence numbers"); ++ /* We used to check nextSequenceNumber >= earliestSequenceNumber ++ here. But in fact the opposite can legitimately be true if ++ notifications have been lost. */ ++ } + } +diff -r d10e47deb098 -r a9be60a78488 src/share/classes/javax/management/remote/TargetedNotification.java +--- jdk/src/share/classes/javax/management/remote/TargetedNotification.java Tue Oct 15 16:47:11 2013 +0100 ++++ jdk/src/share/classes/javax/management/remote/TargetedNotification.java Thu Jun 20 08:51:47 2013 +0200 +@@ -26,6 +26,9 @@ + + package javax.management.remote; + ++import java.io.IOException; ++import java.io.InvalidObjectException; ++import java.io.ObjectInputStream; + import java.io.Serializable; + import javax.management.Notification; + +@@ -73,12 +76,9 @@ + */ + public TargetedNotification(Notification notification, + Integer listenerID) { ++ validate(notification, listenerID); + // If we replace integer with int... + // this(notification,intValue(listenerID)); +- if (notification == null) throw new +- IllegalArgumentException("Invalid notification: null"); +- if (listenerID == null) throw new +- IllegalArgumentException("Invalid listener ID: null"); + this.notif = notification; + this.id = listenerID; + } +@@ -115,13 +115,13 @@ + * @serial A notification to transmit to the other side. + * @see #getNotification() + **/ +- private final Notification notif; ++ private Notification notif; + /** + * @serial The ID of the listener to which the notification is + * targeted. + * @see #getListenerID() + **/ +- private final Integer id; ++ private Integer id; + //private final int id; + + // Needed if we use int instead of Integer... +@@ -130,4 +130,26 @@ + // IllegalArgumentException("Invalid listener ID: null"); + // return id.intValue(); + // } ++ ++ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ++ ObjectInputStream.GetField gf = ois.readFields(); ++ Notification notification = (Notification)gf.get("notif", null); ++ Integer listenerId = (Integer)gf.get("id", null); ++ try { ++ validate(notification, listenerId); ++ this.notif = notification; ++ this.id = listenerId; ++ } catch (IllegalArgumentException e) { ++ throw new InvalidObjectException(e.getMessage()); ++ } ++ } ++ ++ private static void validate(Notification notif, Integer id) throws IllegalArgumentException { ++ if (notif == null) { ++ throw new IllegalArgumentException("Invalid notification: null"); ++ } ++ if (id == null) { ++ throw new IllegalArgumentException("Invalid listener ID: null"); ++ } ++ } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8014093-improve_image_parsing.patch b/java/openjdk6/files/icedtea/openjdk/8014093-improve_image_parsing.patch new file mode 100644 index 000000000000..d0553950951d --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014093-improve_image_parsing.patch @@ -0,0 +1,719 @@ +# HG changeset patch +# User bae +# Date 1368794871 -14400 +# Fri May 17 16:47:51 2013 +0400 +# Node ID 5405d79569f76d1285fd3c840489477a81bd9eff +# Parent a9be60a78488c7b261b92d927d1272afe2484e6b +8014093: Improve parsing of images +Reviewed-by: prr + +diff -r a9be60a78488 -r 5405d79569f7 src/share/native/sun/awt/image/awt_parseImage.c +--- jdk/src/share/native/sun/awt/image/awt_parseImage.c Thu Jun 20 08:51:47 2013 +0200 ++++ jdk/src/share/native/sun/awt/image/awt_parseImage.c Fri May 17 16:47:51 2013 +0400 +@@ -797,363 +797,204 @@ + return 1; + } + +-/* +- * This routine will fill in a buffer of data for either 1 band or all +- * bands (if band == -1). +- */ + #define MAX_TO_GRAB (10240) + +-int awt_getPixelByte(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned char *bufferP) { +- int w = rasterP->width; +- int h = rasterP->height; +- int numBands = rasterP->numBands; ++typedef union { ++ void *pv; ++ unsigned char *pb; ++ unsigned short *ps; ++} PixelData_t; ++ ++ ++int awt_getPixels(JNIEnv *env, RasterS_t *rasterP, void *bufferP) { ++ const int w = rasterP->width; ++ const int h = rasterP->height; ++ const int numBands = rasterP->numBands; + int y; + int i; +- int maxLines = (h < MAX_TO_GRAB/w ? h : MAX_TO_GRAB/w); ++ int maxLines; + jobject jsm; +- int off; ++ int off = 0; + jarray jdata = NULL; + jobject jdatabuffer; + int *dataP; +- int maxBytes = w; ++ int maxSamples; ++ PixelData_t p; ++ ++ if (bufferP == NULL) { ++ return -1; ++ } ++ ++ if (rasterP->dataType != BYTE_DATA_TYPE && ++ rasterP->dataType != SHORT_DATA_TYPE) ++ { ++ return -1; ++ } ++ ++ p.pv = bufferP; ++ ++ if (!SAFE_TO_MULT(w, numBands)) { ++ return -1; ++ } ++ maxSamples = w * numBands; ++ ++ maxLines = maxSamples > MAX_TO_GRAB ? 1 : (MAX_TO_GRAB / maxSamples); ++ if (maxLines > h) { ++ maxLines = h; ++ } ++ ++ if (!SAFE_TO_MULT(maxSamples, maxLines)) { ++ return -1; ++ } ++ ++ maxSamples *= maxLines; + + jsm = (*env)->GetObjectField(env, rasterP->jraster, g_RasterSampleModelID); + jdatabuffer = (*env)->GetObjectField(env, rasterP->jraster, + g_RasterDataBufferID); +- jdata = (*env)->NewIntArray(env, maxBytes*rasterP->numBands*maxLines); ++ ++ jdata = (*env)->NewIntArray(env, maxSamples); + if (JNU_IsNull(env, jdata)) { + JNU_ThrowOutOfMemoryError(env, "Out of Memory"); + return -1; + } + +- /* Here is the generic code */ +- if (band >= 0) { +- int dOff; +- if (band >= numBands) { ++ for (y = 0; y < h; y += maxLines) { ++ if (y + maxLines > h) { ++ maxLines = h - y; ++ maxSamples = w * numBands * maxLines; ++ } ++ ++ (*env)->CallObjectMethod(env, jsm, g_SMGetPixelsMID, ++ 0, y, w, ++ maxLines, jdata, jdatabuffer); ++ ++ if ((*env)->ExceptionOccurred(env)) { + (*env)->DeleteLocalRef(env, jdata); +- JNU_ThrowInternalError(env, "Band out of range."); + return -1; + } +- off = 0; +- for (y=0; y < h; ) { +- (*env)->CallObjectMethod(env, jsm, g_SMGetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- dOff = band; +- for (i=0; i < maxBytes; i++, dOff += numBands) { +- bufferP[off++] = (unsigned char) dataP[dOff]; +- } + +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- +- if (y+maxLines < h) { +- y += maxLines; +- } +- else { +- y++; +- maxBytes = w; +- } +- } +- } +- else { +- off = 0; +- maxBytes *= numBands; +- for (y=0; y < h; ) { +- (*env)->CallObjectMethod(env, jsm, g_SMGetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- for (i=0; i < maxBytes; i++) { +- bufferP[off++] = (unsigned char) dataP[i]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- +- if (y+maxLines < h) { +- y += maxLines; +- } +- else { +- y++; +- maxBytes = w*numBands; +- } ++ dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, ++ NULL); ++ if (dataP == NULL) { ++ (*env)->DeleteLocalRef(env, jdata); ++ return -1; + } + ++ switch (rasterP->dataType) { ++ case BYTE_DATA_TYPE: ++ for (i = 0; i < maxSamples; i ++) { ++ p.pb[off++] = (unsigned char) dataP[i]; ++ } ++ break; ++ case SHORT_DATA_TYPE: ++ for (i = 0; i < maxSamples; i ++) { ++ p.ps[off++] = (unsigned short) dataP[i]; ++ } ++ break; ++ } ++ ++ (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, ++ JNI_ABORT); + } + (*env)->DeleteLocalRef(env, jdata); + +- return 0; ++ return 1; + } +-int awt_setPixelByte(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned char *bufferP) { +- int w = rasterP->width; +- int h = rasterP->height; +- int numBands = rasterP->numBands; ++ ++int awt_setPixels(JNIEnv *env, RasterS_t *rasterP, void *bufferP) { ++ const int w = rasterP->width; ++ const int h = rasterP->height; ++ const int numBands = rasterP->numBands; ++ + int y; + int i; +- int maxLines = (h < MAX_TO_GRAB/w ? h : MAX_TO_GRAB/w); ++ int maxLines; + jobject jsm; +- int off; ++ int off = 0; + jarray jdata = NULL; + jobject jdatabuffer; + int *dataP; +- int maxBytes = w; ++ int maxSamples; ++ PixelData_t p; ++ ++ if (bufferP == NULL) { ++ return -1; ++ } ++ ++ if (rasterP->dataType != BYTE_DATA_TYPE && ++ rasterP->dataType != SHORT_DATA_TYPE) ++ { ++ return -1; ++ } ++ ++ p.pv = bufferP; ++ ++ if (!SAFE_TO_MULT(w, numBands)) { ++ return -1; ++ } ++ maxSamples = w * numBands; ++ ++ maxLines = maxSamples > MAX_TO_GRAB ? 1 : (MAX_TO_GRAB / maxSamples); ++ if (maxLines > h) { ++ maxLines = h; ++ } ++ ++ if (!SAFE_TO_MULT(maxSamples, maxLines)) { ++ return -1; ++ } ++ ++ maxSamples *= maxLines; + + jsm = (*env)->GetObjectField(env, rasterP->jraster, g_RasterSampleModelID); + jdatabuffer = (*env)->GetObjectField(env, rasterP->jraster, + g_RasterDataBufferID); +- /* Here is the generic code */ +- jdata = (*env)->NewIntArray(env, maxBytes*rasterP->numBands*maxLines); ++ ++ jdata = (*env)->NewIntArray(env, maxSamples); + if (JNU_IsNull(env, jdata)) { + JNU_ThrowOutOfMemoryError(env, "Out of Memory"); + return -1; + } +- if (band >= 0) { +- int dOff; +- if (band >= numBands) { ++ ++ for (y = 0; y < h; y += maxLines) { ++ if (y + maxLines > h) { ++ maxLines = h - y; ++ maxSamples = w * numBands * maxLines; ++ } ++ dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, ++ NULL); ++ if (dataP == NULL) { + (*env)->DeleteLocalRef(env, jdata); +- JNU_ThrowInternalError(env, "Band out of range."); + return -1; + } +- off = 0; +- for (y=0; y < h; y+=maxLines) { +- if (y+maxLines > h) { +- maxBytes = w*numBands; +- maxLines = h - y; ++ ++ switch (rasterP->dataType) { ++ case BYTE_DATA_TYPE: ++ for (i = 0; i < maxSamples; i ++) { ++ dataP[i] = p.pb[off++]; + } +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; ++ break; ++ case SHORT_DATA_TYPE: ++ for (i = 0; i < maxSamples; i ++) { ++ dataP[i] = p.ps[off++]; + } +- dOff = band; +- for (i=0; i < maxBytes; i++, dOff += numBands) { +- dataP[dOff] = bufferP[off++]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- +- (*env)->CallVoidMethod(env, jsm, g_SMSetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- } +- } +- else { +- off = 0; +- maxBytes *= numBands; +- for (y=0; y < h; y+=maxLines) { +- if (y+maxLines > h) { +- maxBytes = w*numBands; +- maxLines = h - y; +- } +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- for (i=0; i < maxBytes; i++) { +- dataP[i] = bufferP[off++]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- +- (*env)->CallVoidMethod(env, jsm, g_SMSetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); ++ break; + } + ++ (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, ++ JNI_ABORT); ++ ++ (*env)->CallVoidMethod(env, jsm, g_SMSetPixelsMID, ++ 0, y, w, ++ maxLines, jdata, jdatabuffer); ++ ++ if ((*env)->ExceptionOccurred(env)) { ++ (*env)->DeleteLocalRef(env, jdata); ++ return -1; ++ } + } + + (*env)->DeleteLocalRef(env, jdata); + +- return 0; ++ return 1; + } +-int awt_getPixelShort(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned short *bufferP) { +- int w = rasterP->width; +- int h = rasterP->height; +- int numBands = rasterP->numBands; +- int y; +- int i; +- int maxLines = (h < MAX_TO_GRAB/w ? h : MAX_TO_GRAB/w); +- jobject jsm; +- int off; +- jarray jdata = NULL; +- jobject jdatabuffer; +- int *dataP; +- int maxBytes = w*maxLines; +- +- jsm = (*env)->GetObjectField(env, rasterP->jraster, g_RasterSampleModelID); +- jdatabuffer = (*env)->GetObjectField(env, rasterP->jraster, +- g_RasterDataBufferID); +- jdata = (*env)->NewIntArray(env, maxBytes*rasterP->numBands*maxLines); +- if (JNU_IsNull(env, jdata)) { +- JNU_ThrowOutOfMemoryError(env, "Out of Memory"); +- return -1; +- } +- /* Here is the generic code */ +- if (band >= 0) { +- int dOff; +- if (band >= numBands) { +- (*env)->DeleteLocalRef(env, jdata); +- JNU_ThrowInternalError(env, "Band out of range."); +- return -1; +- } +- off = 0; +- for (y=0; y < h; y += maxLines) { +- if (y+maxLines > h) { +- maxBytes = w*numBands; +- maxLines = h - y; +- } +- (*env)->CallObjectMethod(env, jsm, g_SMGetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- +- dOff = band; +- for (i=0; i < maxBytes; i++, dOff += numBands) { +- bufferP[off++] = (unsigned short) dataP[dOff]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- } +- } +- else { +- off = 0; +- maxBytes *= numBands; +- for (y=0; y < h; y+=maxLines) { +- if (y+maxLines > h) { +- maxBytes = w*numBands; +- maxLines = h - y; +- } +- (*env)->CallObjectMethod(env, jsm, g_SMGetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- for (i=0; i < maxBytes; i++) { +- bufferP[off++] = (unsigned short) dataP[i]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- } +- +- } +- +- (*env)->DeleteLocalRef(env, jdata); +- return 0; +-} +-int awt_setPixelShort(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned short *bufferP) { +- int w = rasterP->width; +- int h = rasterP->height; +- int numBands = rasterP->numBands; +- int y; +- int i; +- int maxLines = (h < MAX_TO_GRAB/w ? h : MAX_TO_GRAB/w); +- jobject jsm; +- int off; +- jarray jdata = NULL; +- jobject jdatabuffer; +- int *dataP; +- int maxBytes = w; +- +- jsm = (*env)->GetObjectField(env, rasterP->jraster, g_RasterSampleModelID); +- jdatabuffer = (*env)->GetObjectField(env, rasterP->jraster, +- g_RasterDataBufferID); +- if (band >= numBands) { +- JNU_ThrowInternalError(env, "Band out of range."); +- return -1; +- } +- /* Here is the generic code */ +- jdata = (*env)->NewIntArray(env, maxBytes*rasterP->numBands*maxLines); +- if (JNU_IsNull(env, jdata)) { +- JNU_ThrowOutOfMemoryError(env, "Out of Memory"); +- return -1; +- } +- if (band >= 0) { +- int dOff; +- off = 0; +- for (y=0; y < h; y+=maxLines) { +- if (y+maxLines > h) { +- maxBytes = w*numBands; +- maxLines = h - y; +- } +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- dOff = band; +- for (i=0; i < maxBytes; i++, dOff += numBands) { +- dataP[dOff] = bufferP[off++]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- +- (*env)->CallVoidMethod(env, jsm, g_SMSetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- } +- } +- else { +- off = 0; +- maxBytes *= numBands; +- for (y=0; y < h; y+=maxLines) { +- if (y+maxLines > h) { +- maxBytes = w*numBands; +- maxLines = h - y; +- } +- dataP = (int *) (*env)->GetPrimitiveArrayCritical(env, jdata, +- NULL); +- if (dataP == NULL) { +- (*env)->DeleteLocalRef(env, jdata); +- return -1; +- } +- for (i=0; i < maxBytes; i++) { +- dataP[i] = bufferP[off++]; +- } +- +- (*env)->ReleasePrimitiveArrayCritical(env, jdata, dataP, +- JNI_ABORT); +- +- (*env)->CallVoidMethod(env, jsm, g_SMSetPixelsMID, +- 0, y, w, +- maxLines, jdata, jdatabuffer); +- } +- +- } +- +- (*env)->DeleteLocalRef(env, jdata); +- return 0; +-} +diff -r a9be60a78488 -r 5405d79569f7 src/share/native/sun/awt/image/awt_parseImage.h +--- jdk/src/share/native/sun/awt/image/awt_parseImage.h Thu Jun 20 08:51:47 2013 +0200 ++++ jdk/src/share/native/sun/awt/image/awt_parseImage.h Fri May 17 16:47:51 2013 +0400 +@@ -188,13 +188,8 @@ + + void awt_freeParsedImage(BufImageS_t *imageP, int freeImageP); + +-int awt_getPixelByte(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned char *bufferP); +-int awt_setPixelByte(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned char *bufferP); +-int awt_getPixelShort(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned short *bufferP); +-int awt_setPixelShort(JNIEnv *env, int band, RasterS_t *rasterP, +- unsigned short *bufferP); ++int awt_getPixels(JNIEnv *env, RasterS_t *rasterP, void *bufferP); ++ ++int awt_setPixels(JNIEnv *env, RasterS_t *rasterP, void *bufferP); + + #endif /* AWT_PARSE_IMAGE_H */ +diff -r a9be60a78488 -r 5405d79569f7 src/share/native/sun/awt/medialib/awt_ImagingLib.c +--- jdk/src/share/native/sun/awt/medialib/awt_ImagingLib.c Thu Jun 20 08:51:47 2013 +0200 ++++ jdk/src/share/native/sun/awt/medialib/awt_ImagingLib.c Fri May 17 16:47:51 2013 +0400 +@@ -700,22 +700,7 @@ + + /* Means that we couldn't write directly into the destination buffer */ + if (ddata == NULL) { +- unsigned char *bdataP; +- unsigned short *sdataP; +- +- /* Punt for now */ +- switch (dstRasterP->dataType) { +- case BYTE_DATA_TYPE: +- bdataP = (unsigned char *) mlib_ImageGetData(dst); +- retStatus = (awt_setPixelByte(env, -1, dstRasterP, bdataP) >= 0) ; +- break; +- case SHORT_DATA_TYPE: +- sdataP = (unsigned short *) mlib_ImageGetData(dst); +- retStatus = (awt_setPixelShort(env, -1, dstRasterP, sdataP) >= 0) ; +- break; +- default: +- retStatus = 0; +- } ++ retStatus = awt_setPixels(env, dstRasterP, mlib_ImageGetData(dst)); + } + + /* Release the pinned memory */ +@@ -1119,24 +1104,9 @@ + + /* Means that we couldn't write directly into the destination buffer */ + if (ddata == NULL) { +- unsigned char *bdataP; +- unsigned short *sdataP; +- + /* Need to store it back into the array */ + if (storeRasterArray(env, srcRasterP, dstRasterP, dst) < 0) { +- /* Punt for now */ +- switch (dst->type) { +- case MLIB_BYTE: +- bdataP = (unsigned char *) mlib_ImageGetData(dst); +- retStatus = (awt_setPixelByte(env, -1, dstRasterP, bdataP) >= 0) ; +- break; +- case MLIB_SHORT: +- sdataP = (unsigned short *) mlib_ImageGetData(dst); +- retStatus = (awt_setPixelShort(env, -1, dstRasterP, sdataP) >= 0) ; +- break; +- default: +- retStatus = 0; +- } ++ retStatus = awt_setPixels(env, dstRasterP, mlib_ImageGetData(dst)); + } + } + +@@ -1705,21 +1675,7 @@ + * the destination buffer + */ + if (ddata == NULL) { +- unsigned char* bdataP; +- unsigned short* sdataP; +- +- switch (dstRasterP->dataType) { +- case BYTE_DATA_TYPE: +- bdataP = (unsigned char *) mlib_ImageGetData(dst); +- retStatus = (awt_setPixelByte(env, -1, dstRasterP, bdataP) >= 0) ; +- break; +- case SHORT_DATA_TYPE: +- sdataP = (unsigned short *) mlib_ImageGetData(dst); +- retStatus = (awt_setPixelShort(env, -1, dstRasterP, sdataP) >= 0) ; +- break; +- default: +- retStatus = 0; +- } ++ retStatus = awt_setPixels(env, dstRasterP, mlib_ImageGetData(dst)); + } + + /* Release the LUT */ +@@ -2299,7 +2255,6 @@ + mlib_image **mlibImagePP, void **dataPP, int isSrc) { + void *dataP; + unsigned char *cDataP; +- unsigned short *sdataP; + int dataType = BYTE_DATA_TYPE; + int width; + int height; +@@ -2485,8 +2440,7 @@ + return -1; + } + if (isSrc) { +- cDataP = (unsigned char *) mlib_ImageGetData(*mlibImagePP); +- if (awt_getPixelByte(env, -1, rasterP, cDataP) < 0) { ++ if (awt_getPixels(env, rasterP, mlib_ImageGetData(*mlibImagePP)) < 0) { + (*sMlibSysFns.deleteImageFP)(*mlibImagePP); + return -1; + } +@@ -2500,8 +2454,7 @@ + return -1; + } + if (isSrc) { +- sdataP = (unsigned short *) mlib_ImageGetData(*mlibImagePP); +- if (awt_getPixelShort(env, -1, rasterP, sdataP) < 0) { ++ if (awt_getPixels(env, rasterP, mlib_ImageGetData(*mlibImagePP)) < 0) { + (*sMlibSysFns.deleteImageFP)(*mlibImagePP); + return -1; + } +@@ -2551,60 +2504,6 @@ + } + } + +-static int +-storeDstArray(JNIEnv *env, BufImageS_t *srcP, BufImageS_t *dstP, +- mlibHintS_t *hintP, mlib_image *mlibImP, void *ddata) { +- RasterS_t *rasterP = &dstP->raster; +- +- /* Nothing to do since it is the same image type */ +- if (srcP->imageType == dstP->imageType +- && srcP->imageType != java_awt_image_BufferedImage_TYPE_CUSTOM +- && srcP->imageType != java_awt_image_BufferedImage_TYPE_BYTE_INDEXED +- && srcP->imageType != java_awt_image_BufferedImage_TYPE_BYTE_BINARY) { +- /* REMIND: Should check the ICM LUTS to see if it is the same */ +- return 0; +- } +- +- /* These types are compatible with TYPE_INT_RGB */ +- if (srcP->imageType == java_awt_image_BufferedImage_TYPE_INT_RGB +- && (dstP->imageType == java_awt_image_BufferedImage_TYPE_INT_ARGB || +- dstP->imageType == java_awt_image_BufferedImage_TYPE_INT_ARGB_PRE)){ +- return 0; +- } +- +- if (hintP->cvtSrcToDefault && +- (srcP->cmodel.isAlphaPre == dstP->cmodel.isAlphaPre)) { +- if (srcP->cmodel.isAlphaPre) { +- if (dstP->imageType == +- java_awt_image_BufferedImage_TYPE_INT_ARGB_PRE) +- { +- return 0; +- } +- if (!srcP->cmodel.supportsAlpha && +- dstP->imageType == java_awt_image_BufferedImage_TYPE_INT_RGB){ +- return 0; +- } +- } +- else { +- /* REMIND: */ +- } +- } +- +- if (dstP->cmodel.cmType == DIRECT_CM_TYPE) { +- /* Just need to move bits */ +- if (mlibImP->type == MLIB_BYTE) { +- return awt_setPixelByte(env, -1, &dstP->raster, +- (unsigned char *) mlibImP->data); +- } +- else if (mlibImP->type == MLIB_SHORT) { +- return awt_setPixelByte(env, -1, &dstP->raster, +- (unsigned char *) mlibImP->data); +- } +- } +- +- return 0; +-} +- + #define ERR_BAD_IMAGE_LAYOUT (-2) + + #define CHECK_DST_ARRAY(start_offset, elements_per_pixel) \ +@@ -2717,8 +2616,7 @@ + } + } + else if (mlibImP->type == MLIB_SHORT) { +- return awt_setPixelShort(env, -1, rasterP, +- (unsigned short *) mlibImP->data); ++ return awt_setPixels(env, rasterP, mlibImP->data); + } + } + else { diff --git a/java/openjdk6/files/icedtea/openjdk/8014102-improve_image_conversion.patch b/java/openjdk6/files/icedtea/openjdk/8014102-improve_image_conversion.patch new file mode 100644 index 000000000000..d49c301836ea --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014102-improve_image_conversion.patch @@ -0,0 +1,190 @@ +# HG changeset patch +# User bae +# Date 1369130199 -14400 +# Tue May 21 13:56:39 2013 +0400 +# Node ID d55d40616754cd93aa396719ddfd81bae584d4f0 +# Parent 5405d79569f76d1285fd3c840489477a81bd9eff +8014102: Improve image conversion +Reviewed-by: prr + +diff -r 5405d79569f7 -r d55d40616754 src/share/native/sun/awt/medialib/awt_ImagingLib.c +--- jdk/src/share/native/sun/awt/medialib/awt_ImagingLib.c Fri May 17 16:47:51 2013 +0400 ++++ jdk/src/share/native/sun/awt/medialib/awt_ImagingLib.c Tue May 21 13:56:39 2013 +0400 +@@ -1986,21 +1986,25 @@ + return 0; + } + ++#define NUM_LINES 10 ++ + static int + cvtCustomToDefault(JNIEnv *env, BufImageS_t *imageP, int component, + unsigned char *dataP) { +- ColorModelS_t *cmP = &imageP->cmodel; +- RasterS_t *rasterP = &imageP->raster; ++ const RasterS_t *rasterP = &imageP->raster; ++ const int w = rasterP->width; ++ const int h = rasterP->height; ++ + int y; +- jobject jpixels = NULL; ++ jintArray jpixels = NULL; + jint *pixels; + unsigned char *dP = dataP; +-#define NUM_LINES 10 +- int numLines = NUM_LINES; ++ int numLines = h > NUM_LINES ? NUM_LINES : h; ++ + /* it is safe to calculate the scan length, because width has been verified + * on creation of the mlib image + */ +- int scanLength = rasterP->width * 4; ++ const int scanLength = w * 4; + + int nbytes = 0; + if (!SAFE_TO_MULT(numLines, scanLength)) { +@@ -2009,71 +2013,99 @@ + + nbytes = numLines * scanLength; + +- for (y=0; y < rasterP->height; y+=numLines) { +- /* getData, one scanline at a time */ +- if (y+numLines > rasterP->height) { +- numLines = rasterP->height - y; +- nbytes = numLines * scanLength; +- } +- jpixels = (*env)->CallObjectMethod(env, imageP->jimage, +- g_BImgGetRGBMID, 0, y, +- rasterP->width, numLines, +- jpixels,0, rasterP->width); +- if (jpixels == NULL) { +- JNU_ThrowInternalError(env, "Can't retrieve pixels."); +- return -1; +- } +- +- pixels = (*env)->GetPrimitiveArrayCritical(env, jpixels, NULL); +- memcpy(dP, pixels, nbytes); +- dP += nbytes; +- (*env)->ReleasePrimitiveArrayCritical(env, jpixels, pixels, +- JNI_ABORT); +- } +- return 0; +-} +- +-static int +-cvtDefaultToCustom(JNIEnv *env, BufImageS_t *imageP, int component, +- unsigned char *dataP) { +- ColorModelS_t *cmP = &imageP->cmodel; +- RasterS_t *rasterP = &imageP->raster; +- int y; +- jint *pixels; +- unsigned char *dP = dataP; +-#define NUM_LINES 10 +- int numLines = NUM_LINES; +- int nbytes = rasterP->width*4*NUM_LINES; +- jintArray jpixels; +- + jpixels = (*env)->NewIntArray(env, nbytes); + if (JNU_IsNull(env, jpixels)) { + JNU_ThrowOutOfMemoryError(env, "Out of Memory"); + return -1; + } + +- for (y=0; y < rasterP->height; y+=NUM_LINES) { +- if (y+numLines > rasterP->height) { +- numLines = rasterP->height - y; +- nbytes = rasterP->width*4*numLines; ++ for (y = 0; y < h; y += numLines) { ++ if (y + numLines > h) { ++ numLines = h - y; ++ nbytes = numLines * scanLength; + } ++ ++ (*env)->CallObjectMethod(env, imageP->jimage, ++ g_BImgGetRGBMID, 0, y, ++ w, numLines, ++ jpixels, 0, w); ++ if ((*env)->ExceptionOccurred(env)) { ++ (*env)->DeleteLocalRef(env, jpixels); ++ return -1; ++ } ++ + pixels = (*env)->GetPrimitiveArrayCritical(env, jpixels, NULL); + if (pixels == NULL) { +- /* JNI error */ ++ (*env)->DeleteLocalRef(env, jpixels); + return -1; + } + ++ memcpy(dP, pixels, nbytes); ++ dP += nbytes; ++ ++ (*env)->ReleasePrimitiveArrayCritical(env, jpixels, pixels, ++ JNI_ABORT); ++ } ++ ++ /* Need to release the array */ ++ (*env)->DeleteLocalRef(env, jpixels); ++ ++ return 0; ++} ++ ++static int ++cvtDefaultToCustom(JNIEnv *env, BufImageS_t *imageP, int component, ++ unsigned char *dataP) { ++ const RasterS_t *rasterP = &imageP->raster; ++ const int w = rasterP->width; ++ const int h = rasterP->height; ++ ++ int y; ++ jintArray jpixels = NULL; ++ jint *pixels; ++ unsigned char *dP = dataP; ++ int numLines = h > NUM_LINES ? NUM_LINES : h; ++ ++ /* it is safe to calculate the scan length, because width has been verified ++ * on creation of the mlib image ++ */ ++ const int scanLength = w * 4; ++ ++ int nbytes = 0; ++ if (!SAFE_TO_MULT(numLines, scanLength)) { ++ return -1; ++ } ++ ++ nbytes = numLines * scanLength; ++ ++ jpixels = (*env)->NewIntArray(env, nbytes); ++ if (JNU_IsNull(env, jpixels)) { ++ JNU_ThrowOutOfMemoryError(env, "Out of Memory"); ++ return -1; ++ } ++ ++ for (y = 0; y < h; y += numLines) { ++ if (y + numLines > h) { ++ numLines = h - y; ++ nbytes = numLines * scanLength; ++ } ++ ++ pixels = (*env)->GetPrimitiveArrayCritical(env, jpixels, NULL); ++ if (pixels == NULL) { ++ (*env)->DeleteLocalRef(env, jpixels); ++ return -1; ++ } ++ + memcpy(pixels, dP, nbytes); + dP += nbytes; + + (*env)->ReleasePrimitiveArrayCritical(env, jpixels, pixels, 0); + +- /* setData, one scanline at a time */ +- /* Fix 4223648, 4184283 */ + (*env)->CallVoidMethod(env, imageP->jimage, g_BImgSetRGBMID, 0, y, +- rasterP->width, numLines, jpixels, 0, +- rasterP->width); ++ w, numLines, jpixels, ++ 0, w); + if ((*env)->ExceptionOccurred(env)) { ++ (*env)->DeleteLocalRef(env, jpixels); + return -1; + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8014341-better_kerberos_service.patch b/java/openjdk6/files/icedtea/openjdk/8014341-better_kerberos_service.patch new file mode 100644 index 000000000000..b1b3edc3ee1e --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014341-better_kerberos_service.patch @@ -0,0 +1,66 @@ +# HG changeset patch +# User weijun +# Date 1381852916 -3600 +# Tue Oct 15 17:01:56 2013 +0100 +# Node ID 698fe468e8b9385c2f74709dca823800b32e0b55 +# Parent d55d40616754cd93aa396719ddfd81bae584d4f0 +8014341: Better service from Kerberos servers +Summary: read incoming data safely and take care of null return value +Reviewed-by: valeriep, ahgross + +diff -r d55d40616754 -r 698fe468e8b9 src/share/classes/sun/security/krb5/KrbKdcReq.java +--- jdk/src/share/classes/sun/security/krb5/KrbKdcReq.java Tue May 21 13:56:39 2013 +0400 ++++ jdk/src/share/classes/sun/security/krb5/KrbKdcReq.java Tue Oct 15 17:01:56 2013 +0100 +@@ -151,11 +151,15 @@ + savedException = e; + } + } +- if (ibuf == null && savedException != null) { +- if (savedException instanceof IOException) { +- throw (IOException) savedException; ++ if (ibuf == null) { ++ if (savedException != null) { ++ if (savedException instanceof IOException) { ++ throw (IOException) savedException; ++ } else { ++ throw (KrbException) savedException; ++ } + } else { +- throw (KrbException) savedException; ++ throw new IOException("Cannot get a KDC reply"); + } + } + return tempKdc; +diff -r d55d40616754 -r 698fe468e8b9 src/share/classes/sun/security/krb5/internal/TCPClient.java +--- jdk/src/share/classes/sun/security/krb5/internal/TCPClient.java Tue May 21 13:56:39 2013 +0400 ++++ jdk/src/share/classes/sun/security/krb5/internal/TCPClient.java Tue Oct 15 17:01:56 2013 +0100 +@@ -30,6 +30,8 @@ + + package sun.security.krb5.internal; + ++import sun.misc.IOUtils; ++ + import java.io.*; + import java.net.*; + +@@ -79,17 +81,15 @@ + return null; + } + +- byte data[] = new byte[len]; +- count = readFully(data, len); +- if (count != len) { ++ try { ++ return IOUtils.readFully(in, len, true); ++ } catch (IOException ioe) { + if (Krb5.DEBUG) { + System.out.println( + ">>>DEBUG: TCPClient could not read complete packet (" + + len + "/" + count + ")"); + } + return null; +- } else { +- return data; + } + } + diff --git a/java/openjdk6/files/icedtea/openjdk/8014349-getdeclaredclass_fix.patch b/java/openjdk6/files/icedtea/openjdk/8014349-getdeclaredclass_fix.patch new file mode 100644 index 000000000000..acf725339cf3 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014349-getdeclaredclass_fix.patch @@ -0,0 +1,43 @@ +# HG changeset patch +# User jfranck +# Date 1382996803 0 +# Mon Oct 28 21:46:43 2013 +0000 +# Node ID e5a4a4ec7b21f3d092d0b29024ff903864d05543 +# Parent 42fd9f22ae5e9aea017af28a2b5ff7a498753e15 +8014349: (cl) Class.getDeclaredClass problematic in some class loader configurations +Reviewed-by: mchung, ahgross, darcy + +diff -r 42fd9f22ae5e -r e5a4a4ec7b21 src/share/classes/java/lang/Class.java +--- jdk/src/share/classes/java/lang/Class.java Mon Oct 28 20:09:40 2013 +0000 ++++ jdk/src/share/classes/java/lang/Class.java Mon Oct 28 21:46:43 2013 +0000 +@@ -1093,7 +1093,17 @@ + * @return the declaring class for this class + * @since JDK1.1 + */ +- public native Class<?> getDeclaringClass(); ++ @CallerSensitive ++ public Class<?> getDeclaringClass() { ++ final Class<?> candidate = getDeclaringClass0(); ++ ++ if (candidate != null) ++ candidate.checkPackageAccess( ++ ClassLoader.getClassLoader(Reflection.getCallerClass()), true); ++ return candidate; ++ } ++ ++ private native Class<?> getDeclaringClass0(); + + + /** +diff -r 42fd9f22ae5e -r e5a4a4ec7b21 src/share/native/java/lang/Class.c +--- jdk/src/share/native/java/lang/Class.c Mon Oct 28 20:09:40 2013 +0000 ++++ jdk/src/share/native/java/lang/Class.c Mon Oct 28 21:46:43 2013 +0000 +@@ -70,7 +70,7 @@ + {"getProtectionDomain0", "()" PD, (void *)&JVM_GetProtectionDomain}, + {"setProtectionDomain0", "(" PD ")V", (void *)&JVM_SetProtectionDomain}, + {"getDeclaredClasses0", "()[" CLS, (void *)&JVM_GetDeclaredClasses}, +- {"getDeclaringClass", "()" CLS, (void *)&JVM_GetDeclaringClass}, ++ {"getDeclaringClass0", "()" CLS, (void *)&JVM_GetDeclaringClass}, + {"getGenericSignature", "()" STR, (void *)&JVM_GetClassSignature}, + {"getRawAnnotations", "()" BA, (void *)&JVM_GetClassAnnotations}, + {"getConstantPool", "()" CPL, (void *)&JVM_GetClassConstantPool}, diff --git a/java/openjdk6/files/icedtea/openjdk/8014530-better_dsp.patch b/java/openjdk6/files/icedtea/openjdk/8014530-better_dsp.patch new file mode 100644 index 000000000000..bcda8c52a4b4 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014530-better_dsp.patch @@ -0,0 +1,3121 @@ +# HG changeset patch +# User joehw +# Date 1383033689 0 +# Tue Oct 29 08:01:29 2013 +0000 +# Node ID 0927621944ccb163d7dcdea7b94b10dfab58f5f1 +# Parent 3dc769c632a1d6a8f69d2857b3c13c43a83481be +8014530: Better digital signature processing +Reviewed-by: alanb, dfuchs, mullan, lancea + +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/XalanConstants.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/XalanConstants.java Tue Oct 29 08:01:29 2013 +0000 +@@ -0,0 +1,151 @@ ++/* ++ * Copyright (c) 2011 Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. Oracle designates this ++ * particular file as subject to the "Classpath" exception as provided ++ * by Oracle in the LICENSE file that accompanied this code. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++package com.sun.org.apache.xalan.internal; ++ ++import com.sun.org.apache.xerces.internal.impl.*; ++ ++/** ++ * Commonly used constants. ++ * ++ * @author Huizhe Wang, Oracle ++ * ++ * @version $Id: Constants.java,v 1.14 2011-06-07 04:39:40 joehw Exp $ ++ */ ++public final class XalanConstants { ++ ++ // ++ // Constants ++ //Xerces security manager ++ public static final String SECURITY_MANAGER = ++ "http://apache.org/xml/properties/security-manager"; ++ ++ // ++ // Implementation limits: API properties ++ // ++ /** Oracle JAXP property prefix ("http://www.oracle.com/xml/jaxp/properties/"). */ ++ public static final String ORACLE_JAXP_PROPERTY_PREFIX = ++ "http://www.oracle.com/xml/jaxp/properties/"; ++ /** ++ * JDK entity expansion limit; Note that the existing system property ++ * "entityExpansionLimit" with no prefix is still observed ++ */ ++ public static final String JDK_ENTITY_EXPANSION_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "entityExpansionLimit"; ++ ++ /** ++ * JDK element attribute limit; Note that the existing system property ++ * "elementAttributeLimit" with no prefix is still observed ++ */ ++ public static final String JDK_ELEMENT_ATTRIBUTE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "elementAttributeLimit"; ++ ++ /** ++ * JDK maxOccur limit; Note that the existing system property ++ * "maxOccurLimit" with no prefix is still observed ++ */ ++ public static final String JDK_MAX_OCCUR_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxOccurLimit"; ++ ++ /** ++ * JDK total entity size limit ++ */ ++ public static final String JDK_TOTAL_ENTITY_SIZE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "totalEntitySizeLimit"; ++ ++ /** ++ * JDK maximum general entity size limit ++ */ ++ public static final String JDK_GENEAL_ENTITY_SIZE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxGeneralEntitySizeLimit"; ++ /** ++ * JDK maximum parameter entity size limit ++ */ ++ public static final String JDK_PARAMETER_ENTITY_SIZE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxParameterEntitySizeLimit"; ++ /** ++ * JDK maximum XML name limit ++ */ ++ public static final String JDK_XML_NAME_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxXMLNameLimit"; ++ /** ++ * JDK property indicating whether the parser shall print out entity ++ * count information ++ * Value: a string "yes" means print, "no" or any other string means not. ++ */ ++ public static final String JDK_ENTITY_COUNT_INFO = ++ ORACLE_JAXP_PROPERTY_PREFIX + "getEntityCountInfo"; ++ ++ // ++ // Implementation limits: corresponding System Properties of the above ++ // API properties ++ // ++ /** ++ * JDK entity expansion limit; Note that the existing system property ++ * "entityExpansionLimit" with no prefix is still observed ++ */ ++ public static final String SP_ENTITY_EXPANSION_LIMIT = "jdk.xml.entityExpansionLimit"; ++ ++ /** ++ * JDK element attribute limit; Note that the existing system property ++ * "elementAttributeLimit" with no prefix is still observed ++ */ ++ public static final String SP_ELEMENT_ATTRIBUTE_LIMIT = "jdk.xml.elementAttributeLimit"; ++ ++ /** ++ * JDK maxOccur limit; Note that the existing system property ++ * "maxOccurLimit" with no prefix is still observed ++ */ ++ public static final String SP_MAX_OCCUR_LIMIT = "jdk.xml.maxOccurLimit"; ++ ++ /** ++ * JDK total entity size limit ++ */ ++ public static final String SP_TOTAL_ENTITY_SIZE_LIMIT = "jdk.xml.totalEntitySizeLimit"; ++ ++ /** ++ * JDK maximum general entity size limit ++ */ ++ public static final String SP_GENEAL_ENTITY_SIZE_LIMIT = "jdk.xml.maxGeneralEntitySizeLimit"; ++ /** ++ * JDK maximum parameter entity size limit ++ */ ++ public static final String SP_PARAMETER_ENTITY_SIZE_LIMIT = "jdk.xml.maxParameterEntitySizeLimit"; ++ /** ++ * JDK maximum XML name limit ++ */ ++ public static final String SP_XML_NAME_LIMIT = "jdk.xml.maxXMLNameLimit"; ++ ++ //legacy System Properties ++ public final static String ENTITY_EXPANSION_LIMIT = "entityExpansionLimit"; ++ public static final String ELEMENT_ATTRIBUTE_LIMIT = "elementAttributeLimit" ; ++ public final static String MAX_OCCUR_LIMIT = "maxOccurLimit"; ++ ++ /** ++ * A string "yes" that can be used for properties such as getEntityCountInfo ++ */ ++ public static final String JDK_YES = "yes"; ++} ++ +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/utils/SecuritySupport.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/utils/SecuritySupport.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/utils/SecuritySupport.java Tue Oct 29 08:01:29 2013 +0000 +@@ -26,6 +26,7 @@ + import java.io.File; + import java.io.FileInputStream; + import java.io.FileNotFoundException; ++import java.io.IOException; + import java.io.InputStream; + + import java.security.AccessController; +@@ -36,6 +37,7 @@ + import java.util.Locale; + import java.util.MissingResourceException; + import java.util.ResourceBundle; ++import java.util.Properties; + + /** + * This class is duplicated for each subpackage so keep it in sync. It is +@@ -200,6 +202,54 @@ + })).longValue(); + } + ++ /** ++ * Read from $java.home/lib/jaxp.properties for the specified property ++ * The program ++ * ++ * @param propertyId the Id of the property ++ * @return the value of the property ++ */ ++ static String readJAXPProperty(String propertyId) { ++ String value = null; ++ InputStream is = null; ++ try { ++ if (firstTime) { ++ synchronized (cacheProps) { ++ if (firstTime) { ++ String configFile = getSystemProperty("java.home") + File.separator + ++ "lib" + File.separator + "jaxp.properties"; ++ File f = new File(configFile); ++ if (getFileExists(f)) { ++ is = getFileInputStream(f); ++ cacheProps.load(is); ++ } ++ firstTime = false; ++ } ++ } ++ } ++ value = cacheProps.getProperty(propertyId); ++ ++ } ++ catch (Exception ex) {} ++ finally { ++ if (is != null) { ++ try { ++ is.close(); ++ } catch (IOException ex) {} ++ } ++ } ++ return value; ++ } ++ ++ /** ++ * Cache for properties in java.home/lib/jaxp.properties ++ */ ++ static final Properties cacheProps = new Properties(); ++ ++ /** ++ * Flag indicating if the program has tried reading java.home/lib/jaxp.properties ++ */ ++ static volatile boolean firstTime = true; + + private SecuritySupport() { + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/utils/XMLSecurityManager.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/utils/XMLSecurityManager.java Tue Oct 29 08:01:29 2013 +0000 +@@ -0,0 +1,449 @@ ++/* ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. ++ * ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * ++ * The contents of this file are subject to the terms of either the GNU ++ * General Public License Version 2 only ("GPL") or the Common Development ++ * and Distribution License("CDDL") (collectively, the "License"). You ++ * may not use this file except in compliance with the License. You can ++ * obtain a copy of the License at ++ * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html ++ * or packager/legal/LICENSE.txt. See the License for the specific ++ * language governing permissions and limitations under the License. ++ * ++ * When distributing the software, include this License Header Notice in each ++ * file and include the License file at packager/legal/LICENSE.txt. ++ * ++ * GPL Classpath Exception: ++ * Oracle designates this particular file as subject to the "Classpath" ++ * exception as provided by Oracle in the GPL Version 2 section of the License ++ * file that accompanied this code. ++ * ++ * Modifications: ++ * If applicable, add the following below the License Header, with the fields ++ * enclosed by brackets [] replaced by your own identifying information: ++ * "Portions Copyright [year] [name of copyright owner]" ++ * ++ * Contributor(s): ++ * If you wish your version of this file to be governed by only the CDDL or ++ * only the GPL Version 2, indicate your decision by adding "[Contributor] ++ * elects to include this software in this distribution under the [CDDL or GPL ++ * Version 2] license." If you don't indicate a single choice of license, a ++ * recipient has the option to distribute your version of this file under ++ * either the CDDL, the GPL Version 2 or to extend the choice of license to ++ * its licensees as provided above. However, if you add GPL Version 2 code ++ * and therefore, elected the GPL Version 2 license, then the option applies ++ * only if the new code is made subject to such option by the copyright ++ * holder. ++ */ ++package com.sun.org.apache.xalan.internal.utils; ++ ++import com.sun.org.apache.xalan.internal.XalanConstants; ++ ++ ++/** ++ * This class is not the same as that in Xerces. It is used to manage the ++ * state of corresponding Xerces properties and pass the values over to ++ * the Xerces Security Manager. ++ * ++ * @author Joe Wang Oracle Corp. ++ * ++ */ ++public final class XMLSecurityManager { ++ ++ /** ++ * States of the settings of a property, in the order: default value, value ++ * set by FEATURE_SECURE_PROCESSING, jaxp.properties file, jaxp system ++ * properties, and jaxp api properties ++ */ ++ public static enum State { ++ //this order reflects the overriding order ++ ++ DEFAULT("default"), FSP("FEATURE_SECURE_PROCESSING"), ++ JAXPDOTPROPERTIES("jaxp.properties"), SYSTEMPROPERTY("system property"), ++ APIPROPERTY("property"); ++ ++ final String literal; ++ State(String literal) { ++ this.literal = literal; ++ } ++ ++ String literal() { ++ return literal; ++ } ++ } ++ ++ /** ++ * Limits managed by the security manager ++ */ ++ public static enum Limit { ++ ++ ENTITY_EXPANSION_LIMIT(XalanConstants.JDK_ENTITY_EXPANSION_LIMIT, ++ XalanConstants.SP_ENTITY_EXPANSION_LIMIT, 0, 64000), ++ MAX_OCCUR_NODE_LIMIT(XalanConstants.JDK_MAX_OCCUR_LIMIT, ++ XalanConstants.SP_MAX_OCCUR_LIMIT, 0, 5000), ++ ELEMENT_ATTRIBUTE_LIMIT(XalanConstants.JDK_ELEMENT_ATTRIBUTE_LIMIT, ++ XalanConstants.SP_ELEMENT_ATTRIBUTE_LIMIT, 0, 10000), ++ TOTAL_ENTITY_SIZE_LIMIT(XalanConstants.JDK_TOTAL_ENTITY_SIZE_LIMIT, ++ XalanConstants.SP_TOTAL_ENTITY_SIZE_LIMIT, 0, 50000000), ++ GENEAL_ENTITY_SIZE_LIMIT(XalanConstants.JDK_GENEAL_ENTITY_SIZE_LIMIT, ++ XalanConstants.SP_GENEAL_ENTITY_SIZE_LIMIT, 0, 0), ++ PARAMETER_ENTITY_SIZE_LIMIT(XalanConstants.JDK_PARAMETER_ENTITY_SIZE_LIMIT, ++ XalanConstants.SP_PARAMETER_ENTITY_SIZE_LIMIT, 0, 1000000); ++ ++ final String apiProperty; ++ final String systemProperty; ++ final int defaultValue; ++ final int secureValue; ++ ++ Limit(String apiProperty, String systemProperty, int value, int secureValue) { ++ this.apiProperty = apiProperty; ++ this.systemProperty = systemProperty; ++ this.defaultValue = value; ++ this.secureValue = secureValue; ++ } ++ ++ public boolean equalsAPIPropertyName(String propertyName) { ++ return (propertyName == null) ? false : apiProperty.equals(propertyName); ++ } ++ ++ public boolean equalsSystemPropertyName(String propertyName) { ++ return (propertyName == null) ? false : systemProperty.equals(propertyName); ++ } ++ ++ public String apiProperty() { ++ return apiProperty; ++ } ++ ++ String systemProperty() { ++ return systemProperty; ++ } ++ ++ int defaultValue() { ++ return defaultValue; ++ } ++ ++ int secureValue() { ++ return secureValue; ++ } ++ } ++ ++ /** ++ * Map old property names with the new ones ++ */ ++ public static enum NameMap { ++ ++ ENTITY_EXPANSION_LIMIT(XalanConstants.SP_ENTITY_EXPANSION_LIMIT, ++ XalanConstants.ENTITY_EXPANSION_LIMIT), ++ MAX_OCCUR_NODE_LIMIT(XalanConstants.SP_MAX_OCCUR_LIMIT, ++ XalanConstants.MAX_OCCUR_LIMIT), ++ ELEMENT_ATTRIBUTE_LIMIT(XalanConstants.SP_ELEMENT_ATTRIBUTE_LIMIT, ++ XalanConstants.ELEMENT_ATTRIBUTE_LIMIT); ++ final String newName; ++ final String oldName; ++ ++ NameMap(String newName, String oldName) { ++ this.newName = newName; ++ this.oldName = oldName; ++ } ++ ++ String getOldName(String newName) { ++ if (newName.equals(this.newName)) { ++ return oldName; ++ } ++ return null; ++ } ++ } ++ /** ++ * Values of the properties ++ */ ++ private final int[] values; ++ /** ++ * States of the settings for each property ++ */ ++ private State[] states; ++ /** ++ * States that determine if properties are set explicitly ++ */ ++ private boolean[] isSet; ++ ++ ++ /** ++ * Index of the special entityCountInfo property ++ */ ++ private int indexEntityCountInfo = 10000; ++ private String printEntityCountInfo = ""; ++ ++ /** ++ * Default constructor. Establishes default values for known security ++ * vulnerabilities. ++ */ ++ public XMLSecurityManager() { ++ this(false); ++ } ++ ++ /** ++ * Instantiate Security Manager in accordance with the status of ++ * secure processing ++ * @param secureProcessing ++ */ ++ public XMLSecurityManager(boolean secureProcessing) { ++ values = new int[Limit.values().length]; ++ states = new State[Limit.values().length]; ++ isSet = new boolean[Limit.values().length]; ++ for (Limit limit : Limit.values()) { ++ if (secureProcessing) { ++ values[limit.ordinal()] = limit.secureValue(); ++ states[limit.ordinal()] = State.FSP; ++ } else { ++ values[limit.ordinal()] = limit.defaultValue(); ++ states[limit.ordinal()] = State.DEFAULT; ++ } ++ } ++ //read system properties or jaxp.properties ++ readSystemProperties(); ++ } ++ ++ /** ++ * Setting FEATURE_SECURE_PROCESSING explicitly ++ */ ++ public void setSecureProcessing(boolean secure) { ++ for (Limit limit : Limit.values()) { ++ if (secure) { ++ setLimit(limit.ordinal(), State.FSP, limit.secureValue()); ++ } else { ++ setLimit(limit.ordinal(), State.FSP, limit.defaultValue()); ++ } ++ } ++ } ++ ++ /** ++ * Set limit by property name and state ++ * @param propertyName property name ++ * @param state the state of the property ++ * @param value the value of the property ++ * @return true if the property is managed by the security manager; false ++ * if otherwise. ++ */ ++ public boolean setLimit(String propertyName, State state, Object value) { ++ int index = getIndex(propertyName); ++ if (index > -1) { ++ setLimit(index, state, value); ++ return true; ++ } ++ return false; ++ } ++ ++ /** ++ * Set the value for a specific limit. ++ * ++ * @param limit the limit ++ * @param state the state of the property ++ * @param value the value of the property ++ */ ++ public void setLimit(Limit limit, State state, int value) { ++ setLimit(limit.ordinal(), state, value); ++ } ++ ++ /** ++ * Set the value of a property by its index ++ * ++ * @param index the index of the property ++ * @param state the state of the property ++ * @param value the value of the property ++ */ ++ public void setLimit(int index, State state, Object value) { ++ if (index == indexEntityCountInfo) { ++ //if it's explicitly set, it's treated as yes no matter the value ++ printEntityCountInfo = (String)value; ++ } else { ++ int temp = 0; ++ try { ++ temp = Integer.parseInt((String) value); ++ if (temp < 0) { ++ temp = 0; ++ } ++ } catch (NumberFormatException e) {} ++ setLimit(index, state, temp); } ++ } ++ ++ /** ++ * Set the value of a property by its index ++ * ++ * @param index the index of the property ++ * @param state the state of the property ++ * @param value the value of the property ++ */ ++ public void setLimit(int index, State state, int value) { ++ if (index == indexEntityCountInfo) { ++ //if it's explicitly set, it's treated as yes no matter the value ++ printEntityCountInfo = XalanConstants.JDK_YES; ++ } else { ++ //only update if it shall override ++ if (state.compareTo(states[index]) >= 0) { ++ values[index] = value; ++ states[index] = state; ++ isSet[index] = true; ++ } ++ } ++ } ++ ++ ++ /** ++ * Return the value of the specified property. ++ * ++ * @param propertyName the property name ++ * @return the value of the property as a string. If a property is managed ++ * by this manager, its value shall not be null. ++ */ ++ public String getLimitAsString(String propertyName) { ++ int index = getIndex(propertyName); ++ if (index > -1) { ++ return getLimitValueByIndex(index); ++ } ++ ++ return null; ++ } ++ ++ /** ++ * Return the value of a property by its ordinal ++ * ++ * @param limit the property ++ * @return value of a property ++ */ ++ public String getLimitValueAsString(Limit limit) { ++ return Integer.toString(values[limit.ordinal()]); ++ } ++ ++ /** ++ * Return the value of the specified property ++ * ++ * @param limit the property ++ * @return the value of the property ++ */ ++ public int getLimit(Limit limit) { ++ return values[limit.ordinal()]; ++ } ++ ++ /** ++ * Return the value of a property by its ordinal ++ * ++ * @param index the index of a property ++ * @return value of a property ++ */ ++ public int getLimitByIndex(int index) { ++ return values[index]; ++ } ++ /** ++ * Return the value of a property by its index ++ * ++ * @param index the index of a property ++ * @return limit of a property as a string ++ */ ++ public String getLimitValueByIndex(int index) { ++ if (index == indexEntityCountInfo) { ++ return printEntityCountInfo; ++ } ++ ++ return Integer.toString(values[index]); ++ } ++ /** ++ * Return the state of the limit property ++ * ++ * @param limit the limit ++ * @return the state of the limit property ++ */ ++ public State getState(Limit limit) { ++ return states[limit.ordinal()]; ++ } ++ ++ /** ++ * Return the state of the limit property ++ * ++ * @param limit the limit ++ * @return the state of the limit property ++ */ ++ public String getStateLiteral(Limit limit) { ++ return states[limit.ordinal()].literal(); ++ } ++ ++ /** ++ * Get the index by property name ++ * ++ * @param propertyName property name ++ * @return the index of the property if found; return -1 if not ++ */ ++ public int getIndex(String propertyName) { ++ for (Limit limit : Limit.values()) { ++ if (limit.equalsAPIPropertyName(propertyName)) { ++ //internally, ordinal is used as index ++ return limit.ordinal(); ++ } ++ } ++ //special property to return entity count info ++ if (propertyName.equals(XalanConstants.JDK_ENTITY_COUNT_INFO)) { ++ return indexEntityCountInfo; ++ } ++ return -1; ++ } ++ ++ /** ++ * Indicate if a property is set explicitly ++ * @param index ++ * @return ++ */ ++ public boolean isSet(int index) { ++ return isSet[index]; ++ } ++ ++ public boolean printEntityCountInfo() { ++ return printEntityCountInfo.equals(XalanConstants.JDK_YES); ++ } ++ /** ++ * Read from system properties, or those in jaxp.properties ++ */ ++ private void readSystemProperties() { ++ ++ for (Limit limit : Limit.values()) { ++ if (!getSystemProperty(limit, limit.systemProperty())) { ++ //if system property is not found, try the older form if any ++ for (NameMap nameMap : NameMap.values()) { ++ String oldName = nameMap.getOldName(limit.systemProperty()); ++ if (oldName != null) { ++ getSystemProperty(limit, oldName); ++ } ++ } ++ } ++ } ++ ++ } ++ ++ /** ++ * Read from system properties, or those in jaxp.properties ++ * ++ * @param property the type of the property ++ * @param sysPropertyName the name of system property ++ */ ++ private boolean getSystemProperty(Limit limit, String sysPropertyName) { ++ try { ++ String value = SecuritySupport.getSystemProperty(sysPropertyName); ++ if (value != null && !value.equals("")) { ++ values[limit.ordinal()] = Integer.parseInt(value); ++ states[limit.ordinal()] = State.SYSTEMPROPERTY; ++ return true; ++ } ++ ++ value = SecuritySupport.readJAXPProperty(sysPropertyName); ++ if (value != null && !value.equals("")) { ++ values[limit.ordinal()] = Integer.parseInt(value); ++ states[limit.ordinal()] = State.JAXPDOTPROPERTIES; ++ return true; ++ } ++ } catch (NumberFormatException e) { ++ //invalid setting ++ throw new NumberFormatException("Invalid setting for system property: " + limit.systemProperty()); ++ } ++ return false; ++ } ++} +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/Parser.java Tue Oct 29 08:01:29 2013 +0000 +@@ -40,10 +40,12 @@ + import javax.xml.parsers.SAXParser; + import javax.xml.parsers.SAXParserFactory; + ++import com.sun.org.apache.xalan.internal.XalanConstants; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.ErrorMsg; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.MethodType; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.Type; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.TypeCheckError; ++import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager; + import org.xml.sax.Attributes; + import org.xml.sax.helpers.AttributesImpl; + import org.xml.sax.ContentHandler; +@@ -466,6 +468,20 @@ + } + final SAXParser parser = factory.newSAXParser(); + final XMLReader reader = parser.getXMLReader(); ++ try { ++ XMLSecurityManager securityManager = ++ (XMLSecurityManager)_xsltc.getProperty(XalanConstants.SECURITY_MANAGER); ++ for (XMLSecurityManager.Limit limit : XMLSecurityManager.Limit.values()) { ++ reader.setProperty(limit.apiProperty(), securityManager.getLimitValueAsString(limit)); ++ } ++ if (securityManager.printEntityCountInfo()) { ++ parser.setProperty(XalanConstants.JDK_ENTITY_COUNT_INFO, XalanConstants.JDK_YES); ++ } ++ } catch (SAXException se) { ++ System.err.println("Warning: " + reader.getClass().getName() + ": " ++ + se.getMessage()); ++ } ++ + return(parse(reader, input)); + } + catch (ParserConfigurationException e) { +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java Tue Oct 29 08:01:29 2013 +0000 +@@ -41,12 +41,13 @@ + import java.util.jar.Manifest; + + import com.sun.org.apache.bcel.internal.classfile.JavaClass; ++import com.sun.org.apache.xalan.internal.XalanConstants; + import com.sun.org.apache.xalan.internal.utils.SecuritySupport; ++import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.ErrorMsg; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.Util; + import com.sun.org.apache.xml.internal.dtm.DTM; + +-import com.sun.org.apache.xalan.internal.utils.SecuritySupport; + import org.xml.sax.InputSource; + import org.xml.sax.XMLReader; + +@@ -105,6 +106,7 @@ + public static final int BYTEARRAY_AND_FILE_OUTPUT = 4; + public static final int BYTEARRAY_AND_JAR_OUTPUT = 5; + ++ private XMLSecurityManager _xmlSecurityManager; + + // Compiler options (passed from command line or XSLTC client) + private boolean _debug = false; // -x +@@ -898,4 +900,24 @@ + + return newDataOffset; + } ++ ++ /** ++ * Return allowed protocols for accessing external stylesheet. ++ */ ++ public Object getProperty(String name) { ++ if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ return _xmlSecurityManager; ++ } ++ return null; ++ } ++ ++ /** ++ * Set allowed protocols for accessing external stylesheet. ++ */ ++ public void setProperty(String name, Object value) { ++ if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ _xmlSecurityManager = (XMLSecurityManager)value; ++ } ++ } ++ + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TemplatesHandlerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TemplatesHandlerImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TemplatesHandlerImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -29,7 +29,7 @@ + import javax.xml.transform.TransformerException; + import javax.xml.transform.URIResolver; + import javax.xml.transform.sax.TemplatesHandler; +- ++import com.sun.org.apache.xalan.internal.XalanConstants; + import com.sun.org.apache.xalan.internal.xsltc.compiler.CompilerException; + import com.sun.org.apache.xalan.internal.xsltc.compiler.Parser; + import com.sun.org.apache.xalan.internal.xsltc.compiler.SourceLoader; +@@ -98,6 +98,8 @@ + XSLTC xsltc = new XSLTC(); + if (tfactory.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING)) + xsltc.setSecureProcessing(true); ++ xsltc.setProperty(XalanConstants.SECURITY_MANAGER, ++ tfactory.getAttribute(XalanConstants.SECURITY_MANAGER)); + + _parser = xsltc.getParser(); + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerFactoryImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerFactoryImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerFactoryImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -64,12 +64,14 @@ + import com.sun.org.apache.xml.internal.utils.StylesheetPIHandler; + import com.sun.org.apache.xml.internal.utils.StopParseException; + ++import com.sun.org.apache.xalan.internal.XalanConstants; + import com.sun.org.apache.xalan.internal.xsltc.compiler.Constants; + import com.sun.org.apache.xalan.internal.xsltc.compiler.SourceLoader; + import com.sun.org.apache.xalan.internal.xsltc.compiler.XSLTC; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.ErrorMsg; + import com.sun.org.apache.xalan.internal.xsltc.dom.XSLTCDTMManager; + import com.sun.org.apache.xalan.internal.utils.SecuritySupport; ++import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager; + + import org.xml.sax.InputSource; + import org.xml.sax.XMLFilter; +@@ -221,8 +223,13 @@ + _isSecureMode = true; + _isNotSecureProcessing = false; + } ++ ++ //Parser's security manager ++ _xmlSecurityManager = new XMLSecurityManager(true); + } + ++ private XMLSecurityManager _xmlSecurityManager; ++ + /** + * javax.xml.transform.sax.TransformerFactory implementation. + * Set the error event listener for the TransformerFactory, which is used +@@ -273,8 +280,9 @@ + } + else if (name.equals(AUTO_TRANSLET)) { + return new Boolean(_autoTranslet); ++ } else if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ return _xmlSecurityManager; + } +- + // Throw an exception for all other attributes + ErrorMsg err = new ErrorMsg(ErrorMsg.JAXP_INVALID_ATTR_ERR, name); + throw new IllegalArgumentException(err.toString()); +@@ -417,6 +425,7 @@ + throw new TransformerConfigurationException(err.toString()); + } + _isNotSecureProcessing = !value; ++ _xmlSecurityManager.setSecureProcessing(value); + // all done processing feature + return; + } +@@ -757,6 +766,7 @@ + if (_debug) xsltc.setDebug(true); + if (_enableInlining) xsltc.setTemplateInlining(true); + if (!_isNotSecureProcessing) xsltc.setSecureProcessing(true); ++ xsltc.setProperty(XalanConstants.SECURITY_MANAGER, _xmlSecurityManager); + xsltc.init(); + + // Set a document loader (for xsl:include/import) if defined +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -64,6 +64,8 @@ + + import com.sun.org.apache.xml.internal.utils.SystemIDResolver; + ++import com.sun.org.apache.xalan.internal.XalanConstants; ++import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xalan.internal.xsltc.DOM; + import com.sun.org.apache.xalan.internal.xsltc.DOMCache; + import com.sun.org.apache.xalan.internal.xsltc.DOMEnhancedForDTM; +@@ -208,6 +210,7 @@ + */ + private Hashtable _parameters = null; + ++ private XMLSecurityManager _securityManager; + /** + * This class wraps an ErrorListener into a MessageHandler in order to + * capture messages reported via xsl:message. +@@ -252,7 +255,9 @@ + _propertiesClone = (Properties) _properties.clone(); + _indentNumber = indentNumber; + _tfactory = tfactory; ++ _securityManager = (XMLSecurityManager)_tfactory.getAttribute(XalanConstants.SECURITY_MANAGER); + _readerManager.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, _isSecureProcessing); ++ _readerManager.setProperty(XalanConstants.SECURITY_MANAGER, _securityManager); + //_isIncremental = tfactory._incremental; + } + +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/Util.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/Util.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/Util.java Tue Oct 29 08:01:29 2013 +0000 +@@ -23,6 +23,7 @@ + + package com.sun.org.apache.xalan.internal.xsltc.trax; + ++import com.sun.org.apache.xalan.internal.XalanConstants; + import java.io.InputStream; + import java.io.Reader; + +@@ -42,6 +43,7 @@ + import javax.xml.transform.stax.StAXSource; + import javax.xml.transform.stream.StreamSource; + ++import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xalan.internal.xsltc.compiler.XSLTC; + import com.sun.org.apache.xalan.internal.xsltc.compiler.util.ErrorMsg; + +@@ -143,6 +145,22 @@ + reader.setFeature + ("http://xml.org/sax/features/namespace-prefixes",false); + ++ try { ++ XMLSecurityManager securityManager = ++ (XMLSecurityManager)xsltc.getProperty(XalanConstants.SECURITY_MANAGER); ++ if (securityManager != null) { ++ for (XMLSecurityManager.Limit limit : XMLSecurityManager.Limit.values()) { ++ reader.setProperty(limit.apiProperty(), ++ securityManager.getLimitValueAsString(limit)); ++ } ++ if (securityManager.printEntityCountInfo()) { ++ reader.setProperty(XalanConstants.JDK_ENTITY_COUNT_INFO, XalanConstants.JDK_YES); ++ } ++ } ++ } catch (SAXException se) { ++ System.err.println("Warning: " + reader.getClass().getName() + ": " ++ + se.getMessage()); ++ } + xsltc.setXMLReader(reader); + }catch (SAXNotRecognizedException snre ) { + throw new TransformerConfigurationException +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/dom/DOMConfigurationImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/dom/DOMConfigurationImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/dom/DOMConfigurationImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -53,6 +53,7 @@ + import com.sun.org.apache.xerces.internal.xni.parser.XMLErrorHandler; + import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; + import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import org.w3c.dom.DOMException; + import org.w3c.dom.ls.LSResourceResolver; + +@@ -189,6 +190,9 @@ + private DOMStringList fRecognizedParameters; + + ++ /** Property identifier: Security manager. */ ++ private static final String SECURITY_MANAGER = Constants.SECURITY_MANAGER; ++ + // + // Constructors + // +@@ -259,7 +263,8 @@ + GRAMMAR_POOL, + JAXP_SCHEMA_SOURCE, + JAXP_SCHEMA_LANGUAGE, +- DTD_VALIDATOR_FACTORY_PROPERTY ++ DTD_VALIDATOR_FACTORY_PROPERTY, ++ SECURITY_MANAGER, + }; + addRecognizedProperties(recognizedProperties); + +@@ -293,6 +298,8 @@ + fValidationManager = createValidationManager(); + setProperty(VALIDATION_MANAGER, fValidationManager); + ++ setProperty(SECURITY_MANAGER, new XMLSecurityManager(true)); ++ + + // add message formatters + if (fErrorReporter.getMessageFormatter(XMLMessageFormatter.XML_DOMAIN) == null) { +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/Constants.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/Constants.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/Constants.java Tue Oct 29 08:01:29 2013 +0000 +@@ -156,9 +156,111 @@ + /** JAXP schemaSource language: when used internally may include DTD namespace (DOM) */ + public static final String SCHEMA_LANGUAGE = "schemaLanguage"; + +- public static final String SYSTEM_PROPERTY_ELEMENT_ATTRIBUTE_LIMIT = "elementAttributeLimit" ; ++ /** Oracle JAXP property prefix ("http://www.oracle.com/xml/jaxp/properties/"). */ ++ public static final String ORACLE_JAXP_PROPERTY_PREFIX = ++ "http://www.oracle.com/xml/jaxp/properties/"; + + // ++ // Implementation limits: corresponding System Properties of the above ++ // API properties ++ // ++ /** ++ * JDK entity expansion limit; Note that the existing system property ++ * "entityExpansionLimit" with no prefix is still observed ++ */ ++ public static final String JDK_ENTITY_EXPANSION_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "entityExpansionLimit"; ++ ++ /** ++ * JDK element attribute limit; Note that the existing system property ++ * "elementAttributeLimit" with no prefix is still observed ++ */ ++ public static final String JDK_ELEMENT_ATTRIBUTE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "elementAttributeLimit"; ++ ++ /** ++ * JDK maxOccur limit; Note that the existing system property ++ * "maxOccurLimit" with no prefix is still observed ++ */ ++ public static final String JDK_MAX_OCCUR_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxOccurLimit"; ++ ++ /** ++ * JDK total entity size limit ++ */ ++ public static final String JDK_TOTAL_ENTITY_SIZE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "totalEntitySizeLimit"; ++ ++ /** ++ * JDK maximum general entity size limit ++ */ ++ public static final String JDK_GENEAL_ENTITY_SIZE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxGeneralEntitySizeLimit"; ++ /** ++ * JDK maximum parameter entity size limit ++ */ ++ public static final String JDK_PARAMETER_ENTITY_SIZE_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxParameterEntitySizeLimit"; ++ /** ++ * JDK maximum XML name limit ++ */ ++ public static final String JDK_XML_NAME_LIMIT = ++ ORACLE_JAXP_PROPERTY_PREFIX + "maxXMLNameLimit"; ++ /** ++ * JDK property to allow printing out information from the limit analyzer ++ */ ++ public static final String JDK_ENTITY_COUNT_INFO = ++ ORACLE_JAXP_PROPERTY_PREFIX + "getEntityCountInfo"; ++ ++ // ++ // Implementation limits: API properties ++ // ++ /** ++ * JDK entity expansion limit; Note that the existing system property ++ * "entityExpansionLimit" with no prefix is still observed ++ */ ++ public static final String SP_ENTITY_EXPANSION_LIMIT = "jdk.xml.entityExpansionLimit"; ++ ++ /** ++ * JDK element attribute limit; Note that the existing system property ++ * "elementAttributeLimit" with no prefix is still observed ++ */ ++ public static final String SP_ELEMENT_ATTRIBUTE_LIMIT = "jdk.xml.elementAttributeLimit"; ++ ++ /** ++ * JDK maxOccur limit; Note that the existing system property ++ * "maxOccurLimit" with no prefix is still observed ++ */ ++ public static final String SP_MAX_OCCUR_LIMIT = "jdk.xml.maxOccurLimit"; ++ ++ /** ++ * JDK total entity size limit ++ */ ++ public static final String SP_TOTAL_ENTITY_SIZE_LIMIT = "jdk.xml.totalEntitySizeLimit"; ++ ++ /** ++ * JDK maximum general entity size limit ++ */ ++ public static final String SP_GENEAL_ENTITY_SIZE_LIMIT = "jdk.xml.maxGeneralEntitySizeLimit"; ++ /** ++ * JDK maximum parameter entity size limit ++ */ ++ public static final String SP_PARAMETER_ENTITY_SIZE_LIMIT = "jdk.xml.maxParameterEntitySizeLimit"; ++ /** ++ * JDK maximum XML name limit ++ */ ++ public static final String SP_XML_NAME_LIMIT = "jdk.xml.maxXMLNameLimit"; ++ ++ //legacy System Properties ++ public final static String ENTITY_EXPANSION_LIMIT = "entityExpansionLimit"; ++ public static final String ELEMENT_ATTRIBUTE_LIMIT = "elementAttributeLimit" ; ++ public final static String MAX_OCCUR_LIMIT = "maxOccurLimit"; ++ ++ /** ++ * A string "yes" that can be used for properties such as getEntityCountInfo ++ */ ++ public static final String JDK_YES = "yes"; ++ // + // DOM features + // + +@@ -387,7 +489,7 @@ + public static final String LOCALE_PROPERTY = "locale"; + + /** property identifier: security manager. */ +- protected static final String SECURITY_MANAGER = ++ public static final String SECURITY_MANAGER = + Constants.XERCES_PROPERTY_PREFIX + Constants.SECURITY_MANAGER_PROPERTY; + + +@@ -452,9 +554,6 @@ + */ + public final static String ATTRIBUTE_DECLARED = "ATTRIBUTE_DECLARED"; + +- public final static String ENTITY_EXPANSION_LIMIT = "entityExpansionLimit"; +- +- public final static String MAX_OCCUR_LIMIT = "maxOccurLimit"; + + /** + * {@link org.w3c.dom.TypeInfo} associated with current element/attribute +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java Tue Oct 29 08:01:29 2013 +0000 +@@ -25,6 +25,7 @@ + + package com.sun.org.apache.xerces.internal.impl; + ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import java.util.HashMap; + import javax.xml.stream.XMLInputFactory; + import javax.xml.stream.XMLOutputFactory; +@@ -50,9 +51,13 @@ + + private static final String STRING_INTERNING = "http://xml.org/sax/features/string-interning"; + ++ /** Property identifier: Security manager. */ ++ private static final String SECURITY_MANAGER = Constants.SECURITY_MANAGER; + + HashMap supportedProps = new HashMap(); + ++ private XMLSecurityManager fSecurityManager; ++ + public static final int CONTEXT_READER = 1; + public static final int CONTEXT_WRITER = 2; + +@@ -77,6 +82,7 @@ + + HashMap properties = propertyManager.getProperties(); + supportedProps.putAll(properties); ++ fSecurityManager = (XMLSecurityManager)getProperty(SECURITY_MANAGER); + } + + private HashMap getProperties(){ +@@ -117,6 +123,9 @@ + supportedProps.put(Constants.XERCES_FEATURE_PREFIX + Constants.WARN_ON_DUPLICATE_ATTDEF_FEATURE, new Boolean(false)); + supportedProps.put(Constants.XERCES_FEATURE_PREFIX + Constants.WARN_ON_DUPLICATE_ENTITYDEF_FEATURE, new Boolean(false)); + supportedProps.put(Constants.XERCES_FEATURE_PREFIX + Constants.WARN_ON_UNDECLARED_ELEMDEF_FEATURE, new Boolean(false)); ++ ++ fSecurityManager = new XMLSecurityManager(true); ++ supportedProps.put(SECURITY_MANAGER, fSecurityManager); + } + + private void initWriterProps(){ +@@ -132,7 +141,8 @@ + * } + */ + public boolean containsProperty(String property){ +- return supportedProps.containsKey(property) ; ++ return supportedProps.containsKey(property) || ++ (fSecurityManager != null && fSecurityManager.getIndex(property) > -1) ; + } + + public Object getProperty(String property){ +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XML11NSDocumentScannerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XML11NSDocumentScannerImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XML11NSDocumentScannerImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -108,6 +108,7 @@ + * @author Elena Litani, IBM + * @author Michael Glavassevich, IBM + * @author Sunitha Reddy, Sun Microsystems ++ * @version $Id: XML11NSDocumentScannerImpl.java,v 1.6 2010-11-01 04:39:40 joehw Exp $ + */ + public class XML11NSDocumentScannerImpl extends XML11DocumentScannerImpl { + +@@ -236,7 +237,8 @@ + + // attributes + scanAttribute(fAttributes); +- if (fSecurityManager != null && fAttributes.getLength() > fElementAttributeLimit){ ++ if (fSecurityManager != null && (!fSecurityManager.isNoLimit(fElementAttributeLimit)) && ++ fAttributes.getLength() > fElementAttributeLimit){ + fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN, + "ElementAttributeLimit", + new Object[]{rawname, new Integer(fElementAttributeLimit) }, +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDTDScannerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDTDScannerImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDTDScannerImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -44,6 +44,8 @@ + import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter; + import com.sun.org.apache.xerces.internal.impl.XMLEntityHandler; + import com.sun.org.apache.xerces.internal.impl.Constants; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; ++import com.sun.xml.internal.stream.Entity; + + /** + * This class is responsible for scanning the declarations found +@@ -66,7 +68,7 @@ + * @author Glenn Marcy, IBM + * @author Eric Ye, IBM + * +- * @version $Id: XMLDTDScannerImpl.java,v 1.7 2007/09/26 12:52:40 ndw Exp $ ++ * @version $Id: XMLDTDScannerImpl.java,v 1.8 2010-11-01 04:39:41 joehw Exp $ + */ + public class XMLDTDScannerImpl + extends XMLScanner +@@ -1545,7 +1547,7 @@ + + // internal entity + if (systemId == null) { +- scanEntityValue(fLiteral, fLiteral2); ++ scanEntityValue(name, isPEDecl, fLiteral, fLiteral2); + // since we need it's value anyway, let's snag it so it doesn't get corrupted + // if a new load takes place before we store the entity values + fStringBuffer.clear(); +@@ -1610,7 +1612,7 @@ + * the use of scanCharReferenceValue), and fStringBuffer2, anything in them + * at the time of calling is lost. + */ +- protected final void scanEntityValue(XMLString value, ++ protected final void scanEntityValue(String entityName, boolean isPEDecl, XMLString value, + XMLString nonNormalizedValue) + throws IOException, XNIException { + int quote = fEntityScanner.scanChar(); +@@ -1622,10 +1624,20 @@ + + XMLString literal = fString; + XMLString literal2 = fString; ++ int countChar = 0; ++ if (fLimitAnalyzer == null && fSecurityManager != null) { ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); ++ fLimitAnalyzer.startEntity(entityName); ++ } ++ + if (fEntityScanner.scanLiteral(quote, fString) != quote) { + fStringBuffer.clear(); + fStringBuffer2.clear(); + do { ++ if (isPEDecl && fLimitAnalyzer != null) { ++ checkLimit("%" + entityName, fString.length + countChar); ++ } ++ countChar = 0; + fStringBuffer.append(fString); + fStringBuffer2.append(fString); + if (fEntityScanner.skipChar('&')) { +@@ -1685,6 +1697,7 @@ + } + } + else { ++ countChar++; + int c = fEntityScanner.peekChar(); + if (XMLChar.isHighSurrogate(c)) { + scanSurrogates(fStringBuffer2); +@@ -1708,9 +1721,17 @@ + fStringBuffer2.append(fString); + literal = fStringBuffer; + literal2 = fStringBuffer2; ++ } else { ++ if (isPEDecl) { ++ checkLimit("%" + entityName, literal); ++ } + } + value.setValues(literal); + nonNormalizedValue.setValues(literal2); ++ if (fLimitAnalyzer != null) { ++ fLimitAnalyzer.endEntity(XMLSecurityManager.Limit.PARAMETER_ENTITY_SIZE_LIMIT, entityName); ++ } ++ + if (!fEntityScanner.skipChar(quote)) { + reportFatalError("CloseQuoteMissingInDecl", null); + } +@@ -2126,6 +2147,43 @@ + //new SymbolTable()); + } + ++ /** ++ * Add the count of the content buffer and check if the accumulated ++ * value exceeds the limit ++ * @param entityName entity name ++ * @param buffer content buffer ++ */ ++ private void checkLimit(String entityName, XMLString buffer) { ++ checkLimit(entityName, buffer.length); ++ } ++ ++ /** ++ * Add the count and check limit ++ * @param entityName entity name ++ * @param len length of the buffer ++ */ ++ private void checkLimit(String entityName, int len) { ++ if (fLimitAnalyzer == null) { ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); ++ } ++ fLimitAnalyzer.addValue(XMLSecurityManager.Limit.PARAMETER_ENTITY_SIZE_LIMIT, entityName, len); ++ if (fSecurityManager.isOverLimit(XMLSecurityManager.Limit.PARAMETER_ENTITY_SIZE_LIMIT)) { ++ fSecurityManager.debugPrint(); ++ reportFatalError("MaxEntitySizeLimit", new Object[]{entityName, ++ fLimitAnalyzer.getValue(XMLSecurityManager.Limit.PARAMETER_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getLimit(XMLSecurityManager.Limit.PARAMETER_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getStateLiteral(XMLSecurityManager.Limit.PARAMETER_ENTITY_SIZE_LIMIT)}); ++ } ++ if (fSecurityManager.isOverLimit(XMLSecurityManager.Limit.TOTAL_ENTITY_SIZE_LIMIT)) { ++ fSecurityManager.debugPrint(); ++ reportFatalError("TotalEntitySizeLimit", ++ new Object[]{fLimitAnalyzer.getTotalValue(XMLSecurityManager.Limit.TOTAL_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getLimit(XMLSecurityManager.Limit.TOTAL_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getStateLiteral(XMLSecurityManager.Limit.TOTAL_ENTITY_SIZE_LIMIT)}); ++ } ++ ++ } ++ + public DTDGrammar getGrammar(){ + return nvGrammarInfo; + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDocumentFragmentScannerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDocumentFragmentScannerImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDocumentFragmentScannerImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -18,7 +18,6 @@ + * limitations under the License. + */ + +- + package com.sun.org.apache.xerces.internal.impl; + + import com.sun.xml.internal.stream.XMLBufferListener; +@@ -51,7 +50,10 @@ + import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.impl.XMLEntityHandler; + import com.sun.org.apache.xerces.internal.util.NamespaceSupport; ++import com.sun.org.apache.xerces.internal.utils.XMLLimitAnalyzer; + import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager.Limit; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager.State; + import com.sun.org.apache.xerces.internal.xni.NamespaceContext; + import javax.xml.stream.XMLStreamConstants; + import javax.xml.stream.events.XMLEvent; +@@ -194,7 +196,7 @@ + }; + + protected static final char [] cdata = {'[','C','D','A','T','A','['}; +- protected static final char [] xmlDecl = {'<','?','x','m','l'}; ++ static final char [] xmlDecl = {'<','?','x','m','l'}; + protected static final char [] endTag = {'<','/'}; + // debugging + +@@ -350,7 +352,6 @@ + + protected boolean foundBuiltInRefs = false; + +- protected XMLSecurityManager fSecurityManager = null; + + //skip element algorithm + static final short MAX_DEPTH_LIMIT = 5 ; +@@ -559,6 +560,8 @@ + } catch (XMLConfigurationException e) { + fSecurityManager = null; + } ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); ++ + fElementAttributeLimit = (fSecurityManager != null)? + fSecurityManager.getLimit(XMLSecurityManager.Limit.ELEMENT_ATTRIBUTE_LIMIT):0; + +@@ -604,8 +607,7 @@ + fEntityStore = fEntityManager.getEntityStore(); + + dtdGrammarUtil = null; +- +- ++ + //fEntityManager.test(); + } // reset(XMLComponentManager) + +@@ -655,6 +657,8 @@ + + dtdGrammarUtil = null; + ++ fSecurityManager = (XMLSecurityManager)propertyManager.getProperty(Constants.SECURITY_MANAGER); ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); + } // reset(XMLComponentManager) + + /** +@@ -931,7 +935,6 @@ + + // scan decl + super.scanXMLDeclOrTextDecl(scanningTextDecl, fStrings); +- + fMarkupDepth--; + + // pseudo-attribute values +@@ -1298,7 +1301,8 @@ + fAddDefaultAttr = true; + do { + scanAttribute(fAttributes); +- if (fSecurityManager != null && fAttributes.getLength() > fElementAttributeLimit){ ++ if (fSecurityManager != null && !fSecurityManager.isNoLimit(fElementAttributeLimit) && ++ fAttributes.getLength() > fElementAttributeLimit){ + fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN, + "ElementAttributeLimit", + new Object[]{rawname, new Integer(fAttributes.getLength()) }, +@@ -2800,6 +2804,8 @@ + if(DEBUG){ + System.out.println("NOT USING THE BUFFER, STRING = " + fTempString.toString()); + } ++ //check limit before returning event ++ checkLimit(fContentBuffer); + if(dtdGrammarUtil!= null && dtdGrammarUtil.isIgnorableWhiteSpace(fContentBuffer)){ + if(DEBUG)System.out.println("Return SPACE EVENT"); + return XMLEvent.SPACE; +@@ -2898,6 +2904,8 @@ + fLastSectionWasCharacterData = true ; + return fDriver.next(); + }else{ ++ //check limit before returning event ++ checkLimit(fContentBuffer); + if(dtdGrammarUtil!= null && dtdGrammarUtil.isIgnorableWhiteSpace(fContentBuffer)){ + if(DEBUG)System.out.println("Return SPACE EVENT"); + return XMLEvent.SPACE; +@@ -3108,6 +3116,31 @@ + + }//next + ++ ++ /** ++ * Add the count of the content buffer and check if the accumulated ++ * value exceeds the limit ++ * @param buffer content buffer ++ */ ++ protected void checkLimit(XMLStringBuffer buffer) { ++ if (fLimitAnalyzer.isTracking(fCurrentEntityName)) { ++ fLimitAnalyzer.addValue(Limit.GENEAL_ENTITY_SIZE_LIMIT, fCurrentEntityName, buffer.length); ++ if (fSecurityManager.isOverLimit(Limit.GENEAL_ENTITY_SIZE_LIMIT)) { ++ fSecurityManager.debugPrint(); ++ reportFatalError("MaxEntitySizeLimit", new Object[]{fCurrentEntityName, ++ fLimitAnalyzer.getValue(Limit.GENEAL_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getLimit(Limit.GENEAL_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getStateLiteral(Limit.GENEAL_ENTITY_SIZE_LIMIT)}); ++ } ++ if (fSecurityManager.isOverLimit(Limit.TOTAL_ENTITY_SIZE_LIMIT)) { ++ fSecurityManager.debugPrint(); ++ reportFatalError("TotalEntitySizeLimit", ++ new Object[]{fLimitAnalyzer.getTotalValue(Limit.TOTAL_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getLimit(Limit.TOTAL_ENTITY_SIZE_LIMIT), ++ fSecurityManager.getStateLiteral(Limit.TOTAL_ENTITY_SIZE_LIMIT)}); ++ } ++ } ++ } + + // + // Protected methods +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java Tue Oct 29 08:01:29 2013 +0000 +@@ -18,7 +18,7 @@ + * limitations under the License. + */ + +-package com.sun.org.apache.xerces.internal.impl ; ++package com.sun.org.apache.xerces.internal.impl; + + import com.sun.xml.internal.stream.StaxEntityResolverWrapper; + import com.sun.xml.internal.stream.StaxXMLInputSource; +@@ -65,6 +65,7 @@ + + import com.sun.org.apache.xerces.internal.impl.validation.ValidationManager; + import com.sun.org.apache.xerces.internal.util.URI; ++import com.sun.org.apache.xerces.internal.utils.XMLLimitAnalyzer; + import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + + +@@ -319,10 +320,13 @@ + */ + protected int fBufferSize = DEFAULT_BUFFER_SIZE; + +- // stores defaults for entity expansion limit if it has +- // been set on the configuration. ++ /** Security Manager */ + protected XMLSecurityManager fSecurityManager = null; + ++ protected XMLLimitAnalyzer fLimitAnalyzer = null; ++ ++ protected int entityExpansionIndex; ++ + /** + * True if the document entity is standalone. This should really + * only be set by the document source (e.g. XMLDocumentScanner). +@@ -347,10 +351,6 @@ + /** XML 1.1 entity scanner. */ + protected XMLEntityScanner fXML11EntityScanner; + +- /** entity expansion limit (contains useful data if and only if +- fSecurityManager is non-null) */ +- protected int fEntityExpansionLimit = 0; +- + /** count of entities expanded: */ + protected int fEntityExpansionCount = 0; + +@@ -848,6 +848,9 @@ + fCurrentEntity.setEncodingExternallySpecified(encodingExternallySpecified); + fEntityScanner.setCurrentEntity(fCurrentEntity); + fResourceIdentifier.setValues(publicId, literalSystemId, baseSystemId, expandedSystemId); ++ if (fLimitAnalyzer != null) { ++ fLimitAnalyzer.startEntity(name); ++ } + return encoding; + } //setupCurrentEntity(String, XMLInputSource, boolean, boolean): String + +@@ -1297,10 +1300,13 @@ + //expansions exceeds the entity expansion limit, parser will throw fatal error. + // Note that this represents the nesting level of open entities. + fEntityExpansionCount++; +- if( fSecurityManager != null && fEntityExpansionCount > fEntityExpansionLimit ){ +- fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN, +- "EntityExpansionLimitExceeded", +- new Object[]{new Integer(fEntityExpansionLimit) }, ++ if(fLimitAnalyzer != null) { ++ fLimitAnalyzer.addValue(entityExpansionIndex, name, 1); ++ } ++ if( fSecurityManager != null && fSecurityManager.isOverLimit(entityExpansionIndex)){ ++ fSecurityManager.debugPrint(); ++ fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN,"EntityExpansionLimitExceeded", ++ new Object[]{fSecurityManager.getLimitValueByIndex(entityExpansionIndex)}, + XMLErrorReporter.SEVERITY_FATAL_ERROR ); + // is there anything better to do than reset the counter? + // at least one can envision debugging applications where this might +@@ -1381,6 +1387,12 @@ + if(fCurrentEntity != null){ + //close the reader + try{ ++ if (fLimitAnalyzer != null) { ++ fLimitAnalyzer.endEntity(XMLSecurityManager.Limit.GENEAL_ENTITY_SIZE_LIMIT, fCurrentEntity.name); ++ if (fCurrentEntity.name.equals("[xml]")) { ++ fSecurityManager.debugPrint(); ++ } ++ } + fCurrentEntity.close(); + }catch(IOException ex){ + throw new XNIException(ex); +@@ -1425,6 +1437,9 @@ + fStaxEntityResolver = null; + } + ++ fSecurityManager = (XMLSecurityManager)propertyManager.getProperty(SECURITY_MANAGER); ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); ++ + // initialize state + //fStandalone = false; + fEntities.clear(); +@@ -1536,6 +1551,8 @@ + catch (XMLConfigurationException e) { + fSecurityManager = null; + } ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); ++ entityExpansionIndex = fSecurityManager.getIndex(Constants.JDK_ENTITY_EXPANSION_LIMIT); + + //reset general state + reset(); +@@ -1549,9 +1566,6 @@ + // a class acting as a component manager but not + // implementing that interface for whatever reason. + public void reset() { +- fEntityExpansionLimit = (fSecurityManager != null)? +- fSecurityManager.getLimit(XMLSecurityManager.Limit.ENTITY_EXPANSION_LIMIT):0; +- + + // initialize state + fStandalone = false; +@@ -1692,8 +1706,7 @@ + if (suffixLength == Constants.SECURITY_MANAGER_PROPERTY.length() && + propertyId.endsWith(Constants.SECURITY_MANAGER_PROPERTY)) { + fSecurityManager = (XMLSecurityManager)value; +- fEntityExpansionLimit = (fSecurityManager != null)? +- fSecurityManager.getLimit(XMLSecurityManager.Limit.ENTITY_EXPANSION_LIMIT):0; ++ fLimitAnalyzer = fSecurityManager.getLimitAnalyzer(); + } + } + +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLNSDocumentScannerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLNSDocumentScannerImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLNSDocumentScannerImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -58,6 +58,7 @@ + * @author Neeraj Bajaj, Sun Microsystems + * @author Venugopal Rao K, Sun Microsystems + * @author Elena Litani, IBM ++ * @version $Id: XMLNSDocumentScannerImpl.java,v 1.11 2010-11-01 04:39:41 joehw Exp $ + */ + public class XMLNSDocumentScannerImpl + extends XMLDocumentScannerImpl { +@@ -251,7 +252,8 @@ + + do { + scanAttribute(fAttributes); +- if (fSecurityManager != null && fAttributes.getLength() > fElementAttributeLimit){ ++ if (fSecurityManager != null && (!fSecurityManager.isNoLimit(fElementAttributeLimit)) && ++ fAttributes.getLength() > fElementAttributeLimit){ + fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN, + "ElementAttributeLimit", + new Object[]{rawname, new Integer(fAttributes.getLength()) }, +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java Tue Oct 29 08:01:29 2013 +0000 +@@ -31,6 +31,8 @@ + import com.sun.org.apache.xerces.internal.util.XMLChar; + import com.sun.org.apache.xerces.internal.util.XMLResourceIdentifierImpl; + import com.sun.org.apache.xerces.internal.util.XMLStringBuffer; ++import com.sun.org.apache.xerces.internal.utils.XMLLimitAnalyzer; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.Augmentations; + import com.sun.org.apache.xerces.internal.xni.XMLAttributes; + import com.sun.org.apache.xerces.internal.xni.XMLResourceIdentifier; +@@ -105,6 +107,9 @@ + protected static final String ENTITY_MANAGER = + Constants.XERCES_PROPERTY_PREFIX + Constants.ENTITY_MANAGER_PROPERTY; + ++ /** Property identifier: Security manager. */ ++ private static final String SECURITY_MANAGER = Constants.SECURITY_MANAGER; ++ + // debugging + + /** Debug attribute normalization. */ +@@ -158,6 +163,12 @@ + /** xxx this should be available from EntityManager Entity storage */ + protected XMLEntityStorage fEntityStore = null ; + ++ /** Security manager. */ ++ protected XMLSecurityManager fSecurityManager = null; ++ ++ /** Limit analyzer. */ ++ protected XMLLimitAnalyzer fLimitAnalyzer = null; ++ + // protected data + + /** event type */ +@@ -259,6 +270,7 @@ + fSymbolTable = (SymbolTable)componentManager.getProperty(SYMBOL_TABLE); + fErrorReporter = (XMLErrorReporter)componentManager.getProperty(ERROR_REPORTER); + fEntityManager = (XMLEntityManager)componentManager.getProperty(ENTITY_MANAGER); ++ fSecurityManager = (XMLSecurityManager)componentManager.getProperty(SECURITY_MANAGER); + + //this step is extra because we have separated the storage of entity + fEntityStore = fEntityManager.getEntityStore() ; +@@ -309,6 +321,10 @@ + fEntityManager = (XMLEntityManager)value; + } + } ++ ++ if (propertyId.equals(SECURITY_MANAGER)) { ++ fSecurityManager = (XMLSecurityManager)value; ++ } + /*else if(propertyId.equals(Constants.STAX_PROPERTIES)){ + fStaxProperties = (HashMap)value; + //TODO::discuss with neeraj what are his thoughts on passing properties. +@@ -368,6 +384,8 @@ + fEntityManager = (XMLEntityManager)propertyManager.getProperty(ENTITY_MANAGER); + fEntityStore = fEntityManager.getEntityStore() ; + fEntityScanner = (XMLEntityScanner)fEntityManager.getEntityScanner() ; ++ fSecurityManager = (XMLSecurityManager)propertyManager.getProperty(SECURITY_MANAGER); ++ + //fEntityManager.reset(); + // DTD preparsing defaults: + fValidation = false; +@@ -526,8 +544,9 @@ + sawSpace = fEntityScanner.skipSpaces(); + } + // restore original literal value +- if(currLiteral) ++ if(currLiteral) { + currEnt.literal = true; ++ } + // REVISIT: should we remove this error reporting? + if (scanningTextDecl && state != STATE_DONE) { + reportFatalError("MorePseudoAttributes", null); +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/msg/XMLMessages.properties +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/msg/XMLMessages.properties Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/msg/XMLMessages.properties Tue Oct 29 08:01:29 2013 +0000 +@@ -289,8 +289,10 @@ + InvalidCharInLiteral=InvalidCharInLiteral + + +-#Application can set the limit of number of entities that should be expanded by the parser. +-EntityExpansionLimitExceeded=The parser has encountered more than \"{0}\" entity expansions in this document; this is the limit imposed by the application. ++# Implementation limits ++ EntityExpansionLimitExceeded=JAXP00010001: The parser has encountered more than \"{0}\" entity expansions in this document; this is the limit imposed by the JDK. ++ ElementAttributeLimit=JAXP00010002: Element \"{0}\" has more than \"{1}\" attributes, \"{1}\" is the limit imposed by the JDK. ++ MaxEntitySizeLimit=JAXP00010003: The length of entity \"{0}\" is \"{1}\" that exceeds the \"{2}\" limit set by \"{3}\". ++ TotalEntitySizeLimit=JAXP00010004: The accumulated size \"{0}\" of entities exceeded the \"{1}\" limit set by \"{2}\". ++ MaxXMLNameLimit=JAXP00010005: The name \"{0}\" exceeded the \"{1}\" limit set by \"{2}\". + +-# Application can set the limit of number of attributes of entity that should be expanded by the parser. +-ElementAttributeLimit= Element \"{0}\" has more than \"{1}\" attributes, \"{1}\" is the limit imposed by the application. +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/models/CMNodeFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/models/CMNodeFactory.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/models/CMNodeFactory.java Tue Oct 29 08:01:29 2013 +0000 +@@ -111,7 +111,8 @@ + } + + public void nodeCountCheck(){ +- if( fSecurityManager != null && nodeCount++ > maxNodeLimit){ ++ if( fSecurityManager != null && !fSecurityManager.isNoLimit(maxNodeLimit) && ++ nodeCount++ > maxNodeLimit){ + if(DEBUG){ + System.out.println("nodeCount = " + nodeCount ) ; + System.out.println("nodeLimit = " + maxNodeLimit ) ; +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -108,6 +108,8 @@ + /** Initial EntityResolver */ + private final EntityResolver fInitEntityResolver; + ++ private XMLSecurityManager fSecurityManager; ++ + DocumentBuilderImpl(DocumentBuilderFactoryImpl dbf, Hashtable dbfAttrs, Hashtable features) + throws SAXNotRecognizedException, SAXNotSupportedException { + this(dbf, dbfAttrs, features, false); +@@ -151,10 +153,8 @@ + domParser.setFeature(XINCLUDE_FEATURE, true); + } + +- // If the secure processing feature is on set a security manager. +- if (secureProcessing) { +- domParser.setProperty(SECURITY_MANAGER, new XMLSecurityManager()); +- } ++ fSecurityManager = new XMLSecurityManager(secureProcessing); ++ domParser.setProperty(SECURITY_MANAGER, fSecurityManager); + + this.grammar = dbf.getSchema(); + if (grammar != null) { +@@ -202,9 +202,9 @@ + String feature = (String)e.nextElement(); + boolean value = ((Boolean)features.get(feature)).booleanValue(); + domParser.setFeature(feature, value); +- } + } + } ++ } + + /** + * Set any DocumentBuilderFactory attributes of our underlying DOMParser +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java Tue Oct 29 08:01:29 2013 +0000 +@@ -105,6 +105,8 @@ + /** Initial EntityResolver */ + private final EntityResolver fInitEntityResolver; + ++ private final XMLSecurityManager fSecurityManager; ++ + /** + * Create a SAX parser with the associated features + * @param features Hashtable of SAX features, may be null +@@ -121,8 +123,9 @@ + SAXParserImpl(SAXParserFactoryImpl spf, Hashtable features, boolean secureProcessing) + throws SAXException + { ++ fSecurityManager = new XMLSecurityManager(secureProcessing); + // Instantiate a SAXParser directly and not through SAX so that we use the right ClassLoader +- xmlReader = new JAXPSAXParser(this); ++ xmlReader = new JAXPSAXParser(this, fSecurityManager); + + // JAXP "namespaceAware" == SAX Namespaces feature + // Note: there is a compatibility problem here with default values: +@@ -141,10 +144,7 @@ + xmlReader.setFeature0(XINCLUDE_FEATURE, true); + } + +- // If the secure processing feature is on set a security manager. +- if (secureProcessing) { +- xmlReader.setProperty0(SECURITY_MANAGER, new XMLSecurityManager()); +- } ++ xmlReader.setProperty0(SECURITY_MANAGER, fSecurityManager); + + // Set application's features, followed by validation features. + setFeatures(features); +@@ -326,14 +326,28 @@ + private HashMap fInitFeatures = new HashMap(); + private HashMap fInitProperties = new HashMap(); + private SAXParserImpl fSAXParser; ++ private XMLSecurityManager fSecurityManager; + + public JAXPSAXParser() { +- super(); ++ this(null, null); + } + +- JAXPSAXParser(SAXParserImpl saxParser) { ++ JAXPSAXParser(SAXParserImpl saxParser, XMLSecurityManager securityManager) { + super(); + fSAXParser = saxParser; ++ fSecurityManager = securityManager; ++ /** ++ * This class may be used directly. So initialize the security manager if ++ * it is null. ++ */ ++ if (fSecurityManager == null) { ++ fSecurityManager = new XMLSecurityManager(true); ++ try { ++ super.setProperty(SECURITY_MANAGER, fSecurityManager); ++ } catch (Exception ex) { ++ //shall not happen ++ } ++ } + } + + /** +@@ -349,7 +363,8 @@ + } + if (name.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { + try { +- setProperty(SECURITY_MANAGER, value ? new XMLSecurityManager() : null); ++ fSecurityManager.setSecureProcessing(value); ++ setProperty(SECURITY_MANAGER, fSecurityManager); + } + catch (SAXNotRecognizedException exc) { + // If the property is not supported +@@ -385,13 +400,7 @@ + throw new NullPointerException(); + } + if (name.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { +- try { +- return (super.getProperty(SECURITY_MANAGER) != null); +- } +- // If the property is not supported the value must be false. +- catch (SAXException exc) { +- return false; +- } ++ return fSecurityManager.isSecureProcessing(); + } + return super.getFeature(name); + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/AbstractXMLSchema.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/AbstractXMLSchema.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/AbstractXMLSchema.java Tue Oct 29 08:01:29 2013 +0000 +@@ -40,8 +40,15 @@ + */ + private final HashMap fFeatures; + ++ /** ++ * Map containing the initial values of properties for ++ * validators created using this grammar pool container. ++ */ ++ private final HashMap<String,Object> fProperties; ++ + public AbstractXMLSchema() { + fFeatures = new HashMap(); ++ fProperties = new HashMap<String,Object>(); + } + + /* +@@ -83,4 +90,20 @@ + fFeatures.put(featureId, state ? Boolean.TRUE : Boolean.FALSE); + } + ++ /** ++ * Returns the initial value of a property for validators created ++ * using this grammar pool container or null if the validators ++ * should use the default value. ++ */ ++ public final Object getProperty(String propertyId) { ++ return fProperties.get(propertyId); ++ } ++ ++ /* ++ * Set a property on the schema ++ */ ++ public final void setProperty(String propertyId, Object state) { ++ fProperties.put(propertyId, state); ++ } ++ + } // AbstractXMLSchema +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StAXValidatorHelper.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StAXValidatorHelper.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StAXValidatorHelper.java Tue Oct 29 08:01:29 2013 +0000 +@@ -25,6 +25,9 @@ + + package com.sun.org.apache.xerces.internal.jaxp.validation; + ++import com.sun.org.apache.xerces.internal.impl.Constants; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; ++ + import java.io.IOException; + + import javax.xml.transform.Result; +@@ -68,6 +71,19 @@ + if( identityTransformer1==null ) { + try { + SAXTransformerFactory tf = (SAXTransformerFactory)SAXTransformerFactory.newInstance(); ++ XMLSecurityManager securityManager = (XMLSecurityManager)fComponentManager.getProperty(Constants.SECURITY_MANAGER); ++ if (securityManager != null) { ++ for (XMLSecurityManager.Limit limit : XMLSecurityManager.Limit.values()) { ++ if (securityManager.isSet(limit.ordinal())){ ++ tf.setAttribute(limit.apiProperty(), ++ securityManager.getLimitValueAsString(limit)); ++ } ++ } ++ if (securityManager.printEntityCountInfo()) { ++ tf.setAttribute(Constants.JDK_ENTITY_COUNT_INFO, "yes"); ++ } ++ } ++ + identityTransformer1 = tf.newTransformer(); + identityTransformer2 = tf.newTransformerHandler(); + } catch (TransformerConfigurationException e) { +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java Tue Oct 29 08:01:29 2013 +0000 +@@ -184,6 +184,8 @@ + config.setDocumentHandler(fSchemaValidator); + config.setDTDHandler(null); + config.setDTDContentModelHandler(null); ++ config.setProperty(Constants.SECURITY_MANAGER, ++ fComponentManager.getProperty(Constants.SECURITY_MANAGER)); + fConfiguration = new SoftReference(config); + return config; + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 08:01:29 2013 +0000 +@@ -97,7 +97,7 @@ + /** The ErrorHandlerWrapper */ + private ErrorHandlerWrapper fErrorHandlerWrapper; + +- /** The XMLSecurityManager. */ ++ /** The SecurityManager. */ + private XMLSecurityManager fSecurityManager; + + /** The container for the real grammar pool. */ +@@ -113,7 +113,7 @@ + fXMLSchemaLoader.setErrorHandler(fErrorHandlerWrapper); + + // Enable secure processing feature by default +- fSecurityManager = new XMLSecurityManager(); ++ fSecurityManager = new XMLSecurityManager(true); + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + } + +@@ -292,7 +292,7 @@ + "property-not-supported", new Object [] {name})); + } + try { +- return fXMLSchemaLoader.getProperty(name); ++ return fXMLSchemaLoader.getProperty(name); + } + catch (XMLConfigurationException e) { + String identifier = e.getIdentifier(); +@@ -321,7 +321,9 @@ + SAXMessageFormatter.formatMessage(null, + "jaxp-secureprocessing-feature", null)); + } ++ + fSecurityManager = value ? new XMLSecurityManager() : null; ++ fSecurityManager.setSecureProcessing(value); + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + return; + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java Tue Oct 29 08:01:29 2013 +0000 +@@ -173,7 +173,7 @@ + private final HashMap fInitProperties = new HashMap(); + + /** Stores the initial security manager. */ +- private final XMLSecurityManager fInitSecurityManager; ++ private XMLSecurityManager fInitSecurityManager; + + // + // User Objects +@@ -210,12 +210,6 @@ + fComponents.put(ENTITY_RESOLVER, null); + fComponents.put(ERROR_HANDLER, null); + +- if (System.getSecurityManager() != null) { +- _isSecureMode = true; +- setProperty(SECURITY_MANAGER, new XMLSecurityManager()); +- } else { +- fComponents.put(SECURITY_MANAGER, null); +- } + fComponents.put(SYMBOL_TABLE, new SymbolTable()); + + // setup grammar pool +@@ -230,15 +224,21 @@ + addRecognizedParamsAndSetDefaults(fErrorReporter, grammarContainer); + addRecognizedParamsAndSetDefaults(fSchemaValidator, grammarContainer); + +- // if the secure processing feature is set to true, add a security manager to the configuration +- Boolean secureProcessing = grammarContainer.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING); +- if (Boolean.TRUE.equals(secureProcessing)) { +- fInitSecurityManager = new XMLSecurityManager(); ++ boolean secureProcessing = grammarContainer.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING); ++ if (System.getSecurityManager() != null) { ++ _isSecureMode = true; ++ secureProcessing = true; + } +- else { +- fInitSecurityManager = null; ++ ++ fInitSecurityManager = (XMLSecurityManager) ++ grammarContainer.getProperty(SECURITY_MANAGER); ++ if (fInitSecurityManager != null ) { ++ fInitSecurityManager.setSecureProcessing(secureProcessing); ++ } else { ++ fInitSecurityManager = new XMLSecurityManager(secureProcessing); + } +- fComponents.put(SECURITY_MANAGER, fInitSecurityManager); ++ ++ setProperty(SECURITY_MANAGER, fInitSecurityManager); + + } + +@@ -266,7 +266,7 @@ + return fUseGrammarPoolOnly; + } + else if (XMLConstants.FEATURE_SECURE_PROCESSING.equals(featureId)) { +- return getProperty(SECURITY_MANAGER) != null; ++ return fInitSecurityManager.isSecureProcessing(); + } + else if (SCHEMA_ELEMENT_DEFAULT.equals(featureId)) { + return true; //pre-condition: VALIDATION and SCHEMA_VALIDATION are always true +@@ -296,7 +296,8 @@ + if (_isSecureMode && !value) { + throw new XMLConfigurationException(XMLConfigurationException.NOT_ALLOWED, XMLConstants.FEATURE_SECURE_PROCESSING); + } +- setProperty(SECURITY_MANAGER, value ? new XMLSecurityManager() : null); ++ fInitSecurityManager.setSecureProcessing(value); ++ setProperty(SECURITY_MANAGER, fInitSecurityManager); + return; + } + fConfigUpdated = true; +@@ -366,10 +367,12 @@ + fComponents.put(propertyId, value); + return; + } +- if (!fInitProperties.containsKey(propertyId)) { +- fInitProperties.put(propertyId, super.getProperty(propertyId)); +- } +- super.setProperty(propertyId, value); ++ ++ //fall back to the existing property manager ++ if (!fInitProperties.containsKey(propertyId)) { ++ fInitProperties.put(propertyId, super.getProperty(propertyId)); ++ } ++ super.setProperty(propertyId, value); + } + + /** +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XSGrammarPoolContainer.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XSGrammarPoolContainer.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XSGrammarPoolContainer.java Tue Oct 29 08:01:29 2013 +0000 +@@ -54,4 +54,11 @@ + */ + public Boolean getFeature(String featureId); + ++ /** ++ * Returns the initial value of a property for validators created ++ * using this grammar pool container or null if the validators ++ * should use the default value. ++ */ ++ public Object getProperty(String propertyId); ++ + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java Tue Oct 29 08:01:29 2013 +0000 +@@ -22,6 +22,7 @@ + + import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.util.SymbolTable; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarPool; + import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; + +@@ -73,6 +74,7 @@ + XMLGRAMMAR_POOL, + }; + ++ XMLSecurityManager securityManager; + // + // Constructors + // +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SecurityConfiguration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SecurityConfiguration.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SecurityConfiguration.java Tue Oct 29 08:01:29 2013 +0000 +@@ -44,6 +44,7 @@ + * + * @author Neil Graham, IBM + * ++ * @version $Id: SecurityConfiguration.java,v 1.6 2010-11-01 04:40:09 joehw Exp $ + */ + public class SecurityConfiguration extends XIncludeAwareParserConfiguration + { +@@ -106,8 +107,8 @@ + XMLComponentManager parentSettings) { + super(symbolTable, grammarPool, parentSettings); + +- // create the XMLSecurityManager property: +- setProperty(SECURITY_MANAGER_PROPERTY, new XMLSecurityManager()); ++ // create the SecurityManager property: ++ setProperty(SECURITY_MANAGER_PROPERTY, new XMLSecurityManager(true)); + } // <init>(SymbolTable,XMLGrammarPool) + + } // class SecurityConfiguration +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java Tue Oct 29 08:01:29 2013 +0000 +@@ -20,6 +20,12 @@ + + package com.sun.org.apache.xerces.internal.parsers; + ++import java.io.IOException; ++import java.util.ArrayList; ++import java.util.HashMap; ++import java.util.Locale; ++import javax.xml.XMLConstants; ++ + import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.impl.XML11DTDScannerImpl; + import com.sun.org.apache.xerces.internal.impl.XML11DocumentScannerImpl; +@@ -44,6 +50,7 @@ + import com.sun.org.apache.xerces.internal.impl.xs.XSMessageFormatter; + import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings; + import com.sun.org.apache.xerces.internal.util.SymbolTable; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XMLDTDContentModelHandler; + import com.sun.org.apache.xerces.internal.xni.XMLDTDHandler; + import com.sun.org.apache.xerces.internal.xni.XMLDocumentHandler; +@@ -60,11 +67,6 @@ + import com.sun.org.apache.xerces.internal.xni.parser.XMLErrorHandler; + import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; + import com.sun.org.apache.xerces.internal.xni.parser.XMLPullParserConfiguration; +-import java.io.IOException; +-import java.util.ArrayList; +-import java.util.HashMap; +-import java.util.Locale; +-import javax.xml.XMLConstants; + + /** + * This class is the configuration used to parse XML 1.0 and XML 1.1 documents. +@@ -259,6 +261,9 @@ + protected static final String LOCALE = + Constants.XERCES_PROPERTY_PREFIX + Constants.LOCALE_PROPERTY; + ++ /** Property identifier: Security manager. */ ++ private static final String SECURITY_MANAGER = Constants.SECURITY_MANAGER; ++ + // debugging + + /** Set to true and recompile to print exception stack trace. */ +@@ -268,33 +273,33 @@ + // Data + // + +- protected SymbolTable fSymbolTable; ++ protected SymbolTable fSymbolTable; + protected XMLInputSource fInputSource; + protected ValidationManager fValidationManager; +- protected XMLVersionDetector fVersionDetector; ++ protected XMLVersionDetector fVersionDetector; + protected XMLLocator fLocator; +- protected Locale fLocale; ++ protected Locale fLocale; + +- /** XML 1.0 Components. */ +- protected ArrayList fComponents; ++ /** XML 1.0 Components. */ ++ protected ArrayList fComponents; + +- /** XML 1.1. Components. */ +- protected ArrayList fXML11Components = null; +- +- /** Common components: XMLEntityManager, XMLErrorReporter, XMLSchemaValidator */ +- protected ArrayList fCommonComponents = null; ++ /** XML 1.1. Components. */ ++ protected ArrayList fXML11Components = null; ++ ++ /** Common components: XMLEntityManager, XMLErrorReporter, XMLSchemaValidator */ ++ protected ArrayList fCommonComponents = null; + +- /** The document handler. */ +- protected XMLDocumentHandler fDocumentHandler; ++ /** The document handler. */ ++ protected XMLDocumentHandler fDocumentHandler; + +- /** The DTD handler. */ +- protected XMLDTDHandler fDTDHandler; ++ /** The DTD handler. */ ++ protected XMLDTDHandler fDTDHandler; ++ ++ /** The DTD content model handler. */ ++ protected XMLDTDContentModelHandler fDTDContentModelHandler; + +- /** The DTD content model handler. */ +- protected XMLDTDContentModelHandler fDTDContentModelHandler; +- +- /** Last component in the document pipeline */ +- protected XMLDocumentSource fLastComponent; ++ /** Last component in the document pipeline */ ++ protected XMLDocumentSource fLastComponent; + + /** + * True if a parse is in progress. This state is needed because +@@ -510,6 +515,7 @@ + SCHEMA_LOCATION, + SCHEMA_NONS_LOCATION, + LOCALE, ++ SECURITY_MANAGER, + }; + addRecognizedProperties(recognizedProperties); + +@@ -557,6 +563,8 @@ + + fVersionDetector = new XMLVersionDetector(); + ++ fProperties.put(SECURITY_MANAGER, new XMLSecurityManager(true)); ++ + // add message formatters + if (fErrorReporter.getMessageFormatter(XMLMessageFormatter.XML_DOMAIN) == null) { + XMLMessageFormatter xmft = new XMLMessageFormatter(); +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/SecuritySupport.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/SecuritySupport.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/SecuritySupport.java Tue Oct 29 08:01:29 2013 +0000 +@@ -23,6 +23,7 @@ + import java.io.File; + import java.io.FileInputStream; + import java.io.FileNotFoundException; ++import java.io.IOException; + import java.io.InputStream; + + import java.security.AccessController; +@@ -31,6 +32,7 @@ + import java.security.PrivilegedExceptionAction; + import java.util.Locale; + import java.util.MissingResourceException; ++import java.util.Properties; + import java.util.PropertyResourceBundle; + import java.util.ResourceBundle; + +@@ -195,5 +197,55 @@ + })).longValue(); + } + ++ /** ++ * Read from $java.home/lib/jaxp.properties for the specified property ++ * The program ++ * ++ * @param propertyId the Id of the property ++ * @return the value of the property ++ */ ++ static String readJAXPProperty(String propertyId) { ++ String value = null; ++ InputStream is = null; ++ try { ++ if (firstTime) { ++ synchronized (cacheProps) { ++ if (firstTime) { ++ String configFile = getSystemProperty("java.home") + File.separator + ++ "lib" + File.separator + "jaxp.properties"; ++ File f = new File(configFile); ++ if (getFileExists(f)) { ++ is = getFileInputStream(f); ++ cacheProps.load(is); ++ } ++ firstTime = false; ++ } ++ } ++ } ++ value = cacheProps.getProperty(propertyId); ++ ++ } ++ catch (Exception ex) {} ++ finally { ++ if (is != null) { ++ try { ++ is.close(); ++ } catch (IOException ex) {} ++ } ++ } ++ ++ return value; ++ } ++ ++ /** ++ * Cache for properties in java.home/lib/jaxp.properties ++ */ ++ static final Properties cacheProps = new Properties(); ++ ++ /** ++ * Flag indicating if the program has tried reading java.home/lib/jaxp.properties ++ */ ++ static volatile boolean firstTime = true; ++ + private SecuritySupport () {} + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLLimitAnalyzer.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLLimitAnalyzer.java Tue Oct 29 08:01:29 2013 +0000 +@@ -0,0 +1,236 @@ ++/* ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. ++ * ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * ++ * The contents of this file are subject to the terms of either the GNU ++ * General Public License Version 2 only ("GPL") or the Common Development ++ * and Distribution License("CDDL") (collectively, the "License"). You ++ * may not use this file except in compliance with the License. You can ++ * obtain a copy of the License at ++ * https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html ++ * or packager/legal/LICENSE.txt. See the License for the specific ++ * language governing permissions and limitations under the License. ++ * ++ * When distributing the software, include this License Header Notice in each ++ * file and include the License file at packager/legal/LICENSE.txt. ++ * ++ * GPL Classpath Exception: ++ * Oracle designates this particular file as subject to the "Classpath" ++ * exception as provided by Oracle in the GPL Version 2 section of the License ++ * file that accompanied this code. ++ * ++ * Modifications: ++ * If applicable, add the following below the License Header, with the fields ++ * enclosed by brackets [] replaced by your own identifying information: ++ * "Portions Copyright [year] [name of copyright owner]" ++ * ++ * Contributor(s): ++ * If you wish your version of this file to be governed by only the CDDL or ++ * only the GPL Version 2, indicate your decision by adding "[Contributor] ++ * elects to include this software in this distribution under the [CDDL or GPL ++ * Version 2] license." If you don't indicate a single choice of license, a ++ * recipient has the option to distribute your version of this file under ++ * either the CDDL, the GPL Version 2 or to extend the choice of license to ++ * its licensees as provided above. However, if you add GPL Version 2 code ++ * and therefore, elected the GPL Version 2 license, then the option applies ++ * only if the new code is made subject to such option by the copyright ++ * holder. ++ */ ++package com.sun.org.apache.xerces.internal.utils; ++ ++import com.sun.org.apache.xerces.internal.impl.Constants; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager.Limit; ++import java.util.Formatter; ++import java.util.HashMap; ++import java.util.Map; ++ ++/** ++ * A helper for analyzing entity expansion limits ++ * ++ * @author Joe Wang Oracle Corp. ++ * ++ */ ++public final class XMLLimitAnalyzer { ++ ++ /** ++ * Map old property names with the new ones ++ */ ++ public static enum NameMap { ++ ENTITY_EXPANSION_LIMIT(Constants.SP_ENTITY_EXPANSION_LIMIT, Constants.ENTITY_EXPANSION_LIMIT), ++ MAX_OCCUR_NODE_LIMIT(Constants.SP_MAX_OCCUR_LIMIT, Constants.MAX_OCCUR_LIMIT), ++ ELEMENT_ATTRIBUTE_LIMIT(Constants.SP_ELEMENT_ATTRIBUTE_LIMIT, Constants.ELEMENT_ATTRIBUTE_LIMIT); ++ ++ final String newName; ++ final String oldName; ++ ++ NameMap(String newName, String oldName) { ++ this.newName = newName; ++ this.oldName = oldName; ++ } ++ ++ String getOldName(String newName) { ++ if (newName.equals(this.newName)) { ++ return oldName; ++ } ++ return null; ++ } ++ } ++ ++ private XMLSecurityManager securityManager; ++ /** ++ * Max value accumulated for each property ++ */ ++ private final int[] values; ++ /** ++ * Names of the entities corresponding to their max values ++ */ ++ private final String[] names; ++ /** ++ * Total value of accumulated entities ++ */ ++ private final int[] totalValue; ++ ++ /** ++ * Maintain values of the top 10 elements in the process of parsing ++ */ ++ private final Map[] caches; ++ ++ private String entityStart, entityEnd; ++ /** ++ * Default constructor. Establishes default values for known security ++ * vulnerabilities. ++ */ ++ public XMLLimitAnalyzer(XMLSecurityManager securityManager) { ++ this.securityManager = securityManager; ++ values = new int[Limit.values().length]; ++ totalValue = new int[Limit.values().length]; ++ names = new String[Limit.values().length]; ++ caches = new Map[Limit.values().length]; ++ } ++ ++ /** ++ * Add the value to the current max count for the specified property ++ * To find the max value of all entities, set no limit ++ * ++ * @param limit the type of the property ++ * @param entityName the name of the entity ++ * @param value the value of the entity ++ */ ++ public void addValue(Limit limit, String entityName, int value) { ++ addValue(limit.ordinal(), entityName, value); ++ } ++ ++ /** ++ * Add the value to the current count by the index of the property ++ * @param index the index of the property ++ * @param entityName the name of the entity ++ * @param value the value of the entity ++ */ ++ public void addValue(int index, String entityName, int value) { ++ if (index == Limit.ENTITY_EXPANSION_LIMIT.ordinal() || ++ index == Limit.MAX_OCCUR_NODE_LIMIT.ordinal() || ++ index == Limit.ELEMENT_ATTRIBUTE_LIMIT.ordinal()) { ++ totalValue[index] += value; ++ return; ++ } ++ ++ Map<String, Integer> cache; ++ if (caches[index] == null) { ++ cache = new HashMap<String, Integer>(10); ++ caches[index] = cache; ++ } else { ++ cache = caches[index]; ++ } ++ ++ int accumulatedValue = value; ++ if (cache.containsKey(entityName)) { ++ accumulatedValue += cache.get(entityName).intValue(); ++ cache.put(entityName, Integer.valueOf(accumulatedValue)); ++ } else { ++ cache.put(entityName, Integer.valueOf(value)); ++ } ++ ++ if (accumulatedValue > values[index]) { ++ values[index] = accumulatedValue; ++ names[index] = entityName; ++ } ++ ++ ++ if (index == Limit.GENEAL_ENTITY_SIZE_LIMIT.ordinal() || ++ index == Limit.PARAMETER_ENTITY_SIZE_LIMIT.ordinal()) { ++ totalValue[Limit.TOTAL_ENTITY_SIZE_LIMIT.ordinal()] += value; ++ } ++ } ++ ++ /** ++ * Return the value of the current max count for the specified property ++ * ++ * @param limit the property ++ * @return the value of the property ++ */ ++ public int getValue(Limit limit) { ++ return values[limit.ordinal()]; ++ } ++ ++ public int getValue(int index) { ++ return values[index]; ++ } ++ /** ++ * Return the total value accumulated so far ++ * ++ * @param limit the property ++ * @return the accumulated value of the property ++ */ ++ public int getTotalValue(Limit limit) { ++ return totalValue[limit.ordinal()]; ++ } ++ ++ public int getTotalValue(int index) { ++ return totalValue[index]; ++ } ++ /** ++ * Return the current max value (count or length) by the index of a property ++ * @param index the index of a property ++ * @return count of a property ++ */ ++ public int getValueByIndex(int index) { ++ return values[index]; ++ } ++ ++ public void startEntity(String name) { ++ entityStart = name; ++ } ++ ++ public boolean isTracking(String name) { ++ return entityStart.equals(name); ++ } ++ /** ++ * Stop tracking the entity ++ * @param limit the limit property ++ * @param name the name of an entity ++ */ ++ public void endEntity(Limit limit, String name) { ++ entityStart = ""; ++ Map<String, Integer> cache = caches[limit.ordinal()]; ++ if (cache != null) { ++ cache.remove(name); ++ } ++ } ++ ++ public void debugPrint() { ++ Formatter formatter = new Formatter(); ++ System.out.println(formatter.format("%30s %15s %15s %15s %30s", ++ "Property","Limit","Total size","Size","Entity Name")); ++ ++ for (Limit limit : Limit.values()) { ++ formatter = new Formatter(); ++ System.out.println(formatter.format("%30s %15d %15d %15d %30s", ++ limit.name(), ++ securityManager.getLimit(limit), ++ totalValue[limit.ordinal()], ++ values[limit.ordinal()], ++ names[limit.ordinal()])); ++ } ++ } ++} +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java Tue Oct 29 08:01:29 2013 +0000 +@@ -40,108 +40,482 @@ + */ + public static enum State { + //this order reflects the overriding order +- DEFAULT, FSP, JAXPDOTPROPERTIES, SYSTEMPROPERTY, APIPROPERTY ++ ++ DEFAULT("default"), FSP("FEATURE_SECURE_PROCESSING"), ++ JAXPDOTPROPERTIES("jaxp.properties"), SYSTEMPROPERTY("system property"), ++ APIPROPERTY("property"); ++ ++ final String literal; ++ State(String literal) { ++ this.literal = literal; ++ } ++ ++ String literal() { ++ return literal; ++ } + } + + /** + * Limits managed by the security manager + */ + public static enum Limit { +- ENTITY_EXPANSION_LIMIT(64000), +- MAX_OCCUR_NODE_LIMIT(5000), +- ELEMENT_ATTRIBUTE_LIMIT(10000); + ++ ENTITY_EXPANSION_LIMIT(Constants.JDK_ENTITY_EXPANSION_LIMIT, Constants.SP_ENTITY_EXPANSION_LIMIT, 0, 64000), ++ MAX_OCCUR_NODE_LIMIT(Constants.JDK_MAX_OCCUR_LIMIT, Constants.SP_MAX_OCCUR_LIMIT, 0, 5000), ++ ELEMENT_ATTRIBUTE_LIMIT(Constants.JDK_ELEMENT_ATTRIBUTE_LIMIT, Constants.SP_ELEMENT_ATTRIBUTE_LIMIT, 0, 10000), ++ TOTAL_ENTITY_SIZE_LIMIT(Constants.JDK_TOTAL_ENTITY_SIZE_LIMIT, Constants.SP_TOTAL_ENTITY_SIZE_LIMIT, 0, 50000000), ++ GENEAL_ENTITY_SIZE_LIMIT(Constants.JDK_GENEAL_ENTITY_SIZE_LIMIT, Constants.SP_GENEAL_ENTITY_SIZE_LIMIT, 0, 0), ++ PARAMETER_ENTITY_SIZE_LIMIT(Constants.JDK_PARAMETER_ENTITY_SIZE_LIMIT, Constants.SP_PARAMETER_ENTITY_SIZE_LIMIT, 0, 1000000); ++ ++ final String apiProperty; ++ final String systemProperty; + final int defaultValue; ++ final int secureValue; + +- Limit(int value) { ++ Limit(String apiProperty, String systemProperty, int value, int secureValue) { ++ this.apiProperty = apiProperty; ++ this.systemProperty = systemProperty; + this.defaultValue = value; ++ this.secureValue = secureValue; ++ } ++ ++ public boolean equalsAPIPropertyName(String propertyName) { ++ return (propertyName == null) ? false : apiProperty.equals(propertyName); ++ } ++ ++ public boolean equalsSystemPropertyName(String propertyName) { ++ return (propertyName == null) ? false : systemProperty.equals(propertyName); ++ } ++ ++ public String apiProperty() { ++ return apiProperty; ++ } ++ ++ String systemProperty() { ++ return systemProperty; + } + + int defaultValue() { + return defaultValue; + } ++ ++ int secureValue() { ++ return secureValue; ++ } + } + + /** +- * Values of the limits as defined in enum Limit ++ * Map old property names with the new ones + */ +- private final int[] limits; ++ public static enum NameMap { ++ ++ ENTITY_EXPANSION_LIMIT(Constants.SP_ENTITY_EXPANSION_LIMIT, Constants.ENTITY_EXPANSION_LIMIT), ++ MAX_OCCUR_NODE_LIMIT(Constants.SP_MAX_OCCUR_LIMIT, Constants.MAX_OCCUR_LIMIT), ++ ELEMENT_ATTRIBUTE_LIMIT(Constants.SP_ELEMENT_ATTRIBUTE_LIMIT, Constants.ELEMENT_ATTRIBUTE_LIMIT); ++ final String newName; ++ final String oldName; ++ ++ NameMap(String newName, String oldName) { ++ this.newName = newName; ++ this.oldName = oldName; ++ } ++ ++ String getOldName(String newName) { ++ if (newName.equals(this.newName)) { ++ return oldName; ++ } ++ return null; ++ } ++ } ++ private static final int NO_LIMIT = 0; + /** +- * States of the settings for each limit in limits above ++ * Values of the properties + */ +- private State[] states = {State.DEFAULT, State.DEFAULT, State.DEFAULT, State.DEFAULT}; ++ private final int[] values; ++ /** ++ * States of the settings for each property ++ */ ++ private State[] states; ++ /** ++ * Flag indicating if secure processing is set ++ */ ++ boolean secureProcessing; ++ ++ /** ++ * States that determine if properties are set explicitly ++ */ ++ private boolean[] isSet; ++ ++ ++ private XMLLimitAnalyzer limitAnalyzer; ++ /** ++ * Index of the special entityCountInfo property ++ */ ++ private int indexEntityCountInfo = 10000; ++ private String printEntityCountInfo = ""; + + /** + * Default constructor. Establishes default values for known security + * vulnerabilities. + */ + public XMLSecurityManager() { +- limits = new int[Limit.values().length]; ++ this(false); ++ } ++ ++ /** ++ * Instantiate Security Manager in accordance with the status of ++ * secure processing ++ * @param secureProcessing ++ */ ++ public XMLSecurityManager(boolean secureProcessing) { ++ limitAnalyzer = new XMLLimitAnalyzer(this); ++ values = new int[Limit.values().length]; ++ states = new State[Limit.values().length]; ++ isSet = new boolean[Limit.values().length]; ++ this.secureProcessing = secureProcessing; + for (Limit limit : Limit.values()) { +- limits[limit.ordinal()] = limit.defaultValue(); ++ if (secureProcessing) { ++ values[limit.ordinal()] = limit.secureValue; ++ states[limit.ordinal()] = State.FSP; ++ } else { ++ values[limit.ordinal()] = limit.defaultValue(); ++ states[limit.ordinal()] = State.DEFAULT; ++ } + } + //read system properties or jaxp.properties + readSystemProperties(); + } + + /** +- * Sets the limit for a specific type of XML constructs. This can be either +- * the size or the number of the constructs. +- * +- * @param type the type of limitation +- * @param state the state of limitation +- * @param limit the limit to the type ++ * Setting FEATURE_SECURE_PROCESSING explicitly + */ +- public void setLimit(Limit limit, State state, int value) { +- //only update if it shall override +- if (state.compareTo(states[limit.ordinal()]) >= 0) { +- limits[limit.ordinal()] = value; +- states[limit.ordinal()] = state; ++ public void setSecureProcessing(boolean secure) { ++ secureProcessing = secure; ++ for (Limit limit : Limit.values()) { ++ if (secure) { ++ setLimit(limit.ordinal(), State.FSP, limit.secureValue()); ++ } else { ++ setLimit(limit.ordinal(), State.FSP, limit.defaultValue()); ++ } + } + } + + /** +- * Returns the limit set for the type specified ++ * Return the state of secure processing ++ * @return the state of secure processing ++ */ ++ public boolean isSecureProcessing() { ++ return secureProcessing; ++ } ++ ++ ++ /** ++ * Set limit by property name and state ++ * @param propertyName property name ++ * @param state the state of the property ++ * @param value the value of the property ++ * @return true if the property is managed by the security manager; false ++ * if otherwise. ++ */ ++ public boolean setLimit(String propertyName, State state, Object value) { ++ int index = getIndex(propertyName); ++ if (index > -1) { ++ setLimit(index, state, value); ++ return true; ++ } ++ return false; ++ } ++ ++ /** ++ * Set the value for a specific limit. + * +- * @param limit the type of limitation +- * @return the limit to the type ++ * @param limit the limit ++ * @param state the state of the property ++ * @param value the value of the property ++ */ ++ public void setLimit(Limit limit, State state, int value) { ++ setLimit(limit.ordinal(), state, value); ++ } ++ ++ /** ++ * Set the value of a property by its index ++ * ++ * @param index the index of the property ++ * @param state the state of the property ++ * @param value the value of the property ++ */ ++ public void setLimit(int index, State state, Object value) { ++ if (index == indexEntityCountInfo) { ++ printEntityCountInfo = (String)value; ++ } else { ++ int temp = 0; ++ try { ++ temp = Integer.parseInt((String) value); ++ if (temp < 0) { ++ temp = 0; ++ } ++ } catch (NumberFormatException e) {} ++ setLimit(index, state, temp); ++ } ++ } ++ ++ /** ++ * Set the value of a property by its index ++ * ++ * @param index the index of the property ++ * @param state the state of the property ++ * @param value the value of the property ++ */ ++ public void setLimit(int index, State state, int value) { ++ if (index == indexEntityCountInfo) { ++ //if it's explicitly set, it's treated as yes no matter the value ++ printEntityCountInfo = Constants.JDK_YES; ++ } else { ++ //only update if it shall override ++ if (state.compareTo(states[index]) >= 0) { ++ values[index] = value; ++ states[index] = state; ++ isSet[index] = true; ++ } ++ } ++ } ++ ++ /** ++ * Return the value of the specified property ++ * ++ * @param propertyName the property name ++ * @return the value of the property as a string. If a property is managed ++ * by this manager, its value shall not be null. ++ */ ++ public String getLimitAsString(String propertyName) { ++ int index = getIndex(propertyName); ++ if (index > -1) { ++ return getLimitValueByIndex(index); ++ } ++ ++ return null; ++ } ++ /** ++ * Return the value of the specified property ++ * ++ * @param limit the property ++ * @return the value of the property + */ + public int getLimit(Limit limit) { +- return limits[limit.ordinal()]; ++ return values[limit.ordinal()]; ++ } ++ ++ /** ++ * Return the value of a property by its ordinal ++ * ++ * @param limit the property ++ * @return value of a property ++ */ ++ public String getLimitValueAsString(Limit limit) { ++ return Integer.toString(values[limit.ordinal()]); ++ } ++ ++ /** ++ * Return the value of a property by its ordinal ++ * ++ * @param index the index of a property ++ * @return limit of a property as a string ++ */ ++ public String getLimitValueByIndex(int index) { ++ if (index == indexEntityCountInfo) { ++ return printEntityCountInfo; ++ } ++ ++ return Integer.toString(values[index]); ++ } ++ ++ /** ++ * Return the state of the limit property ++ * ++ * @param limit the limit ++ * @return the state of the limit property ++ */ ++ public State getState(Limit limit) { ++ return states[limit.ordinal()]; ++ } ++ ++ /** ++ * Return the state of the limit property ++ * ++ * @param limit the limit ++ * @return the state of the limit property ++ */ ++ public String getStateLiteral(Limit limit) { ++ return states[limit.ordinal()].literal(); ++ } ++ ++ /** ++ * Get the index by property name ++ * ++ * @param propertyName property name ++ * @return the index of the property if found; return -1 if not ++ */ ++ public int getIndex(String propertyName) { ++ for (Limit limit : Limit.values()) { ++ if (limit.equalsAPIPropertyName(propertyName)) { ++ //internally, ordinal is used as index ++ return limit.ordinal(); ++ } ++ } ++ //special property to return entity count info ++ if (propertyName.equals(Constants.JDK_ENTITY_COUNT_INFO)) { ++ return indexEntityCountInfo; ++ } ++ return -1; ++ } ++ ++ /** ++ * Check if there's no limit defined by the Security Manager ++ * @param limit ++ * @return ++ */ ++ public boolean isNoLimit(int limit) { ++ return limit==NO_LIMIT; ++ } ++ /** ++ * Check if the size (length or count) of the specified limit property is ++ * over the limit ++ * ++ * @param limit the type of the limit property ++ * @param entityName the name of the entity ++ * @param size the size (count or length) of the entity ++ * @return true if the size is over the limit, false otherwise ++ */ ++ public boolean isOverLimit(Limit limit, String entityName, int size) { ++ return isOverLimit(limit.ordinal(), entityName, size); ++ } ++ ++ /** ++ * Check if the value (length or count) of the specified limit property is ++ * over the limit ++ * ++ * @param index the index of the limit property ++ * @param entityName the name of the entity ++ * @param size the size (count or length) of the entity ++ * @return true if the size is over the limit, false otherwise ++ */ ++ public boolean isOverLimit(int index, String entityName, int size) { ++ if (values[index] == NO_LIMIT) { ++ return false; ++ } ++ if (size > values[index]) { ++ limitAnalyzer.addValue(index, entityName, size); ++ return true; ++ } ++ return false; ++ } ++ ++ /** ++ * Check against cumulated value ++ * ++ * @param limit the type of the limit property ++ * @param size the size (count or length) of the entity ++ * @return true if the size is over the limit, false otherwise ++ */ ++ public boolean isOverLimit(Limit limit) { ++ return isOverLimit(limit.ordinal()); ++ } ++ ++ public boolean isOverLimit(int index) { ++ if (values[index] == NO_LIMIT) { ++ return false; ++ } ++ ++ if (index==Limit.ELEMENT_ATTRIBUTE_LIMIT.ordinal() || ++ index==Limit.ENTITY_EXPANSION_LIMIT.ordinal() || ++ index==Limit.TOTAL_ENTITY_SIZE_LIMIT.ordinal()) { ++ return (limitAnalyzer.getTotalValue(index) > values[index]); ++ } else { ++ return (limitAnalyzer.getValue(index) > values[index]); ++ } ++ } ++ ++ public void debugPrint() { ++ if (printEntityCountInfo.equals(Constants.JDK_YES)) { ++ limitAnalyzer.debugPrint(); ++ } ++ } ++ ++ /** ++ * Return the limit analyzer ++ * ++ * @return the limit analyzer ++ */ ++ public XMLLimitAnalyzer getLimitAnalyzer() { ++ return limitAnalyzer; ++ } ++ ++ /** ++ * Set limit analyzer ++ * ++ * @param analyzer a limit analyzer ++ */ ++ public void setLimitAnalyzer(XMLLimitAnalyzer analyzer) { ++ limitAnalyzer = analyzer; ++ } ++ ++ /** ++ * Indicate if a property is set explicitly ++ * @param index ++ * @return ++ */ ++ public boolean isSet(int index) { ++ return isSet[index]; ++ } ++ ++ public boolean printEntityCountInfo() { ++ return printEntityCountInfo.equals(Constants.JDK_YES); + } + + /** + * Read from system properties, or those in jaxp.properties + */ + private void readSystemProperties() { +- getSystemProperty(Limit.ENTITY_EXPANSION_LIMIT, Constants.ENTITY_EXPANSION_LIMIT); +- getSystemProperty(Limit.MAX_OCCUR_NODE_LIMIT, Constants.MAX_OCCUR_LIMIT); +- getSystemProperty(Limit.ELEMENT_ATTRIBUTE_LIMIT, +- Constants.SYSTEM_PROPERTY_ELEMENT_ATTRIBUTE_LIMIT); ++ ++ for (Limit limit : Limit.values()) { ++ if (!getSystemProperty(limit, limit.systemProperty())) { ++ //if system property is not found, try the older form if any ++ for (NameMap nameMap : NameMap.values()) { ++ String oldName = nameMap.getOldName(limit.systemProperty()); ++ if (oldName != null) { ++ getSystemProperty(limit, oldName); ++ } ++ } ++ } ++ } ++ + } + + /** + * Read from system properties, or those in jaxp.properties + * +- * @param limit the type of the property +- * @param property the property name ++ * @param property the type of the property ++ * @param sysPropertyName the name of system property + */ +- private void getSystemProperty(Limit limit, String property) { ++ private boolean getSystemProperty(Limit limit, String sysPropertyName) { + try { +- String value = SecuritySupport.getSystemProperty(property); ++ String value = SecuritySupport.getSystemProperty(sysPropertyName); + if (value != null && !value.equals("")) { +- limits[limit.ordinal()] = Integer.parseInt(value); ++ values[limit.ordinal()] = Integer.parseInt(value); + states[limit.ordinal()] = State.SYSTEMPROPERTY; +- return; ++ return true; + } + +- value = SecuritySupport.readJAXPProperty(property); ++ value = SecuritySupport.readJAXPProperty(sysPropertyName); + if (value != null && !value.equals("")) { +- limits[limit.ordinal()] = Integer.parseInt(value); ++ values[limit.ordinal()] = Integer.parseInt(value); + states[limit.ordinal()] = State.JAXPDOTPROPERTIES; ++ return true; + } + } catch (NumberFormatException e) { +- //invalid setting ignored ++ //invalid setting ++ throw new NumberFormatException("Invalid setting for system property: " + limit.systemProperty()); + } ++ return false; + } + } +diff -r 3dc769c632a1 -r 0927621944cc drop_included/jaxp_src/src/com/sun/org/apache/xml/internal/utils/XMLReaderManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xml/internal/utils/XMLReaderManager.java Tue Oct 29 07:18:24 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xml/internal/utils/XMLReaderManager.java Tue Oct 29 08:01:29 2013 +0000 +@@ -22,6 +22,9 @@ + */ + package com.sun.org.apache.xml.internal.utils; + ++import com.sun.org.apache.xalan.internal.XalanConstants; ++import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager; ++ + import java.util.HashMap; + + import javax.xml.XMLConstants; +@@ -64,6 +67,8 @@ + + + private boolean _secureProcessing; ++ ++ private XMLSecurityManager _xmlSecurityManager; + /** + * Hidden constructor + */ +@@ -156,6 +161,21 @@ + } + } + ++ try { ++ if (_xmlSecurityManager != null) { ++ for (XMLSecurityManager.Limit limit : XMLSecurityManager.Limit.values()) { ++ reader.setProperty(limit.apiProperty(), ++ _xmlSecurityManager.getLimitValueAsString(limit)); ++ } ++ if (_xmlSecurityManager.printEntityCountInfo()) { ++ reader.setProperty(XalanConstants.JDK_ENTITY_COUNT_INFO, XalanConstants.JDK_YES); ++ } ++ } ++ } catch (SAXException se) { ++ System.err.println("Warning: " + reader.getClass().getName() + ": " ++ + se.getMessage()); ++ } ++ + return reader; + } + +@@ -168,6 +188,24 @@ + } + } + ++ /** ++ * Get property value ++ */ ++ public Object getProperty(String name) { ++ if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ return _xmlSecurityManager; ++ } ++ return null; ++ } ++ ++ /** ++ * Set property. ++ */ ++ public void setProperty(String name, Object value) { ++ if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ _xmlSecurityManager = (XMLSecurityManager)value; ++ } ++ } + /** + * Mark the cached XMLReader as available. If the reader was not + * actually in the cache, do nothing. diff --git a/java/openjdk6/files/icedtea/openjdk/8014534-better_profiling.patch b/java/openjdk6/files/icedtea/openjdk/8014534-better_profiling.patch new file mode 100644 index 000000000000..c55741a63386 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014534-better_profiling.patch @@ -0,0 +1,156 @@ +# HG changeset patch +# User sjiang +# Date 1374135176 -7200 +# Thu Jul 18 10:12:56 2013 +0200 +# Node ID 1e7a5ebc8013b812de73e452e809a3b545dd252f +# Parent 698fe468e8b9385c2f74709dca823800b32e0b55 +8014534: Better profiling support +Summary: Validation of parameters +Reviewed-by: sspitsyn, skoivu, mchung + +diff -r 698fe468e8b9 -r 1e7a5ebc8013 src/share/classes/com/sun/demo/jvmti/hprof/Tracker.java +--- jdk/src/share/classes/com/sun/demo/jvmti/hprof/Tracker.java Tue Oct 15 17:01:56 2013 +0100 ++++ jdk/src/share/classes/com/sun/demo/jvmti/hprof/Tracker.java Thu Jul 18 10:12:56 2013 +0200 +@@ -53,7 +53,10 @@ + + public static void ObjectInit(Object obj) + { +- if ( engaged != 0 ) { ++ if ( engaged != 0) { ++ if (obj == null) { ++ throw new IllegalArgumentException("Null object."); ++ } + nativeObjectInit(Thread.currentThread(), obj); + } + } +@@ -66,7 +69,10 @@ + + public static void NewArray(Object obj) + { +- if ( engaged != 0 ) { ++ if ( engaged != 0) { ++ if (obj == null) { ++ throw new IllegalArgumentException("Null object."); ++ } + nativeNewArray(Thread.currentThread(), obj); + } + } +@@ -82,6 +88,14 @@ + public static void CallSite(int cnum, int mnum) + { + if ( engaged != 0 ) { ++ if (cnum < 0) { ++ throw new IllegalArgumentException("Negative class index"); ++ } ++ ++ if (mnum < 0) { ++ throw new IllegalArgumentException("Negative method index"); ++ } ++ + nativeCallSite(Thread.currentThread(), cnum, mnum); + } + } +@@ -95,6 +109,14 @@ + public static void ReturnSite(int cnum, int mnum) + { + if ( engaged != 0 ) { ++ if (cnum < 0) { ++ throw new IllegalArgumentException("Negative class index"); ++ } ++ ++ if (mnum < 0) { ++ throw new IllegalArgumentException("Negative method index"); ++ } ++ + nativeReturnSite(Thread.currentThread(), cnum, mnum); + } + } +diff -r 698fe468e8b9 -r 1e7a5ebc8013 src/share/demo/jvmti/hprof/hprof_class.c +--- jdk/src/share/demo/jvmti/hprof/hprof_class.c Tue Oct 15 17:01:56 2013 +0100 ++++ jdk/src/share/demo/jvmti/hprof/hprof_class.c Thu Jul 18 10:12:56 2013 +0200 +@@ -518,7 +518,12 @@ + jmethodID method; + + info = get_info(index); +- HPROF_ASSERT(mnum < info->method_count); ++ if (mnum >= info->method_count) { ++ jclass newExcCls = (*env)->FindClass(env, "java/lang/IllegalArgumentException"); ++ (*env)->ThrowNew(env, newExcCls, "Illegal mnum"); ++ ++ return NULL; ++ } + method = info->method[mnum].method_id; + if ( method == NULL ) { + char * name; +@@ -526,7 +531,12 @@ + jclass clazz; + + name = (char *)string_get(info->method[mnum].name_index); +- HPROF_ASSERT(name!=NULL); ++ if (name==NULL) { ++ jclass newExcCls = (*env)->FindClass(env, "java/lang/IllegalArgumentException"); ++ (*env)->ThrowNew(env, newExcCls, "Name not found"); ++ ++ return NULL; ++ } + sig = (char *)string_get(info->method[mnum].sig_index); + HPROF_ASSERT(sig!=NULL); + clazz = class_get_class(env, index); +diff -r 698fe468e8b9 -r 1e7a5ebc8013 src/share/demo/jvmti/hprof/hprof_event.c +--- jdk/src/share/demo/jvmti/hprof/hprof_event.c Tue Oct 15 17:01:56 2013 +0100 ++++ jdk/src/share/demo/jvmti/hprof/hprof_event.c Thu Jul 18 10:12:56 2013 +0200 +@@ -186,7 +186,12 @@ + + HPROF_ASSERT(env!=NULL); + HPROF_ASSERT(thread!=NULL); +- HPROF_ASSERT(cnum!=0 && cnum!=gdata->tracker_cnum); ++ if (cnum == 0 || cnum == gdata->tracker_cnum) { ++ jclass newExcCls = (*env)->FindClass(env, "java/lang/IllegalArgumentException"); ++ (*env)->ThrowNew(env, newExcCls, "Illegal cnum."); ++ ++ return; ++ } + + /* Prevent recursion into any BCI function for this thread (pstatus). */ + if ( tls_get_tracker_status(env, thread, JNI_FALSE, +@@ -195,8 +200,10 @@ + + (*pstatus) = 1; + method = class_get_methodID(env, cnum, mnum); +- HPROF_ASSERT(method!=NULL); +- tls_push_method(tls_index, method); ++ if (method != NULL) { ++ tls_push_method(tls_index, method); ++ } ++ + (*pstatus) = 0; + } + } +@@ -239,7 +246,13 @@ + + HPROF_ASSERT(env!=NULL); + HPROF_ASSERT(thread!=NULL); +- HPROF_ASSERT(cnum!=0 && cnum!=gdata->tracker_cnum); ++ ++ if (cnum == 0 || cnum == gdata->tracker_cnum) { ++ jclass newExcCls = (*env)->FindClass(env, "java/lang/IllegalArgumentException"); ++ (*env)->ThrowNew(env, newExcCls, "Illegal cnum."); ++ ++ return; ++ } + + /* Prevent recursion into any BCI function for this thread (pstatus). */ + if ( tls_get_tracker_status(env, thread, JNI_FALSE, +@@ -248,8 +261,10 @@ + + (*pstatus) = 1; + method = class_get_methodID(env, cnum, mnum); +- HPROF_ASSERT(method!=NULL); +- tls_pop_method(tls_index, thread, method); ++ if (method != NULL) { ++ tls_pop_method(tls_index, thread, method); ++ } ++ + (*pstatus) = 0; + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8014718-remove_logging_suntoolkit.patch b/java/openjdk6/files/icedtea/openjdk/8014718-remove_logging_suntoolkit.patch new file mode 100644 index 000000000000..de29efa6522e --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014718-remove_logging_suntoolkit.patch @@ -0,0 +1,115 @@ +# HG changeset patch +# User leonidr +# Date 1382726240 -3600 +# Fri Oct 25 19:37:20 2013 +0100 +# Node ID e7ed5dad88eefc49130ae02bcbf329d72f18f12e +# Parent 47c881c5439a4542b19ab85f376e94fc2c0a5a57 +8014718: Netbeans IDE begins to throw a lot exceptions since 7u25 b10 +Summary: Removed logging from SunToolkit +Reviewed-by: art, omajid + +diff -r 47c881c5439a -r e7ed5dad88ee src/share/classes/java/awt/Toolkit.java +--- jdk/src/share/classes/java/awt/Toolkit.java Wed May 01 00:49:21 2013 +0200 ++++ jdk/src/share/classes/java/awt/Toolkit.java Fri Oct 25 19:37:20 2013 +0100 +@@ -48,8 +48,6 @@ + import java.io.FileInputStream; + + import java.util.*; +-import java.util.logging.*; +- + import java.beans.PropertyChangeListener; + import java.beans.PropertyChangeSupport; + import sun.awt.AppContext; +@@ -1922,7 +1920,7 @@ + */ + public abstract boolean isModalExclusionTypeSupported(Dialog.ModalExclusionType modalExclusionType); + +- private static final Logger log = Logger.getLogger("java.awt.Toolkit"); ++ // 8014736: logging has been removed from Toolkit + + private static final int LONG_BITS = 64; + private int[] calls = new int[LONG_BITS]; +@@ -2089,12 +2087,6 @@ + } + + synchronized int countAWTEventListeners(long eventMask) { +- if (log.isLoggable(Level.FINE)) { +- if (eventMask == 0) { +- log.log(Level.FINE, "Assertion (eventMask != 0) failed"); +- } +- } +- + int ci = 0; + for (; eventMask != 0; eventMask >>>= 1, ci++) { + } +diff -r 47c881c5439a -r e7ed5dad88ee src/share/classes/sun/awt/SunToolkit.java +--- jdk/src/share/classes/sun/awt/SunToolkit.java Wed May 01 00:49:21 2013 +0200 ++++ jdk/src/share/classes/sun/awt/SunToolkit.java Fri Oct 25 19:37:20 2013 +0100 +@@ -58,7 +58,7 @@ + implements WindowClosingSupport, WindowClosingListener, + ComponentFactory, InputMethodSupport { + +- private static final Logger log = Logger.getLogger("sun.awt.SunToolkit"); ++ // 8014736: logging has been removed from SunToolkit + + /* Load debug settings for native code */ + static { +@@ -554,10 +554,6 @@ + if (event == null) { + throw new NullPointerException(); + } +- AppContext eventContext = targetToAppContext(event.getSource()); +- if (eventContext != null && !eventContext.equals(appContext)) { +- log.fine("Event posted on wrong app context : " + event); +- } + PostEventQueue postEventQueue = + (PostEventQueue)appContext.get(POST_EVENT_QUEUE_KEY); + if(postEventQueue != null) { +@@ -938,10 +934,6 @@ + //with scale factors x1, x3/4, x2/3, xN, x1/N. + Image im = i.next(); + if (im == null) { +- if (log.isLoggable(Level.FINER)) { +- log.log(Level.FINER, "SunToolkit.getScaledIconImage: " + +- "Skipping the image passed into Java because it's null."); +- } + continue; + } + if (im instanceof ToolkitImage) { +@@ -954,10 +946,6 @@ + iw = im.getWidth(null); + ih = im.getHeight(null); + } catch (Exception e){ +- if (log.isLoggable(Level.FINER)) { +- log.log(Level.FINER, "SunToolkit.getScaledIconImage: " + +- "Perhaps the image passed into Java is broken. Skipping this icon."); +- } + continue; + } + if (iw > 0 && ih > 0) { +@@ -1029,14 +1017,6 @@ + try { + int x = (width - bestWidth) / 2; + int y = (height - bestHeight) / 2; +- if (log.isLoggable(Level.FINER)) { +- log.log(Level.FINER, "WWindowPeer.getScaledIconData() result : " + +- "w : " + width + " h : " + height + +- " iW : " + bestImage.getWidth(null) + " iH : " + bestImage.getHeight(null) + +- " sim : " + bestSimilarity + " sf : " + bestScaleFactor + +- " adjW : " + bestWidth + " adjH : " + bestHeight + +- " x : " + x + " y : " + y); +- } + g.drawImage(bestImage, x, y, bestWidth, bestHeight, null); + } finally { + g.dispose(); +@@ -1047,10 +1027,6 @@ + public static DataBufferInt getScaledIconData(java.util.List<Image> imageList, int width, int height) { + BufferedImage bimage = getScaledIconImage(imageList, width, height); + if (bimage == null) { +- if (log.isLoggable(Level.FINER)) { +- log.log(Level.FINER, "SunToolkit.getScaledIconData: " + +- "Perhaps the image passed into Java is broken. Skipping this icon."); +- } + return null; + } + Raster raster = bimage.getRaster(); diff --git a/java/openjdk6/files/icedtea/openjdk/8014745-logger_stack_walk_switch.patch b/java/openjdk6/files/icedtea/openjdk/8014745-logger_stack_walk_switch.patch new file mode 100644 index 000000000000..06cc6e1d282c --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014745-logger_stack_walk_switch.patch @@ -0,0 +1,205 @@ +# HG changeset patch +# User mchung +# Date 1368826191 25200 +# Fri May 17 14:29:51 2013 -0700 +# Node ID 0bf55b4c8a7bbea02a9d848b2a5451adbd6a6ac4 +# Parent 8733761ca20bb4e46405e274c514bda0e0616a21 +8014745: Provide a switch to allow stack walk search of resource bundle +Reviewed-by: alanb, jgish + +diff -r 8733761ca20b -r 0bf55b4c8a7b make/java/java/mapfile-vers +--- jdk/make/java/java/mapfile-vers Wed Jun 26 22:50:47 2013 -0500 ++++ jdk/make/java/java/mapfile-vers Fri May 17 14:29:51 2013 -0700 +@@ -271,6 +271,7 @@ + Java_sun_reflect_NativeConstructorAccessorImpl_newInstance0; + Java_sun_reflect_NativeMethodAccessorImpl_invoke0; + Java_sun_reflect_Reflection_getCallerClass; ++ Java_sun_reflect_Reflection_getCallerClass0; + Java_sun_reflect_Reflection_getClassAccessFlags; + Java_sun_misc_Version_getJdkVersionInfo; + Java_sun_misc_Version_getJdkSpecialVersion; +diff -r 8733761ca20b -r 0bf55b4c8a7b src/share/classes/java/util/logging/Logger.java +--- jdk/src/share/classes/java/util/logging/Logger.java Wed Jun 26 22:50:47 2013 -0500 ++++ jdk/src/share/classes/java/util/logging/Logger.java Fri May 17 14:29:51 2013 -0700 +@@ -303,8 +303,13 @@ + // null, we assume it's a system logger and add it to the system context. + // These system loggers only set the resource bundle to the given + // resource bundle name (rather than the default system resource bundle). +- private static class SystemLoggerHelper { +- static boolean disableCallerCheck = getBooleanProperty("sun.util.logging.disableCallerCheck"); ++ private static class LoggerHelper { ++ static boolean disableCallerCheck = ++ getBooleanProperty("sun.util.logging.disableCallerCheck"); ++ ++ // workaround to turn on the old behavior for resource bundle search ++ static boolean allowStackWalkSearch = ++ getBooleanProperty("jdk.logging.allowStackWalkSearch"); + private static boolean getBooleanProperty(final String key) { + String s = AccessController.doPrivileged(new PrivilegedAction<String>() { + public String run() { +@@ -318,7 +323,7 @@ + private static Logger demandLogger(String name, String resourceBundleName, Class<?> caller) { + LogManager manager = LogManager.getLogManager(); + SecurityManager sm = System.getSecurityManager(); +- if (sm != null && !SystemLoggerHelper.disableCallerCheck) { ++ if (sm != null && !LoggerHelper.disableCallerCheck) { + if (caller.getClassLoader() == null) { + return manager.demandSystemLogger(name, resourceBundleName); + } +@@ -1407,25 +1412,61 @@ + if (useCallersClassLoader) { + // Try with the caller's ClassLoader + ClassLoader callersClassLoader = getCallersClassLoader(); ++ if (callersClassLoader != null && callersClassLoader != cl) { ++ try { ++ catalog = ResourceBundle.getBundle(name, currentLocale, ++ callersClassLoader); ++ catalogName = name; ++ catalogLocale = currentLocale; ++ return catalog; ++ } catch (MissingResourceException ex) { ++ } ++ } ++ } + +- if (callersClassLoader == null || callersClassLoader == cl) { +- return null; +- } +- +- try { +- catalog = ResourceBundle.getBundle(name, currentLocale, +- callersClassLoader); +- catalogName = name; +- catalogLocale = currentLocale; +- return catalog; +- } catch (MissingResourceException ex) { +- return null; // no luck +- } ++ // If -Djdk.logging.allowStackWalkSearch=true is set, ++ // does stack walk to search for the resource bundle ++ if (LoggerHelper.allowStackWalkSearch) { ++ return findResourceBundleFromStack(name, currentLocale, cl); + } else { + return null; + } + } + ++ /** ++ * This method will fail when running with a VM that enforces caller-sensitive ++ * methods and only allows to get the immediate caller. ++ */ ++ @CallerSensitive ++ private synchronized ResourceBundle findResourceBundleFromStack(String name, ++ Locale locale, ++ ClassLoader cl) ++ { ++ for (int ix = 0; ; ix++) { ++ Class<?> clz = sun.reflect.Reflection.getCallerClass(ix); ++ if (clz == null) { ++ break; ++ } ++ ClassLoader cl2 = clz.getClassLoader(); ++ if (cl2 == null) { ++ cl2 = ClassLoader.getSystemClassLoader(); ++ } ++ if (cl == cl2) { ++ // We've already checked this classloader. ++ continue; ++ } ++ cl = cl2; ++ try { ++ catalog = ResourceBundle.getBundle(name, locale, cl); ++ catalogName = name; ++ catalogLocale = locale; ++ return catalog; ++ } catch (MissingResourceException ex) { ++ } ++ } ++ return null; ++ } ++ + // Private utility method to initialize our one entry + // resource bundle name cache and the callers ClassLoader + // Note: for consistency reasons, we are careful to check +diff -r 8733761ca20b -r 0bf55b4c8a7b src/share/classes/sun/reflect/Reflection.java +--- jdk/src/share/classes/sun/reflect/Reflection.java Wed Jun 26 22:50:47 2013 -0500 ++++ jdk/src/share/classes/sun/reflect/Reflection.java Fri May 17 14:29:51 2013 -0700 +@@ -58,6 +58,21 @@ + @CallerSensitive + public static native Class getCallerClass(); + ++ /** ++ * @deprecated No replacement. This method will be removed in the next ++ * JDK 7 update release. ++ */ ++ @Deprecated ++ @CallerSensitive ++ public static Class getCallerClass(int depth) { ++ return getCallerClass0(depth); ++ } ++ ++ // If the VM enforces getting caller class with @CallerSensitive, ++ // this will fail anyway. ++ @CallerSensitive ++ private static native Class getCallerClass0(int depth); ++ + /** Retrieves the access flags written to the class file. For + inner classes these flags may differ from those returned by + Class.getModifiers(), which searches the InnerClasses +diff -r 8733761ca20b -r 0bf55b4c8a7b src/share/native/sun/reflect/Reflection.c +--- jdk/src/share/native/sun/reflect/Reflection.c Wed Jun 26 22:50:47 2013 -0500 ++++ jdk/src/share/native/sun/reflect/Reflection.c Fri May 17 14:29:51 2013 -0700 +@@ -34,6 +34,12 @@ + return JVM_GetCallerClass(env, 2); + } + ++JNIEXPORT jclass JNICALL Java_sun_reflect_Reflection_getCallerClass0 ++(JNIEnv *env, jclass unused, jint depth) ++{ ++ return JVM_GetCallerClass(env, depth); ++} ++ + JNIEXPORT jint JNICALL Java_sun_reflect_Reflection_getClassAccessFlags + (JNIEnv *env, jclass unused, jclass cls) + { +diff -r 8733761ca20b -r 0bf55b4c8a7b test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java +--- jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Wed Jun 26 22:50:47 2013 -0500 ++++ jdk/test/java/util/logging/bundlesearch/ResourceBundleSearchTest.java Fri May 17 14:29:51 2013 -0700 +@@ -28,6 +28,7 @@ + * @author Jim Gish + * @build ResourceBundleSearchTest IndirectlyLoadABundle LoadItUp1 LoadItUp2 TwiceIndirectlyLoadABundle LoadItUp2Invoker + * @run main/othervm ResourceBundleSearchTest ++ * @run main/othervm -Djdk.logging.allowStackWalkSearch=true ResourceBundleSearchTest + */ + import java.net.URL; + import java.net.URLClassLoader; +@@ -79,7 +80,15 @@ + + // Test 1 - can we find a Logger bundle from doing a stack search? + // We shouldn't be able to +- assertFalse(testGetBundleFromStackSearch(), "1-testGetBundleFromStackSearch"); ++ // unless -Djdk.logging.allowStackWalkSearch=true is set ++ ++ boolean allowStackWalkSearch = Boolean.getBoolean("jdk.logging.allowStackWalkSearch"); ++ if (allowStackWalkSearch) { ++ assertTrue(testGetBundleFromStackSearch(), "1-testGetBundleFromStackSearch"); ++ } else { ++ // default behavior ++ assertFalse(testGetBundleFromStackSearch(), "1-testGetBundleFromStackSearch"); ++ } + + // Test 2 - can we find a Logger bundle off of the Thread context class + // loader? We should be able to. +@@ -111,8 +120,10 @@ + // Test 6 - first call getLogger("myLogger"). + // Then call getLogger("myLogger","bundleName") from a different ClassLoader + // Make sure we find the bundle +- assertTrue(testGetBundleFromSecondCallersClassLoader(), +- "6-testGetBundleFromSecondCallersClassLoader"); ++ if (!allowStackWalkSearch) { ++ assertTrue(testGetBundleFromSecondCallersClassLoader(), ++ "6-testGetBundleFromSecondCallersClassLoader"); ++ } + + report(); + } diff --git a/java/openjdk6/files/icedtea/openjdk/8014987-augment_serialization.patch b/java/openjdk6/files/icedtea/openjdk/8014987-augment_serialization.patch new file mode 100644 index 000000000000..f8f53a9e9643 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8014987-augment_serialization.patch @@ -0,0 +1,100 @@ +# HG changeset patch +# User smarks +# Date 1381854512 -3600 +# Tue Oct 15 17:28:32 2013 +0100 +# Node ID a1bc92467cc07e1cb3c93d0b3b629eda4c45238f +# Parent 1e7a5ebc8013b812de73e452e809a3b545dd252f +8014987: Augment serialization handling +Reviewed-by: alanb, coffeys, skoivu + +diff -r 1e7a5ebc8013 -r a1bc92467cc0 src/share/classes/java/io/ObjectInputStream.java +--- jdk/src/share/classes/java/io/ObjectInputStream.java Thu Jul 18 10:12:56 2013 +0200 ++++ jdk/src/share/classes/java/io/ObjectInputStream.java Tue Oct 15 17:28:32 2013 +0100 +@@ -489,11 +489,12 @@ + public void defaultReadObject() + throws IOException, ClassNotFoundException + { +- if (curContext == null) { ++ SerialCallbackContext ctx = curContext; ++ if (ctx == null) { + throw new NotActiveException("not in call to readObject"); + } +- Object curObj = curContext.getObj(); +- ObjectStreamClass curDesc = curContext.getDesc(); ++ Object curObj = ctx.getObj(); ++ ObjectStreamClass curDesc = ctx.getDesc(); + bin.setBlockDataMode(false); + defaultReadFields(curObj, curDesc); + bin.setBlockDataMode(true); +@@ -527,11 +528,12 @@ + public ObjectInputStream.GetField readFields() + throws IOException, ClassNotFoundException + { +- if (curContext == null) { ++ SerialCallbackContext ctx = curContext; ++ if (ctx == null) { + throw new NotActiveException("not in call to readObject"); + } +- Object curObj = curContext.getObj(); +- ObjectStreamClass curDesc = curContext.getDesc(); ++ Object curObj = ctx.getObj(); ++ ObjectStreamClass curDesc = ctx.getDesc(); + bin.setBlockDataMode(false); + GetFieldImpl getField = new GetFieldImpl(curDesc); + getField.readFields(); +@@ -1964,7 +1966,6 @@ + private void defaultReadFields(Object obj, ObjectStreamClass desc) + throws IOException + { +- // REMIND: is isInstance check necessary? + Class cl = desc.forClass(); + if (cl != null && obj != null && !cl.isInstance(obj)) { + throw new ClassCastException(); +diff -r 1e7a5ebc8013 -r a1bc92467cc0 src/share/classes/java/io/ObjectOutputStream.java +--- jdk/src/share/classes/java/io/ObjectOutputStream.java Thu Jul 18 10:12:56 2013 +0200 ++++ jdk/src/share/classes/java/io/ObjectOutputStream.java Tue Oct 15 17:28:32 2013 +0100 +@@ -430,11 +430,12 @@ + * <code>OutputStream</code> + */ + public void defaultWriteObject() throws IOException { +- if ( curContext == null ) { ++ SerialCallbackContext ctx = curContext; ++ if (ctx == null) { + throw new NotActiveException("not in call to writeObject"); + } +- Object curObj = curContext.getObj(); +- ObjectStreamClass curDesc = curContext.getDesc(); ++ Object curObj = ctx.getObj(); ++ ObjectStreamClass curDesc = ctx.getDesc(); + bout.setBlockDataMode(false); + defaultWriteFields(curObj, curDesc); + bout.setBlockDataMode(true); +@@ -452,11 +453,12 @@ + */ + public ObjectOutputStream.PutField putFields() throws IOException { + if (curPut == null) { +- if (curContext == null) { ++ SerialCallbackContext ctx = curContext; ++ if (ctx == null) { + throw new NotActiveException("not in call to writeObject"); + } +- Object curObj = curContext.getObj(); +- ObjectStreamClass curDesc = curContext.getDesc(); ++ Object curObj = ctx.getObj(); ++ ObjectStreamClass curDesc = ctx.getDesc(); + curPut = new PutFieldImpl(curDesc); + } + return curPut; +@@ -1516,7 +1518,11 @@ + private void defaultWriteFields(Object obj, ObjectStreamClass desc) + throws IOException + { +- // REMIND: perform conservative isInstance check here? ++ Class<?> cl = desc.forClass(); ++ if (cl != null && obj != null && !cl.isInstance(obj)) { ++ throw new ClassCastException(); ++ } ++ + desc.checkDefaultSerialize(); + + int primDataSize = desc.getPrimDataSize(); diff --git a/java/openjdk6/files/icedtea/openjdk/8015144-performance_regression.patch b/java/openjdk6/files/icedtea/openjdk/8015144-performance_regression.patch new file mode 100644 index 000000000000..2f13ff3d3131 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8015144-performance_regression.patch @@ -0,0 +1,273 @@ +# HG changeset patch +# User prr +# Date 1383010378 0 +# Tue Oct 29 01:32:58 2013 +0000 +# Node ID bac5d0b011562017738501f02f7db4f39522a62e +# Parent 35c5b3f404aac29ec5cccaeb32106af47546b6db +8015144: Performance regression in ICU OpenType Layout library +Reviewed-by: srl, jgodinez + +diff -r 35c5b3f404aa -r bac5d0b01156 src/share/native/sun/font/layout/GlyphIterator.cpp +--- jdk/src/share/native/sun/font/layout/GlyphIterator.cpp Wed Jun 05 18:39:44 2013 +0100 ++++ jdk/src/share/native/sun/font/layout/GlyphIterator.cpp Tue Oct 29 01:32:58 2013 +0000 +@@ -66,6 +66,7 @@ + nextLimit = -1; + prevLimit = glyphCount; + } ++ filterResetCache(); + } + + GlyphIterator::GlyphIterator(GlyphIterator &that) +@@ -84,6 +85,7 @@ + glyphGroup = that.glyphGroup; + glyphClassDefinitionTable = that.glyphClassDefinitionTable; + markAttachClassDefinitionTable = that.markAttachClassDefinitionTable; ++ filterResetCache(); + } + + GlyphIterator::GlyphIterator(GlyphIterator &that, FeatureMask newFeatureMask) +@@ -102,6 +104,7 @@ + glyphGroup = 0; + glyphClassDefinitionTable = that.glyphClassDefinitionTable; + markAttachClassDefinitionTable = that.markAttachClassDefinitionTable; ++ filterResetCache(); + } + + GlyphIterator::GlyphIterator(GlyphIterator &that, le_uint16 newLookupFlags) +@@ -120,6 +123,7 @@ + glyphGroup = that.glyphGroup; + glyphClassDefinitionTable = that.glyphClassDefinitionTable; + markAttachClassDefinitionTable = that.markAttachClassDefinitionTable; ++ filterResetCache(); + } + + GlyphIterator::~GlyphIterator() +@@ -133,6 +137,7 @@ + featureMask = newFeatureMask; + glyphGroup = 0; + lookupFlags = newLookupFlags; ++ filterResetCache(); + } + + LEGlyphID *GlyphIterator::insertGlyphs(le_int32 count, LEErrorCode& success) +@@ -381,53 +386,68 @@ + glyphPositionAdjustments->setCursiveGlyph(position, baselineIsLogicalEnd()); + } + +-le_bool GlyphIterator::filterGlyph(le_uint32 index) const +-{ +- LEErrorCode success = LE_NO_ERROR; +- LEGlyphID glyphID = glyphStorage[index]; +- le_int32 glyphClass = gcdNoGlyphClass; +- +- if (LE_GET_GLYPH(glyphID) >= 0xFFFE) { +- return TRUE; ++void GlyphIterator::filterResetCache(void) { ++ filterCacheValid = FALSE; + } + ++le_bool GlyphIterator::filterGlyph(le_uint32 index) ++{ ++ LEGlyphID glyphID = glyphStorage[index]; ++ ++ if (!filterCacheValid || filterCache.id != glyphID) { ++ filterCache.id = glyphID; ++ ++ le_bool &filterResult = filterCache.result; // NB: Making this a reference to accept the updated value, in case ++ // we want more fancy cacheing in the future. ++ if (LE_GET_GLYPH(glyphID) >= 0xFFFE) { ++ filterResult = TRUE; ++ } else { ++ LEErrorCode success = LE_NO_ERROR; ++ le_int32 glyphClass = gcdNoGlyphClass; + if (glyphClassDefinitionTable.isValid()) { + glyphClass = glyphClassDefinitionTable->getGlyphClass(glyphClassDefinitionTable, glyphID, success); + } +- +- switch (glyphClass) +- { ++ switch (glyphClass) { + case gcdNoGlyphClass: +- return FALSE; ++ filterResult = FALSE; ++ break; + + case gcdSimpleGlyph: +- return (lookupFlags & lfIgnoreBaseGlyphs) != 0; ++ filterResult = (lookupFlags & lfIgnoreBaseGlyphs) != 0; ++ break; + + case gcdLigatureGlyph: +- return (lookupFlags & lfIgnoreLigatures) != 0; ++ filterResult = (lookupFlags & lfIgnoreLigatures) != 0; ++ break; + + case gcdMarkGlyph: +- { + if ((lookupFlags & lfIgnoreMarks) != 0) { +- return TRUE; +- } +- ++ filterResult = TRUE; ++ } else { + le_uint16 markAttachType = (lookupFlags & lfMarkAttachTypeMask) >> lfMarkAttachTypeShift; + + if ((markAttachType != 0) && (markAttachClassDefinitionTable.isValid())) { +- return markAttachClassDefinitionTable +- -> getGlyphClass(markAttachClassDefinitionTable, glyphID, success) != markAttachType; ++ filterResult = (markAttachClassDefinitionTable ++ -> getGlyphClass(markAttachClassDefinitionTable, glyphID, success) != markAttachType); ++ } else { ++ filterResult = FALSE; ++ } ++ } ++ break; ++ ++ case gcdComponentGlyph: ++ filterResult = ((lookupFlags & lfIgnoreBaseGlyphs) != 0); ++ break; ++ ++ default: ++ filterResult = FALSE; ++ break; ++ } ++ } ++ filterCacheValid = TRUE; + } + +- return FALSE; +- } +- +- case gcdComponentGlyph: +- return (lookupFlags & lfIgnoreBaseGlyphs) != 0; +- +- default: +- return FALSE; +- } ++ return filterCache.result; + } + + le_bool GlyphIterator::hasFeatureTag(le_bool matchGroup) const +diff -r 35c5b3f404aa -r bac5d0b01156 src/share/native/sun/font/layout/GlyphIterator.h +--- jdk/src/share/native/sun/font/layout/GlyphIterator.h Wed Jun 05 18:39:44 2013 +0100 ++++ jdk/src/share/native/sun/font/layout/GlyphIterator.h Tue Oct 29 01:32:58 2013 +0000 +@@ -98,7 +98,7 @@ + le_int32 applyInsertions(); + + private: +- le_bool filterGlyph(le_uint32 index) const; ++ le_bool filterGlyph(le_uint32 index); + le_bool hasFeatureTag(le_bool matchGroup) const; + le_bool nextInternal(le_uint32 delta = 1); + le_bool prevInternal(le_uint32 delta = 1); +@@ -121,6 +121,14 @@ + LEReferenceTo<MarkAttachClassDefinitionTable> markAttachClassDefinitionTable; + + GlyphIterator &operator=(const GlyphIterator &other); // forbid copying of this class ++ ++ struct { ++ LEGlyphID id; ++ le_bool result; ++ } filterCache; ++ le_bool filterCacheValid; ++ ++ void filterResetCache(void); + }; + + U_NAMESPACE_END +diff -r 35c5b3f404aa -r bac5d0b01156 src/share/native/sun/font/layout/LETableReference.h +--- jdk/src/share/native/sun/font/layout/LETableReference.h Wed Jun 05 18:39:44 2013 +0100 ++++ jdk/src/share/native/sun/font/layout/LETableReference.h Tue Oct 29 01:32:58 2013 +0000 +@@ -431,7 +431,7 @@ + * @param success error status + * @param atPtr location of reference - if NULL, will be at offset zero (i.e. downcast of parent). Otherwise must be a pointer within parent's bounds. + */ +- LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr) ++ inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr) + : LETableReference(parent, parent.ptrToOffset(atPtr, success), LE_UINTPTR_MAX, success) { + verifyLength(parent.ptrToOffset(atPtr,success), LETableVarSizer<T>::getSize(), success); + if(LE_FAILURE(success)) clear(); +@@ -439,31 +439,31 @@ + /** + * ptr plus offset + */ +- LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr, size_t offset) ++ inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr, size_t offset) + : LETableReference(parent, parent.ptrToOffset(atPtr, success)+offset, LE_UINTPTR_MAX, success) { + verifyLength(0, LETableVarSizer<T>::getSize(), success); + if(LE_FAILURE(success)) clear(); + } +- LEReferenceTo(const LETableReference &parent, LEErrorCode &success, size_t offset) ++ inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, size_t offset) + : LETableReference(parent, offset, LE_UINTPTR_MAX, success) { + verifyLength(0, LETableVarSizer<T>::getSize(), success); + if(LE_FAILURE(success)) clear(); + } +- LEReferenceTo(const LETableReference &parent, LEErrorCode &success) ++ inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success) + : LETableReference(parent, 0, LE_UINTPTR_MAX, success) { + verifyLength(0, LETableVarSizer<T>::getSize(), success); + if(LE_FAILURE(success)) clear(); + } +- LEReferenceTo(const LEFontInstance *font, LETag tableTag, LEErrorCode &success) ++ inline LEReferenceTo(const LEFontInstance *font, LETag tableTag, LEErrorCode &success) + : LETableReference(font, tableTag, success) { + verifyLength(0, LETableVarSizer<T>::getSize(), success); + if(LE_FAILURE(success)) clear(); + } +- LEReferenceTo(const le_uint8 *data, size_t length = LE_UINTPTR_MAX) : LETableReference(data, length) {} +- LEReferenceTo(const T *data, size_t length = LE_UINTPTR_MAX) : LETableReference((const le_uint8*)data, length) {} +- LEReferenceTo() : LETableReference(NULL) {} ++ inline LEReferenceTo(const le_uint8 *data, size_t length = LE_UINTPTR_MAX) : LETableReference(data, length) {} ++ inline LEReferenceTo(const T *data, size_t length = LE_UINTPTR_MAX) : LETableReference((const le_uint8*)data, length) {} ++ inline LEReferenceTo() : LETableReference(NULL) {} + +- LEReferenceTo<T>& operator=(const T* other) { ++ inline LEReferenceTo<T>& operator=(const T* other) { + setRaw(other); + return *this; + } +diff -r 35c5b3f404aa -r bac5d0b01156 src/share/native/sun/font/layout/OpenTypeUtilities.cpp +--- jdk/src/share/native/sun/font/layout/OpenTypeUtilities.cpp Wed Jun 05 18:39:44 2013 +0100 ++++ jdk/src/share/native/sun/font/layout/OpenTypeUtilities.cpp Tue Oct 29 01:32:58 2013 +0000 +@@ -79,6 +79,7 @@ + + Offset OpenTypeUtilities::getTagOffset(LETag tag, const LEReferenceToArrayOf<TagAndOffsetRecord> &records, LEErrorCode &success) + { ++ const TagAndOffsetRecord *r0 = (const TagAndOffsetRecord*)records.getAlias(); + if(LE_FAILURE(success)) return 0; + + le_uint32 recordCount = records.getCount(); +@@ -89,17 +90,17 @@ + le_int32 index = 0; + + { +- const ATag &aTag = records.getAlias(extra,success)->tag; ++ const ATag &aTag = (r0+extra)->tag; + if (SWAPT(aTag) <= tag) { + index = extra; + } + } + +- while (probe > (1 << 0) && LE_SUCCESS(success)) { ++ while (probe > (1 << 0)) { + probe >>= 1; + + { +- const ATag &aTag = records.getAlias(index+probe,success)->tag; ++ const ATag &aTag = (r0+index+probe)->tag; + if (SWAPT(aTag) <= tag) { + index += probe; + } +@@ -107,9 +108,9 @@ + } + + { +- const ATag &aTag = records.getAlias(index,success)->tag; ++ const ATag &aTag = (r0+index)->tag; + if (SWAPT(aTag) == tag) { +- return SWAPW(records.getAlias(index,success)->offset); ++ return SWAPW((r0+index)->offset); + } + } + diff --git a/java/openjdk6/files/icedtea/openjdk/8015614-update_build.patch b/java/openjdk6/files/icedtea/openjdk/8015614-update_build.patch new file mode 100644 index 000000000000..72ff7b6a37d9 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8015614-update_build.patch @@ -0,0 +1,60 @@ +# HG changeset patch +# User erikj +# Date 1381419677 -3600 +# Thu Oct 10 16:41:17 2013 +0100 +# Node ID 918a90950fa69e5247e3af2599d2e7674d64e3d6 +# Parent d0b5dc55e72cde11331399cbb960458b8f45ea4a +8015614: Update build settings +Reviewed-by: tbell, dholmes, ahgross + +diff -r d0b5dc55e72c -r 918a90950fa6 make/windows/makefiles/compile.make +--- hotspot/make/windows/makefiles/compile.make Tue Sep 17 12:04:11 2013 +0200 ++++ hotspot/make/windows/makefiles/compile.make Thu Oct 10 16:41:17 2013 +0100 +@@ -140,6 +140,7 @@ + !if "$(MSC_VER)" == "1600" + COMPILER_NAME=VS2010 + !endif ++SAFESEH_FLAG = /SAFESEH + !endif + + # By default, we do not want to use the debug version of the msvcrt.dll file +@@ -170,6 +171,7 @@ + PRODUCT_OPT_OPTION = /O2 /Oy- + FASTDEBUG_OPT_OPTION = /O2 /Oy- + DEBUG_OPT_OPTION = /Od ++SAFESEH_FLAG = /SAFESEH + !endif + + !if "$(COMPILER_NAME)" == "VS2005" +@@ -186,6 +188,7 @@ + # Manifest Tool - used in VS2005 and later to adjust manifests stored + # as resources inside build artifacts. + MT=mt.exe ++SAFESEH_FLAG = /SAFESEH + !endif + + !if "$(COMPILER_NAME)" == "VS2008" +@@ -209,8 +212,8 @@ + # as resources inside build artifacts. + MT=mt.exe + !if "$(BUILDARCH)" == "i486" +-LD_FLAGS = /SAFESEH $(LD_FLAGS) +-!endif ++LD_FLAGS = $(SAFESEH_FLAG) $(LD_FLAGS) ++SAFESEH_FLAG = /SAFESEH + !endif + + # Compile for space above time. +diff -r d0b5dc55e72c -r 918a90950fa6 make/windows/makefiles/sa.make +--- hotspot/make/windows/makefiles/sa.make Tue Sep 17 12:04:11 2013 +0200 ++++ hotspot/make/windows/makefiles/sa.make Thu Oct 10 16:41:17 2013 +0100 +@@ -107,6 +107,9 @@ + !if "$(ENABLE_FULL_DEBUG_SYMBOLS)" == "1" + SA_LFLAGS = $(SA_LFLAGS) /map /debug + !endif ++!if "$(BUILDARCH)" == "i486" ++SA_LFLAGS = $(SAFESEH_FLAG) $(SA_LFLAGS) ++!endif + + # Note that we do not keep sawindbj.obj around as it would then + # get included in the dumpbin command in build_vm_def.sh diff --git a/java/openjdk6/files/icedtea/openjdk/8015731-auth_improvements.patch b/java/openjdk6/files/icedtea/openjdk/8015731-auth_improvements.patch new file mode 100644 index 000000000000..0e75d3b06bd2 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8015731-auth_improvements.patch @@ -0,0 +1,28 @@ +# HG changeset patch +# User weijun +# Date 1371090681 -28800 +# Thu Jun 13 10:31:21 2013 +0800 +# Node ID e10e9bfb11b073ee1c108e7a51078d3ead7a2d72 +# Parent a1bc92467cc07e1cb3c93d0b3b629eda4c45238f +8015731: Subject java.security.auth.subject to improvements +Reviewed-by: skoivu, mullan + +diff -r a1bc92467cc0 -r e10e9bfb11b0 src/share/classes/javax/security/auth/Subject.java +--- jdk/src/share/classes/javax/security/auth/Subject.java Tue Oct 15 17:28:32 2013 +0100 ++++ jdk/src/share/classes/javax/security/auth/Subject.java Thu Jun 13 10:31:21 2013 +0800 +@@ -1305,8 +1305,14 @@ + { + ObjectInputStream.GetField fields = ois.readFields(); + subject = (Subject) fields.get("this$0", null); +- elements = (LinkedList<E>) fields.get("elements", null); + which = fields.get("which", 0); ++ ++ LinkedList<E> tmp = (LinkedList<E>) fields.get("elements", null); ++ if (tmp.getClass() != LinkedList.class) { ++ elements = new LinkedList<E>(tmp); ++ } else { ++ elements = tmp; ++ } + } + } + diff --git a/java/openjdk6/files/icedtea/openjdk/8015743-address_internet_addresses.patch b/java/openjdk6/files/icedtea/openjdk/8015743-address_internet_addresses.patch new file mode 100644 index 000000000000..c44cea89db82 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8015743-address_internet_addresses.patch @@ -0,0 +1,1290 @@ +# HG changeset patch +# User michaelm +# Date 1381868930 -3600 +# Tue Oct 15 21:28:50 2013 +0100 +# Node ID 96aee3742c52d2d1a83a3db0be2c14892a511c67 +# Parent e10e9bfb11b073ee1c108e7a51078d3ead7a2d72 +8015743: Address internet addresses +Summary: moved Inet6Address fields to holder class +Reviewed-by: chegar, alanb, skoivu, khazra + +diff -r e10e9bfb11b0 -r 96aee3742c52 src/share/classes/java/net/Inet6Address.java +--- jdk/src/share/classes/java/net/Inet6Address.java Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/share/classes/java/net/Inet6Address.java Tue Oct 15 21:28:50 2013 +0100 +@@ -27,6 +27,8 @@ + + import java.security.AccessController; + import java.io.ObjectInputStream; ++import java.io.ObjectOutputStream; ++import java.io.ObjectStreamField; + import java.io.IOException; + import java.io.ObjectStreamException; + import java.io.InvalidObjectException; +@@ -174,36 +176,196 @@ + */ + private transient int cached_scope_id = 0; + +- /** +- * Holds a 128-bit (16 bytes) IPv6 address. +- * +- * @serial +- */ +- byte[] ipaddress; ++ private class Inet6AddressHolder { + +- /** +- * scope_id. The scope specified when the object is created. If the object is created +- * with an interface name, then the scope_id is not determined until the time it is needed. +- */ +- private int scope_id = 0; ++ private Inet6AddressHolder() { ++ ipaddress = new byte[INADDRSZ]; ++ } + +- /** +- * This will be set to true when the scope_id field contains a valid +- * integer scope_id. +- */ +- private boolean scope_id_set = false; ++ private Inet6AddressHolder( ++ byte[] ipaddress, int scope_id, boolean scope_id_set, ++ NetworkInterface ifname, boolean scope_ifname_set) ++ { ++ this.ipaddress = ipaddress; ++ this.scope_id = scope_id; ++ this.scope_id_set = scope_id_set; ++ this.scope_ifname_set = scope_ifname_set; ++ this.scope_ifname = ifname; ++ } + +- /** +- * scoped interface. scope_id is derived from this as the scope_id of the first +- * address whose scope is the same as this address for the named interface. +- */ +- private transient NetworkInterface scope_ifname = null; ++ /** ++ * Holds a 128-bit (16 bytes) IPv6 address. ++ */ ++ byte[] ipaddress; + +- /** +- * set if the object is constructed with a scoped interface instead of a +- * numeric scope id. +- */ +- private boolean scope_ifname_set = false; ++ /** ++ * scope_id. The scope specified when the object is created. If the object is created ++ * with an interface name, then the scope_id is not determined until the time it is needed. ++ */ ++ int scope_id = 0; ++ ++ /** ++ * This will be set to true when the scope_id field contains a valid ++ * integer scope_id. ++ */ ++ boolean scope_id_set = false; ++ ++ /** ++ * scoped interface. scope_id is derived from this as the scope_id of the first ++ * address whose scope is the same as this address for the named interface. ++ */ ++ NetworkInterface scope_ifname = null; ++ ++ /** ++ * set if the object is constructed with a scoped interface instead of a ++ * numeric scope id. ++ */ ++ boolean scope_ifname_set = false; ++ ++ void setAddr(byte addr[]) { ++ if (addr.length == INADDRSZ) { // normal IPv6 address ++ System.arraycopy(addr, 0, ipaddress, 0, INADDRSZ); ++ } ++ } ++ ++ void init(byte addr[], int scope_id) { ++ setAddr(addr); ++ ++ if (scope_id >= 0) { ++ this.scope_id = scope_id; ++ this.scope_id_set = true; ++ } ++ } ++ ++ void init(byte addr[], NetworkInterface nif) ++ throws UnknownHostException ++ { ++ setAddr(addr); ++ ++ if (nif != null) { ++ this.scope_id = deriveNumericScope(ipaddress, nif); ++ this.scope_id_set = true; ++ this.scope_ifname = nif; ++ this.scope_ifname_set = true; ++ } ++ } ++ ++ String getHostAddress() { ++ String s = numericToTextFormat(ipaddress); ++ if (scope_ifname_set) { /* must check this first */ ++ s = s + "%" + scope_ifname.getName(); ++ } else if (scope_id_set) { ++ s = s + "%" + scope_id; ++ } ++ return s; ++ } ++ ++ public boolean equals(Object o) { ++ if (! (o instanceof Inet6AddressHolder)) { ++ return false; ++ } ++ Inet6AddressHolder that = (Inet6AddressHolder)o; ++ ++ for (int i = 0; i < INADDRSZ; i++) { ++ if (this.ipaddress[i] != that.ipaddress[i]) ++ return false; ++ } ++ ++ return true; ++ } ++ ++ public int hashCode() { ++ if (ipaddress != null) { ++ ++ int hash = 0; ++ int i=0; ++ while (i<INADDRSZ) { ++ int j=0; ++ int component=0; ++ while (j<4 && i<INADDRSZ) { ++ component = (component << 8) + ipaddress[i]; ++ j++; ++ i++; ++ } ++ hash += component; ++ } ++ return hash; ++ ++ } else { ++ return 0; ++ } ++ } ++ ++ boolean isIPv4CompatibleAddress() { ++ if ((ipaddress[0] == 0x00) && (ipaddress[1] == 0x00) && ++ (ipaddress[2] == 0x00) && (ipaddress[3] == 0x00) && ++ (ipaddress[4] == 0x00) && (ipaddress[5] == 0x00) && ++ (ipaddress[6] == 0x00) && (ipaddress[7] == 0x00) && ++ (ipaddress[8] == 0x00) && (ipaddress[9] == 0x00) && ++ (ipaddress[10] == 0x00) && (ipaddress[11] == 0x00)) { ++ return true; ++ } ++ return false; ++ } ++ ++ boolean isMulticastAddress() { ++ return ((ipaddress[0] & 0xff) == 0xff); ++ } ++ ++ boolean isAnyLocalAddress() { ++ byte test = 0x00; ++ for (int i = 0; i < INADDRSZ; i++) { ++ test |= ipaddress[i]; ++ } ++ return (test == 0x00); ++ } ++ ++ boolean isLoopbackAddress() { ++ byte test = 0x00; ++ for (int i = 0; i < 15; i++) { ++ test |= ipaddress[i]; ++ } ++ return (test == 0x00) && (ipaddress[15] == 0x01); ++ } ++ ++ boolean isLinkLocalAddress() { ++ return ((ipaddress[0] & 0xff) == 0xfe ++ && (ipaddress[1] & 0xc0) == 0x80); ++ } ++ ++ ++ boolean isSiteLocalAddress() { ++ return ((ipaddress[0] & 0xff) == 0xfe ++ && (ipaddress[1] & 0xc0) == 0xc0); ++ } ++ ++ boolean isMCGlobal() { ++ return ((ipaddress[0] & 0xff) == 0xff ++ && (ipaddress[1] & 0x0f) == 0x0e); ++ } ++ ++ boolean isMCNodeLocal() { ++ return ((ipaddress[0] & 0xff) == 0xff ++ && (ipaddress[1] & 0x0f) == 0x01); ++ } ++ ++ boolean isMCLinkLocal() { ++ return ((ipaddress[0] & 0xff) == 0xff ++ && (ipaddress[1] & 0x0f) == 0x02); ++ } ++ ++ boolean isMCSiteLocal() { ++ return ((ipaddress[0] & 0xff) == 0xff ++ && (ipaddress[1] & 0x0f) == 0x05); ++ } ++ ++ boolean isMCOrgLocal() { ++ return ((ipaddress[0] & 0xff) == 0xff ++ && (ipaddress[1] & 0x0f) == 0x08); ++ } ++ } ++ ++ private final transient Inet6AddressHolder holder6; + + private static final long serialVersionUID = 6880410070516793377L; + +@@ -216,37 +378,33 @@ + + Inet6Address() { + super(); +- holder().hostName = null; +- ipaddress = new byte[INADDRSZ]; +- holder().family = IPv6; ++ holder.init(null, IPv6); ++ holder6 = new Inet6AddressHolder(); + } + + /* checking of value for scope_id should be done by caller + * scope_id must be >= 0, or -1 to indicate not being set + */ + Inet6Address(String hostName, byte addr[], int scope_id) { +- holder().hostName = hostName; +- if (addr.length == INADDRSZ) { // normal IPv6 address +- holder().family = IPv6; +- ipaddress = addr.clone(); +- } +- if (scope_id >= 0) { +- this.scope_id = scope_id; +- scope_id_set = true; +- } ++ holder.init(hostName, IPv6); ++ holder6 = new Inet6AddressHolder(); ++ holder6.init(addr, scope_id); + } + + Inet6Address(String hostName, byte addr[]) { ++ holder6 = new Inet6AddressHolder(); + try { + initif (hostName, addr, null); + } catch (UnknownHostException e) {} /* cant happen if ifname is null */ + } + + Inet6Address (String hostName, byte addr[], NetworkInterface nif) throws UnknownHostException { ++ holder6 = new Inet6AddressHolder(); + initif (hostName, addr, nif); + } + + Inet6Address (String hostName, byte addr[], String ifname) throws UnknownHostException { ++ holder6 = new Inet6AddressHolder(); + initstr (hostName, addr, ifname); + } + +@@ -328,17 +486,13 @@ + } + + private void initif(String hostName, byte addr[],NetworkInterface nif) throws UnknownHostException { +- holder().hostName = hostName; ++ int family = -1; ++ holder6.init(addr, nif); ++ + if (addr.length == INADDRSZ) { // normal IPv6 address +- holder().family = IPv6; +- ipaddress = addr.clone(); ++ family = IPv6; + } +- if (nif != null) { +- this.scope_ifname = nif; +- scope_ifname_set = true; +- scope_id = deriveNumericScope (nif); +- scope_id_set = true; +- } ++ holder.init(hostName, family); + } + + /* check the two Ipv6 addresses and return false if they are both +@@ -346,18 +500,21 @@ + * (ie. one is sitelocal and the other linklocal) + * return true otherwise. + */ +- private boolean differentLocalAddressTypes(Inet6Address other) { ++ private static boolean differentLocalAddressTypes( ++ byte[] thisAddr, byte[] otherAddr) { + +- if (isLinkLocalAddress() && !other.isLinkLocalAddress()) { ++ if (Inet6Address.isLinkLocalAddress(thisAddr) && ++ !Inet6Address.isLinkLocalAddress(otherAddr)) { + return false; + } +- if (isSiteLocalAddress() && !other.isSiteLocalAddress()) { ++ if (Inet6Address.isSiteLocalAddress(thisAddr) && ++ !Inet6Address.isSiteLocalAddress(otherAddr)) { + return false; + } + return true; + } + +- private int deriveNumericScope (NetworkInterface ifc) throws UnknownHostException { ++ private static int deriveNumericScope (byte[] thisAddr, NetworkInterface ifc) throws UnknownHostException { + Enumeration addresses = ifc.getInetAddresses(); + while (addresses.hasMoreElements()) { + InetAddress address = (InetAddress)addresses.nextElement(); +@@ -366,12 +523,12 @@ + } + Inet6Address ia6_addr = (Inet6Address)address; + /* check if site or link local prefixes match */ +- if (!differentLocalAddressTypes(ia6_addr)){ ++ if (!differentLocalAddressTypes(thisAddr, ia6_addr.getAddress())){ + /* type not the same, so carry on searching */ + continue; + } + /* found a matching address - return its scope_id */ +- return ia6_addr.scope_id; ++ return ia6_addr.getScopeId(); + } + throw new UnknownHostException ("no scope_id found"); + } +@@ -386,47 +543,67 @@ + while (en.hasMoreElements()) { + NetworkInterface ifc = (NetworkInterface)en.nextElement(); + if (ifc.getName().equals (ifname)) { +- Enumeration addresses = ifc.getInetAddresses(); +- while (addresses.hasMoreElements()) { +- InetAddress address = (InetAddress)addresses.nextElement(); +- if (!(address instanceof Inet6Address)) { +- continue; +- } +- Inet6Address ia6_addr = (Inet6Address)address; +- /* check if site or link local prefixes match */ +- if (!differentLocalAddressTypes(ia6_addr)){ +- /* type not the same, so carry on searching */ +- continue; +- } +- /* found a matching address - return its scope_id */ +- return ia6_addr.scope_id; +- } ++ return deriveNumericScope(holder6.ipaddress, ifc); + } + } + throw new UnknownHostException ("No matching address found for interface : " +ifname); + } + + /** ++ * @serialField ipaddress byte[] ++ * @serialField scope_id int ++ * @serialField scope_id_set boolean ++ * @serialField scope_ifname_set boolean ++ * @serialField ifname String ++ */ ++ ++ private static final ObjectStreamField[] serialPersistentFields = { ++ new ObjectStreamField("ipaddress", byte[].class), ++ new ObjectStreamField("scope_id", int.class), ++ new ObjectStreamField("scope_id_set", boolean.class), ++ new ObjectStreamField("scope_ifname_set", boolean.class), ++ new ObjectStreamField("ifname", String.class) ++ }; ++ ++ private static final long FIELDS_OFFSET; ++ private static final sun.misc.Unsafe UNSAFE; ++ ++ static { ++ try { ++ sun.misc.Unsafe unsafe = sun.misc.Unsafe.getUnsafe(); ++ FIELDS_OFFSET = unsafe.objectFieldOffset( ++ Inet6Address.class.getDeclaredField("holder6")); ++ UNSAFE = unsafe; ++ } catch (NoSuchFieldException e) { ++ throw new Error(e); ++ } ++ } ++ ++ /** + * restore the state of this object from stream + * including the scope information, only if the + * scoped interface name is valid on this system + */ + private void readObject(ObjectInputStream s) + throws IOException, ClassNotFoundException { +- scope_ifname = null; +- scope_ifname_set = false; ++ NetworkInterface scope_ifname = null; + + if (getClass().getClassLoader() != null) { + throw new SecurityException ("invalid address type"); + } + +- s.defaultReadObject(); ++ ObjectInputStream.GetField gf = s.readFields(); ++ byte[] ipaddress = (byte[])gf.get("ipaddress", null); ++ int scope_id = (int)gf.get("scope_id", -1); ++ boolean scope_id_set = (boolean)gf.get("scope_id_set", false); ++ boolean scope_ifname_set = (boolean)gf.get("scope_ifname_set", false); ++ String ifname = (String)gf.get("ifname", null); + + if (ifname != null && !"".equals (ifname)) { + try { + scope_ifname = NetworkInterface.getByName(ifname); + try { +- scope_id = deriveNumericScope (scope_ifname); ++ scope_id = deriveNumericScope (ipaddress, scope_ifname); + } catch (UnknownHostException e) { + // should not happen + assert false; +@@ -451,9 +628,37 @@ + ipaddress.length); + } + +- if (holder().getFamily() != IPv6) { ++ if (holder.getFamily() != IPv6) { + throw new InvalidObjectException("invalid address family type"); + } ++ ++ Inet6AddressHolder h = new Inet6AddressHolder( ++ ipaddress, scope_id, scope_id_set, scope_ifname, scope_ifname_set ++ ); ++ ++ UNSAFE.putObject(this, FIELDS_OFFSET, h); ++ } ++ ++ /** ++ * default behavior is overridden in order to write the ++ * scope_ifname field as a String, rather than a NetworkInterface ++ * which is not serializable ++ */ ++ private synchronized void writeObject(ObjectOutputStream s) ++ throws IOException ++ { ++ String ifname = null; ++ ++ if (holder6.scope_ifname_set) { ++ ifname = holder6.scope_ifname.getName(); ++ } ++ ObjectOutputStream.PutField pfields = s.putFields(); ++ pfields.put("ipaddress", holder6.ipaddress); ++ pfields.put("scope_id", holder6.scope_id); ++ pfields.put("scope_id_set", holder6.scope_id_set); ++ pfields.put("scope_ifname_set", holder6.scope_ifname_set); ++ pfields.put("ifname", ifname); ++ s.writeFields(); + } + + /** +@@ -466,7 +671,7 @@ + * @since JDK1.1 + */ + public boolean isMulticastAddress() { +- return ((ipaddress[0] & 0xff) == 0xff); ++ return holder6.isMulticastAddress(); + } + + /** +@@ -476,11 +681,7 @@ + * @since 1.4 + */ + public boolean isAnyLocalAddress() { +- byte test = 0x00; +- for (int i = 0; i < INADDRSZ; i++) { +- test |= ipaddress[i]; +- } +- return (test == 0x00); ++ return holder6.isAnyLocalAddress(); + } + + /** +@@ -491,11 +692,7 @@ + * @since 1.4 + */ + public boolean isLoopbackAddress() { +- byte test = 0x00; +- for (int i = 0; i < 15; i++) { +- test |= ipaddress[i]; +- } +- return (test == 0x00) && (ipaddress[15] == 0x01); ++ return holder6.isLoopbackAddress(); + } + + /** +@@ -506,6 +703,11 @@ + * @since 1.4 + */ + public boolean isLinkLocalAddress() { ++ return holder6.isLinkLocalAddress(); ++ } ++ ++ /* static version of above */ ++ static boolean isLinkLocalAddress(byte[] ipaddress) { + return ((ipaddress[0] & 0xff) == 0xfe + && (ipaddress[1] & 0xc0) == 0x80); + } +@@ -518,6 +720,11 @@ + * @since 1.4 + */ + public boolean isSiteLocalAddress() { ++ return holder6.isSiteLocalAddress(); ++ } ++ ++ /* static version of above */ ++ static boolean isSiteLocalAddress(byte[] ipaddress) { + return ((ipaddress[0] & 0xff) == 0xfe + && (ipaddress[1] & 0xc0) == 0xc0); + } +@@ -531,8 +738,7 @@ + * @since 1.4 + */ + public boolean isMCGlobal() { +- return ((ipaddress[0] & 0xff) == 0xff +- && (ipaddress[1] & 0x0f) == 0x0e); ++ return holder6.isMCGlobal(); + } + + /** +@@ -544,8 +750,7 @@ + * @since 1.4 + */ + public boolean isMCNodeLocal() { +- return ((ipaddress[0] & 0xff) == 0xff +- && (ipaddress[1] & 0x0f) == 0x01); ++ return holder6.isMCNodeLocal(); + } + + /** +@@ -557,8 +762,7 @@ + * @since 1.4 + */ + public boolean isMCLinkLocal() { +- return ((ipaddress[0] & 0xff) == 0xff +- && (ipaddress[1] & 0x0f) == 0x02); ++ return holder6.isMCLinkLocal(); + } + + /** +@@ -570,8 +774,7 @@ + * @since 1.4 + */ + public boolean isMCSiteLocal() { +- return ((ipaddress[0] & 0xff) == 0xff +- && (ipaddress[1] & 0x0f) == 0x05); ++ return holder6.isMCSiteLocal(); + } + + /** +@@ -584,10 +787,8 @@ + * @since 1.4 + */ + public boolean isMCOrgLocal() { +- return ((ipaddress[0] & 0xff) == 0xff +- && (ipaddress[1] & 0x0f) == 0x08); ++ return holder6.isMCOrgLocal(); + } +- + /** + * Returns the raw IP address of this <code>InetAddress</code> + * object. The result is in network byte order: the highest order +@@ -596,7 +797,7 @@ + * @return the raw IP address of this object. + */ + public byte[] getAddress() { +- return ipaddress.clone(); ++ return holder6.ipaddress.clone(); + } + + /** +@@ -607,7 +808,7 @@ + * @since 1.5 + */ + public int getScopeId () { +- return scope_id; ++ return holder6.scope_id; + } + + /** +@@ -618,7 +819,7 @@ + * @since 1.5 + */ + public NetworkInterface getScopedInterface () { +- return scope_ifname; ++ return holder6.scope_ifname; + } + + /** +@@ -630,13 +831,7 @@ + * @return the raw IP address in a string format. + */ + public String getHostAddress() { +- String s = numericToTextFormat(ipaddress); +- if (scope_ifname_set) { /* must check this first */ +- s = s + "%" + scope_ifname.getName(); +- } else if (scope_id_set) { +- s = s + "%" + scope_id; +- } +- return s; ++ return holder6.getHostAddress(); + } + + /** +@@ -645,25 +840,7 @@ + * @return a hash code value for this IP address. + */ + public int hashCode() { +- if (ipaddress != null) { +- +- int hash = 0; +- int i=0; +- while (i<INADDRSZ) { +- int j=0; +- int component=0; +- while (j<4 && i<INADDRSZ) { +- component = (component << 8) + ipaddress[i]; +- j++; +- i++; +- } +- hash += component; +- } +- return hash; +- +- } else { +- return 0; +- } ++ return holder6.hashCode(); + } + + /** +@@ -689,12 +866,7 @@ + + Inet6Address inetAddr = (Inet6Address)obj; + +- for (int i = 0; i < INADDRSZ; i++) { +- if (ipaddress[i] != inetAddr.ipaddress[i]) +- return false; +- } +- +- return true; ++ return holder6.equals(inetAddr.holder6); + } + + /** +@@ -706,15 +878,7 @@ + * @since 1.4 + */ + public boolean isIPv4CompatibleAddress() { +- if ((ipaddress[0] == 0x00) && (ipaddress[1] == 0x00) && +- (ipaddress[2] == 0x00) && (ipaddress[3] == 0x00) && +- (ipaddress[4] == 0x00) && (ipaddress[5] == 0x00) && +- (ipaddress[6] == 0x00) && (ipaddress[7] == 0x00) && +- (ipaddress[8] == 0x00) && (ipaddress[9] == 0x00) && +- (ipaddress[10] == 0x00) && (ipaddress[11] == 0x00)) { +- return true; +- } +- return false; ++ return holder6.isIPv4CompatibleAddress(); + } + + // Utilities +@@ -744,23 +908,4 @@ + * Perform class load-time initializations. + */ + private static native void init(); +- +- /** +- * Following field is only used during (de)/serialization +- */ +- private String ifname; +- +- /** +- * default behavior is overridden in order to write the +- * scope_ifname field as a String, rather than a NetworkInterface +- * which is not serializable +- */ +- private synchronized void writeObject(java.io.ObjectOutputStream s) +- throws IOException +- { +- if (scope_ifname_set) { +- ifname = scope_ifname.getName(); +- } +- s.defaultWriteObject(); +- } + } +diff -r e10e9bfb11b0 -r 96aee3742c52 src/share/classes/java/net/InetAddress.java +--- jdk/src/share/classes/java/net/InetAddress.java Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/share/classes/java/net/InetAddress.java Tue Oct 15 21:28:50 2013 +0100 +@@ -210,6 +210,13 @@ + this.family = family; + } + ++ void init(String hostName, int family) { ++ this.hostName = hostName; ++ if (family != -1) { ++ this.family = family; ++ } ++ } ++ + String hostName; + + String getHostName() { +diff -r e10e9bfb11b0 -r 96aee3742c52 src/share/native/java/net/Inet6Address.c +--- jdk/src/share/native/java/net/Inet6Address.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/share/native/java/net/Inet6Address.c Tue Oct 15 21:28:50 2013 +0100 +@@ -33,6 +33,8 @@ + */ + + jclass ia6_class; ++jfieldID ia6_holder6ID; ++ + jfieldID ia6_ipaddressID; + jfieldID ia6_scopeidID; + jfieldID ia6_cachedscopeidID; +@@ -48,21 +50,26 @@ + */ + JNIEXPORT void JNICALL + Java_java_net_Inet6Address_init(JNIEnv *env, jclass cls) { ++ jclass ia6h_class; + jclass c = (*env)->FindClass(env, "java/net/Inet6Address"); + CHECK_NULL(c); + ia6_class = (*env)->NewGlobalRef(env, c); + CHECK_NULL(ia6_class); +- ia6_ipaddressID = (*env)->GetFieldID(env, ia6_class, "ipaddress", "[B"); ++ ia6h_class = (*env)->FindClass(env, "java/net/Inet6Address$Inet6AddressHolder"); ++ CHECK_NULL(ia6h_class); ++ ia6_holder6ID = (*env)->GetFieldID(env, ia6_class, "holder6", "Ljava/net/Inet6Address$Inet6AddressHolder;"); ++ CHECK_NULL(ia6_holder6ID); ++ ia6_ipaddressID = (*env)->GetFieldID(env, ia6h_class, "ipaddress", "[B"); + CHECK_NULL(ia6_ipaddressID); +- ia6_scopeidID = (*env)->GetFieldID(env, ia6_class, "scope_id", "I"); ++ ia6_scopeidID = (*env)->GetFieldID(env, ia6h_class, "scope_id", "I"); + CHECK_NULL(ia6_scopeidID); + ia6_cachedscopeidID = (*env)->GetFieldID(env, ia6_class, "cached_scope_id", "I"); + CHECK_NULL(ia6_cachedscopeidID); +- ia6_scopeidsetID = (*env)->GetFieldID(env, ia6_class, "scope_id_set", "Z"); ++ ia6_scopeidsetID = (*env)->GetFieldID(env, ia6h_class, "scope_id_set", "Z"); + CHECK_NULL(ia6_scopeidID); +- ia6_scopeifnameID = (*env)->GetFieldID(env, ia6_class, "scope_ifname", "Ljava/net/NetworkInterface;"); ++ ia6_scopeifnameID = (*env)->GetFieldID(env, ia6h_class, "scope_ifname", "Ljava/net/NetworkInterface;"); + CHECK_NULL(ia6_scopeifnameID); +- ia6_scopeifnamesetID = (*env)->GetFieldID(env, ia6_class, "scope_ifname_set", "Z"); ++ ia6_scopeifnamesetID = (*env)->GetFieldID(env, ia6h_class, "scope_ifname_set", "Z"); + CHECK_NULL(ia6_scopeifnamesetID); + ia6_ctrID = (*env)->GetMethodID(env, ia6_class, "<init>", "()V"); + CHECK_NULL(ia6_ctrID); +diff -r e10e9bfb11b0 -r 96aee3742c52 src/share/native/java/net/net_util.c +--- jdk/src/share/native/java/net/net_util.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/share/native/java/net/net_util.c Tue Oct 15 21:28:50 2013 +0100 +@@ -94,6 +94,111 @@ + extern jfieldID iac_addressID; + extern jfieldID iac_familyID; + ++/** ++ * set_ methods return JNI_TRUE on success JNI_FALSE on error ++ * get_ methods that return +ve int return -1 on error ++ * get_ methods that return objects return NULL on error. ++ */ ++jobject getInet6Address_scopeifname(JNIEnv *env, jobject iaObj) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, NULL); ++ return (*env)->GetObjectField(env, holder, ia6_scopeifnameID); ++} ++ ++int setInet6Address_scopeifname(JNIEnv *env, jobject iaObj, jobject scopeifname) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, JNI_FALSE); ++ (*env)->SetObjectField(env, holder, ia6_scopeifnameID, scopeifname); ++ return JNI_TRUE; ++} ++ ++int getInet6Address_scopeifname_set(JNIEnv *env, jobject iaObj) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, -1); ++ return (*env)->GetBooleanField(env, holder, ia6_scopeifnamesetID); ++} ++ ++int setInet6Address_scopeifname_set(JNIEnv *env, jobject iaObj, int scopeifname_set) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, JNI_FALSE); ++ (*env)->SetBooleanField(env, holder, ia6_scopeifnamesetID, scopeifname_set); ++ return JNI_TRUE; ++} ++ ++int getInet6Address_scopeid_set(JNIEnv *env, jobject iaObj) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, -1); ++ return (*env)->GetBooleanField(env, holder, ia6_scopeidsetID); ++} ++ ++int getInet6Address_scopeid(JNIEnv *env, jobject iaObj) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, -1); ++ return (*env)->GetIntField(env, holder, ia6_scopeidID); ++} ++ ++int setInet6Address_scopeid(JNIEnv *env, jobject iaObj, int scopeid) { ++ jobject holder; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, JNI_FALSE); ++ (*env)->SetIntField(env, holder, ia6_scopeidID, scopeid); ++ if (scopeid > 0) { ++ (*env)->SetBooleanField(env, holder, ia6_scopeidsetID, JNI_TRUE); ++ } ++ return JNI_TRUE; ++} ++ ++ ++int getInet6Address_ipaddress(JNIEnv *env, jobject iaObj, char *dest) { ++ jobject holder, addr; ++ jbyteArray barr; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, JNI_FALSE); ++ addr = (*env)->GetObjectField(env, holder, ia6_ipaddressID); ++ CHECK_NULL_RETURN(addr, JNI_FALSE); ++ (*env)->GetByteArrayRegion(env, addr, 0, 16, (jbyte *)dest); ++ return JNI_TRUE; ++} ++ ++int setInet6Address_ipaddress(JNIEnv *env, jobject iaObj, char *address) { ++ jobject holder; ++ jbyteArray addr; ++ ++ init(env); ++ holder = (*env)->GetObjectField(env, iaObj, ia6_holder6ID); ++ CHECK_NULL_RETURN(holder, JNI_FALSE); ++ addr = (jbyteArray)(*env)->GetObjectField(env, holder, ia6_ipaddressID); ++ if (addr == NULL) { ++ addr = (*env)->NewByteArray(env, 16); ++ CHECK_NULL_RETURN(addr, JNI_FALSE); ++ (*env)->SetObjectField(env, holder, ia6_ipaddressID, addr); ++ } ++ (*env)->SetByteArrayRegion(env, addr, 0, 16, (jbyte *)address); ++ return JNI_TRUE; ++} ++ + void setInetAddress_addr(JNIEnv *env, jobject iaObj, int address) { + jobject holder; + init(env); +@@ -166,6 +271,7 @@ + setInetAddress_family(env, iaObj, IPv4); + } else { + static jclass inet6Cls = 0; ++ int ret; + if (inet6Cls == 0) { + jclass c = (*env)->FindClass(env, "java/net/Inet6Address"); + CHECK_NULL_RETURN(c, NULL); +@@ -175,15 +281,10 @@ + } + iaObj = (*env)->NewObject(env, inet6Cls, ia6_ctrID); + CHECK_NULL_RETURN(iaObj, NULL); +- ipaddress = (*env)->NewByteArray(env, 16); +- CHECK_NULL_RETURN(ipaddress, NULL); +- (*env)->SetByteArrayRegion(env, ipaddress, 0, 16, +- (jbyte *)&(him6->sin6_addr)); +- +- (*env)->SetObjectField(env, iaObj, ia6_ipaddressID, ipaddress); +- ++ ret = setInet6Address_ipaddress(env, iaObj, (char *)&(him6->sin6_addr)); ++ CHECK_NULL_RETURN(ret, NULL); + setInetAddress_family(env, iaObj, IPv6); +- (*env)->SetIntField(env, iaObj, ia6_scopeidID, getScopeID(him)); ++ setInet6Address_scopeid(env, iaObj, getScopeID(him)); + } + *port = ntohs(him6->sin6_port); + } else +@@ -242,9 +343,8 @@ + if (family == AF_INET) { + return JNI_FALSE; + } +- ipaddress = (*env)->GetObjectField(env, iaObj, ia6_ipaddressID); +- scope = (*env)->GetIntField(env, iaObj, ia6_scopeidID); +- (*env)->GetByteArrayRegion(env, ipaddress, 0, 16, caddrCur); ++ scope = getInet6Address_scopeid(env, iaObj); ++ getInet6Address_ipaddress(env, iaObj, (char *)caddrCur); + if (NET_IsEqual(caddrNew, caddrCur) && cmpScopeID(scope, him)) { + return JNI_TRUE; + } else { +diff -r e10e9bfb11b0 -r 96aee3742c52 src/share/native/java/net/net_util.h +--- jdk/src/share/native/java/net/net_util.h Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/share/native/java/net/net_util.h Tue Oct 15 21:28:50 2013 +0100 +@@ -58,6 +58,22 @@ + extern jfieldID iac_hostNameID; + extern jfieldID ia_preferIPv6AddressID; + ++/** (Inet6Address accessors) ++ * set_ methods return JNI_TRUE on success JNI_FALSE on error ++ * get_ methods that return int/boolean, return -1 on error ++ * get_ methods that return objects return NULL on error. ++ */ ++extern jobject getInet6Address_scopeifname(JNIEnv *env, jobject ia6Obj); ++extern int setInet6Address_scopeifname(JNIEnv *env, jobject ia6Obj, jobject scopeifname); ++extern int getInet6Address_scopeifname_set(JNIEnv *env, jobject ia6Obj); ++extern int setInet6Address_scopeifname_set(JNIEnv *env, jobject ia6Obj, ++ int scopeifname_set); ++extern int getInet6Address_scopeid_set(JNIEnv *env, jobject ia6Obj); ++extern int getInet6Address_scopeid(JNIEnv *env, jobject ia6Obj); ++extern int setInet6Address_scopeid(JNIEnv *env, jobject ia6Obj, int scopeid); ++extern int getInet6Address_ipaddress(JNIEnv *env, jobject ia6Obj, char *dest); ++extern int setInet6Address_ipaddress(JNIEnv *env, jobject ia6Obj, char *address); ++ + extern void setInetAddress_addr(JNIEnv *env, jobject iaObj, int address); + extern void setInetAddress_family(JNIEnv *env, jobject iaObj, int family); + extern void setInetAddress_hostName(JNIEnv *env, jobject iaObj, jobject h); +@@ -93,6 +109,7 @@ + + /* Inet6Address fields */ + extern jclass ia6_class; ++extern jfieldID ia6_holder6ID; + extern jfieldID ia6_ipaddressID; + extern jfieldID ia6_scopeidID; + extern jfieldID ia6_cachedscopeidID; +diff -r e10e9bfb11b0 -r 96aee3742c52 src/solaris/native/java/net/Inet6AddressImpl.c +--- jdk/src/solaris/native/java/net/Inet6AddressImpl.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/solaris/native/java/net/Inet6AddressImpl.c Tue Oct 15 21:28:50 2013 +0100 +@@ -120,7 +120,6 @@ + static jclass ni_ia6cls; + static jmethodID ni_ia4ctrID; + static jmethodID ni_ia6ctrID; +-static jfieldID ni_ia6ipaddressID; + static int initialized = 0; + + /* +@@ -158,7 +157,6 @@ + ni_ia6cls = (*env)->NewGlobalRef(env, ni_ia6cls); + ni_ia4ctrID = (*env)->GetMethodID(env, ni_ia4cls, "<init>", "()V"); + ni_ia6ctrID = (*env)->GetMethodID(env, ni_ia6cls, "<init>", "()V"); +- ni_ia6ipaddressID = (*env)->GetFieldID(env, ni_ia6cls, "ipaddress", "[B"); + initialized = 1; + } + +@@ -310,6 +308,7 @@ + goto cleanupAndReturn; + } + while (iterator != NULL) { ++ int ret1; + if (iterator->ai_family == AF_INET) { + jobject iaObj = (*env)->NewObject(env, ni_ia4cls, ni_ia4ctrID); + if (IS_NULL(iaObj)) { +@@ -322,20 +321,17 @@ + inetIndex++; + } else if (iterator->ai_family == AF_INET6) { + jint scope = 0; +- jbyteArray ipaddress; + + jobject iaObj = (*env)->NewObject(env, ni_ia6cls, ni_ia6ctrID); + if (IS_NULL(iaObj)) { + ret = NULL; + goto cleanupAndReturn; + } +- ipaddress = (*env)->NewByteArray(env, 16); +- if (IS_NULL(ipaddress)) { +- ret = NULL; +- goto cleanupAndReturn; ++ ret1 = setInet6Address_ipaddress(env, iaObj, (char *)&(((struct sockaddr_in6*)iterator->ai_addr)->sin6_addr)); ++ if (!ret1) { ++ ret = NULL; ++ goto cleanupAndReturn; + } +- (*env)->SetByteArrayRegion(env, ipaddress, 0, 16, +- (jbyte *)&(((struct sockaddr_in6*)iterator->ai_addr)->sin6_addr)); + #ifdef __linux__ + if (!kernelIsV22()) { + scope = ((struct sockaddr_in6*)iterator->ai_addr)->sin6_scope_id; +@@ -344,10 +340,8 @@ + scope = ((struct sockaddr_in6*)iterator->ai_addr)->sin6_scope_id; + #endif + if (scope != 0) { /* zero is default value, no need to set */ +- (*env)->SetIntField(env, iaObj, ia6_scopeidID, scope); +- (*env)->SetBooleanField(env, iaObj, ia6_scopeidsetID, JNI_TRUE); ++ setInet6Address_scopeid(env, iaObj, scope); + } +- (*env)->SetObjectField(env, iaObj, ni_ia6ipaddressID, ipaddress); + setInetAddress_hostName(env, iaObj, name); + (*env)->SetObjectArrayElement(env, ret, inet6Index, iaObj); + inet6Index++; +diff -r e10e9bfb11b0 -r 96aee3742c52 src/solaris/native/java/net/NetworkInterface.c +--- jdk/src/solaris/native/java/net/NetworkInterface.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/solaris/native/java/net/NetworkInterface.c Tue Oct 15 21:28:50 2013 +0100 +@@ -101,7 +101,6 @@ + static jmethodID ni_ia4ctrID; + static jmethodID ni_ia6ctrID; + static jmethodID ni_ibctrID; +-static jfieldID ni_ia6ipaddressID; + static jfieldID ni_ibaddressID; + static jfieldID ni_ib4broadcastID; + static jfieldID ni_ib4maskID; +@@ -151,7 +150,6 @@ + ni_ia4ctrID = (*env)->GetMethodID(env, ni_ia4cls, "<init>", "()V"); + ni_ia6ctrID = (*env)->GetMethodID(env, ni_ia6cls, "<init>", "()V"); + ni_ibctrID = (*env)->GetMethodID(env, ni_ibcls, "<init>", "()V"); +- ni_ia6ipaddressID = (*env)->GetFieldID(env, ni_ia6cls, "ipaddress", "[B"); + ni_ibaddressID = (*env)->GetFieldID(env, ni_ibcls, "address", "Ljava/net/InetAddress;"); + ni_ib4broadcastID = (*env)->GetFieldID(env, ni_ibcls, "broadcast", "Ljava/net/Inet4Address;"); + ni_ib4maskID = (*env)->GetFieldID(env, ni_ibcls, "maskLength", "S"); +@@ -281,11 +279,9 @@ + #ifdef AF_INET6 + if (family == AF_INET6) { + jbyte *bytes = (jbyte *)&(((struct sockaddr_in6*)addrP->addr)->sin6_addr); +- jbyteArray ipaddress = (*env)->GetObjectField(env, iaObj, ni_ia6ipaddressID); + jbyte caddr[16]; + int i; +- +- (*env)->GetByteArrayRegion(env, ipaddress, 0, 16, caddr); ++ getInet6Address_ipaddress(env, iaObj, (char *)caddr); + i = 0; + while (i < 16) { + if (caddr[i] != bytes[i]) { +@@ -468,12 +464,10 @@ + int scope=0; + iaObj = (*env)->NewObject(env, ni_ia6cls, ni_ia6ctrID); + if (iaObj) { +- jbyteArray ipaddress = (*env)->NewByteArray(env, 16); +- if (ipaddress == NULL) { ++ int ret = setInet6Address_ipaddress(env, iaObj, (char *)&(((struct sockaddr_in6*)addrP->addr)->sin6_addr)); ++ if (ret == JNI_FALSE) { + return NULL; + } +- (*env)->SetByteArrayRegion(env, ipaddress, 0, 16, +- (jbyte *)&(((struct sockaddr_in6*)addrP->addr)->sin6_addr)); + #ifdef __linux__ + if (!kernelIsV22()) { + scope = ((struct sockaddr_in6*)addrP->addr)->sin6_scope_id; +@@ -482,11 +476,9 @@ + scope = ((struct sockaddr_in6*)addrP->addr)->sin6_scope_id; + #endif + if (scope != 0) { /* zero is default value, no need to set */ +- (*env)->SetIntField(env, iaObj, ia6_scopeidID, scope); +- (*env)->SetBooleanField(env, iaObj, ia6_scopeidsetID, JNI_TRUE); +- (*env)->SetObjectField(env, iaObj, ia6_scopeifnameID, netifObj); ++ setInet6Address_scopeid(env, iaObj, scope); ++ setInet6Address_scopeifname(env, iaObj, netifObj); + } +- (*env)->SetObjectField(env, iaObj, ni_ia6ipaddressID, ipaddress); + } + ibObj = (*env)->NewObject(env, ni_ibcls, ni_ibctrID); + if (ibObj) { +diff -r e10e9bfb11b0 -r 96aee3742c52 src/solaris/native/java/net/PlainDatagramSocketImpl.c +--- jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c Tue Oct 15 21:28:50 2013 +0100 +@@ -2311,8 +2311,7 @@ + caddr[14] = ((address >> 8) & 0xff); + caddr[15] = (address & 0xff); + } else { +- ipaddress = (*env)->GetObjectField(env, iaObj, ia6_ipaddressID); +- (*env)->GetByteArrayRegion(env, ipaddress, 0, 16, caddr); ++ getInet6Address_ipaddress(env, iaObj, caddr); + } + + memcpy((void *)&(mname6.ipv6mr_multiaddr), caddr, sizeof(struct in6_addr)); +diff -r e10e9bfb11b0 -r 96aee3742c52 src/solaris/native/java/net/net_util_md.c +--- jdk/src/solaris/native/java/net/net_util_md.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/solaris/native/java/net/net_util_md.c Tue Oct 15 21:28:50 2013 +0100 +@@ -680,7 +680,6 @@ + /* needs work. 1. family 2. clean up him6 etc deallocate memory */ + if (ipv6_available() && !(family == IPv4 && v4MappedAddress == JNI_FALSE)) { + struct sockaddr_in6 *him6 = (struct sockaddr_in6 *)him; +- jbyteArray ipaddress; + jbyte caddr[16]; + jint address; + +@@ -701,8 +700,7 @@ + caddr[15] = (address & 0xff); + } + } else { +- ipaddress = (*env)->GetObjectField(env, iaObj, ia6_ipaddressID); +- (*env)->GetByteArrayRegion(env, ipaddress, 0, 16, caddr); ++ getInet6Address_ipaddress(env, iaObj, (char *)caddr); + } + memset((char *)him6, 0, sizeof(struct sockaddr_in6)); + him6->sin6_port = htons(port); +@@ -734,7 +732,7 @@ + */ + if (!cached_scope_id) { + if (ia6_scopeidID) { +- scope_id = (int)(*env)->GetIntField(env,iaObj,ia6_scopeidID); ++ scope_id = getInet6Address_scopeid(env, iaObj); + } + if (scope_id != 0) { + /* check user-specified value for loopback case +@@ -780,7 +778,7 @@ + + if (family != IPv4) { + if (ia6_scopeidID) { +- him6->sin6_scope_id = (int)(*env)->GetIntField(env, iaObj, ia6_scopeidID); ++ him6->sin6_scope_id = getInet6Address_scopeid(env, iaObj); + } + } + #endif +diff -r e10e9bfb11b0 -r 96aee3742c52 src/windows/native/java/net/Inet6AddressImpl.c +--- jdk/src/windows/native/java/net/Inet6AddressImpl.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/windows/native/java/net/Inet6AddressImpl.c Tue Oct 15 21:28:50 2013 +0100 +@@ -76,7 +76,6 @@ + static jclass ni_ia6cls; + static jmethodID ni_ia4ctrID; + static jmethodID ni_ia6ctrID; +-static jfieldID ni_ia6ipaddressID; + static int initialized = 0; + + JNIEXPORT jobjectArray JNICALL +@@ -100,7 +99,6 @@ + ni_ia6cls = (*env)->NewGlobalRef(env, ni_ia6cls); + ni_ia4ctrID = (*env)->GetMethodID(env, ni_ia4cls, "<init>", "()V"); + ni_ia6ctrID = (*env)->GetMethodID(env, ni_ia6cls, "<init>", "()V"); +- ni_ia6ipaddressID = (*env)->GetFieldID(env, ni_ia6cls, "ipaddress", "[B"); + initialized = 1; + } + if (IS_NULL(host)) { +@@ -249,26 +247,22 @@ + (*env)->SetObjectArrayElement(env, ret, inetIndex, iaObj); + inetIndex ++; + } else if (iterator->ai_family == AF_INET6) { +- jint scope = 0; +- jbyteArray ipaddress; ++ jint scope = 0, ret1; + jobject iaObj = (*env)->NewObject(env, ni_ia6cls, ni_ia6ctrID); + if (IS_NULL(iaObj)) { + ret = NULL; + goto cleanupAndReturn; + } +- ipaddress = (*env)->NewByteArray(env, 16); +- if (IS_NULL(ipaddress)) { ++ ret1 = setInet6Address_ipaddress(env, iaObj, (jbyte *)&(((struct sockaddr_in6*)iterator->ai_addr)->sin6_addr)); ++ ++ if (ret1 == JNI_FALSE) { + ret = NULL; + goto cleanupAndReturn; + } +- (*env)->SetByteArrayRegion(env, ipaddress, 0, 16, +- (jbyte *)&(((struct sockaddr_in6*)iterator->ai_addr)->sin6_addr)); + scope = ((struct sockaddr_in6*)iterator->ai_addr)->sin6_scope_id; + if (scope != 0) { /* zero is default value, no need to set */ +- (*env)->SetIntField(env, iaObj, ia6_scopeidID, scope); +- (*env)->SetBooleanField(env, iaObj, ia6_scopeidsetID, JNI_TRUE); ++ setInet6Address_scopeid(env, iaObj, scope); + } +- (*env)->SetObjectField(env, iaObj, ni_ia6ipaddressID, ipaddress); + setInetAddress_hostName(env, iaObj, name); + (*env)->SetObjectArrayElement(env, ret, inet6Index, iaObj); + inet6Index ++; +diff -r e10e9bfb11b0 -r 96aee3742c52 src/windows/native/java/net/NetworkInterface.c +--- jdk/src/windows/native/java/net/NetworkInterface.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/windows/native/java/net/NetworkInterface.c Tue Oct 15 21:28:50 2013 +0100 +@@ -103,8 +103,6 @@ + + jclass ni_ia6cls; /* Inet6Address */ + jmethodID ni_ia6ctrID; /* Inet6Address() */ +-jfieldID ni_ia6ipaddressID; +-jfieldID ni_ia6ipaddressID; + + jclass ni_ibcls; /* InterfaceAddress */ + jmethodID ni_ibctrID; /* InterfaceAddress() */ +@@ -565,7 +563,6 @@ + ni_ia6cls = (*env)->FindClass(env, "java/net/Inet6Address"); + ni_ia6cls = (*env)->NewGlobalRef(env, ni_ia6cls); + ni_ia6ctrID = (*env)->GetMethodID(env, ni_ia6cls, "<init>", "()V"); +- ni_ia6ipaddressID = (*env)->GetFieldID(env, ni_ia6cls, "ipaddress", "[B"); + + ni_ibcls = (*env)->FindClass(env, "java/net/InterfaceAddress"); + ni_ibcls = (*env)->NewGlobalRef(env, ni_ibcls); +@@ -665,19 +662,16 @@ + int scope; + iaObj = (*env)->NewObject(env, ni_ia6cls, ni_ia6ctrID); + if (iaObj) { +- jbyteArray ipaddress = (*env)->NewByteArray(env, 16); +- if (ipaddress == NULL) { ++ int ret = setInet6Address_ipaddress(env, iaObj, (jbyte *)&(addrs->addr.him6.sin6_addr.s6_addr)); ++ if (ret == JNI_FALSE) { + return NULL; + } +- (*env)->SetByteArrayRegion(env, ipaddress, 0, 16, +- (jbyte *)&(addrs->addr.him6.sin6_addr.s6_addr)); ++ + scope = addrs->addr.him6.sin6_scope_id; + if (scope != 0) { /* zero is default value, no need to set */ +- (*env)->SetIntField(env, iaObj, ia6_scopeidID, scope); +- (*env)->SetBooleanField(env, iaObj, ia6_scopeidsetID, JNI_TRUE); +- (*env)->SetObjectField(env, iaObj, ia6_scopeifnameID, netifObj); ++ setInet6Address_scopeid(env, iaObj, scope); ++ setInet6Address_scopeifname(env, iaObj, netifObj); + } +- (*env)->SetObjectField(env, iaObj, ni_ia6ipaddressID, ipaddress); + ibObj = (*env)->NewObject(env, ni_ibcls, ni_ibctrID); + if (ibObj == NULL) { + free_netaddr(netaddrP); +diff -r e10e9bfb11b0 -r 96aee3742c52 src/windows/native/java/net/NetworkInterface_winXP.c +--- jdk/src/windows/native/java/net/NetworkInterface_winXP.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/windows/native/java/net/NetworkInterface_winXP.c Tue Oct 15 21:28:50 2013 +0100 +@@ -490,19 +490,15 @@ + int scope; + iaObj = (*env)->NewObject(env, ni_ia6cls, ni_ia6ctrID); + if (iaObj) { +- jbyteArray ipaddress = (*env)->NewByteArray(env, 16); +- if (ipaddress == NULL) { ++ int ret = setInet6Address_ipaddress(env, iaObj, (jbyte *)&(addrs->addr.him6.sin6_addr.s6_addr)); ++ if (ret == JNI_FALSE) { + return NULL; + } +- (*env)->SetByteArrayRegion(env, ipaddress, 0, 16, +- (jbyte *)&(addrs->addr.him6.sin6_addr.s6_addr)); + scope = addrs->addr.him6.sin6_scope_id; + if (scope != 0) { /* zero is default value, no need to set */ +- (*env)->SetIntField(env, iaObj, ia6_scopeidID, scope); +- (*env)->SetBooleanField(env, iaObj, ia6_scopeidsetID, JNI_TRUE); +- (*env)->SetObjectField(env, iaObj, ia6_scopeifnameID, netifObj); ++ setInet6Address_scopeid(env, iaObj, scope); ++ setInet6Address_scopeifname(env, iaObj, netifObj); + } +- (*env)->SetObjectField(env, iaObj, ni_ia6ipaddressID, ipaddress); + ibObj = (*env)->NewObject(env, ni_ibcls, ni_ibctrID); + if (ibObj == NULL) { + free_netaddr(netaddrP); +diff -r e10e9bfb11b0 -r 96aee3742c52 src/windows/native/java/net/TwoStacksPlainSocketImpl.c +--- jdk/src/windows/native/java/net/TwoStacksPlainSocketImpl.c Thu Jun 13 10:31:21 2013 +0800 ++++ jdk/src/windows/native/java/net/TwoStacksPlainSocketImpl.c Tue Oct 15 21:28:50 2013 +0100 +@@ -726,7 +726,6 @@ + setInetAddress_family(env, socketAddressObj, IPv4); + (*env)->SetObjectField(env, socket, psi_addressID, socketAddressObj); + } else { +- jbyteArray addr; + /* AF_INET6 -> Inet6Address */ + if (inet6Cls == 0) { + jclass c = (*env)->FindClass(env, "java/net/Inet6Address"); +@@ -749,10 +748,10 @@ + NET_SocketClose(fd); + return; + } +- addr = (*env)->GetObjectField (env, socketAddressObj, ia6_ipaddressID); +- (*env)->SetByteArrayRegion (env, addr, 0, 16, (const char *)&him.him6.sin6_addr); ++ setInet6Address_ipaddress(env, socketAddressObj, (const char *)&him.him6.sin6_addr); ++ + setInetAddress_family(env, socketAddressObj, IPv6); +- (*env)->SetIntField(env, socketAddressObj, ia6_scopeidID, him.him6.sin6_scope_id); ++ setInet6Address_scopeid(env, socketAddressObj, him.him6.sin6_scope_id); + } + /* fields common to AF_INET and AF_INET6 */ + diff --git a/java/openjdk6/files/icedtea/openjdk/8015965-typo_in_property_name.patch b/java/openjdk6/files/icedtea/openjdk/8015965-typo_in_property_name.patch new file mode 100644 index 000000000000..0a064060c57e --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8015965-typo_in_property_name.patch @@ -0,0 +1,42 @@ +# HG changeset patch +# User coffeys +# Date 1370453984 -3600 +# Wed Jun 05 18:39:44 2013 +0100 +# Node ID 35c5b3f404aac29ec5cccaeb32106af47546b6db +# Parent 20c88fd14959c6a4df2e0f36bd759b56efa6f2cb +8015965: (process) Typo in name of property to allow ambiguous commands +Reviewed-by: alanb + +diff -r 20c88fd14959 -r 35c5b3f404aa src/windows/classes/java/lang/ProcessImpl.java +--- jdk/src/windows/classes/java/lang/ProcessImpl.java Tue Oct 29 01:07:01 2013 +0000 ++++ jdk/src/windows/classes/java/lang/ProcessImpl.java Wed Jun 05 18:39:44 2013 +0100 +@@ -218,13 +218,13 @@ + { + String cmdstr; + SecurityManager security = System.getSecurityManager(); +- boolean allowAmbigousCommands = false; ++ boolean allowAmbiguousCommands = false; + if (security == null) { +- String value = System.getProperty("jdk.lang.Process.allowAmbigousCommands"); ++ String value = System.getProperty("jdk.lang.Process.allowAmbiguousCommands"); + if (value != null) +- allowAmbigousCommands = !"false".equalsIgnoreCase(value); ++ allowAmbiguousCommands = !"false".equalsIgnoreCase(value); + } +- if (allowAmbigousCommands) { ++ if (allowAmbiguousCommands) { + // Legacy mode. + + // Normalize path if possible. +diff -r 20c88fd14959 -r 35c5b3f404aa test/java/lang/Runtime/exec/ExecCommand.java +--- jdk/test/java/lang/Runtime/exec/ExecCommand.java Tue Oct 29 01:07:01 2013 +0000 ++++ jdk/test/java/lang/Runtime/exec/ExecCommand.java Wed Jun 05 18:39:44 2013 +0100 +@@ -129,7 +129,7 @@ + for (int k = 0; k < 3; ++k) { + switch (k) { + case 1: +- System.setProperty("jdk.lang.Process.allowAmbigousCommands", ""); ++ System.setProperty("jdk.lang.Process.allowAmbiguousCommands", ""); + break; + case 2: + System.setSecurityManager( new SecurityMan() ); diff --git a/java/openjdk6/files/icedtea/openjdk/8015978-incorrect_transformation.patch b/java/openjdk6/files/icedtea/openjdk/8015978-incorrect_transformation.patch new file mode 100644 index 000000000000..1bfbb3b8f64e --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8015978-incorrect_transformation.patch @@ -0,0 +1,22 @@ +# HG changeset patch +# User aefimov +# Date 1383034304 0 +# Tue Oct 29 08:11:44 2013 +0000 +# Node ID efb24af909a020f3a3b3d446f6db15fc8b1c309a +# Parent 20ffb814205c67b5ded678ee6c69b2aa0d6cebb1 +8015978: Incorrect transformation of XPath expression "string(-0)" +Reviewed-by: darcy, joehw + +diff -r 20ffb814205c -r efb24af909a0 drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/runtime/BasisLibrary.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/runtime/BasisLibrary.java Tue Oct 29 08:10:15 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/runtime/BasisLibrary.java Tue Oct 29 08:11:44 2013 +0000 +@@ -950,6 +950,9 @@ + if (Double.isNaN(d) || Double.isInfinite(d)) + return(Double.toString(d)); + ++ //Convert -0.0 to +0.0 other values remains the same ++ d = d + 0.0; ++ + // Use the XPath formatter to ignore locales + StringBuffer result = threadLocalStringBuffer.get(); + result.setLength(0); diff --git a/java/openjdk6/files/icedtea/openjdk/8016256-finalization_final.patch b/java/openjdk6/files/icedtea/openjdk/8016256-finalization_final.patch new file mode 100644 index 000000000000..97e49ca9adfc --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8016256-finalization_final.patch @@ -0,0 +1,24 @@ +# HG changeset patch +# User sgabdura +# Date 1373869363 -14400 +# Mon Jul 15 10:22:43 2013 +0400 +# Node ID bbd051c9089f61c65fe7d95487d47920164c7ee0 +# Parent 918a90950fa69e5247e3af2599d2e7674d64e3d6 +8016256: Make finalization final +Reviewed-by: hseigel + +diff -r 918a90950fa6 -r bbd051c9089f src/share/vm/classfile/classFileParser.cpp +--- hotspot/src/share/vm/classfile/classFileParser.cpp Thu Oct 10 16:41:17 2013 +0100 ++++ hotspot/src/share/vm/classfile/classFileParser.cpp Mon Jul 15 10:22:43 2013 +0400 +@@ -3762,9 +3762,8 @@ + for (int index = 0; index < num_methods; index++) { + methodOop m = (methodOop)methods->obj_at(index); + +- // skip private, static and <init> methods +- if ((!m->is_private()) && +- (!m->is_static()) && ++ // skip static and <init> methods ++ if ((!m->is_static()) && + (m->name() != vmSymbols::object_initializer_name())) { + + Symbol* name = m->name(); diff --git a/java/openjdk6/files/icedtea/openjdk/8016357-update_hs_diagnostic_class.patch b/java/openjdk6/files/icedtea/openjdk/8016357-update_hs_diagnostic_class.patch new file mode 100644 index 000000000000..7c7546939574 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8016357-update_hs_diagnostic_class.patch @@ -0,0 +1,71 @@ +# HG changeset patch +# User sgabdura +# Date 1381896654 -3600 +# Wed Oct 16 05:10:54 2013 +0100 +# Node ID 1ed7c9cea8c508e60d6df30c046ab48b1f1d3ab9 +# Parent 96aee3742c52d2d1a83a3db0be2c14892a511c67 +8016357: Update hotspot diagnostic class +Summary: Add security check to HotSpotDiagnostic.dumpHeap +Reviewed-by: fparain, sla, ahgross + +diff -r 96aee3742c52 -r 1ed7c9cea8c5 make/java/management/mapfile-vers +--- jdk/make/java/management/mapfile-vers Tue Oct 15 21:28:50 2013 +0100 ++++ jdk/make/java/management/mapfile-vers Wed Oct 16 05:10:54 2013 +0100 +@@ -50,7 +50,7 @@ + Java_sun_management_GcInfoBuilder_fillGcAttributeInfo; + Java_sun_management_GcInfoBuilder_getLastGcInfo0; + Java_sun_management_GcInfoBuilder_getNumGcExtAttributes; +- Java_sun_management_HotSpotDiagnostic_dumpHeap; ++ Java_sun_management_HotSpotDiagnostic_dumpHeap0; + Java_sun_management_HotspotThread_getInternalThreadCount; + Java_sun_management_HotspotThread_getInternalThreadTimes0; + Java_sun_management_MemoryImpl_getMemoryManagers0; +diff -r 96aee3742c52 -r 1ed7c9cea8c5 src/share/classes/com/sun/management/HotSpotDiagnosticMXBean.java +--- jdk/src/share/classes/com/sun/management/HotSpotDiagnosticMXBean.java Tue Oct 15 21:28:50 2013 +0100 ++++ jdk/src/share/classes/com/sun/management/HotSpotDiagnosticMXBean.java Wed Oct 16 05:10:54 2013 +0100 +@@ -54,6 +54,11 @@ + * cannot be created, opened, or written to. + * @throws UnsupportedOperationException if this operation is not supported. + * @throws NullPointerException if <tt>outputFile</tt> is <tt>null</tt>. ++ * @throws SecurityException ++ * If a security manager exists and its {@link ++ * java.lang.SecurityManager#checkWrite(java.lang.String)} ++ * method denies write access to the named file ++ * or the caller does not have ManagmentPermission("control"). + */ + public void dumpHeap(String outputFile, boolean live) throws java.io.IOException; + +diff -r 96aee3742c52 -r 1ed7c9cea8c5 src/share/classes/sun/management/HotSpotDiagnostic.java +--- jdk/src/share/classes/sun/management/HotSpotDiagnostic.java Tue Oct 15 21:28:50 2013 +0100 ++++ jdk/src/share/classes/sun/management/HotSpotDiagnostic.java Wed Oct 16 05:10:54 2013 +0100 +@@ -38,7 +38,17 @@ + public HotSpotDiagnostic() { + } + +- public native void dumpHeap(String outputFile, boolean live) throws IOException; ++ public void dumpHeap(String outputFile, boolean live) throws IOException { ++ SecurityManager security = System.getSecurityManager(); ++ if (security != null) { ++ security.checkWrite(outputFile); ++ ManagementFactory.checkControlAccess(); ++ } ++ ++ dumpHeap0(outputFile, live); ++ } ++ ++ private native void dumpHeap0(String outputFile, boolean live) throws IOException; + + public List<VMOption> getDiagnosticOptions() { + List<Flag> allFlags = Flag.getAllFlags(); +diff -r 96aee3742c52 -r 1ed7c9cea8c5 src/share/native/sun/management/HotSpotDiagnostic.c +--- jdk/src/share/native/sun/management/HotSpotDiagnostic.c Tue Oct 15 21:28:50 2013 +0100 ++++ jdk/src/share/native/sun/management/HotSpotDiagnostic.c Wed Oct 16 05:10:54 2013 +0100 +@@ -29,7 +29,7 @@ + #include "sun_management_HotSpotDiagnostic.h" + + JNIEXPORT void JNICALL +-Java_sun_management_HotSpotDiagnostic_dumpHeap ++Java_sun_management_HotSpotDiagnostic_dumpHeap0 + (JNIEnv *env, jobject dummy, jstring outputfile, jboolean live) + { + jmm_interface->DumpHeap0(env, outputfile, live); diff --git a/java/openjdk6/files/icedtea/openjdk/8016653-ignoreable_characters.patch b/java/openjdk6/files/icedtea/openjdk/8016653-ignoreable_characters.patch new file mode 100644 index 000000000000..23f2d235facc --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8016653-ignoreable_characters.patch @@ -0,0 +1,101 @@ +# HG changeset patch +# User robm +# Date 1383034867 0 +# Tue Oct 29 08:21:07 2013 +0000 +# Node ID e6d4480e2b11853e5ec5bbced3d351564e174632 +# Parent 843659ece699889459239c6470e67265de2b3f73 +8016653: javadoc should ignore ignoreable characters in names +Reviewed-by: jjg + +diff -r 843659ece699 -r e6d4480e2b11 src/share/classes/com/sun/tools/javac/parser/Scanner.java +--- langtools/src/share/classes/com/sun/tools/javac/parser/Scanner.java Fri Jul 19 16:02:59 2013 -0700 ++++ langtools/src/share/classes/com/sun/tools/javac/parser/Scanner.java Tue Oct 29 08:21:07 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1999, 2006, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -514,11 +514,10 @@ + private void scanIdent() { + boolean isJavaIdentifierPart; + char high; ++ if (sp == sbuf.length) putChar(ch); else sbuf[sp++] = ch; ++ // optimization, was: putChar(ch); ++ scanChar(); + do { +- if (sp == sbuf.length) putChar(ch); else sbuf[sp++] = ch; +- // optimization, was: putChar(ch); +- +- scanChar(); + switch (ch) { + case 'A': case 'B': case 'C': case 'D': case 'E': + case 'F': case 'G': case 'H': case 'I': case 'J': +@@ -535,6 +534,7 @@ + case '$': case '_': + case '0': case '1': case '2': case '3': case '4': + case '5': case '6': case '7': case '8': case '9': ++ break; + case '\u0000': case '\u0001': case '\u0002': case '\u0003': + case '\u0004': case '\u0005': case '\u0006': case '\u0007': + case '\u0008': case '\u000E': case '\u000F': case '\u0010': +@@ -542,30 +542,37 @@ + case '\u0015': case '\u0016': case '\u0017': + case '\u0018': case '\u0019': case '\u001B': + case '\u007F': +- break; ++ scanChar(); ++ continue; + case '\u001A': // EOI is also a legal identifier part + if (bp >= buflen) { + name = names.fromChars(sbuf, 0, sp); + token = keywords.key(name); + return; + } +- break; ++ scanChar(); ++ continue; + default: + if (ch < '\u0080') { + // all ASCII range chars already handled, above + isJavaIdentifierPart = false; + } else { +- high = scanSurrogates(); +- if (high != 0) { +- if (sp == sbuf.length) { +- putChar(high); ++ if (Character.isIdentifierIgnorable(ch)) { ++ scanChar(); ++ continue; ++ } else { ++ high = scanSurrogates(); ++ if (high != 0) { ++ if (sp == sbuf.length) { ++ putChar(high); ++ } else { ++ sbuf[sp++] = high; ++ } ++ isJavaIdentifierPart = Character.isJavaIdentifierPart( ++ Character.toCodePoint(high, ch)); + } else { +- sbuf[sp++] = high; ++ isJavaIdentifierPart = Character.isJavaIdentifierPart(ch); + } +- isJavaIdentifierPart = Character.isJavaIdentifierPart( +- Character.toCodePoint(high, ch)); +- } else { +- isJavaIdentifierPart = Character.isJavaIdentifierPart(ch); + } + } + if (!isJavaIdentifierPart) { +@@ -574,6 +581,9 @@ + return; + } + } ++ if (sp == sbuf.length) putChar(ch); else sbuf[sp++] = ch; ++ // optimization, was: putChar(ch); ++ scanChar(); + } while (true); + } + diff --git a/java/openjdk6/files/icedtea/openjdk/8016675-robust_javadoc.patch b/java/openjdk6/files/icedtea/openjdk/8016675-robust_javadoc.patch new file mode 100644 index 000000000000..191516077a43 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8016675-robust_javadoc.patch @@ -0,0 +1,75 @@ +# HG changeset patch +# User bpatel +# Date 1374274979 25200 +# Fri Jul 19 16:02:59 2013 -0700 +# Node ID 843659ece699889459239c6470e67265de2b3f73 +# Parent 9083313d5733ca9be66bc52cf64b9b5d4dd2e39a +8016675: Make Javadoc pages more robust +Reviewed-by: jlaskey, ksrini + +diff -r 9083313d5733 -r 843659ece699 src/share/classes/com/sun/tools/doclets/formats/html/markup/HtmlWriter.java +--- langtools/src/share/classes/com/sun/tools/doclets/formats/html/markup/HtmlWriter.java Fri Oct 25 16:10:09 2013 +0100 ++++ langtools/src/share/classes/com/sun/tools/doclets/formats/html/markup/HtmlWriter.java Fri Jul 19 16:02:59 2013 -0700 +@@ -289,7 +289,7 @@ + script.addAttr(HtmlAttr.TYPE, "text/javascript"); + String scriptCode = "<!--" + DocletConstants.NL + + " if (location.href.indexOf('is-external=true') == -1) {" + DocletConstants.NL + +- " parent.document.title=\"" + winTitle + "\";" + DocletConstants.NL + ++ " parent.document.title=\"" + escapeJavaScriptChars(winTitle) + "\";" + DocletConstants.NL + + " }" + DocletConstants.NL + + "//-->" + DocletConstants.NL; + RawHtml scriptContent = new RawHtml(scriptCode); +@@ -299,6 +299,53 @@ + } + + /** ++ * Returns a String with escaped special JavaScript characters. ++ * ++ * @param s String that needs to be escaped ++ * @return a valid escaped JavaScript string ++ */ ++ private static String escapeJavaScriptChars(String s) { ++ StringBuilder sb = new StringBuilder(); ++ for (int i = 0; i < s.length(); i++) { ++ char ch = s.charAt(i); ++ switch (ch) { ++ case '\b': ++ sb.append("\\b"); ++ break; ++ case '\t': ++ sb.append("\\t"); ++ break; ++ case '\n': ++ sb.append("\\n"); ++ break; ++ case '\f': ++ sb.append("\\f"); ++ break; ++ case '\r': ++ sb.append("\\r"); ++ break; ++ case '"': ++ sb.append("\\\""); ++ break; ++ case '\'': ++ sb.append("\\\'"); ++ break; ++ case '\\': ++ sb.append("\\\\"); ++ break; ++ default: ++ if (ch < 32 || ch >= 127) { ++ sb.append(String.format("\\u%04X", (int)ch)); ++ } else { ++ sb.append(ch); ++ } ++ break; ++ } ++ } ++ return sb.toString(); ++ } ++ ++ /** + * Returns a content tree for the SCRIPT tag for the main page(index.html). + * + * @return a content for the SCRIPT tag diff --git a/java/openjdk6/files/icedtea/openjdk/8017196-ensure_proxies_are_handled_appropriately-jdk.patch b/java/openjdk6/files/icedtea/openjdk/8017196-ensure_proxies_are_handled_appropriately-jdk.patch new file mode 100644 index 000000000000..0fab3210af7d --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017196-ensure_proxies_are_handled_appropriately-jdk.patch @@ -0,0 +1,107 @@ +# HG changeset patch +# User mchung +# Date 1382731288 -3600 +# Fri Oct 25 21:01:28 2013 +0100 +# Node ID 43b600fed0e8ac9d5ffe7556617d4850143e2dcd +# Parent a2b63addc0633a5ef8d196d1019d78b920cb4b1a +8017196: Ensure Proxies are handled appropriately +Reviewed-by: dfuchs, jrose, jdn, ahgross, chegar + +diff -r a2b63addc063 -r 43b600fed0e8 src/share/classes/java/lang/reflect/Proxy.java +--- jdk/src/share/classes/java/lang/reflect/Proxy.java Fri Oct 25 19:45:04 2013 +0100 ++++ jdk/src/share/classes/java/lang/reflect/Proxy.java Fri Oct 25 21:01:28 2013 +0100 +@@ -787,6 +787,7 @@ + * @throws IllegalArgumentException if the argument is not a + * proxy instance + */ ++ @CallerSensitive + public static InvocationHandler getInvocationHandler(Object proxy) + throws IllegalArgumentException + { +@@ -797,8 +798,19 @@ + throw new IllegalArgumentException("not a proxy instance"); + } + +- Proxy p = (Proxy) proxy; +- return p.h; ++ final Proxy p = (Proxy) proxy; ++ final InvocationHandler ih = p.h; ++ if (System.getSecurityManager() != null) { ++ Class<?> ihClass = ih.getClass(); ++ Class<?> caller = Reflection.getCallerClass(); ++ if (ReflectUtil.needsPackageAccessCheck(caller.getClassLoader(), ++ ihClass.getClassLoader())) ++ { ++ ReflectUtil.checkPackageAccess(ihClass); ++ } ++ } ++ ++ return ih; + } + + private static native Class defineClass0(ClassLoader loader, String name, +diff -r a2b63addc063 -r 43b600fed0e8 src/share/classes/sun/reflect/misc/ReflectUtil.java +--- jdk/src/share/classes/sun/reflect/misc/ReflectUtil.java Fri Oct 25 19:45:04 2013 +0100 ++++ jdk/src/share/classes/sun/reflect/misc/ReflectUtil.java Fri Oct 25 21:01:28 2013 +0100 +@@ -26,8 +26,10 @@ + + package sun.reflect.misc; + ++import java.lang.reflect.Method; + import java.lang.reflect.Modifier; + import java.lang.reflect.Proxy; ++import java.util.Arrays; + import sun.reflect.Reflection; + + public final class ReflectUtil { +@@ -257,4 +259,50 @@ + String pkg = (i != -1) ? name.substring(0, i) : ""; + return Proxy.isProxyClass(cls) && !pkg.equals(PROXY_PACKAGE); + } ++ ++ /** ++ * Check if the given method is a method declared in the proxy interface ++ * implemented by the given proxy instance. ++ * ++ * @param proxy a proxy instance ++ * @param method an interface method dispatched to a InvocationHandler ++ * ++ * @throws IllegalArgumentException if the given proxy or method is invalid. ++ */ ++ public static void checkProxyMethod(Object proxy, Method method) { ++ // check if it is a valid proxy instance ++ if (proxy == null || !Proxy.isProxyClass(proxy.getClass())) { ++ throw new IllegalArgumentException("Not a Proxy instance"); + } ++ if (Modifier.isStatic(method.getModifiers())) { ++ throw new IllegalArgumentException("Can't handle static method"); ++ } ++ ++ Class<?> c = method.getDeclaringClass(); ++ if (c == Object.class) { ++ String name = method.getName(); ++ if (name.equals("hashCode") || name.equals("equals") || name.equals("toString")) { ++ return; ++ } ++ } ++ ++ if (isSuperInterface(proxy.getClass(), c)) { ++ return; ++ } ++ ++ // disallow any method not declared in one of the proxy intefaces ++ throw new IllegalArgumentException("Can't handle: " + method); ++ } ++ ++ private static boolean isSuperInterface(Class<?> c, Class<?> intf) { ++ for (Class<?> i : c.getInterfaces()) { ++ if (i == intf) { ++ return true; ++ } ++ if (isSuperInterface(i, intf)) { ++ return true; ++ } ++ } ++ return false; ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8017196-ensure_proxies_are_handled_appropriately.patch b/java/openjdk6/files/icedtea/openjdk/8017196-ensure_proxies_are_handled_appropriately.patch new file mode 100644 index 000000000000..4208d24006b3 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017196-ensure_proxies_are_handled_appropriately.patch @@ -0,0 +1,94 @@ +# HG changeset patch +# User mchung +# Date 1374193345 25200 +# Thu Jul 18 17:22:25 2013 -0700 +# Node ID 2a415f9ee0976719ac79e6e5e2b1f00b29636427 +# Parent 9e7e1b6ab5cdf0096c9c16d991e6a982771a15f1 +8017196: Ensure Proxies are handled appropriately +Reviewed-by: dfuchs, jrose, jdn, ahgross, chegar + +diff -r 9e7e1b6ab5cd -r 2a415f9ee097 src/share/classes/com/sun/corba/se/impl/presentation/rmi/InvocationHandlerFactoryImpl.java +--- corba/src/share/classes/com/sun/corba/se/impl/presentation/rmi/InvocationHandlerFactoryImpl.java Tue Oct 15 15:24:25 2013 +0100 ++++ corba/src/share/classes/com/sun/corba/se/impl/presentation/rmi/InvocationHandlerFactoryImpl.java Thu Jul 18 17:22:25 2013 -0700 +@@ -43,6 +43,8 @@ + import com.sun.corba.se.spi.orbutil.proxy.DelegateInvocationHandlerImpl ; + import com.sun.corba.se.spi.orbutil.proxy.CompositeInvocationHandler ; + import com.sun.corba.se.spi.orbutil.proxy.CompositeInvocationHandlerImpl ; ++import java.security.AccessController; ++import java.security.PrivilegedAction; + + public class InvocationHandlerFactoryImpl implements InvocationHandlerFactory + { +@@ -114,24 +116,32 @@ + // which extends org.omg.CORBA.Object. This handler delegates all + // calls directly to a DynamicStubImpl, which extends + // org.omg.CORBA.portable.ObjectImpl. +- InvocationHandler dynamicStubHandler = ++ final InvocationHandler dynamicStubHandler = + DelegateInvocationHandlerImpl.create( stub ) ; + + // Create an invocation handler that handles any remote interface + // methods. +- InvocationHandler stubMethodHandler = new StubInvocationHandlerImpl( ++ final InvocationHandler stubMethodHandler = new StubInvocationHandlerImpl( + pm, classData, stub ) ; + + // Create a composite handler that handles the DynamicStub interface + // as well as the remote interfaces. + final CompositeInvocationHandler handler = + new CustomCompositeInvocationHandlerImpl( stub ) ; ++ ++ AccessController.doPrivileged(new PrivilegedAction<Void>() { ++ @Override ++ public Void run() { + handler.addInvocationHandler( DynamicStub.class, + dynamicStubHandler ) ; + handler.addInvocationHandler( org.omg.CORBA.Object.class, + dynamicStubHandler ) ; + handler.addInvocationHandler( Object.class, + dynamicStubHandler ) ; ++ return null; ++ } ++ }); ++ + + // If the method passed to invoke is not from DynamicStub or its superclasses, + // it must be from an implemented interface, so we just handle +diff -r 9e7e1b6ab5cd -r 2a415f9ee097 src/share/classes/com/sun/corba/se/spi/orbutil/proxy/CompositeInvocationHandlerImpl.java +--- corba/src/share/classes/com/sun/corba/se/spi/orbutil/proxy/CompositeInvocationHandlerImpl.java Tue Oct 15 15:24:25 2013 +0100 ++++ corba/src/share/classes/com/sun/corba/se/spi/orbutil/proxy/CompositeInvocationHandlerImpl.java Thu Jul 18 17:22:25 2013 -0700 +@@ -36,6 +36,7 @@ + + import com.sun.corba.se.spi.logging.CORBALogDomains ; + import com.sun.corba.se.impl.logging.ORBUtilSystemException ; ++import com.sun.corba.se.impl.presentation.rmi.DynamicAccessPermission; + + public class CompositeInvocationHandlerImpl implements + CompositeInvocationHandler +@@ -46,11 +47,13 @@ + public void addInvocationHandler( Class interf, + InvocationHandler handler ) + { ++ checkAccess(); + classToInvocationHandler.put( interf, handler ) ; + } + + public void setDefaultHandler( InvocationHandler handler ) + { ++ checkAccess(); + defaultHandler = handler ; + } + +@@ -78,4 +81,12 @@ + + return handler.invoke( proxy, method, args ) ; + } ++ ++ private static final DynamicAccessPermission perm = new DynamicAccessPermission("access"); ++ private void checkAccess() { ++ final SecurityManager sm = System.getSecurityManager(); ++ if (sm != null) { ++ sm.checkPermission(perm); + } ++ } ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8017287-better_resource_disposal.patch b/java/openjdk6/files/icedtea/openjdk/8017287-better_resource_disposal.patch new file mode 100644 index 000000000000..135085592aed --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017287-better_resource_disposal.patch @@ -0,0 +1,22 @@ +# HG changeset patch +# User bae +# Date 1382732366 -3600 +# Fri Oct 25 21:19:26 2013 +0100 +# Node ID 768afb4062fb6653278e5f7e5304a623fcd80c9c +# Parent 43b600fed0e8ac9d5ffe7556617d4850143e2dcd +8017287: Better resource disposal +Reviewed-by: vadim + +diff -r 43b600fed0e8 -r 768afb4062fb src/share/classes/sun/java2d/Disposer.java +--- jdk/src/share/classes/sun/java2d/Disposer.java Fri Oct 25 21:01:28 2013 +0100 ++++ jdk/src/share/classes/sun/java2d/Disposer.java Fri Oct 25 21:19:26 2013 +0100 +@@ -147,8 +147,7 @@ + obj = null; + rec = null; + } catch (Exception e) { +- System.out.println("Exception while removing reference: " + e); +- e.printStackTrace(); ++ System.out.println("Exception while removing reference."); + } + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8017291-cast_proxies_aside.patch b/java/openjdk6/files/icedtea/openjdk/8017291-cast_proxies_aside.patch new file mode 100644 index 000000000000..e030a78170dc --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017291-cast_proxies_aside.patch @@ -0,0 +1,34 @@ +# HG changeset patch +# User mchung +# Date 1373884816 25200 +# Mon Jul 15 03:40:16 2013 -0700 +# Node ID 011d86bdcbf8d4fe0016351b775ff1f48f3620a1 +# Parent 768afb4062fb6653278e5f7e5304a623fcd80c9c +8017291: Cast Proxies Aside +Reviewed-by: alanb, ahgross + +diff -r 768afb4062fb -r 011d86bdcbf8 src/share/classes/java/lang/ClassLoader.java +--- jdk/src/share/classes/java/lang/ClassLoader.java Fri Oct 25 21:19:26 2013 +0100 ++++ jdk/src/share/classes/java/lang/ClassLoader.java Mon Jul 15 03:40:16 2013 -0700 +@@ -54,6 +54,7 @@ + import sun.misc.VM; + import sun.reflect.CallerSensitive; + import sun.reflect.Reflection; ++import sun.reflect.misc.ReflectUtil; + import sun.security.util.SecurityConstants; + + /** +@@ -338,6 +339,13 @@ + private void checkPackageAccess(Class cls, ProtectionDomain pd) { + final SecurityManager sm = System.getSecurityManager(); + if (sm != null) { ++ if (ReflectUtil.isNonPublicProxyClass(cls)) { ++ for (Class intf: cls.getInterfaces()) { ++ checkPackageAccess(intf, pd); ++ } ++ return; ++ } ++ + final String name = cls.getName(); + final int i = name.lastIndexOf('.'); + if (i != -1) { diff --git a/java/openjdk6/files/icedtea/openjdk/8017298-better_xml_support.patch b/java/openjdk6/files/icedtea/openjdk/8017298-better_xml_support.patch new file mode 100644 index 000000000000..a4baf6b8d326 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017298-better_xml_support.patch @@ -0,0 +1,999 @@ +# HG changeset patch +# User joehw +# Date 1383031104 0 +# Tue Oct 29 07:18:24 2013 +0000 +# Node ID 3dc769c632a1d6a8f69d2857b3c13c43a83481be +# Parent 7799c3bd00f5a4fda6448cb8bcd7768c66ec166d +8017298: Better XML support +Reviewed-by: alanb, dfuchs, mullan + +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDocumentFragmentScannerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDocumentFragmentScannerImpl.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLDocumentFragmentScannerImpl.java Tue Oct 29 07:18:24 2013 +0000 +@@ -50,8 +50,8 @@ + import com.sun.org.apache.xerces.internal.xni.Augmentations; + import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.impl.XMLEntityHandler; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.NamespaceSupport; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.NamespaceContext; + import javax.xml.stream.XMLStreamConstants; + import javax.xml.stream.events.XMLEvent; +@@ -350,7 +350,7 @@ + + protected boolean foundBuiltInRefs = false; + +- protected SecurityManager fSecurityManager = null; ++ protected XMLSecurityManager fSecurityManager = null; + + //skip element algorithm + static final short MAX_DEPTH_LIMIT = 5 ; +@@ -555,11 +555,13 @@ + } + + try { +- fSecurityManager = (SecurityManager)componentManager.getProperty(Constants.SECURITY_MANAGER); ++ fSecurityManager = (XMLSecurityManager)componentManager.getProperty(Constants.SECURITY_MANAGER); + } catch (XMLConfigurationException e) { + fSecurityManager = null; + } +- fElementAttributeLimit = (fSecurityManager != null)?fSecurityManager.getElementAttrLimit():0; ++ fElementAttributeLimit = (fSecurityManager != null)? ++ fSecurityManager.getLimit(XMLSecurityManager.Limit.ELEMENT_ATTRIBUTE_LIMIT):0; ++ + + try { + fNotifyBuiltInRefs = componentManager.getFeature(NOTIFY_BUILTIN_REFS); +@@ -929,6 +931,7 @@ + + // scan decl + super.scanXMLDeclOrTextDecl(scanningTextDecl, fStrings); ++ + fMarkupDepth--; + + // pseudo-attribute values +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java Tue Oct 29 07:18:24 2013 +0000 +@@ -64,8 +64,8 @@ + import com.sun.org.apache.xerces.internal.xinclude.XIncludeHandler; + + import com.sun.org.apache.xerces.internal.impl.validation.ValidationManager; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.URI; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + + + /** +@@ -321,7 +321,7 @@ + + // stores defaults for entity expansion limit if it has + // been set on the configuration. +- protected SecurityManager fSecurityManager = null; ++ protected XMLSecurityManager fSecurityManager = null; + + /** + * True if the document entity is standalone. This should really +@@ -1531,7 +1531,7 @@ + fValidationManager = null; + } + try { +- fSecurityManager = (SecurityManager)componentManager.getProperty(SECURITY_MANAGER); ++ fSecurityManager = (XMLSecurityManager)componentManager.getProperty(SECURITY_MANAGER); + } + catch (XMLConfigurationException e) { + fSecurityManager = null; +@@ -1549,7 +1549,9 @@ + // a class acting as a component manager but not + // implementing that interface for whatever reason. + public void reset() { +- fEntityExpansionLimit = (fSecurityManager != null)?fSecurityManager.getEntityExpansionLimit():0; ++ fEntityExpansionLimit = (fSecurityManager != null)? ++ fSecurityManager.getLimit(XMLSecurityManager.Limit.ENTITY_EXPANSION_LIMIT):0; ++ + + // initialize state + fStandalone = false; +@@ -1689,8 +1691,9 @@ + } + if (suffixLength == Constants.SECURITY_MANAGER_PROPERTY.length() && + propertyId.endsWith(Constants.SECURITY_MANAGER_PROPERTY)) { +- fSecurityManager = (SecurityManager)value; +- fEntityExpansionLimit = (fSecurityManager != null)?fSecurityManager.getEntityExpansionLimit():0; ++ fSecurityManager = (XMLSecurityManager)value; ++ fEntityExpansionLimit = (fSecurityManager != null)? ++ fSecurityManager.getLimit(XMLSecurityManager.Limit.ENTITY_EXPANSION_LIMIT):0; + } + } + +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/XMLScanner.java Tue Oct 29 07:18:24 2013 +0000 +@@ -515,7 +515,7 @@ + reportFatalError("SDDeclInvalid", new Object[] {standalone}); + } + } else { +- reportFatalError("EncodingDeclRequired", null); ++ reportFatalError("SDDeclNameInvalid", null); + } + break; + } +@@ -580,7 +580,7 @@ + XMLString value) + throws IOException, XNIException { + +- String name = fEntityScanner.scanName(); ++ String name = scanPseudoAttributeName(); + // XMLEntityManager.print(fEntityManager.getCurrentEntity()); + + if (name == null) { +@@ -633,6 +633,35 @@ + } // scanPseudoAttribute(XMLString):String + + /** ++ * Scans the name of a pseudo attribute. The only legal names ++ * in XML 1.0/1.1 documents are 'version', 'encoding' and 'standalone'. ++ * ++ * @return the name of the pseudo attribute or <code>null</code> ++ * if a legal pseudo attribute name could not be scanned. ++ */ ++ private String scanPseudoAttributeName() throws IOException, XNIException { ++ final int ch = fEntityScanner.peekChar(); ++ switch (ch) { ++ case 'v': ++ if (fEntityScanner.skipString(fVersionSymbol)) { ++ return fVersionSymbol; ++ } ++ break; ++ case 'e': ++ if (fEntityScanner.skipString(fEncodingSymbol)) { ++ return fEncodingSymbol; ++ } ++ break; ++ case 's': ++ if (fEntityScanner.skipString(fStandaloneSymbol)) { ++ return fStandaloneSymbol; ++ } ++ break; ++ } ++ return null; ++ } // scanPseudoAttributeName() ++ ++ /** + * Scans a processing instruction. + * <p> + * <pre> +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/msg/XMLMessages.properties +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/msg/XMLMessages.properties Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/msg/XMLMessages.properties Tue Oct 29 07:18:24 2013 +0000 +@@ -43,6 +43,7 @@ + + # 2.9 Standalone Document Declaration + SDDeclInvalid = The standalone document declaration value must be \"yes\" or \"no\", not \"{0}\". ++ SDDeclNameInvalid = The standalone name in XML declaration may be misspelled. + # 2.12 Language Identification + XMLLangInvalid = The xml:lang attribute value \"{0}\" is an invalid language identifier. + # 3. Logical Structures +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/models/CMNodeFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/models/CMNodeFactory.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/models/CMNodeFactory.java Tue Oct 29 07:18:24 2013 +0000 +@@ -21,13 +21,13 @@ + + package com.sun.org.apache.xerces.internal.impl.xs.models; + ++import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter; ++import com.sun.org.apache.xerces.internal.impl.dtd.models.CMNode; ++import com.sun.org.apache.xerces.internal.impl.xs.XSMessageFormatter; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager; +-import com.sun.org.apache.xerces.internal.util.SecurityManager ; +-import com.sun.org.apache.xerces.internal.impl.dtd.models.CMNode; + import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException; +-import com.sun.org.apache.xerces.internal.impl.xs.XSMessageFormatter; +-import com.sun.org.apache.xerces.internal.impl.Constants; + + /** + * +@@ -68,7 +68,7 @@ + + // stores defaults for different security holes (maxOccurLimit in current context) if it has + // been set on the configuration. +- private SecurityManager fSecurityManager = null; ++ private XMLSecurityManager fSecurityManager = null; + + /** default constructor */ + public CMNodeFactory() { +@@ -77,10 +77,10 @@ + public void reset(XMLComponentManager componentManager){ + fErrorReporter = (XMLErrorReporter)componentManager.getProperty(ERROR_REPORTER); + try { +- fSecurityManager = (SecurityManager)componentManager.getProperty(SECURITY_MANAGER); ++ fSecurityManager = (XMLSecurityManager)componentManager.getProperty(SECURITY_MANAGER); + //we are setting the limit of number of nodes to 3times the maxOccur value.. + if(fSecurityManager != null){ +- maxNodeLimit = fSecurityManager.getMaxOccurNodeLimit() * MULTIPLICITY ; ++ maxNodeLimit = fSecurityManager.getLimit(XMLSecurityManager.Limit.MAX_OCCUR_NODE_LIMIT) * MULTIPLICITY ; + } + } + catch (XMLConfigurationException e) { +@@ -152,8 +152,9 @@ + + if (suffixLength == Constants.SECURITY_MANAGER_PROPERTY.length() && + propertyId.endsWith(Constants.SECURITY_MANAGER_PROPERTY)) { +- fSecurityManager = (SecurityManager)value; +- maxNodeLimit = (fSecurityManager != null) ? fSecurityManager.getMaxOccurNodeLimit() * MULTIPLICITY : 0 ; ++ fSecurityManager = (XMLSecurityManager)value; ++ maxNodeLimit = (fSecurityManager != null) ? ++ fSecurityManager.getLimit(XMLSecurityManager.Limit.MAX_OCCUR_NODE_LIMIT) * MULTIPLICITY : 0 ; + return; + } + if (suffixLength == Constants.ERROR_REPORTER_PROPERTY.length() && +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSAttributeChecker.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSAttributeChecker.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSAttributeChecker.java Tue Oct 29 07:18:24 2013 +0000 +@@ -38,6 +38,7 @@ + import com.sun.org.apache.xerces.internal.util.DOMUtil; + import com.sun.org.apache.xerces.internal.util.SymbolTable; + import com.sun.org.apache.xerces.internal.util.XMLSymbols; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.QName; + import com.sun.org.apache.xerces.internal.xs.XSConstants; + import org.w3c.dom.Attr; +@@ -1235,7 +1236,7 @@ + if (!optimize) { + //Revisit :: IMO this is not right place to check + // maxOccurNodeLimit. +- int maxOccurNodeLimit = fSchemaHandler.fSecureProcessing.getMaxOccurNodeLimit(); ++ int maxOccurNodeLimit = fSchemaHandler.fSecureProcessing.getLimit(XMLSecurityManager.Limit.MAX_OCCUR_NODE_LIMIT); + if (max > maxOccurNodeLimit) { + reportSchemaFatalError("maxOccurLimit", new Object[] {new Integer(maxOccurNodeLimit)}, element); + +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java Tue Oct 29 07:18:24 2013 +0000 +@@ -56,10 +56,10 @@ + import com.sun.org.apache.xerces.internal.util.DOMInputSource; + import com.sun.org.apache.xerces.internal.util.DefaultErrorHandler; + import com.sun.org.apache.xerces.internal.util.SAXInputSource; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.SymbolTable; + import com.sun.org.apache.xerces.internal.util.XMLSymbols; + import com.sun.org.apache.xerces.internal.util.URI.MalformedURIException; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.QName; + import com.sun.org.apache.xerces.internal.xni.grammars.Grammar; + import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarDescription; +@@ -210,7 +210,7 @@ + * + * <p>Protected to allow access by any traverser.</p> + */ +- protected SecurityManager fSecureProcessing = null; ++ protected XMLSecurityManager fSecureProcessing = null; + + + // These tables correspond to the symbol spaces defined in the +@@ -1963,7 +1963,7 @@ + fSecureProcessing = null; + if( componentManager!=null ) { + try { +- fSecureProcessing = (SecurityManager) componentManager.getProperty(SECURE_PROCESSING); ++ fSecureProcessing = (XMLSecurityManager) componentManager.getProperty(SECURE_PROCESSING); + } catch (XMLConfigurationException xmlConfigurationException) { + ; + } +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java Tue Oct 29 07:18:24 2013 +0000 +@@ -34,7 +34,7 @@ + import com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaValidator; + import com.sun.org.apache.xerces.internal.jaxp.validation.XSGrammarPoolContainer; + import com.sun.org.apache.xerces.internal.parsers.DOMParser; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XMLDocumentHandler; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponent; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager; +@@ -153,7 +153,7 @@ + + // If the secure processing feature is on set a security manager. + if (secureProcessing) { +- domParser.setProperty(SECURITY_MANAGER, new SecurityManager()); ++ domParser.setProperty(SECURITY_MANAGER, new XMLSecurityManager()); + } + + this.grammar = dbf.getSchema(); +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java Tue Oct 29 07:18:24 2013 +0000 +@@ -36,7 +36,7 @@ + import com.sun.org.apache.xerces.internal.impl.xs.XSMessageFormatter; + import com.sun.org.apache.xerces.internal.jaxp.validation.XSGrammarPoolContainer; + import com.sun.org.apache.xerces.internal.util.SAXMessageFormatter; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XMLDocumentHandler; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponent; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager; +@@ -143,7 +143,7 @@ + + // If the secure processing feature is on set a security manager. + if (secureProcessing) { +- xmlReader.setProperty0(SECURITY_MANAGER, new SecurityManager()); ++ xmlReader.setProperty0(SECURITY_MANAGER, new XMLSecurityManager()); + } + + // Set application's features, followed by validation features. +@@ -349,7 +349,7 @@ + } + if (name.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { + try { +- setProperty(SECURITY_MANAGER, value ? new SecurityManager() : null); ++ setProperty(SECURITY_MANAGER, value ? new XMLSecurityManager() : null); + } + catch (SAXNotRecognizedException exc) { + // If the property is not supported +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/StreamValidatorHelper.java Tue Oct 29 07:18:24 2013 +0000 +@@ -24,7 +24,7 @@ + import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter; + import com.sun.org.apache.xerces.internal.impl.msg.XMLMessageFormatter; + import com.sun.org.apache.xerces.internal.parsers.XML11Configuration; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XNIException; + import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; + import com.sun.org.apache.xerces.internal.xni.parser.XMLParseException; +@@ -167,7 +167,7 @@ + private XMLParserConfiguration initialize() { + XML11Configuration config = new XML11Configuration(); + if (fComponentManager.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING)) { +- config.setProperty(SECURITY_MANAGER, new SecurityManager()); ++ config.setProperty(SECURITY_MANAGER, new XMLSecurityManager()); + } + config.setProperty(ENTITY_RESOLVER, fComponentManager.getProperty(ENTITY_RESOLVER)); + config.setProperty(ERROR_HANDLER, fComponentManager.getProperty(ERROR_HANDLER)); +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/ValidatorHandlerImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/ValidatorHandlerImpl.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/ValidatorHandlerImpl.java Tue Oct 29 07:18:24 2013 +0000 +@@ -47,10 +47,10 @@ + import com.sun.org.apache.xerces.internal.util.SAXLocatorWrapper; + import com.sun.org.apache.xerces.internal.util.SAXMessageFormatter; + import com.sun.org.apache.xerces.internal.util.SymbolTable; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.URI; + import com.sun.org.apache.xerces.internal.util.XMLAttributesImpl; + import com.sun.org.apache.xerces.internal.util.XMLSymbols; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.Augmentations; + import com.sun.org.apache.xerces.internal.xni.NamespaceContext; + import com.sun.org.apache.xerces.internal.xni.QName; +@@ -677,7 +677,7 @@ + reader = spf.newSAXParser().getXMLReader(); + // If this is a Xerces SAX parser, set the security manager if there is one + if (reader instanceof com.sun.org.apache.xerces.internal.parsers.SAXParser) { +- SecurityManager securityManager = (SecurityManager) fComponentManager.getProperty(SECURITY_MANAGER); ++ XMLSecurityManager securityManager = (XMLSecurityManager) fComponentManager.getProperty(SECURITY_MANAGER); + if (securityManager != null) { + try { + reader.setProperty(SECURITY_MANAGER, securityManager); +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 07:18:24 2013 +0000 +@@ -39,8 +39,8 @@ + import com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper; + import com.sun.org.apache.xerces.internal.util.SAXInputSource; + import com.sun.org.apache.xerces.internal.util.SAXMessageFormatter; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.XMLGrammarPoolImpl; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XNIException; + import com.sun.org.apache.xerces.internal.xni.grammars.Grammar; + import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarDescription; +@@ -74,7 +74,7 @@ + private static final String XMLGRAMMAR_POOL = + Constants.XERCES_PROPERTY_PREFIX + Constants.XMLGRAMMAR_POOL_PROPERTY; + +- /** Property identifier: SecurityManager. */ ++ /** Property identifier: XMLSecurityManager. */ + private static final String SECURITY_MANAGER = + Constants.XERCES_PROPERTY_PREFIX + Constants.SECURITY_MANAGER_PROPERTY; + +@@ -97,8 +97,8 @@ + /** The ErrorHandlerWrapper */ + private ErrorHandlerWrapper fErrorHandlerWrapper; + +- /** The SecurityManager. */ +- private SecurityManager fSecurityManager; ++ /** The XMLSecurityManager. */ ++ private XMLSecurityManager fSecurityManager; + + /** The container for the real grammar pool. */ + private XMLGrammarPoolWrapper fXMLGrammarPoolWrapper; +@@ -113,7 +113,7 @@ + fXMLSchemaLoader.setErrorHandler(fErrorHandlerWrapper); + + // Enable secure processing feature by default +- fSecurityManager = new SecurityManager(); ++ fSecurityManager = new XMLSecurityManager(); + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + } + +@@ -321,7 +321,7 @@ + SAXMessageFormatter.formatMessage(null, + "jaxp-secureprocessing-feature", null)); + } +- fSecurityManager = value ? new SecurityManager() : null; ++ fSecurityManager = value ? new XMLSecurityManager() : null; + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + return; + } +@@ -350,7 +350,7 @@ + "ProperyNameNull", null)); + } + if (name.equals(SECURITY_MANAGER)) { +- fSecurityManager = (SecurityManager) object; ++ fSecurityManager = (XMLSecurityManager) object; + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + return; + } +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java Tue Oct 29 07:18:24 2013 +0000 +@@ -37,8 +37,8 @@ + import com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper; + import com.sun.org.apache.xerces.internal.util.NamespaceSupport; + import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.SymbolTable; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.NamespaceContext; + import com.sun.org.apache.xerces.internal.xni.XNIException; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponent; +@@ -173,7 +173,7 @@ + private final HashMap fInitProperties = new HashMap(); + + /** Stores the initial security manager. */ +- private final SecurityManager fInitSecurityManager; ++ private final XMLSecurityManager fInitSecurityManager; + + // + // User Objects +@@ -212,7 +212,7 @@ + + if (System.getSecurityManager() != null) { + _isSecureMode = true; +- setProperty(SECURITY_MANAGER, new SecurityManager()); ++ setProperty(SECURITY_MANAGER, new XMLSecurityManager()); + } else { + fComponents.put(SECURITY_MANAGER, null); + } +@@ -233,7 +233,7 @@ + // if the secure processing feature is set to true, add a security manager to the configuration + Boolean secureProcessing = grammarContainer.getFeature(XMLConstants.FEATURE_SECURE_PROCESSING); + if (Boolean.TRUE.equals(secureProcessing)) { +- fInitSecurityManager = new SecurityManager(); ++ fInitSecurityManager = new XMLSecurityManager(); + } + else { + fInitSecurityManager = null; +@@ -296,7 +296,7 @@ + if (_isSecureMode && !value) { + throw new XMLConfigurationException(XMLConfigurationException.NOT_ALLOWED, XMLConstants.FEATURE_SECURE_PROCESSING); + } +- setProperty(SECURITY_MANAGER, value ? new SecurityManager() : null); ++ setProperty(SECURITY_MANAGER, value ? new XMLSecurityManager() : null); + return; + } + fConfigUpdated = true; +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/AbstractSAXParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/AbstractSAXParser.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/AbstractSAXParser.java Tue Oct 29 07:18:24 2013 +0000 +@@ -25,9 +25,9 @@ + import com.sun.org.apache.xerces.internal.util.EntityResolverWrapper; + import com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper; + import com.sun.org.apache.xerces.internal.util.SAXMessageFormatter; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.SymbolHash; + import com.sun.org.apache.xerces.internal.util.XMLSymbols; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.Augmentations; + import com.sun.org.apache.xerces.internal.xni.NamespaceContext; + import com.sun.org.apache.xerces.internal.xni.QName; +@@ -1649,7 +1649,7 @@ + else if (featureId.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { + if (state) { + if (fConfiguration.getProperty(SECURITY_MANAGER )==null) { +- fConfiguration.setProperty(SECURITY_MANAGER, new SecurityManager()); ++ fConfiguration.setProperty(SECURITY_MANAGER, new XMLSecurityManager()); + } + } + } +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SecurityConfiguration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SecurityConfiguration.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SecurityConfiguration.java Tue Oct 29 07:18:24 2013 +0000 +@@ -23,8 +23,8 @@ + import com.sun.org.apache.xerces.internal.impl.Constants; + import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarPool; + import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.SymbolTable; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + + /** + * This configuration allows Xerces to behave in a security-conscious manner; that is, +@@ -106,8 +106,8 @@ + XMLComponentManager parentSettings) { + super(symbolTable, grammarPool, parentSettings); + +- // create the SecurityManager property: +- setProperty(SECURITY_MANAGER_PROPERTY, new SecurityManager()); ++ // create the XMLSecurityManager property: ++ setProperty(SECURITY_MANAGER_PROPERTY, new XMLSecurityManager()); + } // <init>(SymbolTable,XMLGrammarPool) + + } // class SecurityConfiguration +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SecurityManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SecurityManager.java Tue Oct 29 05:50:44 2013 +0000 ++++ /dev/null Thu Jan 01 00:00:00 1970 +0000 +@@ -1,226 +0,0 @@ +-/* +- * reserved comment block +- * DO NOT REMOVE OR ALTER! +- */ +-/* +- * The Apache Software License, Version 1.1 +- * +- * +- * Copyright (c) 2003 The Apache Software Foundation. +- * All rights reserved. +- * +- * Redistribution and use in source and binary forms, with or without +- * modification, are permitted provided that the following conditions +- * are met: +- * +- * 1. Redistributions of source code must retain the above copyright +- * notice, this list of conditions and the following disclaimer. +- * +- * 2. Redistributions in binary form must reproduce the above copyright +- * notice, this list of conditions and the following disclaimer in +- * the documentation and/or other materials provided with the +- * distribution. +- * +- * 3. The end-user documentation included with the redistribution, +- * if any, must include the following acknowledgment: +- * "This product includes software developed by the +- * Apache Software Foundation (http://www.apache.org/)." +- * Alternately, this acknowledgment may appear in the software itself, +- * if and wherever such third-party acknowledgments normally appear. +- * +- * 4. The names "Xerces" and "Apache Software Foundation" must +- * not be used to endorse or promote products derived from this +- * software without prior written permission. For written +- * permission, please contact apache@apache.org. +- * +- * 5. Products derived from this software may not be called "Apache", +- * nor may "Apache" appear in their name, without prior written +- * permission of the Apache Software Foundation. +- * +- * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED +- * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES +- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +- * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR +- * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF +- * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +- * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT +- * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF +- * SUCH DAMAGE. +- * ==================================================================== +- * +- * This software consists of voluntary contributions made by many +- * individuals on behalf of the Apache Software Foundation and was +- * originally based on software copyright (c) 1999, International +- * Business Machines, Inc., http://www.apache.org. For more +- * information on the Apache Software Foundation, please see +- * <http://www.apache.org/>. +- */ +- +-package com.sun.org.apache.xerces.internal.util; +-import com.sun.org.apache.xerces.internal.impl.Constants; +-import java.security.AccessController; +-import java.security.PrivilegedAction; +-/** +- * This class is a container for parser settings that relate to +- * security, or more specifically, it is intended to be used to prevent denial-of-service +- * attacks from being launched against a system running Xerces. +- * Any component that is aware of a denial-of-service attack that can arise +- * from its processing of a certain kind of document may query its Component Manager +- * for the property (http://apache.org/xml/properties/security-manager) +- * whose value will be an instance of this class. +- * If no value has been set for the property, the component should proceed in the "usual" (spec-compliant) +- * manner. If a value has been set, then it must be the case that the component in +- * question needs to know what method of this class to query. This class +- * will provide defaults for all known security issues, but will also provide +- * setters so that those values can be tailored by applications that care. +- * +- * @author Neil Graham, IBM +- * +- * @version $Id: SecurityManager.java,v 1.5 2010-11-01 04:40:14 joehw Exp $ +- */ +-public final class SecurityManager { +- +- // +- // Constants +- // +- +- // default value for entity expansion limit +- private final static int DEFAULT_ENTITY_EXPANSION_LIMIT = 64000; +- +- /** Default value of number of nodes created. **/ +- private final static int DEFAULT_MAX_OCCUR_NODE_LIMIT = 5000; +- +- // +- // Data +- // +- +- private final static int DEFAULT_ELEMENT_ATTRIBUTE_LIMIT = 10000; +- +- /** Entity expansion limit. **/ +- private int entityExpansionLimit; +- +- /** W3C XML Schema maxOccurs limit. **/ +- private int maxOccurLimit; +- +- private int fElementAttributeLimit; +- // default constructor. Establishes default values for +- // all known security holes. +- /** +- * Default constructor. Establishes default values +- * for known security vulnerabilities. +- */ +- public SecurityManager() { +- entityExpansionLimit = DEFAULT_ENTITY_EXPANSION_LIMIT; +- maxOccurLimit = DEFAULT_MAX_OCCUR_NODE_LIMIT ; +- fElementAttributeLimit = DEFAULT_ELEMENT_ATTRIBUTE_LIMIT; +- //We are reading system properties only once , +- //at the time of creation of this object , +- readSystemProperties(); +- } +- +- /** +- * <p>Sets the number of entity expansions that the +- * parser should permit in a document.</p> +- * +- * @param limit the number of entity expansions +- * permitted in a document +- */ +- public void setEntityExpansionLimit(int limit) { +- entityExpansionLimit = limit; +- } +- +- /** +- * <p>Returns the number of entity expansions +- * that the parser permits in a document.</p> +- * +- * @return the number of entity expansions +- * permitted in a document +- */ +- public int getEntityExpansionLimit() { +- return entityExpansionLimit; +- } +- +- /** +- * <p>Sets the limit of the number of content model nodes +- * that may be created when building a grammar for a W3C +- * XML Schema that contains maxOccurs attributes with values +- * other than "unbounded".</p> +- * +- * @param limit the maximum value for maxOccurs other +- * than "unbounded" +- */ +- public void setMaxOccurNodeLimit(int limit){ +- maxOccurLimit = limit; +- } +- +- /** +- * <p>Returns the limit of the number of content model nodes +- * that may be created when building a grammar for a W3C +- * XML Schema that contains maxOccurs attributes with values +- * other than "unbounded".</p> +- * +- * @return the maximum value for maxOccurs other +- * than "unbounded" +- */ +- public int getMaxOccurNodeLimit(){ +- return maxOccurLimit; +- } +- +- public int getElementAttrLimit(){ +- return fElementAttributeLimit; +- } +- +- public void setElementAttrLimit(int limit){ +- fElementAttributeLimit = limit; +- } +- +- private void readSystemProperties(){ +- +- //TODO: also read SYSTEM_PROPERTY_ELEMENT_ATTRIBUTE_LIMIT +- try { +- String value = getSystemProperty(Constants.ENTITY_EXPANSION_LIMIT); +- if(value != null && !value.equals("")){ +- entityExpansionLimit = Integer.parseInt(value); +- if (entityExpansionLimit < 0) +- entityExpansionLimit = DEFAULT_ENTITY_EXPANSION_LIMIT; +- } +- else +- entityExpansionLimit = DEFAULT_ENTITY_EXPANSION_LIMIT; +- }catch(Exception ex){} +- +- try { +- String value = getSystemProperty(Constants.MAX_OCCUR_LIMIT); +- if(value != null && !value.equals("")){ +- maxOccurLimit = Integer.parseInt(value); +- if (maxOccurLimit < 0) +- maxOccurLimit = DEFAULT_MAX_OCCUR_NODE_LIMIT; +- } +- else +- maxOccurLimit = DEFAULT_MAX_OCCUR_NODE_LIMIT; +- }catch(Exception ex){} +- +- try { +- String value = getSystemProperty(Constants.SYSTEM_PROPERTY_ELEMENT_ATTRIBUTE_LIMIT); +- if(value != null && !value.equals("")){ +- fElementAttributeLimit = Integer.parseInt(value); +- if ( fElementAttributeLimit < 0) +- fElementAttributeLimit = DEFAULT_ELEMENT_ATTRIBUTE_LIMIT; +- } +- else +- fElementAttributeLimit = DEFAULT_ELEMENT_ATTRIBUTE_LIMIT; +- +- }catch(Exception ex){} +- +- } +- +- private String getSystemProperty(final String propName) { +- return AccessController.doPrivileged(new PrivilegedAction<String>() { +- public String run() { +- return System.getProperty(propName); +- } +- }); +- } +-} // class SecurityManager +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SymbolTable.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SymbolTable.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SymbolTable.java Tue Oct 29 07:18:24 2013 +0000 +@@ -173,7 +173,7 @@ + for (int i = 0; i < length; i++) { + code = code * 37 + symbol.charAt(i); + } +- return code & 0x7FFFFFF; ++ return code & 0x7FFFFFFF; + + } // hash(String):int + +@@ -194,7 +194,7 @@ + for (int i = 0; i < length; i++) { + code = code * 37 + buffer[offset + i]; + } +- return code & 0x7FFFFFF; ++ return code & 0x7FFFFFFF; + + } // hash(char[],int,int):int + +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java Tue Oct 29 07:18:24 2013 +0000 +@@ -0,0 +1,147 @@ ++/* ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ++ * ++ * This code is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 only, as ++ * published by the Free Software Foundation. Oracle designates this ++ * particular file as subject to the "Classpath" exception as provided ++ * by Oracle in the LICENSE file that accompanied this code. ++ * ++ * This code is distributed in the hope that it will be useful, but WITHOUT ++ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ++ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ++ * version 2 for more details (a copy is included in the LICENSE file that ++ * accompanied this code). ++ * ++ * You should have received a copy of the GNU General Public License version ++ * 2 along with this work; if not, write to the Free Software Foundation, ++ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ++ * ++ * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ++ * or visit www.oracle.com if you need additional information or have any ++ * questions. ++ */ ++ ++package com.sun.org.apache.xerces.internal.utils; ++ ++import com.sun.org.apache.xerces.internal.impl.Constants; ++ ++/** ++ * This class manages standard and implementation-specific limitations. ++ * ++ */ ++public final class XMLSecurityManager { ++ ++ /** ++ * States of the settings of a property, in the order: default value, value ++ * set by FEATURE_SECURE_PROCESSING, jaxp.properties file, jaxp system ++ * properties, and jaxp api properties ++ */ ++ public static enum State { ++ //this order reflects the overriding order ++ DEFAULT, FSP, JAXPDOTPROPERTIES, SYSTEMPROPERTY, APIPROPERTY ++ } ++ ++ /** ++ * Limits managed by the security manager ++ */ ++ public static enum Limit { ++ ENTITY_EXPANSION_LIMIT(64000), ++ MAX_OCCUR_NODE_LIMIT(5000), ++ ELEMENT_ATTRIBUTE_LIMIT(10000); ++ ++ final int defaultValue; ++ ++ Limit(int value) { ++ this.defaultValue = value; ++ } ++ ++ int defaultValue() { ++ return defaultValue; ++ } ++ } ++ ++ /** ++ * Values of the limits as defined in enum Limit ++ */ ++ private final int[] limits; ++ /** ++ * States of the settings for each limit in limits above ++ */ ++ private State[] states = {State.DEFAULT, State.DEFAULT, State.DEFAULT, State.DEFAULT}; ++ ++ /** ++ * Default constructor. Establishes default values for known security ++ * vulnerabilities. ++ */ ++ public XMLSecurityManager() { ++ limits = new int[Limit.values().length]; ++ for (Limit limit : Limit.values()) { ++ limits[limit.ordinal()] = limit.defaultValue(); ++ } ++ //read system properties or jaxp.properties ++ readSystemProperties(); ++ } ++ ++ /** ++ * Sets the limit for a specific type of XML constructs. This can be either ++ * the size or the number of the constructs. ++ * ++ * @param type the type of limitation ++ * @param state the state of limitation ++ * @param limit the limit to the type ++ */ ++ public void setLimit(Limit limit, State state, int value) { ++ //only update if it shall override ++ if (state.compareTo(states[limit.ordinal()]) >= 0) { ++ limits[limit.ordinal()] = value; ++ states[limit.ordinal()] = state; ++ } ++ } ++ ++ /** ++ * Returns the limit set for the type specified ++ * ++ * @param limit the type of limitation ++ * @return the limit to the type ++ */ ++ public int getLimit(Limit limit) { ++ return limits[limit.ordinal()]; ++ } ++ ++ /** ++ * Read from system properties, or those in jaxp.properties ++ */ ++ private void readSystemProperties() { ++ getSystemProperty(Limit.ENTITY_EXPANSION_LIMIT, Constants.ENTITY_EXPANSION_LIMIT); ++ getSystemProperty(Limit.MAX_OCCUR_NODE_LIMIT, Constants.MAX_OCCUR_LIMIT); ++ getSystemProperty(Limit.ELEMENT_ATTRIBUTE_LIMIT, ++ Constants.SYSTEM_PROPERTY_ELEMENT_ATTRIBUTE_LIMIT); ++ } ++ ++ /** ++ * Read from system properties, or those in jaxp.properties ++ * ++ * @param limit the type of the property ++ * @param property the property name ++ */ ++ private void getSystemProperty(Limit limit, String property) { ++ try { ++ String value = SecuritySupport.getSystemProperty(property); ++ if (value != null && !value.equals("")) { ++ limits[limit.ordinal()] = Integer.parseInt(value); ++ states[limit.ordinal()] = State.SYSTEMPROPERTY; ++ return; ++ } ++ ++ value = SecuritySupport.readJAXPProperty(property); ++ if (value != null && !value.equals("")) { ++ limits[limit.ordinal()] = Integer.parseInt(value); ++ states[limit.ordinal()] = State.JAXPDOTPROPERTIES; ++ } ++ } catch (NumberFormatException e) { ++ //invalid setting ignored ++ } ++ } ++} +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java Tue Oct 29 07:18:24 2013 +0000 +@@ -36,7 +36,6 @@ + import com.sun.org.apache.xerces.internal.util.HTTPInputSource; + import com.sun.org.apache.xerces.internal.util.IntStack; + import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings; +-import com.sun.org.apache.xerces.internal.util.SecurityManager; + import com.sun.org.apache.xerces.internal.util.SymbolTable; + import com.sun.org.apache.xerces.internal.util.URI; + import com.sun.org.apache.xerces.internal.util.XMLAttributesImpl; +@@ -44,6 +43,7 @@ + import com.sun.org.apache.xerces.internal.util.XMLChar; + import com.sun.org.apache.xerces.internal.util.XMLSymbols; + import com.sun.org.apache.xerces.internal.util.URI.MalformedURIException; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.Augmentations; + import com.sun.org.apache.xerces.internal.xni.NamespaceContext; + import com.sun.org.apache.xerces.internal.xni.QName; +@@ -280,7 +280,7 @@ + protected SymbolTable fSymbolTable; + protected XMLErrorReporter fErrorReporter; + protected XMLEntityResolver fEntityResolver; +- protected SecurityManager fSecurityManager; ++ protected XMLSecurityManager fSecurityManager; + + // these are needed for text include processing + protected XIncludeTextReader fXInclude10TextReader; +@@ -506,8 +506,8 @@ + + // Get security manager. + try { +- SecurityManager value = +- (SecurityManager)componentManager.getProperty( ++ XMLSecurityManager value = ++ (XMLSecurityManager)componentManager.getProperty( + SECURITY_MANAGER); + + if (value != null) { +@@ -656,7 +656,7 @@ + return; + } + if (propertyId.equals(SECURITY_MANAGER)) { +- fSecurityManager = (SecurityManager)value; ++ fSecurityManager = (XMLSecurityManager)value; + if (fChildConfig != null) { + fChildConfig.setProperty(propertyId, value); + } +diff -r 7799c3bd00f5 -r 3dc769c632a1 drop_included/jaxp_src/src/com/sun/xml/internal/stream/Entity.java +--- jaxp/drop_included/jaxp_src/src/com/sun/xml/internal/stream/Entity.java Tue Oct 29 05:50:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/xml/internal/stream/Entity.java Tue Oct 29 07:18:24 2013 +0000 +@@ -248,7 +248,7 @@ + public int fBufferSize = DEFAULT_BUFFER_SIZE; + + /** Default buffer size before we've finished with the XMLDecl: */ +- public static final int DEFAULT_XMLDECL_BUFFER_SIZE = 28; ++ public static final int DEFAULT_XMLDECL_BUFFER_SIZE = 64; + + /** Default internal entity buffer size (1024). */ + public static final int DEFAULT_INTERNAL_BUFFER_SIZE = 1024; diff --git a/java/openjdk6/files/icedtea/openjdk/8017300-improve_interface_implementation.patch b/java/openjdk6/files/icedtea/openjdk/8017300-improve_interface_implementation.patch new file mode 100644 index 000000000000..29a20dbda079 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017300-improve_interface_implementation.patch @@ -0,0 +1,129 @@ +# HG changeset patch +# User sundar +# Date 1382737389 -3600 +# Fri Oct 25 22:43:09 2013 +0100 +# Node ID de490a43861e05f3da489db136687b1dc6f1949a +# Parent 0b0490779c5b643b7a3e90ac6870c1ee4bd5a155 +8017300: Improve Interface Implementation +Reviewed-by: ahgross, jlaskey, mchung + +diff -r 0b0490779c5b -r de490a43861e src/share/classes/com/sun/script/util/InterfaceImplementor.java +--- jdk/src/share/classes/com/sun/script/util/InterfaceImplementor.java Tue Jul 16 10:58:46 2013 +0100 ++++ jdk/src/share/classes/com/sun/script/util/InterfaceImplementor.java Fri Oct 25 22:43:09 2013 +0100 +@@ -28,6 +28,7 @@ + import javax.script.*; + import java.lang.reflect.*; + import java.security.*; ++import sun.reflect.misc.ReflectUtil; + + /* + * java.lang.reflect.Proxy based interface implementor. This is meant +@@ -82,8 +83,18 @@ + if (iface == null || !iface.isInterface()) { + throw new IllegalArgumentException("interface Class expected"); + } ++ ++ if (System.getSecurityManager() != null && ++ !Modifier.isPublic(iface.getModifiers())) { ++ throw new SecurityException("attempt to implement non-public interface"); ++ } ++ ++ // make sure restricted package interfaces are not attempted. ++ ReflectUtil.checkPackageAccess(iface.getName()); ++ + AccessControlContext accCtxt = AccessController.getContext(); +- return iface.cast(Proxy.newProxyInstance(iface.getClassLoader(), ++ return iface.cast(Proxy.newProxyInstance( ++ getLoaderForProxy(iface), + new Class[]{iface}, + new InterfaceImplementorInvocationHandler(thiz, accCtxt))); + } +@@ -101,4 +112,20 @@ + // default is identity conversion + return args; + } ++ ++ // get appropriate ClassLoader for generated Proxy class ++ private static ClassLoader getLoaderForProxy(Class<?> iface) { ++ ClassLoader loader = iface.getClassLoader(); ++ ++ // if bootstrap class, try TCCL ++ if (loader == null) { ++ loader = Thread.currentThread().getContextClassLoader(); ++ } ++ ++ // if TCCL is also null, try System class loader ++ if (loader == null) { ++ loader = ClassLoader.getSystemClassLoader(); ++ } ++ return loader; ++ } + } +diff -r 0b0490779c5b -r de490a43861e src/share/lib/security/java.security-linux +--- jdk/src/share/lib/security/java.security-linux Tue Jul 16 10:58:46 2013 +0100 ++++ jdk/src/share/lib/security/java.security-linux Fri Oct 25 22:43:09 2013 +0100 +@@ -133,6 +133,7 @@ + com.sun.istack.internal.,\ + com.sun.jmx.,\ + com.sun.proxy.,\ ++ com.sun.script.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +@@ -169,6 +170,7 @@ + com.sun.istack.internal.,\ + com.sun.jmx.,\ + com.sun.proxy.,\ ++ com.sun.script.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +diff -r 0b0490779c5b -r de490a43861e src/share/lib/security/java.security-solaris +--- jdk/src/share/lib/security/java.security-solaris Tue Jul 16 10:58:46 2013 +0100 ++++ jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:43:09 2013 +0100 +@@ -134,6 +134,7 @@ + com.sun.istack.internal.,\ + com.sun.jmx.,\ + com.sun.proxy.,\ ++ com.sun.script.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +@@ -171,6 +172,7 @@ + com.sun.istack.internal.,\ + com.sun.jmx.,\ + com.sun.proxy.,\ ++ com.sun.script.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +diff -r 0b0490779c5b -r de490a43861e src/share/lib/security/java.security-windows +--- jdk/src/share/lib/security/java.security-windows Tue Jul 16 10:58:46 2013 +0100 ++++ jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:43:09 2013 +0100 +@@ -134,6 +134,7 @@ + com.sun.istack.internal.,\ + com.sun.jmx.,\ + com.sun.proxy.,\ ++ com.sun.script.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +@@ -172,6 +173,7 @@ + com.sun.istack.internal.,\ + com.sun.jmx.,\ + com.sun.proxy.,\ ++ com.sun.script.,\ + com.sun.org.apache.bcel.internal.,\ + com.sun.org.apache.regexp.internal.,\ + com.sun.org.apache.xerces.internal.,\ +diff -r 0b0490779c5b -r de490a43861e test/java/lang/SecurityManager/CheckPackageAccess.java +--- jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Tue Jul 16 10:58:46 2013 +0100 ++++ jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Oct 25 22:43:09 2013 +0100 +@@ -74,6 +74,7 @@ + "com.sun.org.apache.xml.internal.serializer.utils.", + "com.sun.org.apache.xml.internal.utils.", + "com.sun.org.glassfish.", ++ "com.sun.script.", + "oracle.jrockit.jfr.", + "org.jcp.xml.dsig.internal.", + }; diff --git a/java/openjdk6/files/icedtea/openjdk/8017505-better_client_service.patch b/java/openjdk6/files/icedtea/openjdk/8017505-better_client_service.patch new file mode 100644 index 000000000000..1ab4a485ea76 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017505-better_client_service.patch @@ -0,0 +1,560 @@ +# HG changeset patch +# User mkos +# Date 1383022122 0 +# Tue Oct 29 04:48:42 2013 +0000 +# Node ID 4ea4a060f3748510aedf4355ae2dbf2921f15494 +# Parent 60ca74797572c7fb8682802738dda073e44aeea0 +8017505: Better Client Service +Reviewed-by: mullan, ahgross, mgrebac + +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/api/server/InstanceResolver.java +--- jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/api/server/InstanceResolver.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/api/server/InstanceResolver.java Tue Oct 29 04:48:42 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -232,7 +232,7 @@ + public Object invoke(Packet p, Method m, Object... args) throws InvocationTargetException, IllegalAccessException { + T t = resolve(p); + try { +- return m.invoke(t, args ); ++ return MethodUtil.invoke(t, m, args ); + } finally { + postInvoke(p,t); + } +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/api/server/MethodUtil.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/api/server/MethodUtil.java Tue Oct 29 04:48:42 2013 +0000 +@@ -0,0 +1,109 @@ ++/* ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. ++ * ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * ++ * The contents of this file are subject to the terms of either the GNU ++ * General Public License Version 2 only ("GPL") or the Common Development ++ * and Distribution License("CDDL") (collectively, the "License"). You ++ * may not use this file except in compliance with the License. You can ++ * obtain a copy of the License at ++ * http://glassfish.java.net/public/CDDL+GPL_1_1.html ++ * or packager/legal/LICENSE.txt. See the License for the specific ++ * language governing permissions and limitations under the License. ++ * ++ * When distributing the software, include this License Header Notice in each ++ * file and include the License file at packager/legal/LICENSE.txt. ++ * ++ * GPL Classpath Exception: ++ * Oracle designates this particular file as subject to the "Classpath" ++ * exception as provided by Oracle in the GPL Version 2 section of the License ++ * file that accompanied this code. ++ * ++ * Modifications: ++ * If applicable, add the following below the License Header, with the fields ++ * enclosed by brackets [] replaced by your own identifying information: ++ * "Portions Copyright [year] [name of copyright owner]" ++ * ++ * Contributor(s): ++ * If you wish your version of this file to be governed by only the CDDL or ++ * only the GPL Version 2, indicate your decision by adding "[Contributor] ++ * elects to include this software in this distribution under the [CDDL or GPL ++ * Version 2] license." If you don't indicate a single choice of license, a ++ * recipient has the option to distribute your version of this file under ++ * either the CDDL, the GPL Version 2 or to extend the choice of license to ++ * its licensees as provided above. However, if you add GPL Version 2 code ++ * and therefore, elected the GPL Version 2 license, then the option applies ++ * only if the new code is made subject to such option by the copyright ++ * holder. ++ */ ++ ++package com.sun.xml.internal.ws.api.server; ++ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.util.logging.Level; ++import java.util.logging.Logger; ++ ++/** ++ * Utility class to invoke sun.reflect.misc.MethodUtil.invoke() if available. If not (other then Oracle JDK) fallbacks ++ * to java.lang,reflect.Method.invoke() ++ * ++ * Be careful, copy of this class exists in several packages, iny modification must be done to other copies too! ++ */ ++class MethodUtil { ++ ++ private static final Logger LOGGER = Logger.getLogger(MethodUtil.class.getName()); ++ private static final Method INVOKE_METHOD; ++ ++ static { ++ Method method; ++ try { ++ Class<?> clazz = Class.forName("sun.reflect.misc.MethodUtil"); ++ method = clazz.getMethod("invoke", Method.class, Object.class, Object[].class); ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil found; it will be used to invoke methods."); ++ } ++ } catch (Throwable t) { ++ method = null; ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil not found, probably non-Oracle JVM"); ++ } ++ } ++ INVOKE_METHOD = method; ++ } ++ ++ static Object invoke(Object target, Method method, Object[] args) throws IllegalAccessException, InvocationTargetException { ++ if (INVOKE_METHOD != null) { ++ // sun.reflect.misc.MethodUtil.invoke(method, owner, args) ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method using sun.reflect.misc.MethodUtil"); ++ } ++ try { ++ return INVOKE_METHOD.invoke(null, method, target, args); ++ } catch (InvocationTargetException ite) { ++ // unwrap invocation exception added by reflection code ... ++ throw unwrapException(ite); ++ } ++ } else { ++ // other then Oracle JDK ... ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method directly, probably non-Oracle JVM"); ++ } ++ return method.invoke(target, args); ++ } ++ } ++ ++ private static InvocationTargetException unwrapException(InvocationTargetException ite) { ++ Throwable targetException = ite.getTargetException(); ++ if (targetException != null && targetException instanceof InvocationTargetException) { ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Unwrapping invocation target exception"); ++ } ++ return (InvocationTargetException) targetException; ++ } else { ++ return ite; ++ } ++ } ++ ++} +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/client/sei/MethodUtil.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/client/sei/MethodUtil.java Tue Oct 29 04:48:42 2013 +0000 +@@ -0,0 +1,109 @@ ++/* ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. ++ * ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * ++ * The contents of this file are subject to the terms of either the GNU ++ * General Public License Version 2 only ("GPL") or the Common Development ++ * and Distribution License("CDDL") (collectively, the "License"). You ++ * may not use this file except in compliance with the License. You can ++ * obtain a copy of the License at ++ * http://glassfish.java.net/public/CDDL+GPL_1_1.html ++ * or packager/legal/LICENSE.txt. See the License for the specific ++ * language governing permissions and limitations under the License. ++ * ++ * When distributing the software, include this License Header Notice in each ++ * file and include the License file at packager/legal/LICENSE.txt. ++ * ++ * GPL Classpath Exception: ++ * Oracle designates this particular file as subject to the "Classpath" ++ * exception as provided by Oracle in the GPL Version 2 section of the License ++ * file that accompanied this code. ++ * ++ * Modifications: ++ * If applicable, add the following below the License Header, with the fields ++ * enclosed by brackets [] replaced by your own identifying information: ++ * "Portions Copyright [year] [name of copyright owner]" ++ * ++ * Contributor(s): ++ * If you wish your version of this file to be governed by only the CDDL or ++ * only the GPL Version 2, indicate your decision by adding "[Contributor] ++ * elects to include this software in this distribution under the [CDDL or GPL ++ * Version 2] license." If you don't indicate a single choice of license, a ++ * recipient has the option to distribute your version of this file under ++ * either the CDDL, the GPL Version 2 or to extend the choice of license to ++ * its licensees as provided above. However, if you add GPL Version 2 code ++ * and therefore, elected the GPL Version 2 license, then the option applies ++ * only if the new code is made subject to such option by the copyright ++ * holder. ++ */ ++ ++package com.sun.xml.internal.ws.client.sei; ++ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.util.logging.Level; ++import java.util.logging.Logger; ++ ++/** ++ * Utility class to invoke sun.reflect.misc.MethodUtil.invoke() if available. If not (other then Oracle JDK) fallbacks ++ * to java.lang,reflect.Method.invoke() ++ * <p/> ++ * Be careful, copy of this class exists in several packages, iny modification must be done to other copies too! ++ */ ++class MethodUtil { ++ ++ private static final Logger LOGGER = Logger.getLogger(MethodUtil.class.getName()); ++ private static final Method INVOKE_METHOD; ++ ++ static { ++ Method method; ++ try { ++ Class<?> clazz = Class.forName("sun.reflect.misc.MethodUtil"); ++ method = clazz.getMethod("invoke", Method.class, Object.class, Object[].class); ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil found; it will be used to invoke methods."); ++ } ++ } catch (Throwable t) { ++ method = null; ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil not found, probably non-Oracle JVM"); ++ } ++ } ++ INVOKE_METHOD = method; ++ } ++ ++ static Object invoke(Object target, Method method, Object[] args) throws IllegalAccessException, InvocationTargetException { ++ if (INVOKE_METHOD != null) { ++ // sun.reflect.misc.MethodUtil.invoke(method, owner, args) ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method using sun.reflect.misc.MethodUtil"); ++ } ++ try { ++ return INVOKE_METHOD.invoke(null, method, target, args); ++ } catch (InvocationTargetException ite) { ++ // unwrap invocation exception added by reflection code ... ++ throw unwrapException(ite); ++ } ++ } else { ++ // other then Oracle JDK ... ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method directly, probably non-Oracle JVM"); ++ } ++ return method.invoke(target, args); ++ } ++ } ++ ++ private static InvocationTargetException unwrapException(InvocationTargetException ite) { ++ Throwable targetException = ite.getTargetException(); ++ if (targetException != null && targetException instanceof InvocationTargetException) { ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Unwrapping invocation target exception"); ++ } ++ return (InvocationTargetException) targetException; ++ } else { ++ return ite; ++ } ++ } ++ ++} +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/client/sei/SEIStub.java +--- jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/client/sei/SEIStub.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/client/sei/SEIStub.java Tue Oct 29 04:48:42 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -33,8 +33,8 @@ + import com.sun.xml.internal.ws.api.message.Packet; + import com.sun.xml.internal.ws.api.model.MEP; + import com.sun.xml.internal.ws.api.model.wsdl.WSDLBoundOperation; ++import com.sun.xml.internal.ws.api.pipe.Fiber; + import com.sun.xml.internal.ws.api.pipe.Tube; +-import com.sun.xml.internal.ws.api.pipe.Fiber; + import com.sun.xml.internal.ws.binding.BindingImpl; + import com.sun.xml.internal.ws.client.RequestContext; + import com.sun.xml.internal.ws.client.ResponseContextReceiver; +@@ -47,6 +47,8 @@ + import java.lang.reflect.InvocationHandler; + import java.lang.reflect.InvocationTargetException; + import java.lang.reflect.Method; ++import java.lang.reflect.Modifier; ++import java.lang.reflect.Proxy; + import java.util.HashMap; + import java.util.Map; + +@@ -102,13 +104,14 @@ + private final Map<Method, MethodHandler> methodHandlers = new HashMap<Method, MethodHandler>(); + + public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { ++ validateInputs(proxy, method); + MethodHandler handler = methodHandlers.get(method); + if (handler != null) { + return handler.invoke(proxy, args); + } else { + // we handle the other method invocations by ourselves + try { +- return method.invoke(this, args); ++ return MethodUtil.invoke(this, method, args); + } catch (IllegalAccessException e) { + // impossible + throw new AssertionError(e); +@@ -120,6 +123,17 @@ + } + } + ++ private void validateInputs(Object proxy, Method method) { ++ if (proxy == null || !Proxy.isProxyClass(proxy.getClass())) { ++ throw new IllegalStateException("Passed object is not proxy!"); ++ } ++ Class<?> declaringClass = method.getDeclaringClass(); ++ if (method == null || declaringClass == null ++ || Modifier.isStatic(method.getModifiers())) { ++ throw new IllegalStateException("Invoking static method is not allowed!"); ++ } ++ } ++ + public final Packet doProcess(Packet request, RequestContext rc, ResponseContextReceiver receiver) { + return super.process(request, rc, receiver); + } +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/policy/privateutil/MethodUtil.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/policy/privateutil/MethodUtil.java Tue Oct 29 04:48:42 2013 +0000 +@@ -0,0 +1,107 @@ ++/* ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. ++ * ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * ++ * The contents of this file are subject to the terms of either the GNU ++ * General Public License Version 2 only ("GPL") or the Common Development ++ * and Distribution License("CDDL") (collectively, the "License"). You ++ * may not use this file except in compliance with the License. You can ++ * obtain a copy of the License at ++ * http://glassfish.java.net/public/CDDL+GPL_1_1.html ++ * or packager/legal/LICENSE.txt. See the License for the specific ++ * language governing permissions and limitations under the License. ++ * ++ * When distributing the software, include this License Header Notice in each ++ * file and include the License file at packager/legal/LICENSE.txt. ++ * ++ * GPL Classpath Exception: ++ * Oracle designates this particular file as subject to the "Classpath" ++ * exception as provided by Oracle in the GPL Version 2 section of the License ++ * file that accompanied this code. ++ * ++ * Modifications: ++ * If applicable, add the following below the License Header, with the fields ++ * enclosed by brackets [] replaced by your own identifying information: ++ * "Portions Copyright [year] [name of copyright owner]" ++ * ++ * Contributor(s): ++ * If you wish your version of this file to be governed by only the CDDL or ++ * only the GPL Version 2, indicate your decision by adding "[Contributor] ++ * elects to include this software in this distribution under the [CDDL or GPL ++ * Version 2] license." If you don't indicate a single choice of license, a ++ * recipient has the option to distribute your version of this file under ++ * either the CDDL, the GPL Version 2 or to extend the choice of license to ++ * its licensees as provided above. However, if you add GPL Version 2 code ++ * and therefore, elected the GPL Version 2 license, then the option applies ++ * only if the new code is made subject to such option by the copyright ++ * holder. ++ */ ++ ++package com.sun.xml.internal.ws.policy.privateutil; ++ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.util.logging.Level; ++import java.util.logging.Logger; ++ ++/** ++ * Utility class to invoke sun.reflect.misc.MethodUtil.invoke() if available. If not (other then Oracle JDK) fallbacks ++ * to java.lang,reflect.Method.invoke() ++ */ ++class MethodUtil { ++ ++ private static final Logger LOGGER = Logger.getLogger(MethodUtil.class.getName()); ++ private static final Method INVOKE_METHOD; ++ ++ static { ++ Method method; ++ try { ++ Class<?> clazz = Class.forName("sun.reflect.misc.MethodUtil"); ++ method = clazz.getMethod("invoke", Method.class, Object.class, Object[].class); ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil found; it will be used to invoke methods."); ++ } ++ } catch (Throwable t) { ++ method = null; ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil not found, probably non-Oracle JVM"); ++ } ++ } ++ INVOKE_METHOD = method; ++ } ++ ++ static Object invoke(Object target, Method method, Object[] args) throws IllegalAccessException, InvocationTargetException { ++ if (INVOKE_METHOD != null) { ++ // sun.reflect.misc.MethodUtil.invoke(method, owner, args) ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method using sun.reflect.misc.MethodUtil"); ++ } ++ try { ++ return INVOKE_METHOD.invoke(null, method, target, args); ++ } catch (InvocationTargetException ite) { ++ // unwrap invocation exception added by reflection code ... ++ throw unwrapException(ite); ++ } ++ } else { ++ // other then Oracle JDK ... ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method directly, probably non-Oracle JVM"); ++ } ++ return method.invoke(target, args); ++ } ++ } ++ ++ private static InvocationTargetException unwrapException(InvocationTargetException ite) { ++ Throwable targetException = ite.getTargetException(); ++ if (targetException != null && targetException instanceof InvocationTargetException) { ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Unwrapping invocation target exception"); ++ } ++ return (InvocationTargetException) targetException; ++ } else { ++ return ite; ++ } ++ } ++ ++} +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/server/AbstractInstanceResolver.java +--- jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/server/AbstractInstanceResolver.java Fri Oct 04 12:22:34 2013 -0400 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/server/AbstractInstanceResolver.java Tue Oct 29 04:48:42 2013 +0000 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -157,7 +157,7 @@ + if (!method.isAccessible()) { + method.setAccessible(true); + } +- method.invoke(instance,args); ++ MethodUtil.invoke(instance,method,args); + } catch (IllegalAccessException e) { + throw new ServerRtException("server.rt.err",e); + } catch (InvocationTargetException e) { +diff -r 60ca74797572 -r 4ea4a060f374 drop_included/jaxws_src/src/com/sun/xml/internal/ws/server/MethodUtil.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxws/drop_included/jaxws_src/src/com/sun/xml/internal/ws/server/MethodUtil.java Tue Oct 29 04:48:42 2013 +0000 +@@ -0,0 +1,109 @@ ++/* ++ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. ++ * ++ * Copyright (c) 2013 Oracle and/or its affiliates. All rights reserved. ++ * ++ * The contents of this file are subject to the terms of either the GNU ++ * General Public License Version 2 only ("GPL") or the Common Development ++ * and Distribution License("CDDL") (collectively, the "License"). You ++ * may not use this file except in compliance with the License. You can ++ * obtain a copy of the License at ++ * http://glassfish.java.net/public/CDDL+GPL_1_1.html ++ * or packager/legal/LICENSE.txt. See the License for the specific ++ * language governing permissions and limitations under the License. ++ * ++ * When distributing the software, include this License Header Notice in each ++ * file and include the License file at packager/legal/LICENSE.txt. ++ * ++ * GPL Classpath Exception: ++ * Oracle designates this particular file as subject to the "Classpath" ++ * exception as provided by Oracle in the GPL Version 2 section of the License ++ * file that accompanied this code. ++ * ++ * Modifications: ++ * If applicable, add the following below the License Header, with the fields ++ * enclosed by brackets [] replaced by your own identifying information: ++ * "Portions Copyright [year] [name of copyright owner]" ++ * ++ * Contributor(s): ++ * If you wish your version of this file to be governed by only the CDDL or ++ * only the GPL Version 2, indicate your decision by adding "[Contributor] ++ * elects to include this software in this distribution under the [CDDL or GPL ++ * Version 2] license." If you don't indicate a single choice of license, a ++ * recipient has the option to distribute your version of this file under ++ * either the CDDL, the GPL Version 2 or to extend the choice of license to ++ * its licensees as provided above. However, if you add GPL Version 2 code ++ * and therefore, elected the GPL Version 2 license, then the option applies ++ * only if the new code is made subject to such option by the copyright ++ * holder. ++ */ ++ ++package com.sun.xml.internal.ws.server; ++ ++import java.lang.reflect.InvocationTargetException; ++import java.lang.reflect.Method; ++import java.util.logging.Level; ++import java.util.logging.Logger; ++ ++/** ++ * Utility class to invoke sun.reflect.misc.MethodUtil.invoke() if available. If not (other then Oracle JDK) fallbacks ++ * to java.lang,reflect.Method.invoke() ++ * ++ * Be careful, copy of this class exists in several packages, iny modification must be done to other copies too! ++ */ ++class MethodUtil { ++ ++ private static final Logger LOGGER = Logger.getLogger(MethodUtil.class.getName()); ++ private static final Method INVOKE_METHOD; ++ ++ static { ++ Method method; ++ try { ++ Class<?> clazz = Class.forName("sun.reflect.misc.MethodUtil"); ++ method = clazz.getMethod("invoke", Method.class, Object.class, Object[].class); ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil found; it will be used to invoke methods."); ++ } ++ } catch (Throwable t) { ++ method = null; ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Class sun.reflect.misc.MethodUtil not found, probably non-Oracle JVM"); ++ } ++ } ++ INVOKE_METHOD = method; ++ } ++ ++ static Object invoke(Object target, Method method, Object[] args) throws IllegalAccessException, InvocationTargetException { ++ if (INVOKE_METHOD != null) { ++ // sun.reflect.misc.MethodUtil.invoke(method, owner, args) ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method using sun.reflect.misc.MethodUtil"); ++ } ++ try { ++ return INVOKE_METHOD.invoke(null, method, target, args); ++ } catch (InvocationTargetException ite) { ++ // unwrap invocation exception added by reflection code ... ++ throw unwrapException(ite); ++ } ++ } else { ++ // other then Oracle JDK ... ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Invoking method directly, probably non-Oracle JVM"); ++ } ++ return method.invoke(target, args); ++ } ++ } ++ ++ private static InvocationTargetException unwrapException(InvocationTargetException ite) { ++ Throwable targetException = ite.getTargetException(); ++ if (targetException != null && targetException instanceof InvocationTargetException) { ++ if (LOGGER.isLoggable(Level.FINE)) { ++ LOGGER.log(Level.FINE, "Unwrapping invocation target exception"); ++ } ++ return (InvocationTargetException) targetException; ++ } else { ++ return ite; ++ } ++ } ++ ++} diff --git a/java/openjdk6/files/icedtea/openjdk/8017566-backout_part_of_8000450.patch b/java/openjdk6/files/icedtea/openjdk/8017566-backout_part_of_8000450.patch new file mode 100644 index 000000000000..f66325cb8107 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8017566-backout_part_of_8000450.patch @@ -0,0 +1,77 @@ +# HG changeset patch +# User coffeys +# Date 1373968726 -3600 +# Tue Jul 16 10:58:46 2013 +0100 +# Node ID 0b0490779c5b643b7a3e90ac6870c1ee4bd5a155 +# Parent 2a023db33371ce5ee42134cf0d860ab9f0adff92 +8017566: Backout 8000450 - Cannot access to com.sun.corba.se.impl.orb.ORBImpl +Reviewed-by: mchung, chegar + +diff -r 2a023db33371 -r 0b0490779c5b src/share/lib/security/java.security-linux +--- jdk/src/share/lib/security/java.security-linux Fri Oct 25 22:35:06 2013 +0100 ++++ jdk/src/share/lib/security/java.security-linux Tue Jul 16 10:58:46 2013 +0100 +@@ -128,7 +128,6 @@ + # corresponding RuntimePermission ("accessClassInPackage."+package) has + # been granted. + package.access=sun.,\ +- com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +@@ -165,7 +164,6 @@ + # checkPackageDefinition. + # + package.definition=sun.,\ +- com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +diff -r 2a023db33371 -r 0b0490779c5b src/share/lib/security/java.security-solaris +--- jdk/src/share/lib/security/java.security-solaris Fri Oct 25 22:35:06 2013 +0100 ++++ jdk/src/share/lib/security/java.security-solaris Tue Jul 16 10:58:46 2013 +0100 +@@ -129,7 +129,6 @@ + # corresponding RuntimePermission ("accessClassInPackage."+package) has + # been granted. + package.access=sun.,\ +- com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +@@ -167,7 +166,6 @@ + # checkPackageDefinition. + # + package.definition=sun.,\ +- com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +diff -r 2a023db33371 -r 0b0490779c5b src/share/lib/security/java.security-windows +--- jdk/src/share/lib/security/java.security-windows Fri Oct 25 22:35:06 2013 +0100 ++++ jdk/src/share/lib/security/java.security-windows Tue Jul 16 10:58:46 2013 +0100 +@@ -129,7 +129,6 @@ + # corresponding RuntimePermission ("accessClassInPackage."+package) has + # been granted. + package.access=sun.,\ +- com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +@@ -168,7 +167,6 @@ + # checkPackageDefinition. + # + package.definition=sun.,\ +- com.sun.corba.se.impl.,\ + com.sun.xml.internal.,\ + com.sun.imageio.,\ + com.sun.istack.internal.,\ +diff -r 2a023db33371 -r 0b0490779c5b test/java/lang/SecurityManager/CheckPackageAccess.java +--- jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Oct 25 22:35:06 2013 +0100 ++++ jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Tue Jul 16 10:58:46 2013 +0100 +@@ -50,7 +50,6 @@ + */ + private static final String[] packages = { + "sun.", +- "com.sun.corba.se.impl.", + "com.sun.xml.internal.", + "com.sun.imageio.", + "com.sun.istack.internal.", diff --git a/java/openjdk6/files/icedtea/openjdk/8019292-better_attribute_value_exceptions.patch b/java/openjdk6/files/icedtea/openjdk/8019292-better_attribute_value_exceptions.patch new file mode 100644 index 000000000000..12ffa0f1a6c9 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8019292-better_attribute_value_exceptions.patch @@ -0,0 +1,57 @@ +# HG changeset patch +# User sjiang +# Date 1375797854 -7200 +# Tue Aug 06 16:04:14 2013 +0200 +# Node ID d80e6f4a4eec26137af6726cfb8abfe108ce23ea +# Parent de490a43861e05f3da489db136687b1dc6f1949a +8019292: Better Attribute Value Exceptions +Reviewed-by: dfuchs, dholmes, ahgross + +diff -r de490a43861e -r d80e6f4a4eec src/share/classes/javax/management/BadAttributeValueExpException.java +--- jdk/src/share/classes/javax/management/BadAttributeValueExpException.java Fri Oct 25 22:43:09 2013 +0100 ++++ jdk/src/share/classes/javax/management/BadAttributeValueExpException.java Tue Aug 06 16:04:14 2013 +0200 +@@ -25,6 +25,9 @@ + + package javax.management; + ++import java.io.IOException; ++import java.io.ObjectInputStream; ++ + + /** + * Thrown when an invalid MBean attribute is passed to a query +@@ -51,7 +54,7 @@ + * @param val the inappropriate value. + */ + public BadAttributeValueExpException (Object val) { +- this.val = val; ++ this.val = val == null ? null : val.toString(); + } + + +@@ -62,4 +65,25 @@ + return "BadAttributeValueException: " + val; + } + ++ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { ++ ObjectInputStream.GetField gf = ois.readFields(); ++ Object valObj = gf.get("val", null); ++ ++ if (valObj == null) { ++ val = null; ++ } else if (valObj instanceof String) { ++ val= valObj; ++ } else if (System.getSecurityManager() == null ++ || valObj instanceof Long ++ || valObj instanceof Integer ++ || valObj instanceof Float ++ || valObj instanceof Double ++ || valObj instanceof Byte ++ || valObj instanceof Short ++ || valObj instanceof Boolean) { ++ val = valObj.toString(); ++ } else { // the serialized object is from a version without JDK-8019292 fix ++ val = System.identityHashCode(valObj) + "@" + valObj.getClass().getName(); ++ } ++ } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8019584-invalid_notification_fix.patch b/java/openjdk6/files/icedtea/openjdk/8019584-invalid_notification_fix.patch new file mode 100644 index 000000000000..bbbc168a683d --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8019584-invalid_notification_fix.patch @@ -0,0 +1,69 @@ +# HG changeset patch +# User jbachorik +# Date 1374244166 -7200 +# Fri Jul 19 16:29:26 2013 +0200 +# Node ID 42cdf6988c2b81b322bf89778ddeb47265cd3bba +# Parent a8132d72370c1f2467c9bb966d9355b387c35039 +8019584: javax/management/remote/mandatory/loading/MissingClassTest.java failed in nightly against jdk7u45: java.io.InvalidObjectException: Invalid notification: null +Reviewed-by: mchung, sjiang, dfuchs, ahgross + +diff -r a8132d72370c -r 42cdf6988c2b src/share/classes/javax/management/remote/NotificationResult.java +--- jdk/src/share/classes/javax/management/remote/NotificationResult.java Mon Jul 15 16:00:57 2013 +0100 ++++ jdk/src/share/classes/javax/management/remote/NotificationResult.java Fri Jul 19 16:29:26 2013 +0200 +@@ -132,16 +132,17 @@ + } + + private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { +- ObjectInputStream.GetField gf = ois.readFields(); +- TargetedNotification[] tNotifs = (TargetedNotification[])gf.get("targetedNotifications", null); +- long snStart = gf.get("earliestSequenceNumber", -1L); +- long snNext = gf.get("nextSequenceNumber", -1L); ++ ois.defaultReadObject(); + try { +- validate(tNotifs, snStart, snNext); ++ validate( ++ this.targetedNotifications, ++ this.earliestSequenceNumber, ++ this.nextSequenceNumber ++ ); + +- this.targetedNotifications = tNotifs.length == 0 ? tNotifs : tNotifs.clone(); +- this.earliestSequenceNumber = snStart; +- this.nextSequenceNumber = snNext; ++ this.targetedNotifications = this.targetedNotifications.length == 0 ? ++ this.targetedNotifications : ++ this.targetedNotifications.clone(); + } catch (IllegalArgumentException e) { + throw new InvalidObjectException(e.getMessage()); + } +diff -r a8132d72370c -r 42cdf6988c2b src/share/classes/javax/management/remote/TargetedNotification.java +--- jdk/src/share/classes/javax/management/remote/TargetedNotification.java Mon Jul 15 16:00:57 2013 +0100 ++++ jdk/src/share/classes/javax/management/remote/TargetedNotification.java Fri Jul 19 16:29:26 2013 +0200 +@@ -132,13 +132,9 @@ + // } + + private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { +- ObjectInputStream.GetField gf = ois.readFields(); +- Notification notification = (Notification)gf.get("notif", null); +- Integer listenerId = (Integer)gf.get("id", null); ++ ois.defaultReadObject(); + try { +- validate(notification, listenerId); +- this.notif = notification; +- this.id = listenerId; ++ validate(this.notif, this.id); + } catch (IllegalArgumentException e) { + throw new InvalidObjectException(e.getMessage()); + } +diff -r a8132d72370c -r 42cdf6988c2b test/javax/management/remote/mandatory/loading/MissingClassTest.java +--- jdk/test/javax/management/remote/mandatory/loading/MissingClassTest.java Mon Jul 15 16:00:57 2013 +0100 ++++ jdk/test/javax/management/remote/mandatory/loading/MissingClassTest.java Fri Jul 19 16:29:26 2013 +0200 +@@ -23,7 +23,7 @@ + + /* + * @test +- * @bug 4915825 4921009 4934965 4977469 ++ * @bug 4915825 4921009 4934965 4977469 8019584 + * @summary Tests behavior when client or server gets object of unknown class + * @author Eamonn McManus + * @run clean MissingClassTest SingleClassLoader diff --git a/java/openjdk6/files/icedtea/openjdk/8019617-better_view_of_objects.patch b/java/openjdk6/files/icedtea/openjdk/8019617-better_view_of_objects.patch new file mode 100644 index 000000000000..25a70c01539b --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8019617-better_view_of_objects.patch @@ -0,0 +1,68 @@ +# HG changeset patch +# User malenkov +# Date 1373994034 -14400 +# Tue Jul 16 21:00:34 2013 +0400 +# Node ID 9cfb9105241489a5fbc3fcfdea15a6aee15b2cfc +# Parent d80e6f4a4eec26137af6726cfb8abfe108ce23ea +8019617: Better view of objects +Reviewed-by: art, skoivu + +diff -r d80e6f4a4eec -r 9cfb91052414 src/share/classes/javax/swing/text/html/ObjectView.java +--- jdk/src/share/classes/javax/swing/text/html/ObjectView.java Tue Aug 06 16:04:14 2013 +0200 ++++ jdk/src/share/classes/javax/swing/text/html/ObjectView.java Tue Jul 16 21:00:34 2013 +0400 +@@ -31,6 +31,9 @@ + import java.beans.*; + import java.lang.reflect.*; + ++import sun.reflect.misc.MethodUtil; ++import sun.reflect.misc.ReflectUtil; ++ + /** + * Component decorator that implements the view interface + * for <object> elements. +@@ -87,6 +90,7 @@ + AttributeSet attr = getElement().getAttributes(); + String classname = (String) attr.getAttribute(HTML.Attribute.CLASSID); + try { ++ ReflectUtil.checkPackageAccess(classname); + Class c = Class.forName(classname, true,Thread.currentThread(). + getContextClassLoader()); + Object o = c.newInstance(); +@@ -116,28 +120,6 @@ + } + + /** +- * Get a Class object to use for loading the +- * classid. If possible, the Classloader +- * used to load the associated Document is used. +- * This would typically be the same as the ClassLoader +- * used to load the EditorKit. If the documents +- * ClassLoader is null, +- * <code>Class.forName</code> is used. +- */ +- private Class getClass(String classname) throws ClassNotFoundException { +- Class klass; +- +- Class docClass = getDocument().getClass(); +- ClassLoader loader = docClass.getClassLoader(); +- if (loader != null) { +- klass = loader.loadClass(classname); +- } else { +- klass = Class.forName(classname); +- } +- return klass; +- } +- +- /** + * Initialize this component according the KEY/VALUEs passed in + * via the <param> elements in the corresponding + * <object> element. +@@ -170,7 +152,7 @@ + } + Object [] args = { value }; + try { +- writer.invoke(comp, args); ++ MethodUtil.invoke(writer, comp, args); + } catch (Exception ex) { + System.err.println("Invocation failed"); + // invocation code diff --git a/java/openjdk6/files/icedtea/openjdk/8019969-inet6_test_case_fix.patch b/java/openjdk6/files/icedtea/openjdk/8019969-inet6_test_case_fix.patch new file mode 100644 index 000000000000..58299d057149 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8019969-inet6_test_case_fix.patch @@ -0,0 +1,33 @@ +# HG changeset patch +# User michaelm +# Date 1373900457 -3600 +# Mon Jul 15 16:00:57 2013 +0100 +# Node ID a8132d72370c1f2467c9bb966d9355b387c35039 +# Parent bac5d0b011562017738501f02f7db4f39522a62e +8019969: nioNetworkChannelInet6/SetOptionGetOptionTestInet6 test case crashes +Reviewed-by: chegar + +diff -r bac5d0b01156 -r a8132d72370c src/windows/native/java/net/net_util_md.c +--- jdk/src/windows/native/java/net/net_util_md.c Tue Oct 29 01:32:58 2013 +0000 ++++ jdk/src/windows/native/java/net/net_util_md.c Mon Jul 15 16:00:57 2013 +0100 +@@ -879,7 +879,6 @@ + family = (iafam == IPv4)? AF_INET : AF_INET6; + if (ipv6_available() && !(family == AF_INET && v4MappedAddress == JNI_FALSE)) { + struct SOCKADDR_IN6 *him6 = (struct SOCKADDR_IN6 *)him; +- jbyteArray ipaddress; + jbyte caddr[16]; + jint address, scopeid = 0; + jint cached_scope_id = 0; +@@ -900,10 +899,9 @@ + caddr[15] = (address & 0xff); + } + } else { +- ipaddress = (*env)->GetObjectField(env, iaObj, ia6_ipaddressID); +- scopeid = (jint)(*env)->GetIntField(env, iaObj, ia6_scopeidID); ++ getInet6Address_ipaddress(env, iaObj, (char *)caddr); ++ scopeid = getInet6Address_scopeid(env, iaObj); + cached_scope_id = (jint)(*env)->GetIntField(env, iaObj, ia6_cachedscopeidID); +- (*env)->GetByteArrayRegion(env, ipaddress, 0, 16, caddr); + } + + memset((char *)him6, 0, sizeof(struct SOCKADDR_IN6)); diff --git a/java/openjdk6/files/icedtea/openjdk/8019979-better_access_test.patch b/java/openjdk6/files/icedtea/openjdk/8019979-better_access_test.patch new file mode 100644 index 000000000000..5a92a81b86c1 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8019979-better_access_test.patch @@ -0,0 +1,154 @@ +# HG changeset patch +# User coffeys +# Date 1373625375 -3600 +# Fri Jul 12 11:36:15 2013 +0100 +# Node ID 3b6f55f02122398ba662fb581352c9c9b102c2e3 +# Parent f7a7c7d70e4968eb99e42f812c59900f545d7fa7 +8019979: Replace CheckPackageAccess test with better one from closed repo +Reviewed-by: mullan, robilad + +diff -r f7a7c7d70e49 -r 3b6f55f02122 test/java/lang/SecurityManager/CheckPackageAccess.java +--- jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Oct 25 22:18:57 2013 +0100 ++++ jdk/test/java/lang/SecurityManager/CheckPackageAccess.java Fri Jul 12 11:36:15 2013 +0100 +@@ -22,31 +22,128 @@ + */ + + /* +- * @test +- * @bug 7146431 8000450 +- * @summary Test that internal packages cannot be accessed ++ * @test ++ * @bug 6741606 7146431 8000450 ++ * @summary Make sure all restricted packages listed in the package.access ++ * property in the java.security file are blocked ++ * @run main/othervm CheckPackageAccess + */ + ++import java.security.Security; ++import java.util.Collections; ++import java.util.Arrays; ++import java.util.ArrayList; ++import java.util.List; ++import java.util.StringTokenizer; ++ ++/* ++ * The main benefit of this test is to catch merge errors or other types ++ * of issues where one or more of the packages are accidentally ++ * removed. This is why the packages that are known to be restricted have to ++ * be explicitly listed below. ++ */ + public class CheckPackageAccess { + ++ /* ++ * This array should be updated whenever new packages are added to the ++ * package.access property in the java.security file ++ */ ++ private static final String[] packages = { ++ "sun.", ++ "com.sun.corba.se.impl.", ++ "com.sun.xml.internal.", ++ "com.sun.imageio.", ++ "com.sun.istack.internal.", ++ "com.sun.jmx.", ++ "com.sun.proxy.", ++ "com.sun.org.apache.bcel.internal.", ++ "com.sun.org.apache.regexp.internal.", ++ "com.sun.org.apache.xerces.internal.", ++ "com.sun.org.apache.xpath.internal.", ++ "com.sun.org.apache.xalan.internal.extensions.", ++ "com.sun.org.apache.xalan.internal.lib.", ++ "com.sun.org.apache.xalan.internal.res.", ++ "com.sun.org.apache.xalan.internal.templates.", ++ "com.sun.org.apache.xalan.internal.utils.", ++ "com.sun.org.apache.xalan.internal.xslt.", ++ "com.sun.org.apache.xalan.internal.xsltc.cmdline.", ++ "com.sun.org.apache.xalan.internal.xsltc.compiler.", ++ "com.sun.org.apache.xalan.internal.xsltc.trax.", ++ "com.sun.org.apache.xalan.internal.xsltc.util.", ++ "com.sun.org.apache.xml.internal.res.", ++ "com.sun.org.apache.xml.internal.security.", ++ "com.sun.org.apache.xml.internal.serializer.utils.", ++ "com.sun.org.apache.xml.internal.utils.", ++ "com.sun.org.glassfish.", ++ "oracle.jrockit.jfr.", ++ "org.jcp.xml.dsig.internal.", ++ }; ++ + public static void main(String[] args) throws Exception { ++ List<String> pkgs = new ArrayList<>(Arrays.asList(packages)); ++ String osName = System.getProperty("os.name"); ++ if (osName.contains("OS X")) { ++ pkgs.add("apple."); // add apple package for OS X ++ } else if (osName.startsWith("Windows")) { ++ pkgs.add("com.sun.java.accessibility."); ++ } + +- String[] pkgs = new String[] { +- "com.sun.corba.se.impl.", +- "com.sun.org.apache.xerces.internal.utils.", +- "com.sun.org.apache.xalan.internal.utils." }; +- SecurityManager sm = new SecurityManager(); +- System.setSecurityManager(sm); +- for (String pkg : pkgs) { +- System.out.println("Checking package access for " + pkg); ++ List<String> jspkgs = ++ getPackages(Security.getProperty("package.access")); ++ ++ // Sort to ensure lists are comparable ++ Collections.sort(pkgs); ++ Collections.sort(jspkgs); ++ ++ if (!pkgs.equals(jspkgs)) { ++ for (String p : pkgs) ++ if (!jspkgs.contains(p)) ++ System.out.println("In golden set, but not in j.s file: " + p); ++ for (String p : jspkgs) ++ if (!pkgs.contains(p)) ++ System.out.println("In j.s file, but not in golden set: " + p); ++ ++ ++ throw new RuntimeException("restricted packages are not " + ++ "consistent with java.security file"); ++ } ++ System.setSecurityManager(new SecurityManager()); ++ SecurityManager sm = System.getSecurityManager(); ++ for (String pkg : packages) { ++ String subpkg = pkg + "foo"; + try { + sm.checkPackageAccess(pkg); +- throw new Exception("Expected PackageAccess SecurityException not thrown"); ++ throw new RuntimeException("Able to access " + pkg + ++ " package"); ++ } catch (SecurityException se) { } ++ try { ++ sm.checkPackageAccess(subpkg); ++ throw new RuntimeException("Able to access " + subpkg + ++ " package"); + } catch (SecurityException se) { } + try { + sm.checkPackageDefinition(pkg); +- throw new Exception("Expected PackageDefinition SecurityException not thrown"); ++ throw new RuntimeException("Able to define class in " + pkg + ++ " package"); ++ } catch (SecurityException se) { } ++ try { ++ sm.checkPackageDefinition(subpkg); ++ throw new RuntimeException("Able to define class in " + subpkg + ++ " package"); + } catch (SecurityException se) { } + } ++ System.out.println("Test passed"); ++ } ++ ++ private static List<String> getPackages(String p) { ++ List<String> packages = new ArrayList<>(); ++ if (p != null && !p.equals("")) { ++ StringTokenizer tok = new StringTokenizer(p, ","); ++ while (tok.hasMoreElements()) { ++ String s = tok.nextToken().trim(); ++ packages.add(s); ++ } ++ } ++ return packages; + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8020293-jvm_crash.patch b/java/openjdk6/files/icedtea/openjdk/8020293-jvm_crash.patch new file mode 100644 index 000000000000..920bce81adbe --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8020293-jvm_crash.patch @@ -0,0 +1,40 @@ +# HG changeset patch +# User jchen +# Date 1374527199 25200 +# Mon Jul 22 14:06:39 2013 -0700 +# Node ID 2adb9f71f6c0723acf40877f059d276557b71034 +# Parent 150e0c3e95ce6869f8e7b42c6d8683817433e124 +8020293: JVM crash +Reviewed-by: prr, jgodinez + +diff -r 150e0c3e95ce -r 2adb9f71f6c0 src/share/classes/sun/font/GlyphLayout.java +--- jdk/src/share/classes/sun/font/GlyphLayout.java Mon Oct 28 20:56:09 2013 +0000 ++++ jdk/src/share/classes/sun/font/GlyphLayout.java Mon Jul 22 14:06:39 2013 -0700 +@@ -468,9 +468,10 @@ + _gvdata.grow(); + } + } +- if (_gvdata._count < 0) { +- break; +- } ++ } ++ // Break out of the outer for loop if layout fails. ++ if (_gvdata._count < 0) { ++ break; + } + } + +diff -r 150e0c3e95ce -r 2adb9f71f6c0 src/share/native/sun/font/layout/SunLayoutEngine.cpp +--- jdk/src/share/native/sun/font/layout/SunLayoutEngine.cpp Mon Oct 28 20:56:09 2013 +0000 ++++ jdk/src/share/native/sun/font/layout/SunLayoutEngine.cpp Mon Jul 22 14:06:39 2013 -0700 +@@ -104,6 +104,10 @@ + + int putGV(JNIEnv* env, jint gmask, jint baseIndex, jobject gvdata, const LayoutEngine* engine, int glyphCount) { + int count = env->GetIntField(gvdata, gvdCountFID); ++ if (count < 0) { ++ JNU_ThrowInternalError(env, "count negative"); ++ return 0; ++ } + + jarray glyphArray = (jarray)env->GetObjectField(gvdata, gvdGlyphsFID); + if (IS_NULL(glyphArray)) { diff --git a/java/openjdk6/files/icedtea/openjdk/8020943-memory_leak.patch b/java/openjdk6/files/icedtea/openjdk/8020943-memory_leak.patch new file mode 100644 index 000000000000..92967c051909 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8020943-memory_leak.patch @@ -0,0 +1,32 @@ +# HG changeset patch +# User kevinw +# Date 1375442806 -3600 +# Fri Aug 02 12:26:46 2013 +0100 +# Node ID 2660219948088d89dd3fc285e093dab2520349e5 +# Parent 4b3487aa553cca3fb7ecb74d284b9524d0bf5bf8 +8020943: Memory leak when GCNotifier uses create_from_platform_dependent_str() +Reviewed-by: mgerdin, fparain, dcubed + +diff -r 4b3487aa553c -r 266021994808 src/share/vm/services/gcNotifier.cpp +--- hotspot/src/share/vm/services/gcNotifier.cpp Thu Oct 17 19:28:00 2013 +0100 ++++ hotspot/src/share/vm/services/gcNotifier.cpp Fri Aug 02 12:26:46 2013 +0100 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -211,9 +211,9 @@ + NotificationMark nm(request); + Handle objGcInfo = createGcInfo(request->gcManager, request->gcStatInfo, THREAD); + +- Handle objName = java_lang_String::create_from_platform_dependent_str(request->gcManager->name(), CHECK); +- Handle objAction = java_lang_String::create_from_platform_dependent_str(request->gcAction, CHECK); +- Handle objCause = java_lang_String::create_from_platform_dependent_str(request->gcCause, CHECK); ++ Handle objName = java_lang_String::create_from_str(request->gcManager->name(), CHECK); ++ Handle objAction = java_lang_String::create_from_str(request->gcAction, CHECK); ++ Handle objCause = java_lang_String::create_from_str(request->gcCause, CHECK); + + klassOop k = Management::sun_management_GarbageCollectorImpl_klass(CHECK); + instanceKlassHandle gc_mbean_klass(THREAD, k); diff --git a/java/openjdk6/files/icedtea/openjdk/8021290-signature_validation.patch b/java/openjdk6/files/icedtea/openjdk/8021290-signature_validation.patch new file mode 100644 index 000000000000..1cb588fecc68 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8021290-signature_validation.patch @@ -0,0 +1,55 @@ +# HG changeset patch +# User mullan +# Date 1375219222 14400 +# Tue Jul 30 17:20:22 2013 -0400 +# Node ID 3e758b40337ef9da5ad030d0ac60ab4407357277 +# Parent 5e3c766d18092d498d9019827c1058a32f1c4e2a +8021290: Better signature validation +Reviewed-by: xuelei, ahgross + +diff -r 5e3c766d1809 -r 3e758b40337e src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java +--- jdk/src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java Fri Oct 15 10:55:59 2010 -0400 ++++ jdk/src/share/classes/com/sun/org/apache/xml/internal/security/utils/UnsyncByteArrayOutputStream.java Tue Jul 30 17:20:22 2013 -0400 +@@ -44,6 +44,9 @@ + } + + public void write(byte[] arg0) { ++ if ((Integer.MAX_VALUE - pos) < arg0.length) { ++ throw new OutOfMemoryError(); ++ } + int newPos = pos + arg0.length; + if (newPos > size) { + expandSize(newPos); +@@ -53,6 +56,9 @@ + } + + public void write(byte[] arg0, int arg1, int arg2) { ++ if ((Integer.MAX_VALUE - pos) < arg2) { ++ throw new OutOfMemoryError(); ++ } + int newPos = pos + arg2; + if (newPos > size) { + expandSize(newPos); +@@ -62,6 +68,9 @@ + } + + public void write(int arg0) { ++ if ((Integer.MAX_VALUE - pos) == 0) { ++ throw new OutOfMemoryError(); ++ } + int newPos = pos + 1; + if (newPos > size) { + expandSize(newPos); +@@ -82,7 +91,11 @@ + private void expandSize(int newPos) { + int newSize = size; + while (newPos > newSize) { +- newSize = newSize<<2; ++ newSize = newSize << 1; ++ // Deal with overflow ++ if (newSize < 0) { ++ newSize = Integer.MAX_VALUE; ++ } + } + byte newBuf[] = new byte[newSize]; + System.arraycopy(buf, 0, newBuf, 0, pos); diff --git a/java/openjdk6/files/icedtea/openjdk/8021355-splashscreen_regression.patch b/java/openjdk6/files/icedtea/openjdk/8021355-splashscreen_regression.patch new file mode 100644 index 000000000000..c5c8d4a08aa2 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8021355-splashscreen_regression.patch @@ -0,0 +1,53 @@ +# HG changeset patch +# User ksrini +# Date 1383014349 0 +# Tue Oct 29 02:39:09 2013 +0000 +# Node ID a5d00a180798f25254bf6f15b7dc31a0d5df60c2 +# Parent 5896fe42b0a429fb5be7abee630b98fa2ec00df3 +8021355: REGRESSION: Five closed/java/awt/SplashScreen tests fail since 7u45 b01 on Linux, Solaris +Reviewed-by: dholmes, anthony, ahgross, erikj, omajid + +diff -r 5896fe42b0a4 -r a5d00a180798 src/solaris/bin/java_md.c +--- jdk/src/solaris/bin/java_md.c Wed Aug 07 16:51:59 2013 +0400 ++++ jdk/src/solaris/bin/java_md.c Tue Oct 29 02:39:09 2013 +0000 +@@ -46,6 +46,10 @@ + #define JVM_DLL "libjvm.so" + #define JAVA_DLL "libjava.so" + ++#define JRE_ERROR1 "Error: Could not find Java SE Runtime Environment." ++#define JRE_ERROR11 "Error: Path length exceeds maximum length (PATH_MAX)" ++#define JRE_ERROR13 "Error: String processing operation failed" ++ + /* + * If a processor / os combination has the ability to run binaries of + * two data models and cohabitation of jre/jdk bits with both data +@@ -1700,7 +1704,28 @@ + + void* SplashProcAddress(const char* name) { + if (!hSplashLib) { +- hSplashLib = dlopen(SPLASHSCREEN_SO, RTLD_LAZY | RTLD_GLOBAL); ++ int ret; ++ char jrePath[MAXPATHLEN]; ++ char splashPath[MAXPATHLEN]; ++ ++ if (!GetJREPath(jrePath, sizeof(jrePath), GetArch(), JNI_FALSE)) { ++ ReportErrorMessage(JRE_ERROR1, JNI_TRUE); ++ return NULL; ++ } ++ ret = snprintf(splashPath, sizeof(splashPath), "%s/lib/%s/%s", ++ jrePath, GetArch(), SPLASHSCREEN_SO); ++ ++ if (ret >= (int) sizeof(splashPath)) { ++ ReportErrorMessage(JRE_ERROR11, JNI_TRUE); ++ return NULL; ++ } ++ if (ret < 0) { ++ ReportErrorMessage(JRE_ERROR13, JNI_TRUE); ++ return NULL; ++ } ++ hSplashLib = dlopen(splashPath, RTLD_LAZY | RTLD_GLOBAL); ++ if (_launcher_debug) ++ printf("Info: loaded %s\n", splashPath); + } + if (hSplashLib) { + void* sym = dlsym(hSplashLib, name); diff --git a/java/openjdk6/files/icedtea/openjdk/8021366-jaxp_test_fix-01.patch b/java/openjdk6/files/icedtea/openjdk/8021366-jaxp_test_fix-01.patch new file mode 100644 index 000000000000..04aea00a5df4 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8021366-jaxp_test_fix-01.patch @@ -0,0 +1,21 @@ +# HG changeset patch +# User joehw +# Date 1375178534 25200 +# Tue Jul 30 03:02:14 2013 -0700 +# Node ID 674ada27a93f4ecd359617d5a27cb2dfe52c44b4 +# Parent 0927621944ccb163d7dcdea7b94b10dfab58f5f1 +8021366: java_util/Properties/PropertiesWithOtherEncodings fails during 7u45 nightly testing +Reviewed-by: lancea, alanb, dfuchs, mullan + +diff -r 0927621944cc -r 674ada27a93f drop_included/jaxp_src/src/com/sun/xml/internal/stream/Entity.java +--- jaxp/drop_included/jaxp_src/src/com/sun/xml/internal/stream/Entity.java Tue Oct 29 08:01:29 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/xml/internal/stream/Entity.java Tue Jul 30 03:02:14 2013 -0700 +@@ -248,7 +248,7 @@ + public int fBufferSize = DEFAULT_BUFFER_SIZE; + + /** Default buffer size before we've finished with the XMLDecl: */ +- public static final int DEFAULT_XMLDECL_BUFFER_SIZE = 64; ++ public static final int DEFAULT_XMLDECL_BUFFER_SIZE = 28; + + /** Default internal entity buffer size (1024). */ + public static final int DEFAULT_INTERNAL_BUFFER_SIZE = 1024; diff --git a/java/openjdk6/files/icedtea/openjdk/8021577-bean_serialization_fix.patch b/java/openjdk6/files/icedtea/openjdk/8021577-bean_serialization_fix.patch new file mode 100644 index 000000000000..396abf4e10ea --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8021577-bean_serialization_fix.patch @@ -0,0 +1,25 @@ +# HG changeset patch +# User jbachorik +# Date 1375098221 25200 +# Mon Jul 29 04:43:41 2013 -0700 +# Node ID 21358b9e406319f4d9ddfd663572dd71a093ce08 +# Parent 42cdf6988c2b81b322bf89778ddeb47265cd3bba +8021577: JCK test api/javax_management/jmx_serial/modelmbean/ModelMBeanNotificationInfo/serial/index.html#Input has failed since jdk 7u45 b01 +Reviewed-by: alanb, dfuchs, ahgross + +diff -r 42cdf6988c2b -r 21358b9e4063 src/share/classes/javax/management/MBeanNotificationInfo.java +--- jdk/src/share/classes/javax/management/MBeanNotificationInfo.java Fri Jul 19 16:29:26 2013 +0200 ++++ jdk/src/share/classes/javax/management/MBeanNotificationInfo.java Mon Jul 29 04:43:41 2013 -0700 +@@ -210,11 +210,6 @@ + ObjectInputStream.GetField gf = ois.readFields(); + String[] t = (String[])gf.get("types", null); + +- if (t == null) { +- throw new InvalidObjectException("Trying to deserialize an invalid " + +- "instance of " + MBeanNotificationInfo.class + +- "[types=null]"); +- } +- types = t.length == 0 ? t : t.clone(); ++ types = (t != null && t.length != 0) ? t.clone() : NO_TYPES; + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8021933-jaxp_test_fix-02.patch b/java/openjdk6/files/icedtea/openjdk/8021933-jaxp_test_fix-02.patch new file mode 100644 index 000000000000..f3ad91a9b147 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8021933-jaxp_test_fix-02.patch @@ -0,0 +1,33 @@ +# HG changeset patch +# User joehw +# Date 1375252858 25200 +# Tue Jul 30 23:40:58 2013 -0700 +# Node ID dce0c261a1837e664e4d8739b97e8758a1fa0de2 +# Parent 674ada27a93f4ecd359617d5a27cb2dfe52c44b4 +8021933: Add extra check for fix # JDK-8014530 +Reviewed-by: alanb, lancea + +diff -r 674ada27a93f -r dce0c261a183 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSAttributeChecker.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSAttributeChecker.java Tue Jul 30 03:02:14 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSAttributeChecker.java Tue Jul 30 23:40:58 2013 -0700 +@@ -1237,7 +1237,7 @@ + //Revisit :: IMO this is not right place to check + // maxOccurNodeLimit. + int maxOccurNodeLimit = fSchemaHandler.fSecureProcessing.getLimit(XMLSecurityManager.Limit.MAX_OCCUR_NODE_LIMIT); +- if (max > maxOccurNodeLimit) { ++ if (max > maxOccurNodeLimit && !fSchemaHandler.fSecureProcessing.isNoLimit(maxOccurNodeLimit)) { + reportSchemaFatalError("maxOccurLimit", new Object[] {new Integer(maxOccurNodeLimit)}, element); + + // reset max values in case processing continues on error +diff -r 674ada27a93f -r dce0c261a183 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Jul 30 03:02:14 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Jul 30 23:40:58 2013 -0700 +@@ -257,7 +257,7 @@ + "FeatureNameNull", null)); + } + if (name.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { +- return (fSecurityManager != null); ++ return (fSecurityManager !=null && fSecurityManager.isSecureProcessing()); + } + try { + return fXMLSchemaLoader.getFeature(name); diff --git a/java/openjdk6/files/icedtea/openjdk/8021969-jnlp_load_failure.patch b/java/openjdk6/files/icedtea/openjdk/8021969-jnlp_load_failure.patch new file mode 100644 index 000000000000..2e12b577eeaa --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8021969-jnlp_load_failure.patch @@ -0,0 +1,25 @@ +# HG changeset patch +# User malenkov +# Date 1375879919 -14400 +# Wed Aug 07 16:51:59 2013 +0400 +# Node ID 5896fe42b0a429fb5be7abee630b98fa2ec00df3 +# Parent 21358b9e406319f4d9ddfd663572dd71a093ce08 +8021969: The index_AccessAllowed jnlp can not load successfully with exception thrown in the log. +Reviewed-by: art, skoivu + +diff -r 21358b9e4063 -r 5896fe42b0a4 src/share/classes/java/awt/datatransfer/DataFlavor.java +--- jdk/src/share/classes/java/awt/datatransfer/DataFlavor.java Mon Jul 29 04:43:41 2013 -0700 ++++ jdk/src/share/classes/java/awt/datatransfer/DataFlavor.java Wed Aug 07 16:51:59 2013 +0400 +@@ -145,11 +145,7 @@ + } catch (SecurityException exception) { + // ignore secured class loaders + } +- if (fallback != null) { +- return Class.forName(className, true, fallback); +- } else { +- throw new ClassNotFoundException(className); +- } ++ return Class.forName(className, true, fallback); + } + + /* diff --git a/java/openjdk6/files/icedtea/openjdk/8022661-writeobject_flush.patch b/java/openjdk6/files/icedtea/openjdk/8022661-writeobject_flush.patch new file mode 100644 index 000000000000..a13b8c5161b3 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8022661-writeobject_flush.patch @@ -0,0 +1,20 @@ +# HG changeset patch +# User chegar +# Date 1376052613 -3600 +# Fri Aug 09 13:50:13 2013 +0100 +# Node ID 6c0b775b1ff2a0a0ba0fe797cfe18c511f9ee3c1 +# Parent a5d00a180798f25254bf6f15b7dc31a0d5df60c2 +8022661: InetAddress.writeObject() performs flush() on object output stream +Reviewed-by: michaelm, alanb + +diff -r a5d00a180798 -r 6c0b775b1ff2 src/share/classes/java/net/InetAddress.java +--- jdk/src/share/classes/java/net/InetAddress.java Tue Oct 29 02:39:09 2013 +0000 ++++ jdk/src/share/classes/java/net/InetAddress.java Fri Aug 09 13:50:13 2013 +0100 +@@ -1586,7 +1586,6 @@ + pf.put("address", holder().address); + pf.put("family", holder().family); + s.writeFields(); +- s.flush(); + } + } + diff --git a/java/openjdk6/files/icedtea/openjdk/8022682-supporting_xom.patch b/java/openjdk6/files/icedtea/openjdk/8022682-supporting_xom.patch new file mode 100644 index 000000000000..c72d12ce5762 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8022682-supporting_xom.patch @@ -0,0 +1,250 @@ +# HG changeset patch +# User joehw +# Date 1383034215 0 +# Tue Oct 29 08:10:15 2013 +0000 +# Node ID 20ffb814205c67b5ded678ee6c69b2aa0d6cebb1 +# Parent dce0c261a1837e664e4d8739b97e8758a1fa0de2 +8022682: Supporting XOM +Reviewed-by: alanb, chegar, lancea + +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java Tue Oct 29 08:10:15 2013 +0000 +@@ -168,6 +168,17 @@ + //add internal stax property + supportedProps.put( Constants.XERCES_PROPERTY_PREFIX + Constants.STAX_ENTITY_RESOLVER_PROPERTY , new StaxEntityResolverWrapper((XMLResolver)value)) ; + } ++ ++ /** ++ * It's possible for users to set a security manager through the interface. ++ * If it's the old SecurityManager, convert it to the new XMLSecurityManager ++ */ ++ if (property.equals(Constants.SECURITY_MANAGER)) { ++ fSecurityManager = XMLSecurityManager.convert(value, fSecurityManager); ++ supportedProps.put(Constants.SECURITY_MANAGER, fSecurityManager); ++ return; ++ } ++ + supportedProps.put(property, value ) ; + if(equivalentProperty != null){ + supportedProps.put(equivalentProperty, value ) ; +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 08:10:15 2013 +0000 +@@ -352,7 +352,7 @@ + "ProperyNameNull", null)); + } + if (name.equals(SECURITY_MANAGER)) { +- fSecurityManager = (XMLSecurityManager) object; ++ fSecurityManager = XMLSecurityManager.convert(object, fSecurityManager); + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + return; + } +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/DOMParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/DOMParser.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/DOMParser.java Tue Oct 29 08:10:15 2013 +0000 +@@ -28,6 +28,7 @@ + import com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper; + import com.sun.org.apache.xerces.internal.util.SAXMessageFormatter; + import com.sun.org.apache.xerces.internal.util.SymbolTable; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XNIException; + import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarPool; + import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException; +@@ -528,7 +529,30 @@ + */ + public void setProperty(String propertyId, Object value) + throws SAXNotRecognizedException, SAXNotSupportedException { ++ /** ++ * It's possible for users to set a security manager through the interface. ++ * If it's the old SecurityManager, convert it to the new XMLSecurityManager ++ */ ++ if (propertyId.equals(Constants.SECURITY_MANAGER)) { ++ securityManager = XMLSecurityManager.convert(value, securityManager); ++ setProperty0(Constants.SECURITY_MANAGER, securityManager); ++ return; ++ } + ++ if (securityManager == null) { ++ securityManager = new XMLSecurityManager(true); ++ setProperty0(Constants.SECURITY_MANAGER, securityManager); ++ } ++ ++ //check if the property is managed by security manager ++ if (!securityManager.setLimit(propertyId, XMLSecurityManager.State.APIPROPERTY, value)) { ++ //fall back to the default configuration to handle the property ++ setProperty0(propertyId, value); ++ } ++ } ++ ++ public void setProperty0(String propertyId, Object value) ++ throws SAXNotRecognizedException, SAXNotSupportedException { + try { + fConfiguration.setProperty(propertyId, value); + } +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/DTDConfiguration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/DTDConfiguration.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/DTDConfiguration.java Tue Oct 29 08:10:15 2013 +0000 +@@ -181,6 +181,9 @@ + protected static final String LOCALE = + Constants.XERCES_PROPERTY_PREFIX + Constants.LOCALE_PROPERTY; + ++ /** Property identifier: Security manager. */ ++ private static final String SECURITY_MANAGER = Constants.SECURITY_MANAGER; ++ + // debugging + + /** Set to true and recompile to print exception stack trace. */ +@@ -325,7 +328,8 @@ + VALIDATION_MANAGER, + JAXP_SCHEMA_SOURCE, + JAXP_SCHEMA_LANGUAGE, +- LOCALE ++ LOCALE, ++ SECURITY_MANAGER + }; + addRecognizedProperties(recognizedProperties); + +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/NonValidatingConfiguration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/NonValidatingConfiguration.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/NonValidatingConfiguration.java Tue Oct 29 08:10:15 2013 +0000 +@@ -154,6 +154,9 @@ + protected static final String LOCALE = + Constants.XERCES_PROPERTY_PREFIX + Constants.LOCALE_PROPERTY; + ++ /** Property identifier: Security manager. */ ++ private static final String SECURITY_MANAGER = Constants.SECURITY_MANAGER; ++ + // debugging + + /** Set to true and recompile to print exception stack trace. */ +@@ -307,7 +310,8 @@ + XMLGRAMMAR_POOL, + DATATYPE_VALIDATOR_FACTORY, + VALIDATION_MANAGER, +- LOCALE ++ LOCALE, ++ SECURITY_MANAGER + }; + addRecognizedProperties(recognizedProperties); + +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java Tue Oct 29 08:10:15 2013 +0000 +@@ -74,7 +74,7 @@ + XMLGRAMMAR_POOL, + }; + +- XMLSecurityManager securityManager; ++ + // + // Constructors + // +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XML11Configuration.java Tue Oct 29 08:10:15 2013 +0000 +@@ -563,8 +563,6 @@ + + fVersionDetector = new XMLVersionDetector(); + +- fProperties.put(SECURITY_MANAGER, new XMLSecurityManager(true)); +- + // add message formatters + if (fErrorReporter.getMessageFormatter(XMLMessageFormatter.XML_DOMAIN) == null) { + XMLMessageFormatter xmft = new XMLMessageFormatter(); +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XMLParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XMLParser.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/XMLParser.java Tue Oct 29 08:10:15 2013 +0000 +@@ -23,6 +23,7 @@ + import java.io.IOException; + + import com.sun.org.apache.xerces.internal.impl.Constants; ++import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.XNIException; + import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource; + import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; +@@ -78,6 +79,10 @@ + /** The parser configuration. */ + protected XMLParserConfiguration fConfiguration; + ++ /** The XML Security Manager. */ ++ XMLSecurityManager securityManager; ++ ++ + // + // Constructors + // +@@ -118,6 +123,11 @@ + */ + public void parse(XMLInputSource inputSource) + throws XNIException, IOException { ++ // null indicates that the parser is called directly, initialize them ++ if (securityManager == null) { ++ securityManager = new XMLSecurityManager(true); ++ fConfiguration.setProperty(Constants.SECURITY_MANAGER, securityManager); ++ } + + reset(); + fConfiguration.parse(inputSource); +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLLimitAnalyzer.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLLimitAnalyzer.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLLimitAnalyzer.java Tue Oct 29 08:10:15 2013 +0000 +@@ -203,6 +203,9 @@ + } + + public boolean isTracking(String name) { ++ if (entityStart == null) { ++ return false; ++ } + return entityStart.equals(name); + } + /** +diff -r dce0c261a183 -r 20ffb814205c drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java Tue Jul 30 23:40:58 2013 -0700 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/utils/XMLSecurityManager.java Tue Oct 29 08:10:15 2013 +0000 +@@ -26,6 +26,7 @@ + package com.sun.org.apache.xerces.internal.utils; + + import com.sun.org.apache.xerces.internal.impl.Constants; ++import com.sun.org.apache.xerces.internal.util.SecurityManager; + + /** + * This class manages standard and implementation-specific limitations. +@@ -518,4 +519,37 @@ + } + return false; + } ++ ++ ++ /** ++ * Convert a value set through setProperty to XMLSecurityManager. ++ * If the value is an instance of XMLSecurityManager, use it to override the default; ++ * If the value is an old SecurityManager, convert to the new XMLSecurityManager. ++ * ++ * @param value user specified security manager ++ * @param securityManager an instance of XMLSecurityManager ++ * @return an instance of the new security manager XMLSecurityManager ++ */ ++ static public XMLSecurityManager convert(Object value, XMLSecurityManager securityManager) { ++ if (value == null) { ++ if (securityManager == null) { ++ securityManager = new XMLSecurityManager(true); ++ } ++ return securityManager; ++ } ++ if (XMLSecurityManager.class.isAssignableFrom(value.getClass())) { ++ return (XMLSecurityManager)value; ++ } else { ++ if (securityManager == null) { ++ securityManager = new XMLSecurityManager(true); ++ } ++ if (SecurityManager.class.isAssignableFrom(value.getClass())) { ++ SecurityManager origSM = (SecurityManager)value; ++ securityManager.setLimit(Limit.MAX_OCCUR_NODE_LIMIT, State.APIPROPERTY, origSM.getMaxOccurNodeLimit()); ++ securityManager.setLimit(Limit.ENTITY_EXPANSION_LIMIT, State.APIPROPERTY, origSM.getEntityExpansionLimit()); ++ securityManager.setLimit(Limit.ELEMENT_ATTRIBUTE_LIMIT, State.APIPROPERTY, origSM.getElementAttrLimit()); ++ } ++ return securityManager; ++ } ++ } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8022940-enhance_corba_translations.patch b/java/openjdk6/files/icedtea/openjdk/8022940-enhance_corba_translations.patch new file mode 100644 index 000000000000..f5b6cc769960 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8022940-enhance_corba_translations.patch @@ -0,0 +1,41 @@ +# HG changeset patch +# User msheppar +# Date 1376928111 -3600 +# Mon Aug 19 17:01:51 2013 +0100 +# Node ID b449df31dbfbf08d0f58a887649c2acacd5d834f +# Parent 2a415f9ee0976719ac79e6e5e2b1f00b29636427 +8022940: Enhance CORBA translations +Reviewed-by: coffeys, alanb, skoivu + +diff -r 2a415f9ee097 -r b449df31dbfb src/share/classes/com/sun/corba/se/impl/presentation/rmi/IDLNameTranslatorImpl.java +--- corba/src/share/classes/com/sun/corba/se/impl/presentation/rmi/IDLNameTranslatorImpl.java Thu Jul 18 17:22:25 2013 -0700 ++++ corba/src/share/classes/com/sun/corba/se/impl/presentation/rmi/IDLNameTranslatorImpl.java Mon Aug 19 17:01:51 2013 +0100 +@@ -905,28 +905,4 @@ + + return contents.toString(); + } +- +- public static void main(String[] args) { +- +- Class remoteInterface = java.rmi.Remote.class; +- +- if( args.length > 0 ) { +- String className = args[0]; +- try { +- remoteInterface = Class.forName(className); +- } catch(Exception e) { +- e.printStackTrace(); +- System.exit(-1); +- } +- } +- +- System.out.println("Building name translation for " + remoteInterface); +- try { +- IDLNameTranslator nameTranslator = +- IDLNameTranslatorImpl.get(remoteInterface); +- System.out.println(nameTranslator); +- } catch(IllegalStateException ise) { +- ise.printStackTrace(); +- } +- } + } diff --git a/java/openjdk6/files/icedtea/openjdk/8023457-tracing_mutex.patch b/java/openjdk6/files/icedtea/openjdk/8023457-tracing_mutex.patch new file mode 100644 index 000000000000..0c55c0cf13ce --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8023457-tracing_mutex.patch @@ -0,0 +1,79 @@ +# HG changeset patch +# User mgronlun +# Date 1382034480 -3600 +# Thu Oct 17 19:28:00 2013 +0100 +# Node ID 4b3487aa553cca3fb7ecb74d284b9524d0bf5bf8 +# Parent 3091721c83780cbb9a946f05007651e0bd09490b +8023457: Event based tracing framework needs a mutex for thread groups +Reviewed-by: acorn, sla + +diff -r 3091721c8378 -r 4b3487aa553c src/share/vm/runtime/mutexLocker.cpp +--- hotspot/src/share/vm/runtime/mutexLocker.cpp Sat Aug 24 00:14:46 2013 -0700 ++++ hotspot/src/share/vm/runtime/mutexLocker.cpp Thu Oct 17 19:28:00 2013 +0100 +@@ -134,12 +134,16 @@ + + Mutex* Management_lock = NULL; + Monitor* Service_lock = NULL; +-Mutex* Stacktrace_lock = NULL; ++Monitor* PeriodicTask_lock = NULL; + ++#ifdef INCLUDE_TRACE + Monitor* JfrQuery_lock = NULL; ++Mutex* JfrStacktrace_lock = NULL; + Monitor* JfrMsg_lock = NULL; + Mutex* JfrBuffer_lock = NULL; + Mutex* JfrStream_lock = NULL; ++Mutex* JfrThreadGroups_lock = NULL; ++#endif + + #define MAX_NUM_MUTEX 128 + static Monitor * _mutex_array[MAX_NUM_MUTEX]; +@@ -215,7 +219,6 @@ + def(Patching_lock , Mutex , special, true ); // used for safepointing and code patching. + def(ObjAllocPost_lock , Monitor, special, false); + def(Service_lock , Monitor, special, true ); // used for service thread operations +- def(Stacktrace_lock , Mutex, special, true ); // used for JFR stacktrace database + def(JmethodIdCreation_lock , Mutex , leaf, true ); // used for creating jmethodIDs. + + def(SystemDictionary_lock , Monitor, leaf, true ); // lookups done by VM thread +@@ -279,12 +282,18 @@ + def(Debug2_lock , Mutex , nonleaf+4, true ); + def(Debug3_lock , Mutex , nonleaf+4, true ); + def(ProfileVM_lock , Monitor, nonleaf+4, false); // used for profiling of the VMThread +- def(CompileThread_lock , Monitor, nonleaf+5, false ); ++ def(CompileThread_lock , Monitor, nonleaf+5, false); ++ def(PeriodicTask_lock , Monitor, nonleaf+5, true); + ++#ifdef INCLUDE_TRACE + def(JfrQuery_lock , Monitor, nonleaf, true); // JFR locks, keep these in consecutive order + def(JfrMsg_lock , Monitor, nonleaf+2, true); + def(JfrBuffer_lock , Mutex, nonleaf+3, true); ++ def(JfrThreadGroups_lock , Mutex, nonleaf+1, true); + def(JfrStream_lock , Mutex, nonleaf+4, true); ++ def(JfrStacktrace_lock , Mutex, special, true ); ++#endif ++ + } + + GCMutexLocker::GCMutexLocker(Monitor * mutex) { +diff -r 3091721c8378 -r 4b3487aa553c src/share/vm/runtime/mutexLocker.hpp +--- hotspot/src/share/vm/runtime/mutexLocker.hpp Sat Aug 24 00:14:46 2013 -0700 ++++ hotspot/src/share/vm/runtime/mutexLocker.hpp Thu Oct 17 19:28:00 2013 +0100 +@@ -136,12 +136,16 @@ + + extern Mutex* Management_lock; // a lock used to serialize JVM management + extern Monitor* Service_lock; // a lock used for service thread operation +-extern Mutex* Stacktrace_lock; // used to guard access to the stacktrace table ++extern Monitor* PeriodicTask_lock; // protects the periodic task structure + ++#ifdef INCLUDE_TRACE ++extern Mutex* JfrStacktrace_lock; // used to guard access to the JFR stacktrace table + extern Monitor* JfrQuery_lock; // protects JFR use + extern Monitor* JfrMsg_lock; // protects JFR messaging + extern Mutex* JfrBuffer_lock; // protects JFR buffer operations + extern Mutex* JfrStream_lock; // protects JFR stream access ++extern Mutex* JfrThreadGroups_lock; // protects JFR access to Thread Groups ++#endif + + // A MutexLocker provides mutual exclusion with respect to a given mutex + // for the scope which contains the locker. The lock is an OS lock, not diff --git a/java/openjdk6/files/icedtea/openjdk/8023478-hs_crash.patch b/java/openjdk6/files/icedtea/openjdk/8023478-hs_crash.patch new file mode 100644 index 000000000000..d9933779a949 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8023478-hs_crash.patch @@ -0,0 +1,21 @@ +# HG changeset patch +# User kevinw +# Date 1379364550 25200 +# Mon Sep 16 13:49:10 2013 -0700 +# Node ID e8d1979fe077eda9a94528c4b76dd4c5243d5dec +# Parent 2660219948088d89dd3fc285e093dab2520349e5 +8023478: Test fails with HS crash in GCNotifier. +Reviewed-by: sla + +diff -r 266021994808 -r e8d1979fe077 src/share/vm/services/gcNotifier.cpp +--- hotspot/src/share/vm/services/gcNotifier.cpp Fri Aug 02 12:26:46 2013 +0100 ++++ hotspot/src/share/vm/services/gcNotifier.cpp Mon Sep 16 13:49:10 2013 -0700 +@@ -209,7 +209,7 @@ + GCNotificationRequest *request = getRequest(); + if (request != NULL) { + NotificationMark nm(request); +- Handle objGcInfo = createGcInfo(request->gcManager, request->gcStatInfo, THREAD); ++ Handle objGcInfo = createGcInfo(request->gcManager, request->gcStatInfo, CHECK); + + Handle objName = java_lang_String::create_from_str(request->gcManager->name(), CHECK); + Handle objAction = java_lang_String::create_from_str(request->gcAction, CHECK); diff --git a/java/openjdk6/files/icedtea/openjdk/8023683-enhance_class_file_parsing.patch b/java/openjdk6/files/icedtea/openjdk/8023683-enhance_class_file_parsing.patch new file mode 100644 index 000000000000..6bd4199dea8c --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8023683-enhance_class_file_parsing.patch @@ -0,0 +1,35 @@ +# HG changeset patch +# User iklam +# Date 1377328486 25200 +# Sat Aug 24 00:14:46 2013 -0700 +# Node ID 3091721c83780cbb9a946f05007651e0bd09490b +# Parent bbd051c9089f61c65fe7d95487d47920164c7ee0 +8023683: Enhance class file parsing +Summary: Use the value returned by REALLOC_RESOURCE_ARRAY() +Reviewed-by: coleenp, ahgross + +diff -r bbd051c9089f -r 3091721c8378 src/share/vm/classfile/classFileParser.cpp +--- hotspot/src/share/vm/classfile/classFileParser.cpp Mon Jul 15 10:22:43 2013 +0400 ++++ hotspot/src/share/vm/classfile/classFileParser.cpp Sat Aug 24 00:14:46 2013 -0700 +@@ -1821,8 +1821,8 @@ + } + if (lvt_cnt == max_lvt_cnt) { + max_lvt_cnt <<= 1; +- REALLOC_RESOURCE_ARRAY(u2, localvariable_table_length, lvt_cnt, max_lvt_cnt); +- REALLOC_RESOURCE_ARRAY(u2*, localvariable_table_start, lvt_cnt, max_lvt_cnt); ++ localvariable_table_length = REALLOC_RESOURCE_ARRAY(u2, localvariable_table_length, lvt_cnt, max_lvt_cnt); ++ localvariable_table_start = REALLOC_RESOURCE_ARRAY(u2*, localvariable_table_start, lvt_cnt, max_lvt_cnt); + } + localvariable_table_start[lvt_cnt] = + parse_localvariable_table(code_length, +@@ -1851,8 +1851,8 @@ + // Parse local variable type table + if (lvtt_cnt == max_lvtt_cnt) { + max_lvtt_cnt <<= 1; +- REALLOC_RESOURCE_ARRAY(u2, localvariable_type_table_length, lvtt_cnt, max_lvtt_cnt); +- REALLOC_RESOURCE_ARRAY(u2*, localvariable_type_table_start, lvtt_cnt, max_lvtt_cnt); ++ localvariable_type_table_length = REALLOC_RESOURCE_ARRAY(u2, localvariable_type_table_length, lvtt_cnt, max_lvtt_cnt); ++ localvariable_type_table_start = REALLOC_RESOURCE_ARRAY(u2*, localvariable_type_table_start, lvtt_cnt, max_lvtt_cnt); + } + localvariable_type_table_start[lvtt_cnt] = + parse_localvariable_table(code_length, diff --git a/java/openjdk6/files/icedtea/openjdk/8023964-ignore_test.patch b/java/openjdk6/files/icedtea/openjdk/8023964-ignore_test.patch new file mode 100644 index 000000000000..89a6bb468e47 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8023964-ignore_test.patch @@ -0,0 +1,29 @@ +# HG changeset patch +# User coffeys +# Date 1378485490 25200 +# Fri Sep 06 09:38:10 2013 -0700 +# Node ID 44a49c18eba21f97222a2cde09f6536a7f365363 +# Parent 6c0b775b1ff2a0a0ba0fe797cfe18c511f9ee3c1 +8023964: java/io/IOException/LastErrorString.java should be @ignore-d +Reviewed-by: alanb + +diff -r 6c0b775b1ff2 -r 44a49c18eba2 test/java/io/IOException/LastErrorString.java +--- jdk/test/java/io/IOException/LastErrorString.java Fri Aug 09 13:50:13 2013 +0100 ++++ jdk/test/java/io/IOException/LastErrorString.java Fri Sep 06 09:38:10 2013 -0700 +@@ -1,5 +1,5 @@ + /* +- * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. ++ * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it +@@ -22,7 +22,8 @@ + */ + + /* @test +- @bug 4167937 ++ @bug 4167937 8023964 ++ @ignore Test truncates system files when run as root, see 7042603 + @summary Test code paths that use the JVM_LastErrorString procedure + */ + diff --git a/java/openjdk6/files/icedtea/openjdk/8024914-swapped_usage.patch b/java/openjdk6/files/icedtea/openjdk/8024914-swapped_usage.patch new file mode 100644 index 000000000000..29ace4855155 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8024914-swapped_usage.patch @@ -0,0 +1,58 @@ +# HG changeset patch +# User tschatzl +# Date 1379412251 -7200 +# Tue Sep 17 12:04:11 2013 +0200 +# Node ID d0b5dc55e72cde11331399cbb960458b8f45ea4a +# Parent 41d2a089e66401c8815af0c6b6efd2af9aeabe99 +8024914: Swapped usage of idx_t and bm_word_t types in bitMap.inline.hpp +Summary: Incorrect usage of idx_t where bm_word_t is appropriate. +Reviewed-by: tschatzl, brutisso +Contributed-by: Dan Horak <dhorak@redhat.com> + +diff -r 41d2a089e664 -r d0b5dc55e72c src/share/vm/utilities/bitMap.inline.hpp +--- hotspot/src/share/vm/utilities/bitMap.inline.hpp Fri Oct 04 12:22:34 2013 -0400 ++++ hotspot/src/share/vm/utilities/bitMap.inline.hpp Tue Sep 17 12:04:11 2013 +0200 +@@ -52,16 +52,16 @@ + + inline bool BitMap::par_set_bit(idx_t bit) { + verify_index(bit); +- volatile idx_t* const addr = word_addr(bit); +- const idx_t mask = bit_mask(bit); +- idx_t old_val = *addr; ++ volatile bm_word_t* const addr = word_addr(bit); ++ const bm_word_t mask = bit_mask(bit); ++ bm_word_t old_val = *addr; + + do { +- const idx_t new_val = old_val | mask; ++ const bm_word_t new_val = old_val | mask; + if (new_val == old_val) { + return false; // Someone else beat us to it. + } +- const idx_t cur_val = (idx_t) Atomic::cmpxchg_ptr((void*) new_val, ++ const bm_word_t cur_val = (bm_word_t) Atomic::cmpxchg_ptr((void*) new_val, + (volatile void*) addr, + (void*) old_val); + if (cur_val == old_val) { +@@ -73,16 +73,16 @@ + + inline bool BitMap::par_clear_bit(idx_t bit) { + verify_index(bit); +- volatile idx_t* const addr = word_addr(bit); +- const idx_t mask = ~bit_mask(bit); +- idx_t old_val = *addr; ++ volatile bm_word_t* const addr = word_addr(bit); ++ const bm_word_t mask = ~bit_mask(bit); ++ bm_word_t old_val = *addr; + + do { +- const idx_t new_val = old_val & mask; ++ const bm_word_t new_val = old_val & mask; + if (new_val == old_val) { + return false; // Someone else beat us to it. + } +- const idx_t cur_val = (idx_t) Atomic::cmpxchg_ptr((void*) new_val, ++ const bm_word_t cur_val = (bm_word_t) Atomic::cmpxchg_ptr((void*) new_val, + (volatile void*) addr, + (void*) old_val); + if (cur_val == old_val) { diff --git a/java/openjdk6/files/icedtea/openjdk/8025128-createtempfile_absolute_prefix.patch b/java/openjdk6/files/icedtea/openjdk/8025128-createtempfile_absolute_prefix.patch new file mode 100644 index 000000000000..d2acd0d22d1a --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/8025128-createtempfile_absolute_prefix.patch @@ -0,0 +1,139 @@ +# HG changeset patch +# User dxu +# Date 1383019831 0 +# Tue Oct 29 04:10:31 2013 +0000 +# Node ID 008e31b76d415f263617e710f19da6254135817f +# Parent 8459b68eb028734b2153266176538e1eddbb87be +8025128: File.createTempFile fails if prefix is absolute path +Reviewed-by: alanb, darcy + +diff -r 8459b68eb028 -r 008e31b76d41 src/share/classes/java/io/File.java +--- jdk/src/share/classes/java/io/File.java Tue Oct 29 03:49:40 2013 +0000 ++++ jdk/src/share/classes/java/io/File.java Tue Oct 29 04:10:31 2013 +0000 +@@ -1801,11 +1801,19 @@ + } else { + n = Math.abs(n); + } +- String name = prefix + Long.toString(n) + suffix; +- File f = new File(dir, name); +- if (!name.equals(f.getName())) +- throw new IOException("Unable to create temporary file"); +- return f; ++ ++ // Use only the file name from the supplied prefix ++ prefix = (new File(prefix)).getName(); ++ ++ String name = prefix + Long.toString(n) + suffix; ++ File f = new File(dir, name); ++ if (!name.equals(f.getName())) { ++ if (System.getSecurityManager() != null) ++ throw new IOException("Unable to create temporary file"); ++ else ++ throw new IOException("Unable to create temporary file, " + f); ++ } ++ return f; + } + + private static boolean checkAndCreate(String filename, SecurityManager sm, +diff -r 8459b68eb028 -r 008e31b76d41 test/java/io/File/createTempFile/SpecialTempFile.java +--- jdk/test/java/io/File/createTempFile/SpecialTempFile.java Tue Oct 29 03:49:40 2013 +0000 ++++ jdk/test/java/io/File/createTempFile/SpecialTempFile.java Tue Oct 29 04:10:31 2013 +0000 +@@ -23,7 +23,7 @@ + + /* + * @test +- * @bug 8013827 8011950 ++ * @bug 8013827 8011950 8025128 + * @summary Check whether File.createTempFile can handle special parameters + * on Windows platforms + * @author Dan Xu +@@ -34,7 +34,9 @@ + + public class SpecialTempFile { + +- private static void test(String name, String[] prefix, String[] suffix) { ++ private static void test(String name, String[] prefix, String[] suffix, ++ boolean expectedException) throws IOException ++ { + if (prefix == null || suffix == null + || prefix.length != suffix.length) + { +@@ -42,39 +44,59 @@ + } + + final String exceptionMsg = "Unable to create temporary file"; +- final String errMsg = "IOException is expected"; + + for (int i = 0; i < prefix.length; i++) { + boolean exceptionThrown = false; + File f = null; +- System.out.println("In test " + name +- + ", creating temp file with prefix, " +- + prefix[i] + ", suffix, " + suffix[i]); +- try { +- f = File.createTempFile(prefix[i], suffix[i]); +- } catch (IOException e) { +- if (exceptionMsg.equals(e.getMessage())) +- exceptionThrown = true; +- else +- System.out.println("Wrong error message:" + e.getMessage()); ++ ++ String[] dirs = { null, "." }; ++ ++ for (String dir : dirs ) { ++ System.out.println("In test " + name + ++ ", creating temp file with prefix, " + ++ prefix[i] + ", suffix, " + suffix[i] + ++ ", in dir, " + dir); ++ ++ try { ++ if (dir == null || dir.isEmpty()) ++ f = File.createTempFile(prefix[i], suffix[i]); ++ else ++ f = File.createTempFile(prefix[i], suffix[i], new File(dir)); ++ } catch (IOException e) { ++ if (expectedException) { ++ if (e.getMessage().startsWith(exceptionMsg)) ++ exceptionThrown = true; ++ else ++ System.out.println("Wrong error message:" + ++ e.getMessage()); ++ } else { ++ throw e; ++ } ++ } ++ ++ if (expectedException && (!exceptionThrown || f != null)) ++ throw new RuntimeException("IOException is expected"); + } +- if (!exceptionThrown || f != null) +- throw new RuntimeException(errMsg); + } + } + + public static void main(String[] args) throws Exception { ++ // Test JDK-8025128 ++ String[] goodPre = { "///..///", "/foo" }; ++ String[] goodSuf = { ".temp", ".tmp" }; ++ test("goodName", goodPre, goodSuf, false); ++ ++ // Test JDK-8011950 ++ String[] slashPre = { "temp", "///..///", "/foo" }; ++ String[] slashSuf = { "///..///..", "///..///..", "///..///.." }; ++ test("SlashedName", slashPre, slashSuf, true); ++ + if (!System.getProperty("os.name").startsWith("Windows")) + return; + + // Test JDK-8013827 + String[] resvPre = { "LPT1.package.zip", "com7.4.package.zip" }; + String[] resvSuf = { ".temp", ".temp" }; +- test("ReservedName", resvPre, resvSuf); +- +- // Test JDK-8011950 +- String[] slashPre = { "///..///", "temp", "///..///" }; +- String[] slashSuf = { ".temp", "///..///..", "///..///.." }; +- test("SlashedName", slashPre, slashSuf); ++ test("ReservedName", resvPre, resvSuf, true); + } + } diff --git a/java/openjdk6/files/icedtea/openjdk/oj6-19-fix_8010118_test_cases.patch b/java/openjdk6/files/icedtea/openjdk/oj6-19-fix_8010118_test_cases.patch new file mode 100644 index 000000000000..313097b8600c --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/oj6-19-fix_8010118_test_cases.patch @@ -0,0 +1,499 @@ +# HG changeset patch +# User andrew +# Date 1382719863 -3600 +# Fri Oct 25 17:51:03 2013 +0100 +# Node ID d4fca2113b280a7db03b67caae22e0ceafb51b89 +# Parent 566f427de7079a0ed32c2f625c952dcc45c348e3 +OPENJDK6-19: Fix test cases from 8010118 to work with OpenJDK 6 +Reviewed-by: omajid + +diff -r 566f427de707 -r d4fca2113b28 test/sun/reflect/CallerSensitive/CallerSensitiveFinder.java +--- jdk/test/sun/reflect/CallerSensitive/CallerSensitiveFinder.java Tue Jun 03 13:28:16 2008 -0700 ++++ jdk/test/sun/reflect/CallerSensitive/CallerSensitiveFinder.java Fri Oct 25 17:51:03 2013 +0100 +@@ -23,16 +23,12 @@ + + import com.sun.tools.classfile.*; + import static com.sun.tools.classfile.ConstantPool.*; ++ + import java.io.File; + import java.io.IOException; + import java.lang.reflect.InvocationTargetException; +-import java.nio.file.FileVisitResult; +-import java.nio.file.Files; +-import java.nio.file.Path; +-import java.nio.file.Paths; +-import java.nio.file.SimpleFileVisitor; +-import java.nio.file.attribute.BasicFileAttributes; + import java.util.ArrayList; ++import java.util.Arrays; + import java.util.List; + import java.util.Set; + import java.util.concurrent.Callable; +@@ -53,7 +49,7 @@ + private static int numThreads = 3; + private static boolean verbose = false; + public static void main(String[] args) throws Exception { +- List<Path> classes = new ArrayList<>(); ++ List<File> classes = new ArrayList<File>(); + String testclasses = System.getProperty("test.classes", "."); + int i = 0; + while (i < args.length) { +@@ -61,11 +57,11 @@ + if (arg.equals("-v")) { + verbose = true; + } else { +- Path p = Paths.get(testclasses, arg); +- if (!p.toFile().exists()) { ++ File f = new File(testclasses, arg); ++ if (!f.exists()) { + throw new IllegalArgumentException(arg + " does not exist"); + } +- classes.add(p); ++ classes.add(f); + } + } + if (classes.isEmpty()) { +@@ -81,7 +77,7 @@ + } + } + +- private final List<String> csMethodsMissingAnnotation = new ArrayList<>(); ++ private final List<String> csMethodsMissingAnnotation = new ArrayList<String>(); + private final java.lang.reflect.Method mhnCallerSensitiveMethod; + public CallerSensitiveFinder(String... methods) throws Exception { + super(methods); +@@ -91,12 +87,114 @@ + static java.lang.reflect.Method getIsCallerSensitiveMethod() + throws ClassNotFoundException, NoSuchMethodException + { +- Class<?> cls = Class.forName("java.lang.invoke.MethodHandleNatives"); ++ Class<?> cls = CallerSensitiveFinder.class; + java.lang.reflect.Method m = cls.getDeclaredMethod("isCallerSensitiveMethod", Class.class, String.class); + m.setAccessible(true); + return m; + } + ++ // Needs to match method in 7's java.lang.invoke.MethodHandleNatives ++ private static boolean isCallerSensitiveMethod(Class<?> defc, String method) { ++ if ("doPrivileged".equals(method) || ++ "doPrivilegedWithCombiner".equals(method)) ++ return defc == java.security.AccessController.class; ++ else if ("checkMemberAccess".equals(method)) ++ return defc == java.lang.SecurityManager.class; ++ else if ("getUnsafe".equals(method)) ++ return defc == sun.misc.Unsafe.class; ++ else if ("invoke".equals(method)) ++ return defc == java.lang.reflect.Method.class; ++ else if ("get".equals(method) || ++ "getBoolean".equals(method) || ++ "getByte".equals(method) || ++ "getChar".equals(method) || ++ "getShort".equals(method) || ++ "getInt".equals(method) || ++ "getLong".equals(method) || ++ "getFloat".equals(method) || ++ "getDouble".equals(method) || ++ "set".equals(method) || ++ "setBoolean".equals(method) || ++ "setByte".equals(method) || ++ "setChar".equals(method) || ++ "setShort".equals(method) || ++ "setInt".equals(method) || ++ "setLong".equals(method) || ++ "setFloat".equals(method) || ++ "setDouble".equals(method)) ++ return defc == java.lang.reflect.Field.class; ++ else if ("newInstance".equals(method)) { ++ if (defc == java.lang.reflect.Constructor.class) return true; ++ if (defc == java.lang.Class.class) return true; ++ } else if ("getFields".equals(method)) ++ return defc == java.lang.Class.class || ++ defc == javax.sql.rowset.serial.SerialJavaObject.class; ++ else if ("forName".equals(method) || ++ "getClassLoader".equals(method) || ++ "getClasses".equals(method) || ++ "getMethods".equals(method) || ++ "getConstructors".equals(method) || ++ "getDeclaredClasses".equals(method) || ++ "getDeclaredFields".equals(method) || ++ "getDeclaredMethods".equals(method) || ++ "getDeclaredConstructors".equals(method) || ++ "getField".equals(method) || ++ "getMethod".equals(method) || ++ "getConstructor".equals(method) || ++ "getDeclaredField".equals(method) || ++ "getDeclaredMethod".equals(method) || ++ "getDeclaredConstructor".equals(method) || ++ "getDeclaringClass".equals(method) || ++ "getEnclosingClass".equals(method) || ++ "getEnclosingMethod".equals(method) || ++ "getEnclosingConstructor".equals(method)) ++ return defc == java.lang.Class.class; ++ else if ("getConnection".equals(method) || ++ "getDriver".equals(method) || ++ "getDrivers".equals(method) || ++ "deregisterDriver".equals(method)) ++ return defc == java.sql.DriverManager.class; ++ else if ("newUpdater".equals(method)) { ++ if (defc == java.util.concurrent.atomic.AtomicIntegerFieldUpdater.class) return true; ++ if (defc == java.util.concurrent.atomic.AtomicLongFieldUpdater.class) return true; ++ if (defc == java.util.concurrent.atomic.AtomicReferenceFieldUpdater.class) return true; ++ } else if ("getContextClassLoader".equals(method)) ++ return defc == java.lang.Thread.class; ++ else if ("getPackage".equals(method) || ++ "getPackages".equals(method)) ++ return defc == java.lang.Package.class; ++ else if ("getParent".equals(method) || ++ "getSystemClassLoader".equals(method)) ++ return defc == java.lang.ClassLoader.class; ++ else if ("load".equals(method) || ++ "loadLibrary".equals(method)) { ++ if (defc == java.lang.Runtime.class) return true; ++ if (defc == java.lang.System.class) return true; ++ } else if ("getCallerClass".equals(method)) { ++ if (defc == sun.reflect.Reflection.class) return true; ++ if (defc == java.lang.System.class) return true; ++ } else if ("getCallerClassLoader".equals(method)) ++ return defc == java.lang.ClassLoader.class; ++ else if ("registerAsParallelCapable".equals(method)) ++ return defc == java.lang.ClassLoader.class; ++ else if ("getInvocationHandler".equals(method) || ++ "getProxyClass".equals(method) || ++ "newProxyInstance".equals(method)) ++ return defc == java.lang.reflect.Proxy.class; ++ else if ("getBundle".equals(method) || ++ "clearCache".equals(method)) ++ return defc == java.util.ResourceBundle.class; ++ else if ("getType".equals(method)) ++ return defc == java.io.ObjectStreamField.class; ++ else if ("forClass".equals(method)) ++ return defc == java.io.ObjectStreamClass.class; ++ else if ("getLogger".equals(method)) ++ return defc == java.util.logging.Logger.class; ++ else if ("getAnonymousLogger".equals(method)) ++ return defc == java.util.logging.Logger.class; ++ return false; ++ } ++ + boolean inMethodHandlesList(String classname, String method) { + Class<?> cls; + try { +@@ -104,19 +202,21 @@ + false, + ClassLoader.getSystemClassLoader()); + return (Boolean) mhnCallerSensitiveMethod.invoke(null, cls, method); +- } catch (ClassNotFoundException|IllegalAccessException e) { ++ } catch (ClassNotFoundException e) { ++ throw new RuntimeException(e); ++ } catch (IllegalAccessException e) { + throw new RuntimeException(e); + } catch (InvocationTargetException e) { + throw new RuntimeException(e.getCause()); + } + } + +- public List<String> run(List<Path> classes) throws IOException, InterruptedException, ++ public List<String> run(List<File> classes) throws IOException, InterruptedException, + ExecutionException, ConstantPoolException + { + ExecutorService pool = Executors.newFixedThreadPool(numThreads); +- for (Path path : classes) { +- ClassFileReader reader = ClassFileReader.newInstance(path.toFile()); ++ for (File path : classes) { ++ ClassFileReader reader = ClassFileReader.newInstance(path); + for (ClassFile cf : reader.getClassFiles()) { + String classFileName = cf.getName(); + // for each ClassFile +@@ -192,56 +292,46 @@ + } + + static class PlatformClassPath { +- static List<Path> getJREClasses() throws IOException { +- List<Path> result = new ArrayList<Path>(); +- Path home = Paths.get(System.getProperty("java.home")); ++ static List<File> getJREClasses() throws IOException { ++ List<File> result = new ArrayList<File>(); ++ File home = new File(System.getProperty("java.home")); + +- if (home.endsWith("jre")) { ++ if (home.toString().endsWith("jre")) { + // jar files in <javahome>/jre/lib + // skip <javahome>/lib +- result.addAll(addJarFiles(home.resolve("lib"))); +- } else if (home.resolve("lib").toFile().exists()) { ++ result.addAll(addJarFiles(new File(home, "lib"))); ++ } else if (new File(home, "lib").exists()) { + // either a JRE or a jdk build image +- File classes = home.resolve("classes").toFile(); ++ File classes = new File(home, "classes"); + if (classes.exists() && classes.isDirectory()) { + // jdk build outputdir +- result.add(classes.toPath()); ++ result.add(classes); + } + // add other JAR files +- result.addAll(addJarFiles(home.resolve("lib"))); ++ result.addAll(addJarFiles(new File(home, "lib"))); + } else { + throw new RuntimeException("\"" + home + "\" not a JDK home"); + } + return result; + } + +- static List<Path> addJarFiles(final Path root) throws IOException { +- final List<Path> result = new ArrayList<Path>(); +- final Path ext = root.resolve("ext"); +- Files.walkFileTree(root, new SimpleFileVisitor<Path>() { +- @Override +- public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) +- throws IOException { +- if (dir.equals(root) || dir.equals(ext)) { +- return FileVisitResult.CONTINUE; +- } else { +- // skip other cobundled JAR files +- return FileVisitResult.SKIP_SUBTREE; +- } +- } +- +- @Override +- public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) +- throws IOException { +- File f = file.toFile(); ++ static List<File> addJarFiles(final File root) throws IOException { ++ final List<File> result = new ArrayList<File>(); ++ final File ext = new File(root, "ext"); ++ final List<File> files = new ArrayList<File>(); ++ for (String s : root.list()) ++ files.add(new File(root, s)); ++ for (String s : ext.list()) ++ files.add(new File(ext, s)); ++ for (File f : files) { ++ if (f.isFile()) { + String fn = f.getName(); + // parse alt-rt.jar as well + if (fn.endsWith(".jar") && !fn.equals("jfxrt.jar")) { +- result.add(file); ++ result.add(f); + } +- return FileVisitResult.CONTINUE; + } +- }); ++ } + return result; + } + } +diff -r 566f427de707 -r d4fca2113b28 test/sun/reflect/CallerSensitive/ClassFileReader.java +--- jdk/test/sun/reflect/CallerSensitive/ClassFileReader.java Tue Jun 03 13:28:16 2008 -0700 ++++ jdk/test/sun/reflect/CallerSensitive/ClassFileReader.java Fri Oct 25 17:51:03 2013 +0100 +@@ -23,12 +23,8 @@ + + import com.sun.tools.classfile.ClassFile; + import com.sun.tools.classfile.ConstantPoolException; ++ + import java.io.*; +-import java.nio.file.FileVisitResult; +-import java.nio.file.Files; +-import java.nio.file.Path; +-import java.nio.file.SimpleFileVisitor; +-import java.nio.file.attribute.BasicFileAttributes; + import java.util.*; + import java.util.jar.JarEntry; + import java.util.jar.JarFile; +@@ -47,28 +43,28 @@ + } + + if (path.isDirectory()) { +- return new DirectoryReader(path.toPath()); ++ return new DirectoryReader(path); + } else if (path.getName().endsWith(".jar")) { +- return new JarFileReader(path.toPath()); ++ return new JarFileReader(path); + } else { +- return new ClassFileReader(path.toPath()); ++ return new ClassFileReader(path); + } + } + + /** + * Returns a ClassFileReader instance of a given JarFile. + */ +- public static ClassFileReader newInstance(Path path, JarFile jf) throws IOException { ++ public static ClassFileReader newInstance(File path, JarFile jf) throws IOException { + return new JarFileReader(path, jf); + } + +- protected final Path path; ++ protected final File path; + protected final String baseFileName; +- private ClassFileReader(Path path) { ++ private ClassFileReader(File path) { + this.path = path; +- this.baseFileName = path.getFileName() != null +- ? path.getFileName().toString() +- : path.toString(); ++ this.baseFileName = path.getName().equals("") ++ ? path.toString() ++ : path.getName(); + } + + public String getFileName() { +@@ -104,10 +100,10 @@ + }; + } + +- protected ClassFile readClassFile(Path p) throws IOException { ++ protected ClassFile readClassFile(File p) throws IOException { + InputStream is = null; + try { +- is = Files.newInputStream(p); ++ is = new FileInputStream(p); + return ClassFile.read(is); + } catch (ConstantPoolException e) { + throw new ClassFileError(e); +@@ -150,7 +146,7 @@ + } + + private static class DirectoryReader extends ClassFileReader { +- DirectoryReader(Path path) throws IOException { ++ DirectoryReader(File path) throws IOException { + super(path); + } + +@@ -158,17 +154,17 @@ + if (name.indexOf('.') > 0) { + int i = name.lastIndexOf('.'); + String pathname = name.replace('.', File.separatorChar) + ".class"; +- Path p = path.resolve(pathname); +- if (!p.toFile().exists()) { +- p = path.resolve(pathname.substring(0, i) + "$" + +- pathname.substring(i+1, pathname.length())); ++ File p = new File(path, pathname); ++ if (!p.exists()) { ++ p = new File(path, pathname.substring(0, i) + "$" + ++ pathname.substring(i+1, pathname.length())); + } +- if (p.toFile().exists()) { ++ if (p.exists()) { + return readClassFile(p); + } + } else { +- Path p = path.resolve(name + ".class"); +- if (p.toFile().exists()) { ++ File p = new File(path, name + ".class"); ++ if (p.exists()) { + return readClassFile(p); + } + } +@@ -184,22 +180,24 @@ + }; + } + +- private List<Path> walkTree(Path dir) throws IOException { +- final List<Path> files = new ArrayList<Path>(); +- Files.walkFileTree(dir, new SimpleFileVisitor<Path>() { +- public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) +- throws IOException { +- if (file.toFile().getName().endsWith(".class")) { +- files.add(file); ++ private List<File> walkTree(File dir) throws IOException { ++ final List<File> files = new ArrayList<File>(); ++ final List<String> dirContents = Arrays.asList(dir.list()); ++ for (String file : dirContents) { ++ File f = new File(dir, file); ++ if (f.isDirectory()) ++ files.addAll(walkTree(f)); ++ else { ++ if (f.getName().endsWith(".class")) { ++ files.add(f); + } +- return FileVisitResult.CONTINUE; + } +- }); ++ } + return files; + } + + class DirectoryIterator implements Iterator<ClassFile> { +- private List<Path> entries; ++ private List<File> entries; + private int index = 0; + DirectoryIterator() throws IOException { + entries = walkTree(path); +@@ -214,7 +212,7 @@ + if (!hasNext()) { + throw new NoSuchElementException(); + } +- Path path = entries.get(index++); ++ File path = entries.get(index++); + try { + return readClassFile(path); + } catch (IOException e) { +@@ -230,10 +228,10 @@ + + private static class JarFileReader extends ClassFileReader { + final JarFile jarfile; +- JarFileReader(Path path) throws IOException { +- this(path, new JarFile(path.toFile())); ++ JarFileReader(File path) throws IOException { ++ this(path, new JarFile(path)); + } +- JarFileReader(Path path, JarFile jf) throws IOException { ++ JarFileReader(File path, JarFile jf) throws IOException { + super(path); + this.jarfile = jf; + } +diff -r 566f427de707 -r d4fca2113b28 test/sun/reflect/CallerSensitive/MethodFinder.java +--- jdk/test/sun/reflect/CallerSensitive/MethodFinder.java Tue Jun 03 13:28:16 2008 -0700 ++++ jdk/test/sun/reflect/CallerSensitive/MethodFinder.java Fri Oct 25 17:51:03 2013 +0100 +@@ -121,10 +121,6 @@ + return false; + } + +- public Boolean visitInvokeDynamic(CONSTANT_InvokeDynamic_info info, Void p) { +- return false; +- } +- + public Boolean visitLong(CONSTANT_Long_info info, Void p) { + return false; + } +@@ -133,14 +129,6 @@ + return false; + } + +- public Boolean visitMethodHandle(CONSTANT_MethodHandle_info info, Void p) { +- return false; +- } +- +- public Boolean visitMethodType(CONSTANT_MethodType_info info, Void p) { +- return false; +- } +- + public Boolean visitString(CONSTANT_String_info info, Void p) { + return false; + } +@@ -198,4 +186,3 @@ + } + }; + } +- +diff -r 566f427de707 -r d4fca2113b28 test/sun/reflect/CallerSensitive/MissingCallerSensitive.java +--- jdk/test/sun/reflect/CallerSensitive/MissingCallerSensitive.java Tue Jun 03 13:28:16 2008 -0700 ++++ jdk/test/sun/reflect/CallerSensitive/MissingCallerSensitive.java Fri Oct 25 17:51:03 2013 +0100 +@@ -30,14 +30,13 @@ + * @run main/othervm MissingCallerSensitive + */ + +-import java.nio.file.Path; +-import java.nio.file.Paths; ++import java.io.File; + import java.util.*; + public class MissingCallerSensitive { + public static void main(String[] args) throws Exception { + String testclasses = System.getProperty("test.classes", "."); +- List<Path> classes = new ArrayList<>(); +- classes.add(Paths.get(testclasses, "MissingCallerSensitive.class")); ++ List<File> classes = new ArrayList<File>(); ++ classes.add(new File(testclasses, "MissingCallerSensitive.class")); + + final String method = "sun/reflect/Reflection.getCallerClass"; + CallerSensitiveFinder csfinder = new CallerSensitiveFinder(method); diff --git a/java/openjdk6/files/icedtea/openjdk/oj6-20-merge.patch b/java/openjdk6/files/icedtea/openjdk/oj6-20-merge.patch new file mode 100644 index 000000000000..e689c33d8a9f --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/oj6-20-merge.patch @@ -0,0 +1,599 @@ +# HG changeset patch +# User andrew +# Date 1383034761 0 +# Tue Oct 29 08:19:21 2013 +0000 +# Node ID 05c35de6d7047c6d6d6e8edc402b7fab861d0a21 +# Parent efb24af909a020f3a3b3d446f6db15fc8b1c309a +OPENJDK6-20: Resolve merge issues with JAXP security fixes +Reviewed-by: omajid + +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java Tue Oct 29 08:19:21 2013 +0000 +@@ -157,6 +157,25 @@ + } + + /** ++ * Return allowed protocols for accessing external stylesheet. ++ */ ++ public Object getProperty(String name) { ++ if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ return _xmlSecurityManager; ++ } ++ return null; ++ } ++ ++ /** ++ * Set allowed protocols for accessing external stylesheet. ++ */ ++ public void setProperty(String name, Object value) { ++ if (name.equals(XalanConstants.SECURITY_MANAGER)) { ++ _xmlSecurityManager = (XMLSecurityManager)value; ++ } ++ } ++ ++ /** + * Only for user by the internal TrAX implementation. + */ + public Parser getParser() { +@@ -901,23 +920,4 @@ + return newDataOffset; + } + +- /** +- * Return allowed protocols for accessing external stylesheet. +- */ +- public Object getProperty(String name) { +- if (name.equals(XalanConstants.SECURITY_MANAGER)) { +- return _xmlSecurityManager; +- } +- return null; +- } +- +- /** +- * Set allowed protocols for accessing external stylesheet. +- */ +- public void setProperty(String name, Object value) { +- if (name.equals(XalanConstants.SECURITY_MANAGER)) { +- _xmlSecurityManager = (XMLSecurityManager)value; +- } +- } +- + } +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerFactoryImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerFactoryImpl.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xalan/internal/xsltc/trax/TransformerFactoryImpl.java Tue Oct 29 08:19:21 2013 +0000 +@@ -283,6 +283,14 @@ + } else if (name.equals(XalanConstants.SECURITY_MANAGER)) { + return _xmlSecurityManager; + } ++ ++ /** Check to see if the property is managed by the security manager **/ ++ String propertyValue = (_xmlSecurityManager != null) ? ++ _xmlSecurityManager.getLimitAsString(name) : null; ++ if (propertyValue != null) { ++ return propertyValue; ++ } ++ + // Throw an exception for all other attributes + ErrorMsg err = new ErrorMsg(ErrorMsg.JAXP_INVALID_ATTR_ERR, name); + throw new IllegalArgumentException(err.toString()); +@@ -383,6 +391,11 @@ + } + } + ++ if (_xmlSecurityManager != null && ++ _xmlSecurityManager.setLimit(name, XMLSecurityManager.State.APIPROPERTY, value)) { ++ return; ++ } ++ + // Throw an exception for all other attributes + final ErrorMsg err + = new ErrorMsg(ErrorMsg.JAXP_INVALID_ATTR_ERR, name); +@@ -856,7 +869,13 @@ + } else { + err = new ErrorMsg(ErrorMsg.JAXP_COMPILE_ERR); + } +- TransformerConfigurationException exc = new TransformerConfigurationException(err.toString(), err.getCause()); ++ Throwable cause = err.getCause(); ++ TransformerConfigurationException exc; ++ if (cause != null) { ++ exc = new TransformerConfigurationException(cause.getMessage(), cause); ++ } else { ++ exc = new TransformerConfigurationException(err.toString()); ++ } + + // Pass compiler errors to the error listener + if (_errorListener != null) { +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/impl/PropertyManager.java Tue Oct 29 08:19:21 2013 +0000 +@@ -179,6 +179,13 @@ + return; + } + ++ //check if the property is managed by security manager ++ if (fSecurityManager == null || ++ !fSecurityManager.setLimit(property, XMLSecurityManager.State.APIPROPERTY, value)) { ++ //fall back to the existing property manager ++ supportedProps.put(property, value); ++ } ++ + supportedProps.put(property, value ) ; + if(equivalentProperty != null){ + supportedProps.put(equivalentProperty, value ) ; +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderFactoryImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderFactoryImpl.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderFactoryImpl.java Tue Oct 29 08:19:21 2013 +0000 +@@ -191,6 +191,9 @@ + + public void setFeature(String name, boolean value) + throws ParserConfigurationException { ++ if (features == null) { ++ features = new Hashtable(); ++ } + // If this is the secure processing feature, save it then return. + if (name.equals(XMLConstants.FEATURE_SECURE_PROCESSING)) { + if (System.getSecurityManager() != null && (!value)) { +@@ -199,11 +202,10 @@ + "jaxp-secureprocessing-feature", null)); + } + fSecureProcess = value; ++ features.put(name, value ? Boolean.TRUE : Boolean.FALSE); + return; + } +- if (features == null) { +- features = new Hashtable(); +- } ++ + features.put(name, value ? Boolean.TRUE : Boolean.FALSE); + // Test the feature by possibly throwing SAX exceptions + try { +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/DocumentBuilderImpl.java Tue Oct 29 08:19:21 2013 +0000 +@@ -253,12 +253,16 @@ + } + } + } else { +- // Let Xerces code handle the property +- domParser.setProperty(name, val); +- } +- } ++ //check if the property is managed by security manager ++ if (fSecurityManager == null || ++ !fSecurityManager.setLimit(name, XMLSecurityManager.State.APIPROPERTY, val)) { ++ //fall back to the existing property manager ++ domParser.setProperty(name, val); ++ } + } ++ } + } ++ } + + /** + * Non-preferred: use the getDOMImplementation() method instead of this +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserFactoryImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserFactoryImpl.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserFactoryImpl.java Tue Oct 29 08:19:21 2013 +0000 +@@ -124,6 +124,7 @@ + "jaxp-secureprocessing-feature", null)); + } + fSecureProcess = value; ++ putInFeatures(name, value); + return; + } + +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/SAXParserImpl.java Tue Oct 29 08:19:21 2013 +0000 +@@ -344,8 +344,10 @@ + fSecurityManager = new XMLSecurityManager(true); + try { + super.setProperty(SECURITY_MANAGER, fSecurityManager); +- } catch (Exception ex) { +- //shall not happen ++ } catch (SAXException e) { ++ throw new UnsupportedOperationException( ++ SAXMessageFormatter.formatMessage(fConfiguration.getLocale(), ++ "property-not-recognized", new Object [] {SECURITY_MANAGER}), e); + } + } + } +@@ -475,14 +477,21 @@ + return; + } + } +- if (!fInitProperties.containsKey(name)) { +- fInitProperties.put(name, super.getProperty(name)); +- } + /** Forward property to the schema validator if there is one. **/ + if (fSAXParser != null && fSAXParser.fSchemaValidator != null) { + setSchemaValidatorProperty(name, value); + } +- super.setProperty(name, value); ++ ++ //check if the property is managed by security manager ++ if (fSecurityManager == null || ++ !fSecurityManager.setLimit(name, XMLSecurityManager.State.APIPROPERTY, value)) { ++ //fall back to the existing property manager ++ if (!fInitProperties.containsKey(name)) { ++ fInitProperties.put(name, super.getProperty(name)); ++ } ++ super.setProperty(name, value); ++ } ++ + } + + public synchronized Object getProperty(String name) +@@ -495,6 +504,14 @@ + // JAXP 1.2 support + return fSAXParser.schemaLanguage; + } ++ ++ /** Check to see if the property is managed by the security manager **/ ++ String propertyValue = (fSecurityManager != null) ? ++ fSecurityManager.getLimitAsString(name) : null; ++ if (propertyValue != null) { ++ return propertyValue; ++ } ++ + return super.getProperty(name); + } + +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/AbstractXMLSchema.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/AbstractXMLSchema.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/AbstractXMLSchema.java Tue Oct 29 08:19:21 2013 +0000 +@@ -85,8 +85,7 @@ + /* + * Other methods + */ +- +- final void setFeature(String featureId, boolean state) { ++ public final void setFeature(String featureId, boolean state) { + fFeatures.put(featureId, state ? Boolean.TRUE : Boolean.FALSE); + } + +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaFactory.java Tue Oct 29 08:19:21 2013 +0000 +@@ -239,6 +239,7 @@ + else { + schema = new EmptyXMLSchema(); + } ++ propagateProperties(schema); + propagateFeatures(schema); + return schema; + } +@@ -247,6 +248,7 @@ + // Use a Schema that uses the system id as the equality source. + AbstractXMLSchema schema = new WeakReferenceXMLSchema(); + propagateFeatures(schema); ++ propagateProperties(schema); + return schema; + } + +@@ -322,7 +324,6 @@ + "jaxp-secureprocessing-feature", null)); + } + +- fSecurityManager = value ? new XMLSecurityManager() : null; + fSecurityManager.setSecureProcessing(value); + fXMLSchemaLoader.setProperty(SECURITY_MANAGER, fSecurityManager); + return; +@@ -362,7 +363,12 @@ + "property-not-supported", new Object [] {name})); + } + try { +- fXMLSchemaLoader.setProperty(name, object); ++ //check if the property is managed by security manager ++ if (fSecurityManager == null || ++ !fSecurityManager.setLimit(name, XMLSecurityManager.State.APIPROPERTY, object)) { ++ //fall back to the existing property manager ++ fXMLSchemaLoader.setProperty(name, object); ++ } + } + catch (XMLConfigurationException e) { + String identifier = e.getIdentifier(); +@@ -388,6 +394,15 @@ + } + } + ++ private void propagateProperties(AbstractXMLSchema schema) { ++ String[] properties = fXMLSchemaLoader.getRecognizedProperties(); ++ for (int i = 0; i < properties.length; ++i) { ++ Object state = fXMLSchemaLoader.getProperty(properties[i]); ++ schema.setProperty(properties[i], state); ++ } ++ } ++ ++ + /** + * Extension of XMLGrammarPoolImpl which exposes the number of + * grammars stored in the grammar pool. +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/jaxp/validation/XMLSchemaValidatorComponentManager.java Tue Oct 29 08:19:21 2013 +0000 +@@ -368,11 +368,15 @@ + return; + } + +- //fall back to the existing property manager +- if (!fInitProperties.containsKey(propertyId)) { +- fInitProperties.put(propertyId, super.getProperty(propertyId)); ++ //check if the property is managed by security manager ++ if (fInitSecurityManager == null || ++ !fInitSecurityManager.setLimit(propertyId, XMLSecurityManager.State.APIPROPERTY, value)) { ++ //fall back to the existing property manager ++ if (!fInitProperties.containsKey(propertyId)) { ++ fInitProperties.put(propertyId, super.getProperty(propertyId)); ++ } ++ super.setProperty(propertyId, value); + } +- super.setProperty(propertyId, value); + } + + /** +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java +--- jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java Tue Oct 29 08:11:44 2013 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/parsers/SAXParser.java Tue Oct 29 08:19:21 2013 +0000 +@@ -25,6 +25,8 @@ + import com.sun.org.apache.xerces.internal.utils.XMLSecurityManager; + import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarPool; + import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration; ++import org.xml.sax.SAXNotRecognizedException; ++import org.xml.sax.SAXNotSupportedException; + + /** + * This is the main Xerces SAX parser class. It uses the abstract SAX +@@ -125,4 +127,31 @@ + + } // <init>(SymbolTable,XMLGrammarPool) + ++ /** ++ * Sets the particular property in the underlying implementation of ++ * org.xml.sax.XMLReader. ++ */ ++ public void setProperty(String name, Object value) ++ throws SAXNotRecognizedException, SAXNotSupportedException { ++ /** ++ * It's possible for users to set a security manager through the interface. ++ * If it's the old SecurityManager, convert it to the new XMLSecurityManager ++ */ ++ if (name.equals(Constants.SECURITY_MANAGER)) { ++ securityManager = XMLSecurityManager.convert(value, securityManager); ++ super.setProperty(Constants.SECURITY_MANAGER, securityManager); ++ return; ++ } ++ ++ if (securityManager == null) { ++ securityManager = new XMLSecurityManager(true); ++ super.setProperty(Constants.SECURITY_MANAGER, securityManager); ++ } ++ ++ //check if the property is managed by security manager ++ if (!securityManager.setLimit(name, XMLSecurityManager.State.APIPROPERTY, value)) { ++ //fall back to the default configuration to handle the property ++ super.setProperty(name, value); ++ } ++ } + } // class SAXParser +diff -r efb24af909a0 -r 05c35de6d704 drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SecurityManager.java +--- /dev/null Thu Jan 01 00:00:00 1970 +0000 ++++ jaxp/drop_included/jaxp_src/src/com/sun/org/apache/xerces/internal/util/SecurityManager.java Tue Oct 29 08:19:21 2013 +0000 +@@ -0,0 +1,215 @@ ++/* ++ * reserved comment block ++ * DO NOT REMOVE OR ALTER! ++ */ ++/* ++ * The Apache Software License, Version 1.1 ++ * ++ * ++ * Copyright (c) 2003 The Apache Software Foundation. ++ * All rights reserved. ++ * ++ * Redistribution and use in source and binary forms, with or without ++ * modification, are permitted provided that the following conditions ++ * are met: ++ * ++ * 1. Redistributions of source code must retain the above copyright ++ * notice, this list of conditions and the following disclaimer. ++ * ++ * 2. Redistributions in binary form must reproduce the above copyright ++ * notice, this list of conditions and the following disclaimer in ++ * the documentation and/or other materials provided with the ++ * distribution. ++ * ++ * 3. The end-user documentation included with the redistribution, ++ * if any, must include the following acknowledgment: ++ * "This product includes software developed by the ++ * Apache Software Foundation (http://www.apache.org/)." ++ * Alternately, this acknowledgment may appear in the software itself, ++ * if and wherever such third-party acknowledgments normally appear. ++ * ++ * 4. The names "Xerces" and "Apache Software Foundation" must ++ * not be used to endorse or promote products derived from this ++ * software without prior written permission. For written ++ * permission, please contact apache@apache.org. ++ * ++ * 5. Products derived from this software may not be called "Apache", ++ * nor may "Apache" appear in their name, without prior written ++ * permission of the Apache Software Foundation. ++ * ++ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED ++ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES ++ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR ++ * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT ++ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF ++ * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ++ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, ++ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT ++ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF ++ * SUCH DAMAGE. ++ * ==================================================================== ++ * ++ * This software consists of voluntary contributions made by many ++ * individuals on behalf of the Apache Software Foundation and was ++ * originally based on software copyright (c) 1999, International ++ * Business Machines, Inc., http://www.apache.org. For more ++ * information on the Apache Software Foundation, please see ++ * <http://www.apache.org/>. ++ */ ++ ++package com.sun.org.apache.xerces.internal.util; ++import com.sun.org.apache.xerces.internal.impl.Constants; ++/** ++ * This class is a container for parser settings that relate to ++ * security, or more specifically, it is intended to be used to prevent denial-of-service ++ * attacks from being launched against a system running Xerces. ++ * Any component that is aware of a denial-of-service attack that can arise ++ * from its processing of a certain kind of document may query its Component Manager ++ * for the property (http://apache.org/xml/properties/security-manager) ++ * whose value will be an instance of this class. ++ * If no value has been set for the property, the component should proceed in the "usual" (spec-compliant) ++ * manner. If a value has been set, then it must be the case that the component in ++ * question needs to know what method of this class to query. This class ++ * will provide defaults for all known security issues, but will also provide ++ * setters so that those values can be tailored by applications that care. ++ * ++ * @author Neil Graham, IBM ++ * ++ */ ++public final class SecurityManager { ++ ++ // ++ // Constants ++ // ++ ++ // default value for entity expansion limit ++ private final static int DEFAULT_ENTITY_EXPANSION_LIMIT = 64000; ++ ++ /** Default value of number of nodes created. **/ ++ private final static int DEFAULT_MAX_OCCUR_NODE_LIMIT = 5000; ++ ++ // ++ // Data ++ // ++ ++ private final static int DEFAULT_ELEMENT_ATTRIBUTE_LIMIT = 10000; ++ ++ /** Entity expansion limit. **/ ++ private int entityExpansionLimit; ++ ++ /** W3C XML Schema maxOccurs limit. **/ ++ private int maxOccurLimit; ++ ++ private int fElementAttributeLimit; ++ // default constructor. Establishes default values for ++ // all known security holes. ++ /** ++ * Default constructor. Establishes default values ++ * for known security vulnerabilities. ++ */ ++ public SecurityManager() { ++ entityExpansionLimit = DEFAULT_ENTITY_EXPANSION_LIMIT; ++ maxOccurLimit = DEFAULT_MAX_OCCUR_NODE_LIMIT ; ++ fElementAttributeLimit = DEFAULT_ELEMENT_ATTRIBUTE_LIMIT; ++ //We are reading system properties only once , ++ //at the time of creation of this object , ++ readSystemProperties(); ++ } ++ ++ /** ++ * <p>Sets the number of entity expansions that the ++ * parser should permit in a document.</p> ++ * ++ * @param limit the number of entity expansions ++ * permitted in a document ++ */ ++ public void setEntityExpansionLimit(int limit) { ++ entityExpansionLimit = limit; ++ } ++ ++ /** ++ * <p>Returns the number of entity expansions ++ * that the parser permits in a document.</p> ++ * ++ * @return the number of entity expansions ++ * permitted in a document ++ */ ++ public int getEntityExpansionLimit() { ++ return entityExpansionLimit; ++ } ++ ++ /** ++ * <p>Sets the limit of the number of content model nodes ++ * that may be created when building a grammar for a W3C ++ * XML Schema that contains maxOccurs attributes with values ++ * other than "unbounded".</p> ++ * ++ * @param limit the maximum value for maxOccurs other ++ * than "unbounded" ++ */ ++ public void setMaxOccurNodeLimit(int limit){ ++ maxOccurLimit = limit; ++ } ++ ++ /** ++ * <p>Returns the limit of the number of content model nodes ++ * that may be created when building a grammar for a W3C ++ * XML Schema that contains maxOccurs attributes with values ++ * other than "unbounded".</p> ++ * ++ * @return the maximum value for maxOccurs other ++ * than "unbounded" ++ */ ++ public int getMaxOccurNodeLimit(){ ++ return maxOccurLimit; ++ } ++ ++ public int getElementAttrLimit(){ ++ return fElementAttributeLimit; ++ } ++ ++ public void setElementAttrLimit(int limit){ ++ fElementAttributeLimit = limit; ++ } ++ ++ private void readSystemProperties(){ ++ ++ try { ++ String value = System.getProperty(Constants.ENTITY_EXPANSION_LIMIT); ++ if(value != null && !value.equals("")){ ++ entityExpansionLimit = Integer.parseInt(value); ++ if (entityExpansionLimit < 0) ++ entityExpansionLimit = DEFAULT_ENTITY_EXPANSION_LIMIT; ++ } ++ else ++ entityExpansionLimit = DEFAULT_ENTITY_EXPANSION_LIMIT; ++ }catch(Exception ex){} ++ ++ try { ++ String value = System.getProperty(Constants.MAX_OCCUR_LIMIT); ++ if(value != null && !value.equals("")){ ++ maxOccurLimit = Integer.parseInt(value); ++ if (maxOccurLimit < 0) ++ maxOccurLimit = DEFAULT_MAX_OCCUR_NODE_LIMIT; ++ } ++ else ++ maxOccurLimit = DEFAULT_MAX_OCCUR_NODE_LIMIT; ++ }catch(Exception ex){} ++ ++ try { ++ String value = System.getProperty(Constants.ELEMENT_ATTRIBUTE_LIMIT); ++ if(value != null && !value.equals("")){ ++ fElementAttributeLimit = Integer.parseInt(value); ++ if ( fElementAttributeLimit < 0) ++ fElementAttributeLimit = DEFAULT_ELEMENT_ATTRIBUTE_LIMIT; ++ } ++ else ++ fElementAttributeLimit = DEFAULT_ELEMENT_ATTRIBUTE_LIMIT; ++ ++ }catch(Exception ex){} ++ ++ } ++ ++} // class SecurityManager diff --git a/java/openjdk6/files/icedtea/openjdk/oj6-21-overrides.patch b/java/openjdk6/files/icedtea/openjdk/oj6-21-overrides.patch new file mode 100644 index 000000000000..797a4f63f305 --- /dev/null +++ b/java/openjdk6/files/icedtea/openjdk/oj6-21-overrides.patch @@ -0,0 +1,20 @@ +# HG changeset patch +# User andrew +# Date 1383055466 0 +# Tue Oct 29 14:04:26 2013 +0000 +# Node ID 4a15d8b1c94aa5e5a9c61bbd0feb7a6727343927 +# Parent f587451cfca426297a5d9be67c7bfc36f1ad8e10 +OPENJDK6-21: Remove @Override annotation added on interface by 2013/10/15 security fixes +Reviewed-by: omajid + +diff -r f587451cfca4 -r 4a15d8b1c94a src/share/classes/com/sun/corba/se/impl/presentation/rmi/InvocationHandlerFactoryImpl.java +--- corba/src/share/classes/com/sun/corba/se/impl/presentation/rmi/InvocationHandlerFactoryImpl.java Tue Oct 15 15:55:15 2013 +0100 ++++ corba/src/share/classes/com/sun/corba/se/impl/presentation/rmi/InvocationHandlerFactoryImpl.java Tue Oct 29 14:04:26 2013 +0000 +@@ -130,7 +130,6 @@ + new CustomCompositeInvocationHandlerImpl( stub ) ; + + AccessController.doPrivileged(new PrivilegedAction<Void>() { +- @Override + public Void run() { + handler.addInvocationHandler( DynamicStub.class, + dynamicStubHandler ) ; |