From 33fbc10cb8c869984159230b55ab9f3c9ca039ec Mon Sep 17 00:00:00 2001 From: Guoxiong Li Date: Mon, 11 Jan 2021 13:50:53 +0000 Subject: [PATCH] 8259025: Record compact constructor using Objects.requireNonNull Reviewed-by: attila --- .../classes/com/sun/tools/javac/comp/Attr.java | 2 +- .../javac/records/RecordCompilationTests.java | 14 ++++++++++++-- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java index e56eb9f2c8d..a70f6b1214b 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java @@ -2962,7 +2962,6 @@ public class Attr extends JCTree.Visitor { localEnv.info.isSerializable = true; localEnv.info.isSerializableLambda = true; } - localEnv.info.isLambda = true; List explicitParamTypes = null; if (that.paramKind == JCLambda.ParameterKind.EXPLICIT) { //attribute lambda parameters @@ -3404,6 +3403,7 @@ public class Attr extends JCTree.Visitor { lambdaEnv = env.dup(that, env.info.dup(env.info.scope.dup())); } lambdaEnv.info.yieldResult = null; + lambdaEnv.info.isLambda = true; return lambdaEnv; } diff --git a/test/langtools/tools/javac/records/RecordCompilationTests.java b/test/langtools/tools/javac/records/RecordCompilationTests.java index d7bf4f249b7..0588e6a2143 100644 --- a/test/langtools/tools/javac/records/RecordCompilationTests.java +++ b/test/langtools/tools/javac/records/RecordCompilationTests.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2021, 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 @@ -25,7 +25,7 @@ * RecordCompilationTests * * @test - * @bug 8250629 8252307 8247352 8241151 8246774 + * @bug 8250629 8252307 8247352 8241151 8246774 8259025 * @summary Negative compilation tests, and positive compilation (smoke) tests for records * @library /lib/combo /tools/lib /tools/javac/lib * @modules @@ -343,6 +343,16 @@ public class RecordCompilationTests extends CompilationTestCase { assertOK("import java.util.*; record R(String x, String y) { public R { Objects.requireNonNull(x); Objects.requireNonNull(y); } }"); + // The lambda expressions in the constructor should be compiled successfully. + assertOK(""" + import static java.util.Objects.*; + record R(String v) { + R { + requireNonNull(v, () -> "v must be provided"); + requireNonNullElseGet(v, () -> "w"); + } + }"""); + // Not OK to redeclare canonical without DA assertFail("compiler.err.var.might.not.have.been.initialized", "record R(int x, int y) { # }", "public R(int x, int y) { this.x = x; }");