digitalmars.D - Help needed for "recursive template expansion error"
- Anthony Abeo (45/45) Oct 21 2019 Hello all,
- Nicholas Wilson (10/34) Oct 21 2019 Please post such questions to the learn forum in the future.
- Anthony Abeo (5/16) Oct 22 2019 - Please post such questions to the learn forum in the future.
- Simen =?UTF-8?B?S2rDpnLDpXM=?= (32/54) Oct 22 2019 I'd suggest using SumType
- Anthony Abeo (4/10) Oct 23 2019 Thanks Simen.
Hello all, I have an Algebraic type of structs as shown below. One of the structs is the `Code` struct and this struct holds an array of ATTR_INFO. It is self-referential. Obviously the compiler is unable to get the maximum size of ATTR_INFO at compile-time, hence throwing the error. I will be very grateful for any help to resolve this issue. alias ATTR_INFO = Algebraic!(SourceFile, ConstantValue, Excepsion, Code, LineNumberTable, LocalVariableTable); struct Code { size_t attribute_name_index; size_t attribute_len; size_t max_stack; size_t max_locals; size_t code_length; const(ubyte[]) code; size_t exception_table_length; Tuple!(size_t, size_t, size_t, size_t) exception_table; size_t attribute_count; ATTR_INFO[] attributes; } STACK TRACE /Library/D/dmd/src/phobos/std/variant.d(1517,23): Error: template instance `VariantN!(maxSize!(SourceFile, ConstantV alue, Excepsion, Code, LineNumberTable, LocalVariableTable), T)` recursive template expansion /Library/D/dmd/src/phobos/std/variant.d(87,48): Error: template instance `std.variant.maxSize!(Code, LineNumberTable , LocalVariableTable)` error instantiating /Library/D/dmd/src/phobos/std/variant.d(87,48): instantiated from here: maxSize!(Excepsion, Code, LineNumberT able, LocalVariableTable) /Library/D/dmd/src/phobos/std/variant.d(87,48): instantiated from here: maxSize!(ConstantValue, Excepsion, Code, LineNumberTable, LocalVariableTable) /Library/D/dmd/src/phobos/std/variant.d(1517,33): instantiated from here: maxSize!(SourceFile, ConstantValue, Excepsion, Code, LineNumberTable, LocalVariableTable) source/app.d(8,19): instantiated from here: Algebraic!(SourceFile, ConstantValue, Excepsion, Code, LineNumberTable, LocalVariableTable) /Library/D/dmd/bin/dmd failed with exit code 1.
Oct 21 2019
On Monday, 21 October 2019 at 18:14:11 UTC, Anthony Abeo wrote:Hello all, I have an Algebraic type of structs as shown below. One of the structs is the `Code` struct and this struct holds an array of ATTR_INFO. It is self-referential. Obviously the compiler is unable to get the maximum size of ATTR_INFO at compile-time, hence throwing the error. I will be very grateful for any help to resolve this issue. alias ATTR_INFO = Algebraic!(SourceFile, ConstantValue, Excepsion, Code, LineNumberTable, LocalVariableTable); struct Code { size_t attribute_name_index; size_t attribute_len; size_t max_stack; size_t max_locals; size_t code_length; const(ubyte[]) code; size_t exception_table_length; Tuple!(size_t, size_t, size_t, size_t) exception_table; size_t attribute_count; ATTR_INFO[] attributes; }Please post such questions to the learn forum in the future. One way to fix this is to use the `This` type to perform type substitution in the Algebraic which refers to the final type of the Algebraic, used like `alias F = Algebraic!(int, string, This[])`. Where F is either an int, a string or an array of Fs. You could probably remove `attributes` from code and use alias ATTR_INFO = Algebraic!(SourceFile, ConstantValue, Excepsion, Tuple!(Code,This[]), LineNumberTable, LocalVariableTable);
Oct 21 2019
On Monday, 21 October 2019 at 18:45:44 UTC, Nicholas Wilson wrote:On Monday, 21 October 2019 at 18:14:11 UTC, Anthony Abeo wrote:- Please post such questions to the learn forum in the future. Noted. I will do that next time. I tried your suggestion and it fails silently; no error message / stack trace.[...]Please post such questions to the learn forum in the future. One way to fix this is to use the `This` type to perform type substitution in the Algebraic which refers to the final type of the Algebraic, used like `alias F = Algebraic!(int, string, This[])`. Where F is either an int, a string or an array of Fs. You could probably remove `attributes` from code and use alias ATTR_INFO = Algebraic!(SourceFile, ConstantValue, Excepsion, Tuple!(Code,This[]), LineNumberTable, LocalVariableTable);
Oct 22 2019
On Tuesday, 22 October 2019 at 08:16:47 UTC, Anthony Abeo wrote:On Monday, 21 October 2019 at 18:45:44 UTC, Nicholas Wilson wrote:I'd suggest using SumType (https://code.dlang.org/packages/sumtype) instead of std.variant, as the latter has its share of problems. Otherwise, this kinda works, but can hardly be called anything but a horrible hack: alias ATTR_INFO = Algebraic!(SourceFile, ConstantValue, Excepsion, Code, LineNumberTable, LocalVariableTable); struct Code { size_t attribute_name_index; size_t attribute_len; size_t max_stack; size_t max_locals; size_t code_length; const(ubyte[]) code; size_t exception_table_length; Tuple!(size_t, size_t, size_t, size_t) exception_table; size_t attribute_count; private ubyte[] _attributes; } ref ATTR_INFO[] attributes(return ref Code code) { return *cast(ATTR_INFO[]*)&code._attributes; } It will need some fixing if you have any destructors, as Code treats those ATTR_INFOs as just a bunch of bytes, but it will make the code compile and it might be good enough. Seriously though, check out SumType instead. -- SimenOn Monday, 21 October 2019 at 18:14:11 UTC, Anthony Abeo wrote:- Please post such questions to the learn forum in the future. Noted. I will do that next time. I tried your suggestion and it fails silently; no error message / stack trace.[...]Please post such questions to the learn forum in the future. One way to fix this is to use the `This` type to perform type substitution in the Algebraic which refers to the final type of the Algebraic, used like `alias F = Algebraic!(int, string, This[])`. Where F is either an int, a string or an array of Fs. You could probably remove `attributes` from code and use alias ATTR_INFO = Algebraic!(SourceFile, ConstantValue, Excepsion, Tuple!(Code,This[]), LineNumberTable, LocalVariableTable);
Oct 22 2019
On Tuesday, 22 October 2019 at 08:42:48 UTC, Simen Kjærås wrote:On Tuesday, 22 October 2019 at 08:16:47 UTC, Anthony Abeo wrote:Thanks Simen. the sumtype package helped. Thanks everyone.[...]I'd suggest using SumType (https://code.dlang.org/packages/sumtype) instead of std.variant, as the latter has its share of problems. [...]
Oct 23 2019