Codeblock Steps
Codeblock Steps
| HOME
Step 1: Download
Goto http://www.codeblocks.org/downloads. Click "Download the binary release". Select your operating platform (e.g., Windows 2000/XP/Vista/7). Download the installer with GCC Compiler, e.g.,
codeblocks-13.12mingw-setup.exe (98 MB) (which includes MinGW's GNU GCC compiler and GNU GDB debugger).
Step 2: Install
Verify the Compiler's and Debugger's Path: (For CodeBlocks 13.12 For Windows) Goto "Settings" menu ⇒ "Compiler..." ⇒ In "Selected Compiler", choose "GNU GCC Compiler" ⇒ Select tab
"Toolchain Executables" ⇒ Check the "Compiler's Installation Directory". It shall be set to the "MinGW" sub-directory of the CodeBlocks installation directory, for example, suppose that CodeBlocks
is installed in "c:\Program Files\codeblocks", set it to "c:\Program Files\codeblocks\MinGW".
Similarly, check the debugger's path. Goto "Settings" menu ⇒ "Debugger..." ⇒ Expand "GDB/CDB debugger" ⇒ Select "Default" ⇒ In "Executable path", provide the full-path name of "gdb.exe", for
example, "c:\Program Files\codeblocks\MinGW\bin\gdb.exe".
I encountered problem running debugger with CodeBlocks 13.12 bundled with MinGW (gcc v4.7.1 and gdb 7.5).
I resolved by installing the latast MinGW (gcc 4.8.1, gdb 7.6.1) separately (See "How to install MinGW"), and configured the compiler's and debugger's path to the installed MinGW as in the above
step.
Alternatively, consider using Eclipse or Netbeans with Cygwin or MinGW GNU GCC compiler.
1. CodeBlocks' Wiki @ http://wiki.codeblocks.org/index.php?title=Main_Page, in particular, "Creating a new project" and "Debug my Program".
int main() {
cout << "Hello, world!" << endl;
return 0;
}
Other than the few-line toy programs, you shall create a project for each of your application. A project contains related files such as source codes, header files, and relevant resources. Also, under
CodeBlocks, you can only debug your program under a project - single-file program (in previous section) debugging is not supported.
You can create more projects. However, the "Build" and "Run" commands are always apply to the active project, which is shown in bold. To activate a project: right-click on the project name ⇒
"Activate Project".
Although a project may contain many source files, there can only be one main() function among all the source files. That is, you cannot keep two toy programs (each having a main() function) in one
project (you will get the error "multiple definition of 'main'" when you try to build the project). You need to create one project for each toy program. This is clumsy!
Codeblock, nonetheless, allow you to add files or remove files from a project. The removed files are not deleted and remain in the folder. We could use this feature to write many toy programs under one
project. The procedures are as follows:
1. Create a C/C++ project called "ToyProgramProject" (read previous section on how to create a project). You shall get a "main.cpp" automatically.
2. Write your toy program on "main.cpp". Build and run the program.
3. To write another program: select "File" ⇒ "Save File as" ⇒ enter a program name such as "myfirst.cpp". Remove it from the project (because each project can only have one file with main()), by
right-click on "myfirst.cpp" ⇒ "remove file from project".
4. Continue to write your second toy program on "main.cpp". Build and run.
5. Repeat Step 3 and 4 for another toy program.
6. Suppose that you wish to run "myfirst.cpp" again: First remove "main.cpp" from the project. Right-click on the project ⇒ Add File... ⇒ Choose "myfirst.cpp" ⇒ Open ⇒ Check both the
"Debug" and "Release" box ⇒ OK. You can now build and run the "myfirst.cpp".
In brief, use the "Add File" and "Remove File" to place your desired toy program file (with the main() function) under the active project. You can then "Build" the project and "Run" your toy program.
Check:
1. You downloaded the CodeBlocks with "MinGW GNU C/C++ Compiler" (e.g., "codeblocks-10.05mingw-setup.exe").
2. Goto "Settings" menu ⇒ "Compiler..." ⇒ Select tab "Toolchain Executables" ⇒ Check the "Compiler's Installation Directory". It shall be set to the "MinGW" sub-directory of the CodeBlocks
installation directory, e.g., "c:\Program Files\codeblocks\MinGW" suppose that CodeBlocks is installed in "c:\Program Files\codeblocks".
Cannot Build or Run Program - Build/Run Buttons and Menu-Items are Grey and Not Selectable
A previous program is still running. You need to terminate the program by closing the output console window.
Check that you have a main() function in your function. Check your spelling of main!
Check your scanf() function. You probably omitted the '&' before the variable name.
Follow the steps in "Writing C++ Program (with Project)" to write the following C++ program, to be used for the debugging practice. This program computes and prints the factorial of n
(=1*2*3*...*n). The program, however, has a logical error and produce a wrong answer for n=20. (It outputs "The Factorial of 20 is -2102132736" - a negative number?!).
1 /*
2 * Compute the factorial of n, with n=20.
3 * n! = 1*2*3*...*n
4 */
5 #include <iostream>
6 using namespace std;
7
8 int main() {
9 int n = 20; // To compute factorial of n
10 int factorial = 1; // Initialize the product to 1
11
12 int i = 1;
13 while (i <= n) {
14 factorial = factorial * i;
15 i++;
16 }
17 cout << "The Factorial of " << n << " is " << factorial << endl;
18 return 0;
19 }
Set an initial breakpoint at main() function by clicking on the "left-margin" (right-side of the line number) of the line containing main(). A red circle appears indicating a breakpoint has been set at that
line. A breakpoint suspends program execution for you to examine the internal states.
From "Debug" menu, select "Start (F8)". The program begins execution but suspends its execution at the breakpoint, i.e., main(). An yellow arrow (as shown in the diagram) appears and points at the
main(), indicating this is the next statement to be executed.
Click the "Debugging Windows" button on the "Debug" toolbar and select "Watches" to enable the "Watch" pane. (You could also do it from the "Debug" menu.)
Click the "Next line" button on the "Debug" toolbar to single-step thru your program. At each of the step, you could examine the internal state of your program, such as the value of the variables (in the
"Watches" pane), the outputs produced by your program (in the console), etc.
Single-stepping thru the program and watching the values of the variables and the outputs produced is the ultimate mean in debugging programs - because it is exactly how the computer runs your
program!
As mentioned, a breakpoint suspends program execution and let you examine the internal states of the program. To set a breakpoint on a particular line, click the left-margin of that line (or select
"Toggle Breakpoint (F5)" from "Debug" menu).
The "Continue" resumes the program execution, up to the next breakpoint, or till the end of the program.
Single-stepping thru a loop with a large count is time-consuming. You could set a breakpoint at the statement immediately outside the loop (e.g., Line 12 of the above program), and issue "Continue" to
complete the loop.
Alternatively, you can place the cursor on a particular line, right-click and select "Run-To-Cursor" to resume execution up to this line.
The "Stop" ends the debugging session. Always terminate your current debugging session using "Stop" or "Continue" till the end of the program.
Important: I can's stress more that mastering the use of debugger is crucial in programming. Explore the features provided by the debuggers.
Step-Into and Step-Out: To debug a function, you need to use "Step-Into" to step into the first statement of the function. ("Step-Over" runs the function in a single step without stepping through the
statements inside the function.) You could use "Step-Out" to return to the caller, anywhere within the function. Alternatively, you can set a breakpoint inside a function.
Watching a Variable: To add a variable into the "Watches" panel, goto "Debug" ⇒ "Edit Watch..." ⇒ "Add" ⇒ Enter the variable name ⇒ You can select the format, or "watch as array".
5. Tips and Tweaks
1. Re-format Source Code: Right-click on the source file ⇒ Format this file (AStyle). [Source formatting feature is provided by a plugin called AStyle, which can be accessed via menu "Plugins" ⇒
"Source Code Formatter (AStyle)". To configure the formatting styles, goto "Settings" ⇒ "Editor..." ⇒ "Source Formatter".]
2. Auto-Complete: type the initial letters of a keyword/identifier and press Ctrl-space to list the available options.
3. Abbreviation: e.g., type "for" and press control-J to get the skeleton of for-loop. The abbreviation list can be configured in "Settings" menu ⇒ "Editor..." ⇒ "Abbreviations".
4. Zoom in/out on Editor Panel: Either:
1. From "Edit" menu ⇒ "Special Commands" ⇒ "Zoom" ⇒ "In", "Out", or "Reset", or
2. Hold the control key and zoom in/out via the mouse scroll wheel, or
3. Use keyboard shortcut: control number-pad + (zoom in), control number-pad / (zoom out).
5. Configure Editor: Right-click on the editor panel ⇒ "Configure editor...".
1. Source Formatter: You can choose the "Java" style.
2. [TODO] more
6. [How to link to API documentation?]
Feedback, comments, corrections, and errata can be sent to Chua Hock-Chuan ([email protected]) | HOME