back_end.adb (Call_Back_End): Pass the maximum logical line number instead of the maximum physical line...

* back_end.adb (Call_Back_End): Pass the maximum logical line number
	instead of the maximum physical line number to gigi.
	* gcc-interface/trans.c (Sloc_to_locus): Cope with line zero.

From-SVN: r180242
This commit is contained in:
Eric Botcazou 2011-10-20 10:56:08 +00:00 committed by Eric Botcazou
parent 687adac02d
commit b756276959
6 changed files with 33 additions and 1 deletions

View File

@ -1,3 +1,9 @@
2011-10-20 Eric Botcazou <ebotcazou@adacore.com>
* back_end.adb (Call_Back_End): Pass the maximum logical line number
instead of the maximum physical line number to gigi.
* gcc-interface/trans.c (Sloc_to_locus): Cope with line zero.
2011-10-16 Tom Tromey <tromey@redhat.com>
Dodji Seketeli <dodji@redhat.com>

View File

@ -114,9 +114,13 @@ package body Back_End is
return;
end if;
-- The back end needs to know the maximum line number that can appear
-- in a Sloc, in other words the maximum logical line number.
for J in 1 .. Last_Source_File loop
File_Info_Array (J).File_Name := Full_Debug_Name (J);
File_Info_Array (J).Num_Source_Lines := Num_Source_Lines (J);
File_Info_Array (J).Num_Source_Lines :=
Nat (Physical_To_Logical (Last_Source_Line (J), J));
end loop;
if Generate_SCIL then

View File

@ -8393,6 +8393,10 @@ Sloc_to_locus (Source_Ptr Sloc, location_t *locus)
Column_Number column = Get_Column_Number (Sloc);
struct line_map *map = LINEMAPS_ORDINARY_MAP_AT (line_table, file - 1);
/* We can have zero if pragma Source_Reference is in effect. */
if (line < 1)
line = 1;
/* Translate the location. */
*locus = linemap_position_for_line_and_column (map, line, column);
}

View File

@ -1,3 +1,8 @@
2011-10-20 Eric Botcazou <ebotcazou@adacore.com>
* gnat.dg/source_ref1.adb: New test.
* gnat.dg/source_ref2.adb: Likewise.
2011-10-19 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/13657

View File

@ -0,0 +1,6 @@
pragma Source_Reference (3, "p1.adb");
procedure Source_Ref1 is
begin
null;
end;

View File

@ -0,0 +1,7 @@
pragma Source_Reference (1, "p2.adb");
procedure Source_Ref2 is
pragma Source_Reference (2, "p2.adb");
begin
null;
end;