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.