Embeddable scripting language loosely based off of Lua
Go to file
2023-05-28 21:13:51 -05:00
docs update Docs to reflect keyword changes 2023-02-10 20:46:05 -06:00
examples syntax: 'var'->'let' 'function'->'func' 2023-02-09 15:58:25 -06:00
src major main.c refactoring 2023-05-28 20:52:12 -05:00
.clang-format added clang-format 2023-02-09 12:32:48 -06:00
.gitignore Added CMake support 2021-02-11 20:34:04 -06:00
appveyor.yml whoops, need to update the command to run the testsuite 2023-05-28 21:13:51 -05:00
CMakeLists.txt Added AppVeyor CI 2021-03-16 14:54:52 -05:00
LICENSE.md Initial commit 2020-10-28 00:16:30 -05:00
main.c minor usage fix 2023-05-28 20:57:53 -05:00
Makefile major main.c refactoring 2023-05-28 20:52:12 -05:00
README.md update README.md 2023-05-28 21:11:52 -05:00

Cosmo

AppVeyor

Usage

Usage: ./bin/cosmo [-clsr] [args]

available options are:
-c <in> <out>   compile <in> and dump to <out>
-l <in>         load dump from <in>
-s <in...>      compile and run <in...> script(s)
-r              start the repl

What is a 'cosmo'?

Cosmo is a portable scripting language loosely based off of Lua. Cosmo easily allows the user to extend the language through the use of Proto objects, which describe the behavior of Objects. For example the following is a simple Vector Proto which describes behavior for a Vector-like object.

proto Vector
    func __init(self)
        self.vector = []
        self.x = 0
    end

    func __index(self, key)
        return self.vector[key]
    end

    func push(self, val)
        self.vector[self.x++] = val
    end 

    func pop(self)
        return self.vector[--self.x]
    end
end

let vector = Vector()

for (let i = 0; i < 4; i++) do
    vector:push(i)
end

for (let i = 0; i < 4; i++) do
    print(vector:pop() .. " : " .. vector[i])
end
3 : 0
2 : 1
1 : 2
0 : 3