PuqiAR 7ddf03d4c9
Some checks failed
Release Build / build-windows-x64 (push) Has been cancelled
Release Build / build-linux-x64 (push) Has been cancelled
v0.4.3-alpha
[Fix] 修复builtin type的方法可能会导致 bad_variant_access的问题。现在Function严格区分3中函数:
    Normal, Builtin, MemberType
[Feat] 增加了 Repl! 通过 Fig -r/--repl进入。目前必须写分号,且异常产生时因为获取不到源文件会有意想不到的问题 :(
[Impl] 精简了Context类,减少内存占用。当然,一些内置函数名获取不了了
        后续的 Fig lang standard (目前还没有)中内置函数(MemberType/Builtin)严格无异常抛出
[Feat] 写了个Simple Compiler 和 Bytecode VM作为测试。性能拉跨。优化目前停止
[...] 剩下的忘了~
2026-01-28 18:30:31 +08:00
2026-01-04 14:01:06 +08:00
2026-01-24 18:10:34 +08:00
2026-01-22 23:51:13 +08:00
2026-01-22 08:24:14 +08:00
2026-01-04 00:51:11 +08:00
2026-01-28 18:30:31 +08:00
2026-01-01 16:38:21 +08:00
2025-12-19 20:38:40 +08:00
2025-12-19 20:38:40 +08:00
2025-12-20 21:54:09 +08:00
2026-01-24 18:10:34 +08:00
2026-01-24 18:10:34 +08:00
2026-01-28 18:30:31 +08:00

Fig Language - A Modern Scripting Language

Fig-Gitea Recommend view on Gitea Endpoint

简体中文

Fig is a statically-typed, expression-oriented programming language designed for clarity, safety, and modern development practices. With features inspired by Go, Rust, and JavaScript, Fig aims to provide a productive development experience while maintaining strong type safety.

Features

🚀 Core Language Features

  • Static typing with type inference - Strong typing with minimal annotations
  • Modern control flow - Full for loop support with proper scoping
  • First-class functions - Lambda expressions and closures
  • Rich data structures - Structs, lists, maps, and tuples
  • Memory safety - No null pointer exceptions, automatic memory management

🔧 Technical Highlights

  • Three-level scoping for loops - Proper variable isolation in iterations
  • Smart semicolon handling - Flexible statement termination with RAII guards
  • Comprehensive error handling - Detailed error messages with source locations
  • Clean C++ implementation - Modern C++23 with RAII and smart pointers

🔧 Install

Installation

Prerequisites

Xmake version 3.0.0 or higher must be installed on your system.

Build Instructions

  1. Clone the repository:
git clone https://github.com/PuqiAR/Fig.git
  1. Navigate to the project directory:
cd Fig
  1. Build the project:
xmake build Fig
  1. Run the program:
xmake run Fig [file]

Replace [file] with the path to your input file.

Language Philosophy

Fig is designed around several core principles:

Clarity over cleverness - Code should be readable first

Safety by default - Prevent common errors at compile time

Modern ergonomics - Developer experience matters

Gradual learning - Simple to start, powerful when needed

Performance Summary

Version: 0.4.2-alpha (Tree-walker Interpreter)
Test Hardware: i5-13490F, Windows 11

Execution Times for Fibonacci(30):

  • Naive Recursion: 11.72s
  • Memoization: 0.93ms (12,600× faster)
  • Iteration: 0.37ms (31,300× faster)
  • Tail Recursion: 0.40ms (29,200× faster)

Visual Comparison:

Naive Recursion  : ████████████████████████████████████████ 11.72s
Memoization      : ▉ 0.93ms
Iteration        : ▍ 0.37ms
Tail Recursion   : ▎ 0.40ms

Key Insight: Algorithm choice dominates performance in this tree-walker implementation.

Detailed Reports: English | 中文

Language Documents

see ./docs/en_US/...

We're looking for translators to help translate our project and make it accessible to more language communities.

Description
The Fig Programming Language
Readme MIT 4.5 MiB
2026-02-04 19:21:52 +08:00
Languages
C++ 98.7%
Python 0.7%
Lua 0.2%
Dockerfile 0.2%