| Deutsch English Français Italiano |
|
<2024Sep17.212539@mips.complang.tuwien.ac.at> View for Bookmarking (what is this?) Look up another Usenet article |
Path: ...!news.mixmin.net!eternal-september.org!feeder3.eternal-september.org!news.eternal-september.org!.POSTED!not-for-mail
From: anton@mips.complang.tuwien.ac.at (Anton Ertl)
Newsgroups: comp.lang.forth
Subject: Re: single-xt approach in the standard
Date: Tue, 17 Sep 2024 19:25:39 GMT
Organization: Institut fuer Computersprachen, Technische Universitaet Wien
Lines: 79
Message-ID: <2024Sep17.212539@mips.complang.tuwien.ac.at>
References: <vcbn5e$3etuk$1@dont-email.me> <vccka8$3l9rv$2@dont-email.me>
Injection-Date: Tue, 17 Sep 2024 21:36:05 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="b4109738b00b52fd655592671127ba97";
logging-data="3860854"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18rkyLz8VXCNEFatas8y+PX"
Cancel-Lock: sha1:b2s9a0dHIJZtXqM4fJzuKxbaT6M=
X-newsreader: xrn 10.11
Bytes: 4558
Anthony Howe <achowe@snert.com> writes:
>On 2024-09-17 06:54, Ruvim wrote:
>> Do you think that the Forth standard should recognize the classic single-xt
>> approach as possible for implementing a standard Forth system?
>>
>> The classic single-xt approach implies that only one execution token (xt) is
>> associated with a name token (nt), and only one name token is associated with a
>> word (a named Forth definition). And words whose compilation semantics differ
>> form default compilation semantics are implemented as immediate words.
>
>Given I prefer single-xt (currently), what I don't get is how for a dual-xt
>system you define a single word with two actions for interpret and compile.
If you want the interpretation and compilation semantics,
NAME>INTERPRET gives you the interpretation semantics of the word, and
NAME>COMPILE gives you the compilation semantics.
>I
>don't see a word to distinguish between the two, except maybe IMMEDIATE.
There is no standardized way to define words with arbitrary
combinations of interpretation and compilation semantics. I don't
consider this to be a problem. We would need such words only for
defining words like S", and we don't need additional words of this
kind.
If you want to see where going for full support for defining arbitrary
combinations leads, read our EuroForth 2019 paper [paysan&ertl19].
@InProceedings{paysan&ertl19,
author = {Bernd Paysan and M. Anton Ertl},
title = {The new {Gforth} Header},
crossref = {euroforth19},
pages = {5--20},
url = {http://www.euroforth.org/ef19/papers/paysan.pdf},
url-slides = {http://www.euroforth.org/ef19/papers/paysan-slides.pdf},
video = {https://wiki.forth-ev.de/doku.php/events:ef2019:header},
OPTnote = {refereed},
abstract = {The new Gforth header is designed to directly
implement the requirements of Forth-94 and
Forth-2012. Every header is an object with a fixed
set of fields (code, parameter, count, name, link)
and methods (\texttt{execute}, \texttt{compile,},
\texttt{(to)}, \texttt{defer@}, \texttt{does},
\texttt{name>interpret}, \texttt{name>compile},
\texttt{name>string}, \texttt{name>link}). The
implementation of each method can be changed
per-word (prototype-based object-oriented
programming). We demonstrate how to use these
features to implement optimization of constants,
\texttt{fvalue}, \texttt{defer}, \texttt{immediate},
\texttt{to} and other dual-semantics words, and
\texttt{synonym}.}
}
@Proceedings{euroforth19,
title = {35th EuroForth Conference},
booktitle = {35th EuroForth Conference},
year = {2019},
key = {EuroForth'19},
url = {http://www.euroforth.org/ef19/papers/proceedings.pdf}
}
>> : s" ( "ccc" -- sd | )
>> [char] " parse
>> state @ if postpone sliteral exit then
>> dup >r allocate throw tuck r@ move r>
>> ; immediate
This definition does not implement the standard word CORE S" or FILE
S" (maybe if he redefined NAME>INTERPRET and NAME>COMPILE, and
consequently POSTPONE, and ', but he doesn't do that).
- anton
--
M. Anton Ertl http://www.complang.tuwien.ac.at/anton/home.html
comp.lang.forth FAQs: http://www.complang.tuwien.ac.at/forth/faq/toc.html
New standard: https://forth-standard.org/
EuroForth 2024: https://euro.theforth.net