digitalmars.D.dwt - DWT fails to build with DMD 2.074.0
- JamesD (25/25) Apr 29 2017 Is there a known issue with DMD 2.074.0 importing *.di files?
- Petar Kirov [ZombineDev] (17/42) Apr 29 2017 Are the *.di generated automatically, or are they written by
- JamesD (12/29) Apr 29 2017 Thank you for your feedback and for the links to the bug reports!
Is there a known issue with DMD 2.074.0 importing *.di files?
(If no answer here, I will re-post in the DMD thread)
I've searched, but could not find this issue in the forums.
The following errors occur on both linux and windows when
building a simple hello world DWT gui app. The same code builds
on DMD 2.073.2 with no errors on both 32-bit and 64-bit linux and
windows.
Build error with DMD 2.074.0 importing *.di files:
https://pastebin.com/UgWNqZzh
It is beyond my technical ability to decipher what the core issue
is.
The same code builds with no errors when importing the
corresponding *.d files instead of the *.di files.
There are no errors building the DWT static libraries with DMD
2.074.0.
The errors occur when building a simple hello.d DWT gui app.
The obvious work-around is to import the *.d files instead of the
*.di files.
Building *.d files is a little slower, but almost negligible on a
fast PC.
However, there are minor issues with a few of the *.d files.
There are double semi-colons (;;) at the end of a few lines.
Here are the warnings building *.d files with dmd on linux:
https://pastebin.com/Zw7LjTh3
Perhaps I'll do a pull request to fix these minor errors?
Apr 29 2017
On Saturday, 29 April 2017 at 12:42:09 UTC, JamesD wrote:
Is there a known issue with DMD 2.074.0 importing *.di files?
(If no answer here, I will re-post in the DMD thread)
I've searched, but could not find this issue in the forums.
The following errors occur on both linux and windows when
building a simple hello world DWT gui app. The same code builds
on DMD 2.073.2 with no errors on both 32-bit and 64-bit linux
and windows.
Build error with DMD 2.074.0 importing *.di files:
https://pastebin.com/UgWNqZzh
It is beyond my technical ability to decipher what the core
issue is.
The same code builds with no errors when importing the
corresponding *.d files instead of the *.di files.
There are no errors building the DWT static libraries with DMD
2.074.0.
The errors occur when building a simple hello.d DWT gui app.
The obvious work-around is to import the *.d files instead of
the *.di files.
Building *.d files is a little slower, but almost negligible on
a fast PC.
However, there are minor issues with a few of the *.d files.
There are double semi-colons (;;) at the end of a few lines.
Here are the warnings building *.d files with dmd on linux:
https://pastebin.com/Zw7LjTh3
Perhaps I'll do a pull request to fix these minor errors?
Are the *.di generated automatically, or are they written by
hand? The compiler is known [0] to have problems with header
(*.di) generation, and IIRC there were some fixes recently [1]
that may have caused this problem. On the other hand there are no
known issues with importing *.di, since it works the same as as
improting plain *.d files (*.di is only a convention - you can
functions without bodies or vice versa in both).
Looking at https://pastebin.com/UgWNqZzh it seems that the
problem shouldn't be hard to solve, since it's only a syntax
error. I suggest examining and manually editing
../dwt/imp/org/eclipse/swt/accessibility/Accessible.di to narrow
down the problem.
I have no knowledge of DWT, so sorry if this is not very helpful.
[0]:
https://issues.dlang.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=NEW&bug_status=ASSIGNED&bug_status=REOPENED&bug_status=VERIFIED&component=dmd&list_id=214662&product=D&query_format=advanced&resolution=---&short_desc=header%20generation&short_desc_type=anywordssubstr
[1]: http://dlang.org/changelog/2.074.0.html issue 15676
Apr 29 2017
On Saturday, 29 April 2017 at 13:54:04 UTC, Petar Kirov [ZombineDev] wrote:Are the *.di generated automatically, or are they written by hand? The compiler is known [0] to have problems with header (*.di) generation, and IIRC there were some fixes recently [1] that may have caused this problem. On the other hand there are no known issues with importing *.di, since it works the same as as improting plain *.d files (*.di is only a convention - you can functions without bodies or vice versa in both). Looking at https://pastebin.com/UgWNqZzh it seems that the problem shouldn't be hard to solve, since it's only a syntax error. I suggest examining and manually editing ../dwt/imp/org/eclipse/swt/accessibility/Accessible.di to narrow down the problem. I have no knowledge of DWT, so sorry if this is not very helpful. [0]: https://issues.dlang.org/buglist.cgi?bug_status=UNCONFIRMED&bug_status=NEW&bug_status=ASSIGNED&bug_status=REOPENED&bug_status=VERIFIED&component=dmd&list_id=214662&product=D&query_format=advanced&resolution=---&short_desc=header%20generation&short_desc_type=anywordssubstr [1]: http://dlang.org/changelog/2.074.0.html issue 15676Thank you for your feedback and for the links to the bug reports! The *.di files are generated by DMD when building the *.di files, not by hand. I makes sense that it is an issue with DMD creating the *.di files, versus importing. Understood about editing the *.di files manually, but they are intended to be rebuilt depending on platform and arch. However, manually editing the *.d file is an option. I'm not sure if I have the technical knowledge to do this, but I'll consider after reviewing any other feedback.
Apr 29 2017








JamesD <none mail.com>