From 194405882619b94a0bdb54166886b43a9676c5ae Mon Sep 17 00:00:00 2001 From: Eric Botcazou Date: Sat, 25 Apr 2009 10:38:24 +0000 Subject: [PATCH] decl.c (gnat_to_gnu_entity): Put back kludge. * gcc-interface/decl.c (gnat_to_gnu_entity) : Put back kludge. From-SVN: r146766 --- gcc/ada/ChangeLog | 5 +++++ gcc/ada/gcc-interface/decl.c | 7 ++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index e76ea9d441c..46ae18aea16 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,3 +1,8 @@ +2009-04-25 Eric Botcazou + + * gcc-interface/decl.c (gnat_to_gnu_entity) : Put + back kludge. + 2009-04-24 Robert Dewar * mlib-prj.adb, prj-env.adb, prj-nmsc.adb, prj-proc.adb, make.adb, diff --git a/gcc/ada/gcc-interface/decl.c b/gcc/ada/gcc-interface/decl.c index 94f14bf6b06..d55d56b61f6 100644 --- a/gcc/ada/gcc-interface/decl.c +++ b/gcc/ada/gcc-interface/decl.c @@ -2546,9 +2546,14 @@ gnat_to_gnu_entity (Entity_Id gnat_entity, tree gnu_expr, int definition) | (TYPE_QUAL_VOLATILE * Treat_As_Volatile (gnat_entity)))); + /* Make it artificial only if the base type was artificial as well. + That's sort of "morally" true and will make it possible for the + debugger to look it up by name in DWARF, which is necessary in + order to decode the packed array type. */ gnu_decl = create_type_decl (gnu_entity_name, gnu_type, attr_list, - !Comes_From_Source (gnat_entity), + !Comes_From_Source (gnat_entity) + && !Comes_From_Source (Etype (gnat_entity)), debug_info_p, gnat_entity); /* Save it as our equivalent in case the call below elaborates