|  | # Licensed to the Apache Software Foundation (ASF) under one | 
|  | # or more contributor license agreements.  See the NOTICE file | 
|  | # distributed with this work for additional information | 
|  | # regarding copyright ownership.  The ASF licenses this file | 
|  | # to you under the Apache License, Version 2.0 (the | 
|  | # "License"); you may not use this file except in compliance | 
|  | # with the License.  You may obtain a copy of the License at | 
|  | # | 
|  | #   http://www.apache.org/licenses/LICENSE-2.0 | 
|  | # | 
|  | # Unless required by applicable law or agreed to in writing, | 
|  | # software distributed under the License is distributed on an | 
|  | # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
|  | # KIND, either express or implied.  See the License for the | 
|  | # specific language governing permissions and limitations | 
|  | # under the License. | 
|  |  | 
|  | cmake_minimum_required(VERSION 2.8.10) | 
|  | project(dynamic_partition_echo_c++ C CXX) | 
|  |  | 
|  | option(LINK_SO "Whether examples are linked dynamically" OFF) | 
|  |  | 
|  | execute_process( | 
|  | COMMAND bash -c "find ${PROJECT_SOURCE_DIR}/../.. -type d -regex \".*output/include$\" | head -n1 | xargs dirname | tr -d '\n'" | 
|  | OUTPUT_VARIABLE OUTPUT_PATH | 
|  | ) | 
|  |  | 
|  | set(CMAKE_PREFIX_PATH ${OUTPUT_PATH}) | 
|  |  | 
|  | include(FindThreads) | 
|  | include(FindProtobuf) | 
|  | protobuf_generate_cpp(PROTO_SRC PROTO_HEADER echo.proto) | 
|  | # include PROTO_HEADER | 
|  | include_directories(${CMAKE_CURRENT_BINARY_DIR}) | 
|  |  | 
|  | find_path(GPERFTOOLS_INCLUDE_DIR NAMES gperftools/heap-profiler.h) | 
|  | find_library(GPERFTOOLS_LIBRARIES NAMES tcmalloc_and_profiler) | 
|  | include_directories(${GPERFTOOLS_INCLUDE_DIR}) | 
|  |  | 
|  | # Search for libthrift* by best effort. If it is not found and brpc is | 
|  | # compiled with thrift protocol enabled, a link error would be reported. | 
|  | find_library(THRIFT_LIB NAMES thrift) | 
|  | if (NOT THRIFT_LIB) | 
|  | set(THRIFT_LIB "") | 
|  | endif() | 
|  |  | 
|  | find_path(BRPC_INCLUDE_PATH NAMES brpc/server.h) | 
|  | if(LINK_SO) | 
|  | find_library(BRPC_LIB NAMES brpc) | 
|  | else() | 
|  | find_library(BRPC_LIB NAMES libbrpc.a brpc) | 
|  | endif() | 
|  | if((NOT BRPC_INCLUDE_PATH) OR (NOT BRPC_LIB)) | 
|  | message(FATAL_ERROR "Fail to find brpc") | 
|  | endif() | 
|  | include_directories(${BRPC_INCLUDE_PATH}) | 
|  |  | 
|  | find_path(GFLAGS_INCLUDE_PATH gflags/gflags.h) | 
|  | find_library(GFLAGS_LIBRARY NAMES gflags libgflags) | 
|  | if((NOT GFLAGS_INCLUDE_PATH) OR (NOT GFLAGS_LIBRARY)) | 
|  | message(FATAL_ERROR "Fail to find gflags") | 
|  | endif() | 
|  | include_directories(${GFLAGS_INCLUDE_PATH}) | 
|  |  | 
|  | if(CMAKE_SYSTEM_NAME STREQUAL "Darwin") | 
|  | include(CheckFunctionExists) | 
|  | CHECK_FUNCTION_EXISTS(clock_gettime HAVE_CLOCK_GETTIME) | 
|  | if(NOT HAVE_CLOCK_GETTIME) | 
|  | set(DEFINE_CLOCK_GETTIME "-DNO_CLOCK_GETTIME_IN_MAC") | 
|  | endif() | 
|  | endif() | 
|  |  | 
|  | set(CMAKE_CXX_FLAGS "${DEFINE_CLOCK_GETTIME} -DNDEBUG -O2 -D__const__=__unused__ -pipe -W -Wall -Wno-unused-parameter -fPIC -fno-omit-frame-pointer") | 
|  | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DBRPC_ENABLE_CPU_PROFILER") | 
|  |  | 
|  | if(CMAKE_VERSION VERSION_LESS "3.1.3") | 
|  | if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU") | 
|  | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") | 
|  | endif() | 
|  | if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang") | 
|  | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") | 
|  | endif() | 
|  | else() | 
|  | set(CMAKE_CXX_STANDARD 11) | 
|  | set(CMAKE_CXX_STANDARD_REQUIRED ON) | 
|  | endif() | 
|  |  | 
|  | find_path(LEVELDB_INCLUDE_PATH NAMES leveldb/db.h) | 
|  | find_library(LEVELDB_LIB NAMES leveldb) | 
|  | if ((NOT LEVELDB_INCLUDE_PATH) OR (NOT LEVELDB_LIB)) | 
|  | message(FATAL_ERROR "Fail to find leveldb") | 
|  | endif() | 
|  | include_directories(${LEVELDB_INCLUDE_PATH}) | 
|  |  | 
|  | if(CMAKE_SYSTEM_NAME STREQUAL "Darwin") | 
|  | set(OPENSSL_ROOT_DIR | 
|  | "/usr/local/opt/openssl"    # Homebrew installed OpenSSL | 
|  | ) | 
|  | endif() | 
|  |  | 
|  | find_package(OpenSSL) | 
|  | include_directories(${OPENSSL_INCLUDE_DIR}) | 
|  |  | 
|  |  | 
|  | set(DYNAMIC_LIB | 
|  | ${CMAKE_THREAD_LIBS_INIT} | 
|  | ${GFLAGS_LIBRARY} | 
|  | ${PROTOBUF_LIBRARIES} | 
|  | ${LEVELDB_LIB} | 
|  | ${OPENSSL_CRYPTO_LIBRARY} | 
|  | ${OPENSSL_SSL_LIBRARY} | 
|  | ${THRIFT_LIB} | 
|  | dl | 
|  | ) | 
|  |  | 
|  | if(CMAKE_SYSTEM_NAME STREQUAL "Darwin") | 
|  | set(DYNAMIC_LIB ${DYNAMIC_LIB} | 
|  | pthread | 
|  | "-framework CoreFoundation" | 
|  | "-framework CoreGraphics" | 
|  | "-framework CoreData" | 
|  | "-framework CoreText" | 
|  | "-framework Security" | 
|  | "-framework Foundation" | 
|  | "-Wl,-U,_MallocExtension_ReleaseFreeMemory" | 
|  | "-Wl,-U,_ProfilerStart" | 
|  | "-Wl,-U,_ProfilerStop" | 
|  | "-Wl,-U,__Z13GetStackTracePPvii" | 
|  | "-Wl,-U,_mallctl" | 
|  | "-Wl,-U,_malloc_stats_print" | 
|  | ) | 
|  | endif() | 
|  |  | 
|  | add_executable(dynamic_partition_echo_client client.cpp ${PROTO_SRC} ${PROTO_HEADER}) | 
|  | add_executable(dynamic_partition_echo_server server.cpp ${PROTO_SRC} ${PROTO_HEADER}) | 
|  |  | 
|  | target_link_libraries(dynamic_partition_echo_client ${BRPC_LIB} ${DYNAMIC_LIB} ${GPERFTOOLS_LIBRARIES}) | 
|  | target_link_libraries(dynamic_partition_echo_server ${BRPC_LIB} ${DYNAMIC_LIB} ${GPERFTOOLS_LIBRARIES}) | 
|  |  | 
|  | file(COPY ${PROJECT_SOURCE_DIR}/server_list | 
|  | DESTINATION ${CMAKE_CURRENT_BINARY_DIR}) |