/[cvs]/stack/stack.h
ViewVC logotype

Contents of /stack/stack.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.10 - (show annotations)
Sun Mar 10 20:08:47 2002 UTC (22 years, 2 months ago) by masse
Branch: MAIN
Changes since 1.9: +20 -12 lines
File MIME type: text/plain
Modified internal data structure to use cons cells instead of simple linked
lists. There is now a new value type "tcons".

1 /*
2 stack - an interactive interpreter for a stack-based language
3 Copyright (C) 2002 Mats Alritzson and Teddy Hogeborn
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18
19 Authors: Mats Alritzson <masse@fukt.bth.se>
20 Teddy Hogeborn <teddy@fukt.bth.se>
21 */
22
23 #define HASHTBLSIZE 2048
24
25 /* First, define some types. */
26
27 struct cons_struct;
28
29 /* A value of some type */
30 typedef struct {
31 enum {
32 integer,
33 tfloat,
34 string,
35 func, /* Function pointer */
36 symb,
37 tcons
38 } type:4; /* Type of stack element */
39
40 union {
41 struct {
42 unsigned int mark:1;
43 unsigned int protect:1;
44 } flag;
45 unsigned int no_gc:2;
46 } gc;
47
48 union {
49 struct cons_struct *c;
50 void *ptr; /* Pointer to the content */
51 int i; /* ...or an integer */
52 float f;
53 } content; /* Stores a pointer or an integer */
54
55 } value;
56
57 /* An item (value) on a stack */
58 typedef struct stackitem_struct
59 {
60 value *item; /* The value on the stack */
61 /* (This is never NULL) */
62 struct stackitem_struct *next; /* Next item */
63 } stackitem;
64
65 typedef struct cons_struct {
66 value *car;
67 value *cdr;
68 } cons;
69
70 /* A symbol with a name and possible value */
71 /* (These do not need reference counters, they are kept unique by
72 hashing.) */
73 typedef struct symbol_struct {
74 char *id; /* Symbol name */
75 value *val; /* The value (if any) bound to it */
76 struct symbol_struct *next; /* In case of hashing conflicts, a */
77 } symbol; /* symbol is a kind of stack item. */
78
79 /* A type for a hash table for symbols */
80 typedef symbol *hashtbl[HASHTBLSIZE]; /* Hash table declaration */
81
82 /* An environment; gives access to the stack and a hash table of
83 defined symbols */
84 typedef struct {
85 stackitem *gc_ref;
86 int gc_limit, gc_count;
87
88 cons *head; /* Head of the stack */
89 hashtbl symbols; /* Hash table of all variable bindings */
90 int err; /* Error flag */
91 char *in_string; /* Input pending to be read */
92 char *free_string; /* Free this string when all input is
93 read from in_string */
94 FILE *inputstream; /* stdin or a file, most likely */
95 int interactive; /* print prompts, stack, etc */
96 } environment;
97
98 /* A type for pointers to external functions */
99 typedef void (*funcp)(environment*); /* funcp is a pointer to a void
100 function (environment *) */
101
102 void init_env(environment*);
103 void printerr(const char*);
104 extern void toss(environment*);
105 symbol **hash(hashtbl, const char*);
106 value* new_val(environment*);
107 void gc_mark(value*);
108 void gc_maybe(environment *env);
109 extern void gc_init(environment*);
110 void push_val(environment*, value*);
111 void push_int(environment*, int);
112 void push_float(environment*, float);
113 void push_cstring(environment*, const char*);
114 char *mangle_str(const char*);
115 extern void mangle(environment*);
116 void push_sym(environment*, const char*);
117 extern void nl();
118 extern void type(environment*);
119 void print_h(cons*, int);
120 extern void print_(environment*);
121 extern void print(environment*);
122 extern void princ_(environment*);
123 extern void princ(environment*);
124 void print_st(cons*, long);
125 extern void printstack(environment*);
126 extern void swap(environment*);
127 extern void rot(environment*);
128 extern void rcl(environment*);
129 extern void eval(environment*);
130 extern void rev(environment*);
131 extern void pack(environment*);
132 extern void expand(environment*);
133 extern void eq(environment*);
134 extern void not(environment*);
135 extern void neq(environment*);
136 extern void def(environment*);
137 extern void quit(environment*);
138 extern void clear(environment*);
139 extern void words(environment*);
140 void forget_sym(symbol**);
141 extern void forget(environment*);
142 extern void errn(environment*);
143 extern void sx_2b(environment*);
144 extern void sx_2d(environment*);
145 extern void sx_3e(environment*);
146 value *copy_val(environment*, value*);
147 extern void sx_647570(environment*);
148 extern void sx_6966(environment*);
149 extern void ifelse(environment*);
150 extern void sx_7768696c65(environment*);
151 extern void sx_666f72(environment*);
152 extern void to(environment*);
153 extern void readline(environment*);
154 extern void sx_72656164(environment*);
155 extern void foreach(environment*);
156 void protect(value*);
157 void unprotect(value*);
158 extern void copying(environment*);
159 extern void warranty(environment*);
160 extern void sx_2a(environment*);
161 extern void sx_2f(environment*);
162 extern void mod(environment*);
163 extern void sx_3c(environment*);
164 extern void sx_3c3d(environment*);
165 extern void sx_3e3d(environment*);
166 extern void sx_646976(environment*);

root@recompile.se
ViewVC Help
Powered by ViewVC 1.1.26