Bug #3723
closedRemove unused control frame variable: rb_control_frame_t.block_iseq
Description
=begin
rb_control_frame_t.block_iseq does not appear to serve any purpose and can possibly be removed.
=end
Updated by naruse (Yui NARUSE) over 14 years ago
- Status changed from Open to Assigned
- Assignee set to ko1 (Koichi Sasada)
=begin
As you said, it seems useless variable.
But if block_iseq of rb_control_frame_t is simply removed, it breaks ABI compatibility.
I assign this to ko1.
=end
Updated by naruse (Yui NARUSE) over 14 years ago
- Status changed from Assigned to Rejected
=begin
I talked this with ko1.
It is used from rb_block_t.iseq, so it can't be removed.
=end
Updated by pweldon (Peter Weldon) over 14 years ago
=begin
I apologise, I did not understand the connection between rb_control_frame_t and rb_block_t. I see now that these macros are used to access rb_control_frame_t members via a rb_block_t:
vm_core.h:
#define RUBY_VM_GET_BLOCK_PTR_IN_CFP(cfp) ((rb_block_t *)(&(cfp)->self))
#define RUBY_VM_GET_CFP_FROM_BLOCK_PTR(b)
((rb_control_frame_t *)((VALUE *)(b) - 5))
The rb_control_frame_t comments in vm_core.h now also make sense to me. Thank you for helping me understand.
=end