6 /* Copyright (C) 1995,1996,2000,2001, 2004, 2006, 2008 Free Software Foundation, Inc.
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public License
10 * as published by the Free Software Foundation; either version 3 of
11 * the License, or (at your option) any later version.
13 * This library is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26 #include "libguile/__scm.h"
28 /* {Frames and stacks}
31 typedef struct scm_t_info_frame
{
38 #define SCM_FRAME_N_SLOTS (sizeof (scm_t_info_frame) / sizeof (SCM))
40 #define SCM_STACK(obj) ((scm_t_stack *) SCM_STRUCT_DATA (obj))
41 #define SCM_STACK_LAYOUT "pwuourpW"
42 typedef struct scm_t_stack
{
43 SCM id
; /* Stack id */
44 scm_t_info_frame
*frames
; /* Info frames */
45 unsigned long length
; /* Stack length */
46 unsigned long tail_length
;
47 scm_t_info_frame tail
[1];
50 SCM_API SCM scm_stack_type
;
52 #define SCM_STACKP(obj) (SCM_STRUCTP (obj) && scm_is_eq (SCM_STRUCT_VTABLE (obj), scm_stack_type))
53 #define SCM_STACK_LENGTH(stack) (SCM_STACK (stack) -> length)
55 #define SCM_FRAMEP(obj) \
56 (scm_is_pair (obj) && SCM_STACKP (SCM_CAR (obj)) \
57 && scm_is_unsigned_integer (SCM_CDR (obj), \
58 0, SCM_STACK_LENGTH (SCM_CAR (obj))-1))
60 #define SCM_FRAME_REF(frame, slot) \
61 (SCM_STACK (SCM_CAR (frame)) -> frames[scm_to_size_t (SCM_CDR (frame))].slot)
63 #define SCM_FRAME_NUMBER(frame) \
65 ? scm_to_size_t (SCM_CDR (frame)) \
66 : (SCM_STACK_LENGTH (SCM_CAR (frame)) \
67 - scm_to_size_t (SCM_CDR (frame)) \
70 #define SCM_FRAME_FLAGS(frame) SCM_FRAME_REF (frame, flags)
71 #define SCM_FRAME_SOURCE(frame) SCM_FRAME_REF (frame, source)
72 #define SCM_FRAME_PROC(frame) SCM_FRAME_REF (frame, proc)
73 #define SCM_FRAME_ARGS(frame) SCM_FRAME_REF (frame, args)
74 #define SCM_FRAME_PREV(frame) scm_frame_previous (frame)
75 #define SCM_FRAME_NEXT(frame) scm_frame_next (frame)
77 #define SCM_FRAMEF_VOID (1L << 2)
78 #define SCM_FRAMEF_REAL (1L << 3)
79 #define SCM_FRAMEF_PROC (1L << 4)
80 #define SCM_FRAMEF_EVAL_ARGS (1L << 5)
81 #define SCM_FRAMEF_OVERFLOW (1L << 6)
83 #define SCM_FRAME_VOID_P(f) (SCM_FRAME_FLAGS (f) & SCM_FRAMEF_VOID)
84 #define SCM_FRAME_REAL_P(f) (SCM_FRAME_FLAGS (f) & SCM_FRAMEF_REAL)
85 #define SCM_FRAME_PROC_P(f) (SCM_FRAME_FLAGS (f) & SCM_FRAMEF_PROC)
86 #define SCM_FRAME_EVAL_ARGS_P(f) (SCM_FRAME_FLAGS (f) & SCM_FRAMEF_EVAL_ARGS)
87 #define SCM_FRAME_OVERFLOW_P(f) (SCM_FRAME_FLAGS (f) & SCM_FRAMEF_OVERFLOW)
91 SCM_API SCM
scm_stack_p (SCM obj
);
92 SCM_API SCM
scm_make_stack (SCM obj
, SCM args
);
93 SCM_API SCM
scm_stack_id (SCM stack
);
94 SCM_API SCM
scm_stack_ref (SCM stack
, SCM i
);
95 SCM_API SCM
scm_stack_length (SCM stack
);
97 SCM_API SCM
scm_frame_p (SCM obj
);
98 SCM_API SCM
scm_last_stack_frame (SCM obj
);
99 SCM_API SCM
scm_frame_number (SCM frame
);
100 SCM_API SCM
scm_frame_source (SCM frame
);
101 SCM_API SCM
scm_frame_procedure (SCM frame
);
102 SCM_API SCM
scm_frame_arguments (SCM frame
);
103 SCM_API SCM
scm_frame_previous (SCM frame
);
104 SCM_API SCM
scm_frame_next (SCM frame
);
105 SCM_API SCM
scm_frame_real_p (SCM frame
);
106 SCM_API SCM
scm_frame_procedure_p (SCM frame
);
107 SCM_API SCM
scm_frame_evaluating_args_p (SCM frame
);
108 SCM_API SCM
scm_frame_overflow_p (SCM frame
);
110 SCM_INTERNAL
void scm_init_stacks (void);
112 #endif /* SCM_STACKS_H */