2019-01-17 20:39:23 +03:00
< p align = "center" >
< img src = "https://raw.githubusercontent.com/d5/tengolang.com/master/logo_400.png" width = "200" height = "200" >
< / p >
2019-01-13 08:36:50 +03:00
# The Tengo Language
2019-01-14 18:17:07 +03:00
[![GoDoc ](https://godoc.org/github.com/d5/tengo?status.svg )](https://godoc.org/github.com/d5/tengo/script)
2019-01-15 14:30:32 +03:00
[![Go Report Card ](https://goreportcard.com/badge/github.com/d5/tengo )](https://goreportcard.com/report/github.com/d5/tengo)
2019-01-20 07:46:32 +03:00
[![Build Status ](https://travis-ci.org/d5/tengo.svg?branch=master )](https://travis-ci.org/d5/tengo)
2019-01-14 18:17:07 +03:00
2019-01-24 03:30:41 +03:00
Tengo is a small, dynamic, [securely embeddable ](https://github.com/d5/tengo/blob/master/docs/interoperability.md ) script language for Go.
2019-01-14 16:25:04 +03:00
2019-01-24 03:30:41 +03:00
Tengo is ** [fast ](#benchmark )** because it's compiled/executed as bytecode on stack-based VM that's written in native Go.
2019-01-13 08:36:50 +03:00
2019-01-24 03:30:41 +03:00
> Try [Tengo in Playground](https://tengolang.com/)
2019-01-13 08:36:50 +03:00
2019-01-13 09:09:43 +03:00
## Features
2019-01-13 08:36:50 +03:00
2019-01-24 03:30:41 +03:00
- Similar [syntax ](https://github.com/d5/tengo/blob/master/docs/tutorial.md ) to Go but much simpler
- Dynamically-typed with type coercions
- First-class functions and closures
- Garbage-collected
- [Extensible ](https://github.com/d5/tengo/blob/master/docs/objects.md )
- Written in Go _(no external deps or CGO)_
- Executable as a [standalone ](https://github.com/d5/tengo/blob/master/docs/tengo-cli.md ) language / REPL
2019-01-13 08:36:50 +03:00
## Benchmark
| | fib(35) | fibt(35) | Type |
| :--- | ---: | ---: | :---: |
2019-01-23 21:21:25 +03:00
| Go | `58ms` | `3ms` | Go (native) |
| [**Tengo** ](https://github.com/d5/tengo ) | `4,245ms` | `5ms` | VM on Go |
| Lua | `1,739ms` | `3ms` | Lua (native) |
| [go-lua ](https://github.com/Shopify/go-lua ) | `5,368ms` | `5ms` | Lua VM on Go |
| [GopherLua ](https://github.com/yuin/gopher-lua ) | `5,408ms` | `5ms` | Lua VM on Go |
| Python | `3,176ms` | `27ms` | Python (native) |
| [starlark-go ](https://github.com/google/starlark-go ) | `15,400ms` | `5ms` | Python-like Interpreter on Go |
| [gpython ](https://github.com/go-python/gpython ) | `17,724ms` | `6ms` | Python Interpreter on Go |
| [otto ](https://github.com/robertkrimen/otto ) | `82,050ms` | `22ms` | JS Interpreter on Go |
| [Anko ](https://github.com/mattn/anko ) | `98,739ms` | `31ms` | Interpreter on Go |
2019-01-20 18:41:57 +03:00
2019-01-24 03:30:41 +03:00
_* [fib(35) ](https://github.com/d5/tengobench/blob/master/code/fib.tengo ): Fibonacci(35)_
_* [fibt(35) ](https://github.com/d5/tengobench/blob/master/code/fibtc.tengo ): [tail-call ](https://en.wikipedia.org/wiki/Tail_call ) version of Fibonacci(35)_
_* **Go** does not read the source code from file, while all other cases do_
_* See [here ](https://github.com/d5/tengobench ) for commands/codes used_
2019-01-13 08:36:50 +03:00
2019-01-24 03:30:41 +03:00
## References
2019-01-13 08:36:50 +03:00
2019-01-24 03:30:41 +03:00
- [Language Syntax ](https://github.com/d5/tengo/blob/master/docs/tutorial.md )
- [Tengo Objects ](https://github.com/d5/tengo/blob/master/docs/objects.md )
- [Runtime Types ](https://github.com/d5/tengo/blob/master/docs/runtime-types.md )
- [Builtin Functions ](https://github.com/d5/tengo/blob/master/docs/builtins.md )
- [Interoperability ](https://github.com/d5/tengo/blob/master/docs/interoperability.md )
- [Tengo CLI ](https://github.com/d5/tengo/blob/master/docs/tengo-cli.md )
- [Standard Library ](https://github.com/d5/tengo/blob/master/docs/stdlib.md ) _(experimental)_
2019-01-13 08:36:50 +03:00
## Roadmap
2019-01-19 12:33:06 +03:00
### v0. _(Current)_
2019-01-13 08:36:50 +03:00
2019-01-19 12:33:06 +03:00
Things are experimental, and, the focus is on the **core language features** , **stability** , **basic interoperability** , and the **performance optimization** .
### v1. Tengo as a Script Language
This will be the first _versioned_ release, and, the main goal for v1 is to make Tengo as a _fast_ embeddable script language for Go, which means Tengo will be comparable to other Go-based script languages such as [Starlark ](https://github.com/google/starlark-go ), [Lua ](https://github.com/Shopify/go-lua ) [VM ](https://github.com/yuin/gopher-lua )s, and [other ](https://github.com/robertkrimen/otto ) [interpreter ](https://github.com/mattn/anko )s.
2019-01-13 08:36:50 +03:00
2019-01-19 12:33:06 +03:00
- Interoperability with Go code
2019-01-19 12:36:17 +03:00
- Sandbox environment
2019-01-19 12:33:06 +03:00
- More language features such as bound methods and switch-case statements
### v2. Tengo as a Standalone Language
- Language-level concurrency support
- Tengo Standard Libraries
- Native executables compilation
- More language features