2024-02-24 13:06:49 -08:00
|
|
|
# Tomo - Tomorrow's Language
|
|
|
|
|
2024-03-09 21:17:45 -08:00
|
|
|
Tomo is a statically typed, safe, simple, lightweight, efficient programming
|
|
|
|
language that cross-compiles to C. Tomo is designed to anticipate and influence
|
|
|
|
the language design decisions of the future.
|
2024-02-24 13:06:49 -08:00
|
|
|
|
|
|
|
```
|
2024-09-03 18:10:08 -07:00
|
|
|
func greeting(name:Text, add_exclamation:Bool)->Text:
|
|
|
|
message := "hello $name"
|
|
|
|
message = " ":join([w:title() for w in message:split($/{space}/)])
|
|
|
|
if add_exclamation:
|
|
|
|
message ++= "!!!"
|
|
|
|
return message
|
2024-03-09 20:16:43 -08:00
|
|
|
|
2024-09-03 18:10:08 -07:00
|
|
|
func main(name:Text, shout=no):
|
|
|
|
to_say := greeting(name, add_exclamation=shout)
|
2024-08-10 13:53:12 -07:00
|
|
|
say(to_say)
|
2024-04-17 11:13:53 -07:00
|
|
|
```
|
|
|
|
|
|
|
|
```bash
|
2024-09-03 18:10:08 -07:00
|
|
|
$ tomo hello.tm world
|
|
|
|
Hello World
|
2024-04-17 11:13:53 -07:00
|
|
|
$ tomo hello.tm --name=åke
|
2024-09-03 18:10:08 -07:00
|
|
|
Hello Åke
|
2024-04-17 11:13:53 -07:00
|
|
|
$ tomo -e hello.tm
|
2024-09-03 18:10:08 -07:00
|
|
|
$ ./hello "john doe" --shout
|
|
|
|
Hello John Doe!!!
|
2024-02-24 13:06:49 -08:00
|
|
|
```
|
|
|
|
|
2024-09-12 21:27:46 -07:00
|
|
|
For more examples, see [learnXinY](/examples/learnxiny.tm) which as an overview
|
|
|
|
of many language features or the other example programs/modules in
|
2024-09-05 12:38:58 -07:00
|
|
|
[examples/](examples/).
|
2024-06-17 22:34:42 -07:00
|
|
|
|
2024-03-09 21:17:45 -08:00
|
|
|
## Features
|
|
|
|
|
2024-04-20 12:12:25 -07:00
|
|
|
### Performance
|
2024-03-09 21:17:45 -08:00
|
|
|
- Extremely high performance code generation with minimal overhead compared to C
|
2024-08-19 12:08:29 -07:00
|
|
|
- Extremely fast parallel [compilation](docs/compilation.md) times
|
2024-08-19 12:57:06 -07:00
|
|
|
- Language-level support for correct [function caching](docs/functions.md)
|
2024-08-19 12:08:29 -07:00
|
|
|
- [Structs](docs/structs.md) with known-at-compile-time methods, not OOP
|
|
|
|
objects with vtable lookups
|
2024-04-20 12:12:25 -07:00
|
|
|
|
|
|
|
## Safety
|
2024-08-19 12:08:29 -07:00
|
|
|
- Memory safety (garbage collection, [compiler-enforced null
|
|
|
|
safety](docs/pointers.md), [automatic array bounds
|
|
|
|
checking](docs/arrays.md), and no uninitialized variables)
|
|
|
|
- [Arbitrary-precision integers](docs/integers.md) by default with opt-in
|
|
|
|
fixed-with integers with arithmetic overflow checking
|
|
|
|
- [Type-safe strings representing different languages](docs/langs.md) with
|
|
|
|
automatic prevention of code injection
|
|
|
|
- Pattern matching with exhaustiveness checking for [tagged unions
|
|
|
|
(enums)](docs/enums.md)
|
|
|
|
- Efficient immutable datastructures: [arrays](docs/arrays.md),
|
|
|
|
[tables](docs/tables.md), [sets](docs/sets.md), [text](docs/text.md).
|
|
|
|
- [Privacy-protecting types](docs/structs.md#Secret-Values) that help prevent
|
|
|
|
logging sensitive information
|
2024-04-20 12:12:25 -07:00
|
|
|
|
|
|
|
## Simplicity
|
|
|
|
- Simple, low-boilerplate type system with type inference
|
|
|
|
- Well-defined reference and value semantics and mutability rules
|
2024-08-10 13:53:12 -07:00
|
|
|
- No polymorphism, generics, or inheritance
|
2024-04-20 12:12:25 -07:00
|
|
|
|
|
|
|
## User-friendliness
|
2024-08-19 12:08:29 -07:00
|
|
|
- [String interpolation](docs/text.md) and debug printing builtins
|
|
|
|
- Full-featured [libraries/modules](docs/libraries.md)
|
|
|
|
- [Full UTF8 support](docs/text.md) for all text operations
|
2024-03-09 21:17:45 -08:00
|
|
|
- Built-in doctests with syntax highlighting
|
2024-09-04 13:29:18 -07:00
|
|
|
- [Automatic command line argument parsing with type safety](docs/command-line-parsing.md)
|
2024-09-15 14:36:03 -07:00
|
|
|
- [Easy interoperability with C](docs/c-interoperability.md)
|
2024-03-09 20:21:44 -08:00
|
|
|
|
|
|
|
## Dependencies
|
|
|
|
|
2024-03-09 20:44:52 -08:00
|
|
|
Tomo has a very small set of dependencies:
|
|
|
|
|
|
|
|
- The [Boehm garbage collector](https://www.hboehm.info/gc/) for runtime
|
2024-08-10 13:53:12 -07:00
|
|
|
garbage collection.
|
2024-03-09 20:44:52 -08:00
|
|
|
- [libunistring](https://www.gnu.org/software/libunistring/) for unicode
|
2024-08-10 13:53:12 -07:00
|
|
|
string support.
|
2024-08-19 12:02:22 -07:00
|
|
|
- [GNU multiple precision arithmetic library](https://gmplib.org/manual/index)
|
|
|
|
for arbitrary precision integer math.
|
2024-07-04 21:37:01 -07:00
|
|
|
- [Binutils](https://www.gnu.org/software/binutils/) for stack traces.
|
2024-03-09 20:44:52 -08:00
|
|
|
- a C compiler
|
|
|
|
- and libc/libm, which should definitely already be installed.
|
|
|
|
|
2024-07-04 21:37:01 -07:00
|
|
|
The Boehm GC, libunistring, and binutils should be available on your package
|
|
|
|
manager of choice (for example, `pacman -S gc libunistring binutils`).
|
2024-03-09 20:44:52 -08:00
|
|
|
|
|
|
|
## Building
|
|
|
|
|
|
|
|
The Tomo compiler can be compiled with either GCC or Clang by running `make`.
|
|
|
|
|
2024-03-09 21:42:59 -08:00
|
|
|
## Usage
|
2024-03-09 20:44:52 -08:00
|
|
|
|
2024-05-14 11:27:42 -07:00
|
|
|
Run Tomo interactively as a REPL (limited functionality):
|
|
|
|
|
|
|
|
```bash
|
|
|
|
tomo
|
|
|
|
# Starts a REPL session
|
|
|
|
```
|
|
|
|
|
2024-03-09 21:42:59 -08:00
|
|
|
Run a Tomo file directly:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
tomo foo.tm
|
|
|
|
# Runs the program
|
|
|
|
```
|
|
|
|
|
|
|
|
Compile a Tomo file into an object file:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
tomo -c foo.tm
|
|
|
|
# Output: foo.tm.o
|
|
|
|
```
|
|
|
|
|
|
|
|
Transpile a Tomo file into a C header and source file:
|
|
|
|
```bash
|
|
|
|
tomo -t foo.tm
|
|
|
|
# Outputs: foo.tm.h foo.tm.c
|
|
|
|
```
|
|
|
|
|
|
|
|
Tomo uses the environment variables (`$CC`, `$VERBOSE`, and `$AUTOFMT`), which
|
|
|
|
control the compilation/running behavior of Tomo. The default behavior is to
|
|
|
|
use `tcc` (Tiny C Compiler) for fast compilation, `VERBOSE=0`, and
|
|
|
|
`AUTOFMT='indent -kr -l100 -nbbo -nut -sob'` for autoformatting generated code.
|
|
|
|
Any of these variables may be overridden, e.g. `CC=gcc VERBOSE=1 AUTOFMT= tomo
|
|
|
|
foo.tm` (compile with GCC and verbose compiler output without autoformatting
|
|
|
|
the code).
|
2024-03-09 21:17:45 -08:00
|
|
|
|
|
|
|
## Installing
|
|
|
|
|
|
|
|
```
|
|
|
|
make && sudo make install
|
|
|
|
```
|
2024-07-04 17:50:25 -07:00
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Tomo is provided under the Sustainable Use License (see
|
|
|
|
[LICENSE.md](LICENSE.md) for full details). This is a source-available
|
|
|
|
[fair-code](https://faircode.io) license that does not grant unlimited rights
|
|
|
|
for commercial use, but otherwise has permissive rights for noncommercial use
|
|
|
|
and allows distributing and modifying the source code. It does not comply with
|
|
|
|
the [Open Source Initiative's definition of "Open
|
|
|
|
Source"](https://opensource.org/osd), which does not allow any restrictions on
|
|
|
|
commercial use. If you would like to use this project commercially, please
|
|
|
|
contact me to work out a licensing agreement.
|