Language guide | Try now in browser | Install | Changelog
ShnooTalk is a programming language implemented in C++ using the LLVM compiler framework. ShnooTalk works by being compiled to a custom IR format and then translating that to LLVM IR. It is possible to run ShnooTalk on any runtime that supports the clang compiler. ShnooTalk links against standard C libraries/runtime.
See the tests directory for examples, try out the language in your browser on ShnooTalk Playground.
🛠️ Project under construction, some things may not be fully polished yet 🛠️
curl -sf -L https://raw.githubusercontent.com/RainingComputers/ShnooTalk/main/install.sh | sudo sh
curl -sf -L https://raw.githubusercontent.com/RainingComputers/ShnooTalk/main/install.sh | sh
Download app image from releases page
Download the source from latest release
./ci/Linux/build.sh llvmorg-12.0.1/clang+llvm-12.0.1-x86_64-linux-gnu-ubuntu-16.04.tar.xz
sudo make install
Download the source from latest release
brew install llvm@12
make build
sudo make install
Install the extension from here
Uninstallation is straightforward and easy
rm -f /usr/local/bin/shtkc
rm -f /usr/local/bin/shtkc-<version>
rm -rf /usr/local/lib/shnootalk-<version>
app.shtk
fn main() -> int
{
println("Hello world")
return 0
}
Compile and run
shtkc app.shtk -c
clang app.o -o app
./app
(You can also use gcc instead of clang)
These are end to end tests which can be used to test an implementation of ShnooTalk. The tests_runner
python application is used to run the tests.
This is meant to test the AST generated from the parser.
Test the output executable produced by the compiler and the generated ShnooTalk icode (not the entire IR just the generated function IR instructions only, see -icode-all
option).
This is meant to test the overall structure of the generated IR (i.e the parts that were not tested in compiler/tests/compiler/ tests).
Tests for the standard library
- When you discover a compiler bug
- When you add a new grammar or syntax
- If you make changes to existing syntax, you will most probably just have to fix failing tests
- When you make changes to the IR or the IR builder
- Avoid making changes to the pretty printer or modifying syntax of existing IR
instructions, but if you do, you may have to change a lot of test cases, re-generate the test cases,
and do careful review using
git diff
- If you made changes to the parser, add test to the parser/ directory
- If you have made changes to the icode (IR instructions) or added a new IR instruction, add test to the compiler/ directory
- If you have fixed a compiler bug, add a test to compiler/ directory
- If you have made changes to the IR but not icode (IR instructions), add test to the ir/ directory
- Create a .shtk files in appropriate test directory, add print statements for asserting
- After adding the test, run
make gen FILTERS='--file <test-file-name>'
- Check generated files
- Run
make test
to run all tests
- To run all tests, run
make test
ormake coverage
- To run a single file, run
make test FILTERS='--file <test-file-name>'
- To run only a group of tests, run
make test FILTERS='--group <group-name>'
- Run
make gen
to generate all test cases - Run
make gen FILTERS='--file <test-file-name>'
to generate for a particular test file - Carefully review the changes using
git diff
For more detailed status see github project or github issues