Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/d-plaindoux/mfun
Micro functional langage
https://github.com/d-plaindoux/mfun
compiler embedded-language functional-programming parser-combinators
Last synced: 2 months ago
JSON representation
Micro functional langage
- Host: GitHub
- URL: https://github.com/d-plaindoux/mfun
- Owner: d-plaindoux
- License: lgpl-2.1
- Created: 2017-09-06T08:11:45.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2021-09-15T11:33:50.000Z (over 3 years ago)
- Last Synced: 2023-03-12T10:07:09.811Z (almost 2 years ago)
- Topics: compiler, embedded-language, functional-programming, parser-combinators
- Language: JavaScript
- Homepage:
- Size: 2.24 MB
- Stars: 12
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
README
# FµN
[![Build Status](https://travis-ci.org/d-plaindoux/mfun.svg)](https://travis-ci.org/d-plaindoux/mfun)
[![Coverage Status](https://coveralls.io/repos/d-plaindoux/mfun/badge.png?branch=master)](https://coveralls.io/r/d-plaindoux/mfun?branch=master)
[![experimental](http://badges.github.io/stability-badges/dist/experimental.svg)](http://github.com/badges/stability-badges)## Introduction
[Slides](http://d.plaindoux.free.fr/talks/lambdalille/mfun/index.html#/)
FµN is a micro functional language designed for compilation explanation purpose equiped with primitive data and a naive Javascript interoperability.
## Grammar
```
Id ::= [a-zA-Z_][a-zA-Z0-9_$?]*
exp ::= Id -- Identifier
| Number -- Float literal e.g. -1.3e2
| String -- String literal e.g. "o_O"
| "native" String -- Native binding
| '(' ')' -- Unit
| '(' exp+ ')' -- Block of application
| '$' exp+ -- Infix application
| '{' (Id+ "->")? exp+ '}' -- Abstraction à la Kotlin
| "let" Id '=' exp+ "in" exp+ -- Binding
def ::= "let" Id '=' exp+
s0 ::= def*
```## Example
```
let leq { l r t f -> native "leq" }
let mult { l r -> native "mult" }
let minus { l r -> native "minus" }let cond { c t f -> c t f () }
let fact { a ->
cond (leq a 1)
{ 1 }
{ mult a $ fact $ minus a 1 }
}let _ = fact 12
```## License
Copyright (C)2019-2020 D. Plaindoux.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as
published by the Free Software Foundation; either version 2, or (at
your option) any later version.This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.You should have received a copy of the GNU Lesser General Public
License along with this program; see the file COPYING. If not, write
to the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139,
USA.