aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/cmake
diff options
context:
space:
mode:
authorEgor Tensin <Egor.Tensin@gmail.com>2020-03-28 17:19:43 +0000
committerEgor Tensin <Egor.Tensin@gmail.com>2020-03-28 17:23:15 +0000
commit70da99e4f70845da37ae368c4788ecc18546792d (patch)
tree51f50290e2ea926350c88fa5fa0e8d4d2ad426fa /cmake
parentcommon.cmake: account for ALIAS targets (diff)
downloadcmake-common-70da99e4f70845da37ae368c4788ecc18546792d.tar.gz
cmake-common-70da99e4f70845da37ae368c4788ecc18546792d.zip
WIP: restructure
A stupid attempt to reduce code duplication led me to believe that all the scripts could use _a bit_ of refactoring. This is going to be a major pain (factoring out all the things), which I'll take gladly. All the links and usage examples are broken right now, but nobody cares, so whatevs.
Diffstat (limited to 'cmake')
-rw-r--r--cmake/build/README.md13
-rwxr-xr-xcmake/build/build.py190
-rwxr-xr-xcmake/build/ci/appveyor.py167
-rwxr-xr-xcmake/build/ci/travis.py102
-rw-r--r--cmake/common.cmake225
-rw-r--r--cmake/examples/boost/CMakeLists.txt14
-rw-r--r--cmake/examples/boost/foo.cpp11
-rw-r--r--cmake/examples/dynamic/CMakeLists.txt16
-rw-r--r--cmake/examples/dynamic/baz.cpp7
-rw-r--r--cmake/examples/dynamic/baz.hpp9
-rw-r--r--cmake/examples/dynamic/foo.cpp6
-rw-r--r--cmake/examples/simple/CMakeLists.txt12
-rw-r--r--cmake/examples/simple/foo.cpp6
-rw-r--r--cmake/examples/static/CMakeLists.txt16
-rw-r--r--cmake/examples/static/bar.cpp7
-rw-r--r--cmake/examples/static/bar.hpp3
-rw-r--r--cmake/examples/static/foo.cpp6
-rw-r--r--cmake/toolchains/README.md3
-rw-r--r--cmake/toolchains/gcc-x64.cmake4
-rw-r--r--cmake/toolchains/gcc-x86.cmake4
-rw-r--r--cmake/toolchains/mingw-w64-x64.cmake4
-rw-r--r--cmake/toolchains/mingw-w64-x86.cmake4
22 files changed, 0 insertions, 829 deletions
diff --git a/cmake/build/README.md b/cmake/build/README.md
deleted file mode 100644
index b63564d..0000000
--- a/cmake/build/README.md
+++ /dev/null
@@ -1,13 +0,0 @@
-CMake
-=====
-
-Build a CMake project.
-Consult the output of `build.py --help` for details.
-
-A simple usage example:
-
- > python3 build.py --configuration Release --install path/to/somewhere -- ../examples/simple
- ...
-
- > ./path/to/somewhere/bin/foo
- foo
diff --git a/cmake/build/build.py b/cmake/build/build.py
deleted file mode 100755
index 695489b..0000000
--- a/cmake/build/build.py
+++ /dev/null
@@ -1,190 +0,0 @@
-#!/usr/bin/env python3
-
-# Copyright (c) 2019 Egor Tensin <Egor.Tensin@gmail.com>
-# This file is part of the "cmake-common" project.
-# For details, see https://github.com/egor-tensin/cmake-common.
-# Distributed under the MIT License.
-
-R'''Build a CMake project.
-
-This script is used basically to invoke the CMake executable in a
-cross-platform way (provided the platform has Python 3, of course). The
-motivation was to merge my Travis and AppVeyor build scripts (largely similar,
-but written in bash and PowerShell, respectively).
-
-A simple usage example:
-
- $ %(prog)s --configuration Release --install path/to/somewhere -- ../examples/simple
- ...
-
- $ ./path/to/somewhere/bin/foo
- foo
-
-Picking the target platform is build system-specific. On Visual Studio, pass
-the target platform using the `-A` flag like this:
-
- > %(prog)s --install path\to\somewhere -- ..\examples\simple -A Win32
- ...
-
-Using GCC-like compilers, the best way is to use CMake toolchain files (see
-cmake/toolchains in this repository for examples).
-
- $ %(prog)s --install path/to/somewhere -- ../examples/simple -D CMAKE_TOOLCHAIN_FILE="$( pwd )/../toolchains/mingw-x86.cmake"
- ...
-'''
-
-import argparse
-from contextlib import contextmanager
-import logging
-from enum import Enum
-import os
-import os.path
-import subprocess
-import sys
-import tempfile
-
-
-def _run_executable(cmd_line):
- logging.info('Running executable: %s', cmd_line)
- return subprocess.run(cmd_line, check=True)
-
-
-def _run_cmake(cmake_args):
- _run_executable(['cmake'] + cmake_args)
-
-
-class Configuration(Enum):
- DEBUG = 'Debug'
- MINSIZEREL = 'MinSizeRel'
- RELWITHDEBINFO = 'RelWithDebInfo'
- RELEASE = 'Release'
-
- def __str__(self):
- return self.value
-
-
-def _parse_configuration(s):
- try:
- return Configuration(s)
- except ValueError:
- raise argparse.ArgumentTypeError(f'invalid configuration: {s}')
-
-
-@contextmanager
-def _create_build_dir(args):
- if args.build_dir is not None:
- logging.info('Build directory: %s', args.build_dir)
- yield args.build_dir
- return
-
- with tempfile.TemporaryDirectory(dir=os.path.dirname(args.src_dir)) as build_dir:
- logging.info('Build directory: %s', build_dir)
- try:
- yield build_dir
- finally:
- logging.info('Removing build directory: %s', build_dir)
- return
-
-
-class GenerationPhase:
- def __init__(self, build_dir, args):
- self.build_dir = build_dir
- self.args = args
-
- def _cmake_args(self):
- return self._to_cmake_args(self.build_dir, self.args)
-
- @staticmethod
- def _to_cmake_args(build_dir, args):
- result = []
- if args.install_dir is not None:
- result += ['-D', f'CMAKE_INSTALL_PREFIX={args.install_dir}']
- if args.configuration is not None:
- result += ['-D', f'CMAKE_BUILD_TYPE={args.configuration}']
- if args.cmake_args is not None:
- result += args.cmake_args
- result += [f'-B{build_dir}', f'-H{args.src_dir}']
- return result
-
- def run(self):
- _run_cmake(self._cmake_args())
-
-
-class BuildPhase:
- def __init__(self, build_dir, args):
- self.build_dir = build_dir
- self.args = args
-
- def _cmake_args(self):
- return self._to_cmake_args(self.build_dir, self.args)
-
- @staticmethod
- def _to_cmake_args(build_dir, args):
- result = ['--build', build_dir]
- if args.configuration is not None:
- result += ['--config', str(args.configuration)]
- if args.install_dir is not None:
- result += ['--target', 'install']
- return result
-
- def run(self):
- _run_cmake(self._cmake_args())
-
-
-def _parse_dir(s):
- return os.path.abspath(os.path.normpath(s))
-
-
-def _parse_args(argv=None):
- if argv is None:
- argv = sys.argv[1:]
- logging.info('Command line arguments: %s', argv)
-
- parser = argparse.ArgumentParser(
- description=__doc__,
- formatter_class=argparse.RawDescriptionHelpFormatter)
-
- parser.add_argument('--build', metavar='DIR', dest='build_dir',
- type=_parse_dir,
- help='build directory (temporary directory unless specified)')
- parser.add_argument('--install', metavar='DIR', dest='install_dir',
- type=_parse_dir,
- help='install directory')
- parser.add_argument('--configuration', metavar='CONFIG',
- type=_parse_configuration, default=Configuration.DEBUG,
- help=f'build configuration ({"/".join(map(str, Configuration))})')
- parser.add_argument('src_dir', metavar='DIR',
- type=_parse_dir,
- help='source directory')
- parser.add_argument('cmake_args', nargs='*', metavar='CMAKE_ARG',
- help='additional CMake arguments, to be passed verbatim')
- args = parser.parse_args(argv)
- return args
-
-
-def _setup_logging():
- logging.basicConfig(
- format='%(asctime)s | %(levelname)s | %(message)s',
- level=logging.INFO)
-
-
-def build(argv=None):
- args = _parse_args(argv)
- with _create_build_dir(args) as build_dir:
- gen_phase = GenerationPhase(build_dir, args)
- gen_phase.run()
- build_phase = BuildPhase(build_dir, args)
- build_phase.run()
-
-
-def main(argv=None):
- _setup_logging()
- try:
- build(argv)
- except Exception as e:
- logging.exception(e)
- raise
-
-
-if __name__ == '__main__':
- main()
diff --git a/cmake/build/ci/appveyor.py b/cmake/build/ci/appveyor.py
deleted file mode 100755
index b9141ec..0000000
--- a/cmake/build/ci/appveyor.py
+++ /dev/null
@@ -1,167 +0,0 @@
-#!/usr/bin/env python3
-
-# Copyright (c) 2019 Egor Tensin <Egor.Tensin@gmail.com>
-# This file is part of the "cmake-common" project.
-# For details, see https://github.com/egor-tensin/cmake-common.
-# Distributed under the MIT License.
-
-'''Build a CMake project on AppVeyor.
-
-This is similar to build.py, but auto-fills some parameters for build.py from
-the AppVeyor-defined environment variables.
-
-The project is built in C:\Projects\build.
-'''
-
-import argparse
-from enum import Enum
-import logging
-import os
-import sys
-
-
-class Image(Enum):
- VS_2013 = 'Visual Studio 2013'
- VS_2015 = 'Visual Studio 2015'
- VS_2017 = 'Visual Studio 2017'
- VS_2019 = 'Visual Studio 2019'
-
- def __str__(self):
- return self.value
-
-
-def _parse_image(s):
- try:
- return Image(s)
- except ValueError as e:
- raise ValueError(f'unsupported AppVeyor image: {s}') from e
-
-
-class Generator(Enum):
- VS_2013 = 'Visual Studio 12 2013'
- VS_2015 = 'Visual Studio 14 2015'
- VS_2017 = 'Visual Studio 15 2017'
- VS_2019 = 'Visual Studio 16 2019'
-
- def __str__(self):
- return self.value
-
- @staticmethod
- def from_image(image):
- if image is Image.VS_2013:
- return Generator.VS_2013
- if image is Image.VS_2015:
- return Generator.VS_2015
- if image is Image.VS_2017:
- return Generator.VS_2017
- if image is Image.VS_2019:
- return Generator.VS_2019
- raise RuntimeError(f"don't know which generator to use for image: {image}")
-
-
-class Platform(Enum):
- x86 = 'Win32'
- X64 = 'x64'
-
- def __str__(self):
- return self.value
-
-
-def _parse_platform(s):
- try:
- return Platform(s)
- except ValueError as e:
- raise ValueError(f'unsupported AppVeyor platform: {s}') from e
-
-
-def _env(name):
- if name not in os.environ:
- raise RuntimeError(f'undefined environment variable: {name}')
- return os.environ[name]
-
-
-def _check_appveyor():
- if 'APPVEYOR' not in os.environ:
- raise RuntimeError('not running on AppVeyor')
-
-
-def _get_src_dir():
- return _env('APPVEYOR_BUILD_FOLDER')
-
-
-def _get_build_dir():
- return R'C:\Projects\build'
-
-
-def _get_generator():
- image = _parse_image(_env('APPVEYOR_BUILD_WORKER_IMAGE'))
- return str(Generator.from_image(image))
-
-
-def _get_platform():
- return str(_parse_platform(_env('PLATFORM')))
-
-
-def _get_configuration():
- return _env('CONFIGURATION')
-
-
-def _setup_logging():
- logging.basicConfig(
- format='%(asctime)s | %(levelname)s | %(message)s',
- level=logging.INFO)
-
-
-def _parse_args(argv=None):
- if argv is None:
- argv = sys.argv[1:]
- logging.info('Command line arguments: %s', argv)
-
- parser = argparse.ArgumentParser(
- description=__doc__,
- formatter_class=argparse.RawDescriptionHelpFormatter)
-
- parser.add_argument('--install', metavar='DIR', dest='install_dir',
- help='install directory')
- parser.add_argument('cmake_args', nargs='*', metavar='CMAKE_ARG', default=[],
- help='additional CMake arguments, to be passed verbatim')
- return parser.parse_args(argv)
-
-
-def build_appveyor(argv=None):
- args = _parse_args(argv)
- _check_appveyor()
-
- this_module_dir = os.path.dirname(os.path.abspath(__file__))
- parent_module_dir = os.path.dirname(this_module_dir)
- sys.path.insert(1, parent_module_dir)
- from build import build
-
- appveyor_argv = [
- '--build', _get_build_dir(),
- '--configuration', _get_configuration(),
- ]
- if args.install_dir is not None:
- appveyor_argv += [
- '--install', args.install_dir,
- ]
- appveyor_argv += [
- '--',
- _get_src_dir(),
- '-G', _get_generator(),
- '-A', _get_platform(),
- ]
- build(appveyor_argv + args.cmake_args)
-
-
-def main(argv=None):
- _setup_logging()
- try:
- build_appveyor(argv)
- except Exception as e:
- logging.exception(e)
- raise
-
-
-if __name__ == '__main__':
- main()
diff --git a/cmake/build/ci/travis.py b/cmake/build/ci/travis.py
deleted file mode 100755
index ab93711..0000000
--- a/cmake/build/ci/travis.py
+++ /dev/null
@@ -1,102 +0,0 @@
-#!/usr/bin/env python3
-
-# Copyright (c) 2019 Egor Tensin <Egor.Tensin@gmail.com>
-# This file is part of the "cmake-common" project.
-# For details, see https://github.com/egor-tensin/cmake-common.
-# Distributed under the MIT License.
-
-'''Build a CMake project on Travis.
-
-This is similar to build.py, but auto-fills some parameters for build.py from
-the Travis-defined environment variables.
-
-The project is built in $HOME/build.
-'''
-
-import argparse
-import logging
-import os
-import os.path
-import sys
-
-
-def _env(name):
- if name not in os.environ:
- raise RuntimeError(f'undefined environment variable: {name}')
- return os.environ[name]
-
-
-def _check_travis():
- if 'TRAVIS' not in os.environ:
- raise RuntimeError('not running on Travis')
-
-
-def _get_src_dir():
- return _env('TRAVIS_BUILD_DIR')
-
-
-def _get_build_dir():
- return os.path.join(_env('HOME'), 'build')
-
-
-def _get_configuration():
- return _env('configuration')
-
-
-def _setup_logging():
- logging.basicConfig(
- format='%(asctime)s | %(levelname)s | %(message)s',
- level=logging.INFO)
-
-
-def _parse_args(argv=None):
- if argv is None:
- argv = sys.argv[1:]
- logging.info('Command line arguments: %s', argv)
-
- parser = argparse.ArgumentParser(
- description=__doc__,
- formatter_class=argparse.RawDescriptionHelpFormatter)
-
- parser.add_argument('--install', metavar='DIR', dest='install_dir',
- help='install directory')
- parser.add_argument('cmake_args', nargs='*', metavar='CMAKE_ARG', default=[],
- help='additional CMake arguments, to be passed verbatim')
- return parser.parse_args(argv)
-
-
-def build_travis(argv=None):
- args = _parse_args(argv)
- _check_travis()
-
- this_module_dir = os.path.dirname(os.path.abspath(__file__))
- parent_module_dir = os.path.dirname(this_module_dir)
- sys.path.insert(1, parent_module_dir)
- from build import build
-
- travis_argv = [
- '--build', _get_build_dir(),
- '--configuration', _get_configuration(),
- ]
- if args.install_dir is not None:
- travis_argv += [
- '--install', args.install_dir,
- ]
- travis_argv += [
- '--',
- _get_src_dir(),
- ]
- build(travis_argv + args.cmake_args)
-
-
-def main(argv=None):
- _setup_logging()
- try:
- build_travis(argv)
- except Exception as e:
- logging.exception(e)
- raise
-
-
-if __name__ == '__main__':
- main()
diff --git a/cmake/common.cmake b/cmake/common.cmake
deleted file mode 100644
index 0d813fe..0000000
--- a/cmake/common.cmake
+++ /dev/null
@@ -1,225 +0,0 @@
-# Copyright (c) 2017 Egor Tensin <Egor.Tensin@gmail.com>
-# This file is part of the "cmake-common" project.
-# For details, see https://github.com/egor-tensin/cmake-common.
-# Distributed under the MIT License.
-
-# It's a CMake code snippet I use in all of my CMake projects.
-# It makes targets link the runtime statically by default, strips debug symbols
-# in release builds and sets a couple of useful compilation options.
-
-# Add this to the top-level CMakeLists.txt (unless a higher version has already
-# been specified):
-#
-# cmake_minimum_required(VERSION 3.1)
-
-# Without this policy set, this line:
-#
-# if(toolset STREQUAL "MSVC")
-#
-# evaluates to false even when using Visual Studio (since MSVC is a predefined
-# variable; it's completely bonkers).
-if(NOT POLICY CMP0054)
- message(FATAL_ERROR "common.cmake uses CMP0054, which is unsupported by this CMake version")
-endif()
-cmake_policy(SET CMP0054 NEW)
-
-# Toolset identification:
-
-if(CMAKE_C_COMPILER_ID)
- set(toolset "${CMAKE_C_COMPILER_ID}")
-elseif(CMAKE_CXX_COMPILER_ID)
- set(toolset "${CMAKE_CXX_COMPILER_ID}")
-else()
- set(toolset "unknown")
-endif()
-
-if(toolset STREQUAL "GNU")
- set(is_gcc ON)
-elseif(toolset STREQUAL "MSVC")
- set(is_msvc ON)
-else()
- message(WARNING "Unrecognized toolset: ${toolset}")
-endif()
-
-# User-defined switches:
-
-set(default_value ON)
-get_directory_property(parent_dir PARENT_DIRECTORY)
-if(parent_dir)
- set(default_value OFF)
-endif()
-
-if(NOT DEFINED CC_CXX_STANDARD)
- set(CC_CXX_STANDARD "14" CACHE STRING "C++ standard version")
-endif()
-if(NOT DEFINED CC_BEST_PRACTICES)
- option(CC_BEST_PRACTICES "Set common compiler options" "${default_value}")
-endif()
-if(NOT DEFINED CC_WINDOWS_DEF)
- option(CC_WINDOWS_DEF "Define useful Windows macros" "${default_value}")
-endif()
-if(NOT DEFINED CC_STATIC_RUNTIME)
- set(static_runtime_default_value "${default_value}")
- if(DEFINED Boost_USE_STATIC_LIBS AND NOT Boost_USE_STATIC_LIBS)
- # Linking to dynamic Boost libs and the static runtime is a no-no:
- set(static_runtime_default_value OFF)
- elseif(CMAKE_SYSTEM_NAME STREQUAL "Windows" OR MINGW)
- else()
- # At this point, Linux-like environment & the GNU C Library are assumed.
- set(static_runtime_default_value OFF)
- endif()
- option(CC_STATIC_RUNTIME "Link the runtime statically" "${static_runtime_default_value}")
-endif()
-if(NOT DEFINED CC_STRIP_SYMBOLS)
- option(CC_STRIP_SYMBOLS "Strip debug symbols" "${default_value}")
-endif()
-
-option(Boost_USE_STATIC_LIBS "Use the static Boost libraries" "${default_value}")
-option(Boost_USE_STATIC_RUNTIME "Use Boost libraries linked to the runtime statically" "${CC_STATIC_RUNTIME}")
-
-message(STATUS "Toolset: ${toolset}")
-message(STATUS "C++ standard: ${CC_CXX_STANDARD}")
-message(STATUS "Set common compiler options: ${CC_BEST_PRACTICES}")
-message(STATUS "Define useful Windows macros: ${CC_WINDOWS_DEF}")
-message(STATUS "Use the static Boost libraries: ${Boost_USE_STATIC_LIBS}")
-message(STATUS "Link the runtime statically: ${CC_STATIC_RUNTIME}")
-message(STATUS "Strip symbols: ${CC_STRIP_SYMBOLS}")
-
-# C++ standard version:
-
-set(CMAKE_CXX_STANDARD "${CC_CXX_STANDARD}")
-set(CMAKE_CXX_STANDARD_REQUIRED ON)
-set(CMAKE_CXX_EXTENSIONS OFF)
-
-# Common compiler options routines:
-
-function(_cc_best_practices_msvc target)
- set(compile_options /MP /W4)
- get_target_property(target_type "${target}" TYPE)
- get_target_property(aliased "${target}" ALIASED_TARGET)
- if(NOT target_type STREQUAL "INTERFACE_LIBRARY" AND NOT aliased)
- target_compile_options("${target}" PRIVATE ${compile_options})
- endif()
-endfunction()
-
-function(_cc_best_practices_gcc target)
- set(compile_options -Wall -Wextra)
- get_target_property(target_type "${target}" TYPE)
- get_target_property(aliased "${target}" ALIASED_TARGET)
- if(NOT target_type STREQUAL "INTERFACE_LIBRARY" AND NOT aliased)
- target_compile_options("${target}" PRIVATE ${compile_options})
- endif()
-endfunction()
-
-function(_cc_best_practices target)
- if(is_msvc)
- _cc_best_practices_msvc("${target}")
- elseif(is_gcc)
- _cc_best_practices_gcc("${target}")
- endif()
-endfunction()
-
-# Useful Windows macros routines:
-
-function(_cc_common_windows_definitions target)
- set(compile_definitions WIN32_LEAN_AND_MEAN NOMINMAX)
- get_target_property(target_type "${target}" TYPE)
- if(target_type STREQUAL "INTERFACE_LIBRARY")
- target_compile_definitions("${target}" INTERFACE ${compile_definitions})
- else()
- get_target_property(aliased "${target}" ALIASED_TARGET)
- if(NOT aliased)
- target_compile_definitions("${target}" PRIVATE ${compile_definitions})
- endif()
- endif()
-endfunction()
-
-# Static runtime routines:
-
-function(_cc_static_runtime_msvc target)
- get_target_property(target_type "${target}" TYPE)
- get_target_property(aliased "${target}" ALIASED_TARGET)
- if(NOT target_type STREQUAL "INTERFACE_LIBRARY" AND NOT aliased)
- target_compile_options("${target}" PRIVATE
- $<$<CONFIG:Debug>:/MTd>
- $<$<NOT:$<CONFIG:Debug>>:/MT>)
- endif()
-endfunction()
-
-function(_cc_static_runtime_gcc target)
- get_target_property(target_type "${target}" TYPE)
- get_target_property(aliased "${target}" ALIASED_TARGET)
- if(NOT target_type STREQUAL "INTERFACE_LIBRARY" AND NOT aliased)
- # This causes issues with mixing keyword- and plain- versions of
- # target_link_libraries:
- #target_link_libraries("${target}" PRIVATE -static)
-
- set_property(TARGET "${target}" APPEND_STRING PROPERTY LINK_FLAGS " -static")
-
- # Or (haven't tested this), if CMake 3.13+ is used:
- #target_link_options("${target}" PRIVATE -static)
- endif()
-endfunction()
-
-function(_cc_static_runtime target)
- if(is_msvc)
- _cc_static_runtime_msvc("${target}")
- elseif(is_gcc)
- _cc_static_runtime_gcc("${target}")
- endif()
-endfunction()
-
-# Symbol stripping routines:
-
-function(_cc_strip_symbols_gcc target)
- get_target_property(target_type "${target}" TYPE)
- get_target_property(aliased "${target}" ALIASED_TARGET)
- if(NOT target_type STREQUAL "INTERFACE_LIBRARY" AND NOT aliased)
- set(release_build $<OR:$<CONFIG:Release>,$<CONFIG:MinSizeRel>>)
- if(release_build)
- # This causes issues with mixing keyword- and plain- versions of
- # target_link_libraries:
- #target_link_libraries("${target}" PRIVATE -s)
-
- set_property(TARGET "${target}" APPEND_STRING PROPERTY LINK_FLAGS " -s")
- endif()
- endif()
-endfunction()
-
-function(_cc_strip_symbols target)
- if(is_gcc)
- _cc_strip_symbols_gcc("${target}")
- endif()
-endfunction()
-
-# Main macros:
-
-function(_cc_apply_settings target)
- if(TARGET "${target}")
- get_target_property(target_imported "${target}" IMPORTED)
- if(NOT target_imported)
- if(CC_BEST_PRACTICES)
- _cc_best_practices("${target}")
- endif()
- if(CC_WINDOWS_DEF)
- _cc_common_windows_definitions("${target}")
- endif()
- if(CC_STRIP_SYMBOLS)
- _cc_strip_symbols("${target}")
- endif()
- if(CC_STATIC_RUNTIME)
- _cc_static_runtime("${target}")
- endif()
- endif()
- endif()
-endfunction()
-
-macro(add_executable target)
- _add_executable(${ARGV})
- _cc_apply_settings("${target}")
-endmacro()
-
-macro(add_library target)
- _add_library(${ARGV})
- _cc_apply_settings("${target}")
-endmacro()
diff --git a/cmake/examples/boost/CMakeLists.txt b/cmake/examples/boost/CMakeLists.txt
deleted file mode 100644
index 8c076c9..0000000
--- a/cmake/examples/boost/CMakeLists.txt
+++ /dev/null
@@ -1,14 +0,0 @@
-cmake_minimum_required(VERSION 3.5) # for Boost::* imported targets
-
-project(example_boost)
-
-include(../../common.cmake)
-
-find_package(Boost REQUIRED COMPONENTS filesystem)
-add_executable(foo foo.cpp)
-target_link_libraries(foo PRIVATE Boost::disable_autolinking Boost::filesystem)
-
-install(TARGETS foo RUNTIME DESTINATION bin)
-if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
- install(FILES "$<TARGET_PDB_FILE:foo>" DESTINATION bin OPTIONAL)
-endif()
diff --git a/cmake/examples/boost/foo.cpp b/cmake/examples/boost/foo.cpp
deleted file mode 100644
index 3bd0326..0000000
--- a/cmake/examples/boost/foo.cpp
+++ /dev/null
@@ -1,11 +0,0 @@
-#include <boost/filesystem.hpp>
-
-#include <iostream>
-
-int main(int argc, char* argv[]) {
- std::cout << "Hello from "
- << boost::filesystem::absolute(boost::filesystem::path{argv[0]})
- .string()
- << "!\n";
- return 0;
-}
diff --git a/cmake/examples/dynamic/CMakeLists.txt b/cmake/examples/dynamic/CMakeLists.txt
deleted file mode 100644
index 4602adb..0000000
--- a/cmake/examples/dynamic/CMakeLists.txt
+++ /dev/null
@@ -1,16 +0,0 @@
-cmake_minimum_required(VERSION 3.1)
-
-project(example_dynamic)
-
-include(../../common.cmake)
-
-add_library(baz SHARED baz.cpp)
-target_include_directories(baz PUBLIC .)
-
-add_executable(foo foo.cpp)
-target_link_libraries(foo PRIVATE baz)
-
-install(TARGETS foo baz RUNTIME DESTINATION bin LIBRARY DESTINATION lib)
-if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
- install(FILES "$<TARGET_PDB_FILE:foo>" "$<TARGET_PDB_FILE:baz>" DESTINATION bin OPTIONAL)
-endif()
diff --git a/cmake/examples/dynamic/baz.cpp b/cmake/examples/dynamic/baz.cpp
deleted file mode 100644
index d108ae3..0000000
--- a/cmake/examples/dynamic/baz.cpp
+++ /dev/null
@@ -1,7 +0,0 @@
-#include "baz.hpp"
-
-#include <iostream>
-
-void baz() {
- std::cout << "baz\n";
-}
diff --git a/cmake/examples/dynamic/baz.hpp b/cmake/examples/dynamic/baz.hpp
deleted file mode 100644
index 2fc9b2a..0000000
--- a/cmake/examples/dynamic/baz.hpp
+++ /dev/null
@@ -1,9 +0,0 @@
-#pragma once
-
-#ifdef _MSC_VER
-#define DLLEXPORT __declspec(dllexport)
-#else
-#define DLLEXPORT
-#endif
-
-DLLEXPORT void baz();
diff --git a/cmake/examples/dynamic/foo.cpp b/cmake/examples/dynamic/foo.cpp
deleted file mode 100644
index b7d9986..0000000
--- a/cmake/examples/dynamic/foo.cpp
+++ /dev/null
@@ -1,6 +0,0 @@
-#include <baz.hpp>
-
-int main() {
- baz();
- return 0;
-}
diff --git a/cmake/examples/simple/CMakeLists.txt b/cmake/examples/simple/CMakeLists.txt
deleted file mode 100644
index 4f8859e..0000000
--- a/cmake/examples/simple/CMakeLists.txt
+++ /dev/null
@@ -1,12 +0,0 @@
-cmake_minimum_required(VERSION 3.1)
-
-project(example_simple)
-
-include(../../common.cmake)
-
-add_executable(foo foo.cpp)
-
-install(TARGETS foo RUNTIME DESTINATION bin)
-if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
- install(FILES "$<TARGET_PDB_FILE:foo>" DESTINATION bin OPTIONAL)
-endif()
diff --git a/cmake/examples/simple/foo.cpp b/cmake/examples/simple/foo.cpp
deleted file mode 100644
index b9d3132..0000000
--- a/cmake/examples/simple/foo.cpp
+++ /dev/null
@@ -1,6 +0,0 @@
-#include <iostream>
-
-int main() {
- std::cout << "foo\n";
- return 0;
-}
diff --git a/cmake/examples/static/CMakeLists.txt b/cmake/examples/static/CMakeLists.txt
deleted file mode 100644
index 8a6acb8..0000000
--- a/cmake/examples/static/CMakeLists.txt
+++ /dev/null
@@ -1,16 +0,0 @@
-cmake_minimum_required(VERSION 3.1)
-
-project(example_static)
-
-include(../../common.cmake)
-
-add_library(bar bar.cpp)
-target_include_directories(bar PUBLIC .)
-
-add_executable(foo foo.cpp)
-target_link_libraries(foo PRIVATE bar)
-
-install(TARGETS foo bar RUNTIME DESTINATION bin ARCHIVE DESTINATION lib)
-if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
- install(FILES "$<TARGET_PDB_FILE:foo>" DESTINATION bin OPTIONAL)
-endif()
diff --git a/cmake/examples/static/bar.cpp b/cmake/examples/static/bar.cpp
deleted file mode 100644
index 37aa9b5..0000000
--- a/cmake/examples/static/bar.cpp
+++ /dev/null
@@ -1,7 +0,0 @@
-#include "bar.hpp"
-
-#include <iostream>
-
-void bar() {
- std::cout << "bar\n";
-}
diff --git a/cmake/examples/static/bar.hpp b/cmake/examples/static/bar.hpp
deleted file mode 100644
index a3ea4c1..0000000
--- a/cmake/examples/static/bar.hpp
+++ /dev/null
@@ -1,3 +0,0 @@
-#pragma once
-
-void bar();
diff --git a/cmake/examples/static/foo.cpp b/cmake/examples/static/foo.cpp
deleted file mode 100644
index c6355a2..0000000
--- a/cmake/examples/static/foo.cpp
+++ /dev/null
@@ -1,6 +0,0 @@
-#include <bar.hpp>
-
-int main() {
- bar();
- return 0;
-}
diff --git a/cmake/toolchains/README.md b/cmake/toolchains/README.md
deleted file mode 100644
index 9c58eb6..0000000
--- a/cmake/toolchains/README.md
+++ /dev/null
@@ -1,3 +0,0 @@
-Use the toolchain files by passing something like
-`-D CMAKE_TOOLCHAIN_FILE=PATH/TO/cmake-common/cmake/toolchains/TOOLCHAIN.cmake`
-to `cmake`.
diff --git a/cmake/toolchains/gcc-x64.cmake b/cmake/toolchains/gcc-x64.cmake
deleted file mode 100644
index 2f7019e..0000000
--- a/cmake/toolchains/gcc-x64.cmake
+++ /dev/null
@@ -1,4 +0,0 @@
-set(CMAKE_C_COMPILER gcc)
-set(CMAKE_C_FLAGS -m64)
-set(CMAKE_CXX_COMIPLER g++)
-set(CMAKE_CXX_FLAGS -m64)
diff --git a/cmake/toolchains/gcc-x86.cmake b/cmake/toolchains/gcc-x86.cmake
deleted file mode 100644
index e2e84be..0000000
--- a/cmake/toolchains/gcc-x86.cmake
+++ /dev/null
@@ -1,4 +0,0 @@
-set(CMAKE_C_COMPILER gcc)
-set(CMAKE_C_FLAGS -m32)
-set(CMAKE_CXX_COMIPLER g++)
-set(CMAKE_CXX_FLAGS -m32)
diff --git a/cmake/toolchains/mingw-w64-x64.cmake b/cmake/toolchains/mingw-w64-x64.cmake
deleted file mode 100644
index c689d39..0000000
--- a/cmake/toolchains/mingw-w64-x64.cmake
+++ /dev/null
@@ -1,4 +0,0 @@
-set(CMAKE_C_COMPILER x86_64-w64-mingw32-gcc)
-set(CMAKE_CXX_COMPILER x86_64-w64-mingw32-g++)
-set(CMAKE_RC_COMILER x86_64-w64-mingw32-windres)
-set(CMAKE_SYSTEM_NAME Windows)
diff --git a/cmake/toolchains/mingw-w64-x86.cmake b/cmake/toolchains/mingw-w64-x86.cmake
deleted file mode 100644
index e5dedd4..0000000
--- a/cmake/toolchains/mingw-w64-x86.cmake
+++ /dev/null
@@ -1,4 +0,0 @@
-set(CMAKE_C_COMPILER i686-w64-mingw32-gcc)
-set(CMAKE_CXX_COMPILER i686-w64-mingw32-g++)
-set(CMAKE_RC_COMILER i686-w64-mingw32-windres)
-set(CMAKE_SYSTEM_NAME Windows)