-
Notifications
You must be signed in to change notification settings - Fork 2
/
CMakeLists.txt
58 lines (48 loc) · 1.76 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# SPDX-FileCopyrightText: 2023 The Naja verilog authors <https://github.com/najaeda/naja-verilog/blob/main/AUTHORS>
#
# SPDX-License-Identifier: Apache-2.0
cmake_minimum_required(VERSION 3.21)
project(naja-verilog LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 20)
include(GNUInstallDirs)
#For Finding flex include path on MacOS with homebrew installation
set(CMAKE_INCLUDE_PATH ${CMAKE_INCLUDE_PATH} /opt/homebrew/opt/flex/include)
set(CMAKE_INCLUDE_PATH ${CMAKE_INCLUDE_PATH} /usr/local/opt/flex/include)
find_package(BISON REQUIRED)
find_package(FLEX REQUIRED)
add_library(naja_verilog_coverage_config INTERFACE)
option(CODE_COVERAGE "Enable coverage reporting" OFF)
if(CODE_COVERAGE)
# Add required flags (GCC & LLVM/Clang)
target_compile_options(naja_verilog_coverage_config INTERFACE
-O0 # no optimization
-g # generate debug info
--coverage # sets all required flags
)
target_link_options(naja_verilog_coverage_config INTERFACE --coverage)
endif(CODE_COVERAGE)
add_library(naja_verilog_sanitizers_config INTERFACE)
option(ENABLE_SANITIZERS "Enable sanitizers in compilation" OFF)
if(ENABLE_SANITIZERS)
target_compile_options(naja_verilog_sanitizers_config INTERFACE
-fsanitize=address
-fno-omit-frame-pointer
#-fsanitize=thread
)
target_link_options(naja_verilog_sanitizers_config INTERFACE
-fsanitize=address
#-fsanitize=thread
)
endif(ENABLE_SANITIZERS)
add_subdirectory(src)
if(PROJECT_IS_TOP_LEVEL)
add_subdirectory(cmake)
if(EXISTS "${PROJECT_SOURCE_DIR}/thirdparty/googletest/CMakeLists.txt")
#Build tests only if module is top level
#and if googletest submodule has been added.
add_subdirectory(thirdparty)
include(CTest)
enable_testing()
add_subdirectory(test)
endif()
endif(PROJECT_IS_TOP_LEVEL)