Skip to content

Latest commit

 

History

History
183 lines (144 loc) · 4.48 KB

README.md

File metadata and controls

183 lines (144 loc) · 4.48 KB

μScheme Interpreter

CodeFactor GitHub contributors GitHub commit activity GitHub repo size GitHub issues open GitHub issues closed

This is a small Scheme-subset interpreter written in Java with the ANTLR4 parsing library. Right now, it supports:

  • Arbitrarily Large Numbers & Complex Numbers
  • Primitive Operations
  • Pairs
  • Lists
  • Let/Let*/Letrec
  • Lambda Expressions (can be created with lambda or λ)
  • Procedures
  • Variadic Arguments
  • Closures with Lexical Scoping
  • Vectors
  • Symbols/Atoms
  • Quoted Expressions
  • Quasiquote Expressions
  • Random Number Generators
  • Format String Printing

Example μScheme Programs

  1. Defining a variable:
(define var 5)
  1. Defining a procedure:
(define (factorial n)
    (if (<= n 1) 1
        (* n (factorial (- n 1)))))
        
(factorial 6) 
>>> 720        
  1. Defining a lambda:
(define fib
    (λ (n)
       (if (<= n 2) 1
           (+ (fib (- n 1)) (fib (- n 2))))))

(fib 5)
>>> 5            
  1. Length of a list with cond:
(define length 
    (λ (l)
        (cond [(null? l) 0]
              [else (+ 1 (length (cdr l))))])))
  1. Iteration with do loop:
(define sum-from-iterative
    (λ (a b) 
        (do ((i a (+ i 1)) (total 0))
            ((> i b) total)
            (set! total (+ total i)))))

(sum-from-iterative 1 10)
>>> 55
(sum-from-iterative 1 100)
>>> 5050
(sum-from-iterative 55 10000)
>>> 50003515
c
>>> 4726979370
  1. Filter procedure:
(define (odd? x) (= 1 (remainder x 2)))
(define (filter predicate sequence)
    (cond [(null? sequence) '()]
          [(predicate (car sequence))
              (cons (car sequence)
              (filter predicate (cdr sequence)))]
          [else (filter predicate (cdr sequence))]))
    
(filter odd? (list 1 2 3 4 5))
>>> (1 3 5)
  1. Accumulate procedure (using passed lambda):
(define (accumulate op initial sequence)
  (if (null? sequence) initial
      (op (car sequence)
          (accumulate op initial (cdr sequence)))))
                              
(accumulate (λ (x y) (+ x y)) 0 (list 1 2 3 4 5))
>>> 15
  1. Format printing via printf:
(define val 3.1415+0.75i)
(define val2 78.55)
(define val3 65093)
(printf "The ~s of ~d and ~d is ~d." "sum" val val2 (+ val val2))
(printf "~d in hex is ~x, in binary is ~b, in octal is ~o." val3 val3 val3 val3)

>>> The sum of 3.1415+0.75i and 78.55 is 81.6915+0.75i.
    65073 in hex is fe45, in binary is 1111111001000101, in octal is 177105. 
  1. Variadic arguments:
(define length 
    (λ (l)
        (cond ((null? l) 0)
            (else (+ 1 (length (cdr l)))))))
(define (alt-length . args)
    (length args))
    
(alt-length 10 'apple 'orange 20 (+ 2 3 4 5) 'grapes)
>>> 6
  1. Closure with lexical scoping:
(define make-counter
    (lambda ()
       (let ((count 0))
          (lambda ()
             (set! count (+ count 1)) count))))

(define c1 (make-counter))
(define c2 (make-counter))
(define c3 (make-counter))
(c1)
(c1)
(c1)
(c2)
(c3)
(c2)
(c1)
(c3)
>>> (separated by new lines) 1 2 3 1 1 2 4 2

Planned Features

The following is a list of features that I'd like to include in the interpreter, but are not guaranteed.

  • Drawing capabilities (i.e., drawing shapes, images and other functionality)
  • Structs (user-defined objects)
  • File I/O
  • Call stack optimization

Dependencies

This project uses Maven, and was developed using IntelliJ. Though, it works with any IDE, so long as the ANTLR plugin is available.

Reporting Bugs

See the Issues Tab.

Version History

The master branch encompasses all changes. The development branches have in-progress additions and updates that are not yet ready for the master branch. There will most likely be other branches present in the future, each with the " development" prefix, and a suffix denoting its purpose with a hyphen (-).