diff options
author | Koichi Sasada <ko1@atdot.net> | 2020-03-10 02:22:11 +0900 |
---|---|---|
committer | Koichi Sasada <ko1@atdot.net> | 2020-09-03 21:11:06 +0900 |
commit | 79df14c04b452411b9d17e26a398e491bca1a811 (patch) | |
tree | 7598cee0f105439efd5bb328a727b0fe27d7c666 /parse.y | |
parent | eeb5325d3bfd71301896360c17e8f51abcb9a7e5 (diff) | |
download | ruby-79df14c04b452411b9d17e26a398e491bca1a811.tar.gz |
Introduce Ractor mechanism for parallel execution
This commit introduces Ractor mechanism to run Ruby program in
parallel. See doc/ractor.md for more details about Ractor.
See ticket [Feature #17100] to see the implementation details
and discussions.
[Feature #17100]
This commit does not complete the implementation. You can find
many bugs on using Ractor. Also the specification will be changed
so that this feature is experimental. You will see a warning when
you make the first Ractor with `Ractor.new`.
I hope this feature can help programmers from thread-safety issues.
Diffstat (limited to 'parse.y')
-rw-r--r-- | parse.y | 7 |
1 files changed, 4 insertions, 3 deletions
@@ -58,6 +58,7 @@ struct lex_context { #include "ruby/st.h" #include "ruby/util.h" #include "symbol.h" +#include "ractor_pub.h" #define AREF(ary, i) RARRAY_AREF(ary, i) @@ -10514,8 +10515,8 @@ rb_parser_fatal(struct parser_params *p, const char *fmt, ...) rb_str_resize(mesg, 0); append_bitstack_value(p->cmdarg_stack, mesg); compile_error(p, "cmdarg_stack: %"PRIsVALUE, mesg); - if (p->debug_output == rb_stdout) - p->debug_output = rb_stderr; + if (p->debug_output == rb_ractor_stdout()) + p->debug_output = rb_ractor_stderr(); p->debug = TRUE; } @@ -12554,7 +12555,7 @@ parser_initialize(struct parser_params *p) p->error_buffer = Qfalse; #endif p->debug_buffer = Qnil; - p->debug_output = rb_stdout; + p->debug_output = rb_ractor_stdout(); p->enc = rb_utf8_encoding(); } |