[phobos] I applied @safe, @trusted, @system to Phobos!
Andrei Alexandrescu
andrei at erdani.com
Sat May 22 06:24:18 PDT 2010
That's great work. Walter, any chance you'd give one extra iota of
priority to the bugs Shoo discovered?
Thanks,
Andrei
On 05/22/2010 06:36 AM, SHOO wrote:
> I succeeded in applying @safe, @trusted, @system to Phobos after hardship.
>
> I made a branch, please look:
>
> http://svn.dsource.org/projects/phobos/branches/devel/applying_safe_system_trusted
>
> I discovered some bugs and problems about @safe, @trusted, @system
> during my work.
>
> 1. Bugzilla 4211 - struct with annotation(@safe)
> See also http://d.puremagic.com/issues/show_bug.cgi?id=4211
>
> 2. Bugzilla 4218 - safe function cannot call opApply
> See also http://d.puremagic.com/issues/show_bug.cgi?id=4218
>
> 3. I cannot apply @safe to intrinsic operation(eg: std.math.sqrt)
> This causes mangling that had been influenced by @safe/@trusted.
> dmd converts a specific symbol into intrinsic operation. However,
> dmd cannot convert symbols that are marked by @safe/@trusted.
> I am skeptical about the influence on mangling rule by @safe.
>
> 4. dmd should not allow overload between @safe/@trusted and @system
> Document says "Functions are overloaded based on how well the
> arguments to a function can match up with the parameters."
> But @safe functions can overload between @system functions, though
> @safe is unrelated to parameters.
> It's enough to have only @safe function.
>
> 5. druntime's modules are not applying @safe/@system/@trusted
> This shows that Exception, TypeInfo, Thread and others are not
> usable by the @safe function virtually.
>
> 6. You must make the template function @trusted by all means
> When you use template, type that is maked @system may be handed to
> parameters.
> Therefore @trusted is required.
> This means that every template functions cannot take benefits from
> @safe.
>
> 7. Some mysterious compile errors
> When @safe unittest...
> Some functions are going to call opAssign. (eg: std.range(2670))
> Some functions are going to call __cpctor. (eg: std.stdio(165))
> Some functions are going to call ~this. (eg: std.stdio(872))
> (I try compile command: "dmd -I.. -c -o- -unittest -debug stdio.d")
>
> Please do not make it an useless treasure.
> I really wait for the day when this is used effectively.
>
> _______________________________________________
> phobos mailing list
> phobos at puremagic.com
> http://lists.puremagic.com/mailman/listinfo/phobos
More information about the phobos
mailing list