32

Let f x y = x * y. We can apply this function in two ways: f 5 6, or, using infix notation, 5 `f` 6. Do the operator rules apply to this last expression? What precedence will this application have? Is it just another form of function application, and so will it also have the highest precedence?

I suppose that the compiler sees this special form (due to `` and/or the name starting with a letter(?)), and actually treats this as ordinary function application, instead of considering it an operator.

1

2 Answers 2

31

The Haskell 98 Report has a section on Operator Applications that clears it up:

An operator is either an operator symbol, such as + or $$, or is an ordinary identifier enclosed in grave accents (backquotes), such as `op`. For example, instead of writing the prefix application op x y, one can write the infix application x `op` y. If no fixity declaration is given for `op` then it defaults to highest precedence and left associativity (see Section 4.4.2).

As indicated by the other answers, the Report also has a section on Fixity Declarations that allows you to define your own fixity, for example:

infixl 7 `op` 
Sign up to request clarification or add additional context in comments.

Comments

12

If no explicit fixity declaration is given, as e.g.

infixl 7 `quot` 

a backticked infix function has the default fixity of infixl 9, so will be treated like any other infix operator with the same fixity.

4 Comments

Why does it default to infixl 9? Is there any reason behind this choice, or is it arbitrary?
In a way, it's arbitrary of course. But since having it infix doesn't allow chaining without parentheses, it's more convenient to have a direction of associativity. Right-associativity is rarer, so infixl is the "least surprising" choice. The precedence level of 9 is closest to prefix application precedence, hence that changes the least in comparison to prefix application. I wasn't there when it was decided, but I think the idea is that infixl 9 was chosen with the expectation that it is most convenient and causes least surprise.
I see, but what about things like !! and $. Is there any reason given for why !! has higher precedence than $? Just trying to understand the reasoning for all the placements of the operators in the table: haskell.org/onlinereport/decls.html#fixity
$ needs a very low precedence because otherwise you'd still need parentheses when applying a function to a non-atomic argument, foo $ a + b*c would be pretty pointless if it meant (foo a) + (b*c). The purpose of $ demands that practically everything else has higher precedence. A lot of the [relative] precedences, * binds tighter than + etc., are common in mathematics and also other programming languages. Apart from prior conventions, considerations what would be most convenient for the [expected] common cases will have played a role deciding the precedences.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.