summaryrefslogtreecommitdiff
path: root/CMakeLists.txt
diff options
context:
space:
mode:
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r--CMakeLists.txt65
1 files changed, 37 insertions, 28 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index f5ff1d2..a6d5c2e 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -1,60 +1,69 @@
cmake_minimum_required(VERSION 2.8.4)
project(TgBot)
-### options
+# options
option(ENABLE_TESTS "Set to ON to enable building of tests" OFF)
option(BUILD_SHARED_LIBS "Build tgbot-cpp shared/static library." OFF)
-### sources
+# sources
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall")
include_directories(include)
set(SRC_LIST
- src/Api.cpp
- src/TgTypeParser.cpp
- src/TgException.cpp
- src/EventHandler.cpp
- src/net/Url.cpp
- src/net/HttpClient.cpp
- src/net/HttpParser.cpp
- src/net/TgLongPoll.cpp
- src/tools/StringTools.cpp
- src/tools/FileTools.cpp
- src/types/InlineQueryResult.cpp
- src/types/InputFile.cpp
+ src/Api.cpp
+ src/EventHandler.cpp
+ src/TgException.cpp
+ src/TgTypeParser.cpp
+ src/net/BoostHttpOnlySslClient.cpp
+ src/net/CurlHttpClient.cpp
+ src/net/HttpParser.cpp
+ src/net/TgLongPoll.cpp
+ src/net/Url.cpp
+ src/tools/FileTools.cpp
+ src/tools/StringTools.cpp
+ src/types/InlineQueryResult.cpp
+ src/types/InputFile.cpp
)
-### libs
-# threads
+# libs
+## threads
find_package(Threads REQUIRED)
-# openssl
+## openssl
find_package(OpenSSL REQUIRED)
include_directories(${OPENSSL_INCLUDE_DIR})
-# boost
+## curl
+find_package(CURL)
+if (CURL_FOUND)
+ include_directories(${CURL_INCLUDE_DIRS})
+ add_definitions(-DHAVE_CURL)
+endif()
+
+## boost
set(Boost_USE_MULTITHREADED ON)
if (ENABLE_TESTS)
- find_package(Boost 1.59.0 COMPONENTS system unit_test_framework REQUIRED)
+ find_package(Boost 1.59.0 COMPONENTS system unit_test_framework REQUIRED)
else()
- find_package(Boost 1.59.0 COMPONENTS system REQUIRED)
+ find_package(Boost 1.59.0 COMPONENTS system REQUIRED)
endif()
include_directories(${Boost_INCLUDE_DIR})
set(LIB_LIST
- ${CMAKE_THREAD_LIBS_INIT}
- ${OPENSSL_LIBRARIES}
- ${Boost_LIBRARIES}
+ ${CMAKE_THREAD_LIBS_INIT}
+ ${OPENSSL_LIBRARIES}
+ ${Boost_LIBRARIES}
+ ${CURL_LIBRARIES}
)
-### building project
+# building project
add_library(${PROJECT_NAME} ${SRC_LIST})
target_link_libraries(${PROJECT_NAME} ${LIB_LIST})
install(TARGETS ${PROJECT_NAME} DESTINATION lib)
install(DIRECTORY include/ DESTINATION include)
-### tests
+# tests
if (ENABLE_TESTS)
- message(STATUS "Building of tests is enabled")
- enable_testing()
- add_subdirectory(test)
+ message(STATUS "Building of tests is enabled")
+ enable_testing()
+ add_subdirectory(test)
endif()