Skip to content

timfennis/andy-cpp

Repository files navigation

Andy C++

This is the source code for the Andy C++ programming language. Not meant for anything serious.

Example

Currently, the language has quite a lot of features allowing you to write some pretty neat programs.

Factorial

You can produce very large numbers quite quickly because we use the num crate under the hood.

let n, v = 10, 10;
while { n -= 1; n } > 0 {
    v *= n;
}
print(v);

Recursive factorial

fn factorial(n) {
    if n == 1 {
        return 1
    }

    n * factorial(n - 1)
}

print(factorial(100));

// You can call all functions as if they are methods on an object
print(100.factorial());

Overloading

The interpreter looks for a function using the types and the number of values.

fn add(n) { n + 1 }
fn add(a, b) { a + b }

print(add(add(5), add(4))); // prints 11
print(add(5).add(4.add())); // prints 11 as well

Use functions as augmented assignment operators

Many functions can be used to create augmented assignment operators.

let r = 0;

for i in 0..100 {
    // roughly translates to r = max(r, i * 8333446703 % 94608103)
    r max= i * 8333446703 % 94608103;
}

print(r);

Maps and Sets

Maps and sets are the same type and have their own special syntax

let map = %{"foo": "bar"};

let set = %{1,2,3,4};

Something like the defaultdict in python is natively supported using this syntax (stolen from Noulith)

let default_map = %{:1, 0: 10};
default_map[0] == 10
default_map[1] == 1 // default value

// supports augmented asignment
default_map[5] += 3; // puts 4 in the map

// pitfall: lists are copied by reference
let uhm = %{:[]};
uhm[0] ++= [1];

// true because the default value was changed in the line above
uhm[1] == [1]

List comprehensions

The language supports list comprehensions with the same semantics as Haskell but a syntax slightly more similar to python.

fn pythagorean_triples(n) {
    return [(a, b, c) for a in 1..=n,
                          b in a..=n,
                          c in b..=n,
                          if a ^ 2 + b ^ 2 == c ^ 2]
}

The same features are also available in regular for iterations

for a in 1..=25, b in a..=25, c in b..=25, if a ^ 2 + b ^ 2 == c ^ 2 {
    print(a, b, c);
}

Thanks

This language and implementation was inspired by Robert Nystrom's book Crafting Interpreters. I've also taken plagiaristic levels of inspiration from Noulith which is the language that inspired me to read the book in the first place.

About

Andy C++ programming language

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages