Why think unit tests should be in their own source code hierarchy instead of side-by-side
Marco Leise
Marco.Leise at gmx.de
Thu Mar 22 17:09:55 UTC 2018
I understand your opinion and I think it is all reasonable.
You talk about longer compile times since every D module is
like a C++ header. That touches one of my pet peeves with the
language or eco system as it stands and I wonder if you would
agree with me on the following:
Libraries should be tied into applications using interface
files (*.di) that are auto-generated by the compiler for the
_library author_ with inferred function attributes. If after
a code change, a declaration in the *.di file changes, the
library's interface changed and a new minor version must be
released. The language must allow to explicitly declare a
function or method as @gc, impure, etc. so the auto-inferred
attributes don't later become an issue when the implementation
changes from e.g. a pure to an impure one.
Opaque struct pointers as seen in most C APIs should also be
considered for *.di files to reduce the number of imports for
member fields.
That means:
* No more fuzzyness about whether a library function
will remain @nogc, @safe, etc. in the next update.
* Explicit library boundaries that don't recursively import the
world.
--
Marco
More information about the Digitalmars-d-announce
mailing list