The Death of D. (Was Tango vs Phobos)
Sean Kelly
sean at invisibleduck.org
Fri Aug 15 12:21:23 PDT 2008
Steven Schveighoffer wrote:
> "Sean Kelly" wrote
>> Steven Schveighoffer wrote:
>>> "Sean Kelly" <sean at invisibleduck.org> wrote in message
>>> news:g8347r$201b$1 at digitalmars.com...
>>>> Walter Bright wrote:
>>>>> Sean Kelly wrote:
>>>>>>> What specifically I'd like from the Tango team is explicit permission
>>>>>>> for the Phobos team to go over the Tango code and be able to copy/use
>>>>>>> whatever portions of it are necessary to get the two libraries to
>>>>>>> have a compatible core, and to relicense those parts under the
>>>>>>> corresponding Phobos license.
>>>>>> I think this is arguably a reasonable first step, but working towards
>>>>>> a compatible core still means two separate cores, which means not
>>>>>> being able to use Tango and Phobos together in the same app. So I'll
>>>>>> admit to not completely understanding the reasoning behind this
>>>>>> approach, but it's the only option so I'm happy to comply. Frankly, I
>>>>>> don't want to be stuck maintaining the Tango runtime from now until
>>>>>> doomsday anyway :-)
>>>>> If the cores are compatible at the API level, then one should be able
>>>>> to mix and match Tango/Phobos user level modules.
>>>> I think it will turn out to be more complicated than that. The runtime
>>>> contains user-visible code as well as the compiler support code and GC:
>>>> exception definitions, the thread code, etc. And Phobos vs. Tango have
>>>> different exception hierarchies, at the very least.
>>> As far as threads, I agree. One must be chosen.
>>>
>>> As far as exceptions, yes, one base must be chosen, and the exceptions
>>> put forth by the compiler must be chosen, but higher level exceptions do
>>> not have to be part of the runtime. For example, in Tango, socket
>>> exceptions are in the same module as array bound exception (which is
>>> needed by the compiler). These should be separated if we are to have a
>>> common runtime.
>> This decision camw fairly late in the game, and the basic reasoning was
>> that we wanted to establish a formal exception hierarchy. So a bunch of
>> relatively standard exceptions were moved into tango.core.Exception to
>> populate the hierarchy. The alternative would have been for multiple
>> packages in Tango to try and declare and share a common top-level
>> Exception class, and that was just too messy. However, I think it's worth
>> noting that none of the exceptions declared in tango.core are terribly
>> specific. Even SocketException is extremely broad, and as applicable for
>> end users as it is for Tango itself.
>
> I didn't mean exceptions need to be defined in individual modules, they can
> live in one file, but the user-lib exceptions need to be separate, because
> Phobos isn't going to care about Tango's SocketException for instance (or
> vice versa).
>
> There is nothing wrong with having runtime exceptions in one module, and
> being publicly imported in the user lib's exception module (which could
> remain as tango.core.Exception).
>
>> For what it's worth, this is one of the few bits of the runtime that I
>> didn't send to Walter because others were involved in designing the
>> hierarchy. Since there's no real code involved in exception declarations
>> it was probably over-cautious of me to omit it, but I didn't want there to
>> be any risk of contention later.
>>
>>> And in that case, I think you can draw a clear line: what is needed to
>>> compile programs, and what is needed to start the runtime. Everything
>>> else should be standard library code, and should be relegated to whatever
>>> you fancy as the runtime.
>> Tango was designed from the start such that the runtime (that is, the code
>> which is loaded invisibly for every D application) consists of three
>> distinct parts:
>>
>> * the compiler runtime (ie. language support code)
>> * the garbage collector
>> * some subset of the standard library which the compiler and GC code may
>> depend upon
>>
>> This design has some great advantages:
>>
>> * People with special needs (such as kernel developers) can replace or
>> stub out an entire subset of the runtime if the default version doesn't
>> suit their needs
>> * The compiler runtime is completely separate from the other runtime code
>> and may be maintained entirely separately--ie. it has no dependencies on
>> standard library code
>> * The garbage collector is completely separate as well. In fact, the GC
>> may be chosen at link-time simply by specifying a different library. Tango
>> contains two GCs to demonstrate this: one is the classic mark/sweep GC and
>> the other simply calls malloc and free.
>
> I agree that Tango's runtime design makes it ideal for splitting out from
> the user code.
>
>> Unfortunately however, none of this gets around the issue that the
>> standard library portion of the code must exist in only one location. And
>> I expect that both the Phobos and Tango team have a vested interest in not
>> changing how this stuff is exposed. In the case of Tango, this interest
>> is backed by the fact that we have a book in print documenting this stuff,
>> which also happens to be the only English book about D that I'm aware of.
>
> Exposure can be aliased (see below).
>
>>> I propose these essential classes and modules be moved into a separate
>>> package, like std.runtime. So you would have std.runtime.thread,
>>> std.runtime.exception, etc. Or whatever. Then the line is even clearer.
>> See above. That would be fine except for the confusion it would cause for
>> readers of our book. Also, maintenance responsibility is a potential
>> issue. None of these issues are addressed by a simple desire to share
>> code.
>
> This is my view (might not work, but I think it could). For purposes of
> simplicity, I'll assume Walter currently develops the Phobos runtime (not
> that he doesn't, but I'm really not sure :).
>
> Maintenance of the merged runtime would become Walter's responsibility, with
> your help if necessary (ideas and help understanding, and enhancements if
> you wish). Any changes desired for the runtime would go through Phobos (and
> Walter). The Tango lib would use the now tango-fied Phobos runtime, with
> alias imports for existing code (e.g. tango.core.Thread would either
> publicly import std.thread or would privately import it, and alias the
> Thread class).
My original goal was to have Walter maintain the DMD compiler runtime
and leave the rest to the appropriate parties. Walter clearly can't
maintain the entire runtime because Tango includes compiler runtimes for
GDC (currently) and LLVMC (soon), etc. Each of these should ideally be
maintained by the respective compiler author. One of the problems in my
mind is that Phobos isn't portable, as justified by the fact that GDC
contains GPhobos. It's an untenable long-term solution.
> Phobos user lib code would do the same, although I'd suspect that since
> Walter is maintaining the runtime, he'd want to follow Phobos' package and
> naming conventions. The one requirement for it is that the Phobos runtime
> MUST be separate from the user lib, and not depend on it. So no calling on
> Andrei's fancy Phobos-only templates :) This is similar to how I wanted
> Thread to use TimeSpan, but we can't because TimeSpan is part of the user
> lib.
Yeah, I wanted to move TimeSpan into the runtime so this would be
possible but was out-voted. But I think we both agree that the Tango
design is fairly close to ideal in that the runtime is entirely separate
from the user code (aside from some of the necessary exported bits).
> People who have the book can still use the code and ideas presented in the
> book, because the imports will alias the real classes/structs from the new
> Phobos runtime.
One concern I have about moving the runtime into Phobos is portability /
flexibility. Will it be possible to use the runtime without the user
code as it is in Tango? Will it continue to be compiler-agnostic? I'll
admit that I completely fail to see the point of the language creator
being the go-to man for the standard library as well.
> BTW, since the book was released, there have been a lot of breaking changes,
> so the edge of that point is dulled quite a bit.
Few, if any, of those breaking changes were covered by the book as far
as I'm aware.
> How does this sound (for both you and Walter)?
When you get right down to it, I really don't want to be stuck working
on Tango for the rest of my life, so my feelings are mixed. I think
that D accepting Tango as the official standard library and Walter et
al. collaborating with the Tango maintainers would be the optimal
solution for all concerned. However, I also don't want to be placed in
a position where I'm the linchpin holding everything together. My
personal responsibilities have grown considerably since Tango was
started and that's far more time and responsibility than I want, barring
a considerable paycheck for doing so. So in short I think it would be a
bad idea but I'd probably agree to it anyway because doing so is in my
own best interest.
Sean
More information about the Digitalmars-d
mailing list