/koenig-accelerated-cpp-solutions

Solutions to Koenig and Moo's textbook Accelerated C++

Primary LanguageC++GNU General Public License v3.0GPL-3.0

Solutions to Koenig and Moo's textbook Accelerated C++

Solutions and related materials are organized into directories according to book chapter.

Solutions

  • Within a directory, exercises are named according to the scheme exerXX_YY.ZZZ, where XX refers to the chapter number, YY refers to the exercise number, and the ZZZ refers to a file suffix. So for example, exer00_09.cpp is a C++ program written as a solution to chapter 0 exercise 9.

  • Exercises that do not require programming are answered as a text file with a .txt suffix. So for example, exer01_06.txt is a solution to chapter 1 exercise 6 that is provided as an answer in a regular text format.

  • The 0-th exercise in each chapter asks the reader to compile and run the programs presented in the chapter. These exercises are skipped, with the execption of the Hello, World! program (chapter 0 exercise 0).

Test programs

Programming exercises have accompanying test programs.

  • Testing programs are named according to the scheme testXX.YY.sh where XX refers to the chapter number and YY refers to the exercise number. So for example, test10_01.sh tests the program created as a solution for chapter 10, exercise 1.

  • Running the test program will output results from one or more tests as text to stdout. The exit code of the program will be 0 if all of the tests were successful and nonzero if one or more tests fails.

Makefiles

Makefiles are provided for each chapter to aid with compilation and testing (with the exception of chapter 1 which did not include any programming exercises).

  • To compile all of the programs in a directory, simply run make without any arguments while in the directory. For every exercise in the directory that has a program written for it, an executable is created with the form exerXX_YY. So for example, in chapter 0 there were programming exercises for problems 0, 2, 3, 4, 9, and 10. So after running make, the directory chap00 will include the executable files exer00_00, exer00_02, exer00_03, exer00_04, exer00_09, and exer00_10.

  • To compile a single program, run make with the name of the exercise in the form exerXX_YY as an argument while in the directory that the program is located. So for example, running make exer02_09 will compile the program associated with chapter 2 exercise 9 and create an executable called exer02_09.

  • To test all of the programs in a directory, simply run make test while in the directory. This will print a line of output for each program in the directory stating whether or not the program passed all of the tests created for it.

  • To test a single program, you can run make with the name of the test program in the form testXX_YY as an argument while in the directory that the program is located. So for example, running make test05_01 will print a single line of output stating whether or not the program associated with chapter 5 exercise 1 passed all of the tests created for it.

    Doing this essentially calls the appropriate test program and reports whether or not all of the tests in the program passed. However, it suppresses all of the output containing individual test information that is provided by the test program, so it may be preferable to run the corresponding test program directly instead.

  • To remove any object files in a directory created during the compilation process, simply run make clean while in the directory.

  • To remove any object files and any executables in a directory that were created during the compilation process, simply run make clobber while in the directory.