Windows POSIX read() write()
C++ / C programs using POSIX write or read need a preprocessor include stack:
#if defined(_WIN32)
#include <io.h>
#else
#include <unistd.h>
#endifC++ / C programs using POSIX write or read need a preprocessor include stack:
#if defined(_WIN32)
#include <io.h>
#else
#include <unistd.h>
#endifCygwin startup configuration is controlled by Windows environment variable CYGWIN. Not populating Cygwin PATH from Windows PATH avoids confusion from Windows programs being used instead of Cygwin programs. Set Windows environment variable:
CYGWIN_NOWINPATH=1will result in a basic Cygwin PATH like:
/usr/local/bin:/usr/bin
Look inside Cygwin “/etc/profile” for more environment variables that may be of interest.
NOTE: all Windows environment variables are imported by Cygwin. Override these variables in ~/.profile or scripts if desired.
Related: don’t populate WSL PATH from Windows PATH.
Libutil gives abstractions for OS-specific TTY operations. When using these abstractions across macOS and Linux, use this preprocessing statement for the appropriate header:
#ifdef __APPLE__
#include <util.h>
#else
#include <pty.h>
#endifIf using CMake, ensure the library and header are found:
find_library(UTIL_LIBRARY NAMES util)
if(APPLE)
find_path(UTIL_INCLUDE_DIR NAMES util.h)
elseif(UNIX)
find_path(UTIL_INCLUDE_DIR NAMES pty.h)
endif()OpenWatcom is an open-source C/C++ compiler that can compile for a variety of systems, particularly legacy 16/32-bit Windows and DOS systems. This can be of interest for retro gamers and those using old devices that have DOS-based software, including industrial controllers and two-way radio programming.
CMake supports OpenWatcom, and is conveniently used with a toolchain file. GitHub Actions has easy scripting for OpenWatcom to test building of DOS programs from Linux.
The easiest way to show this is by example: see the PDCurses CMake Watcom toolchain file and GitHub Actions yml for how to build with OpenWatcom for DOS from Windows/Linux and GitHub Actions build CI.
To run the programs build for DOS, use DOSBox-X.
CMake target_compile_features sets a transitive MINIMUM language standard necessary. If the compiler defaults to a newer language standard, target_compile_features() allows that default higher language standard.
target_compile_features(<target> PRIVATE cxx_std_98)This can make issues for legacy code that requires an older language standard.
For example, an old C++98 code may need to have the compiler in C++98 mode.
This is accomplished with the target property
CXX_STANDARD.
Other languages may have a similar property e.g. C_STANDARD.
Example: if C++98 needed for old code:
set_property(TARGET old PROPERTY CXX_STANDARD 98)CMake can add interface linking to imported libraries. For example, a imported library obtained by find_package() or otherwise. Normally, this would work like the following example to say link “stdc++fs” to example imported library “imported::lib” for GCC older than 9.1.
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU" AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 9.1.0)
target_link_libraries(imported::lib INTERFACE stdc++fs)
endif()Function target_link_libraries() should work, but does not always work for some projects with a configure time error. To workaround this issue if it arises, set target property INTERFACE_LINK_LIBRARIES directly like:
set_property(TARGET imported::lib PROPERTY INTERFACE_LINK_LIBRARIES stdc++fs)Many CMake users have muscle memory for the three-stanza configure, build, test with CMake:
cmake -B build
# configure CMake and generate build files
cmake --build build
# compile and link binaries
ctest --test-dir build
# run program self-testsThis can be reduced to a single command for many programs:
ctest -S setup.cmakewhere a single file setup.cmake is added to the project.
Command-line options like “-Dvar=yes” must be aggregated and passed along to ctest_configure(OPTIONS) in setup.cmake.
Capture the number of physical CPU cores available on a computer from Matlab:
function N = get_cpu_count()
%% get apparent number of physical CPU cores
N = maxNumCompThreads;
if N < 2 % happens on some HPC
N = feature('NumCores');
end
endRelated: Python CPU count
Python can easily be used from CMake, perhaps to simplify test scripts for continuous integration.
Python scripts are managed in CMakeLists.txt.
First, find Python interpreter:
find_package(Python COMPONENTS Interpreter REQUIRED)Then to run a simple Python script in a CMake test:
add_test(NAME MatmulPython
COMMAND ${Python_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/matmul.py
)To use PyTest:
add_test(NAME MatmulPython
COMMAND ${Python_EXECUTABLE} -m pytest ${CMAKE_CURRENT_SOURCE_DIR}
)That will look under tests/test*.py by default.
From the project directory:
cmake -B build -S .-S .-S srcThis generates the makefile, but does not compile anything, since CMake is a build script generator.
Compile:
cmake --build build --parallel--parallelThis uses the appropriate compilers and linkers to generate the executables and libraries.
Execute self-tests you’ve defined with add_test() in CMakeLists.txt:
ctest --test-dir build -VIf that’s too verbose, try:
ctest --test-dir build --output-on-failureFor faster testing by defaulting to running multiple tests in parallel, set CTEST_PARALLEL_LEVEL environment variable.
Octave uses startup.m persistent user settings like Matlab. To keep Matlab compatibility, put Octave-specific startup commands and plotting defaults into ~/.octaverc, which sets default parameters for all GNU Octave sessions.
suppress_verbose_help_message(1)
page_output_immediately(1)
page_screen_output(0)
crash_dumps_octave_core(0)
sigterm_dumps_octave_core(0)
sighup_dumps_octave_core(0)
if isfile('~/Documents/MATLAB/startup.m')
source('~/Documents/MATLAB/startup.m')
endif*_dumps_*octave-workspace files that appear when Octave is Ctrl+c
exited or crashes.page_output_immediately(1)if existstartup.m file like Matlab.Set plot defaults: useful for HiDPI systems, control Octave default plot text size of axes and titles, useful for HiDPI systems by adding to “~/.octaverc”:
set(0, "defaultaxesfontsize", 16)
set(0, "defaultlinelinewidth", 2)adjust 16 to produce the most appealing text labels in:
defaultline is the root category for lines, so defaultlinelinewidth is not a typo.
Speedup Octave start (without GUI): don’t autoload Octave packages