X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fmsvccompiler.cpp;h=dbbc64d41895baea735e41d2e7f8f5c19ec8dd59;hb=5e00719d0c63e306786ff36df61797cdbc86f3e9;hp=12668a639c6dfc7db8941be12627ef52b520ba20;hpb=c0e0728ff439ddb364cee26f164e46705beac822;p=builder.git diff --git a/source/msvccompiler.cpp b/source/msvccompiler.cpp index 12668a6..dbbc64d 100644 --- a/source/msvccompiler.cpp +++ b/source/msvccompiler.cpp @@ -46,7 +46,7 @@ Target *MsvcCompiler::create_source(const FS::Path &path) const return new CSourceFile(builder, path); } -Target *MsvcCompiler::create_target(const list &sources, const string &) +Target *MsvcCompiler::create_target(const vector &sources, const string &) { if(sources.size()!=1) throw invalid_argument("MsvcCompiler::create_target"); @@ -58,7 +58,7 @@ Target *MsvcCompiler::create_target(const list &sources, const string string MsvcCompiler::create_build_signature(const BuildInfo &binfo) const { - string result = FS::basename(executable->get_path()); + string result = Tool::create_build_signature(binfo); result += ','; if(binfo.debug) result += 'g'; @@ -84,10 +84,10 @@ void MsvcCompiler::do_prepare() system_path.push_back(win_sdk_dir/"include"/win_sdk_ver/"um"); string path; - for(SearchPath::const_iterator i=system_path.begin(); i!=system_path.end(); ++i) + for(const FS::Path &p: system_path) { - append(path, ";", i->str()); - builder.get_logger().log("tools", format("Got %s system path: %s", tag, *i)); + append(path, ";", p.str()); + builder.get_logger().log("tools", "Got %s system path: %s", tag, p); } setenv("INCLUDE", path); @@ -107,9 +107,9 @@ Task *MsvcCompiler::run(const Target &target) const if(binfo.standards.count(tag)) { - string std = get_item(binfo.standards, tag); - if(std!="c++11" && std!="c99") - argv.push_back("/std:"+std); + const BuildInfo::LanguageStandard &std = get_item(binfo.standards, tag); + if((tag=="CXX" && std.year>2011) || (tag=="CC" && std.year>1999)) + argv.push_back("/std:"+std.str()); } if(binfo.warning_level>=1) @@ -130,24 +130,24 @@ Task *MsvcCompiler::run(const Target &target) const else argv.push_back("/w"); - for(BuildInfo::PathList::const_iterator i=binfo.local_incpath.begin(); i!=binfo.local_incpath.end(); ++i) + for(const FS::Path &p: binfo.local_incpath) { argv.push_back("/I"); - argv.push_back(i->str()); + argv.push_back(p.str()); } - for(BuildInfo::PathList::const_iterator i=binfo.incpath.begin(); i!=binfo.incpath.end(); ++i) + for(const FS::Path &p: binfo.incpath) { argv.push_back("/I"); - argv.push_back(i->str()); + argv.push_back(p.str()); } - for(BuildInfo::DefineMap::const_iterator i=binfo.defines.begin(); i!=binfo.defines.end(); ++i) + for(const auto &kvp: binfo.defines) { argv.push_back("/D"); - if(i->second.empty()) - argv.push_back(i->first); + if(kvp.second.empty()) + argv.push_back(kvp.first); else - argv.push_back(format("%s=%s", i->first, i->second)); + argv.push_back(format("%s=%s", kvp.first, kvp.second)); } if(binfo.debug)