//===- ARCMigrate.cpp - Clang-C ARC Migration Library ---------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file implements the main API hooks in the Clang-C ARC Migration library. // //===----------------------------------------------------------------------===// #include "clang-c/Index.h" #include "CXString.h" #include "clang/ARCMigrate/ARCMT.h" #include "clang/Frontend/TextDiagnosticBuffer.h" #include "llvm/Support/FileSystem.h" using namespace clang; using namespace arcmt; namespace { struct Remap { std::vector > Vec; }; } // anonymous namespace. //===----------------------------------------------------------------------===// // libClang public APIs. //===----------------------------------------------------------------------===// extern "C" { CXRemapping clang_getRemappings(const char *migrate_dir_path) { bool Logging = ::getenv("LIBCLANG_LOGGING"); if (!migrate_dir_path) { if (Logging) llvm::errs() << "clang_getRemappings was called with NULL parameter\n"; return nullptr; } bool exists = false; llvm::sys::fs::exists(migrate_dir_path, exists); if (!exists) { if (Logging) { llvm::errs() << "Error by clang_getRemappings(\"" << migrate_dir_path << "\")\n"; llvm::errs() << "\"" << migrate_dir_path << "\" does not exist\n"; } return nullptr; } TextDiagnosticBuffer diagBuffer; std::unique_ptr remap(new Remap()); bool err = arcmt::getFileRemappings(remap->Vec, migrate_dir_path,&diagBuffer); if (err) { if (Logging) { llvm::errs() << "Error by clang_getRemappings(\"" << migrate_dir_path << "\")\n"; for (TextDiagnosticBuffer::const_iterator I = diagBuffer.err_begin(), E = diagBuffer.err_end(); I != E; ++I) llvm::errs() << I->second << '\n'; } return nullptr; } return remap.release(); } CXRemapping clang_getRemappingsFromFileList(const char **filePaths, unsigned numFiles) { bool Logging = ::getenv("LIBCLANG_LOGGING"); std::unique_ptr remap(new Remap()); if (numFiles == 0) { if (Logging) llvm::errs() << "clang_getRemappingsFromFileList was called with " "numFiles=0\n"; return remap.release(); } if (!filePaths) { if (Logging) llvm::errs() << "clang_getRemappingsFromFileList was called with " "NULL filePaths\n"; return nullptr; } TextDiagnosticBuffer diagBuffer; SmallVector Files; for (unsigned i = 0; i != numFiles; ++i) Files.push_back(filePaths[i]); bool err = arcmt::getFileRemappingsFromFileList(remap->Vec, Files, &diagBuffer); if (err) { if (Logging) { llvm::errs() << "Error by clang_getRemappingsFromFileList\n"; for (TextDiagnosticBuffer::const_iterator I = diagBuffer.err_begin(), E = diagBuffer.err_end(); I != E; ++I) llvm::errs() << I->second << '\n'; } return remap.release(); } return remap.release(); } unsigned clang_remap_getNumFiles(CXRemapping map) { return static_cast(map)->Vec.size(); } void clang_remap_getFilenames(CXRemapping map, unsigned index, CXString *original, CXString *transformed) { if (original) *original = cxstring::createDup( static_cast(map)->Vec[index].first); if (transformed) *transformed = cxstring::createDup( static_cast(map)->Vec[index].second); } void clang_remap_dispose(CXRemapping map) { delete static_cast(map); } } // end: extern "C"