Brandon Moore wrote:
Greg Fitzgerald wrote:
Since there's talk of removal of the composition operator in Haskell-prime <http://hackage.haskell.org/trac/haskell-prime/wiki/CompositionAsDot>, how about this:

Instead of:
foo = f . g

you write:
foo = .g.f

A leading dot would mean, "apply all unnamed parameters to the function on the right". A trailing dot would mean, "apply the result of the left to the function on the right".
You mean "apply the function on the right to the result of the left"? Otherwise .g.f == \x -> (g x) f

Prelude> notNull = .null.not
=> [a] -> Bool
notNull [1,2,3]
=> True

[1,2,3].notNull
=> True
[1,2,3].null.not
=> True

I like this because it has the same perks as the composition operator, yet it looks like OO code and the data flows nicely from left to right. It reads especially well when using the bind operator on the same line.

Thoughts?
The left-to-right flow is pretty nice. I don't like the mechanics of your leading and internal dots - I don't see any way to interpret the internal dots as an infix operator without using some fancy typeclasses, whatever the leading dot gets to do. The infix dot would have to work at types
(a -> b) -> (b -> c) -> (a -> b)
and a -> (a -> b) -> b

Instead, How about making . reverse composition, and having some other symbol for flip ($), maybe '#'. Then you get things like

[1,2,3]#null.not

Which still vaguely resemble OO operations, if you think of composing together a path of accessors first, and then indexing with it.

you can even work with mutable fields reasonably nicely,
obj#a.b.c.readIORef
obj#a.b.c.flip writeIORef newVal

Finally,

Writing things in this left-to-right order lets you think of the starting value and make a sequence of transformations to get a result. Dangerously imperative ;)

The existing order instead calls to mind successively reducing the problem of producing desired output to simpler problems, eventually reaching a previously produced value. Wonderfully mathematical ;)
Or, think of taking the continuation of your expression, and transforming it in left-to-right steps into one prepared to accept the value you've got.

Brandon
_______________________________________________
Haskell-Cafe mailing list
Haskell-Cafe@haskell.org
http://www.haskell.org/mailman/listinfo/haskell-cafe

Reply via email to