Step through the program
Step Over: F8
Step Into: F7
RustRover provides a set of stepping actions for various debugging strategies (for example, whether you need to go directly to the next line or enter the functions called on your way there).
tip
To avoid cluttering the editor with many tabs during stepping, enable the preview tab. It allows you to view files in a single tab one by one without opening each file in a new tab.
Stepping actions are located on the Debug tool window toolbar and in the menu:
data:image/s3,"s3://crabby-images/646fd/646fd92757dfd4e93dc0855131b834234c6c6283" alt="Stepping actions Stepping actions"
Steps over the current line and takes you to the next line even if the current line includes function calls. The calls are skipped, and you move straight to the next line of the caller.
Click the Step Over button
or press F8.
If there are breakpoints inside the skipped methods, the debugger will stop at them. To skip any breakpoints on the way, use Force step over.
data:image/s3,"s3://crabby-images/280fe/280fe99df803a7308492e847667c9f13e84633f4" alt="Step over takes you to the next line Step over takes you to the next line"
Steps inside the code of a called function.
Click the Step Into button
or press F7.
data:image/s3,"s3://crabby-images/23684/23684a9adfa0b97dba31179bf8a6653209f443c0" alt="Stepping into a called method Stepping into a called method"
If you don't want to step into standard library code (std, core, alloc), in the Settings dialog (CtrlAlt0S) , go to Build, Execution, Deployment | Debugger | Stepping and set the Do not step into stdlib checkbox.
data:image/s3,"s3://crabby-images/052c8/052c816101a11edf6b2b7d17c10edf78b0117218" alt="Stepping into stdlib option Stepping into stdlib option"
Steps out of the current function and takes you to the code of the caller.
Click the Step Out button
or press ShiftF8.
Continues the execution until the position of the caret is reached.
Place the caret at the line where you want the program to pause.
Select Run to Cursor from the
menu or press AltF9.
Also, you can Run to Cursor by hovering over the line and clicking the Run to Cursor icon.
data:image/s3,"s3://crabby-images/ee21e/ee21e7e0ebc6eca599d8e7677e9b29d944dba8cd" alt="Run to cursor with a single click Run to cursor with a single click"
You can configure whether you want Run to Cursor to work on clicking a line number in Settings | Build, Execution, Deployment | Debugger.
To skip any breakpoints on the way, use Force run to cursor.
Steps into the function even if it is skipped by the regular Step Into by default.
Select Force Step Into from the
menu or press AltShiftF7.
In case the source code of the method or function that you want to step into is unavailable, you can debug disassembled code in a dedicated view.
static void count(int to) {
for (int i = 0; i < to; i++) {
// the program is suspended here
System.out.println(i);
}
System.out.println("Complete!");
}
public void println(String x) {
// Force Step Into enters the implementation of PrintStream.println()
if (getClass() == PrintStream.class) {
writeln(String.valueOf(x));
} else {
synchronized (this) {
print(x);
newLine();
}
}
}
Continues the execution until the position of the caret is reached. All breakpoints on the way are ignored.
Place the caret at the line where you want the program to pause.
Select Force Run to Cursor from the
menu or press CtrlAltF9.
Steps over the current line of code and takes you to the next line even if the current line has method calls in it. If there are breakpoints in the called methods, they are ignored.
Select Force Step Over from the
menu or press AltShiftF8.
Thanks for your feedback!