1. Field of the Invention
The present invention generally relates to software development. More particularly, the invention is directed to techniques for debugging the source code of a computer program.
2. Description of the Related Art
A programmer usually develops a software program using a text editor to create source code files. From these source code files, an executable program is generated by translating the source code files into an executable program. The process of generating the executable program from the source code usually involves the use of several software programs. For example, a compiler program may be used to generate a set of object code modules from the source code file, and a linker may be used to link the modules together to form the executable program.
It is not uncommon for the source code files of a computer program to include thousands, if not millions, of lines of source code, often spread across many files. Because of this complexity, software programs often contain errors that manifest themselves during program execution (commonly referred to as bugs). Accordingly, a debugging tool has become an essential tool of software development. Typically, a debugger program allows a developer to monitor the execution of a computer program. Doing so assists a programmer in finding and correcting errors. A typical debugging system includes a combination of computer hardware and debugger software that executes the program being debugged in a controlled manner. For example, a user interface provided for the debugger typically allows a user to set breakpoints at lines of code. During program execution, when the executing program encounters a breakpoint, the program ceases executing and turns control over to the debugger, allowing the developer to examine the state of the program at the breakpoint.
Additionally, debuggers often provide a variety of other debugging commands that allow a user to control the execution of a program. For example, one common debugger command allows a user to “step” though lines of source code, executing the program line-by-line. When a user issues a step command, the program executes the machine instructions corresponding to the line of source code based on the current execution point of the program, and advances the execution point to the next line of source code. Step commands typically take one of two forms: step into and step over. A step over command causes the program to execute the current line of code and set the execution point of the program to the next line of source code. If the line of code contains a function call (i.e., it invokes a routine or method defined by the program), then the program executes all of the instructions specified by the function. In contrast, the step into command will set the execution point of the program to the first line of code for the function, allowing a programmer to step through each of the instructions specified by the function.
One common frustration users experience when debugging a program is inadvertently causing the program to execute beyond a desired execution point. For example, this may occur when a user enters a step command causing the program to step over a routine they intended to step into. This is a particularly common experience when using a debugger that includes a type-ahead buffer that buffers step commands. Overstepping a desired execution point is also a problem where a parameter of a function call is itself a function call. In order for a user to step into the function call, a programmer must first step into the function called as a parameter. Another common frustration experienced by programmers occurs when a program must execute for long periods of time before invoking the debugger. If a user issues an untimely step command while debugging the program, the program must be restarted, requiring the programmer to wait until the program again reaches the desired execution point (where the same mistake can again occur).
Accordingly, there remains a need for improved techniques for debugging source code. For example, there remains a need for a debugging system configured to respond to user step commands in a manner that reduces the likelihood that a user will inadvertently case a program being debugged to proceed past a desired execution point.
The present invention generally provides methods for controlling the execution of a program while debugging code. The method generally includes presenting a debugger interface displaying the source code for a program being debugged and an execution point to a user. In one embodiment, the execution point indicates the next line of source code that will be executed. Users interact with the interface to request the debugger to perform actions, such as executing lines of code and setting breakpoints. Additionally, users may specify lines of code at which to override a step over and instead perform a step into command. Further, the debugger may be configured to analyze user activity or the program being debugged to identify locations in the source code where a programmer may prefer to step into a function call, rather than perform a step over operation.
One embodiment provides a method for debugging the source code of a computer program using an interactive debugging system. The method generally includes initiating a debugging session, wherein the debugging session is configured to allow a user to control the step-wise execution of the computer program by issuing step over and step into commands, and selecting a location in the source code at which to override a step over command issued to the debugging system. The method generally further includes, in response to a step over command issued at the selected location, during the subsequent step-wise execution of the computer program, overriding the step over command by performing an alternative action. In various embodiments, the selected location may be identified by a name associated with a function call present in the source code at the selected location, and the selected location may include each line of source code in which the selected function call is present. Alternatively, a user may select a location in the source code by specifying particular lines of source code (e.g., by line number) in the program at which to perform an alternate action to an issued step over command.
In addition to user selected locations, in one embodiment, the method may be configured to identify locations in the source code where a user may wish to have an alternate action performed in response to a step over command. In such a case, the alternate action may include, displaying a prompt, prior to executing the step over command that allows the user to selectively override a step over command. After a brief period, such a prompt may time-out of its own accord.
Another embodiment of the invention provides a computer-readable medium containing a program which when executed by a processor, performs operations for debugging the source code of a computer program using an interactive debugging system. The operations may generally include, initiating a debugging session, wherein the debugging session is configured to allow a user to control the step-wise execution of the computer program by issuing step over and step into commands, selecting a location in the source code at which to override a step over command issued to the debugging system, and in response to a step over command issued at the selected location during the subsequent step-wise execution of the computer program, overriding the step over command by performing an alternative action.
Another embodiment of the invention includes a computing device. The computing device may include a processor, and a memory configured to store an application that includes instructions which, when executed by the processor, cause the processor to provide an interactive debugging system by performing operations. The operations may generally include initiating a debugging session, wherein the debugging session is configured to allow a user to control the step-wise execution of the computer program by issuing step over and step into commands, selecting a location in the source code at which to override a step over command issued to the debugging system, and in response to a step over command issued at the selected location during the subsequent step-wise execution of the computer program, overriding the step over command by performing an alternative action.
So that the manner in which the above recited features, advantages and objects of the present invention are attained and can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to the embodiments thereof; which are illustrated in the appended drawings.
Note, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
Embodiments of the invention generally include a method, computer readable medium, and apparatus that provide a debugging system configured to assist users debugging the source code of a computer program.
One embodiment of the invention provides a method for determining the action a debugger program should take in response to a user step requests. For example, users may specify lines of source code at which to override a step over command, and instead perform a step into command. Doing so may prevent a user from inadvertently issuing a step over command while later using the debugger to step through the code line-by-line.
Additionally, the debugger may be configured to identify locations in the source code of a computer program where a user may desire to step into a function, rather than step over one. For example, the debugger may monitor what function calls were on the stack when an unhandled exception occurred. While subsequently executing the program during a debugging session, the debugger may modify the response to a step over command. For example, a user interface may indicate to a user that a function call at the current execution point corresponds to the point where an unhandled exception occurred during a prior execution of the program. For example, the debugger may display a dialog box allowing a user a step into the current line of source code, rather than a step over it. After a brief period, if the user takes no action the step over is performed. Doing so provides a user with a second chance at executing a step into command for at least some lines of source code.
In the following, reference is made to embodiments of the invention. However, it should be understood that the invention is not limited to specific described embodiments. Instead, any combination of the following features and elements, whether related to different embodiments or not, is contemplated to implement and practice the invention. Furthermore, in various embodiments the invention provides numerous advantages over the prior art. However, although embodiments of the invention may achieve advantages over other possible solutions and/or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the invention. Thus, the following aspects, features, embodiments and advantages are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s). Likewise, reference to “the invention” shall not be construed as a generalization of any inventive subject matter disclosed herein and shall not be considered to be an element or limitation of the appended claims except where explicitly recited in a claim(s).
One embodiment of the invention is implemented as a program product for use with a computer system such as, for example, the commuting environment 100 shown in
In general, the routines executed to implement the embodiments of the invention, may be part of an operating system or a specific application, component, program, module, object, or sequence of instructions. The computer program of the present invention typically is comprised of a multitude of instructions that will be translated by the native computer into a machine-readable format and hence executable instructions. Also, programs are comprised of variables and data structures that either reside locally to the program or are found in memory or on storage devices. In addition, various programs described hereinafter may be identified based upon the application for which they are implemented in a specific embodiment of the invention. However, it should be appreciated that any particular program nomenclature that follows is used merely for convenience, and thus the invention should not be limited to use solely in any specific application identified and/or implied by such nomenclature.
Illustratively, the computer system 110 is shown including a mass storage interface 137 connected to direct access storage device 138, a video interface 140 connected to a display 142, and a network interface 144 connected to computer network 146. The display 142 may be any video output device configured to display visual images to a user of the debugging system disclosed herein. Computer system 110 is shown with at least one processor 112, which obtains instructions and data via a bus 114 from a main memory 116.
The main memory 116 provides a sufficiently large storage area to store the programs and data structures required by the present invention. Main memory 116 could be one or a combination of memory devices, including Random Access Memory, nonvolatile or backup memory, (e.g., programmable or flash memories, read-only memories, etc.). In addition, memory 116 may include memory physically located elsewhere in a computer system 110. For example, memory may include any storage capacity used as virtual memory or stored on a mass storage device or on another computer coupled to the computer system 110 via bus 114.
As shown, the main memory 116 generally includes an operating system 118, a computer program 119 and an Integrated Development Environment (IDE) 120. The computer program 119 represents the program being debugged using IDE 120. Accordingly, the computer 119 may include both the source code for computer program 119, and a machine-readable version of the code executed by processor 112. Illustratively, the IDE 120 includes a compiler 121, an editor 122 and a debugger program (sometimes referred to as ‘she debugger’) 123. More generally, the IDE 120 provides a combination of software programs, data structures, and any associated utilities for editing, compiling and locating, analyzing and correcting errors in the source code of the computer program 119. The IDE 120, however, is merely illustrative.
Further, although the software elements illustrated in
In various embodiments, the debugger 123 may include a number of components. Illustratively, debugger 123 includes a debugger user interface 124, expression evaluator 126, Dcode interpreter 128 (also referred to herein as the debug interpreter 128), debugger hook (also known as a stop or breakpoint handler) 134, a breakpoint manager 135, a results buffer 136, a breakpoint table 150, a step into data table 151, a function call data table 152, and a function call stack 153. Although treated herein as integral components of the debugger 123, one or more of the foregoing components may exist separately in the computer system 110. Further, the debugger 123 may include additional components not shown.
In one embodiment, a user initiates the debugging process by interacting with the user interface 124. The user interface 124 may display the program being debugged and highlight the current execution point of the program 119, relative to the source code. In addition, the interface 124 may display information about other locations within the source code, e.g., breakpoints, step point overrides, or other or other information used to convey the state of the program during a debugging session. The user interface 124 may be configured to allow a user to set control points (e.g., breakpoints, watch points, and alternate step points), display and change values for variables of the program 119, and activate and control other features described herein.
After initiating a debugging session, a user may cause debugger 123 to begin executing program 119. During execution, when a breakpoint is encountered, control is returned to the debugger 123 via the debug hook 134. The debug hook 134 includes instructions returning control to the debugger 123. In one embodiment, the debug hook 134 may be configured to invoke the debug user interface 124 and may pass information about the execution state of program 119 to the interface 124. Alternatively, information may be passed to the results buffer 136 to cache data for the user interface 124. While the debugger has control, a user may issue individual step commands (e.g., step into, and step over), to execute the computer program, one line of code at a time. Additionally, the user may input commands to run a desired debugging routine, inspect the state of data associated with the program being debugged, or perform other debugging actions.
In one embodiment, the GUI 200 includes control elements for issuing debugger commands (e.g., step into and step over commands) and may further include elements for setting watch points, breakpoints, step point overrides, etc. As illustrated, the interface 200 includes four buttons, a start button 210, stop button 211, a step into button 212 and a step over button 213. The start button 210 may be used to resume execution of the program from the current execution point indicated by the arrow 204. The stop button 211 may be used to stop or interrupt the execution of the program 119.
Illustratively, the step into button 212 allows a user to issue a step into command, and step over button 213 allows the user to issue a step over command. As described above, a step into command instructs the debugger to execute the next line of source code, but to step into the first function call (if any) present in the line of source code. In contrast, the step over command instructs the debugger to execute the current line of source code, including any function calls, and pause execution at the next sequential line of source code.
For example, the execution point of the program 119 illustrated in
In one embodiment, however, the behavior of the debugger just described may be modified to account for instances where a user may inadvertently issue a step over command, when a step into is, in fact, desired. Additionally, the debugger 123 may be configured to predict locations within the source code being debugged where a user may desire to step into a function call, rather than step over one. For example, the debugger 123 may be configured to present a user with the opportunity to override a just issued step over command and, instead perform a step into command.
The GUI 200 illustrates breakpoints and alternate step points (i.e., a step point override) specified for the column using the symbols listed in column 205. In one embodiment, a user defines breakpoints and alternate step points by interacting with the debugger interface 124. Illustratively, at line 11, the trap column 205 includes a circle icon (●) used to represents a user-defined breakpoint 206. Accordingly, if a user issues a run command (using button 210) the program 119 would execute until reaching this line. The trap column 205 displays a star icon (*) at line 12, used herein to represent a step point override location. If the user issues a step command at line 12, the debugger overrides this command and instead performs a step into. At line 16, the pound (#) icon 208 is used herein to represent a step point override set by the debugger. Thus, the (*) and (#) icons both represent step point override locations. In one embodiment, however, the debugger 123 distinguishes between a step point override, set by a user with a step point override set by the debugger. The use and operation of the debugger 123 regarding each of these constructs is described in greater detail below. Additionally, the symbols (●, *, and #) used to represent the breakpoint 206 and step points overrides 207 and 208, are arbitrary and used solely to illustrate the present invention.
Additionally, in one embodiment the interface 124 may provide an additional GUI control element to override the override. For example, interface 124 may include an additional step button to perform a step over at a line location for which a step point override has been set, e.g., as indicated by the (*) at line 12 of the source code illustrated in
In one embodiment, the debugger may store information regarding the step point overrides, breakpoints, etc., using a data structure such as a table.
First,
Second,
Finally,
At step 604, the debugger 123 determines if the user is defining the step point override by function name. That is, the debugger 123 determines whether the step point override should be applied to each instance of a function call in program 119. If so, then at step 605, the debugger 123 obtains the function name from the user. The method 600 then continues to step 606, where the debugger 123 retrieves from the function call table 402 the line locations 406 for all records 402 where the function name column 403 matches the function name identified by the user. The method 600 proceeds to step 607 where the debugger 123 records all the line locations retrieved at step 606 into the override step table 500. Finally, the debugger 123 returns to step 602 where it processes the next user action.
At step 604, if the step point override is not being set for each instance of a function call, the debugger 123 assumes that the user is defining the override step point by line number. If so, the debugger 123 continues to step 608, where the debugger 123 obtains the selected line location at which to place the step point override. The method 600 then proceeds to step 609 where the debugger 123 records the line location in table 500. Finally, after completing steps 607 or 609, the debugger 123 returns to step 602 where it processes the next user action. Once a user defines a step point override, any step command issued at the selected line or function will cause the debugger 123 to perform a step into command.
Once a step override is set, if the user issues a step over command for a location where a step point override has been set then, the debugger 123 ignores a step over command and instead performs a step into for the current execution point. For example,
At step 704, when a user issues a step command, the debugger 123 searches the table 500 for a record in which the entry in the line number column matches the current execution point of the program 119 being debugged. If the debugger 123 finds a match, then the debugger 123 continues to step 705, where the debugger 123 performs a step into action. Otherwise, the debugger 123 proceeds to step 707, where the debugger 123 performs a step over action. After performing the appropriate step action, the method 700 returns to step 702, where the debugger 123 continues to process user actions received from the debugger user interface 124.
As described above, in one embodiment, the debugger 123 may be configured to identify locations in the program 119, where a user may be interested in stepping into a function call, rather then stepping over. For example, this may occur for functions that have previously caused the program 119 to crash, or for functions that a user has decided to step into during prior debugging sessions.
When an unmonitored exception occurs, at step 904, the debugger 123 examines a function call stack for the program being debugged. For each routine on a function call stack, the debugger 123 retrieves the line number of the first statement of the routine 906, and enters a record into the breakpoint table 300 that includes the address, op code, and line number of the first statement of the routine. The flag 907 for this record 302 is set to true. After the debugger 123 enters records for all routines on the function call stack 153 into the breakpoint table 300, the debugger 123 proceeds to step 909, where the debugger 123 retrieves the next user action. Then, the debugger 123 returns to step 902 where the debugger 123 processes the user action.
For example, in one embodiment, the debugger 123 will display a prompt 1204 asking the user to confirm the step over command, and informing the user that the prompt will disappear after a specified period of time. In this embodiment, the timeout before the prompt disappears is 2 seconds, but this can be any period of time. If the user presses the step confirm button 1205, or the timeout period elapses, then the prompt will disappear, and the debugger 123 will execute the step over command by executing the line “temp=foo2(foo1( ));” and setting the execution point of the program 119 to line 5. Thus, the step over command will cause all of the instructions defined by both foo2( ) and foo1( ) to be executed. Alternatively, if the user decides to perform a step into the code by pressing the step override button 1206 before the timeout period elapses. In response, the debugger 123 will advance the execution point of the program 119 being debugged to line 16, the first line of the foo1( ) function call.
Embodiments of the invention provide a debugging system configured to detect when a step over command should be interpreted (or overridden) as a step into command. One embodiment allows a user to select functions, routines, or specific source code locations that should be stepped into when encountered. Thus, if the user attempts to issue a normal step command when stopped at a selected location, the resulting action will be a step into rather than a step over. In another embodiment, the debugger may be configured to detect locations in the source code where a step into may be preferred to a step over, e.g., based on user or program patterns, such as which routines where on the call stack when the last unmonitored exception occurred. Based on these patterns a debugger configured according to the present invention flags functions that the user may want to step into. Further, in one embodiment, these debugger selected locations may not automatically override a step over command issued by a user. For example, when a user issues a step function to step over one of these routines the debugger may display a reminder, allowing the user a second chance to step into a routine. After a predetermined amount of time, the second chance may expire and the step over command will be performed.
While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.