digitalmars.D - Can't put a const(char)[] into a char[]
- Steven Schveighoffer (10/10) Apr 21 2018 I just came across this. Can't believe there's not been more people
- Nicholas Wilson (27/38) Apr 21 2018 "Use .representation" would be the official answer for the second
- Steven Schveighoffer (21/22) Apr 21 2018 I have since discovered that I can use byCodeUnit, but I'm still annoyed...
- Steven Schveighoffer (3/4) Apr 21 2018 https://github.com/dlang/phobos/pull/6471
I just came across this. Can't believe there's not been more people
finding this:
char[] buf = new char[100];
buf.formattedWrite("This is a number: %s", 5); // Error cannot put a
const(char)[] into a char[]
OK, challenge accepted!
buf[0 .. myName.length] = myName[]; // Hey phobos, look, this is easy!
But no, of course -- autodecoding. >:(
https://issues.dlang.org/show_bug.cgi?id=18790
-Steve
Apr 21 2018
On Saturday, 21 April 2018 at 22:34:39 UTC, Steven Schveighoffer
wrote:
I just came across this. Can't believe there's not been more
people finding this:
char[] buf = new char[100];
buf.formattedWrite("This is a number: %s", 5); // Error cannot
put a const(char)[] into a char[]
OK, challenge accepted!
buf[0 .. myName.length] = myName[]; // Hey phobos, look, this
is easy!
But no, of course -- autodecoding. >:(
https://issues.dlang.org/show_bug.cgi?id=18790
-Steve
"Use .representation" would be the official answer for the second
hack.
But this should absolutely work. It looks this looks the same
thing as
https://issues.dlang.org/show_bug.cgi?id=18472#c10
---
enum s = "%1$s,%2$s".format("foo","bar");
---
phobos/std/range/primitives.d(405): Error: static assert:
"Cannot put a const(char)[] into a Appender!string."
phobos/std/format.d(1184): instantiated from here:
put!(Appender!string, const(char)[])
/phobos/std/format.d(473): instantiated from here:
writeUpToNextSpec!(Appender!string)
phobos/std/format.d(6168): instantiated from here:
formattedWrite!(Appender!string, char, string, string)
main.d(5): instantiated from here: format!(char, string,
string)
18472 broke compilation of DCompute under -betterC when upgrading
LDC to a newer DMDFE, I "fixed" it by not compiling with -betterC
but then Mike Franklin (thanks!) discovered the above error after
fixing the -betterC side of things.
I'm going to be extremely unhappy if I can't compile dcompute at
all with the latest LDC.
IMO this is a priority 1 regression.
Apr 21 2018
On 4/21/18 7:30 PM, Nicholas Wilson wrote:"Use .representation" would be the official answer for the second hack.I have since discovered that I can use byCodeUnit, but I'm still annoyed that this is required. I *think* that this is the only problem: https://github.com/dlang/phobos/blob/master/std/range/primitives.d#L365 Essentially, here is the block: //Optional optimization block for straight up array to array copy. else static if (isDynamicArray!R && !isNarrowString!R && isDynamicArray!E && is(typeof(r[] = e[]))) { immutable len = e.length; r[0 .. len] = e[]; r = r[len .. $]; } If we just take out the !isNarrowString!R, I think it will just work, and probably cause no problems. I have NO IDEA why we are purposely shooting ourselves in the foot here. I'm going to at least try it (PR forthcoming). There are a few bits inside put that are supposed to cater to narrow strings, I'm not sure why it's not working. -Steve
Apr 21 2018
On 4/21/18 7:56 PM, Steven Schveighoffer wrote:I'm going to at least try it (PR forthcoming).https://github.com/dlang/phobos/pull/6471 -Steve
Apr 21 2018








Steven Schveighoffer <schveiguy yahoo.com>