@misterscan/sesi
v1.5.5
Published
Sesi: A Concise, Legible Programming Language
Maintainers
Readme
SESI IS NOT AN AI WRAPPER LANGUAGE. IT IS NOT AN AI-NATIVE PROGRAMMING LANGUAGE. IT IS A GENERAL-PURPOSE PROGRAMMING LANGUAGE WITH OPTIONAL AI CAPABILITIES BUILT-IN. STRONG EMPHASIS ON OPTIONAL.
✨ New: Sesi Studio IDE
We are excited to announce the release of Sesi Studio, a high-performance, browser-based IDE built specifically for Sesi developers. It combines the power of VS Code's editor with deep native integration for the Sesi toolchain.
- Pro Editor Features: Bracket pair colorization, document symbols, and go-to-definition.
- Integrated Terminal: Run Sesi scripts and manage your system directly from the IDE.
- Sesi Co-Pilot: Context-aware chat assistant that understands your codebase.
- Local Timeline: Never lose code with built-in edit history.
- Command Palette: Access all workspace operations, extension actions, zoom controls, and theme settings with a single keystroke (
Cmd/Ctrl+P). - Extension & Theme Packagers & Installers: Pack CSS themes into portable
.sesithemebundles and JS extensions into.sesiextbundles. Validate, distribute, and install themes/extensions dynamically via the Settings Hub or Command Palette.
To launch Sesi Studio, you can:
- Open Sesi Studio.app (macOS)
- Run
./SesiStudio.commandfrom the root directory - Use the CLI:
sesi -s(after installing Sesi)
Installation
You can install Sesi in three ways:
1. Global Installation via npm (Recommended)
If you have Node.js installed, download Sesi directly from the npm registry:
npm install -g sesi2. Standalone Executables
Don't want to install Node.js? Download the standalone executables bundled for Windows, Mac, and Linux directly from our Downloads page. Drop the executable in your system PATH and you're good to go!
For macOS users, Sesi also supports a native PKG installer flow when building from source:
npm run build:exe
npm run build:mac:pkgThis generates installer packages in releases/ (for available architectures) that install sesi to /usr/local/bin.
3. Build from Source (For contributors)
git clone https://github.com/Misterscan/Sesi.git
cd Sesi
npm install
npm run build
npm install -g . # Unlock the `sesi` command locallyQuick Start
You'll need a Gemini API Key for the reasoning features. Create a .env file referencing your key where you run your scripts:
GEMINI_API_KEY="AIzaSy..."Then run any program directly:
# Standard script execution
sesi examples/main/01_hello.sesi
# Run script with arguments
sesi main/tests/test_args.sesi arg1 arg2
# Reasoning script example
sesi examples/optional/08_model_call.sesi
# Run all examples
sesi examples.sesiUseful CLI shortcuts:
# Evaluate a quick snippet
sesi -e "print 'hello'"# Ask the built-in co-pilot a question
sesi -h "how do I use memory?"# Ask for help about a specific file
sesi examples/main/01_hello.sesi -h "what is this script doing?"# Encrypt or decrypt a script file manually
sesi -enc my_script.sesi -p "my-password"
sesi -dec my_script.sesi -p "my-password"To avoid exposing passwords in your shell's history, you can set the SESI_PASSWORD environment variable in your .env file (or your system's shell environment).
export SESI_PASSWORD="my-password"
# Encrypt or decrypt automatically using SESI_PASSWORD environment variable
sesi -enc my_script.sesi
sesi -dec my_script.sesi# Run with sandbox restrictions disabled
sesi examples/main/01_hello.sesi -lLocal Execution (Development)
If you are developing inside the repository or haven't installed sesi globally, use the npm scripts:
# Run a Sesi script
npm run sesi -- examples/main/01_hello.sesi# Evaluate an inline snippet
npm run sesi:eval "print 'Sesi running!'"# Ask Sesi's Co-Pilot
npm run sesi:help "how to make a directory?"# Encrypt / Decrypt scripts (uses SESI_PASSWORD from your .env automatically)
npm run sesi:encrypt "secret.sesi"
npm run sesi:decrypt "secret.sesi"# Sesi Studio Theme Packager
npm run studio:css:pack <css-file-path> [output-dir]
npm run studio:css:unpack <sesitheme-file-path> [output-dir]
npm run studio:css:validate <css-file-path># Sesi Studio Extension Packager
npm run studio:ext:pack <js-file-path> [output-dir]
npm run studio:ext:unpack <sesiext-file-path> [output-dir]
npm run studio:ext:validate <js-file-path># Run classic examples
npm run example examples/main/01_hello.sesi
npm run example:ai examples/optional/08_model_call.sesi
npm run example:allLanguage Overview
Sesi is designed for developers who want to:
- Write normal code (variables, functions, loops, etc.)
- Call Reasoning directly within code using
promptandmodelblocks - Get structured outputs from Reasoning with type guarantees
- Build Reasoning agents with memory and multi-step reasoning
- Maintain full control and transparency
Example
// Basic computation
let x = 10
let y = 20
let result = x + y
print result // 30
// Reasoning-powered code generation
prompt generateCode {"Write a TypeScript function that reverses a string"}
let code = model("gemini-3.1-pro-preview") {generateCode}
print codeSecurity & Sandboxing
Sesi incorporates a safe-by-default, zero-trust sandboxing engine.
🛡️ Core Security Features
Safe-by-Default Execution:
- Sesi's sandbox is enabled by default. Any standard Sesi interpreter execution blocks system command lines (
exec,spawn) and locks down imports and paths. - Overriding Safety: Developers can explicitly bypass safe mode programmatically by initializing the interpreter with options, or on the command line by setting
SESI_SAFE_MODE=false.
- Sesi's sandbox is enabled by default. Any standard Sesi interpreter execution blocks system command lines (
Absolute Prototype Pollution Immunity:
- Sesi uses prototype-free objects (
Object.create(null)) for all object literals, JSON parses (from_jsonorstd/json), and structured model responses inside the interpreter. - Because these objects do not inherit from standard JavaScript prototypes and possess no
__proto__or prototype chain, prototype pollution is physically and architecturally impossible.
- Sesi uses prototype-free objects (
Strict Path Whitelisting:
- Sesi validates all filesystem and subprocess paths against a strict directory whitelist (by default, only the Current Working Directory and the Script's base directory are allowed).
- Any path traversal resolving outside the whitelist is instantly rejected with a
Security Violationexception.
Automated LLM Tool Call Sanitization:
- Even if safe mode is explicitly turned off for developer automation, Sesi strictly blocks automated tool execution of sensitive commands (like
execandspawn) when requested dynamically by the model viatool_call. This completely isolates the host from prompt-injection RCE.
- Even if safe mode is explicitly turned off for developer automation, Sesi strictly blocks automated tool execution of sensitive commands (like
Deep isolation & Map Cloning:
- Sub-interpreters loaded via concurrent workflows (
multi_req) are fully isolated. Sesi deep-clones prompts and memories, preventing concurrent agent tasks from leaking state or polluting each other.
- Sub-interpreters loaded via concurrent workflows (
⚙️ Programmatic Embedding Configurations
When embedding Sesi inside a host application, you can statically configure safety settings directly in code:
const interpreter = new Interpreter(scriptDir, {
safeMode: true, // Enable full sandbox limits (on by default)
allowLocalFs: false, // Block directory escapes (on by default)
allowedPaths: ["/var/tmp/sandbox"], // Custom strict whitelist directories
});Documentation
- Getting Started
- Examples
- Tutorial: Writing Scripts
- CLI Reference
- Language Specification
- Language Comparison Showcase
- Built-in Functions
- Reasoning
- Runtime Architecture
Agent Context
The root-level SKILLS.md file is a workspace context file for AI agents.
Project Structure
Sesi/
├── SKILLS.md # Workspace context and repo guardrails
├── eslint.config.mjs # ESLint configuration
├── example.js # Helper script to run basic examples
├── example-ai.js # Helper script to run reasoning examples
├── examples.sesi # Central execution suite for examples
├── README.md # Project overview
├── QUICKSTART.md # Getting started guide
├── package.json # Dependencies & scripts
├── tsconfig.json # TypeScript configuration
├── dist/ # Compiled TypeScript output
│
├── src/ # Source code
│ ├── types.ts # Type definitions & AST nodes (400+ lines)
│ ├── lexer.ts # Tokenization (350+ lines)
│ ├── parser.ts # Recursive descent parser (700+ lines)
│ ├── interpreter.ts # Tree-walking interpreter (600+ lines)
│ ├── builtins.ts # Built-in functions (250+ lines)
│ ├── ai-runtime.ts # Integrated reasoning integration (120+ lines)
│ └── index.ts # Entry point (30+ lines)
│
├── bin/
│ └── sesi.js # CLI executable
│
├── main/ # Playgrounds & debugging
│ └── tests/ # Additional syntax validation scripts
│
├── docs/
│ ├── CLI.md # Comprehensive CLI & Parametric Eval guide
│ ├── SPECIFICATION.md # Complete language spec (600+ lines)
│ ├── ARCHITECTURE.md # Runtime & system design (400+ lines)
│ ├── BUILTINS.md # Built-in functions reference (450+ lines)
│ ├── COMPARISON.md # Language comparison showcase
│ ├── IMAGE_GENERATION.md # Image generation guide (>100 lines)
│ ├── REASONING.md # Reasoning and simple logic guide (>500 lines)
│ └── ROADMAP.md # V2-V4+ development plan (400+ lines)
│
│
├── examples/
│ ├── 01_hello.sesi # Hello World
│ ├── 02_variables.sesi # Variables & operations
│ ├── 03_functions.sesi # Functions with parameters
│ ├── 04_conditionals.sesi # If/else control flow
│ ├── 05_loops.sesi # While, for, for-in loops
│ ├── 06_arrays_objects.sesi # Collections
│ ├── 07_prompts.sesi # Reasoning blocks
│ ├── 08_model_call.sesi # Basic reasoning calls
│ ├── 09_structured_output.sesi # Type-safe reasoning responses
│ ├── 10_code_generation.sesi # Systems logic generation
│ ├── 11_memory_conversation.sesi # Multi-turn stateful reasoning
│ ├── 12_classification.sesi # Systems classification loop
│ ├── 13_data_pipeline.sesi # Complete systems pipeline
│ ├── 14_folder_explainer.sesi # Directory parsing & reasoning
│ ├── 15_image_generation.sesi # Image generation API test
│ ├── 16_modules.sesi # Modules & std library namespaces
│ ├── 17_http_client.sesi # Network GET/POST client
│ ├── 18_parallel_requests.sesi # Parallel requests concurrency
│ ├── 19_search_web.sesi # Web search integration
│ ├── 20_model_aliases.sesi # Custom model naming aliases
│ ├── 21_custom_tools.sesi # Custom runtime tool definitions
│ ├── 22_reasoning_plus_custom_tools.sesi # Reasoning composed with custom tools
│ ├── 23_file_conversion.sesi # File and document format conversions
│ ├── 24_http_server.sesi # Non-blocking native HTTP server
│ ├── 25_webpage_server.sesi # Native web page hosting
│ ├── 26_database.sesi # Embedded document database operations
│ └── 27_robust_web_db.sesi # Dynamic database-backed web analytics
│
└── tests/ # Engine test suite
├── basic.test.ts # Core parsing & evaluation tests
├── cache.test.ts # Execution caching tests
├── http.test.ts # Web request builtins testing
├── module.test.ts # Imports & module loading tests
├── parallel.test.ts # Concurrent execution tests
├── security.test.ts # Sandbox & guardrail tests
├── test-gemini.ts # Base model integration test
├── test-gemini2.ts # Extended model integration test
└── workflow.test.ts # Complex sequence workflows testsVersion 1.5 Features (In Progress)
Core Language ✅
- Variables & Bindings:
letfor all bindings (const is deprecated). - Functions: Side-effect driven functions with typed parameters.
- Control Flow:
if/else,while,for, andtry/catch. - Collections: Robust Arrays and Objects.
- Error Handling: Structured
try/catchfor both runtime and Reasoning-level errors. - Local Module Imports/Exports: Import custom local
.sesimodules cleanly using relative import/export syntax! - Standard Library Modules: Native support for imported standard libraries, including:
std/math(providingPI,E,sqrt,pow,sin,cos, etc.)std/time(providingsleepandnow)std/json(providing JSON serialization/deserialization)
Reasoning-Native Features ✅
model()calls with Reasoning provider configurationimage()calls with specific ratio/size generation capabilities- Async Polling: Native looping to auto-resume generation when hitting
MAX_TOKENSlimit
System Features ✅
- Memory: Basic memory for multi-turn reasoning
- Filesystem I/O:
read_file(),write_file(),to_json(),write_image(),list_dir(), andconvert()for local file I/O and format transformations - Native Concurrency:
spawn()andexec()for concurrent process management, andmulti_req(array<function>)for physical parallel request execution. - Logic Caching: High-efficiency Sesi Logic Caching (
.sesi_cache.json) for local call caching. - HTTP Client: Built-in, native HTTP client support using
web_get(url)andweb_send(url, body, headers)with zero external dependencies. - Utility Builtins:
time()andrandom()for robust coordination - Structured Output:
structured_output()for typed JSON Schema - Function Calling:
tool_call()for function calling - Prompt Blocks:
promptblocks for cleaner and more concise script composition
Type System
- Static types:
number,string,bool,array<T>,object<T> - Type inference
- Union types for Reasoning response handling
Roadmap
V2: Advanced Reasoning
- Long-term memory and context management
- Custom tool definitions
- Streaming responses
V3: Agents & Orchestration
- Agent definitions with state
- Tool composition and chaining
- Multi-agent collaboration
- Persistent knowledge bases
License
MIT
