aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada
diff options
context:
space:
mode:
authorEtienne Servais <servais@adacore.com>2021-10-26 18:08:47 +0200
committerPierre-Marie de Rodat <derodat@adacore.com>2021-11-09 09:44:48 +0000
commit0803fd245a35c4b465cdefff20364f0f6e9f6fa7 (patch)
tree24e2a8b0b1f706d07e306cea2ec6408e086c0f61 /gcc/ada
parent02ca2184cdabf79c8c8353b7d464f15d26d1f24f (diff)
downloadgcc-0803fd245a35c4b465cdefff20364f0f6e9f6fa7.zip
gcc-0803fd245a35c4b465cdefff20364f0f6e9f6fa7.tar.gz
gcc-0803fd245a35c4b465cdefff20364f0f6e9f6fa7.tar.bz2
[Ada] Return a valid value when handling Constraint_Error
gcc/ada/ * scng.adb (Set_Start_Column): Return Column_Number'Last when handling Constraint_Error. Plus reformat a strangely 7 level if loop.
Diffstat (limited to 'gcc/ada')
-rw-r--r--gcc/ada/scng.adb55
1 files changed, 8 insertions, 47 deletions
diff --git a/gcc/ada/scng.adb b/gcc/ada/scng.adb
index fb42e30b..3c62337 100644
--- a/gcc/ada/scng.adb
+++ b/gcc/ada/scng.adb
@@ -2701,52 +2701,13 @@ package body Scng is
Tabs_Loop : loop
- -- Inner loop scans past blanks as fast as possible, bumping Scan_Ptr
- -- past the blanks and adjusting Start_Column to account for them.
-
- Blanks_Loop : loop
- if Source (Scan_Ptr) = ' ' then
- if Source (Scan_Ptr + 1) = ' ' then
- if Source (Scan_Ptr + 2) = ' ' then
- if Source (Scan_Ptr + 3) = ' ' then
- if Source (Scan_Ptr + 4) = ' ' then
- if Source (Scan_Ptr + 5) = ' ' then
- if Source (Scan_Ptr + 6) = ' ' then
- Scan_Ptr := Scan_Ptr + 7;
- Start_Column := Start_Column + 7;
- else
- Scan_Ptr := Scan_Ptr + 6;
- Start_Column := Start_Column + 6;
- exit Blanks_Loop;
- end if;
- else
- Scan_Ptr := Scan_Ptr + 5;
- Start_Column := Start_Column + 5;
- exit Blanks_Loop;
- end if;
- else
- Scan_Ptr := Scan_Ptr + 4;
- Start_Column := Start_Column + 4;
- exit Blanks_Loop;
- end if;
- else
- Scan_Ptr := Scan_Ptr + 3;
- Start_Column := Start_Column + 3;
- exit Blanks_Loop;
- end if;
- else
- Scan_Ptr := Scan_Ptr + 2;
- Start_Column := Start_Column + 2;
- exit Blanks_Loop;
- end if;
- else
- Scan_Ptr := Scan_Ptr + 1;
- Start_Column := Start_Column + 1;
- exit Blanks_Loop;
- end if;
- else
- exit Blanks_Loop;
- end if;
+ -- Inner loop scans past blanks, bumping Scan_Ptr past the blanks and
+ -- adjusting Start_Column to account for them.
+
+ Blanks_Loop :
+ while Source (Scan_Ptr) = ' ' loop
+ Scan_Ptr := Scan_Ptr + 1;
+ Start_Column := Start_Column + 1;
end loop Blanks_Loop;
-- Outer loop keeps going only if a horizontal tab follows
@@ -2771,7 +2732,7 @@ package body Scng is
exception
when Constraint_Error =>
- return Start_Column;
+ return Column_Number'Last;
end Set_Start_Column;
end Scng;