longforth:start

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
longforth:start [2024/07/28 06:58] gedbadminlongforth:start [2024/08/26 16:37] (current) – [My Approach] gedbadmin
Line 1: Line 1:
-====== A Persistent Version of Forth ======+====== LongForth - A Persistent Version of Forth ======
  
 For me, personally, the best way to start learning about the design of persistent virtual machines is to create a working persistent implementation of the [[wp>Forth_(programming_language)|Forth Programming Language]]. For me, personally, the best way to start learning about the design of persistent virtual machines is to create a working persistent implementation of the [[wp>Forth_(programming_language)|Forth Programming Language]].
Line 23: Line 23:
 Rather than working from a specification, I will be using NibbleForth as my model of Forth.  I've chosen NibbleForth because it implements a fully functioning, minimalistic, version of Forth using Python code that is easy to read and understand. Rather than working from a specification, I will be using NibbleForth as my model of Forth.  I've chosen NibbleForth because it implements a fully functioning, minimalistic, version of Forth using Python code that is easy to read and understand.
  
-I have chosen NibbleForth over more compact implementations such as [https://hackaday.com/2023/11/06/tiny-forth-could-be-the-smallest/|Tiny Forth] because of this simplicity and clarity of implementation.+I have chosen NibbleForth over more compact implementations such as [[https://hackaday.com/2023/11/06/tiny-forth-could-be-the-smallest/|Tiny Forth]] because of this simplicity and clarity of implementation.
  
-NibbleForth was written by [[https://github.com/benhoyt|Ben Hoyt]] as an experiment on compact code.  The source can be found in his GitHub account: [[https://github.com/benhoyt/nibbleforth]].+NibbleForth was written by [[https://github.com/benhoyt|Ben Hoyt]] as an experiment on compact code.  The source can be found in his GitHub account: https://github.com/benhoyt/nibbleforth.
  
 One limitation to NibbleForth is that it does not support Progressive Word Definitions.  It just maintains a dictionary of word definitions as text rather than compiling to execution tokens.  I will need to fix this. One limitation to NibbleForth is that it does not support Progressive Word Definitions.  It just maintains a dictionary of word definitions as text rather than compiling to execution tokens.  I will need to fix this.
Line 31: Line 31:
 ====== My Approach ====== ====== My Approach ======
  
-I don'have much spare time to spend on this project, so I need to break the whole think up into neat little chunks.  I expect this to keep my busy until at least the end of 2025.+I don'st have much spare time to spend on this project, so I need to break the whole think up into neat little chunks.  I expect this to keep my busy until at least the end of 2025.
  
-  - Python Console Implementation +The goal is to move as quickly as possible to a SQL driven VM with an debugger API that can be accessed through a web application. 
-    - Extract the core primitives from NibbleForth into my own console driven implementation that will allow me to run Forth code but not define word. + 
-    - Add the compiler and words required for writing structured code to the point where I can run Forth code at the command line. +  - Simple Execution 
-    - Update the implementation to support progressive word definitions. +    - [[>Step 1a - Execution - Python script and tests|Python script and tests]] 
-    - Build up full test suite of forth code that can be automatically executed+    - [[>Step 1b Execution - SQL + PHP version with tests|SQL + PHP version with tests]] 
-  - Python SQL Implementation +    - [[>Step 1c - Execution - HTMLX based debugger|HTMLX based debugger]] 
-    - Redefine core words to execute, using SQLite, against database tables instead of Python lists and dictionaries. +  - Compilation 
-    - Update the test suite to execute across multiple Python instances access the same database file to ensure that my implementation is persistent. +    - [[>Step 2a - Compilation - Python script and tests|Python script and tests]] 
-  Minimal Web Front End +    [[>Step 2b - Compilation - SQL + PHP version with tests|SQL + PHP version with tests]] 
-    - Write a simple web front end that will allow me to develop and test LongForth in my browser. +    - [[>Step 2c - Compilation - HTMLX based debugger|HTMLX based debugger]]
-  - PHP and MySql Port +
-    - Port LongForth to PHP and MySql, ensuring that the effort to Port and maintain multiple implementations is kept simple and straightforward. +
-  Interactive Web Front End  +
-    - Extend the Web Front End to provide the ability to interact with the VM state, stepping through code and viewing the changes to internal state.+
  
  
  • longforth/start.1722164334.txt.gz
  • Last modified: 2024/07/28 06:58
  • by gedbadmin