diff options
author | Koichi Sasada <[email protected]> | 2019-10-24 16:28:15 +0900 |
---|---|---|
committer | Koichi Sasada <[email protected]> | 2019-10-24 16:46:21 +0900 |
commit | 38e931fa2ceac6d922f3eabedb8f35f211de0bdb (patch) | |
tree | 9ff2a464fa55a4c0c41c66e59a24f80156843a90 /cont.c | |
parent | 4c3e3b8028ca76fcaedc0e40d9ac678e3ac79ee9 (diff) |
show "transferred" attribute on Fiber#to_s
If a fiber is invoked with transfer method (such as "f.transfer"),
then the invoked fiber ("f") is labeled as "transferred" and this
fiber can not be invoked with Fiber#resume. This patch adds
transferred attribute for "Fiber#to_s" (and inspect).
Diffstat (limited to 'cont.c')
-rw-r--r-- | cont.c | 14 |
1 files changed, 10 insertions, 4 deletions
@@ -228,8 +228,8 @@ struct rb_fiber_struct { VALUE first_proc; struct rb_fiber_struct *prev; BITFIELD(enum fiber_status, status, 2); - /* If a fiber invokes "transfer", - * then this fiber can't "resume" any more after that. + /* If a fiber invokes by "transfer", + * then this fiber can't be invoked by "resume" any more after that. * You shouldn't mix "transfer" and "resume". */ unsigned int transferred : 1; @@ -2273,9 +2273,15 @@ fiber_to_s(VALUE fiber_value) { const rb_fiber_t *fiber = fiber_ptr(fiber_value); const rb_proc_t *proc; - char status_info[0x10]; + char status_info[0x20]; + + if (fiber->transferred) { + snprintf(status_info, 0x20, " (%s, transferred)", fiber_status_name(fiber->status)); + } + else { + snprintf(status_info, 0x20, " (%s)", fiber_status_name(fiber->status)); + } - snprintf(status_info, 0x10, " (%s)", fiber_status_name(fiber->status)); if (!rb_obj_is_proc(fiber->first_proc)) { VALUE str = rb_any_to_s(fiber_value); strlcat(status_info, ">", sizeof(status_info)); |