digitalmars.D.bugs - [Issue 2082] New: Cannot convert char[] to string
- d-bugmail puremagic.com (22/22) May 08 2008 http://d.puremagic.com/issues/show_bug.cgi?id=2082
- BCS (2/29) May 08 2008 I think you need to use .idup
- d-bugmail puremagic.com (7/7) May 08 2008 http://d.puremagic.com/issues/show_bug.cgi?id=2082
- d-bugmail puremagic.com (11/11) May 08 2008 http://d.puremagic.com/issues/show_bug.cgi?id=2082
- d-bugmail puremagic.com (4/4) May 08 2008 http://d.puremagic.com/issues/show_bug.cgi?id=2082
http://d.puremagic.com/issues/show_bug.cgi?id=2082
Summary: Cannot convert char[] to string
Product: D
Version: 2.012
Platform: PC
OS/Version: Linux
Status: NEW
Severity: normal
Priority: P2
Component: DMD
AssignedTo: bugzilla digitalmars.com
ReportedBy: jlquinn optonline.net
This is really ugly. The following program:
void test(char[] s) {
string t = s;
}
gives the following error:
junk2.d(2): Error: cannot implicitly convert expression (s) of type char[] to
invariant(char)[]
I haven't found a way around this yet. It really should be handled as an
implicit conversion, with a copy being made under the covers as needed.
--
May 08 2008
Reply to d-bugmail puremagic.com,
http://d.puremagic.com/issues/show_bug.cgi?id=2082
Summary: Cannot convert char[] to string
Product: D
Version: 2.012
Platform: PC
OS/Version: Linux
Status: NEW
Severity: normal
Priority: P2
Component: DMD
AssignedTo: bugzilla digitalmars.com
ReportedBy: jlquinn optonline.net
This is really ugly. The following program:
void test(char[] s) {
string t = s;
}
gives the following error:
junk2.d(2): Error: cannot implicitly convert expression (s) of type
char[] to invariant(char)[]
I haven't found a way around this yet. It really should be handled as
an implicit conversion, with a copy being made under the covers as
needed.
I think you need to use .idup
May 08 2008
http://d.puremagic.com/issues/show_bug.cgi?id=2082 To me, this seems like it's going to clutter commonly occurring code. Since char[] and string are similar, and the language is generally trying to treat them like built-in types, I would hope this kind of conversion was transparent most of the time. --
May 08 2008
http://d.puremagic.com/issues/show_bug.cgi?id=2082
kamm-removethis incasoftware.de changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|NEW |RESOLVED
Resolution| |INVALID
-------
This is desired behaviour. Use idup() to make a new invariant copy or use a
cast (via assumeUnique from std.contracts?) if you can guarantee the data is
invariant.
--
May 08 2008
http://d.puremagic.com/issues/show_bug.cgi?id=2082 ------- *** Bug 2083 has been marked as a duplicate of this bug. *** --
May 08 2008









BCS <ao pathlink.com> 