From 75304a0c82859c61011945ebe53e97a79210a8a6 Mon Sep 17 00:00:00 2001 From: psf Date: Sat, 26 Mar 2022 21:11:55 -0700 Subject: [PATCH] get rid of special words understood by outer interpreter --- frustration.rs | 59 ++++++++++++++++++++++---------------------------- 1 file changed, 26 insertions(+), 33 deletions(-) diff --git a/frustration.rs b/frustration.rs index 0f4a766..dd36c20 100644 --- a/frustration.rs +++ b/frustration.rs @@ -1,6 +1,5 @@ -use std::cmp; use std::io; -use std::process; +//use std::process; use std::convert::TryInto; //const CORE_SIZE: usize = 65408 @@ -40,7 +39,6 @@ fn truncate_name(name: &str) -> ShortName { let n = std::cmp::min(3, out.length) as usize; out.bytes[0..n].copy_from_slice(&name_bytes[0..n]); return out; - } struct TableEntry { @@ -49,11 +47,12 @@ struct TableEntry { immediate: bool } -const PRIMITIVES: [TableEntry; 13] = [ +const PRIMITIVES: [TableEntry; 14] = [ TableEntry {f: ret , name: None, immediate: false}, TableEntry {f: lit , name: None, immediate: false}, TableEntry {f: call , name: Some(ShortName {bytes: *b"cal", length: 4}), immediate: false}, TableEntry {f: dot , name: Some(ShortName {bytes: *b". ", length: 1}), immediate: false}, + TableEntry {f: dump , name: Some(ShortName {bytes: *b"dum", length: 4}), immediate: false}, TableEntry {f: comma_ , name: Some(ShortName {bytes: *b", ", length: 1}), immediate: false}, TableEntry {f: store , name: Some(ShortName {bytes: *b"! ", length: 1}), immediate: false}, TableEntry {f: load , name: Some(ShortName {bytes: *b"@ ", length: 1}), immediate: false}, @@ -181,9 +180,6 @@ fn call(c: &mut Core) { // note: this is an inline primitive, not a dict entry fn ret(c: &mut Core) { - if c.trs == 0 { - - } c.ip = from_r(c); } @@ -228,6 +224,10 @@ fn dot(c: &mut Core) { print!("{} ", pop(c)); } +fn dump(c: &mut Core) { + println!("{:?}", c); +} + // note: this is an inline primitive, not a dict entry fn lit(c: &mut Core) { let ip = c.ip as usize; @@ -273,35 +273,28 @@ fn outer(c: &mut Core, s: &str) { let ss = s.trim(); let tokens = ss.split(" "); for t in tokens { - match t { - "dmp" => { - println!("{:?}", c); - }, - _ => { - match find(c, truncate_name(t)) { - Some(addr) => { - if c.state == State::Interpreting || is_immediate(c, addr) { - c.ip = addr; - inner(c); - } else { - comma(c, addr); - } - } - None => { - let val = t.parse::(); - match val { - Ok(n) => { - match c.state { - State::Interpreting => { push(c, n) } - State::Compiling => { - comma(c, 65534); // lit - comma(c, n); - } - } + match find(c, truncate_name(t)) { + Some(addr) => { + if c.state == State::Interpreting || is_immediate(c, addr) { + c.ip = addr; + inner(c); + } else { + comma(c, addr); + } + } + None => { + let val = t.parse::(); + match val { + Ok(n) => { + match c.state { + State::Interpreting => { push(c, n) } + State::Compiling => { + comma(c, 65534); // lit + comma(c, n); } - Err(_) => { if t != "" { println!("{}?", t) }} } } + Err(_) => { if t != "" { println!("{}?", t) }} } } }