On Fri, 24 Mar 2023 06:42:30 GMT, Hannes Greule <d...@openjdk.org> wrote:
>> After merging master into https://github.com/openjdk/jdk/pull/9862, we >> encountered test failures (e.g., >> https://github.com/SirYwell/jdk/actions/runs/4500940829/jobs/7923018438#step:9:2541). >> The Classfile API tries to read from constant pool index 0 if a >> MethodParameters attribute has an entry without name. >> >> The fix is simply using `readUtf8EntryOrNull` instead of `readUtf8Entry`. >> The related code already correctly handles nullability. >> >> I didn't find an appropriate test class so I added a new one. Let me know if >> there's a better place or if the test can be improved somehow. >> >> As I don't have a JBS account, someone needs to create a bug report there >> for me. Thanks. > > Hannes Greule has updated the pull request incrementally with one additional > commit since the last revision: > > Move and fix test comment And just to double-check, the JVMS does allow the parameter name information to be missing even if the access flags are defined: https://docs.oracle.com/javase/specs/jvms/se20/html/jvms-4.html#jvms-4.7.24 > name_index > > The value of the name_index item must either be zero or a valid index > into the constant_pool table. > > If the value of the name_index item is zero, then this parameters element > indicates a formal parameter with no name. > > If the value of the name_index item is nonzero, the constant_pool entry > at that index must be a CONSTANT_Utf8_info structure representing a valid > unqualified name denoting a formal parameter > ([ยง4.2.2](https://docs.oracle.com/javase/specs/jvms/se20/html/jvms-4.html#jvms-4.2.2)). ------------- PR Comment: https://git.openjdk.org/jdk/pull/13167#issuecomment-1483407717