Diff for /gforth/Attic/forth.h between versions 1.15 and 1.27

version 1.15, 1995/10/07 17:38:13 version 1.27, 1996/12/28 17:19:24
Line 1 Line 1
 /*  /* common header file
   Copyright 1992 by the ANSI figForth Development Group  
     Copyright (C) 1995 Free Software Foundation, Inc.
   
     This file is part of Gforth.
   
     Gforth is free software; you can redistribute it and/or
     modify it under the terms of the GNU General Public License
     as published by the Free Software Foundation; either version 2
     of the License, or (at your option) any later version.
   
     This program is distributed in the hope that it will be useful,
     but WITHOUT ANY WARRANTY; without even the implied warranty of
     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     GNU General Public License for more details.
   
     You should have received a copy of the GNU General Public License
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */  */
   
 /* common header file */  #include "config.h"
   #include <limits.h>
   #if defined(NeXT)
   #  include <libc.h>
   #endif /* NeXT */
   
 typedef void *Label;  typedef void *Label;
   
Line 13  typedef void *Label; Line 34  typedef void *Label;
 #define DOVAR   2  #define DOVAR   2
 #define DOUSER  3  #define DOUSER  3
 #define DODEFER 4  #define DODEFER 4
 #define DOSTRUC 5  #define DOFIELD 5
 #define DODOES  6  #define DODOES  6
 #define DOESJUMP        7  #define DOESJUMP        7
   
 #include "machine.h"  #include "machine.h"
   
 /* Forth data types */  /* Forth data types */
 typedef int Bool;  /* Cell and UCell must be the same size as a pointer */
   typedef CELL_TYPE Cell;
   typedef unsigned CELL_TYPE UCell;
   #define CELL_BITS       (sizeof(Cell) * CHAR_BIT)
   typedef Cell Bool;
 #define FLAG(b) (-(b))  #define FLAG(b) (-(b))
 #define FILEIO(error)   (FLAG(error) & -37)  #define FILEIO(error)   (FLAG(error) & -37)
 #define FILEEXIST(error)        (FLAG(error) & -38)  #define FILEEXIST(error)        (FLAG(error) & -38)
Line 32  typedef unsigned char Char; Line 57  typedef unsigned char Char;
 typedef double Float;  typedef double Float;
 typedef char *Address;  typedef char *Address;
   
   #ifdef BUGGY_LONG_LONG
   typedef struct {
     Cell hi;
     UCell lo;
   } DCell;
   
   typedef struct {
     UCell hi;
     UCell lo;
   } UDCell;
   
   #define FETCH_DCELL(d,lo,hi)    ((d)=(typeof(d)){(hi),(lo)})
   #define STORE_DCELL(d,low,high) ({ \
                                        typeof(d) _d = (d); \
                                        (low) = _d.lo; \
                                        (high)= _d.hi; \
                                    })
   
   #define LONG2UD(l)      ({UDCell _ud; _ud.hi=0; _ud.lo=(Cell)(l); _ud;})
   #define UD2LONG(ud)     ((long)(ud.lo))
   #define DZERO           ((DCell){0,0})
   
   #else /* ! defined(BUGGY_LONG_LONG) */
   
   /* DCell and UDCell must be twice as large as Cell */
   typedef DOUBLE_CELL_TYPE DCell;
   typedef unsigned DOUBLE_CELL_TYPE UDCell;
   
   typedef union {
     struct {
   #ifdef WORDS_BIGENDIAN
       Cell high;
       UCell low;
   #else
       UCell low;
       Cell high;
   #endif;
     } cells;
     DCell dcell;
   } Double_Store;
   
   #define FETCH_DCELL(d,lo,hi)    ({ \
                                        Double_Store _d; \
                                        _d.cells.low = (lo); \
                                        _d.cells.high = (hi); \
                                        (d) = _d.dcell; \
                                    })
   
   #define STORE_DCELL(d,lo,hi)    ({ \
                                        Double_Store _d; \
                                        _d.dcell = (d); \
                                        (lo) = _d.cells.low; \
                                        (hi) = _d.cells.high; \
                                    })
   
   #define LONG2UD(l)      ((UDCell)(l))
   #define UD2LONG(ud)     ((long)(ud))
   #define DZERO           ((DCell)0)
   
   #endif /* ! defined(BUGGY_LONG_LONG) */
   
 #ifdef DIRECT_THREADED  #ifdef DIRECT_THREADED
 typedef Label Xt;  typedef Label Xt;
 #else  #else
 typedef Label *Xt;  typedef Label *Xt;
 #endif  #endif
   
 Label *engine(Xt *ip, Cell *sp, Cell *rp, Float *fp, Address lp);  
   
 #ifndef DIRECT_THREADED  #ifndef DIRECT_THREADED
 /* i.e. indirect threaded */  /* i.e. indirect threaded */
 /* the direct threaded version is machine dependent and resides in machine.h */  /* the direct threaded version is machine dependent and resides in machine.h */
Line 50  Label *engine(Xt *ip, Cell *sp, Cell *rp Line 134  Label *engine(Xt *ip, Cell *sp, Cell *rp
 #define PFA1(cfa)       PFA(cfa)  #define PFA1(cfa)       PFA(cfa)
 /* CODE_ADDRESS is the address of the code jumped to through the code field */  /* CODE_ADDRESS is the address of the code jumped to through the code field */
 #define CODE_ADDRESS(cfa)       (*(Label *)(cfa))  #define CODE_ADDRESS(cfa)       (*(Label *)(cfa))
       /* DOES_CODE is the Forth code does jumps to */  /* DOES_CODE is the Forth code does jumps to */
 #define DOES_CODE(cfa)           (cfa[1])  #define DOES_CODE(cfa)  ({Xt _cfa=(Xt)(cfa); \
 #define DOES_CODE1(cfa)          DOES_CODE(cfa)                            _cfa[0] == symbols[DODOES] ? _cfa[1] : NULL;})
   #define DOES_CODE1(cfa) (cfa[1])
 /* MAKE_CF creates an appropriate code field at the cfa;  /* MAKE_CF creates an appropriate code field at the cfa;
    ca is the code address */     ca is the code address */
 #define MAKE_CF(cfa,ca) ((*(Label *)(cfa)) = ((Label)ca))  #define MAKE_CF(cfa,ca) ((*(Label *)(cfa)) = ((Label)ca))
Line 62  Label *engine(Xt *ip, Cell *sp, Cell *rp Line 147  Label *engine(Xt *ip, Cell *sp, Cell *rp
 /* the does handler resides between DOES> and the following Forth code */  /* the does handler resides between DOES> and the following Forth code */
 #define DOES_HANDLER_SIZE       (2*sizeof(Cell))  #define DOES_HANDLER_SIZE       (2*sizeof(Cell))
 #define MAKE_DOES_HANDLER(addr) 0 /* do nothing */  #define MAKE_DOES_HANDLER(addr) 0 /* do nothing */
 #endif  #endif /* !defined(DIRECT_THREADED) */
   
 #ifdef DEBUG  #ifdef DEBUG
 #       define  NAME(string)    fprintf(stderr,"%08x: "string"\n",(Cell)ip);  #       define  NAME(string)    fprintf(stderr,"%08lx: "string"\n",(Cell)ip);
 #else  #else
 #       define  NAME(string)  #       define  NAME(string)
 #endif  #endif
Line 75  Label *engine(Xt *ip, Cell *sp, Cell *rp Line 160  Label *engine(Xt *ip, Cell *sp, Cell *rp
 #define CF_NIL  -1  #define CF_NIL  -1
   
 #ifndef FLUSH_ICACHE  #ifndef FLUSH_ICACHE
 #       define FLUSH_ICACHE(addr,size) 0  #warning flush-icache probably will not work (see manual)
   #       define FLUSH_ICACHE(addr,size)
 #endif  #endif
   
 #ifdef DIRECT_THREADED  #ifdef DIRECT_THREADED
 #define CACHE_FLUSH(addr,size) FLUSH_ICACHE(addr,size)  #define CACHE_FLUSH(addr,size) FLUSH_ICACHE(addr,size)
 #else  #else
 #define CACHE_FLUSH(addr,size) 0  #define CACHE_FLUSH(addr,size)
 #endif  #endif
   
   #ifdef USE_TOS
   #define IF_TOS(x) x
   #else
   #define IF_TOS(x)
   #define TOS (sp[0])
   #endif
   
   #ifdef USE_FTOS
   #define IF_FTOS(x) x
   #else
   #define IF_FTOS(x)
   #define FTOS (fp[0])
   #endif
   
   Label *engine(Xt *ip, Cell *sp, Cell *rp, Float *fp, Address lp);
   
   /* dblsub routines */
   DCell dnegate(DCell d1);
   UDCell ummul (UCell a, UCell b);
   DCell mmul (Cell a, Cell b);
   UDCell umdiv (UDCell u, UCell v);
   DCell smdiv (DCell num, Cell denom);
   DCell fmdiv (DCell num, Cell denom);
   
   int memcasecmp(const char *s1, const char *s2, long n);
   

Removed from v.1.15  
changed lines
  Added in v.1.27


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>