“CMake”这个名字是“cross platform make”
cmake_百度百科 https://baike.baidu.com/item/cmake/7138032?fr=aladdin
功能
历史
组态档
message("== Configuring legacy connector build using cmake generator: ${CMAKE_GENERATOR}")
if(NOT EXISTS "${PROJECT_SOURCE_DIR}/jdbc/CMakeLists.txt")
message(FATAL_ERROR
"Could not find JDBC API sources at ${PROJECT_SOURCE_DIR}/jdbc."
" Have you updated git sub-modules?"
)
endif()
set(JDBC_DIR "${PROJECT_BINARY_DIR}/jdbc")
if(FORCE_REBUILD AND EXISTS "${JDBC_DIR}/CMakeCache.txt")
file(REMOVE ${JDBC_DIR}/CMakeCache.txt)
endif()
file(MAKE_DIRECTORY "${JDBC_DIR}")
#############################################################################
#
# Configure legacy connector build environment in ${JDBC_DIR}
#
if(BUILD_STATIC)
list(APPEND jdbc_cmake_opts -DENABLE_BUILD_STATIC=ON)
else()
list(APPEND jdbc_cmake_opts -DENABLE_BUILD_DYNAMIC=ON)
endif()
if(MAINTAINER_MODE)
list(APPEND jdbc_cmake_opts -DENABLE_BUILD_STATIC=ON)
endif()
if(MYSQL_DIR)
list(APPEND jdbc_cmake_opts -DMYSQL_DIR=${MYSQL_DIR})
endif()
if(MYSQL_CONFIG_EXECUTABLE)
list(APPEND jdbc_cmake_opts -DMYSQL_CONFIG_EXECUTABLE=${MYSQL_CONFIG_EXECUTABLE})
endif()
list(APPEND jdbc_cmake_opts -DMYSQLCLIENT_STATIC_LINKING=ON)
if(CMAKE_BUILD_TYPE)
if(CMAKE_BUILD_TYPE MATCHES "[Ss][Tt][Aa][Tt][Ii][Cc]")
list(APPEND jdbc_cmake_opts -DCMAKE_BUILD_TYPE=Release)
else()
list(APPEND jdbc_cmake_opts -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE})
endif()
endif()
if(DEFINED STATIC_MSVCRT)
list(APPEND jdbc_cmake_opts -DSTATIC_MSVCRT=${STATIC_MSVCRT})
endif()
if(VS)
list(APPEND jdbc_cmake_opts -DVS=${VS})
endif()
#
# Find Boost which is required by legacy connector
#
include(boost)
list(APPEND jdbc_cmake_opts -DBOOST_ROOT=${BOOST_ROOT})
#
# Generate version info for legacy connector
#
configure_file(
"${PROJECT_SOURCE_DIR}/jdbc/VersionInfo.cmake.in"
"${JDBC_DIR}/VersionInfo.cmake"
@ONLY
)
# Dirty trick to speed up cmake set up time.
file(
COPY "${CMAKE_BINARY_DIR}/CMakeFiles/${CMAKE_VERSION}"
DESTINATION "${JDBC_DIR}/CMakeFiles"
)
if(1)
execute_process(
COMMAND ${CMAKE_COMMAND} -Wno-dev
-G "${CMAKE_GENERATOR}"
${jdbc_cmake_opts}
-DCMAKE_INSTALL_PREFIX=${JDBC_DIR}/install
-DCMAKE_POSITION_INDEPENDENT_CODE=${CMAKE_POSITION_INDEPENDENT_CODE}
-DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER}
-DCMAKE_CXX_FLAGS=${CMAKE_CXX_FLAGS}
${PROJECT_SOURCE_DIR}/jdbc
WORKING_DIRECTORY ${JDBC_DIR}
RESULT_VARIABLE jdbc_config
)
endif()
if(jdbc_config)
message(FATAL_ERROR "Could not configure legacy connector build: ${jdbc_config}")
endif()
#############################################################################
#
# Target build_jdbc which triggers build and installation of the legacy
# connector.
#
#
# jdbc.buildstamp
#
set(JDBC_BUILD_STAMP "${PROJECT_BINARY_DIR}/jdbc.buildstamp")
file(REMOVE "${JDBC_BUILD_STAMP}")
#message("JDBC_BUILD_STAMP: ${JDBC_BUILD_STAMP}")
set(CONFIG_EXPR
$<$<CONFIG:Static>:Release>$<$<NOT:$<CONFIG:Static>>:$<CONFIGURATION>>
)
add_custom_command(OUTPUT ${JDBC_BUILD_STAMP}
COMMAND ${CMAKE_COMMAND} -E remove_directory install
COMMAND ${CMAKE_COMMAND}
--build . --target install --config ${CONFIG_EXPR} --clean-first
# Move installed headers from include/ to include/jdbc and rename lib/
# to lib64/ for 64-bit platform
COMMAND ${CMAKE_COMMAND} -E remove_directory install/jdbc
COMMAND ${CMAKE_COMMAND} -E rename install/include install/jdbc
COMMAND ${CMAKE_COMMAND} -E make_directory install/include
COMMAND ${CMAKE_COMMAND} -E copy_directory install/jdbc install/include/jdbc
COMMAND ${CMAKE_COMMAND} -E remove_directory install/jdbc
COMMAND ${CMAKE_COMMAND} -E touch ${JDBC_BUILD_STAMP}
WORKING_DIRECTORY ${JDBC_DIR}
COMMENT "Building legacy connector library using configuration: $(Configuration)"
)
# Collect sources of legacy connector and specify them in the build
# target.
unset(jdbc_sources)
foreach(dir driver cppconn thread)
file(
GLOB_RECURSE sources
#RELATIVE "${PROJECT_SOURCE_DIR}/jdbc/${dir}"
"${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.cpp"
"${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.h"
"${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.cmake"
"${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.cm"
"${PROJECT_SOURCE_DIR}/jdbc/${dir}/CMakeLists.txt"
)
# TODO: Split into Headers/Sources/Other sub-groups
source_group(${dir} FILES ${sources})
list(APPEND jdbc_sources ${sources})
endforeach()
add_custom_target(build_jdbc ALL
DEPENDS ${JDBC_BUILD_STAMP}
SOURCES ${jdbc_sources}
)
#############################################################################
#
# Import legacy connector library so that it can be used by other targets.
#
set(JDBC_INCLUDES ${Boost_INCLUDE_DIRS} "${JDBC_DIR}/install/include")
#message("legacy connector includes: ${JDBC_INCLUDES}")
#
# Import library targets exported from the legacy connector project.
#
include("${JDBC_DIR}/exports.cmake")
if(BUILD_STATIC)
set(JDBC_LIB mysqlcppconn-static)
else()
set(JDBC_LIB mysqlcppconn)
endif()
add_dependencies(${JDBC_LIB} build_jdbc)
set(JDBC_LIBS ${JDBC_LIB} CACHE INTERNAL "legacy connector library")
#############################################################################
#
# Installation specs for the legacy connector
#
get_target_property(configurations ${JDBC_LIB} IMPORTED_CONFIGURATIONS)
foreach(config ${configurations})
get_target_property(location ${JDBC_LIB} IMPORTED_LOCATION_${config})
message("jdbc installing: ${location}")
if(config STREQUAL DEBUG)
set(loc "${INSTALL_LIB_DIR}/debug")
set(loc_static "${INSTALL_LIB_DIR_STATIC}/debug")
else()
set(loc "${INSTALL_LIB_DIR}")
set(loc_static "${INSTALL_LIB_DIR_STATIC}")
endif()
if(BUILD_STATIC)
install(
FILES ${location}
CONFIGURATIONS ${config}
DESTINATION ${loc_static}
COMPONENT JDBCDev
)
else()
if(WIN32)
install(FILES ${location} CONFIGURATIONS ${config} DESTINATION ${loc} COMPONENT JDBCDll)
# install import library for the DLL
get_target_property(imp_location ${JDBC_LIB} IMPORTED_IMPLIB_${config})
install(
FILES ${imp_location}
CONFIGURATIONS ${config}
DESTINATION ${loc_static}
COMPONENT JDBCDev
)
else()
# We need to install soname and linkname links together with the shared
# library.
get_filename_component(name "${location}" NAME)
get_filename_component(loc_path "${location}" PATH)
get_target_property(soname ${JDBC_LIB} IMPORTED_SONAME_${config})
set(linkname "${CMAKE_SHARED_LIBRARY_PREFIX}mysqlcppconn${CMAKE_SHARED_LIBRARY_SUFFIX}")
#
# Warning: Using undocumented file(INSTALL ...) signature which creates
# required symlinks. This command is used in install scripts generated
# by cmake.
#
install(CODE
"file(INSTALL
DESTINATION \"\${CMAKE_INSTALL_PREFIX}/${loc}\"
TYPE SHARED_LIBRARY
FILES
\"${location}\"
\"${loc_path}/${soname}\"
\"${loc_path}/${linkname}\"
)"
)
endif()
endif()
endforeach()
install(
DIRECTORY ${JDBC_DIR}/install/include/jdbc
DESTINATION ${INSTALL_INCLUDE_DIR}
COMPONENT JDBCDev
)
#
# In maintainer mode add specifications for installing the static library
# which is always built in this mode.
#
if(MAINTAINER_MODE)
add_dependencies(mysqlcppconn-static build_jdbc)
get_target_property(location mysqlcppconn-static IMPORTED_LOCATION_RELEASE)
message("jdbc installing: ${location} (MAINTAINER_MODE)")
install(
FILES ${location}
CONFIGURATIONS Static
DESTINATION "${INSTALL_LIB_DIR_STATIC}"
COMPONENT JDBCDev
)
endif()
#
# Install external dependencies of MySQL client library, such as OpenSSL,
# if bundled with client library installation.
#
# Note: if main connector uses OpenSSL, then we will use the same libraries
# to satisfy client library dependency. But if main connector does not use
# OpenSSL, we copy required dependencies from MySQL installation.
#
if(BUNDLE_DEPENDENCIES AND WITH_SSL STREQUAL "bundled")
message("Bundling OpenSSL libraries from: ${MYSQL_DIR}")
install(DIRECTORY "${MYSQL_DIR}/bin/" DESTINATION lib64
FILES_MATCHING PATTERN "*${CMAKE_SHARED_LIBRARY_SUFFIX}"
COMPONENT JDBCDev
)
endif()
#############################################################################
#
# Public header checks
#
if(WITH_HEADER_CHECKS)
# Prepare location where checks will be performed.
set(CHECK_DIR "${JDBC_DIR}/headers_check")
file(REMOVE_RECURSE "${CHECK_DIR}")
file(MAKE_DIRECTORY "${CHECK_DIR}")
# Dirty trick to speed up cmake set up time.
file(
COPY "${CMAKE_BINARY_DIR}/CMakeFiles/${CMAKE_VERSION}"
DESTINATION "${CHECK_DIR}/CMakeFiles"
)
#
# Target to run header checks.
#
ADD_CUSTOM_TARGET(Headers_jdbc
COMMAND ${CMAKE_COMMAND}
-DCMAKE_GENERATOR=${CMAKE_GENERATOR}
-DJDBC_DIR=${JDBC_DIR}
-DJDBC_INCLUDES="${JDBC_INCLUDES}"
-DHEADERS_DIR=${PROJECT_SOURCE_DIR}/cdk/cmake/headers
-DCHECK_DIR=${CHECK_DIR}
-P ${PROJECT_SOURCE_DIR}/cmake/jdbc_headers_check.cmake
SOURCES ${all_headers}
)
add_dependencies(Headers_jdbc build_jdbc)
add_test(NAME Headers_jdbc
COMMAND cmake --build . --target Headers_jdbc
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
)
message(STATUS "Added JDBC public headers test")
endif()
message("== legacy connector build configured")
message("== Configuring legacy connector build using cmake generator: ${CMAKE_GENERATOR}")
if(NOT EXISTS "${PROJECT_SOURCE_DIR}/jdbc/CMakeLists.txt") message(FATAL_ERROR "Could not find JDBC API sources at ${PROJECT_SOURCE_DIR}/jdbc." " Have you updated git sub-modules?" )endif()
set(JDBC_DIR "${PROJECT_BINARY_DIR}/jdbc")
if(FORCE_REBUILD AND EXISTS "${JDBC_DIR}/CMakeCache.txt") file(REMOVE ${JDBC_DIR}/CMakeCache.txt)endif()file(MAKE_DIRECTORY "${JDBC_DIR}")
############################################################################### Configure legacy connector build environment in ${JDBC_DIR}#
if(BUILD_STATIC) list(APPEND jdbc_cmake_opts -DENABLE_BUILD_STATIC=ON)else() list(APPEND jdbc_cmake_opts -DENABLE_BUILD_DYNAMIC=ON)endif()
if(MAINTAINER_MODE) list(APPEND jdbc_cmake_opts -DENABLE_BUILD_STATIC=ON)endif()
if(MYSQL_DIR) list(APPEND jdbc_cmake_opts -DMYSQL_DIR=${MYSQL_DIR})endif()
if(MYSQL_CONFIG_EXECUTABLE) list(APPEND jdbc_cmake_opts -DMYSQL_CONFIG_EXECUTABLE=${MYSQL_CONFIG_EXECUTABLE})endif()
list(APPEND jdbc_cmake_opts -DMYSQLCLIENT_STATIC_LINKING=ON)
if(CMAKE_BUILD_TYPE) if(CMAKE_BUILD_TYPE MATCHES "[Ss][Tt][Aa][Tt][Ii][Cc]") list(APPEND jdbc_cmake_opts -DCMAKE_BUILD_TYPE=Release) else() list(APPEND jdbc_cmake_opts -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}) endif()endif()
if(DEFINED STATIC_MSVCRT) list(APPEND jdbc_cmake_opts -DSTATIC_MSVCRT=${STATIC_MSVCRT})endif()
if(VS) list(APPEND jdbc_cmake_opts -DVS=${VS})endif()
## Find Boost which is required by legacy connector#
include(boost)list(APPEND jdbc_cmake_opts -DBOOST_ROOT=${BOOST_ROOT})
## Generate version info for legacy connector#
configure_file( "${PROJECT_SOURCE_DIR}/jdbc/VersionInfo.cmake.in" "${JDBC_DIR}/VersionInfo.cmake" @ONLY)
# Dirty trick to speed up cmake set up time.
file( COPY "${CMAKE_BINARY_DIR}/CMakeFiles/${CMAKE_VERSION}" DESTINATION "${JDBC_DIR}/CMakeFiles")
if(1)execute_process( COMMAND ${CMAKE_COMMAND} -Wno-dev -G "${CMAKE_GENERATOR}" ${jdbc_cmake_opts} -DCMAKE_INSTALL_PREFIX=${JDBC_DIR}/install -DCMAKE_POSITION_INDEPENDENT_CODE=${CMAKE_POSITION_INDEPENDENT_CODE} -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER} -DCMAKE_CXX_FLAGS=${CMAKE_CXX_FLAGS} ${PROJECT_SOURCE_DIR}/jdbc WORKING_DIRECTORY ${JDBC_DIR} RESULT_VARIABLE jdbc_config)endif()
if(jdbc_config) message(FATAL_ERROR "Could not configure legacy connector build: ${jdbc_config}")endif()
############################################################################### Target build_jdbc which triggers build and installation of the legacy# connector.#
## jdbc.buildstamp#
set(JDBC_BUILD_STAMP "${PROJECT_BINARY_DIR}/jdbc.buildstamp")file(REMOVE "${JDBC_BUILD_STAMP}")#message("JDBC_BUILD_STAMP: ${JDBC_BUILD_STAMP}")
set(CONFIG_EXPR $<$<CONFIG:Static>:Release>$<$<NOT:$<CONFIG:Static>>:$<CONFIGURATION>>)
add_custom_command(OUTPUT ${JDBC_BUILD_STAMP}
COMMAND ${CMAKE_COMMAND} -E remove_directory install COMMAND ${CMAKE_COMMAND} --build . --target install --config ${CONFIG_EXPR} --clean-first
# Move installed headers from include/ to include/jdbc and rename lib/ # to lib64/ for 64-bit platform
COMMAND ${CMAKE_COMMAND} -E remove_directory install/jdbc COMMAND ${CMAKE_COMMAND} -E rename install/include install/jdbc COMMAND ${CMAKE_COMMAND} -E make_directory install/include COMMAND ${CMAKE_COMMAND} -E copy_directory install/jdbc install/include/jdbc COMMAND ${CMAKE_COMMAND} -E remove_directory install/jdbc
COMMAND ${CMAKE_COMMAND} -E touch ${JDBC_BUILD_STAMP}
WORKING_DIRECTORY ${JDBC_DIR} COMMENT "Building legacy connector library using configuration: $(Configuration)")
# Collect sources of legacy connector and specify them in the build# target.
unset(jdbc_sources)foreach(dir driver cppconn thread)
file( GLOB_RECURSE sources #RELATIVE "${PROJECT_SOURCE_DIR}/jdbc/${dir}" "${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.cpp" "${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.h" "${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.cmake" "${PROJECT_SOURCE_DIR}/jdbc/${dir}/*.cm" "${PROJECT_SOURCE_DIR}/jdbc/${dir}/CMakeLists.txt" )
# TODO: Split into Headers/Sources/Other sub-groups
source_group(${dir} FILES ${sources})
list(APPEND jdbc_sources ${sources})
endforeach()
add_custom_target(build_jdbc ALL DEPENDS ${JDBC_BUILD_STAMP} SOURCES ${jdbc_sources})
############################################################################### Import legacy connector library so that it can be used by other targets.#
set(JDBC_INCLUDES ${Boost_INCLUDE_DIRS} "${JDBC_DIR}/install/include")#message("legacy connector includes: ${JDBC_INCLUDES}")
## Import library targets exported from the legacy connector project.#
include("${JDBC_DIR}/exports.cmake")
if(BUILD_STATIC) set(JDBC_LIB mysqlcppconn-static)else() set(JDBC_LIB mysqlcppconn)endif()
add_dependencies(${JDBC_LIB} build_jdbc)
set(JDBC_LIBS ${JDBC_LIB} CACHE INTERNAL "legacy connector library")
############################################################################### Installation specs for the legacy connector#
get_target_property(configurations ${JDBC_LIB} IMPORTED_CONFIGURATIONS)
foreach(config ${configurations})
get_target_property(location ${JDBC_LIB} IMPORTED_LOCATION_${config}) message("jdbc installing: ${location}")
if(config STREQUAL DEBUG) set(loc "${INSTALL_LIB_DIR}/debug") set(loc_static "${INSTALL_LIB_DIR_STATIC}/debug") else() set(loc "${INSTALL_LIB_DIR}") set(loc_static "${INSTALL_LIB_DIR_STATIC}") endif()
if(BUILD_STATIC)
install( FILES ${location} CONFIGURATIONS ${config} DESTINATION ${loc_static} COMPONENT JDBCDev )
else()
if(WIN32)
install(FILES ${location} CONFIGURATIONS ${config} DESTINATION ${loc} COMPONENT JDBCDll)
# install import library for the DLL
get_target_property(imp_location ${JDBC_LIB} IMPORTED_IMPLIB_${config})
install( FILES ${imp_location} CONFIGURATIONS ${config} DESTINATION ${loc_static} COMPONENT JDBCDev )
else()
# We need to install soname and linkname links together with the shared # library.
get_filename_component(name "${location}" NAME) get_filename_component(loc_path "${location}" PATH) get_target_property(soname ${JDBC_LIB} IMPORTED_SONAME_${config}) set(linkname "${CMAKE_SHARED_LIBRARY_PREFIX}mysqlcppconn${CMAKE_SHARED_LIBRARY_SUFFIX}")
# # Warning: Using undocumented file(INSTALL ...) signature which creates # required symlinks. This command is used in install scripts generated # by cmake. #
install(CODE "file(INSTALL DESTINATION \"\${CMAKE_INSTALL_PREFIX}/${loc}\" TYPE SHARED_LIBRARY FILES \"${location}\" \"${loc_path}/${soname}\" \"${loc_path}/${linkname}\" )" )
endif()
endif()
endforeach()
install( DIRECTORY ${JDBC_DIR}/install/include/jdbc DESTINATION ${INSTALL_INCLUDE_DIR} COMPONENT JDBCDev)
## In maintainer mode add specifications for installing the static library# which is always built in this mode.#
if(MAINTAINER_MODE)
add_dependencies(mysqlcppconn-static build_jdbc) get_target_property(location mysqlcppconn-static IMPORTED_LOCATION_RELEASE) message("jdbc installing: ${location} (MAINTAINER_MODE)")
install( FILES ${location} CONFIGURATIONS Static DESTINATION "${INSTALL_LIB_DIR_STATIC}" COMPONENT JDBCDev )
endif()
## Install external dependencies of MySQL client library, such as OpenSSL,# if bundled with client library installation.## Note: if main connector uses OpenSSL, then we will use the same libraries# to satisfy client library dependency. But if main connector does not use# OpenSSL, we copy required dependencies from MySQL installation.#
if(BUNDLE_DEPENDENCIES AND WITH_SSL STREQUAL "bundled")
message("Bundling OpenSSL libraries from: ${MYSQL_DIR}")
install(DIRECTORY "${MYSQL_DIR}/bin/" DESTINATION lib64 FILES_MATCHING PATTERN "*${CMAKE_SHARED_LIBRARY_SUFFIX}" COMPONENT JDBCDev )
endif()
############################################################################### Public header checks#
if(WITH_HEADER_CHECKS)
# Prepare location where checks will be performed.
set(CHECK_DIR "${JDBC_DIR}/headers_check")
file(REMOVE_RECURSE "${CHECK_DIR}") file(MAKE_DIRECTORY "${CHECK_DIR}")
# Dirty trick to speed up cmake set up time.
file( COPY "${CMAKE_BINARY_DIR}/CMakeFiles/${CMAKE_VERSION}" DESTINATION "${CHECK_DIR}/CMakeFiles" )
# # Target to run header checks. #
ADD_CUSTOM_TARGET(Headers_jdbc COMMAND ${CMAKE_COMMAND} -DCMAKE_GENERATOR=${CMAKE_GENERATOR} -DJDBC_DIR=${JDBC_DIR} -DJDBC_INCLUDES="${JDBC_INCLUDES}" -DHEADERS_DIR=${PROJECT_SOURCE_DIR}/cdk/cmake/headers -DCHECK_DIR=${CHECK_DIR} -P ${PROJECT_SOURCE_DIR}/cmake/jdbc_headers_check.cmake SOURCES ${all_headers} )
add_dependencies(Headers_jdbc build_jdbc)
add_test(NAME Headers_jdbc COMMAND cmake --build . --target Headers_jdbc WORKING_DIRECTORY ${PROJECT_BINARY_DIR} ) message(STATUS "Added JDBC public headers test")
endif()
message("== legacy connector build configured")
“CMake”这个名字是“cross platform make”的更多相关文章
- Comparing Xamarin and Delphi XE5 to Xcode for Cross Platform Mobile App Development
Comparing Xamarin and Delphi XE5 to Xcode for Cross Platform Mobile App Development If you are consi ...
- V4 Reduce Transportable Tablespace Downtime using Cross Platform Incremental Backup (Doc ID 2471245.1)
V4 Reduce Transportable Tablespace Downtime using Cross Platform Incremental Backup (Doc ID 2471245. ...
- Gtest:Using visual studio 2017 cross platform feature to compile code remotely
参考:使用Visual Studio 2017作为Linux C++开发工具 前言 最近在学Gtest单元测试框架,由于平时都是使用Source Insight写代码,遇到问题自己还是要到Linux下 ...
- Cross Platform Note: STD C++ Preprocessor directives & pre-defined macros
ref: http://www.cplusplus.com/doc/tutorial/preprocessor/ concolusion: directives: #define #undef #in ...
- Cross platform
值得学习的C/C++语言开源项目 (1)ACE 庞大.复杂,适合大型项目.开源.免费,不依赖第三方库,支持跨平台. http://www.cs.wustl.edu/~schmidt/ACE.html ...
- Cross platform GUI for creating SSL certs with OpenSSL
Someone said: from : https://micksmix.wordpress.com/2012/08/09/xca-cross-platform-gui-for-creating-s ...
- 非常陌生的cmake
CMake是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程).他能够输出各种各样的makefile或者project文件,能测试编译器所支持的C++特性,类似UNIX下的 ...
- CMake编译linux C++
CMake是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程).他能够输出各种各样的makefile或者project文件,能测试编译器所支持的C++特性,类似UNIX下的 ...
- centos 6.5下cmake工具的安装与配置
一.cmake是什么? CMake是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程).他能够输出各种各样的makefile或者project文件,能测试编译器所支持的C+ ...
随机推荐
- spring in action第一章小结1
1 spring基本理念是简化java开发. 使用以下4个策略简化java开发 1) 基于POJO的轻量级和最小侵入性编程 2)通过使用DI和AOP实现松耦合 3)基于切面和惯例进行声明式编程 4)通 ...
- myeclipse中配置schemaLocation路径,实现xml文件自动提示
在开发中,XML的xsi:schemaLocation路径都是指向网络,但是这个网络地址有时候很不给力导致工程检验XML格式缓慢.所以有必要再myeclipse中配置本地xsd文件路径,以免每次校验都 ...
- mysql数据库中不能插入0000-00-00 00:00:00日期数据(报错Invalid datetime format: 1292 Incorrect datetime value: '0000-00-00 00:00:00')
报错信息 SQLSTATE[22007]: Invalid datetime format: 1292 Incorrect datetime value: '0000-00-00 00:00:00' ...
- Failure [INSTALL_FAILED_OLDER_SDK] [每件问题100块]
问题描述:链接真机时候出现的问题 解决问题: minSdkVersion 10targetSdkVersion 22 修改这两个值
- TLS线程局部存储
0x01 TLS (Thread Local Storage) 为线程单独提供的私有空间 0x02 gcc中的隐式TLS使用方法 隐式TLS __thread int number; 显式TLS pt ...
- 使用Lua的扩展库LuaSocket用例
目录结构 LuaSocket 是 Lua 的网络模块库,它可以很方便地提供 TCP.UDP.DNS.FTP.HTTP.SMTP.MIME 等多种网络协议的访问操作. 它由两部分组成:一部分是用 C 写 ...
- mysql之slave_skip_errors选项
要说slave_skip_errors选项,就不得不提mysql的replication机制,总的来说它分了三步来实现mysql主从库的同步 master将改变记录到二进制日志(binary log) ...
- C1编译器的实现
总览 词法.语法分析 分析方案 词法 语法 符号表 类型系统 AST 语义检查 EIR代码生成器 MIPS代码生成器 寄存器分配 体系结构相关特性优化 使用说明 编译 运行 总览 C1语言编译器及流程 ...
- Ubuntu 12.04下PostgreSQL-9.1安装与配置详解(在线安装) [转]
说明: 我是用root用户在终端登陆的,如果是非root用户,那在命令前需要加上"sudo",你懂的... 第一步:在Ubuntu下安装Postgresql ...
- Angular js ie 7,8 兼容性
Angularjs 官网有云: 1)在html 里面 ,有ng-app 的标签里需要定义个id ,id='ng-app'; 2)ie 7及以下版本需要json2.js或json3.js,主要用来解析 ...