Skip to content

Latest commit

 

History

History
396 lines (258 loc) · 12.9 KB

GETTING_STARTED.md

File metadata and controls

396 lines (258 loc) · 12.9 KB

Getting Started with Game of Life kata in C++

Prerequisites

  • macOS, Linux or Windows

  • git client

  • curl command line utility

  • a working build environment (Visual Studio, GCC or Clang) for C++ 20

    Details
    • C++ Version

      By default, the kata's CMake file is referencing C++ version 20. We also tested and compiled the code with versions 11, 14 and 17.

      To use a version other than 20, simply modify the line below in the CMake configuration file to reference 11, 14 or 17.

      set(CMAKE_CXX_STANDARD 20)
      
    • Compiler

      When running on Windows, the code is compiled with MSVC.

      On other platforms, the script uses the default C++ compiler set on the machine. Both GCC and Clang are supported.

Getting ready

1 - Clone the kata repository

git clone https://github.com/murex/Kata-GameOfLife.git

2 - Go to the kata's cpp directory

cd Kata-GameOfLife/cpp

3 - Run the build setup script

The kata comes with a setup script to simplify initializing the project.

This setup script does the following:

  • Create a build directory: Kata-GameOfLife/cpp/build. All build-related files are generated under this directory.
  • Download a copy of cmake compatible with your platform.
  • Download the dependencies required to build and test the kata (such as GoogleTest).
  • Generate the solution file Kata-GameOfLife.sln for Visual Studio 2022 on Windows, or the project file Kata-GameOfLife.xcodeproj for Xcode on macOS.
  • Run an initial build and test of the kata to ensure that everything is set up properly.
./cpp_easy_setup.sh

Running the kata

You can run the kata from the command line or from your IDE of choice.

You may also run it using TCR if you want to add a bit of spice.

Running the kata from a terminal with CMake

If you already have CMake 3.21.0 or higher installed on your machine, you can run one of the below commands to build the project.

Reminder: the commands below should be run from Kata-GameOfLife/cpp directory

To build the project:

cmake --build . --config Debug

To run the tests:

ctest --output-on-failure -C Debug

Running the kata from a terminal with TCR

Note to Windows users

Use a git bash terminal for running the command below. Windows CMD and PowerShell are not supported

Reminder: the command below should be run from Kata-GameOfLife/cpp directory

Type the following to start TCR:

./tcrw

Refer to Using TCR section for additional details about TCR and available options.

Running the kata from Visual Studio

Supported Versions: Visual Studio 2022 or later

Open Visual Studio, choose Open a project or solution, navigate to the location containing the cloned kata repository, and open the solution file:

Kata-GameOfLife / cpp / build / Kata-GameOfLife.sln

After loading the solution:

  1. Make sure the 'Kata-GameOfLife-test' project is set as the Start-up Project.
  2. Run the project (press F5 or click on Local Window Debugger in the toolbar).
  3. You can also use the Test Explorer window to run and browse all the executed tests.

Running the kata from Visual Studio with TCR

TCR is provided as a command line utility running in a terminal. You can run it from Visual Studio directly, through leveraging on its built-in terminal.

Notes

  • Supported Versions: Visual Studio 2022 or later
  • Visual Studio 2017 and earlier versions are not supported as they do not have a built-in terminal.

1. Open the kata

Open Visual Studio, choose Open a project or solution, navigate to the location containing the cloned kata repository, and open the solution file:

Kata-GameOfLife / cpp / build / Kata-GameOfLife.sln

2. Configure the built-in terminal to run git bash

Windows Only

Skip this step if you're on macOS or Linux

Visual Studio for Windows is usually set up to run PowerShell by default in its built-in terminal. TCR does not run in PowerShell.

Tools > Options > Environment > Terminal > Add

Parameter Set value to
Name: Git Bash
Shell location: C:\Program Files\Git\bin\bash.exe
Arguments:

The above Shell location value is for a default git installation location. You may need to adjust it in case you have installed git at a different location.

Don't forget to click the Apply button when done.

3. Open a built-in terminal

View > Terminal

If Git Bash is not set as the default environment for Visual Studio built-in terminal, click in the terminal title bar on the dropdown arrow button to the right of title, and select Git Bash from the dropdown list.

4. Launch TCR

Reminder: the command below should be run from Kata-GameOfLife/cpp directory

From the built-in terminal:

./tcrw

Refer to Using TCR section for additional details about TCR and available options.

Running the kata from CLion

Open CLion and select:

File > Open > Kata-GameOfLife > cpp

CLion should automatically build the CMake file.

Run the test file GameOfLifeTest.cpp

The "Run" tool window should display all the executed tests.

Running the kata from CLion with TCR

TCR is provided as a command line utility running in a terminal. You can run it from CLion directly, through leveraging on its built-in terminal.

1. Open the kata

Open CLion and select:

File > Open > Kata-GameOfLife > cpp

2. Turn off auto-save

TCR is constantly watching the filesystem for changes. For this reason you need to turn off CLion's auto-save in order for it to behave as expected.

File > Settings > Appearance & Behavior > System Settings

Under Autosave section, uncheck the 2 following options:

  • Save files if the IDE is idle for ___ seconds
  • Save files when switching to a different application or a built-in terminal

3. Configure the built-in terminal to run git bash

Windows Only

Skip this step if you're on macOS or Linux

CLion for Windows is usually set up to run PowerShell by default in its built-in terminal. TCR does not run in PowerShell.

File > Settings > Tools > Terminal

Under Application Settings section, set the Shell path to C:\Program Files\Git\bin\bash.exe

The above path is for a default git installation location. You may need to adjust it in case you have installed git at a different location.

4. Open a built-in terminal

View > Tool Windows > Terminal

5. Launch TCR

Reminder: the command below should be run from Kata-GameOfLife/cpp directory

From the built-in terminal:

./tcrw

Refer to Using TCR section for additional details about TCR and available options.

Running the kata from Visual Studio Code

Open Visual Studio Code, choose Open Folder, navigate to Kata-GameOfLife / cpp then click Select Folder.

Once the project is opened in Visual Studio Code, click on Build in the bottom toolbar to build the project.

In order to run the tests, select View > Testing, then click on the Play button.

Running the kata from Visual Studio Code with TCR

TCR is provided as a command line utility running in a terminal. You can run it from Visual Studio Code directly, through leveraging on its built-in terminal.

1. Open the kata

Open Visual Studio Code, choose Open Folder, navigate to Kata-GameOfLife / cpp then click Select Folder.

2. Turn off auto-save

TCR is constantly watching the filesystem for changes. For this reason you need to make sure that Visual Studio Code's auto-save is turned off in order for TCR to behave as expected.

File > Preferences > Settings

In Text Editor > Files section, make sure that Auto Save setting is set to off

3. Configure the built-in terminal to run git bash

Windows Only

Skip this step if you're on macOS or Linux

Visual Studio Code for Windows is usually set up to run PowerShell by default in its built-in terminal. TCR does not run in PowerShell.

File > Preferences > Settings

In Features > Terminal section, set External: Windows Exec to C:\Program Files\Git\bin\bash.exe

The above path is for a default git installation location. You may need to adjust it in case you have installed git at a different location.

4. Open a built-in terminal

Terminal > New Terminal

5. Launch TCR

Reminder: the command below should be run from Kata-GameOfLife/cpp directory

From the built-in terminal:

./tcrw

Refer to Using TCR section for additional details about TCR and available options.

Running the kata from Xcode

Open Xcode, choose Open a project or file, navigate to Kata-GameOfLife / cpp / build / Kata-GameOfLife.xcodeproj then click Open.

Once the project is opened in Xcode, select Product / Scheme / Kata-GameOfLife-test to set it as the current active scheme.

Select Product / Run to build the project and run the tests.

Running the kata from Xcode with TCR

TCR is provided as a command line utility running in a terminal.

Xcode does not provide a built-in terminal. You can still use Xcode as an editor while running TCR in a separate terminal window.

1. Open the kata

Open Xcode, choose Open a project or file, navigate to Kata-GameOfLife / cpp / build / Kata-GameOfLife.xcodeproj then click Open.

Once the project is opened in Xcode, select Product / Scheme / Kata-GameOfLife-test to set it as the current active scheme.

No need to build and test from Xcode

TCR takes care of building the project and running the tests. For this reason you should not build and test the project from Xcode when TCR is running. The only thing you should pay attention to is when saving your changes, which will trigger TCR's build and test.

2. Open a terminal

You can use any terminal application available on macOS.

If you're not familiar with terminals, macOS comes with a built-in terminal application available under Applications > Utilities > Terminal.app.

3. Launch TCR

Reminder: the command below should be run from Kata-GameOfLife/cpp directory

From the terminal window:

./tcrw

Refer to Using TCR section for additional details about TCR and available options.

Using TCR

Cheat Sheet

Here are the main shortcuts available once TCR utility is running:

Shortcut Description
o / O Open in browser (with web subcommand only)
d / D Enter driver role
n / N Enter navigator role
t / T Query timer status
p / P Toggle on/off git auto-push
l / L Pull from remote
s / S Push to remote
a / A Abort current command (when in driver role)
q / Q Quit current role / Quit TCR
? List available options

Additional Details

Refer to TCR - Test && Commit || Revert page for additional details and explanations about TCR utility.