Bug 17542 – DSON conversion of enums misses enum name

Status
NEW
Severity
enhancement
Priority
P4
Component
phobos
Product
D
Version
D2
Platform
All
OS
All
Creation time
2017-06-23T15:00:48Z
Last change time
2024-12-01T16:30:27Z
Assigned to
No Owner
Creator
Vladimir Panteleev
Moved to GitHub: phobos#10254 →

Comments

Comment #0 by dlang-bugzilla — 2017-06-23T15:00:48Z
This almost works: ///////////// test.d //////////// import std.conv : text; enum E { a } struct S { E e; } immutable S s1 = S.init; immutable S s2 = mixin(text(s1)); ///////////////////////////////// It doesn't work because for the enum member a, std.format emits just "a" instead of "E.a". std.format is already capable of converting the same type to string in different ways, e.g. format("%s", "hello") and format("%(%s%)", ["hello"]) will have the string converted differently (in the second case, with quotes and escapes). So, it would be nice that for similar circumstances, stringified enums had their name included in the same way that stringified structs have their name included. Incidentally, I found an interesting use case for DSON: parsing or generating a complicated data structure, dumping it to a .d file, then loading the .d file by using a mixin+import expression, for cases when generating said data directly at compile time would be too slow or otherwise impractical.
Comment #1 by robert.schadek — 2024-12-01T16:30:27Z
THIS ISSUE HAS BEEN MOVED TO GITHUB https://github.com/dlang/phobos/issues/10254 DO NOT COMMENT HERE ANYMORE, NOBODY WILL SEE IT, THIS ISSUE HAS BEEN MOVED TO GITHUB