Project

fam

0.0
No commit activity in last 3 years
No release in over 3 years
A very watered down language ment to look like an assembly language.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies
 Project Readme

FAM

A very Fake Assembly(-ish language) Machine, parser and interpreter.

Installation

gem install fam

Documentation

See this repository's DOC.md file.

Examples

Examples can be found in scarce supply, in the example folder in this repository.

Some examples:

    STORE 55 : @0
    DATA dyn : 0b01101  !! Dynamic memory allocation,
    LOAD -0xf : &DAT    !! finds available memory location.
    LOAD &DAT : &ACC

LOOP:
    ADD 1 : &ACC
    OUT &ACC
    STORE &ACC : dyn

    EQUAL &ACC : 30
        | GOTO END
        | GOTO LOOP

END: HALT 0
    GOTO INCR
    OUT &ACC
    HALT 0

INCR:
    ADD 1 : &ACC
    GOTO _BACK

{{  _BACK works by jumping to just after the last GOTO
    statement, or jumping to the last label that was passed
    without GOTOing to it.  }}

Usage

Current terminal usage is very simplistic. Simply, write fam and the file name ensuring the file name ends in .fam.

e.g.

fam some_file.fam

by default, the program is extremely verbose. To make any changes it is recommended you write a Ruby script to deal with it yourself.

e.g.

program = <<EOF
  IN  &DAT
  ADD 10 : &DAT
  OUT &DAT

  HALT 0
EOF

# PROGRAM STRING, ALLOC, CLOCK, VERBOSE?
# All except the `program string' are optional,
#   block is not required either.
FAM.run program, '200B', 6, true do |ram, pc, regs|
  puts "RAM:\n#{ram.to_a}"
  puts "REGISTERS:"
  regs.each { |name, value| puts "#{name} => #{value}" }

  puts "PROGRAM COUNTER: #{pc}"
end

in a more verbose manner:

require 'fam'

$VERBOSE = true
$CLOCK = $VERBOSE ? 20 : Float::INFINITY

file_names = ARGV.select { |file| file.include? '.fam'}
lexed = FAM::Syntax::Lexer.lex File.read file_names[-1]

parsed = FAM::Syntax::Parser.parse lexed.tokens
AST = parsed.ast

MEM = FAM::Machine::RAM.new '100B'  # Alloc 100 bytes
CPU = FAM::Machine::CPU.new MEM

CPU.run AST do |pc|
  # Do something every `clock-cycle'
  puts "Program counter: #{pc}"
end

A #step(syntax_tree) method is also available for the CPU class.

for auto-generated documentation, see: rubydoc.info/gems/fam/