Skip to content

Commit

Permalink
Merge pull request #5269 from unisonweb/cp/restrict-annotation-change…
Browse files Browse the repository at this point in the history
…s-in-diffs
  • Loading branch information
aryairani authored Aug 9, 2024
2 parents 4c3eb03 + c341cc4 commit 096aeea
Show file tree
Hide file tree
Showing 3 changed files with 2,850 additions and 7 deletions.
14 changes: 13 additions & 1 deletion unison-share-api/src/Unison/Server/Backend/DefinitionDiff.hs
Original file line number Diff line number Diff line change
Expand Up @@ -59,5 +59,17 @@ diffSyntaxText (AnnotatedText fromST) (AnnotatedText toST) =
detectSpecialCase fromSegment toSegment
| fromSegment == toSegment = Left fromSegment
| AT.annotation fromSegment == AT.annotation toSegment = Right (SegmentChange (AT.segment fromSegment, AT.segment toSegment) (AT.annotation fromSegment))
| AT.segment fromSegment == AT.segment toSegment = Right (AnnotationChange (AT.segment fromSegment) (AT.annotation fromSegment, AT.annotation toSegment))
-- We only emit an annotation change if it's a change in just the hash of the element (optionally the KIND of hash reference can change too).
| AT.segment fromSegment == AT.segment toSegment,
Just _fromHash <- AT.annotation fromSegment >>= elementHash,
Just _toHash <- AT.annotation toSegment >>= elementHash =
Right (AnnotationChange (AT.segment fromSegment) (AT.annotation fromSegment, AT.annotation toSegment))
| otherwise = error "diffSyntaxText: found Syntax Elements in 'both' which have nothing in common."
where
elementHash :: Syntax.Element -> Maybe Syntax.UnisonHash
elementHash = \case
Syntax.TypeReference hash -> Just hash
Syntax.TermReference hash -> Just hash
Syntax.DataConstructorReference hash -> Just hash
Syntax.AbilityConstructorReference hash -> Just hash
_ -> Nothing
41 changes: 40 additions & 1 deletion unison-src/transcripts/definition-diff-api.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
```ucm
diffs/main> builtins.merge
diffs/main> builtins.mergeio lib.builtins
diffs/main> alias.term lib.builtins.Nat.gt lib.builtins.Nat.>
diffs/main> alias.term lib.builtins.Nat.drop lib.builtins.Nat.-
```

```unison
Expand All @@ -8,6 +10,20 @@ term =
1 + 1
type Type = Type Nat
ability Stream a where
emit : a -> ()
take n s =
use Nat > -
h n = cases
{ emit a -> k } -> if n > 0
then
emit a
handle k() with h (n - 1)
else None
{ r } -> Some r
handle s() with h n
```

```ucm
Expand All @@ -21,6 +37,22 @@ term =
1 + 2
type Type a = Type a Text
ability Stream a where
emit : a -> ()
take n s =
use Nat > -
h n = cases
{ emit a -> k } ->
emit a
if n > 0
then handle k() with h (n - 1)
else None
{ r } -> Some r
if n > 0
then handle s () with h (n - 1)
else None
```

```ucm
Expand All @@ -33,6 +65,13 @@ Diff terms
GET /api/projects/diffs/diff/terms?oldBranchRef=main&newBranchRef=new&oldTerm=term&newTerm=term
```

More complex diff

```api
GET /api/projects/diffs/diff/terms?oldBranchRef=main&newBranchRef=new&oldTerm=take&newTerm=take
```


Diff types

```api
Expand Down
Loading

0 comments on commit 096aeea

Please sign in to comment.