--- gforth/kernel/Attic/special.fs 1997/06/06 17:28:16 1.2 +++ gforth/kernel/Attic/special.fs 1999/05/05 18:10:30 1.10 @@ -1,6 +1,6 @@ \ words with non-default and non-immediate compilation semantics -\ Copyright (C) 1996 Free Software Foundation, Inc. +\ Copyright (C) 1996,1998 Free Software Foundation, Inc. \ This file is part of Gforth. @@ -21,12 +21,21 @@ \ this file comes last, because these words override cross' words. create s"-buffer /line chars allot -:noname [char] " parse - /line min >r s"-buffer r@ cmove - s"-buffer r> ; -:noname [char] " parse postpone SLiteral ; +has? compiler 0= +[IF] : s" [ELSE] :noname [THEN] + [char] " parse + /line min >r s"-buffer r@ cmove + s"-buffer r> ; +has? compiler [IF] +:noname [char] " parse postpone SLiteral ; interpret/compile: S" ( compilation 'ccc"' -- ; run-time -- c-addr u ) \ core,file s-quote + \G Compilation: Parse a string ccc delimited by a " (double quote). At run-time, + \G return the length, u, and the start address, c-addr of the string. Interpretation: + \G parse the string as before, and return c-addr, u. The string is stored in a + \G temporary buffer which may be overwritten by subsequent uses of @code{S"}. +[THEN] +has? compiler [IF] : [IS] ( compilation "name" -- ; run-time xt -- ) \ possibly-gforth bracket-is ' >body postpone ALiteral postpone ! ; immediate restrict @@ -41,6 +50,11 @@ interpret/compile: What's ( "name" -- ad :noname [char] " parse type ; :noname postpone (.") ," align ; interpret/compile: ." ( compilation 'ccc"' -- ; run-time -- ) \ core dot-quote + \G Compilation: Parse a string ccc delimited by a " (double quote). At run-time, + \G display the string. Interpretation semantics for this word are undefined in + \G the ANS Forth Standard. Gforth's interpretation semantics are to display the + \G string. This is the simplest way to display a string from + \G within a definition; see examples below. \ DOES> 17mar93py @@ -48,11 +62,22 @@ interpret/compile: ." ( compilation 'ccc dodoes, here !does ] defstart :-hook ; :noname - ;-hook postpone (does>) ?struc dodoes, + ;-hook ?struc + [ has? xconds [IF] ] exit-like [ [THEN] ] + postpone (does>) dodoes, defstart :-hook ; interpret/compile: DOES> ( compilation colon-sys1 -- colon-sys2 ; run-time nest-sys -- ) \ core does ' IS Alias TO ( addr "name" -- ) \ core-ext immediate +[THEN] + +has? compiler [IF] +: interpret/compile? ( xt -- flag ) + >does-code ['] S" >does-code = ; +[ELSE] +: interpret/compile? + false ; +[THEN]