mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* Merge YARV
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11439 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
3e7566d8fb
commit
a3e1b1ce7e
233 changed files with 46004 additions and 13653 deletions
48
gc.h
Normal file
48
gc.h
Normal file
|
|
@ -0,0 +1,48 @@
|
|||
|
||||
#ifndef MARK_FREE_DEBUG
|
||||
#define MARK_FREE_DEBUG 0
|
||||
#endif
|
||||
|
||||
|
||||
#if MARK_FREE_DEBUG
|
||||
static int g_indent = 0;
|
||||
|
||||
static void
|
||||
rb_gc_debug_indent(void)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < g_indent; i++) {
|
||||
printf(" ");
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
rb_gc_debug_body(char *mode, char *msg, int st, void *ptr)
|
||||
{
|
||||
if (st == 0) {
|
||||
g_indent--;
|
||||
}
|
||||
rb_gc_debug_indent();
|
||||
printf("%s: %s %s (%p)\n", mode, st ? "->" : "<-", msg, ptr);
|
||||
if (st) {
|
||||
g_indent++;
|
||||
}
|
||||
fflush(stdout);
|
||||
}
|
||||
|
||||
#define MARK_REPORT_ENTER(msg) rb_gc_debug_body("mark", msg, 1, ptr)
|
||||
#define MARK_REPORT_LEAVE(msg) rb_gc_debug_body("mark", msg, 0, ptr)
|
||||
#define FREE_REPORT_ENTER(msg) rb_gc_debug_body("free", msg, 1, ptr)
|
||||
#define FREE_REPORT_LEAVE(msg) rb_gc_debug_body("free", msg, 0, ptr)
|
||||
#define GC_INFO rb_gc_debug_indent(); printf
|
||||
|
||||
#else
|
||||
#define MARK_REPORT_ENTER(msg)
|
||||
#define MARK_REPORT_LEAVE(msg)
|
||||
#define FREE_REPORT_ENTER(msg)
|
||||
#define FREE_REPORT_LEAVE(msg)
|
||||
#define GC_INFO if(0)printf
|
||||
#endif
|
||||
|
||||
#define MARK_UNLESS_NULL(ptr) if(ptr){rb_gc_mark(ptr);}
|
||||
#define FREE_UNLESS_NULL(ptr) if(ptr){ruby_xfree(ptr);}
|
||||
Loading…
Add table
Add a link
Reference in a new issue