On Tuesday, 5 April 2016 at 01:21:55 UTC, Thalamus wrote:
I'm sorry for this total newbie question, but for some reason this is eluding me. I must be overlooking something obvious, but I haven't been able to figure this out and haven't found anything helpful.

I am invoking an entry point in a D DLL from C# (via extern (C)), and one of the parameters is a string. This works just fine for ANSI, but I'm having trouble with the Unicode equivalent.

For ANSI, the message parameter is char*, and string info = to!string(message) produces the correct string.

For Unicode, I assumed this would be wchar_t*, as it is in C++. (In C++ you can just pass the wchar_t* value to the wstring constructor.) So I tried wchar_t*, wchar* and dchar* as well. When the message parameter is wchar*, wstring info = to!wstring(message) populates the string with the _address_ of the wchar*. So when message was in the debugger as 0x00000000035370e8 L"Writing Exhaustive unit tests is exhausting.", the wstring info variable ended up as {length=7 ptr=0x000000001c174a20 L"35370E8" }. The dstring*/wchar_t* version had equivalent results.

Again, I'm sure I'm missing something obvious, but I poked at this problem with various types, casts, Phobos library string conversions, and I'm just stumped! :)

thanks,
Thalamus

I cannot give you any code example, but can you try that:

1. By using a loop, calculate the total byte length until finding 0 (zero). (This would work only if it was given as NULL-terminated, otherwise you need to know the length already.)
2. Then define wchar[ calculated_length ] mystring;
3. Copy the content from wchar* into you array. mystring[0 .. calculated_length ] = wcharptr[0 .. calculated_length]; 4. If you want, you can do casting for your mystring to convert it to wstring.

Reply via email to