diff options
| author | Tristan Gingold <tgingold@free.fr> | 2020-07-25 19:09:17 +0200 | 
|---|---|---|
| committer | Tristan Gingold <tgingold@free.fr> | 2020-07-25 19:09:17 +0200 | 
| commit | 9f2f749c32d6ca8500f3f96977a4ee3801dc13a2 (patch) | |
| tree | 37f3ac6c4674514e5713c4a430fc04c102d7adcd /src | |
| parent | 3972f6c78055902116e6c9227da45e1bfe5e2c27 (diff) | |
| download | ghdl-9f2f749c32d6ca8500f3f96977a4ee3801dc13a2.tar.gz ghdl-9f2f749c32d6ca8500f3f96977a4ee3801dc13a2.tar.bz2 ghdl-9f2f749c32d6ca8500f3f96977a4ee3801dc13a2.zip | |
synth-aggr: handle strings in aggregates.  Fix #1406
Diffstat (limited to 'src')
| -rw-r--r-- | src/synth/synth-aggr.adb | 25 | 
1 files changed, 25 insertions, 0 deletions
| diff --git a/src/synth/synth-aggr.adb b/src/synth/synth-aggr.adb index 7732744a1..19d622195 100644 --- a/src/synth/synth-aggr.adb +++ b/src/synth/synth-aggr.adb @@ -19,6 +19,7 @@  --  MA 02110-1301, USA.  with Types; use Types; +with Str_Table;  with Netlists; use Netlists;  with Netlists.Utils; use Netlists.Utils; @@ -174,6 +175,30 @@ package body Synth.Aggr is        Const_P := True;        Err_P := False; +      if Get_Kind (Aggr) = Iir_Kind_String_Literal8 then +         declare +            Str_Id  : constant String8_Id := Get_String8_Id (Aggr); +            Str_Len : constant Int32 := Get_String_Length (Aggr); +            E       : Valtyp; +            V       : Nat8; +         begin +            pragma Assert (Stride = 1); +            if Bound.Len /= Width (Str_Len) then +               Error_Msg_Synth +                 (+Aggr, "string length doesn't match bound length"); +               Err_P := True; +            end if; +            for I in 1 .. Pos32'Min (Pos32 (Str_Len), Pos32 (Bound.Len)) loop +               E := Create_Value_Memory (El_Typ); +               V := Str_Table.Element_String8 (Str_Id, I); +               Write_U8 (E.Val.Mem, Nat8'Pos (V)); +               Res (Pos) := E; +               Pos := Pos + 1; +            end loop; +            return; +         end; +      end if; +        Assoc := Get_Association_Choices_Chain (Aggr);        while Is_Valid (Assoc) loop           Value := Get_Associated_Expr (Assoc); | 
