The Tomo programming language
Go to file
2024-07-04 18:45:04 -04:00
.pandoc Add manpage 2024-06-11 13:38:46 -04:00
builtins Randomize hash key on startup and rename to TOMO_HASH_KEY. 2024-07-04 16:46:24 -04:00
docs updated docs 2024-03-18 13:34:11 -04:00
include Hook things up so the compiler can run better without installing 2024-04-03 03:08:40 -04:00
test Fixes for defer statements in lambdas 2024-07-04 18:09:33 -04:00
.gitignore Ignore compiled test binaries 2024-05-02 12:51:59 -04:00
ast.c Check for newline between statements in blocks 2024-07-04 18:45:04 -04:00
ast.h Add 'defer' 2024-07-04 18:00:01 -04:00
compile.c Check for functions that don't return when they need to, as well as a 2024-07-04 18:27:08 -04:00
compile.h Remove some dead code and support -l as a tomo flag 2024-06-16 18:09:54 -04:00
enums.c Randomize hash key on startup and rename to TOMO_HASH_KEY. 2024-07-04 16:46:24 -04:00
enums.h Split header compilation into a separate function 2024-06-06 16:28:53 -04:00
environment.c Clean up some type checking with math operations and metamethods 2024-07-01 11:43:18 -04:00
environment.h Add 'defer' 2024-07-04 18:00:01 -04:00
learnxiny.tm Add multiline string 2024-07-02 13:21:17 -04:00
libraries.md Add library documentation 2024-06-10 12:11:44 -04:00
LICENSE Add license 2024-04-19 13:41:38 -04:00
Makefile Dump test results to console again 2024-06-17 17:35:21 -04:00
parse.c Check for newline between statements in blocks 2024-07-04 18:45:04 -04:00
parse.h More file comments 2024-03-18 12:49:38 -04:00
README.md Reference learnxiny in the readme 2024-06-18 01:34:42 -04:00
repl.c Support library name as a separate environment field from namespace 2024-06-16 16:08:35 -04:00
repl.h Adding a REPL 2024-03-30 12:14:24 -04:00
structs.c Randomize hash key on startup and rename to TOMO_HASH_KEY. 2024-07-04 16:46:24 -04:00
structs.h Split header compilation into a separate function 2024-06-06 16:28:53 -04:00
tomo.1 Add manpage 2024-06-11 13:38:46 -04:00
tomo.1.md Add manpage 2024-06-11 13:38:46 -04:00
tomo.c Clean up symbol_renames.txt 2024-06-16 20:07:33 -04:00
typecheck.c Check for functions that don't return when they need to, as well as a 2024-07-04 18:27:08 -04:00
typecheck.h Support corecursive structs 2024-05-14 13:30:46 -04:00
types.c Deprecate enum field access 2024-05-22 13:45:13 -04:00
types.h Add C string type 2024-05-18 14:38:41 -04:00

Tomo - Tomorrow's Language

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.

func greeting(name:Text)->Text:
	greeting := "hello {name}!"
	words := greeting:split(" ")
	return " ":join([w:capitalize() for w in words])

func main(name="World"):
	to_say := greeting(name)
	say(to_say)
$ tomo hello.tm
Hello World!
$ tomo hello.tm --name=åke
Hello Åke!
$ tomo -e hello.tm
$ ./hello --name="john doe"
Hello John Doe!

For more examples, see learnXinY which as an overview of many language features.

Features

Performance

  • Extremely high performance code generation with minimal overhead compared to C
  • Extremely fast parallel compilation times
  • Language-level support for out-of-the-box function caching emphasizing correctness
  • Structs with known-at-compile-time methods, not OOP objects with vtable lookups

Safety

  • Memory safety (garbage collection, compiler-enforced null safety, automatic array bounds checking, and no uninitialized variables)
  • Arithmetic overflow checking
  • Type-safe strings representing different languages with automatic prevention of code injection
  • Pattern matching with exhaustiveness checking for tagged unions

Simplicity

  • Simple, low-boilerplate type system with type inference
  • Well-defined reference and value semantics and mutability rules

User-friendliness

  • Useful and efficient built-in types: arrays, hash tables, structs, tagged unions (sum types), cords (efficient string representation)
  • Beautiful and helpful compiler and runtime error messages with emphasis on user-friendliness
  • Full UTF8 support for all text operations
  • Built-in doctests with syntax highlighting
  • Automatic command line argument parsing with type safety and no need for libraries.
  • Easy interoperability with C

Dependencies

Tomo has a very small set of dependencies:

  • The Boehm garbage collector for runtime garbage collection.
  • libunistring for unicode string support.
  • a C compiler
  • and libc/libm, which should definitely already be installed.

The Boehm GC and libunistring should be available on your package manager of choice (for example, pacman -S gc libunistring).

Building

The Tomo compiler can be compiled with either GCC or Clang by running make.

Usage

Run Tomo interactively as a REPL (limited functionality):

tomo
# Starts a REPL session

Run a Tomo file directly:

tomo foo.tm
# Runs the program

Compile a Tomo file into an object file:

tomo -c foo.tm
# Output: foo.tm.o

Transpile a Tomo file into a C header and source file:

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).

Installing

make && sudo make install