The Tomo programming language
Go to file
2024-03-10 00:17:45 -05:00
builtins Rearranging some files 2024-03-10 00:03:21 -05:00
docs Rename Str -> Text 2024-03-03 18:15:45 -05:00
test Add test for secret structs 2024-03-09 19:06:09 -05:00
.gitignore Rename 'nextlang'->'tomo' 2024-02-24 16:06:49 -05:00
ast.c Deprecate secret langs (just use one-member structs) 2024-03-09 19:02:13 -05:00
ast.h Rearranging some files 2024-03-10 00:03:21 -05:00
compile.c Rearranging some files 2024-03-10 00:03:21 -05:00
compile.h Rearranging some files 2024-03-10 00:03:21 -05:00
enums.c Rearranging some files 2024-03-10 00:03:21 -05:00
enums.h Improve enums with metamethods 2024-02-24 15:24:44 -05:00
environment.c Rearranging some files 2024-03-10 00:03:21 -05:00
environment.h Implement lambdas and closures 2024-03-09 16:03:38 -05:00
Makefile Rearranging some files 2024-03-10 00:03:21 -05:00
parse.c Rearranging some files 2024-03-10 00:03:21 -05:00
parse.h Rename sss_* to just * 2024-02-11 19:06:42 -05:00
README.md Updated README 2024-03-10 00:17:45 -05:00
structs.c Rearranging some files 2024-03-10 00:03:21 -05:00
structs.h Unused import 2024-03-09 14:47:40 -05:00
tomo.c Add ld flag to find library 2024-03-10 00:05:32 -05:00
typecheck.c Rearranging some files 2024-03-10 00:03:21 -05:00
typecheck.h Initial pass at namespacing 2024-03-03 13:04:50 -05:00
types.c Rearranging some files 2024-03-10 00:03:21 -05:00
types.h Remove references to libgccjit 2024-03-09 23:23:31 -05: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}!"
	return greeting:title()

>> greeting("world")
= "Hello World!"

Features

  • Extremely high performance code generation with minimal overhead compared to C
  • Extremely fast parallel compilation times
  • Memory safety (garbage collection, compiler-enforced null safety, automatic array bounds checking, and no uninitialized variables)
  • Arithmetic overflow checking
  • Simple, low-boilerplate type system with type inference
  • Useful and efficient built-in types: arrays, hash tables, structs, tagged unions (sum types), cords (efficient string representation)
  • Well-defined reference and value semantics and mutability rules
  • Language-level support for out-of-the-box function caching emphasizing correctness
  • Type-safe strings representing different languages with automatic prevention of code injection
  • Full UTF8 support for both source code and standard library
  • Pattern matching with exhaustiveness checking for tagged unions
  • Beautiful and helpful compiler and runtime error messages with emphasis on user-friendliness
  • Structs with known-at-compile-time methods, not OOP objects with vtable lookups
  • Built-in doctests with syntax highlighting
  • 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.

Both of which 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.

Running

You can run a Tomo program by running ./tomo program.tm. By default, this will use your environment's $CC variable to select which C compiler to use. If no C compiler is specified, it will default to tcc (Tiny C Compiler), which is exceptionally fast.

Installing

make && sudo make install