💾 Archived View for bbs.geminispace.org › u › karel › 5335 captured on 2024-05-10 at 12:50:31. Gemini links have been rewritten to link to archived content

View Raw

More Information

⬅️ Previous capture (2024-03-21)

➡️ Next capture (2024-06-16)

🚧 View Differences

-=-=-=-=-=-=-

Comment by 🦋 karel

Re: "Loading files in nForth: implementation"

In: s/FORTH

@stack: I faced a similar problem in a pet project of mine. My decision is to drop it and let the "user" (that's me) use the C preprocessor in order to gather all the code into one file. As an alternative he (me) can supply multiple code files at the command line. Disadvantage: impossible to output correct file_name:line_number error messages with CPP #includes. Advantage: separation of concerns, old-skool Unix-style. What do you think about this solution?

🦋 karel

2023-09-15 · 8 months ago

1 Later Comment

🚀 stack [OP/mod] · 2023-09-15 at 12:12:

@karel, that is fine if it works for you, and I could've had the assembler append other forth files (it alread appends 'nforth.f'). But it turned out to be dead simple:

: included; \ (fname,cnt--)
  drop zero dup rot osopen
  pop drop \ do not return to brace
  loadh 
;

And in the process I got the sync/abort logic working.

So I do append one file, nforth.f, which normally defines included; and uses it to bootstrap itself by loading nf.f. But the user can stuff anything into nforth.f, say for a single file CGI script.

Original Post

🌒 s/FORTH

Loading files in nForth: implementation — Having implemented the normally-compile semantics I discussed in the previous post, I must now tackle the `include` functionality to load more forth code from a file. The problem: since nForth is now a compterpreter (it compiles code and runs/erases it to simulate interpretation), we must compile and run the loading code and the filename into the dictionary to execute the load. If we blindly load on top, the pseudo-interpretive block of code that does...

💬 stack [mod] · 2 comments · 2023-09-14 · 8 months ago