зеркало из https://github.com/microsoft/clang.git
remove unneeded llvm:: namespace qualifiers on some core types now that LLVM.h imports
them into the clang namespace. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@135852 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
d47d3b0cfe
Коммит
5f9e272e63
|
@ -19,10 +19,8 @@
|
|||
#include "clang/Lex/Preprocessor.h"
|
||||
#include "llvm/Support/MemoryBuffer.h"
|
||||
#include "llvm/ADT/Triple.h"
|
||||
|
||||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using llvm::StringRef;
|
||||
|
||||
bool CapturedDiagList::clearDiagnostic(llvm::ArrayRef<unsigned> IDs,
|
||||
SourceRange range) {
|
||||
|
@ -113,7 +111,7 @@ public:
|
|||
|
||||
} // end anonymous namespace
|
||||
|
||||
static inline llvm::StringRef SimulatorVersionDefineName() {
|
||||
static inline StringRef SimulatorVersionDefineName() {
|
||||
return "__IPHONE_OS_VERSION_MIN_REQUIRED=";
|
||||
}
|
||||
|
||||
|
@ -122,11 +120,11 @@ static inline llvm::StringRef SimulatorVersionDefineName() {
|
|||
// and return the grouped values as integers, e.g:
|
||||
// __IPHONE_OS_VERSION_MIN_REQUIRED=40201
|
||||
// will return Major=4, Minor=2, Micro=1.
|
||||
static bool GetVersionFromSimulatorDefine(llvm::StringRef define,
|
||||
static bool GetVersionFromSimulatorDefine(StringRef define,
|
||||
unsigned &Major, unsigned &Minor,
|
||||
unsigned &Micro) {
|
||||
assert(define.startswith(SimulatorVersionDefineName()));
|
||||
llvm::StringRef name, version;
|
||||
StringRef name, version;
|
||||
llvm::tie(name, version) = define.split('=');
|
||||
if (version.empty())
|
||||
return false;
|
||||
|
@ -214,10 +212,10 @@ void emitPremigrationErrors(const CapturedDiagList &arcDiags,
|
|||
//===----------------------------------------------------------------------===//
|
||||
|
||||
bool arcmt::checkForManualIssues(CompilerInvocation &origCI,
|
||||
llvm::StringRef Filename, InputKind Kind,
|
||||
StringRef Filename, InputKind Kind,
|
||||
DiagnosticClient *DiagClient,
|
||||
bool emitPremigrationARCErrors,
|
||||
llvm::StringRef plistOut) {
|
||||
StringRef plistOut) {
|
||||
if (!origCI.getLangOpts().ObjC1)
|
||||
return false;
|
||||
|
||||
|
@ -262,7 +260,7 @@ bool arcmt::checkForManualIssues(CompilerInvocation &origCI,
|
|||
emitPremigrationErrors(capturedDiags, origCI.getDiagnosticOpts(),
|
||||
Unit->getPreprocessor());
|
||||
if (!plistOut.empty()) {
|
||||
llvm::SmallVector<StoredDiagnostic, 8> arcDiags;
|
||||
SmallVector<StoredDiagnostic, 8> arcDiags;
|
||||
for (CapturedDiagList::iterator
|
||||
I = capturedDiags.begin(), E = capturedDiags.end(); I != E; ++I)
|
||||
arcDiags.push_back(*I);
|
||||
|
@ -303,11 +301,11 @@ bool arcmt::checkForManualIssues(CompilerInvocation &origCI,
|
|||
//===----------------------------------------------------------------------===//
|
||||
|
||||
static bool applyTransforms(CompilerInvocation &origCI,
|
||||
llvm::StringRef Filename, InputKind Kind,
|
||||
StringRef Filename, InputKind Kind,
|
||||
DiagnosticClient *DiagClient,
|
||||
llvm::StringRef outputDir,
|
||||
StringRef outputDir,
|
||||
bool emitPremigrationARCErrors,
|
||||
llvm::StringRef plistOut) {
|
||||
StringRef plistOut) {
|
||||
if (!origCI.getLangOpts().ObjC1)
|
||||
return false;
|
||||
|
||||
|
@ -347,18 +345,18 @@ static bool applyTransforms(CompilerInvocation &origCI,
|
|||
}
|
||||
|
||||
bool arcmt::applyTransformations(CompilerInvocation &origCI,
|
||||
llvm::StringRef Filename, InputKind Kind,
|
||||
StringRef Filename, InputKind Kind,
|
||||
DiagnosticClient *DiagClient) {
|
||||
return applyTransforms(origCI, Filename, Kind, DiagClient,
|
||||
llvm::StringRef(), false, llvm::StringRef());
|
||||
StringRef(), false, StringRef());
|
||||
}
|
||||
|
||||
bool arcmt::migrateWithTemporaryFiles(CompilerInvocation &origCI,
|
||||
llvm::StringRef Filename, InputKind Kind,
|
||||
StringRef Filename, InputKind Kind,
|
||||
DiagnosticClient *DiagClient,
|
||||
llvm::StringRef outputDir,
|
||||
StringRef outputDir,
|
||||
bool emitPremigrationARCErrors,
|
||||
llvm::StringRef plistOut) {
|
||||
StringRef plistOut) {
|
||||
assert(!outputDir.empty() && "Expected output directory path");
|
||||
return applyTransforms(origCI, Filename, Kind, DiagClient,
|
||||
outputDir, emitPremigrationARCErrors, plistOut);
|
||||
|
@ -366,7 +364,7 @@ bool arcmt::migrateWithTemporaryFiles(CompilerInvocation &origCI,
|
|||
|
||||
bool arcmt::getFileRemappings(std::vector<std::pair<std::string,std::string> > &
|
||||
remap,
|
||||
llvm::StringRef outputDir,
|
||||
StringRef outputDir,
|
||||
DiagnosticClient *DiagClient) {
|
||||
assert(!outputDir.empty());
|
||||
|
||||
|
@ -414,7 +412,7 @@ public:
|
|||
: ARCMTMacroLocs(ARCMTMacroLocs) { }
|
||||
|
||||
virtual ASTConsumer *CreateASTConsumer(CompilerInstance &CI,
|
||||
llvm::StringRef InFile) {
|
||||
StringRef InFile) {
|
||||
CI.getPreprocessor().addPPCallbacks(
|
||||
new ARCMTMacroTrackerPPCallbacks(ARCMTMacroLocs));
|
||||
return new ASTConsumer();
|
||||
|
@ -438,7 +436,7 @@ public:
|
|||
Listener->finish();
|
||||
}
|
||||
|
||||
virtual void insert(SourceLocation loc, llvm::StringRef text) {
|
||||
virtual void insert(SourceLocation loc, StringRef text) {
|
||||
bool err = rewriter.InsertText(loc, text, /*InsertAfter=*/true,
|
||||
/*indentNewLines=*/true);
|
||||
if (!err && Listener)
|
||||
|
@ -469,7 +467,7 @@ MigrationProcess::RewriteListener::~RewriteListener() { }
|
|||
|
||||
MigrationProcess::MigrationProcess(const CompilerInvocation &CI,
|
||||
DiagnosticClient *diagClient,
|
||||
llvm::StringRef outputDir)
|
||||
StringRef outputDir)
|
||||
: OrigCI(CI), DiagClient(diagClient) {
|
||||
if (!outputDir.empty()) {
|
||||
llvm::IntrusiveRefCntPtr<DiagnosticIDs> DiagID(new DiagnosticIDs());
|
||||
|
@ -558,7 +556,7 @@ bool MigrationProcess::applyTransform(TransformFn trans,
|
|||
buf.write(vecOS);
|
||||
vecOS.flush();
|
||||
llvm::MemoryBuffer *memBuf = llvm::MemoryBuffer::getMemBufferCopy(
|
||||
llvm::StringRef(newText.data(), newText.size()), newFname);
|
||||
StringRef(newText.data(), newText.size()), newFname);
|
||||
llvm::SmallString<64> filePath(file->getName());
|
||||
Unit->getFileManager().FixupRelativePath(filePath);
|
||||
Remapper.remap(filePath.str(), memBuf);
|
||||
|
|
|
@ -53,8 +53,8 @@ bool MigrateAction::BeginInvocation(CompilerInstance &CI) {
|
|||
}
|
||||
|
||||
MigrateAction::MigrateAction(FrontendAction *WrappedAction,
|
||||
llvm::StringRef migrateDir,
|
||||
llvm::StringRef plistOut,
|
||||
StringRef migrateDir,
|
||||
StringRef plistOut,
|
||||
bool emitPremigrationARCErrors)
|
||||
: WrapperFrontendAction(WrappedAction), MigrateDir(migrateDir),
|
||||
PlistOut(plistOut), EmitPremigrationARCErros(emitPremigrationARCErrors) {
|
||||
|
|
|
@ -27,7 +27,7 @@ FileRemapper::~FileRemapper() {
|
|||
clear();
|
||||
}
|
||||
|
||||
void FileRemapper::clear(llvm::StringRef outputDir) {
|
||||
void FileRemapper::clear(StringRef outputDir) {
|
||||
for (MappingsTy::iterator
|
||||
I = FromToMappings.begin(), E = FromToMappings.end(); I != E; ++I)
|
||||
resetTarget(I->second);
|
||||
|
@ -40,7 +40,7 @@ void FileRemapper::clear(llvm::StringRef outputDir) {
|
|||
}
|
||||
}
|
||||
|
||||
std::string FileRemapper::getRemapInfoFile(llvm::StringRef outputDir) {
|
||||
std::string FileRemapper::getRemapInfoFile(StringRef outputDir) {
|
||||
assert(!outputDir.empty());
|
||||
llvm::sys::Path dir(outputDir);
|
||||
llvm::sys::Path infoFile = dir;
|
||||
|
@ -48,7 +48,7 @@ std::string FileRemapper::getRemapInfoFile(llvm::StringRef outputDir) {
|
|||
return infoFile.str();
|
||||
}
|
||||
|
||||
bool FileRemapper::initFromDisk(llvm::StringRef outputDir, Diagnostic &Diag,
|
||||
bool FileRemapper::initFromDisk(StringRef outputDir, Diagnostic &Diag,
|
||||
bool ignoreIfFilesChanged) {
|
||||
assert(FromToMappings.empty() &&
|
||||
"initFromDisk should be called before any remap calls");
|
||||
|
@ -102,7 +102,7 @@ bool FileRemapper::initFromDisk(llvm::StringRef outputDir, Diagnostic &Diag,
|
|||
return false;
|
||||
}
|
||||
|
||||
bool FileRemapper::flushToDisk(llvm::StringRef outputDir, Diagnostic &Diag) {
|
||||
bool FileRemapper::flushToDisk(StringRef outputDir, Diagnostic &Diag) {
|
||||
using namespace llvm::sys;
|
||||
|
||||
bool existed;
|
||||
|
@ -121,13 +121,13 @@ bool FileRemapper::flushToDisk(llvm::StringRef outputDir, Diagnostic &Diag) {
|
|||
I = FromToMappings.begin(), E = FromToMappings.end(); I != E; ++I) {
|
||||
|
||||
const FileEntry *origFE = I->first;
|
||||
llvm::SmallString<200> origPath = llvm::StringRef(origFE->getName());
|
||||
llvm::SmallString<200> origPath = StringRef(origFE->getName());
|
||||
fs::make_absolute(origPath);
|
||||
infoOut << origPath << '\n';
|
||||
infoOut << (uint64_t)origFE->getModificationTime() << '\n';
|
||||
|
||||
if (const FileEntry *FE = I->second.dyn_cast<const FileEntry *>()) {
|
||||
llvm::SmallString<200> newPath = llvm::StringRef(FE->getName());
|
||||
llvm::SmallString<200> newPath = StringRef(FE->getName());
|
||||
fs::make_absolute(newPath);
|
||||
infoOut << newPath << '\n';
|
||||
} else {
|
||||
|
@ -157,7 +157,7 @@ bool FileRemapper::flushToDisk(llvm::StringRef outputDir, Diagnostic &Diag) {
|
|||
}
|
||||
|
||||
bool FileRemapper::overwriteOriginal(Diagnostic &Diag,
|
||||
llvm::StringRef outputDir) {
|
||||
StringRef outputDir) {
|
||||
using namespace llvm::sys;
|
||||
|
||||
for (MappingsTy::iterator
|
||||
|
@ -229,11 +229,11 @@ void FileRemapper::transferMappingsAndClear(CompilerInvocation &CI) {
|
|||
clear();
|
||||
}
|
||||
|
||||
void FileRemapper::remap(llvm::StringRef filePath, llvm::MemoryBuffer *memBuf) {
|
||||
void FileRemapper::remap(StringRef filePath, llvm::MemoryBuffer *memBuf) {
|
||||
remap(getOriginalFile(filePath), memBuf);
|
||||
}
|
||||
|
||||
void FileRemapper::remap(llvm::StringRef filePath, llvm::StringRef newPath) {
|
||||
void FileRemapper::remap(StringRef filePath, StringRef newPath) {
|
||||
const FileEntry *file = getOriginalFile(filePath);
|
||||
const FileEntry *newfile = FileMgr->getFile(newPath);
|
||||
remap(file, newfile);
|
||||
|
@ -254,7 +254,7 @@ void FileRemapper::remap(const FileEntry *file, const FileEntry *newfile) {
|
|||
ToFromMappings[newfile] = file;
|
||||
}
|
||||
|
||||
const FileEntry *FileRemapper::getOriginalFile(llvm::StringRef filePath) {
|
||||
const FileEntry *FileRemapper::getOriginalFile(StringRef filePath) {
|
||||
const FileEntry *file = FileMgr->getFile(filePath);
|
||||
// If we are updating a file that overriden an original file,
|
||||
// actually update the original file.
|
||||
|
|
|
@ -11,17 +11,15 @@
|
|||
#include "clang/Lex/Lexer.h"
|
||||
#include "clang/Basic/SourceManager.h"
|
||||
#include "clang/Basic/FileManager.h"
|
||||
|
||||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using llvm::StringRef;
|
||||
|
||||
// FIXME: This duplicates significant functionality from PlistDiagnostics.cpp,
|
||||
// it would be jolly good if there was a reusable PlistWriter or something.
|
||||
|
||||
typedef llvm::DenseMap<FileID, unsigned> FIDMap;
|
||||
|
||||
static void AddFID(FIDMap &FIDs, llvm::SmallVectorImpl<FileID> &V,
|
||||
static void AddFID(FIDMap &FIDs, SmallVectorImpl<FileID> &V,
|
||||
const SourceManager &SM, SourceLocation L) {
|
||||
|
||||
FileID FID = SM.getFileID(SM.getInstantiationLoc(L));
|
||||
|
@ -39,12 +37,12 @@ static unsigned GetFID(const FIDMap& FIDs, const SourceManager &SM,
|
|||
return I->second;
|
||||
}
|
||||
|
||||
static llvm::raw_ostream& Indent(llvm::raw_ostream& o, const unsigned indent) {
|
||||
static raw_ostream& Indent(raw_ostream& o, const unsigned indent) {
|
||||
for (unsigned i = 0; i < indent; ++i) o << ' ';
|
||||
return o;
|
||||
}
|
||||
|
||||
static void EmitLocation(llvm::raw_ostream& o, const SourceManager &SM,
|
||||
static void EmitLocation(raw_ostream& o, const SourceManager &SM,
|
||||
const LangOptions &LangOpts,
|
||||
SourceLocation L, const FIDMap &FM,
|
||||
unsigned indent, bool extend = false) {
|
||||
|
@ -65,7 +63,7 @@ static void EmitLocation(llvm::raw_ostream& o, const SourceManager &SM,
|
|||
Indent(o, indent) << "</dict>\n";
|
||||
}
|
||||
|
||||
static void EmitRange(llvm::raw_ostream& o, const SourceManager &SM,
|
||||
static void EmitRange(raw_ostream& o, const SourceManager &SM,
|
||||
const LangOptions &LangOpts,
|
||||
CharSourceRange R, const FIDMap &FM,
|
||||
unsigned indent) {
|
||||
|
@ -75,7 +73,7 @@ static void EmitRange(llvm::raw_ostream& o, const SourceManager &SM,
|
|||
Indent(o, indent) << "</array>\n";
|
||||
}
|
||||
|
||||
static llvm::raw_ostream& EmitString(llvm::raw_ostream& o,
|
||||
static raw_ostream& EmitString(raw_ostream& o,
|
||||
StringRef s) {
|
||||
o << "<string>";
|
||||
for (StringRef::const_iterator I=s.begin(), E=s.end(); I!=E; ++I) {
|
||||
|
@ -102,7 +100,7 @@ void arcmt::writeARCDiagsToPlist(const std::string &outPath,
|
|||
// Build up a set of FIDs that we use by scanning the locations and
|
||||
// ranges of the diagnostics.
|
||||
FIDMap FM;
|
||||
llvm::SmallVector<FileID, 10> Fids;
|
||||
SmallVector<FileID, 10> Fids;
|
||||
|
||||
for (llvm::ArrayRef<StoredDiagnostic>::iterator
|
||||
I = diags.begin(), E = diags.end(); I != E; ++I) {
|
||||
|
@ -137,7 +135,7 @@ void arcmt::writeARCDiagsToPlist(const std::string &outPath,
|
|||
" <key>files</key>\n"
|
||||
" <array>\n";
|
||||
|
||||
for (llvm::SmallVectorImpl<FileID>::iterator I=Fids.begin(), E=Fids.end();
|
||||
for (SmallVectorImpl<FileID>::iterator I=Fids.begin(), E=Fids.end();
|
||||
I!=E; ++I) {
|
||||
o << " ";
|
||||
EmitString(o, SM.getFileEntryForID(*I)->getName()) << '\n';
|
||||
|
|
|
@ -24,7 +24,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -28,7 +28,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -36,16 +36,15 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
class ReleaseCollector : public RecursiveASTVisitor<ReleaseCollector> {
|
||||
Decl *Dcl;
|
||||
llvm::SmallVectorImpl<ObjCMessageExpr *> &Releases;
|
||||
SmallVectorImpl<ObjCMessageExpr *> &Releases;
|
||||
|
||||
public:
|
||||
ReleaseCollector(Decl *D, llvm::SmallVectorImpl<ObjCMessageExpr *> &releases)
|
||||
ReleaseCollector(Decl *D, SmallVectorImpl<ObjCMessageExpr *> &releases)
|
||||
: Dcl(D), Releases(releases) { }
|
||||
|
||||
bool VisitObjCMessageExpr(ObjCMessageExpr *E) {
|
||||
|
@ -82,7 +81,7 @@ public:
|
|||
}
|
||||
|
||||
~AutoreleasePoolRewriter() {
|
||||
llvm::SmallVector<VarDecl *, 8> VarsToHandle;
|
||||
SmallVector<VarDecl *, 8> VarsToHandle;
|
||||
|
||||
for (std::map<VarDecl *, PoolVarInfo>::iterator
|
||||
I = PoolVars.begin(), E = PoolVars.end(); I != E; ++I) {
|
||||
|
@ -92,7 +91,7 @@ public:
|
|||
// Check that we can handle/rewrite all references of the pool.
|
||||
|
||||
clearRefsIn(info.Dcl, info.Refs);
|
||||
for (llvm::SmallVectorImpl<PoolScope>::iterator
|
||||
for (SmallVectorImpl<PoolScope>::iterator
|
||||
scpI = info.Scopes.begin(),
|
||||
scpE = info.Scopes.end(); scpI != scpE; ++scpI) {
|
||||
PoolScope &scope = *scpI;
|
||||
|
@ -116,7 +115,7 @@ public:
|
|||
Pass.TA.removeStmt(info.Dcl);
|
||||
|
||||
// Add "@autoreleasepool { }"
|
||||
for (llvm::SmallVectorImpl<PoolScope>::iterator
|
||||
for (SmallVectorImpl<PoolScope>::iterator
|
||||
scpI = info.Scopes.begin(),
|
||||
scpE = info.Scopes.end(); scpI != scpE; ++scpI) {
|
||||
PoolScope &scope = *scpI;
|
||||
|
@ -147,11 +146,11 @@ public:
|
|||
}
|
||||
|
||||
// Remove rest of pool var references.
|
||||
for (llvm::SmallVectorImpl<PoolScope>::iterator
|
||||
for (SmallVectorImpl<PoolScope>::iterator
|
||||
scpI = info.Scopes.begin(),
|
||||
scpE = info.Scopes.end(); scpI != scpE; ++scpI) {
|
||||
PoolScope &scope = *scpI;
|
||||
for (llvm::SmallVectorImpl<ObjCMessageExpr *>::iterator
|
||||
for (SmallVectorImpl<ObjCMessageExpr *>::iterator
|
||||
relI = scope.Releases.begin(),
|
||||
relE = scope.Releases.end(); relI != relE; ++relI) {
|
||||
clearUnavailableDiags(*relI);
|
||||
|
@ -162,7 +161,7 @@ public:
|
|||
}
|
||||
|
||||
bool VisitCompoundStmt(CompoundStmt *S) {
|
||||
llvm::SmallVector<PoolScope, 4> Scopes;
|
||||
SmallVector<PoolScope, 4> Scopes;
|
||||
|
||||
for (Stmt::child_iterator
|
||||
I = S->body_begin(), E = S->body_end(); I != E; ++I) {
|
||||
|
@ -228,7 +227,7 @@ private:
|
|||
Stmt::child_iterator Begin;
|
||||
Stmt::child_iterator End;
|
||||
bool IsFollowedBySimpleReturnStmt;
|
||||
llvm::SmallVector<ObjCMessageExpr *, 4> Releases;
|
||||
SmallVector<ObjCMessageExpr *, 4> Releases;
|
||||
|
||||
PoolScope() : PoolVar(0), CompoundParent(0), Begin(), End(),
|
||||
IsFollowedBySimpleReturnStmt(false) { }
|
||||
|
@ -420,7 +419,7 @@ private:
|
|||
struct PoolVarInfo {
|
||||
DeclStmt *Dcl;
|
||||
ExprSet Refs;
|
||||
llvm::SmallVector<PoolScope, 2> Scopes;
|
||||
SmallVector<PoolScope, 2> Scopes;
|
||||
|
||||
PoolVarInfo() : Dcl(0) { }
|
||||
};
|
||||
|
|
|
@ -32,7 +32,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
@ -75,7 +74,7 @@ public:
|
|||
RootBlockObjCVarRewriter(MigrationPass &pass) : Pass(pass) { }
|
||||
|
||||
bool VisitBlockDecl(BlockDecl *block) {
|
||||
llvm::SmallVector<VarDecl *, 4> BlockVars;
|
||||
SmallVector<VarDecl *, 4> BlockVars;
|
||||
|
||||
for (BlockDecl::capture_iterator
|
||||
I = block->capture_begin(), E = block->capture_end(); I != E; ++I) {
|
||||
|
|
|
@ -26,7 +26,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -40,7 +40,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
@ -55,7 +54,7 @@ class PropertiesRewriter {
|
|||
PropData(ObjCPropertyDecl *propD) : PropD(propD), IvarD(0), ImplD(0) { }
|
||||
};
|
||||
|
||||
typedef llvm::SmallVector<PropData, 2> PropsTy;
|
||||
typedef SmallVector<PropData, 2> PropsTy;
|
||||
typedef std::map<unsigned, PropsTy> AtPropDeclsTy;
|
||||
AtPropDeclsTy AtProps;
|
||||
|
||||
|
@ -187,7 +186,7 @@ private:
|
|||
}
|
||||
}
|
||||
|
||||
bool rewriteAttribute(llvm::StringRef fromAttr, llvm::StringRef toAttr,
|
||||
bool rewriteAttribute(StringRef fromAttr, StringRef toAttr,
|
||||
SourceLocation atLoc) const {
|
||||
if (atLoc.isMacroID())
|
||||
return false;
|
||||
|
@ -199,7 +198,7 @@ private:
|
|||
|
||||
// Try to load the file buffer.
|
||||
bool invalidTemp = false;
|
||||
llvm::StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
if (invalidTemp)
|
||||
return false;
|
||||
|
||||
|
@ -214,7 +213,7 @@ private:
|
|||
if (tok.isNot(tok::at)) return false;
|
||||
lexer.LexFromRawLexer(tok);
|
||||
if (tok.isNot(tok::raw_identifier)) return false;
|
||||
if (llvm::StringRef(tok.getRawIdentifierData(), tok.getLength())
|
||||
if (StringRef(tok.getRawIdentifierData(), tok.getLength())
|
||||
!= "property")
|
||||
return false;
|
||||
lexer.LexFromRawLexer(tok);
|
||||
|
@ -226,7 +225,7 @@ private:
|
|||
|
||||
while (1) {
|
||||
if (tok.isNot(tok::raw_identifier)) return false;
|
||||
llvm::StringRef ident(tok.getRawIdentifierData(), tok.getLength());
|
||||
StringRef ident(tok.getRawIdentifierData(), tok.getLength());
|
||||
if (ident == fromAttr) {
|
||||
Pass.TA.replaceText(tok.getLocation(), fromAttr, toAttr);
|
||||
return true;
|
||||
|
@ -243,7 +242,7 @@ private:
|
|||
return false;
|
||||
}
|
||||
|
||||
bool addAttribute(llvm::StringRef attr, SourceLocation atLoc) const {
|
||||
bool addAttribute(StringRef attr, SourceLocation atLoc) const {
|
||||
if (atLoc.isMacroID())
|
||||
return false;
|
||||
|
||||
|
@ -254,7 +253,7 @@ private:
|
|||
|
||||
// Try to load the file buffer.
|
||||
bool invalidTemp = false;
|
||||
llvm::StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
if (invalidTemp)
|
||||
return false;
|
||||
|
||||
|
@ -269,7 +268,7 @@ private:
|
|||
if (tok.isNot(tok::at)) return false;
|
||||
lexer.LexFromRawLexer(tok);
|
||||
if (tok.isNot(tok::raw_identifier)) return false;
|
||||
if (llvm::StringRef(tok.getRawIdentifierData(), tok.getLength())
|
||||
if (StringRef(tok.getRawIdentifierData(), tok.getLength())
|
||||
!= "property")
|
||||
return false;
|
||||
lexer.LexFromRawLexer(tok);
|
||||
|
|
|
@ -25,7 +25,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -41,7 +41,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -27,7 +27,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -19,7 +19,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
|
@ -13,10 +13,8 @@
|
|||
#include "clang/Basic/SourceManager.h"
|
||||
#include "llvm/ADT/DenseSet.h"
|
||||
#include <map>
|
||||
|
||||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using llvm::StringRef;
|
||||
|
||||
namespace {
|
||||
|
||||
|
@ -46,9 +44,9 @@ class TransformActionsImpl {
|
|||
ActionKind Kind;
|
||||
SourceLocation Loc;
|
||||
SourceRange R1, R2;
|
||||
llvm::StringRef Text1, Text2;
|
||||
StringRef Text1, Text2;
|
||||
Stmt *S;
|
||||
llvm::SmallVector<unsigned, 2> DiagIDs;
|
||||
SmallVector<unsigned, 2> DiagIDs;
|
||||
};
|
||||
|
||||
std::vector<ActionData> CachedActions;
|
||||
|
@ -104,7 +102,7 @@ class TransformActionsImpl {
|
|||
}
|
||||
};
|
||||
|
||||
typedef llvm::SmallVector<StringRef, 2> TextsVec;
|
||||
typedef SmallVector<StringRef, 2> TextsVec;
|
||||
typedef std::map<FullSourceLoc, TextsVec, FullSourceLoc::BeforeThanCompare>
|
||||
InsertsMap;
|
||||
InsertsMap Inserts;
|
||||
|
@ -130,15 +128,15 @@ public:
|
|||
|
||||
bool isInTransaction() const { return IsInTransaction; }
|
||||
|
||||
void insert(SourceLocation loc, llvm::StringRef text);
|
||||
void insertAfterToken(SourceLocation loc, llvm::StringRef text);
|
||||
void insert(SourceLocation loc, StringRef text);
|
||||
void insertAfterToken(SourceLocation loc, StringRef text);
|
||||
void remove(SourceRange range);
|
||||
void removeStmt(Stmt *S);
|
||||
void replace(SourceRange range, llvm::StringRef text);
|
||||
void replace(SourceRange range, StringRef text);
|
||||
void replace(SourceRange range, SourceRange replacementRange);
|
||||
void replaceStmt(Stmt *S, llvm::StringRef text);
|
||||
void replaceText(SourceLocation loc, llvm::StringRef text,
|
||||
llvm::StringRef replacementText);
|
||||
void replaceStmt(Stmt *S, StringRef text);
|
||||
void replaceText(SourceLocation loc, StringRef text,
|
||||
StringRef replacementText);
|
||||
void increaseIndentation(SourceRange range,
|
||||
SourceLocation parentIndent);
|
||||
|
||||
|
@ -151,15 +149,15 @@ private:
|
|||
bool canInsertAfterToken(SourceLocation loc);
|
||||
bool canRemoveRange(SourceRange range);
|
||||
bool canReplaceRange(SourceRange range, SourceRange replacementRange);
|
||||
bool canReplaceText(SourceLocation loc, llvm::StringRef text);
|
||||
bool canReplaceText(SourceLocation loc, StringRef text);
|
||||
|
||||
void commitInsert(SourceLocation loc, StringRef text);
|
||||
void commitInsertAfterToken(SourceLocation loc, StringRef text);
|
||||
void commitRemove(SourceRange range);
|
||||
void commitRemoveStmt(Stmt *S);
|
||||
void commitReplace(SourceRange range, SourceRange replacementRange);
|
||||
void commitReplaceText(SourceLocation loc, llvm::StringRef text,
|
||||
llvm::StringRef replacementText);
|
||||
void commitReplaceText(SourceLocation loc, StringRef text,
|
||||
StringRef replacementText);
|
||||
void commitIncreaseIndentation(SourceRange range,SourceLocation parentIndent);
|
||||
void commitClearDiagnostic(llvm::ArrayRef<unsigned> IDs, SourceRange range);
|
||||
|
||||
|
@ -425,7 +423,7 @@ bool TransformActionsImpl::canReplaceText(SourceLocation loc, StringRef text) {
|
|||
|
||||
// Try to load the file buffer.
|
||||
bool invalidTemp = false;
|
||||
llvm::StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
if (invalidTemp)
|
||||
return false;
|
||||
|
||||
|
@ -621,12 +619,12 @@ void TransformActions::abortTransaction() {
|
|||
}
|
||||
|
||||
|
||||
void TransformActions::insert(SourceLocation loc, llvm::StringRef text) {
|
||||
void TransformActions::insert(SourceLocation loc, StringRef text) {
|
||||
static_cast<TransformActionsImpl*>(Impl)->insert(loc, text);
|
||||
}
|
||||
|
||||
void TransformActions::insertAfterToken(SourceLocation loc,
|
||||
llvm::StringRef text) {
|
||||
StringRef text) {
|
||||
static_cast<TransformActionsImpl*>(Impl)->insertAfterToken(loc, text);
|
||||
}
|
||||
|
||||
|
@ -638,7 +636,7 @@ void TransformActions::removeStmt(Stmt *S) {
|
|||
static_cast<TransformActionsImpl*>(Impl)->removeStmt(S);
|
||||
}
|
||||
|
||||
void TransformActions::replace(SourceRange range, llvm::StringRef text) {
|
||||
void TransformActions::replace(SourceRange range, StringRef text) {
|
||||
static_cast<TransformActionsImpl*>(Impl)->replace(range, text);
|
||||
}
|
||||
|
||||
|
@ -647,12 +645,12 @@ void TransformActions::replace(SourceRange range,
|
|||
static_cast<TransformActionsImpl*>(Impl)->replace(range, replacementRange);
|
||||
}
|
||||
|
||||
void TransformActions::replaceStmt(Stmt *S, llvm::StringRef text) {
|
||||
void TransformActions::replaceStmt(Stmt *S, StringRef text) {
|
||||
static_cast<TransformActionsImpl*>(Impl)->replaceStmt(S, text);
|
||||
}
|
||||
|
||||
void TransformActions::replaceText(SourceLocation loc, llvm::StringRef text,
|
||||
llvm::StringRef replacementText) {
|
||||
void TransformActions::replaceText(SourceLocation loc, StringRef text,
|
||||
StringRef replacementText) {
|
||||
static_cast<TransformActionsImpl*>(Impl)->replaceText(loc, text,
|
||||
replacementText);
|
||||
}
|
||||
|
@ -672,7 +670,7 @@ void TransformActions::applyRewrites(RewriteReceiver &receiver) {
|
|||
static_cast<TransformActionsImpl*>(Impl)->applyRewrites(receiver);
|
||||
}
|
||||
|
||||
void TransformActions::reportError(llvm::StringRef error, SourceLocation loc,
|
||||
void TransformActions::reportError(StringRef error, SourceLocation loc,
|
||||
SourceRange range) {
|
||||
assert(!static_cast<TransformActionsImpl*>(Impl)->isInTransaction() &&
|
||||
"Errors should be emitted out of a transaction");
|
||||
|
@ -686,7 +684,7 @@ void TransformActions::reportError(llvm::StringRef error, SourceLocation loc,
|
|||
ReportedErrors = true;
|
||||
}
|
||||
|
||||
void TransformActions::reportNote(llvm::StringRef note, SourceLocation loc,
|
||||
void TransformActions::reportNote(StringRef note, SourceLocation loc,
|
||||
SourceRange range) {
|
||||
assert(!static_cast<TransformActionsImpl*>(Impl)->isInTransaction() &&
|
||||
"Errors should be emitted out of a transaction");
|
||||
|
|
|
@ -23,7 +23,6 @@
|
|||
using namespace clang;
|
||||
using namespace arcmt;
|
||||
using namespace trans;
|
||||
using llvm::StringRef;
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Helpers.
|
||||
|
@ -105,7 +104,7 @@ SourceLocation trans::findLocationAfterSemi(SourceLocation loc,
|
|||
|
||||
// Try to load the file buffer.
|
||||
bool invalidTemp = false;
|
||||
llvm::StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
StringRef file = SM.getBufferData(locInfo.first, &invalidTemp);
|
||||
if (invalidTemp)
|
||||
return SourceLocation();
|
||||
|
||||
|
|
|
@ -91,7 +91,7 @@ static double GetApproxValue(const llvm::APFloat &F) {
|
|||
return V.convertToDouble();
|
||||
}
|
||||
|
||||
void APValue::print(llvm::raw_ostream &OS) const {
|
||||
void APValue::print(raw_ostream &OS) const {
|
||||
switch (getKind()) {
|
||||
default: assert(0 && "Unknown APValue kind!");
|
||||
case Uninitialized:
|
||||
|
@ -120,7 +120,7 @@ void APValue::print(llvm::raw_ostream &OS) const {
|
|||
}
|
||||
}
|
||||
|
||||
static void WriteShortAPValueToStream(llvm::raw_ostream& Out,
|
||||
static void WriteShortAPValueToStream(raw_ostream& Out,
|
||||
const APValue& V) {
|
||||
switch (V.getKind()) {
|
||||
default: assert(0 && "Unknown APValue kind!");
|
||||
|
|
|
@ -104,7 +104,7 @@ ASTContext::getCanonicalTemplateTemplateParmDecl(
|
|||
|
||||
// Build a canonical template parameter list.
|
||||
TemplateParameterList *Params = TTP->getTemplateParameters();
|
||||
llvm::SmallVector<NamedDecl *, 4> CanonParams;
|
||||
SmallVector<NamedDecl *, 4> CanonParams;
|
||||
CanonParams.reserve(Params->size());
|
||||
for (TemplateParameterList::const_iterator P = Params->begin(),
|
||||
PEnd = Params->end();
|
||||
|
@ -123,8 +123,8 @@ ASTContext::getCanonicalTemplateTemplateParmDecl(
|
|||
TypeSourceInfo *TInfo = getTrivialTypeSourceInfo(T);
|
||||
NonTypeTemplateParmDecl *Param;
|
||||
if (NTTP->isExpandedParameterPack()) {
|
||||
llvm::SmallVector<QualType, 2> ExpandedTypes;
|
||||
llvm::SmallVector<TypeSourceInfo *, 2> ExpandedTInfos;
|
||||
SmallVector<QualType, 2> ExpandedTypes;
|
||||
SmallVector<TypeSourceInfo *, 2> ExpandedTInfos;
|
||||
for (unsigned I = 0, N = NTTP->getNumExpansionTypes(); I != N; ++I) {
|
||||
ExpandedTypes.push_back(getCanonicalType(NTTP->getExpansionType(I)));
|
||||
ExpandedTInfos.push_back(
|
||||
|
@ -2013,7 +2013,7 @@ ASTContext::getFunctionType(QualType ResultTy,
|
|||
// The exception spec is not part of the canonical type.
|
||||
QualType Canonical;
|
||||
if (!isCanonical || getCanonicalCallConv(CallConv) != CallConv) {
|
||||
llvm::SmallVector<QualType, 16> CanonicalArgs;
|
||||
SmallVector<QualType, 16> CanonicalArgs;
|
||||
CanonicalArgs.reserve(NumArgs);
|
||||
for (unsigned i = 0; i != NumArgs; ++i)
|
||||
CanonicalArgs.push_back(getCanonicalParamType(ArgArray[i]));
|
||||
|
@ -2309,7 +2309,7 @@ ASTContext::getTemplateSpecializationType(TemplateName Template,
|
|||
|
||||
unsigned NumArgs = Args.size();
|
||||
|
||||
llvm::SmallVector<TemplateArgument, 4> ArgVec;
|
||||
SmallVector<TemplateArgument, 4> ArgVec;
|
||||
ArgVec.reserve(NumArgs);
|
||||
for (unsigned i = 0; i != NumArgs; ++i)
|
||||
ArgVec.push_back(Args[i].getArgument());
|
||||
|
@ -2376,7 +2376,7 @@ ASTContext::getCanonicalTemplateSpecializationType(TemplateName Template,
|
|||
|
||||
// Build the canonical template specialization type.
|
||||
TemplateName CanonTemplate = getCanonicalTemplateName(Template);
|
||||
llvm::SmallVector<TemplateArgument, 4> CanonArgs;
|
||||
SmallVector<TemplateArgument, 4> CanonArgs;
|
||||
CanonArgs.reserve(NumArgs);
|
||||
for (unsigned I = 0; I != NumArgs; ++I)
|
||||
CanonArgs.push_back(getCanonicalTemplateArgument(Args[I]));
|
||||
|
@ -2496,7 +2496,7 @@ ASTContext::getDependentTemplateSpecializationType(
|
|||
const IdentifierInfo *Name,
|
||||
const TemplateArgumentListInfo &Args) const {
|
||||
// TODO: avoid this copy
|
||||
llvm::SmallVector<TemplateArgument, 16> ArgCopy;
|
||||
SmallVector<TemplateArgument, 16> ArgCopy;
|
||||
for (unsigned I = 0, E = Args.size(); I != E; ++I)
|
||||
ArgCopy.push_back(Args[I].getArgument());
|
||||
return getDependentTemplateSpecializationType(Keyword, NNS, Name,
|
||||
|
@ -2530,7 +2530,7 @@ ASTContext::getDependentTemplateSpecializationType(
|
|||
if (Keyword == ETK_None) CanonKeyword = ETK_Typename;
|
||||
|
||||
bool AnyNonCanonArgs = false;
|
||||
llvm::SmallVector<TemplateArgument, 16> CanonArgs(NumArgs);
|
||||
SmallVector<TemplateArgument, 16> CanonArgs(NumArgs);
|
||||
for (unsigned I = 0; I != NumArgs; ++I) {
|
||||
CanonArgs[I] = getCanonicalTemplateArgument(Args[I]);
|
||||
if (!CanonArgs[I].structurallyEquals(Args[I]))
|
||||
|
@ -2634,7 +2634,7 @@ QualType ASTContext::getObjCObjectType(QualType BaseType,
|
|||
bool ProtocolsSorted = areSortedAndUniqued(Protocols, NumProtocols);
|
||||
if (!ProtocolsSorted || !BaseType.isCanonical()) {
|
||||
if (!ProtocolsSorted) {
|
||||
llvm::SmallVector<ObjCProtocolDecl*, 8> Sorted(Protocols,
|
||||
SmallVector<ObjCProtocolDecl*, 8> Sorted(Protocols,
|
||||
Protocols + NumProtocols);
|
||||
unsigned UniqueCount = NumProtocols;
|
||||
|
||||
|
@ -3824,7 +3824,7 @@ bool ASTContext::BlockRequiresCopying(QualType Ty) const {
|
|||
}
|
||||
|
||||
QualType
|
||||
ASTContext::BuildByRefType(llvm::StringRef DeclName, QualType Ty) const {
|
||||
ASTContext::BuildByRefType(StringRef DeclName, QualType Ty) const {
|
||||
// type = struct __Block_byref_1_X {
|
||||
// void *__isa;
|
||||
// struct __Block_byref_1_X *__forwarding;
|
||||
|
@ -3856,7 +3856,7 @@ ASTContext::BuildByRefType(llvm::StringRef DeclName, QualType Ty) const {
|
|||
Ty
|
||||
};
|
||||
|
||||
llvm::StringRef FieldNames[] = {
|
||||
StringRef FieldNames[] = {
|
||||
"__isa",
|
||||
"__forwarding",
|
||||
"__flags",
|
||||
|
@ -4329,7 +4329,7 @@ void ASTContext::getObjCEncodingForTypeImpl(QualType T, std::string& S,
|
|||
// Another legacy compatibility encoding. Some ObjC qualifier and type
|
||||
// combinations need to be rearranged.
|
||||
// Rewrite "in const" from "nr" to "rn"
|
||||
if (llvm::StringRef(S).endswith("nr"))
|
||||
if (StringRef(S).endswith("nr"))
|
||||
S.replace(S.end()-2, S.end(), "rn");
|
||||
}
|
||||
|
||||
|
@ -5248,7 +5248,7 @@ static
|
|||
void getIntersectionOfProtocols(ASTContext &Context,
|
||||
const ObjCObjectPointerType *LHSOPT,
|
||||
const ObjCObjectPointerType *RHSOPT,
|
||||
llvm::SmallVectorImpl<ObjCProtocolDecl *> &IntersectionOfProtocols) {
|
||||
SmallVectorImpl<ObjCProtocolDecl *> &IntersectionOfProtocols) {
|
||||
|
||||
const ObjCObjectType* LHS = LHSOPT->getObjectType();
|
||||
const ObjCObjectType* RHS = RHSOPT->getObjectType();
|
||||
|
@ -5304,7 +5304,7 @@ QualType ASTContext::areCommonBaseCompatible(
|
|||
do {
|
||||
LHS = cast<ObjCInterfaceType>(getObjCInterfaceType(LDecl));
|
||||
if (canAssignObjCInterfaces(LHS, RHS)) {
|
||||
llvm::SmallVector<ObjCProtocolDecl *, 8> Protocols;
|
||||
SmallVector<ObjCProtocolDecl *, 8> Protocols;
|
||||
getIntersectionOfProtocols(*this, Lptr, Rptr, Protocols);
|
||||
|
||||
QualType Result = QualType(LHS, 0);
|
||||
|
@ -5567,7 +5567,7 @@ QualType ASTContext::mergeFunctionTypes(QualType lhs, QualType rhs,
|
|||
return QualType();
|
||||
|
||||
// Check argument compatibility
|
||||
llvm::SmallVector<QualType, 10> types;
|
||||
SmallVector<QualType, 10> types;
|
||||
for (unsigned i = 0; i < lproto_nargs; i++) {
|
||||
QualType largtype = lproto->getArgType(i).getUnqualifiedType();
|
||||
QualType rargtype = rproto->getArgType(i).getUnqualifiedType();
|
||||
|
@ -6234,7 +6234,7 @@ QualType ASTContext::GetBuiltinType(unsigned Id,
|
|||
unsigned *IntegerConstantArgs) const {
|
||||
const char *TypeStr = BuiltinInfo.GetTypeString(Id);
|
||||
|
||||
llvm::SmallVector<QualType, 8> ArgTypes;
|
||||
SmallVector<QualType, 8> ArgTypes;
|
||||
|
||||
bool RequiresICE = false;
|
||||
Error = GE_None;
|
||||
|
|
|
@ -154,14 +154,14 @@ static std::string
|
|||
ConvertTypeToDiagnosticString(ASTContext &Context, QualType Ty,
|
||||
const Diagnostic::ArgumentValue *PrevArgs,
|
||||
unsigned NumPrevArgs,
|
||||
llvm::SmallVectorImpl<intptr_t> &QualTypeVals) {
|
||||
SmallVectorImpl<intptr_t> &QualTypeVals) {
|
||||
// FIXME: Playing with std::string is really slow.
|
||||
bool ForceAKA = false;
|
||||
QualType CanTy = Ty.getCanonicalType();
|
||||
std::string S = Ty.getAsString(Context.PrintingPolicy);
|
||||
std::string CanS = CanTy.getAsString(Context.PrintingPolicy);
|
||||
|
||||
for (llvm::SmallVectorImpl<intptr_t>::iterator I = QualTypeVals.begin(),
|
||||
for (SmallVectorImpl<intptr_t>::iterator I = QualTypeVals.begin(),
|
||||
E = QualTypeVals.end(); I != E; ++I) {
|
||||
QualType CompareTy =
|
||||
QualType::getFromOpaquePtr(reinterpret_cast<void*>(*I));
|
||||
|
@ -226,9 +226,9 @@ void clang::FormatASTNodeDiagnosticArgument(
|
|||
unsigned ArgLen,
|
||||
const Diagnostic::ArgumentValue *PrevArgs,
|
||||
unsigned NumPrevArgs,
|
||||
llvm::SmallVectorImpl<char> &Output,
|
||||
SmallVectorImpl<char> &Output,
|
||||
void *Cookie,
|
||||
llvm::SmallVectorImpl<intptr_t> &QualTypeVals) {
|
||||
SmallVectorImpl<intptr_t> &QualTypeVals) {
|
||||
ASTContext &Context = *static_cast<ASTContext*>(Cookie);
|
||||
|
||||
std::string S;
|
||||
|
|
|
@ -92,7 +92,7 @@ namespace {
|
|||
TemplateArgument ImportTemplateArgument(const TemplateArgument &From);
|
||||
bool ImportTemplateArguments(const TemplateArgument *FromArgs,
|
||||
unsigned NumFromArgs,
|
||||
llvm::SmallVectorImpl<TemplateArgument> &ToArgs);
|
||||
SmallVectorImpl<TemplateArgument> &ToArgs);
|
||||
bool IsStructuralMatch(RecordDecl *FromRecord, RecordDecl *ToRecord);
|
||||
bool IsStructuralMatch(EnumDecl *FromEnum, EnumDecl *ToRecord);
|
||||
bool IsStructuralMatch(ClassTemplateDecl *From, ClassTemplateDecl *To);
|
||||
|
@ -1518,7 +1518,7 @@ QualType ASTNodeImporter::VisitFunctionProtoType(const FunctionProtoType *T) {
|
|||
return QualType();
|
||||
|
||||
// Import argument types
|
||||
llvm::SmallVector<QualType, 4> ArgTypes;
|
||||
SmallVector<QualType, 4> ArgTypes;
|
||||
for (FunctionProtoType::arg_type_iterator A = T->arg_type_begin(),
|
||||
AEnd = T->arg_type_end();
|
||||
A != AEnd; ++A) {
|
||||
|
@ -1529,7 +1529,7 @@ QualType ASTNodeImporter::VisitFunctionProtoType(const FunctionProtoType *T) {
|
|||
}
|
||||
|
||||
// Import exception types
|
||||
llvm::SmallVector<QualType, 4> ExceptionTypes;
|
||||
SmallVector<QualType, 4> ExceptionTypes;
|
||||
for (FunctionProtoType::exception_iterator E = T->exception_begin(),
|
||||
EEnd = T->exception_end();
|
||||
E != EEnd; ++E) {
|
||||
|
@ -1628,7 +1628,7 @@ QualType ASTNodeImporter::VisitTemplateSpecializationType(
|
|||
if (ToTemplate.isNull())
|
||||
return QualType();
|
||||
|
||||
llvm::SmallVector<TemplateArgument, 2> ToTemplateArgs;
|
||||
SmallVector<TemplateArgument, 2> ToTemplateArgs;
|
||||
if (ImportTemplateArguments(T->getArgs(), T->getNumArgs(), ToTemplateArgs))
|
||||
return QualType();
|
||||
|
||||
|
@ -1677,7 +1677,7 @@ QualType ASTNodeImporter::VisitObjCObjectType(const ObjCObjectType *T) {
|
|||
if (ToBaseType.isNull())
|
||||
return QualType();
|
||||
|
||||
llvm::SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
for (ObjCObjectType::qual_iterator P = T->qual_begin(),
|
||||
PEnd = T->qual_end();
|
||||
P != PEnd; ++P) {
|
||||
|
@ -1788,7 +1788,7 @@ bool ASTNodeImporter::ImportDefinition(RecordDecl *From, RecordDecl *To, bool Fo
|
|||
if (CXXRecordDecl *ToCXX = dyn_cast<CXXRecordDecl>(To)) {
|
||||
CXXRecordDecl *FromCXX = cast<CXXRecordDecl>(From);
|
||||
|
||||
llvm::SmallVector<CXXBaseSpecifier *, 4> Bases;
|
||||
SmallVector<CXXBaseSpecifier *, 4> Bases;
|
||||
for (CXXRecordDecl::base_class_iterator
|
||||
Base1 = FromCXX->bases_begin(),
|
||||
FromBaseEnd = FromCXX->bases_end();
|
||||
|
@ -1822,7 +1822,7 @@ bool ASTNodeImporter::ImportDefinition(RecordDecl *From, RecordDecl *To, bool Fo
|
|||
|
||||
TemplateParameterList *ASTNodeImporter::ImportTemplateParameterList(
|
||||
TemplateParameterList *Params) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ToParams;
|
||||
SmallVector<NamedDecl *, 4> ToParams;
|
||||
ToParams.reserve(Params->size());
|
||||
for (TemplateParameterList::iterator P = Params->begin(),
|
||||
PEnd = Params->end();
|
||||
|
@ -1889,7 +1889,7 @@ ASTNodeImporter::ImportTemplateArgument(const TemplateArgument &From) {
|
|||
return TemplateArgument();
|
||||
|
||||
case TemplateArgument::Pack: {
|
||||
llvm::SmallVector<TemplateArgument, 2> ToPack;
|
||||
SmallVector<TemplateArgument, 2> ToPack;
|
||||
ToPack.reserve(From.pack_size());
|
||||
if (ImportTemplateArguments(From.pack_begin(), From.pack_size(), ToPack))
|
||||
return TemplateArgument();
|
||||
|
@ -1907,7 +1907,7 @@ ASTNodeImporter::ImportTemplateArgument(const TemplateArgument &From) {
|
|||
|
||||
bool ASTNodeImporter::ImportTemplateArguments(const TemplateArgument *FromArgs,
|
||||
unsigned NumFromArgs,
|
||||
llvm::SmallVectorImpl<TemplateArgument> &ToArgs) {
|
||||
SmallVectorImpl<TemplateArgument> &ToArgs) {
|
||||
for (unsigned I = 0; I != NumFromArgs; ++I) {
|
||||
TemplateArgument To = ImportTemplateArgument(FromArgs[I]);
|
||||
if (To.isNull() && !FromArgs[I].isNull())
|
||||
|
@ -1966,7 +1966,7 @@ Decl *ASTNodeImporter::VisitNamespaceDecl(NamespaceDecl *D) {
|
|||
else
|
||||
MergeWithNamespace = cast<NamespaceDecl>(DC)->getAnonymousNamespace();
|
||||
} else {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
++Lookup.first) {
|
||||
|
@ -2026,7 +2026,7 @@ Decl *ASTNodeImporter::VisitTypedefNameDecl(TypedefNameDecl *D, bool IsAlias) {
|
|||
// seen a typedef with the same name (that we can merge with) or any
|
||||
// other entity by that name (which name lookup could conflict with).
|
||||
if (!DC->isFunctionOrMethod()) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
unsigned IDNS = Decl::IDNS_Ordinary;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
|
@ -2106,7 +2106,7 @@ Decl *ASTNodeImporter::VisitEnumDecl(EnumDecl *D) {
|
|||
|
||||
// We may already have an enum of the same name; try to find and match it.
|
||||
if (!DC->isFunctionOrMethod() && SearchName) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
++Lookup.first) {
|
||||
|
@ -2208,7 +2208,7 @@ Decl *ASTNodeImporter::VisitRecordDecl(RecordDecl *D) {
|
|||
// We may already have a record of the same name; try to find and match it.
|
||||
RecordDecl *AdoptDecl = 0;
|
||||
if (!DC->isFunctionOrMethod() && SearchName) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
++Lookup.first) {
|
||||
|
@ -2292,7 +2292,7 @@ Decl *ASTNodeImporter::VisitEnumConstantDecl(EnumConstantDecl *D) {
|
|||
// Determine whether there are any other declarations with the same name and
|
||||
// in the same context.
|
||||
if (!LexicalDC->isFunctionOrMethod()) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
unsigned IDNS = Decl::IDNS_Ordinary;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
|
@ -2338,7 +2338,7 @@ Decl *ASTNodeImporter::VisitFunctionDecl(FunctionDecl *D) {
|
|||
// Try to find a function in our own ("to") context with the same name, same
|
||||
// type, and in the same context as the function we're importing.
|
||||
if (!LexicalDC->isFunctionOrMethod()) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
unsigned IDNS = Decl::IDNS_Ordinary;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
|
@ -2393,7 +2393,7 @@ Decl *ASTNodeImporter::VisitFunctionDecl(FunctionDecl *D) {
|
|||
return 0;
|
||||
|
||||
// Import the function parameters.
|
||||
llvm::SmallVector<ParmVarDecl *, 8> Parameters;
|
||||
SmallVector<ParmVarDecl *, 8> Parameters;
|
||||
for (FunctionDecl::param_iterator P = D->param_begin(), PEnd = D->param_end();
|
||||
P != PEnd; ++P) {
|
||||
ParmVarDecl *ToP = cast_or_null<ParmVarDecl>(Importer.Import(*P));
|
||||
|
@ -2618,7 +2618,7 @@ Decl *ASTNodeImporter::VisitVarDecl(VarDecl *D) {
|
|||
// in the same context as the variable we're importing.
|
||||
if (D->isFileVarDecl()) {
|
||||
VarDecl *MergeWithVar = 0;
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
unsigned IDNS = Decl::IDNS_Ordinary;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
|
@ -2877,7 +2877,7 @@ Decl *ASTNodeImporter::VisitObjCMethodDecl(ObjCMethodDecl *D) {
|
|||
// deal with implicit parameters.
|
||||
|
||||
// Import the parameters
|
||||
llvm::SmallVector<ParmVarDecl *, 5> ToParams;
|
||||
SmallVector<ParmVarDecl *, 5> ToParams;
|
||||
for (ObjCMethodDecl::param_iterator FromP = D->param_begin(),
|
||||
FromPEnd = D->param_end();
|
||||
FromP != FromPEnd;
|
||||
|
@ -2936,8 +2936,8 @@ Decl *ASTNodeImporter::VisitObjCCategoryDecl(ObjCCategoryDecl *D) {
|
|||
ToCategory->insertNextClassCategory();
|
||||
|
||||
// Import protocols
|
||||
llvm::SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
llvm::SmallVector<SourceLocation, 4> ProtocolLocs;
|
||||
SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
SmallVector<SourceLocation, 4> ProtocolLocs;
|
||||
ObjCCategoryDecl::protocol_loc_iterator FromProtoLoc
|
||||
= D->protocol_loc_begin();
|
||||
for (ObjCCategoryDecl::protocol_iterator FromProto = D->protocol_begin(),
|
||||
|
@ -3008,8 +3008,8 @@ Decl *ASTNodeImporter::VisitObjCProtocolDecl(ObjCProtocolDecl *D) {
|
|||
Importer.Imported(D, ToProto);
|
||||
|
||||
// Import protocols
|
||||
llvm::SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
llvm::SmallVector<SourceLocation, 4> ProtocolLocs;
|
||||
SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
SmallVector<SourceLocation, 4> ProtocolLocs;
|
||||
ObjCProtocolDecl::protocol_loc_iterator
|
||||
FromProtoLoc = D->protocol_loc_begin();
|
||||
for (ObjCProtocolDecl::protocol_iterator FromProto = D->protocol_begin(),
|
||||
|
@ -3082,8 +3082,8 @@ Decl *ASTNodeImporter::VisitObjCInterfaceDecl(ObjCInterfaceDecl *D) {
|
|||
}
|
||||
|
||||
// Import protocols
|
||||
llvm::SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
llvm::SmallVector<SourceLocation, 4> ProtocolLocs;
|
||||
SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
SmallVector<SourceLocation, 4> ProtocolLocs;
|
||||
ObjCInterfaceDecl::protocol_loc_iterator
|
||||
FromProtoLoc = D->protocol_loc_begin();
|
||||
|
||||
|
@ -3427,8 +3427,8 @@ ASTNodeImporter::VisitObjCForwardProtocolDecl(ObjCForwardProtocolDecl *D) {
|
|||
// Import the location of this declaration.
|
||||
SourceLocation Loc = Importer.Import(D->getLocation());
|
||||
|
||||
llvm::SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
llvm::SmallVector<SourceLocation, 4> Locations;
|
||||
SmallVector<ObjCProtocolDecl *, 4> Protocols;
|
||||
SmallVector<SourceLocation, 4> Locations;
|
||||
ObjCForwardProtocolDecl::protocol_loc_iterator FromProtoLoc
|
||||
= D->protocol_loc_begin();
|
||||
for (ObjCForwardProtocolDecl::protocol_iterator FromProto
|
||||
|
@ -3470,8 +3470,8 @@ Decl *ASTNodeImporter::VisitObjCClassDecl(ObjCClassDecl *D) {
|
|||
// Import the location of this declaration.
|
||||
SourceLocation Loc = Importer.Import(D->getLocation());
|
||||
|
||||
llvm::SmallVector<ObjCInterfaceDecl *, 4> Interfaces;
|
||||
llvm::SmallVector<SourceLocation, 4> Locations;
|
||||
SmallVector<ObjCInterfaceDecl *, 4> Interfaces;
|
||||
SmallVector<SourceLocation, 4> Locations;
|
||||
for (ObjCClassDecl::iterator From = D->begin(), FromEnd = D->end();
|
||||
From != FromEnd; ++From) {
|
||||
ObjCInterfaceDecl *ToIface
|
||||
|
@ -3591,7 +3591,7 @@ Decl *ASTNodeImporter::VisitClassTemplateDecl(ClassTemplateDecl *D) {
|
|||
|
||||
// We may already have a template of the same name; try to find and match it.
|
||||
if (!DC->isFunctionOrMethod()) {
|
||||
llvm::SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
SmallVector<NamedDecl *, 4> ConflictingDecls;
|
||||
for (DeclContext::lookup_result Lookup = DC->lookup(Name);
|
||||
Lookup.first != Lookup.second;
|
||||
++Lookup.first) {
|
||||
|
@ -3701,7 +3701,7 @@ Decl *ASTNodeImporter::VisitClassTemplateSpecializationDecl(
|
|||
SourceLocation IdLoc = Importer.Import(D->getLocation());
|
||||
|
||||
// Import template arguments.
|
||||
llvm::SmallVector<TemplateArgument, 2> TemplateArgs;
|
||||
SmallVector<TemplateArgument, 2> TemplateArgs;
|
||||
if (ImportTemplateArguments(D->getTemplateArgs().data(),
|
||||
D->getTemplateArgs().size(),
|
||||
TemplateArgs))
|
||||
|
@ -4042,7 +4042,7 @@ Decl *ASTImporter::Import(Decl *FromD) {
|
|||
} else if (TypedefNameDecl *FromTypedef = dyn_cast<TypedefNameDecl>(FromD)) {
|
||||
// When we've finished transforming a typedef, see whether it was the
|
||||
// typedef for an anonymous tag.
|
||||
for (llvm::SmallVector<TagDecl *, 4>::iterator
|
||||
for (SmallVector<TagDecl *, 4>::iterator
|
||||
FromTag = AnonTagsWithPendingTypedefs.begin(),
|
||||
FromTagEnd = AnonTagsWithPendingTypedefs.end();
|
||||
FromTag != FromTagEnd; ++FromTag) {
|
||||
|
@ -4384,7 +4384,7 @@ Selector ASTImporter::Import(Selector FromSel) {
|
|||
if (FromSel.isNull())
|
||||
return Selector();
|
||||
|
||||
llvm::SmallVector<IdentifierInfo *, 4> Idents;
|
||||
SmallVector<IdentifierInfo *, 4> Idents;
|
||||
Idents.push_back(Import(FromSel.getIdentifierInfoForSlot(0)));
|
||||
for (unsigned I = 1, N = FromSel.getNumArgs(); I < N; ++I)
|
||||
Idents.push_back(Import(FromSel.getIdentifierInfoForSlot(I)));
|
||||
|
|
|
@ -119,7 +119,7 @@ bool CXXRecordDecl::isProvablyNotDerivedFrom(const CXXRecordDecl *Base) const {
|
|||
bool CXXRecordDecl::forallBases(ForallBasesCallback *BaseMatches,
|
||||
void *OpaqueData,
|
||||
bool AllowShortCircuit) const {
|
||||
llvm::SmallVector<const CXXRecordDecl*, 8> Queue;
|
||||
SmallVector<const CXXRecordDecl*, 8> Queue;
|
||||
|
||||
const CXXRecordDecl *Record = this;
|
||||
bool AllMatches = true;
|
||||
|
@ -425,7 +425,7 @@ FindNestedNameSpecifierMember(const CXXBaseSpecifier *Specifier,
|
|||
|
||||
void OverridingMethods::add(unsigned OverriddenSubobject,
|
||||
UniqueVirtualMethod Overriding) {
|
||||
llvm::SmallVector<UniqueVirtualMethod, 4> &SubobjectOverrides
|
||||
SmallVector<UniqueVirtualMethod, 4> &SubobjectOverrides
|
||||
= Overrides[OverriddenSubobject];
|
||||
if (std::find(SubobjectOverrides.begin(), SubobjectOverrides.end(),
|
||||
Overriding) == SubobjectOverrides.end())
|
||||
|
@ -556,7 +556,7 @@ void FinalOverriderCollector::Collect(const CXXRecordDecl *RD,
|
|||
// overrides.
|
||||
typedef std::pair<CXXMethodDecl::method_iterator,
|
||||
CXXMethodDecl::method_iterator> OverriddenMethods;
|
||||
llvm::SmallVector<OverriddenMethods, 4> Stack;
|
||||
SmallVector<OverriddenMethods, 4> Stack;
|
||||
Stack.push_back(std::make_pair(CanonM->begin_overridden_methods(),
|
||||
CanonM->end_overridden_methods()));
|
||||
while (!Stack.empty()) {
|
||||
|
@ -623,11 +623,11 @@ CXXRecordDecl::getFinalOverriders(CXXFinalOverriderMap &FinalOverriders) const {
|
|||
SOEnd = OM->second.end();
|
||||
SO != SOEnd;
|
||||
++SO) {
|
||||
llvm::SmallVector<UniqueVirtualMethod, 4> &Overriding = SO->second;
|
||||
SmallVector<UniqueVirtualMethod, 4> &Overriding = SO->second;
|
||||
if (Overriding.size() < 2)
|
||||
continue;
|
||||
|
||||
for (llvm::SmallVector<UniqueVirtualMethod, 4>::iterator
|
||||
for (SmallVector<UniqueVirtualMethod, 4>::iterator
|
||||
Pos = Overriding.begin(), PosEnd = Overriding.end();
|
||||
Pos != PosEnd;
|
||||
/* increment in loop */) {
|
||||
|
@ -642,7 +642,7 @@ CXXRecordDecl::getFinalOverriders(CXXFinalOverriderMap &FinalOverriders) const {
|
|||
// in a base class subobject that hides the virtual base class
|
||||
// subobject.
|
||||
bool Hidden = false;
|
||||
for (llvm::SmallVector<UniqueVirtualMethod, 4>::iterator
|
||||
for (SmallVector<UniqueVirtualMethod, 4>::iterator
|
||||
OP = Overriding.begin(), OPEnd = Overriding.end();
|
||||
OP != OPEnd && !Hidden;
|
||||
++OP) {
|
||||
|
|
|
@ -818,7 +818,7 @@ std::string NamedDecl::getQualifiedNameAsString(const PrintingPolicy &P) const {
|
|||
if (Ctx->isFunctionOrMethod())
|
||||
return getNameAsString();
|
||||
|
||||
typedef llvm::SmallVector<const DeclContext *, 8> ContextsTy;
|
||||
typedef SmallVector<const DeclContext *, 8> ContextsTy;
|
||||
ContextsTy Contexts;
|
||||
|
||||
// Collect contexts.
|
||||
|
@ -2387,7 +2387,7 @@ void RecordDecl::LoadFieldsFromExternalStorage() const {
|
|||
// Notify that we have a RecordDecl doing some initialization.
|
||||
ExternalASTSource::Deserializing TheFields(Source);
|
||||
|
||||
llvm::SmallVector<Decl*, 64> Decls;
|
||||
SmallVector<Decl*, 64> Decls;
|
||||
LoadedFieldsFromExternalStorage = true;
|
||||
switch (Source->FindExternalLexicalDeclsBy<FieldDecl>(this, Decls)) {
|
||||
case ELR_Success:
|
||||
|
|
|
@ -148,7 +148,7 @@ bool Decl::isDefinedOutsideFunctionOrMethod() const {
|
|||
// PrettyStackTraceDecl Implementation
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
void PrettyStackTraceDecl::print(llvm::raw_ostream &OS) const {
|
||||
void PrettyStackTraceDecl::print(raw_ostream &OS) const {
|
||||
SourceLocation TheLoc = Loc;
|
||||
if (TheLoc.isInvalid() && TheDecl)
|
||||
TheLoc = TheDecl->getLocation();
|
||||
|
@ -265,8 +265,8 @@ bool Decl::isReferenced() const {
|
|||
static AvailabilityResult CheckAvailability(ASTContext &Context,
|
||||
const AvailabilityAttr *A,
|
||||
std::string *Message) {
|
||||
llvm::StringRef TargetPlatform = Context.Target.getPlatformName();
|
||||
llvm::StringRef PrettyPlatformName
|
||||
StringRef TargetPlatform = Context.Target.getPlatformName();
|
||||
StringRef PrettyPlatformName
|
||||
= AvailabilityAttr::getPrettyPlatformName(TargetPlatform);
|
||||
if (PrettyPlatformName.empty())
|
||||
PrettyPlatformName = TargetPlatform;
|
||||
|
@ -812,7 +812,7 @@ DeclContext *DeclContext::getNextContext() {
|
|||
}
|
||||
|
||||
std::pair<Decl *, Decl *>
|
||||
DeclContext::BuildDeclChain(const llvm::SmallVectorImpl<Decl*> &Decls) {
|
||||
DeclContext::BuildDeclChain(const SmallVectorImpl<Decl*> &Decls) {
|
||||
// Build up a chain of declarations via the Decl::NextDeclInContext field.
|
||||
Decl *FirstNewDecl = 0;
|
||||
Decl *PrevDecl = 0;
|
||||
|
@ -840,7 +840,7 @@ DeclContext::LoadLexicalDeclsFromExternalStorage() const {
|
|||
ExternalASTSource::Deserializing ADeclContext(Source);
|
||||
|
||||
// Load the external declarations, if any.
|
||||
llvm::SmallVector<Decl*, 64> Decls;
|
||||
SmallVector<Decl*, 64> Decls;
|
||||
ExternalLexicalStorage = false;
|
||||
switch (Source->FindExternalLexicalDecls(this, Decls)) {
|
||||
case ELR_Success:
|
||||
|
@ -890,7 +890,7 @@ ExternalASTSource::SetNoExternalVisibleDeclsForName(const DeclContext *DC,
|
|||
DeclContext::lookup_result
|
||||
ExternalASTSource::SetExternalVisibleDeclsForName(const DeclContext *DC,
|
||||
DeclarationName Name,
|
||||
llvm::SmallVectorImpl<NamedDecl*> &Decls) {
|
||||
SmallVectorImpl<NamedDecl*> &Decls) {
|
||||
ASTContext &Context = DC->getParentASTContext();;
|
||||
|
||||
StoredDeclsMap *Map;
|
||||
|
@ -910,7 +910,7 @@ ExternalASTSource::SetExternalVisibleDeclsForName(const DeclContext *DC,
|
|||
|
||||
void ExternalASTSource::MaterializeVisibleDeclsForName(const DeclContext *DC,
|
||||
DeclarationName Name,
|
||||
llvm::SmallVectorImpl<NamedDecl*> &Decls) {
|
||||
SmallVectorImpl<NamedDecl*> &Decls) {
|
||||
assert(DC->LookupPtr);
|
||||
StoredDeclsMap &Map = *DC->LookupPtr;
|
||||
|
||||
|
|
|
@ -89,7 +89,7 @@ CXXRecordDecl::setBases(CXXBaseSpecifier const * const *Bases,
|
|||
llvm::SmallPtrSet<CanQualType, 8> SeenVBaseTypes;
|
||||
|
||||
// The virtual bases of this class.
|
||||
llvm::SmallVector<const CXXBaseSpecifier *, 8> VBases;
|
||||
SmallVector<const CXXBaseSpecifier *, 8> VBases;
|
||||
|
||||
data().Bases = new(C) CXXBaseSpecifier [NumBases];
|
||||
data().NumBases = NumBases;
|
||||
|
@ -287,7 +287,7 @@ bool CXXRecordDecl::isTriviallyCopyable() const {
|
|||
/// (if there is one).
|
||||
static CXXMethodDecl *
|
||||
GetBestOverloadCandidateSimple(
|
||||
const llvm::SmallVectorImpl<std::pair<CXXMethodDecl *, Qualifiers> > &Cands) {
|
||||
const SmallVectorImpl<std::pair<CXXMethodDecl *, Qualifiers> > &Cands) {
|
||||
if (Cands.empty())
|
||||
return 0;
|
||||
if (Cands.size() == 1)
|
||||
|
@ -313,7 +313,7 @@ CXXConstructorDecl *CXXRecordDecl::getCopyConstructor(unsigned TypeQuals) const{
|
|||
= Context.DeclarationNames.getCXXConstructorName(
|
||||
Context.getCanonicalType(ClassType));
|
||||
unsigned FoundTQs;
|
||||
llvm::SmallVector<std::pair<CXXMethodDecl *, Qualifiers>, 4> Found;
|
||||
SmallVector<std::pair<CXXMethodDecl *, Qualifiers>, 4> Found;
|
||||
DeclContext::lookup_const_iterator Con, ConEnd;
|
||||
for (llvm::tie(Con, ConEnd) = this->lookup(ConstructorName);
|
||||
Con != ConEnd; ++Con) {
|
||||
|
@ -349,7 +349,7 @@ CXXMethodDecl *CXXRecordDecl::getCopyAssignmentOperator(bool ArgIsConst) const {
|
|||
QualType Class = Context.getTypeDeclType(const_cast<CXXRecordDecl *>(this));
|
||||
DeclarationName Name = Context.DeclarationNames.getCXXOperatorName(OO_Equal);
|
||||
|
||||
llvm::SmallVector<std::pair<CXXMethodDecl *, Qualifiers>, 4> Found;
|
||||
SmallVector<std::pair<CXXMethodDecl *, Qualifiers>, 4> Found;
|
||||
DeclContext::lookup_const_iterator Op, OpEnd;
|
||||
for (llvm::tie(Op, OpEnd) = this->lookup(Name); Op != OpEnd; ++Op) {
|
||||
// C++ [class.copy]p9:
|
||||
|
|
|
@ -185,7 +185,7 @@ void ObjCInterfaceDecl::mergeClassExtensionProtocolList(
|
|||
// Check for duplicate protocol in class's protocol list.
|
||||
// This is O(n*m). But it is extremely rare and number of protocols in
|
||||
// class or its extension are very few.
|
||||
llvm::SmallVector<ObjCProtocolDecl*, 8> ProtocolRefs;
|
||||
SmallVector<ObjCProtocolDecl*, 8> ProtocolRefs;
|
||||
for (unsigned i = 0; i < ExtNum; i++) {
|
||||
bool protocolExists = false;
|
||||
ObjCProtocolDecl *ProtoInExtension = ExtList[i];
|
||||
|
@ -997,7 +997,7 @@ FindPropertyImplDecl(IdentifierInfo *Id) const {
|
|||
return 0;
|
||||
}
|
||||
|
||||
llvm::raw_ostream &clang::operator<<(llvm::raw_ostream &OS,
|
||||
raw_ostream &clang::operator<<(raw_ostream &OS,
|
||||
const ObjCCategoryImplDecl *CID) {
|
||||
OS << CID->getName();
|
||||
return OS;
|
||||
|
@ -1028,7 +1028,7 @@ void ObjCImplementationDecl::setIvarInitializers(ASTContext &C,
|
|||
}
|
||||
}
|
||||
|
||||
llvm::raw_ostream &clang::operator<<(llvm::raw_ostream &OS,
|
||||
raw_ostream &clang::operator<<(raw_ostream &OS,
|
||||
const ObjCImplementationDecl *ID) {
|
||||
OS << ID->getName();
|
||||
return OS;
|
||||
|
|
|
@ -24,19 +24,19 @@ using namespace clang;
|
|||
|
||||
namespace {
|
||||
class DeclPrinter : public DeclVisitor<DeclPrinter> {
|
||||
llvm::raw_ostream &Out;
|
||||
raw_ostream &Out;
|
||||
ASTContext &Context;
|
||||
PrintingPolicy Policy;
|
||||
unsigned Indentation;
|
||||
|
||||
llvm::raw_ostream& Indent() { return Indent(Indentation); }
|
||||
llvm::raw_ostream& Indent(unsigned Indentation);
|
||||
void ProcessDeclGroup(llvm::SmallVectorImpl<Decl*>& Decls);
|
||||
raw_ostream& Indent() { return Indent(Indentation); }
|
||||
raw_ostream& Indent(unsigned Indentation);
|
||||
void ProcessDeclGroup(SmallVectorImpl<Decl*>& Decls);
|
||||
|
||||
void Print(AccessSpecifier AS);
|
||||
|
||||
public:
|
||||
DeclPrinter(llvm::raw_ostream &Out, ASTContext &Context,
|
||||
DeclPrinter(raw_ostream &Out, ASTContext &Context,
|
||||
const PrintingPolicy &Policy,
|
||||
unsigned Indentation = 0)
|
||||
: Out(Out), Context(Context), Policy(Policy), Indentation(Indentation) { }
|
||||
|
@ -80,11 +80,11 @@ namespace {
|
|||
};
|
||||
}
|
||||
|
||||
void Decl::print(llvm::raw_ostream &Out, unsigned Indentation) const {
|
||||
void Decl::print(raw_ostream &Out, unsigned Indentation) const {
|
||||
print(Out, getASTContext().PrintingPolicy, Indentation);
|
||||
}
|
||||
|
||||
void Decl::print(llvm::raw_ostream &Out, const PrintingPolicy &Policy,
|
||||
void Decl::print(raw_ostream &Out, const PrintingPolicy &Policy,
|
||||
unsigned Indentation) const {
|
||||
DeclPrinter Printer(Out, getASTContext(), Policy, Indentation);
|
||||
Printer.Visit(const_cast<Decl*>(this));
|
||||
|
@ -119,7 +119,7 @@ static QualType getDeclType(Decl* D) {
|
|||
}
|
||||
|
||||
void Decl::printGroup(Decl** Begin, unsigned NumDecls,
|
||||
llvm::raw_ostream &Out, const PrintingPolicy &Policy,
|
||||
raw_ostream &Out, const PrintingPolicy &Policy,
|
||||
unsigned Indentation) {
|
||||
if (NumDecls == 1) {
|
||||
(*Begin)->print(Out, Policy, Indentation);
|
||||
|
@ -167,13 +167,13 @@ void Decl::dump() const {
|
|||
print(llvm::errs());
|
||||
}
|
||||
|
||||
llvm::raw_ostream& DeclPrinter::Indent(unsigned Indentation) {
|
||||
raw_ostream& DeclPrinter::Indent(unsigned Indentation) {
|
||||
for (unsigned i = 0; i != Indentation; ++i)
|
||||
Out << " ";
|
||||
return Out;
|
||||
}
|
||||
|
||||
void DeclPrinter::ProcessDeclGroup(llvm::SmallVectorImpl<Decl*>& Decls) {
|
||||
void DeclPrinter::ProcessDeclGroup(SmallVectorImpl<Decl*>& Decls) {
|
||||
this->Indent();
|
||||
Decl::printGroup(Decls.data(), Decls.size(), Out, Policy, Indentation);
|
||||
Out << ";\n";
|
||||
|
@ -198,7 +198,7 @@ void DeclPrinter::VisitDeclContext(DeclContext *DC, bool Indent) {
|
|||
if (Indent)
|
||||
Indentation += Policy.Indentation;
|
||||
|
||||
llvm::SmallVector<Decl*, 2> Decls;
|
||||
SmallVector<Decl*, 2> Decls;
|
||||
for (DeclContext::decl_iterator D = DC->decls_begin(), DEnd = DC->decls_end();
|
||||
D != DEnd; ++D) {
|
||||
|
||||
|
|
|
@ -348,7 +348,7 @@ void ClassTemplateDecl::AddPartialSpecialization(
|
|||
}
|
||||
|
||||
void ClassTemplateDecl::getPartialSpecializations(
|
||||
llvm::SmallVectorImpl<ClassTemplatePartialSpecializationDecl *> &PS) {
|
||||
SmallVectorImpl<ClassTemplatePartialSpecializationDecl *> &PS) {
|
||||
llvm::FoldingSet<ClassTemplatePartialSpecializationDecl> &PartialSpecs
|
||||
= getPartialSpecializations();
|
||||
PS.clear();
|
||||
|
@ -406,7 +406,7 @@ ClassTemplateDecl::getInjectedClassNameSpecialization() {
|
|||
// pack.
|
||||
ASTContext &Context = getASTContext();
|
||||
TemplateParameterList *Params = getTemplateParameters();
|
||||
llvm::SmallVector<TemplateArgument, 16> TemplateArgs;
|
||||
SmallVector<TemplateArgument, 16> TemplateArgs;
|
||||
TemplateArgs.resize(Params->size());
|
||||
GenerateInjectedTemplateArgs(getASTContext(), Params, TemplateArgs.data());
|
||||
CommonPtr->InjectedClassNameType
|
||||
|
|
|
@ -209,7 +209,7 @@ std::string DeclarationName::getAsString() const {
|
|||
return OS.str();
|
||||
}
|
||||
|
||||
void DeclarationName::printName(llvm::raw_ostream &OS) const {
|
||||
void DeclarationName::printName(raw_ostream &OS) const {
|
||||
switch (getNameKind()) {
|
||||
case Identifier:
|
||||
if (const IdentifierInfo *II = getAsIdentifierInfo())
|
||||
|
@ -562,7 +562,7 @@ std::string DeclarationNameInfo::getAsString() const {
|
|||
return OS.str();
|
||||
}
|
||||
|
||||
void DeclarationNameInfo::printName(llvm::raw_ostream &OS) const {
|
||||
void DeclarationNameInfo::printName(raw_ostream &OS) const {
|
||||
switch (Name.getNameKind()) {
|
||||
case DeclarationName::Identifier:
|
||||
case DeclarationName::ObjCZeroArgSelector:
|
||||
|
|
|
@ -53,9 +53,9 @@ enum NodeState {
|
|||
};
|
||||
|
||||
struct Node {
|
||||
llvm::StringRef Name;
|
||||
StringRef Name;
|
||||
NodeState State;
|
||||
Node(llvm::StringRef name) : Name(name), State(NS_Attrs) {}
|
||||
Node(StringRef name) : Name(name), State(NS_Attrs) {}
|
||||
|
||||
bool isDoneWithAttrs() const { return State != NS_Attrs; }
|
||||
};
|
||||
|
@ -159,7 +159,7 @@ template <class Impl> struct XMLTypeVisitor {
|
|||
#undef DISPATCH
|
||||
};
|
||||
|
||||
static llvm::StringRef getTypeKindName(Type *T) {
|
||||
static StringRef getTypeKindName(Type *T) {
|
||||
switch (T->getTypeClass()) {
|
||||
#define TYPE(DERIVED, BASE) case Type::DERIVED: return #DERIVED "Type";
|
||||
#define ABSTRACT_TYPE(DERIVED, BASE)
|
||||
|
@ -172,11 +172,11 @@ static llvm::StringRef getTypeKindName(Type *T) {
|
|||
|
||||
struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
||||
public XMLTypeVisitor<XMLDumper> {
|
||||
llvm::raw_ostream &out;
|
||||
raw_ostream &out;
|
||||
ASTContext &Context;
|
||||
llvm::SmallVector<Node, 16> Stack;
|
||||
SmallVector<Node, 16> Stack;
|
||||
unsigned Indent;
|
||||
explicit XMLDumper(llvm::raw_ostream &OS, ASTContext &context)
|
||||
explicit XMLDumper(raw_ostream &OS, ASTContext &context)
|
||||
: out(OS), Context(context), Indent(0) {}
|
||||
|
||||
void indent() {
|
||||
|
@ -185,7 +185,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
}
|
||||
|
||||
/// Push a new node on the stack.
|
||||
void push(llvm::StringRef name) {
|
||||
void push(StringRef name) {
|
||||
if (!Stack.empty()) {
|
||||
assert(Stack.back().isDoneWithAttrs());
|
||||
if (Stack.back().State == NS_LazyChildren) {
|
||||
|
@ -200,7 +200,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
}
|
||||
|
||||
/// Set the given attribute to the given value.
|
||||
void set(llvm::StringRef attr, llvm::StringRef value) {
|
||||
void set(StringRef attr, StringRef value) {
|
||||
assert(!Stack.empty() && !Stack.back().isDoneWithAttrs());
|
||||
out << ' ' << attr << '=' << '"' << value << '"'; // TODO: quotation
|
||||
}
|
||||
|
@ -226,7 +226,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
|
||||
//---- General utilities -------------------------------------------//
|
||||
|
||||
void setPointer(llvm::StringRef prop, const void *p) {
|
||||
void setPointer(StringRef prop, const void *p) {
|
||||
llvm::SmallString<10> buffer;
|
||||
llvm::raw_svector_ostream os(buffer);
|
||||
os << p;
|
||||
|
@ -238,11 +238,11 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
setPointer("ptr", p);
|
||||
}
|
||||
|
||||
void setInteger(llvm::StringRef prop, const llvm::APSInt &v) {
|
||||
void setInteger(StringRef prop, const llvm::APSInt &v) {
|
||||
set(prop, v.toString(10));
|
||||
}
|
||||
|
||||
void setInteger(llvm::StringRef prop, unsigned n) {
|
||||
void setInteger(StringRef prop, unsigned n) {
|
||||
llvm::SmallString<10> buffer;
|
||||
llvm::raw_svector_ostream os(buffer);
|
||||
os << n;
|
||||
|
@ -250,7 +250,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
set(prop, buffer);
|
||||
}
|
||||
|
||||
void setFlag(llvm::StringRef prop, bool flag) {
|
||||
void setFlag(StringRef prop, bool flag) {
|
||||
if (flag) set(prop, "true");
|
||||
}
|
||||
|
||||
|
@ -268,7 +268,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
class TemporaryContainer {
|
||||
XMLDumper &Dumper;
|
||||
public:
|
||||
TemporaryContainer(XMLDumper &dumper, llvm::StringRef name)
|
||||
TemporaryContainer(XMLDumper &dumper, StringRef name)
|
||||
: Dumper(dumper) {
|
||||
Dumper.push(name);
|
||||
Dumper.completeAttrs();
|
||||
|
@ -303,7 +303,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
completeAttrs();
|
||||
pop();
|
||||
}
|
||||
void visitDeclRef(llvm::StringRef Name, Decl *D) {
|
||||
void visitDeclRef(StringRef Name, Decl *D) {
|
||||
TemporaryContainer C(*this, Name);
|
||||
if (D) visitDeclRef(D);
|
||||
}
|
||||
|
@ -423,7 +423,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
|
||||
// LinkageSpecDecl
|
||||
void visitLinkageSpecDeclAttrs(LinkageSpecDecl *D) {
|
||||
llvm::StringRef lang = "";
|
||||
StringRef lang = "";
|
||||
switch (D->getLanguage()) {
|
||||
case LinkageSpecDecl::lang_c: lang = "C"; break;
|
||||
case LinkageSpecDecl::lang_cxx: lang = "C++"; break;
|
||||
|
@ -860,7 +860,7 @@ struct XMLDumper : public XMLDeclVisitor<XMLDumper>,
|
|||
}
|
||||
|
||||
// ObjCIvarDecl
|
||||
void setAccessControl(llvm::StringRef prop, ObjCIvarDecl::AccessControl AC) {
|
||||
void setAccessControl(StringRef prop, ObjCIvarDecl::AccessControl AC) {
|
||||
switch (AC) {
|
||||
case ObjCIvarDecl::None: return set(prop, "none");
|
||||
case ObjCIvarDecl::Private: return set(prop, "private");
|
||||
|
@ -1031,13 +1031,13 @@ void Decl::dumpXML() const {
|
|||
dumpXML(llvm::errs());
|
||||
}
|
||||
|
||||
void Decl::dumpXML(llvm::raw_ostream &out) const {
|
||||
void Decl::dumpXML(raw_ostream &out) const {
|
||||
XMLDumper(out, getASTContext()).dispatch(const_cast<Decl*>(this));
|
||||
}
|
||||
|
||||
#else /* ifndef NDEBUG */
|
||||
|
||||
void Decl::dumpXML() const {}
|
||||
void Decl::dumpXML(llvm::raw_ostream &out) const {}
|
||||
void Decl::dumpXML(raw_ostream &out) const {}
|
||||
|
||||
#endif
|
||||
|
|
|
@ -532,7 +532,7 @@ double FloatingLiteral::getValueAsApproximateDouble() const {
|
|||
return V.convertToDouble();
|
||||
}
|
||||
|
||||
StringLiteral *StringLiteral::Create(ASTContext &C, llvm::StringRef Str,
|
||||
StringLiteral *StringLiteral::Create(ASTContext &C, StringRef Str,
|
||||
bool Wide,
|
||||
bool Pascal, QualType Ty,
|
||||
const SourceLocation *Loc,
|
||||
|
@ -570,7 +570,7 @@ StringLiteral *StringLiteral::CreateEmpty(ASTContext &C, unsigned NumStrs) {
|
|||
return SL;
|
||||
}
|
||||
|
||||
void StringLiteral::setString(ASTContext &C, llvm::StringRef Str) {
|
||||
void StringLiteral::setString(ASTContext &C, StringRef Str) {
|
||||
char *AStrData = new (C, 1) char[Str.size()];
|
||||
memcpy(AStrData, Str.data(), Str.size());
|
||||
StrData = AStrData;
|
||||
|
@ -604,7 +604,7 @@ getLocationOfByte(unsigned ByteNo, const SourceManager &SM,
|
|||
// Re-lex the token to get its length and original spelling.
|
||||
std::pair<FileID, unsigned> LocInfo =SM.getDecomposedLoc(StrTokSpellingLoc);
|
||||
bool Invalid = false;
|
||||
llvm::StringRef Buffer = SM.getBufferData(LocInfo.first, &Invalid);
|
||||
StringRef Buffer = SM.getBufferData(LocInfo.first, &Invalid);
|
||||
if (Invalid)
|
||||
return StrTokSpellingLoc;
|
||||
|
||||
|
@ -2397,7 +2397,7 @@ bool Expr::isConstantInitializer(ASTContext &Ctx, bool IsForRef) const {
|
|||
break;
|
||||
|
||||
case MaterializeTemporaryExprClass:
|
||||
return llvm::cast<MaterializeTemporaryExpr>(this)->GetTemporaryExpr()
|
||||
return cast<MaterializeTemporaryExpr>(this)->GetTemporaryExpr()
|
||||
->isConstantInitializer(Ctx, false);
|
||||
}
|
||||
return isEvaluatable(Ctx);
|
||||
|
@ -2576,7 +2576,7 @@ unsigned ExtVectorElementExpr::getNumElements() const {
|
|||
bool ExtVectorElementExpr::containsDuplicateElements() const {
|
||||
// FIXME: Refactor this code to an accessor on the AST node which returns the
|
||||
// "type" of component access, and share with code below and in Sema.
|
||||
llvm::StringRef Comp = Accessor->getName();
|
||||
StringRef Comp = Accessor->getName();
|
||||
|
||||
// Halving swizzles do not contain duplicate elements.
|
||||
if (Comp == "hi" || Comp == "lo" || Comp == "even" || Comp == "odd")
|
||||
|
@ -2587,7 +2587,7 @@ bool ExtVectorElementExpr::containsDuplicateElements() const {
|
|||
Comp = Comp.substr(1);
|
||||
|
||||
for (unsigned i = 0, e = Comp.size(); i != e; ++i)
|
||||
if (Comp.substr(i + 1).find(Comp[i]) != llvm::StringRef::npos)
|
||||
if (Comp.substr(i + 1).find(Comp[i]) != StringRef::npos)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
|
@ -2595,8 +2595,8 @@ bool ExtVectorElementExpr::containsDuplicateElements() const {
|
|||
|
||||
/// getEncodedElementAccess - We encode the fields as a llvm ConstantArray.
|
||||
void ExtVectorElementExpr::getEncodedElementAccess(
|
||||
llvm::SmallVectorImpl<unsigned> &Elts) const {
|
||||
llvm::StringRef Comp = Accessor->getName();
|
||||
SmallVectorImpl<unsigned> &Elts) const {
|
||||
StringRef Comp = Accessor->getName();
|
||||
if (Comp[0] == 's' || Comp[0] == 'S')
|
||||
Comp = Comp.substr(1);
|
||||
|
||||
|
@ -2830,7 +2830,7 @@ ObjCInterfaceDecl *ObjCMessageExpr::getReceiverInterface() const {
|
|||
return 0;
|
||||
}
|
||||
|
||||
llvm::StringRef ObjCBridgedCastExpr::getBridgeKindName() const {
|
||||
StringRef ObjCBridgedCastExpr::getBridgeKindName() const {
|
||||
switch (getBridgeKind()) {
|
||||
case OBC_Bridge:
|
||||
return "__bridge";
|
||||
|
|
|
@ -812,7 +812,7 @@ APValue VectorExprEvaluator::VisitCastExpr(const CastExpr* E) {
|
|||
}
|
||||
|
||||
// Splat and create vector APValue.
|
||||
llvm::SmallVector<APValue, 4> Elts(NElts, Result);
|
||||
SmallVector<APValue, 4> Elts(NElts, Result);
|
||||
return APValue(&Elts[0], Elts.size());
|
||||
}
|
||||
case CK_BitCast: {
|
||||
|
@ -829,7 +829,7 @@ APValue VectorExprEvaluator::VisitCastExpr(const CastExpr* E) {
|
|||
assert((EltTy->isIntegerType() || EltTy->isRealFloatingType()) &&
|
||||
"Vectors must be composed of ints or floats");
|
||||
|
||||
llvm::SmallVector<APValue, 4> Elts;
|
||||
SmallVector<APValue, 4> Elts;
|
||||
for (unsigned i = 0; i != NElts; ++i) {
|
||||
APSInt Tmp = Init.extOrTrunc(EltWidth);
|
||||
|
||||
|
@ -862,7 +862,7 @@ VectorExprEvaluator::VisitInitListExpr(const InitListExpr *E) {
|
|||
unsigned NumElements = VT->getNumElements();
|
||||
|
||||
QualType EltTy = VT->getElementType();
|
||||
llvm::SmallVector<APValue, 4> Elements;
|
||||
SmallVector<APValue, 4> Elements;
|
||||
|
||||
// If a vector is initialized with a single element, that value
|
||||
// becomes every element of the vector, not just the first.
|
||||
|
@ -926,7 +926,7 @@ VectorExprEvaluator::GetZeroVector(QualType T) {
|
|||
ZeroElement =
|
||||
APValue(APFloat::getZero(Info.Ctx.getFloatTypeSemantics(EltTy)));
|
||||
|
||||
llvm::SmallVector<APValue, 4> Elements(VT->getNumElements(), ZeroElement);
|
||||
SmallVector<APValue, 4> Elements(VT->getNumElements(), ZeroElement);
|
||||
return APValue(&Elements[0], Elements.size());
|
||||
}
|
||||
|
||||
|
@ -1300,9 +1300,9 @@ bool IntExprEvaluator::VisitCallExpr(const CallExpr *E) {
|
|||
= dyn_cast<StringLiteral>(E->getArg(0)->IgnoreParenImpCasts())) {
|
||||
// The string literal may have embedded null characters. Find the first
|
||||
// one and truncate there.
|
||||
llvm::StringRef Str = S->getString();
|
||||
llvm::StringRef::size_type Pos = Str.find(0);
|
||||
if (Pos != llvm::StringRef::npos)
|
||||
StringRef Str = S->getString();
|
||||
StringRef::size_type Pos = Str.find(0);
|
||||
if (Pos != StringRef::npos)
|
||||
Str = Str.substr(0, Pos);
|
||||
|
||||
return Success(Str.size(), E);
|
||||
|
|
|
@ -54,7 +54,7 @@ void ExternalASTSource::MaterializeVisibleDecls(const DeclContext *DC) { }
|
|||
ExternalLoadResult
|
||||
ExternalASTSource::FindExternalLexicalDecls(const DeclContext *DC,
|
||||
bool (*isKindWeWant)(Decl::Kind),
|
||||
llvm::SmallVectorImpl<Decl*> &Result) {
|
||||
SmallVectorImpl<Decl*> &Result) {
|
||||
return ELR_AlreadyLoaded;
|
||||
}
|
||||
|
||||
|
|
|
@ -33,12 +33,12 @@ namespace clang {
|
|||
/// vs. non-virtual bases.
|
||||
class InheritanceHierarchyWriter {
|
||||
ASTContext& Context;
|
||||
llvm::raw_ostream &Out;
|
||||
raw_ostream &Out;
|
||||
std::map<QualType, int, QualTypeOrdering> DirectBaseCount;
|
||||
std::set<QualType, QualTypeOrdering> KnownVirtualBases;
|
||||
|
||||
public:
|
||||
InheritanceHierarchyWriter(ASTContext& Context, llvm::raw_ostream& Out)
|
||||
InheritanceHierarchyWriter(ASTContext& Context, raw_ostream& Out)
|
||||
: Context(Context), Out(Out) { }
|
||||
|
||||
void WriteGraph(QualType Type) {
|
||||
|
@ -55,7 +55,7 @@ protected:
|
|||
/// WriteNodeReference - Write out a reference to the given node,
|
||||
/// using a unique identifier for each direct base and for the
|
||||
/// (only) virtual base.
|
||||
llvm::raw_ostream& WriteNodeReference(QualType Type, bool FromVirtual);
|
||||
raw_ostream& WriteNodeReference(QualType Type, bool FromVirtual);
|
||||
};
|
||||
|
||||
void InheritanceHierarchyWriter::WriteNode(QualType Type, bool FromVirtual) {
|
||||
|
@ -120,7 +120,7 @@ void InheritanceHierarchyWriter::WriteNode(QualType Type, bool FromVirtual) {
|
|||
/// WriteNodeReference - Write out a reference to the given node,
|
||||
/// using a unique identifier for each direct base and for the
|
||||
/// (only) virtual base.
|
||||
llvm::raw_ostream&
|
||||
raw_ostream&
|
||||
InheritanceHierarchyWriter::WriteNodeReference(QualType Type,
|
||||
bool FromVirtual) {
|
||||
QualType CanonType = Context.getCanonicalType(Type);
|
||||
|
|
|
@ -92,30 +92,30 @@ public:
|
|||
/// @{
|
||||
|
||||
bool shouldMangleDeclName(const NamedDecl *D);
|
||||
void mangleName(const NamedDecl *D, llvm::raw_ostream &);
|
||||
void mangleName(const NamedDecl *D, raw_ostream &);
|
||||
void mangleThunk(const CXXMethodDecl *MD,
|
||||
const ThunkInfo &Thunk,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleCXXDtorThunk(const CXXDestructorDecl *DD, CXXDtorType Type,
|
||||
const ThisAdjustment &ThisAdjustment,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleReferenceTemporary(const VarDecl *D,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleCXXVTable(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleCXXVTT(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleCXXCtorVTable(const CXXRecordDecl *RD, int64_t Offset,
|
||||
const CXXRecordDecl *Type,
|
||||
llvm::raw_ostream &);
|
||||
void mangleCXXRTTI(QualType T, llvm::raw_ostream &);
|
||||
void mangleCXXRTTIName(QualType T, llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleCXXRTTI(QualType T, raw_ostream &);
|
||||
void mangleCXXRTTIName(QualType T, raw_ostream &);
|
||||
void mangleCXXCtor(const CXXConstructorDecl *D, CXXCtorType Type,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
void mangleCXXDtor(const CXXDestructorDecl *D, CXXDtorType Type,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
|
||||
void mangleItaniumGuardVariable(const VarDecl *D, llvm::raw_ostream &);
|
||||
void mangleItaniumGuardVariable(const VarDecl *D, raw_ostream &);
|
||||
|
||||
void mangleInitDiscriminator() {
|
||||
Discriminator = 0;
|
||||
|
@ -136,7 +136,7 @@ public:
|
|||
/// CXXNameMangler - Manage the mangling of a single name.
|
||||
class CXXNameMangler {
|
||||
ItaniumMangleContext &Context;
|
||||
llvm::raw_ostream &Out;
|
||||
raw_ostream &Out;
|
||||
|
||||
/// The "structor" is the top-level declaration being mangled, if
|
||||
/// that's not a template specialization; otherwise it's the pattern
|
||||
|
@ -191,7 +191,7 @@ class CXXNameMangler {
|
|||
ASTContext &getASTContext() const { return Context.getASTContext(); }
|
||||
|
||||
public:
|
||||
CXXNameMangler(ItaniumMangleContext &C, llvm::raw_ostream &Out_,
|
||||
CXXNameMangler(ItaniumMangleContext &C, raw_ostream &Out_,
|
||||
const NamedDecl *D = 0)
|
||||
: Context(C), Out(Out_), Structor(getStructor(D)), StructorType(0),
|
||||
SeqID(0) {
|
||||
|
@ -199,11 +199,11 @@ public:
|
|||
assert(!D || (!isa<CXXDestructorDecl>(D) &&
|
||||
!isa<CXXConstructorDecl>(D)));
|
||||
}
|
||||
CXXNameMangler(ItaniumMangleContext &C, llvm::raw_ostream &Out_,
|
||||
CXXNameMangler(ItaniumMangleContext &C, raw_ostream &Out_,
|
||||
const CXXConstructorDecl *D, CXXCtorType Type)
|
||||
: Context(C), Out(Out_), Structor(getStructor(D)), StructorType(Type),
|
||||
SeqID(0) { }
|
||||
CXXNameMangler(ItaniumMangleContext &C, llvm::raw_ostream &Out_,
|
||||
CXXNameMangler(ItaniumMangleContext &C, raw_ostream &Out_,
|
||||
const CXXDestructorDecl *D, CXXDtorType Type)
|
||||
: Context(C), Out(Out_), Structor(getStructor(D)), StructorType(Type),
|
||||
SeqID(0) { }
|
||||
|
@ -219,9 +219,9 @@ public:
|
|||
free(result);
|
||||
}
|
||||
#endif
|
||||
llvm::raw_ostream &getStream() { return Out; }
|
||||
raw_ostream &getStream() { return Out; }
|
||||
|
||||
void mangle(const NamedDecl *D, llvm::StringRef Prefix = "_Z");
|
||||
void mangle(const NamedDecl *D, StringRef Prefix = "_Z");
|
||||
void mangleCallOffset(int64_t NonVirtual, int64_t Virtual);
|
||||
void mangleNumber(const llvm::APSInt &I);
|
||||
void mangleNumber(int64_t Number);
|
||||
|
@ -385,7 +385,7 @@ bool ItaniumMangleContext::shouldMangleDeclName(const NamedDecl *D) {
|
|||
return true;
|
||||
}
|
||||
|
||||
void CXXNameMangler::mangle(const NamedDecl *D, llvm::StringRef Prefix) {
|
||||
void CXXNameMangler::mangle(const NamedDecl *D, StringRef Prefix) {
|
||||
// Any decl can be declared with __asm("foo") on it, and this takes precedence
|
||||
// over all other naming in the .o file.
|
||||
if (const AsmLabelAttr *ALA = D->getAttr<AsmLabelAttr>()) {
|
||||
|
@ -397,7 +397,7 @@ void CXXNameMangler::mangle(const NamedDecl *D, llvm::StringRef Prefix) {
|
|||
// llvm mangler on ELF is a nop, so we can just avoid adding the \01
|
||||
// marker. We also avoid adding the marker if this is an alias for an
|
||||
// LLVM intrinsic.
|
||||
llvm::StringRef UserLabelPrefix =
|
||||
StringRef UserLabelPrefix =
|
||||
getASTContext().Target.getUserLabelPrefix();
|
||||
if (!UserLabelPrefix.empty() && !ALA->getLabel().startswith("llvm."))
|
||||
Out << '\01'; // LLVM IR Marker for __asm("foo")
|
||||
|
@ -1538,7 +1538,7 @@ void CXXNameMangler::mangleQualifiers(Qualifiers Quals) {
|
|||
Out << 'U' << ASString.size() << ASString;
|
||||
}
|
||||
|
||||
llvm::StringRef LifetimeName;
|
||||
StringRef LifetimeName;
|
||||
switch (Quals.getObjCLifetime()) {
|
||||
// Objective-C ARC Extension:
|
||||
//
|
||||
|
@ -2526,7 +2526,7 @@ recurse:
|
|||
case Expr::ObjCBridgedCastExprClass: {
|
||||
// Mangle ownership casts as a vendor extended operator __bridge,
|
||||
// __bridge_transfer, or __bridge_retain.
|
||||
llvm::StringRef Kind = cast<ObjCBridgedCastExpr>(E)->getBridgeKindName();
|
||||
StringRef Kind = cast<ObjCBridgedCastExpr>(E)->getBridgeKindName();
|
||||
Out << "v1U" << Kind.size() << Kind;
|
||||
}
|
||||
// Fall through to mangle the cast itself.
|
||||
|
@ -3021,7 +3021,7 @@ bool CXXNameMangler::mangleSubstitution(uintptr_t Ptr) {
|
|||
}
|
||||
|
||||
Out << 'S'
|
||||
<< llvm::StringRef(BufferPtr, llvm::array_endof(Buffer)-BufferPtr)
|
||||
<< StringRef(BufferPtr, llvm::array_endof(Buffer)-BufferPtr)
|
||||
<< '_';
|
||||
}
|
||||
|
||||
|
@ -3196,7 +3196,7 @@ void CXXNameMangler::addSubstitution(uintptr_t Ptr) {
|
|||
/// emit the identifier of the declaration (\c D->getIdentifier()) as its
|
||||
/// name.
|
||||
void ItaniumMangleContext::mangleName(const NamedDecl *D,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
assert((isa<FunctionDecl>(D) || isa<VarDecl>(D)) &&
|
||||
"Invalid mangleName() call, argument is not a variable or function!");
|
||||
assert(!isa<CXXConstructorDecl>(D) && !isa<CXXDestructorDecl>(D) &&
|
||||
|
@ -3212,21 +3212,21 @@ void ItaniumMangleContext::mangleName(const NamedDecl *D,
|
|||
|
||||
void ItaniumMangleContext::mangleCXXCtor(const CXXConstructorDecl *D,
|
||||
CXXCtorType Type,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
CXXNameMangler Mangler(*this, Out, D, Type);
|
||||
Mangler.mangle(D);
|
||||
}
|
||||
|
||||
void ItaniumMangleContext::mangleCXXDtor(const CXXDestructorDecl *D,
|
||||
CXXDtorType Type,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
CXXNameMangler Mangler(*this, Out, D, Type);
|
||||
Mangler.mangle(D);
|
||||
}
|
||||
|
||||
void ItaniumMangleContext::mangleThunk(const CXXMethodDecl *MD,
|
||||
const ThunkInfo &Thunk,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= T <call-offset> <base encoding>
|
||||
// # base is the nominal target function of thunk
|
||||
// <special-name> ::= Tc <call-offset> <call-offset> <base encoding>
|
||||
|
@ -3256,7 +3256,7 @@ void
|
|||
ItaniumMangleContext::mangleCXXDtorThunk(const CXXDestructorDecl *DD,
|
||||
CXXDtorType Type,
|
||||
const ThisAdjustment &ThisAdjustment,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= T <call-offset> <base encoding>
|
||||
// # base is the nominal target function of thunk
|
||||
CXXNameMangler Mangler(*this, Out, DD, Type);
|
||||
|
@ -3272,7 +3272,7 @@ ItaniumMangleContext::mangleCXXDtorThunk(const CXXDestructorDecl *DD,
|
|||
/// mangleGuardVariable - Returns the mangled name for a guard variable
|
||||
/// for the passed in VarDecl.
|
||||
void ItaniumMangleContext::mangleItaniumGuardVariable(const VarDecl *D,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= GV <object name> # Guard variable for one-time
|
||||
// # initialization
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
|
@ -3281,7 +3281,7 @@ void ItaniumMangleContext::mangleItaniumGuardVariable(const VarDecl *D,
|
|||
}
|
||||
|
||||
void ItaniumMangleContext::mangleReferenceTemporary(const VarDecl *D,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// We match the GCC mangling here.
|
||||
// <special-name> ::= GR <object name>
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
|
@ -3290,7 +3290,7 @@ void ItaniumMangleContext::mangleReferenceTemporary(const VarDecl *D,
|
|||
}
|
||||
|
||||
void ItaniumMangleContext::mangleCXXVTable(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= TV <type> # virtual table
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
Mangler.getStream() << "_ZTV";
|
||||
|
@ -3298,7 +3298,7 @@ void ItaniumMangleContext::mangleCXXVTable(const CXXRecordDecl *RD,
|
|||
}
|
||||
|
||||
void ItaniumMangleContext::mangleCXXVTT(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= TT <type> # VTT structure
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
Mangler.getStream() << "_ZTT";
|
||||
|
@ -3308,7 +3308,7 @@ void ItaniumMangleContext::mangleCXXVTT(const CXXRecordDecl *RD,
|
|||
void ItaniumMangleContext::mangleCXXCtorVTable(const CXXRecordDecl *RD,
|
||||
int64_t Offset,
|
||||
const CXXRecordDecl *Type,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= TC <type> <offset number> _ <base type>
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
Mangler.getStream() << "_ZTC";
|
||||
|
@ -3319,7 +3319,7 @@ void ItaniumMangleContext::mangleCXXCtorVTable(const CXXRecordDecl *RD,
|
|||
}
|
||||
|
||||
void ItaniumMangleContext::mangleCXXRTTI(QualType Ty,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= TI <type> # typeinfo structure
|
||||
assert(!Ty.hasQualifiers() && "RTTI info cannot have top-level qualifiers");
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
|
@ -3328,7 +3328,7 @@ void ItaniumMangleContext::mangleCXXRTTI(QualType Ty,
|
|||
}
|
||||
|
||||
void ItaniumMangleContext::mangleCXXRTTIName(QualType Ty,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
// <special-name> ::= TS <type> # typeinfo name (null terminated byte string)
|
||||
CXXNameMangler Mangler(*this, Out);
|
||||
Mangler.getStream() << "_ZTS";
|
||||
|
|
|
@ -37,9 +37,9 @@ using namespace clang;
|
|||
namespace {
|
||||
|
||||
static void mangleFunctionBlock(MangleContext &Context,
|
||||
llvm::StringRef Outer,
|
||||
StringRef Outer,
|
||||
const BlockDecl *BD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
Out << "__" << Outer << "_block_invoke_" << Context.getBlockId(BD, true);
|
||||
}
|
||||
|
||||
|
@ -60,13 +60,13 @@ static void checkMangleDC(const DeclContext *DC, const BlockDecl *BD) {
|
|||
}
|
||||
|
||||
void MangleContext::mangleGlobalBlock(const BlockDecl *BD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
Out << "__block_global_" << getBlockId(BD, false);
|
||||
}
|
||||
|
||||
void MangleContext::mangleCtorBlock(const CXXConstructorDecl *CD,
|
||||
CXXCtorType CT, const BlockDecl *BD,
|
||||
llvm::raw_ostream &ResStream) {
|
||||
raw_ostream &ResStream) {
|
||||
checkMangleDC(CD, BD);
|
||||
llvm::SmallString<64> Buffer;
|
||||
llvm::raw_svector_ostream Out(Buffer);
|
||||
|
@ -77,7 +77,7 @@ void MangleContext::mangleCtorBlock(const CXXConstructorDecl *CD,
|
|||
|
||||
void MangleContext::mangleDtorBlock(const CXXDestructorDecl *DD,
|
||||
CXXDtorType DT, const BlockDecl *BD,
|
||||
llvm::raw_ostream &ResStream) {
|
||||
raw_ostream &ResStream) {
|
||||
checkMangleDC(DD, BD);
|
||||
llvm::SmallString<64> Buffer;
|
||||
llvm::raw_svector_ostream Out(Buffer);
|
||||
|
@ -87,7 +87,7 @@ void MangleContext::mangleDtorBlock(const CXXDestructorDecl *DD,
|
|||
}
|
||||
|
||||
void MangleContext::mangleBlock(const DeclContext *DC, const BlockDecl *BD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
assert(!isa<CXXConstructorDecl>(DC) && !isa<CXXDestructorDecl>(DC));
|
||||
checkMangleDC(DC, BD);
|
||||
|
||||
|
@ -113,7 +113,7 @@ void MangleContext::mangleBlock(const DeclContext *DC, const BlockDecl *BD,
|
|||
}
|
||||
|
||||
void MangleContext::mangleObjCMethodName(const ObjCMethodDecl *MD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
llvm::SmallString<64> Name;
|
||||
llvm::raw_svector_ostream OS(Name);
|
||||
|
||||
|
@ -129,7 +129,7 @@ void MangleContext::mangleObjCMethodName(const ObjCMethodDecl *MD,
|
|||
}
|
||||
|
||||
void MangleContext::mangleBlock(const BlockDecl *BD,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
const DeclContext *DC = BD->getDeclContext();
|
||||
while (isa<BlockDecl>(DC) || isa<EnumDecl>(DC))
|
||||
DC = DC->getParent();
|
||||
|
|
|
@ -29,15 +29,15 @@ namespace {
|
|||
/// Microsoft Visual C++ ABI.
|
||||
class MicrosoftCXXNameMangler {
|
||||
MangleContext &Context;
|
||||
llvm::raw_ostream &Out;
|
||||
raw_ostream &Out;
|
||||
|
||||
ASTContext &getASTContext() const { return Context.getASTContext(); }
|
||||
|
||||
public:
|
||||
MicrosoftCXXNameMangler(MangleContext &C, llvm::raw_ostream &Out_)
|
||||
MicrosoftCXXNameMangler(MangleContext &C, raw_ostream &Out_)
|
||||
: Context(C), Out(Out_) { }
|
||||
|
||||
void mangle(const NamedDecl *D, llvm::StringRef Prefix = "?");
|
||||
void mangle(const NamedDecl *D, StringRef Prefix = "?");
|
||||
void mangleName(const NamedDecl *ND);
|
||||
void mangleFunctionEncoding(const FunctionDecl *FD);
|
||||
void mangleVariableEncoding(const VarDecl *VD);
|
||||
|
@ -80,28 +80,28 @@ public:
|
|||
MicrosoftMangleContext(ASTContext &Context,
|
||||
Diagnostic &Diags) : MangleContext(Context, Diags) { }
|
||||
virtual bool shouldMangleDeclName(const NamedDecl *D);
|
||||
virtual void mangleName(const NamedDecl *D, llvm::raw_ostream &Out);
|
||||
virtual void mangleName(const NamedDecl *D, raw_ostream &Out);
|
||||
virtual void mangleThunk(const CXXMethodDecl *MD,
|
||||
const ThunkInfo &Thunk,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleCXXDtorThunk(const CXXDestructorDecl *DD, CXXDtorType Type,
|
||||
const ThisAdjustment &ThisAdjustment,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleCXXVTable(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleCXXVTT(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleCXXCtorVTable(const CXXRecordDecl *RD, int64_t Offset,
|
||||
const CXXRecordDecl *Type,
|
||||
llvm::raw_ostream &);
|
||||
virtual void mangleCXXRTTI(QualType T, llvm::raw_ostream &);
|
||||
virtual void mangleCXXRTTIName(QualType T, llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleCXXRTTI(QualType T, raw_ostream &);
|
||||
virtual void mangleCXXRTTIName(QualType T, raw_ostream &);
|
||||
virtual void mangleCXXCtor(const CXXConstructorDecl *D, CXXCtorType Type,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleCXXDtor(const CXXDestructorDecl *D, CXXDtorType Type,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
virtual void mangleReferenceTemporary(const clang::VarDecl *,
|
||||
llvm::raw_ostream &);
|
||||
raw_ostream &);
|
||||
};
|
||||
|
||||
}
|
||||
|
@ -154,7 +154,7 @@ bool MicrosoftMangleContext::shouldMangleDeclName(const NamedDecl *D) {
|
|||
}
|
||||
|
||||
void MicrosoftCXXNameMangler::mangle(const NamedDecl *D,
|
||||
llvm::StringRef Prefix) {
|
||||
StringRef Prefix) {
|
||||
// MSVC doesn't mangle C++ names the same way it mangles extern "C" names.
|
||||
// Therefore it's really important that we don't decorate the
|
||||
// name with leading underscores or leading/trailing at signs. So, emit a
|
||||
|
@ -954,7 +954,7 @@ void MicrosoftCXXNameMangler::mangleType(const IncompleteArrayType *T) {
|
|||
mangleType(static_cast<const ArrayType *>(T), false);
|
||||
}
|
||||
void MicrosoftCXXNameMangler::mangleExtraDimensions(QualType ElementTy) {
|
||||
llvm::SmallVector<llvm::APInt, 3> Dimensions;
|
||||
SmallVector<llvm::APInt, 3> Dimensions;
|
||||
for (;;) {
|
||||
if (ElementTy->isConstantArrayType()) {
|
||||
const ConstantArrayType *CAT =
|
||||
|
@ -1122,7 +1122,7 @@ void MicrosoftCXXNameMangler::mangleType(const AutoType *T) {
|
|||
}
|
||||
|
||||
void MicrosoftMangleContext::mangleName(const NamedDecl *D,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
assert((isa<FunctionDecl>(D) || isa<VarDecl>(D)) &&
|
||||
"Invalid mangleName() call, argument is not a variable or function!");
|
||||
assert(!isa<CXXConstructorDecl>(D) && !isa<CXXDestructorDecl>(D) &&
|
||||
|
@ -1137,49 +1137,49 @@ void MicrosoftMangleContext::mangleName(const NamedDecl *D,
|
|||
}
|
||||
void MicrosoftMangleContext::mangleThunk(const CXXMethodDecl *MD,
|
||||
const ThunkInfo &Thunk,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle thunks!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXDtorThunk(const CXXDestructorDecl *DD,
|
||||
CXXDtorType Type,
|
||||
const ThisAdjustment &,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle destructor thunks!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXVTable(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle virtual tables!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXVTT(const CXXRecordDecl *RD,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
llvm_unreachable("The MS C++ ABI does not have virtual table tables!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXCtorVTable(const CXXRecordDecl *RD,
|
||||
int64_t Offset,
|
||||
const CXXRecordDecl *Type,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
llvm_unreachable("The MS C++ ABI does not have constructor vtables!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXRTTI(QualType T,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle RTTI!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXRTTIName(QualType T,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle RTTI names!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXCtor(const CXXConstructorDecl *D,
|
||||
CXXCtorType Type,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle constructors!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleCXXDtor(const CXXDestructorDecl *D,
|
||||
CXXDtorType Type,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle destructors!");
|
||||
}
|
||||
void MicrosoftMangleContext::mangleReferenceTemporary(const clang::VarDecl *,
|
||||
llvm::raw_ostream &) {
|
||||
raw_ostream &) {
|
||||
assert(false && "Can't yet mangle reference temporaries!");
|
||||
}
|
||||
|
||||
|
|
|
@ -218,7 +218,7 @@ bool NestedNameSpecifier::containsUnexpandedParameterPack() const {
|
|||
/// \brief Print this nested name specifier to the given output
|
||||
/// stream.
|
||||
void
|
||||
NestedNameSpecifier::print(llvm::raw_ostream &OS,
|
||||
NestedNameSpecifier::print(raw_ostream &OS,
|
||||
const PrintingPolicy &Policy) const {
|
||||
if (getPrefix())
|
||||
getPrefix()->print(OS, Policy);
|
||||
|
@ -569,7 +569,7 @@ void NestedNameSpecifierLocBuilder::MakeTrivial(ASTContext &Context,
|
|||
// Construct bogus (but well-formed) source information for the
|
||||
// nested-name-specifier.
|
||||
BufferSize = 0;
|
||||
llvm::SmallVector<NestedNameSpecifier *, 4> Stack;
|
||||
SmallVector<NestedNameSpecifier *, 4> Stack;
|
||||
for (NestedNameSpecifier *NNS = Qualifier; NNS; NNS = NNS->getPrefix())
|
||||
Stack.push_back(NNS);
|
||||
while (!Stack.empty()) {
|
||||
|
|
|
@ -44,7 +44,7 @@ struct BaseSubobjectInfo {
|
|||
bool IsVirtual;
|
||||
|
||||
/// Bases - Information about the base subobjects.
|
||||
llvm::SmallVector<BaseSubobjectInfo*, 4> Bases;
|
||||
SmallVector<BaseSubobjectInfo*, 4> Bases;
|
||||
|
||||
/// PrimaryVirtualBaseInfo - Holds the base info for the primary virtual base
|
||||
/// of this base info (if one exists).
|
||||
|
@ -64,7 +64,7 @@ class EmptySubobjectMap {
|
|||
const CXXRecordDecl *Class;
|
||||
|
||||
/// EmptyClassOffsets - A map from offsets to empty record decls.
|
||||
typedef llvm::SmallVector<const CXXRecordDecl *, 1> ClassVectorTy;
|
||||
typedef SmallVector<const CXXRecordDecl *, 1> ClassVectorTy;
|
||||
typedef llvm::DenseMap<CharUnits, ClassVectorTy> EmptyClassOffsetsMapTy;
|
||||
EmptyClassOffsetsMapTy EmptyClassOffsets;
|
||||
|
||||
|
@ -556,7 +556,7 @@ protected:
|
|||
/// \brief The alignment if attribute packed is not used.
|
||||
CharUnits UnpackedAlignment;
|
||||
|
||||
llvm::SmallVector<uint64_t, 16> FieldOffsets;
|
||||
SmallVector<uint64_t, 16> FieldOffsets;
|
||||
|
||||
/// Packed - Whether the record is packed or not.
|
||||
unsigned Packed : 1;
|
||||
|
@ -1956,13 +1956,13 @@ ASTContext::getObjCLayout(const ObjCInterfaceDecl *D,
|
|||
return *NewEntry;
|
||||
}
|
||||
|
||||
static void PrintOffset(llvm::raw_ostream &OS,
|
||||
static void PrintOffset(raw_ostream &OS,
|
||||
CharUnits Offset, unsigned IndentLevel) {
|
||||
OS << llvm::format("%4d | ", Offset.getQuantity());
|
||||
OS.indent(IndentLevel * 2);
|
||||
}
|
||||
|
||||
static void DumpCXXRecordLayout(llvm::raw_ostream &OS,
|
||||
static void DumpCXXRecordLayout(raw_ostream &OS,
|
||||
const CXXRecordDecl *RD, const ASTContext &C,
|
||||
CharUnits Offset,
|
||||
unsigned IndentLevel,
|
||||
|
@ -2052,7 +2052,7 @@ static void DumpCXXRecordLayout(llvm::raw_ostream &OS,
|
|||
}
|
||||
|
||||
void ASTContext::DumpRecordLayout(const RecordDecl *RD,
|
||||
llvm::raw_ostream &OS) const {
|
||||
raw_ostream &OS) const {
|
||||
const ASTRecordLayout &Info = getASTRecordLayout(RD);
|
||||
|
||||
if (const CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(RD))
|
||||
|
|
|
@ -214,7 +214,7 @@ Expr *AsmStmt::getOutputExpr(unsigned i) {
|
|||
/// getOutputConstraint - Return the constraint string for the specified
|
||||
/// output operand. All output constraints are known to be non-empty (either
|
||||
/// '=' or '+').
|
||||
llvm::StringRef AsmStmt::getOutputConstraint(unsigned i) const {
|
||||
StringRef AsmStmt::getOutputConstraint(unsigned i) const {
|
||||
return getOutputConstraintLiteral(i)->getString();
|
||||
}
|
||||
|
||||
|
@ -238,7 +238,7 @@ void AsmStmt::setInputExpr(unsigned i, Expr *E) {
|
|||
|
||||
/// getInputConstraint - Return the specified input constraint. Unlike output
|
||||
/// constraints, these can be empty.
|
||||
llvm::StringRef AsmStmt::getInputConstraint(unsigned i) const {
|
||||
StringRef AsmStmt::getInputConstraint(unsigned i) const {
|
||||
return getInputConstraintLiteral(i)->getString();
|
||||
}
|
||||
|
||||
|
@ -277,7 +277,7 @@ void AsmStmt::setOutputsAndInputsAndClobbers(ASTContext &C,
|
|||
/// getNamedOperand - Given a symbolic operand reference like %[foo],
|
||||
/// translate this into a numeric value needed to reference the same operand.
|
||||
/// This returns -1 if the operand name is invalid.
|
||||
int AsmStmt::getNamedOperand(llvm::StringRef SymbolicName) const {
|
||||
int AsmStmt::getNamedOperand(StringRef SymbolicName) const {
|
||||
unsigned NumPlusOperands = 0;
|
||||
|
||||
// Check if this is an output operand.
|
||||
|
@ -297,9 +297,9 @@ int AsmStmt::getNamedOperand(llvm::StringRef SymbolicName) const {
|
|||
/// AnalyzeAsmString - Analyze the asm string of the current asm, decomposing
|
||||
/// it into pieces. If the asm string is erroneous, emit errors and return
|
||||
/// true, otherwise return false.
|
||||
unsigned AsmStmt::AnalyzeAsmString(llvm::SmallVectorImpl<AsmStringPiece>&Pieces,
|
||||
unsigned AsmStmt::AnalyzeAsmString(SmallVectorImpl<AsmStringPiece>&Pieces,
|
||||
ASTContext &C, unsigned &DiagOffs) const {
|
||||
llvm::StringRef Str = getAsmString()->getString();
|
||||
StringRef Str = getAsmString()->getString();
|
||||
const char *StrStart = Str.begin();
|
||||
const char *StrEnd = Str.end();
|
||||
const char *CurPtr = StrStart;
|
||||
|
@ -416,7 +416,7 @@ unsigned AsmStmt::AnalyzeAsmString(llvm::SmallVectorImpl<AsmStringPiece>&Pieces,
|
|||
if (NameEnd == CurPtr)
|
||||
return diag::err_asm_empty_symbolic_operand_name;
|
||||
|
||||
llvm::StringRef SymbolicName(CurPtr, NameEnd - CurPtr);
|
||||
StringRef SymbolicName(CurPtr, NameEnd - CurPtr);
|
||||
|
||||
int N = getNamedOperand(SymbolicName);
|
||||
if (N == -1) {
|
||||
|
|
|
@ -27,7 +27,7 @@ using namespace clang;
|
|||
namespace {
|
||||
class StmtDumper : public StmtVisitor<StmtDumper> {
|
||||
SourceManager *SM;
|
||||
llvm::raw_ostream &OS;
|
||||
raw_ostream &OS;
|
||||
unsigned IndentLevel;
|
||||
|
||||
/// MaxDepth - When doing a normal dump (not dumpAll) we only want to dump
|
||||
|
@ -41,7 +41,7 @@ namespace {
|
|||
unsigned LastLocLine;
|
||||
|
||||
public:
|
||||
StmtDumper(SourceManager *sm, llvm::raw_ostream &os, unsigned maxDepth)
|
||||
StmtDumper(SourceManager *sm, raw_ostream &os, unsigned maxDepth)
|
||||
: SM(sm), OS(os), IndentLevel(0-1), MaxDepth(maxDepth) {
|
||||
LastLocFilename = "";
|
||||
LastLocLine = ~0U;
|
||||
|
@ -333,7 +333,7 @@ void StmtDumper::VisitExpr(Expr *Node) {
|
|||
DumpExpr(Node);
|
||||
}
|
||||
|
||||
static void DumpBasePath(llvm::raw_ostream &OS, CastExpr *Node) {
|
||||
static void DumpBasePath(raw_ostream &OS, CastExpr *Node) {
|
||||
if (Node->path_empty())
|
||||
return;
|
||||
|
||||
|
@ -674,7 +674,7 @@ void Stmt::dump(SourceManager &SM) const {
|
|||
dump(llvm::errs(), SM);
|
||||
}
|
||||
|
||||
void Stmt::dump(llvm::raw_ostream &OS, SourceManager &SM) const {
|
||||
void Stmt::dump(raw_ostream &OS, SourceManager &SM) const {
|
||||
StmtDumper P(&SM, OS, 4);
|
||||
P.DumpSubTree(const_cast<Stmt*>(this));
|
||||
OS << "\n";
|
||||
|
|
|
@ -28,14 +28,14 @@ using namespace clang;
|
|||
|
||||
namespace {
|
||||
class StmtPrinter : public StmtVisitor<StmtPrinter> {
|
||||
llvm::raw_ostream &OS;
|
||||
raw_ostream &OS;
|
||||
ASTContext &Context;
|
||||
unsigned IndentLevel;
|
||||
clang::PrinterHelper* Helper;
|
||||
PrintingPolicy Policy;
|
||||
|
||||
public:
|
||||
StmtPrinter(llvm::raw_ostream &os, ASTContext &C, PrinterHelper* helper,
|
||||
StmtPrinter(raw_ostream &os, ASTContext &C, PrinterHelper* helper,
|
||||
const PrintingPolicy &Policy,
|
||||
unsigned Indentation = 0)
|
||||
: OS(os), Context(C), IndentLevel(Indentation), Helper(helper),
|
||||
|
@ -76,7 +76,7 @@ namespace {
|
|||
OS << "<null expr>";
|
||||
}
|
||||
|
||||
llvm::raw_ostream &Indent(int Delta = 0) {
|
||||
raw_ostream &Indent(int Delta = 0) {
|
||||
for (int i = 0, e = IndentLevel+Delta; i < e; ++i)
|
||||
OS << " ";
|
||||
return OS;
|
||||
|
@ -124,7 +124,7 @@ void StmtPrinter::PrintRawDecl(Decl *D) {
|
|||
|
||||
void StmtPrinter::PrintRawDeclStmt(DeclStmt *S) {
|
||||
DeclStmt::decl_iterator Begin = S->decl_begin(), End = S->decl_end();
|
||||
llvm::SmallVector<Decl*, 2> Decls;
|
||||
SmallVector<Decl*, 2> Decls;
|
||||
for ( ; Begin != End; ++Begin)
|
||||
Decls.push_back(*Begin);
|
||||
|
||||
|
@ -676,8 +676,8 @@ void StmtPrinter::VisitStringLiteral(StringLiteral *Str) {
|
|||
OS << '"';
|
||||
|
||||
// FIXME: this doesn't print wstrings right.
|
||||
llvm::StringRef StrData = Str->getString();
|
||||
for (llvm::StringRef::iterator I = StrData.begin(), E = StrData.end();
|
||||
StringRef StrData = Str->getString();
|
||||
for (StringRef::iterator I = StrData.begin(), E = StrData.end();
|
||||
I != E; ++I) {
|
||||
unsigned char Char = *I;
|
||||
|
||||
|
@ -1541,7 +1541,7 @@ void Stmt::dumpPretty(ASTContext& Context) const {
|
|||
PrintingPolicy(Context.getLangOptions()));
|
||||
}
|
||||
|
||||
void Stmt::printPretty(llvm::raw_ostream &OS, ASTContext& Context,
|
||||
void Stmt::printPretty(raw_ostream &OS, ASTContext& Context,
|
||||
PrinterHelper* Helper,
|
||||
const PrintingPolicy &Policy,
|
||||
unsigned Indentation) const {
|
||||
|
|
|
@ -33,7 +33,7 @@ using namespace clang;
|
|||
///
|
||||
/// \param Out the raw_ostream instance to use for printing.
|
||||
static void printIntegral(const TemplateArgument &TemplArg,
|
||||
llvm::raw_ostream &Out) {
|
||||
raw_ostream &Out) {
|
||||
const ::clang::Type *T = TemplArg.getIntegralType().getTypePtr();
|
||||
const llvm::APSInt *Val = TemplArg.getAsIntegral();
|
||||
|
||||
|
@ -309,7 +309,7 @@ TemplateArgument TemplateArgument::getPackExpansionPattern() const {
|
|||
}
|
||||
|
||||
void TemplateArgument::print(const PrintingPolicy &Policy,
|
||||
llvm::raw_ostream &Out) const {
|
||||
raw_ostream &Out) const {
|
||||
switch (getKind()) {
|
||||
case Null:
|
||||
Out << "<no value>";
|
||||
|
|
|
@ -125,7 +125,7 @@ bool TemplateName::containsUnexpandedParameterPack() const {
|
|||
}
|
||||
|
||||
void
|
||||
TemplateName::print(llvm::raw_ostream &OS, const PrintingPolicy &Policy,
|
||||
TemplateName::print(raw_ostream &OS, const PrintingPolicy &Policy,
|
||||
bool SuppressNNS) const {
|
||||
if (TemplateDecl *Template = Storage.dyn_cast<TemplateDecl *>())
|
||||
OS << Template;
|
||||
|
|
|
@ -1481,7 +1481,7 @@ QualType QualType::getNonLValueExprType(ASTContext &Context) const {
|
|||
return *this;
|
||||
}
|
||||
|
||||
llvm::StringRef FunctionType::getNameForCallConv(CallingConv CC) {
|
||||
StringRef FunctionType::getNameForCallConv(CallingConv CC) {
|
||||
switch (CC) {
|
||||
case CC_Default:
|
||||
llvm_unreachable("no name for default cc");
|
||||
|
|
|
@ -1333,7 +1333,7 @@ CFGBlock *CFGBuilder::VisitDeclStmt(DeclStmt *DS) {
|
|||
CFGBlock *B = 0;
|
||||
|
||||
// FIXME: Add a reverse iterator for DeclStmt to avoid this extra copy.
|
||||
typedef llvm::SmallVector<Decl*,10> BufTy;
|
||||
typedef SmallVector<Decl*,10> BufTy;
|
||||
BufTy Buf(DS->decl_begin(), DS->decl_end());
|
||||
|
||||
for (BufTy::reverse_iterator I = Buf.rbegin(), E = Buf.rend(); I != E; ++I) {
|
||||
|
@ -2776,7 +2776,7 @@ CFGBlock *CFGBuilder::VisitChildrenForTemporaryDtors(Stmt *E) {
|
|||
// When visiting children for destructors we want to visit them in reverse
|
||||
// order. Because there's no reverse iterator for children must to reverse
|
||||
// them in helper vector.
|
||||
typedef llvm::SmallVector<Stmt *, 4> ChildrenVect;
|
||||
typedef SmallVector<Stmt *, 4> ChildrenVect;
|
||||
ChildrenVect ChildrenRev;
|
||||
for (Stmt::child_range I = E->children(); I; ++I) {
|
||||
if (*I) ChildrenRev.push_back(*I);
|
||||
|
@ -3225,7 +3225,7 @@ public:
|
|||
void setBlockID(signed i) { currentBlock = i; }
|
||||
void setStmtID(unsigned i) { currentStmt = i; }
|
||||
|
||||
virtual bool handledStmt(Stmt* S, llvm::raw_ostream& OS) {
|
||||
virtual bool handledStmt(Stmt* S, raw_ostream& OS) {
|
||||
StmtMapTy::iterator I = StmtMap.find(S);
|
||||
|
||||
if (I == StmtMap.end())
|
||||
|
@ -3240,7 +3240,7 @@ public:
|
|||
return true;
|
||||
}
|
||||
|
||||
bool handleDecl(const Decl* D, llvm::raw_ostream& OS) {
|
||||
bool handleDecl(const Decl* D, raw_ostream& OS) {
|
||||
DeclMapTy::iterator I = DeclMap.find(D);
|
||||
|
||||
if (I == DeclMap.end())
|
||||
|
@ -3262,11 +3262,11 @@ namespace {
|
|||
class CFGBlockTerminatorPrint
|
||||
: public StmtVisitor<CFGBlockTerminatorPrint,void> {
|
||||
|
||||
llvm::raw_ostream& OS;
|
||||
raw_ostream& OS;
|
||||
StmtPrinterHelper* Helper;
|
||||
PrintingPolicy Policy;
|
||||
public:
|
||||
CFGBlockTerminatorPrint(llvm::raw_ostream& os, StmtPrinterHelper* helper,
|
||||
CFGBlockTerminatorPrint(raw_ostream& os, StmtPrinterHelper* helper,
|
||||
const PrintingPolicy &Policy)
|
||||
: OS(os), Helper(helper), Policy(Policy) {}
|
||||
|
||||
|
@ -3356,7 +3356,7 @@ public:
|
|||
};
|
||||
} // end anonymous namespace
|
||||
|
||||
static void print_elem(llvm::raw_ostream &OS, StmtPrinterHelper* Helper,
|
||||
static void print_elem(raw_ostream &OS, StmtPrinterHelper* Helper,
|
||||
const CFGElement &E) {
|
||||
if (const CFGStmt *CS = E.getAs<CFGStmt>()) {
|
||||
Stmt *S = CS->getStmt();
|
||||
|
@ -3447,7 +3447,7 @@ static void print_elem(llvm::raw_ostream &OS, StmtPrinterHelper* Helper,
|
|||
}
|
||||
}
|
||||
|
||||
static void print_block(llvm::raw_ostream& OS, const CFG* cfg,
|
||||
static void print_block(raw_ostream& OS, const CFG* cfg,
|
||||
const CFGBlock& B,
|
||||
StmtPrinterHelper* Helper, bool print_edges) {
|
||||
|
||||
|
@ -3573,7 +3573,7 @@ static void print_block(llvm::raw_ostream& OS, const CFG* cfg,
|
|||
void CFG::dump(const LangOptions &LO) const { print(llvm::errs(), LO); }
|
||||
|
||||
/// print - A simple pretty printer of a CFG that outputs to an ostream.
|
||||
void CFG::print(llvm::raw_ostream &OS, const LangOptions &LO) const {
|
||||
void CFG::print(raw_ostream &OS, const LangOptions &LO) const {
|
||||
StmtPrinterHelper Helper(this, LO);
|
||||
|
||||
// Print the entry block.
|
||||
|
@ -3600,14 +3600,14 @@ void CFGBlock::dump(const CFG* cfg, const LangOptions &LO) const {
|
|||
|
||||
/// print - A simple pretty printer of a CFGBlock that outputs to an ostream.
|
||||
/// Generally this will only be called from CFG::print.
|
||||
void CFGBlock::print(llvm::raw_ostream& OS, const CFG* cfg,
|
||||
void CFGBlock::print(raw_ostream& OS, const CFG* cfg,
|
||||
const LangOptions &LO) const {
|
||||
StmtPrinterHelper Helper(cfg, LO);
|
||||
print_block(OS, cfg, *this, &Helper, true);
|
||||
}
|
||||
|
||||
/// printTerminator - A simple pretty printer of the terminator of a CFGBlock.
|
||||
void CFGBlock::printTerminator(llvm::raw_ostream &OS,
|
||||
void CFGBlock::printTerminator(raw_ostream &OS,
|
||||
const LangOptions &LO) const {
|
||||
CFGBlockTerminatorPrint TPrinter(OS, NULL, PrintingPolicy(LO));
|
||||
TPrinter.Visit(const_cast<Stmt*>(getTerminator().getStmt()));
|
||||
|
|
|
@ -40,7 +40,7 @@ bool CFGReverseBlockReachabilityAnalysis::isReachable(const CFGBlock *Src,
|
|||
// Maps reachability to a common node by walking the predecessors of the
|
||||
// destination node.
|
||||
void CFGReverseBlockReachabilityAnalysis::mapReachability(const CFGBlock *Dst) {
|
||||
llvm::SmallVector<const CFGBlock *, 11> worklist;
|
||||
SmallVector<const CFGBlock *, 11> worklist;
|
||||
llvm::BitVector visited(analyzed.size());
|
||||
|
||||
ReachableSet &DstReachability = reachable[Dst->getBlockID()];
|
||||
|
|
|
@ -17,12 +17,9 @@
|
|||
#include "clang/AST/DeclObjC.h"
|
||||
#include "llvm/ADT/StringExtras.h"
|
||||
#include "llvm/Support/ErrorHandling.h"
|
||||
|
||||
using namespace clang;
|
||||
using namespace ento;
|
||||
|
||||
using llvm::StringRef;
|
||||
|
||||
// The "fundamental rule" for naming conventions of methods:
|
||||
// (url broken into two lines)
|
||||
// http://developer.apple.com/documentation/Cocoa/Conceptual/
|
||||
|
@ -63,11 +60,11 @@ cocoa::NamingConvention cocoa::deriveNamingConvention(Selector S,
|
|||
return NoConvention;
|
||||
}
|
||||
|
||||
bool cocoa::isRefType(QualType RetTy, llvm::StringRef Prefix,
|
||||
llvm::StringRef Name) {
|
||||
bool cocoa::isRefType(QualType RetTy, StringRef Prefix,
|
||||
StringRef Name) {
|
||||
// Recursively walk the typedef stack, allowing typedefs of reference types.
|
||||
while (const TypedefType *TD = dyn_cast<TypedefType>(RetTy.getTypePtr())) {
|
||||
llvm::StringRef TDName = TD->getDecl()->getIdentifier()->getName();
|
||||
StringRef TDName = TD->getDecl()->getIdentifier()->getName();
|
||||
if (TDName.startswith(Prefix) && TDName.endswith("Ref"))
|
||||
return true;
|
||||
|
||||
|
@ -127,10 +124,10 @@ bool cocoa::isCocoaObjectRef(QualType Ty) {
|
|||
return false;
|
||||
}
|
||||
|
||||
bool coreFoundation::followsCreateRule(llvm::StringRef functionName) {
|
||||
llvm::StringRef::iterator it = functionName.begin();
|
||||
llvm::StringRef::iterator start = it;
|
||||
llvm::StringRef::iterator endI = functionName.end();
|
||||
bool coreFoundation::followsCreateRule(StringRef functionName) {
|
||||
StringRef::iterator it = functionName.begin();
|
||||
StringRef::iterator start = it;
|
||||
StringRef::iterator endI = functionName.end();
|
||||
|
||||
while (true) {
|
||||
// Scan for the start of 'create' or 'copy'.
|
||||
|
@ -149,7 +146,7 @@ bool coreFoundation::followsCreateRule(llvm::StringRef functionName) {
|
|||
|
||||
// Scan for *lowercase* 'reate' or 'opy', followed by no lowercase
|
||||
// character.
|
||||
llvm::StringRef suffix = functionName.substr(it - start);
|
||||
StringRef suffix = functionName.substr(it - start);
|
||||
if (suffix.startswith("reate")) {
|
||||
it += 5;
|
||||
}
|
||||
|
|
|
@ -379,7 +379,7 @@ analyze_format_string::LengthModifier::toString() const {
|
|||
// Methods on OptionalAmount.
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
void OptionalAmount::toString(llvm::raw_ostream &os) const {
|
||||
void OptionalAmount::toString(raw_ostream &os) const {
|
||||
switch (hs) {
|
||||
case Invalid:
|
||||
case NotSpecified:
|
||||
|
|
|
@ -43,7 +43,7 @@ class RegisterDecls
|
|||
|
||||
LiveVariables::AnalysisDataTy& AD;
|
||||
|
||||
typedef llvm::SmallVector<VarDecl*, 20> AlwaysLiveTy;
|
||||
typedef SmallVector<VarDecl*, 20> AlwaysLiveTy;
|
||||
AlwaysLiveTy AlwaysLive;
|
||||
|
||||
|
||||
|
|
|
@ -469,7 +469,7 @@ bool PrintfSpecifier::fixType(QualType QT) {
|
|||
return true;
|
||||
}
|
||||
|
||||
void PrintfSpecifier::toString(llvm::raw_ostream &os) const {
|
||||
void PrintfSpecifier::toString(raw_ostream &os) const {
|
||||
// Whilst some features have no defined order, we are using the order
|
||||
// appearing in the C99 standard (ISO/IEC 9899:1999 (E) 7.19.6.1)
|
||||
os << "%";
|
||||
|
|
|
@ -125,7 +125,7 @@ static SourceLocation MarkLiveTop(const CFGBlock *Start,
|
|||
SourceManager &SM) {
|
||||
|
||||
// Prep work worklist.
|
||||
llvm::SmallVector<const CFGBlock*, 32> WL;
|
||||
SmallVector<const CFGBlock*, 32> WL;
|
||||
WL.push_back(Start);
|
||||
|
||||
SourceRange R1, R2;
|
||||
|
@ -197,7 +197,7 @@ namespace clang { namespace reachable_code {
|
|||
unsigned ScanReachableFromBlock(const CFGBlock &Start,
|
||||
llvm::BitVector &Reachable) {
|
||||
unsigned count = 0;
|
||||
llvm::SmallVector<const CFGBlock*, 32> WL;
|
||||
SmallVector<const CFGBlock*, 32> WL;
|
||||
|
||||
// Prep work queue
|
||||
Reachable.set(Start.getBlockID());
|
||||
|
@ -242,7 +242,7 @@ void FindUnreachableCode(AnalysisContext &AC, Callback &CB) {
|
|||
|
||||
SourceRange R1, R2;
|
||||
|
||||
llvm::SmallVector<ErrLoc, 24> lines;
|
||||
SmallVector<ErrLoc, 24> lines;
|
||||
bool AddEHEdges = AC.getAddEHEdges();
|
||||
|
||||
// First, give warnings for blocks with no predecessors, as they
|
||||
|
@ -287,7 +287,7 @@ void FindUnreachableCode(AnalysisContext &AC, Callback &CB) {
|
|||
|
||||
llvm::array_pod_sort(lines.begin(), lines.end(), LineCmp);
|
||||
|
||||
for (llvm::SmallVectorImpl<ErrLoc>::iterator I=lines.begin(), E=lines.end();
|
||||
for (SmallVectorImpl<ErrLoc>::iterator I=lines.begin(), E=lines.end();
|
||||
I != E; ++I)
|
||||
if (I->Loc.isValid())
|
||||
CB.HandleUnreachable(I->Loc, I->R1, I->R2);
|
||||
|
|
|
@ -178,7 +178,7 @@ static BinaryOperator *getLogicalOperatorInChain(const CFGBlock *block) {
|
|||
if (!cstmt)
|
||||
return 0;
|
||||
|
||||
BinaryOperator *b = llvm::dyn_cast_or_null<BinaryOperator>(cstmt->getStmt());
|
||||
BinaryOperator *b = dyn_cast_or_null<BinaryOperator>(cstmt->getStmt());
|
||||
|
||||
if (!b || !b->isLogicalOp())
|
||||
return 0;
|
||||
|
@ -283,7 +283,7 @@ ValueVector::reference CFGBlockValues::operator[](const VarDecl *vd) {
|
|||
|
||||
namespace {
|
||||
class DataflowWorklist {
|
||||
llvm::SmallVector<const CFGBlock *, 20> worklist;
|
||||
SmallVector<const CFGBlock *, 20> worklist;
|
||||
llvm::BitVector enqueuedBlocks;
|
||||
public:
|
||||
DataflowWorklist(const CFG &cfg) : enqueuedBlocks(cfg.getNumBlockIDs()) {}
|
||||
|
|
|
@ -59,7 +59,7 @@ void Builtin::Context::InitializeBuiltins(IdentifierTable &Table,
|
|||
}
|
||||
|
||||
void
|
||||
Builtin::Context::GetBuiltinNames(llvm::SmallVectorImpl<const char *> &Names,
|
||||
Builtin::Context::GetBuiltinNames(SmallVectorImpl<const char *> &Names,
|
||||
bool NoBuiltins) {
|
||||
// Final all target-independent names
|
||||
for (unsigned i = Builtin::NotBuiltin+1; i != Builtin::FirstTSBuiltin; ++i)
|
||||
|
|
|
@ -25,9 +25,9 @@ static void DummyArgToStringFn(Diagnostic::ArgumentKind AK, intptr_t QT,
|
|||
const char *Argument, unsigned ArgLen,
|
||||
const Diagnostic::ArgumentValue *PrevArgs,
|
||||
unsigned NumPrevArgs,
|
||||
llvm::SmallVectorImpl<char> &Output,
|
||||
SmallVectorImpl<char> &Output,
|
||||
void *Cookie,
|
||||
llvm::SmallVectorImpl<intptr_t> &QualTypeVals) {
|
||||
SmallVectorImpl<intptr_t> &QualTypeVals) {
|
||||
const char *Str = "<can't format argument>";
|
||||
Output.append(Str, Str+strlen(Str));
|
||||
}
|
||||
|
@ -112,8 +112,8 @@ void Diagnostic::Reset() {
|
|||
PushDiagStatePoint(&DiagStates.back(), SourceLocation());
|
||||
}
|
||||
|
||||
void Diagnostic::SetDelayedDiagnostic(unsigned DiagID, llvm::StringRef Arg1,
|
||||
llvm::StringRef Arg2) {
|
||||
void Diagnostic::SetDelayedDiagnostic(unsigned DiagID, StringRef Arg1,
|
||||
StringRef Arg2) {
|
||||
if (DelayedDiagID)
|
||||
return;
|
||||
|
||||
|
@ -339,7 +339,7 @@ static const char *ScanFormat(const char *I, const char *E, char Target) {
|
|||
/// This is very useful for certain classes of variant diagnostics.
|
||||
static void HandleSelectModifier(const DiagnosticInfo &DInfo, unsigned ValNo,
|
||||
const char *Argument, unsigned ArgumentLen,
|
||||
llvm::SmallVectorImpl<char> &OutStr) {
|
||||
SmallVectorImpl<char> &OutStr) {
|
||||
const char *ArgumentEnd = Argument+ArgumentLen;
|
||||
|
||||
// Skip over 'ValNo' |'s.
|
||||
|
@ -362,7 +362,7 @@ static void HandleSelectModifier(const DiagnosticInfo &DInfo, unsigned ValNo,
|
|||
/// letter 's' to the string if the value is not 1. This is used in cases like
|
||||
/// this: "you idiot, you have %4 parameter%s4!".
|
||||
static void HandleIntegerSModifier(unsigned ValNo,
|
||||
llvm::SmallVectorImpl<char> &OutStr) {
|
||||
SmallVectorImpl<char> &OutStr) {
|
||||
if (ValNo != 1)
|
||||
OutStr.push_back('s');
|
||||
}
|
||||
|
@ -372,7 +372,7 @@ static void HandleIntegerSModifier(unsigned ValNo,
|
|||
/// to the first ordinal. Currently this is hard-coded to use the
|
||||
/// English form.
|
||||
static void HandleOrdinalModifier(unsigned ValNo,
|
||||
llvm::SmallVectorImpl<char> &OutStr) {
|
||||
SmallVectorImpl<char> &OutStr) {
|
||||
assert(ValNo != 0 && "ValNo must be strictly positive!");
|
||||
|
||||
llvm::raw_svector_ostream Out(OutStr);
|
||||
|
@ -497,7 +497,7 @@ static bool EvalPluralExpr(unsigned ValNo, const char *Start, const char *End) {
|
|||
/// {1:form0|%100=[10,20]:form2|%10=[2,4]:form1|:form2}
|
||||
static void HandlePluralModifier(const DiagnosticInfo &DInfo, unsigned ValNo,
|
||||
const char *Argument, unsigned ArgumentLen,
|
||||
llvm::SmallVectorImpl<char> &OutStr) {
|
||||
SmallVectorImpl<char> &OutStr) {
|
||||
const char *ArgumentEnd = Argument + ArgumentLen;
|
||||
while (1) {
|
||||
assert(Argument < ArgumentEnd && "Plural expression didn't match.");
|
||||
|
@ -524,13 +524,13 @@ static void HandlePluralModifier(const DiagnosticInfo &DInfo, unsigned ValNo,
|
|||
/// formal arguments into the %0 slots. The result is appended onto the Str
|
||||
/// array.
|
||||
void DiagnosticInfo::
|
||||
FormatDiagnostic(llvm::SmallVectorImpl<char> &OutStr) const {
|
||||
FormatDiagnostic(SmallVectorImpl<char> &OutStr) const {
|
||||
if (!StoredDiagMessage.empty()) {
|
||||
OutStr.append(StoredDiagMessage.begin(), StoredDiagMessage.end());
|
||||
return;
|
||||
}
|
||||
|
||||
llvm::StringRef Diag =
|
||||
StringRef Diag =
|
||||
getDiags()->getDiagnosticIDs()->getDescription(getID());
|
||||
|
||||
FormatDiagnostic(Diag.begin(), Diag.end(), OutStr);
|
||||
|
@ -538,17 +538,17 @@ FormatDiagnostic(llvm::SmallVectorImpl<char> &OutStr) const {
|
|||
|
||||
void DiagnosticInfo::
|
||||
FormatDiagnostic(const char *DiagStr, const char *DiagEnd,
|
||||
llvm::SmallVectorImpl<char> &OutStr) const {
|
||||
SmallVectorImpl<char> &OutStr) const {
|
||||
|
||||
/// FormattedArgs - Keep track of all of the arguments formatted by
|
||||
/// ConvertArgToString and pass them into subsequent calls to
|
||||
/// ConvertArgToString, allowing the implementation to avoid redundancies in
|
||||
/// obvious cases.
|
||||
llvm::SmallVector<Diagnostic::ArgumentValue, 8> FormattedArgs;
|
||||
SmallVector<Diagnostic::ArgumentValue, 8> FormattedArgs;
|
||||
|
||||
/// QualTypeVals - Pass a vector of arrays so that QualType names can be
|
||||
/// compared to see if more information is needed to be printed.
|
||||
llvm::SmallVector<intptr_t, 2> QualTypeVals;
|
||||
SmallVector<intptr_t, 2> QualTypeVals;
|
||||
for (unsigned i = 0, e = getNumArgs(); i < e; ++i)
|
||||
if (getArgKind(i) == Diagnostic::ak_qualtype)
|
||||
QualTypeVals.push_back(getRawArg(i));
|
||||
|
@ -702,7 +702,7 @@ FormatDiagnostic(const char *DiagStr, const char *DiagEnd,
|
|||
StoredDiagnostic::StoredDiagnostic() { }
|
||||
|
||||
StoredDiagnostic::StoredDiagnostic(Diagnostic::Level Level, unsigned ID,
|
||||
llvm::StringRef Message)
|
||||
StringRef Message)
|
||||
: ID(ID), Level(Level), Loc(), Message(Message) { }
|
||||
|
||||
StoredDiagnostic::StoredDiagnostic(Diagnostic::Level Level,
|
||||
|
@ -727,7 +727,7 @@ StoredDiagnostic::StoredDiagnostic(Diagnostic::Level Level,
|
|||
}
|
||||
|
||||
StoredDiagnostic::StoredDiagnostic(Diagnostic::Level Level, unsigned ID,
|
||||
llvm::StringRef Message, FullSourceLoc Loc,
|
||||
StringRef Message, FullSourceLoc Loc,
|
||||
llvm::ArrayRef<CharSourceRange> Ranges,
|
||||
llvm::ArrayRef<FixItHint> Fixits)
|
||||
: ID(ID), Level(Level), Loc(Loc), Message(Message)
|
||||
|
|
|
@ -61,21 +61,21 @@ struct StaticDiagInfoRec {
|
|||
const char *BriefExplanationStr;
|
||||
const char *FullExplanationStr;
|
||||
|
||||
llvm::StringRef getName() const {
|
||||
return llvm::StringRef(NameStr, NameLen);
|
||||
StringRef getName() const {
|
||||
return StringRef(NameStr, NameLen);
|
||||
}
|
||||
llvm::StringRef getOptionGroup() const {
|
||||
return llvm::StringRef(OptionGroupStr, OptionGroupLen);
|
||||
StringRef getOptionGroup() const {
|
||||
return StringRef(OptionGroupStr, OptionGroupLen);
|
||||
}
|
||||
|
||||
llvm::StringRef getDescription() const {
|
||||
return llvm::StringRef(DescriptionStr, DescriptionLen);
|
||||
StringRef getDescription() const {
|
||||
return StringRef(DescriptionStr, DescriptionLen);
|
||||
}
|
||||
llvm::StringRef getBriefExplanation() const {
|
||||
return llvm::StringRef(BriefExplanationStr, BriefExplanationLen);
|
||||
StringRef getBriefExplanation() const {
|
||||
return StringRef(BriefExplanationStr, BriefExplanationLen);
|
||||
}
|
||||
llvm::StringRef getFullExplanation() const {
|
||||
return llvm::StringRef(FullExplanationStr, FullExplanationLen);
|
||||
StringRef getFullExplanation() const {
|
||||
return StringRef(FullExplanationStr, FullExplanationLen);
|
||||
}
|
||||
|
||||
bool operator<(const StaticDiagInfoRec &RHS) const {
|
||||
|
@ -88,8 +88,8 @@ struct StaticDiagNameIndexRec {
|
|||
unsigned short DiagID;
|
||||
uint8_t NameLen;
|
||||
|
||||
llvm::StringRef getName() const {
|
||||
return llvm::StringRef(NameStr, NameLen);
|
||||
StringRef getName() const {
|
||||
return StringRef(NameStr, NameLen);
|
||||
}
|
||||
|
||||
bool operator<(const StaticDiagNameIndexRec &RHS) const {
|
||||
|
@ -186,10 +186,10 @@ static unsigned GetDefaultDiagMapping(unsigned DiagID) {
|
|||
/// getWarningOptionForDiag - Return the lowest-level warning option that
|
||||
/// enables the specified diagnostic. If there is no -Wfoo flag that controls
|
||||
/// the diagnostic, this returns null.
|
||||
llvm::StringRef DiagnosticIDs::getWarningOptionForDiag(unsigned DiagID) {
|
||||
StringRef DiagnosticIDs::getWarningOptionForDiag(unsigned DiagID) {
|
||||
if (const StaticDiagInfoRec *Info = GetDiagInfo(DiagID))
|
||||
return Info->getOptionGroup();
|
||||
return llvm::StringRef();
|
||||
return StringRef();
|
||||
}
|
||||
|
||||
/// getCategoryNumberForDiag - Return the category number that a specified
|
||||
|
@ -206,8 +206,8 @@ namespace {
|
|||
const char *NameStr;
|
||||
uint8_t NameLen;
|
||||
|
||||
llvm::StringRef getName() const {
|
||||
return llvm::StringRef(NameStr, NameLen);
|
||||
StringRef getName() const {
|
||||
return StringRef(NameStr, NameLen);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
@ -228,9 +228,9 @@ unsigned DiagnosticIDs::getNumberOfCategories() {
|
|||
/// getCategoryNameFromID - Given a category ID, return the name of the
|
||||
/// category, an empty string if CategoryID is zero, or null if CategoryID is
|
||||
/// invalid.
|
||||
llvm::StringRef DiagnosticIDs::getCategoryNameFromID(unsigned CategoryID) {
|
||||
StringRef DiagnosticIDs::getCategoryNameFromID(unsigned CategoryID) {
|
||||
if (CategoryID >= getNumberOfCategories())
|
||||
return llvm::StringRef();
|
||||
return StringRef();
|
||||
return CategoryNameTable[CategoryID].getName();
|
||||
}
|
||||
|
||||
|
@ -256,14 +256,14 @@ DiagnosticIDs::getDiagnosticSFINAEResponse(unsigned DiagID) {
|
|||
}
|
||||
|
||||
/// getName - Given a diagnostic ID, return its name
|
||||
llvm::StringRef DiagnosticIDs::getName(unsigned DiagID) {
|
||||
StringRef DiagnosticIDs::getName(unsigned DiagID) {
|
||||
if (const StaticDiagInfoRec *Info = GetDiagInfo(DiagID))
|
||||
return Info->getName();
|
||||
return llvm::StringRef();
|
||||
return StringRef();
|
||||
}
|
||||
|
||||
/// getIdFromName - Given a diagnostic name, return its ID, or 0
|
||||
unsigned DiagnosticIDs::getIdFromName(llvm::StringRef Name) {
|
||||
unsigned DiagnosticIDs::getIdFromName(StringRef Name) {
|
||||
const StaticDiagNameIndexRec *StaticDiagNameIndexEnd =
|
||||
StaticDiagNameIndex + StaticDiagNameIndexSize;
|
||||
|
||||
|
@ -282,18 +282,18 @@ unsigned DiagnosticIDs::getIdFromName(llvm::StringRef Name) {
|
|||
|
||||
/// getBriefExplanation - Given a diagnostic ID, return a brief explanation
|
||||
/// of the issue
|
||||
llvm::StringRef DiagnosticIDs::getBriefExplanation(unsigned DiagID) {
|
||||
StringRef DiagnosticIDs::getBriefExplanation(unsigned DiagID) {
|
||||
if (const StaticDiagInfoRec *Info = GetDiagInfo(DiagID))
|
||||
return Info->getBriefExplanation();
|
||||
return llvm::StringRef();
|
||||
return StringRef();
|
||||
}
|
||||
|
||||
/// getFullExplanation - Given a diagnostic ID, return a full explanation
|
||||
/// of the issue
|
||||
llvm::StringRef DiagnosticIDs::getFullExplanation(unsigned DiagID) {
|
||||
StringRef DiagnosticIDs::getFullExplanation(unsigned DiagID) {
|
||||
if (const StaticDiagInfoRec *Info = GetDiagInfo(DiagID))
|
||||
return Info->getFullExplanation();
|
||||
return llvm::StringRef();
|
||||
return StringRef();
|
||||
}
|
||||
|
||||
/// getBuiltinDiagClass - Return the class field of the diagnostic.
|
||||
|
@ -318,7 +318,7 @@ namespace clang {
|
|||
|
||||
/// getDescription - Return the description of the specified custom
|
||||
/// diagnostic.
|
||||
llvm::StringRef getDescription(unsigned DiagID) const {
|
||||
StringRef getDescription(unsigned DiagID) const {
|
||||
assert(this && DiagID-DIAG_UPPER_LIMIT < DiagInfo.size() &&
|
||||
"Invalid diagnosic ID");
|
||||
return DiagInfo[DiagID-DIAG_UPPER_LIMIT].second;
|
||||
|
@ -331,7 +331,7 @@ namespace clang {
|
|||
return DiagInfo[DiagID-DIAG_UPPER_LIMIT].first;
|
||||
}
|
||||
|
||||
unsigned getOrCreateDiagID(DiagnosticIDs::Level L, llvm::StringRef Message,
|
||||
unsigned getOrCreateDiagID(DiagnosticIDs::Level L, StringRef Message,
|
||||
DiagnosticIDs &Diags) {
|
||||
DiagDesc D(L, Message);
|
||||
// Check to see if it already exists.
|
||||
|
@ -366,7 +366,7 @@ DiagnosticIDs::~DiagnosticIDs() {
|
|||
/// getCustomDiagID - Return an ID for a diagnostic with the specified message
|
||||
/// and level. If this is the first request for this diagnosic, it is
|
||||
/// registered and created, otherwise the existing ID is returned.
|
||||
unsigned DiagnosticIDs::getCustomDiagID(Level L, llvm::StringRef Message) {
|
||||
unsigned DiagnosticIDs::getCustomDiagID(Level L, StringRef Message) {
|
||||
if (CustomDiagInfo == 0)
|
||||
CustomDiagInfo = new diag::CustomDiagInfo();
|
||||
return CustomDiagInfo->getOrCreateDiagID(L, Message, *this);
|
||||
|
@ -406,7 +406,7 @@ bool DiagnosticIDs::isBuiltinExtensionDiag(unsigned DiagID,
|
|||
|
||||
/// getDescription - Given a diagnostic ID, return a description of the
|
||||
/// issue.
|
||||
llvm::StringRef DiagnosticIDs::getDescription(unsigned DiagID) const {
|
||||
StringRef DiagnosticIDs::getDescription(unsigned DiagID) const {
|
||||
if (const StaticDiagInfoRec *Info = GetDiagInfo(DiagID))
|
||||
return Info->getDescription();
|
||||
return CustomDiagInfo->getDescription(DiagID);
|
||||
|
@ -556,8 +556,8 @@ namespace {
|
|||
const short *Members;
|
||||
const short *SubGroups;
|
||||
|
||||
llvm::StringRef getName() const {
|
||||
return llvm::StringRef(NameStr, NameLen);
|
||||
StringRef getName() const {
|
||||
return StringRef(NameStr, NameLen);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
@ -598,7 +598,7 @@ static void MapGroupMembers(const WarningOption *Group, diag::Mapping Mapping,
|
|||
/// setDiagnosticGroupMapping - Change an entire diagnostic group (e.g.
|
||||
/// "unknown-pragmas" to have the specified mapping. This returns true and
|
||||
/// ignores the request if "Group" was unknown, false otherwise.
|
||||
bool DiagnosticIDs::setDiagnosticGroupMapping(llvm::StringRef Group,
|
||||
bool DiagnosticIDs::setDiagnosticGroupMapping(StringRef Group,
|
||||
diag::Mapping Map,
|
||||
SourceLocation Loc,
|
||||
Diagnostic &Diag) const {
|
||||
|
|
|
@ -217,14 +217,14 @@ void FileManager::removeStatCache(FileSystemStatCache *statCache) {
|
|||
/// \brief Retrieve the directory that the given file name resides in.
|
||||
/// Filename can point to either a real file or a virtual file.
|
||||
static const DirectoryEntry *getDirectoryFromFile(FileManager &FileMgr,
|
||||
llvm::StringRef Filename) {
|
||||
StringRef Filename) {
|
||||
if (Filename.empty())
|
||||
return NULL;
|
||||
|
||||
if (llvm::sys::path::is_separator(Filename[Filename.size() - 1]))
|
||||
return NULL; // If Filename is a directory.
|
||||
|
||||
llvm::StringRef DirName = llvm::sys::path::parent_path(Filename);
|
||||
StringRef DirName = llvm::sys::path::parent_path(Filename);
|
||||
// Use the current directory if file has no path component.
|
||||
if (DirName.empty())
|
||||
DirName = ".";
|
||||
|
@ -234,8 +234,8 @@ static const DirectoryEntry *getDirectoryFromFile(FileManager &FileMgr,
|
|||
|
||||
/// Add all ancestors of the given path (pointing to either a file or
|
||||
/// a directory) as virtual directories.
|
||||
void FileManager::addAncestorsAsVirtualDirs(llvm::StringRef Path) {
|
||||
llvm::StringRef DirName = llvm::sys::path::parent_path(Path);
|
||||
void FileManager::addAncestorsAsVirtualDirs(StringRef Path) {
|
||||
StringRef DirName = llvm::sys::path::parent_path(Path);
|
||||
if (DirName.empty())
|
||||
return;
|
||||
|
||||
|
@ -263,7 +263,7 @@ void FileManager::addAncestorsAsVirtualDirs(llvm::StringRef Path) {
|
|||
/// (real or virtual). This returns NULL if the directory doesn't
|
||||
/// exist.
|
||||
///
|
||||
const DirectoryEntry *FileManager::getDirectory(llvm::StringRef DirName) {
|
||||
const DirectoryEntry *FileManager::getDirectory(StringRef DirName) {
|
||||
++NumDirLookups;
|
||||
llvm::StringMapEntry<DirectoryEntry *> &NamedDirEnt =
|
||||
SeenDirEntries.GetOrCreateValue(DirName);
|
||||
|
@ -309,7 +309,7 @@ const DirectoryEntry *FileManager::getDirectory(llvm::StringRef DirName) {
|
|||
/// getFile - Lookup, cache, and verify the specified file (real or
|
||||
/// virtual). This returns NULL if the file doesn't exist.
|
||||
///
|
||||
const FileEntry *FileManager::getFile(llvm::StringRef Filename, bool openFile) {
|
||||
const FileEntry *FileManager::getFile(StringRef Filename, bool openFile) {
|
||||
++NumFileLookups;
|
||||
|
||||
// See if there is already an entry in the map.
|
||||
|
@ -381,7 +381,7 @@ const FileEntry *FileManager::getFile(llvm::StringRef Filename, bool openFile) {
|
|||
}
|
||||
|
||||
const FileEntry *
|
||||
FileManager::getVirtualFile(llvm::StringRef Filename, off_t Size,
|
||||
FileManager::getVirtualFile(StringRef Filename, off_t Size,
|
||||
time_t ModificationTime) {
|
||||
++NumFileLookups;
|
||||
|
||||
|
@ -451,8 +451,8 @@ FileManager::getVirtualFile(llvm::StringRef Filename, off_t Size,
|
|||
return UFE;
|
||||
}
|
||||
|
||||
void FileManager::FixupRelativePath(llvm::SmallVectorImpl<char> &path) const {
|
||||
llvm::StringRef pathRef(path.data(), path.size());
|
||||
void FileManager::FixupRelativePath(SmallVectorImpl<char> &path) const {
|
||||
StringRef pathRef(path.data(), path.size());
|
||||
|
||||
if (FileSystemOpts.WorkingDir.empty()
|
||||
|| llvm::sys::path::is_absolute(pathRef))
|
||||
|
@ -499,7 +499,7 @@ getBufferForFile(const FileEntry *Entry, std::string *ErrorStr) {
|
|||
}
|
||||
|
||||
llvm::MemoryBuffer *FileManager::
|
||||
getBufferForFile(llvm::StringRef Filename, std::string *ErrorStr) {
|
||||
getBufferForFile(StringRef Filename, std::string *ErrorStr) {
|
||||
llvm::OwningPtr<llvm::MemoryBuffer> Result;
|
||||
llvm::error_code ec;
|
||||
if (FileSystemOpts.WorkingDir.empty()) {
|
||||
|
@ -537,7 +537,7 @@ bool FileManager::getStatValue(const char *Path, struct stat &StatBuf,
|
|||
StatCache.get());
|
||||
}
|
||||
|
||||
bool FileManager::getNoncachedStatValue(llvm::StringRef Path,
|
||||
bool FileManager::getNoncachedStatValue(StringRef Path,
|
||||
struct stat &StatBuf) {
|
||||
llvm::SmallString<128> FilePath(Path);
|
||||
FixupRelativePath(FilePath);
|
||||
|
@ -546,7 +546,7 @@ bool FileManager::getNoncachedStatValue(llvm::StringRef Path,
|
|||
}
|
||||
|
||||
void FileManager::GetUniqueIDMapping(
|
||||
llvm::SmallVectorImpl<const FileEntry *> &UIDToFiles) const {
|
||||
SmallVectorImpl<const FileEntry *> &UIDToFiles) const {
|
||||
UIDToFiles.clear();
|
||||
UIDToFiles.resize(NextFileUID);
|
||||
|
||||
|
@ -558,7 +558,7 @@ void FileManager::GetUniqueIDMapping(
|
|||
UIDToFiles[FE->getValue()->getUID()] = FE->getValue();
|
||||
|
||||
// Map virtual file entries
|
||||
for (llvm::SmallVector<FileEntry*, 4>::const_iterator
|
||||
for (SmallVector<FileEntry*, 4>::const_iterator
|
||||
VFE = VirtualFileEntries.begin(), VFEEnd = VirtualFileEntries.end();
|
||||
VFE != VFEEnd; ++VFE)
|
||||
if (*VFE && *VFE != NON_EXISTENT_FILE)
|
||||
|
|
|
@ -55,7 +55,7 @@ namespace {
|
|||
class EmptyLookupIterator : public IdentifierIterator
|
||||
{
|
||||
public:
|
||||
virtual llvm::StringRef Next() { return llvm::StringRef(); }
|
||||
virtual StringRef Next() { return StringRef(); }
|
||||
};
|
||||
}
|
||||
|
||||
|
@ -106,7 +106,7 @@ namespace {
|
|||
/// enabled in the specified langauge, set to 1 if it is an extension
|
||||
/// in the specified language, and set to 0 if disabled in the
|
||||
/// specified language.
|
||||
static void AddKeyword(llvm::StringRef Keyword,
|
||||
static void AddKeyword(StringRef Keyword,
|
||||
tok::TokenKind TokenCode, unsigned Flags,
|
||||
const LangOptions &LangOpts, IdentifierTable &Table) {
|
||||
unsigned AddResult = 0;
|
||||
|
@ -133,7 +133,7 @@ static void AddKeyword(llvm::StringRef Keyword,
|
|||
|
||||
/// AddCXXOperatorKeyword - Register a C++ operator keyword alternative
|
||||
/// representations.
|
||||
static void AddCXXOperatorKeyword(llvm::StringRef Keyword,
|
||||
static void AddCXXOperatorKeyword(StringRef Keyword,
|
||||
tok::TokenKind TokenCode,
|
||||
IdentifierTable &Table) {
|
||||
IdentifierInfo &Info = Table.get(Keyword, TokenCode);
|
||||
|
@ -142,7 +142,7 @@ static void AddCXXOperatorKeyword(llvm::StringRef Keyword,
|
|||
|
||||
/// AddObjCKeyword - Register an Objective-C @keyword like "class" "selector" or
|
||||
/// "property".
|
||||
static void AddObjCKeyword(llvm::StringRef Name,
|
||||
static void AddObjCKeyword(StringRef Name,
|
||||
tok::ObjCKeywordKind ObjCID,
|
||||
IdentifierTable &Table) {
|
||||
Table.get(Name).setObjCKeywordID(ObjCID);
|
||||
|
@ -153,20 +153,20 @@ static void AddObjCKeyword(llvm::StringRef Name,
|
|||
void IdentifierTable::AddKeywords(const LangOptions &LangOpts) {
|
||||
// Add keywords and tokens for the current language.
|
||||
#define KEYWORD(NAME, FLAGS) \
|
||||
AddKeyword(llvm::StringRef(#NAME), tok::kw_ ## NAME, \
|
||||
AddKeyword(StringRef(#NAME), tok::kw_ ## NAME, \
|
||||
FLAGS, LangOpts, *this);
|
||||
#define ALIAS(NAME, TOK, FLAGS) \
|
||||
AddKeyword(llvm::StringRef(NAME), tok::kw_ ## TOK, \
|
||||
AddKeyword(StringRef(NAME), tok::kw_ ## TOK, \
|
||||
FLAGS, LangOpts, *this);
|
||||
#define CXX_KEYWORD_OPERATOR(NAME, ALIAS) \
|
||||
if (LangOpts.CXXOperatorNames) \
|
||||
AddCXXOperatorKeyword(llvm::StringRef(#NAME), tok::ALIAS, *this);
|
||||
AddCXXOperatorKeyword(StringRef(#NAME), tok::ALIAS, *this);
|
||||
#define OBJC1_AT_KEYWORD(NAME) \
|
||||
if (LangOpts.ObjC1) \
|
||||
AddObjCKeyword(llvm::StringRef(#NAME), tok::objc_##NAME, *this);
|
||||
AddObjCKeyword(StringRef(#NAME), tok::objc_##NAME, *this);
|
||||
#define OBJC2_AT_KEYWORD(NAME) \
|
||||
if (LangOpts.ObjC2) \
|
||||
AddObjCKeyword(llvm::StringRef(#NAME), tok::objc_##NAME, *this);
|
||||
AddObjCKeyword(StringRef(#NAME), tok::objc_##NAME, *this);
|
||||
#define TESTING_KEYWORD(NAME, FLAGS)
|
||||
#include "clang/Basic/TokenKinds.def"
|
||||
|
||||
|
@ -336,9 +336,9 @@ IdentifierInfo *Selector::getIdentifierInfoForSlot(unsigned argIndex) const {
|
|||
return SI->getIdentifierInfoForSlot(argIndex);
|
||||
}
|
||||
|
||||
llvm::StringRef Selector::getNameForSlot(unsigned int argIndex) const {
|
||||
StringRef Selector::getNameForSlot(unsigned int argIndex) const {
|
||||
IdentifierInfo *II = getIdentifierInfoForSlot(argIndex);
|
||||
return II? II->getName() : llvm::StringRef();
|
||||
return II? II->getName() : StringRef();
|
||||
}
|
||||
|
||||
std::string MultiKeywordSelector::getName() const {
|
||||
|
@ -377,7 +377,7 @@ std::string Selector::getAsString() const {
|
|||
/// Interpreting the given string using the normal CamelCase
|
||||
/// conventions, determine whether the given string starts with the
|
||||
/// given "word", which is assumed to end in a lowercase letter.
|
||||
static bool startsWithWord(llvm::StringRef name, llvm::StringRef word) {
|
||||
static bool startsWithWord(StringRef name, StringRef word) {
|
||||
if (name.size() < word.size()) return false;
|
||||
return ((name.size() == word.size() ||
|
||||
!islower(name[word.size()]))
|
||||
|
@ -388,7 +388,7 @@ ObjCMethodFamily Selector::getMethodFamilyImpl(Selector sel) {
|
|||
IdentifierInfo *first = sel.getIdentifierInfoForSlot(0);
|
||||
if (!first) return OMF_None;
|
||||
|
||||
llvm::StringRef name = first->getName();
|
||||
StringRef name = first->getName();
|
||||
if (sel.isUnarySelector()) {
|
||||
if (name == "autorelease") return OMF_autorelease;
|
||||
if (name == "dealloc") return OMF_dealloc;
|
||||
|
|
|
@ -23,7 +23,7 @@ using namespace clang;
|
|||
// PrettyStackTraceLoc
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
void PrettyStackTraceLoc::print(llvm::raw_ostream &OS) const {
|
||||
void PrettyStackTraceLoc::print(raw_ostream &OS) const {
|
||||
if (Loc.isValid()) {
|
||||
Loc.print(OS, SM);
|
||||
OS << ": ";
|
||||
|
@ -35,7 +35,7 @@ void PrettyStackTraceLoc::print(llvm::raw_ostream &OS) const {
|
|||
// SourceLocation
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
void SourceLocation::print(llvm::raw_ostream &OS, const SourceManager &SM)const{
|
||||
void SourceLocation::print(raw_ostream &OS, const SourceManager &SM)const{
|
||||
if (!isValid()) {
|
||||
OS << "<invalid loc>";
|
||||
return;
|
||||
|
@ -125,7 +125,7 @@ const llvm::MemoryBuffer* FullSourceLoc::getBuffer(bool *Invalid) const {
|
|||
return SrcMgr->getBuffer(SrcMgr->getFileID(*this), Invalid);
|
||||
}
|
||||
|
||||
llvm::StringRef FullSourceLoc::getBufferData(bool *Invalid) const {
|
||||
StringRef FullSourceLoc::getBufferData(bool *Invalid) const {
|
||||
return getBuffer(Invalid)->getBuffer();
|
||||
}
|
||||
|
||||
|
|
|
@ -105,7 +105,7 @@ const llvm::MemoryBuffer *ContentCache::getBuffer(Diagnostic &Diag,
|
|||
// that we are in an inconsistent situation and error out as quickly as
|
||||
// possible.
|
||||
if (!Buffer.getPointer()) {
|
||||
const llvm::StringRef FillStr("<<<MISSING SOURCE FILE>>>\n");
|
||||
const StringRef FillStr("<<<MISSING SOURCE FILE>>>\n");
|
||||
Buffer.setPointer(MemoryBuffer::getNewMemBuffer(ContentsEntry->getSize(),
|
||||
"<invalid>"));
|
||||
char *Ptr = const_cast<char*>(Buffer.getPointer()->getBufferStart());
|
||||
|
@ -143,7 +143,7 @@ const llvm::MemoryBuffer *ContentCache::getBuffer(Diagnostic &Diag,
|
|||
// If the buffer is valid, check to see if it has a UTF Byte Order Mark
|
||||
// (BOM). We only support UTF-8 with and without a BOM right now. See
|
||||
// http://en.wikipedia.org/wiki/Byte_order_mark for more information.
|
||||
llvm::StringRef BufStr = Buffer.getPointer()->getBuffer();
|
||||
StringRef BufStr = Buffer.getPointer()->getBuffer();
|
||||
const char *InvalidBOM = llvm::StringSwitch<const char *>(BufStr)
|
||||
.StartsWith("\xFE\xFF", "UTF-16 (BE)")
|
||||
.StartsWith("\xFF\xFE", "UTF-16 (LE)")
|
||||
|
@ -169,7 +169,7 @@ const llvm::MemoryBuffer *ContentCache::getBuffer(Diagnostic &Diag,
|
|||
return Buffer.getPointer();
|
||||
}
|
||||
|
||||
unsigned LineTableInfo::getLineTableFilenameID(llvm::StringRef Name) {
|
||||
unsigned LineTableInfo::getLineTableFilenameID(StringRef Name) {
|
||||
// Look up the filename in the string table, returning the pre-existing value
|
||||
// if it exists.
|
||||
llvm::StringMapEntry<unsigned> &Entry =
|
||||
|
@ -277,7 +277,7 @@ void LineTableInfo::AddEntry(int FID,
|
|||
|
||||
/// getLineTableFilenameID - Return the uniqued ID for the specified filename.
|
||||
///
|
||||
unsigned SourceManager::getLineTableFilenameID(llvm::StringRef Name) {
|
||||
unsigned SourceManager::getLineTableFilenameID(StringRef Name) {
|
||||
if (LineTable == 0)
|
||||
LineTable = new LineTableInfo();
|
||||
return LineTable->getLineTableFilenameID(Name);
|
||||
|
@ -588,7 +588,7 @@ void SourceManager::overrideFileContents(const FileEntry *SourceFile,
|
|||
OverriddenFiles[SourceFile] = NewFile;
|
||||
}
|
||||
|
||||
llvm::StringRef SourceManager::getBufferData(FileID FID, bool *Invalid) const {
|
||||
StringRef SourceManager::getBufferData(FileID FID, bool *Invalid) const {
|
||||
bool MyInvalid = false;
|
||||
const SLocEntry &SLoc = getSLocEntry(FID, &MyInvalid);
|
||||
if (!SLoc.isFile() || MyInvalid) {
|
||||
|
@ -986,7 +986,7 @@ static void ComputeLineNumbers(Diagnostic &Diag, ContentCache *FI,
|
|||
|
||||
// Find the file offsets of all of the *physical* source lines. This does
|
||||
// not look at trigraphs, escaped newlines, or anything else tricky.
|
||||
llvm::SmallVector<unsigned, 256> LineOffsets;
|
||||
SmallVector<unsigned, 256> LineOffsets;
|
||||
|
||||
// Line #1 starts at char 0.
|
||||
LineOffsets.push_back(0);
|
||||
|
@ -1316,7 +1316,7 @@ SourceLocation SourceManager::getLocation(const FileEntry *SourceFile,
|
|||
// First, check the main file ID, since it is common to look for a
|
||||
// location in the main file.
|
||||
llvm::Optional<ino_t> SourceFileInode;
|
||||
llvm::Optional<llvm::StringRef> SourceFileName;
|
||||
llvm::Optional<StringRef> SourceFileName;
|
||||
if (!MainFileID.isInvalid()) {
|
||||
bool Invalid = false;
|
||||
const SLocEntry &MainSLoc = getSLocEntry(MainFileID, &Invalid);
|
||||
|
|
|
@ -174,7 +174,7 @@ void TargetInfo::setForcedLangOptions(LangOptions &Opts) {
|
|||
//===----------------------------------------------------------------------===//
|
||||
|
||||
|
||||
static llvm::StringRef removeGCCRegisterPrefix(llvm::StringRef Name) {
|
||||
static StringRef removeGCCRegisterPrefix(StringRef Name) {
|
||||
if (Name[0] == '%' || Name[0] == '#')
|
||||
Name = Name.substr(1);
|
||||
|
||||
|
@ -184,7 +184,7 @@ static llvm::StringRef removeGCCRegisterPrefix(llvm::StringRef Name) {
|
|||
/// isValidClobber - Returns whether the passed in string is
|
||||
/// a valid clobber in an inline asm statement. This is used by
|
||||
/// Sema.
|
||||
bool TargetInfo::isValidClobber(llvm::StringRef Name) const {
|
||||
bool TargetInfo::isValidClobber(StringRef Name) const {
|
||||
return (isValidGCCRegisterName(Name) ||
|
||||
Name == "memory" || Name == "cc");
|
||||
}
|
||||
|
@ -192,7 +192,7 @@ bool TargetInfo::isValidClobber(llvm::StringRef Name) const {
|
|||
/// isValidGCCRegisterName - Returns whether the passed in string
|
||||
/// is a valid register name according to GCC. This is used by Sema for
|
||||
/// inline asm statements.
|
||||
bool TargetInfo::isValidGCCRegisterName(llvm::StringRef Name) const {
|
||||
bool TargetInfo::isValidGCCRegisterName(StringRef Name) const {
|
||||
if (Name.empty())
|
||||
return false;
|
||||
|
||||
|
@ -248,8 +248,8 @@ bool TargetInfo::isValidGCCRegisterName(llvm::StringRef Name) const {
|
|||
return false;
|
||||
}
|
||||
|
||||
llvm::StringRef
|
||||
TargetInfo::getNormalizedGCCRegisterName(llvm::StringRef Name) const {
|
||||
StringRef
|
||||
TargetInfo::getNormalizedGCCRegisterName(StringRef Name) const {
|
||||
assert(isValidGCCRegisterName(Name) && "Invalid register passed in");
|
||||
|
||||
// Get rid of any register prefix.
|
||||
|
|
|
@ -37,7 +37,7 @@ using namespace clang;
|
|||
/// DefineStd - Define a macro name and standard variants. For example if
|
||||
/// MacroName is "unix", then this will define "__unix", "__unix__", and "unix"
|
||||
/// when in GNU mode.
|
||||
static void DefineStd(MacroBuilder &Builder, llvm::StringRef MacroName,
|
||||
static void DefineStd(MacroBuilder &Builder, StringRef MacroName,
|
||||
const LangOptions &Opts) {
|
||||
assert(MacroName[0] != '_' && "Identifier should be in the user's namespace");
|
||||
|
||||
|
@ -77,7 +77,7 @@ public:
|
|||
|
||||
static void getDarwinDefines(MacroBuilder &Builder, const LangOptions &Opts,
|
||||
const llvm::Triple &Triple,
|
||||
llvm::StringRef &PlatformName,
|
||||
StringRef &PlatformName,
|
||||
VersionTuple &PlatformMinVersion) {
|
||||
Builder.defineMacro("__APPLE_CC__", "5621");
|
||||
Builder.defineMacro("__APPLE__");
|
||||
|
@ -202,9 +202,9 @@ public:
|
|||
this->MCountName = "\01mcount";
|
||||
}
|
||||
|
||||
virtual std::string isValidSectionSpecifier(llvm::StringRef SR) const {
|
||||
virtual std::string isValidSectionSpecifier(StringRef SR) const {
|
||||
// Let MCSectionMachO validate this.
|
||||
llvm::StringRef Segment, Section;
|
||||
StringRef Segment, Section;
|
||||
unsigned TAA, StubSize;
|
||||
bool HasTAA;
|
||||
return llvm::MCSectionMachO::ParseSectionSpecifier(SR, Segment, Section,
|
||||
|
@ -247,7 +247,7 @@ protected:
|
|||
// FreeBSD defines; list based off of gcc output
|
||||
|
||||
// FIXME: Move version number handling to llvm::Triple.
|
||||
llvm::StringRef Release = Triple.getOSName().substr(strlen("freebsd"), 1);
|
||||
StringRef Release = Triple.getOSName().substr(strlen("freebsd"), 1);
|
||||
|
||||
Builder.defineMacro("__FreeBSD__", Release);
|
||||
Builder.defineMacro("__FreeBSD_cc_version", Release + "00001");
|
||||
|
@ -503,7 +503,7 @@ protected:
|
|||
Builder.defineMacro("_MT");
|
||||
|
||||
if (Opts.MSCVersion != 0)
|
||||
Builder.defineMacro("_MSC_VER", llvm::Twine(Opts.MSCVersion));
|
||||
Builder.defineMacro("_MSC_VER", Twine(Opts.MSCVersion));
|
||||
|
||||
if (Opts.Microsoft) {
|
||||
Builder.defineMacro("_MSC_EXTENSIONS");
|
||||
|
@ -1429,13 +1429,13 @@ void X86TargetInfo::getTargetDefines(const LangOptions &Opts,
|
|||
case SSSE3:
|
||||
case SSE3:
|
||||
case SSE2:
|
||||
Builder.defineMacro("_M_IX86_FP", llvm::Twine(2));
|
||||
Builder.defineMacro("_M_IX86_FP", Twine(2));
|
||||
break;
|
||||
case SSE1:
|
||||
Builder.defineMacro("_M_IX86_FP", llvm::Twine(1));
|
||||
Builder.defineMacro("_M_IX86_FP", Twine(1));
|
||||
break;
|
||||
default:
|
||||
Builder.defineMacro("_M_IX86_FP", llvm::Twine(0));
|
||||
Builder.defineMacro("_M_IX86_FP", Twine(0));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1706,7 +1706,7 @@ protected:
|
|||
// RTEMS defines; list based off of gcc output
|
||||
|
||||
// FIXME: Move version number handling to llvm::Triple.
|
||||
llvm::StringRef Release = Triple.getOSName().substr(strlen("rtems"), 1);
|
||||
StringRef Release = Triple.getOSName().substr(strlen("rtems"), 1);
|
||||
|
||||
Builder.defineMacro("__rtems__");
|
||||
Builder.defineMacro("__ELF__");
|
||||
|
@ -2035,7 +2035,7 @@ public:
|
|||
Features.erase(it);
|
||||
}
|
||||
|
||||
static const char *getCPUDefineSuffix(llvm::StringRef Name) {
|
||||
static const char *getCPUDefineSuffix(StringRef Name) {
|
||||
return llvm::StringSwitch<const char*>(Name)
|
||||
.Cases("arm8", "arm810", "4")
|
||||
.Cases("strongarm", "strongarm110", "strongarm1100", "strongarm1110", "4")
|
||||
|
@ -2074,7 +2074,7 @@ public:
|
|||
Builder.defineMacro("__LITTLE_ENDIAN__");
|
||||
Builder.defineMacro("__REGISTER_PREFIX__", "");
|
||||
|
||||
llvm::StringRef CPUArch = getCPUDefineSuffix(CPU);
|
||||
StringRef CPUArch = getCPUDefineSuffix(CPU);
|
||||
Builder.defineMacro("__ARM_ARCH_" + CPUArch + "__");
|
||||
|
||||
// Subtarget options.
|
||||
|
|
|
@ -12,6 +12,7 @@
|
|||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "clang/Basic/Version.h"
|
||||
#include "clang/Basic/LLVM.h"
|
||||
#include "llvm/Support/raw_ostream.h"
|
||||
#include "llvm/Config/config.h"
|
||||
#include <cstring>
|
||||
|
@ -24,14 +25,14 @@ std::string getClangRepositoryPath() {
|
|||
return CLANG_REPOSITORY_STRING;
|
||||
#else
|
||||
#ifdef SVN_REPOSITORY
|
||||
llvm::StringRef URL(SVN_REPOSITORY);
|
||||
StringRef URL(SVN_REPOSITORY);
|
||||
#else
|
||||
llvm::StringRef URL("");
|
||||
StringRef URL("");
|
||||
#endif
|
||||
|
||||
// If the SVN_REPOSITORY is empty, try to use the SVN keyword. This helps us
|
||||
// pick up a tag in an SVN export, for example.
|
||||
static llvm::StringRef SVNRepository("$URL$");
|
||||
static StringRef SVNRepository("$URL$");
|
||||
if (URL.empty()) {
|
||||
URL = SVNRepository.slice(SVNRepository.find(':'),
|
||||
SVNRepository.find("/lib/Basic"));
|
||||
|
@ -42,7 +43,7 @@ std::string getClangRepositoryPath() {
|
|||
|
||||
// Trim path prefix off, assuming path came from standard cfe path.
|
||||
size_t Start = URL.find("cfe/");
|
||||
if (Start != llvm::StringRef::npos)
|
||||
if (Start != StringRef::npos)
|
||||
URL = URL.substr(Start + 4);
|
||||
|
||||
return URL;
|
||||
|
|
|
@ -25,7 +25,7 @@ std::string VersionTuple::getAsString() const {
|
|||
return Result;
|
||||
}
|
||||
|
||||
llvm::raw_ostream& clang::operator<<(llvm::raw_ostream &Out,
|
||||
raw_ostream& clang::operator<<(raw_ostream &Out,
|
||||
const VersionTuple &V) {
|
||||
Out << V.getMajor();
|
||||
if (llvm::Optional<unsigned> Minor = V.getMinor())
|
||||
|
|
|
@ -62,7 +62,7 @@ static llvm::Constant *buildBlockDescriptor(CodeGenModule &CGM,
|
|||
llvm::Type *ulong = CGM.getTypes().ConvertType(C.UnsignedLongTy);
|
||||
llvm::Type *i8p = CGM.getTypes().ConvertType(C.VoidPtrTy);
|
||||
|
||||
llvm::SmallVector<llvm::Constant*, 6> elements;
|
||||
SmallVector<llvm::Constant*, 6> elements;
|
||||
|
||||
// reserved
|
||||
elements.push_back(llvm::ConstantInt::get(ulong, 0));
|
||||
|
@ -243,7 +243,7 @@ static CharUnits getLowBit(CharUnits v) {
|
|||
}
|
||||
|
||||
static void initializeForBlockHeader(CodeGenModule &CGM, CGBlockInfo &info,
|
||||
llvm::SmallVectorImpl<llvm::Type*> &elementTypes) {
|
||||
SmallVectorImpl<llvm::Type*> &elementTypes) {
|
||||
ASTContext &C = CGM.getContext();
|
||||
|
||||
// The header is basically a 'struct { void *; int; int; void *; void *; }'.
|
||||
|
@ -280,7 +280,7 @@ static void computeBlockInfo(CodeGenModule &CGM, CGBlockInfo &info) {
|
|||
ASTContext &C = CGM.getContext();
|
||||
const BlockDecl *block = info.getBlockDecl();
|
||||
|
||||
llvm::SmallVector<llvm::Type*, 8> elementTypes;
|
||||
SmallVector<llvm::Type*, 8> elementTypes;
|
||||
initializeForBlockHeader(CGM, info, elementTypes);
|
||||
|
||||
if (!block->hasCaptures()) {
|
||||
|
@ -291,7 +291,7 @@ static void computeBlockInfo(CodeGenModule &CGM, CGBlockInfo &info) {
|
|||
}
|
||||
|
||||
// Collect the layout chunks.
|
||||
llvm::SmallVector<BlockLayoutChunk, 16> layout;
|
||||
SmallVector<BlockLayoutChunk, 16> layout;
|
||||
layout.reserve(block->capturesCXXThis() +
|
||||
(block->capture_end() - block->capture_begin()));
|
||||
|
||||
|
@ -422,7 +422,7 @@ static void computeBlockInfo(CodeGenModule &CGM, CGBlockInfo &info) {
|
|||
// which has 7 bytes of padding, as opposed to the naive solution
|
||||
// which might have less (?).
|
||||
if (endAlign < maxFieldAlign) {
|
||||
llvm::SmallVectorImpl<BlockLayoutChunk>::iterator
|
||||
SmallVectorImpl<BlockLayoutChunk>::iterator
|
||||
li = layout.begin() + 1, le = layout.end();
|
||||
|
||||
// Look for something that the header end is already
|
||||
|
@ -433,7 +433,7 @@ static void computeBlockInfo(CodeGenModule &CGM, CGBlockInfo &info) {
|
|||
// If we found something that's naturally aligned for the end of
|
||||
// the header, keep adding things...
|
||||
if (li != le) {
|
||||
llvm::SmallVectorImpl<BlockLayoutChunk>::iterator first = li;
|
||||
SmallVectorImpl<BlockLayoutChunk>::iterator first = li;
|
||||
for (; li != le; ++li) {
|
||||
assert(endAlign >= li->Alignment);
|
||||
|
||||
|
@ -468,7 +468,7 @@ static void computeBlockInfo(CodeGenModule &CGM, CGBlockInfo &info) {
|
|||
// Slam everything else on now. This works because they have
|
||||
// strictly decreasing alignment and we expect that size is always a
|
||||
// multiple of alignment.
|
||||
for (llvm::SmallVectorImpl<BlockLayoutChunk>::iterator
|
||||
for (SmallVectorImpl<BlockLayoutChunk>::iterator
|
||||
li = layout.begin(), le = layout.end(); li != le; ++li) {
|
||||
assert(endAlign >= li->Alignment);
|
||||
li->setIndex(info, elementTypes.size());
|
||||
|
@ -1665,7 +1665,7 @@ llvm::Type *CodeGenFunction::BuildByRefType(const VarDecl *D) {
|
|||
|
||||
QualType Ty = D->getType();
|
||||
|
||||
llvm::SmallVector<llvm::Type *, 8> types;
|
||||
SmallVector<llvm::Type *, 8> types;
|
||||
|
||||
llvm::StructType *ByRefType =
|
||||
llvm::StructType::createNamed(getLLVMContext(),
|
||||
|
|
|
@ -1193,12 +1193,12 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID,
|
|||
const FunctionDecl *FD = E->getDirectCallee();
|
||||
// Oddly people write this call without args on occasion and gcc accepts
|
||||
// it - it's also marked as varargs in the description file.
|
||||
llvm::SmallVector<Value*, 2> Ops;
|
||||
SmallVector<Value*, 2> Ops;
|
||||
for (unsigned i = 0; i < E->getNumArgs(); i++)
|
||||
Ops.push_back(EmitScalarExpr(E->getArg(i)));
|
||||
llvm::Type *Ty = CGM.getTypes().ConvertType(FD->getType());
|
||||
llvm::FunctionType *FTy = cast<llvm::FunctionType>(Ty);
|
||||
llvm::StringRef Name = FD->getName();
|
||||
StringRef Name = FD->getName();
|
||||
return Builder.CreateCall(CGM.CreateRuntimeFunction(FTy, Name), Ops);
|
||||
}
|
||||
|
||||
|
@ -1236,7 +1236,7 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID,
|
|||
return Builder.CreateCall3(F, Arg0, Arg1, StPtr, "strexd");
|
||||
}
|
||||
|
||||
llvm::SmallVector<Value*, 4> Ops;
|
||||
SmallVector<Value*, 4> Ops;
|
||||
for (unsigned i = 0, e = E->getNumArgs() - 1; i != e; i++)
|
||||
Ops.push_back(EmitScalarExpr(E->getArg(i)));
|
||||
|
||||
|
@ -1918,7 +1918,7 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID,
|
|||
}
|
||||
|
||||
llvm::Value *CodeGenFunction::
|
||||
BuildVector(const llvm::SmallVectorImpl<llvm::Value*> &Ops) {
|
||||
BuildVector(const SmallVectorImpl<llvm::Value*> &Ops) {
|
||||
assert((Ops.size() & (Ops.size() - 1)) == 0 &&
|
||||
"Not a power-of-two sized vector!");
|
||||
bool AllConstants = true;
|
||||
|
@ -1946,7 +1946,7 @@ BuildVector(const llvm::SmallVectorImpl<llvm::Value*> &Ops) {
|
|||
|
||||
Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID,
|
||||
const CallExpr *E) {
|
||||
llvm::SmallVector<Value*, 4> Ops;
|
||||
SmallVector<Value*, 4> Ops;
|
||||
|
||||
// Find out if any arguments are required to be integer constant expressions.
|
||||
unsigned ICEArguments = 0;
|
||||
|
@ -2141,7 +2141,7 @@ Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID,
|
|||
// If palignr is shifting the pair of input vectors less than 9 bytes,
|
||||
// emit a shuffle instruction.
|
||||
if (shiftVal <= 8) {
|
||||
llvm::SmallVector<llvm::Constant*, 8> Indices;
|
||||
SmallVector<llvm::Constant*, 8> Indices;
|
||||
for (unsigned i = 0; i != 8; ++i)
|
||||
Indices.push_back(llvm::ConstantInt::get(Int32Ty, shiftVal + i));
|
||||
|
||||
|
@ -2172,7 +2172,7 @@ Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID,
|
|||
// If palignr is shifting the pair of input vectors less than 17 bytes,
|
||||
// emit a shuffle instruction.
|
||||
if (shiftVal <= 16) {
|
||||
llvm::SmallVector<llvm::Constant*, 16> Indices;
|
||||
SmallVector<llvm::Constant*, 16> Indices;
|
||||
for (unsigned i = 0; i != 16; ++i)
|
||||
Indices.push_back(llvm::ConstantInt::get(Int32Ty, shiftVal + i));
|
||||
|
||||
|
@ -2349,7 +2349,7 @@ Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID,
|
|||
|
||||
Value *CodeGenFunction::EmitPPCBuiltinExpr(unsigned BuiltinID,
|
||||
const CallExpr *E) {
|
||||
llvm::SmallVector<Value*, 4> Ops;
|
||||
SmallVector<Value*, 4> Ops;
|
||||
|
||||
for (unsigned i = 0, e = E->getNumArgs(); i != e; i++)
|
||||
Ops.push_back(EmitScalarExpr(E->getArg(i)));
|
||||
|
|
|
@ -154,7 +154,7 @@ bool CodeGenModule::TryEmitDefinitionAsAlias(GlobalDecl AliasDecl,
|
|||
new llvm::GlobalAlias(AliasType, Linkage, "", Aliasee, &getModule());
|
||||
|
||||
// Switch any previous uses to the alias.
|
||||
llvm::StringRef MangledName = getMangledName(AliasDecl);
|
||||
StringRef MangledName = getMangledName(AliasDecl);
|
||||
llvm::GlobalValue *Entry = GetGlobalValue(MangledName);
|
||||
if (Entry) {
|
||||
assert(Entry->isDeclaration() && "definition already exists for alias");
|
||||
|
@ -214,7 +214,7 @@ CodeGenModule::GetAddrOfCXXConstructor(const CXXConstructorDecl *ctor,
|
|||
const CGFunctionInfo *fnInfo) {
|
||||
GlobalDecl GD(ctor, ctorType);
|
||||
|
||||
llvm::StringRef name = getMangledName(GD);
|
||||
StringRef name = getMangledName(GD);
|
||||
if (llvm::GlobalValue *existing = GetGlobalValue(name))
|
||||
return existing;
|
||||
|
||||
|
@ -282,7 +282,7 @@ CodeGenModule::GetAddrOfCXXDestructor(const CXXDestructorDecl *dtor,
|
|||
const CGFunctionInfo *fnInfo) {
|
||||
GlobalDecl GD(dtor, dtorType);
|
||||
|
||||
llvm::StringRef name = getMangledName(GD);
|
||||
StringRef name = getMangledName(GD);
|
||||
if (llvm::GlobalValue *existing = GetGlobalValue(name))
|
||||
return existing;
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@ using namespace CodeGen;
|
|||
CGCXXABI::~CGCXXABI() { }
|
||||
|
||||
static void ErrorUnsupportedABI(CodeGenFunction &CGF,
|
||||
llvm::StringRef S) {
|
||||
StringRef S) {
|
||||
Diagnostic &Diags = CGF.CGM.getDiags();
|
||||
unsigned DiagID = Diags.getCustomDiagID(Diagnostic::Error,
|
||||
"cannot yet compile %1 in this ABI");
|
||||
|
|
|
@ -69,14 +69,14 @@ static CanQualType GetReturnType(QualType RetTy) {
|
|||
const CGFunctionInfo &
|
||||
CodeGenTypes::getFunctionInfo(CanQual<FunctionNoProtoType> FTNP) {
|
||||
return getFunctionInfo(FTNP->getResultType().getUnqualifiedType(),
|
||||
llvm::SmallVector<CanQualType, 16>(),
|
||||
SmallVector<CanQualType, 16>(),
|
||||
FTNP->getExtInfo());
|
||||
}
|
||||
|
||||
/// \param Args - contains any initial parameters besides those
|
||||
/// in the formal type
|
||||
static const CGFunctionInfo &getFunctionInfo(CodeGenTypes &CGT,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys,
|
||||
SmallVectorImpl<CanQualType> &ArgTys,
|
||||
CanQual<FunctionProtoType> FTP) {
|
||||
// FIXME: Kill copy.
|
||||
for (unsigned i = 0, e = FTP->getNumArgs(); i != e; ++i)
|
||||
|
@ -87,7 +87,7 @@ static const CGFunctionInfo &getFunctionInfo(CodeGenTypes &CGT,
|
|||
|
||||
const CGFunctionInfo &
|
||||
CodeGenTypes::getFunctionInfo(CanQual<FunctionProtoType> FTP) {
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
return ::getFunctionInfo(*this, ArgTys, FTP);
|
||||
}
|
||||
|
||||
|
@ -113,7 +113,7 @@ static CallingConv getCallingConventionForDecl(const Decl *D) {
|
|||
|
||||
const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXRecordDecl *RD,
|
||||
const FunctionProtoType *FTP) {
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
|
||||
// Add the 'this' pointer.
|
||||
ArgTys.push_back(GetThisType(Context, RD));
|
||||
|
@ -123,7 +123,7 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXRecordDecl *RD,
|
|||
}
|
||||
|
||||
const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXMethodDecl *MD) {
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
|
||||
assert(!isa<CXXConstructorDecl>(MD) && "wrong method for contructors!");
|
||||
assert(!isa<CXXDestructorDecl>(MD) && "wrong method for destructors!");
|
||||
|
@ -137,7 +137,7 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXMethodDecl *MD) {
|
|||
|
||||
const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXConstructorDecl *D,
|
||||
CXXCtorType Type) {
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
ArgTys.push_back(GetThisType(Context, D->getParent()));
|
||||
CanQualType ResTy = Context.VoidTy;
|
||||
|
||||
|
@ -154,7 +154,7 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXConstructorDecl *D,
|
|||
|
||||
const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const CXXDestructorDecl *D,
|
||||
CXXDtorType Type) {
|
||||
llvm::SmallVector<CanQualType, 2> ArgTys;
|
||||
SmallVector<CanQualType, 2> ArgTys;
|
||||
ArgTys.push_back(GetThisType(Context, D->getParent()));
|
||||
CanQualType ResTy = Context.VoidTy;
|
||||
|
||||
|
@ -180,7 +180,7 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const FunctionDecl *FD) {
|
|||
}
|
||||
|
||||
const CGFunctionInfo &CodeGenTypes::getFunctionInfo(const ObjCMethodDecl *MD) {
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
ArgTys.push_back(Context.getCanonicalParamType(MD->getSelfDecl()->getType()));
|
||||
ArgTys.push_back(Context.getCanonicalParamType(Context.getObjCSelType()));
|
||||
// FIXME: Kill copy?
|
||||
|
@ -216,7 +216,7 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(QualType ResTy,
|
|||
const CallArgList &Args,
|
||||
const FunctionType::ExtInfo &Info) {
|
||||
// FIXME: Kill copy.
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
for (CallArgList::const_iterator i = Args.begin(), e = Args.end();
|
||||
i != e; ++i)
|
||||
ArgTys.push_back(Context.getCanonicalParamType(i->Ty));
|
||||
|
@ -227,7 +227,7 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(QualType ResTy,
|
|||
const FunctionArgList &Args,
|
||||
const FunctionType::ExtInfo &Info) {
|
||||
// FIXME: Kill copy.
|
||||
llvm::SmallVector<CanQualType, 16> ArgTys;
|
||||
SmallVector<CanQualType, 16> ArgTys;
|
||||
for (FunctionArgList::const_iterator i = Args.begin(), e = Args.end();
|
||||
i != e; ++i)
|
||||
ArgTys.push_back(Context.getCanonicalParamType((*i)->getType()));
|
||||
|
@ -235,15 +235,15 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(QualType ResTy,
|
|||
}
|
||||
|
||||
const CGFunctionInfo &CodeGenTypes::getNullaryFunctionInfo() {
|
||||
llvm::SmallVector<CanQualType, 1> args;
|
||||
SmallVector<CanQualType, 1> args;
|
||||
return getFunctionInfo(getContext().VoidTy, args, FunctionType::ExtInfo());
|
||||
}
|
||||
|
||||
const CGFunctionInfo &CodeGenTypes::getFunctionInfo(CanQualType ResTy,
|
||||
const llvm::SmallVectorImpl<CanQualType> &ArgTys,
|
||||
const SmallVectorImpl<CanQualType> &ArgTys,
|
||||
const FunctionType::ExtInfo &Info) {
|
||||
#ifndef NDEBUG
|
||||
for (llvm::SmallVectorImpl<CanQualType>::const_iterator
|
||||
for (SmallVectorImpl<CanQualType>::const_iterator
|
||||
I = ArgTys.begin(), E = ArgTys.end(); I != E; ++I)
|
||||
assert(I->isCanonicalAsParam());
|
||||
#endif
|
||||
|
@ -312,7 +312,7 @@ CGFunctionInfo::CGFunctionInfo(unsigned _CallingConvention,
|
|||
/***/
|
||||
|
||||
void CodeGenTypes::GetExpandedTypes(QualType type,
|
||||
llvm::SmallVectorImpl<llvm::Type*> &expandedTypes) {
|
||||
SmallVectorImpl<llvm::Type*> &expandedTypes) {
|
||||
const RecordType *RT = type->getAsStructureType();
|
||||
assert(RT && "Can only expand structure types.");
|
||||
const RecordDecl *RD = RT->getDecl();
|
||||
|
@ -614,7 +614,7 @@ CodeGenTypes::GetFunctionType(const CGFunctionInfo &FI, bool isVariadic) {
|
|||
bool Inserted = FunctionsBeingProcessed.insert(&FI); (void)Inserted;
|
||||
assert(Inserted && "Recursively being processed?");
|
||||
|
||||
llvm::SmallVector<llvm::Type*, 8> argTypes;
|
||||
SmallVector<llvm::Type*, 8> argTypes;
|
||||
llvm::Type *resultType = 0;
|
||||
|
||||
const ABIArgInfo &retAI = FI.getReturnInfo();
|
||||
|
@ -824,7 +824,7 @@ void CodeGenModule::ConstructAttributeList(const CGFunctionInfo &FI,
|
|||
continue;
|
||||
|
||||
case ABIArgInfo::Expand: {
|
||||
llvm::SmallVector<llvm::Type*, 8> types;
|
||||
SmallVector<llvm::Type*, 8> types;
|
||||
// FIXME: This is rather inefficient. Do we ever actually need to do
|
||||
// anything here? The result should be just reconstructed on the other
|
||||
// side, so extension should be a non-issue.
|
||||
|
@ -995,7 +995,7 @@ void CodeGenFunction::EmitFunctionProlog(const CGFunctionInfo &FI,
|
|||
|
||||
for (unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
|
||||
assert(AI != Fn->arg_end() && "Argument mismatch!");
|
||||
AI->setName(Arg->getName() + ".coerce" + llvm::Twine(i));
|
||||
AI->setName(Arg->getName() + ".coerce" + Twine(i));
|
||||
llvm::Value *EltPtr = Builder.CreateConstGEP2_32(Ptr, 0, i);
|
||||
Builder.CreateStore(AI++, EltPtr);
|
||||
}
|
||||
|
@ -1029,7 +1029,7 @@ void CodeGenFunction::EmitFunctionProlog(const CGFunctionInfo &FI,
|
|||
// Name the arguments used in expansion and increment AI.
|
||||
unsigned Index = 0;
|
||||
for (; AI != End; ++AI, ++Index)
|
||||
AI->setName(Arg->getName() + "." + llvm::Twine(Index));
|
||||
AI->setName(Arg->getName() + "." + Twine(Index));
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@ -1063,7 +1063,7 @@ static llvm::Value *tryEmitFusedAutoreleaseOfResult(CodeGenFunction &CGF,
|
|||
// result is in a BasicBlock and is therefore an Instruction.
|
||||
llvm::Instruction *generator = cast<llvm::Instruction>(result);
|
||||
|
||||
llvm::SmallVector<llvm::Instruction*,4> insnsToKill;
|
||||
SmallVector<llvm::Instruction*,4> insnsToKill;
|
||||
|
||||
// Look for:
|
||||
// %generator = bitcast %type1* %generator2 to %type2*
|
||||
|
@ -1116,7 +1116,7 @@ static llvm::Value *tryEmitFusedAutoreleaseOfResult(CodeGenFunction &CGF,
|
|||
}
|
||||
|
||||
// Delete all the unnecessary instructions, from latest to earliest.
|
||||
for (llvm::SmallVectorImpl<llvm::Instruction*>::iterator
|
||||
for (SmallVectorImpl<llvm::Instruction*>::iterator
|
||||
i = insnsToKill.begin(), e = insnsToKill.end(); i != e; ++i)
|
||||
(*i)->eraseFromParent();
|
||||
|
||||
|
@ -1432,7 +1432,7 @@ void CodeGenFunction::EmitCallArg(CallArgList &args, const Expr *E,
|
|||
llvm::CallSite
|
||||
CodeGenFunction::EmitCallOrInvoke(llvm::Value *Callee,
|
||||
llvm::ArrayRef<llvm::Value *> Args,
|
||||
const llvm::Twine &Name) {
|
||||
const Twine &Name) {
|
||||
llvm::BasicBlock *InvokeDest = getInvokeDest();
|
||||
if (!InvokeDest)
|
||||
return Builder.CreateCall(Callee, Args, Name);
|
||||
|
@ -1446,7 +1446,7 @@ CodeGenFunction::EmitCallOrInvoke(llvm::Value *Callee,
|
|||
|
||||
llvm::CallSite
|
||||
CodeGenFunction::EmitCallOrInvoke(llvm::Value *Callee,
|
||||
const llvm::Twine &Name) {
|
||||
const Twine &Name) {
|
||||
return EmitCallOrInvoke(Callee, llvm::ArrayRef<llvm::Value *>(), Name);
|
||||
}
|
||||
|
||||
|
@ -1460,7 +1460,7 @@ static void checkArgMatches(llvm::Value *Elt, unsigned &ArgNo,
|
|||
}
|
||||
|
||||
void CodeGenFunction::ExpandTypeToArgs(QualType Ty, RValue RV,
|
||||
llvm::SmallVector<llvm::Value*,16> &Args,
|
||||
SmallVector<llvm::Value*,16> &Args,
|
||||
llvm::FunctionType *IRFuncTy) {
|
||||
const RecordType *RT = Ty->getAsStructureType();
|
||||
assert(RT && "Can only expand structure types.");
|
||||
|
@ -1503,7 +1503,7 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,
|
|||
const Decl *TargetDecl,
|
||||
llvm::Instruction **callOrInvoke) {
|
||||
// FIXME: We no longer need the types from CallArgs; lift up and simplify.
|
||||
llvm::SmallVector<llvm::Value*, 16> Args;
|
||||
SmallVector<llvm::Value*, 16> Args;
|
||||
|
||||
// Handle struct-return functions by passing a pointer to the
|
||||
// location that we would like to return into.
|
||||
|
|
|
@ -729,7 +729,7 @@ void CodeGenFunction::EmitCtorPrologue(const CXXConstructorDecl *CD,
|
|||
|
||||
const CXXRecordDecl *ClassDecl = CD->getParent();
|
||||
|
||||
llvm::SmallVector<CXXCtorInitializer *, 8> MemberInitializers;
|
||||
SmallVector<CXXCtorInitializer *, 8> MemberInitializers;
|
||||
|
||||
for (CXXConstructorDecl::init_const_iterator B = CD->init_begin(),
|
||||
E = CD->init_end();
|
||||
|
@ -1018,7 +1018,7 @@ void CodeGenFunction::EnterDtorCleanups(const CXXDestructorDecl *DD,
|
|||
}
|
||||
|
||||
// Destroy direct fields.
|
||||
llvm::SmallVector<const FieldDecl *, 16> FieldDecls;
|
||||
SmallVector<const FieldDecl *, 16> FieldDecls;
|
||||
for (CXXRecordDecl::field_iterator I = ClassDecl->field_begin(),
|
||||
E = ClassDecl->field_end(); I != E; ++I) {
|
||||
const FieldDecl *field = *I;
|
||||
|
|
|
@ -583,7 +583,7 @@ void CodeGenFunction::PopCleanupBlock(bool FallthroughIsBranchThrough) {
|
|||
// Copy the cleanup emission data out. Note that SmallVector
|
||||
// guarantees maximal alignment for its buffer regardless of its
|
||||
// type parameter.
|
||||
llvm::SmallVector<char, 8*sizeof(void*)> CleanupBuffer;
|
||||
SmallVector<char, 8*sizeof(void*)> CleanupBuffer;
|
||||
CleanupBuffer.reserve(Scope.getCleanupSize());
|
||||
memcpy(CleanupBuffer.data(),
|
||||
Scope.getCleanupBuffer(), Scope.getCleanupSize());
|
||||
|
@ -595,7 +595,7 @@ void CodeGenFunction::PopCleanupBlock(bool FallthroughIsBranchThrough) {
|
|||
// ahead and do the setup for the EH cleanup while the scope is still
|
||||
// alive.
|
||||
llvm::BasicBlock *EHEntry = 0;
|
||||
llvm::SmallVector<llvm::Instruction*, 2> EHInstsToAppend;
|
||||
SmallVector<llvm::Instruction*, 2> EHInstsToAppend;
|
||||
if (RequiresEHCleanup) {
|
||||
EHEntry = CreateEHEntry(*this, Scope);
|
||||
|
||||
|
@ -716,7 +716,7 @@ void CodeGenFunction::PopCleanupBlock(bool FallthroughIsBranchThrough) {
|
|||
}
|
||||
|
||||
llvm::BasicBlock *FallthroughDest = 0;
|
||||
llvm::SmallVector<llvm::Instruction*, 2> InstsToAppend;
|
||||
SmallVector<llvm::Instruction*, 2> InstsToAppend;
|
||||
|
||||
// If there's exactly one branch-after and no other threads,
|
||||
// we can route it without a switch.
|
||||
|
|
|
@ -81,7 +81,7 @@ llvm::DIDescriptor CGDebugInfo::getContextDescriptor(const Decl *Context) {
|
|||
/// getFunctionName - Get function name for the given FunctionDecl. If the
|
||||
/// name is constructred on demand (e.g. C++ destructor) then the name
|
||||
/// is stored on the side.
|
||||
llvm::StringRef CGDebugInfo::getFunctionName(const FunctionDecl *FD) {
|
||||
StringRef CGDebugInfo::getFunctionName(const FunctionDecl *FD) {
|
||||
assert (FD && "Invalid FunctionDecl!");
|
||||
IdentifierInfo *FII = FD->getIdentifier();
|
||||
if (FII)
|
||||
|
@ -93,10 +93,10 @@ llvm::StringRef CGDebugInfo::getFunctionName(const FunctionDecl *FD) {
|
|||
// Copy this name on the side and use its reference.
|
||||
char *StrPtr = DebugInfoNames.Allocate<char>(NS.length());
|
||||
memcpy(StrPtr, NS.data(), NS.length());
|
||||
return llvm::StringRef(StrPtr, NS.length());
|
||||
return StringRef(StrPtr, NS.length());
|
||||
}
|
||||
|
||||
llvm::StringRef CGDebugInfo::getObjCMethodName(const ObjCMethodDecl *OMD) {
|
||||
StringRef CGDebugInfo::getObjCMethodName(const ObjCMethodDecl *OMD) {
|
||||
llvm::SmallString<256> MethodName;
|
||||
llvm::raw_svector_ostream OS(MethodName);
|
||||
OS << (OMD->isInstanceMethod() ? '-' : '+') << '[';
|
||||
|
@ -116,22 +116,22 @@ llvm::StringRef CGDebugInfo::getObjCMethodName(const ObjCMethodDecl *OMD) {
|
|||
|
||||
char *StrPtr = DebugInfoNames.Allocate<char>(OS.tell());
|
||||
memcpy(StrPtr, MethodName.begin(), OS.tell());
|
||||
return llvm::StringRef(StrPtr, OS.tell());
|
||||
return StringRef(StrPtr, OS.tell());
|
||||
}
|
||||
|
||||
/// getSelectorName - Return selector name. This is used for debugging
|
||||
/// info.
|
||||
llvm::StringRef CGDebugInfo::getSelectorName(Selector S) {
|
||||
StringRef CGDebugInfo::getSelectorName(Selector S) {
|
||||
llvm::SmallString<256> SName;
|
||||
llvm::raw_svector_ostream OS(SName);
|
||||
OS << S.getAsString();
|
||||
char *StrPtr = DebugInfoNames.Allocate<char>(OS.tell());
|
||||
memcpy(StrPtr, SName.begin(), OS.tell());
|
||||
return llvm::StringRef(StrPtr, OS.tell());
|
||||
return StringRef(StrPtr, OS.tell());
|
||||
}
|
||||
|
||||
/// getClassName - Get class name including template argument list.
|
||||
llvm::StringRef
|
||||
StringRef
|
||||
CGDebugInfo::getClassName(RecordDecl *RD) {
|
||||
ClassTemplateSpecializationDecl *Spec
|
||||
= dyn_cast<ClassTemplateSpecializationDecl>(RD);
|
||||
|
@ -160,7 +160,7 @@ CGDebugInfo::getClassName(RecordDecl *RD) {
|
|||
// Copy this name on the side and use its reference.
|
||||
char *StrPtr = DebugInfoNames.Allocate<char>(Buffer.length());
|
||||
memcpy(StrPtr, Buffer.data(), Buffer.length());
|
||||
return llvm::StringRef(StrPtr, Buffer.length());
|
||||
return StringRef(StrPtr, Buffer.length());
|
||||
}
|
||||
|
||||
/// getOrCreateFile - Get the file debug info descriptor for the input location.
|
||||
|
@ -172,7 +172,7 @@ llvm::DIFile CGDebugInfo::getOrCreateFile(SourceLocation Loc) {
|
|||
SourceManager &SM = CGM.getContext().getSourceManager();
|
||||
PresumedLoc PLoc = SM.getPresumedLoc(Loc);
|
||||
|
||||
if (PLoc.isInvalid() || llvm::StringRef(PLoc.getFilename()).empty())
|
||||
if (PLoc.isInvalid() || StringRef(PLoc.getFilename()).empty())
|
||||
// If the location is not valid then use main input file.
|
||||
return DBuilder.createFile(TheCU.getFilename(), TheCU.getDirectory());
|
||||
|
||||
|
@ -217,14 +217,14 @@ unsigned CGDebugInfo::getColumnNumber(SourceLocation Loc) {
|
|||
return PLoc.isValid()? PLoc.getColumn() : 0;
|
||||
}
|
||||
|
||||
llvm::StringRef CGDebugInfo::getCurrentDirname() {
|
||||
StringRef CGDebugInfo::getCurrentDirname() {
|
||||
if (!CWDName.empty())
|
||||
return CWDName;
|
||||
char *CompDirnamePtr = NULL;
|
||||
llvm::sys::Path CWD = llvm::sys::Path::GetCurrentDirectory();
|
||||
CompDirnamePtr = DebugInfoNames.Allocate<char>(CWD.size());
|
||||
memcpy(CompDirnamePtr, CWD.c_str(), CWD.size());
|
||||
return CWDName = llvm::StringRef(CompDirnamePtr, CWD.size());
|
||||
return CWDName = StringRef(CompDirnamePtr, CWD.size());
|
||||
}
|
||||
|
||||
/// CreateCompileUnit - Create new compile unit.
|
||||
|
@ -250,7 +250,7 @@ void CGDebugInfo::CreateCompileUnit() {
|
|||
// Save filename string.
|
||||
char *FilenamePtr = DebugInfoNames.Allocate<char>(MainFileName.length());
|
||||
memcpy(FilenamePtr, MainFileName.c_str(), MainFileName.length());
|
||||
llvm::StringRef Filename(FilenamePtr, MainFileName.length());
|
||||
StringRef Filename(FilenamePtr, MainFileName.length());
|
||||
|
||||
unsigned LangTag;
|
||||
const LangOptions &LO = CGM.getLangOptions();
|
||||
|
@ -312,7 +312,7 @@ llvm::DIType CGDebugInfo::CreateType(const BuiltinType *BT) {
|
|||
|
||||
llvm::DIType ISATy = DBuilder.createPointerType(OCTy, Size);
|
||||
|
||||
llvm::SmallVector<llvm::Value *, 16> EltTys;
|
||||
SmallVector<llvm::Value *, 16> EltTys;
|
||||
llvm::DIType FieldTy =
|
||||
DBuilder.createMemberType(getOrCreateMainFile(), "isa",
|
||||
getOrCreateMainFile(), 0, Size,
|
||||
|
@ -489,7 +489,7 @@ llvm::DIType CGDebugInfo::CreateType(const BlockPointerType *Ty,
|
|||
if (BlockLiteralGenericSet)
|
||||
return BlockLiteralGeneric;
|
||||
|
||||
llvm::SmallVector<llvm::Value *, 8> EltTys;
|
||||
SmallVector<llvm::Value *, 8> EltTys;
|
||||
llvm::DIType FieldTy;
|
||||
QualType FType;
|
||||
uint64_t FieldSize, FieldOffset;
|
||||
|
@ -567,7 +567,7 @@ llvm::DIType CGDebugInfo::CreateType(const TypedefType *Ty,
|
|||
|
||||
llvm::DIType CGDebugInfo::CreateType(const FunctionType *Ty,
|
||||
llvm::DIFile Unit) {
|
||||
llvm::SmallVector<llvm::Value *, 16> EltTys;
|
||||
SmallVector<llvm::Value *, 16> EltTys;
|
||||
|
||||
// Add the result type at least.
|
||||
EltTys.push_back(getOrCreateType(Ty->getResultType(), Unit));
|
||||
|
@ -587,7 +587,7 @@ llvm::DIType CGDebugInfo::CreateType(const FunctionType *Ty,
|
|||
return DbgTy;
|
||||
}
|
||||
|
||||
llvm::DIType CGDebugInfo::createFieldType(llvm::StringRef name,
|
||||
llvm::DIType CGDebugInfo::createFieldType(StringRef name,
|
||||
QualType type,
|
||||
Expr *bitWidth,
|
||||
SourceLocation loc,
|
||||
|
@ -624,7 +624,7 @@ llvm::DIType CGDebugInfo::createFieldType(llvm::StringRef name,
|
|||
/// record fields. This is used while creating debug info entry for a Record.
|
||||
void CGDebugInfo::
|
||||
CollectRecordFields(const RecordDecl *record, llvm::DIFile tunit,
|
||||
llvm::SmallVectorImpl<llvm::Value *> &elements,
|
||||
SmallVectorImpl<llvm::Value *> &elements,
|
||||
llvm::DIType RecordTy) {
|
||||
unsigned fieldNo = 0;
|
||||
const FieldDecl *LastFD = 0;
|
||||
|
@ -644,7 +644,7 @@ CollectRecordFields(const RecordDecl *record, llvm::DIFile tunit,
|
|||
LastFD = field;
|
||||
}
|
||||
|
||||
llvm::StringRef name = field->getName();
|
||||
StringRef name = field->getName();
|
||||
QualType type = field->getType();
|
||||
|
||||
// Ignore unnamed fields unless they're anonymous structs/unions.
|
||||
|
@ -678,7 +678,7 @@ CGDebugInfo::getOrCreateMethodType(const CXXMethodDecl *Method,
|
|||
llvm::DIArray Args = llvm::DICompositeType(FnTy).getTypeArray();
|
||||
assert (Args.getNumElements() && "Invalid number of arguments!");
|
||||
|
||||
llvm::SmallVector<llvm::Value *, 16> Elts;
|
||||
SmallVector<llvm::Value *, 16> Elts;
|
||||
|
||||
// First element is always return type. For 'void' functions it is NULL.
|
||||
Elts.push_back(Args.getElement(0));
|
||||
|
@ -723,12 +723,12 @@ CGDebugInfo::CreateCXXMemberFunction(const CXXMethodDecl *Method,
|
|||
bool IsCtorOrDtor =
|
||||
isa<CXXConstructorDecl>(Method) || isa<CXXDestructorDecl>(Method);
|
||||
|
||||
llvm::StringRef MethodName = getFunctionName(Method);
|
||||
StringRef MethodName = getFunctionName(Method);
|
||||
llvm::DIType MethodTy = getOrCreateMethodType(Method, Unit);
|
||||
|
||||
// Since a single ctor/dtor corresponds to multiple functions, it doesn't
|
||||
// make sense to give a single ctor/dtor a linkage name.
|
||||
llvm::StringRef MethodLinkageName;
|
||||
StringRef MethodLinkageName;
|
||||
if (!IsCtorOrDtor && !isFunctionLocalClass(Method->getParent()))
|
||||
MethodLinkageName = CGM.getMangledName(Method);
|
||||
|
||||
|
@ -791,7 +791,7 @@ CGDebugInfo::CreateCXXMemberFunction(const CXXMethodDecl *Method,
|
|||
/// a Record.
|
||||
void CGDebugInfo::
|
||||
CollectCXXMemberFunctions(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
||||
llvm::SmallVectorImpl<llvm::Value *> &EltTys,
|
||||
SmallVectorImpl<llvm::Value *> &EltTys,
|
||||
llvm::DIType RecordTy) {
|
||||
for(CXXRecordDecl::method_iterator I = RD->method_begin(),
|
||||
E = RD->method_end(); I != E; ++I) {
|
||||
|
@ -809,7 +809,7 @@ CollectCXXMemberFunctions(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
|||
/// a Record.
|
||||
void CGDebugInfo::
|
||||
CollectCXXFriends(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
||||
llvm::SmallVectorImpl<llvm::Value *> &EltTys,
|
||||
SmallVectorImpl<llvm::Value *> &EltTys,
|
||||
llvm::DIType RecordTy) {
|
||||
|
||||
for (CXXRecordDecl::friend_iterator BI = RD->friend_begin(),
|
||||
|
@ -826,7 +826,7 @@ CollectCXXFriends(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
|||
/// a Record.
|
||||
void CGDebugInfo::
|
||||
CollectCXXBases(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
||||
llvm::SmallVectorImpl<llvm::Value *> &EltTys,
|
||||
SmallVectorImpl<llvm::Value *> &EltTys,
|
||||
llvm::DIType RecordTy) {
|
||||
|
||||
const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
|
||||
|
@ -868,7 +868,7 @@ llvm::DIArray CGDebugInfo::
|
|||
CollectTemplateParams(const TemplateParameterList *TPList,
|
||||
const TemplateArgumentList &TAList,
|
||||
llvm::DIFile Unit) {
|
||||
llvm::SmallVector<llvm::Value *, 16> TemplateParams;
|
||||
SmallVector<llvm::Value *, 16> TemplateParams;
|
||||
for (unsigned i = 0, e = TAList.size(); i != e; ++i) {
|
||||
const TemplateArgument &TA = TAList[i];
|
||||
const NamedDecl *ND = TPList->getParam(i);
|
||||
|
@ -936,14 +936,14 @@ llvm::DIType CGDebugInfo::getOrCreateVTablePtrType(llvm::DIFile Unit) {
|
|||
}
|
||||
|
||||
/// getVTableName - Get vtable name for the given Class.
|
||||
llvm::StringRef CGDebugInfo::getVTableName(const CXXRecordDecl *RD) {
|
||||
StringRef CGDebugInfo::getVTableName(const CXXRecordDecl *RD) {
|
||||
// Otherwise construct gdb compatible name name.
|
||||
std::string Name = "_vptr$" + RD->getNameAsString();
|
||||
|
||||
// Copy this name on the side and use its reference.
|
||||
char *StrPtr = DebugInfoNames.Allocate<char>(Name.length());
|
||||
memcpy(StrPtr, Name.data(), Name.length());
|
||||
return llvm::StringRef(StrPtr, Name.length());
|
||||
return StringRef(StrPtr, Name.length());
|
||||
}
|
||||
|
||||
|
||||
|
@ -951,7 +951,7 @@ llvm::StringRef CGDebugInfo::getVTableName(const CXXRecordDecl *RD) {
|
|||
/// debug info entry in EltTys vector.
|
||||
void CGDebugInfo::
|
||||
CollectVTableInfo(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
||||
llvm::SmallVectorImpl<llvm::Value *> &EltTys) {
|
||||
SmallVectorImpl<llvm::Value *> &EltTys) {
|
||||
const ASTRecordLayout &RL = CGM.getContext().getASTRecordLayout(RD);
|
||||
|
||||
// If there is a primary base then it will hold vtable info.
|
||||
|
@ -1020,7 +1020,7 @@ llvm::DIType CGDebugInfo::CreateType(const RecordType *Ty) {
|
|||
RegionMap[Ty->getDecl()] = llvm::WeakVH(FwdDecl);
|
||||
|
||||
// Convert all the elements.
|
||||
llvm::SmallVector<llvm::Value *, 16> EltTys;
|
||||
SmallVector<llvm::Value *, 16> EltTys;
|
||||
|
||||
const CXXRecordDecl *CXXDecl = dyn_cast<CXXRecordDecl>(RD);
|
||||
if (CXXDecl) {
|
||||
|
@ -1040,7 +1040,7 @@ llvm::DIType CGDebugInfo::CreateType(const RecordType *Ty) {
|
|||
|
||||
// Create the descriptor for static variable.
|
||||
llvm::DIFile VUnit = getOrCreateFile(V->getLocation());
|
||||
llvm::StringRef VName = V->getName();
|
||||
StringRef VName = V->getName();
|
||||
llvm::DIType VTy = getOrCreateType(V->getType(), VUnit);
|
||||
// Do not use DIGlobalVariable for enums.
|
||||
if (VTy.getTag() != llvm::dwarf::DW_TAG_enumeration_type) {
|
||||
|
@ -1070,7 +1070,7 @@ llvm::DIType CGDebugInfo::CreateType(const RecordType *Ty) {
|
|||
|
||||
llvm::DIDescriptor RDContext =
|
||||
getContextDescriptor(cast<Decl>(RD->getDeclContext()));
|
||||
llvm::StringRef RDName = RD->getName();
|
||||
StringRef RDName = RD->getName();
|
||||
uint64_t Size = CGM.getContext().getTypeSize(Ty);
|
||||
uint64_t Align = CGM.getContext().getTypeAlign(Ty);
|
||||
llvm::DIArray Elements = DBuilder.getOrCreateArray(EltTys);
|
||||
|
@ -1162,7 +1162,7 @@ llvm::DIType CGDebugInfo::CreateType(const ObjCInterfaceType *Ty,
|
|||
RegionMap[Ty->getDecl()] = llvm::WeakVH(FwdDecl);
|
||||
|
||||
// Convert all the elements.
|
||||
llvm::SmallVector<llvm::Value *, 16> EltTys;
|
||||
SmallVector<llvm::Value *, 16> EltTys;
|
||||
|
||||
ObjCInterfaceDecl *SClass = ID->getSuperClass();
|
||||
if (SClass) {
|
||||
|
@ -1185,7 +1185,7 @@ llvm::DIType CGDebugInfo::CreateType(const ObjCInterfaceType *Ty,
|
|||
if (!FieldTy.isValid())
|
||||
return llvm::DIType();
|
||||
|
||||
llvm::StringRef FieldName = Field->getName();
|
||||
StringRef FieldName = Field->getName();
|
||||
|
||||
// Ignore unnamed fields.
|
||||
if (FieldName.empty())
|
||||
|
@ -1217,9 +1217,9 @@ llvm::DIType CGDebugInfo::CreateType(const ObjCInterfaceType *Ty,
|
|||
else if (Field->getAccessControl() == ObjCIvarDecl::Private)
|
||||
Flags = llvm::DIDescriptor::FlagPrivate;
|
||||
|
||||
llvm::StringRef PropertyName;
|
||||
llvm::StringRef PropertyGetter;
|
||||
llvm::StringRef PropertySetter;
|
||||
StringRef PropertyName;
|
||||
StringRef PropertyGetter;
|
||||
StringRef PropertySetter;
|
||||
unsigned PropertyAttributes = 0;
|
||||
if (ObjCPropertyDecl *PD =
|
||||
ID->FindPropertyVisibleInPrimaryClass(Field->getIdentifier())) {
|
||||
|
@ -1322,7 +1322,7 @@ llvm::DIType CGDebugInfo::CreateType(const ArrayType *Ty,
|
|||
// Add the dimensions of the array. FIXME: This loses CV qualifiers from
|
||||
// interior arrays, do we care? Why aren't nested arrays represented the
|
||||
// obvious/recursive way?
|
||||
llvm::SmallVector<llvm::Value *, 8> Subscripts;
|
||||
SmallVector<llvm::Value *, 8> Subscripts;
|
||||
QualType EltTy(Ty, 0);
|
||||
if (Ty->isIncompleteArrayType())
|
||||
EltTy = Ty->getElementType();
|
||||
|
@ -1395,7 +1395,7 @@ llvm::DIType CGDebugInfo::CreateType(const MemberPointerType *Ty,
|
|||
|
||||
llvm::DIArray Elements = DBuilder.getOrCreateArray(ElementTypes);
|
||||
|
||||
return DBuilder.createStructType(U, llvm::StringRef("test"),
|
||||
return DBuilder.createStructType(U, StringRef("test"),
|
||||
U, 0, FieldOffset,
|
||||
0, 0, Elements);
|
||||
}
|
||||
|
@ -1403,7 +1403,7 @@ llvm::DIType CGDebugInfo::CreateType(const MemberPointerType *Ty,
|
|||
/// CreateEnumType - get enumeration type.
|
||||
llvm::DIType CGDebugInfo::CreateEnumType(const EnumDecl *ED) {
|
||||
llvm::DIFile Unit = getOrCreateFile(ED->getLocation());
|
||||
llvm::SmallVector<llvm::Value *, 16> Enumerators;
|
||||
SmallVector<llvm::Value *, 16> Enumerators;
|
||||
|
||||
// Create DIEnumerator elements for each enumerator.
|
||||
for (EnumDecl::enumerator_iterator
|
||||
|
@ -1582,7 +1582,7 @@ llvm::DIType CGDebugInfo::CreateTypeNode(QualType Ty,
|
|||
|
||||
/// CreateMemberType - Create new member and increase Offset by FType's size.
|
||||
llvm::DIType CGDebugInfo::CreateMemberType(llvm::DIFile Unit, QualType FType,
|
||||
llvm::StringRef Name,
|
||||
StringRef Name,
|
||||
uint64_t *Offset) {
|
||||
llvm::DIType FieldTy = CGDebugInfo::getOrCreateType(FType, Unit);
|
||||
uint64_t FieldSize = CGM.getContext().getTypeSize(FType);
|
||||
|
@ -1633,7 +1633,7 @@ llvm::DIType CGDebugInfo::getOrCreateFunctionType(const Decl * D, QualType FnTyp
|
|||
return getOrCreateMethodType(Method, F);
|
||||
else if (const ObjCMethodDecl *OMethod = dyn_cast<ObjCMethodDecl>(D)) {
|
||||
// Add "self" and "_cmd"
|
||||
llvm::SmallVector<llvm::Value *, 16> Elts;
|
||||
SmallVector<llvm::Value *, 16> Elts;
|
||||
|
||||
// First element is always return type. For 'void' functions it is NULL.
|
||||
Elts.push_back(getOrCreateType(OMethod->getResultType(), F));
|
||||
|
@ -1658,8 +1658,8 @@ void CGDebugInfo::EmitFunctionStart(GlobalDecl GD, QualType FnType,
|
|||
llvm::Function *Fn,
|
||||
CGBuilderTy &Builder) {
|
||||
|
||||
llvm::StringRef Name;
|
||||
llvm::StringRef LinkageName;
|
||||
StringRef Name;
|
||||
StringRef LinkageName;
|
||||
|
||||
FnBeginRegionCount.push_back(RegionStack.size());
|
||||
|
||||
|
@ -1687,7 +1687,7 @@ void CGDebugInfo::EmitFunctionStart(GlobalDecl GD, QualType FnType,
|
|||
if (!Fn->hasInternalLinkage())
|
||||
LinkageName = CGM.getMangledName(GD);
|
||||
if (LinkageName == Name)
|
||||
LinkageName = llvm::StringRef();
|
||||
LinkageName = StringRef();
|
||||
if (FD->hasPrototype())
|
||||
Flags |= llvm::DIDescriptor::FlagPrototyped;
|
||||
if (const NamespaceDecl *NSDecl =
|
||||
|
@ -1847,7 +1847,7 @@ void CGDebugInfo::EmitFunctionEnd(CGBuilderTy &Builder) {
|
|||
llvm::DIType CGDebugInfo::EmitTypeForVarWithBlocksAttr(const ValueDecl *VD,
|
||||
uint64_t *XOffset) {
|
||||
|
||||
llvm::SmallVector<llvm::Value *, 5> EltTys;
|
||||
SmallVector<llvm::Value *, 5> EltTys;
|
||||
QualType FType;
|
||||
uint64_t FieldSize, FieldOffset;
|
||||
unsigned FieldAlign;
|
||||
|
@ -1951,11 +1951,11 @@ void CGDebugInfo::EmitDeclare(const VarDecl *VD, unsigned Tag,
|
|||
Flags |= llvm::DIDescriptor::FlagArtificial;
|
||||
llvm::MDNode *Scope = RegionStack.back();
|
||||
|
||||
llvm::StringRef Name = VD->getName();
|
||||
StringRef Name = VD->getName();
|
||||
if (!Name.empty()) {
|
||||
if (VD->hasAttr<BlocksAttr>()) {
|
||||
CharUnits offset = CharUnits::fromQuantity(32);
|
||||
llvm::SmallVector<llvm::Value *, 9> addr;
|
||||
SmallVector<llvm::Value *, 9> addr;
|
||||
llvm::Type *Int64Ty = llvm::Type::getInt64Ty(CGM.getLLVMContext());
|
||||
addr.push_back(llvm::ConstantInt::get(Int64Ty, llvm::DIBuilder::OpPlus));
|
||||
// offset of __forwarding field
|
||||
|
@ -2006,7 +2006,7 @@ void CGDebugInfo::EmitDeclare(const VarDecl *VD, unsigned Tag,
|
|||
I != E; ++I) {
|
||||
FieldDecl *Field = *I;
|
||||
llvm::DIType FieldTy = getOrCreateType(Field->getType(), Unit);
|
||||
llvm::StringRef FieldName = Field->getName();
|
||||
StringRef FieldName = Field->getName();
|
||||
|
||||
// Ignore unnamed fields. Do not ignore unnamed records.
|
||||
if (FieldName.empty() && !isa<RecordType>(Field->getType()))
|
||||
|
@ -2063,7 +2063,7 @@ void CGDebugInfo::EmitDeclareOfBlockDeclRefVariable(
|
|||
target.getStructLayout(blockInfo.StructureType)
|
||||
->getElementOffset(blockInfo.getCapture(VD).getIndex()));
|
||||
|
||||
llvm::SmallVector<llvm::Value *, 9> addr;
|
||||
SmallVector<llvm::Value *, 9> addr;
|
||||
llvm::Type *Int64Ty = llvm::Type::getInt64Ty(CGM.getLLVMContext());
|
||||
addr.push_back(llvm::ConstantInt::get(Int64Ty, llvm::DIBuilder::OpPlus));
|
||||
addr.push_back(llvm::ConstantInt::get(Int64Ty, offset.getQuantity()));
|
||||
|
@ -2129,7 +2129,7 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
|||
const llvm::StructLayout *blockLayout =
|
||||
CGM.getTargetData().getStructLayout(block.StructureType);
|
||||
|
||||
llvm::SmallVector<llvm::Value*, 16> fields;
|
||||
SmallVector<llvm::Value*, 16> fields;
|
||||
fields.push_back(createFieldType("__isa", C.VoidPtrTy, 0, loc, AS_public,
|
||||
blockLayout->getElementOffsetInBits(0),
|
||||
tunit, tunit));
|
||||
|
@ -2152,7 +2152,7 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
|||
|
||||
// We want to sort the captures by offset, not because DWARF
|
||||
// requires this, but because we're paranoid about debuggers.
|
||||
llvm::SmallVector<BlockLayoutChunk, 8> chunks;
|
||||
SmallVector<BlockLayoutChunk, 8> chunks;
|
||||
|
||||
// 'this' capture.
|
||||
if (blockDecl->capturesCXXThis()) {
|
||||
|
@ -2185,7 +2185,7 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
|||
// Sort by offset.
|
||||
llvm::array_pod_sort(chunks.begin(), chunks.end());
|
||||
|
||||
for (llvm::SmallVectorImpl<BlockLayoutChunk>::iterator
|
||||
for (SmallVectorImpl<BlockLayoutChunk>::iterator
|
||||
i = chunks.begin(), e = chunks.end(); i != e; ++i) {
|
||||
uint64_t offsetInBits = i->OffsetInBits;
|
||||
const BlockDecl::Capture *capture = i->Capture;
|
||||
|
@ -2202,7 +2202,7 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
|||
}
|
||||
|
||||
const VarDecl *variable = capture->getVariable();
|
||||
llvm::StringRef name = variable->getName();
|
||||
StringRef name = variable->getName();
|
||||
|
||||
llvm::DIType fieldType;
|
||||
if (capture->isByRef()) {
|
||||
|
@ -2238,7 +2238,7 @@ void CGDebugInfo::EmitDeclareOfBlockLiteralArgVariable(const CGBlockInfo &block,
|
|||
// Get overall information about the block.
|
||||
unsigned flags = llvm::DIDescriptor::FlagArtificial;
|
||||
llvm::MDNode *scope = RegionStack.back();
|
||||
llvm::StringRef name = ".block_descriptor";
|
||||
StringRef name = ".block_descriptor";
|
||||
|
||||
// Create the descriptor for the parameter.
|
||||
llvm::DIVariable debugVar =
|
||||
|
@ -2275,13 +2275,13 @@ void CGDebugInfo::EmitGlobalVariable(llvm::GlobalVariable *Var,
|
|||
T = CGM.getContext().getConstantArrayType(ET, ConstVal,
|
||||
ArrayType::Normal, 0);
|
||||
}
|
||||
llvm::StringRef DeclName = D->getName();
|
||||
llvm::StringRef LinkageName;
|
||||
StringRef DeclName = D->getName();
|
||||
StringRef LinkageName;
|
||||
if (D->getDeclContext() && !isa<FunctionDecl>(D->getDeclContext())
|
||||
&& !isa<ObjCMethodDecl>(D->getDeclContext()))
|
||||
LinkageName = Var->getName();
|
||||
if (LinkageName == DeclName)
|
||||
LinkageName = llvm::StringRef();
|
||||
LinkageName = StringRef();
|
||||
llvm::DIDescriptor DContext =
|
||||
getContextDescriptor(dyn_cast<Decl>(D->getDeclContext()));
|
||||
DBuilder.createStaticVariable(DContext, DeclName, LinkageName,
|
||||
|
@ -2296,7 +2296,7 @@ void CGDebugInfo::EmitGlobalVariable(llvm::GlobalVariable *Var,
|
|||
llvm::DIFile Unit = getOrCreateFile(ID->getLocation());
|
||||
unsigned LineNo = getLineNumber(ID->getLocation());
|
||||
|
||||
llvm::StringRef Name = ID->getName();
|
||||
StringRef Name = ID->getName();
|
||||
|
||||
QualType T = CGM.getContext().getObjCInterfaceType(ID);
|
||||
if (T->isIncompleteArrayType()) {
|
||||
|
@ -2321,7 +2321,7 @@ void CGDebugInfo::EmitGlobalVariable(const ValueDecl *VD,
|
|||
llvm::Constant *Init) {
|
||||
// Create the descriptor for the variable.
|
||||
llvm::DIFile Unit = getOrCreateFile(VD->getLocation());
|
||||
llvm::StringRef Name = VD->getName();
|
||||
StringRef Name = VD->getName();
|
||||
llvm::DIType Ty = getOrCreateType(VD->getType(), Unit);
|
||||
if (const EnumConstantDecl *ECD = dyn_cast<EnumConstantDecl>(VD)) {
|
||||
if (const EnumDecl *ED = dyn_cast<EnumDecl>(ECD->getDeclContext()))
|
||||
|
|
|
@ -139,7 +139,7 @@ static std::string GetStaticDeclName(CodeGenFunction &CGF, const VarDecl &D,
|
|||
const char *Separator) {
|
||||
CodeGenModule &CGM = CGF.CGM;
|
||||
if (CGF.getContext().getLangOptions().CPlusPlus) {
|
||||
llvm::StringRef Name = CGM.getMangledName(&D);
|
||||
StringRef Name = CGM.getMangledName(&D);
|
||||
return Name.str();
|
||||
}
|
||||
|
||||
|
@ -156,7 +156,7 @@ static std::string GetStaticDeclName(CodeGenFunction &CGF, const VarDecl &D,
|
|||
else
|
||||
assert(0 && "Unknown context for block static var decl");
|
||||
} else if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(CGF.CurFuncDecl)) {
|
||||
llvm::StringRef Name = CGM.getMangledName(FD);
|
||||
StringRef Name = CGM.getMangledName(FD);
|
||||
ContextName = Name.str();
|
||||
} else if (isa<ObjCMethodDecl>(CGF.CurFuncDecl))
|
||||
ContextName = CGF.CurFn->getName();
|
||||
|
@ -1267,7 +1267,7 @@ static void emitPartialArrayDestroy(CodeGenFunction &CGF,
|
|||
if (arrayDepth) {
|
||||
llvm::Value *zero = llvm::ConstantInt::get(CGF.SizeTy, arrayDepth+1);
|
||||
|
||||
llvm::SmallVector<llvm::Value*,4> gepIndices(arrayDepth, zero);
|
||||
SmallVector<llvm::Value*,4> gepIndices(arrayDepth, zero);
|
||||
begin = CGF.Builder.CreateInBoundsGEP(begin, gepIndices, "pad.arraybegin");
|
||||
end = CGF.Builder.CreateInBoundsGEP(end, gepIndices, "pad.arrayend");
|
||||
}
|
||||
|
|
|
@ -168,7 +168,7 @@ void CodeGenFunction::EmitCXXGuardedInit(const VarDecl &D,
|
|||
static llvm::Function *
|
||||
CreateGlobalInitOrDestructFunction(CodeGenModule &CGM,
|
||||
llvm::FunctionType *FTy,
|
||||
llvm::StringRef Name) {
|
||||
StringRef Name) {
|
||||
llvm::Function *Fn =
|
||||
llvm::Function::Create(FTy, llvm::GlobalValue::InternalLinkage,
|
||||
Name, &CGM.getModule());
|
||||
|
@ -234,7 +234,7 @@ CodeGenModule::EmitCXXGlobalInitFunc() {
|
|||
CreateGlobalInitOrDestructFunction(*this, FTy, "_GLOBAL__I_a");
|
||||
|
||||
if (!PrioritizedCXXGlobalInits.empty()) {
|
||||
llvm::SmallVector<llvm::Constant*, 8> LocalCXXGlobalInits;
|
||||
SmallVector<llvm::Constant*, 8> LocalCXXGlobalInits;
|
||||
llvm::array_pod_sort(PrioritizedCXXGlobalInits.begin(),
|
||||
PrioritizedCXXGlobalInits.end());
|
||||
for (unsigned i = 0; i < PrioritizedCXXGlobalInits.size(); i++) {
|
||||
|
|
|
@ -131,7 +131,7 @@ static llvm::Constant *getTerminateFn(CodeGenFunction &CGF) {
|
|||
llvm::FunctionType *FTy =
|
||||
llvm::FunctionType::get(CGF.VoidTy, /*IsVarArgs=*/false);
|
||||
|
||||
llvm::StringRef name;
|
||||
StringRef name;
|
||||
|
||||
// In C++, use std::terminate().
|
||||
if (CGF.getLangOptions().CPlusPlus)
|
||||
|
@ -145,7 +145,7 @@ static llvm::Constant *getTerminateFn(CodeGenFunction &CGF) {
|
|||
}
|
||||
|
||||
static llvm::Constant *getCatchallRethrowFn(CodeGenFunction &CGF,
|
||||
llvm::StringRef Name) {
|
||||
StringRef Name) {
|
||||
llvm::Type *ArgTys[] = { CGF.Int8PtrTy };
|
||||
llvm::FunctionType *FTy =
|
||||
llvm::FunctionType::get(CGF.VoidTy, ArgTys, /*IsVarArgs=*/false);
|
||||
|
@ -665,7 +665,7 @@ llvm::BasicBlock *CodeGenFunction::EmitLandingPad() {
|
|||
Builder.CreateStore(Exn, getExceptionSlot());
|
||||
|
||||
// Build the selector arguments.
|
||||
llvm::SmallVector<llvm::Value*, 8> EHSelector;
|
||||
SmallVector<llvm::Value*, 8> EHSelector;
|
||||
EHSelector.push_back(Exn);
|
||||
EHSelector.push_back(getOpaquePersonalityFn(CGM, Personality));
|
||||
|
||||
|
@ -674,7 +674,7 @@ llvm::BasicBlock *CodeGenFunction::EmitLandingPad() {
|
|||
UnwindDest CatchAll;
|
||||
bool HasEHCleanup = false;
|
||||
bool HasEHFilter = false;
|
||||
llvm::SmallVector<llvm::Value*, 8> EHFilters;
|
||||
SmallVector<llvm::Value*, 8> EHFilters;
|
||||
for (EHScopeStack::iterator I = EHStack.begin(), E = EHStack.end();
|
||||
I != E; ++I) {
|
||||
|
||||
|
@ -1153,7 +1153,7 @@ void CodeGenFunction::ExitCXXTryStmt(const CXXTryStmt &S, bool IsFnTryBlock) {
|
|||
|
||||
// Copy the handler blocks off before we pop the EH stack. Emitting
|
||||
// the handlers might scribble on this memory.
|
||||
llvm::SmallVector<EHCatchScope::Handler, 8> Handlers(NumHandlers);
|
||||
SmallVector<EHCatchScope::Handler, 8> Handlers(NumHandlers);
|
||||
memcpy(Handlers.data(), CatchScope.begin(),
|
||||
NumHandlers * sizeof(EHCatchScope::Handler));
|
||||
EHStack.popCatch();
|
||||
|
@ -1464,7 +1464,7 @@ CodeGenFunction::UnwindDest CodeGenFunction::getRethrowDest() {
|
|||
|
||||
// This can always be a call because we necessarily didn't find
|
||||
// anything on the EH stack which needs our help.
|
||||
llvm::StringRef RethrowName = Personality.getCatchallRethrowFnName();
|
||||
StringRef RethrowName = Personality.getCatchallRethrowFnName();
|
||||
if (!RethrowName.empty()) {
|
||||
Builder.CreateCall(getCatchallRethrowFn(*this, RethrowName),
|
||||
Builder.CreateLoad(getExceptionSlot()))
|
||||
|
|
|
@ -45,7 +45,7 @@ llvm::Value *CodeGenFunction::EmitCastToVoidPtr(llvm::Value *value) {
|
|||
/// CreateTempAlloca - This creates a alloca and inserts it into the entry
|
||||
/// block.
|
||||
llvm::AllocaInst *CodeGenFunction::CreateTempAlloca(llvm::Type *Ty,
|
||||
const llvm::Twine &Name) {
|
||||
const Twine &Name) {
|
||||
if (!Builder.isNamePreserving())
|
||||
return new llvm::AllocaInst(Ty, 0, "", AllocaInsertPt);
|
||||
return new llvm::AllocaInst(Ty, 0, Name, AllocaInsertPt);
|
||||
|
@ -59,7 +59,7 @@ void CodeGenFunction::InitTempAlloca(llvm::AllocaInst *Var,
|
|||
}
|
||||
|
||||
llvm::AllocaInst *CodeGenFunction::CreateIRTemp(QualType Ty,
|
||||
const llvm::Twine &Name) {
|
||||
const Twine &Name) {
|
||||
llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertType(Ty), Name);
|
||||
// FIXME: Should we prefer the preferred type alignment here?
|
||||
CharUnits Align = getContext().getTypeAlignInChars(Ty);
|
||||
|
@ -68,7 +68,7 @@ llvm::AllocaInst *CodeGenFunction::CreateIRTemp(QualType Ty,
|
|||
}
|
||||
|
||||
llvm::AllocaInst *CodeGenFunction::CreateMemTemp(QualType Ty,
|
||||
const llvm::Twine &Name) {
|
||||
const Twine &Name) {
|
||||
llvm::AllocaInst *Alloc = CreateTempAlloca(ConvertTypeForMem(Ty), Name);
|
||||
// FIXME: Should we prefer the preferred type alignment here?
|
||||
CharUnits Align = getContext().getTypeAlignInChars(Ty);
|
||||
|
@ -310,7 +310,7 @@ EmitExprForReferenceBinding(CodeGenFunction &CGF, const Expr *E,
|
|||
return ReferenceTemporary;
|
||||
}
|
||||
|
||||
llvm::SmallVector<SubobjectAdjustment, 2> Adjustments;
|
||||
SmallVector<SubobjectAdjustment, 2> Adjustments;
|
||||
while (true) {
|
||||
E = E->IgnoreParens();
|
||||
|
||||
|
@ -921,7 +921,7 @@ RValue CodeGenFunction::EmitLoadOfExtVectorElementLValue(LValue LV) {
|
|||
// Always use shuffle vector to try to retain the original program structure
|
||||
unsigned NumResultElts = ExprVT->getNumElements();
|
||||
|
||||
llvm::SmallVector<llvm::Constant*, 4> Mask;
|
||||
SmallVector<llvm::Constant*, 4> Mask;
|
||||
for (unsigned i = 0; i != NumResultElts; ++i) {
|
||||
unsigned InIdx = getAccessedFieldNo(i, Elts);
|
||||
Mask.push_back(llvm::ConstantInt::get(Int32Ty, InIdx));
|
||||
|
@ -1147,7 +1147,7 @@ void CodeGenFunction::EmitStoreThroughExtVectorComponentLValue(RValue Src,
|
|||
// Use shuffle vector is the src and destination are the same number of
|
||||
// elements and restore the vector mask since it is on the side it will be
|
||||
// stored.
|
||||
llvm::SmallVector<llvm::Constant*, 4> Mask(NumDstElts);
|
||||
SmallVector<llvm::Constant*, 4> Mask(NumDstElts);
|
||||
for (unsigned i = 0; i != NumSrcElts; ++i) {
|
||||
unsigned InIdx = getAccessedFieldNo(i, Elts);
|
||||
Mask[InIdx] = llvm::ConstantInt::get(Int32Ty, i);
|
||||
|
@ -1162,7 +1162,7 @@ void CodeGenFunction::EmitStoreThroughExtVectorComponentLValue(RValue Src,
|
|||
// into the destination.
|
||||
// FIXME: since we're shuffling with undef, can we just use the indices
|
||||
// into that? This could be simpler.
|
||||
llvm::SmallVector<llvm::Constant*, 4> ExtMask;
|
||||
SmallVector<llvm::Constant*, 4> ExtMask;
|
||||
unsigned i;
|
||||
for (i = 0; i != NumSrcElts; ++i)
|
||||
ExtMask.push_back(llvm::ConstantInt::get(Int32Ty, i));
|
||||
|
@ -1174,7 +1174,7 @@ void CodeGenFunction::EmitStoreThroughExtVectorComponentLValue(RValue Src,
|
|||
llvm::UndefValue::get(SrcVal->getType()),
|
||||
ExtMaskV, "tmp");
|
||||
// build identity
|
||||
llvm::SmallVector<llvm::Constant*, 4> Mask;
|
||||
SmallVector<llvm::Constant*, 4> Mask;
|
||||
for (unsigned i = 0; i != NumDstElts; ++i)
|
||||
Mask.push_back(llvm::ConstantInt::get(Int32Ty, i));
|
||||
|
||||
|
@ -1290,7 +1290,7 @@ static void setObjCGCLValueClass(const ASTContext &Ctx, const Expr *E,
|
|||
static llvm::Value *
|
||||
EmitBitCastOfLValueToProperType(CodeGenFunction &CGF,
|
||||
llvm::Value *V, llvm::Type *IRType,
|
||||
llvm::StringRef Name = llvm::StringRef()) {
|
||||
StringRef Name = StringRef()) {
|
||||
unsigned AS = cast<llvm::PointerType>(V->getType())->getAddressSpace();
|
||||
return CGF.Builder.CreateBitCast(V, IRType->getPointerTo(AS), Name);
|
||||
}
|
||||
|
@ -1486,7 +1486,7 @@ LValue CodeGenFunction::EmitPredefinedLValue(const PredefinedExpr *E) {
|
|||
break;
|
||||
}
|
||||
|
||||
llvm::StringRef FnName = CurFn->getName();
|
||||
StringRef FnName = CurFn->getName();
|
||||
if (FnName.startswith("\01"))
|
||||
FnName = FnName.substr(1);
|
||||
GlobalVarName += FnName;
|
||||
|
@ -1681,8 +1681,8 @@ LValue CodeGenFunction::EmitArraySubscriptExpr(const ArraySubscriptExpr *E) {
|
|||
|
||||
static
|
||||
llvm::Constant *GenerateConstantVector(llvm::LLVMContext &VMContext,
|
||||
llvm::SmallVector<unsigned, 4> &Elts) {
|
||||
llvm::SmallVector<llvm::Constant*, 4> CElts;
|
||||
SmallVector<unsigned, 4> &Elts) {
|
||||
SmallVector<llvm::Constant*, 4> CElts;
|
||||
|
||||
llvm::Type *Int32Ty = llvm::Type::getInt32Ty(VMContext);
|
||||
for (unsigned i = 0, e = Elts.size(); i != e; ++i)
|
||||
|
@ -1725,7 +1725,7 @@ EmitExtVectorElementExpr(const ExtVectorElementExpr *E) {
|
|||
E->getType().withCVRQualifiers(Base.getQuals().getCVRQualifiers());
|
||||
|
||||
// Encode the element access list into a vector of unsigned indices.
|
||||
llvm::SmallVector<unsigned, 4> Indices;
|
||||
SmallVector<unsigned, 4> Indices;
|
||||
E->getEncodedElementAccess(Indices);
|
||||
|
||||
if (Base.isSimple()) {
|
||||
|
@ -1735,7 +1735,7 @@ EmitExtVectorElementExpr(const ExtVectorElementExpr *E) {
|
|||
assert(Base.isExtVectorElt() && "Can only subscript lvalue vec elts here!");
|
||||
|
||||
llvm::Constant *BaseElts = Base.getExtVectorElts();
|
||||
llvm::SmallVector<llvm::Constant *, 4> CElts;
|
||||
SmallVector<llvm::Constant *, 4> CElts;
|
||||
|
||||
for (unsigned i = 0, e = Indices.size(); i != e; ++i) {
|
||||
if (isa<llvm::ConstantAggregateZero>(BaseElts))
|
||||
|
|
|
@ -839,7 +839,7 @@ void AggExprEmitter::VisitInitListExpr(InitListExpr *E) {
|
|||
|
||||
// We'll need to enter cleanup scopes in case any of the member
|
||||
// initializers throw an exception.
|
||||
llvm::SmallVector<EHScopeStack::stable_iterator, 16> cleanups;
|
||||
SmallVector<EHScopeStack::stable_iterator, 16> cleanups;
|
||||
|
||||
// Here we iterate over the fields; this makes it simpler to both
|
||||
// default-initialize fields and skip over unnamed fields.
|
||||
|
|
|
@ -1406,7 +1406,7 @@ void CodeGenFunction::EmitCXXDeleteExpr(const CXXDeleteExpr *E) {
|
|||
QualType DeleteTy = Arg->getType()->getAs<PointerType>()->getPointeeType();
|
||||
if (DeleteTy->isConstantArrayType()) {
|
||||
llvm::Value *Zero = Builder.getInt32(0);
|
||||
llvm::SmallVector<llvm::Value*,8> GEP;
|
||||
SmallVector<llvm::Value*,8> GEP;
|
||||
|
||||
GEP.push_back(Zero); // point at the outermost array
|
||||
|
||||
|
|
|
@ -1030,7 +1030,7 @@ llvm::Constant *CodeGenModule::EmitConstantExpr(const Expr *E,
|
|||
return llvm::ConstantStruct::get(STy, Complex);
|
||||
}
|
||||
case APValue::Vector: {
|
||||
llvm::SmallVector<llvm::Constant *, 4> Inits;
|
||||
SmallVector<llvm::Constant *, 4> Inits;
|
||||
unsigned NumElts = Result.Val.getVectorLength();
|
||||
|
||||
if (Context.getLangOptions().AltiVec &&
|
||||
|
|
|
@ -595,7 +595,7 @@ Value *ScalarExprEmitter::EmitScalarConversion(Value *Src, QualType SrcType,
|
|||
UnV = Builder.CreateInsertElement(UnV, Elt, Idx, "tmp");
|
||||
|
||||
// Splat the element across to all elements
|
||||
llvm::SmallVector<llvm::Constant*, 16> Args;
|
||||
SmallVector<llvm::Constant*, 16> Args;
|
||||
unsigned NumElements = cast<llvm::VectorType>(DstTy)->getNumElements();
|
||||
for (unsigned i = 0; i != NumElements; ++i)
|
||||
Args.push_back(Builder.getInt32(0));
|
||||
|
@ -693,7 +693,7 @@ Value *ScalarExprEmitter::VisitShuffleVectorExpr(ShuffleVectorExpr *E) {
|
|||
Mask = CGF.EmitScalarExpr(E->getExpr(2));
|
||||
|
||||
// Shuffle LHS & RHS into one input vector.
|
||||
llvm::SmallVector<llvm::Constant*, 32> concat;
|
||||
SmallVector<llvm::Constant*, 32> concat;
|
||||
for (unsigned i = 0; i != LHSElts; ++i) {
|
||||
concat.push_back(Builder.getInt32(2*i));
|
||||
concat.push_back(Builder.getInt32(2*i+1));
|
||||
|
@ -721,7 +721,7 @@ Value *ScalarExprEmitter::VisitShuffleVectorExpr(ShuffleVectorExpr *E) {
|
|||
(1 << llvm::Log2_32(LHSElts))-1);
|
||||
|
||||
// Mask off the high bits of each shuffle index.
|
||||
llvm::SmallVector<llvm::Constant *, 32> MaskV;
|
||||
SmallVector<llvm::Constant *, 32> MaskV;
|
||||
for (unsigned i = 0, e = MTy->getNumElements(); i != e; ++i)
|
||||
MaskV.push_back(EltMask);
|
||||
|
||||
|
@ -761,7 +761,7 @@ Value *ScalarExprEmitter::VisitShuffleVectorExpr(ShuffleVectorExpr *E) {
|
|||
|
||||
// Handle vec3 special since the index will be off by one for the RHS.
|
||||
llvm::VectorType *VTy = cast<llvm::VectorType>(V1->getType());
|
||||
llvm::SmallVector<llvm::Constant*, 32> indices;
|
||||
SmallVector<llvm::Constant*, 32> indices;
|
||||
for (unsigned i = 2; i < E->getNumSubExprs(); i++) {
|
||||
unsigned Idx = E->getShuffleMaskIdx(CGF.getContext(), i-2);
|
||||
if (VTy->getNumElements() == 3 && Idx > 3)
|
||||
|
@ -851,7 +851,7 @@ Value *ScalarExprEmitter::VisitInitListExpr(InitListExpr *E) {
|
|||
for (unsigned i = 0; i != NumInitElements; ++i) {
|
||||
Expr *IE = E->getInit(i);
|
||||
Value *Init = Visit(IE);
|
||||
llvm::SmallVector<llvm::Constant*, 16> Args;
|
||||
SmallVector<llvm::Constant*, 16> Args;
|
||||
|
||||
llvm::VectorType *VVT = dyn_cast<llvm::VectorType>(Init->getType());
|
||||
|
||||
|
@ -1174,7 +1174,7 @@ Value *ScalarExprEmitter::VisitCastExpr(CastExpr *CE) {
|
|||
UnV = Builder.CreateInsertElement(UnV, Elt, Idx, "tmp");
|
||||
|
||||
// Splat the element across to all elements
|
||||
llvm::SmallVector<llvm::Constant*, 16> Args;
|
||||
SmallVector<llvm::Constant*, 16> Args;
|
||||
unsigned NumElements = cast<llvm::VectorType>(DstTy)->getNumElements();
|
||||
llvm::Constant *Zero = Builder.getInt32(0);
|
||||
for (unsigned i = 0; i < NumElements; i++)
|
||||
|
@ -2610,7 +2610,7 @@ Value *ScalarExprEmitter::VisitAsTypeExpr(AsTypeExpr *E) {
|
|||
|
||||
llvm::Value *UnV = llvm::UndefValue::get(Src->getType());
|
||||
|
||||
llvm::SmallVector<llvm::Constant*, 3> Args;
|
||||
SmallVector<llvm::Constant*, 3> Args;
|
||||
Args.push_back(Builder.getInt32(0));
|
||||
Args.push_back(Builder.getInt32(1));
|
||||
Args.push_back(Builder.getInt32(2));
|
||||
|
|
|
@ -810,7 +810,7 @@ void CodeGenFunction::GenerateObjCCtorDtorMethod(ObjCImplementationDecl *IMP,
|
|||
// Suppress the final autorelease in ARC.
|
||||
AutoreleaseResult = false;
|
||||
|
||||
llvm::SmallVector<CXXCtorInitializer *, 8> IvarInitializers;
|
||||
SmallVector<CXXCtorInitializer *, 8> IvarInitializers;
|
||||
for (ObjCImplementationDecl::init_const_iterator B = IMP->init_begin(),
|
||||
E = IMP->init_end(); B != E; ++B) {
|
||||
CXXCtorInitializer *IvarInit = (*B);
|
||||
|
@ -1329,7 +1329,7 @@ llvm::Value *CodeGenFunction::EmitObjCExtendObjectLifetime(QualType type,
|
|||
|
||||
static llvm::Constant *createARCRuntimeFunction(CodeGenModule &CGM,
|
||||
llvm::FunctionType *type,
|
||||
llvm::StringRef fnName) {
|
||||
StringRef fnName) {
|
||||
llvm::Constant *fn = CGM.CreateRuntimeFunction(type, fnName);
|
||||
|
||||
// In -fobjc-no-arc-runtime, emit weak references to the runtime
|
||||
|
@ -1347,7 +1347,7 @@ static llvm::Constant *createARCRuntimeFunction(CodeGenModule &CGM,
|
|||
static llvm::Value *emitARCValueOperation(CodeGenFunction &CGF,
|
||||
llvm::Value *value,
|
||||
llvm::Constant *&fn,
|
||||
llvm::StringRef fnName) {
|
||||
StringRef fnName) {
|
||||
if (isa<llvm::ConstantPointerNull>(value)) return value;
|
||||
|
||||
if (!fn) {
|
||||
|
@ -1374,7 +1374,7 @@ static llvm::Value *emitARCValueOperation(CodeGenFunction &CGF,
|
|||
static llvm::Value *emitARCLoadOperation(CodeGenFunction &CGF,
|
||||
llvm::Value *addr,
|
||||
llvm::Constant *&fn,
|
||||
llvm::StringRef fnName) {
|
||||
StringRef fnName) {
|
||||
if (!fn) {
|
||||
std::vector<llvm::Type*> args(1, CGF.Int8PtrPtrTy);
|
||||
llvm::FunctionType *fnType =
|
||||
|
@ -1405,7 +1405,7 @@ static llvm::Value *emitARCStoreOperation(CodeGenFunction &CGF,
|
|||
llvm::Value *addr,
|
||||
llvm::Value *value,
|
||||
llvm::Constant *&fn,
|
||||
llvm::StringRef fnName,
|
||||
StringRef fnName,
|
||||
bool ignored) {
|
||||
assert(cast<llvm::PointerType>(addr->getType())->getElementType()
|
||||
== value->getType());
|
||||
|
@ -1439,7 +1439,7 @@ static void emitARCCopyOperation(CodeGenFunction &CGF,
|
|||
llvm::Value *dst,
|
||||
llvm::Value *src,
|
||||
llvm::Constant *&fn,
|
||||
llvm::StringRef fnName) {
|
||||
StringRef fnName) {
|
||||
assert(dst->getType() == src->getType());
|
||||
|
||||
if (!fn) {
|
||||
|
@ -1494,7 +1494,7 @@ CodeGenFunction::EmitARCRetainAutoreleasedReturnValue(llvm::Value *value) {
|
|||
llvm::InlineAsm *&marker
|
||||
= CGM.getARCEntrypoints().retainAutoreleasedReturnValueMarker;
|
||||
if (!marker) {
|
||||
llvm::StringRef assembly
|
||||
StringRef assembly
|
||||
= CGM.getTargetCodeGenInfo()
|
||||
.getARCRetainAutoreleasedReturnValueMarker();
|
||||
|
||||
|
@ -1555,7 +1555,7 @@ void CodeGenFunction::EmitARCRelease(llvm::Value *value, bool precise) {
|
|||
call->setDoesNotThrow();
|
||||
|
||||
if (!precise) {
|
||||
llvm::SmallVector<llvm::Value*,1> args;
|
||||
SmallVector<llvm::Value*,1> args;
|
||||
call->setMetadata("clang.imprecise_release",
|
||||
llvm::MDNode::get(Builder.getContext(), args));
|
||||
}
|
||||
|
|
|
@ -36,12 +36,11 @@
|
|||
#include "llvm/Support/Compiler.h"
|
||||
#include "llvm/Target/TargetData.h"
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <cstdarg>
|
||||
|
||||
|
||||
using namespace clang;
|
||||
using namespace CodeGen;
|
||||
using llvm::dyn_cast;
|
||||
|
||||
|
||||
namespace {
|
||||
|
@ -193,7 +192,7 @@ protected:
|
|||
/// first argument.
|
||||
llvm::GlobalVariable *MakeGlobal(llvm::StructType *Ty,
|
||||
std::vector<llvm::Constant*> &V,
|
||||
llvm::StringRef Name="",
|
||||
StringRef Name="",
|
||||
llvm::GlobalValue::LinkageTypes linkage
|
||||
=llvm::GlobalValue::InternalLinkage) {
|
||||
llvm::Constant *C = llvm::ConstantStruct::get(Ty, V);
|
||||
|
@ -205,7 +204,7 @@ protected:
|
|||
/// element type.
|
||||
llvm::GlobalVariable *MakeGlobal(llvm::ArrayType *Ty,
|
||||
std::vector<llvm::Constant*> &V,
|
||||
llvm::StringRef Name="",
|
||||
StringRef Name="",
|
||||
llvm::GlobalValue::LinkageTypes linkage
|
||||
=llvm::GlobalValue::InternalLinkage) {
|
||||
llvm::Constant *C = llvm::ConstantArray::get(Ty, V);
|
||||
|
@ -216,7 +215,7 @@ protected:
|
|||
/// element type and the size of the initialiser.
|
||||
llvm::GlobalVariable *MakeGlobalArray(llvm::Type *Ty,
|
||||
std::vector<llvm::Constant*> &V,
|
||||
llvm::StringRef Name="",
|
||||
StringRef Name="",
|
||||
llvm::GlobalValue::LinkageTypes linkage
|
||||
=llvm::GlobalValue::InternalLinkage) {
|
||||
llvm::ArrayType *ArrayTy = llvm::ArrayType::get(Ty, V.size());
|
||||
|
@ -268,7 +267,7 @@ private:
|
|||
/// Type of the selector map. This is roughly equivalent to the structure
|
||||
/// used in the GNUstep runtime, which maintains a list of all of the valid
|
||||
/// types for a selector in a table.
|
||||
typedef llvm::DenseMap<Selector, llvm::SmallVector<TypedSelector, 2> >
|
||||
typedef llvm::DenseMap<Selector, SmallVector<TypedSelector, 2> >
|
||||
SelectorMap;
|
||||
/// A map from selectors to selector types. This allows us to emit all
|
||||
/// selectors of the same name and type together.
|
||||
|
@ -332,18 +331,18 @@ private:
|
|||
/// metadata. This is used purely for introspection in the fragile ABI. In
|
||||
/// the non-fragile ABI, it's used for instance variable fixup.
|
||||
llvm::Constant *GenerateIvarList(
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &IvarNames,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &IvarTypes,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &IvarOffsets);
|
||||
const SmallVectorImpl<llvm::Constant *> &IvarNames,
|
||||
const SmallVectorImpl<llvm::Constant *> &IvarTypes,
|
||||
const SmallVectorImpl<llvm::Constant *> &IvarOffsets);
|
||||
/// Generates a method list structure. This is a structure containing a size
|
||||
/// and an array of structures containing method metadata.
|
||||
///
|
||||
/// This structure is used by both classes and categories, and contains a next
|
||||
/// pointer allowing them to be chained together in a linked list.
|
||||
llvm::Constant *GenerateMethodList(const llvm::StringRef &ClassName,
|
||||
const llvm::StringRef &CategoryName,
|
||||
const llvm::SmallVectorImpl<Selector> &MethodSels,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &MethodTypes,
|
||||
llvm::Constant *GenerateMethodList(const StringRef &ClassName,
|
||||
const StringRef &CategoryName,
|
||||
const SmallVectorImpl<Selector> &MethodSels,
|
||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes,
|
||||
bool isClassMethodList);
|
||||
/// Emits an empty protocol. This is used for @protocol() where no protocol
|
||||
/// is found. The runtime will (hopefully) fix up the pointer to refer to the
|
||||
|
@ -352,12 +351,12 @@ private:
|
|||
/// Generates a list of property metadata structures. This follows the same
|
||||
/// pattern as method and instance variable metadata lists.
|
||||
llvm::Constant *GeneratePropertyList(const ObjCImplementationDecl *OID,
|
||||
llvm::SmallVectorImpl<Selector> &InstanceMethodSels,
|
||||
llvm::SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes);
|
||||
SmallVectorImpl<Selector> &InstanceMethodSels,
|
||||
SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes);
|
||||
/// Generates a list of referenced protocols. Classes, categories, and
|
||||
/// protocols all use this structure.
|
||||
llvm::Constant *GenerateProtocolList(
|
||||
const llvm::SmallVectorImpl<std::string> &Protocols);
|
||||
const SmallVectorImpl<std::string> &Protocols);
|
||||
/// To ensure that all protocols are seen by the runtime, we add a category on
|
||||
/// a class defined in the runtime, declaring no methods, but adopting the
|
||||
/// protocols. This is a horribly ugly hack, but it allows us to collect all
|
||||
|
@ -380,8 +379,8 @@ private:
|
|||
/// Generates a method list. This is used by protocols to define the required
|
||||
/// and optional methods.
|
||||
llvm::Constant *GenerateProtocolMethodList(
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &MethodNames,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &MethodTypes);
|
||||
const SmallVectorImpl<llvm::Constant *> &MethodNames,
|
||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes);
|
||||
/// Returns a selector with the specified type encoding. An empty string is
|
||||
/// used to return an untyped selector (with the types field set to NULL).
|
||||
llvm::Value *GetSelector(CGBuilderTy &Builder, Selector Sel,
|
||||
|
@ -650,13 +649,13 @@ void CGObjCGNU::EmitClassRef(const std::string &className) {
|
|||
llvm::GlobalValue::WeakAnyLinkage, ClassSymbol, symbolRef);
|
||||
}
|
||||
|
||||
static std::string SymbolNameForMethod(const llvm::StringRef &ClassName,
|
||||
const llvm::StringRef &CategoryName, const Selector MethodName,
|
||||
static std::string SymbolNameForMethod(const StringRef &ClassName,
|
||||
const StringRef &CategoryName, const Selector MethodName,
|
||||
bool isClassMethod) {
|
||||
std::string MethodNameColonStripped = MethodName.getAsString();
|
||||
std::replace(MethodNameColonStripped.begin(), MethodNameColonStripped.end(),
|
||||
':', '_');
|
||||
return (llvm::Twine(isClassMethod ? "_c_" : "_i_") + ClassName + "_" +
|
||||
return (Twine(isClassMethod ? "_c_" : "_i_") + ClassName + "_" +
|
||||
CategoryName + "_" + MethodNameColonStripped).str();
|
||||
}
|
||||
|
||||
|
@ -813,11 +812,11 @@ llvm::Value *CGObjCGNU::EmitNSAutoreleasePoolClassRef(CGBuilderTy &Builder) {
|
|||
llvm::Value *CGObjCGNU::GetSelector(CGBuilderTy &Builder, Selector Sel,
|
||||
const std::string &TypeEncoding, bool lval) {
|
||||
|
||||
llvm::SmallVector<TypedSelector, 2> &Types = SelectorTable[Sel];
|
||||
SmallVector<TypedSelector, 2> &Types = SelectorTable[Sel];
|
||||
llvm::GlobalAlias *SelValue = 0;
|
||||
|
||||
|
||||
for (llvm::SmallVectorImpl<TypedSelector>::iterator i = Types.begin(),
|
||||
for (SmallVectorImpl<TypedSelector>::iterator i = Types.begin(),
|
||||
e = Types.end() ; i!=e ; i++) {
|
||||
if (i->first == TypeEncoding) {
|
||||
SelValue = i->second;
|
||||
|
@ -1201,10 +1200,10 @@ CGObjCGNU::GenerateMessageSend(CodeGenFunction &CGF,
|
|||
|
||||
/// Generates a MethodList. Used in construction of a objc_class and
|
||||
/// objc_category structures.
|
||||
llvm::Constant *CGObjCGNU::GenerateMethodList(const llvm::StringRef &ClassName,
|
||||
const llvm::StringRef &CategoryName,
|
||||
const llvm::SmallVectorImpl<Selector> &MethodSels,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &MethodTypes,
|
||||
llvm::Constant *CGObjCGNU::GenerateMethodList(const StringRef &ClassName,
|
||||
const StringRef &CategoryName,
|
||||
const SmallVectorImpl<Selector> &MethodSels,
|
||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes,
|
||||
bool isClassMethodList) {
|
||||
if (MethodSels.empty())
|
||||
return NULLPtr;
|
||||
|
@ -1261,9 +1260,9 @@ llvm::Constant *CGObjCGNU::GenerateMethodList(const llvm::StringRef &ClassName,
|
|||
|
||||
/// Generates an IvarList. Used in construction of a objc_class.
|
||||
llvm::Constant *CGObjCGNU::GenerateIvarList(
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &IvarNames,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &IvarTypes,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &IvarOffsets) {
|
||||
const SmallVectorImpl<llvm::Constant *> &IvarNames,
|
||||
const SmallVectorImpl<llvm::Constant *> &IvarTypes,
|
||||
const SmallVectorImpl<llvm::Constant *> &IvarOffsets) {
|
||||
if (IvarNames.size() == 0)
|
||||
return NULLPtr;
|
||||
// Get the method structure type.
|
||||
|
@ -1374,8 +1373,8 @@ llvm::Constant *CGObjCGNU::GenerateClassStructure(
|
|||
}
|
||||
|
||||
llvm::Constant *CGObjCGNU::GenerateProtocolMethodList(
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &MethodNames,
|
||||
const llvm::SmallVectorImpl<llvm::Constant *> &MethodTypes) {
|
||||
const SmallVectorImpl<llvm::Constant *> &MethodNames,
|
||||
const SmallVectorImpl<llvm::Constant *> &MethodTypes) {
|
||||
// Get the method structure type.
|
||||
llvm::StructType *ObjCMethodDescTy = llvm::StructType::get(
|
||||
PtrToInt8Ty, // Really a selector, but the runtime does the casting for us.
|
||||
|
@ -1403,7 +1402,7 @@ llvm::Constant *CGObjCGNU::GenerateProtocolMethodList(
|
|||
|
||||
// Create the protocol list structure used in classes, categories and so on
|
||||
llvm::Constant *CGObjCGNU::GenerateProtocolList(
|
||||
const llvm::SmallVectorImpl<std::string> &Protocols) {
|
||||
const SmallVectorImpl<std::string> &Protocols) {
|
||||
llvm::ArrayType *ProtocolArrayTy = llvm::ArrayType::get(PtrToInt8Ty,
|
||||
Protocols.size());
|
||||
llvm::StructType *ProtocolListTy = llvm::StructType::get(
|
||||
|
@ -1445,8 +1444,8 @@ llvm::Value *CGObjCGNU::GenerateProtocolRef(CGBuilderTy &Builder,
|
|||
|
||||
llvm::Constant *CGObjCGNU::GenerateEmptyProtocol(
|
||||
const std::string &ProtocolName) {
|
||||
llvm::SmallVector<std::string, 0> EmptyStringVector;
|
||||
llvm::SmallVector<llvm::Constant*, 0> EmptyConstantVector;
|
||||
SmallVector<std::string, 0> EmptyStringVector;
|
||||
SmallVector<llvm::Constant*, 0> EmptyConstantVector;
|
||||
|
||||
llvm::Constant *ProtocolList = GenerateProtocolList(EmptyStringVector);
|
||||
llvm::Constant *MethodList =
|
||||
|
@ -1479,14 +1478,14 @@ llvm::Constant *CGObjCGNU::GenerateEmptyProtocol(
|
|||
void CGObjCGNU::GenerateProtocol(const ObjCProtocolDecl *PD) {
|
||||
ASTContext &Context = CGM.getContext();
|
||||
std::string ProtocolName = PD->getNameAsString();
|
||||
llvm::SmallVector<std::string, 16> Protocols;
|
||||
SmallVector<std::string, 16> Protocols;
|
||||
for (ObjCProtocolDecl::protocol_iterator PI = PD->protocol_begin(),
|
||||
E = PD->protocol_end(); PI != E; ++PI)
|
||||
Protocols.push_back((*PI)->getNameAsString());
|
||||
llvm::SmallVector<llvm::Constant*, 16> InstanceMethodNames;
|
||||
llvm::SmallVector<llvm::Constant*, 16> InstanceMethodTypes;
|
||||
llvm::SmallVector<llvm::Constant*, 16> OptionalInstanceMethodNames;
|
||||
llvm::SmallVector<llvm::Constant*, 16> OptionalInstanceMethodTypes;
|
||||
SmallVector<llvm::Constant*, 16> InstanceMethodNames;
|
||||
SmallVector<llvm::Constant*, 16> InstanceMethodTypes;
|
||||
SmallVector<llvm::Constant*, 16> OptionalInstanceMethodNames;
|
||||
SmallVector<llvm::Constant*, 16> OptionalInstanceMethodTypes;
|
||||
for (ObjCProtocolDecl::instmeth_iterator iter = PD->instmeth_begin(),
|
||||
E = PD->instmeth_end(); iter != E; iter++) {
|
||||
std::string TypeStr;
|
||||
|
@ -1502,10 +1501,10 @@ void CGObjCGNU::GenerateProtocol(const ObjCProtocolDecl *PD) {
|
|||
}
|
||||
}
|
||||
// Collect information about class methods:
|
||||
llvm::SmallVector<llvm::Constant*, 16> ClassMethodNames;
|
||||
llvm::SmallVector<llvm::Constant*, 16> ClassMethodTypes;
|
||||
llvm::SmallVector<llvm::Constant*, 16> OptionalClassMethodNames;
|
||||
llvm::SmallVector<llvm::Constant*, 16> OptionalClassMethodTypes;
|
||||
SmallVector<llvm::Constant*, 16> ClassMethodNames;
|
||||
SmallVector<llvm::Constant*, 16> ClassMethodTypes;
|
||||
SmallVector<llvm::Constant*, 16> OptionalClassMethodNames;
|
||||
SmallVector<llvm::Constant*, 16> OptionalClassMethodTypes;
|
||||
for (ObjCProtocolDecl::classmeth_iterator
|
||||
iter = PD->classmeth_begin(), endIter = PD->classmeth_end();
|
||||
iter != endIter ; iter++) {
|
||||
|
@ -1642,8 +1641,8 @@ void CGObjCGNU::GenerateProtocol(const ObjCProtocolDecl *PD) {
|
|||
}
|
||||
void CGObjCGNU::GenerateProtocolHolderCategory(void) {
|
||||
// Collect information about instance methods
|
||||
llvm::SmallVector<Selector, 1> MethodSels;
|
||||
llvm::SmallVector<llvm::Constant*, 1> MethodTypes;
|
||||
SmallVector<Selector, 1> MethodSels;
|
||||
SmallVector<llvm::Constant*, 1> MethodTypes;
|
||||
|
||||
std::vector<llvm::Constant*> Elements;
|
||||
const std::string ClassName = "__ObjC_Protocol_Holder_Ugly_Hack";
|
||||
|
@ -1690,8 +1689,8 @@ void CGObjCGNU::GenerateCategory(const ObjCCategoryImplDecl *OCD) {
|
|||
std::string ClassName = OCD->getClassInterface()->getNameAsString();
|
||||
std::string CategoryName = OCD->getNameAsString();
|
||||
// Collect information about instance methods
|
||||
llvm::SmallVector<Selector, 16> InstanceMethodSels;
|
||||
llvm::SmallVector<llvm::Constant*, 16> InstanceMethodTypes;
|
||||
SmallVector<Selector, 16> InstanceMethodSels;
|
||||
SmallVector<llvm::Constant*, 16> InstanceMethodTypes;
|
||||
for (ObjCCategoryImplDecl::instmeth_iterator
|
||||
iter = OCD->instmeth_begin(), endIter = OCD->instmeth_end();
|
||||
iter != endIter ; iter++) {
|
||||
|
@ -1702,8 +1701,8 @@ void CGObjCGNU::GenerateCategory(const ObjCCategoryImplDecl *OCD) {
|
|||
}
|
||||
|
||||
// Collect information about class methods
|
||||
llvm::SmallVector<Selector, 16> ClassMethodSels;
|
||||
llvm::SmallVector<llvm::Constant*, 16> ClassMethodTypes;
|
||||
SmallVector<Selector, 16> ClassMethodSels;
|
||||
SmallVector<llvm::Constant*, 16> ClassMethodTypes;
|
||||
for (ObjCCategoryImplDecl::classmeth_iterator
|
||||
iter = OCD->classmeth_begin(), endIter = OCD->classmeth_end();
|
||||
iter != endIter ; iter++) {
|
||||
|
@ -1714,7 +1713,7 @@ void CGObjCGNU::GenerateCategory(const ObjCCategoryImplDecl *OCD) {
|
|||
}
|
||||
|
||||
// Collect the names of referenced protocols
|
||||
llvm::SmallVector<std::string, 16> Protocols;
|
||||
SmallVector<std::string, 16> Protocols;
|
||||
const ObjCCategoryDecl *CatDecl = OCD->getCategoryDecl();
|
||||
const ObjCList<ObjCProtocolDecl> &Protos = CatDecl->getReferencedProtocols();
|
||||
for (ObjCList<ObjCProtocolDecl>::iterator I = Protos.begin(),
|
||||
|
@ -1741,8 +1740,8 @@ void CGObjCGNU::GenerateCategory(const ObjCCategoryImplDecl *OCD) {
|
|||
}
|
||||
|
||||
llvm::Constant *CGObjCGNU::GeneratePropertyList(const ObjCImplementationDecl *OID,
|
||||
llvm::SmallVectorImpl<Selector> &InstanceMethodSels,
|
||||
llvm::SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes) {
|
||||
SmallVectorImpl<Selector> &InstanceMethodSels,
|
||||
SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes) {
|
||||
ASTContext &Context = CGM.getContext();
|
||||
//
|
||||
// Property metadata: name, attributes, isSynthesized, setter name, setter
|
||||
|
@ -1845,9 +1844,9 @@ void CGObjCGNU::GenerateClass(const ObjCImplementationDecl *OID) {
|
|||
Context.getASTObjCImplementationLayout(OID).getSize().getQuantity();
|
||||
|
||||
// Collect information about instance variables.
|
||||
llvm::SmallVector<llvm::Constant*, 16> IvarNames;
|
||||
llvm::SmallVector<llvm::Constant*, 16> IvarTypes;
|
||||
llvm::SmallVector<llvm::Constant*, 16> IvarOffsets;
|
||||
SmallVector<llvm::Constant*, 16> IvarNames;
|
||||
SmallVector<llvm::Constant*, 16> IvarTypes;
|
||||
SmallVector<llvm::Constant*, 16> IvarOffsets;
|
||||
|
||||
std::vector<llvm::Constant*> IvarOffsetValues;
|
||||
|
||||
|
@ -1898,8 +1897,8 @@ void CGObjCGNU::GenerateClass(const ObjCImplementationDecl *OID) {
|
|||
|
||||
|
||||
// Collect information about instance methods
|
||||
llvm::SmallVector<Selector, 16> InstanceMethodSels;
|
||||
llvm::SmallVector<llvm::Constant*, 16> InstanceMethodTypes;
|
||||
SmallVector<Selector, 16> InstanceMethodSels;
|
||||
SmallVector<llvm::Constant*, 16> InstanceMethodTypes;
|
||||
for (ObjCImplementationDecl::instmeth_iterator
|
||||
iter = OID->instmeth_begin(), endIter = OID->instmeth_end();
|
||||
iter != endIter ; iter++) {
|
||||
|
@ -1914,8 +1913,8 @@ void CGObjCGNU::GenerateClass(const ObjCImplementationDecl *OID) {
|
|||
|
||||
|
||||
// Collect information about class methods
|
||||
llvm::SmallVector<Selector, 16> ClassMethodSels;
|
||||
llvm::SmallVector<llvm::Constant*, 16> ClassMethodTypes;
|
||||
SmallVector<Selector, 16> ClassMethodSels;
|
||||
SmallVector<llvm::Constant*, 16> ClassMethodTypes;
|
||||
for (ObjCImplementationDecl::classmeth_iterator
|
||||
iter = OID->classmeth_begin(), endIter = OID->classmeth_end();
|
||||
iter != endIter ; iter++) {
|
||||
|
@ -1925,7 +1924,7 @@ void CGObjCGNU::GenerateClass(const ObjCImplementationDecl *OID) {
|
|||
ClassMethodTypes.push_back(MakeConstantString(TypeStr));
|
||||
}
|
||||
// Collect the names of referenced protocols
|
||||
llvm::SmallVector<std::string, 16> Protocols;
|
||||
SmallVector<std::string, 16> Protocols;
|
||||
const ObjCList<ObjCProtocolDecl> &Protos =ClassDecl->getReferencedProtocols();
|
||||
for (ObjCList<ObjCProtocolDecl>::iterator I = Protos.begin(),
|
||||
E = Protos.end(); I != E; ++I)
|
||||
|
@ -1941,7 +1940,7 @@ void CGObjCGNU::GenerateClass(const ObjCImplementationDecl *OID) {
|
|||
SuperClass = llvm::ConstantPointerNull::get(PtrToInt8Ty);
|
||||
}
|
||||
// Empty vector used to construct empty method lists
|
||||
llvm::SmallVector<llvm::Constant*, 1> empty;
|
||||
SmallVector<llvm::Constant*, 1> empty;
|
||||
// Generate the method and instance variable lists
|
||||
llvm::Constant *MethodList = GenerateMethodList(ClassName, "",
|
||||
InstanceMethodSels, InstanceMethodTypes, false);
|
||||
|
@ -2046,7 +2045,7 @@ llvm::Function *CGObjCGNU::ModuleInitFunction() {
|
|||
ConstantStrings.size() + 1);
|
||||
ConstantStrings.push_back(NULLPtr);
|
||||
|
||||
llvm::StringRef StringClass = CGM.getLangOptions().ObjCConstantStringClass;
|
||||
StringRef StringClass = CGM.getLangOptions().ObjCConstantStringClass;
|
||||
|
||||
if (StringClass.empty()) StringClass = "NXConstantString";
|
||||
|
||||
|
@ -2085,8 +2084,8 @@ llvm::Function *CGObjCGNU::ModuleInitFunction() {
|
|||
std::string SelNameStr = iter->first.getAsString();
|
||||
llvm::Constant *SelName = ExportUniqueString(SelNameStr, ".objc_sel_name");
|
||||
|
||||
llvm::SmallVectorImpl<TypedSelector> &Types = iter->second;
|
||||
for (llvm::SmallVectorImpl<TypedSelector>::iterator i = Types.begin(),
|
||||
SmallVectorImpl<TypedSelector> &Types = iter->second;
|
||||
for (SmallVectorImpl<TypedSelector>::iterator i = Types.begin(),
|
||||
e = Types.end() ; i!=e ; i++) {
|
||||
|
||||
llvm::Constant *SelectorTypeEncoding = NULLPtr;
|
||||
|
@ -2216,8 +2215,8 @@ llvm::Function *CGObjCGNU::GenerateMethod(const ObjCMethodDecl *OMD,
|
|||
const ObjCContainerDecl *CD) {
|
||||
const ObjCCategoryImplDecl *OCD =
|
||||
dyn_cast<ObjCCategoryImplDecl>(OMD->getDeclContext());
|
||||
llvm::StringRef CategoryName = OCD ? OCD->getName() : "";
|
||||
llvm::StringRef ClassName = CD->getName();
|
||||
StringRef CategoryName = OCD ? OCD->getName() : "";
|
||||
StringRef ClassName = CD->getName();
|
||||
Selector MethodName = OMD->getSelector();
|
||||
bool isClassMethod = !OMD->isInstanceMethod();
|
||||
|
||||
|
|
|
@ -205,7 +205,7 @@ public:
|
|||
CodeGen::CodeGenTypes &Types = CGM.getTypes();
|
||||
ASTContext &Ctx = CGM.getContext();
|
||||
// id objc_getProperty (id, SEL, ptrdiff_t, bool)
|
||||
llvm::SmallVector<CanQualType,4> Params;
|
||||
SmallVector<CanQualType,4> Params;
|
||||
CanQualType IdType = Ctx.getCanonicalParamType(Ctx.getObjCIdType());
|
||||
CanQualType SelType = Ctx.getCanonicalParamType(Ctx.getObjCSelType());
|
||||
Params.push_back(IdType);
|
||||
|
@ -223,7 +223,7 @@ public:
|
|||
CodeGen::CodeGenTypes &Types = CGM.getTypes();
|
||||
ASTContext &Ctx = CGM.getContext();
|
||||
// void objc_setProperty (id, SEL, ptrdiff_t, id, bool, bool)
|
||||
llvm::SmallVector<CanQualType,6> Params;
|
||||
SmallVector<CanQualType,6> Params;
|
||||
CanQualType IdType = Ctx.getCanonicalParamType(Ctx.getObjCIdType());
|
||||
CanQualType SelType = Ctx.getCanonicalParamType(Ctx.getObjCSelType());
|
||||
Params.push_back(IdType);
|
||||
|
@ -244,7 +244,7 @@ public:
|
|||
CodeGen::CodeGenTypes &Types = CGM.getTypes();
|
||||
ASTContext &Ctx = CGM.getContext();
|
||||
// void objc_copyStruct (void *, const void *, size_t, bool, bool)
|
||||
llvm::SmallVector<CanQualType,5> Params;
|
||||
SmallVector<CanQualType,5> Params;
|
||||
Params.push_back(Ctx.VoidPtrTy);
|
||||
Params.push_back(Ctx.VoidPtrTy);
|
||||
Params.push_back(Ctx.LongTy);
|
||||
|
@ -261,7 +261,7 @@ public:
|
|||
CodeGen::CodeGenTypes &Types = CGM.getTypes();
|
||||
ASTContext &Ctx = CGM.getContext();
|
||||
// void objc_enumerationMutation (id)
|
||||
llvm::SmallVector<CanQualType,1> Params;
|
||||
SmallVector<CanQualType,1> Params;
|
||||
Params.push_back(Ctx.getCanonicalParamType(Ctx.getObjCIdType()));
|
||||
llvm::FunctionType *FTy =
|
||||
Types.GetFunctionType(Types.getFunctionInfo(Ctx.VoidTy, Params,
|
||||
|
@ -669,8 +669,8 @@ protected:
|
|||
unsigned ObjCABI;
|
||||
|
||||
// gc ivar layout bitmap calculation helper caches.
|
||||
llvm::SmallVector<GC_IVAR, 16> SkipIvars;
|
||||
llvm::SmallVector<GC_IVAR, 16> IvarsInfo;
|
||||
SmallVector<GC_IVAR, 16> SkipIvars;
|
||||
SmallVector<GC_IVAR, 16> IvarsInfo;
|
||||
|
||||
/// LazySymbols - Symbols to generate a lazy reference for. See
|
||||
/// DefinedSymbols and FinishModule().
|
||||
|
@ -733,7 +733,7 @@ protected:
|
|||
/// \param[out] NameOut - The return value.
|
||||
void GetNameForMethod(const ObjCMethodDecl *OMD,
|
||||
const ObjCContainerDecl *CD,
|
||||
llvm::SmallVectorImpl<char> &NameOut);
|
||||
SmallVectorImpl<char> &NameOut);
|
||||
|
||||
/// GetMethodVarName - Return a unique constant for the given
|
||||
/// selector's name. The return value has type char *.
|
||||
|
@ -786,7 +786,7 @@ protected:
|
|||
|
||||
/// EmitPropertyList - Emit the given property list. The return
|
||||
/// value has type PropertyListPtrTy.
|
||||
llvm::Constant *EmitPropertyList(llvm::Twine Name,
|
||||
llvm::Constant *EmitPropertyList(Twine Name,
|
||||
const Decl *Container,
|
||||
const ObjCContainerDecl *OCD,
|
||||
const ObjCCommonTypesHelper &ObjCTypes);
|
||||
|
@ -817,7 +817,7 @@ protected:
|
|||
/// \param Align - The alignment for the variable, or 0.
|
||||
/// \param AddToUsed - Whether the variable should be added to
|
||||
/// "llvm.used".
|
||||
llvm::GlobalVariable *CreateMetadataVar(llvm::Twine Name,
|
||||
llvm::GlobalVariable *CreateMetadataVar(Twine Name,
|
||||
llvm::Constant *Init,
|
||||
const char *Section,
|
||||
unsigned Align,
|
||||
|
@ -923,7 +923,7 @@ private:
|
|||
|
||||
/// EmitMethodList - Emit the method list for the given
|
||||
/// implementation. The return value has type MethodListPtrTy.
|
||||
llvm::Constant *EmitMethodList(llvm::Twine Name,
|
||||
llvm::Constant *EmitMethodList(Twine Name,
|
||||
const char *Section,
|
||||
const ConstantVector &Methods);
|
||||
|
||||
|
@ -938,7 +938,7 @@ private:
|
|||
/// - begin, end: The method list to output.
|
||||
///
|
||||
/// The return value has type MethodDescriptionListPtrTy.
|
||||
llvm::Constant *EmitMethodDescList(llvm::Twine Name,
|
||||
llvm::Constant *EmitMethodDescList(Twine Name,
|
||||
const char *Section,
|
||||
const ConstantVector &Methods);
|
||||
|
||||
|
@ -964,7 +964,7 @@ private:
|
|||
|
||||
/// EmitProtocolList - Generate the list of referenced
|
||||
/// protocols. The return value has type ProtocolListPtrTy.
|
||||
llvm::Constant *EmitProtocolList(llvm::Twine Name,
|
||||
llvm::Constant *EmitProtocolList(Twine Name,
|
||||
ObjCProtocolDecl::protocol_iterator begin,
|
||||
ObjCProtocolDecl::protocol_iterator end);
|
||||
|
||||
|
@ -1117,7 +1117,7 @@ private:
|
|||
|
||||
/// EmitMethodList - Emit the method list for the given
|
||||
/// implementation. The return value has type MethodListnfABITy.
|
||||
llvm::Constant *EmitMethodList(llvm::Twine Name,
|
||||
llvm::Constant *EmitMethodList(Twine Name,
|
||||
const char *Section,
|
||||
const ConstantVector &Methods);
|
||||
/// EmitIvarList - Emit the ivar list for the given
|
||||
|
@ -1144,7 +1144,7 @@ private:
|
|||
|
||||
/// EmitProtocolList - Generate the list of referenced
|
||||
/// protocols. The return value has type ProtocolListPtrTy.
|
||||
llvm::Constant *EmitProtocolList(llvm::Twine Name,
|
||||
llvm::Constant *EmitProtocolList(Twine Name,
|
||||
ObjCProtocolDecl::protocol_iterator begin,
|
||||
ObjCProtocolDecl::protocol_iterator end);
|
||||
|
||||
|
@ -1878,7 +1878,7 @@ CGObjCMac::EmitProtocolExtension(const ObjCProtocolDecl *PD,
|
|||
};
|
||||
*/
|
||||
llvm::Constant *
|
||||
CGObjCMac::EmitProtocolList(llvm::Twine Name,
|
||||
CGObjCMac::EmitProtocolList(Twine Name,
|
||||
ObjCProtocolDecl::protocol_iterator begin,
|
||||
ObjCProtocolDecl::protocol_iterator end) {
|
||||
std::vector<llvm::Constant*> ProtocolRefs;
|
||||
|
@ -1942,7 +1942,7 @@ void CGObjCCommonMac::PushProtocolProperties(llvm::SmallPtrSet<const IdentifierI
|
|||
struct _objc_property[prop_count];
|
||||
};
|
||||
*/
|
||||
llvm::Constant *CGObjCCommonMac::EmitPropertyList(llvm::Twine Name,
|
||||
llvm::Constant *CGObjCCommonMac::EmitPropertyList(Twine Name,
|
||||
const Decl *Container,
|
||||
const ObjCContainerDecl *OCD,
|
||||
const ObjCCommonTypesHelper &ObjCTypes) {
|
||||
|
@ -2014,7 +2014,7 @@ CGObjCMac::GetMethodDescriptionConstant(const ObjCMethodDecl *MD) {
|
|||
Desc);
|
||||
}
|
||||
|
||||
llvm::Constant *CGObjCMac::EmitMethodDescList(llvm::Twine Name,
|
||||
llvm::Constant *CGObjCMac::EmitMethodDescList(Twine Name,
|
||||
const char *Section,
|
||||
const ConstantVector &Methods) {
|
||||
// Return null for empty list.
|
||||
|
@ -2475,7 +2475,7 @@ llvm::Constant *CGObjCMac::GetMethodConstant(const ObjCMethodDecl *MD) {
|
|||
return llvm::ConstantStruct::get(ObjCTypes.MethodTy, Method);
|
||||
}
|
||||
|
||||
llvm::Constant *CGObjCMac::EmitMethodList(llvm::Twine Name,
|
||||
llvm::Constant *CGObjCMac::EmitMethodList(Twine Name,
|
||||
const char *Section,
|
||||
const ConstantVector &Methods) {
|
||||
// Return null for empty list.
|
||||
|
@ -2513,7 +2513,7 @@ llvm::Function *CGObjCCommonMac::GenerateMethod(const ObjCMethodDecl *OMD,
|
|||
}
|
||||
|
||||
llvm::GlobalVariable *
|
||||
CGObjCCommonMac::CreateMetadataVar(llvm::Twine Name,
|
||||
CGObjCCommonMac::CreateMetadataVar(Twine Name,
|
||||
llvm::Constant *Init,
|
||||
const char *Section,
|
||||
unsigned Align,
|
||||
|
@ -2626,7 +2626,7 @@ namespace {
|
|||
|
||||
class FragileHazards {
|
||||
CodeGenFunction &CGF;
|
||||
llvm::SmallVector<llvm::Value*, 20> Locals;
|
||||
SmallVector<llvm::Value*, 20> Locals;
|
||||
llvm::DenseSet<llvm::BasicBlock*> BlocksBeforeTry;
|
||||
|
||||
llvm::InlineAsm *ReadHazard;
|
||||
|
@ -2765,7 +2765,7 @@ void FragileHazards::collectLocals() {
|
|||
}
|
||||
|
||||
llvm::FunctionType *FragileHazards::GetAsmFnType() {
|
||||
llvm::SmallVector<llvm::Type *, 16> tys(Locals.size());
|
||||
SmallVector<llvm::Type *, 16> tys(Locals.size());
|
||||
for (unsigned i = 0, e = Locals.size(); i != e; ++i)
|
||||
tys[i] = Locals[i]->getType();
|
||||
return llvm::FunctionType::get(CGF.VoidTy, tys, false);
|
||||
|
@ -3756,7 +3756,7 @@ llvm::Constant *CGObjCCommonMac::BuildIvarLayoutBitmap(std::string& BitMap) {
|
|||
llvm::Type *PtrTy = llvm::Type::getInt8PtrTy(VMContext);
|
||||
|
||||
// Build the string of skip/scan nibbles
|
||||
llvm::SmallVector<SKIP_SCAN, 32> SkipScanIvars;
|
||||
SmallVector<SKIP_SCAN, 32> SkipScanIvars;
|
||||
unsigned int WordSize =
|
||||
CGM.getTypes().getTargetData().getTypeAllocSize(PtrTy);
|
||||
if (IvarsInfo[0].ivar_bytepos == 0) {
|
||||
|
@ -4034,7 +4034,7 @@ CGObjCCommonMac::GetPropertyTypeString(const ObjCPropertyDecl *PD,
|
|||
|
||||
void CGObjCCommonMac::GetNameForMethod(const ObjCMethodDecl *D,
|
||||
const ObjCContainerDecl *CD,
|
||||
llvm::SmallVectorImpl<char> &Name) {
|
||||
SmallVectorImpl<char> &Name) {
|
||||
llvm::raw_svector_ostream OS(Name);
|
||||
assert (CD && "Missing container decl in GetNameForMethod");
|
||||
OS << '\01' << (D->isInstanceMethod() ? '-' : '+')
|
||||
|
@ -5165,7 +5165,7 @@ llvm::Constant *CGObjCNonFragileABIMac::GetMethodConstant(
|
|||
/// struct _objc_method method_list[method_count];
|
||||
/// }
|
||||
///
|
||||
llvm::Constant *CGObjCNonFragileABIMac::EmitMethodList(llvm::Twine Name,
|
||||
llvm::Constant *CGObjCNonFragileABIMac::EmitMethodList(Twine Name,
|
||||
const char *Section,
|
||||
const ConstantVector &Methods) {
|
||||
// Return null for empty list.
|
||||
|
@ -5458,7 +5458,7 @@ llvm::Constant *CGObjCNonFragileABIMac::GetOrEmitProtocol(
|
|||
/// @endcode
|
||||
///
|
||||
llvm::Constant *
|
||||
CGObjCNonFragileABIMac::EmitProtocolList(llvm::Twine Name,
|
||||
CGObjCNonFragileABIMac::EmitProtocolList(Twine Name,
|
||||
ObjCProtocolDecl::protocol_iterator begin,
|
||||
ObjCProtocolDecl::protocol_iterator end) {
|
||||
std::vector<llvm::Constant*> ProtocolRefs;
|
||||
|
|
|
@ -177,7 +177,7 @@ void CGObjCRuntime::EmitTryCatchStmt(CodeGenFunction &CGF,
|
|||
FinallyInfo.enter(CGF, Finally->getFinallyBody(),
|
||||
beginCatchFn, endCatchFn, exceptionRethrowFn);
|
||||
|
||||
llvm::SmallVector<CatchHandler, 8> Handlers;
|
||||
SmallVector<CatchHandler, 8> Handlers;
|
||||
|
||||
// Enter the catch, if there is one.
|
||||
if (S.getNumCatchStmts()) {
|
||||
|
|
|
@ -29,7 +29,7 @@ class RTTIBuilder {
|
|||
llvm::Type *Int8PtrTy;
|
||||
|
||||
/// Fields - The fields of the RTTI descriptor currently being built.
|
||||
llvm::SmallVector<llvm::Constant *, 16> Fields;
|
||||
SmallVector<llvm::Constant *, 16> Fields;
|
||||
|
||||
/// GetAddrOfTypeName - Returns the mangled type name of the given type.
|
||||
llvm::GlobalVariable *
|
||||
|
@ -120,7 +120,7 @@ RTTIBuilder::GetAddrOfTypeName(QualType Ty,
|
|||
llvm::raw_svector_ostream Out(OutName);
|
||||
CGM.getCXXABI().getMangleContext().mangleCXXRTTIName(Ty, Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
// We know that the mangled name of the type starts at index 4 of the
|
||||
// mangled name of the typename, so we can just index into it in order to
|
||||
|
@ -141,7 +141,7 @@ llvm::Constant *RTTIBuilder::GetAddrOfExternalRTTIDescriptor(QualType Ty) {
|
|||
llvm::raw_svector_ostream Out(OutName);
|
||||
CGM.getCXXABI().getMangleContext().mangleCXXRTTI(Ty, Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
// Look for an existing global.
|
||||
llvm::GlobalVariable *GV = CGM.getModule().getNamedGlobal(Name);
|
||||
|
@ -533,7 +533,7 @@ maybeUpdateRTTILinkage(CodeGenModule &CGM, llvm::GlobalVariable *GV,
|
|||
llvm::raw_svector_ostream Out(OutName);
|
||||
CGM.getCXXABI().getMangleContext().mangleCXXRTTIName(Ty, Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
llvm::GlobalVariable *TypeNameGV = CGM.getModule().getNamedGlobal(Name);
|
||||
|
||||
|
@ -553,7 +553,7 @@ llvm::Constant *RTTIBuilder::BuildTypeInfo(QualType Ty, bool Force) {
|
|||
llvm::raw_svector_ostream Out(OutName);
|
||||
CGM.getCXXABI().getMangleContext().mangleCXXRTTI(Ty, Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
llvm::GlobalVariable *OldGV = CGM.getModule().getNamedGlobal(Name);
|
||||
if (OldGV && !OldGV->isDeclaration()) {
|
||||
|
|
|
@ -35,7 +35,7 @@ class CGRecordLayoutBuilder {
|
|||
public:
|
||||
/// FieldTypes - Holds the LLVM types that the struct is created from.
|
||||
///
|
||||
llvm::SmallVector<llvm::Type *, 16> FieldTypes;
|
||||
SmallVector<llvm::Type *, 16> FieldTypes;
|
||||
|
||||
/// BaseSubobjectType - Holds the LLVM type for the non-virtual part
|
||||
/// of the struct. For example, consider:
|
||||
|
@ -1037,7 +1037,7 @@ CGRecordLayout *CodeGenTypes::ComputeRecordLayout(const RecordDecl *D,
|
|||
return RL;
|
||||
}
|
||||
|
||||
void CGRecordLayout::print(llvm::raw_ostream &OS) const {
|
||||
void CGRecordLayout::print(raw_ostream &OS) const {
|
||||
OS << "<CGRecordLayout\n";
|
||||
OS << " LLVMType:" << *CompleteObjectType << "\n";
|
||||
if (BaseSubobjectType)
|
||||
|
@ -1071,7 +1071,7 @@ void CGRecordLayout::dump() const {
|
|||
print(llvm::errs());
|
||||
}
|
||||
|
||||
void CGBitFieldInfo::print(llvm::raw_ostream &OS) const {
|
||||
void CGBitFieldInfo::print(raw_ostream &OS) const {
|
||||
OS << "<CGBitFieldInfo";
|
||||
OS << " Size:" << Size;
|
||||
OS << " IsSigned:" << IsSigned << "\n";
|
||||
|
|
|
@ -961,7 +961,7 @@ enum CSFC_Result { CSFC_Failure, CSFC_FallThrough, CSFC_Success };
|
|||
static CSFC_Result CollectStatementsForCase(const Stmt *S,
|
||||
const SwitchCase *Case,
|
||||
bool &FoundCase,
|
||||
llvm::SmallVectorImpl<const Stmt*> &ResultStmts) {
|
||||
SmallVectorImpl<const Stmt*> &ResultStmts) {
|
||||
// If this is a null statement, just succeed.
|
||||
if (S == 0)
|
||||
return Case ? CSFC_Success : CSFC_FallThrough;
|
||||
|
@ -1086,7 +1086,7 @@ static CSFC_Result CollectStatementsForCase(const Stmt *S,
|
|||
/// for more details.
|
||||
static bool FindCaseStatementsForValue(const SwitchStmt &S,
|
||||
const llvm::APInt &ConstantCondValue,
|
||||
llvm::SmallVectorImpl<const Stmt*> &ResultStmts,
|
||||
SmallVectorImpl<const Stmt*> &ResultStmts,
|
||||
ASTContext &C) {
|
||||
// First step, find the switch case that is being branched to. We can do this
|
||||
// efficiently by scanning the SwitchCase list.
|
||||
|
@ -1147,7 +1147,7 @@ void CodeGenFunction::EmitSwitchStmt(const SwitchStmt &S) {
|
|||
// emit the live case statement (if any) of the switch.
|
||||
llvm::APInt ConstantCondValue;
|
||||
if (ConstantFoldsToSimpleInteger(S.getCond(), ConstantCondValue)) {
|
||||
llvm::SmallVector<const Stmt*, 4> CaseStmts;
|
||||
SmallVector<const Stmt*, 4> CaseStmts;
|
||||
if (FindCaseStatementsForValue(S, ConstantCondValue, CaseStmts,
|
||||
getContext())) {
|
||||
RunCleanupsScope ExecutedScope(*this);
|
||||
|
@ -1219,7 +1219,7 @@ void CodeGenFunction::EmitSwitchStmt(const SwitchStmt &S) {
|
|||
|
||||
static std::string
|
||||
SimplifyConstraint(const char *Constraint, const TargetInfo &Target,
|
||||
llvm::SmallVectorImpl<TargetInfo::ConstraintInfo> *OutCons=0) {
|
||||
SmallVectorImpl<TargetInfo::ConstraintInfo> *OutCons=0) {
|
||||
std::string Result;
|
||||
|
||||
while (*Constraint) {
|
||||
|
@ -1276,7 +1276,7 @@ AddVariableConstraints(const std::string &Constraint, const Expr &AsmExpr,
|
|||
AsmLabelAttr *Attr = Variable->getAttr<AsmLabelAttr>();
|
||||
if (!Attr)
|
||||
return Constraint;
|
||||
llvm::StringRef Register = Attr->getLabel();
|
||||
StringRef Register = Attr->getLabel();
|
||||
assert(Target.isValidGCCRegisterName(Register));
|
||||
// We're using validateOutputConstraint here because we only care if
|
||||
// this is a register constraint.
|
||||
|
@ -1341,11 +1341,11 @@ llvm::Value* CodeGenFunction::EmitAsmInput(const AsmStmt &S,
|
|||
/// asm.
|
||||
static llvm::MDNode *getAsmSrcLocInfo(const StringLiteral *Str,
|
||||
CodeGenFunction &CGF) {
|
||||
llvm::SmallVector<llvm::Value *, 8> Locs;
|
||||
SmallVector<llvm::Value *, 8> Locs;
|
||||
// Add the location of the first line to the MDNode.
|
||||
Locs.push_back(llvm::ConstantInt::get(CGF.Int32Ty,
|
||||
Str->getLocStart().getRawEncoding()));
|
||||
llvm::StringRef StrVal = Str->getString();
|
||||
StringRef StrVal = Str->getString();
|
||||
if (!StrVal.empty()) {
|
||||
const SourceManager &SM = CGF.CGM.getContext().getSourceManager();
|
||||
const LangOptions &LangOpts = CGF.CGM.getLangOptions();
|
||||
|
@ -1367,7 +1367,7 @@ static llvm::MDNode *getAsmSrcLocInfo(const StringLiteral *Str,
|
|||
void CodeGenFunction::EmitAsmStmt(const AsmStmt &S) {
|
||||
// Analyze the asm string to decompose it into its pieces. We know that Sema
|
||||
// has already done this, so it is guaranteed to be successful.
|
||||
llvm::SmallVector<AsmStmt::AsmStringPiece, 4> Pieces;
|
||||
SmallVector<AsmStmt::AsmStringPiece, 4> Pieces;
|
||||
unsigned DiagOffs;
|
||||
S.AnalyzeAsmString(Pieces, getContext(), DiagOffs);
|
||||
|
||||
|
@ -1384,8 +1384,8 @@ void CodeGenFunction::EmitAsmStmt(const AsmStmt &S) {
|
|||
}
|
||||
|
||||
// Get all the output and input constraints together.
|
||||
llvm::SmallVector<TargetInfo::ConstraintInfo, 4> OutputConstraintInfos;
|
||||
llvm::SmallVector<TargetInfo::ConstraintInfo, 4> InputConstraintInfos;
|
||||
SmallVector<TargetInfo::ConstraintInfo, 4> OutputConstraintInfos;
|
||||
SmallVector<TargetInfo::ConstraintInfo, 4> InputConstraintInfos;
|
||||
|
||||
for (unsigned i = 0, e = S.getNumOutputs(); i != e; i++) {
|
||||
TargetInfo::ConstraintInfo Info(S.getOutputConstraint(i),
|
||||
|
@ -1556,7 +1556,7 @@ void CodeGenFunction::EmitAsmStmt(const AsmStmt &S) {
|
|||
|
||||
// Clobbers
|
||||
for (unsigned i = 0, e = S.getNumClobbers(); i != e; i++) {
|
||||
llvm::StringRef Clobber = S.getClobber(i)->getString();
|
||||
StringRef Clobber = S.getClobber(i)->getString();
|
||||
|
||||
if (Clobber != "memory" && Clobber != "cc")
|
||||
Clobber = Target.getNormalizedGCCRegisterName(Clobber);
|
||||
|
|
|
@ -30,7 +30,7 @@ class VTTBuilder {
|
|||
/// vtable.
|
||||
const CXXRecordDecl *MostDerivedClass;
|
||||
|
||||
typedef llvm::SmallVector<llvm::Constant *, 64> VTTComponentsVectorTy;
|
||||
typedef SmallVector<llvm::Constant *, 64> VTTComponentsVectorTy;
|
||||
|
||||
/// VTTComponents - The VTT components.
|
||||
VTTComponentsVectorTy VTTComponents;
|
||||
|
@ -408,7 +408,7 @@ llvm::GlobalVariable *CodeGenVTables::GetAddrOfVTT(const CXXRecordDecl *RD) {
|
|||
llvm::raw_svector_ostream Out(OutName);
|
||||
CGM.getCXXABI().getMangleContext().mangleCXXVTT(RD, Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
ComputeVTableRelatedInformation(RD, /*VTableRequired=*/true);
|
||||
|
||||
|
|
|
@ -122,7 +122,7 @@ private:
|
|||
|
||||
/// dump - dump the final overriders for a base subobject, and all its direct
|
||||
/// and indirect base subobjects.
|
||||
void dump(llvm::raw_ostream &Out, BaseSubobject Base,
|
||||
void dump(raw_ostream &Out, BaseSubobject Base,
|
||||
VisitedVirtualBasesSetTy& VisitedVirtualBases);
|
||||
|
||||
public:
|
||||
|
@ -380,7 +380,7 @@ FinalOverriders::ComputeBaseOffsets(BaseSubobject Base, bool IsVirtual,
|
|||
}
|
||||
}
|
||||
|
||||
void FinalOverriders::dump(llvm::raw_ostream &Out, BaseSubobject Base,
|
||||
void FinalOverriders::dump(raw_ostream &Out, BaseSubobject Base,
|
||||
VisitedVirtualBasesSetTy &VisitedVirtualBases) {
|
||||
const CXXRecordDecl *RD = Base.getBase();
|
||||
const ASTRecordLayout &Layout = Context.getASTRecordLayout(RD);
|
||||
|
@ -616,7 +616,7 @@ struct VCallOffsetMap {
|
|||
|
||||
/// Offsets - Keeps track of methods and their offsets.
|
||||
// FIXME: This should be a real map and not a vector.
|
||||
llvm::SmallVector<MethodAndOffsetPairTy, 16> Offsets;
|
||||
SmallVector<MethodAndOffsetPairTy, 16> Offsets;
|
||||
|
||||
/// MethodsCanShareVCallOffset - Returns whether two virtual member functions
|
||||
/// can share the same vcall offset.
|
||||
|
@ -724,7 +724,7 @@ private:
|
|||
ASTContext &Context;
|
||||
|
||||
/// Components - vcall and vbase offset components
|
||||
typedef llvm::SmallVector<VTableComponent, 64> VTableComponentVectorTy;
|
||||
typedef SmallVector<VTableComponent, 64> VTableComponentVectorTy;
|
||||
VTableComponentVectorTy Components;
|
||||
|
||||
/// VisitedVirtualBases - Visited virtual bases.
|
||||
|
@ -999,7 +999,7 @@ private:
|
|||
VBaseOffsetOffsetsMapTy VBaseOffsetOffsets;
|
||||
|
||||
/// Components - The components of the vtable being built.
|
||||
llvm::SmallVector<VTableComponent, 64> Components;
|
||||
SmallVector<VTableComponent, 64> Components;
|
||||
|
||||
/// AddressPoints - Address points for the vtable being built.
|
||||
AddressPointsMapTy AddressPoints;
|
||||
|
@ -1042,7 +1042,7 @@ private:
|
|||
/// built.
|
||||
VTableThunksMapTy VTableThunks;
|
||||
|
||||
typedef llvm::SmallVector<ThunkInfo, 1> ThunkInfoVectorTy;
|
||||
typedef SmallVector<ThunkInfo, 1> ThunkInfoVectorTy;
|
||||
typedef llvm::DenseMap<const CXXMethodDecl *, ThunkInfoVectorTy> ThunksMapTy;
|
||||
|
||||
/// Thunks - A map that contains all the thunks needed for all methods in the
|
||||
|
@ -1214,14 +1214,14 @@ public:
|
|||
}
|
||||
|
||||
/// dumpLayout - Dump the vtable layout.
|
||||
void dumpLayout(llvm::raw_ostream&);
|
||||
void dumpLayout(raw_ostream&);
|
||||
};
|
||||
|
||||
void VTableBuilder::AddThunk(const CXXMethodDecl *MD, const ThunkInfo &Thunk) {
|
||||
assert(!isBuildingConstructorVTable() &&
|
||||
"Can't add thunks for construction vtable");
|
||||
|
||||
llvm::SmallVector<ThunkInfo, 1> &ThunksVector = Thunks[MD];
|
||||
SmallVector<ThunkInfo, 1> &ThunksVector = Thunks[MD];
|
||||
|
||||
// Check if we have this thunk already.
|
||||
if (std::find(ThunksVector.begin(), ThunksVector.end(), Thunk) !=
|
||||
|
@ -1981,7 +1981,7 @@ VTableBuilder::LayoutVTablesForVirtualBases(const CXXRecordDecl *RD,
|
|||
}
|
||||
|
||||
/// dumpLayout - Dump the vtable layout.
|
||||
void VTableBuilder::dumpLayout(llvm::raw_ostream& Out) {
|
||||
void VTableBuilder::dumpLayout(raw_ostream& Out) {
|
||||
|
||||
if (isBuildingConstructorVTable()) {
|
||||
Out << "Construction vtable for ('";
|
||||
|
@ -2881,7 +2881,7 @@ void CodeGenVTables::EmitThunk(GlobalDecl GD, const ThunkInfo &Thunk,
|
|||
"Shouldn't replace non-declaration");
|
||||
|
||||
// Remove the name from the old thunk function and get a new thunk.
|
||||
OldThunkFn->setName(llvm::StringRef());
|
||||
OldThunkFn->setName(StringRef());
|
||||
Entry = CGM.GetAddrOfThunk(GD, Thunk);
|
||||
|
||||
// If needed, replace the old thunk with a bitcast.
|
||||
|
@ -3064,7 +3064,7 @@ CodeGenVTables::CreateVTableInitializer(const CXXRecordDecl *RD,
|
|||
const uint64_t *Components,
|
||||
unsigned NumComponents,
|
||||
const VTableThunksTy &VTableThunks) {
|
||||
llvm::SmallVector<llvm::Constant *, 64> Inits;
|
||||
SmallVector<llvm::Constant *, 64> Inits;
|
||||
|
||||
llvm::Type *Int8PtrTy = llvm::Type::getInt8PtrTy(CGM.getLLVMContext());
|
||||
|
||||
|
@ -3174,7 +3174,7 @@ llvm::GlobalVariable *CodeGenVTables::GetAddrOfVTable(const CXXRecordDecl *RD) {
|
|||
llvm::raw_svector_ostream Out(OutName);
|
||||
CGM.getCXXABI().getMangleContext().mangleCXXVTable(RD, Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
ComputeVTableRelatedInformation(RD, /*VTableRequired=*/true);
|
||||
|
||||
|
@ -3244,7 +3244,7 @@ CodeGenVTables::GenerateConstructionVTable(const CXXRecordDecl *RD,
|
|||
mangleCXXCtorVTable(RD, Base.getBaseOffset().getQuantity(), Base.getBase(),
|
||||
Out);
|
||||
Out.flush();
|
||||
llvm::StringRef Name = OutName.str();
|
||||
StringRef Name = OutName.str();
|
||||
|
||||
llvm::Type *Int8PtrTy = llvm::Type::getInt8PtrTy(CGM.getLLVMContext());
|
||||
llvm::ArrayType *ArrayType =
|
||||
|
|
|
@ -35,7 +35,7 @@ namespace clang {
|
|||
const CodeGenOptions &CodeGenOpts;
|
||||
const TargetOptions &TargetOpts;
|
||||
const LangOptions &LangOpts;
|
||||
llvm::raw_ostream *AsmOutStream;
|
||||
raw_ostream *AsmOutStream;
|
||||
ASTContext *Context;
|
||||
|
||||
Timer LLVMIRGeneration;
|
||||
|
@ -50,7 +50,7 @@ namespace clang {
|
|||
const TargetOptions &targetopts,
|
||||
const LangOptions &langopts,
|
||||
bool TimePasses,
|
||||
const std::string &infile, llvm::raw_ostream *OS,
|
||||
const std::string &infile, raw_ostream *OS,
|
||||
LLVMContext &C) :
|
||||
Diags(_Diags),
|
||||
Action(action),
|
||||
|
@ -199,7 +199,7 @@ void BackendConsumer::InlineAsmDiagHandler2(const llvm::SMDiagnostic &D,
|
|||
// we re-format the SMDiagnostic in terms of a clang diagnostic.
|
||||
|
||||
// Strip "error: " off the start of the message string.
|
||||
llvm::StringRef Message = D.getMessage();
|
||||
StringRef Message = D.getMessage();
|
||||
if (Message.startswith("error: "))
|
||||
Message = Message.substr(7);
|
||||
|
||||
|
@ -259,7 +259,7 @@ llvm::LLVMContext *CodeGenAction::takeLLVMContext() {
|
|||
}
|
||||
|
||||
static raw_ostream *GetOutputStream(CompilerInstance &CI,
|
||||
llvm::StringRef InFile,
|
||||
StringRef InFile,
|
||||
BackendAction Action) {
|
||||
switch (Action) {
|
||||
case Backend_EmitAssembly:
|
||||
|
@ -280,9 +280,9 @@ static raw_ostream *GetOutputStream(CompilerInstance &CI,
|
|||
}
|
||||
|
||||
ASTConsumer *CodeGenAction::CreateASTConsumer(CompilerInstance &CI,
|
||||
llvm::StringRef InFile) {
|
||||
StringRef InFile) {
|
||||
BackendAction BA = static_cast<BackendAction>(Act);
|
||||
llvm::OwningPtr<llvm::raw_ostream> OS(GetOutputStream(CI, InFile, BA));
|
||||
llvm::OwningPtr<raw_ostream> OS(GetOutputStream(CI, InFile, BA));
|
||||
if (BA != Backend_EmitNothing && !OS)
|
||||
return 0;
|
||||
|
||||
|
@ -326,7 +326,7 @@ void CodeGenAction::ExecuteAction() {
|
|||
|
||||
// Get a custom diagnostic for the error. We strip off a leading
|
||||
// diagnostic code if there is one.
|
||||
llvm::StringRef Msg = Err.getMessage();
|
||||
StringRef Msg = Err.getMessage();
|
||||
if (Msg.startswith("error: "))
|
||||
Msg = Msg.substr(7);
|
||||
unsigned DiagID = CI.getDiagnostics().getCustomDiagID(Diagnostic::Error,
|
||||
|
|
|
@ -740,7 +740,7 @@ CodeGenFunction::EmitNullInitialization(llvm::Value *DestPtr, QualType Ty) {
|
|||
new llvm::GlobalVariable(CGM.getModule(), NullConstant->getType(),
|
||||
/*isConstant=*/true,
|
||||
llvm::GlobalVariable::PrivateLinkage,
|
||||
NullConstant, llvm::Twine());
|
||||
NullConstant, Twine());
|
||||
llvm::Value *SrcPtr =
|
||||
Builder.CreateBitCast(NullVariable, Builder.getInt8PtrTy());
|
||||
|
||||
|
@ -818,7 +818,7 @@ llvm::Value *CodeGenFunction::emitArrayLength(const ArrayType *origArrayType,
|
|||
// We have some number of constant-length arrays, so addr should
|
||||
// have LLVM type [M x [N x [...]]]*. Build a GEP that walks
|
||||
// down to the first element of addr.
|
||||
llvm::SmallVector<llvm::Value*, 8> gepIndices;
|
||||
SmallVector<llvm::Value*, 8> gepIndices;
|
||||
|
||||
// GEP down to the array type.
|
||||
llvm::ConstantInt *zero = Builder.getInt32(0);
|
||||
|
|
|
@ -166,7 +166,7 @@ bool CodeGenModule::isTargetDarwin() const {
|
|||
return getContext().Target.getTriple().isOSDarwin();
|
||||
}
|
||||
|
||||
void CodeGenModule::Error(SourceLocation loc, llvm::StringRef error) {
|
||||
void CodeGenModule::Error(SourceLocation loc, StringRef error) {
|
||||
unsigned diagID = getDiags().getCustomDiagID(Diagnostic::Error, error);
|
||||
getDiags().Report(Context.getFullLoc(loc), diagID);
|
||||
}
|
||||
|
@ -281,10 +281,10 @@ void CodeGenModule::setTypeVisibility(llvm::GlobalValue *GV,
|
|||
GV->setUnnamedAddr(true);
|
||||
}
|
||||
|
||||
llvm::StringRef CodeGenModule::getMangledName(GlobalDecl GD) {
|
||||
StringRef CodeGenModule::getMangledName(GlobalDecl GD) {
|
||||
const NamedDecl *ND = cast<NamedDecl>(GD.getDecl());
|
||||
|
||||
llvm::StringRef &Str = MangledDeclNames[GD.getCanonicalDecl()];
|
||||
StringRef &Str = MangledDeclNames[GD.getCanonicalDecl()];
|
||||
if (!Str.empty())
|
||||
return Str;
|
||||
|
||||
|
@ -313,7 +313,7 @@ llvm::StringRef CodeGenModule::getMangledName(GlobalDecl GD) {
|
|||
char *Name = MangledNamesAllocator.Allocate<char>(Length);
|
||||
std::copy(Buffer.begin(), Buffer.end(), Name);
|
||||
|
||||
Str = llvm::StringRef(Name, Length);
|
||||
Str = StringRef(Name, Length);
|
||||
|
||||
return Str;
|
||||
}
|
||||
|
@ -333,7 +333,7 @@ void CodeGenModule::getBlockMangledName(GlobalDecl GD, MangleBuffer &Buffer,
|
|||
MangleCtx.mangleBlock(cast<DeclContext>(D), BD, Out);
|
||||
}
|
||||
|
||||
llvm::GlobalValue *CodeGenModule::GetGlobalValue(llvm::StringRef Name) {
|
||||
llvm::GlobalValue *CodeGenModule::GetGlobalValue(StringRef Name) {
|
||||
return getModule().getNamedValue(Name);
|
||||
}
|
||||
|
||||
|
@ -618,7 +618,7 @@ void CodeGenModule::EmitDeferred() {
|
|||
// ignore these cases.
|
||||
//
|
||||
// TODO: That said, looking this up multiple times is very wasteful.
|
||||
llvm::StringRef Name = getMangledName(D);
|
||||
StringRef Name = getMangledName(D);
|
||||
llvm::GlobalValue *CGRef = GetGlobalValue(Name);
|
||||
assert(CGRef && "Deferred decl wasn't referenced?");
|
||||
|
||||
|
@ -731,7 +731,7 @@ void CodeGenModule::EmitGlobal(GlobalDecl GD) {
|
|||
// Ignore declarations, they will be emitted on their first use.
|
||||
if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(Global)) {
|
||||
if (FD->getIdentifier()) {
|
||||
llvm::StringRef Name = FD->getName();
|
||||
StringRef Name = FD->getName();
|
||||
if (Name == "_Block_object_assign") {
|
||||
BlockObjectAssignDecl = FD;
|
||||
} else if (Name == "_Block_object_dispose") {
|
||||
|
@ -747,7 +747,7 @@ void CodeGenModule::EmitGlobal(GlobalDecl GD) {
|
|||
const FunctionDecl *InlineDefinition = 0;
|
||||
FD->getBody(InlineDefinition);
|
||||
|
||||
llvm::StringRef MangledName = getMangledName(GD);
|
||||
StringRef MangledName = getMangledName(GD);
|
||||
llvm::StringMap<GlobalDecl>::iterator DDI =
|
||||
DeferredDecls.find(MangledName);
|
||||
if (DDI != DeferredDecls.end())
|
||||
|
@ -760,7 +760,7 @@ void CodeGenModule::EmitGlobal(GlobalDecl GD) {
|
|||
assert(VD->isFileVarDecl() && "Cannot emit local var decl as global.");
|
||||
|
||||
if (VD->getIdentifier()) {
|
||||
llvm::StringRef Name = VD->getName();
|
||||
StringRef Name = VD->getName();
|
||||
if (Name == "_NSConcreteGlobalBlock") {
|
||||
NSConcreteGlobalBlockDecl = VD;
|
||||
} else if (Name == "_NSConcreteStackBlock") {
|
||||
|
@ -791,7 +791,7 @@ void CodeGenModule::EmitGlobal(GlobalDecl GD) {
|
|||
|
||||
// If the value has already been used, add it directly to the
|
||||
// DeferredDeclsToEmit list.
|
||||
llvm::StringRef MangledName = getMangledName(GD);
|
||||
StringRef MangledName = getMangledName(GD);
|
||||
if (GetGlobalValue(MangledName))
|
||||
DeferredDeclsToEmit.push_back(GD);
|
||||
else {
|
||||
|
@ -851,7 +851,7 @@ void CodeGenModule::EmitGlobalDefinition(GlobalDecl GD) {
|
|||
/// If D is non-null, it specifies a decl that correspond to this. This is used
|
||||
/// to set the attributes on the function when it is first created.
|
||||
llvm::Constant *
|
||||
CodeGenModule::GetOrCreateLLVMFunction(llvm::StringRef MangledName,
|
||||
CodeGenModule::GetOrCreateLLVMFunction(StringRef MangledName,
|
||||
llvm::Type *Ty,
|
||||
GlobalDecl D, bool ForVTable,
|
||||
llvm::Attributes ExtraAttrs) {
|
||||
|
@ -954,7 +954,7 @@ llvm::Constant *CodeGenModule::GetAddrOfFunction(GlobalDecl GD,
|
|||
if (!Ty)
|
||||
Ty = getTypes().ConvertType(cast<ValueDecl>(GD.getDecl())->getType());
|
||||
|
||||
llvm::StringRef MangledName = getMangledName(GD);
|
||||
StringRef MangledName = getMangledName(GD);
|
||||
return GetOrCreateLLVMFunction(MangledName, Ty, GD, ForVTable);
|
||||
}
|
||||
|
||||
|
@ -962,7 +962,7 @@ llvm::Constant *CodeGenModule::GetAddrOfFunction(GlobalDecl GD,
|
|||
/// type and name.
|
||||
llvm::Constant *
|
||||
CodeGenModule::CreateRuntimeFunction(llvm::FunctionType *FTy,
|
||||
llvm::StringRef Name,
|
||||
StringRef Name,
|
||||
llvm::Attributes ExtraAttrs) {
|
||||
return GetOrCreateLLVMFunction(Name, FTy, GlobalDecl(), /*ForVTable=*/false,
|
||||
ExtraAttrs);
|
||||
|
@ -992,7 +992,7 @@ static bool DeclIsConstantGlobal(ASTContext &Context, const VarDecl *D,
|
|||
/// If D is non-null, it specifies a decl that correspond to this. This is used
|
||||
/// to set the attributes on the global when it is first created.
|
||||
llvm::Constant *
|
||||
CodeGenModule::GetOrCreateLLVMGlobal(llvm::StringRef MangledName,
|
||||
CodeGenModule::GetOrCreateLLVMGlobal(StringRef MangledName,
|
||||
llvm::PointerType *Ty,
|
||||
const VarDecl *D,
|
||||
bool UnnamedAddr) {
|
||||
|
@ -1062,7 +1062,7 @@ CodeGenModule::GetOrCreateLLVMGlobal(llvm::StringRef MangledName,
|
|||
|
||||
|
||||
llvm::GlobalVariable *
|
||||
CodeGenModule::CreateOrReplaceCXXRuntimeVariable(llvm::StringRef Name,
|
||||
CodeGenModule::CreateOrReplaceCXXRuntimeVariable(StringRef Name,
|
||||
llvm::Type *Ty,
|
||||
llvm::GlobalValue::LinkageTypes Linkage) {
|
||||
llvm::GlobalVariable *GV = getModule().getNamedGlobal(Name);
|
||||
|
@ -1114,7 +1114,7 @@ llvm::Constant *CodeGenModule::GetAddrOfGlobalVar(const VarDecl *D,
|
|||
llvm::PointerType *PTy =
|
||||
llvm::PointerType::get(Ty, getContext().getTargetAddressSpace(ASTTy));
|
||||
|
||||
llvm::StringRef MangledName = getMangledName(D);
|
||||
StringRef MangledName = getMangledName(D);
|
||||
return GetOrCreateLLVMGlobal(MangledName, PTy, D);
|
||||
}
|
||||
|
||||
|
@ -1122,7 +1122,7 @@ llvm::Constant *CodeGenModule::GetAddrOfGlobalVar(const VarDecl *D,
|
|||
/// specified type and name.
|
||||
llvm::Constant *
|
||||
CodeGenModule::CreateRuntimeVariable(llvm::Type *Ty,
|
||||
llvm::StringRef Name) {
|
||||
StringRef Name) {
|
||||
return GetOrCreateLLVMGlobal(Name, llvm::PointerType::getUnqual(Ty), 0,
|
||||
true);
|
||||
}
|
||||
|
@ -1134,7 +1134,7 @@ void CodeGenModule::EmitTentativeDefinition(const VarDecl *D) {
|
|||
// If we have not seen a reference to this variable yet, place it
|
||||
// into the deferred declarations table to be emitted if needed
|
||||
// later.
|
||||
llvm::StringRef MangledName = getMangledName(D);
|
||||
StringRef MangledName = getMangledName(D);
|
||||
if (!GetGlobalValue(MangledName)) {
|
||||
DeferredDecls[MangledName] = D;
|
||||
return;
|
||||
|
@ -1295,7 +1295,7 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) {
|
|||
getContext().getTargetAddressSpace(ASTTy)) {
|
||||
|
||||
// Move the old entry aside so that we'll create a new one.
|
||||
Entry->setName(llvm::StringRef());
|
||||
Entry->setName(StringRef());
|
||||
|
||||
// Make a new global with the correct type, this is now guaranteed to work.
|
||||
GV = cast<llvm::GlobalVariable>(GetAddrOfGlobalVar(D, InitType));
|
||||
|
@ -1391,7 +1391,7 @@ static void ReplaceUsesOfNonProtoTypeWithRealFunction(llvm::GlobalValue *Old,
|
|||
if (OldFn == 0) return;
|
||||
|
||||
llvm::Type *NewRetTy = NewFn->getReturnType();
|
||||
llvm::SmallVector<llvm::Value*, 4> ArgList;
|
||||
SmallVector<llvm::Value*, 4> ArgList;
|
||||
|
||||
for (llvm::Value::use_iterator UI = OldFn->use_begin(), E = OldFn->use_end();
|
||||
UI != E; ) {
|
||||
|
@ -1480,7 +1480,7 @@ void CodeGenModule::EmitGlobalFunctionDefinition(GlobalDecl GD) {
|
|||
// (e.g. "int f()") and then a definition of a different type
|
||||
// (e.g. "int f(int x)"). Move the old function aside so that it
|
||||
// doesn't interfere with GetAddrOfFunction.
|
||||
OldFn->setName(llvm::StringRef());
|
||||
OldFn->setName(StringRef());
|
||||
llvm::Function *NewFn = cast<llvm::Function>(GetAddrOfFunction(GD, Ty));
|
||||
|
||||
// If this is an implementation of a function without a prototype, try to
|
||||
|
@ -1530,7 +1530,7 @@ void CodeGenModule::EmitAliasDefinition(GlobalDecl GD) {
|
|||
const AliasAttr *AA = D->getAttr<AliasAttr>();
|
||||
assert(AA && "Not an alias?");
|
||||
|
||||
llvm::StringRef MangledName = getMangledName(GD);
|
||||
StringRef MangledName = getMangledName(GD);
|
||||
|
||||
// If there is a definition in the module, then it wins over the alias.
|
||||
// This is dubious, but allow it to be safe. Just ignore the alias.
|
||||
|
@ -1604,7 +1604,7 @@ llvm::Value *CodeGenModule::getBuiltinLibFunction(const FunctionDecl *FD,
|
|||
"isn't a lib fn");
|
||||
|
||||
// Get the name, skip over the __builtin_ prefix (if necessary).
|
||||
llvm::StringRef Name;
|
||||
StringRef Name;
|
||||
GlobalDecl D(FD);
|
||||
|
||||
// If the builtin has been declared explicitly with an assembler label,
|
||||
|
@ -1636,7 +1636,7 @@ GetConstantCFStringEntry(llvm::StringMap<llvm::Constant*> &Map,
|
|||
bool TargetIsLSB,
|
||||
bool &IsUTF16,
|
||||
unsigned &StringLength) {
|
||||
llvm::StringRef String = Literal->getString();
|
||||
StringRef String = Literal->getString();
|
||||
unsigned NumBytes = String.size();
|
||||
|
||||
// Check for simple case.
|
||||
|
@ -1646,7 +1646,7 @@ GetConstantCFStringEntry(llvm::StringMap<llvm::Constant*> &Map,
|
|||
}
|
||||
|
||||
// Otherwise, convert the UTF8 literals into a byte string.
|
||||
llvm::SmallVector<UTF16, 128> ToBuf(NumBytes);
|
||||
SmallVector<UTF16, 128> ToBuf(NumBytes);
|
||||
const UTF8 *FromPtr = (UTF8 *)String.data();
|
||||
UTF16 *ToPtr = &ToBuf[0];
|
||||
|
||||
|
@ -1678,7 +1678,7 @@ GetConstantCFStringEntry(llvm::StringMap<llvm::Constant*> &Map,
|
|||
AsBytes.push_back(0);
|
||||
|
||||
IsUTF16 = true;
|
||||
return Map.GetOrCreateValue(llvm::StringRef(AsBytes.data(), AsBytes.size()));
|
||||
return Map.GetOrCreateValue(StringRef(AsBytes.data(), AsBytes.size()));
|
||||
}
|
||||
|
||||
static llvm::StringMapEntry<llvm::Constant*> &
|
||||
|
@ -1686,7 +1686,7 @@ GetConstantStringEntry(llvm::StringMap<llvm::Constant*> &Map,
|
|||
const StringLiteral *Literal,
|
||||
unsigned &StringLength)
|
||||
{
|
||||
llvm::StringRef String = Literal->getString();
|
||||
StringRef String = Literal->getString();
|
||||
StringLength = String.size();
|
||||
return Map.GetOrCreateValue(String);
|
||||
}
|
||||
|
@ -1913,7 +1913,7 @@ CodeGenModule::GetAddrOfConstantStringFromObjCEncode(const ObjCEncodeExpr *E) {
|
|||
|
||||
|
||||
/// GenerateWritableString -- Creates storage for a string literal.
|
||||
static llvm::Constant *GenerateStringLiteral(llvm::StringRef str,
|
||||
static llvm::Constant *GenerateStringLiteral(StringRef str,
|
||||
bool constant,
|
||||
CodeGenModule &CGM,
|
||||
const char *GlobalName) {
|
||||
|
@ -1939,7 +1939,7 @@ static llvm::Constant *GenerateStringLiteral(llvm::StringRef str,
|
|||
/// Feature.WriteableStrings.
|
||||
///
|
||||
/// The result has pointer to array type.
|
||||
llvm::Constant *CodeGenModule::GetAddrOfConstantString(llvm::StringRef Str,
|
||||
llvm::Constant *CodeGenModule::GetAddrOfConstantString(StringRef Str,
|
||||
const char *GlobalName) {
|
||||
bool IsConstant = !Features.WritableStrings;
|
||||
|
||||
|
@ -1968,7 +1968,7 @@ llvm::Constant *CodeGenModule::GetAddrOfConstantString(llvm::StringRef Str,
|
|||
/// character. The result has pointer to array type.
|
||||
llvm::Constant *CodeGenModule::GetAddrOfConstantCString(const std::string &Str,
|
||||
const char *GlobalName){
|
||||
llvm::StringRef StrWithNull(Str.c_str(), Str.size() + 1);
|
||||
StringRef StrWithNull(Str.c_str(), Str.size() + 1);
|
||||
return GetAddrOfConstantString(StrWithNull, GlobalName);
|
||||
}
|
||||
|
||||
|
@ -2181,7 +2181,7 @@ void CodeGenModule::EmitTopLevelDecl(Decl *D) {
|
|||
|
||||
case Decl::FileScopeAsm: {
|
||||
FileScopeAsmDecl *AD = cast<FileScopeAsmDecl>(D);
|
||||
llvm::StringRef AsmString = AD->getAsmString()->getString();
|
||||
StringRef AsmString = AD->getAsmString()->getString();
|
||||
|
||||
const std::string &S = getModule().getModuleInlineAsm();
|
||||
if (S.empty())
|
||||
|
@ -2234,7 +2234,7 @@ void CodeGenModule::EmitDeclMetadata() {
|
|||
llvm::NamedMDNode *GlobalMetadata = 0;
|
||||
|
||||
// StaticLocalDeclMap
|
||||
for (llvm::DenseMap<GlobalDecl,llvm::StringRef>::iterator
|
||||
for (llvm::DenseMap<GlobalDecl,StringRef>::iterator
|
||||
I = MangledDeclNames.begin(), E = MangledDeclNames.end();
|
||||
I != E; ++I) {
|
||||
llvm::GlobalValue *Addr = getModule().getNamedValue(I->second);
|
||||
|
|
|
@ -58,7 +58,7 @@ llvm::MDNode *CodeGenTBAA::getChar() {
|
|||
|
||||
/// getTBAAInfoForNamedType - Create a TBAA tree node with the given string
|
||||
/// as its identifier, and the given Parent node as its tree parent.
|
||||
llvm::MDNode *CodeGenTBAA::getTBAAInfoForNamedType(llvm::StringRef NameStr,
|
||||
llvm::MDNode *CodeGenTBAA::getTBAAInfoForNamedType(StringRef NameStr,
|
||||
llvm::MDNode *Parent,
|
||||
bool Readonly) {
|
||||
// Currently there is only one flag defined - the readonly flag.
|
||||
|
|
|
@ -47,7 +47,7 @@ CodeGenTypes::~CodeGenTypes() {
|
|||
|
||||
void CodeGenTypes::addRecordTypeName(const RecordDecl *RD,
|
||||
llvm::StructType *Ty,
|
||||
llvm::StringRef suffix) {
|
||||
StringRef suffix) {
|
||||
llvm::SmallString<256> TypeName;
|
||||
llvm::raw_svector_ostream OS(TypeName);
|
||||
OS << RD->getKindName() << '.';
|
||||
|
|
|
@ -96,12 +96,12 @@ public:
|
|||
void BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
||||
CXXCtorType T,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys);
|
||||
SmallVectorImpl<CanQualType> &ArgTys);
|
||||
|
||||
void BuildDestructorSignature(const CXXDestructorDecl *Dtor,
|
||||
CXXDtorType T,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys);
|
||||
SmallVectorImpl<CanQualType> &ArgTys);
|
||||
|
||||
void BuildInstanceFunctionParams(CodeGenFunction &CGF,
|
||||
QualType &ResTy,
|
||||
|
@ -131,12 +131,12 @@ public:
|
|||
void BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
||||
CXXCtorType T,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys);
|
||||
SmallVectorImpl<CanQualType> &ArgTys);
|
||||
|
||||
void BuildDestructorSignature(const CXXDestructorDecl *Dtor,
|
||||
CXXDtorType T,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys);
|
||||
SmallVectorImpl<CanQualType> &ArgTys);
|
||||
|
||||
void BuildInstanceFunctionParams(CodeGenFunction &CGF,
|
||||
QualType &ResTy,
|
||||
|
@ -678,7 +678,7 @@ bool ItaniumCXXABI::isZeroInitializable(const MemberPointerType *MPT) {
|
|||
void ItaniumCXXABI::BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
||||
CXXCtorType Type,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
ASTContext &Context = getContext();
|
||||
|
||||
// 'this' is already there.
|
||||
|
@ -692,7 +692,7 @@ void ItaniumCXXABI::BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
|||
void ARMCXXABI::BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
||||
CXXCtorType Type,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
ItaniumCXXABI::BuildConstructorSignature(Ctor, Type, ResTy, ArgTys);
|
||||
ResTy = ArgTys[0];
|
||||
}
|
||||
|
@ -702,7 +702,7 @@ void ARMCXXABI::BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
|||
void ItaniumCXXABI::BuildDestructorSignature(const CXXDestructorDecl *Dtor,
|
||||
CXXDtorType Type,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
ASTContext &Context = getContext();
|
||||
|
||||
// 'this' is already there.
|
||||
|
@ -717,7 +717,7 @@ void ItaniumCXXABI::BuildDestructorSignature(const CXXDestructorDecl *Dtor,
|
|||
void ARMCXXABI::BuildDestructorSignature(const CXXDestructorDecl *Dtor,
|
||||
CXXDtorType Type,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
ItaniumCXXABI::BuildDestructorSignature(Dtor, Type, ResTy, ArgTys);
|
||||
|
||||
if (Type != Dtor_Deleting)
|
||||
|
|
|
@ -31,7 +31,7 @@ public:
|
|||
void BuildConstructorSignature(const CXXConstructorDecl *Ctor,
|
||||
CXXCtorType Type,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
// 'this' is already in place
|
||||
// TODO: 'for base' flag
|
||||
}
|
||||
|
@ -39,7 +39,7 @@ public:
|
|||
void BuildDestructorSignature(const CXXDestructorDecl *Ctor,
|
||||
CXXDtorType Type,
|
||||
CanQualType &ResTy,
|
||||
llvm::SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
SmallVectorImpl<CanQualType> &ArgTys) {
|
||||
// 'this' is already in place
|
||||
// TODO: 'for base' flag
|
||||
}
|
||||
|
|
|
@ -57,7 +57,7 @@ const llvm::TargetData &ABIInfo::getTargetData() const {
|
|||
|
||||
|
||||
void ABIArgInfo::dump() const {
|
||||
llvm::raw_ostream &OS = llvm::errs();
|
||||
raw_ostream &OS = llvm::errs();
|
||||
OS << "(ABIArgInfo Kind=";
|
||||
switch (TheKind) {
|
||||
case Direct:
|
||||
|
@ -357,7 +357,7 @@ bool UseX86_MMXType(llvm::Type *IRType) {
|
|||
}
|
||||
|
||||
static llvm::Type* X86AdjustInlineAsmType(CodeGen::CodeGenFunction &CGF,
|
||||
llvm::StringRef Constraint,
|
||||
StringRef Constraint,
|
||||
llvm::Type* Ty) {
|
||||
if ((Constraint == "y" || Constraint == "&y") && Ty->isVectorTy())
|
||||
return llvm::Type::getX86_MMXTy(CGF.getLLVMContext());
|
||||
|
@ -428,7 +428,7 @@ public:
|
|||
llvm::Value *Address) const;
|
||||
|
||||
llvm::Type* adjustInlineAsmType(CodeGen::CodeGenFunction &CGF,
|
||||
llvm::StringRef Constraint,
|
||||
StringRef Constraint,
|
||||
llvm::Type* Ty) const {
|
||||
return X86AdjustInlineAsmType(CGF, Constraint, Ty);
|
||||
}
|
||||
|
@ -943,7 +943,7 @@ public:
|
|||
}
|
||||
|
||||
llvm::Type* adjustInlineAsmType(CodeGen::CodeGenFunction &CGF,
|
||||
llvm::StringRef Constraint,
|
||||
StringRef Constraint,
|
||||
llvm::Type* Ty) const {
|
||||
return X86AdjustInlineAsmType(CGF, Constraint, Ty);
|
||||
}
|
||||
|
@ -2321,7 +2321,7 @@ public:
|
|||
return 13;
|
||||
}
|
||||
|
||||
llvm::StringRef getARCRetainAutoreleasedReturnValueMarker() const {
|
||||
StringRef getARCRetainAutoreleasedReturnValueMarker() const {
|
||||
return "mov\tr7, r7\t\t@ marker for objc_retainAutoreleaseReturnValue";
|
||||
}
|
||||
|
||||
|
@ -2354,7 +2354,7 @@ void ARMABIInfo::computeInfo(CGFunctionInfo &FI) const {
|
|||
|
||||
// Calling convention as default by an ABI.
|
||||
llvm::CallingConv::ID DefaultCC;
|
||||
llvm::StringRef Env = getContext().Target.getTriple().getEnvironmentName();
|
||||
StringRef Env = getContext().Target.getTriple().getEnvironmentName();
|
||||
if (Env == "gnueabi" || Env == "eabi")
|
||||
DefaultCC = llvm::CallingConv::ARM_AAPCS;
|
||||
else
|
||||
|
@ -2652,7 +2652,7 @@ void PTXABIInfo::computeInfo(CGFunctionInfo &FI) const {
|
|||
|
||||
// Calling convention as default by an ABI.
|
||||
llvm::CallingConv::ID DefaultCC;
|
||||
llvm::StringRef Env = getContext().Target.getTriple().getEnvironmentName();
|
||||
StringRef Env = getContext().Target.getTriple().getEnvironmentName();
|
||||
if (Env == "device")
|
||||
DefaultCC = llvm::CallingConv::PTX_Device;
|
||||
else
|
||||
|
@ -2891,7 +2891,7 @@ void MSP430TargetCodeGenInfo::SetTargetAttributes(const Decl *D,
|
|||
// Step 3: Emit ISR vector alias.
|
||||
unsigned Num = attr->getNumber() + 0xffe0;
|
||||
new llvm::GlobalAlias(GV->getType(), llvm::Function::ExternalLinkage,
|
||||
"vector_" + llvm::Twine::utohexstr(Num),
|
||||
"vector_" + Twine::utohexstr(Num),
|
||||
GV, &M.getModule());
|
||||
}
|
||||
}
|
||||
|
|
|
@ -117,8 +117,8 @@ bool ArgList::hasFlag(OptSpecifier Pos, OptSpecifier Neg, bool Default) const {
|
|||
return Default;
|
||||
}
|
||||
|
||||
llvm::StringRef ArgList::getLastArgValue(OptSpecifier Id,
|
||||
llvm::StringRef Default) const {
|
||||
StringRef ArgList::getLastArgValue(OptSpecifier Id,
|
||||
StringRef Default) const {
|
||||
if (Arg *A = getLastArg(Id))
|
||||
return A->getValue(*this);
|
||||
return Default;
|
||||
|
@ -129,7 +129,7 @@ int ArgList::getLastArgIntValue(OptSpecifier Id, int Default,
|
|||
int Res = Default;
|
||||
|
||||
if (Arg *A = getLastArg(Id)) {
|
||||
if (llvm::StringRef(A->getValue(*this)).getAsInteger(10, Res))
|
||||
if (StringRef(A->getValue(*this)).getAsInteger(10, Res))
|
||||
Diags.Report(diag::err_drv_invalid_int_value)
|
||||
<< A->getAsString(*this) << A->getValue(*this);
|
||||
}
|
||||
|
@ -138,7 +138,7 @@ int ArgList::getLastArgIntValue(OptSpecifier Id, int Default,
|
|||
}
|
||||
|
||||
std::vector<std::string> ArgList::getAllArgValues(OptSpecifier Id) const {
|
||||
llvm::SmallVector<const char *, 16> Values;
|
||||
SmallVector<const char *, 16> Values;
|
||||
AddAllArgValues(Values, Id);
|
||||
return std::vector<std::string>(Values.begin(), Values.end());
|
||||
}
|
||||
|
@ -177,7 +177,7 @@ void ArgList::AddAllArgsTranslated(ArgStringList &Output, OptSpecifier Id0,
|
|||
(*it)->claim();
|
||||
|
||||
if (Joined) {
|
||||
Output.push_back(MakeArgString(llvm::StringRef(Translation) +
|
||||
Output.push_back(MakeArgString(StringRef(Translation) +
|
||||
(*it)->getValue(*this, 0)));
|
||||
} else {
|
||||
Output.push_back(Translation);
|
||||
|
@ -192,16 +192,16 @@ void ArgList::ClaimAllArgs(OptSpecifier Id0) const {
|
|||
(*it)->claim();
|
||||
}
|
||||
|
||||
const char *ArgList::MakeArgString(const llvm::Twine &T) const {
|
||||
const char *ArgList::MakeArgString(const Twine &T) const {
|
||||
llvm::SmallString<256> Str;
|
||||
T.toVector(Str);
|
||||
return MakeArgString(Str.str());
|
||||
}
|
||||
|
||||
const char *ArgList::GetOrMakeJoinedArgString(unsigned Index,
|
||||
llvm::StringRef LHS,
|
||||
llvm::StringRef RHS) const {
|
||||
llvm::StringRef Cur = getArgString(Index);
|
||||
StringRef LHS,
|
||||
StringRef RHS) const {
|
||||
StringRef Cur = getArgString(Index);
|
||||
if (Cur.size() == LHS.size() + RHS.size() &&
|
||||
Cur.startswith(LHS) && Cur.endswith(RHS))
|
||||
return Cur.data();
|
||||
|
@ -223,7 +223,7 @@ InputArgList::~InputArgList() {
|
|||
delete *it;
|
||||
}
|
||||
|
||||
unsigned InputArgList::MakeIndex(llvm::StringRef String0) const {
|
||||
unsigned InputArgList::MakeIndex(StringRef String0) const {
|
||||
unsigned Index = ArgStrings.size();
|
||||
|
||||
// Tuck away so we have a reliable const char *.
|
||||
|
@ -233,8 +233,8 @@ unsigned InputArgList::MakeIndex(llvm::StringRef String0) const {
|
|||
return Index;
|
||||
}
|
||||
|
||||
unsigned InputArgList::MakeIndex(llvm::StringRef String0,
|
||||
llvm::StringRef String1) const {
|
||||
unsigned InputArgList::MakeIndex(StringRef String0,
|
||||
StringRef String1) const {
|
||||
unsigned Index0 = MakeIndex(String0);
|
||||
unsigned Index1 = MakeIndex(String1);
|
||||
assert(Index0 + 1 == Index1 && "Unexpected non-consecutive indices!");
|
||||
|
@ -242,7 +242,7 @@ unsigned InputArgList::MakeIndex(llvm::StringRef String0,
|
|||
return Index0;
|
||||
}
|
||||
|
||||
const char *InputArgList::MakeArgString(llvm::StringRef Str) const {
|
||||
const char *InputArgList::MakeArgString(StringRef Str) const {
|
||||
return getArgString(MakeIndex(Str));
|
||||
}
|
||||
|
||||
|
@ -259,7 +259,7 @@ DerivedArgList::~DerivedArgList() {
|
|||
delete *it;
|
||||
}
|
||||
|
||||
const char *DerivedArgList::MakeArgString(llvm::StringRef Str) const {
|
||||
const char *DerivedArgList::MakeArgString(StringRef Str) const {
|
||||
return BaseArgs.MakeArgString(Str);
|
||||
}
|
||||
|
||||
|
@ -270,7 +270,7 @@ Arg *DerivedArgList::MakeFlagArg(const Arg *BaseArg, const Option *Opt) const {
|
|||
}
|
||||
|
||||
Arg *DerivedArgList::MakePositionalArg(const Arg *BaseArg, const Option *Opt,
|
||||
llvm::StringRef Value) const {
|
||||
StringRef Value) const {
|
||||
unsigned Index = BaseArgs.MakeIndex(Value);
|
||||
Arg *A = new Arg(Opt, Index, BaseArgs.getArgString(Index), BaseArg);
|
||||
SynthesizedArgs.push_back(A);
|
||||
|
@ -278,7 +278,7 @@ Arg *DerivedArgList::MakePositionalArg(const Arg *BaseArg, const Option *Opt,
|
|||
}
|
||||
|
||||
Arg *DerivedArgList::MakeSeparateArg(const Arg *BaseArg, const Option *Opt,
|
||||
llvm::StringRef Value) const {
|
||||
StringRef Value) const {
|
||||
unsigned Index = BaseArgs.MakeIndex(Opt->getName(), Value);
|
||||
Arg *A = new Arg(Opt, Index, BaseArgs.getArgString(Index + 1), BaseArg);
|
||||
SynthesizedArgs.push_back(A);
|
||||
|
@ -286,7 +286,7 @@ Arg *DerivedArgList::MakeSeparateArg(const Arg *BaseArg, const Option *Opt,
|
|||
}
|
||||
|
||||
Arg *DerivedArgList::MakeJoinedArg(const Arg *BaseArg, const Option *Opt,
|
||||
llvm::StringRef Value) const {
|
||||
StringRef Value) const {
|
||||
unsigned Index = BaseArgs.MakeIndex(Opt->getName().str() + Value.str());
|
||||
Arg *A = new Arg(Opt, Index,
|
||||
BaseArgs.getArgString(Index) + Opt->getName().size(),
|
||||
|
|
|
@ -60,7 +60,7 @@ const DerivedArgList &Compilation::getArgsForToolChain(const ToolChain *TC,
|
|||
return *Entry;
|
||||
}
|
||||
|
||||
void Compilation::PrintJob(llvm::raw_ostream &OS, const Job &J,
|
||||
void Compilation::PrintJob(raw_ostream &OS, const Job &J,
|
||||
const char *Terminator, bool Quote) const {
|
||||
if (const Command *C = dyn_cast<Command>(&J)) {
|
||||
OS << " \"" << C->getExecutable() << '"';
|
||||
|
@ -137,7 +137,7 @@ int Compilation::ExecuteCommand(const Command &C,
|
|||
|
||||
if (getDriver().CCCEcho || getDriver().CCPrintOptions ||
|
||||
getArgs().hasArg(options::OPT_v)) {
|
||||
llvm::raw_ostream *OS = &llvm::errs();
|
||||
raw_ostream *OS = &llvm::errs();
|
||||
|
||||
// Follow gcc implementation of CC_PRINT_OPTIONS; we could also cache the
|
||||
// output stream.
|
||||
|
|
|
@ -46,9 +46,9 @@
|
|||
using namespace clang::driver;
|
||||
using namespace clang;
|
||||
|
||||
Driver::Driver(llvm::StringRef ClangExecutable,
|
||||
llvm::StringRef DefaultHostTriple,
|
||||
llvm::StringRef DefaultImageName,
|
||||
Driver::Driver(StringRef ClangExecutable,
|
||||
StringRef DefaultHostTriple,
|
||||
StringRef DefaultImageName,
|
||||
bool IsProduction, bool CXXIsProduction,
|
||||
Diagnostic &Diags)
|
||||
: Opts(createDriverOptTable()), Diags(Diags),
|
||||
|
@ -82,7 +82,7 @@ Driver::Driver(llvm::StringRef ClangExecutable,
|
|||
Dir = llvm::sys::path::parent_path(ClangExecutable);
|
||||
|
||||
// Compute the path to the resource directory.
|
||||
llvm::StringRef ClangResourceDir(CLANG_RESOURCE_DIR);
|
||||
StringRef ClangResourceDir(CLANG_RESOURCE_DIR);
|
||||
llvm::SmallString<128> P(Dir);
|
||||
if (ClangResourceDir != "")
|
||||
llvm::sys::path::append(P, ClangResourceDir);
|
||||
|
@ -142,7 +142,7 @@ DerivedArgList *Driver::TranslateInputArgs(const InputArgList &Args) const {
|
|||
|
||||
// Add the remaining values as Xlinker arguments.
|
||||
for (unsigned i = 0, e = A->getNumValues(); i != e; ++i)
|
||||
if (llvm::StringRef(A->getValue(Args, i)) != "--no-demangle")
|
||||
if (StringRef(A->getValue(Args, i)) != "--no-demangle")
|
||||
DAL->AddSeparateArg(A, Opts->getOption(options::OPT_Xlinker),
|
||||
A->getValue(Args, i));
|
||||
|
||||
|
@ -154,10 +154,10 @@ DerivedArgList *Driver::TranslateInputArgs(const InputArgList &Args) const {
|
|||
// care to encourage this usage model.
|
||||
if (A->getOption().matches(options::OPT_Wp_COMMA) &&
|
||||
A->getNumValues() == 2 &&
|
||||
(A->getValue(Args, 0) == llvm::StringRef("-MD") ||
|
||||
A->getValue(Args, 0) == llvm::StringRef("-MMD"))) {
|
||||
(A->getValue(Args, 0) == StringRef("-MD") ||
|
||||
A->getValue(Args, 0) == StringRef("-MMD"))) {
|
||||
// Rewrite to -MD/-MMD along with -MF.
|
||||
if (A->getValue(Args, 0) == llvm::StringRef("-MD"))
|
||||
if (A->getValue(Args, 0) == StringRef("-MD"))
|
||||
DAL->AddFlagArg(A, Opts->getOption(options::OPT_MD));
|
||||
else
|
||||
DAL->AddFlagArg(A, Opts->getOption(options::OPT_MMD));
|
||||
|
@ -168,7 +168,7 @@ DerivedArgList *Driver::TranslateInputArgs(const InputArgList &Args) const {
|
|||
|
||||
// Rewrite reserved library names.
|
||||
if (A->getOption().matches(options::OPT_l)) {
|
||||
llvm::StringRef Value = A->getValue(Args);
|
||||
StringRef Value = A->getValue(Args);
|
||||
|
||||
// Rewrite unless -nostdlib is present.
|
||||
if (!HasNostdlib && Value == "stdc++") {
|
||||
|
@ -242,11 +242,11 @@ Compilation *Driver::BuildCompilation(llvm::ArrayRef<const char *> ArgList) {
|
|||
CCCUseClang = !Args->hasArg(options::OPT_ccc_no_clang);
|
||||
CCCUseClangCPP = !Args->hasArg(options::OPT_ccc_no_clang_cpp);
|
||||
if (const Arg *A = Args->getLastArg(options::OPT_ccc_clang_archs)) {
|
||||
llvm::StringRef Cur = A->getValue(*Args);
|
||||
StringRef Cur = A->getValue(*Args);
|
||||
|
||||
CCCClangArchs.clear();
|
||||
while (!Cur.empty()) {
|
||||
std::pair<llvm::StringRef, llvm::StringRef> Split = Cur.split(',');
|
||||
std::pair<StringRef, StringRef> Split = Cur.split(',');
|
||||
|
||||
if (!Split.first.empty()) {
|
||||
llvm::Triple::ArchType Arch =
|
||||
|
@ -382,7 +382,7 @@ void Driver::PrintHelp(bool ShowHidden) const {
|
|||
ShowHidden);
|
||||
}
|
||||
|
||||
void Driver::PrintVersion(const Compilation &C, llvm::raw_ostream &OS) const {
|
||||
void Driver::PrintVersion(const Compilation &C, raw_ostream &OS) const {
|
||||
// FIXME: The following handlers should use a callback mechanism, we don't
|
||||
// know what the client would like to do.
|
||||
OS << getClangFullVersion() << '\n';
|
||||
|
@ -397,7 +397,7 @@ void Driver::PrintVersion(const Compilation &C, llvm::raw_ostream &OS) const {
|
|||
|
||||
/// PrintDiagnosticCategories - Implement the --print-diagnostic-categories
|
||||
/// option.
|
||||
static void PrintDiagnosticCategories(llvm::raw_ostream &OS) {
|
||||
static void PrintDiagnosticCategories(raw_ostream &OS) {
|
||||
// Skip the empty category.
|
||||
for (unsigned i = 1, max = DiagnosticIDs::getNumberOfCategories();
|
||||
i != max; ++i)
|
||||
|
@ -599,7 +599,7 @@ void Driver::BuildUniversalActions(const ToolChain &TC,
|
|||
// Collect the list of architectures. Duplicates are allowed, but should only
|
||||
// be handled once (in the order seen).
|
||||
llvm::StringSet<> ArchNames;
|
||||
llvm::SmallVector<const char *, 4> Archs;
|
||||
SmallVector<const char *, 4> Archs;
|
||||
for (ArgList::const_iterator it = Args.begin(), ie = Args.end();
|
||||
it != ie; ++it) {
|
||||
Arg *A = *it;
|
||||
|
@ -699,7 +699,7 @@ void Driver::BuildActions(const ToolChain &TC, const DerivedArgList &Args,
|
|||
types::ID InputType = types::TY_Nothing;
|
||||
Arg *InputTypeArg = 0;
|
||||
|
||||
llvm::SmallVector<std::pair<types::ID, const Arg*>, 16> Inputs;
|
||||
SmallVector<std::pair<types::ID, const Arg*>, 16> Inputs;
|
||||
for (ArgList::const_iterator it = Args.begin(), ie = Args.end();
|
||||
it != ie; ++it) {
|
||||
Arg *A = *it;
|
||||
|
@ -1236,7 +1236,7 @@ const char *Driver::GetNamedOutputPath(Compilation &C,
|
|||
}
|
||||
|
||||
llvm::SmallString<128> BasePath(BaseInput);
|
||||
llvm::StringRef BaseName;
|
||||
StringRef BaseName;
|
||||
|
||||
// Dsymutil actions should use the full path.
|
||||
if (isa<DsymutilJobAction>(JA))
|
||||
|
|
|
@ -13,10 +13,10 @@
|
|||
#include "clang/Driver/Option.h"
|
||||
#include "llvm/Support/raw_ostream.h"
|
||||
#include <algorithm>
|
||||
#include <cassert>
|
||||
#include <map>
|
||||
using namespace clang::driver;
|
||||
using namespace clang::driver::options;
|
||||
using namespace clang;
|
||||
|
||||
// Ordering on Info. The ordering is *almost* lexicographic, with two
|
||||
// exceptions. First, '\0' comes at the end of the alphabet instead of
|
||||
|
@ -291,7 +291,7 @@ static std::string getOptionHelpName(const OptTable &Opts, OptSpecifier Id) {
|
|||
return Name;
|
||||
}
|
||||
|
||||
static void PrintHelpOptionList(llvm::raw_ostream &OS, llvm::StringRef Title,
|
||||
static void PrintHelpOptionList(raw_ostream &OS, StringRef Title,
|
||||
std::vector<std::pair<std::string,
|
||||
const char*> > &OptionHelp) {
|
||||
OS << Title << ":\n";
|
||||
|
@ -342,7 +342,7 @@ static const char *getOptionHelpGroup(const OptTable &Opts, OptSpecifier Id) {
|
|||
return getOptionHelpGroup(Opts, GroupID);
|
||||
}
|
||||
|
||||
void OptTable::PrintHelp(llvm::raw_ostream &OS, const char *Name,
|
||||
void OptTable::PrintHelp(raw_ostream &OS, const char *Name,
|
||||
const char *Title, bool ShowHidden) const {
|
||||
OS << "OVERVIEW: " << Title << "\n";
|
||||
OS << '\n';
|
||||
|
|
Некоторые файлы не были показаны из-за слишком большого количества измененных файлов Показать больше
Загрузка…
Ссылка в новой задаче