mirror of
https://github.com/TheLartians/ModernCppStarter.git
synced 2025-08-30 21:51:12 +02:00
Add optional standalone executable directory (#2)
* add standalone executable * update readme * add standalone workflow * fix path
This commit is contained in:
parent
ad1f006762
commit
1dc64084eb
5 changed files with 122 additions and 10 deletions
20
.github/workflows/standalone.yml
vendored
Normal file
20
.github/workflows/standalone.yml
vendored
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
name: Standalone
|
||||||
|
|
||||||
|
on: [push]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v1
|
||||||
|
|
||||||
|
- name: configure
|
||||||
|
run: cmake -Hstandalone -Bbuild
|
||||||
|
|
||||||
|
- name: build
|
||||||
|
run: cmake --build build
|
||||||
|
|
||||||
|
- name: run
|
||||||
|
run: ./build/Greeter
|
|
@ -37,7 +37,6 @@ CPMAddPackage(
|
||||||
|
|
||||||
# Note:
|
# Note:
|
||||||
# for single header libraries use `add_library(Greeter INTERFACE)` instead
|
# for single header libraries use `add_library(Greeter INTERFACE)` instead
|
||||||
# To create an executable use `add_executable(Greeter ${headers} ${sources})`
|
|
||||||
add_library(Greeter ${headers} ${sources})
|
add_library(Greeter ${headers} ${sources})
|
||||||
|
|
||||||
# Note: for single header libraries use the following instead:
|
# Note: for single header libraries use the following instead:
|
||||||
|
|
34
README.md
34
README.md
|
@ -15,7 +15,8 @@ This template is a collection from learnings of previous projects and should all
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
- Modern CMake practices
|
- Modern CMake practices
|
||||||
- Suited for single header libraries and larger projects
|
- Suited for single header libraries and projects of any scale
|
||||||
|
- Separation into library and executable code
|
||||||
- Integrated test suite
|
- Integrated test suite
|
||||||
- Continuous integration via [GitHub Actions](https://help.github.com/en/actions/)
|
- Continuous integration via [GitHub Actions](https://help.github.com/en/actions/)
|
||||||
- Code coverage via [codecov](https://codecov.io)
|
- Code coverage via [codecov](https://codecov.io)
|
||||||
|
@ -27,22 +28,35 @@ This template is a collection from learnings of previous projects and should all
|
||||||
|
|
||||||
### Adjust the template to your needs
|
### Adjust the template to your needs
|
||||||
|
|
||||||
- Use this repo [as a template](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/creating-a-repository-from-a-template) and replace all occurrences of "Greeter" in [both](test/CMakeLists.txt) [CMakeLists.txt](CMakeLists.txt) with the name of your project
|
- Use this repo [as a template](https://help.github.com/en/github/creating-cloning-and-archiving-repositories/creating-a-repository-from-a-template) and replace all occurrences of "Greeter" in the relevant CMakeLists.txt with the name of your project
|
||||||
- Replace the source files with your own
|
- Replace the source files with your own
|
||||||
- For single-header libraries: see the comments in [CMakeLists.txt](CMakeLists.txt)
|
- For single-header libraries: see the comments in [CMakeLists.txt](CMakeLists.txt)
|
||||||
- Add your project's codecov token to your project's github secrets under `CODECOV_TOKEN`
|
- Add your project's codecov token to your project's github secrets under `CODECOV_TOKEN`
|
||||||
- Happy coding!
|
- Happy coding!
|
||||||
|
|
||||||
|
Remember to eventually remove any unused files, such as the standalone directory or irrelevant tests for your project.
|
||||||
|
|
||||||
|
### Build and run the standalone target
|
||||||
|
|
||||||
|
Use the following command to build and run the executable target.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cmake -Hstandalone -Bbuild/standalone
|
||||||
|
cmake --build build/standalone
|
||||||
|
./build/standalone/Greeter --help
|
||||||
|
```
|
||||||
|
|
||||||
### Build and run test suite
|
### Build and run test suite
|
||||||
|
|
||||||
Use the following commands from the project's root directory to run the test suite.
|
Use the following commands from the project's root directory to run the test suite.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
cmake -Htest -Bbuild
|
cmake -Htest -Bbuild/test
|
||||||
cmake --build build
|
cmake --build build/test
|
||||||
CTEST_OUTPUT_ON_FAILURE=1 cmake --build build --target test
|
CTEST_OUTPUT_ON_FAILURE=1 cmake --build build/test --target test
|
||||||
|
|
||||||
# or simply call the executable:
|
# or simply call the executable:
|
||||||
./build/GreeterTests
|
./build/test/GreeterTests
|
||||||
```
|
```
|
||||||
|
|
||||||
To collect code coverage information, run CMake with the `-DENABLE_TEST_COVERAGE=1` option.
|
To collect code coverage information, run CMake with the `-DENABLE_TEST_COVERAGE=1` option.
|
||||||
|
@ -52,11 +66,13 @@ To collect code coverage information, run CMake with the `-DENABLE_TEST_COVERAGE
|
||||||
Use the following commands from the project's root directory to run clang-format (must be installed on the host system).
|
Use the following commands from the project's root directory to run clang-format (must be installed on the host system).
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
cmake -Htest -Bbuild
|
cmake -Htest -Bbuild/test
|
||||||
|
|
||||||
# view changes
|
# view changes
|
||||||
cmake --build build --target format
|
cmake --build build/test --target format
|
||||||
|
|
||||||
# apply changes
|
# apply changes
|
||||||
cmake --build build --target fix-format
|
cmake --build build/test --target fix-format
|
||||||
```
|
```
|
||||||
|
|
||||||
See [Format.cmake](https://github.com/TheLartians/Format.cmake) for more options.
|
See [Format.cmake](https://github.com/TheLartians/Format.cmake) for more options.
|
||||||
|
|
31
standalone/CMakeLists.txt
Normal file
31
standalone/CMakeLists.txt
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
cmake_minimum_required(VERSION 3.5 FATAL_ERROR)
|
||||||
|
|
||||||
|
project(GreeterStandalone
|
||||||
|
LANGUAGES CXX
|
||||||
|
)
|
||||||
|
|
||||||
|
# ---- Dependencies ----
|
||||||
|
|
||||||
|
include(../cmake/CPM.cmake)
|
||||||
|
|
||||||
|
CPMAddPackage(
|
||||||
|
NAME cxxopts
|
||||||
|
GITHUB_REPOSITORY jarro2783/cxxopts
|
||||||
|
VERSION 2.2.0
|
||||||
|
OPTIONS
|
||||||
|
"CXXOPTS_BUILD_EXAMPLES Off"
|
||||||
|
"CXXOPTS_BUILD_TESTS Off"
|
||||||
|
)
|
||||||
|
|
||||||
|
CPMAddPackage(
|
||||||
|
NAME Greeter
|
||||||
|
SOURCE_DIR ${CMAKE_CURRENT_LIST_DIR}/..
|
||||||
|
)
|
||||||
|
|
||||||
|
# ---- Create standalone executable ----
|
||||||
|
|
||||||
|
file(GLOB sources ${CMAKE_CURRENT_SOURCE_DIR}/source/*.cpp)
|
||||||
|
add_executable(GreeterStandalone ${sources})
|
||||||
|
set_target_properties(GreeterStandalone PROPERTIES CXX_STANDARD 17 COMPILE_FLAGS "-Wall -pedantic -Wextra")
|
||||||
|
set_target_properties(GreeterStandalone PROPERTIES OUTPUT_NAME "Greeter")
|
||||||
|
target_link_libraries(GreeterStandalone Greeter cxxopts)
|
46
standalone/source/main.cpp
Normal file
46
standalone/source/main.cpp
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
#include <greeter.h>
|
||||||
|
|
||||||
|
#include <cxxopts.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include <string>
|
||||||
|
#include <unordered_map>
|
||||||
|
|
||||||
|
const std::unordered_map<std::string, greeter::LanguageCode> languages{
|
||||||
|
{"en", greeter::LanguageCode::EN},
|
||||||
|
{"de", greeter::LanguageCode::DE},
|
||||||
|
{"es", greeter::LanguageCode::ES},
|
||||||
|
{"fr", greeter::LanguageCode::FR},
|
||||||
|
};
|
||||||
|
|
||||||
|
int main(int argc, char** argv) {
|
||||||
|
cxxopts::Options options(argv[0], "A program to welcome the world!");
|
||||||
|
|
||||||
|
std::string language;
|
||||||
|
std::string name;
|
||||||
|
|
||||||
|
// clang-format off
|
||||||
|
options.add_options()
|
||||||
|
("h,help", "Show help")
|
||||||
|
("n,name", "Name to greet", cxxopts::value(name)->default_value("World"))
|
||||||
|
("l,lang", "Language code to use", cxxopts::value(language)->default_value("en"))
|
||||||
|
;
|
||||||
|
// clang-format on
|
||||||
|
|
||||||
|
auto result = options.parse(argc, argv);
|
||||||
|
|
||||||
|
if (result["help"].as<bool>()) {
|
||||||
|
std::cout << options.help() << std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto langIt = languages.find(language);
|
||||||
|
if (langIt == languages.end()) {
|
||||||
|
std::cout << "unknown language code: " << language << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
greeter::Greeter greeter(name);
|
||||||
|
std::cout << greeter.greet(langIt->second) << std::endl;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue