Package Exports
- functionalscript
- functionalscript/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (functionalscript) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
FunctionalScript
FunctionalScript is a pure functional programming language and a strict subset of ECMAScript/JavaScript. It's inspired by
- JSON, as a subset of JavaScript; FunctionalScript is a superset of JSON.
- asm.JS/WebAssembly, as a subset of JavaScript;
- TypeScript, as a superset of JavaScript.
Try FunctionalScript here.
Create a new FunctionalScript repository on GitHub here.
One of the main challenges is how to make a pure functional language when ES6 TCO is not supported by Chrome and Firefox.
A workaround for this problem is to use let
for renaming objects.
JSON
jsonFile = expression
expression = primitive | array | objects
primitive = 'true' | 'false' | 'null' | number | string
array = '[' (() | items) ']'
items = expression (() | ',' items)
object = '{' (() | properties) '}'
properties = propertyId ':' expression (() | ',' properties)
propertyId = string
Stage 0
This stage can be used as an intermediate-code for VMs.
fjsFile = expression
expression = primitive | array | object | func | id | propertyAccessor
func = ('()' | id) '=>' body
body = '{' statements 'return' expression ';' '}'
statements = () | (statement statements)
statement = decl | ifStatement
decl = `const` id `=` expression `;`
ifStatement = `if` `(` expression `)` body
propertyAccessor = expression `[` expression `]`
call = expression `(` ( expression | ()) `)`
Stage 0.1. Node.js
nodeFile = statements 'module.exports' '=' expression ';'
Stage 0.2.
Operators
expression = ... | 'undefined' | groupingOperator | binaryOperatorExpression | unaryOperator | conditionalOperator
groupingOperator = '(' expression ')'
binaryOperatorExpression = expression binaryOperator expression
binaryOperator = comparisonOperator | arithmeticOperator | bitwiseOperator | logicalOperators | '??'
comparisonBinaryOperator = '===' | '!==' | '>' | '<' | '>=' | '<='
arithmeticBinaryOperator = '+' | '-' | '*' | '/' | '%' | '**'
bitwiseBinaryOperator = '&' | '|' | '^' | '<<' | '>>' | '>>>'
logicalBinaryOperator = '&&' | '||'
unaryOperator = '-' | '~' | '!'
Note: the syntax should be fixed to reflect operator precedents.
No ==
, !=
, =...
operators.
Function Expression
func = ('()' | id) '=>' (('{' statements 'return' expression ';' '}') | expression)
PropertyAccessor
propertyAccessor = expression (('[' expression ']') | ('.' id))
propertyId = string | id
BigInt
For example 42n
.
Additional Operators
typeOfOperator = 'typeof' expression
inOperator = expression 'in' expression
Stage 0.3. Syntax sugar
Hex, binary and octal literals
Functions with multiple parameters.
Spread syntax. For example ...object
.
Destructing assignments. For example const {a,b} = exp;
, const [a, b] = exp
.
Property Id expression { [exp]: exp }
.
Allow no semicolons.
Optional comma in arrays and objects.
Template literals const r= `onst r = ${exp}`;
.
An if
statement if (exp) { ... return exp }
Multiline strings
'sss\
wwww'
Regular expressions.
Stage 1
Typing using JSDoc and TypeScript types.
Stage 2
Mutable types with exclusive ownership (similar to Rust mutability).
let
,for
,while
etc. Note:let
can work as an object name reuse. In this case,let
objects can't be used in nested functions. It means we can't referencelet
object.Translated intolet x = 5 // ok f(x) x = 'hello!' // ok f(x) const r = () => { return x // compilation error }
const x0 = 5 f(x0) const x1 = 'hello!' f(x1)
- Generators
function*(){ ... yield ... }
. - Async
async () => f(await exp())
. - hopefully, we will have ES pipe operator at this time.
- pattern matching
Controversial ideas:
- Import and export
import x from "..."
,export const x = ...
,export default =
e.t.c. This may breaknew Function
runners. - Functional-TypeScript as a subset of TypeScript. Note: FunctionalScript doesn't require an additional build step in contrast to TypeScript.