summaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorMatthías Páll Gissurarson <mpg@mpg.is>2017-03-29 17:30:28 -0400
committerBen Gamari <ben@smart-cactus.org>2017-03-29 18:06:21 -0400
commit26c95f46e679fb73e1ec2bec2be0801c72fd1449 (patch)
treeeeedf7a400c80f07a8295c333875576d1b7b5800 /utils
parent924a65fc27bb2a3e24489f7baea7ad5fb8a556ac (diff)
downloadhaskell-26c95f46e679fb73e1ec2bec2be0801c72fd1449.tar.gz
Show valid substitutions for typed holes
The idea is to implement a mechanism similar to PureScript, where they suggest which identifiers in scope would fit the given hole. In PureScript, they use subsumption (which is what we would like here as well). For subsumption, we would have to check each type in scope whether the hole is a subtype of the given type, but that would require `tcSubType` and constraint satisfiability checking. Currently, `TcSimplify` uses a lot of functions from `TcErrors`, so that would require more of a rewrite, I will hold on with that for now, and submit the more simpler type equality version. As an example, consider ``` ps :: String -> IO () ps = putStrLn ps2 :: a -> IO () ps2 _ = putStrLn "hello, world" main :: IO () main = _ "hello, world" ``` The results would be something like ``` • Found hole: _ :: [Char] -> IO () • In the expression: _ In a stmt of a 'do' block: _ "hello, world" In the expression: do _ "hello, world" • Relevant bindings include main :: IO () (bound at test.hs:13:1) ps :: String -> IO () (bound at test.hs:7:1) ps2 :: forall a. a -> IO () (bound at test.hs:10:1) Valid substitutions include putStrLn :: String -> IO () (imported from ‘Prelude’ at test.hs:1:1-14 (and originally defined in ‘System.IO’)) putStr :: String -> IO () (imported from ‘Prelude’ at test.hs:1:1-14 (and originally defined in ‘System.IO’)) ``` We'd like here for ps2 to be suggested as well, but for that we require subsumption. Reviewers: austin, bgamari, dfeuer, mpickering Reviewed By: dfeuer, mpickering Subscribers: mpickering, Wizek, dfeuer, rwbarton, thomie Differential Revision: https://phabricator.haskell.org/D3361
Diffstat (limited to 'utils')
-rw-r--r--utils/mkUserGuidePart/Options/Optimizations.hs7
1 files changed, 7 insertions, 0 deletions
diff --git a/utils/mkUserGuidePart/Options/Optimizations.hs b/utils/mkUserGuidePart/Options/Optimizations.hs
index b0f9bc5ac8..992390ba3d 100644
--- a/utils/mkUserGuidePart/Options/Optimizations.hs
+++ b/utils/mkUserGuidePart/Options/Optimizations.hs
@@ -183,6 +183,13 @@ optimizationsOptions =
, flagType = DynamicFlag
, flagReverse = "-fno-max-relevant-bindings"
}
+ , flag { flagName = "-fmax-valid-substitutions=⟨n⟩"
+ , flagDescription =
+ "*default: 6.* Set the maximum number of valid substitutions for"++
+ "typed holes to display in type error messages."
+ , flagType = DynamicFlag
+ , flagReverse = "-fno-max-valid-substitutions"
+ }
, flag { flagName = "-fmax-uncovered-patterns=⟨n⟩"
, flagDescription =
"*default: 4.* Set the maximum number of patterns to display in "++