X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fandroidcompiler.cpp;h=07047937f41a1010d009349f8b46c2ccd6604051;hb=1ce9890cb950d516d5c1ede51264f1dcdde7356a;hp=490c198196c9764af402a91235b782d258eb12af;hpb=a4f02f02d4682c7f504e46ff2ce8f93035fd36dd;p=builder.git diff --git a/source/androidcompiler.cpp b/source/androidcompiler.cpp index 490c198..0704793 100644 --- a/source/androidcompiler.cpp +++ b/source/androidcompiler.cpp @@ -1,41 +1,83 @@ #include #include +#include #include +#include #include "androidcompiler.h" #include "androidtools.h" #include "builder.h" +#include "externaltask.h" +#include "filetarget.h" using namespace std; using namespace Msp; AndroidCompiler::AndroidCompiler(Builder &b, const Architecture &a, const string &t, const AndroidNdk &n): - GnuCompiler(b, a, t, n.get_platform_sysroot()), + CustomizedTool(b, t, a), ndk(n) { - set_command((ndk.get_bin_dir()/command).str()); - build_info.incpath.insert(build_info.incpath.end(), system_path.begin(), system_path.end()); + set_command((tag=="CXX" ? "g++" : "gcc"), true); + if(ndk.get_root_dir().empty()) + problems.push_back("Android NDK not found"); + else if(ndk.get_bin_dir().empty()) + problems.push_back("Android NDK toolchain not found"); + else + set_command((ndk.get_bin_dir()/command).str()); + + if(ndk.get_platform_sysroot().empty()) + problems.push_back("Android platform not found"); + else if(!ndk.get_common_sysroot().empty()) + { + build_info.sysroot = ndk.get_common_sysroot(); + /* The common sysroot has asm headers in arch directories and the + compiler doesn't pick them up automatically */ + build_info.incpath.push_back(ndk.get_common_sysroot()/"usr/include"/architecture->get_cross_prefix()); + } + else + build_info.sysroot = ndk.get_platform_sysroot(); + if(tag=="CXX") build_info.libs.push_back("gnustl_static"); } -void AndroidCompiler::do_prepare() +void AndroidCompiler::do_prepare(ToolData &tool) const { - GnuCompiler::do_prepare(); - if(executable && tag=="CXX") + const Architecture &arch = *static_cast(tool).get_architecture(); + + CustomizedTool::do_prepare(tool); + if(tag=="CXX") { - FS::Path libstdcxx_path = ndk.get_root_dir()/"sources"/"cxx-stl"/"gnu-libstdc++"/version; + unsigned version = tool.extra_data; + string version_str = format("%d.%d.%d", version>>16, (version>>8)&0xFF, version&0xFF); + FS::Path libstdcxx_dir = ndk.get_root_dir()/"sources"/"cxx-stl"/"gnu-libstdc++"; + FS::Path libstdcxx_path; + while(1) + { + libstdcxx_path = libstdcxx_dir/version_str; + if(FS::exists(libstdcxx_path)) + break; + + string::size_type dot = version_str.rfind('.'); + if(dot==string::npos) + { + tool.problems.push_back("C++ standard library not found"); + return; + } + + version_str = version_str.substr(0, dot); + } FS::Path public_dir = libstdcxx_path/"include"; - system_path.push_back(public_dir); - build_info.incpath.push_back(public_dir); + tool.system_path.push_back(public_dir); + tool.build_info.incpath.push_back(public_dir); FS::Path arch_path = libstdcxx_path/"libs"; - builder.get_logger().log("files", format("Traversing %s", arch_path.str())); - string arch_dir = architecture->best_match(list_files(arch_path)); + builder.get_logger().log("files", "Traversing %s", arch_path.str()); + string arch_dir = arch.best_match(list_files(arch_path)); if(!arch_dir.empty()) { - build_info.incpath.push_back(libstdcxx_path/"libs"/arch_dir/"include"); - build_info.libpath.push_back(libstdcxx_path/"libs"/arch_dir); + tool.build_info.incpath.push_back(libstdcxx_path/"libs"/arch_dir/"include"); + tool.build_info.libpath.push_back(libstdcxx_path/"libs"/arch_dir); } } }