Change DIBuilder::createImportedDeclaration from taking a DIScope to a DIDescriptor.
authorFrederic Riss <friss@apple.com>
Thu, 6 Nov 2014 17:46:55 +0000 (17:46 +0000)
committerFrederic Riss <friss@apple.com>
Thu, 6 Nov 2014 17:46:55 +0000 (17:46 +0000)
Imported declarations can be DIGlobalVariables which aren't a DIScope. Today
clang (unknowingly I believe) shoehorns these into a DIScope and it all works
just because we never access the fields.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@221466 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/IR/DIBuilder.h
lib/IR/DIBuilder.cpp

index 8484d04e91494e77e58b0684688a2caff920af65..78ab3dc97568b347f9e34cd089df3e98f5868af8 100644 (file)
@@ -651,7 +651,7 @@ namespace llvm {
     /// @param Decl The declaration (or definition) of a function, type, or
     ///             variable
     /// @param Line Line number
-    DIImportedEntity createImportedDeclaration(DIScope Context, DIScope Decl,
+    DIImportedEntity createImportedDeclaration(DIScope Context, DIDescriptor Decl,
                                                unsigned Line,
                                                StringRef Name = StringRef());
     DIImportedEntity createImportedDeclaration(DIScope Context,
index 3276fe6452a58b1fbf4bdb7db61eb948fc00df81..fbd19596377cb02bb9a5ac1a74ceef5a88840941 100644 (file)
@@ -190,10 +190,13 @@ DIImportedEntity DIBuilder::createImportedModule(DIScope Context,
 }
 
 DIImportedEntity DIBuilder::createImportedDeclaration(DIScope Context,
-                                                      DIScope Decl,
+                                                      DIDescriptor Decl,
                                                       unsigned Line, StringRef Name) {
+  // Make sure to use the unique identifier based metadata reference for
+  // types that have one.
+  Value *V = Decl.isType() ? DIType(Decl).getRef() : Decl;
   return ::createImportedModule(VMContext, dwarf::DW_TAG_imported_declaration,
-                                Context, Decl.getRef(), Line, Name,
+                                Context, V, Line, Name,
                                 AllImportedModules);
 }