forked from qedalab/vcd_assert
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
88 lines (72 loc) · 2.91 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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
cmake_minimum_required (VERSION 3.2)
project (Parse)
#Options
option(BUILD_TESTS "Build tests" FALSE)
option(BUILD_DOCS "Build documentation [unused]" FALSE)
include(cmake/warnings.cmake)
include(cmake/create_vcd_from_verilog.cmake)
#Include dependencies
find_package(fmt REQUIRED)
find_package(pegtl REQUIRED)
find_package(range-v3 0.3.6 REQUIRED)
find_package(CLI11 REQUIRED)
# add_library(verilog_parser INTERFACE)
# target_include_directories(verilog_parser INTERFACE "${PROJECT_SOURCE_DIR}/external/verilog-parser/src")
# add_subdirectory("${PROJECT_SOURCE_DIR}/external/verilog-parser/src")
# # target_compile_definitions(verilog_parser INTERFACE fms-extensions)
#Ensure C++17
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
#Add libparse library
add_library(libparse "src/parse")
target_include_directories(libparse PUBLIC "${PROJECT_SOURCE_DIR}/include/")
target_link_libraries(libparse PUBLIC range-v3 taocpp::pegtl)
target_add_warnings(libparse)
#Handle filesystem seperately
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
target_link_libraries(libparse PUBLIC c++experimental)
else()
target_link_libraries(libparse PUBLIC stdc++fs)
endif()
#Add libvcd library
add_library(libvcd "src/vcd")
target_include_directories(libvcd PUBLIC "${PROJECT_SOURCE_DIR}/include/")
target_link_libraries(libvcd PUBLIC libparse )
target_add_warnings(libvcd)
#Add libsdf library
add_library(libsdf "src/sdf")
target_include_directories(libsdf PUBLIC "${PROJECT_SOURCE_DIR}/include/")
target_link_libraries(libsdf PUBLIC libparse fmt::fmt)
# target_compile_definitions(libsdf PUBLIC -DVERBOSE_DEBUG_OUTPUT=1)
target_add_warnings(libsdf)
#Add libverilog library
add_library(libverilog "src/verilog")
target_include_directories(libverilog PUBLIC "${PROJECT_SOURCE_DIR}/include/")
target_link_libraries(libverilog PUBLIC libparse fmt::fmt)
# target_compile_definitions(libverilog PUBLIC -DVERBOSE_DEBUG_OUTPUT=1)
target_add_warnings(libverilog)
#Add vcd_assert library
add_library(libvcd_assert "src/vcd_assert")
target_include_directories(libvcd PUBLIC "${PROJECT_SOURCE_DIR}/include/")
target_link_libraries(libvcd_assert PUBLIC libvcd libsdf libverilog libparse)
target_add_warnings(libvcd_assert)
add_subdirectory(src)
if(${BUILD_TESTS})
option(RUN_ALL_TESTS "Run slow hidden tests" FALSE)
find_package(Catch2 2.2.3 REQUIRED)
include(CTest)
add_subdirectory(tests)
set_target_properties(unit_parse unit_parse unit_vcd unit_vcd_assert
unit_sdf unit_verilog libvcd_bench_grammar
PROPERTIES
ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib"
LIBRARY_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib"
RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
)
endif()
set_target_properties(libparse libvcd libvcd_assert vcd_assert libsdf libverilog
PROPERTIES
ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib"
LIBRARY_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/lib"
RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
)