lily

This repository has moved: https://gitlab.com/FascinatedBox/lily

Github星跟踪图

Linux: Linux Build

Windows: Windows Build

Test Coverage: codecov

Lily

Lily is a programming language focused on expressiveness and type safety.

Sample

scoped enum Color { Black, Blue, Cyan, Green, Magenta, Red, White, Yellow }

class Terminal(var @foreground: Color, width_str: String)
{
    public var @width = width_str.parse_i().unwrap_or(80)

    public define set_fg(new_color: Color) {
        @foreground = new_color
    }
}

var terms = [Terminal(Color.White, "A"), Terminal(Color.Red, "40")]

terms.each(, e, e.width += 20 ), > print

Features

Templating

By default, Lily runs in standalone mode where all content is code to
execute. But Lily can also be run in template mode. In template mode,
code is between <?lily ... ?> tags. When a file is imported, it's always
loaded in standalone mode, so that it doesn't accidentally send headers.
Files that are imported are also namespaced (no 'global namespace').

Embeddable

Lily may be a statically-typed language, but the reference implementation is an
interpreter. The interpreter as well as its API have been carefully designed
with sandboxing in mind. As a result, it's possible to have multiple
interpreters exist alongside each other.

Shorter edit cycle

Another benefit from having the reference implementation as an interpreter is a
shorter turn around time. The interpreter's parser is comparable in speed to
that of languages using an interpreter as their reference.

Building

You need a C compiler and CMake (3.0.0 +). There are no external dependencies.

To build Lily, execute the following in a terminal:

cmake .

make

Note: Windows users may need to add -G"Unix Makefiles" to the end of the cmake
invocation.

The above will build the lily executable, as well as a liblily that you can
use with your program. It also builds pre-commit-tests.

Running tests

The centerpiece of Lily's testing is test_main.lily in the test directory.
That file imports and invokes a large number of tests that cover a lot of Lily.

The make command also builds covlib and pre-commit-tests. No additional
commands are necessary. covlib is a library that tests some parts of Lily that
native code can't test. pre-commit-tests is a special runner that executes
test_main.lily.

To run Lily's tests, execute pre-commit-tests from the directory it's in after
building Lily.

Community

Lily is a very young language and the community is still growing.

  • Discord: Lily to chat with others in real-time.

  • IRC: freenode #lily is
    another way to chat with others.

  • Reddit: /r/lily for discussion around the
    language and providing support to new users.

Resources

License

MIT

主要指标

概览
名称与所有者FascinatedBox/lily
主编程语言C
编程语言C (语言数: 6)
平台
许可证MIT License
所有者活动
创建于2014-04-05 11:24:41
推送于2025-11-03 06:34:30
最后一次提交
发布数34
最新版本名称v2.2 (发布于 2025-10-11 01:00:00)
第一版名称v0.5 (发布于 )
用户参与
星数1.1k
关注者数30
派生数38
提交数3.5k
已启用问题?
问题数343
打开的问题数0
拉请求数31
打开的拉请求数1
关闭的拉请求数4
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?