From e5e77efb2d9832fe3d9fc1df33037307f2ea897f Mon Sep 17 00:00:00 2001 From: aamine Date: Mon, 2 Sep 2002 12:19:30 +0000 Subject: * gc.c (gc_sweep): does reclaim nodes in also compile time, if we can. * ruby.c (load_file): omit GC if we can. * parse.y (ruby_parser_stack_on_heap): new function. * intern.h (ruby_parser_stack_on_heap): added. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@2780 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 11 +++++++++++ gc.c | 5 +++-- intern.h | 1 + parse.y | 10 ++++++++++ ruby.c | 5 ++++- 5 files changed, 29 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index af8c37596..9b2836eae 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,14 @@ +Mon Sep 2 21:21:46 2002 Minero Aoki + + * gc.c (gc_sweep): does reclaim nodes in also compile time, if we + can. + + * ruby.c (load_file): omit GC if we can. + + * parse.y (ruby_parser_stack_on_heap): new function. + + * intern.h (ruby_parser_stack_on_heap): added. + Sun Sep 1 15:54:33 2002 WATANABE Hirofumi * config.guess: fixed for Linux/PPC. diff --git a/gc.c b/gc.c index 1503d42a7..e5ecea76f 100644 --- a/gc.c +++ b/gc.c @@ -863,8 +863,9 @@ gc_sweep() int freed = 0; int i, used = heaps_used; - if (ruby_in_compile) { - /* should not reclaim nodes during compilation */ + if (ruby_in_compile && ruby_parser_stack_on_heap()) { + /* should not reclaim nodes during compilation + if yacc's semantic stack is not allocated on machine stack */ for (i = 0; i < used; i++) { p = heaps[i]; pend = p + heaps_limits[i]; while (p < pend) { diff --git a/intern.h b/intern.h index 59fcfa67f..afc902d26 100644 --- a/intern.h +++ b/intern.h @@ -291,6 +291,7 @@ int yyparse _((void)); ID rb_id_attrset _((ID)); void rb_parser_append_print _((void)); void rb_parser_while_loop _((int, int)); +int ruby_parser_stack_on_heap _((void)); int rb_is_const_id _((ID)); int rb_is_instance_id _((ID)); int rb_is_class_id _((ID)); diff --git a/parse.y b/parse.y index 0ba14a1c7..661188e95 100644 --- a/parse.y +++ b/parse.y @@ -5341,6 +5341,16 @@ dyna_in_block() return (lvtbl->dlev > 0); } +int +ruby_parser_stack_on_heap() +{ +#if defined(YYBISON) && !defined(C_ALLOCA) + return Qfalse; +#else + return Qtrue; +#endif +} + void rb_parser_append_print() { diff --git a/ruby.c b/ruby.c index 8aa20ce11..dfaa2e1c9 100644 --- a/ruby.c +++ b/ruby.c @@ -856,7 +856,10 @@ load_file(fname, script) else if (f != rb_stdin) { rb_io_close(f); } - rb_gc(); + + if (ruby_parser_stack_on_heap()) { + rb_gc(); + } } void -- cgit