aboutsummaryrefslogtreecommitdiff
path: root/ports/libaaplus/fix-cmakelists.patch
blob: a57e05b3b4969d01deecc19a9dfbd0caf1f8d360 (plain)
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
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 9bb8ea3..c445c4b 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -5,6 +5,7 @@ cmake_minimum_required(VERSION 3.8)
 SET(CMAKE_CXX_STANDARD 17)
 SET(CMAKE_CXX_STANDARD_REQUIRED ON)
 
+option(BUILD_TOOLS "Build libaaplus tools" OFF)
 #-----------------------------------------------------------------------------
 # Output directories.
 SET(EXECUTABLE_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin CACHE PATH
@@ -261,18 +262,66 @@ SET ( SRCS
 #-----------------------------------------------------------------------------
 # Executables.
 #-----------------------------------------------------------------------------
+if(BUILD_TOOLS)
 ADD_EXECUTABLE(AATest ${SRCS} )
-
+endif()
 #-----------------------------------------------------------------------------
 # Libraries.
+if(NOT BUILD_SHARED_LIBS)
 ADD_LIBRARY(aaplus-static STATIC ${SRCS_LIB} ${INCS})
 SET_TARGET_PROPERTIES(aaplus-static PROPERTIES OUTPUT_NAME "aaplus")
-
+target_include_directories(aaplus-static PUBLIC $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}> $<INSTALL_INTERFACE:include/aaplus>)
+else()
 ADD_LIBRARY(aaplus-shared SHARED ${SRCS_LIB} ${INCS})
 SET_TARGET_PROPERTIES(aaplus-shared PROPERTIES OUTPUT_NAME "aaplus")
+target_include_directories(aaplus-shared PUBLIC $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}> $<INSTALL_INTERFACE:include/aaplus>)
+endif()
+
+if (MSVC AND BUILD_SHARED_LIBS)
+target_compile_definitions(aaplus-shared
+    PRIVATE
+        -DAAPLUS_EXT_CLASS\=__declspec\(dllexport\)
+)
+endif (MSVC AND BUILD_SHARED_LIBS)
+
+if(BUILD_SHARED_LIBS)
+    install(
+        TARGETS aaplus-shared
+        EXPORT aaplus
+        ARCHIVE DESTINATION lib
+        LIBRARY DESTINATION lib
+        RUNTIME DESTINATION bin
+    )
+else()
+    install(
+        TARGETS aaplus-static
+        EXPORT aaplus
+        ARCHIVE DESTINATION lib
+        LIBRARY DESTINATION lib
+        RUNTIME DESTINATION bin
+    )
+endif()
 
-install(TARGETS aaplus-shared aaplus-static 
-		DESTINATION "${CMAKE_INSTALL_PREFIX}/lib" )
+if(BUILD_TOOLS)
+    if(BUILD_SHARED_LIBS)
+        TARGET_LINK_LIBRARIES(AATest aaplus-shared)
+        if(MSVC)
+            target_compile_definitions(AATest
+                PUBLIC
+                -DAAPLUS_EXT_CLASS\=__declspec\(dllimport\)
+        )
+        endif()
+        
+    else()
+        TARGET_LINK_LIBRARIES(AATest aaplus-static)
+    endif()    
+endif()
 
-TARGET_LINK_LIBRARIES(AATest aaplus-static)
+install(
+    EXPORT aaplus
+    DESTINATION share/aaplus
+    FILE aaplusConfig.cmake
+    NAMESPACE aaplus::
+)
 
+install(FILES ${INCS} DESTINATION include/aaplus)
\ No newline at end of file