aboutsummaryrefslogtreecommitdiffstats
path: root/src/grt
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2017-12-18 19:13:45 +0100
committerTristan Gingold <tgingold@free.fr>2017-12-20 20:58:40 +0100
commit7d1b6da515251a33f10f85793aeb02c60171ca95 (patch)
treefcabc4f0310249bd379479141245649430b238ca /src/grt
parent6bc6e9b69843f897bf43002c8da58e513db7b6e3 (diff)
downloadghdl-7d1b6da515251a33f10f85793aeb02c60171ca95.tar.gz
ghdl-7d1b6da515251a33f10f85793aeb02c60171ca95.tar.bz2
ghdl-7d1b6da515251a33f10f85793aeb02c60171ca95.zip
grt-options: extract Parse_Time.
Diffstat (limited to 'src/grt')
-rw-r--r--src/grt/grt-options.adb102
-rw-r--r--src/grt/grt-options.ads5
2 files changed, 61 insertions, 46 deletions
diff --git a/src/grt/grt-options.adb b/src/grt/grt-options.adb
index 8c045bd7d..535c0b8a8 100644
--- a/src/grt/grt-options.adb
+++ b/src/grt/grt-options.adb
@@ -217,6 +217,57 @@ package body Grt.Options is
end loop;
end Extract_Integer;
+ function Parse_Time (Str : String) return Std_Time
+ is
+ Ok : Boolean;
+ Pos : Natural;
+ Time : Integer_64;
+ Unit : String (1 .. 3);
+ begin
+ Extract_Integer (Str, Ok, Time, Pos);
+ if not Ok then
+ Time := 1;
+ end if;
+
+ -- Check unit length and convert it to lower case.
+ if Str'Last = Pos + 1 then
+ Unit (3) := ' ';
+ elsif Str'Last = Pos + 2 then
+ Unit (3) := To_Lower (Str (Pos + 2));
+ else
+ Error_C ("bad unit for '");
+ Error_C (Str);
+ Error_E ("'");
+ return -1;
+ end if;
+ Unit (1) := To_Lower (Str (Pos));
+ Unit (2) := To_Lower (Str (Pos + 1));
+
+ if Unit = "fs " then
+ null;
+ elsif Unit = "ps " then
+ Time := Time * (10 ** 3);
+ elsif Unit = "ns " then
+ Time := Time * (10 ** 6);
+ elsif Unit = "us " then
+ Time := Time * (10 ** 9);
+ elsif Unit = "ms " then
+ Time := Time * (10 ** 12);
+ elsif Unit = "sec" then
+ Time := Time * (10 ** 15);
+ elsif Unit = "min" then
+ Time := Time * (10 ** 15) * 60;
+ elsif Unit = "hr " then
+ Time := Time * (10 ** 15) * 3600;
+ else
+ Error_C ("bad unit name for '");
+ Error_C (Str);
+ Error_E ("'");
+ return -1;
+ end if;
+ return Std_Time (Time);
+ end Parse_Time;
+
procedure Decode_Option
(Option : String; Status : out Decode_Option_Status)
is
@@ -317,52 +368,11 @@ package body Grt.Options is
end if;
end;
elsif Len > 12 and then Option (1 .. 12) = "--stop-time=" then
- declare
- Ok : Boolean;
- Pos : Natural;
- Time : Integer_64;
- Unit : String (1 .. 3);
- begin
- Extract_Integer (Option (13 .. Len), Ok, Time, Pos);
- if not Ok then
- Time := 1;
- end if;
- if (Len - Pos + 1) not in 2 .. 3 then
- Error_C ("bad unit for '");
- Error_C (Option);
- Error_E ("'");
- return;
- end if;
- Unit (1) := To_Lower (Option (Pos));
- Unit (2) := To_Lower (Option (Pos + 1));
- if Len = Pos + 2 then
- Unit (3) := To_Lower (Option (Pos + 2));
- else
- Unit (3) := ' ';
- end if;
- if Unit = "fs " then
- null;
- elsif Unit = "ps " then
- Time := Time * (10 ** 3);
- elsif Unit = "ns " then
- Time := Time * (10 ** 6);
- elsif Unit = "us " then
- Time := Time * (10 ** 9);
- elsif Unit = "ms " then
- Time := Time * (10 ** 12);
- elsif Unit = "sec" then
- Time := Time * (10 ** 15);
- elsif Unit = "min" then
- Time := Time * (10 ** 15) * 60;
- elsif Unit = "hr " then
- Time := Time * (10 ** 15) * 3600;
- else
- Error_C ("bad unit name for '");
- Error_C (Option);
- Error_E ("'");
- end if;
- Stop_Time := Std_Time (Time);
- end;
+ Stop_Time := Parse_Time (Option (13 .. Len));
+ if Stop_Time = -1 then
+ -- In case of error...
+ return;
+ end if;
elsif Len > 13 and then Option (1 .. 13) = "--stop-delta=" then
declare
Ok : Boolean;
diff --git a/src/grt/grt-options.ads b/src/grt/grt-options.ads
index bd3721921..78fe9d8d7 100644
--- a/src/grt/grt-options.ads
+++ b/src/grt/grt-options.ads
@@ -144,6 +144,11 @@ package Grt.Options is
-- or append_mode (TEXTIO)
Unbuffered_Writes : Boolean := False;
+ -- Helper: extract time from STR (a number followed by a unit, without
+ -- spaces; the number is optionnal). In case of error, display an error
+ -- message and returns -1.
+ function Parse_Time (Str : String) return Std_Time;
+
-- Set the time resolution.
-- Only call this subprogram if you are allowed to set the time resolution.
procedure Set_Time_Resolution (Res : Character);