From a9f5e76a65f743be9cd995fbea9c78ff9cef3402 Mon Sep 17 00:00:00 2001 From: Chen Liang Date: Sun, 14 Jul 2024 15:01:51 +0000 Subject: [PATCH] 8335905: CompoundElement API cleanup Reviewed-by: asotona --- .../java/lang/classfile/ClassFileBuilder.java | 4 ++-- .../java/lang/classfile/ClassModel.java | 4 ++-- .../java/lang/classfile/CodeModel.java | 5 ++--- .../java/lang/classfile/CompoundElement.java | 19 ++++++------------- .../java/lang/classfile/FieldModel.java | 4 ++-- .../java/lang/classfile/MethodModel.java | 4 ++-- .../classfile/impl/AbstractUnboundModel.java | 4 ++-- .../classfile/impl/BufferedCodeBuilder.java | 2 +- .../classfile/impl/BufferedMethodBuilder.java | 4 ++-- .../internal/classfile/impl/ClassImpl.java | 2 +- .../classfile/impl/ClassRemapperImpl.java | 6 ++---- .../jdk/internal/classfile/impl/CodeImpl.java | 10 ++++++---- .../internal/classfile/impl/FieldImpl.java | 4 ++-- .../internal/classfile/impl/MethodImpl.java | 4 ++-- .../classes/sun/tools/jar/FingerPrint.java | 4 ++-- .../jfr/internal/EventInstrumentation.java | 4 ++-- .../classes/jdk/tools/jimage/JImageTask.java | 9 ++++----- .../lang/instrument/asmlib/Instrumentor.java | 2 +- .../lang/invoke/8022701/MHIllegalAccess.java | 4 ++-- .../java/lang/invoke/lambda/LambdaAsm.java | 4 ++-- test/jdk/jdk/classfile/AdaptCodeTest.java | 2 +- test/jdk/jdk/classfile/BasicBlockTest.java | 4 ++-- .../jdk/classfile/ClassHierarchyInfoTest.java | 2 +- test/jdk/jdk/classfile/CorpusTest.java | 2 +- test/jdk/jdk/classfile/LvtTest.java | 10 +++++----- test/jdk/jdk/classfile/OptionsTest.java | 2 +- test/jdk/jdk/classfile/StackMapsTest.java | 2 +- .../jdk/classfile/TestRecordComponent.java | 2 +- test/jdk/jdk/classfile/VerifierSelfTest.java | 2 +- .../helpers/RebuildingTransformation.java | 2 +- .../jdk/jdk/classfile/helpers/Transforms.java | 6 +++--- .../event/compiler/TestCompilerInlining.java | 2 +- .../openjdk/bench/jdk/classfile/ReadDeep.java | 8 ++++---- .../bench/jdk/classfile/Transforms.java | 6 +++--- 34 files changed, 73 insertions(+), 82 deletions(-) diff --git a/src/java.base/share/classes/java/lang/classfile/ClassFileBuilder.java b/src/java.base/share/classes/java/lang/classfile/ClassFileBuilder.java index 9381c0510ef..b4993976ecd 100644 --- a/src/java.base/share/classes/java/lang/classfile/ClassFileBuilder.java +++ b/src/java.base/share/classes/java/lang/classfile/ClassFileBuilder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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 @@ -89,7 +89,7 @@ public sealed interface ClassFileBuilder the element type * * @sealedGraph @@ -55,15 +55,8 @@ public sealed interface CompoundElement * compound element * @param consumer the handler */ - void forEachElement(Consumer consumer); - - /** - * {@return an {@link Iterable} describing all the elements contained in this - * compound element} - */ - default Iterable elements() { - return elementList(); - } + @Override + void forEach(Consumer consumer); /** * {@return an {@link Iterator} describing all the elements contained in this @@ -71,7 +64,7 @@ public sealed interface CompoundElement */ @Override default Iterator iterator() { - return elements().iterator(); + return elementList().iterator(); } /** @@ -91,7 +84,7 @@ public sealed interface CompoundElement */ default List elementList() { List list = new ArrayList<>(); - forEachElement(new Consumer<>() { + forEach(new Consumer<>() { @Override public void accept(E e) { list.add(e); diff --git a/src/java.base/share/classes/java/lang/classfile/FieldModel.java b/src/java.base/share/classes/java/lang/classfile/FieldModel.java index cb2e167b9cf..35465dfe97d 100644 --- a/src/java.base/share/classes/java/lang/classfile/FieldModel.java +++ b/src/java.base/share/classes/java/lang/classfile/FieldModel.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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 @@ -35,7 +35,7 @@ import jdk.internal.javac.PreviewFeature; /** * Models a field. The contents of the field can be traversed via - * a streaming view (e.g., {@link #elements()}), or via random access (e.g., + * a streaming view, or via random access (e.g., * {@link #flags()}), or by freely mixing the two. * * @since 22 diff --git a/src/java.base/share/classes/java/lang/classfile/MethodModel.java b/src/java.base/share/classes/java/lang/classfile/MethodModel.java index 49cbb6ac7fd..3d91683e218 100644 --- a/src/java.base/share/classes/java/lang/classfile/MethodModel.java +++ b/src/java.base/share/classes/java/lang/classfile/MethodModel.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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 @@ -35,7 +35,7 @@ import jdk.internal.javac.PreviewFeature; /** * Models a method. The contents of the method can be traversed via - * a streaming view (e.g., {@link #elements()}), or via random access (e.g., + * a streaming view, or via random access (e.g., * {@link #flags()}), or by freely mixing the two. * * @since 22 diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/AbstractUnboundModel.java b/src/java.base/share/classes/jdk/internal/classfile/impl/AbstractUnboundModel.java index 6aa046eb06d..5aebec8ab40 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/AbstractUnboundModel.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/AbstractUnboundModel.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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 @@ -45,7 +45,7 @@ public abstract sealed class AbstractUnboundModel } @Override - public void forEachElement(Consumer consumer) { + public void forEach(Consumer consumer) { elements.forEach(consumer); } diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedCodeBuilder.java b/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedCodeBuilder.java index 8603c77ab8b..e9a8f2e1e1c 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedCodeBuilder.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedCodeBuilder.java @@ -201,7 +201,7 @@ public final class BufferedCodeBuilder builder.withCode(new Consumer<>() { @Override public void accept(CodeBuilder cb) { - forEachElement(cb); + forEach(cb); } }); } diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedMethodBuilder.java b/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedMethodBuilder.java index c6cf9d8ea53..0819831466e 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedMethodBuilder.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/BufferedMethodBuilder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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,7 +200,7 @@ public final class BufferedMethodBuilder builder.withMethod(methodName(), methodType(), methodFlags(), new Consumer<>() { @Override public void accept(MethodBuilder mb) { - forEachElement(mb); + forEach(mb); } }); } diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/ClassImpl.java b/src/java.base/share/classes/jdk/internal/classfile/impl/ClassImpl.java index 907a5cc5351..eab283a8c60 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/ClassImpl.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/ClassImpl.java @@ -156,7 +156,7 @@ public final class ClassImpl // ClassModel @Override - public void forEachElement(Consumer consumer) { + public void forEach(Consumer consumer) { consumer.accept(flags()); consumer.accept(ClassFileVersion.of(majorVersion(), minorVersion())); superclass().ifPresent(new Consumer() { diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/ClassRemapperImpl.java b/src/java.base/share/classes/jdk/internal/classfile/impl/ClassRemapperImpl.java index d1a02d9a93c..e3f701b2e2a 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/ClassRemapperImpl.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/ClassRemapperImpl.java @@ -97,12 +97,10 @@ public record ClassRemapperImpl(Function mapFunction) impl switch (cle) { case FieldModel fm -> clb.withField(fm.fieldName().stringValue(), map( - fm.fieldTypeSymbol()), fb -> - fm.forEachElement(asFieldTransform().resolve(fb).consumer())); + fm.fieldTypeSymbol()), fb -> fb.transform(fm, asFieldTransform())); case MethodModel mm -> clb.withMethod(mm.methodName().stringValue(), mapMethodDesc( - mm.methodTypeSymbol()), mm.flags().flagsMask(), mb -> - mm.forEachElement(asMethodTransform().resolve(mb).consumer())); + mm.methodTypeSymbol()), mm.flags().flagsMask(), mb -> mb.transform(mm, asMethodTransform())); case Superclass sc -> clb.withSuperclass(map(sc.superclassEntry().asSymbol())); case Interfaces ins -> diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/CodeImpl.java b/src/java.base/share/classes/jdk/internal/classfile/impl/CodeImpl.java index 06058bba282..4b2a21072f0 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/CodeImpl.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/CodeImpl.java @@ -27,6 +27,7 @@ package jdk.internal.classfile.impl; import java.util.ArrayList; import java.util.Collections; import java.util.List; +import java.util.Objects; import java.util.Optional; import java.util.function.Consumer; @@ -149,7 +150,7 @@ public final class CodeImpl new Consumer() { @Override public void accept(CodeBuilder cb) { - forEachElement(cb); + forEach(cb); } }, (SplitConstantPool)buf.constantPool(), @@ -166,7 +167,8 @@ public final class CodeImpl } @Override - public void forEachElement(Consumer consumer) { + public void forEach(Consumer consumer) { + Objects.requireNonNull(consumer); inflateMetadata(); boolean doLineNumbers = (lineNumbers != null); generateCatchTargets(consumer); @@ -329,7 +331,7 @@ public final class CodeImpl findAttribute(Attributes.runtimeInvisibleTypeAnnotations()).ifPresent(RuntimeInvisibleTypeAnnotationsAttribute::annotations); } - private void generateCatchTargets(Consumer consumer) { + private void generateCatchTargets(Consumer consumer) { // We attach all catch targets to bci zero, because trying to attach them // to their range could subtly affect the order of exception processing iterateExceptionHandlers(new ExceptionHandlerAction() { @@ -343,7 +345,7 @@ public final class CodeImpl }); } - private void generateDebugElements(Consumer consumer) { + private void generateDebugElements(Consumer consumer) { for (Attribute a : attributes()) { if (a.attributeMapper() == Attributes.characterRangeTable()) { var attr = (BoundCharacterRangeTableAttribute) a; diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/FieldImpl.java b/src/java.base/share/classes/jdk/internal/classfile/impl/FieldImpl.java index fb072ae5638..ba424c862fd 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/FieldImpl.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/FieldImpl.java @@ -101,14 +101,14 @@ public final class FieldImpl builder.withField(fieldName(), fieldType(), new Consumer<>() { @Override public void accept(FieldBuilder fb) { - FieldImpl.this.forEachElement(fb); + FieldImpl.this.forEach(fb); } }); } } @Override - public void forEachElement(Consumer consumer) { + public void forEach(Consumer consumer) { consumer.accept(flags()); for (Attribute attr : attributes()) { if (attr instanceof FieldElement e) diff --git a/src/java.base/share/classes/jdk/internal/classfile/impl/MethodImpl.java b/src/java.base/share/classes/jdk/internal/classfile/impl/MethodImpl.java index 3bc811634ee..62a83dffc6e 100644 --- a/src/java.base/share/classes/jdk/internal/classfile/impl/MethodImpl.java +++ b/src/java.base/share/classes/jdk/internal/classfile/impl/MethodImpl.java @@ -122,7 +122,7 @@ public final class MethodImpl } @Override - public void forEachElement(Consumer consumer) { + public void forEach(Consumer consumer) { consumer.accept(flags()); for (Attribute attr : attributes()) { if (attr instanceof MethodElement e) @@ -140,7 +140,7 @@ public final class MethodImpl new Consumer<>() { @Override public void accept(MethodBuilder mb) { - MethodImpl.this.forEachElement(mb); + MethodImpl.this.forEach(mb); } }); } diff --git a/src/jdk.jartool/share/classes/sun/tools/jar/FingerPrint.java b/src/jdk.jartool/share/classes/sun/tools/jar/FingerPrint.java index b28078916c5..beb97ae5fd8 100644 --- a/src/jdk.jartool/share/classes/sun/tools/jar/FingerPrint.java +++ b/src/jdk.jartool/share/classes/sun/tools/jar/FingerPrint.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2024, 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 @@ -172,7 +172,7 @@ final class FingerPrint { cm.thisClass().asInternalName(), cm.superclass().map(ClassEntry::asInternalName).orElse(null), cm.majorVersion()); - cm.forEachElement(attrs); + cm.forEach(attrs); return attrs; } diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/EventInstrumentation.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/EventInstrumentation.java index d8f5e689ca1..5521336f938 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/EventInstrumentation.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/EventInstrumentation.java @@ -222,7 +222,7 @@ final class EventInstrumentation { // Only supports String, String[] and Boolean values private static T annotationValue(ClassModel classModel, ClassDesc classDesc, Class type) { String typeDescriptor = classDesc.descriptorString(); - for (ClassElement ce : classModel.elements()) { + for (ClassElement ce : classModel) { if (ce instanceof RuntimeVisibleAnnotationsAttribute rvaa) { for (Annotation a : rvaa.annotations()) { if (a.className().equalsString(typeDescriptor)) { @@ -260,7 +260,7 @@ final class EventInstrumentation { Set methodSet = new HashSet<>(); List settingDescs = new ArrayList<>(); for (MethodModel m : classModel.methods()) { - for (var me : m.elements()) { + for (var me : m) { if (me instanceof RuntimeVisibleAnnotationsAttribute rvaa) { for (Annotation a : rvaa.annotations()) { // We can't really validate the method at this diff --git a/src/jdk.jlink/share/classes/jdk/tools/jimage/JImageTask.java b/src/jdk.jlink/share/classes/jdk/tools/jimage/JImageTask.java index f128a84cc89..df2aca02d68 100644 --- a/src/jdk.jlink/share/classes/jdk/tools/jimage/JImageTask.java +++ b/src/jdk.jlink/share/classes/jdk/tools/jimage/JImageTask.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2023, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2024, 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 @@ -39,7 +39,6 @@ import java.util.MissingResourceException; import java.util.function.Predicate; import java.util.stream.Collectors; import java.util.stream.Stream; -import java.lang.classfile.ClassModel; import java.lang.classfile.ClassFile; import java.lang.classfile.CodeModel; import java.lang.classfile.MethodModel; @@ -368,9 +367,9 @@ class JImageTask { if (name.endsWith(".class") && !name.endsWith("module-info.class")) { try { byte[] bytes = reader.getResource(location); - ClassFile.of().parse(bytes).forEachElement(cle -> { - if (cle instanceof MethodModel mm) mm.forEachElement(me -> { - if (me instanceof CodeModel com) com.forEachElement(coe -> { + ClassFile.of().parse(bytes).forEach(cle -> { + if (cle instanceof MethodModel mm) mm.forEach(me -> { + if (me instanceof CodeModel com) com.forEach(coe -> { //do nothing here, just visit each model element }); }); diff --git a/test/jdk/java/lang/instrument/asmlib/Instrumentor.java b/test/jdk/java/lang/instrument/asmlib/Instrumentor.java index 77893ed8a11..2a2e97b8a37 100644 --- a/test/jdk/java/lang/instrument/asmlib/Instrumentor.java +++ b/test/jdk/java/lang/instrument/asmlib/Instrumentor.java @@ -133,7 +133,7 @@ public class Instrumentor { } })); - builder.withMethod(newName, mt, mm.flags().flagsMask(), mm::forEachElement); + builder.withMethod(newName, mt, mm.flags().flagsMask(), mm::forEach); } else { builder.accept(element); } diff --git a/test/jdk/java/lang/invoke/8022701/MHIllegalAccess.java b/test/jdk/java/lang/invoke/8022701/MHIllegalAccess.java index 0880985638d..896e29439e9 100644 --- a/test/jdk/java/lang/invoke/8022701/MHIllegalAccess.java +++ b/test/jdk/java/lang/invoke/8022701/MHIllegalAccess.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2023, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2024, 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 @@ -63,7 +63,7 @@ public class MHIllegalAccess { */ ClassTransform changeName = (cb, ce) -> { if (ce instanceof MethodModel mm && mm.methodName().equalsString("m")) { - cb.withMethod("nemo", mm.methodTypeSymbol(), mm.flags().flagsMask(), mm::forEachElement); + cb.withMethod("nemo", mm.methodTypeSymbol(), mm.flags().flagsMask(), mm::forEach); } else { cb.accept(ce); } diff --git a/test/jdk/java/lang/invoke/lambda/LambdaAsm.java b/test/jdk/java/lang/invoke/lambda/LambdaAsm.java index 8369ea2bcd3..76d091cc51d 100644 --- a/test/jdk/java/lang/invoke/lambda/LambdaAsm.java +++ b/test/jdk/java/lang/invoke/lambda/LambdaAsm.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2023, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2024, 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 @@ -100,7 +100,7 @@ public class LambdaAsm { static void checkMethod(String cname, String mname, ConstantPool cp, CodeAttribute code) throws IllegalArgumentException { - for (var inst : code.elements()) { + for (var inst : code) { if (inst instanceof InvokeInstruction inv && (inv.opcode() == Opcode.INVOKESPECIAL || inv.opcode() == Opcode.INVOKEINTERFACE)) { var ref = inv.method(); diff --git a/test/jdk/jdk/classfile/AdaptCodeTest.java b/test/jdk/jdk/classfile/AdaptCodeTest.java index 2b9dff58819..ca9145d6885 100644 --- a/test/jdk/jdk/classfile/AdaptCodeTest.java +++ b/test/jdk/jdk/classfile/AdaptCodeTest.java @@ -114,7 +114,7 @@ class AdaptCodeTest { void testCopy() throws Exception { var cc = ClassFile.of(); ClassModel cm = cc.parse(testClassPath); - byte[] newBytes = cc.build(cm.thisClass().asSymbol(), cb -> cm.forEachElement(cb)); + byte[] newBytes = cc.build(cm.thisClass().asSymbol(), cm::forEach); // TestUtil.writeClass(newBytes, "TestClass.class"); String result = (String) new ByteArrayClassLoader(AdaptCodeTest.class.getClassLoader(), testClassName, newBytes) diff --git a/test/jdk/jdk/classfile/BasicBlockTest.java b/test/jdk/jdk/classfile/BasicBlockTest.java index 9c4b931857e..0781c5a10c1 100644 --- a/test/jdk/jdk/classfile/BasicBlockTest.java +++ b/test/jdk/jdk/classfile/BasicBlockTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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 @@ -57,7 +57,7 @@ class BasicBlockTest { try (InputStream in = BasicBlockTest.class.getResourceAsStream("BasicBlockTest.class")) { var cc = ClassFile.of(); var classModel = cc.parse(in.readAllBytes()); - cc.build(classModel.thisClass().asSymbol(), cb -> classModel.forEachElement(cb)); + cc.build(classModel.thisClass().asSymbol(), classModel::forEach); } } } diff --git a/test/jdk/jdk/classfile/ClassHierarchyInfoTest.java b/test/jdk/jdk/classfile/ClassHierarchyInfoTest.java index 4065f1d5e2f..d4a9e3a4297 100644 --- a/test/jdk/jdk/classfile/ClassHierarchyInfoTest.java +++ b/test/jdk/jdk/classfile/ClassHierarchyInfoTest.java @@ -127,7 +127,7 @@ class ClassHierarchyInfoTest { if (cle instanceof MethodModel mm) { clb.transformMethod(mm, (mb, me) -> { if (me instanceof CodeModel cm) { - mb.withCode(cob -> cm.forEachElement(cob)); + mb.withCode(cm::forEach); } else mb.with(me); diff --git a/test/jdk/jdk/classfile/CorpusTest.java b/test/jdk/jdk/classfile/CorpusTest.java index 67a2ebabb31..2dfbef10d67 100644 --- a/test/jdk/jdk/classfile/CorpusTest.java +++ b/test/jdk/jdk/classfile/CorpusTest.java @@ -200,7 +200,7 @@ class CorpusTest { byte[] newBytes = cc.build( classModel.thisClass().asSymbol(), - classModel::forEachElement); + classModel::forEach); var newModel = cc.parse(newBytes); assertEqualsDeep(ClassRecord.ofClassModel(newModel, CompatibilityFilter.By_ClassBuilder), ClassRecord.ofClassModel(classModel, CompatibilityFilter.By_ClassBuilder), diff --git a/test/jdk/jdk/classfile/LvtTest.java b/test/jdk/jdk/classfile/LvtTest.java index 7fb289cc175..3d789809798 100644 --- a/test/jdk/jdk/classfile/LvtTest.java +++ b/test/jdk/jdk/classfile/LvtTest.java @@ -88,7 +88,7 @@ class LvtTest { .orElseThrow(); List lvs = new ArrayList<>(); - co.forEachElement(e -> { + co.forEach(e -> { if (e instanceof LocalVariable l) lvs.add(l); }); @@ -198,7 +198,7 @@ class LvtTest { .orElseThrow(); List lvts = new ArrayList<>(); - co.forEachElement(e -> { + co.forEach(e -> { if (e instanceof LocalVariableType l) lvts.add(l); }); @@ -304,11 +304,11 @@ class LvtTest { void skipDebugSkipsLVT() { ClassModel c = ClassFile.of(ClassFile.DebugElementsOption.DROP_DEBUG).parse(fileBytes); - c.forEachElement(e -> { + c.forEach(e -> { if (e instanceof MethodModel m) { - m.forEachElement(el -> { + m.forEach(el -> { if (el instanceof CodeModel cm) { - cm.forEachElement(elem -> { + cm.forEach(elem -> { assertFalse(elem instanceof LocalVariable); assertFalse(elem instanceof LocalVariableType); }); diff --git a/test/jdk/jdk/classfile/OptionsTest.java b/test/jdk/jdk/classfile/OptionsTest.java index 10e3855b060..fda155cfd2a 100644 --- a/test/jdk/jdk/classfile/OptionsTest.java +++ b/test/jdk/jdk/classfile/OptionsTest.java @@ -117,6 +117,6 @@ class OptionsTest { if (e instanceof AttributedElement ae) ae.attributes().forEach(a -> assertTrue(AttributeMapper.AttributeStability.UNSTABLE.ordinal() >= a.attributeMapper().stability().ordinal(), () -> "class " + path + " contains unexpected " + a)); - if (e instanceof CompoundElement ce) ce.forEachElement(ee -> testNoUnstable(path, (ClassFileElement)ee)); + if (e instanceof CompoundElement ce) ce.forEach(ee -> testNoUnstable(path, (ClassFileElement)ee)); } } diff --git a/test/jdk/jdk/classfile/StackMapsTest.java b/test/jdk/jdk/classfile/StackMapsTest.java index 137f5bac486..211490c3f8e 100644 --- a/test/jdk/jdk/classfile/StackMapsTest.java +++ b/test/jdk/jdk/classfile/StackMapsTest.java @@ -270,7 +270,7 @@ class StackMapsTest { // classModel.superclass().ifPresent(cb::withSuperclass); // cb.withInterfaces(classModel.interfaces()); // cb.withVersion(classModel.majorVersion(), classModel.minorVersion()); - classModel.forEachElement(cb); + classModel.forEach(cb); }); //then verify transformed bytecode diff --git a/test/jdk/jdk/classfile/TestRecordComponent.java b/test/jdk/jdk/classfile/TestRecordComponent.java index b39029154a0..7512e2e3167 100644 --- a/test/jdk/jdk/classfile/TestRecordComponent.java +++ b/test/jdk/jdk/classfile/TestRecordComponent.java @@ -105,7 +105,7 @@ class TestRecordComponent { void testOptions() throws Exception { AtomicInteger count = new AtomicInteger(0); ClassModel cm = ClassFile.of().parse(Files.readAllBytes(testClassPath)); - cm.forEachElement((ce) -> { + cm.forEach((ce) -> { if (ce instanceof RecordAttribute rm) { count.addAndGet(rm.components().size()); }}); diff --git a/test/jdk/jdk/classfile/VerifierSelfTest.java b/test/jdk/jdk/classfile/VerifierSelfTest.java index 529edbf2b79..26513a54335 100644 --- a/test/jdk/jdk/classfile/VerifierSelfTest.java +++ b/test/jdk/jdk/classfile/VerifierSelfTest.java @@ -79,7 +79,7 @@ class VerifierSelfTest { if (cle instanceof MethodModel mm) { clb.transformMethod(mm, (mb, me) -> { if (me instanceof CodeModel cm) { - mb.withCode(cob -> cm.forEachElement(cob)); + mb.withCode(cob -> cm.forEach(cob)); } else mb.with(me); diff --git a/test/jdk/jdk/classfile/helpers/RebuildingTransformation.java b/test/jdk/jdk/classfile/helpers/RebuildingTransformation.java index 7905a79fd40..2af3cd9410f 100644 --- a/test/jdk/jdk/classfile/helpers/RebuildingTransformation.java +++ b/test/jdk/jdk/classfile/helpers/RebuildingTransformation.java @@ -75,7 +75,7 @@ class RebuildingTransformation { cob2.transforming(new CodeRebuildingTransform(), cob3 -> // first pass transforms bound to unbound instructions cob3.transforming(new CodeRebuildingTransform(), cob4 -> { - com.forEachElement(cob4::with); + com.forEach(cob4::with); com.findAttribute(Attributes.stackMapTable()).ifPresent(cob4::with); })))); case AnnotationDefaultAttribute a -> mb.with(AnnotationDefaultAttribute.of(transformAnnotationValue(a.defaultValue()))); diff --git a/test/jdk/jdk/classfile/helpers/Transforms.java b/test/jdk/jdk/classfile/helpers/Transforms.java index 0b44c5a22aa..c385fe61663 100644 --- a/test/jdk/jdk/classfile/helpers/Transforms.java +++ b/test/jdk/jdk/classfile/helpers/Transforms.java @@ -218,7 +218,7 @@ public class Transforms { if (me instanceof CodeModel xm) { mb.withCode(xb -> { xb.nop(); - xm.forEachElement(new Consumer<>() { + xm.forEach(new Consumer<>() { @Override public void accept(CodeElement e) { xb.with(e); @@ -270,7 +270,7 @@ public class Transforms { ClassModel cm = cc.parse(bytes); return cc.build(cm.thisClass().asSymbol(), cb -> { - cm.forEachElement(cb); + cm.forEach(cb); cb.withField("argleBargleWoogaWooga", ConstantDescs.CD_int, b -> { }); }); }), @@ -301,7 +301,7 @@ public class Transforms { ClassModel cm = cc.parse(bytes); return cc.build(cm.thisClass().asSymbol(), cb -> { - cm.forEachElement(element -> { + cm.forEach(element -> { if (element instanceof MethodModel mm && mm.methodName().stringValue().equals("hashCode") && mm.methodType().stringValue().equals("()Z")) { diff --git a/test/jdk/jdk/jfr/event/compiler/TestCompilerInlining.java b/test/jdk/jdk/jfr/event/compiler/TestCompilerInlining.java index 79b3fe11cb9..56005fa7458 100644 --- a/test/jdk/jdk/jfr/event/compiler/TestCompilerInlining.java +++ b/test/jdk/jdk/jfr/event/compiler/TestCompilerInlining.java @@ -390,7 +390,7 @@ class InlineCalls { mm.methodTypeSymbol() ); int offset = 0; - for (var ce : com.elements()) { + for (var ce : com) { if (ce instanceof Instruction ins) { if (ins instanceof InvokeInstruction inv) { calls.add(new Call(caller, new MethodDesc( diff --git a/test/micro/org/openjdk/bench/jdk/classfile/ReadDeep.java b/test/micro/org/openjdk/bench/jdk/classfile/ReadDeep.java index 2f5e2cfbe1e..4165785135c 100644 --- a/test/micro/org/openjdk/bench/jdk/classfile/ReadDeep.java +++ b/test/micro/org/openjdk/bench/jdk/classfile/ReadDeep.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2022, 2024, 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 @@ -101,11 +101,11 @@ public class ReadDeep extends AbstractCorpusBenchmark { for (byte[] bytes : classes) { int[] count = new int[1]; ClassModel cm = cc.parse(bytes); - cm.forEachElement(ce -> { + cm.forEach(ce -> { if (ce instanceof MethodModel mm) { - mm.forEachElement(me -> { + mm.forEach(me -> { if (me instanceof CodeModel xm) { - xm.forEachElement(xe -> { + xm.forEach(xe -> { if (xe instanceof LoadInstruction) { ++count[0]; } diff --git a/test/micro/org/openjdk/bench/jdk/classfile/Transforms.java b/test/micro/org/openjdk/bench/jdk/classfile/Transforms.java index d49897dc9c2..e4d553c268f 100644 --- a/test/micro/org/openjdk/bench/jdk/classfile/Transforms.java +++ b/test/micro/org/openjdk/bench/jdk/classfile/Transforms.java @@ -204,7 +204,7 @@ public class Transforms { if (me instanceof CodeModel xm) { mb.withCode(xb -> { xb.nop(); - xm.forEachElement(new Consumer<>() { + xm.forEach(new Consumer<>() { @Override public void accept(CodeElement e) { xb.with(e); @@ -256,7 +256,7 @@ public class Transforms { ClassModel cm = cc.parse(bytes); return cc.build(cm.thisClass().asSymbol(), cb -> { - cm.forEachElement(cb); + cm.forEach(cb); cb.withField("argleBargleWoogaWooga", ConstantDescs.CD_int, b -> { }); }); }), @@ -287,7 +287,7 @@ public class Transforms { ClassModel cm = cc.parse(bytes); return cc.build(cm.thisClass().asSymbol(), cb -> { - cm.forEachElement(element -> { + cm.forEach(element -> { if (element instanceof MethodModel mm && mm.methodName().stringValue().equals("hashCode") && mm.methodType().stringValue().equals("()Z")) {