The Tomo programming language
Go to file
2025-03-15 14:22:11 -04:00
.pandoc Add manpage 2024-06-11 13:38:46 -04:00
docs Rename without_escaping() -> from_text() 2025-03-12 18:12:53 -04:00
examples Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
stdlib Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
test Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
.gitignore Tweak gitignore 2024-09-06 12:20:58 -04:00
ast.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
ast.h Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
compile.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
compile.h Modify compile_type_info() so it no longer needs an env_t 2025-03-11 15:54:06 -04:00
cordhelpers.c Fix up some GCC compiler flag options for LTO and inlining 2024-10-29 23:14:31 -04:00
cordhelpers.h Move cord helper functions into their own file 2024-09-13 14:23:24 -04:00
enums.c Add extern structs 2025-03-11 17:03:03 -04:00
enums.h Restructure compile_file() so it moves a bit more towards less usage of 2025-02-19 16:30:19 -05:00
environment.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
environment.h Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
LICENSE.md Update license to Sustainable Use License 2024-07-04 20:50:25 -04:00
Makefile Set locale when running tests 2025-03-07 15:16:14 -05:00
parse.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
parse.h Deprecate dead code 2024-09-18 00:43:50 -04:00
README.md Deprecate autoformatter 2025-02-21 15:19:19 -05:00
repl.c Overhaul of constructors, making it more consistent and correct. Also 2025-03-05 18:20:54 -05:00
repl.h Adding a REPL 2024-03-30 12:14:24 -04:00
structs.c Support external structs with namespaced methods (also C-strings are now 2025-03-11 17:49:04 -04:00
structs.h Add extern structs 2025-03-11 17:03:03 -04:00
tomo.1 Update manpage 2025-03-11 00:11:39 -04:00
tomo.1.md Deprecate --quiet and just have that be the default 2025-03-11 00:08:26 -04:00
tomo.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
typecheck.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
typecheck.h Support 'when' for literal values with equality checking 2025-03-06 18:37:08 -05:00
types.c Overhaul of Path so it uses root and array of components instead of 2025-03-15 14:22:11 -04:00
types.h Add extern structs 2025-03-11 17:03:03 -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, add_exclamation:Bool -> Text):
    message := "hello $name"
    message = " ":join([w:title() for w in message:split($/{space}/)])
    if add_exclamation:
        message ++= "!!!"
    return message

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

For more examples, see learnXinY which as an overview of many language features or the other example programs/modules in examples/.

Features

Performance

Safety

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

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

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.