D: A language without focus

Alberto Simon lugaidster at gmail.com
Wed Apr 26 23:38:04 PDT 2006


I would be glad to help with everything you mentioned. I come from a C# 
background and I like the fact that most useful things you need are already 
there in .NET libraries. I like D for the fact that it provides a clean 
language without giving up power and speed, like C# (or any other .NET 
language for that matter). Since I believe D is meant to be a productive 
language in that you should only code what you need, I would really like to 
see a productive package (debugger plz!) for it, and if any help is needed I 
would like to offer mine. I hope that everything that is said here on 
doesn't become dust in the wind and that something useful comes from this.

Regards,
Alberto Simon

"gabe" <gabe_member at pathlink.com> escribió en el mensaje 
news:e2pnib$eht$1 at digitaldaemon.com...
> In article <e2pgfg$4s3$1 at digitaldaemon.com>, nick says...
>>
>>Sounds to me as though you are really eager to have D1.0 right this
>>moment and you are frustrated with all the things that aren't working
>>just the way you like them.
>>
>
> Well, you're only partially right about that.  I do have some 
> dissapointment
> that things don't exactly 'work'.  I think that anything that doesn't just
> 'work' for people coming to the language (or even working in it for a long
> time), tends to make D look inflexible and amaturish compared to other 
> efforts.
> That is not to say that D is in any way either of those things -- I think 
> it has
> the potential to be very robust and quite user-friendly, but in order for 
> the
> language to really succeed, you're going to have to convince more than 
> just me.
> In order to succeed, you're going to have to convince all the other 
> beginning,
> 10 cent hackers out there that D is a language of the future -- that it 
> HAS a
> future -- at the center of a stable and growing community.  All this feeds 
> into
> the notions that I outlined in my first message.  Design a system -- not 
> just
> part of the language -- to foster growth and stability, and people will 
> search
> YOU out, and not the other way around.  The keys to that system revolves 
> around
> finding what is necessary within the community and then designing toward 
> those
> goals.
>
> So, with that in mind, let me offer up some ideas that I have been 
> ruminating
> upon.
>
> First: The Build Mechanism
> I've tried to play around a little with Build, and I think to a certain 
> extent
> it's a fine tool.  What it lacks, I feel is not so much the ability to 
> compile a
> series of programs but to really bring the end product together for users. 
> To
> clarify: what build doesn't really seem to do is build in 
> user-friendliness into
> the libraries.  To a large extent, I think this more the fault of 
> documentation
> than of Build.  In my idea of a build tool, the documentation is far more
> succinct and far more powerful; it leverages the native unicode support of 
> D
> against XML.  Now, I know XML is everyone's favorite language to hate, as 
> it
> quickly becomes quite complicated if not done well, but I feel that by 
> using a
> basic and standardized syntax, D could quickly develop a usable (online)
> documentation system that exists in real-time with the development code 
> itself.
> Allow me to elaborate with the following, very rough example
>
> ---D source---
> /++doc.xml
> <doc lang="en_us">
> <author name="Danger Duck" date="01.12.07" liscense="GPLv3" />
> <method>
> <param>long sec_uid</param>
> <desc>A fake variable passed to secure this message against flame</desc>
> <return>A <link lib="util.fire.safety">FlameRetardantSuit</link> to 
> protect user
> against singing</return>
> </method>
> <example><![CDATA[[
> {
> Suit s = Suit.getRetardantSuit(my_long_security_id); /* pass in unique 
> id*/
> s.buttonUpItsGonnaGetHotInHere(); /* Lock yourself in the vault */
> s.waitForAllClear(clear_handler); /* Whew!, saved my tail feathers again! 
> */
> s.divest(); /* release the lock */
> }
> ]]>
> </example>
> <tutorial><![CDATA[
> You have to know what you're doing when you use this object.  Put it on 
> too
> soon, and you may overheat and cook your own goose.  Put it on too late, 
> and
> those henpecked farmers may get your gizzard.  As you can see from this 
> example
> <example ref="inline" /> the feathers are really flying.  Use it 
> carefully,
> though, and it'll all be like water off a duck's back.
>
> I apologize for all the fowl phrases.
> ]]>
> </tutorial>
> </doc>
> <doc lang="fr_fr">
> <method nom_de_poulet="Danger Duck" date="01.12.07" permet="GPLv3">
> <param>long sec_uid</param>
> <usage>Parlez le francais mieux de moi</usage>
> <rentre>Quelquechose de 'honk'</rentre>
> <exemple>
> ..etc., etc., etc., ...
> </doc>
> +/
> public FlameRetardantSuit getFlameRetardantSuit(long sec_uid) {
> ...
> }
>
> --- end D ---
> As you can see, it's possible to implement documentation at a level that 
> can be
> directly transformed into any number of kinds of documentation.   You 
> could
> publish the API and the examples on the Web; you could publish a library
> reference in PDF; you could distribute a localized tutorial in every 
> language
> imaginable.  The possibilities, frankly, for brining in people form around 
> the
> world are virtually limitless.  I know that this probably seems like way 
> too
> much documentation for a single method, but I think the idea is 
> essentially
> there -- it just has to be mined efffectively.
>
> Second:
> I've heard back from a few people about having a small core library.  I 
> can
> certainly respect that: coming from Java, I know what it feels like to 
> have a
> glut of options.  On the other hand, one of the undeniable draws for a 
> language
> is a substantial library of well-tested code.  The functionality of a 
> language
> is, in this sense, directly reflected in the composition of its libraries. 
> To
> that end, I would propose a two-tiered solution.  On the first tier, there 
> sits
> two basic libraries: 'lang' and 'sys'.  Unlike Java, which hides much of 
> the
> implementation details of the system, D users should be allowed the 
> freedom to
> deal directly with the hardware and the underlying system when needed. 
> For this
> reason, the sys and the lang packages will supply all of the basic 
> functionality
> needed for D to run in any environment.  This should especially appeal to
> systems programmers and library implementers, as one can hide a good deal 
> of
> existing c code behind some carefully constructed interfaces or superior
> packaging.  The 'lang' package, in particular, needs the 'sys' libs in 
> order to
> deliver all of the low-level coding required by each operating system, 
> thus, I
> believe, releiving even some of the lower details from language 
> implementors.
> It should be the case that these two packages are automatically searched 
> and
> compiled into any running program, though the top level DPATH may only 
> refer to
> '/usr/include/d/', or whatnot.
>
> The second part of this teir delivers everything else that the core 
> library
> lacks, including complicated IO, data structures, utilities, ui 
> components, and
> parsers.  I've given a rough outline of what the library might looklike 
> below.
> Of course, much of my model liberally samples (i.e. outright steals) from 
> the
> Java and C# library implementations.  This is the way I feel that it 
> should be
> -- each language should stand on the shoulders of the one that came before 
> it --
> and I think each of those languages are quite good at packaging together
> disparate pieces.  Of course, we wouldn't import from d.xxx -- we can drop 
> the
> 'd.' syntax entirely once the compiler supports native library builds; I 
> always
> did resent the whole 'import java....' fiasco.  This seems to be an ok 
> solution
> as long as we make sure that we don't conflict with URL domains in these
> top-level directories.
>
> d/
> ------ BRL - Basic Runtime Library ------
> lang
> gc
> exception
> thread
> primitives
> array
> bitarray
> string
> box
> hashmap
> compiler
> ..
>
> sys
> console (for some basic io)
> memory
> call (hiding system calls, I thought)
> lib  (Windows lib, glibc, ... what have you)
> ..
>
> -------------------------------------------
>
> ----- ERL - Extended Runtime Library ------
>
> ext
> c
> stdio
> math
> fenv
> process
> stdarg
> stddef
> stdlib
> string
> time
> ..
> c++
> ..
>
> data (collections/standard data structures, probably via templates)
> ArrayList
> Stack
> Queue
> LinkedList
> DoublyLinkedList
> CircularlyLinkedList
> BinaryTree
> Map
> ..
>
> util
> compress (protocols for bzip, gzip, tar etc.)
> logging
> date
> random
> ..
>
> os (or 'kaos', for nameing conflicts [kernel and o/s] -- hsa mythic 
> overtones)
> posix
> c
> windows
> c
> ..
> com
> ..
> dotnet
> linux
> c
> ..
> kernel (???)
> ..
> userland (???)
> titan
> minix
> ..
>
> security
> crypt
> md5
> sha1
> ..
> dgp (a port of gnu pgp might be very helpful, if signing mail, for 
> instance)
> invoke (secure calls to the system? 'Titan' might find this useful)
> ssl
> key
>
> math
> complex
> fourier
> boolean
> ..
>
> ui
> curses
> thea (D language graphical system based on the qt framework)
> opengl
> window
> ..
> ..
>
> text
> encoding
> unicode
> ansi
> codepage
> locale
> format
> regex
> parsers
> CVS
> yaml
> yacc (?)
> ..
>
> sql
> dbi (database interface abstraction)
> vendor (specific vendor APIs)
> slumber (hibernate or ado api?)
> ..
>
> io  (or 'dio', to avoid any conflicts)
> file
> buffer
> pipe
> stream
> ..
>
> inet (to deal with local imports like net.chickenplucker.geetar.blah)
> socket
> server
> http
> udp
> ftp
> mail
> encoding
> protocols
> ident
> url
> uri
> ..
> reactor
> svn
> ..
>
> xml
> parsers
> validators
> xpath
> xslt
> rpc
> soap
> ..
>
> ..
>
> ----------------------------------------
>
> One last thing before I slip off to bed: I really want to rally around an 
> open
> source license for this project, particularly one that strives for 
> complete
> transparency.  Not only does this really promote a sense of sharing and
> community, but I feel that it also gives newcomers and old hackers some 
> ideals
> to really identify with.  To that end I would suggest the GPL as the 
> starting
> point -- possibly even liscenesed under some kind of dual GPL/LGPL 
> liscense.
> This kind of transparency, I feel, really invites people to the table in 
> an
> egalitarian and communal way.  (Not to mention the fact that putting it 
> under
> the GPL opens up the floodworks for linking into other GPL code -- and 
> there's
> tons of it.)
>
> I'm sure that I've forgotten a few things in all this, and I think that 
> there's
> so much more to say, but I'm tired so I wish you all a fond goodnight and 
> I look
> forward to reading your responses in the morning.
>
> Quack!
> Gabe
>
> 





More information about the Digitalmars-d mailing list