mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
thread.c (rb_reset_coverages): remove coverage counters from all ISeqs
When coverage measurement is enabled, the compiler makes each iseq have a reference to the counter array of coverage. Even after coverage measurement is disabled, the reference is kept. And, if coverage measurement is restarted, a coverage hook will increase the counter. This is completely meaningless; it brings just overhead. To remove this meaninglessness, this change removes all the reference when coverage measuement is stopped. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@64504 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
84fd997fe6
commit
33af0429ea
3 changed files with 22 additions and 0 deletions
19
iseq.c
19
iseq.c
|
@ -966,6 +966,25 @@ rb_iseq_coverage(const rb_iseq_t *iseq)
|
|||
return ISEQ_COVERAGE(iseq);
|
||||
}
|
||||
|
||||
static int
|
||||
remove_coverage_i(void *vstart, void *vend, size_t stride, void *data)
|
||||
{
|
||||
VALUE v = (VALUE)vstart;
|
||||
for (; v != (VALUE)vend; v += stride) {
|
||||
if (rb_obj_is_iseq(v)) {
|
||||
rb_iseq_t *iseq = (rb_iseq_t *)v;
|
||||
ISEQ_COVERAGE_SET(iseq, Qnil);
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
rb_iseq_remove_coverage_all()
|
||||
{
|
||||
rb_objspace_each_objects(remove_coverage_i, NULL);
|
||||
}
|
||||
|
||||
/* define wrapper class methods (RubyVM::InstructionSequence) */
|
||||
|
||||
static void
|
||||
|
|
2
iseq.h
2
iseq.h
|
@ -178,6 +178,8 @@ VALUE rb_iseq_first_lineno(const rb_iseq_t *iseq);
|
|||
VALUE rb_iseq_method_name(const rb_iseq_t *iseq);
|
||||
void rb_iseq_code_location(const rb_iseq_t *iseq, int *first_lineno, int *first_column, int *last_lineno, int *last_column);
|
||||
|
||||
void rb_iseq_remove_coverage_all();
|
||||
|
||||
/* proc.c */
|
||||
const rb_iseq_t *rb_method_iseq(VALUE body);
|
||||
const rb_iseq_t *rb_proc_get_iseq(VALUE proc, int *is_proc);
|
||||
|
|
1
thread.c
1
thread.c
|
@ -5404,6 +5404,7 @@ rb_reset_coverages(void)
|
|||
{
|
||||
VALUE coverages = rb_get_coverages();
|
||||
st_foreach(rb_hash_tbl_raw(coverages), reset_coverage_i, 0);
|
||||
rb_iseq_remove_coverage_all();
|
||||
GET_VM()->coverages = Qfalse;
|
||||
rb_remove_event_hook((rb_event_hook_func_t) update_line_coverage);
|
||||
if (GET_VM()->coverage_mode & COVERAGE_TARGET_BRANCHES) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue