cmake 2.8
之前寫cmkae編譯帶有c++11特性的代碼有這麽壹句:
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
但是總會出現cc1plus: error: unrecognized command line option "-std=c++11" 報錯。
所以set(QMAKE_CXXFLAGS "-std=c++11") 類似的寫法肯定不行。
後來發現是std=c++11 這種寫法老版本不支持。
ok
直接測試新寫法:
<pre name="code" class="plain">#CMakeLists.txt
project(test)
cmake_minimum_required(VERSION 2.8)
aux_source_directory(. SRC_LIST)
add_executable(${PROJECT_NAME} ${SRC_LIST})
include(CheckCXXCompilerFlag)
CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11)
CHECK_CXX_COMPILER_FLAG("-std=c++0x" COMPILER_SUPPORTS_CXX0X)
if(COMPILER_SUPPORTS_CXX11)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
elseif(COMPILER_SUPPORTS_CXX0X)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x")
else()
message(STATUS "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.")
endif()
測試c++11代碼
//test.cc
#include <iostream>
#include<vector>
using namespace std;
int main()
{
const std::vector<int>v(1);
auto a = v[0];//a為int類型
cout <<"a : "<< a <<endl;
decltype(v[0]) b = 0;//b為const int&類型,即std::vector<int>::operator[](size_type)const的返回類型
auto c = 0;//c為int類型
auto d = c;//d為int類型
decltype(c) e;//e為int類型,c實體的類型
decltype((c)) f = e;//f為int&類型,因為(c)是左值
decltype(0) g;//g為int類型,因為0是右值
return 0;
}
所以,不同版本的gcc給指定c++11支持設定了不同的標誌,也就說老版本支持-std=c++0x的寫法,新版本用-std=c++11的寫法。以上程序就是判斷本機的g++該使用那種輸出版本。