Michael137 added a comment.

In D130213#3668450 <https://reviews.llvm.org/D130213#3668450>, @aprantl wrote:

> @werat did you build with assertions enabled?
>
> This change looks fine to me, but it might be interesting to see where the 
> discrepancy between the platforms comes from.

Interestingly, @werat's test case crashes for me (without the patch) but only 
if I explicitly create an instance of `struct A`. Otherwise, lldb doesn't find 
`A::e`.

If a class only has constexpr statics, on Darwin we omit the structure type 
from DWARF:

  0x0000000b: DW_TAG_compile_unit            
                DW_AT_producer    ("Apple clang version 14.0.0 
(clang-1400.0.25)")                           
                DW_AT_language    (DW_LANG_C_plus_plus_14)                      
                             
                DW_AT_name        ("test.cpp")                                  
                             
                DW_AT_LLVM_sysroot        
("/Library/Developer/CommandLineTools/SDKs/MacOSX12.5.sdk")        
                DW_AT_APPLE_sdk   ("MacOSX12.5.sdk")                            
                             
                DW_AT_stmt_list   (0x00000000)         
                DW_AT_comp_dir    ("/Users/michaelbuch/Git/lldb-build-lambda")  
                             
                DW_AT_low_pc      (0x0000000100003f9c)                          
                                                                                
                                                        
                DW_AT_high_pc     (0x0000000100003fb8)                          
                             
                                                       
  0x00000032:   DW_TAG_enumeration_type                                         
                             
                  DW_AT_type      (0x000000000000004b "int")                    
                             
                  DW_AT_enum_class        (true)                                
                             
                  DW_AT_name      ("ScopedEnum")                                
                             
                  DW_AT_byte_size (0x04)               
                  DW_AT_decl_file 
("/Users/michaelbuch/Git/lldb-build-lambda/test.cpp")                      
                  DW_AT_decl_line (1)                                           
                             
                                                       
  0x0000003e:     DW_TAG_enumerator                                             
                             
                    DW_AT_name    ("scoped_enum_case1")
                    DW_AT_const_value     (1)                                   
                             
                                                                                
                             
  0x00000044:     DW_TAG_enumerator                    
                    DW_AT_name    ("scoped_enum_case2")                         
                             
                    DW_AT_const_value     (2)                                   
                             
                                                                                
                             
  0x0000004a:     NULL                                                          
                             
                                                                                
                             
  0x0000004b:   DW_TAG_base_type                                                
                             
                  DW_AT_name      ("int")                                       
                             
                  DW_AT_encoding  (DW_ATE_signed)                               
                             
                  DW_AT_byte_size (0x04)                                        
                             
                                                                                
                             
  0x00000052:   DW_TAG_subprogram                                               
                             
                  DW_AT_low_pc    (0x0000000100003f9c) 
                  DW_AT_high_pc   (0x0000000100003fb8)                          
                             
                  DW_AT_APPLE_omit_frame_ptr      (true)                        
                                                                                
                                                        
                  DW_AT_frame_base        (DW_OP_reg31 WSP)                     
                             
                  DW_AT_name      ("main")
                  DW_AT_decl_file 
("/Users/michaelbuch/Git/lldb-build-lambda/test.cpp")                      
                  DW_AT_decl_line (13)                                          
                             
                  DW_AT_type      (0x000000000000004b "int")                    
                             
                  DW_AT_external  (true)
  
  0x0000006b:     DW_TAG_variable
                    DW_AT_location        (DW_OP_fbreg +8)                      
                             
                    DW_AT_name    ("enum_alias_val")
                    DW_AT_decl_file       
("/Users/michaelbuch/Git/lldb-build-lambda/test.cpp")              
                    DW_AT_decl_line       (14)
                    DW_AT_type    (0x0000000000000032 "ScopedEnum")             
                             
  
  0x00000079:     NULL                                 
  
  0x0000007a:   NULL                                   

This is actually noted in one of the test cases in 
`TestConstStaticIntegralMember.py`:

  # dsymutil strips the debug info for classes that only have const static
  # data members without a definition namespace scope.                    
  @expectedFailureAll(debug_info=["dsym"])                                
  def test_class_with_only_const_static(self):                            


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D130213/new/

https://reviews.llvm.org/D130213

_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to