[GHC] #8581: Pattern synonym used in an expression context could have different constraints to pattern used in a pattern context

GHC ghc-devs at haskell.org
Sat Jul 30 08:46:52 UTC 2016


#8581: Pattern synonym used in an expression context could have different
constraints to pattern used in a pattern context
-------------------------------------+-------------------------------------
        Reporter:  cactus            |                Owner:
            Type:  feature request   |               Status:  new
        Priority:  normal            |            Milestone:
       Component:  Compiler          |              Version:
      Resolution:                    |             Keywords:
                                     |  PatternSynonyms
Operating System:  Unknown/Multiple  |         Architecture:
                                     |  Unknown/Multiple
 Type of failure:  None/Unknown      |            Test Case:
      Blocked By:                    |             Blocking:
 Related Tickets:                    |  Differential Rev(s):
       Wiki Page:                    |
-------------------------------------+-------------------------------------

Comment (by cactus):

 Replying to [comment:43 dfeuer]:
 > If we let the constructor have its own signature, can we drop the whole
 required constraints bit? If so, I think that would make things
 considerably less confusing.

 But the required constraints don't come from builders; a unidirectional
 pattern synonym can have just as much of a required context. The simplest
 example I can think of is


 {{{
 pattern P x <- (f -> x)
 }}}

 Here, any constraint of `f` on its argument's type will be a required
 constraint in `P`'s type.

 (Note that a special case of this is matching against overloaded literals,
 e.g. `pattern Z = 0`, which requires `(Num a, Eq a)`.)

--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/8581#comment:44>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler


More information about the ghc-tickets mailing list