The Tomo programming language
Go to file
2024-08-19 14:41:04 -04:00
.pandoc Add manpage 2024-06-11 13:38:46 -04:00
builtins Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
docs Add docs for lang 2024-08-19 14:41:04 -04:00
include Hook things up so the compiler can run better without installing 2024-04-03 03:08:40 -04:00
test Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
.gitignore Ignore compiled test binaries 2024-05-02 12:51:59 -04:00
ast.c Deprecate # operator in favor of .length and fix up some issues 2024-08-18 20:39:57 -04:00
ast.h Deprecate # operator in favor of .length and fix up some issues 2024-08-18 20:39:57 -04:00
compile.c Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
compile.h Fix for order of operations issues with enum and function typedef code 2024-07-23 19:46:42 -04:00
enums.c Add enum.tag as a way to do a boolean test for whether a value has a 2024-08-18 20:58:36 -04:00
enums.h Fix for order of operations issues with enum and function typedef code 2024-07-23 19:46:42 -04:00
environment.c Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
environment.h Restructure things so that DSL constructors do proper escaping 2024-08-19 13:23:02 -04:00
learnxiny.tm Update learnxiny to use new table syntax 2024-08-10 16:13:29 -04:00
LICENSE.md Update license to Sustainable Use License 2024-07-04 20:50:25 -04:00
Makefile Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
parse.c Add -deg suffix: 90deg for specifying degrees. Also fixed percent 2024-08-19 01:22:17 -04:00
parse.h Cache AST parsings so we don't have to re-parse files 2024-07-05 15:51:23 -04:00
README.md Update docs 2024-08-13 04:29:04 -04:00
repl.c Split BigIntType out of IntType and switch to using enums for the size 2024-08-18 11:49:51 -04:00
repl.h Adding a REPL 2024-03-30 12:14:24 -04:00
structs.c Split BigIntType out of IntType and switch to using enums for the size 2024-08-18 11:49:51 -04:00
structs.h Fix for order of operations issues with enum and function typedef code 2024-07-23 19:46:42 -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 Partially working first draft of bigints 2024-08-13 01:30:25 -04:00
typecheck.c Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
typecheck.h Support corecursive structs 2024-05-14 13:30:46 -04:00
types.c Add .text_content as a field on DSLs instead of a method 2024-08-19 14:29:58 -04:00
types.h Fix up some bigint logic issues 2024-08-18 12:47:29 -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)
  • Arbitrary-precision integers by default with opt-in fixed-with integers with arithmetic overflow checking
  • Type-safe strings representing different languages with automatic prevention of code injection
  • Pattern matching with exhaustiveness checking for tagged unions
  • Efficient immutable datastructures

Simplicity

  • Simple, low-boilerplate type system with type inference
  • Well-defined reference and value semantics and mutability rules
  • No polymorphism, generics, or inheritance

User-friendliness

  • Useful and efficient built-in types: arrays, hash tables, sets, structs, tagged unions (sum types), cords (efficient string representation)
  • String interpolation and debug printing builtins
  • 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 GC, libunistring, and binutils should be available on your package manager of choice (for example, pacman -S gc libunistring binutils).

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

License

Tomo is provided under the Sustainable Use License (see LICENSE.md for full details). This is a source-available fair-code 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", 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.