From 5ccf8612d714fa1eecc68d486b1f693d9c53edb5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=20O=20M=20P=20=CE=9E=20Z?= Date: Mon, 25 Nov 2024 12:52:26 +0330 Subject: [PATCH] Upgrade to 1.2.20 - Added Wasm (WebAssembly) target. - Fixed UI support technology for QtQuick. - Fixed and added Qt 6.8 support. - Fixed C++ 23/26 compiler support. - Removed some extra config. - Fixed some platform detection scripts. - Some issue fixed. --- CMakeLists.txt | 79 +- cmake/compiler-options.cmake | 74 +- cmake/cross-compile.cmake | 18 +- .../android-toolchain.cmake | 69 +- cmake/platforms-toolchain/ios-toolchain.cmake | 54 +- .../platforms-toolchain/linux-toolchain.cmake | 50 +- .../platforms-toolchain/macos-toolchain.cmake | 44 +- .../platforms-toolchain/unix-toolchain.cmake | 48 +- .../platforms-toolchain/wasm-toolchain.cmake | 27 + .../windows-toolchain.cmake | 44 +- cmake/project-setting.cmake | 2 +- config/project.cmake | 2 +- precompiled/pch.hpp | 12 +- source/entrypoint/qt/qtquick/main.cpp | 20 + source/entrypoint/stl/main.cpp | 59 +- source/examples/configtest.cpp | 1 - source/examples/librarytest.cpp | 1 - ui/qtquick/main.qml | 23 +- ui/qtquick/qml.qrc | 1 - ui/qtquick/test.qml | 8 - utilities/preprocessor.cppm | 1257 +++++++++++++++++ utilities/preprocessor.hpp | 18 +- 22 files changed, 1677 insertions(+), 234 deletions(-) create mode 100644 cmake/platforms-toolchain/wasm-toolchain.cmake delete mode 100644 ui/qtquick/test.qml create mode 100644 utilities/preprocessor.cppm diff --git a/CMakeLists.txt b/CMakeLists.txt index 5655ced..3382e97 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,23 +1,14 @@ # -------------------- PROJECT TEMPLATE INFO --------------------------------------------- # Title : Project Template -# Version : 1.1.430 -# Author : Kambiz Asadzadeh +# Version : 1.2.20 +# Author : Kambiz Asadzadeh (compez.eth) # License : MIT # Url : https://github.com/genyleap/Project-Template # Organization : Genyleap # ---------------------------------------------------------------------------------------- -cmake_minimum_required(VERSION 3.28) - -if(${CMAKE_VERSION} VERSION_LESS 3.28) - cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}) -else() - cmake_policy(VERSION 3.28) -endif() - +cmake_minimum_required(VERSION 3.23) cmake_policy(SET CMP0048 NEW) -cmake_policy(SET CMP0152 NEW) -cmake_policy(SET CMP0155 NEW) # Add include path for cmake modules # ------ PROJECT EXTRA CMAKE ------ @@ -28,11 +19,14 @@ list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/config/") include(ExternalProject) include(FetchContent) -include(project) -if(project) - return() -endif() -set(project ON) +# ------ PROJECT INFO ------ +# Options +set(PROJECT_NAME "PT" CACHE STRING "Project Name.") #You can change "ProjectTemplate" with your project name. +set(PROJECT_TARGET ${PROJECT_NAME} CACHE STRING "Project Target Name.") + +set(PROJECT_VERSION_MAJOR 1) +set(PROJECT_VERSION_MINOR 0) +set(PROJECT_VERSION_PATCH 6) # ---- Project settings ---- set_property(GLOBAL APPEND PROPERTY USE_FOLDERS ON) @@ -42,9 +36,13 @@ set(CMAKE_INCLUDE_CURRENT_DIR ON) if(NOT DEFINED CMAKE_CXX_STANDARD) set(CMAKE_CXX_STANDARD 23) set(CMAKE_CXX_STANDARD_REQUIRED ON) - set(CMAKE_CXX_EXTENSIONS OFF) + set(CMAKE_CXX_EXTENSIONS ON) endif() +set(PROJECT_CREATOR "Kambiz Asadzadeh" CACHE STRING "Creator of your project.") #Your project creator. + +set(PROJECT_LICENSE_TYPE "MIT" CACHE STRING "Project License Type.") #Your project license type. + if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/.git") execute_process( COMMAND git rev-parse --short HEAD @@ -52,12 +50,13 @@ if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/.git") OUTPUT_VARIABLE PROJECT_VERSION_TAG OUTPUT_STRIP_TRAILING_WHITESPACE ) -endif() +endif() if(NOT PROJECT_VERSION_TAG) set(PROJECT_VERSION_TAG 00000000) endif() set(PROJECT_VERSION_TAG_HEX 0x${PROJECT_VERSION_TAG}) +set(PROJECT_VERSION_TYPE "final" CACHE STRING "Version type.") set(PROJECT_VERSION ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}) set(PROJECT_VERSION_STRING ${PROJECT_VERSION}-${PROJECT_VERSION_TYPE}) @@ -65,6 +64,20 @@ set(PROJECT_VERSION_STRING ${PROJECT_VERSION}-${PROJECT_VERSION_TYPE}) # Specify language NONE, or use the LANGUAGES keyword and list no languages, to skip enabling any languages. set(PROJECT_LANGUAGES CXX) +#Use these keys [application, library] +set(PROJECT_USAGE_TYPE "application" CACHE STRING "Usage Type.") + +#Use these keys [stl, qt, qtwidget, qtquick] +set(PROJECT_MAIN_TYPE "qtquick" CACHE STRING "Library System.") + +set(DEVELOPER_BUNDLE_IDENTIFIER com.kambizasadzadeh.app.${PROJECT_NAME} CACHE STRING "Developer Bundle Identifier.") + +#You can replace your project description with this string. +set(PROJECT_DESCRIPTION "A concept mobile app UI/UX prototype based on Qt Quick technology." CACHE STRING "Project Description") + +#Your project website address. +set(PROJECT_HOMEPAGE_URL "https://kambizasadzadeh.com" CACHE STRING "Project URL.") + #Project pre-configuration system. configure_file( ${PROJECT_SOURCE_DIR}config.hpp.in @@ -142,10 +155,11 @@ file(GLOB HEADERS ) file(GLOB SOURCES source/${SUFFIX_SOURCE}) -file(GLOB EXAMPLES - source/examples/${SUFFIX_HPPHEADER} - source/examples/${SUFFIX_SOURCE} -) +#file(GLOB EXAMPLES +# source/examples/${SUFFIX_HPPHEADER} +# source/examples/${SUFFIX_SOURCE} +#) + file(GLOB UTILS utilities/${SUFFIX_HPPHEADER} utilities/${SUFFIX_SOURCE} @@ -295,18 +309,21 @@ if(GUI_APPLICATION AND PROJECT_MAIN_TYPE STREQUAL "qt" OR PROJECT_MAIN_TYPE STRE Qt${QT_VERSION_MAJOR}::Core Qt${QT_VERSION_MAJOR}::Widgets ) - find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Core Widgets) - find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Core Widgets) + find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Widgets) + find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Widgets) elseif(${PROJECT_MAIN_TYPE} STREQUAL "qtquick") list(APPEND QT_MODULES Core${SPACE_ARG}) list(APPEND QT_MODULES Quick${SPACE_ARG}) list(APPEND QT_MODULES_LINK - Qt${QT_VERSION_MAJOR}::Core Qt${QT_VERSION_MAJOR}::Quick + Qt${QT_VERSION_MAJOR}::Quick ) - find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Core Quick) - find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Core Quick) + find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Quick) + find_package(Qt${QT_VERSION_MAJOR} REQUIRED COMPONENTS Quick) endif() endif() + + qt_standard_project_setup(REQUIRES 6.5) + if(${QT_VERSION_MAJOR} GREATER_EQUAL 6) if(PROJECT_USAGE_TYPE STREQUAL "library") qt_add_library(${PROJECT_NAME} @@ -442,3 +459,9 @@ file(COPY ${CMAKE_CURRENT_SOURCE_DIR}/config/system-config.json DESTINATION ${CM #Ignore unused files. list(APPEND CPACK_SOURCE_IGNORE_FILES /.git/ /build/ .gitignore .DS_Store) + +include(InstallRequiredSystemLibraries) +set(CPACK_GENERATOR "TGZ;ZIP") +set(CPACK_PACKAGE_VERSION ${PROJECT_VERSION}) +set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "A brief description of your project") +include(CPack) diff --git a/cmake/compiler-options.cmake b/cmake/compiler-options.cmake index c64e918..41aa4c8 100644 --- a/cmake/compiler-options.cmake +++ b/cmake/compiler-options.cmake @@ -50,9 +50,6 @@ if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang") set(CMAKE_CXX_STANDARD_LIBRARIES "-lc++ -lc++abi") endif() -if(CMAKE_CXX_COMPILER_ID STREQUAL "AppleClang") - set(CMAKE_CXX_STANDARD_LIBRARIES "-lc++ -lc++abi") -endif() if(CMAKE_CXX_COMPILER_ID STREQUAL "MSVC") message("-- CMake run for msvc") @@ -108,6 +105,23 @@ else() endif() endif() +# Enable optional features +option(ENABLE_MODULES "Enable C++20 modules" OFF) +if(ENABLE_MODULES) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fmodules") + add_definitions(-DENABLE_MODULES) +endif() + +# Debug/Testing Modes +option(ENABLE_DEBUG_LOGGING "Enable debug logging" OFF) +option(ENABLE_TESTING "Enable testing mode" OFF) +if(ENABLE_DEBUG_LOGGING) + add_definitions(-DDEBUG_LOGGING) +endif() +if(ENABLE_TESTING) + add_definitions(-DENABLE_TESTING) +endif() + ######################### # --- Build Options --- # ######################### @@ -148,12 +162,6 @@ if (SIMPLE_BUILD) add_definitions(-DSIMPLE_BUILD) endif() -# Enable address sanitizer -option(ENABLE_ASAN "Enable address sanitizer" OFF) -if (ENABLE_ASAN) - add_definitions(-DENABLE_ASAN) -endif() - # Build the project's documentation option(BUILD_DOC "Build the project's documentation" OFF) if (BUILD_DOC) @@ -255,7 +263,7 @@ if (FORCE_LATEST_STANDARD_FEATURE) endif() # Sanitizers Options -option(ENABLE_SANITIZERS "Enable Sanitizers" ON) +option(ENABLE_SANITIZERS "Enable Sanitizers" OFF) option(ENABLE_ADDRESS_SANITIZER "Enable AddressSanitizer (ASan)" OFF) option(ENABLE_LEAK_SANITIZER "Enable LeakSanitizer (LSan)" OFF) option(ENABLE_MEMORY_SANITIZER "Enable MemorySanitizer" OFF) @@ -265,7 +273,11 @@ option(ENABLE_UNDEFINED_SANITIZER "Enable UndefinedBehaviorSanitizer" OFF) if (ENABLE_SANITIZERS) add_definitions(-DENABLE_SANITIZERS) if (CMAKE_CXX_COMPILER_ID MATCHES "Clang") - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address,leak,undefined") + if (APPLE AND CMAKE_SYSTEM_PROCESSOR STREQUAL "arm64") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address,undefined") + else() + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=address,leak,undefined") + endif() if (ENABLE_MEMORY_SANITIZER AND NOT APPLE) add_definitions(-DENABLE_MEMORY_SANITIZER) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=memory") @@ -289,22 +301,26 @@ if (ENABLE_SANITIZERS) message(WARNING "Unsupported compiler. Sanitizers are disabled.") endif() else() -# Check and enable individual sanitizers -if (CMAKE_CXX_COMPILER_ID MATCHES "Clang") - foreach(SANITIZER IN ITEMS ADDRESS LEAK MEMORY THREAD UNDEFINED) - if ("ENABLE_${SANITIZER}_SANITIZER") - add_definitions(-DENABLE_${SANITIZER}_SANITIZER) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=${SANITIZER}") - endif() - endforeach() -elseif (CMAKE_CXX_COMPILER_ID MATCHES "GNU" AND NOT APPLE) - foreach(SANITIZER IN ITEMS ADDRESS LEAK MEMORY THREAD UNDEFINED) - if ("ENABLE_${SANITIZER}_SANITIZER") - add_definitions(-DENABLE_${SANITIZER}_SANITIZER) - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=${SANITIZER}") - endif() - endforeach() -else() - message(WARNING "Unsupported compiler. Sanitizers are disabled.") -endif() + # Check and enable individual sanitizers + if (CMAKE_CXX_COMPILER_ID MATCHES "Clang") + foreach(SANITIZER IN ITEMS ADDRESS LEAK MEMORY THREAD UNDEFINED) + if ("ENABLE_${SANITIZER}_SANITIZER") + add_definitions(-DENABLE_${SANITIZER}_SANITIZER) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=${SANITIZER}") + endif() + endforeach() + elseif (CMAKE_CXX_COMPILER_ID MATCHES "GNU" AND NOT APPLE) + foreach(SANITIZER IN ITEMS ADDRESS LEAK MEMORY THREAD UNDEFINED) + if ("ENABLE_${SANITIZER}_SANITIZER") + add_definitions(-DENABLE_${SANITIZER}_SANITIZER) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fsanitize=${SANITIZER}") + endif() + endforeach() + else() + message(WARNING "Unsupported compiler. Sanitizers are disabled.") + endif() endif() + + +# Summary +message(STATUS "Final compiler flags: ${CMAKE_CXX_FLAGS}") diff --git a/cmake/cross-compile.cmake b/cmake/cross-compile.cmake index 028acdd..7dc0c88 100644 --- a/cmake/cross-compile.cmake +++ b/cmake/cross-compile.cmake @@ -2,6 +2,22 @@ list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake/") list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake/platforms-toolchain/") # ------ CROSS-COMPILE CONFIG ------ +if (EXISTS "${CMAKE_CXX_COMPILER}") + execute_process(COMMAND ${CMAKE_CXX_COMPILER} --version + OUTPUT_VARIABLE EMCC_VERSION + ERROR_VARIABLE EMCC_VERSION) + if (EMCC_VERSION MATCHES "Emscripten") + message(STATUS "Ready for Wasm...") + set(WASM TRUE) + set(PLATFORM_OS "Web") + set(OS_ARCHITECTURES ${CMAKE_SYSTEM_PROCESSOR}) + include(wasm-toolchain) + if(wasm-toolchain) + return() + endif() + set(wasm-toolchain ON) + endif() +endif() #LINUX if(LINUX AND NOT ANDROID AND NOT APPLE) @@ -60,7 +76,7 @@ if(UNIX AND NOT ANDROID AND NOT LINUX AND APPLE) endif() #FREEBSD -if(UNIX AND NOT ANDROID AND NOT LINUX AND NOT APPLE) +if(UNIX AND NOT ANDROID AND NOT LINUX AND NOT APPLE AND NOT WASM) message(STATUS "Ready for Unix, BSDs...") set(UNIX TRUE) set(PLATFORM_OS "Unix") diff --git a/cmake/platforms-toolchain/android-toolchain.cmake b/cmake/platforms-toolchain/android-toolchain.cmake index 7d42468..b51530b 100644 --- a/cmake/platforms-toolchain/android-toolchain.cmake +++ b/cmake/platforms-toolchain/android-toolchain.cmake @@ -1,9 +1,27 @@ -# Standard settings -set (CMAKE_SYSTEM_NAME ANDROID) -set (CMAKE_SYSTEM_VERSION 1) -set (CMAKE_CROSSCOMPILING TRUE) -set (ANDROID TRUE) -set (PLATFORM_FOLDER "Android") +# Standard settings for Android +set(CMAKE_SYSTEM_NAME Android) +set(CMAKE_SYSTEM_VERSION 21) # Android API level (can be changed to your target version) +set(CMAKE_CROSSCOMPILING TRUE) +set(ANDROID TRUE) +set(PLATFORM_FOLDER "Android") + +#------ PROJECT DIRECTORIES ------ +# Define base build directory for Android +set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) + +# Set output directories for executables, libraries, and other build files +set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) +set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) + +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) + +# Set NDK path (if it's not set globally, you can also set the NDK path here) +# set(ANDROID_NDK "/path/to/your/ndk") # Uncomment if needed if(ANDROID_SDK_ROOT) include(${ANDROID_SDK_ROOT}/android_openssl/CMakeLists.txt) @@ -13,17 +31,28 @@ if(ANDROID_SDK) include(${ANDROID_SDK}/android_openssl/CMakeLists.txt) endif() -#------ PROJECT DIRECTORIES ------ -set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) -message("Make sure that build/Android path is set manually.") -#Qt Creator cannot set android path as default base on dir. -#You shoud set custom as buid/android from QtCreator. -#set(EXECUTABLE_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -#set(LIBRARY_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -#set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) -#set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) -#set(CMAKE_BUILD_DIRECTORY ${dir}) -#set(CMAKE_BINARY_DIR ${dir}) -#SET(EXECUTABLE_OUTPUT_PATH ${dir}) -#SET(LIBRARY_OUTPUT_PATH ${dir}/lib) -#SET(CMAKE_CACHEFILE_DIR ${dir}) +# Specify the Android ABIs (Architectures) to target +set(ANDROID_ABI "arm64-v8a" CACHE STRING "Android ABI" FORCE) # You can use "armeabi-v7a", "x86", "x86_64", "arm64-v8a" +set(ANDROID_NATIVE_API_LEVEL 21) # Android API level, the minimum required by your app + +# Set Android toolchain file (you need to provide the correct path to the Android toolchain file) +set(CMAKE_TOOLCHAIN_FILE ${ANDROID_NDK}/build/cmake/android.toolchain.cmake) + +# Android-specific libraries (Android system libraries) +# You can add more libraries depending on your requirements (e.g., OpenGL, Vulkan, JNI, etc.) +set(OS_LIBS + "-landroid" # Basic Android library + "-lEGL" # OpenGL ES library + "-lGLESv2" # OpenGL ES 2.0 + "-ljnigraphics" # JNI Graphics interface (useful for drawing) + "-llog" # Android log library (for logging in C++ code) +) + +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("Android NDK path: ${ANDROID_NDK}") +message("Android ABI: ${ANDROID_ABI}") +message("Android API Level: ${ANDROID_NATIVE_API_LEVEL}") +message("Android Libraries: ${OS_LIBS}") diff --git a/cmake/platforms-toolchain/ios-toolchain.cmake b/cmake/platforms-toolchain/ios-toolchain.cmake index be97085..ce783b4 100644 --- a/cmake/platforms-toolchain/ios-toolchain.cmake +++ b/cmake/platforms-toolchain/ios-toolchain.cmake @@ -1,27 +1,37 @@ -# Standard settings -set (CMAKE_SYSTEM_NAME iOS) -set (CMAKE_SYSTEM_VERSION 1) +# Standard settings for iOS +set(CMAKE_SYSTEM_NAME iOS) +set(CMAKE_SYSTEM_VERSION 13.0) # You can adjust this to the minimum iOS version required set(CMAKE_CROSSCOMPILING TRUE) -set (IOS TRUE) -set (PLATFORM_FOLDER "iOS") +set(IOS TRUE) +set(PLATFORM_FOLDER "iOS") -if(NOT DEFINED IOS_BITCODE) # check xcode/clang version? since xcode 7 - set(IOS_BITCODE 1) -endif() -set(IOS_BITCODE_MARKER 0) +#------ PROJECT DIRECTORIES ------ +# Define base build directory for iOS +set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) -set(OS_LIBS "-framework IOKit -framework Foundation") +# Set output directories for executables, libraries, and other build files +set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) +set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) -#------ PROJECT DIRECTORIES ------ -#set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/iOS) -#set(EXECUTABLE_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -#set(LIBRARY_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -#set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) -#set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) -#set(CMAKE_BUILD_DIRECTORY ${dir}) -#set(CMAKE_BINARY_DIR ${dir}) -#SET(EXECUTABLE_OUTPUT_PATH ${dir}) -#SET(LIBRARY_OUTPUT_PATH ${dir}lib) -#SET(CMAKE_CACHEFILE_DIR ${dir}) +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) + +# iOS-specific libraries and frameworks +# You will need to link the appropriate iOS frameworks depending on your application's requirements. +set(OS_LIBS + "-framework Foundation" # Core iOS Foundation framework + "-framework UIKit" # User interface components + "-framework CoreGraphics" # 2D drawing framework + "-framework CoreMedia" # Media and video processing + "-framework AVFoundation" # Audio and video framework +) -#message("CMAKE_BUILD_FILES_DIRECTORY: " ${CMAKE_BUILD_FILES_DIRECTORY}) +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("iOS Libraries: ${OS_LIBS}") diff --git a/cmake/platforms-toolchain/linux-toolchain.cmake b/cmake/platforms-toolchain/linux-toolchain.cmake index 6a0dd37..cc1d2f4 100644 --- a/cmake/platforms-toolchain/linux-toolchain.cmake +++ b/cmake/platforms-toolchain/linux-toolchain.cmake @@ -1,20 +1,44 @@ -# Standard settings -set (CMAKE_SYSTEM_NAME Linux) -set (CMAKE_SYSTEM_VERSION 1) -set (CMAKE_CROSSCOMPILING TRUE) +# Standard settings for Linux systems +set(CMAKE_SYSTEM_NAME Linux) # Set system to Linux +set(CMAKE_SYSTEM_VERSION 1) # Version is generic for all Linux distributions +set(CMAKE_CROSSCOMPILING FALSE) # Not cross-compiling set (LINUX TRUE) -set (PLATFORM_FOLDER "Unix") +set(PLATFORM_FOLDER "Linux") #------ PROJECT DIRECTORIES ------ +# Define base build directory set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) -set(EXECUTABLE_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -set(LIBRARY_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) + +# Set output directories for executables, libraries, and other build files set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) -set(CMAKE_BUILD_DIRECTORY ${dir}) -set(CMAKE_BINARY_DIR ${dir}) -SET(EXECUTABLE_OUTPUT_PATH ${dir}) -SET(LIBRARY_OUTPUT_PATH ${dir}lib/) -SET(CMAKE_CACHEFILE_DIR ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) + +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) + +# Linux system libraries - Common across most Linux distributions +set(OS_LIBS + "-lpthread" # Pthread library for multithreading (POSIX threads) + "-lm" # Math library (for common math functions like sqrt, sin, etc.) + "-lstdc++" # Standard C++ library + "-lc" # C standard library + "-ldl" # Dynamic loading library + "-lrt" # Real-time extensions for Linux systems + "-lX11" # X11 library for graphical applications (if needed) + "-lssl -lcrypto" # OpenSSL for encryption (if needed) +) + +# Optional: Add other libraries depending on the specific Linux distribution or features you need +# For example, for network-related features or GUI, you can add: +# set(OS_LIBS ${OS_LIBS} "-lgtk-3") # If using GTK+ for GUI applications +# set(OS_LIBS ${OS_LIBS} "-lboost_system -lboost_filesystem") # If using Boost -message("CMAKE_BUILD_FILES_DIRECTORY: " ${CMAKE_BUILD_FILES_DIRECTORY}) +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("Linux Libraries: ${OS_LIBS}") diff --git a/cmake/platforms-toolchain/macos-toolchain.cmake b/cmake/platforms-toolchain/macos-toolchain.cmake index 6f58ae8..732db06 100644 --- a/cmake/platforms-toolchain/macos-toolchain.cmake +++ b/cmake/platforms-toolchain/macos-toolchain.cmake @@ -1,22 +1,36 @@ -# Standard settings -set (CMAKE_SYSTEM_NAME Darwin) -set (CMAKE_SYSTEM_VERSION 1) -set (CMAKE_CROSSCOMPILING TRUE) -set (APPLE TRUE) -set (PLATFORM_FOLDER "macOS") +# Standard settings for macOS +set(CMAKE_SYSTEM_NAME Darwin) +set(CMAKE_SYSTEM_VERSION 1) +set(CMAKE_CROSSCOMPILING TRUE) +set(APPLE TRUE) +set(PLATFORM_FOLDER "macOS") #------ PROJECT DIRECTORIES ------ +# Define base build directory for macOS set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) -set(EXECUTABLE_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -set(LIBRARY_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) + +# Set output directories for executables, libraries, and other build files set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) -set(CMAKE_BUILD_DIRECTORY ${dir}) -set(CMAKE_BINARY_DIR ${dir}) -SET(EXECUTABLE_OUTPUT_PATH ${dir}) -SET(LIBRARY_OUTPUT_PATH ${dir}lib/) -SET(CMAKE_CACHEFILE_DIR ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) + +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) -set(OS_LIBS "-framework IOKit -framework ApplicationServices -framework CoreServices -framework CoreGraphics -framework Foundation") +# macOS specific libraries and frameworks +set(OS_LIBS + "-framework IOKit" + "-framework ApplicationServices" + "-framework CoreServices" + "-framework CoreGraphics" + "-framework Foundation" +) -message("CMAKE_BUILD_FILES_DIRECTORY: " ${CMAKE_BUILD_FILES_DIRECTORY}) +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("macOS Frameworks: ${OS_LIBS}") diff --git a/cmake/platforms-toolchain/unix-toolchain.cmake b/cmake/platforms-toolchain/unix-toolchain.cmake index 6e7312e..701a4d7 100644 --- a/cmake/platforms-toolchain/unix-toolchain.cmake +++ b/cmake/platforms-toolchain/unix-toolchain.cmake @@ -1,19 +1,41 @@ -# Standard settings -set (CMAKE_SYSTEM_NAME UNIX) -set (CMAKE_SYSTEM_VERSION 1) -set(CMAKE_CROSSCOMPILING TRUE) -set (PLATFORM_FOLDER "Unix") +# Standard settings for Unix-like systems (FreeBSD, OpenBSD, etc.) +set(CMAKE_SYSTEM_NAME UNIX) # Generic Unix system for FreeBSD, OpenBSD, etc. +set(CMAKE_SYSTEM_VERSION 1) # Version is generic for all Unix-like systems +set(CMAKE_CROSSCOMPILING FALSE) # We are not cross-compiling +set (UNIX TRUE) +set(PLATFORM_FOLDER "Unix") #------ PROJECT DIRECTORIES ------ +# Define base build directory set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) -set(EXECUTABLE_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -set(LIBRARY_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) + +# Set output directories for executables, libraries, and other build files set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) -set(CMAKE_BUILD_DIRECTORY ${dir}) -set(CMAKE_BINARY_DIR ${dir}) -SET(EXECUTABLE_OUTPUT_PATH ${dir}) -SET(LIBRARY_OUTPUT_PATH ${dir}lib/) -SET(CMAKE_CACHEFILE_DIR ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) + +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) + +# Unix system libraries - Common across most BSD-like systems +set(OS_LIBS + "-lpthread" # Pthread library for multithreading (POSIX threads) + "-lm" # Math library (for common math functions like sqrt, sin, etc.) + "-lstdc++" # Standard C++ library + "-lc" # C standard library + "-ldl" # Dynamic loading library (for Unix-like systems) + "-lrt" # Real-time extensions for Unix-like systems +) + +# Optional: Add more libraries depending on the specific BSD system or features you need +# set(OS_LIBS ${OS_LIBS} "-lX11") # If using X11 for graphical apps +# set(OS_LIBS ${OS_LIBS} "-lssl -lcrypto") # If using OpenSSL for encryption -message("CMAKE_BUILD_FILES_DIRECTORY: " ${CMAKE_BUILD_FILES_DIRECTORY}) +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("Unix-like Libraries: ${OS_LIBS}") diff --git a/cmake/platforms-toolchain/wasm-toolchain.cmake b/cmake/platforms-toolchain/wasm-toolchain.cmake new file mode 100644 index 0000000..b293265 --- /dev/null +++ b/cmake/platforms-toolchain/wasm-toolchain.cmake @@ -0,0 +1,27 @@ +# Standard settings for Wasm systems +set(CMAKE_SYSTEM_NAME WASM) # Generic Wasm system for Web. +set(CMAKE_SYSTEM_VERSION 1) # Version is generic for all wasm systems +set(CMAKE_CROSSCOMPILING FALSE) # We are not cross-compiling +set (WASM TRUE) +set(PLATFORM_FOLDER "Wasm") + +#------ PROJECT DIRECTORIES ------ +# Define base build directory +set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) + +# Set output directories for executables, libraries, and other build files +set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) +set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) + +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) + +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("Unix-like Libraries: ${OS_LIBS}") diff --git a/cmake/platforms-toolchain/windows-toolchain.cmake b/cmake/platforms-toolchain/windows-toolchain.cmake index d852db4..5898ead 100644 --- a/cmake/platforms-toolchain/windows-toolchain.cmake +++ b/cmake/platforms-toolchain/windows-toolchain.cmake @@ -1,22 +1,36 @@ -# Standard settings -set (CMAKE_SYSTEM_NAME Windows) -set (CMAKE_SYSTEM_VERSION 1) +# Standard settings for Windows +set(CMAKE_SYSTEM_NAME Windows) +set(CMAKE_SYSTEM_VERSION 10) # Set the system version (you can adjust if needed) set(CMAKE_CROSSCOMPILING TRUE) -set (WIN32 TRUE) -set (PLATFORM_FOLDER "Windows") - -set (WIN32_RESOURCES ${CMAKE_CURRENT_SOURCE_DIR}/properties/${PLATFORM_FOLDER}/app.rc) +set(WINDOWS TRUE) +set(PLATFORM_FOLDER "Windows") #------ PROJECT DIRECTORIES ------ +# Define base build directory for Windows set(dir ${CMAKE_CURRENT_SOURCE_DIR}/build/${PLATFORM_FOLDER}) -set(EXECUTABLE_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) -set(LIBRARY_OUTPUT_PATH ${dir} CACHE PATH "Build directory" FORCE) + +# Set output directories for executables, libraries, and other build files set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${dir}) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${dir}/lib) set(CMAKE_BUILD_FILES_DIRECTORY ${dir}) -set(CMAKE_BUILD_DIRECTORY ${dir}) -set(CMAKE_BINARY_DIR ${dir}) -SET(EXECUTABLE_OUTPUT_PATH ${dir}) -SET(LIBRARY_OUTPUT_PATH ${dir}lib/) -SET(CMAKE_CACHEFILE_DIR ${dir}) +set(CMAKE_BINARY_DIR ${dir}) +set(CMAKE_CACHEFILE_DIR ${dir}) + +# Ensure all output paths are unified +set(EXECUTABLE_OUTPUT_PATH ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}) +set(LIBRARY_OUTPUT_PATH ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}) + +# Windows specific libraries and settings +# For simplicity, here are some commonly used libraries on Windows. +# You may need to modify this list based on your project's requirements. +set(OS_LIBS + "user32.lib" # Basic Windows user interface library + "gdi32.lib" # Windows graphics device interface library + "kernel32.lib" # Kernel-level services +) -message("CMAKE_BUILD_FILES_DIRECTORY: " ${CMAKE_BUILD_FILES_DIRECTORY}) +# Output information for debugging +message("Build directory: ${dir}") +message("CMAKE_RUNTIME_OUTPUT_DIRECTORY: ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}") +message("CMAKE_LIBRARY_OUTPUT_DIRECTORY: ${CMAKE_LIBRARY_OUTPUT_DIRECTORY}") +message("Windows Libraries: ${OS_LIBS}") diff --git a/cmake/project-setting.cmake b/cmake/project-setting.cmake index dc8e731..5dad25c 100644 --- a/cmake/project-setting.cmake +++ b/cmake/project-setting.cmake @@ -19,7 +19,7 @@ if (USE_FULL_QT_FEATURES) endif() # Include User Interface -option(GUI_APPLICATION "Include User Interface" OFF) +option(GUI_APPLICATION "Include User Interface" ON) if (GUI_APPLICATION) add_definitions(-DGUI_APPLICATION) endif() diff --git a/config/project.cmake b/config/project.cmake index 1fd274e..c51ed4d 100644 --- a/config/project.cmake +++ b/config/project.cmake @@ -24,7 +24,7 @@ set(PROJECT_VERSION_TYPE "final" CACHE STRING "Version type.") set(PROJECT_USAGE_TYPE "application" CACHE STRING "Usage Type.") #Use these keys [stl, qt, qtwidget, qtquick] -set(PROJECT_MAIN_TYPE "stl" CACHE STRING "Library System.") +set(PROJECT_MAIN_TYPE "qtquick" CACHE STRING "Library System.") set(DEVELOPER_BUNDLE_IDENTIFIER com.genyleap.api.${PROJECT_NAME} CACHE STRING "Developer Bundle Identifier.") diff --git a/precompiled/pch.hpp b/precompiled/pch.hpp index e86f380..9a6de93 100644 --- a/precompiled/pch.hpp +++ b/precompiled/pch.hpp @@ -1,13 +1,20 @@ /*! * Gen3 License * - * Copyright (c) 2021 Kambiz Asadzadeh - * Copyright (c) 2023 Genyleap + * Copyright (c) 2024 Kambiz Asadzadeh + * Copyright (c) 2024 Genyleap */ #ifndef PCH_HPP #define PCH_HPP +#if __cpp_modules +import std; // Import core language support. +#ifdef ENABLE_C_FACILITIES +import std.compat; //Import C++ headers for C library facilities +#endif +#else + /*! * Creating and using precompiled headers can do two major things for you: * Can reduce the compilation time of C++ files. @@ -319,6 +326,7 @@ #ifdef _MSC_VER #include #endif +#endif #if __cpp_lib_json # include diff --git a/source/entrypoint/qt/qtquick/main.cpp b/source/entrypoint/qt/qtquick/main.cpp index dbc376a..c717150 100644 --- a/source/entrypoint/qt/qtquick/main.cpp +++ b/source/entrypoint/qt/qtquick/main.cpp @@ -20,3 +20,23 @@ int main(int argc, char *argv[]) return app.exec(); } + + +// #include +// #include + +// int main(int argc, char *argv[]) +// { +// QGuiApplication app(argc, argv); + +// QQmlApplicationEngine engine; +// QObject::connect( +// &engine, +// &QQmlApplicationEngine::objectCreationFailed, +// &app, +// []() { QCoreApplication::exit(-1); }, +// Qt::QueuedConnection); +// engine.loadFromModule("Rare", "Main"); + +// return app.exec(); +// } diff --git a/source/entrypoint/stl/main.cpp b/source/entrypoint/stl/main.cpp index ceba0b8..1001239 100644 --- a/source/entrypoint/stl/main.cpp +++ b/source/entrypoint/stl/main.cpp @@ -14,6 +14,8 @@ #include "examples/languagetest.hpp" #include "examples/configtest.hpp" +// #include + //!JSon [Non-STL] Features #if defined(USE_JSON) && !defined(USE_BOOST) #include @@ -97,52 +99,29 @@ TEST_CASE( "Factorials are computed", "[factorial]" ) { #include //Project Config -using namespace std; - #include +#include -int main() -{ - cout << "Hello World!" << endl; - - //!Config Test - ConfigTest config; - config.readConfig(); - - //!Compiler Test - CompilerTest compiler; - compiler.getCompilerInfo(); - - //!Platform Test - PlatformTest platform; - platform.getPlatformInfo(); - - //!Library Test - LibraryTest library; - -#ifdef USE_OPENSSL - library.testOpenSSL(); // OpenSSL -#endif - -#ifdef USE_BOOST - library.testBoost(); // Boost -#endif - -#ifdef USE_OPENCV - library.testOpenCV(); // OpenCV -#endif - +using namespace std; - //!Language Features - LanguageTest language; - language.checkFeatures(); +int main() { + std::unique_ptr arr = std::make_unique(5); // Allocate an array of integers on the heap - //!ThirdParty Library - ThirdPartyTest thirdPartyTest; - thirdPartyTest.testFmt(); - thirdPartyTest.testCtre(); + // Access elements of the array + for (int i = 0; i < 5; ++i) { + arr[i] = i; + } + // Memory is automatically freed when arr goes out of scope + // No need for explicit delete[] + // Try to access the freed memory + std::cout << "Array elements after deletion: "; + for (int i = 0; i < 5; ++i) { + // The following line is safe, as memory is managed by unique_ptr + std::cout << arr[i] << " "; + } return 0; } + diff --git a/source/examples/configtest.cpp b/source/examples/configtest.cpp index 424d524..155a6c7 100644 --- a/source/examples/configtest.cpp +++ b/source/examples/configtest.cpp @@ -1,7 +1,6 @@ #include "configtest.hpp" #include "common.hpp" #include "config.hpp" -#include ConfigTest::ConfigTest() { diff --git a/source/examples/librarytest.cpp b/source/examples/librarytest.cpp index 4e438b9..972afe4 100644 --- a/source/examples/librarytest.cpp +++ b/source/examples/librarytest.cpp @@ -1,6 +1,5 @@ #include "librarytest.hpp" #include "common.hpp" -#include #ifdef USE_BOOST # include diff --git a/ui/qtquick/main.qml b/ui/qtquick/main.qml index 5cd9b70..d1a534a 100644 --- a/ui/qtquick/main.qml +++ b/ui/qtquick/main.qml @@ -1,7 +1,7 @@ -import QtQuick 2.15 -import QtQuick.Window 2.15 -import QtQuick.Controls 2.15 -import QtQuick.Layouts 1.15 +import QtQuick +import QtQuick.Window +import QtQuick.Controls +import QtQuick.Layouts ApplicationWindow { width: 640 @@ -9,10 +9,19 @@ ApplicationWindow { visible: true title: qsTr("Hello World") - Label { + ColumnLayout { anchors.centerIn: parent - text: qsTr("Hello from Qt Quick!") + spacing: 10 + Button { + text: qsTr("Check State") + onClicked: { + result.text = "My Name is Kambiz!"; + console.log("Hello, Kambiz!") + } + } + Text { + id: result + } } - } diff --git a/ui/qtquick/qml.qrc b/ui/qtquick/qml.qrc index a58de19..b341c0a 100644 --- a/ui/qtquick/qml.qrc +++ b/ui/qtquick/qml.qrc @@ -1,6 +1,5 @@ main.qml - test.qml diff --git a/ui/qtquick/test.qml b/ui/qtquick/test.qml deleted file mode 100644 index 589b9b2..0000000 --- a/ui/qtquick/test.qml +++ /dev/null @@ -1,8 +0,0 @@ -import QtQuick 2.15 -import QtQuick.Window 2.15 -import QtQuick.Controls 2.15 -import QtQuick.Layouts 1.15 - -Item { - -} diff --git a/utilities/preprocessor.cppm b/utilities/preprocessor.cppm new file mode 100644 index 0000000..6771f5c --- /dev/null +++ b/utilities/preprocessor.cppm @@ -0,0 +1,1257 @@ +/*! + * + * Copyright (c) 2024 Kambiz Asadzadeh + * Copyright (c) 2024 Genyleap + */ + +export module preprocessor; + +//! COMPILERS +#if defined(__clang__) +/* Clang/LLVM. ---------------------------------------------- */ +#undef COMPILER +#define COMPILER "Clang/LLVM" +#undef COMPILER_CLANG_LLVM +#define COMPILER_CLANG_LLVM "Clang/LLVM" +#undef COMPILER_VER +#define COMPILER_VER __clang_version__ +#elif (defined(__clang__) && !defined(__llvm__)) && !defined(__GNUC__) +#elif defined(__ICC) || defined(__INTEL_COMPILER) +/* Intel ICC/ICPC. ------------------------------------------ */ +#undef COMPILER +#define COMPILER "Intel ICC/ICPC" +#undef COMPILER_INTEL +#define COMPILER_INTEL "Intel ICC/ICPC" +#define COMPILER_VER __INTEL_COMPILER_BUILD_DATE +#elif defined(__MINGW32__) && !defined(__amd64__) && !defined(__amd64) && \ + !defined(__ia64__) +/* __MINGW32__. ------------------------------------------------- */ +#undef COMPILER +#define COMPILER "MinGW-w86 (x86) 32 Bit" +#undef COMPILER_MINGW +#define COMPILER_MINGW "MinGW-w86 (x86) 32 Bit" +#undef COMPILER_VER +#define COMPILER_VER __MINGW32_MAJOR_VERSION << "." << __MINGW32_MINOR_VERSION +#elif defined(__MINGW32__) +/* __MINGW64_32__. ------------------------------------------------- */ +#undef COMPILER +#define COMPILER "MinGW-w64 (x86_64) 32-64 Bit" +#undef COMPILER_MINGW64_32 +#define COMPILER_MINGW64_32 "MinGW-w64 (x86_64) 32-64 Bit" +#undef COMPILER_VER +#define COMPILER_VER __MINGW32_MAJOR_VERSION << "." << __MINGW32_MINOR_VERSION +#elif defined(__MINGW64__) +/* __MINGW64__. ------------------------------------------------- */ +#undef COMPILER +#define COMPILER "MinGW-w64 (x64) 64 Bit" +#undef COMPILER_MINGW_64 +#define COMPILER_MINGW_64 "MinGW-w64 (x64) 64 Bit" +#undef COMPILER_VER +#define COMPILER_VER __MINGW64_MAJOR_VERSION << "." << __MINGW64_MINOR_VERSION +#elif defined(__GNUC__) || defined(__GNUG__) && !defined(__clang__) +#define GCC_VERSION __GNUC__ << "." << __GNUC_MINOR__ << "." << __GNUC_PATCHLEVEL__ +/* GNU GCC/G++. --------------------------------------------- */ +#undef COMPILER +#define COMPILER "GNU GCC/G++" +#undef COMPILER_GNU +#define COMPILER_GNU "GNU GCC/G++" +#undef COMPILER_GCC +#define COMPILER_GCC "GNU GCC/G++" +#undef COMPILER_VER +#define COMPILER_VER GCC_VERSION +#elif defined(__HP_cc) || defined(__HP_aCC) +/* Hewlett-Packard C/aC++. ---------------------------------- */ +#undef COMPILER +#define COMPILER "Hewlett-Packard C/aC++" +#undef COMPILERHEWLETT +#define COMPILERHEWLETT "Hewlett-Packard C/aC++" +#define COMPILER_VER __HP_aCC +#elif defined(__IBMC__) || defined(__IBMCPP__) +/* IBM XL C/C++. -------------------------------------------- */ +#undef COMPILER +#define COMPILER "IBM XL C/C++" +#undef COMPILER_IBM +#define COMPILER_IBM "IBM XL C/C++" +#define COMPILER_VER __xlC_ver__ +#elif defined(_MSC_VER) +/* Microsoft Visual Studio. --------------------------------- */ +#undef COMPILER +#define COMPILER "MSVC++ " +#undef COMPILER_MSVC +#define COMPILER_MSVC "MSVC++ " +#undef COMPILER_VER +#define COMPILER_VER _MSC_VER +#elif defined(__PGI) +/* Portland Group PGCC/PGCPP. ------------------------------- */ +#undef COMPILER "PGCC/PGCPP" +#define COMPILER "PGCC/PGCPP" +#undef COMPILER_PGCC "PGCC/PGCPP" +#define COMPILER_PGCC "PGCC/PGCPP" +#define COMPILER_VER __VERSION__ +#elif defined(__SUNPRO_C) || defined(__SUNPRO_CC) +/* Oracle Solaris Studio. ----------------------------------- */ +#undef COMPILER "Oracle Solaris" +#define COMPILER "Oracle Solaris" +#undef COMPILER_ORACLE "Oracle Solaris" +#define COMPILER_ORACLE "Oracle Solaris" +#define COMPILER_VER __SUNPRO_CC +#endif + +#if defined(_MSC_VER) && _MSC_VER == 1400 +#undef MSVCPP +#define MSVCPP "MSVC++ 8.0" +#elif defined(_MSC_VER) && _MSC_VER == 1500 +#undef MSVCPP +#define MSVCPP "MSVC++ 9.0" +#elif defined(_MSC_VER) && _MSC_VER == 1600 +#undef MSVCPP +#define MSVCPP "MSVC++ 10.0" +#elif defined(_MSC_VER) && _MSC_VER == 1700 +#undef MSVCPP +#define MSVCPP "MSVC++ 11.0" +#elif defined(_MSC_VER) && _MSC_VER == 1800 +#undef MSVCPP +#define MSVCPP "MSVC++ 12.0" +#elif defined(_MSC_VER) && _MSC_VER == 1900 +#undef MSVCPP +#define MSVCPP "MSVC++ 14.0" +#elif defined(_MSC_VER) && _MSC_VER == 1910 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.0" +#elif defined(_MSC_VER) && _MSC_VER == 1911 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.3" +#elif defined(_MSC_VER) && _MSC_VER == 1912 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.5" +#elif defined(_MSC_VER) && _MSC_VER == 1913 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.6" +#elif defined(_MSC_VER) && _MSC_VER == 1914 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.7" +#elif defined(_MSC_VER) && _MSC_VER == 1915 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.8" +#elif defined(_MSC_VER) && _MSC_VER == 1915 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.8" +#elif defined(_MSC_VER) && _MSC_VER == 1916 +#undef MSVCPP +#define MSVCPP "MSVC++ 15.9" +#elif defined(_MSC_VER) && _MSC_VER == 1920 +#undef MSVCPP +#define MSVCPP "MSVC++ RTW 16.0" +#elif defined(_MSC_VER) && _MSC_VER == 1921 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.1" +#elif defined(_MSC_VER) && _MSC_VER == 1922 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.2" +#elif defined(_MSC_VER) && _MSC_VER == 1923 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.3" +#elif defined(_MSC_VER) && _MSC_VER == 1924 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.4" +#elif defined(_MSC_VER) && _MSC_VER == 1925 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.5" +#elif defined(_MSC_VER) && _MSC_VER == 1926 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.6" +#elif defined(_MSC_VER) && _MSC_VER == 1927 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.7" +#elif defined(_MSC_VER) && _MSC_VER == 1928 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.8, 16.9" +#elif defined(_MSC_VER) && _MSC_VER == 1929 +#undef MSVCPP +#define MSVCPP "MSVC++ 16.10" +#elif defined(_MSC_VER) && _MSC_VER == 1930 +#undef MSVCPP +#elif defined(_MSC_VER) && _MSC_VER == 1931 +#undef MSVCPP +#define MSVCPP "MSVC++ (17.1)" +#endif + +//! LANGUAGE STANDARD +#if __cplusplus == 199711L && !defined(_MSC_VER) +/* C++98: __cplusplus is 19971L.*/ +#undef CPP_VERSION +#define CPP_VERSION "C++98" +#undef CPP_VALUE +#define CPP_VALUE "19971L" +#elif __cplusplus == 201103L +/* C++11: __cplusplus is 201103L.*/ +#undef CPP_VERSION +#define CPP_VERSION "C++11" +#undef CPP_VALUE +#define CPP_VALUE "201103L" +#elif __cplusplus == 201402L +/* C++14: __cplusplus is 201402L.*/ +#undef CPP_VERSION +#define CPP_VERSION "C++14" +#undef CPP_VALUE +#define CPP_VALUE "201402L" +#elif __cplusplus == 201702L || __cplusplus == 201703 +/* C++17: __cplusplus is c++1z.*/ +#undef CPP_VERSION +#define CPP_VERSION "C++17" +#undef CPP_VALUE +#define CPP_VALUE "201703" +#elif __cplusplus == 201707 || __cplusplus == 202002L || __cplusplus == 201709 +/* C++20: __cplusplus is c++2a.*/ +#undef CPP_VERSION +#define CPP_VERSION "C++20" +#undef CPP_VALUE +#define CPP_VALUE __cplusplus +#elif __cplusplus == 20120 +/* C++23: __cplusplus is c++2b.*/ +#undef CPP_VERSION +#define CPP_VERSION "C++23" +#undef CPP_VALUE +#define CPP_VALUE __cplusplus +#elif __embedded_cplusplus +#undef CPP_VERSION +#define CPP_VERSION "Embedded C++" +#undef CPP_VALUE +#define CPP_VALUE "19971L" +#elif defined(__clang__) +#undef CPP_VERSION +#define CPP_VERSION __cplusplus +#undef CPP_VALUE +#define CPP_VALUE __cplusplus +#elif defined(__GNUC__) +#undef CPP_VERSION +#define CPP_VERSION __cplusplus +#undef CPP_VALUE +#define CPP_VALUE __cplusplus +#else +#undef CPP_VERSION +#define CPP_VERSION 0 +#undef CPP_VALUE +#define CPP_VALUE "Unknown" +#endif + +//! EXPORTS & EXTRA +#if defined(__WINNT) || defined(__WINNT__) || defined(WIN32) || \ + defined(_WIN32) || defined(__WIN32) || defined(__WIN32__) || \ + defined(WIN64) || defined(_WIN64) || defined(__WIN64) || \ + defined(__WIN64__) +//! Microsoft Windows +#define PROJECT_EXPORT __declspec(dllexport) +#define PROJECT_IMPORT __declspec(dllimport) +#elif defined(__GNUC__) +//! Define for Unix base OS such as: Linux, macOS, FreeBSD, etc... +#define PROJECT_EXPORT __attribute__((visibility("default"))) +#define PROJECT_IMPORT __attribute__((visibility("default"))) +#define PROJECT_HIDDEN __attribute__((visibility("hidden"))) +#else +// do nothing and hope for the best? +#define PROJECT_EXPORT +#define PROJECT_IMPORT +#pragma warning Unknown dynamic link import / export semantics. +#endif + +#define PROJECT_DATE __DATE__ +#define PROJECT_TIME __TIME__ +#define PROJECT_FUNCTION __FUNCTION__ +#define PROJECT_LINE __LINE__ +#define PROJECT_FILE __FILE__ +#define PROJECT_COUNTER __COUNTER__ + +/* NOTICE: __attribute__ is Linux syntax; __declspec is the Windows syntax.*/ +/*The __declspec(noinline) attribute suppresses the inlining of a function at +the call points of the function. + +__declspec(noinline) can also be applied to constant data, to prevent the +compiler from using the value for optimization purposes, without affecting its +placement in the object. This is a feature that can be used for patchable +constants, that is, data that is later patched to a different value. It is an +error to try to use such constants in a context where a constant value is +required. For example, an array dimension. +*/ + +#if defined(__WINNT) || defined(__WINNT__) || defined(WIN32) || \ + defined(_WIN32) || defined(__WIN32) || defined(__WIN32__) || \ + defined(WIN64) || defined(_WIN64) || defined(__WIN64) || \ + defined(__WIN64__) +#define PROJECT_NOINLINE __declspec(noinline) +#define PROJECT_INLINE inline +#else +/// Define for Unix base OS such as: Linux, macOS, FreeBSD, etc... +#define PROJECT_NOINLINE __attribute__((noinline)) +#define PROJECT_INLINE inline +#endif + +//! ARCHITECTURE + +/* + * Classic Standard + * 32-bit and 64-Bit systems + * Developer: Intel & AMD Holdings + * Processors: Intel & AMD Machine + * (64-bit): EM64T, IA-32e, Intel64, x64, x86-64 + * (32-bit): IA-32, i386, x86, x86-32 + * Processors: Athlon, Atom, Core, Core 2, Core i3/i5/i7, Opteron, Pentium, + * Phenom, Sempron, Turion, etc. + */ + +#if (defined(i386) || defined(__i386) || defined(__i386__) || \ + defined(__IA32__) || defined(_M_IX86) || defined(_X86_)) && \ + !defined(__amd64) +//! x86 based systems (32-bit) +#undef X86_64BIT +#define X86_64BIT +#undef PROCESSOR +#define PROCESSOR "Intel" +#undef INTEL +#define INTEL +#undef ARCHITECTURE +#define ARCHITECTURE "x86 (32-Bit)" +#elif defined(__x86_64) || defined(__x86_64__) || defined(__amd64) || \ + defined(_M_AMD64) || defined(_M_X64) && !defined(X86_32bit) +//! x64 based systems (64-bit) +#undef X64_64BIT +#define X64_64BIT +#undef PROCESSOR +#define PROCESSOR "Intel" +#undef INTEL +#define INTEL +#undef ARCHITECTURE +#define ARCHITECTURE "x86_64 (64-Bit)" +#endif + +/* + * x86 and x86-64 + * (64-bit): EM64T, IA-32e, Intel64, x64, x86-64 + * (32-bit): IA-32, i386, x86, x86-32 + * Developers: Intel only + * Processors: Athlon + * + */ + +#if defined(__i386__) && !defined(_M_AMD64) +/* x86 32-bit ----------------------------------------------- */ +#undef INTEL_32BIT +#define INTEL_32BIT +#undef PROCESSOR +#define PROCESSOR "Intel" +#undef INTEL +#define INTEL +#undef ARCHITECTURE_INTEL +#define ARCHITECTURE_INTEL "x86 (32-Bit)" +#elif defined(__x86_64__) && !defined(_M_AMD64) +/* x64 64-bit ----------------------------------------------- */ +#undef INTEL_64BIT +#define INTEL_64BIT +#undef PROCESSOR +#define PROCESSOR "Intel" +#undef INTEL +#define INTEL +#undef ARCHITECTURE_INTEL +#define ARCHITECTURE_INTEL "x86_64 (64-Bit)" +#endif + +/* + * x86 and x86-64 + * (32-bit): i386, x86, x86-32 + * (64-bit): AMD64, x64 + * Developers: AMD only + * Processors: Athlon + * + */ + +#if defined(__i386__) && !defined(__x86_64__) +/* x86 32-bit ----------------------------------------------- */ +#undef AMD_32BIT +#define AMD_32BIT +#undef PROCESSOR +#define PROCESSOR "AMD" +#undef AMD +#define AMD +#undef ARCHITECTURE +#undef ARCHITECTURE_AMD +#define ARCHITECTURE_AMD "x86 (32-Bit)" +#elif (defined(__amd64__) || defined(__amd64) || defined(_M_AMD64)) && \ + !defined(__x86_64__) +/* x64 64-bit ----------------------------------------------- */ +#undef AMD_64BIT +#define AMD_64BIT +#undef PROCESSOR +#define PROCESSOR "AMD" +#undef AMD +#define AMD +#undef ARCHITECTURE_AMD +#define ARCHITECTURE_AMD "x86_64 (64-Bit)" +#endif + +/* + * Alpha AXP + * (64-bit): x64 + * (32-bit): x86 + * Developers: Digital Equipment Corporation + * Processors: Alpha + * + */ + +#if defined(__alpha__) || defined(__alpha) || defined(_M_ALPHA) +/* Alpha ----------------------------------------------- */ +#undef ALPHA_32BIT +#define ALPHA_32BIT +#undef PROCESSOR +#define PROCESSOR "Alpha" +#undef ALPHA +#define ALPHA +#undef ARCHITECTURE +#define ARCHITECTURE "Alpha (32-Bit)" +#endif + +/* + * ARM + * 32-bit + * Developer: ARM Holdings + * Processors: Acorn RISC Machine + */ + +#if defined(__arm__) || defined(__thumb__) || defined(__TARGET_ARCH_ARM) || \ + defined(__TARGET_ARCH_THUMB) || defined(_ARM) || defined(_M_ARM) || \ + defined(_M_ARMT) || defined(__arm) +/* ARM-x86 -------------------------------------------------- */ +#undef ARM_32BIT +#define ARM_32BIT +#undef PROCESSOR +#define PROCESSOR "Arm" +#undef ARM +#define ARM +#undef ARCHITECTURE +#define ARCHITECTURE "Arm (32-Bit)" +#endif + +/* + * ARM + * 64-bit + * Developer: ARM Holdings + * Processors: Acorn RISC Machine + */ + +#if defined(__aarch64__) +/* ARM-x64 -------------------------------------------------- */ +#undef ARM_64BIT +#define ARM_64BIT +#undef PROCESSOR +#define PROCESSOR "Arm64" +#undef ARM +#define ARM +#undef ARCHITECTURE +#define ARCHITECTURE "ARM64/AArch64 (64-Bit)" +#endif + +/* + * PA-RISC + * 32-bit + * Developer: Convex Computer Corporation + * Processors: PA-RISC + */ + +#if defined(__convex__) +/* Blackfin -------------------------------------------------- */ +#undef PA_RISC_32BIT +#define PA_RISC_32BIT +#undef PROCESSOR +#define PROCESSOR "Convex PA-RISC" +#undef PA_RISC +#define PA_RISC +#undef ARCHITECTURE +#define ARCHITECTURE "RISC (32-Bit)" +#endif + +/* + * Epiphany + * 32-bit & 64-bit + * Developer: Adapteva + * Processors: Epiphany + */ + +#if defined(__epiphany__) +/* Convex -------------------------------------------------- */ +#undef EP_32BIT +#define EP_32BIT +#undef PROCESSOR +#define PROCESSOR "Adapteva Epiphany" +#undef EPIPHANY +#define EPIPHANY +#undef ARCHITECTURE +#define ARCHITECTURE "Epiphany (32-Bit)" +#endif + +/* + * Motorola 68000 + * 32-bit + * Developer: Motorola + * Processors: Motorola 68000 + */ + +#if defined(__m68k__) || defined(M68000) || defined(__MC68K__) +/* Convex -------------------------------------------------- */ +#undef MOTOROLA_32BIT +#define MOTOROLA_32BIT +#undef PROCESSOR +#define PROCESSOR "Motorola 68000" +#undef MOTOROLA +#define MOTOROLA +#undef ARCHITECTURE +#define ARCHITECTURE "Motorola (32-Bit)" +#endif +/* + * Notes: + * "IA64" is the old name for the processor ARCHITECTURE. Intel now prefers + * "Itanium". There is no single Itanium processor macro defined by all + * compilers on all OSes. An #if/#endif that checks multiple macros is required. + * Microsoft's support for Itanium ended after Visual Studio 2010 and Windows + * Server 2008. Clang/LLVM currently does not support Itanium processors. + */ + +/* + * POWER + * PowerPC + * Developer: IBM, Freescale + * Processors: PowerPC, POWER 1/2/3/4/5/6/7, G1, G2, G3, G4, G5, etc. + */ + +/// Indicates that the target architecture is PowerPC®. +#if defined(__powerpc) || defined(__powerpc__) || defined(__POWERPC__) || defined(__ppc__) || defined(_M_PPC) || defined(__PPC) || defined(__PPC__) +/* POWER ---------------------------------------------------- */ +#undef POWER_PC_32BIT +#define POWER_PC_32BIT +#undef PROCESSOR +#define PROCESSOR "Power PC" +#undef ARCHITECTURE +#define ARCHITECTURE "PowerPC (32-Bit)" +#undef POWER_PC +#define POWER_PC +/// Indicates that the target architecture is PowerPC and that 64-bit +/// compilation mode is enabled. +#elif defined(__powerpc64__) +/* POWER 64-bit --------------------------------------------- */ +#undef POWER_PC_64bit__ +#define POWER_PC_64bit__ +#undef PROCESSOR +#define PROCESSOR "Power PC" +#undef POWER_PC +#define POWER_PC +#undef ARCHITECTURE +#define ARCHITECTURE "PowerPC (64-Bit)" +#endif + +/* + * Notes: + * There is no single POWER processor macro defined by all compilers on all + * OSes. An #if/#endif that checks multiple macros is required. GCC for AIX, + * NetBSD, and OpenBSD defines the same macros for 32-bit and 64-bit POWER + * processors. For AIX, __64BIT__ is defined for 64-bit POWER. For OpenBSD, + * _LP64 and __LP64__ are defined for 64-bit POWER. For NetBSD, GCC doesn't + * provide a macro to check for 64-bit use. Apple's OSX support for POWER + * processors ended after OSX 10.5 Leopard in 2007. The open source Darwin + * distribution, on which OSX is based, is still available for POWER processors. + */ + +/* + * SPARC + * Developer: Oracle, Fujitsu, Sun + * Processors: UltraSPARC I/II/III/IV/T1/T2, SPARC T3/T4, etc. + */ + +/* + * Notes: + * GCC defines processor name macros depending upon the value of the -march + * command-line option. These include__sparclite__, __sparclet__, __sparc_v8__, + * __sparc_v9__, __supersparc__, __hypersparc__, and so forth. However, other + * compilers don't provide this level of detail and writing code that depends + * upon these macros is probably a bad idea. + */ + +#if defined(sparc) || defined(__sparc) || defined(__sparc__) || \ + defined(__sparc64__) +/* x86 32-bit ----------------------------------------------- */ +#undef SPARC_32BIT +#define SPARC_32BIT +#undef PROCESSOR +#define PROCESSOR "Sparc" +#undef SPARC +#define SPARC +#undef ARCHITECTURE +#define ARCHITECTURE "Sparc (32-Bit)" +#elif defined(__sparc64__) +/* x64 64-bit ----------------------------------------------- */ +#undef SPARC_64bit__ +#define SPARC_64bit__ +#undef PROCESSOR +#define PROCESSOR "Sparc" +#undef SPARC +#define SPARC +#undef ARCHITECTURE +#define ARCHITECTURE "Sparc (64-Bit)" +#endif + +/* + * ARM + * 32-bit + * Developer: ARM Holdings + * Processors: Acorn RISC Machine + */ + +#if defined(__arm__) || defined(__thumb__) || defined(__TARGET_ARCH_ARM) || \ + defined(__TARGET_ARCH_THUMB) || defined(_ARM) || defined(_M_ARM) || \ + defined(_M_ARMT) || defined(__arm) +/* ARM-x86 -------------------------------------------------- */ +#undef ARM_32BIT +#define ARM_32BIT +#undef PROCESSOR +#define PROCESSOR "Arm" +#undef ARM +#define ARM +#undef ARCHITECTURE +#define ARCHITECTURE "Arm (32-Bit)" +#endif + +// Embedded Architecture +#if defined(__arm__) || defined(__thumb__) || defined(__TARGET_ARCH_ARM) || \ + defined(__TARGET_ARCH_THUMB) || defined(_ARM) || defined(_M_ARM) || \ + defined(_M_ARMT) || defined(__arm) +#undef EMBEDDED +#define EMBEDDED +#undef PROCESSOR +#define PROCESSOR "Ebedded Unknown!" +#undef IS_EMBEDDED +#define IS_EMBEDDED 1 +#endif + +//! PLATFORM + +/* + Supported platforms: + * - Mac OSX, iPhone, Darwin + * - Orbis + * - OpenBSD + * - Generic BSD + * - Atari ST TOS + * - AmigaOS + * - Windows + * - Flashplayer (Crossbridge) + * - QNX + * - TI-Nspire + * - Emscripten + * - Linux + * - Solaris + * - Generic POSIX + * - Cygwin + * - Generic UNIX + * - Generic fallback + * - Playstation + * - Xbox + * Supported architectures: + * - x86 + * - x64 + * - ARM 32-bit + * - ARM 64-bit + * - MIPS 32-bit + * - MIPS 64-bit + * - PowerPC 32-bit + * - PowerPC 64-bit + * - SPARC 32-bit + * - SPARC 64-bit + * - SuperH + * - Motorola 68k + * - Emscripten + * - Generic + * + * Supported compilers: + * - Clang + * - GCC + * - MSVC + * - Emscripten + * - TinyC + * - VBCC + * - Bruce's C compiler + * - Generic + * + */ + +/* + * AIX + * Developer: IBM + * Distributions: AIX + * Processors: POWER + */ + +#if defined(X86_32bit) && defined(_AIX) || defined(__TOS_AIX__) || \ + defined(__xlC__) +/* IBM AIX. ------------------------------------------------- */ +#define PLATFORM_OS "AIX" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_AIX "AIX" +#define PLATFORM_TYPE "UNIX AIX" +#undef AIX +#define AIX +#elif defined(X64_64bit) && defined(_AIX) || defined(__TOS_AIX__) || \ + defined(__xlC__) +/* IBM AIX. ------------------------------------------------- */ +#define PLATFORM_OS "AIX" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_AIX "AIX" +#undef AIX +#define AIX +#define PLATFORM_TYPE "UNIX AIX" +#endif + +/* + * HP-UX + * Developer: Hewlett-Packard + * Distributions: HP-UX + * Processors: Itanium + */ + +#if defined(X86_32bit) && defined(hpux) || defined(__hpux) || \ + defined(__hpux) || defined(__hpux) +/* Hewlett-Packard HP-UX. ----------------------------------- */ +#define PLATFORM_OS "HP" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_HP "HP" +#define PLATFORM_TYPE "UNIX HP-UX" +#undef HPUX +#define HPUX +#elif defined(X64_64bit) && defined(X86_32bit) && defined(hpux) || \ + defined(__hpux) || defined(__hpux) || defined(__hpux) +/* Hewlett-Packard HP-UX. ----------------------------------- */ +#define PLATFORM_OS "HP" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_HP "HP" +#define PLATFORM_TYPE "UNIX HP-UX" +#undef HPUX +#define HPUX +#endif + +/* + * Linux + * Developer: Open source + * Distributions: Centos, Debian, Fedora, OpenSUSE, RedHat, Ubuntu + * Processors: x86, x86-64, arm64, POWER, etc. + */ + +#if defined(__linux__) && defined(linux) && !defined(ARM64_BIT) && !defined(X64_64bit) +/* Linux. --------------------------------------------------- */ +#define PLATFORM_OS "Linux" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_LINUX "Linux" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_TYPE "Unix (Linux)" +#undef PLATFORM_IS_LINUX +#define PLATFORM_IS_LINUX +#elif defined(X64_64bit) && defined(__linux) && defined(__linux__) && defined(linux) +/* Linux. --------------------------------------------------- */ +#define PLATFORM_OS "Linux" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_LINUX "Linux" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_TYPE "Unix (Linux)" +#undef PLATFORM_IS_LINUX +#define PLATFORM_IS_LINUX +/* Linux. --------------------------------------------------- */ +#elif defined(ARM64_BIT) && defined(__linux) && defined(__linux__) && !defined(ANDROID) +#define PLATFORM_OS "Linux" +#define PLATFORM_ARCH "arm64 (aarch64)" +#define PLATFORM_LINUX "Linux" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_TYPE "Unix (Linux)" +#undef PLATFORM_IS_LINUX +#define PLATFORM_IS_LINUX +#endif + +/* + * OSX, iOS, and Darwin + * Developer: Apple and open source + * Distributions: OSX, iOS, Darwin + * Processors: x86, x86-64, ARM + */ + +#if defined(__APPLE__) && defined(__MACH__) +// Detect for x86 +/* Apple OSX and iOS (Darwin). ------------------------------ */ +#include +#if TARGET_OS_SIMULATOR == 1 +/* iOS in Xcode simulator */ +#define PLATFORM_OS "Apple iOS" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_MOBILE +#define PLATFORM_IOS_SIMULATOR "iOS Simulator" +#define PLATFORM_TYPE "iOS-Emulator" +#undef PLATFORM_IS_IOS_EMULATOR +#define PLATFORM_IS_IOS_EMULATOR +#elif TARGET_OS_WATCH == 1 +/* iOS on iWatch. */ +#define PLATFORM_OS "Apple iOS" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_MOBILE +#define PLATFORM_IWATCH "iOS (iWatch)" +#define PLATFORM_TYPE "iWatch" +#undef PLATFORM_IS_IWATCH +#define PLATFORM_IS_IWATCH +#elif TARGET_OS_TV == 1 +/* Apple TV. */ +#define PLATFORM_OS "Apple iOS" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_MOBILE +#define PLATFORM_APPLE_TV "Apple (TV)" +#define PLATFORM_TYPE "Apple TV" +#undef PLATFORM_IS_IOS_APPLE_TV +#define PLATFORM_IS_IOS_APPLE_TV +#elif TARGET_OS_IPHONE == 1 +/* iOS on iPhone, iPad, etc. */ +#if defined(__arm__) && !defined(__arm64__) +#define PLATFORM_OS "Apple iOS" +#define PLATFORM_ARCH "arm (32-Bit)" +#define PLATFORM_MOBILE +#define PLATFORM_IOS "iOS" +#define PLATFORM_DEVICE "Mobile" +#define PLATFORM_TYPE "iPhone, iPad" +#undef PLATFORM_IS_IOS +#define PLATFORM_IS_IOS +#elif !defined(__arm__) && defined(__arm64__) +#define PLATFORM_OS "Apple iOS" +#define PLATFORM_ARCH "arm64 (64-Bit)" +#define PLATFORM_MOBILE +#define PLATFORM_IOS "iOS" +#define PLATFORM_DEVICE "Mobile" +#define PLATFORM_TYPE "iPhone, iPad" +#undef PLATFORM_IS_IOS +#define PLATFORM_IS_IOS +#endif +#elif TARGET_OS_MAC == 1 +/* macOS */ +#define PLATFORM_OS "macOS" +#define PLATFORM_ARCH ARCHITECTURE +#define PLATFORM_DESKTOP +#define PLATFORM_MAC "Unix(Darwin)-macOS (X11)" +#define PLATFORM_DEVICE "Unix(Darwin)-macOS (X11)" +#define PLATFORM_TYPE "Macintosh" +#undef PLATFORM_IS_MAC +#define PLATFORM_IS_MAC +#endif +#endif +#if defined(_APPLE) && defined(_LINUX) || \ + defined(__APPLE__) && defined(__LINUX__) +#error Conflicting operating system option selected, choose one. +#endif + +/* + * Solaris + * Developer: Oracle and open source + * Distributions: Oracle Solaris, Open Indiana + * Processors: x86, x86-64, SPARC + */ + +#if defined(X86_32bit) && defined(__sun) && defined(__SVR4) +/* Solaris. ------------------------------------------------- */ +#define PLATFORM_OS "Solaris" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_SOLARIS "Solaris" +#define PLATFORM_TYPE "SUN (Solaris)" +#elif defined(X64_64bit) && defined(__sun) && defined(__SVR4) +/* Solaris. ------------------------------------------------- */ +#define PLATFORM_OS "Solaris" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_SOLARIS "Solaris" +#define PLATFORM_TYPE "SUN (Solaris)" +#endif + +/* + * Android + * Developer: Google + * Distributions: Android + * Processors: x86, x86-64, ARM + */ + +#if !defined(__aarch64__) && defined(__ANDROID__) && defined(__ARM_ARCH) || defined(__ARM_ARCH_7A__) +/* Android. ------------------------------------------------- */ +#define PLATFORM_OS "Linux" +#define PLATFORM_ANDROID "Linux (Android)" +#undef PLATFORM_DEVICE +#define PLATFORM_DEVICE "Mobile" +#undef PLATFORM_MOBILE +#define PLATFORM_MOBILE +#undef PLATFORM_ARCH +#define PLATFORM_ARCH "armv7a (32-Bit)" +#undef PLATFORM_TYPE +#define PLATFORM_TYPE "Android" +#undef PLATFORM_IS_ANDROID +#define PLATFORM_IS_ANDROID +#elif defined(__aarch64__) && defined(__ANDROID__) +/* Android. ------------------------------------------------- */ +#define PLATFORM_OS "Linux" +#define PLATFORM_ANDROID "Linux (Android)" +#undef PLATFORM_DEVICE +#define PLATFORM_DEVICE "Mobile" +#undef PLATFORM_MOBILE +#define PLATFORM_MOBILE +#undef PLATFORM_ARCH +#define PLATFORM_ARCH "arm64-v8a (64-Bit)" +#undef PLATFORM_TYPE +#define PLATFORM_TYPE "Android" +#undef PLATFORM_IS_ANDROID +#define PLATFORM_IS_ANDROID +#elif defined(X86_64BIT) && !defined(__aarch64__) && !defined(__ARM_ARCH) && defined(__ANDROID__) +/* Android. ------------------------------------------------- */ +#define PLATFORM_OS "Linux" +#define PLATFORM_ANDROID "Linux (Android)" +#undef PLATFORM_DEVICE +#define PLATFORM_DEVICE "Mobile" +#undef PLATFORM_MOBILE +#define PLATFORM_MOBILE +#undef PLATFORM_ARCH +#define PLATFORM_ARCH "x86 (32-Bit)" +#undef PLATFORM_TYPE +#define PLATFORM_TYPE "Android" +#undef PLATFORM_IS_ANDROID +#define PLATFORM_IS_ANDROID +#elif defined(X64_64BIT) && !defined(__aarch64__) && !defined(__ARM_ARCH) && defined(__ANDROID__) +/* Android. ------------------------------------------------- */ +#define PLATFORM_OS "Linux" +#define PLATFORM_ANDROID "Linux (Android)" +#undef PLATFORM_DEVICE +#define PLATFORM_DEVICE "Mobile" +#undef PLATFORM_MOBILE +#define PLATFORM_MOBILE +#undef PLATFORM_ARCH +#define PLATFORM_ARCH "x86_64 (64-Bit)" +#undef PLATFORM_TYPE +#define PLATFORM_TYPE "Android" +#undef PLATFORM_IS_ANDROID +#define PLATFORM_IS_ANDROID +#endif + +/* + * Windows with Cygwin (POSIX) + * Developer: Open source + * Distributions: Cygwin + * Processors: x86 + */ + +#if defined(X86_32bit) && defined(__CYGWIN__) && !defined(_WIN32) +/* Cygwin POSIX under Microsoft Windows. -------------------- */ +#define PLATFORM_OS "Microsoft Windows" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_POSIX_WINDOWS "POSIX under Microsoft Windows" +#define PLATFORM_TYPE "POSIX under Microsoft Windows" +#elif defined(X64_64bit) && defined(__CYGWIN__) && !defined(_WIN32) +/* Cygwin POSIX under Microsoft Windows. -------------------- */ +#define PLATFORM_OS "Microsoft Windows" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_POSIX_WINDOWS "POSIX under Microsoft Windows" +#define PLATFORM_TYPE "POSIX under Microsoft Windows" +#undef PLATFORM_IS_WINDOWS +#define PLATFORM_IS_WINDOWS +#endif + +/* FreeBSD */ +#if defined(X86_32bit) && defined(__FreeBSD__) || defined(__FreeBSD) +#define CELL_P_FREEBSD +#define PLATFORM_OS "FreeBSD" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_FREEBSD "Linux (FreeBSD)" +#define PLATFORM_TYPE "FreeBSD" +#elif defined(X64_64bit) && defined(__FreeBSD__) || defined(__FreeBSD) +#define CELL_P_FREEBSD +#define PLATFORM_OS "FreeBSD" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_FREEBSD "Linux (FreeBSD)" +#undef PLATFORM_IS_FREEBSD +#define PLATFORM_IS_FREEBSD +#endif + +/* + * FreeBSD, ORBIS + * Developer: Sony + * Distributions: Orbis OS based on FreeBSD + * Processors: x86, x86-64 + */ + +/* Orbis (PS4) variant */ +#if defined(X86_32bit) && defined(CELL_P_FREEBSD) && defined(__ORBIS__) +#define PLATFORM_OS "Orbis" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_ORBIS "Linux (Orbis)" +#define PLATFORM_PLAYSTATION "Playstation" +#define PLATFORM_TYPE "Playstation" +#elif defined(X64_64bit) && defined(CELL_P_FREEBSD) && defined(__ORBIS__) +#define PLATFORM_OS "Orbis" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_ORBIS "Linux (Orbis)" +#define PLATFORM_TYPE "Playstation" +#undef PLATFORM_IS_PLAYSTATION +#define PLATFORM_IS_PLAYSTATION +#endif + +/* OpenBSD */ +#if defined(X86_32bit) && defined(__OpenBSD__) || defined(__OpenBSD) +#define PLATFORM_OS "Unix-like (BSD)" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_OPENBSD "OpenBSD" +#define PLATFORM_TYPE "OpenBSD" +#elif defined(X64_64bit) && defined(__OpenBSD__) || defined(__OpenBSD) +#define PLATFORM_OS "Unix-like (BSD)" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_OPENBSD "OpenBSD" +#define PLATFORM_TYPE "OpenBSD" +#undef PLATFORM_IS_OPENBSD +#define PLATFORM_IS_OPENBSD +#endif + +#if defined(_XBOX_ONE) && defined(_TITLE) +#define PLATFORM_OS "Windows 10.x" +#define PLATFORM_ARCH "AMD64 (x86-64)" +#define PLATFORM_XBOX "Windows 10 (Xbox)" +#define PLATFORM_TYPE "Xbox" +#undef PLATFORM_IS_XBOX +#define PLATFORM_IS_XBOX +#endif + +/* NetBSD */ +#if defined(X86_32bit) && defined(__NetBSD__) || defined(__NetBSD) +#define PLATFORM_OS "Unix (NetBSD)" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_BLACKBERRY "NetBSD" +#define PLATFORM_TYPE "NetBSD" +#elif defined(X64_64bit) && defined(__NetBSD__) || defined(__NetBSD) +#define PLATFORM_OS "Unix (NetBSD)" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_BLACKBERRY "NetBSD" +#define PLATFORM_TYPE "NetBSD" +#undef PLATFORM_IS_NETBSD +#define PLATFORM_IS_NETBSD +#endif + +/* QNX (Blackberry) variant */ +#if defined(X86_32bit) && defined(__QNXNTO__) || defined(__QNX__) +#define PLATFORM_OS "Unix (RTOS)" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_BLACKBERRY "QNX" +#define PLATFORM_TYPE "Blackberry" +#elif defined(X64_64bit) && defined(__QNXNTO__) || defined(__QNX__) +#define PLATFORM_OS "Unix (RTOS)" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_BLACKBERRY "QNX" +#define PLATFORM_TYPE "Blackberry" +#undef PLATFORM_IS_BLACKBERRY +#define PLATFORM_IS_BLACKBERRY +#endif + +/* VMS */ +#if defined(X86_32bit) && defined(VMS) || defined(__VMS) +#define PLATFORM_OS "OpenVMS" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_VMS "DEC (OpenVMS)" +#define PLATFORM_TYPE "DEC" +#elif defined(X64_64bit) && defined(VMS) || defined(__VMS) +#define PLATFORM_OS "OpenVMS" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_VMS "DEC (OpenVMS)" +#define PLATFORM_TYPE "DEC" +#undef PLATFORM_IS_OPENVMS +#define PLATFORM_IS_OPENVMS +#endif + +/* VXWORKS variant */ +#if defined(X86_32bit) && defined(VXWORKS) +#define PLATFORM_OS "RTOS" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_VXWORKS "Monolithic" +#define PLATFORM_TYPE "VXWORKS" +#elif defined(X64_64bit) && defined(VXWORKS) +#define PLATFORM_OS "RTOS" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_VXWORKS "Monolithic" +#define PLATFORM_TYPE "VXWORKS" +#undef PLATFORM_IS_VXWORKS +#define PLATFORM_IS_VXWORKS +#endif + +/* Motorola 68K. Not defined by VBCC, so user must define one of these + * manually when using VBCC. + */ +#if defined(X86_32bit) && defined(__m68k__) || defined(M68000) || \ + defined(__MC68K__) +#define PLATFORM_OS "68K" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_MOTOROLA "Motorola (68K)" +#define PLATFORM_TYPE "Motorola 68K" +#elif defined(X64_64bit) && defined(__m68k__) || defined(M68000) || \ + defined(__MC68K__) +#define PLATFORM_OS "68K" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_MOTOROLA "Motorola (68K)" +#define PLATFORM_TYPE "Motorola 68K" +#endif + +/* Ultrix */ +#if defined(X86_32bit) && defined(ultrix) || defined(__ultrix) || \ + defined(__ultrix__) +#define PLATFORM_OS "Ultrix Os" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_ULTRIX "Ultrix" +#define PLATFORM_TYPE "Ultrix" +#elif defined(X86_32bit) && defined(unix) && defined(vax) +#define PLATFORM_OS "Ultrix Os" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_ULTRIX "Ultrix" +#define PLATFORM_TYPE "Ultrix" +#elif defined(X64_64bit) && defined(ultrix) || defined(__ultrix) || \ + defined(__ultrix__) +#define PLATFORM_OS "Ultrix Os" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_ULTRIX "Ultrix" +#define PLATFORM_TYPE "Ultrix" +#elif defined(X64_64bit) && defined(unix) && defined(vax) +#define PLATFORM_OS "Ultrix Os" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_ULTRIX "Ultrix" +#define PLATFORM_TYPE "Ultrix" +#undef PLATFORM_IS_ULTRIX +#define PLATFORM_IS_ULTRIX +#endif + +/* Embedded */ +#if defined(IS_EMBEDDED) +#define PLATFORM_EMBEDDED "Embedded" +#define PLATFORM_RPI "Embedded" +#endif + +/* Microsoft DOS */ +#if defined(MSDOS) || defined(__MSDOS__) || defined(_MSDOS) || defined(__DOS__) +#define PLATFORM_OS "Dos" +#define PLATFORM_DOS "Microsoft-DOS" +#define PLATFORM_ARCH "16-Bit" +#define PLATFORM_TYPE "MS-Dos" +#undef PLATFORM_IS_MSDOS +#define PLATFORM_IS_MSDOS +#endif + +/* + * Windows, Cygwin (non-POSIX), and MinGW + * Developer: Microsoft + * Distributions: Windows XP, Vista, 7, 8 + * Processors: x86, x86-64 + */ + + +#if defined(_WIN32) && !defined(_WIN64) && !defined (WINAPI_FAMILY_PHONE_APP) && (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP) +/* Microsoft Windows (32-bit). ------------------------------ */ +#define PLATFORM_OS "Windows" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_WINDOWS_X86 "Microsoft Windows (32-Bit)" +#define PLATFORM_WINDOWS "Microsoft Windows (32-Bit)" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_DESKTOP +#define PLATFORM_TYPE "PC" +#undef PLATFORM_IS_PC +#define PLATFORM_IS_PC +#elif defined(_WIN64) && defined(_WIN32) && !defined(_M_ARM64) && !defined (WINAPI_FAMILY_PHONE_APP) && (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP) +/* Microsoft Windows (64-bit). ------------------------------ */ +#define PLATFORM_OS "Windows" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_WINDOWS_X64 "Microsoft Windows (64-Bit)" +#define PLATFORM_WINDOWS "Microsoft Windows (64-Bit)" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_DESKTOP +#define PLATFORM_TYPE "PC" +#undef PLATFORM_IS_PC +#define PLATFORM_IS_PC +#elif defined(_M_ARM64) && defined(_WIN32) && !defined (WINAPI_FAMILY_PHONE_APP) && (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP) +/* Microsoft Windows (64-bit). ------------------------------ */ +#define PLATFORM_OS "Windows" +#define PLATFORM_ARCH "Arm64 (64-Bit)" +#define PLATFORM_WINDOWS_ARM64 "Microsoft Windows (64-Bit)" +#define PLATFORM_WINDOWS "Microsoft Windows (64-Bit)" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_DESKTOP +#define PLATFORM_TYPE "PC" +#undef PLATFORM_IS_PC +#define PLATFORM_IS_PC +/* Microsoft Phone ------------------------------ */ +#elif defined(WINAPI_FAMILY) && (WINAPI_FAMILY == WINAPI_FAMILY_APP) +/* Microsoft Windows Store or Universal Windows Platform - (32-bit). + * ------------------------------ */ +#define PLATFORM_OS "Windows" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_WINDOWS_X86 "Microsoft Windows (32-Bit)" +#define PLATFORM_WINDOWS_UWP "Microsoft Windows UWP (32-Bit)" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_DESKTOP +#define PLATFORM_TYPE "PC" +#undef PLATFORM_IS_PC +#define PLATFORM_IS_PC +#elif defined(WINAPI_FAMILY) && (WINAPI_FAMILY == WINAPI_FAMILY_APP) && \ + defined(_WIN64) && !defined(_WIN32) && !defined(_WIN32_WINNT) +/* Microsoft Windows (64-bit). ------------------------------ */ +#define PLATFORM_OS "Windows " +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_WINDOWS_X64 "Microsoft Windows x64" +#define PLATFORM_WINDOWS_UWP "Microsoft Windows UWP" +#define PLATFORM_DEVICE "Desktop" +#define PLATFORM_DESKTOP +#define PLATFORM_WINDOWS "Microsoft Windows" +#define PLATFORM_TYPE "PC" +#undef PLATFORM_IS_PC +#define PLATFORM_IS_PC +/* Microsoft Phone ------------------------------ */ +#elif defined(WINAPI_FAMILY) && (WINAPI_FAMILY == WINAPI_FAMILY_PHONE_APP) +/* Microsoft Windows (Phone). ------------------------------ */ +#define PLATFORM_OS "WindowsRT" +#define PLATFORM_ARCH "x86 (32-Bit)" +#define PLATFORM_WINDOWS_PHONE "Windows Phone" +#define PLATFORM_DEVICE "Mobile" +#define PLATFORM_MOBILE +#define PLATFORM_TYPE "Mobile (Windows Phone)" +#elif defined(_WIN64) && defined(WINAPI_FAMILY_PHONE_APP) +/* Microsoft Windows (Phone). ------------------------------ */ +#define PLATFORM_OS "WindowsRT" +#define PLATFORM_ARCH "x64 (64-Bit)" +#define PLATFORM_DEVICE "Mobile" +#define PLATFORM_WINDOWS_PHONE "Windows Phone" +#define PLATFORM_TYPE "Mobile (Windows Phone)" +#undef PLATFORM_IS_WINDOWS_PHONE +#define PLATFORM_IS_WINDOWS_PHPNE +#endif + +//! Language Standard Macro +#ifdef _MSC_VER + #if _MSC_VER < 1920 + #if __cplusplus == 199711L + #define CXX_STANDARD_98 199711L + #elif __cplusplus == 201103L || __cplusplus == 201100 + #define CXX_STANDARD_11 201100 + #elif __cplusplus == 201402L + #define CXX_STANDARD_14 + #elif __cplusplus == 201703L || __cplusplus == 201704L + #define CXX_STANDARD_17 201703L + #elif __cplusplus == 202002L + #define CXX_STANDARD_20 202002L + #endif + #else + #define CXX_STANDARD_20 202002L + #endif +#else + #if __cplusplus == 199711L + #define CXX_STANDARD_98 199711L + #elif __cplusplus == 201103L || __cplusplus == 201100 + #define CXX_STANDARD_11 201100 + #elif __cplusplus == 201402L + #define CXX_STANDARD_14 201402L + #elif __cplusplus == 201703L || __cplusplus == 201704L + #define CXX_STANDARD_17 201703L + #elif __cplusplus == 202002L + #define CXX_STANDARD_20 202002L + #endif +#endif diff --git a/utilities/preprocessor.hpp b/utilities/preprocessor.hpp index bae6389..82f89be 100644 --- a/utilities/preprocessor.hpp +++ b/utilities/preprocessor.hpp @@ -1,19 +1,9 @@ /*! * - * Copyright (c) 2021 Kambiz Asadzadeh - * Copyright (c) 2023 Genyleap + * Copyright (c) 2024 Kambiz Asadzadeh + * Copyright (c) 2024 Genyleap */ -#ifndef PREPROCESSOR_HPP -#define PREPROCESSOR_HPP - -/*! - * namespace Preprocessor - * This preprocessor helps you to detect compiler, platform, and architecture. - */ - -namespace Preprocessor { - //! COMPILERS #if defined(__clang__) /* Clang/LLVM. ---------------------------------------------- */ @@ -1263,7 +1253,3 @@ required. For example, an array dimension. #define CXX_STANDARD_20 202002L #endif #endif - -} // namespace Preprocessor - -#endif // PREPROCESSORS_HPP