blob: 7002dd453d616961398ced3b1aeb68728ee9ecf8 [file] [log] [blame]
Guido van Rossuma3309961993-07-28 09:05:47 +00001#ifndef Py_CEVAL_H
2#define Py_CEVAL_H
3#ifdef __cplusplus
4extern "C" {
5#endif
6
Guido van Rossumf70e43a1991-02-19 12:39:46 +00007/***********************************************************
Guido van Rossumb6775db1994-08-01 11:34:53 +00008Copyright 1991, 1992, 1993, 1994 by Stichting Mathematisch Centrum,
Guido van Rossum9bfef441993-03-29 10:43:31 +00009Amsterdam, The Netherlands.
Guido van Rossumf70e43a1991-02-19 12:39:46 +000010
11 All Rights Reserved
12
13Permission to use, copy, modify, and distribute this software and its
14documentation for any purpose and without fee is hereby granted,
15provided that the above copyright notice appear in all copies and that
16both that copyright notice and this permission notice appear in
17supporting documentation, and that the names of Stichting Mathematisch
18Centrum or CWI not be used in advertising or publicity pertaining to
19distribution of the software without specific, written prior permission.
20
21STICHTING MATHEMATISCH CENTRUM DISCLAIMS ALL WARRANTIES WITH REGARD TO
22THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
23FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH CENTRUM BE LIABLE
24FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
25WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
26ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
27OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
28
29******************************************************************/
30
Guido van Rossumff4949e1992-08-05 19:58:53 +000031/* Interface to random parts in ceval.c */
Guido van Rossum3f5da241990-12-20 15:06:42 +000032
Guido van Rossuma0490311991-07-27 21:33:03 +000033object *call_object PROTO((object *, object *));
34
Guido van Rossum3f5da241990-12-20 15:06:42 +000035object *getglobals PROTO((void));
36object *getlocals PROTO((void));
Guido van Rossumeb6b33a1993-05-25 09:38:27 +000037object *getowner PROTO((void));
Guido van Rossumb6775db1994-08-01 11:34:53 +000038object *getframe PROTO((void));
Guido van Rossum3f5da241990-12-20 15:06:42 +000039
Guido van Rossum3165fe61992-09-25 21:59:05 +000040void printtraceback PROTO((object *));
Guido van Rossum704a26c1992-03-27 17:29:31 +000041void flushline PROTO((void));
Guido van Rossumff4949e1992-08-05 19:58:53 +000042
Guido van Rossum95664081994-09-14 13:23:36 +000043int Py_AddPendingCall PROTO((int (*func) PROTO((ANY *)), ANY *arg));
Guido van Rossumc5d92e11994-09-28 15:44:39 +000044int Py_MakePendingCalls PROTO((void));
Guido van Rossum95664081994-09-14 13:23:36 +000045
Guido van Rossumff4949e1992-08-05 19:58:53 +000046
47/* Interface for threads.
48
49 A module that plans to do a blocking system call (or something else
50 that lasts a long time and doesn't touch Python data) can allow other
51 threads to run as follows:
52
53 ...preparations here...
54 BGN_SAVE
55 ...blocking system call here...
56 END_SAVE
57 ...interpretr result here...
58
59 The BGN_SAVE/END_SAVE pair expands to a {}-surrounded block.
60 To leave the block in the middle (e.g., with return), you must insert
61 a line containing RET_SAVE before the return, e.g.
62
63 if (...premature_exit...) {
64 RET_SAVE
65 err_errno(IOError);
66 return NULL;
67 }
68
69 An alternative is:
70
71 RET_SAVE
72 if (...premature_exit...) {
73 err_errno(IOError);
74 return NULL;
75 }
76 RES_SAVE
77
78 For convenience, that the value of 'errno' is restored across
79 END_SAVE and RET_SAVE.
80
81 WARNING: NEVER NEST CALLS TO BGN_SAVE AND END_SAVE!!!
82
83 The function init_save_thread() should be called only from
84 initthread() in "threadmodule.c".
85
86 Note that not yet all candidates have been converted to use this
87 mechanism!
88*/
89
90extern void init_save_thread PROTO((void));
Guido van Rossum04691fc1992-08-12 15:35:34 +000091extern object *save_thread PROTO((void));
92extern void restore_thread PROTO((object *));
Guido van Rossumff4949e1992-08-05 19:58:53 +000093
Guido van Rossumb6775db1994-08-01 11:34:53 +000094#ifdef WITH_THREAD
Guido van Rossumff4949e1992-08-05 19:58:53 +000095
96#define BGN_SAVE { \
Guido van Rossum04691fc1992-08-12 15:35:34 +000097 object *_save; \
Guido van Rossumff4949e1992-08-05 19:58:53 +000098 _save = save_thread();
99#define RET_SAVE restore_thread(_save);
100#define RES_SAVE _save = save_thread();
101#define END_SAVE restore_thread(_save); \
102 }
103
Guido van Rossumb6775db1994-08-01 11:34:53 +0000104#else /* !WITH_THREAD */
Guido van Rossumff4949e1992-08-05 19:58:53 +0000105
106#define BGN_SAVE {
107#define RET_SAVE
108#define RES_SAVE
109#define END_SAVE }
110
Guido van Rossumb6775db1994-08-01 11:34:53 +0000111#endif /* !WITH_THREAD */
Guido van Rossuma3309961993-07-28 09:05:47 +0000112
113#ifdef __cplusplus
114}
115#endif
116#endif /* !Py_CEVAL_H */