RFR: JDK-8266877: Missing local debug information when debugging JEP-330
Jaroslav Tulach
github.com+26887752+jaroslavtulach at openjdk.java.net
Tue May 11 03:50:12 UTC 2021
On Mon, 10 May 2021 06:09:21 GMT, Alan Bateman <alanb at openjdk.org> wrote:
>> I am polishing support for [JEP-330](https://openjdk.java.net/jeps/330) in NetBeans ([PR-2938](https://github.com/apache/netbeans/pull/2938)) and I have problems with debugging. Local variables aren't visible as the compiler doesn't pass `-g` option when compiling the main class. I'd like to see
>>
>> 
>>
>> however, that requires one to pass `-g` option to the compiler somehow. As far as I can say there is no such way and hence I decided to create this pull request. If I invoke:
>>
>> $ java -agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=y x.java
>>
>> it detects JDWP is on and adds `-g` to the compiler arguments. Is this an acceptable improvement? The alternative is to avoid using JEP-330 when debugging and rather generate `.class` by invoking `javac` and then run it as usual, but I'd rather rely on JEP-330 and avoid creation of the `.class` file.
>
> src/jdk.compiler/share/classes/com/sun/tools/javac/launcher/Main.java line 347:
>
>> 345: if (opt.startsWith("-agentlib:jdwp")) {
>> 346: javacOpts.add("-g");
>> 347: }
>
> The JDWP agent does expose an agent property for tools for the server=y case but it wouldn't be appropriate for the source launcher to look for that. So checking for a CLI option is probably okay, just needs to be "-agentlib:jdwp=" to avoid matching other agents prefixed with "jdwp". Also check for "-Xrunjdwp:" too because -Xrun is still used.
Done in 48ecf90
-------------
PR: https://git.openjdk.java.net/jdk/pull/3939
More information about the compiler-dev
mailing list