The FSF has a new address.
[bpt/guile.git] / libguile / continuations.h
CommitLineData
0f2d19dd
JB
1/* classes: h_files */
2
b29058ff
DH
3#ifndef SCM_CONTINUATIONS_H
4#define SCM_CONTINUATIONS_H
5
6/* Copyright (C) 1995,1996,2000,2001 Free Software Foundation, Inc.
7 *
73be1d9e
MV
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
b29058ff 12 *
73be1d9e 13 * This library is distributed in the hope that it will be useful,
0f2d19dd 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
73be1d9e
MV
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
b29058ff 17 *
73be1d9e
MV
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
92205699 20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
73be1d9e 21 */
b29058ff 22
0f2d19dd 23\f
b29058ff 24
b4309c3c 25#include "libguile/__scm.h"
0f2d19dd 26
766c5eaf 27#ifdef __ia64__
6a535440 28#include <signal.h>
78b6566e 29#include <ucontext.h>
87855fa2
MV
30extern unsigned long * __libc_ia64_register_backing_store_base;
31#endif /* __ia64__ */
0f2d19dd
JB
32\f
33
5f144b10 34/* a continuation SCM is a non-immediate pointing to a heap cell with:
2dbec7b5
GH
35 word 0: bits 0-15: smob type tag: scm_tc16_continuation.
36 bits 16-31: unused.
92c2555f 37 word 1: malloc block containing an scm_t_contregs structure with a
5f144b10
GH
38 tail array of SCM_STACKITEM. the size of the array is stored
39 in the num_stack_items field of the structure.
40*/
41
87855fa2 42SCM_API scm_t_bits scm_tc16_continuation;
5f144b10 43
0f2d19dd
JB
44typedef struct
45{
46 SCM throw_value;
47 jmp_buf jmpbuf;
48 SCM dynenv;
766c5eaf
RB
49#ifdef __ia64__
50 ucontext_t ctx;
51 void *backing_store;
52 unsigned long backing_store_size;
53#endif /* __ia64__ */
c014a02e 54 size_t num_stack_items; /* size of the saved stack. */
9de87eea 55 SCM root; /* continuation root identifier. */
0f2d19dd 56
9de87eea 57 /* The offset from the live stack location to this copy. This is
5c5c27dc
MV
58 used to adjust pointers from within the copied stack to the stack
59 itself.
60
61 Thus, when you read a pointer from the copied stack that points
62 into the live stack, you need to add OFFSET so that it points
63 into the copy.
64 */
65 scm_t_ptrdiff offset;
66
67 /* The most recently created debug frame on the live stack, before
9de87eea 68 it was saved. This needs to be adjusted with OFFSET, above.
5c5c27dc 69 */
92c2555f 70 struct scm_t_debug_frame *dframe;
d0f6ceb8 71
5f144b10 72 SCM_STACKITEM stack[1]; /* copied stack of size num_stack_items. */
92c2555f 73} scm_t_contregs;
1be6b49c 74
e841c3e0 75#define SCM_CONTINUATIONP(x) SCM_TYP16_PREDICATE (scm_tc16_continuation, x)
8b3bda20 76
92c2555f 77#define SCM_CONTREGS(x) ((scm_t_contregs *) SCM_CELL_WORD_1 (x))
8b3bda20 78
5f144b10 79#define SCM_CONTINUATION_LENGTH(x) (SCM_CONTREGS (x)->num_stack_items)
34d19ef6 80#define SCM_SET_CONTINUATION_LENGTH(x, n)\
5f144b10 81 (SCM_CONTREGS (x)->num_stack_items = (n))
9de87eea
MV
82#define SCM_JMPBUF(x) ((SCM_CONTREGS (x))->jmpbuf)
83#define SCM_DYNENV(x) ((SCM_CONTREGS (x))->dynenv)
84#define SCM_THROW_VALUE(x) ((SCM_CONTREGS (x))->throw_value)
85#define SCM_CONTINUATION_ROOT(x) ((SCM_CONTREGS (x))->root)
86#define SCM_DFRAME(x) ((SCM_CONTREGS (x))->dframe)
0f2d19dd
JB
87
88\f
89
87855fa2 90SCM_API SCM scm_make_continuation (int *first);
9de87eea
MV
91
92SCM_API void *scm_c_with_continuation_barrier (void *(*func)(void*), void *);
93SCM_API SCM scm_with_continuation_barrier (SCM proc);
94
95SCM_API SCM scm_i_with_continuation_barrier (scm_t_catch_body body,
96 void *body_data,
97 scm_t_catch_handler handler,
98 void *handler_data);
99
87855fa2 100SCM_API void scm_init_continuations (void);
0f2d19dd 101
b29058ff 102#endif /* SCM_CONTINUATIONS_H */
89e00824
ML
103
104/*
105 Local Variables:
106 c-file-style: "gnu"
107 End:
108*/