< prev index next >

src/java.base/share/classes/jdk/internal/org/objectweb/asm/FieldWriter.java

Print this page
rev 47452 : imported patch jdk-new-asmv6.patch

*** 145,155 **** * @param value * the field's constant value. May be <tt>null</tt>. */ FieldWriter(final ClassWriter cw, final int access, final String name, final String desc, final String signature, final Object value) { ! super(Opcodes.ASM5); if (cw.firstField == null) { cw.firstField = this; } else { cw.lastField.fv = this; } --- 145,155 ---- * @param value * the field's constant value. May be <tt>null</tt>. */ FieldWriter(final ClassWriter cw, final int access, final String name, final String desc, final String signature, final Object value) { ! super(Opcodes.ASM6); if (cw.firstField == null) { cw.firstField = this; } else { cw.lastField.fv = this; }
*** 156,166 **** cw.lastField = this; this.cw = cw; this.access = access; this.name = cw.newUTF8(name); this.desc = cw.newUTF8(desc); ! if (ClassReader.SIGNATURES && signature != null) { this.signature = cw.newUTF8(signature); } if (value != null) { this.value = cw.newConstItem(value).index; } --- 156,166 ---- cw.lastField = this; this.cw = cw; this.access = access; this.name = cw.newUTF8(name); this.desc = cw.newUTF8(desc); ! if (signature != null) { this.signature = cw.newUTF8(signature); } if (value != null) { this.value = cw.newConstItem(value).index; }
*** 171,183 **** // ------------------------------------------------------------------------ @Override public AnnotationVisitor visitAnnotation(final String desc, final boolean visible) { - if (!ClassReader.ANNOTATIONS) { - return null; - } ByteVector bv = new ByteVector(); // write type, and reserve space for values count bv.putShort(cw.newUTF8(desc)).putShort(0); AnnotationWriter aw = new AnnotationWriter(cw, true, bv, bv, 2); if (visible) { --- 171,180 ----
*** 191,203 **** } @Override public AnnotationVisitor visitTypeAnnotation(final int typeRef, final TypePath typePath, final String desc, final boolean visible) { - if (!ClassReader.ANNOTATIONS) { - return null; - } ByteVector bv = new ByteVector(); // write target_type and target_info AnnotationWriter.putTarget(typeRef, typePath, bv); // write type, and reserve space for values count bv.putShort(cw.newUTF8(desc)).putShort(0); --- 188,197 ----
*** 247,273 **** } if ((access & Opcodes.ACC_DEPRECATED) != 0) { cw.newUTF8("Deprecated"); size += 6; } ! if (ClassReader.SIGNATURES && signature != 0) { cw.newUTF8("Signature"); size += 8; } ! if (ClassReader.ANNOTATIONS && anns != null) { cw.newUTF8("RuntimeVisibleAnnotations"); size += 8 + anns.getSize(); } ! if (ClassReader.ANNOTATIONS && ianns != null) { cw.newUTF8("RuntimeInvisibleAnnotations"); size += 8 + ianns.getSize(); } ! if (ClassReader.ANNOTATIONS && tanns != null) { cw.newUTF8("RuntimeVisibleTypeAnnotations"); size += 8 + tanns.getSize(); } ! if (ClassReader.ANNOTATIONS && itanns != null) { cw.newUTF8("RuntimeInvisibleTypeAnnotations"); size += 8 + itanns.getSize(); } if (attrs != null) { size += attrs.getSize(cw, null, 0, -1, -1); --- 241,267 ---- } if ((access & Opcodes.ACC_DEPRECATED) != 0) { cw.newUTF8("Deprecated"); size += 6; } ! if (signature != 0) { cw.newUTF8("Signature"); size += 8; } ! if (anns != null) { cw.newUTF8("RuntimeVisibleAnnotations"); size += 8 + anns.getSize(); } ! if (ianns != null) { cw.newUTF8("RuntimeInvisibleAnnotations"); size += 8 + ianns.getSize(); } ! if (tanns != null) { cw.newUTF8("RuntimeVisibleTypeAnnotations"); size += 8 + tanns.getSize(); } ! if (itanns != null) { cw.newUTF8("RuntimeInvisibleTypeAnnotations"); size += 8 + itanns.getSize(); } if (attrs != null) { size += attrs.getSize(cw, null, 0, -1, -1);
*** 297,319 **** } } if ((access & Opcodes.ACC_DEPRECATED) != 0) { ++attributeCount; } ! if (ClassReader.SIGNATURES && signature != 0) { ++attributeCount; } ! if (ClassReader.ANNOTATIONS && anns != null) { ++attributeCount; } ! if (ClassReader.ANNOTATIONS && ianns != null) { ++attributeCount; } ! if (ClassReader.ANNOTATIONS && tanns != null) { ++attributeCount; } ! if (ClassReader.ANNOTATIONS && itanns != null) { ++attributeCount; } if (attrs != null) { attributeCount += attrs.getCount(); } --- 291,313 ---- } } if ((access & Opcodes.ACC_DEPRECATED) != 0) { ++attributeCount; } ! if (signature != 0) { ++attributeCount; } ! if (anns != null) { ++attributeCount; } ! if (ianns != null) { ++attributeCount; } ! if (tanns != null) { ++attributeCount; } ! if (itanns != null) { ++attributeCount; } if (attrs != null) { attributeCount += attrs.getCount(); }
*** 329,355 **** } } if ((access & Opcodes.ACC_DEPRECATED) != 0) { out.putShort(cw.newUTF8("Deprecated")).putInt(0); } ! if (ClassReader.SIGNATURES && signature != 0) { out.putShort(cw.newUTF8("Signature")); out.putInt(2).putShort(signature); } ! if (ClassReader.ANNOTATIONS && anns != null) { out.putShort(cw.newUTF8("RuntimeVisibleAnnotations")); anns.put(out); } ! if (ClassReader.ANNOTATIONS && ianns != null) { out.putShort(cw.newUTF8("RuntimeInvisibleAnnotations")); ianns.put(out); } ! if (ClassReader.ANNOTATIONS && tanns != null) { out.putShort(cw.newUTF8("RuntimeVisibleTypeAnnotations")); tanns.put(out); } ! if (ClassReader.ANNOTATIONS && itanns != null) { out.putShort(cw.newUTF8("RuntimeInvisibleTypeAnnotations")); itanns.put(out); } if (attrs != null) { attrs.put(cw, null, 0, -1, -1, out); --- 323,349 ---- } } if ((access & Opcodes.ACC_DEPRECATED) != 0) { out.putShort(cw.newUTF8("Deprecated")).putInt(0); } ! if (signature != 0) { out.putShort(cw.newUTF8("Signature")); out.putInt(2).putShort(signature); } ! if (anns != null) { out.putShort(cw.newUTF8("RuntimeVisibleAnnotations")); anns.put(out); } ! if (ianns != null) { out.putShort(cw.newUTF8("RuntimeInvisibleAnnotations")); ianns.put(out); } ! if (tanns != null) { out.putShort(cw.newUTF8("RuntimeVisibleTypeAnnotations")); tanns.put(out); } ! if (itanns != null) { out.putShort(cw.newUTF8("RuntimeInvisibleTypeAnnotations")); itanns.put(out); } if (attrs != null) { attrs.put(cw, null, 0, -1, -1, out);
< prev index next >