Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/main' into feature/sc-479/update…
Browse files Browse the repository at this point in the history
…-encodings-to-make-use-of-hvmc-n-ary
  • Loading branch information
developedby committed Mar 1, 2024
2 parents b5fd2e2 + 2e9b3d3 commit 54af9f1
Show file tree
Hide file tree
Showing 37 changed files with 731,608 additions and 652 deletions.
56 changes: 29 additions & 27 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,12 @@ indexmap = "2.2.3"
interner = "0.2.1"
itertools = "0.11.0"
logos = "0.14.0"
stacker = "0.1"

[dev-dependencies]
insta = "1.34.0"
stdext = "0.3.1"
walkdir = "2.3.3"

[profile.test]
opt-level = 2
51 changes: 51 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,56 @@ data List = (List.cons head tail) | (List.nil)
ListEx2 = (List.cons 1 (List.cons 2 (List.cons 3 List.nil)))
```

It's possible to match different kinds of terms. These three forms are equivalent:
```rs
match list {
(List.cons hd tl): (Some hd)
List.nil: None
}

// If we don't provide field bindings, it will implicitly use
// the fields of the declared data type
match list {
List.cons: (Some list.head)
List.nil: None
}

match bind = list {
List.cons: (Some bind.head)
List.nil: None
}
```

Match native numbers:
```rs
match 4 {
0: "zero"
5: "five"
4: "four"
_: "other"
}
```

Which is the equivalent of nesting match terms:
```rs
match 4 {
0: "zero"
1+a: match (- (+ a (+ 0 1)) 5) {
0: "five"
_: ...
}
}
```

Match multiple terms:
```rs
λa λb match a, b {
(Some True) (x, y): (Some (x, y))
(Some False) (x, y): (Some (y, x))
None *: None
}
```

### More features

Key:
Expand All @@ -141,6 +191,7 @@ Other features are described in the following documentation files:

- 📗 Lazy definitions: [Making recursive definitions lazy](docs/lazy-definitions.md)
- 📗 Data types: [Defining data types](docs/defining-data-types.md)
- 📗 Pattern matching: [Pattern matching](docs/pattern-matching.md)
- 📗 Native numbers and operations: [Native numbers](docs/native-numbers.md)
- 📗 Builtin definitions: [Builtin definitions](docs/builtin-defs.md)
- 📙 Duplications and superpositions: [Dups and sups](docs/dups-and-sups.md)
Expand Down
2 changes: 1 addition & 1 deletion cspell.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"ctrs",
"datatypes",
"desugared",
"desugars",
"dref",
"dups",
"effectful",
Expand Down Expand Up @@ -48,7 +49,6 @@
"oprune",
"oref",
"postcondition",
"rdex",
"redex",
"redexes",
"readback",
Expand Down
8 changes: 4 additions & 4 deletions docs/compiler-options.md
Original file line number Diff line number Diff line change
Expand Up @@ -142,20 +142,20 @@ When the `linearize-matches` option is used, linearizes only vars that are used

Example:
```rs
λa λb match a { 0: b; +: b }
λa λb match a { 0: b; 1+: b }

// Is transformed to
λa λb (match a { 0: λc c; +: λd d } b)
λa λb (match a { 0: λc c; 1+: λd d } b)
```

When the `linearize-matches-extra` option is used, linearizes all vars used in the arms.

example:
```rs
λa λb λc match a { 0: b; +: c }
λa λb λc match a { 0: b; 1+: c }

// Is transformed to
λa λb λc (match a { 0: λd λ* d; +: λ* λe e } b c)
λa λb λc (match a { 0: λd λ* d; 1+: λ* λe e } b c)
```

## float-combinators
Expand Down
26 changes: 12 additions & 14 deletions docs/native-numbers.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,22 +34,22 @@ main = (~ 42 10)

HVM-lang also includes a `match` syntax for native numbers. The `0` case is chosen when `n` is 0, and the `+` case is chosen when `n` is greater than 0. The previous number, by default, bound to `n-1`.
```rs
Number.to_church = λn λf λx
Number.to_church = λn λf λx
match n {
0: x
+: (f (Number.to_church n-1 f x))
1+: (f (Number.to_church n-1 f x))
}
// Alternative syntax
Number.to_church = λn λf λx
Number.to_church = λn λf λx
match n {
0: x
+p: (f (Number.to_church p f x))
1+p: (f (Number.to_church p f x))
}
// Alternative syntax with name binding
Number.to_church = λn λf λx
Number.to_church = λn λf λx
match num = n {
0: x
+: (f (Number.to_church num-1 f x)
1+: (f (Number.to_church num-1 f x)
}
```

Expand All @@ -60,14 +60,12 @@ fibonacci = λn // n is the argument
match n {
// If the number is 0, then return 0
0: 0
// If the number is greater than 0, bind it predecessor to `a`
+a:
match a {
// If the predecessor is 0, then return 1
0: 1
// Otherwise, bind n-2 to `b` and return the sum of (fib n-1) and (fib n-2)
+b: (+ (fibonacci a) (fibonacci b))
}
// If the number is 1, then return 1
1: 1
// Otherwise, return the sum of (fib (n-2 + 1)) and (fib n-2)
// The successor pattern provides a `var`-`successor number` bind
// and it's also possible to define other bind name `2+x`
2+: (+ (fibonacci (+ n-2 1)) (fibonacci n-2))
}

main = (fibonacci 15)
Expand Down
Loading

0 comments on commit 54af9f1

Please sign in to comment.