8337219: AccessFlags factories do not require necessary arguments
Reviewed-by: asotona
This commit is contained in:
parent
6154a2129b
commit
93c19ac73c
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -64,52 +64,4 @@ public sealed interface AccessFlags
|
|||||||
* method, or field}
|
* method, or field}
|
||||||
*/
|
*/
|
||||||
AccessFlag.Location location();
|
AccessFlag.Location location();
|
||||||
|
|
||||||
/**
|
|
||||||
* {@return an {@linkplain AccessFlags} for a class}
|
|
||||||
* @param mask the flags to be set, as a bit mask
|
|
||||||
*/
|
|
||||||
static AccessFlags ofClass(int mask) {
|
|
||||||
return new AccessFlagsImpl(AccessFlag.Location.CLASS, mask);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@return an {@linkplain AccessFlags} for a class}
|
|
||||||
* @param flags the flags to be set
|
|
||||||
*/
|
|
||||||
static AccessFlags ofClass(AccessFlag... flags) {
|
|
||||||
return new AccessFlagsImpl(AccessFlag.Location.CLASS, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@return an {@linkplain AccessFlags} for a field}
|
|
||||||
* @param mask the flags to be set, as a bit mask
|
|
||||||
*/
|
|
||||||
static AccessFlags ofField(int mask) {
|
|
||||||
return new AccessFlagsImpl(AccessFlag.Location.FIELD, mask);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@return an {@linkplain AccessFlags} for a field}
|
|
||||||
* @param flags the flags to be set
|
|
||||||
*/
|
|
||||||
static AccessFlags ofField(AccessFlag... flags) {
|
|
||||||
return new AccessFlagsImpl(AccessFlag.Location.FIELD, flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@return an {@linkplain AccessFlags} for a method}
|
|
||||||
* @param mask the flags to be set, as a bit mask
|
|
||||||
*/
|
|
||||||
static AccessFlags ofMethod(int mask) {
|
|
||||||
return new AccessFlagsImpl(AccessFlag.Location.METHOD, mask);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* {@return an {@linkplain AccessFlags} for a method}
|
|
||||||
* @param flags the flags to be set
|
|
||||||
*/
|
|
||||||
static AccessFlags ofMethod(AccessFlag... flags) {
|
|
||||||
return new AccessFlagsImpl(AccessFlag.Location.METHOD, flags);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,8 @@ import java.util.function.Consumer;
|
|||||||
|
|
||||||
import java.lang.classfile.constantpool.ClassEntry;
|
import java.lang.classfile.constantpool.ClassEntry;
|
||||||
import java.lang.classfile.constantpool.Utf8Entry;
|
import java.lang.classfile.constantpool.Utf8Entry;
|
||||||
|
|
||||||
|
import jdk.internal.classfile.impl.AccessFlagsImpl;
|
||||||
import jdk.internal.classfile.impl.ChainedClassBuilder;
|
import jdk.internal.classfile.impl.ChainedClassBuilder;
|
||||||
import jdk.internal.classfile.impl.DirectClassBuilder;
|
import jdk.internal.classfile.impl.DirectClassBuilder;
|
||||||
import jdk.internal.classfile.impl.Util;
|
import jdk.internal.classfile.impl.Util;
|
||||||
@ -73,7 +75,7 @@ public sealed interface ClassBuilder
|
|||||||
* @return this builder
|
* @return this builder
|
||||||
*/
|
*/
|
||||||
default ClassBuilder withFlags(int flags) {
|
default ClassBuilder withFlags(int flags) {
|
||||||
return with(AccessFlags.ofClass(flags));
|
return with(new AccessFlagsImpl(AccessFlag.Location.CLASS, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -82,7 +84,7 @@ public sealed interface ClassBuilder
|
|||||||
* @return this builder
|
* @return this builder
|
||||||
*/
|
*/
|
||||||
default ClassBuilder withFlags(AccessFlag... flags) {
|
default ClassBuilder withFlags(AccessFlag... flags) {
|
||||||
return with(AccessFlags.ofClass(flags));
|
return with(new AccessFlagsImpl(AccessFlag.Location.CLASS, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -26,6 +26,8 @@
|
|||||||
package java.lang.classfile;
|
package java.lang.classfile;
|
||||||
|
|
||||||
import java.lang.classfile.constantpool.Utf8Entry;
|
import java.lang.classfile.constantpool.Utf8Entry;
|
||||||
|
|
||||||
|
import jdk.internal.classfile.impl.AccessFlagsImpl;
|
||||||
import jdk.internal.classfile.impl.ChainedFieldBuilder;
|
import jdk.internal.classfile.impl.ChainedFieldBuilder;
|
||||||
import jdk.internal.classfile.impl.TerminalFieldBuilder;
|
import jdk.internal.classfile.impl.TerminalFieldBuilder;
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
@ -55,7 +57,7 @@ public sealed interface FieldBuilder
|
|||||||
* @return this builder
|
* @return this builder
|
||||||
*/
|
*/
|
||||||
default FieldBuilder withFlags(int flags) {
|
default FieldBuilder withFlags(int flags) {
|
||||||
return with(AccessFlags.ofField(flags));
|
return with(new AccessFlagsImpl(AccessFlag.Location.FIELD, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -64,7 +66,7 @@ public sealed interface FieldBuilder
|
|||||||
* @return this builder
|
* @return this builder
|
||||||
*/
|
*/
|
||||||
default FieldBuilder withFlags(AccessFlag... flags) {
|
default FieldBuilder withFlags(AccessFlag... flags) {
|
||||||
return with(AccessFlags.ofField(flags));
|
return with(new AccessFlagsImpl(AccessFlag.Location.FIELD, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -28,6 +28,8 @@ package java.lang.classfile;
|
|||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
import java.lang.classfile.constantpool.Utf8Entry;
|
import java.lang.classfile.constantpool.Utf8Entry;
|
||||||
|
|
||||||
|
import jdk.internal.classfile.impl.AccessFlagsImpl;
|
||||||
import jdk.internal.classfile.impl.ChainedMethodBuilder;
|
import jdk.internal.classfile.impl.ChainedMethodBuilder;
|
||||||
import jdk.internal.classfile.impl.TerminalMethodBuilder;
|
import jdk.internal.classfile.impl.TerminalMethodBuilder;
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
@ -55,7 +57,7 @@ public sealed interface MethodBuilder
|
|||||||
* @return this builder
|
* @return this builder
|
||||||
*/
|
*/
|
||||||
default MethodBuilder withFlags(int flags) {
|
default MethodBuilder withFlags(int flags) {
|
||||||
return with(AccessFlags.ofMethod(flags));
|
return with(new AccessFlagsImpl(AccessFlag.Location.METHOD, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -64,7 +66,7 @@ public sealed interface MethodBuilder
|
|||||||
* @return this builder
|
* @return this builder
|
||||||
*/
|
*/
|
||||||
default MethodBuilder withFlags(AccessFlag... flags) {
|
default MethodBuilder withFlags(AccessFlag... flags) {
|
||||||
return with(AccessFlags.ofMethod(flags));
|
return with(new AccessFlagsImpl(AccessFlag.Location.METHOD, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
*/
|
*/
|
||||||
package jdk.internal.classfile.impl;
|
package jdk.internal.classfile.impl;
|
||||||
|
|
||||||
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
@ -50,7 +51,7 @@ public final class BufferedFieldBuilder
|
|||||||
this.context = context;
|
this.context = context;
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.desc = type;
|
this.desc = type;
|
||||||
this.flags = AccessFlags.ofField();
|
this.flags = new AccessFlagsImpl(AccessFlag.Location.FIELD);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -66,7 +66,7 @@ public final class BufferedMethodBuilder
|
|||||||
this.context = context;
|
this.context = context;
|
||||||
this.name = nameInfo;
|
this.name = nameInfo;
|
||||||
this.desc = typeInfo;
|
this.desc = typeInfo;
|
||||||
this.flags = AccessFlags.ofMethod(flags);
|
this.flags = new AccessFlagsImpl(AccessFlag.Location.METHOD, flags);
|
||||||
this.original = original;
|
this.original = original;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,7 +101,7 @@ public final class ClassImpl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AccessFlags flags() {
|
public AccessFlags flags() {
|
||||||
return AccessFlags.ofClass(reader.flags());
|
return new AccessFlagsImpl(AccessFlag.Location.CLASS, reader.flags());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
*/
|
*/
|
||||||
package jdk.internal.classfile.impl;
|
package jdk.internal.classfile.impl;
|
||||||
|
|
||||||
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
@ -48,7 +49,7 @@ public final class FieldImpl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AccessFlags flags() {
|
public AccessFlags flags() {
|
||||||
return AccessFlags.ofField(reader.readU2(startPos));
|
return new AccessFlagsImpl(AccessFlag.Location.FIELD, reader.readU2(startPos));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -28,6 +28,7 @@ import java.lang.constant.MethodTypeDesc;
|
|||||||
import java.lang.classfile.*;
|
import java.lang.classfile.*;
|
||||||
import java.lang.classfile.constantpool.Utf8Entry;
|
import java.lang.classfile.constantpool.Utf8Entry;
|
||||||
|
|
||||||
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
@ -51,7 +52,7 @@ public final class MethodImpl
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AccessFlags flags() {
|
public AccessFlags flags() {
|
||||||
return AccessFlags.ofMethod(reader.readU2(startPos));
|
return new AccessFlagsImpl(AccessFlag.Location.METHOD, reader.readU2(startPos));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2007, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2007, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -25,10 +25,12 @@
|
|||||||
|
|
||||||
package com.sun.tools.javap;
|
package com.sun.tools.javap;
|
||||||
|
|
||||||
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.EnumSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
@ -149,7 +151,7 @@ public class ClassWriter extends BasicWriter {
|
|||||||
indent(-1);
|
indent(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
writeModifiers(getClassModifiers(cm.flags().flagsMask()));
|
writeModifiers(getClassModifiers(cm.flags()));
|
||||||
|
|
||||||
if ((classModel.flags().flagsMask() & ACC_MODULE) != 0) {
|
if ((classModel.flags().flagsMask() & ACC_MODULE) != 0) {
|
||||||
var attr = classModel.findAttribute(Attributes.module());
|
var attr = classModel.findAttribute(Attributes.module());
|
||||||
@ -210,7 +212,7 @@ public class ClassWriter extends BasicWriter {
|
|||||||
println("minor version: " + classModel.minorVersion());
|
println("minor version: " + classModel.minorVersion());
|
||||||
println("major version: " + classModel.majorVersion());
|
println("major version: " + classModel.majorVersion());
|
||||||
writeList(String.format("flags: (0x%04x) ", cm.flags().flagsMask()),
|
writeList(String.format("flags: (0x%04x) ", cm.flags().flagsMask()),
|
||||||
getClassFlags(cm.flags().flagsMask()), "\n");
|
getClassFlags(cm.flags()), "\n");
|
||||||
print("this_class: #");print(() -> classModel.thisClass().index());
|
print("this_class: #");print(() -> classModel.thisClass().index());
|
||||||
tab();
|
tab();
|
||||||
print(() -> "// " + classModel.thisClass().asInternalName());
|
print(() -> "// " + classModel.thisClass().asInternalName());
|
||||||
@ -416,7 +418,7 @@ public class ClassWriter extends BasicWriter {
|
|||||||
if (!options.checkAccess(f.flags().flagsMask()))
|
if (!options.checkAccess(f.flags().flagsMask()))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
var flags = AccessFlags.ofField(f.flags().flagsMask());
|
var flags = f.flags();
|
||||||
writeModifiers(flagsReportUnknown(flags).stream().filter(fl -> fl.sourceModifier())
|
writeModifiers(flagsReportUnknown(flags).stream().filter(fl -> fl.sourceModifier())
|
||||||
.map(fl -> Modifier.toString(fl.mask())).toList());
|
.map(fl -> Modifier.toString(fl.mask())).toList());
|
||||||
print(() -> sigPrinter.print(
|
print(() -> sigPrinter.print(
|
||||||
@ -794,9 +796,16 @@ public class ClassWriter extends BasicWriter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Set<String> getClassModifiers(int mask) {
|
private Set<String> getClassModifiers(AccessFlags flags) {
|
||||||
return getModifiers(flagsReportUnknown(AccessFlags.ofClass((mask & ACC_INTERFACE) != 0
|
var flagSet = flagsReportUnknown(flags);
|
||||||
? mask & ~ACC_ABSTRACT : mask)));
|
Set<AccessFlag> set;
|
||||||
|
if (flagSet.contains(AccessFlag.INTERFACE)) {
|
||||||
|
set = EnumSet.copyOf(flagSet);
|
||||||
|
set.remove(AccessFlag.ABSTRACT);
|
||||||
|
} else {
|
||||||
|
set = flagSet;
|
||||||
|
}
|
||||||
|
return getModifiers(set);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Set<String> getModifiers(Set<java.lang.reflect.AccessFlag> flags) {
|
private static Set<String> getModifiers(Set<java.lang.reflect.AccessFlag> flags) {
|
||||||
@ -806,16 +815,8 @@ public class ClassWriter extends BasicWriter {
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Set<String> getClassFlags(int mask) {
|
private Set<String> getClassFlags(AccessFlags flags) {
|
||||||
return getFlags(mask, flagsReportUnknown(AccessFlags.ofClass(mask)));
|
return getFlags(flags.flagsMask(), flagsReportUnknown(flags));
|
||||||
}
|
|
||||||
|
|
||||||
private Set<String> getMethodFlags(int mask) {
|
|
||||||
return getFlags(mask, flagsReportUnknown(AccessFlags.ofMethod(mask)));
|
|
||||||
}
|
|
||||||
|
|
||||||
private Set<String> getFieldFlags(int mask) {
|
|
||||||
return getFlags(mask, flagsReportUnknown(AccessFlags.ofField(mask)));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Set<String> getFlags(int mask, Set<java.lang.reflect.AccessFlag> flags) {
|
private static Set<String> getFlags(int mask, Set<java.lang.reflect.AccessFlag> flags) {
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -26,6 +26,9 @@
|
|||||||
* @summary Testing ClassFile AccessFlags.
|
* @summary Testing ClassFile AccessFlags.
|
||||||
* @run junit AccessFlagsTest
|
* @run junit AccessFlagsTest
|
||||||
*/
|
*/
|
||||||
|
import java.lang.classfile.ClassFile;
|
||||||
|
import java.lang.constant.ClassDesc;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -34,6 +37,10 @@ import java.util.function.Function;
|
|||||||
import java.util.function.IntFunction;
|
import java.util.function.IntFunction;
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.lang.classfile.AccessFlags;
|
import java.lang.classfile.AccessFlags;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
|
import static java.lang.constant.ConstantDescs.CD_int;
|
||||||
|
import static java.lang.constant.ConstantDescs.MTD_void;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.params.provider.EnumSource;
|
import org.junit.jupiter.params.provider.EnumSource;
|
||||||
@ -45,15 +52,38 @@ class AccessFlagsTest {
|
|||||||
@EnumSource(names = { "CLASS", "METHOD", "FIELD" })
|
@EnumSource(names = { "CLASS", "METHOD", "FIELD" })
|
||||||
void testRandomAccessFlagsConverions(AccessFlag.Location ctx) {
|
void testRandomAccessFlagsConverions(AccessFlag.Location ctx) {
|
||||||
IntFunction<AccessFlags> intFactory = switch (ctx) {
|
IntFunction<AccessFlags> intFactory = switch (ctx) {
|
||||||
case CLASS -> AccessFlags::ofClass;
|
case CLASS -> v -> {
|
||||||
case METHOD -> AccessFlags::ofMethod;
|
var bytes = ClassFile.of().build(ClassDesc.of("Test"), clb -> clb.withFlags(v));
|
||||||
case FIELD -> AccessFlags::ofField;
|
return ClassFile.of().parse(bytes).flags();
|
||||||
|
};
|
||||||
|
case METHOD -> v -> {
|
||||||
|
var bytes = ClassFile.of().build(ClassDesc.of("Test"), clb ->
|
||||||
|
clb.withMethod("test", MTD_void, v & ACC_STATIC, mb -> mb.withFlags(v)));
|
||||||
|
return ClassFile.of().parse(bytes).methods().getFirst().flags();
|
||||||
|
};
|
||||||
|
case FIELD -> v -> {
|
||||||
|
var bytes = ClassFile.of().build(ClassDesc.of("Test"), clb ->
|
||||||
|
clb.withField("test", CD_int, fb -> fb.withFlags(v)));
|
||||||
|
return ClassFile.of().parse(bytes).fields().getFirst().flags();
|
||||||
|
};
|
||||||
default -> null;
|
default -> null;
|
||||||
};
|
};
|
||||||
Function<AccessFlag[], AccessFlags> flagsFactory = switch (ctx) {
|
Function<AccessFlag[], AccessFlags> flagsFactory = switch (ctx) {
|
||||||
case CLASS -> AccessFlags::ofClass;
|
case CLASS -> v -> {
|
||||||
case METHOD -> AccessFlags::ofMethod;
|
var bytes = ClassFile.of().build(ClassDesc.of("Test"), clb -> clb.withFlags(v));
|
||||||
case FIELD -> AccessFlags::ofField;
|
return ClassFile.of().parse(bytes).flags();
|
||||||
|
};
|
||||||
|
case METHOD -> v -> {
|
||||||
|
boolean hasStatic = Arrays.stream(v).anyMatch(f -> f == AccessFlag.STATIC);
|
||||||
|
var bytes = ClassFile.of().build(ClassDesc.of("Test"), clb ->
|
||||||
|
clb.withMethod("test", MTD_void, hasStatic ? ACC_STATIC : 0, mb -> mb.withFlags(v)));
|
||||||
|
return ClassFile.of().parse(bytes).methods().getFirst().flags();
|
||||||
|
};
|
||||||
|
case FIELD -> v -> {
|
||||||
|
var bytes = ClassFile.of().build(ClassDesc.of("Test"), clb ->
|
||||||
|
clb.withField("test", CD_int, fb -> fb.withFlags(v)));
|
||||||
|
return ClassFile.of().parse(bytes).fields().getFirst().flags();
|
||||||
|
};
|
||||||
default -> null;
|
default -> null;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -72,11 +102,11 @@ class AccessFlagsTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testInvalidFlagsUse() {
|
void testInvalidFlagsUse() {
|
||||||
assertAll(
|
ClassFile.of().build(ClassDesc.of("Test"), clb -> {
|
||||||
() -> assertThrowsForInvalidFlagsUse(AccessFlags::ofClass),
|
assertThrowsForInvalidFlagsUse(clb::withFlags);
|
||||||
() -> assertThrowsForInvalidFlagsUse(AccessFlags::ofField),
|
clb.withMethod("test", MTD_void, ACC_STATIC, mb -> assertThrowsForInvalidFlagsUse(mb::withFlags));
|
||||||
() -> assertThrowsForInvalidFlagsUse(AccessFlags::ofMethod)
|
clb.withField("test", CD_int, fb -> assertThrowsForInvalidFlagsUse(fb::withFlags));
|
||||||
);
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void assertThrowsForInvalidFlagsUse(Consumer<AccessFlag[]> factory) {
|
void assertThrowsForInvalidFlagsUse(Consumer<AccessFlag[]> factory) {
|
||||||
|
@ -28,7 +28,6 @@
|
|||||||
* @run junit BuilderBlockTest
|
* @run junit BuilderBlockTest
|
||||||
*/
|
*/
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.classfile.Attributes;
|
import java.lang.classfile.Attributes;
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
import java.lang.classfile.ClassTransform;
|
import java.lang.classfile.ClassTransform;
|
||||||
@ -53,6 +52,8 @@ import helpers.ByteArrayClassLoader;
|
|||||||
import jdk.internal.classfile.impl.LabelImpl;
|
import jdk.internal.classfile.impl.LabelImpl;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.CD_int;
|
import static java.lang.constant.ConstantDescs.CD_int;
|
||||||
import static java.lang.constant.ConstantDescs.CD_void;
|
import static java.lang.constant.ConstantDescs.CD_void;
|
||||||
|
|
||||||
@ -116,7 +117,7 @@ class BuilderBlockTest {
|
|||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> xb.iload(0)
|
mb -> mb.withCode(xb -> xb.iload(0)
|
||||||
.ifThen(xxb -> xxb.iconst_1().ireturn())
|
.ifThen(xxb -> xxb.iconst_1().ireturn())
|
||||||
.iconst_2()
|
.iconst_2()
|
||||||
@ -135,7 +136,7 @@ class BuilderBlockTest {
|
|||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> xb.iload(0)
|
mb -> mb.withCode(xb -> xb.iload(0)
|
||||||
.ifThenElse(xxb -> xxb.iconst_1().ireturn(),
|
.ifThenElse(xxb -> xxb.iconst_1().ireturn(),
|
||||||
xxb -> xxb.iconst_2().ireturn())));
|
xxb -> xxb.iconst_2().ireturn())));
|
||||||
@ -153,7 +154,7 @@ class BuilderBlockTest {
|
|||||||
ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> {
|
mb -> mb.withCode(xb -> {
|
||||||
xb.iload(0);
|
xb.iload(0);
|
||||||
xb.iload(1);
|
xb.iload(1);
|
||||||
@ -173,7 +174,7 @@ class BuilderBlockTest {
|
|||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> xb.iload(0)
|
mb -> mb.withCode(xb -> xb.iload(0)
|
||||||
.ifThenElse(xxb -> xxb.iconst_1().istore(2),
|
.ifThenElse(xxb -> xxb.iconst_1().istore(2),
|
||||||
xxb -> xxb.iconst_2().istore(2))
|
xxb -> xxb.iconst_2().istore(2))
|
||||||
@ -193,7 +194,7 @@ class BuilderBlockTest {
|
|||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> xb.iload(0)
|
mb -> mb.withCode(xb -> xb.iload(0)
|
||||||
.ifThenElse(xxb -> xxb.iconst_1().istore(2).goto_(xxb.breakLabel()),
|
.ifThenElse(xxb -> xxb.iconst_1().istore(2).goto_(xxb.breakLabel()),
|
||||||
xxb -> xxb.iconst_2().istore(2).goto_(xxb.breakLabel()))
|
xxb -> xxb.iconst_2().istore(2).goto_(xxb.breakLabel()))
|
||||||
@ -212,7 +213,7 @@ class BuilderBlockTest {
|
|||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb ->
|
mb -> mb.withCode(xb ->
|
||||||
xb.iload(0)
|
xb.iload(0)
|
||||||
.iload(1)
|
.iload(1)
|
||||||
@ -237,7 +238,7 @@ class BuilderBlockTest {
|
|||||||
ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
ClassFile.of().build(ClassDesc.of("Foo"), cb -> {
|
||||||
cb.withFlags(AccessFlag.PUBLIC);
|
cb.withFlags(AccessFlag.PUBLIC);
|
||||||
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int, CD_int),
|
cb.withMethod("foo", MethodTypeDesc.of(CD_int, CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> {
|
mb -> mb.withCode(xb -> {
|
||||||
xb.iload(0);
|
xb.iload(0);
|
||||||
xb.iload(1);
|
xb.iload(1);
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,7 +27,6 @@
|
|||||||
* @run junit BuilderTryCatchTest
|
* @run junit BuilderTryCatchTest
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
import java.lang.classfile.CodeBuilder;
|
import java.lang.classfile.CodeBuilder;
|
||||||
import java.lang.classfile.CompoundElement;
|
import java.lang.classfile.CompoundElement;
|
||||||
@ -35,6 +34,9 @@ import java.lang.classfile.Opcode;
|
|||||||
import java.lang.classfile.TypeKind;
|
import java.lang.classfile.TypeKind;
|
||||||
import java.lang.classfile.instruction.BranchInstruction;
|
import java.lang.classfile.instruction.BranchInstruction;
|
||||||
import java.lang.classfile.instruction.ExceptionCatch;
|
import java.lang.classfile.instruction.ExceptionCatch;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
@ -43,7 +45,6 @@ import java.lang.constant.MethodTypeDesc;
|
|||||||
import java.lang.invoke.MethodHandle;
|
import java.lang.invoke.MethodHandle;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.lang.invoke.MethodType;
|
import java.lang.invoke.MethodType;
|
||||||
import java.lang.reflect.AccessFlag;
|
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -184,7 +185,7 @@ class BuilderTryCatchTest {
|
|||||||
void testEmptyTry() {
|
void testEmptyTry() {
|
||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
||||||
cb.withMethod("main", MethodTypeDesc.of(CD_String, CD_String.arrayType()),
|
cb.withMethod("main", MethodTypeDesc.of(CD_String, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(), mb -> {
|
ACC_PUBLIC | ACC_STATIC, mb -> {
|
||||||
mb.withCode(xb -> {
|
mb.withCode(xb -> {
|
||||||
int stringSlot = xb.allocateLocal(TypeKind.ReferenceType);
|
int stringSlot = xb.allocateLocal(TypeKind.ReferenceType);
|
||||||
xb.loadConstant("S");
|
xb.loadConstant("S");
|
||||||
@ -215,7 +216,7 @@ class BuilderTryCatchTest {
|
|||||||
void testLocalAllocation() throws Throwable {
|
void testLocalAllocation() throws Throwable {
|
||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
||||||
cb.withMethod("main", MethodTypeDesc.of(CD_String, CD_String.arrayType()),
|
cb.withMethod("main", MethodTypeDesc.of(CD_String, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(), mb -> {
|
ACC_PUBLIC | ACC_STATIC, mb -> {
|
||||||
mb.withCode(xb -> {
|
mb.withCode(xb -> {
|
||||||
int stringSlot = xb.allocateLocal(TypeKind.ReferenceType);
|
int stringSlot = xb.allocateLocal(TypeKind.ReferenceType);
|
||||||
xb.loadConstant("S");
|
xb.loadConstant("S");
|
||||||
@ -278,7 +279,7 @@ class BuilderTryCatchTest {
|
|||||||
static byte[] generateTryCatchMethod(Consumer<CodeBuilder.CatchBuilder> c) {
|
static byte[] generateTryCatchMethod(Consumer<CodeBuilder.CatchBuilder> c) {
|
||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
||||||
cb.withMethod("main", MethodTypeDesc.of(CD_String, CD_String.arrayType()),
|
cb.withMethod("main", MethodTypeDesc.of(CD_String, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(), mb -> {
|
ACC_PUBLIC | ACC_STATIC, mb -> {
|
||||||
mb.withCode(xb -> {
|
mb.withCode(xb -> {
|
||||||
int stringSlot = xb.allocateLocal(TypeKind.ReferenceType);
|
int stringSlot = xb.allocateLocal(TypeKind.ReferenceType);
|
||||||
xb.loadConstant("S");
|
xb.loadConstant("S");
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,6 +27,9 @@
|
|||||||
* @run junit LDCTest
|
* @run junit LDCTest
|
||||||
*/
|
*/
|
||||||
import java.lang.constant.ClassDesc;
|
import java.lang.constant.ClassDesc;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.*;
|
import static java.lang.constant.ConstantDescs.*;
|
||||||
import java.lang.constant.MethodTypeDesc;
|
import java.lang.constant.MethodTypeDesc;
|
||||||
|
|
||||||
@ -38,7 +41,6 @@ import static org.junit.jupiter.api.Assertions.*;
|
|||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import static helpers.TestConstants.MTD_VOID;
|
import static helpers.TestConstants.MTD_VOID;
|
||||||
import static java.lang.classfile.Opcode.*;
|
import static java.lang.classfile.Opcode.*;
|
||||||
import static java.lang.classfile.TypeKind.VoidType;
|
|
||||||
import java.lang.classfile.instruction.ConstantInstruction;
|
import java.lang.classfile.instruction.ConstantInstruction;
|
||||||
|
|
||||||
class LDCTest {
|
class LDCTest {
|
||||||
@ -56,7 +58,7 @@ class LDCTest {
|
|||||||
)
|
)
|
||||||
|
|
||||||
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(c0 -> {
|
mb -> mb.withCode(c0 -> {
|
||||||
ConstantPoolBuilder cpb = cb.constantPool();
|
ConstantPoolBuilder cpb = cb.constantPool();
|
||||||
for (int i = 0; i <= 256/2 + 2; i++) { // two entries per String
|
for (int i = 0; i <= 256/2 + 2; i++) { // two entries per String
|
||||||
|
@ -27,6 +27,9 @@
|
|||||||
* @run junit LowAdaptTest
|
* @run junit LowAdaptTest
|
||||||
*/
|
*/
|
||||||
import java.lang.constant.ClassDesc;
|
import java.lang.constant.ClassDesc;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.*;
|
import static java.lang.constant.ConstantDescs.*;
|
||||||
import java.lang.constant.DirectMethodHandleDesc;
|
import java.lang.constant.DirectMethodHandleDesc;
|
||||||
import java.lang.constant.DynamicCallSiteDesc;
|
import java.lang.constant.DynamicCallSiteDesc;
|
||||||
@ -35,7 +38,6 @@ import java.lang.constant.MethodTypeDesc;
|
|||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
|
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.lang.classfile.ClassModel;
|
import java.lang.classfile.ClassModel;
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
@ -75,7 +77,7 @@ class LowAdaptTest {
|
|||||||
cl.methods().forEach(cb::with);
|
cl.methods().forEach(cb::with);
|
||||||
|
|
||||||
cb.withMethod("doit", MethodTypeDesc.of(CD_int, CD_int),
|
cb.withMethod("doit", MethodTypeDesc.of(CD_int, CD_int),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(xb -> {
|
mb -> mb.withCode(xb -> {
|
||||||
xb.invokedynamic(indy);
|
xb.invokedynamic(indy);
|
||||||
xb.astore(1);
|
xb.astore(1);
|
||||||
|
@ -35,13 +35,10 @@ import java.io.*;
|
|||||||
import java.lang.constant.ClassDesc;
|
import java.lang.constant.ClassDesc;
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.classfile.Attributes;
|
import java.lang.classfile.Attributes;
|
||||||
import java.lang.classfile.attribute.SourceFileAttribute;
|
import java.lang.classfile.attribute.SourceFileAttribute;
|
||||||
import java.lang.classfile.constantpool.ConstantPoolBuilder;
|
import java.lang.classfile.constantpool.ConstantPoolBuilder;
|
||||||
@ -58,11 +55,10 @@ import static helpers.TestConstants.MTD_INT_VOID;
|
|||||||
import static helpers.TestConstants.MTD_VOID;
|
import static helpers.TestConstants.MTD_VOID;
|
||||||
import static helpers.TestUtil.ExpectedLvRecord;
|
import static helpers.TestUtil.ExpectedLvRecord;
|
||||||
import static helpers.TestUtil.ExpectedLvtRecord;
|
import static helpers.TestUtil.ExpectedLvtRecord;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.*;
|
import static java.lang.constant.ConstantDescs.*;
|
||||||
import java.lang.constant.MethodTypeDesc;
|
import java.lang.constant.MethodTypeDesc;
|
||||||
import static java.lang.classfile.Opcode.*;
|
|
||||||
import static java.lang.classfile.Opcode.INVOKEVIRTUAL;
|
|
||||||
import static java.lang.classfile.TypeKind.VoidType;
|
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
class LvtTest {
|
class LvtTest {
|
||||||
@ -128,7 +124,7 @@ class LvtTest {
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb
|
mb -> mb
|
||||||
.withCode(c0 -> {
|
.withCode(c0 -> {
|
||||||
ConstantPoolBuilder cpb = cb.constantPool();
|
ConstantPoolBuilder cpb = cb.constantPool();
|
||||||
@ -243,7 +239,7 @@ class LvtTest {
|
|||||||
)
|
)
|
||||||
|
|
||||||
.withMethod("m", MethodTypeDesc.of(CD_Object, CD_Object.arrayType()),
|
.withMethod("m", MethodTypeDesc.of(CD_Object, CD_Object.arrayType()),
|
||||||
ClassFile.ACC_PUBLIC,
|
ACC_PUBLIC,
|
||||||
mb -> mb.withFlags(AccessFlag.PUBLIC)
|
mb -> mb.withFlags(AccessFlag.PUBLIC)
|
||||||
.withCode(c0 -> {
|
.withCode(c0 -> {
|
||||||
ConstantPoolBuilder cpb = cb.constantPool();
|
ConstantPoolBuilder cpb = cb.constantPool();
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,18 +27,19 @@
|
|||||||
* @run junit OneToOneTest
|
* @run junit OneToOneTest
|
||||||
*/
|
*/
|
||||||
import java.lang.constant.ClassDesc;
|
import java.lang.constant.ClassDesc;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.*;
|
import static java.lang.constant.ConstantDescs.*;
|
||||||
import java.lang.constant.MethodTypeDesc;
|
import java.lang.constant.MethodTypeDesc;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.lang.classfile.ClassModel;
|
import java.lang.classfile.ClassModel;
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
import java.lang.classfile.Instruction;
|
import java.lang.classfile.Instruction;
|
||||||
import java.lang.classfile.Label;
|
import java.lang.classfile.Label;
|
||||||
import java.lang.classfile.MethodModel;
|
import java.lang.classfile.MethodModel;
|
||||||
import java.lang.classfile.TypeKind;
|
|
||||||
import java.lang.classfile.attribute.SourceFileAttribute;
|
import java.lang.classfile.attribute.SourceFileAttribute;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
@ -74,7 +75,7 @@ class OneToOneTest {
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.STATIC, AccessFlag.PUBLIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(c0 -> {
|
mb -> mb.withCode(c0 -> {
|
||||||
Label loopTop = c0.newLabel();
|
Label loopTop = c0.newLabel();
|
||||||
Label loopEnd = c0.newLabel();
|
Label loopEnd = c0.newLabel();
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,8 +27,10 @@
|
|||||||
* @run junit SwapTest
|
* @run junit SwapTest
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
|
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
@ -38,9 +40,6 @@ import java.lang.invoke.MethodHandle;
|
|||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.lang.invoke.MethodType;
|
import java.lang.invoke.MethodType;
|
||||||
|
|
||||||
import static java.lang.reflect.AccessFlag.PUBLIC;
|
|
||||||
import static java.lang.reflect.AccessFlag.STATIC;
|
|
||||||
|
|
||||||
class SwapTest {
|
class SwapTest {
|
||||||
@Test
|
@Test
|
||||||
void testTryCatchCatchAll() throws Throwable {
|
void testTryCatchCatchAll() throws Throwable {
|
||||||
@ -48,7 +47,7 @@ class SwapTest {
|
|||||||
MethodTypeDesc mtd = mt.describeConstable().get();
|
MethodTypeDesc mtd = mt.describeConstable().get();
|
||||||
|
|
||||||
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
byte[] bytes = ClassFile.of().build(ClassDesc.of("C"), cb -> {
|
||||||
cb.withMethodBody("m", mtd, AccessFlags.ofMethod(PUBLIC, STATIC).flagsMask(), xb -> {
|
cb.withMethodBody("m", mtd, ACC_PUBLIC | ACC_STATIC, xb -> {
|
||||||
xb.aload(0); // 0
|
xb.aload(0); // 0
|
||||||
xb.aload(1); // 1, 0
|
xb.aload(1); // 1, 0
|
||||||
xb.swap(); // 0, 1
|
xb.swap(); // 0, 1
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,20 +30,16 @@ import java.lang.constant.ClassDesc;
|
|||||||
import java.lang.constant.MethodTypeDesc;
|
import java.lang.constant.MethodTypeDesc;
|
||||||
|
|
||||||
import helpers.TestConstants;
|
import helpers.TestConstants;
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
import java.lang.classfile.TypeKind;
|
|
||||||
import java.lang.classfile.Label;
|
import java.lang.classfile.Label;
|
||||||
import java.lang.classfile.attribute.SourceFileAttribute;
|
import java.lang.classfile.attribute.SourceFileAttribute;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
import static helpers.TestConstants.MTD_VOID;
|
import static helpers.TestConstants.MTD_VOID;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.*;
|
import static java.lang.constant.ConstantDescs.*;
|
||||||
import static java.lang.classfile.Opcode.*;
|
|
||||||
import static java.lang.classfile.TypeKind.IntType;
|
|
||||||
import static java.lang.classfile.TypeKind.ReferenceType;
|
|
||||||
import static java.lang.classfile.TypeKind.VoidType;
|
|
||||||
|
|
||||||
class WriteTest {
|
class WriteTest {
|
||||||
|
|
||||||
@ -61,7 +57,7 @@ class WriteTest {
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(c0 -> {
|
mb -> mb.withCode(c0 -> {
|
||||||
Label loopTop = c0.newLabel();
|
Label loopTop = c0.newLabel();
|
||||||
Label loopEnd = c0.newLabel();
|
Label loopEnd = c0.newLabel();
|
||||||
@ -102,7 +98,7 @@ class WriteTest {
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
.withMethod("main", MethodTypeDesc.of(CD_void, CD_String.arrayType()),
|
||||||
AccessFlags.ofMethod(AccessFlag.PUBLIC, AccessFlag.STATIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(c0 -> {
|
mb -> mb.withCode(c0 -> {
|
||||||
Label loopTop = c0.newLabel();
|
Label loopTop = c0.newLabel();
|
||||||
Label loopEnd = c0.newLabel();
|
Label loopEnd = c0.newLabel();
|
||||||
|
@ -207,7 +207,7 @@ public class ExampleGallery {
|
|||||||
public byte[] changeFieldFlags(ClassModel cm) {
|
public byte[] changeFieldFlags(ClassModel cm) {
|
||||||
return ClassFile.of().transformClass(cm, ClassTransform.transformingFields((fb, fe) -> {
|
return ClassFile.of().transformClass(cm, ClassTransform.transformingFields((fb, fe) -> {
|
||||||
switch (fe) {
|
switch (fe) {
|
||||||
case AccessFlags a -> fb.with(AccessFlags.ofField(a.flagsMask() & ~ClassFile.ACC_PUBLIC & ~ClassFile.ACC_PROTECTED));
|
case AccessFlags a -> fb.withFlags(a.flagsMask() & ~ClassFile.ACC_PUBLIC & ~ClassFile.ACC_PROTECTED);
|
||||||
default -> fb.with(fe);
|
default -> fb.with(fe);
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
@ -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.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -22,7 +22,6 @@
|
|||||||
*/
|
*/
|
||||||
package org.openjdk.bench.jdk.classfile;
|
package org.openjdk.bench.jdk.classfile;
|
||||||
|
|
||||||
import java.lang.classfile.AccessFlags;
|
|
||||||
import java.lang.reflect.AccessFlag;
|
import java.lang.reflect.AccessFlag;
|
||||||
import java.lang.classfile.ClassFile;
|
import java.lang.classfile.ClassFile;
|
||||||
import java.lang.classfile.TypeKind;
|
import java.lang.classfile.TypeKind;
|
||||||
@ -30,6 +29,8 @@ import java.lang.classfile.attribute.SourceFileAttribute;
|
|||||||
import jdk.internal.org.objectweb.asm.*;
|
import jdk.internal.org.objectweb.asm.*;
|
||||||
import org.openjdk.jmh.annotations.*;
|
import org.openjdk.jmh.annotations.*;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_PUBLIC;
|
||||||
|
import static java.lang.classfile.ClassFile.ACC_STATIC;
|
||||||
import static java.lang.constant.ConstantDescs.*;
|
import static java.lang.constant.ConstantDescs.*;
|
||||||
|
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
@ -148,7 +149,7 @@ public class Write {
|
|||||||
);
|
);
|
||||||
for (int xi = 0; xi < 40; ++xi) {
|
for (int xi = 0; xi < 40; ++xi) {
|
||||||
cb.withMethod("main" + ((xi == 0) ? "" : "" + xi), MTD_void_StringArray,
|
cb.withMethod("main" + ((xi == 0) ? "" : "" + xi), MTD_void_StringArray,
|
||||||
AccessFlags.ofMethod(AccessFlag.STATIC, AccessFlag.PUBLIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(c0 -> {
|
mb -> mb.withCode(c0 -> {
|
||||||
java.lang.classfile.Label loopTop = c0.newLabel();
|
java.lang.classfile.Label loopTop = c0.newLabel();
|
||||||
java.lang.classfile.Label loopEnd = c0.newLabel();
|
java.lang.classfile.Label loopEnd = c0.newLabel();
|
||||||
@ -196,7 +197,7 @@ public class Write {
|
|||||||
);
|
);
|
||||||
for (int xi = 0; xi < 40; ++xi) {
|
for (int xi = 0; xi < 40; ++xi) {
|
||||||
cb.withMethod("main" + ((xi == 0) ? "" : "" + xi), MTD_void_StringArray,
|
cb.withMethod("main" + ((xi == 0) ? "" : "" + xi), MTD_void_StringArray,
|
||||||
AccessFlags.ofMethod(AccessFlag.STATIC, AccessFlag.PUBLIC).flagsMask(),
|
ACC_PUBLIC | ACC_STATIC,
|
||||||
mb -> mb.withCode(c0 -> {
|
mb -> mb.withCode(c0 -> {
|
||||||
java.lang.classfile.Label loopTop = c0.newLabel();
|
java.lang.classfile.Label loopTop = c0.newLabel();
|
||||||
java.lang.classfile.Label loopEnd = c0.newLabel();
|
java.lang.classfile.Label loopEnd = c0.newLabel();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user