5. Source NavigationΒΆ
Now let’s try to understand a little bit about how the program is working by
looking at the sdc.adb
editor: there’s a loop, the main processing is
done by the functions Process and Next (at line 30).
Click around line 30, move the mouse over Process and let a tool tip appear (Tokens.Process global procedure declared at tokens.ads:19): this gives information about the kind of entity and the location (file and line) of the declaration of this procedure, the profile of the parameters, and documentation for this function, as extracted from the comments surrounding the procedure declaration.
Do the same for Next (Tokens.Next global function declared at tokens.ads:15).
Keeping the mouse over Next, display the contextual menu by clicking on the
right mouse button, then click on Goto declaration of Next: we’re now in the
package Tokens, in file tokens.ads
; but where is this file in the
project?
A simple way to locate a file in the Project view is to use the contextual menu from the source editor: Locate tokens.ads in Project View. You can also enable the Auto Locate File plugin via the Preferences/Plugins: it will automatically locate the current editor’s file in the Project view.
You can also use the filter entry located at the top of the Project view.
Now let’s see another way of navigating among your sources: move the mouse
over the Next identifier in tokens.ads
editor, and then hold the
Control
key: while you’re holding the key, move the mouse over entities:
these entities now become clickable hyperlinks. Clicking on the first mouse
button will go to the declaration of the entity highlighted (or the body if you
are already on the declaration). Alternatively, you can use the contextual
menu and select Goto Body.
We’ve now navigated quite a bit through the application source code, which you can verify by clicking on the left arrow in the tool bar, to go back to the previous locations visited.
Repeat the operation until you’re back in sdc.adb
. As with the
undo/redo capability in the source editor, the goto previous/next location is
infinite.