[Haskell-cafe] Ternary infix expression parser

S D Swierstra doaitse.swierstra at gmail.com
Sat Aug 19 10:13:26 UTC 2017


Make the #uses expr #because expr #needs part act like an operator?

Doaitse

> Op 19 aug. 2017 om 05:56 heeft Jeffrey Brown <jeffbrown.the at gmail.com> het volgende geschreven:
> 
> I want to write a parser that lets someone write "(a #uses b) #because (c #needs d)" and read it into a tree:
> 
>   data Tree = Tree String Tree Tree | Leaf String
>   magic "(a #uses b) #because (c #needs d)"
>     = Tree "because" (Tree "uses" (Leaf "a") (Leaf "b"))
>                      (Tree "needs" (Leaf "c") (Leaf "d"))
> 
> I thought I could use Text.Megaparsec.Expr for it, but now I realize it hadnles binary operations, and this is a ternary one.
> 
> Suggestions?
> 
> 
> -- 
> Jeff Brown | Jeffrey Benjamin Brown
> Website   |   Facebook   |   LinkedIn(spammy, so I often miss messages here)   |   Github   
> _______________________________________________
> Haskell-Cafe mailing list
> To (un)subscribe, modify options or view archives go to:
> http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe
> Only members subscribed via the mailman list are allowed to post.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.haskell.org/pipermail/haskell-cafe/attachments/20170819/3aa02b71/attachment.html>


More information about the Haskell-Cafe mailing list