why D matters for Bioinformatics
Christophe Travert
travert at phare.normalesup.org
Wed May 23 01:30:14 PDT 2012
"bearophile" , dans le message (digitalmars.D:168160), a écrit :
> deadalnix:
>>>> http://blog.thebird.nl/?p=93
>>>...
>> I spreaded the word. This article is great and I 100% agree
>> with it :D
>
> The article says:
>
>>There are a few things I miss in D. For example pattern
>>recognition on unpacking data, which is great in Haskell,
>>Erlang, and Scala (see example
>>[http://www.scala-lang.org/node/120 ]).<
>
> The author of that article has missed that D lacks something much
> simpler than pattern matching, and even more commonly useful.
> Currently in D you have to write something like:
>
> int[2][] directions = [[-1, 0], [1, 0], [0, -1], [0, 1]];
> foreach (sx_sy; directions) {
> immutable sx = sx_sy[0];
> immutable sy = sx_sy[1];
> // code that uses sx and sy
>
>
> While a less clunky language allows you to unpack them better,
> something like:
>
> auto directions = [tuple(-1, 0), tuple(1, 0), tuple(0, -1),
> tuple(0, 1)];
> foreach (immutable (sx, sy); directions) {
> // code that uses sx and sy
>
>
> If you use tuples, you want to unpack them often, it's a basic
> operation on tuples.
This little example raises a question if tuples becomes part of the
langage. Should static array have tuple capabilities ?
Besides that, it is easy to emulate your example with a little
library solution. Maybe something like that should be added to
std.range.
--
Christophe
More information about the Digitalmars-d
mailing list