Skip to content

Latest commit

 

History

History
100 lines (66 loc) · 2.52 KB

README.md

File metadata and controls

100 lines (66 loc) · 2.52 KB

Bait programming language

CI Discord

Introduction

This repository contains the compiler, cli, standard library and documentation for Bait.

fun main() {
    println('hello world')
}

Key Features

Status: Active Development.
Bait is usable for personal projects, but please be aware of bugs and incomplete features.

  • Consistent syntax balancing simplicity for newcomers with power for experienced developers
  • Type and memory safety with immutability by default
  • Explicit and predictable error handling using Result types
  • JavaScript backend (NodeJS)
  • 🚧 C backend
  • Cross-platform support (Linux, 🚧 Windows)

Documentation

The Language Overview provides a brief introduction to the syntax and features.

More ressources, docs and examples will be released in the future.

Examples

Some basic example programs can be found in the examples directory.

For a much larger list of examples, check out the Rosetta Code solutions.

Installation

Right now Bait has to be compiled from source. Precompiled binaries will be available in the future.

Building from source

Required dependencies: git and NodeJS >= 18

Linux:

git clone https://github.com/bait-lang/bait
cd bait
./make.sh
sudo ./bait symlink

Windows:

git clone https://github.com/bait-lang/bait
cd bait
./make.bat

# In admin shell:
./bait.bat symlink

Now you should have Bait compiled to JS at <repo>/bait.js.

Thanks to the symlinked wrapper script, you can use the compiler with a simple command like bait run examples/hello_world.bt.

Upgrading to the latest version

To update Bait to the latest commit, run bait up.

Contributing

Your contributions are always welcome and highly appreciated! To get started, please take a look at CONTRIBUTING.md.

Community

For progress updates, discussions and support, join the official Discord server.

License

Bait is provided under the MIT License.