On Friday, 15 June 2018 at 23:04:40 UTC, Sjoerd Nijboer wrote:
For someone coming from a C# background there is some seemingly
simple syntactic sugar missing from D.
* The null conditional operator `?.`
* Something like a `yield return` statement for coroutines.
T* he `async` & `await` keyword from C# make proactor pattern
async code extremely easy to reason about.
* a good syntax for properties so there's less code bloat.
* replacing `Allocator.make()` with `new!Allocator`. After all
`new` can be concidered as just a wrapper around the standard
GC allocator. Why can't we just have a special template of it?
I have realized that I have become quite dependant on syntactic
sugar to the point that it severely impacts my productivity
when I work whitout. And these ones are my biggest obstacles
when I try to work with D from a C# experience. I think that C#
really nailed down some of these particular examples except the
last one of course.
And I also think D could do a better job of embracing
productivity through supporting syntax of common tasks and
borrow from other languages in that regard.
But the most important question is how other people feel about
that.
If people hate syntactic sugar D will never become that gem for
me that I would like it to be. But if key people want it, it
one day might.
They are generally vehemently against anything that will make
programmers lives easier unless it can be implemented as a
library solution. They err on the side of library complexity vs
compiler complexity even if the feature adds no additional
complexity.
This is a good thing because most things that one wants to do can
be done as a library solution with only a more inconvenient form.
In the long term it is better to litter the library with poorly
thought out "features" than poorly thought out features being
permanently lodged in to the compiler/language. Of course, their
is depreciation... This also allows one to "depreciate" without
"depreciating", but at least it's easy to back up a source code
library and all the dependencies of to that library and the
compiler and all those dependencies of those dependencies. With
modern TB drives we can now create a near continuous recordings
of the state of a program and never worry about anything becoming
stale.