Trillium 1.4.0

dotnet add package Trillium --version 1.4.0                
NuGet\Install-Package Trillium -Version 1.4.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Trillium" Version="1.4.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Trillium --version 1.4.0                
#r "nuget: Trillium, 1.4.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Trillium as a Cake Addin
#addin nuget:?package=Trillium&version=1.4.0

// Install Trillium as a Cake Tool
#tool nuget:?package=Trillium&version=1.4.0                

Trillium

Generic badge Generic badge Generic badge

license GitHub Workflow Status issues Discord

GitHub commit activity GitHub last commit

GitHub Release Date

Trillium is the smart contract language that will be powering our smart contracts. This is a from scratch language that has roots from C#, C, and some Javascript.

Core Features (Statements, expressions, etc)

This language is turing complete and has many features. Below are most of the current implemented features:

  • Numbers (ints)
  • Strings ("Any")
  • Booleans (true, false)
  • Addition ('+')
  • Subtraction ('-')
  • Multiplication ('*')
  • Division ('/')
  • Basic Operator Tokens(&, !, ^, |, =, (, ), >, <, [, ], :, ',', &&, !=, ^=, ==, >=, ⇐, and more)
  • If Statements
  • Else Statements
  • Else If Statements
  • Returns
  • While Loops
  • For Loops
  • Do While Statements
  • Block Statements
  • Expressions
  • Variable Declaration
  • LiteralExpression,
  • Name Expression
  • Unary Expression
  • Binary Expression
  • Parenthesized Expression
  • Assignment Expression
  • Call Expression

Examples

The Languages purpose is to drive all self-executing NFT (SENs) functions.

Some examples are below:

function HelloPerson(name : string) : string
{
    var text = "Hello " + name
    return text
}
HelloPerson("Trillium")

outputs Hello Trillium

12 + 12 -> press enter

outputs 24

function WhoAmI(age : int, name : string)
{
    if name == "Trillium" && age == 99
    {
        print("Hi " + name)
    }
    else
    {
        print("Hello, sorry but we don't know you")
    }
}

outputs "Hi Trillium" if name = "Trillium" and age = 99 outputs "Hello, sorry but we don't know you" for everything else

You can define variables as such:

{
    var name : string = "Some Name" (or var name = "Some Name")
    var number : int  = 22 (or var number = 22)
    var truth : bool = true (or var truth = true)
}

Lets make a basic two number calculator where we pass in the operator as a string

function calculator(firstNum : int, secondNum : int, operator : string) : string
{
    var result = 0
    if operator == "+"
    {
        result = firstNum + secondNum
        return string(result)
    }
    else if operator == "-"
    {
        result = firstNum - secondNum
        return string(result)
    }
    else if operator == "*"
    {
        result = firstNum * secondNum
        return string(result)
    }
    else if operator == "/"
    {
        result = firstNum / secondNum
        return string(result)
    }
    else 
    {
        return "No known operator was given"
    }
}

calculator(2, 2, "+") 

output is 4

image image

Trillium is constantly growing and will evolve over time to support more functions and have more built in features to reduce code writing.

Things to do

  • Emit IL
  • Nullable types
  • Comments (May not do this to keep source code files smaller)

Setup

  • Install Visual Studio 2022 or latest version of Visual Code
  • .Net Core 6
  • Download the Trillium repo from GitHub
  • Open the Trillium.sln file in Visual Studio or open the src folder in VS Code

Testing

To write and test your own contracts first follow the setup instructions above. Next you will want to run the TrilliumI project. This will open the REPL in the CLI and allow you to being writing natively in Trillium and getting results. The REPL provides full diagnostics, so you will know exactly what is wrong within your statements of code.

Who do I talk to?

People to Thank and Sources

The language was modeled after the language courses from Microsoft's Immo Landwerth and adapted further to work within the ReserveBlocks core wallet infastructure.

Some other references to site are (please note none of these people worked on the project, but rather provided material to help make this. They are in no way affiliated with this project):

  • Clinton L. Jeffery and his Books
  • Jon Skeet and his C# In Depth books
  • Alex Williams and his debugging methodology
  • Immo Landwerth and his series

License

Trillium is released under the terms of the MIT license. See COPYING for more information or see https://opensource.org/licenses/MIT.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net6.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.