diff options
author | Tristan Gingold <tgingold@free.fr> | 2022-05-15 17:13:22 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2022-05-15 17:13:22 +0200 |
commit | dfc2238813b6a8caa6dfae91ae6838dbd8ef218a (patch) | |
tree | ad6e6a5a40c1fbfcf11872c973a519a44e11d6c5 | |
parent | ed155d259025f321a54fdf55065273830f2be904 (diff) | |
download | ghdl-dfc2238813b6a8caa6dfae91ae6838dbd8ef218a.tar.gz ghdl-dfc2238813b6a8caa6dfae91ae6838dbd8ef218a.tar.bz2 ghdl-dfc2238813b6a8caa6dfae91ae6838dbd8ef218a.zip |
elab-vhdl_values-debug: add disp_type_short
-rw-r--r-- | src/synth/elab-vhdl_values-debug.adb | 63 | ||||
-rw-r--r-- | src/synth/elab-vhdl_values-debug.ads | 3 |
2 files changed, 58 insertions, 8 deletions
diff --git a/src/synth/elab-vhdl_values-debug.adb b/src/synth/elab-vhdl_values-debug.adb index 8792fe292..193515e27 100644 --- a/src/synth/elab-vhdl_values-debug.adb +++ b/src/synth/elab-vhdl_values-debug.adb @@ -32,16 +32,18 @@ package body Elab.Vhdl_Values.Debug is end case; end Put_Dir; - procedure Debug_Bound (Bnd : Bound_Type) is + procedure Debug_Bound (Bnd : Bound_Type; Verbose : Boolean) is begin Put_Int32 (Bnd.Left); Put (' '); Put_Dir (Bnd.Dir); Put (' '); Put_Int32 (Bnd.Right); - Put (" [l="); - Put_Uns32 (Bnd.Len); - Put (']'); + if Verbose then + Put (" [l="); + Put_Uns32 (Bnd.Len); + Put (']'); + end if; end Debug_Bound; procedure Debug_Typ1 (T : Type_Acc) is @@ -52,7 +54,7 @@ package body Elab.Vhdl_Values.Debug is Put ("bit/logic"); when Type_Vector => Put ("vector ("); - Debug_Bound (T.Vbound); + Debug_Bound (T.Vbound, True); Put (") of ["); Debug_Typ1 (T.Vec_El); Put ("]"); @@ -62,7 +64,7 @@ package body Elab.Vhdl_Values.Debug is if I > 1 then Put (", "); end if; - Debug_Bound (T.Abounds.D (I)); + Debug_Bound (T.Abounds.D (I), True); end loop; Put (") of "); Debug_Typ1 (T.Arr_El); @@ -113,6 +115,51 @@ package body Elab.Vhdl_Values.Debug is New_Line; end Debug_Typ; + procedure Debug_Type_Short (T : Type_Acc) is + begin + case T.Kind is + when Type_Bit => + Put ("bit"); + when Type_Logic => + Put ("logic"); + when Type_Vector => + Debug_Type_Short (T.Vec_El); + Put ("_vec("); + Debug_Bound (T.Vbound, False); + Put (")"); + when Type_Array => + Put ("arr ("); + for I in 1 .. T.Abounds.Ndim loop + if I > 1 then + Put (", "); + end if; + Debug_Bound (T.Abounds.D (I), False); + end loop; + Put (")"); + when Type_Record => + Put ("rec: ("); + Put (")"); + when Type_Unbounded_Record => + Put ("unbounded record"); + when Type_Discrete => + Put ("discrete"); + when Type_Access => + Put ("access"); + when Type_File => + Put ("file"); + when Type_Float => + Put ("float"); + when Type_Slice => + Put ("slice"); + when Type_Unbounded_Vector => + Put ("unbounded vector"); + when Type_Unbounded_Array => + Put ("unbounded array"); + when Type_Protected => + Put ("protected"); + end case; + end Debug_Type_Short; + procedure Debug_Memtyp (M : Memtyp) is begin case M.Typ.Kind is @@ -121,7 +168,7 @@ package body Elab.Vhdl_Values.Debug is Put ("bit/logic"); when Type_Vector => Put ("vector ("); - Debug_Bound (M.Typ.Vbound); + Debug_Bound (M.Typ.Vbound, True); Put ("): "); for I in 1 .. M.Typ.Vbound.Len loop Put_Uns32 (Uns32 (Read_U8 (M.Mem + Size_Type (I - 1)))); @@ -132,7 +179,7 @@ package body Elab.Vhdl_Values.Debug is if I > 1 then Put (", "); end if; - Debug_Bound (M.Typ.Abounds.D (I)); + Debug_Bound (M.Typ.Abounds.D (I), True); end loop; Put ("): "); for I in 1 .. Get_Array_Flat_Length (M.Typ) loop diff --git a/src/synth/elab-vhdl_values-debug.ads b/src/synth/elab-vhdl_values-debug.ads index 6972a1b3e..000cd59c5 100644 --- a/src/synth/elab-vhdl_values-debug.ads +++ b/src/synth/elab-vhdl_values-debug.ads @@ -20,4 +20,7 @@ package Elab.Vhdl_Values.Debug is procedure Debug_Valtyp (V : Valtyp); procedure Debug_Memtyp (M : Memtyp); procedure Debug_Typ (T : Type_Acc); + + -- Short description, no newline. + procedure Debug_Type_Short (T : Type_Acc); end Elab.Vhdl_Values.Debug; |