Bootstrapping Forth on JVM, .NET CLR, etc.

forth

    Sponsored Links

    Next

  • 1. My the third forth, almost
    // Some notes of my meta language running on a little stack vm to build // a forth system (subroutine thread style) the third ! // has 23 opcodes: // // BAND BOR BXOR // PUSH POP R> >R // CALL RET QJMP // MOV COP // LESS ZEQU EQU // ADD SUB MUL SMOD // AT STORE // DATA PORT // // are enough to have a compiler and interpreter with blocks and colours // no forth dictionary implemented on system, the user choose what to // implement with editor (todo) // immediate is "macro" like in colorforth (not found interpreting, // found first during compile) // DATA opcode // ( n -- value ) DATA 8 // first number is vector size 0 5 0 9 2 3 4 6 ADD AT // this is like does> ( -- n ) RET It makes me happy
  • 2. FSL : error functions added to Library
    On Jan 14, 3:52m, Andrew Haley < XXXX@XXXXX.COM > wrote: > Charles G Montgomery < XXXX@XXXXX.COM > wrote: > > > Algorithm #62 of the Forth Scientific Library, filename erf.fs, Error > > functions, contributed by Krishna Myneni, > > <cough> > > > is the latest addition to the Library. > > Andrew. Ah, yes. That reminds me that we should acknowledge the reviewer who did a thorough and meticulous examination of this module. Since I'm not sure he wishes to be named, I will refrain from doing so. Everyone who was involved in the development of this module, and their respective contributions are, of course, acknowledged in the comments as they rightly should be (I don't think CGM was slighting anyone, just stating factually that I was the contributor of this module to the FSL, with permission from all authors): \ erf.fs .... \ compiled by Krishna Myneni from postings on comp.lang.forth by \ Andrew P. Haley, Charles G. Montgomery, and Marcel A. Hendrix \ Thread Root Message ID: <gPTPl. 42433$ XXXX@XXXXX.COM > Krishna

Bootstrapping Forth on JVM, .NET CLR, etc.

Postby joel reymont » Tue, 07 Aug 2007 14:38:01 GMT

Folks,

Suppose I wanted to bootstrap a Forth on a JVM, .NET CLR or another
existing VM.

Where would I start?

I'm learning Forth on a Mac (gForth) and don't want to use Windows.

My goal is to create a network link from my Mac to the target VM for
interactive development with cross-compilation and debugging happening
locally.

    Thanks, Joel


Re: Bootstrapping Forth on JVM, .NET CLR, etc.

Postby joel reymont » Tue, 07 Aug 2007 15:53:42 GMT

To be more precise... Suppose I started up gforth and I'm at the
interpreter prompt.

I want EXECUTE to generate the appropriate bytecode and run it on the
linked VM.

How do I make sure that EXECUTE is not the one that gforth supplies?

Do I hack at the gforth source code to build the cross-compiled Forth
and if so then is gforth the right Forth to start with?

I see no reason to re-implement the "outer interpreter" (right
expression?) and would like to let gforth parse my Forth code. I can't
envision how I would replace the code generation part, though.

    Thanks, Joel



Re: Bootstrapping Forth on JVM, .NET CLR, etc.

Postby Dmitry Ponyatov » Fri, 10 Aug 2007 03:01:27 GMT

You can use your own byte-code interpreter (a.k.a. inner interpreter =
engine = virtual machine) written in Java/C#, and cross-compiler
written in FORTH which generates byte-code from Forth-like language


Re: Bootstrapping Forth on JVM, .NET CLR, etc.

Postby Dmitry Ponyatov » Fri, 10 Aug 2007 03:04:52 GMT

at  http://www.**--****.com/ 
build upon this principle -- simple virtual forth machine in C with
some C++ elements and cross-compiler for SP-FORTH (I still now
understand vocabularies and use lower-cased words for FVM commands and
some non-standard language elements like { } var const buffer)


Similar Threads:

1.JVM vs CLR

2.Micro Focus COBOL runtime, /clr:pure, etc.

Pete raised this issue in another thread, and coincidentally I ran
smack up against it yesterday.

A .NET application compiled using the Micro Focus Net Express add-in
for Visual Studio will not run on a system which lacks the Micro Focus
COBOL runtime DLLs. I infer from the reference to accountants, that
the cost per seat to license the runtime is high. This rules out
redistribution on my part.

Interested developers could just download and install the same free
tools as I've already used to create my non-commercial project. I've
posted instructions on the Barbarian's CodePlex page, which explain
how to acquire and install these tools: Net Express 5.1 Personal
Edition, and the Visual Studio Shell which is its minimal requirement
for installation.

Granted, nobody should do this while on the clock. My application is a
toy.

Tell me, though, does the Micro Focus COBOL compiler have any command
line option similar to /crl:pure? This compiler option for Visual C++
2008 generates assemblies which run with nothing more than the .NET
runtime.

One last technical question. When working with other languages, the
command line arguments for the compiler are displayed in Visual
Studio's project properties. Does the Micro Focus add-in provide this
feature somewhere?

If I've violated the Net Express Personal Edition license agreement by
releasing a Micro Focus-dependent EXE to CodePlex, somebody please
tell me, so I can kill that project now.

Thanks.

 - Matt Fisher

3.a tutorial on bootstrapping forth?

For a while now I've been trying to find a good tutorial on implementing a
forth system from scratch.  I haven't found one yet so I decided to ask here
and see if anybody knows of one.

From my research I've learned about the inner/outer interpreters.  I've even
heard that some people have written extremely basic forth compilers in
assembly that support only a handful of words (e.g. get/set a byte, colon,
semicolon and a few others) and then they "cross-compile" forth code for
the two interpreters into full featured Forth system.

Does anybody know what the minimal set of words would be for the
"cross-compile" bootstrapping method?  Does anybody know of forth source for
an inner and outer interpeter combo?

Thanks,
Dave



4.Forth bootstrapping framework - Bootforth

5.Bootstrapping a Forth in 40 lines of Lua code

6. Cleaning up ANS Forth variables, values etc

7. Fw: Using Forth to send a windows message to a MS application (spell checking etc)

8. cat-v.org FORTH v GO plan9 etc



Return to forth

 

Who is online

Users browsing this forum: No registered users and 40 guest