Some checks failed
Lint & Format / detect (push) Failing after 36s
Monorepo Lint / lint-shell (push) Failing after 40s
Monorepo Lint / lint-js (push) Failing after 40s
Lint & Format / js-lint (push) Has been skipped
Lint & Format / py-lint (push) Has been skipped
Lint & Format / sh-lint (push) Has been skipped
Lint & Format / go-lint (push) Has been skipped
RoadChain-SHA2048: 59e0f844fc760998 RoadChain-Identity: alexa@sovereign RoadChain-Full: 59e0f844fc760998d8a3ce5f7d219f21bf7a4b82472c28ebe3e1258438b6770dac3c13ca3f8a43275319408ec7847d36f0031322f7608066c4f8bdd225b2b127eb1c1f3d773ea645b9569eaf9d430766951c0613bf350f2db285cc35fccead7e4a9608b46fd8e057561a25705cf4cc5aaf9abedc4cce547df8008777c4af3b2f2578c2a0eb47489f660eb108414dd7f8d3ada3e2d4062e50cc1d29099f5fa3490e6e44a7216ed37cd761bc507e3d855558935931f27c19981f26c1d2d2c91a9b1b227e3ee7650ab885eaa69aabb856110557d98346a0807bacb36142c0b7fd1510158fdd5d9756f9f2e2d7f1d5d2b0ee8b1277025f8d9a9cafd9cfb536abf568
RoadC
A programming language with Python-style indentation, built from scratch. Two implementations: a tree-walking interpreter in Python, and a zero-dependency C99 compiler.
What Works Today
The Python interpreter supports:
- Variables:
let,var,constwith optional type annotations - Functions:
funkeyword, parameters,return, recursion, closures - Control flow:
if/elif/else,while,for/in,break,continue - Types: integers, floats, strings (with
{var}interpolation), booleans, colors (#FF1D6C) - Collections: lists, dicts, sets, tuples, ranges
- Operators: arithmetic, comparison, logical, bitwise, compound assignment
- Builtins:
print,len,range,str,int,abs,min,max,sorted,input, and more - Member access: string/list/dict methods (
.upper(),.append(),.keys())
fun fibonacci(n):
if n <= 1:
return n
return fibonacci(n - 1) + fibonacci(n - 2)
let result = fibonacci(10)
print(result) # 55
let name = "world"
let msg = "hello {name}"
print(msg) # hello world
let xs = [1, 2, 3, 4, 5]
let total = 0
for x in xs:
total += x
print(total) # 15
Architecture
source.road
|
v
Lexer (lexer.py, 462 LOC)
| Tokens: keywords, literals, operators, INDENT/DEDENT
v
Parser (parser.py, 826 LOC)
| AST nodes defined in ast_nodes.py (462 LOC)
v
Interpreter (interpreter.py, 320 LOC)
Tree-walking execution with Environment chain
The C compiler (roadc.c, 618 LOC) is a separate implementation that compiles .road files to native executables. Zero external dependencies — just a C99 compiler.
gcc -std=c99 -O2 -o roadc roadc.c
./roadc program.road
Development
# Run a .road file
python roadc.py examples/fibonacci.road
# Run tests (30+ tests)
pytest tests/ -v
# Build C compiler
gcc -std=c99 -O2 -o roadc roadc.c
# Start REPL
python roadc.py
Roadmap
- Type checker (static analysis pass between parser and interpreter)
- Bytecode VM (replace tree-walking for performance)
- Standard library (file I/O, math, networking)
- 3D scene graph (
space,cube,spherekeywords — lexer ready, runtime not yet) - Package manager
- Self-hosting compiler
License
Proprietary — BlackRoad OS, Inc.
Related Projects
| Project | Description |
|---|---|
| RoadC Playground | Interactive browser IDE for RoadC |
| Universal Computer | Turing machine simulator |
| Quantum Math Lab | Mathematical computation toolkit |