Skip to content
Snippets Groups Projects

Make RULE matching insensitive to eta-expansion

Closed Simon Peyton Jones requested to merge wip/T19790a into master

This is a new MR for #19790 (closed), focusing just on RULES

This patch fixes #19790 (closed) by making the rule matcher do on-the-fly eta reduction. See Note [Eta reduction the target] in GHC.Core.Rules

Other things in here

  • I found I also had to careful about casts when matching; see Note [Casts in the target] and Note [Casts in the template]

  • I made eta-reduction conditional on sm_eta_expand, in GHC.Core.Opt.Simplify.Utils.mkLam; reasons explained in Note [Casts and lambdas] in that module.

  • Lots more comments and Notes in the rule matcher

Merge request reports

Loading
Loading

Activity

Filter activity
  • Approvals
  • Assignees & reviewers
  • Comments (from bots)
  • Comments (from users)
  • Commits & branches
  • Edits
  • Labels
  • Lock status
  • Mentions
  • Merge request status
  • Tracking
  • added 18 commits

    Compare with previous version

  • And that match will succeed. Or am I missing something?

    I think you are missing something. It's this: you say:

    where we don't rename in e.

    but in fact we do rename e in because we return a renv which does so. (Only lazily.)

    I've updated the comments to make this clearer, I hope -- would you like to check?

  • Sebastian Graf
  • Thanks, that's much clearer!

  • added 2 commits

    • a5de5ded - Make RULE matching insensitive to eta-expansion
    • 29f7b427 - Fix a subtle scoping error in simplLazyBind

    Compare with previous version

  • added 47 commits

    • 29f7b427...f27dba8b - 43 commits from branch master
    • e1808496 - Simplify and improve the eta expansion mechanism
    • e8003e6d - Improve performance of eta expansion
    • ca6ebd6c - Fix a subtle scoping error in simplLazyBind
    • 69331402 - Make RULE matching insensitive to eta-expansion

    Compare with previous version

  • added 25 commits

    Compare with previous version

  • Simon Peyton Jones
  • Simon Peyton Jones
  • Richard Eisenberg
  • Richard Eisenberg
  • Richard Eisenberg
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Loading
  • Please register or sign in to reply
    Loading