How could I remove the "if ... then ... else ..." keywords in Haskell (GHC)?
Asked Answered
F

3

16

I would like to remove the if ... then ... else ... keywords, because I am embedding a language/DSL in Haskell. if, then and else convey a lot of meaning in many domains, and it would be great if I could redefine (or leave them undefined) them to reflect the nature of the language/domain.

I've searched on Google and stackoverflow, but found nothing. (I did find an old thread on why if ... then ... else ... was included as keywords in Haskell.)

My IDE is in Leksah, and, if the keywords can be removed, it would also be nice to have a setting to change the if ... then ... else ... keywords back to their normal font/color/unbold.


I've already tried a naming convention of if' for if and so on. It doesn't feel as good, especially when I want to define if and if', and have to define if' and if'' instead, or if1 and if2. The presence of both if' and if might also be confusing. (The confusion is not that serious an issue in my situation as the users of the DSL are Haskell programmers, but I suppose it can help in other situations).


Summarizing the responses to date:

  • Use the RebindableSyntax extension to GHC. Not as general as removing the keywords: the syntax of Haskell's if-then-else is retained. (Frerich Raabe)
  • Workaround: Use very similar words/names, by using data Conditional b a = If b (Then a) (Else a) (only applicable in some contexts). (C. A. McCann)

If RebindableSyntax is a relatively new feature, then it's unlikely to find a more general way, at least not till the next version of GHC.

Forefather answered 9/8, 2011 at 12:37 Comment(4)
Do you actually want to remove keywords of a language so that the compiler can treat them as variables?Aerial
If your DSL is sufficiently distinct from the surrounding Haskell, and works by building some sort of data structure representing expressions in the DSL, you could also just use a data type. e.g., something like data Conditional b a = If b (Then a) (Else a).Dry
You should remember that you shouldn't design your DSL's to make code look like English, you should design them to make it easy to see if the code doesn't work.Citrus
Antal: Thanks for the edit. ; camccann: Good suggestion. (And it seems like you have refactored your SO name.) ; eternalmatt: I agree that there are disadvantages when removing keywords, which must be properly considered. However, Haskell's if-then-else is quite unnecessary even as sugar, yet they use up prime short names.Forefather
B
31

The RebindableSyntax extension to GHC lets you overload if ... then ... else expressions with your own version. In particular, the ifThenElse function is used to define alternative meanings. if e1 then e2 else e3" means ifThenElse e1 e2 e3.

See the blog article Rebindable if..then..else expressions for a nice discussion of this feature, including some examples.

Brumaire answered 9/8, 2011 at 12:42 Comment(0)
P
11

You can't remove existing keywords. As was pointed out you can use RebindableSyntax, but that might not do what you want.

The only thing getting close to removing keywords is to turn on the CPP option and doing something like

#define if if_
#define then then_
#define else else_

The preprocessor will then expand if/then/else to if_/then_/else_.

Payroll answered 9/8, 2011 at 13:1 Comment(2)
Doing that naively would be unsafe. Doing that properly would involve writing a Haskell parser to refactor Haskell code...Forefather
Definitely unsafe in general.Payroll
C
0

How about:

cond True  t _ = t
cond False _ f = f
Connieconniption answered 9/8, 2011 at 12:51 Comment(1)
This is missing the point, really. Of course we can implement the same behavior as "if ... then ... else ..." with a different name, but what we really want is a different behavior with the same name.Tagmemic

© 2022 - 2024 — McMap. All rights reserved.