... | ... | @@ -98,7 +98,15 @@ I can't think of any down-sides, except the slight loss of consistency ("the hob |
|
|
|
|
|
|
|
|
- Note that classes can be infix too; this is useful.
|
|
|
- Need to have a way to set the fixity of a type constructor `T` differently than the data constructor `T` (or not?).
|
|
|
|
|
|
- If you say `module M( (+) ) where ...` are you exporting the type constructor `(+)` or the value `(+)`? Ditto import lists. Possibilities:
|
|
|
|
|
|
- An ambiguous reference defaults to the locally-defined one. (If we did this we should do so consistently, including for unqualified names in the text of a module. I think this'd be a Good Thing. A warning flag could warn if you used it. It's just like shadowing.)
|
|
|
- If the two `(+)` things are not both locally defined, you can disambiguate with a qualified name `Prelude.(+)` or `M.(+)`. That does not help if you define *both* in `M`.
|
|
|
- Use a keyword to distinguish; eg `module M( data (+) ) where`. There are design issues here (e.g. distinguish `data` and `newtype`?).
|
|
|
|
|
|
- Can you set the fixity of a type constructor `T` differently than the data constructor `T`? This is a similar ambiguity to the one in export lists. Except that in this case it is very common to have a type constructor and data constructor with the same name.
|
|
|
|
|
|
- Need to allow infix notation in contexts
|
|
|
|
|
|
```wiki
|
... | ... | |