Skip to main content

cmakew is a CMake wrapper CLI tool.

Project description

Summary

cmakew is a CMake wrapper CLI tool.

PyPI package version Supported Python versions

Examples

Build googletest at Linux

$ wget -O - https://github.com/google/googletest/archive/release-1.8.1.tar.gz | tar zxf -
$ cmakew googletest-release-1.8.1/
[INFO] cmakew: -- The C compiler identification is GNU 7.3.0
-- The CXX compiler identification is GNU 7.3.0
-- Check for working C compiler: /usr/bin/cc
-- Check for working C compiler: /usr/bin/cc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Detecting C compile features
-- Detecting C compile features - done
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Found PythonInterp: /home/toor/.pyenv/versions/3.7.0/bin/python (found version "3.7")
-- Looking for pthread.h
-- Looking for pthread.h - found
-- Looking for pthread_create
-- Looking for pthread_create - not found
-- Check if compiler accepts -pthread
-- Check if compiler accepts -pthread - yes
-- Found Threads: TRUE
-- Configuring done
-- Generating done
-- Build files have been written to: /home/github/build

[INFO] cmakew: Scanning dependencies of target gtest
[ 12%] Building CXX object googlemock/gtest/CMakeFiles/gtest.dir/src/gtest-all.cc.o
[ 25%] Linking CXX static library libgtestd.a
[ 25%] Built target gtest
Scanning dependencies of target gtest_main
[ 37%] Building CXX object googlemock/gtest/CMakeFiles/gtest_main.dir/src/gtest_main.cc.o
Scanning dependencies of target gmock
[ 50%] Building CXX object googlemock/CMakeFiles/gmock.dir/src/gmock-all.cc.o
[ 62%] Linking CXX static library libgtest_maind.a
[ 62%] Built target gtest_main
[ 75%] Linking CXX static library libgmockd.a
[ 75%] Built target gmock
Scanning dependencies of target gmock_main
[ 87%] Building CXX object googlemock/CMakeFiles/gmock_main.dir/src/gmock_main.cc.o
[100%] Linking CXX static library libgmock_maind.a
[100%] Built target gmock_main

Output

$ tree build/googlemock/ -L 2
build/googlemock/
├── CMakeFiles
│   ├── CMakeDirectoryInformation.cmake
│   ├── gmock.dir
│   ├── gmock_main.dir
│   └── progress.marks
├── cmake_install.cmake
├── CTestTestfile.cmake
├── gtest
│   ├── CMakeFiles
│   ├── cmake_install.cmake
│   ├── CTestTestfile.cmake
│   ├── generated
│   ├── libgtestd.a
│   ├── libgtest_maind.a
│   └── Makefile
├── libgmockd.a
├── libgmock_maind.a
└── Makefile

6 directories, 12 files

Installation

Install from PyPI

pip install cmakew

Install from PPA (for Ubuntu)

sudo add-apt-repository ppa:thombashi/ppa
sudo apt update
sudo apt install cmakew

cmakew help

usage: cmakew [-h] [-V] [--build-dir BUILD_DIR]
              [--action {cmake,recmake,clean,build,rebuild}]
              [--cmake-options CMAKE_OPTIONS] [--build-type {Debug,Release}]
              [--generator GENERATOR] [--debug | --quiet]
              SOURCE_DIR_PATH

A CLI tool for CMake and compiler wrapper.

positional arguments:
  SOURCE_DIR_PATH       relative path to the source directory.

optional arguments:
  -h, --help            show this help message and exit
  -V, --version         show program's version number and exit
  --debug               for debug print.
  --quiet               suppress execution log messages.

Directory Options:
  --build-dir BUILD_DIR
                        relative path to the build output directory (defaults
                        to 'build').

Build Options:
  --action {cmake,recmake,clean,build,rebuild}
                        cmake: execute CMake and exit. clean: delete existing
                        build directory and exit. recmake: delete existing
                        CMakeCache and execute CMake after that. build:
                        execute MSBuild to Visual Studio solution files that
                        created by cmake. rebuild: delete existing build
                        directory and execute CMake and MSBuild after that.
                        defaults to 'build'.

CMake Options:
  --cmake-options CMAKE_OPTIONS
                        path to the CMake options file. use "{key :value,
                        ...}" to set specific parameters. defaults to
                        cmake_options.json.
  --build-type {Debug,Release}
                        defaults to Debug.
  --generator GENERATOR
                        generator that passes to cmake. the default value
                        decided by execution platform: (a) if executed at
                        Windows and Visual Studio is installed in C: or D:
                        drive, cmakew pass 'Visual Studio NN' as a generator
                        to cmake. (b) "Unix Makefiles" otherwise

Issue tracker: https://github.com/thombashi/cmakew/issues

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for cmakew, version 0.2.0
Filename, size File type Python version Upload date Hashes
Filename, size cmakew-0.2.0-py2.py3-none-any.whl (11.7 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size cmakew-0.2.0.tar.gz (11.5 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page