From: Robert Dewar Date: Wed, 6 Jun 2007 10:28:45 +0000 (+0200) Subject: g-catiio.ads, [...] (Image): Check for null picture string X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f24f72e8928aad26ed15009ef1047de16d0193c2;p=gcc.git g-catiio.ads, [...] (Image): Check for null picture string 2007-04-20 Robert Dewar * g-catiio.ads, g-catiio.adb (Image): Check for null picture string From-SVN: r125413 --- diff --git a/gcc/ada/g-catiio.adb b/gcc/ada/g-catiio.adb index 585caea721d..f0174d5266a 100644 --- a/gcc/ada/g-catiio.adb +++ b/gcc/ada/g-catiio.adb @@ -6,7 +6,7 @@ -- -- -- B o d y -- -- -- --- Copyright (C) 1999-2006, AdaCore -- +-- Copyright (C) 1999-2007, AdaCore -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- @@ -202,19 +202,32 @@ package body GNAT.Calendar.Time_IO is Second : Second_Number; Sub_Second : Second_Duration; - P : Positive := Picture'First; + P : Positive; begin + -- Get current time in split format + Split (Date, Year, Month, Day, Hour, Minute, Second, Sub_Second); - loop + -- Null picture string is error + + if Picture = "" then + raise Picture_Error with "null picture string"; + end if; + + -- Loop through characters of picture string, building result + + Result := Null_Unbounded_String; + P := Picture'First; + while P <= Picture'Last loop + -- A directive has the following format "%[-_]." if Picture (P) = '%' then Padding := Zero; if P = Picture'Last then - raise Picture_Error; + raise Picture_Error with "picture string ends with '%"; end if; -- Check for GNU extension to change the padding @@ -222,13 +235,14 @@ package body GNAT.Calendar.Time_IO is if Picture (P + 1) = '-' then Padding := None; P := P + 1; + elsif Picture (P + 1) = '_' then Padding := Space; P := P + 1; end if; if P = Picture'Last then - raise Picture_Error; + raise Picture_Error with "picture string ends with '- or '_"; end if; case Picture (P + 1) is @@ -462,18 +476,21 @@ package body GNAT.Calendar.Time_IO is Result := Result & Image (Year, None, 4); when others => - raise Picture_Error; + raise Picture_Error with + "unknown format character in picture string"; + end case; + -- Skip past % and format character + P := P + 2; + -- Character other than % is copied into the result + else Result := Result & Picture (P); P := P + 1; end if; - - exit when P > Picture'Last; - end loop; return To_String (Result); diff --git a/gcc/ada/g-catiio.ads b/gcc/ada/g-catiio.ads index 0ed4f5e6e1f..48abe6a14d4 100644 --- a/gcc/ada/g-catiio.ads +++ b/gcc/ada/g-catiio.ads @@ -6,7 +6,7 @@ -- -- -- S p e c -- -- -- --- Copyright (C) 1999-2006, AdaCore -- +-- Copyright (C) 1999-2007, AdaCore -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- @@ -114,7 +114,7 @@ package GNAT.Calendar.Time_IO is (Date : Ada.Calendar.Time; Picture : Picture_String) return String; -- Return Date as a string with format Picture. Raise Picture_Error if - -- picture string is wrong. + -- picture string is null or has an incorrect format. function Value (Date : String) return Ada.Calendar.Time; -- Parse the string Date and return its equivalent as a Time value. The