<p dir="ltr">Thanks for the fix. Sorry about that.</p>
<div class="gmail_quote">On May 7, 2013 12:48 AM, "Timur Iskhodzhanov" <<a href="mailto:timurrrr@google.com">timurrrr@google.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Should be fixed by r181296.<br>
<br>
2013/5/7 Timur Iskhodzhanov <<a href="mailto:timurrrr@google.com">timurrrr@google.com</a>>:<br>
> This fails to compile with VS2010:<br>
><br>
> 168>  DwarfDebug.cpp<br>
> 168>C:\Program Files (x86)\Microsoft Visual Studio<br>
> 10.0\VC\include\utility(163): error C2440: 'initializing' : cannot<br>
> convert from 'int' to 'const llvm::MDNode *'<br>
> 168>          Conversion from integral type to pointer type requires<br>
> reinterpret_cast, C-style cast or function-style cast<br>
> 168>          C:\Program Files (x86)\Microsoft Visual Studio<br>
> 10.0\VC\include\utility(247) : see reference to function template<br>
> instantiation 'std::_Pair_base<_Ty1,_Ty2>::_Pair_base<llvm::DIScope&,_Ty>(_Other1,_Other2<br>
> &&)' being compiled<br>
> 168>          with<br>
> 168>          [<br>
> 168>              _Ty1=const llvm::MDNode *,<br>
> 168>              _Ty2=const llvm::MDNode *,<br>
> 168>              _Ty=int,<br>
> 168>              _Other1=llvm::DIScope &,<br>
> 168>              _Other2=int<br>
> 168>          ]<br>
> 168>          ..\..\..\..\llvm\lib\CodeGen\AsmPrinter\DwarfDebug.cpp(609)<br>
> : see reference to function template instantiation<br>
> 'std::pair<_Ty1,_Ty2>::pair<llvm::DIScope&,int>(_Other1,_Other2 &&)'<br>
> being compiled<br>
> 168>          with<br>
> 168>          [<br>
> 168>              _Ty1=const llvm::MDNode *,<br>
> 168>              _Ty2=const llvm::MDNode *,<br>
> 168>              _Other1=llvm::DIScope &,<br>
> 168>              _Other2=int<br>
> 168>          ]<br>
> 168>C:\Program Files (x86)\Microsoft Visual Studio<br>
> 10.0\VC\include\utility(163): error C2439:<br>
> 'std::_Pair_base<_Ty1,_Ty2>::second' : member could not be initialized<br>
> 168>          with<br>
> 168>          [<br>
> 168>              _Ty1=const llvm::MDNode *,<br>
> 168>              _Ty2=const llvm::MDNode *<br>
> 168>          ]<br>
> 168>          C:\Program Files (x86)\Microsoft Visual Studio<br>
> 10.0\VC\include\utility(167) : see declaration of<br>
> 'std::_Pair_base<_Ty1,_Ty2>::second'<br>
> 168>          with<br>
> 168>          [<br>
> 168>              _Ty1=const llvm::MDNode *,<br>
> 168>              _Ty2=const llvm::MDNode *<br>
> 168>          ]<br>
><br>
> 2013/5/7 David Blaikie <<a href="mailto:dblaikie@gmail.com">dblaikie@gmail.com</a>>:<br>
>> Author: dblaikie<br>
>> Date: Mon May  6 18:33:07 2013<br>
>> New Revision: 181271<br>
>><br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=181271&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=181271&view=rev</a><br>
>> Log:<br>
>> DebugInfo: Support imported modules in lexical blocks<br>
>><br>
>> Modified:<br>
>>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h<br>
>>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
>>     llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h<br>
>>     llvm/trunk/test/DebugInfo/namespace.ll<br>
>><br>
>> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h<br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h?rev=181271&r1=181270&r2=181271&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h?rev=181271&r1=181270&r2=181271&view=diff</a><br>

>> ==============================================================================<br>
>> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h (original)<br>
>> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h Mon May  6 18:33:07 2013<br>
>> @@ -94,9 +94,6 @@ class CompileUnit {<br>
>>    /// DWARF version doesn't handle the language, return -1.<br>
>>    int64_t getDefaultLowerBound() const;<br>
>><br>
>> -  /// getOrCreateContextDIE - Get context owner's DIE.<br>
>> -  DIE *getOrCreateContextDIE(DIDescriptor Context);<br>
>> -<br>
>>  public:<br>
>>    CompileUnit(unsigned UID, unsigned L, DIE *D, AsmPrinter *A, DwarfDebug *DW,<br>
>>                DwarfUnits *);<br>
>> @@ -372,6 +369,9 @@ public:<br>
>>    /// createStaticMemberDIE - Create new static data member DIE.<br>
>>    DIE *createStaticMemberDIE(DIDerivedType DT);<br>
>><br>
>> +  /// getOrCreateContextDIE - Get context owner's DIE.<br>
>> +  DIE *getOrCreateContextDIE(DIDescriptor Context);<br>
>> +<br>
>>  private:<br>
>><br>
>>    // DIEValueAllocator - All DIEValues are allocated through this allocator.<br>
>><br>
>> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp<br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=181271&r1=181270&r2=181271&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp?rev=181271&r1=181270&r2=181271&view=diff</a><br>

>> ==============================================================================<br>
>> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp (original)<br>
>> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.cpp Mon May  6 18:33:07 2013<br>
>> @@ -94,6 +94,12 @@ static cl::opt<DefaultOnOff> SplitDwarf(<br>
>>  namespace {<br>
>>    const char *DWARFGroupName = "DWARF Emission";<br>
>>    const char *DbgTimerName = "DWARF Debug Writer";<br>
>> +<br>
>> +  struct CompareFirst {<br>
>> +    template <typename T> bool operator()(const T &lhs, const T &rhs) const {<br>
>> +      return lhs.first < rhs.first;<br>
>> +    }<br>
>> +  };<br>
>>  } // end anonymous namespace<br>
>><br>
>>  //===----------------------------------------------------------------------===//<br>
>> @@ -597,9 +603,15 @@ DIE *DwarfDebug::constructScopeDIE(Compi<br>
>>    }<br>
>>    else {<br>
>>      // There is no need to emit empty lexical block DIE.<br>
>> -    if (Children.empty())<br>
>> +    std::pair<ImportedEntityMap::const_iterator,<br>
>> +              ImportedEntityMap::const_iterator> Range = std::equal_range(<br>
>> +        ScopesWithImportedEntities.begin(), ScopesWithImportedEntities.end(),<br>
>> +        std::pair<const MDNode *, const MDNode *>(DS, 0), CompareFirst());<br>
>> +    if (Children.empty() && Range.first == Range.second)<br>
>>        return NULL;<br>
>>      ScopeDIE = constructLexicalScopeDIE(TheCU, Scope);<br>
>> +    for (ImportedEntityMap::const_iterator i = Range.first; i != Range.second; ++i)<br>
>> +      constructImportedModuleDIE(TheCU, i->second, ScopeDIE);<br>
>>    }<br>
>><br>
>>    if (!ScopeDIE) return NULL;<br>
>> @@ -768,6 +780,24 @@ void DwarfDebug::constructImportedModule<br>
>>    DIImportedModule Module(N);<br>
>>    if (!Module.Verify())<br>
>>      return;<br>
>> +  if (DIE *D = TheCU->getOrCreateContextDIE(Module.getContext()))<br>
>> +    constructImportedModuleDIE(TheCU, Module, D);<br>
>> +}<br>
>> +<br>
>> +void DwarfDebug::constructImportedModuleDIE(CompileUnit *TheCU, const MDNode *N,<br>
>> +                                            DIE *Context) {<br>
>> +  DIImportedModule Module(N);<br>
>> +  if (!Module.Verify())<br>
>> +    return;<br>
>> +  return constructImportedModuleDIE(TheCU, Module, Context);<br>
>> +}<br>
>> +<br>
>> +void DwarfDebug::constructImportedModuleDIE(CompileUnit *TheCU,<br>
>> +                                            const DIImportedModule &Module,<br>
>> +                                            DIE *Context) {<br>
>> +  assert(Module.Verify() &&<br>
>> +         "Use one of the MDNode * overloads to handle invalid metadata");<br>
>> +  assert(Context && "Should always have a context for an imported_module");<br>
>>    DIE *IMDie = new DIE(dwarf::DW_TAG_imported_module);<br>
>>    TheCU->insertDIE(Module, IMDie);<br>
>>    DIE *NSDie = TheCU->getOrCreateNameSpace(Module.getNameSpace());<br>
>> @@ -777,7 +807,7 @@ void DwarfDebug::constructImportedModule<br>
>>    TheCU->addUInt(IMDie, dwarf::DW_AT_decl_file, 0, FileID);<br>
>>    TheCU->addUInt(IMDie, dwarf::DW_AT_decl_line, 0, Module.getLineNumber());<br>
>>    TheCU->addDIEEntry(IMDie, dwarf::DW_AT_import, dwarf::DW_FORM_ref4, NSDie);<br>
>> -  TheCU->addToContextOwner(IMDie, Module.getContext());<br>
>> +  Context->addChild(IMDie);<br>
>>  }<br>
>><br>
>>  // Emit all Dwarf sections that should come prior to the content. Create<br>
>> @@ -801,6 +831,13 @@ void DwarfDebug::beginModule() {<br>
>>    for (unsigned i = 0, e = CU_Nodes->getNumOperands(); i != e; ++i) {<br>
>>      DICompileUnit CUNode(CU_Nodes->getOperand(i));<br>
>>      CompileUnit *CU = constructCompileUnit(CUNode);<br>
>> +    DIArray ImportedModules = CUNode.getImportedModules();<br>
>> +    for (unsigned i = 0, e = ImportedModules.getNumElements(); i != e; ++i)<br>
>> +      ScopesWithImportedEntities.push_back(std::make_pair(<br>
>> +          DIImportedModule(ImportedModules.getElement(i)).getContext(),<br>
>> +          ImportedModules.getElement(i)));<br>
>> +    std::sort(ScopesWithImportedEntities.begin(),<br>
>> +              ScopesWithImportedEntities.end(), CompareFirst());<br>
>>      DIArray GVs = CUNode.getGlobalVariables();<br>
>>      for (unsigned i = 0, e = GVs.getNumElements(); i != e; ++i)<br>
>>        CU->createGlobalVariableDIE(GVs.getElement(i));<br>
>> @@ -815,7 +852,6 @@ void DwarfDebug::beginModule() {<br>
>>        CU->getOrCreateTypeDIE(RetainedTypes.getElement(i));<br>
>>      // Emit imported_modules last so that the relevant context is already<br>
>>      // available.<br>
>> -    DIArray ImportedModules = CUNode.getImportedModules();<br>
>>      for (unsigned i = 0, e = ImportedModules.getNumElements(); i != e; ++i)<br>
>>        constructImportedModuleDIE(CU, ImportedModules.getElement(i));<br>
>>      // If we're splitting the dwarf out now that we've got the entire<br>
>><br>
>> Modified: llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h<br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h?rev=181271&r1=181270&r2=181271&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h?rev=181271&r1=181270&r2=181271&view=diff</a><br>

>> ==============================================================================<br>
>> --- llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h (original)<br>
>> +++ llvm/trunk/lib/CodeGen/AsmPrinter/DwarfDebug.h Mon May  6 18:33:07 2013<br>
>> @@ -433,6 +433,10 @@ class DwarfDebug {<br>
>>    // Holder for the skeleton information.<br>
>>    DwarfUnits SkeletonHolder;<br>
>><br>
>> +  typedef SmallVector<std::pair<const MDNode *, const MDNode *>, 32><br>
>> +    ImportedEntityMap;<br>
>> +  ImportedEntityMap ScopesWithImportedEntities;<br>
>> +<br>
>>  private:<br>
>><br>
>>    void addScopeVariable(LexicalScope *LS, DbgVariable *Var);<br>
>> @@ -558,6 +562,15 @@ private:<br>
>>    /// \brief Construct import_module DIE.<br>
>>    void constructImportedModuleDIE(CompileUnit *TheCU, const MDNode *N);<br>
>><br>
>> +  /// \brief Construct import_module DIE.<br>
>> +  void constructImportedModuleDIE(CompileUnit *TheCU, const MDNode *N,<br>
>> +                                  DIE *Context);<br>
>> +<br>
>> +  /// \brief Construct import_module DIE.<br>
>> +  void constructImportedModuleDIE(CompileUnit *TheCU,<br>
>> +                                  const DIImportedModule &Module,<br>
>> +                                  DIE *Context);<br>
>> +<br>
>>    /// \brief Register a source line with debug info. Returns the unique<br>
>>    /// label that was emitted and which provides correspondence to the<br>
>>    /// source line list.<br>
>><br>
>> Modified: llvm/trunk/test/DebugInfo/namespace.ll<br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/namespace.ll?rev=181271&r1=181270&r2=181271&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/DebugInfo/namespace.ll?rev=181271&r1=181270&r2=181271&view=diff</a><br>

>> ==============================================================================<br>
>> --- llvm/trunk/test/DebugInfo/namespace.ll (original)<br>
>> +++ llvm/trunk/test/DebugInfo/namespace.ll Mon May  6 18:33:07 2013<br>
>> @@ -3,7 +3,7 @@<br>
>>  ; RUN: llc -O0 -filetype=obj < %s > %t<br>
>>  ; RUN: llvm-dwarfdump %t | FileCheck %s<br>
>>  ; CHECK: debug_info contents<br>
>> -; CHECK: DW_TAG_namespace<br>
>> +; CHECK: [[NS1:0x[0-9a-f]*]]:{{ *}}DW_TAG_namespace<br>
>>  ; CHECK-NEXT: DW_AT_name{{.*}} = "A"<br>
>>  ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F1:[0-9]]])<br>
>>  ; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x03)<br>
>> @@ -15,14 +15,31 @@<br>
>>  ; CHECK-NOT: NULL<br>
>>  ; CHECK: DW_TAG_variable<br>
>>  ; CHECK-NEXT: DW_AT_name{{.*}}= "i"<br>
>> +; CHECK: NULL<br>
>> +; CHECK-NOT: NULL<br>
>> +; CHECK: DW_TAG_imported_module<br>
>> +; This is a bug, it should be in F2 but it inherits the file from its<br>
>> +; enclosing scope<br>
>> +; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F1]])<br>
>> +; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x04)<br>
>> +; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS2]]})<br>
>> +<br>
>>  ; CHECK: DW_TAG_subprogram<br>
>>  ; CHECK-NEXT: DW_AT_MIPS_linkage_name<br>
>>  ; CHECK-NEXT: DW_AT_name{{.*}}= "func"<br>
>>  ; CHECK-NOT: NULL<br>
>>  ; CHECK: DW_TAG_imported_module<br>
>>  ; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])<br>
>> -; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x07)<br>
>> +; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x0e)<br>
>> +; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS1]]})<br>
>> +; CHECK-NOT: NULL<br>
>> +; CHECK: DW_TAG_lexical_block<br>
>> +; CHECK-NOT: NULL<br>
>> +; CHECK: DW_TAG_imported_module<br>
>> +; CHECK-NEXT: DW_AT_decl_file{{.*}}(0x0[[F2]])<br>
>> +; CHECK-NEXT: DW_AT_decl_line{{.*}}(0x0b)<br>
>>  ; CHECK-NEXT: DW_AT_import{{.*}}=> {[[NS2]]})<br>
>> +<br>
>>  ; CHECK: file_names[  [[F1]]]{{.*}}debug-info-namespace.cpp<br>
>>  ; CHECK: file_names[  [[F2]]]{{.*}}foo.cpp<br>
>><br>
>> @@ -33,40 +50,81 @@<br>
>>  ; namespace B {<br>
>>  ; int i;<br>
>>  ; }<br>
>> +; using namespace B;<br>
>>  ; }<br>
>>  ;<br>
>> -; int func() {<br>
>> -;   using namespace A::B;<br>
>> -;   return i;<br>
>> +; using namespace A;<br>
>> +;<br>
>> +; int func(bool b) {<br>
>> +;   if (b) {<br>
>> +;     using namespace A::B;<br>
>> +;     return i;<br>
>> +;   }<br>
>> +;   using namespace A;<br>
>> +;   return B::i;<br>
>>  ; }<br>
>><br>
>>  @_ZN1A1B1iE = global i32 0, align 4<br>
>><br>
>> -; Function Attrs: nounwind uwtable<br>
>> -define i32 @_Z4funcv() #0 {<br>
>> +; Function Attrs: nounwind uwtable<br>
>> +define i32 @_Z4funcb(i1 zeroext %b) #0 {<br>
>>  entry:<br>
>> -  %0 = load i32* @_ZN1A1B1iE, align 4, !dbg !16<br>
>> -  ret i32 %0, !dbg !16<br>
>> +  %retval = alloca i32, align 4<br>
>> +  %b.addr = alloca i8, align 1<br>
>> +  %frombool = zext i1 %b to i8<br>
>> +  store i8 %frombool, i8* %b.addr, align 1<br>
>> +  call void @llvm.dbg.declare(metadata !{i8* %b.addr}, metadata !21), !dbg !22<br>
>> +  %0 = load i8* %b.addr, align 1, !dbg !23<br>
>> +  %tobool = trunc i8 %0 to i1, !dbg !23<br>
>> +  br i1 %tobool, label %if.then, label %if.end, !dbg !23<br>
>> +<br>
>> +if.then:                                          ; preds = %entry<br>
>> +  %1 = load i32* @_ZN1A1B1iE, align 4, !dbg !24<br>
>> +  store i32 %1, i32* %retval, !dbg !24<br>
>> +  br label %return, !dbg !24<br>
>> +<br>
>> +if.end:                                           ; preds = %entry<br>
>> +  %2 = load i32* @_ZN1A1B1iE, align 4, !dbg !25<br>
>> +  store i32 %2, i32* %retval, !dbg !25<br>
>> +  br label %return, !dbg !25<br>
>> +<br>
>> +return:                                           ; preds = %if.end, %if.then<br>
>> +  %3 = load i32* %retval, !dbg !26<br>
>> +  ret i32 %3, !dbg !26<br>
>>  }<br>
>><br>
>> +; Function Attrs: nounwind readnone<br>
>> +declare void @llvm.dbg.declare(metadata, metadata) #1<br>
>> +<br>
>>  attributes #0 = { nounwind uwtable "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf"="true" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="false" }<br>

>> +attributes #1 = { nounwind readnone }<br>
>><br>
>>  !<a href="http://llvm.dbg.cu" target="_blank">llvm.dbg.cu</a> = !{!0}<br>
>><br>
>> -!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.3 ", i1 false, metadata !"", i32 0, metadata !2, metadata !2, metadata !3, metadata !10, metadata !14, metadata !""} ; [ DW_TAG_compile_unit ] [/usr/local/google/home/blaikie/dev/llvm/src/tools/clang//usr/local/google/home/blaikie/dev/llvm/src/tools/clang/test/CodeGenCXX/debug-info-namespace.cpp] [DW_LANG_C_plus_plus]<br>

>> +!0 = metadata !{i32 786449, metadata !1, i32 4, metadata !"clang version 3.3 ", i1 false, metadata !"", i32 0, metadata !2, metadata !2, metadata !3, metadata !11, metadata !15, metadata !""} ; [ DW_TAG_compile_unit ] [/usr/local/google/home/blaikie/dev/llvm/src/tools/clang//usr/local/google/home/blaikie/dev/llvm/src/tools/clang/test/CodeGenCXX/debug-info-namespace.cpp] [DW_LANG_C_plus_plus]<br>

>>  !1 = metadata !{metadata !"/usr/local/google/home/blaikie/dev/llvm/src/tools/clang/test/CodeGenCXX/debug-info-namespace.cpp", metadata !"/usr/local/google/home/blaikie/dev/llvm/src/tools/clang"}<br>

>>  !2 = metadata !{i32 0}<br>
>>  !3 = metadata !{metadata !4}<br>
>> -!4 = metadata !{i32 786478, metadata !5, metadata !6, metadata !"func", metadata !"func", metadata !"_Z4funcv", i32 6, metadata !7, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, i32 ()* @_Z4funcv, null, null, metadata !2, i32 6} ; [ DW_TAG_subprogram ] [line 6] [def] [func]<br>

>> +!4 = metadata !{i32 786478, metadata !5, metadata !6, metadata !"func", metadata !"func", metadata !"_Z4funcb", i32 9, metadata !7, i1 false, i1 true, i32 0, i32 0, null, i32 256, i1 false, i32 (i1)* @_Z4funcb, null, null, metadata !2, i32 9} ; [ DW_TAG_subprogram ] [line 9] [def] [func]<br>

>>  !5 = metadata !{metadata !"foo.cpp", metadata !"/usr/local/google/home/blaikie/dev/llvm/src/tools/clang"}<br>
>> -!6 = metadata !{i32 786473, metadata !5}          ; [ DW_TAG_file_type ] [/usr/local/google/home/blaikie/dev/llvm/src/tools/clang/foo.cpp]<br>
>> +!6 = metadata !{i32 786473, metadata !5}          ; [ DW_TAG_file_type ] [/usr/local/google/home/blaikie/dev/llvm/build/clang/debug/foo.cpp]<br>
>>  !7 = metadata !{i32 786453, i32 0, i32 0, metadata !"", i32 0, i64 0, i64 0, i64 0, i32 0, null, metadata !8, i32 0, i32 0} ; [ DW_TAG_subroutine_type ] [line 0, size 0, align 0, offset 0] [from ]<br>

>> -!8 = metadata !{metadata !9}<br>
>> +!8 = metadata !{metadata !9, metadata !10}<br>
>>  !9 = metadata !{i32 786468, null, null, metadata !"int", i32 0, i64 32, i64 32, i64 0, i32 0, i32 5} ; [ DW_TAG_base_type ] [int] [line 0, size 32, align 32, offset 0, enc DW_ATE_signed]<br>
>> -!10 = metadata !{metadata !11}<br>
>> -!11 = metadata !{i32 786484, i32 0, metadata !12, metadata !"i", metadata !"i", metadata !"_ZN1A1B1iE", metadata !6, i32 2, metadata !9, i32 0, i32 1, i32* @_ZN1A1B1iE, null} ; [ DW_TAG_variable ] [i] [line 2] [def]<br>

>> -!12 = metadata !{i32 786489, metadata !5, metadata !13, metadata !"B", i32 1} ; [ DW_TAG_namespace ] [B] [line 1]<br>
>> -!13 = metadata !{i32 786489, metadata !1, null, metadata !"A", i32 3} ; [ DW_TAG_namespace ] [A] [line 3]<br>
>> -!14 = metadata !{metadata !15}<br>
>> -!15 = metadata !{i32 786490, metadata !4, metadata !12, i32 7} ; [ DW_TAG_imported_module ]<br>
>> -!16 = metadata !{i32 8, i32 0, metadata !4, null}<br>
>> +!10 = metadata !{i32 786468, null, null, metadata !"bool", i32 0, i64 8, i64 8, i64 0, i32 0, i32 2} ; [ DW_TAG_base_type ] [bool] [line 0, size 8, align 8, offset 0, enc DW_ATE_boolean]<br>
>> +!11 = metadata !{metadata !12}<br>
>> +!12 = metadata !{i32 786484, i32 0, metadata !13, metadata !"i", metadata !"i", metadata !"_ZN1A1B1iE", metadata !6, i32 2, metadata !9, i32 0, i32 1, i32* @_ZN1A1B1iE, null} ; [ DW_TAG_variable ] [i] [line 2] [def]<br>

>> +!13 = metadata !{i32 786489, metadata !5, metadata !14, metadata !"B", i32 1} ; [ DW_TAG_namespace ] [B] [line 1]<br>
>> +!14 = metadata !{i32 786489, metadata !1, null, metadata !"A", i32 3} ; [ DW_TAG_namespace ] [A] [line 3]<br>
>> +!15 = metadata !{metadata !16, metadata !17, metadata !18, metadata !20}<br>
>> +!16 = metadata !{i32 786490, metadata !14, metadata !13, i32 4} ; [ DW_TAG_imported_module ]<br>
>> +!17 = metadata !{i32 786490, metadata !0, metadata !14, i32 7} ; [ DW_TAG_imported_module ]<br>
>> +!18 = metadata !{i32 786490, metadata !19, metadata !13, i32 11} ; [ DW_TAG_imported_module ]<br>
>> +!19 = metadata !{i32 786443, metadata !5, metadata !4, i32 10, i32 0, i32 0} ; [ DW_TAG_lexical_block ] [/usr/local/google/home/blaikie/dev/llvm/build/clang/debug/foo.cpp]<br>
>> +!20 = metadata !{i32 786490, metadata !4, metadata !14, i32 14} ; [ DW_TAG_imported_module ]<br>
>> +!21 = metadata !{i32 786689, metadata !4, metadata !"b", metadata !6, i32 16777225, metadata !10, i32 0, i32 0} ; [ DW_TAG_arg_variable ] [b] [line 9]<br>
>> +!22 = metadata !{i32 9, i32 0, metadata !4, null}<br>
>> +!23 = metadata !{i32 10, i32 0, metadata !4, null}<br>
>> +!24 = metadata !{i32 12, i32 0, metadata !19, null}<br>
>> +!25 = metadata !{i32 15, i32 0, metadata !4, null}<br>
>> +!26 = metadata !{i32 16, i32 0, metadata !4, null}<br>
>><br>
>><br>
>> _______________________________________________<br>
>> llvm-commits mailing list<br>
>> <a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
>> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
</blockquote></div>