* dwarf2read.c (add_partial_symbol): Always store all Ada subprograms
authorJoel Brobecker <brobecker@gnat.com>
Fri, 1 Feb 2008 22:45:13 +0000 (22:45 +0000)
committerJoel Brobecker <brobecker@gnat.com>
Fri, 1 Feb 2008 22:45:13 +0000 (22:45 +0000)
        in the global scope.
        (new_symbol): Likewise.

gdb/ChangeLog
gdb/dwarf2read.c

index cc2bfecadfa9802e1c11bcf416a795a05390ede8..c5380b0aeda4ae970f98c450509a706b66540884 100644 (file)
@@ -1,3 +1,9 @@
+2007-02-01  Joel Brobecker  <brobecker@adacore.com>
+
+       * dwarf2read.c (add_partial_symbol): Always store all Ada subprograms
+       in the global scope.
+       (new_symbol): Likewise.
+
 2008-02-01  Vladimir Prus  <vladimir@codesourcery.com>
        
         * breakpoint.c (break_command_1): Return void.
index 15e168ff9b4ff83942979eb7c93c61ac25f2c09c..ecba9edfe76006ce188cef3fa98956216f4e68d8 100644 (file)
@@ -1898,8 +1898,12 @@ add_partial_symbol (struct partial_die_info *pdi, struct dwarf2_cu *cu)
   switch (pdi->tag)
     {
     case DW_TAG_subprogram:
-      if (pdi->is_external)
+      if (pdi->is_external || cu->language == language_ada)
        {
+          /* brobecker/2007-12-26: Normally, only "external" DIEs are part
+             of the global scope.  But in Ada, we want to be able to access
+             nested procedures globally.  So all Ada subprograms are stored
+             in the global scope.  */
          /*prim_record_minimal_symbol (actual_name, pdi->lowpc + baseaddr,
             mst_text, objfile); */
          psym = add_psymbol_to_list (actual_name, strlen (actual_name),
@@ -7296,8 +7300,15 @@ new_symbol (struct die_info *die, struct type *type, struct dwarf2_cu *cu)
             finish_block.  */
          SYMBOL_CLASS (sym) = LOC_BLOCK;
          attr2 = dwarf2_attr (die, DW_AT_external, cu);
-         if (attr2 && (DW_UNSND (attr2) != 0))
+         if ((attr2 && (DW_UNSND (attr2) != 0))
+              || cu->language == language_ada)
            {
+              /* Subprograms marked external are stored as a global symbol.
+                 Ada subprograms, whether marked external or not, are always
+                 stored as a global symbol, because we want to be able to
+                 access them globally.  For instance, we want to be able
+                 to break on a nested subprogram without having to
+                 specify the context.  */
              add_symbol_to_list (sym, &global_symbols);
            }
          else