tomo/README.md

146 lines
4.8 KiB
Markdown
Raw Normal View History

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
```
func greeting(name:Text, add_exclamation:Bool -> Text):
2024-09-03 18:10:08 -07:00
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)
## 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
```
## 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.