summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-10-23 08:59:42 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-10-23 08:59:42 +0000
commitd74e7e6837c92e33eeff2fdbdca8833c973dbd21 (patch)
tree9a0c26f214ec94e2c58c6b058edcf37afe13b93f /eval.c
parent443ddb09699926f74798fdb8440a24ebda358088 (diff)
* eval.c (ruby_cleanup): initialize stack bottom for embedding.
[ruby-dev:21686] * ext/dl/extconf.rb: move list of files to clean from DEPEND file, to get rid of macro redefinitions. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4836 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/eval.c b/eval.c
index 483beea2db..5961e1ec62 100644
--- a/eval.c
+++ b/eval.c
@@ -1301,7 +1301,7 @@ ruby_options(argc, argv)
if ((state = EXEC_TAG()) == 0) {
ruby_process_options(argc, argv);
}
- if (state) {
+ else {
trace_func = 0;
tracing = 0;
exit(error_handle(state));
@@ -1347,6 +1347,7 @@ ruby_cleanup(ex)
volatile VALUE err = ruby_errinfo;
ruby_safe_level = 0;
+ Init_stack((void*)&state);
ruby_finalize_0();
if (ruby_errinfo) err = ruby_errinfo;
PUSH_TAG(PROT_NONE);