summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-03-25 03:28:08 +0000
committerChris Lattner <sabre@nondot.org>2009-03-25 03:28:08 +0000
commit8c37df4f91431e7df5bcc115d6615295d1b08d5f (patch)
tree76226cc64c0b53fa79da1a81e620c2686b38426f
parent0e0cf39a9ee2aa8119d9cc60fcfde482ceffc931 (diff)
downloadbcm5719-llvm-8c37df4f91431e7df5bcc115d6615295d1b08d5f.tar.gz
bcm5719-llvm-8c37df4f91431e7df5bcc115d6615295d1b08d5f.zip
simplify some conditionals, don't copy LangOptions.
llvm-svn: 67674
-rw-r--r--clang/lib/CodeGen/CGDebugInfo.cpp26
1 files changed, 15 insertions, 11 deletions
diff --git a/clang/lib/CodeGen/CGDebugInfo.cpp b/clang/lib/CodeGen/CGDebugInfo.cpp
index 7014fa839ef..b437f3dfbd6 100644
--- a/clang/lib/CodeGen/CGDebugInfo.cpp
+++ b/clang/lib/CodeGen/CGDebugInfo.cpp
@@ -53,12 +53,15 @@ llvm::DICompileUnit CGDebugInfo::getOrCreateCompileUnit(SourceLocation Loc) {
const FileEntry *FE = 0;
SourceManager &SM = M->getContext().getSourceManager();
+ bool isMain;
if (Loc.isValid()) {
Loc = SM.getInstantiationLoc(Loc);
FE = SM.getFileEntryForID(SM.getFileID(Loc));
+ isMain = SM.getFileID(Loc) == SM.getMainFileID();
} else {
// If Loc is not valid then use main file id.
FE = SM.getFileEntryForID(SM.getMainFileID());
+ isMain = true;
}
// See if this compile unit has been used before.
@@ -69,19 +72,20 @@ llvm::DICompileUnit CGDebugInfo::getOrCreateCompileUnit(SourceLocation Loc) {
const char *FileName = FE ? FE->getName() : "<unknown>";
const char *DirName = FE ? FE->getDir()->getName() : "<unknown>";
- bool isMain = (FE == SM.getFileEntryForID(SM.getMainFileID()));
- unsigned LangTag = llvm::dwarf::DW_LANG_C89;
-
- LangOptions LO = M->getLangOptions();
- if (LO.CPlusPlus
- && (LO.ObjC1 || LO.ObjC2 || LO.ObjCNonFragileABI || LO.NeXTRuntime))
- LangTag = llvm::dwarf::DW_LANG_ObjC_plus_plus;
- else if (LO.CPlusPlus)
- LangTag = llvm::dwarf::DW_LANG_C_plus_plus;
- else if (LO.ObjC1 || LO.ObjC2 || LO.ObjCNonFragileABI || LO.NeXTRuntime)
+ const LangOptions &LO = M->getLangOptions();
+ unsigned LangTag;
+ if (LO.CPlusPlus) {
+ if (LO.ObjC1)
+ LangTag = llvm::dwarf::DW_LANG_ObjC_plus_plus;
+ else
+ LangTag = llvm::dwarf::DW_LANG_C_plus_plus;
+ } else if (LO.ObjC1) {
LangTag = llvm::dwarf::DW_LANG_ObjC;
- else if (LO.C99)
+ } else if (LO.C99) {
LangTag = llvm::dwarf::DW_LANG_C99;
+ } else {
+ LangTag = llvm::dwarf::DW_LANG_C89;
+ }
// Create new compile unit.
// FIXME: Do not know how to get clang version yet.
OpenPOWER on IntegriCloud