Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joshsharp/braid
A functional language with Reason-like syntax that compiles to Go.
https://github.com/joshsharp/braid
functional-languages go language ocaml reasonml
Last synced: about 2 months ago
JSON representation
A functional language with Reason-like syntax that compiles to Go.
- Host: GitHub
- URL: https://github.com/joshsharp/braid
- Owner: joshsharp
- License: mit
- Archived: true
- Created: 2018-05-25T12:54:12.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-04-24T05:59:31.000Z (over 5 years ago)
- Last Synced: 2024-11-14T20:55:11.735Z (about 2 months ago)
- Topics: functional-languages, go, language, ocaml, reasonml
- Language: Go
- Size: 813 KB
- Stars: 139
- Watchers: 10
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- programming-languages - Braid - Functional language with Reason-like syntax that compiles to Go. (Functional)
README
# Braid
A functional language with Reason-like syntax that compiles to Go.I’m working on a language I’m calling Braid, an ML-like language that compiles to Go. Braid’s syntax is heavily inspired by [Reason](https://reasonml.github.io/), itself a more C-like syntax on top of OCaml. So really I’m writing a language that aims to be fairly similar to OCaml in what it can do, but visually a bit closer to Go. I’m not trying to reimplement OCaml or Reason 1:1 on top of Go, but build something sharing many of the same concepts.
I've written some more about it on my [Braid dev blog](https://braid.joshsharp.com.au/).
## Status
Very, very alpha.
## Goals
- Pair an OCaml-like language with the benefits of the Go platform (speed, concurrency, static binaries, a healthy ecosystem)
- Bring powerful FP concepts to Go
- Get around Go's lack of generics
- Interop with Go code
- Ability to use Go stdlib## Non-goals
- Performance matching idiomatic Go
- Just reimplementing Reason on top of Go## Language overview
Consider anything ticked off to exist in the language, but be barely usable.
- [X] Record types
- [X] Variant types
- [X] If-expressions
- [X] Importing Go functions and types
- [X] Immutability by default
- [X] Hindley-Milner type inference
- [X] Type annotations
- [X] Implicit return
- [X] Multiple return
- [ ] Modules
- [ ] Pattern matching
- [ ] Currying
- [ ] Typeclasses/traits
- [ ] Concurrency
- [ ] Infix operatorsBraid supports records and variants:
```
type Person = {
name: string,
age: int64,
}type Fruit =
| Peach
| Plum
| Peartype Option ('a) =
| Some ('a)
| None
let result = Some("it worked")
```Braid attempts to support significant newlines, meaning no `;` required — however this is probably broken in a lot of cases right now.
A full example:
```
module Main// record type
type Payload = {
name: string,
data: string,
}// go interop - external functions must be annotated
extern func println = "fmt.Println" (s: string) -> ()
extern func printf1 = "fmt.Printf" (s: string, arg1:string) -> ()/* func to add cheesiness to any two items */
let cheesy = (item, item2) {
item ++ " and " ++ item2 ++ " with cheese please"
}let main = {
// nested functions
let something = {
4 + 9
}
let a = something()
let yumPizza = cheesy("pineapple", "bbq sauce")
println(yumPizza)
// calling a go function
printf1("Woo I can print %s\n", "6")
let b = Payload{name: "greeting", data: "hi"}
println(b.name)
}
```## Trying it out
Grab the correct Braid package for your platform from the [releases](https://github.com/joshsharp/braid/releases), extract the `braid` binary, and run it.
```sh
./braid filename.bd
```This will compile your Braid file to Go and print the resulting Go source code to stdout.
```sh
./braid filename.bd > main.go
```You can redirect this into a file if you like.
## Developing
### Requirements
- [Go 1.10](https://golang.org/dl/)
- [GB](https://getgb.io/)
- [goimports](https://godoc.org/golang.org/x/tools/cmd/goimports)### Building
Making sure Go and GB are in your path, clone the Braid repository into a new directory:
```sh
git clone https://github.com/joshsharp/braid.git
```Enter the new `braid` directory and fetch the requirements:
```sh
cd braid
gb vendor restore
```Make sure the vendored dependencies are built (you'll only need to do this once):
```sh
cd vendor
gb build all
```Use the makefile at `src/braid/Makefile` to build and run Braid:
```sh
cd ../src/braid
make run file=examples/example.bd
```## FAQ
### Will Braid support X?I don't know yet. I'm open to proposals, provided you help me do the work.
### Do you even know what you're doing?
Nope, not at all. I have no formal background in this stuff. Really I'm doing it for fun. I'd love to see it reach maturity, because I want to use it myself. But I'll need a lot of help if it's to get that far.
## Contributing
### Contribution guidelines
Your help makes Braid better! I welcome pull requests, bug fixes, and issue reports.Before proposing a change, please first create an issue to discuss your proposal.
## License
Licensed under the [MIT License](https://choosealicense.com/licenses/mit/).