4D v16.3Source Code Pane |
||
|
4D v16.3
Source Code Pane
Source Code Pane
The Source Code Pane shows the source code of the method being traced. If the method is too long to fit in the text area, you can scroll to view other parts of the method. Moving the mouse pointer over any expression that can be evaluated (field, variable, pointer, array,...) will cause a Tool Tip to display the current value of the object or expression and its declared type. Here is an example of the Source Code Pane: A tool tip is displayed because the mouse pointer was over the variable pTable which, according to the tool tip, is a pointer to the table [Customers]. You can also select a portion of the text in the area displaying the code being executed. In this case, when the cursor is placed above the selected text, a tip displays the selected object’s value: When you click on a variable name or field, it is automatically selected. Tip: It is possible to copy any selected expression (that can be evaluated) from the Source Code Pane to the Custom Watch Pane. You can use one of the following ways:
A yellow arrow in the left margin of the Source Code pane (see the figure above) marks the next line that will be executed. This arrow is called the program counter. The program counter always indicates the line that is about to be executed. For debugging purposes, you can change the program counter for the method being on top of the call chain (the method actually being executed). To do so, click and drag the yellow arrow vertically, to the line you want. WARNING: Use this feature with caution! Moving the program counter forward does NOT mean that the debugger is rapidly executing the lines you skip. Similarly, moving the program counter backward does NOT mean that the debugger is reversing the effect of the lines that has already been executed. Moving the program counter simply tells the debugger to “pursue tracing or executing from here.” All current settings, fields, variables, and so on are not affected by the move. Here is an example of moving the program counter. Let’s say you are debugging the following code: ` ... The program counter is set to the line If (This condition). You step once and you see that the program counter moves to the line DO SOMETHING ELSE. This is unfortunate, because you wanted to execute the other alternative of the branch. In this case, and provided that the expression This condition does not perform operations affecting the next steps in your testing, just move the program counter back to the line DO SOMETHING. You can now continuing tracing the part of the code in which you are interested. In the debugging process, you may need to skip the tracing of some parts of the code. The debugger offers you several ways to execute code up to a certain point:
Now, let’s say you are executing the following code, with the program counter set to the line ALL RECORDS([ThisTable]): ` ... Your goal is to evaluate the value of $vrResult after the For loop has been completed. Since it takes quite some execution time to reach this point in your code, you do not want to abort the current execution, then edit the method in order to insert a TRACE call before the line If ($vrResult.... One solution is to step through the loop, however, if the table [ThisTable] contains several hundreds records, you are going to spend the entire day for this operation. In this type of situation, the debugger offers you break points. You can insert break points by clicking in the left margin of the Source Code pane. For example: This inserts a break point for the line. The break point is indicated by a red bullet. Then click the No Trace button. This resumes the normal execution up to the line marked with the break point. That line is not executed itself—you are back to the trace mode. In this example, the whole loop has consequently been executed normally. Then, when reaching the break point, you just need to move the mouse button over $vrResult to evaluate its value at the exit point of the loop. Setting a break point beyond the program counter and clicking the No Trace button allows you to skip portions of the method being traced. Note: You can also set break points directly in 4D's Method Editor. Please refer to the section Break Points. Once you add a break point, it remains associated with the method. Even if you quit the database and then reopen it later on, the break point is still there. There are two ways to eliminate a persistent break point:
The context menu of the Source Code Pane provides access to several functions that are useful when executing methods in Trace mode:
See also
Break Points
|
PROPERTIES
Product: 4D
HISTORY
TAGS debugger source code pane ARTICLE USAGE
4D Language Reference ( 4D v16) |