diff options
author | Egor Tensin <Egor.Tensin@gmail.com> | 2020-03-28 17:19:43 +0000 |
---|---|---|
committer | Egor Tensin <Egor.Tensin@gmail.com> | 2020-03-28 17:23:15 +0000 |
commit | 70da99e4f70845da37ae368c4788ecc18546792d (patch) | |
tree | 51f50290e2ea926350c88fa5fa0e8d4d2ad426fa /cmake | |
parent | common.cmake: account for ALIAS targets (diff) | |
download | cmake-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.md | 13 | ||||
-rwxr-xr-x | cmake/build/build.py | 190 | ||||
-rwxr-xr-x | cmake/build/ci/appveyor.py | 167 | ||||
-rwxr-xr-x | cmake/build/ci/travis.py | 102 | ||||
-rw-r--r-- | cmake/common.cmake | 225 | ||||
-rw-r--r-- | cmake/examples/boost/CMakeLists.txt | 14 | ||||
-rw-r--r-- | cmake/examples/boost/foo.cpp | 11 | ||||
-rw-r--r-- | cmake/examples/dynamic/CMakeLists.txt | 16 | ||||
-rw-r--r-- | cmake/examples/dynamic/baz.cpp | 7 | ||||
-rw-r--r-- | cmake/examples/dynamic/baz.hpp | 9 | ||||
-rw-r--r-- | cmake/examples/dynamic/foo.cpp | 6 | ||||
-rw-r--r-- | cmake/examples/simple/CMakeLists.txt | 12 | ||||
-rw-r--r-- | cmake/examples/simple/foo.cpp | 6 | ||||
-rw-r--r-- | cmake/examples/static/CMakeLists.txt | 16 | ||||
-rw-r--r-- | cmake/examples/static/bar.cpp | 7 | ||||
-rw-r--r-- | cmake/examples/static/bar.hpp | 3 | ||||
-rw-r--r-- | cmake/examples/static/foo.cpp | 6 | ||||
-rw-r--r-- | cmake/toolchains/README.md | 3 | ||||
-rw-r--r-- | cmake/toolchains/gcc-x64.cmake | 4 | ||||
-rw-r--r-- | cmake/toolchains/gcc-x86.cmake | 4 | ||||
-rw-r--r-- | cmake/toolchains/mingw-w64-x64.cmake | 4 | ||||
-rw-r--r-- | cmake/toolchains/mingw-w64-x86.cmake | 4 |
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) |