Debugging DataFlex Apps
Lesson 4: Locals, Globals, Call Stack windows & useful actions
- The Locals window lists all local variables in the following context…
- Where the Debugger is currently paused
- The method selected in the Call Stack window
- The method selected in the Message Trace window
- Note: Values of local variables can also be altered in the Locals window
data:image/s3,"s3://crabby-images/d5b43/d5b43a2701aa4c50d5d4eb034cbc86bd60555b6e" alt=""
- The Globals Window lists…
- Predefined global variables in packages that are currently compiled the program
- Global variable in the program code
- Note: Values of global variables can also be altered in the Globals window
data:image/s3,"s3://crabby-images/af9de/af9def8da2814d175bd0ea35e7a233dd7bd53494" alt=""
- The Call Stack Window…
- Lists all methods called in the program to reach the current execution point
- With the first method called at the lowest stack level
- With the last method called at the highest/top stack level
- Allows the stepping through of all called methods while examining variables, locals, and so on in that context
- Click on the top stack level to return to where the Debugger is currently paused
data:image/s3,"s3://crabby-images/1bc70/1bc70b787d5c646999cbb6198902fe38c0a6158a" alt=""
data:image/s3,"s3://crabby-images/3f0e5/3f0e5d1a8f059e1f4cb834a085709e45d9e63bce" alt=""
Useful Actions While Debugging
- Step Over: executes the current line of code and pauses on the following line
- Step Into: steps into the method being called on the current line of code
- Step Out: steps out of the current method and returns to the method that called it
- Set Next Instruction: moves the instruction marker to the selected line of code
data:image/s3,"s3://crabby-images/49108/4910801efae427d627513165fccad1b6d8b2c26d" alt=""
- Typically, the instruction marker is only moved within the method currently being worked on because moving outside of the current scope may cause unexpected behavior
data:image/s3,"s3://crabby-images/514ac/514aca84eb601f291f45d4d3b50885c5b6fcc513" alt=""
- Run to Cursor: executes the program to the selected line
- This allows the skipping of several lines of code with having ‘step over’ each one individually, and does stop at enabled breakpoints
- Pause: manually pauses the running program at the next possible opportunity without requiring a breakpoint
- Continue: continues the running program until a breakpoint is encountered or is manually paused
- Restart: stops and restarts the program in debug mode
data:image/s3,"s3://crabby-images/77a21/77a21e978d9a1c401ef39a7c970aa0c2aa98f102" alt=""
Demonstration
The current view shows the source code for the ‘Generate’ button that was navigated to in previous lessons, and it is currently paused where a breakpoint has been added – If (bSpeckOk) Begin
- Selecting the ‘Step Over’ icon from the top toolbar executes the current line of code, and then pauses again on the following line
data:image/s3,"s3://crabby-images/754cb/754cb1c75d020eb5e0ecff1c4f18d334bd0045be" alt=""
data:image/s3,"s3://crabby-images/f3683/f3683310b516dfe7ab5ec6e3aabdb6589aee5b3e" alt=""
- Cursor over any item in the Code Editor for the Debugger to evaluate it
- If it’s a variable the current value will be shown
- Example: bRemoveExistingData
- When initially hovered over, it shows as blank because it has not been initialized
data:image/s3,"s3://crabby-images/6c5f6/6c5f6a4dc414edeb11e8b10a1e83434d709a4e64" alt=""
- Select the ‘Step Over’ icon again to execute the current line containing bRemoveExistingData
- Now when bRemoveExistingData is hovered over its value shows as ‘false’
data:image/s3,"s3://crabby-images/50a3f/50a3f33e04da0095c2e8fa987a1c527f201304e0" alt=""
- The value is also displayed in the Locals window, and it is red because the value has changed since the last time the Debugger was paused
data:image/s3,"s3://crabby-images/04ada/04adab4c3b23c777ae66c27187e22afb60ba4c7b" alt=""
- The value of variables can be edited within the Locals window – bRemoveExistingData can be changed to ‘true’
data:image/s3,"s3://crabby-images/54537/5453795f1e3f75f0737c3a03a09855c6993aafb4" alt=""
- Selecting the ‘Step Over’ icon again causes it to step into the ‘If’ (true) block of code
data:image/s3,"s3://crabby-images/c87c7/c87c7886fb0f75747edb6672cbfbd55552940cbd" alt=""
- If the value had remained false it would have stepped into the ‘Else’ (false) block of code
- To re-execute the if statement using the variable’s original value of ‘false’ …
- Right-click in the left margin next to the line of code that is to be re-executed, and select ‘Set Next Instruction’ to change the current line in the Debugger to that line
data:image/s3,"s3://crabby-images/482ef/482ef82ea8df53195a8304f32214586cab9d8f9b" alt=""
- In the Locals window, change the value of bRemoveExistingData back to ‘false’
- Now selecting the ‘Step Over’ icon again causes it to step into the ‘Else’ (false) block of code
data:image/s3,"s3://crabby-images/11940/11940c269b5d3a21df6f74b3cbd38b1f779fbd27" alt=""
- The next line of code in the program displays a ‘Yes/No’ message box to the user and asks for user input
- If the ‘Step Over’ icon is selected again the execution does not return to the Debugger because the program has displayed the message box, and is awaiting user input
- Selecting ‘Yes’ from the running program results in the Debugger being paused on the next line of code
data:image/s3,"s3://crabby-images/56644/5664461eb2d30df8e587ff914961a2742a42ee20" alt=""
- Hovering over the return value variable, iAnswer, and the constant, MBR_Yes, to see that both values are ‘6’
data:image/s3,"s3://crabby-images/9c61a/9c61a38aca147ed31caa8c199fc85640310f05a4" alt=""
- Stepping over that line to execute the If statement to the next, which calls the DoProcess method of the oOrdersGeneratorBPO object
data:image/s3,"s3://crabby-images/ce5d4/ce5d468a9122e840e3c8d660753c37eb1a31d6d4" alt=""
- Clicking the Step Into icon here moves the execution into the DoProcess method
data:image/s3,"s3://crabby-images/02aa8/02aa86ed0f85c6391c23017d30524496d48bdd75" alt=""
data:image/s3,"s3://crabby-images/0c567/0c56798d76b9d5009dc2bc038299636c7a38477b" alt=""
- Note that the contents of the Locals window have changed to the new context, which is the DoProcess method
data:image/s3,"s3://crabby-images/f32c9/f32c9c0c9563eeb9b5eac07bdb4b0d5a233b0309" alt=""
- The ‘Call Stack’ panel on the right contains the list of nested methods the program has called
data:image/s3,"s3://crabby-images/251f5/251f53862c5b638087d74f5be412677af0638d43" alt=""
- Clicking on any method in the list will cause the context of Debugger and all associated windows will change to that method
- If other methods are viewed, the program will remain paused in DoProcess
- Clicking on the top item in the ‘Call Stack’ will return the view back to where the program is currently paused