A unique loop-based programming language where everything runs in implicit loops with conditional execution.
main:
runs continuouslyos name():
- One Shot (run once when called)de name(n):
- Declarative (run exactly n times)fo name():
- Forever (run until stopped)when condition:
for reactive programming.start()
and .stop()
for managing executiondef
# Clone or download the WHEN interpreter
git clone https://github.com/PhialsBasement/WHEN-Language.git
cd WHEN-Language
# Run WHEN programs
python when.py program.when
# Install globally with pip
pip install -e .
pip install when-lang
# Now use the 'when' command
when program.when
# Copy when.bat to a directory in your PATH, or add the whenloop directory to PATH
when program.when
# Make the script executable and copy to PATH
chmod +x when
cp when /usr/local/bin/
# Or add the whenloop directory to your PATH
when program.when
when program.when # Run a WHEN program
when -i # Interactive mode (limited)
when --version # Show version
when --help # Show help
# hello.when
count = 0
os setup():
print("Starting up...")
fo counter():
count = count + 1
print("Count:", count)
when count >= 5:
break
main:
when count == 0:
setup()
counter.start()
when count >= 5:
print("Done!")
exit()
Run with: when hello.when
x = 10
name = "Alice"
active = 1
def add(a, b):
return a + b
result = add(5, 3)
import math
from time import sleep
from random import randint as rand_int
angle = math.sin(math.pi / 4)
sleep(1)
num = rand_int(1, 10)
# One-shot execution
os initialize():
print("Setting up...")
# Run exactly 5 times
de heartbeat(5):
print("Beat")
# Run forever until stopped
fo monitor():
check_status()
when error_detected():
break
main:
# Setup (runs once)
when not_started:
initialize()
heartbeat.start()
monitor.start()
not_started = 0
# Conditional logic
when heartbeat_complete():
monitor.stop()
exit()
All blocks run cooperatively in the main loop - no threading complexity.
Variables persist between loop iterations, enabling stateful reactive programming.
Start and stop execution blocks dynamically based on conditions.
Access the full Python ecosystem within WHEN programs.
See the included example programs:
- clock.when
- Simple clock implementation
- traffic_light.when
- Traffic light simulation
- restaurant_sim.when
- Complex restaurant management system
- tic_tac_toe.when
- Interactive game with AI
- python_modules_demo.when
- Python integration showcase
WHEN is a experimental language. Contributions welcome for:
- Language features
- Standard library
- Documentation
- Examples
- Performance improvements
Last modified 11 October 2025