What's best practice to use compound literals with structs and C-APIs?
Robert M. Münch
robert.muench at saphirion.com
Thu May 2 07:11:37 UTC 2019
On 2019-05-01 19:13:54 +0000, Alex said:
>> Doesn't work because this seems to kick in some D releated run-time
>> stuff which lead to unresolved externals during linking:
>>
>> error LNK2001: Nicht aufgelöstes externes Symbol "...__initZ".
>> error LNK2001: Nicht aufgelöstes externes Symbol
>> "...__xtoHashFNbNeKxSQBtQBoQBfZm".
>> error LNK2001: Nicht aufgelöstes externes Symbol
>> "...__xopEqualsFKxSQBsQBnQBeKxQmZb".
>>
>> Not sure, why this happens.
>
> Found this bug: https://issues.dlang.org/show_bug.cgi?id=12374
>
> It is closed now, because of inactivity, if you have a current case - a
> reopen is welcome.
> However... Not sure, maybe someone else has more knowledge about this.
Thanks for the link, looks a bit related. I would need to see if I can
create a small case which shows the problem...
> So, you generate D structs from C, right? If so, and if you need the
> byRef at any cost - you could tweak the generator, so byRef is
> generated for all structs.
Well, the generator is DStep... and I'm not sure if a general "byRef"
approach would make sense. And listing affected structs manually will
complicate the workflow again.
What I'm irriated about is, that this works:
A tmp = {x,y};
return myfunc(&tmp);
But this doesn't:
return myfunc(new A(x,y));
Or I haven't found a valid syntax to do it inline.
--
Robert M. Münch
http://www.saphirion.com
smarter | better | faster
More information about the Digitalmars-d-learn
mailing list