dwarf2out.c (is_c_family): Understand new DWARF3 language types.
authorGeoffrey Keating <geoffk@apple.com>
Sat, 25 Mar 2006 00:54:40 +0000 (00:54 +0000)
committerGeoffrey Keating <geoffk@gcc.gnu.org>
Sat, 25 Mar 2006 00:54:40 +0000 (00:54 +0000)
2006-03-24  Geoffrey Keating  <geoffk@apple.com>

* dwarf2out.c (is_c_family): Understand new DWARF3 language types.
(is_cxx): Likewise.
(gen_compile_unit_die): Use new language types for Objective-C and
Objective-C++.
(dwarf2out_decl): Use is_cxx rather than testing explicitly against
DW_LANG_C_plus_plus.

Index: testsuite/ChangeLog
2006-03-24  Geoffrey Keating  <geoffk@apple.com>

* objc.dg/dwarf-2.m: New.
* obj-c++.dg/dwarf-2.mm: New.

From-SVN: r112372

gcc/ChangeLog
gcc/dwarf2out.c
gcc/testsuite/ChangeLog
gcc/testsuite/obj-c++.dg/dwarf-2.mm [new file with mode: 0644]
gcc/testsuite/objc.dg/dwarf-2.m [new file with mode: 0644]

index 51a9ae858c746bf9658c014c4147b026065cbe8d..6ef0675e6b5d50aef7b2cb66e1e490aed34405cb 100644 (file)
@@ -5,6 +5,13 @@
 
 2006-03-24  Geoffrey Keating  <geoffk@apple.com>
 
+       * dwarf2out.c (is_c_family): Understand new DWARF3 language types.
+       (is_cxx): Likewise.
+       (gen_compile_unit_die): Use new language types for Objective-C and
+       Objective-C++.
+       (dwarf2out_decl): Use is_cxx rather than testing explicitly against
+       DW_LANG_C_plus_plus.
+
        PR 26793
        * config/t-darwin (crt3.o): Work around bug 26840.
        * config/darwin-crt3.c: Rewrite.
index ccfb5df699fb17f8241e926774f36bab75121bab..6255c40208f4f4b2fa369475a734ece388437f51 100644 (file)
@@ -5326,8 +5326,9 @@ is_c_family (void)
 {
   unsigned int lang = get_AT_unsigned (comp_unit_die, DW_AT_language);
 
-  return (lang == DW_LANG_C || lang == DW_LANG_C89
-         || lang == DW_LANG_C_plus_plus);
+  return (lang == DW_LANG_C || lang == DW_LANG_C89 || lang == DW_LANG_ObjC
+         || lang == DW_LANG_C99
+         || lang == DW_LANG_C_plus_plus || lang == DW_LANG_ObjC_plus_plus);
 }
 
 /* Return TRUE if the language is C++.  */
@@ -5335,8 +5336,9 @@ is_c_family (void)
 static inline bool
 is_cxx (void)
 {
-  return (get_AT_unsigned (comp_unit_die, DW_AT_language)
-         == DW_LANG_C_plus_plus);
+  unsigned int lang = get_AT_unsigned (comp_unit_die, DW_AT_language);
+  
+  return lang == DW_LANG_C_plus_plus || lang == DW_LANG_ObjC_plus_plus;
 }
 
 /* Return TRUE if the language is Fortran.  */
@@ -12204,6 +12206,10 @@ gen_compile_unit_die (const char *filename)
     language = DW_LANG_Pascal83;
   else if (strcmp (language_string, "GNU Java") == 0)
     language = DW_LANG_Java;
+  else if (strcmp (language_string, "GNU Objective-C") == 0)
+    language = DW_LANG_ObjC;
+  else if (strcmp (language_string, "GNU Objective-C++") == 0)
+    language = DW_LANG_ObjC_plus_plus;
   else
     language = DW_LANG_C89;
 
@@ -13314,8 +13320,7 @@ dwarf2out_decl (tree decl)
        {
          /* OK, we need to generate one for `bool' so GDB knows what type
             comparisons have.  */
-         if ((get_AT_unsigned (comp_unit_die, DW_AT_language)
-              == DW_LANG_C_plus_plus)
+         if (is_cxx ()
              && TREE_CODE (TREE_TYPE (decl)) == BOOLEAN_TYPE
              && ! DECL_IGNORED_P (decl))
            modified_type_die (TREE_TYPE (decl), 0, 0, NULL);
index c7daaebf205b4b5ca142737342b5fa752b43fee3..f85f232bf8ae6cfcb47de368151e0db66f293c0c 100644 (file)
@@ -4,6 +4,9 @@
 
 2006-03-24  Geoffrey Keating  <geoffk@apple.com>
 
+       * objc.dg/dwarf-2.m: New.
+       * obj-c++.dg/dwarf-2.mm: New.
+
        * g++.old-deja/g++.other/init19.C: New.
 
 2006-03-24  David Edelsohn  <edelsohn@gnu.org>
diff --git a/gcc/testsuite/obj-c++.dg/dwarf-2.mm b/gcc/testsuite/obj-c++.dg/dwarf-2.mm
new file mode 100644 (file)
index 0000000..46ab5bb
--- /dev/null
@@ -0,0 +1,3 @@
+/* { dg-options "-gdwarf-2 -dA" } */
+/* { dg-final { scan-assembler "0x11\[^0-9a-f\].*DW_AT_language" } } */
+int x;
diff --git a/gcc/testsuite/objc.dg/dwarf-2.m b/gcc/testsuite/objc.dg/dwarf-2.m
new file mode 100644 (file)
index 0000000..444ed23
--- /dev/null
@@ -0,0 +1,3 @@
+/* { dg-options "-gdwarf-2 -dA" } */
+/* { dg-final { scan-assembler "0x10\[^0-9a-f\].*DW_AT_language" } } */
+int x;