aboutsummaryrefslogtreecommitdiffstats
path: root/src/grt/grt-wave_opt.adb
diff options
context:
space:
mode:
authorJonas Baggett <jonas17b@gmail.com>2016-11-01 19:23:38 +0100
committertgingold <tgingold@users.noreply.github.com>2016-11-01 19:23:38 +0100
commitb869a4acb52358fe8ca5decaac826af056bfdfca (patch)
treebf9f65e7be9f06ab401e5f23f22194846aa1c389 /src/grt/grt-wave_opt.adb
parentdc6a82418653ce5b732d2bc26b393d3259fd93d5 (diff)
downloadghdl-b869a4acb52358fe8ca5decaac826af056bfdfca.tar.gz
ghdl-b869a4acb52358fe8ca5decaac826af056bfdfca.tar.bz2
ghdl-b869a4acb52358fe8ca5decaac826af056bfdfca.zip
There is a new --write-opt-file option that will create a wave option file with all the signals of the design. (#179)
The --wave-opt-file option is renamed to --read-opt-file for consistency Some code cleanup and bug fixes
Diffstat (limited to 'src/grt/grt-wave_opt.adb')
-rw-r--r--src/grt/grt-wave_opt.adb75
1 files changed, 75 insertions, 0 deletions
diff --git a/src/grt/grt-wave_opt.adb b/src/grt/grt-wave_opt.adb
new file mode 100644
index 000000000..0a6059adc
--- /dev/null
+++ b/src/grt/grt-wave_opt.adb
@@ -0,0 +1,75 @@
+-- GHDL Run Time (GRT) - Wave option file top package.
+-- Copyright (C) 2016 Jonas Baggett
+--
+-- GHDL is free software; you can redistribute it and/or modify it under
+-- the terms of the GNU General Public License as published by the Free
+-- Software Foundation; either version 2, or (at your option) any later
+-- version.
+--
+-- GHDL is distributed in the hope that it will be useful, but WITHOUT ANY
+-- WARRANTY; without even the implied warranty of MERCHANTABILITY or
+-- FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+-- for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with GCC; see the file COPYING. If not, write to the Free
+-- Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+-- 02111-1307, USA.
+--
+-- As a special exception, if other files instantiate generics from this
+-- unit, or you link this unit with other files to produce an executable,
+-- this unit does not by itself cause the resulting executable to be
+-- covered by the GNU General Public License. This exception does not
+-- however invalidate any other reasons why the executable file might be
+-- covered by the GNU Public License.
+
+-- Description: See package specifications
+
+with Grt.Errors; use Grt.Errors;
+
+package body Grt.Wave_Opt is
+
+ procedure Print_Context
+ (Lineno, Column : Positive; Severity : Severity_Type) is
+ begin
+ case Severity is
+ when Error =>
+ Error_C ("");
+ when Warning =>
+ Report_C ("warning: ");
+ end case;
+ Report_C (File_Path.all);
+ Report_C (":");
+ Report_C (Lineno);
+ Report_C (":");
+ Report_C (Column);
+ Report_C (": ");
+ end Print_Context;
+
+ procedure Print_Context (Element : Elem_Acc; Severity : Severity_Type) is
+ begin
+ Print_Context
+ (Element.Path_Context.Lineno, Element.Column, Severity);
+ end Print_Context;
+
+ procedure Error_Context (Msg : String;
+ Lineno, Column : Positive;
+ Severity : Severity_Type := Error) is
+ begin
+ Print_Context (Lineno, Column, Severity);
+ case Severity is
+ when Error =>
+ Error_E (Msg);
+ when Warning =>
+ Report_E (Msg);
+ end case;
+ end Error_Context;
+
+ procedure Error_Context
+ (Msg : String; Element : Elem_Acc; Severity : Severity_Type := Error) is
+ begin
+ Error_Context
+ (Msg, Element.Path_Context.Lineno, Element.Column, Severity);
+ end Error_Context;
+
+end Grt.Wave_Opt;