Step through JDK source code in IntelliJ IDEA

DebuggingIntellij IdeaJava

Debugging Problem Overview


How can I step through JDK source code in IntelliJ IDEA 7 and see the debug info? I can currently hit breakpoints and step through the code, but the debug info is not available. This means I can't see the value of local variables.

I only want to step through the source code of one class, if that matters.
For what it's worth, it's the javax.swing.text.html.HTMLDocument class and I do have a copy of the corresponding .java file.

Debugging Solutions


Solution 1 - Debugging

If you look in [File menu ->] Settings -> Debugger -> Stepping you will see a list "Do not step into these classes", probably with "java.*" listed there. Is that the case? You can turn that off there.

Apparently the debug information is not available. According to this thread:

> Sadly the JDK classes have debug information for parameters and local variable stripped off. > > Years ago I filed a request that Idea should deduce the necessary information from the source code (basically converting variable names to indexes into the methods local var):
Debugger: Show variable information when no debug info > > Please vote/comment. > >As a workaround you can re-compile the JDK from sources, but you need to exclude some classes which do not have all needed source code attached.

Interestingly, you can download the beta version of Java 6u18, which has debug information in it (in the DEBUG bundle).

Solution 2 - Debugging

UPDATE: IntelliJ IDEA 13+ version can provide local variables information without debug info.

Java classes which are part of the JDK are compiled without debug info for the size and performance reasons. If you want debug info in these classes, you'll either need to install a development version of the JDK where the classes are built with the debug info or rebuild the parts of JDK you want to debug from source with the debug info enabled and configure the new JDK with these versions of classes in jars.

This thread provides the instructions how to rebuild JDK classes in rt.jar from the source code with debugging information.

P.S. This question is not specific to IntelliJ IDEA.

Solution 3 - Debugging

  1. Install the JDK
  1. Add src.jar path
  2. Go to: Project Structure (Project Settings) > Platform Settings > SDKs > Sourcepath
  3. Add the path to src.jar * OSX example: /Library/Java/JavaVirtualMachines/1.6.0_45-b06-451.jdk/Contents/Home * Windows example: C:\Program Files\Java\jdk1.7.0_03 (check Program (x86) for 32-bit)
  4. Wait a long time for indexing!
  5. Remove debugger filter
  6. Go to: Settings > Debugger > Stepping
  7. Uncheck the package(s) you want, e.g. javax.*

Solution 4 - Debugging

Along with the "Do not step into these classes" information, the src.jar should be configured. Right-click the project, select "Open Module Settings." Under Platform Settings, select "SDKs." Select the Java SDK version you're using. Select the Sourcepath tab, hit the "+" button, and add your src.jar from the JDK (or the separate source download for the OSX JDK). This will let you open JDK classes and step into them while debugging.

Solution 5 - Debugging

I did this on my Mac to get my Android source code but a similar approach should work for you.

  • File > Project Structure

  • Selected "SDKs" under Platform Settings.

  • Selected "Android SDK"

  • Selected "Sourcepath" tab

  • Pressed "+"

  • Browsed to location of my Java source code

Solution 6 - Debugging

you can find the source code from External Libraries --> rt.jar

Solution 7 - Debugging

setting - compiler - java Compiler - java options, you should check the option "generate debugging info", then, it will compile with debug info.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionPaul ReinersView Question on Stackoverflow
Solution 1 - DebuggingcletusView Answer on Stackoverflow
Solution 2 - DebuggingCrazyCoderView Answer on Stackoverflow
Solution 3 - DebuggingPeter TsengView Answer on Stackoverflow
Solution 4 - Debuggingcodingismy11to7View Answer on Stackoverflow
Solution 5 - DebuggingPeter TheillView Answer on Stackoverflow
Solution 6 - DebuggingilawrenceView Answer on Stackoverflow
Solution 7 - DebuggingheavenView Answer on Stackoverflow