Skip to content

Commit

Permalink
⅄ trunk → 24-07-01-todo-merge-precondition-violations
Browse files Browse the repository at this point in the history
  • Loading branch information
mitchellwrosen committed Jul 3, 2024
2 parents 05d3402 + a74d4e8 commit 8ff7e6d
Show file tree
Hide file tree
Showing 11 changed files with 64 additions and 65 deletions.
6 changes: 5 additions & 1 deletion unison-cli/src/Unison/LSP/VFS.hs
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,11 @@ identifierSplitAtPosition uri pos = do
vf <- getVirtualFile uri
PosPrefixInfo {fullLine, cursorPos} <- MaybeT (VFS.getCompletionPrefix pos vf)
let (before, after) = Text.splitAt (cursorPos ^. character . to fromIntegral) fullLine
pure (Text.takeWhileEnd isIdentifierChar before, Text.takeWhile isIdentifierChar after)
pure
( Text.takeWhileEnd isIdentifierChar before,
-- names can end with '!', and it's not a force, so we include it in the identifier if it's at the end.
Text.takeWhile (\c -> isIdentifierChar c || c == '!') after
)
where
isIdentifierChar c =
-- Manually exclude '!' and apostrophe, since those are usually just forces and
Expand Down
20 changes: 10 additions & 10 deletions unison-src/transcripts/ability-term-conflicts-on-update.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
https://github.com/unisonweb/unison/issues/2786

```ucm:hide
.ns> builtins.merge
scratch/main> builtins.merge lib.builtins
```

First we add an ability to the codebase.
Expand All @@ -15,7 +15,7 @@ unique ability Channels where
```

```ucm
.ns> add
scratch/main> add
```

Now we update the ability, changing the name of the constructor, _but_, we simultaneously
Expand All @@ -36,8 +36,8 @@ thing _ = send 1
These should fail with a term/ctor conflict since we exclude the ability from the update.

```ucm:error
.ns> update.old patch Channels.send
.ns> update.old patch thing
scratch/main> update.old patch Channels.send
scratch/main> update.old patch thing
```

If however, `Channels.send` and `thing` _depend_ on `Channels`, updating them should succeed since it pulls in the ability as a dependency.
Expand All @@ -56,20 +56,20 @@ thing _ = send 1
These updates should succeed since `Channels` is a dependency.

```ucm
.ns> update.old.preview patch Channels.send
.ns> update.old.preview patch thing
scratch/main> update.old.preview patch Channels.send
scratch/main> update.old.preview patch thing
```

We should also be able to successfully update the whole thing.

```ucm
.ns> update.old
scratch/main> update.old
```

# Constructor-term conflict

```ucm:hide
.ns2> builtins.merge
scratch/main2> builtins.merge lib.builtins
```


Expand All @@ -78,7 +78,7 @@ X.x = 1
```

```ucm
.ns2> add
scratch/main2> add
```

```unison
Expand All @@ -89,5 +89,5 @@ structural ability X where
This should fail with a ctor/term conflict.

```ucm:error
.ns2> add
scratch/main2> add
```
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ unique ability Channels where
```
```ucm
.ns> add
scratch/main> add
⍟ I've added these definitions:
Expand Down Expand Up @@ -68,7 +68,7 @@ thing _ = send 1
These should fail with a term/ctor conflict since we exclude the ability from the update.

```ucm
.ns> update.old patch Channels.send
scratch/main> update.old patch Channels.send
x These definitions failed:
Expand All @@ -77,7 +77,7 @@ These should fail with a term/ctor conflict since we exclude the ability from th
Tip: Use `help filestatus` to learn more.
.ns> update.old patch thing
scratch/main> update.old patch thing
⍟ I've added these definitions:
Expand Down Expand Up @@ -122,7 +122,7 @@ thing _ = send 1
These updates should succeed since `Channels` is a dependency.

```ucm
.ns> update.old.preview patch Channels.send
scratch/main> update.old.preview patch Channels.send
I found and typechecked these definitions in scratch.u. If you
do an `add` or `update`, here's how your codebase would
Expand All @@ -135,7 +135,7 @@ These updates should succeed since `Channels` is a dependency.
Channels.send : a ->{Channels} ()
.ns> update.old.preview patch thing
scratch/main> update.old.preview patch thing
I found and typechecked these definitions in scratch.u. If you
do an `add` or `update`, here's how your codebase would
Expand All @@ -153,7 +153,7 @@ These updates should succeed since `Channels` is a dependency.
We should also be able to successfully update the whole thing.

```ucm
.ns> update.old
scratch/main> update.old
⊡ Ignored previously added definitions: Channels
Expand Down Expand Up @@ -183,7 +183,7 @@ X.x = 1
```
```ucm
.ns2> add
scratch/main2> add
⍟ I've added these definitions:
Expand Down Expand Up @@ -215,7 +215,7 @@ structural ability X where
This should fail with a ctor/term conflict.

```ucm
.ns2> add
scratch/main2> add
x These definitions failed:
Expand Down
24 changes: 12 additions & 12 deletions unison-src/transcripts/higher-rank.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ f id = (id 1, id "hi")
Another example, involving abilities. Here the ability-polymorphic function is instantiated with two different ability lists, `{}` and `{IO}`:

```unison
f : (forall a g . '{g} a -> '{g} a) -> () -> ()
f id _ =
f : (forall a g . '{g} a -> '{g} a) -> () -> ()
f id _ =
_ = (id ('1 : '{} Nat), id ('("hi") : '{IO} Text))
()
```
Expand All @@ -34,38 +34,38 @@ Functor.map : Functor f -> (forall a b . (a -> b) -> f a -> f b)
Functor.map = cases Functor f -> f
Functor.blah : Functor f -> ()
Functor.blah = cases Functor f ->
Functor.blah = cases Functor f ->
g : forall a b . (a -> b) -> f a -> f b
g = f
()
```

This example is similar, but involves abilities:
This example is similar, but involves abilities:

```unison
unique ability Remote t where doRemoteStuff : t ()
unique type Loc = Loc (forall t a . '{Remote t} a ->{Remote t} t a)
unique type Loc = Loc (forall t a . '{Remote t} a ->{Remote t} t a)
Loc.blah : Loc -> ()
Loc.blah = cases Loc f ->
f0 : '{Remote tx} ax ->{Remote tx} tx ax
f0 = f
()
-- In this case, no annotation is needed since the lambda
-- In this case, no annotation is needed since the lambda
-- is checked against a polymorphic type
Loc.transform : (forall t a . '{Remote t} a -> '{Remote t} a)
Loc.transform : (forall t a . '{Remote t} a -> '{Remote t} a)
-> Loc -> Loc
Loc.transform nt = cases Loc f -> Loc (a -> f (nt a))
-- In this case, the annotation is needed since f' is inferred
-- on its own it won't infer the higher-rank type
Loc.transform2 : (forall t a . '{Remote t} a -> '{Remote t} a)
Loc.transform2 : (forall t a . '{Remote t} a -> '{Remote t} a)
-> Loc -> Loc
Loc.transform2 nt = cases Loc f ->
Loc.transform2 nt = cases Loc f ->
f' : forall t a . '{Remote t} a ->{Remote t} t a
f' a = f (nt a)
Loc f'
Loc f'
```

## Types with polymorphic fields
Expand All @@ -77,6 +77,6 @@ structural type HigherRanked = HigherRanked (forall a. a -> a)
We should be able to add and view records with higher-rank fields.

```ucm
.higher_ranked> add
.higher_ranked> view HigherRanked
scratch/main> add
scratch/main> view HigherRanked
```
26 changes: 12 additions & 14 deletions unison-src/transcripts/higher-rank.output.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ f id = (id 1, id "hi")
Another example, involving abilities. Here the ability-polymorphic function is instantiated with two different ability lists, `{}` and `{IO}`:

```unison
f : (forall a g . '{g} a -> '{g} a) -> () -> ()
f id _ =
f : (forall a g . '{g} a -> '{g} a) -> () -> ()
f id _ =
_ = (id ('1 : '{} Nat), id ('("hi") : '{IO} Text))
()
```
Expand All @@ -61,7 +61,7 @@ Functor.map : Functor f -> (forall a b . (a -> b) -> f a -> f b)
Functor.map = cases Functor f -> f
Functor.blah : Functor f -> ()
Functor.blah = cases Functor f ->
Functor.blah = cases Functor f ->
g : forall a b . (a -> b) -> f a -> f b
g = f
()
Expand All @@ -83,32 +83,32 @@ Functor.blah = cases Functor f ->
-> (∀ a b. (a -> b) -> f a -> f b)
```
This example is similar, but involves abilities:
This example is similar, but involves abilities:

```unison
unique ability Remote t where doRemoteStuff : t ()
unique type Loc = Loc (forall t a . '{Remote t} a ->{Remote t} t a)
unique type Loc = Loc (forall t a . '{Remote t} a ->{Remote t} t a)
Loc.blah : Loc -> ()
Loc.blah = cases Loc f ->
f0 : '{Remote tx} ax ->{Remote tx} tx ax
f0 = f
()
-- In this case, no annotation is needed since the lambda
-- In this case, no annotation is needed since the lambda
-- is checked against a polymorphic type
Loc.transform : (forall t a . '{Remote t} a -> '{Remote t} a)
Loc.transform : (forall t a . '{Remote t} a -> '{Remote t} a)
-> Loc -> Loc
Loc.transform nt = cases Loc f -> Loc (a -> f (nt a))
-- In this case, the annotation is needed since f' is inferred
-- on its own it won't infer the higher-rank type
Loc.transform2 : (forall t a . '{Remote t} a -> '{Remote t} a)
Loc.transform2 : (forall t a . '{Remote t} a -> '{Remote t} a)
-> Loc -> Loc
Loc.transform2 nt = cases Loc f ->
Loc.transform2 nt = cases Loc f ->
f' : forall t a . '{Remote t} a ->{Remote t} t a
f' a = f (nt a)
Loc f'
Loc f'
```

```ucm
Expand Down Expand Up @@ -141,15 +141,13 @@ structural type HigherRanked = HigherRanked (forall a. a -> a)
We should be able to add and view records with higher-rank fields.

```ucm
☝️ The namespace .higher_ranked is empty.
.higher_ranked> add
scratch/main> add
⍟ I've added these definitions:
structural type HigherRanked
.higher_ranked> view HigherRanked
scratch/main> view HigherRanked
structural type HigherRanked = HigherRanked (∀ a. a -> a)
Expand Down
4 changes: 2 additions & 2 deletions unison-src/transcripts/merge.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@ The `merge` command merges together two branches in the same project: the curren
branch. For example, to merge `topic` into `main`, switch to `main` and run `merge topic`:

```ucm:error
.> help merge
.> help merge.commit
scratch/main> help merge
scratch/main> help merge.commit
```

Let's see a simple unconflicted merge in action: Alice (us) and Bob (them) add different terms. The merged result
Expand Down
4 changes: 2 additions & 2 deletions unison-src/transcripts/merge.output.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@ The `merge` command merges together two branches in the same project: the curren
branch. For example, to merge `topic` into `main`, switch to `main` and run `merge topic`:

```ucm
.> help merge
scratch/main> help merge
merge
`merge /branch` merges `branch` into the current branch
.> help merge.commit
scratch/main> help merge.commit
merge.commit (or commit.merge)
`merge.commit` merges a temporary branch created by the `merge`
Expand Down
2 changes: 1 addition & 1 deletion unison-src/transcripts/resolution-failures.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ two.ambiguousTerm = "term two"
```

```ucm
.example.resolution_failures> add
scratch/main> add
```

## Tests
Expand Down
4 changes: 1 addition & 3 deletions unison-src/transcripts/resolution-failures.output.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,7 @@ two.ambiguousTerm = "term two"
```
```ucm
☝️ The namespace .example.resolution_failures is empty.
.example.resolution_failures> add
scratch/main> add
⍟ I've added these definitions:
Expand Down
13 changes: 6 additions & 7 deletions unison-src/transcripts/update-on-conflict.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,7 @@
Updating conflicted definitions works fine.

```ucm:hide
.> builtins.merge
.merged> builtins.merge
scratch/main> builtins.merge lib.builtins
```

```unison
Expand All @@ -13,16 +12,16 @@ temp = 2
```

```ucm
.> add
.> debug.alias.term.force temp x
.> delete.term temp
scratch/main> add
scratch/main> debug.alias.term.force temp x
scratch/main> delete.term temp
```

```unison
x = 3
```

```ucm
.> update
.> view x
scratch/main> update
scratch/main> view x
```
Loading

0 comments on commit 8ff7e6d

Please sign in to comment.