From 4da9d12ef11a74074087ee93754d9ee80061ced3 Mon Sep 17 00:00:00 2001 From: Chris Penner Date: Mon, 5 Feb 2024 10:45:03 -0800 Subject: [PATCH] Fix span annotations on handle-with blocks --- .../src/Unison/Syntax/TermParser.hs | 9 ++++--- unison-src/transcripts/formatter.md | 13 ++++++++++ unison-src/transcripts/formatter.output.md | 25 +++++++++++++++++++ 3 files changed, 44 insertions(+), 3 deletions(-) diff --git a/parser-typechecker/src/Unison/Syntax/TermParser.hs b/parser-typechecker/src/Unison/Syntax/TermParser.hs index ef7c8360dd..fd2380e6ef 100644 --- a/parser-typechecker/src/Unison/Syntax/TermParser.hs +++ b/parser-typechecker/src/Unison/Syntax/TermParser.hs @@ -352,9 +352,12 @@ lam p = label "lambda" $ mkLam <$> P.try (some prefixDefinitionName <* reserved letBlock, handle, ifthen :: (Monad m, Var v) => TermP v m letBlock = label "let" $ (snd <$> block "let") handle = label "handle" do - (_spanAnn, b) <- block "handle" - (_spanAnn, handler) <- block "with" - pure $ Term.handle (ann b) handler b + (handleSpan, b) <- block "handle" + (_withSpan, handler) <- block "with" + -- We don't use the annotation span from 'with' here because it will + -- include a dedent if it's at the end of block. + -- Meaning the newline gets overwritten when pretty-printing and it messes things up. + pure $ Term.handle (handleSpan <> ann handler) handler b checkCasesArities :: (Ord v, Annotated a) => NonEmpty (Int, a) -> P v m (Int, NonEmpty a) checkCasesArities cases@((i, _) NonEmpty.:| rest) = diff --git a/unison-src/transcripts/formatter.md b/unison-src/transcripts/formatter.md index 81dbba2104..1999a4d1cc 100644 --- a/unison-src/transcripts/formatter.md +++ b/unison-src/transcripts/formatter.md @@ -38,6 +38,19 @@ ability Thing where more : Nat -> Text -> Nat doThing : Nat -> Int + +{{ Ability with single constructor }} +structural ability Ask a where + ask : {Ask a} a + +-- Regression test for: https://github.com/unisonweb/unison/issues/4666 +provide : a -> '{Ask a} r -> r +provide a action = + h = cases + {ask -> resume} -> handle resume a with h + {r} -> r + handle !action with h + {{ A Doc before a type }} diff --git a/unison-src/transcripts/formatter.output.md b/unison-src/transcripts/formatter.output.md index e0132020ab..03c313d79d 100644 --- a/unison-src/transcripts/formatter.output.md +++ b/unison-src/transcripts/formatter.output.md @@ -34,6 +34,19 @@ ability Thing where more : Nat -> Text -> Nat doThing : Nat -> Int + +{{ Ability with single constructor }} +structural ability Ask a where + ask : {Ask a} a + +-- Regression test for: https://github.com/unisonweb/unison/issues/4666 +provide : a -> '{Ask a} r -> r +provide a action = + h = cases + {ask -> resume} -> handle resume a with h + {r} -> r + handle !action with h + {{ A Doc before a type }} @@ -86,6 +99,18 @@ ability Thing where more : Nat -> Text ->{Thing} Nat doThing : Nat ->{Thing} Int + +Ask.doc = {{ Ability with single constructor }} +structural ability Ask a where ask : {Ask a} a + +-- Regression test for: https://github.com/unisonweb/unison/issues/4666 +provide : a -> '{Ask a} r -> r +provide a action = + h = cases + { ask -> resume } -> handle resume a with h + { r } -> r + handle !action with h + Optional.doc = {{ A Doc before a type }} structural type Optional a = More Text | Some | Other a | None Nat