diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2018-04-05 07:04:39 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2018-04-05 07:04:39 +0000 |
commit | bc6e61f149deaf1f74e04af9c5e32683e6b39644 (patch) | |
tree | ab64ee958d73d4b7ccc58e7bddde5f9437e7a5ac /compile.c | |
parent | 04dfc46ad0918964260d095b8f58e35eff5a33af (diff) | |
download | ruby-bc6e61f149deaf1f74e04af9c5e32683e6b39644.tar.gz |
compile.c: do not dump pointers
* compile.c (ibf_dump_iseq_each): do not dump succ_index_table
pointer. positions are dumped as integer arrays. pointer
values are meaningless outside the process.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@63099 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'compile.c')
-rw-r--r-- | compile.c | 14 |
1 files changed, 9 insertions, 5 deletions
@@ -8612,9 +8612,9 @@ ibf_load_insns_info_body(const struct ibf_load *load, const struct rb_iseq_const } static unsigned int * -ibf_dump_insns_info_positions(struct ibf_dump *dump, const rb_iseq_t *iseq) +ibf_dump_insns_info_positions(struct ibf_dump *dump, const struct rb_iseq_constant_body *body) { - return IBF_W(iseq->body->insns_info.positions, unsigned int, iseq->body->insns_info.size); + return IBF_W(body->insns_info.positions, unsigned int, body->insns_info.size); } static unsigned int * @@ -8765,7 +8765,10 @@ static ibf_offset_t ibf_dump_iseq_each(struct ibf_dump *dump, const rb_iseq_t *iseq) { struct rb_iseq_constant_body dump_body; + unsigned int *positions; +#if VM_INSN_INFO_TABLE_IMPL == 2 dump_body = *iseq->body; +#endif dump_body.location.pathobj = ibf_dump_object(dump, dump_body.location.pathobj); /* TODO: freeze */ dump_body.location.base_label = ibf_dump_object(dump, dump_body.location.base_label); @@ -8776,11 +8779,12 @@ ibf_dump_iseq_each(struct ibf_dump *dump, const rb_iseq_t *iseq) dump_body.param.keyword = ibf_dump_param_keyword(dump, iseq); dump_body.insns_info.body = ibf_dump_insns_info_body(dump, iseq); #if VM_INSN_INFO_TABLE_IMPL == 2 - rb_iseq_insns_info_decode_positions(iseq); + positions = rb_iseq_insns_info_decode_positions(&dump_body); + dump_body.insns_info.positions = positions; #endif - dump_body.insns_info.positions = ibf_dump_insns_info_positions(dump, iseq); + dump_body.insns_info.positions = ibf_dump_insns_info_positions(dump, &dump_body); #if VM_INSN_INFO_TABLE_IMPL == 2 - rb_iseq_insns_info_encode_positions(iseq); + ruby_xfree(positions); #endif dump_body.local_table = ibf_dump_local_table(dump, iseq); dump_body.catch_table = ibf_dump_catch_table(dump, iseq); |