dsIIr4/bin/
dsIIr4/extra/creremote/
dsIIr4/extra/wolfpaw/
dsIIr4/lib/cmds/admins/
dsIIr4/lib/cmds/common/
dsIIr4/lib/cmds/creators/include/
dsIIr4/lib/cmds/creators/include/SCCS/
dsIIr4/lib/daemon/services/
dsIIr4/lib/doc/
dsIIr4/lib/domains/Ylsrim/
dsIIr4/lib/domains/Ylsrim/adm/
dsIIr4/lib/domains/Ylsrim/armor/
dsIIr4/lib/domains/Ylsrim/broken/
dsIIr4/lib/domains/Ylsrim/fish/
dsIIr4/lib/domains/Ylsrim/meal/
dsIIr4/lib/domains/Ylsrim/npc/
dsIIr4/lib/domains/Ylsrim/virtual/
dsIIr4/lib/domains/Ylsrim/weapon/
dsIIr4/lib/domains/campus/adm/
dsIIr4/lib/domains/campus/etc/
dsIIr4/lib/domains/campus/meals/
dsIIr4/lib/domains/campus/npc/
dsIIr4/lib/domains/campus/save/
dsIIr4/lib/domains/campus/txt/
dsIIr4/lib/domains/campus/txt/ai/charles/
dsIIr4/lib/domains/campus/txt/ai/charles/bak2/
dsIIr4/lib/domains/campus/txt/ai/charles/bak2/bak1/
dsIIr4/lib/domains/campus/txt/ai/charly/
dsIIr4/lib/domains/campus/txt/ai/charly/bak/
dsIIr4/lib/domains/campus/txt/jenny/
dsIIr4/lib/domains/default/creator/
dsIIr4/lib/domains/default/doors/
dsIIr4/lib/domains/default/etc/
dsIIr4/lib/domains/default/virtual/
dsIIr4/lib/domains/default/weap/
dsIIr4/lib/domains/town/virtual/
dsIIr4/lib/lib/comp/
dsIIr4/lib/lib/lvs/
dsIIr4/lib/lib/user/
dsIIr4/lib/lib/virtual/
dsIIr4/lib/log/
dsIIr4/lib/obj/book_source/
dsIIr4/lib/obj/include/
dsIIr4/lib/realms/template/
dsIIr4/lib/realms/template/adm/
dsIIr4/lib/realms/template/area/armor/
dsIIr4/lib/realms/template/area/npc/
dsIIr4/lib/realms/template/area/obj/
dsIIr4/lib/realms/template/area/room/
dsIIr4/lib/realms/template/area/weap/
dsIIr4/lib/realms/template/bak/
dsIIr4/lib/realms/template/cmds/
dsIIr4/lib/save/
dsIIr4/lib/save/kills/o/
dsIIr4/lib/secure/cfg/classes/
dsIIr4/lib/secure/cmds/creators/include/
dsIIr4/lib/secure/cmds/players/
dsIIr4/lib/secure/cmds/players/include/
dsIIr4/lib/secure/daemon/include/
dsIIr4/lib/secure/lib/
dsIIr4/lib/secure/lib/include/
dsIIr4/lib/secure/lib/net/include/
dsIIr4/lib/secure/lib/std/
dsIIr4/lib/secure/modules/
dsIIr4/lib/secure/npc/
dsIIr4/lib/secure/obj/include/
dsIIr4/lib/secure/room/
dsIIr4/lib/secure/save/
dsIIr4/lib/secure/save/boards/
dsIIr4/lib/secure/save/players/g/
dsIIr4/lib/secure/tmp/
dsIIr4/lib/secure/verbs/creators/
dsIIr4/lib/shadows/
dsIIr4/lib/spells/
dsIIr4/lib/std/board/
dsIIr4/lib/std/lib/
dsIIr4/lib/tmp/
dsIIr4/lib/verbs/admins/include/
dsIIr4/lib/verbs/common/
dsIIr4/lib/verbs/common/include/
dsIIr4/lib/verbs/creators/include/
dsIIr4/lib/verbs/players/include/SCCS/
dsIIr4/lib/verbs/rooms/
dsIIr4/lib/verbs/rooms/include/
dsIIr4/lib/www/
dsIIr4/v22.2b14-dsouls2/
dsIIr4/v22.2b14-dsouls2/ChangeLog.old/
dsIIr4/v22.2b14-dsouls2/Win32/
dsIIr4/v22.2b14-dsouls2/compat/
dsIIr4/v22.2b14-dsouls2/compat/simuls/
dsIIr4/v22.2b14-dsouls2/include/
dsIIr4/v22.2b14-dsouls2/mudlib/
dsIIr4/v22.2b14-dsouls2/testsuite/
dsIIr4/v22.2b14-dsouls2/testsuite/clone/
dsIIr4/v22.2b14-dsouls2/testsuite/command/
dsIIr4/v22.2b14-dsouls2/testsuite/data/
dsIIr4/v22.2b14-dsouls2/testsuite/etc/
dsIIr4/v22.2b14-dsouls2/testsuite/include/
dsIIr4/v22.2b14-dsouls2/testsuite/inherit/
dsIIr4/v22.2b14-dsouls2/testsuite/inherit/master/
dsIIr4/v22.2b14-dsouls2/testsuite/log/
dsIIr4/v22.2b14-dsouls2/testsuite/single/
dsIIr4/v22.2b14-dsouls2/testsuite/single/tests/compiler/
dsIIr4/v22.2b14-dsouls2/testsuite/single/tests/efuns/
dsIIr4/v22.2b14-dsouls2/testsuite/single/tests/operators/
dsIIr4/v22.2b14-dsouls2/testsuite/u/
dsIIr4/v22.2b14-dsouls2/tmp/
dsIIr4/win32/
/*
 * Defines and types for the compiler parse trees.
 */

#ifndef _TREES_H
#define _TREES_H

#define NODES_PER_BLOCK         256

enum node_type {
    NODE_RETURN, NODE_TWO_VALUES, NODE_OPCODE, NODE_OPCODE_1, NODE_OPCODE_2,
    NODE_UNARY_OP, NODE_UNARY_OP_1, NODE_BINARY_OP, NODE_BINARY_OP_1,
    NODE_TERNARY_OP, NODE_TERNARY_OP_1, NODE_CONTROL_JUMP, NODE_LOOP,
    NODE_CALL, NODE_CALL_1, NODE_CALL_2, NODE_LAND_LOR, NODE_FOREACH,
    NODE_LVALUE_EFUN, NODE_SWITCH_RANGES, NODE_SWITCH_STRINGS, 
    NODE_SWITCH_DIRECT, NODE_SWITCH_NUMBERS, NODE_CASE_NUMBER,
    NODE_CASE_STRING, NODE_DEFAULT, NODE_IF, NODE_BRANCH_LINK, NODE_PARAMETER,
    NODE_PARAMETER_LVALUE, NODE_EFUN, NODE_ANON_FUNC, NODE_REAL, NODE_NUMBER,
    NODE_STRING, NODE_FUNCTION_CONSTRUCTOR, NODE_CATCH, NODE_TIME_EXPRESSION,
    NODE_FUNCTION
};

enum control_jump_type {
    CJ_BREAK_SWITCH = 2, CJ_BREAK = 0, CJ_CONTINUE = 1
};

union parse_value {
    int number;
    float real;
    struct parse_node_s *expr;
};

typedef struct parse_node_s {
    short kind;
    short line;
    unsigned char type;
    union parse_value v, l, r; /* left, right, and value */
} parse_node_t;

typedef struct parse_node_block_s {
    struct parse_node_block_s *next;
    parse_node_t nodes[NODES_PER_BLOCK];
} parse_node_block_t;

#define IS_NODE(vn, nt, op) ((vn)->kind == nt && (vn)->v.number == op)

#define CREATE_TERNARY_OP(vn, op, t, x, y, z) SAFE(\
					 (vn) = new_node();\
					 (vn)->kind = NODE_TERNARY_OP;\
					 INT_CREATE_TERNARY_OP(vn, op, t,\
							       x, y, z);\
						   )
#define INT_CREATE_TERNARY_OP(vn, op, t, x, y, z) SAFE(\
						       (vn)->l.expr = (x);\
						       (vn)->type = t;\
						       CREATE_BINARY_OP((vn)->r.expr, op, t, y, z);\
						       )
#define CREATE_BINARY_OP(vn, op, t, x, y) SAFE(\
					       (vn) = new_node();\
					       (vn)->kind = NODE_BINARY_OP;\
					       INT_CREATE_BINARY_OP(vn, op,\
								    t, x, y);\
					       )
#define INT_CREATE_BINARY_OP(vn, op, t, x, y) SAFE(\
						   INT_CREATE_UNARY_OP(vn, op,\
								       t, y);\
						   (vn)->l.expr = x;\
						   )
#define CREATE_UNARY_OP(vn, op, t, x) SAFE(\
					   (vn) = new_node();\
					   (vn)->kind = NODE_UNARY_OP;\
					   INT_CREATE_UNARY_OP(vn, op, t, x);\
					   )
#define INT_CREATE_UNARY_OP(vn, op, t, x) SAFE(\
					       INT_CREATE_OPCODE(vn, op, t);\
					       (vn)->r.expr = x;\
					       )
#define CREATE_OPCODE(vn, op, t) SAFE(\
				      (vn) = new_node();\
				      (vn)->kind = NODE_OPCODE;\
				      INT_CREATE_OPCODE(vn, op, t);\
				      )
#define INT_CREATE_OPCODE(vn, op, t) SAFE(\
					  (vn)->v.number = op;\
					  (vn)->type = t;\
					  )

#define CREATE_OPCODE_1(vn, op, t, p) SAFE(\
					   (vn) = new_node();\
					   (vn)->kind = NODE_OPCODE_1;\
					   INT_CREATE_OPCODE(vn, op, t);\
					   (vn)->l.number = p;\
					   )
#define CREATE_OPCODE_2(vn, op, t, p1, p2) SAFE(\
						(vn) = new_node();\
						(vn)->kind = NODE_OPCODE_2;\
						INT_CREATE_OPCODE(vn, op, t);\
						(vn)->l.number = p1;\
						(vn)->r.number = p2;\
						)
#define CREATE_UNARY_OP_1(vn, op, t, x, p) SAFE(\
						(vn) = new_node();\
						(vn)->kind = NODE_UNARY_OP_1;\
						INT_CREATE_UNARY_OP(vn,\
								    op, t, x);\
						(vn)->l.number = p;\
						)
#define CREATE_BINARY_OP_1(vn, op, t, x, y, p) SAFE(\
					    (vn) = new_node();\
					    (vn)->kind = NODE_BINARY_OP_1;\
					    INT_CREATE_BINARY_OP(vn, op,\
								 t, x, y);\
					    (vn)->type = p;\
						    )
#define CREATE_TERNARY_OP_1(vn, op, t, x, y, z, p) SAFE(\
					     (vn) = new_node();\
					     (vn)->kind = NODE_TERNARY_OP_1;\
					     INT_CREATE_TERNARY_OP(vn, op, t,\
								   x, y, z);\
					     (vn)->r.expr->type = p;\
					     )
#define CREATE_RETURN(vn, val) SAFE(\
				    (vn) = new_node_no_line();\
				    (vn)->kind = NODE_RETURN;\
				    (vn)->r.expr = val;\
				    )
#define CREATE_LAND_LOR(vn, op, x, y) SAFE(\
					   (vn) = new_node();\
					   (vn)->kind = NODE_LAND_LOR;\
					   (vn)->v.number = op;\
					   (vn)->l.expr = x;\
					   (vn)->r.expr = y;\
					   (vn)->type = ((x->type == y->type)\
							 ? x->type : TYPE_ANY);\
					   )
#define CREATE_CALL(vn, op, t, el) SAFE(\
					(vn) = el;\
					(vn)->kind = NODE_CALL;\
					(vn)->l.number = (vn)->v.number;\
					(vn)->v.number = op;\
					(vn)->type = t;\
					)
#define CREATE_STATEMENTS(vn, ln, rn) SAFE(\
					   (vn) = new_node_no_line();\
					   (vn)->kind = NODE_TWO_VALUES;\
					   (vn)->l.expr = ln;\
					   (vn)->r.expr = rn;\
					   )
#define CREATE_TWO_VALUES(vn, t, ln, rn) SAFE(\
					      CREATE_STATEMENTS(vn, ln, rn);\
					      (vn)->type = t;\
					      )
#define CREATE_CONTROL_JUMP(vn, op) SAFE(\
					 (vn) = new_node_no_line();\
					 (vn)->kind = NODE_CONTROL_JUMP;\
					 (vn)->v.number = op;\
					 )
#define CREATE_PARAMETER(vn, t, p) SAFE(\
					(vn) = new_node_no_line();\
					(vn)->kind = NODE_PARAMETER;\
					(vn)->type = t;\
					(vn)->v.number = p;\
					)
#define CREATE_IF(vn, c, s, e) SAFE(\
				    (vn) = new_node_no_line();\
				    (vn)->kind = NODE_IF;\
				    (vn)->v.expr = c;\
				    (vn)->l.expr = s;\
				    (vn)->r.expr = (e);\
				    )

#define CREATE_IGNORE(vn, c,s,e) SAFE(\
                                      (vn) = new_node_no_line();\
				      (vn)->kind = NODE_IGNORE;\
				      (vn)->v.expr = c;\
				      (vn)->l.expr = s;\
				      (vn)->r.expr = (e);\
				      )

#define CREATE_LOOP(vn, tf, b, i, t) SAFE(\
					  (vn) = new_node_no_line();\
					  (vn)->kind = NODE_LOOP;\
					  (vn)->type = tf;\
					  (vn)->v.expr = b;\
					  (vn)->l.expr = i;\
					  (vn)->r.expr = t;\
				      )
#define CREATE_LVALUE_EFUN(vn, t, lvl) SAFE(\
					    (vn) = new_node();\
					    (vn)->kind = NODE_LVALUE_EFUN;\
					    (vn)->r.expr = lvl;\
					    (vn)->type = t;\
					    )
#define CREATE_FOREACH(vn, ln, rn) SAFE(\
					(vn) = new_node();\
					(vn)->kind = NODE_FOREACH;\
					(vn)->l.expr = ln;\
					(vn)->r.expr = rn;\
					)
#define CREATE_ERROR(vn) SAFE(\
			      (vn) = new_node_no_line();\
			      (vn)->kind = NODE_NUMBER;\
			      (vn)->type = TYPE_ANY;\
			      )
#define CREATE_REAL(vn, val) SAFE(\
				  (vn) = new_node_no_line();\
				  (vn)->kind = NODE_REAL;\
				  (vn)->type = TYPE_REAL;\
				  (vn)->v.real = val;\
				  )
#define CREATE_NUMBER(vn, val) SAFE(\
				    (vn) = new_node_no_line();\
				    (vn)->kind = NODE_NUMBER;\
				    (vn)->type = (val ? TYPE_NUMBER : TYPE_ANY);\
				    (vn)->v.number = val;\
 )
#define CREATE_STRING(vn, val) SAFE(\
				    (vn) = new_node_no_line();\
				    (vn)->kind = NODE_STRING;\
				    (vn)->type = TYPE_STRING;\
				    (vn)->v.number = store_prog_string(val);\
				    )
#define CREATE_EXPR_LIST(vn, pn) SAFE(\
				      (vn) = new_node();\
				      (vn)->v.number = (pn ? ((parse_node_t *)pn)->kind : 0);\
				      (vn)->l.expr = (pn ? ((parse_node_t *)pn)->l.expr : (vn));\
				      (vn)->r.expr = pn;\
				      )
#define CREATE_EXPR_NODE(vn, pn, f) SAFE(\
					 (vn) = new_node_no_line();\
					 (vn)->v.expr = pn;\
					 (vn)->l.expr = vn;\
					 (vn)->r.expr = 0;\
					 (vn)->type = f;\
					 )
#define CREATE_CATCH(vn, pn) SAFE(\
				  (vn) = new_node();\
				  (vn)->kind = NODE_CATCH;\
				  (vn)->type = TYPE_ANY;\
				  (vn)->r.expr = pn;\
				  )
#define CREATE_TIME_EXPRESSION(vn, pn) SAFE(\
                                          (vn) = new_node();\
                                          (vn)->kind = NODE_TIME_EXPRESSION;\
                                          (vn)->type = TYPE_ANY;\
                                          (vn)->r.expr = pn;\
                                          )

#define NODE_NO_LINE(x,y) SAFE(\
			       (x) = new_node_no_line();\
			       (x)->kind = y;\
			       )

/* tree functions */
void free_tree PROT((void));
void release_tree PROT((void));
void lock_expressions PROT((void));
void unlock_expressions PROT((void));
/* node functions */
parse_node_t *new_node PROT((void));
parse_node_t *new_node_no_line PROT((void));
parse_node_t *make_branched_node PROT((short, char, 
				       parse_node_t *, parse_node_t *));
/* parser grammar functions */
parse_node_t *binary_int_op PROT((parse_node_t *, parse_node_t *, 
				  char, char *));
parse_node_t *make_range_node PROT((int, parse_node_t *,
					 parse_node_t *,
					 parse_node_t *));
parse_node_t *insert_pop_value PROT((parse_node_t *));
parse_node_t *pop_value PROT((parse_node_t *));
parse_node_t *optimize_loop_test PROT((parse_node_t *));
int is_boolean PROT((parse_node_t *));

#endif