From 86904d513734134beffc29c6f4012d53a99f25c5 Mon Sep 17 00:00:00 2001
From: Ferenc Szontágh <szf@fsociety.hu>
Date: Sun, 13 Apr 2025 15:38:34 +0000
Subject: [PATCH] some clean up, added function declaration
---
CMakeLists.txt | 53 +++++++++++++++++++++++++++++++++++++++++------------
1 files changed, 41 insertions(+), 12 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 95bdf33..d6d4bf2 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -9,32 +9,61 @@
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
+set(NEED_CLI ON)
+set(NEED_TESTS OFF)
+set(NEED_STATIC_LIBS ON)
+set(NEED_SHARED_LIBS ON)
-option(BUILD_CLI, "Build example commandline intrepeter" ON)
-option(BUILD_TESTS, "Build tests" OFF)
-option(BUILD_SHARED_LIBS "Build shared library" ON)
-option(BUILD_STATIC_LIBS "Build static library" ON)
+option(BUILD_CLI, "Build example commandline intrepeter" ${NEED_CLI})
+option(BUILD_TESTS, "Build tests" ${NEED_TESTS})
+option(BUILD_SHARED_LIBS "Build shared library" ${NEED_SHARED_LIBS})
+option(BUILD_STATIC_LIBS "Build static library" ${NEED_STATIC_LIBS})
+
+if (BUILD_CLI)
+ set(NEED_CLI ${BUILD_CLI})
+endif()
+if (BUILD_TESTS)
+ set(NEED_TESTS ${BUILD_TESTS})
+endif()
+
+if (BUILD_SHARED_LIBS)
+ set(NEED_SHARED_LIBS ${BUILD_SHARED_LIBS})
+endif()
+
+if (BUILD_STATIC_LIBS)
+ set(NEED_STATIC_LIBS ${BUILD_STATIC_LIBS})
+endif()
set(COMMENT_CHARACTER "#")
+set(PARSER_OPEN_TAG "<?void")
+set(PARSER_CLOSE_TAG "?>")
-message(STATUS "BUILD_CLI: ${BUILD_CLI}")
-message(STATUS "BUILD_TESTS: ${BUILD_TESTS}")
-message(STATUS "\tCOMMENT_CHARACTER: ${COMMENT_CHARACTER}")
+message(STATUS "BUILD_CLI: ${NEED_CLI}")
+message(STATUS "BUILD_TESTS: ${NEED_TESTS}")
+message(STATUS "BUILD_SHARED_LIBS: ${NEED_SHARED_LIBS}")
+message(STATUS "BUILD_STATIC_LIBS: ${NEED_STATIC_LIBS}")
+message(STATUS " COMMENT_CHARACTER: ${COMMENT_CHARACTER}")
+message(STATUS " PARSER_OPEN_TAG: ${PARSER_OPEN_TAG}")
+message(STATUS " PARSER_CLOSE_TAG: ${PARSER_CLOSE_TAG}")
if (CMAKE_BUILD_TYPE STREQUAL "")
- set(CMAKE_BUILD_TYPE Release)
- message(STATUS "CMAKE_BUILD_TYPE is not set, defaulting to Release")
+ set(CMAKE_BUILD_TYPE Release CACHE STRING "Build type" FORCE)
endif()
message(STATUS "CMAKE_BUILD_TYPE: ${CMAKE_BUILD_TYPE}")
+
if (CMAKE_BUILD_TYPE STREQUAL "Debug")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g")
set(DEBUG_BUILD ON)
endif()
configure_file("cmake/options.h.in" "include/options.h" @ONLY)
+configure_file("test_scripts/test1.vs" "test_scripts/test1.vs" @ONLY)
+configure_file("test_scripts/test2.vs" "test_scripts/test2.vs" @ONLY)
+
+
include_directories(${CMAKE_BINARY_DIR}/include)
include_directories(src)
@@ -45,12 +74,12 @@
src/Lexer.cpp
)
-if (BUILD_SHARED_LIBS)
+if (NEED_SHARED_LIBS)
add_library(${CMAKE_PROJECT_NAME} SHARED)
target_sources(${CMAKE_PROJECT_NAME} PRIVATE ${SOURCES})
set_target_properties(${CMAKE_PROJECT_NAME} PROPERTIES OUTPUT_NAME ${CMAKE_PROJECT_NAME})
endif()
-if (BUILD_STATIC_LIBS)
+if (NEED_STATIC_LIBS)
add_library(${CMAKE_PROJECT_NAME}_static STATIC)
target_sources(${CMAKE_PROJECT_NAME}_static PRIVATE ${SOURCES})
set_target_properties(${CMAKE_PROJECT_NAME}_static PROPERTIES OUTPUT_NAME ${CMAKE_PROJECT_NAME})
@@ -59,7 +88,7 @@
set_target_properties(${CMAKE_PROJECT_NAME} PROPERTIES LINKER_LANGUAGE CXX)
-if (BUILD_CLI)
+if (NEED_CLI)
add_executable(cli cli/main.cpp)
add_dependencies(cli ${CMAKE_PROJECT_NAME})
if (BUILD_SHARED_LIBS)
--
Gitblit v1.9.3