2018-08-10 07:26:54 +03:00
|
|
|
set startup-with-shell off
|
|
|
|
|
2013-03-07 08:38:50 +04:00
|
|
|
define hook-run
|
|
|
|
set $color_type = 0
|
|
|
|
set $color_highlite = 0
|
|
|
|
set $color_end = 0
|
|
|
|
end
|
|
|
|
|
2013-02-16 09:46:06 +04:00
|
|
|
define ruby_gdb_init
|
|
|
|
if !$color_type
|
|
|
|
set $color_type = "\033[31m"
|
|
|
|
end
|
|
|
|
if !$color_highlite
|
|
|
|
set $color_highlite = "\033[36m"
|
|
|
|
end
|
|
|
|
if !$color_end
|
|
|
|
set $color_end = "\033[m"
|
|
|
|
end
|
2013-12-13 05:36:29 +04:00
|
|
|
if ruby_dummy_gdb_enums.special_consts
|
|
|
|
end
|
2013-02-16 09:46:06 +04:00
|
|
|
end
|
|
|
|
|
2013-02-17 11:56:57 +04:00
|
|
|
# set prompt \033[36m(gdb)\033[m\040
|
2013-02-16 09:46:06 +04:00
|
|
|
|
2007-06-15 17:59:45 +04:00
|
|
|
define rp
|
2013-02-16 09:46:06 +04:00
|
|
|
ruby_gdb_init
|
2009-05-21 17:17:54 +04:00
|
|
|
if (VALUE)($arg0) & RUBY_FIXNUM_FLAG
|
|
|
|
printf "FIXNUM: %ld\n", (long)($arg0) >> 1
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
if ((VALUE)($arg0) & ~(~(VALUE)0<<RUBY_SPECIAL_SHIFT)) == RUBY_SYMBOL_FLAG
|
|
|
|
set $id = (($arg0) >> RUBY_SPECIAL_SHIFT)
|
2013-09-27 06:18:07 +04:00
|
|
|
printf "%sSYMBOL%s: ", $color_type, $color_end
|
2013-09-20 08:53:04 +04:00
|
|
|
rp_id $id
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0) == RUBY_Qfalse
|
2007-06-15 17:59:45 +04:00
|
|
|
echo false\n
|
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0) == RUBY_Qtrue
|
2007-06-15 17:59:45 +04:00
|
|
|
echo true\n
|
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0) == RUBY_Qnil
|
2007-06-15 17:59:45 +04:00
|
|
|
echo nil\n
|
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0) == RUBY_Qundef
|
2007-06-15 17:59:45 +04:00
|
|
|
echo undef\n
|
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
if (VALUE)($arg0) & RUBY_IMMEDIATE_MASK
|
2012-09-06 09:49:51 +04:00
|
|
|
if ((VALUE)($arg0) & RUBY_FLONUM_MASK) == RUBY_FLONUM_FLAG
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sFLONUM%s: %g\n", $color_type, $color_end, (double)rb_float_value($arg0)
|
2012-09-06 09:49:51 +04:00
|
|
|
else
|
|
|
|
echo immediate\n
|
|
|
|
end
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
set $flags = ((struct RBasic*)($arg0))->flags
|
2014-09-12 18:16:57 +04:00
|
|
|
if ($flags & RUBY_FL_PROMOTED) == RUBY_FL_PROMOTED
|
2013-11-04 22:59:33 +04:00
|
|
|
printf "[PROMOTED] "
|
|
|
|
end
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_NONE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_NONE%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_NIL
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_NIL%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_OBJECT
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_OBJECT%s: ", $color_type, $color_end
|
2016-11-12 09:12:09 +03:00
|
|
|
print ((struct RObject *)($arg0))->basic
|
|
|
|
if ($flags & ROBJECT_EMBED)
|
|
|
|
print/x *((VALUE*)((struct RObject*)($arg0))->as.ary) @ (ROBJECT_EMBED_LEN_MAX+0)
|
|
|
|
else
|
|
|
|
print (((struct RObject *)($arg0))->as.heap)
|
2017-03-18 13:37:53 +03:00
|
|
|
if (((struct RObject*)($arg0))->as.heap.numiv) > 0
|
|
|
|
print/x *(((struct RObject*)($arg0))->as.heap.ivptr) @ (((struct RObject*)($arg0))->as.heap.numiv)
|
|
|
|
end
|
2016-11-12 09:12:09 +03:00
|
|
|
end
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_CLASS
|
2013-02-24 06:59:17 +04:00
|
|
|
printf "%sT_CLASS%s%s: ", $color_type, ($flags & RUBY_FL_SINGLETON) ? "*" : "", $color_end
|
2012-07-02 12:07:01 +04:00
|
|
|
rp_class $arg0
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_ICLASS
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_ICLASS%s: ", $color_type, $color_end
|
2012-07-02 12:07:01 +04:00
|
|
|
rp_class $arg0
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_MODULE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_MODULE%s: ", $color_type, $color_end
|
2012-07-02 12:07:01 +04:00
|
|
|
rp_class $arg0
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_FLOAT
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_FLOAT%s: %.16g ", $color_type, $color_end, (((struct RFloat*)($arg0))->float_value)
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RFloat *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_STRING
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_STRING%s: ", $color_type, $color_end
|
2013-09-20 08:53:06 +04:00
|
|
|
rp_string $arg0 $flags
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_REGEXP
|
2009-05-21 17:17:54 +04:00
|
|
|
set $regsrc = ((struct RRegexp*)($arg0))->src
|
2008-10-17 02:21:42 +04:00
|
|
|
set $rsflags = ((struct RBasic*)$regsrc)->flags
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_REGEXP%s: ", $color_type, $color_end
|
2017-01-15 09:08:09 +03:00
|
|
|
set $len = ($rsflags & RUBY_FL_USER1) ? \
|
|
|
|
((struct RString*)$regsrc)->as.heap.len : \
|
|
|
|
(($rsflags & (RUBY_FL_USER2|RUBY_FL_USER3|RUBY_FL_USER4|RUBY_FL_USER5|RUBY_FL_USER6)) >> RUBY_FL_USHIFT+2)
|
2007-08-07 08:58:07 +04:00
|
|
|
set print address off
|
2017-01-15 09:08:09 +03:00
|
|
|
output *(char *)(($rsflags & RUBY_FL_USER1) ? \
|
2008-10-17 02:21:42 +04:00
|
|
|
((struct RString*)$regsrc)->as.heap.ptr : \
|
2017-01-15 09:08:09 +03:00
|
|
|
((struct RString*)$regsrc)->as.ary) @ $len
|
2007-08-07 08:58:07 +04:00
|
|
|
set print address on
|
2017-01-15 09:08:09 +03:00
|
|
|
printf " len:%ld ", $len
|
2007-12-21 19:39:36 +03:00
|
|
|
if $flags & RUBY_FL_USER6
|
|
|
|
printf "(none) "
|
|
|
|
end
|
2007-12-17 16:11:13 +03:00
|
|
|
if $flags & RUBY_FL_USER5
|
|
|
|
printf "(literal) "
|
|
|
|
end
|
|
|
|
if $flags & RUBY_FL_USER4
|
|
|
|
printf "(fixed) "
|
|
|
|
end
|
2007-12-21 11:31:24 +03:00
|
|
|
printf "encoding:%d ", ($flags & RUBY_ENCODING_MASK) >> RUBY_ENCODING_SHIFT
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RRegexp *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_ARRAY
|
2008-10-09 09:47:04 +04:00
|
|
|
if ($flags & RUBY_FL_USER1)
|
|
|
|
set $len = (($flags & (RUBY_FL_USER3|RUBY_FL_USER4)) >> (RUBY_FL_USHIFT+3))
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_ARRAY%s: len=%ld ", $color_type, $color_end, $len
|
2008-10-09 09:47:04 +04:00
|
|
|
printf "(embed) "
|
|
|
|
if ($len == 0)
|
|
|
|
printf "{(empty)} "
|
|
|
|
else
|
2017-03-18 13:19:52 +03:00
|
|
|
print/x *((VALUE*)((struct RArray*)($arg0))->as.ary) @ $len
|
2008-10-09 09:47:04 +04:00
|
|
|
printf " "
|
|
|
|
end
|
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
set $len = ((struct RArray*)($arg0))->as.heap.len
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_ARRAY%s: len=%ld ", $color_type, $color_end, $len
|
2008-10-09 09:47:04 +04:00
|
|
|
if ($flags & RUBY_FL_USER2)
|
|
|
|
printf "(shared) shared="
|
2020-06-12 04:23:15 +03:00
|
|
|
output/x ((struct RArray*)($arg0))->as.heap.aux.shared_root
|
2008-10-09 09:47:04 +04:00
|
|
|
printf " "
|
|
|
|
else
|
2009-05-21 17:17:54 +04:00
|
|
|
printf "(ownership) capa=%ld ", ((struct RArray*)($arg0))->as.heap.aux.capa
|
2008-10-09 09:47:04 +04:00
|
|
|
end
|
|
|
|
if ($len == 0)
|
|
|
|
printf "{(empty)} "
|
|
|
|
else
|
2017-03-18 13:19:52 +03:00
|
|
|
print/x *((VALUE*)((struct RArray*)($arg0))->as.heap.ptr) @ $len
|
2008-10-09 09:47:04 +04:00
|
|
|
printf " "
|
|
|
|
end
|
|
|
|
end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RArray *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_FIXNUM
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_FIXNUM%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_HASH
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_HASH%s: ", $color_type, $color_end,
|
2020-06-12 04:35:44 +03:00
|
|
|
if (((struct RHash *)($arg0))->basic.flags & RHASH_ST_TABLE_FLAG)
|
2018-10-31 01:11:51 +03:00
|
|
|
printf "st len=%ld ", ((struct RHash *)($arg0))->as.st->num_entries
|
|
|
|
else
|
|
|
|
printf "li len=%ld bound=%ld ", \
|
2020-06-12 04:35:44 +03:00
|
|
|
((((struct RHash *)($arg0))->basic.flags & RHASH_AR_TABLE_SIZE_MASK) >> RHASH_AR_TABLE_SIZE_SHIFT), \
|
|
|
|
((((struct RHash *)($arg0))->basic.flags & RHASH_AR_TABLE_BOUND_MASK) >> RHASH_AR_TABLE_BOUND_SHIFT)
|
2007-08-07 08:58:07 +04:00
|
|
|
end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RHash *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_STRUCT
|
2016-12-25 08:58:24 +03:00
|
|
|
set $len = (($flags & (RUBY_FL_USER1|RUBY_FL_USER2)) ? \
|
2007-08-07 08:58:07 +04:00
|
|
|
($flags & (RUBY_FL_USER1|RUBY_FL_USER2)) >> (RUBY_FL_USHIFT+1) : \
|
2009-05-21 17:17:54 +04:00
|
|
|
((struct RStruct *)($arg0))->as.heap.len)
|
2016-12-25 08:58:24 +03:00
|
|
|
printf "%sT_STRUCT%s: len=%ld ", $color_type, $color_end, $len
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RStruct *)($arg0)
|
2016-12-25 08:58:24 +03:00
|
|
|
output/x *(($flags & (RUBY_FL_USER1|RUBY_FL_USER2)) ? \
|
|
|
|
((struct RStruct *)($arg0))->as.ary : \
|
|
|
|
((struct RStruct *)($arg0))->as.heap.ptr) @ $len
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_BIGNUM
|
2017-02-25 05:59:47 +03:00
|
|
|
rp_bignum $arg0
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2008-04-02 01:54:16 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_RATIONAL
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_RATIONAL%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RRational *)($arg0)
|
2008-04-02 01:54:16 +04:00
|
|
|
else
|
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_COMPLEX
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_COMPLEX%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RComplex *)($arg0)
|
2008-04-02 01:54:16 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_FILE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_FILE%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RFile *)($arg0)
|
|
|
|
output *((struct RFile *)($arg0))->fptr
|
2007-07-05 05:42:09 +04:00
|
|
|
printf "\n"
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_TRUE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_TRUE%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_FALSE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_FALSE%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_DATA
|
2010-06-05 05:04:15 +04:00
|
|
|
if ((struct RTypedData *)($arg0))->typed_flag == 1
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_DATA%s(%s): ", $color_type, $color_end, ((struct RTypedData *)($arg0))->type->wrap_struct_name
|
2010-06-05 05:04:15 +04:00
|
|
|
print (struct RTypedData *)($arg0)
|
|
|
|
else
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_DATA%s: ", $color_type, $color_end
|
2010-06-05 05:04:15 +04:00
|
|
|
print (struct RData *)($arg0)
|
|
|
|
end
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_MATCH
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_MATCH%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RMatch *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_SYMBOL
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_SYMBOL%s: ", $color_type, $color_end
|
2014-03-28 11:58:10 +04:00
|
|
|
print (struct RSymbol *)($arg0)
|
2014-11-18 00:08:23 +03:00
|
|
|
set $id_type = ((struct RSymbol *)($arg0))->id & RUBY_ID_SCOPE_MASK
|
2014-03-28 11:58:10 +04:00
|
|
|
if $id_type == RUBY_ID_LOCAL
|
|
|
|
printf "l"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_INSTANCE
|
|
|
|
printf "i"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_GLOBAL
|
|
|
|
printf "G"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_ATTRSET
|
|
|
|
printf "a"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_CONST
|
|
|
|
printf "C"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_CLASS
|
|
|
|
printf "c"
|
|
|
|
else
|
|
|
|
printf "j"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
set $id_fstr = ((struct RSymbol *)($arg0))->fstr
|
|
|
|
rp_string $id_fstr
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_UNDEF
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_UNDEF%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2015-03-26 09:30:15 +03:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_IMEMO
|
|
|
|
printf "%sT_IMEMO%s(", $color_type, $color_end
|
2017-10-25 02:19:57 +03:00
|
|
|
output (enum imemo_type)(($flags>>RUBY_FL_USHIFT)&RUBY_IMEMO_MASK)
|
2015-03-26 09:30:15 +03:00
|
|
|
printf "): "
|
2015-03-26 09:50:57 +03:00
|
|
|
rp_imemo $arg0
|
2015-03-26 09:30:15 +03:00
|
|
|
else
|
2007-10-07 17:26:41 +04:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_NODE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_NODE%s(", $color_type, $color_end
|
2007-10-07 17:03:05 +04:00
|
|
|
output (enum node_type)(($flags&RUBY_NODE_TYPEMASK)>>RUBY_NODE_TYPESHIFT)
|
2007-07-05 05:42:09 +04:00
|
|
|
printf "): "
|
2009-05-21 17:17:54 +04:00
|
|
|
print *(NODE *)($arg0)
|
2009-05-21 16:42:54 +04:00
|
|
|
else
|
2008-12-27 11:08:44 +03:00
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_ZOMBIE
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sT_ZOMBIE%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RData *)($arg0)
|
2020-12-04 18:49:33 +03:00
|
|
|
else
|
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_MOVED
|
|
|
|
printf "%sT_MOVED%s: ", $color_type, $color_end
|
|
|
|
print *(struct RMoved *)$arg0
|
2007-06-15 17:59:45 +04:00
|
|
|
else
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%sunknown%s: ", $color_type, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
print (struct RBasic *)($arg0)
|
2007-06-15 17:59:45 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2008-12-27 11:08:44 +03:00
|
|
|
end
|
2015-03-26 09:30:15 +03:00
|
|
|
end
|
2020-12-04 18:49:33 +03:00
|
|
|
end
|
2007-06-15 17:59:45 +04:00
|
|
|
end
|
|
|
|
document rp
|
|
|
|
Print a Ruby's VALUE.
|
|
|
|
end
|
2007-07-05 05:42:09 +04:00
|
|
|
|
2013-09-20 08:53:04 +04:00
|
|
|
define rp_id
|
|
|
|
set $id = (ID)$arg0
|
|
|
|
if $id == '!' || $id == '+' || $id == '-' || $id == '*' || $id == '/' || $id == '%' || $id == '<' || $id == '>' || $id == '`'
|
|
|
|
printf "(:%c)\n", $id
|
|
|
|
else
|
|
|
|
if $id == idDot2
|
|
|
|
printf "(:..)\n"
|
|
|
|
else
|
|
|
|
if $id == idDot3
|
|
|
|
printf "(:...)\n"
|
|
|
|
else
|
|
|
|
if $id == idUPlus
|
|
|
|
printf "(:+@)\n"
|
|
|
|
else
|
|
|
|
if $id == idUMinus
|
|
|
|
printf "(:-@)\n"
|
|
|
|
else
|
|
|
|
if $id == idPow
|
|
|
|
printf "(:**)\n"
|
|
|
|
else
|
|
|
|
if $id == idCmp
|
|
|
|
printf "(:<=>)\n"
|
|
|
|
else
|
|
|
|
if $id == idLTLT
|
|
|
|
printf "(:<<)\n"
|
|
|
|
else
|
2017-01-25 09:05:50 +03:00
|
|
|
if $id == idGTGT
|
|
|
|
printf "(:>>)\n"
|
|
|
|
else
|
2013-09-20 08:53:04 +04:00
|
|
|
if $id == idLE
|
|
|
|
printf "(:<=)\n"
|
|
|
|
else
|
|
|
|
if $id == idGE
|
|
|
|
printf "(:>=)\n"
|
|
|
|
else
|
|
|
|
if $id == idEq
|
|
|
|
printf "(:==)\n"
|
|
|
|
else
|
|
|
|
if $id == idEqq
|
|
|
|
printf "(:===)\n"
|
|
|
|
else
|
|
|
|
if $id == idNeq
|
|
|
|
printf "(:!=)\n"
|
|
|
|
else
|
|
|
|
if $id == idEqTilde
|
|
|
|
printf "(:=~)\n"
|
|
|
|
else
|
|
|
|
if $id == idNeqTilde
|
|
|
|
printf "(:!~)\n"
|
|
|
|
else
|
|
|
|
if $id == idAREF
|
|
|
|
printf "(:[])\n"
|
|
|
|
else
|
|
|
|
if $id == idASET
|
|
|
|
printf "(:[]=)\n"
|
2017-01-25 09:05:50 +03:00
|
|
|
else
|
|
|
|
if $id == idCOLON2
|
|
|
|
printf "(:'::')\n"
|
|
|
|
else
|
|
|
|
if $id == idANDOP
|
|
|
|
printf "(:&&)\n"
|
|
|
|
else
|
|
|
|
if $id == idOROP
|
|
|
|
printf "(:||)\n"
|
|
|
|
else
|
|
|
|
if $id == idANDDOT
|
|
|
|
printf "(:&.)\n"
|
2013-09-20 08:53:04 +04:00
|
|
|
else
|
2013-09-20 08:53:08 +04:00
|
|
|
if $id <= tLAST_OP_ID
|
|
|
|
printf "O"
|
|
|
|
else
|
|
|
|
set $id_type = $id & RUBY_ID_SCOPE_MASK
|
|
|
|
if $id_type == RUBY_ID_LOCAL
|
|
|
|
printf "l"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_INSTANCE
|
|
|
|
printf "i"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_GLOBAL
|
|
|
|
printf "G"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_ATTRSET
|
|
|
|
printf "a"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_CONST
|
|
|
|
printf "C"
|
|
|
|
else
|
|
|
|
if $id_type == RUBY_ID_CLASS
|
|
|
|
printf "c"
|
|
|
|
else
|
|
|
|
printf "j"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-09-20 08:53:04 +04:00
|
|
|
printf "(%ld): ", $id
|
2017-10-06 09:11:25 +03:00
|
|
|
print_id $id
|
2017-10-08 08:14:18 +03:00
|
|
|
echo \n
|
2013-09-20 08:53:04 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-01-25 09:05:50 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-09-20 08:53:04 +04:00
|
|
|
end
|
|
|
|
document rp_id
|
|
|
|
Print an ID.
|
|
|
|
end
|
|
|
|
|
2016-07-01 12:24:59 +03:00
|
|
|
define output_string
|
2016-06-30 22:36:38 +03:00
|
|
|
set $flags = ((struct RBasic*)($arg0))->flags
|
2017-01-15 09:08:09 +03:00
|
|
|
set $len = ($flags & RUBY_FL_USER1) ? \
|
|
|
|
((struct RString*)($arg0))->as.heap.len : \
|
|
|
|
(($flags & (RUBY_FL_USER2|RUBY_FL_USER3|RUBY_FL_USER4|RUBY_FL_USER5|RUBY_FL_USER6)) >> RUBY_FL_USHIFT+2)
|
2017-01-25 09:05:51 +03:00
|
|
|
if $len > 0
|
|
|
|
output *(char *)(($flags & RUBY_FL_USER1) ? \
|
2016-06-30 22:36:38 +03:00
|
|
|
((struct RString*)($arg0))->as.heap.ptr : \
|
2017-01-15 09:08:09 +03:00
|
|
|
((struct RString*)($arg0))->as.ary) @ $len
|
2017-01-25 09:05:51 +03:00
|
|
|
else
|
|
|
|
output ""
|
|
|
|
end
|
2016-06-30 22:36:38 +03:00
|
|
|
end
|
|
|
|
|
2017-09-12 15:49:38 +03:00
|
|
|
define print_string
|
|
|
|
set $flags = ((struct RBasic*)($arg0))->flags
|
|
|
|
set $len = ($flags & RUBY_FL_USER1) ? \
|
|
|
|
((struct RString*)($arg0))->as.heap.len : \
|
|
|
|
(($flags & (RUBY_FL_USER2|RUBY_FL_USER3|RUBY_FL_USER4|RUBY_FL_USER5|RUBY_FL_USER6)) >> RUBY_FL_USHIFT+2)
|
|
|
|
if $len > 0
|
|
|
|
printf "%s", *(char *)(($flags & RUBY_FL_USER1) ? \
|
|
|
|
((struct RString*)($arg0))->as.heap.ptr : \
|
|
|
|
((struct RString*)($arg0))->as.ary) @ $len
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-20 08:53:06 +04:00
|
|
|
define rp_string
|
2017-01-15 09:08:09 +03:00
|
|
|
output_string $arg0
|
|
|
|
printf " bytesize:%ld ", $len
|
2013-09-20 08:53:06 +04:00
|
|
|
if !($flags & RUBY_FL_USER1)
|
|
|
|
printf "(embed) "
|
|
|
|
else
|
|
|
|
if ($flags & RUBY_FL_USER2)
|
|
|
|
printf "(shared) "
|
|
|
|
end
|
|
|
|
if ($flags & RUBY_FL_USER3)
|
|
|
|
printf "(assoc) "
|
|
|
|
end
|
|
|
|
end
|
|
|
|
printf "encoding:%d ", ($flags & RUBY_ENCODING_MASK) >> RUBY_ENCODING_SHIFT
|
|
|
|
if ($flags & RUBY_ENC_CODERANGE_MASK) == 0
|
|
|
|
printf "coderange:unknown "
|
|
|
|
else
|
|
|
|
if ($flags & RUBY_ENC_CODERANGE_MASK) == RUBY_ENC_CODERANGE_7BIT
|
|
|
|
printf "coderange:7bit "
|
|
|
|
else
|
|
|
|
if ($flags & RUBY_ENC_CODERANGE_MASK) == RUBY_ENC_CODERANGE_VALID
|
|
|
|
printf "coderange:valid "
|
|
|
|
else
|
|
|
|
printf "coderange:broken "
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
print (struct RString *)($arg0)
|
|
|
|
end
|
|
|
|
document rp_string
|
|
|
|
Print the content of a String.
|
|
|
|
end
|
|
|
|
|
2017-02-25 05:59:47 +03:00
|
|
|
define rp_bignum
|
|
|
|
set $flags = ((struct RBignum*)($arg0))->basic.flags
|
|
|
|
set $len = (($flags & RUBY_FL_USER2) ? \
|
|
|
|
($flags & (RUBY_FL_USER5|RUBY_FL_USER4|RUBY_FL_USER3)) >> (RUBY_FL_USHIFT+3) : \
|
|
|
|
((struct RBignum*)($arg0))->as.heap.len)
|
|
|
|
printf "%sT_BIGNUM%s: sign=%d len=%ld ", $color_type, $color_end, \
|
|
|
|
(($flags & RUBY_FL_USER1) != 0), $len
|
|
|
|
if $flags & RUBY_FL_USER2
|
|
|
|
printf "(embed) "
|
|
|
|
end
|
|
|
|
print (struct RBignum *)($arg0)
|
|
|
|
set $ptr = (($flags & RUBY_FL_USER2) ? \
|
|
|
|
((struct RBignum*)($arg0))->as.ary : \
|
|
|
|
((struct RBignum*)($arg0))->as.heap.digits)
|
|
|
|
set $len = $len-1
|
|
|
|
printf "0x%x", $ptr[$len]
|
|
|
|
while $len > 0
|
|
|
|
set $len = $len-1
|
|
|
|
set $val = $ptr[$len]
|
|
|
|
set $w = sizeof($ptr[0])
|
|
|
|
printf "_"
|
|
|
|
if $w > 8
|
|
|
|
printf "%.32x", $val
|
|
|
|
else
|
|
|
|
if $w > 4
|
|
|
|
printf "%.16x", $val
|
|
|
|
else
|
|
|
|
if $w > 2
|
|
|
|
printf "%.8x", $val
|
|
|
|
else
|
|
|
|
if $w > 1
|
|
|
|
printf "%.4x", $val
|
|
|
|
else
|
|
|
|
printf "%.2x", $val
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
printf "\n"
|
|
|
|
end
|
|
|
|
document rp_bignum
|
|
|
|
Print the content of a Bignum.
|
|
|
|
end
|
|
|
|
|
2012-07-02 12:07:01 +04:00
|
|
|
define rp_class
|
|
|
|
printf "(struct RClass *) %p", (void*)$arg0
|
2015-03-25 03:41:42 +03:00
|
|
|
if ((struct RClass *)($arg0))->ptr.origin_ != $arg0
|
|
|
|
printf " -> %p", ((struct RClass *)($arg0))->ptr.origin_
|
2012-07-02 12:07:01 +04:00
|
|
|
end
|
|
|
|
printf "\n"
|
2013-08-29 05:20:28 +04:00
|
|
|
rb_classname $arg0
|
2016-11-12 09:12:09 +03:00
|
|
|
print/x *(struct RClass *)($arg0)
|
2012-07-02 12:07:01 +04:00
|
|
|
print *((struct RClass *)($arg0))->ptr
|
|
|
|
end
|
|
|
|
document rp_class
|
|
|
|
Print the content of a Class/Module.
|
|
|
|
end
|
|
|
|
|
2015-03-26 09:50:57 +03:00
|
|
|
define rp_imemo
|
2017-10-25 02:19:57 +03:00
|
|
|
set $flags = (enum imemo_type)((((struct RBasic *)($arg0))->flags >> RUBY_FL_USHIFT) & RUBY_IMEMO_MASK)
|
2015-03-26 09:50:57 +03:00
|
|
|
if $flags == imemo_cref
|
|
|
|
printf "(rb_cref_t *) %p\n", (void*)$arg0
|
|
|
|
print *(rb_cref_t *)$arg0
|
|
|
|
else
|
|
|
|
if $flags == imemo_svar
|
|
|
|
printf "(struct vm_svar *) %p\n", (void*)$arg0
|
|
|
|
print *(struct vm_svar *)$arg0
|
|
|
|
else
|
|
|
|
if $flags == imemo_throw_data
|
|
|
|
printf "(struct vm_throw_data *) %p\n", (void*)$arg0
|
|
|
|
print *(struct vm_throw_data *)$arg0
|
|
|
|
else
|
|
|
|
if $flags == imemo_ifunc
|
|
|
|
printf "(struct vm_ifunc *) %p\n", (void*)$arg0
|
|
|
|
print *(struct vm_ifunc *)$arg0
|
|
|
|
else
|
|
|
|
if $flags == imemo_memo
|
|
|
|
printf "(struct MEMO *) %p\n", (void*)$arg0
|
|
|
|
print *(struct MEMO *)$arg0
|
2016-02-09 05:09:24 +03:00
|
|
|
else
|
|
|
|
if $flags == imemo_ment
|
|
|
|
printf "(rb_method_entry_t *) %p\n", (void*)$arg0
|
|
|
|
print *(rb_method_entry_t *)$arg0
|
|
|
|
else
|
|
|
|
if $flags == imemo_iseq
|
|
|
|
printf "(rb_iseq_t *) %p\n", (void*)$arg0
|
|
|
|
print *(rb_iseq_t *)$arg0
|
2015-03-26 09:50:57 +03:00
|
|
|
else
|
|
|
|
printf "(struct RIMemo *) %p\n", (void*)$arg0
|
|
|
|
print *(struct RIMemo *)$arg0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-02-09 05:09:24 +03:00
|
|
|
end
|
|
|
|
end
|
2015-03-26 09:50:57 +03:00
|
|
|
end
|
|
|
|
document rp_imemo
|
|
|
|
Print the content of a memo
|
|
|
|
end
|
|
|
|
|
2007-07-05 05:42:09 +04:00
|
|
|
define nd_type
|
2009-05-21 17:17:54 +04:00
|
|
|
print (enum node_type)((((NODE*)($arg0))->flags&RUBY_NODE_TYPEMASK)>>RUBY_NODE_TYPESHIFT)
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
document nd_type
|
|
|
|
Print a Ruby' node type.
|
|
|
|
end
|
|
|
|
|
|
|
|
define nd_file
|
2009-05-21 17:17:54 +04:00
|
|
|
print ((NODE*)($arg0))->nd_file
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
document nd_file
|
|
|
|
Print the source file name of a node.
|
|
|
|
end
|
|
|
|
|
|
|
|
define nd_line
|
2009-05-21 17:17:54 +04:00
|
|
|
print ((unsigned int)((((NODE*)($arg0))->flags>>RUBY_NODE_LSHIFT)&RUBY_NODE_LMASK))
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
document nd_line
|
|
|
|
Print the source line number of a node.
|
|
|
|
end
|
|
|
|
|
|
|
|
# Print members of ruby node.
|
|
|
|
|
|
|
|
define nd_head
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_alen
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.argc%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u2.argc
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_next
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_cond
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_body
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_else
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_orig
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.value%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.value
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_resq
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_ensr
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_1st
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_2nd
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_stts
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_entry
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.entry%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u3.entry
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_vid
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u1.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_cflag
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u2.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_cval
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.value%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.value
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_tbl
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.tbl%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u1.tbl
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_var
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_ibdy
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_iter
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_value
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_aid
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u3.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_lit
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.value%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.value
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_rest
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.argc%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u2.argc
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_opt
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_recv
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_mid
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u2.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_args
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_defn
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_old
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u1.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_new
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u2.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_cname
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u1.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_super
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u3.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_modl
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u1.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_clss
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.value%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.value
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_beg
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u1.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_end
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.node%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.node
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_state
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su3.state%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u3.state
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_rval
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.value%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.value
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_nth
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.argc%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u2.argc
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
define nd_tag
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su1.id%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
p ($arg0).u1.id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define nd_tval
|
2013-02-16 09:46:06 +04:00
|
|
|
printf "%su2.value%s: ", $color_highlite, $color_end
|
2009-05-21 17:17:54 +04:00
|
|
|
rp ($arg0).u2.value
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
2014-10-12 21:35:25 +04:00
|
|
|
define nd_tree
|
|
|
|
set $buf = (struct RString *)rb_str_buf_new(0)
|
2017-05-17 07:44:12 +03:00
|
|
|
call dump_node((VALUE)($buf), rb_str_tmp_new(0), 0, ($arg0))
|
2014-10-12 21:35:25 +04:00
|
|
|
printf "%s\n", $buf->as.heap.ptr
|
|
|
|
end
|
|
|
|
|
2007-07-05 05:42:09 +04:00
|
|
|
define rb_p
|
|
|
|
call rb_p($arg0)
|
|
|
|
end
|
|
|
|
|
2009-10-19 10:17:31 +04:00
|
|
|
define rb_numtable_entry
|
|
|
|
set $rb_numtable_tbl = $arg0
|
|
|
|
set $rb_numtable_id = (st_data_t)$arg1
|
|
|
|
set $rb_numtable_key = 0
|
|
|
|
set $rb_numtable_rec = 0
|
|
|
|
if $rb_numtable_tbl->entries_packed
|
2012-03-08 11:44:08 +04:00
|
|
|
set $rb_numtable_p = $rb_numtable_tbl->as.packed.bins
|
|
|
|
while $rb_numtable_p && $rb_numtable_p < $rb_numtable_tbl->as.packed.bins+$rb_numtable_tbl->num_entries
|
|
|
|
if $rb_numtable_p.k == $rb_numtable_id
|
|
|
|
set $rb_numtable_key = $rb_numtable_p.k
|
|
|
|
set $rb_numtable_rec = $rb_numtable_p.v
|
2009-10-19 10:17:31 +04:00
|
|
|
set $rb_numtable_p = 0
|
|
|
|
else
|
2012-03-08 11:44:08 +04:00
|
|
|
set $rb_numtable_p = $rb_numtable_p + 1
|
2009-10-19 10:17:31 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
else
|
2014-03-23 18:47:04 +04:00
|
|
|
set $rb_numtable_p = $rb_numtable_tbl->as.big.bins[st_numhash($rb_numtable_id) % $rb_numtable_tbl->num_bins]
|
2009-10-19 10:17:31 +04:00
|
|
|
while $rb_numtable_p
|
|
|
|
if $rb_numtable_p->key == $rb_numtable_id
|
|
|
|
set $rb_numtable_key = $rb_numtable_p->key
|
|
|
|
set $rb_numtable_rec = $rb_numtable_p->record
|
|
|
|
set $rb_numtable_p = 0
|
|
|
|
else
|
|
|
|
set $rb_numtable_p = $rb_numtable_p->next
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2007-07-05 05:42:09 +04:00
|
|
|
define rb_id2name
|
2013-12-13 05:36:29 +04:00
|
|
|
ruby_gdb_init
|
2013-09-20 08:53:04 +04:00
|
|
|
printf "%sID%s: ", $color_type, $color_end
|
|
|
|
rp_id $arg0
|
2009-10-19 10:17:31 +04:00
|
|
|
end
|
|
|
|
document rb_id2name
|
|
|
|
Print the name of id
|
|
|
|
end
|
|
|
|
|
|
|
|
define rb_method_entry
|
|
|
|
set $rb_method_entry_klass = (struct RClass *)$arg0
|
|
|
|
set $rb_method_entry_id = (ID)$arg1
|
|
|
|
set $rb_method_entry_me = (rb_method_entry_t *)0
|
|
|
|
while !$rb_method_entry_me && $rb_method_entry_klass
|
2013-12-03 12:11:07 +04:00
|
|
|
rb_numtable_entry $rb_method_entry_klass->m_tbl_wrapper->tbl $rb_method_entry_id
|
2009-10-19 10:17:31 +04:00
|
|
|
set $rb_method_entry_me = (rb_method_entry_t *)$rb_numtable_rec
|
|
|
|
if !$rb_method_entry_me
|
2014-03-19 04:42:26 +04:00
|
|
|
set $rb_method_entry_klass = (struct RClass *)RCLASS_SUPER($rb_method_entry_klass)
|
2009-10-19 10:17:31 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
if $rb_method_entry_me
|
|
|
|
print *$rb_method_entry_klass
|
|
|
|
print *$rb_method_entry_me
|
|
|
|
else
|
|
|
|
echo method not found\n
|
|
|
|
end
|
|
|
|
end
|
|
|
|
document rb_method_entry
|
|
|
|
Search method entry by class and id
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
define rb_classname
|
2013-08-29 05:20:24 +04:00
|
|
|
# up to 128bit int
|
2016-11-15 15:42:04 +03:00
|
|
|
set $rb_classname = rb_mod_name($arg0)
|
2013-08-29 05:20:24 +04:00
|
|
|
if $rb_classname != RUBY_Qnil
|
|
|
|
rp $rb_classname
|
|
|
|
else
|
|
|
|
echo anonymous class/module\n
|
|
|
|
end
|
2007-07-05 05:42:09 +04:00
|
|
|
end
|
|
|
|
|
2012-07-02 12:07:01 +04:00
|
|
|
define rb_ancestors
|
|
|
|
set $rb_ancestors_module = $arg0
|
|
|
|
while $rb_ancestors_module
|
2013-08-29 05:20:28 +04:00
|
|
|
rp_class $rb_ancestors_module
|
2014-03-19 04:42:26 +04:00
|
|
|
set $rb_ancestors_module = RCLASS_SUPER($rb_ancestors_module)
|
2012-07-02 12:07:01 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
document rb_ancestors
|
|
|
|
Print ancestors.
|
|
|
|
end
|
|
|
|
|
2007-07-05 05:42:09 +04:00
|
|
|
define rb_backtrace
|
|
|
|
call rb_backtrace()
|
|
|
|
end
|
2009-02-13 17:33:48 +03:00
|
|
|
|
|
|
|
define iseq
|
2013-02-16 16:11:37 +04:00
|
|
|
if ruby_dummy_gdb_enums.special_consts
|
2009-06-15 06:04:36 +04:00
|
|
|
end
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0)->type == ISEQ_ELEMENT_NONE
|
2009-02-13 17:33:48 +03:00
|
|
|
echo [none]\n
|
|
|
|
end
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0)->type == ISEQ_ELEMENT_LABEL
|
|
|
|
print *(LABEL*)($arg0)
|
2009-02-13 17:33:48 +03:00
|
|
|
end
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0)->type == ISEQ_ELEMENT_INSN
|
|
|
|
print *(INSN*)($arg0)
|
|
|
|
if ((INSN*)($arg0))->insn_id != YARVINSN_jump
|
2009-02-13 17:33:48 +03:00
|
|
|
set $i = 0
|
2009-05-21 17:17:54 +04:00
|
|
|
set $operand_size = ((INSN*)($arg0))->operand_size
|
|
|
|
set $operands = ((INSN*)($arg0))->operands
|
2009-02-13 17:33:48 +03:00
|
|
|
while $i < $operand_size
|
|
|
|
rp $operands[$i++]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2009-05-21 17:17:54 +04:00
|
|
|
if ($arg0)->type == ISEQ_ELEMENT_ADJUST
|
|
|
|
print *(ADJUST*)($arg0)
|
2009-02-13 17:33:48 +03:00
|
|
|
end
|
|
|
|
end
|
2009-10-19 06:34:40 +04:00
|
|
|
|
|
|
|
define rb_ps
|
2017-10-29 09:16:10 +03:00
|
|
|
rb_ps_vm ruby_current_vm_ptr
|
2009-10-19 06:34:40 +04:00
|
|
|
end
|
|
|
|
document rb_ps
|
|
|
|
Dump all threads and their callstacks
|
|
|
|
end
|
|
|
|
|
|
|
|
define rb_ps_vm
|
|
|
|
print $ps_vm = (rb_vm_t*)$arg0
|
2015-07-29 04:39:17 +03:00
|
|
|
set $ps_thread_ln = $ps_vm->living_threads.n.next
|
|
|
|
set $ps_thread_ln_last = $ps_vm->living_threads.n.prev
|
|
|
|
while 1
|
|
|
|
set $ps_thread_th = (rb_thread_t *)$ps_thread_ln
|
|
|
|
set $ps_thread = (VALUE)($ps_thread_th->self)
|
|
|
|
rb_ps_thread $ps_thread
|
|
|
|
if $ps_thread_ln == $ps_thread_ln_last
|
|
|
|
loop_break
|
2009-10-19 06:34:40 +04:00
|
|
|
end
|
2015-07-29 04:39:17 +03:00
|
|
|
set $ps_thread_ln = $ps_thread_ln->next
|
2009-10-19 06:34:40 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
document rb_ps_vm
|
|
|
|
Dump all threads in a (rb_vm_t*) and their callstacks
|
|
|
|
end
|
|
|
|
|
2016-06-30 22:36:38 +03:00
|
|
|
define print_lineno
|
|
|
|
set $cfp = $arg0
|
|
|
|
set $iseq = $cfp->iseq
|
|
|
|
set $pos = $cfp->pc - $iseq->body->iseq_encoded
|
|
|
|
if $pos != 0
|
|
|
|
set $pos = $pos - 1
|
|
|
|
end
|
|
|
|
|
2018-02-10 09:02:37 +03:00
|
|
|
set $index = 0
|
2018-01-09 04:46:07 +03:00
|
|
|
set $size = $iseq->body->insns_info.size
|
|
|
|
set $table = $iseq->body->insns_info.body
|
|
|
|
set $positions = $iseq->body->insns_info.positions
|
2016-06-30 22:36:38 +03:00
|
|
|
#printf "size: %d\n", $size
|
|
|
|
if $size == 0
|
|
|
|
else
|
2018-02-10 09:02:37 +03:00
|
|
|
if $size == 1
|
|
|
|
printf "%d", $table[0].line_no
|
|
|
|
else
|
|
|
|
if $positions
|
|
|
|
# get_insn_info_linear_search
|
|
|
|
set $index = 1
|
|
|
|
while $index < $size
|
|
|
|
#printf "table[%d]: position: %d, line: %d, pos: %d\n", $i, $positions[$i], $table[$i].line_no, $pos
|
|
|
|
if $positions[$index] > $pos
|
|
|
|
loop_break
|
|
|
|
end
|
|
|
|
set $index = $index + 1
|
|
|
|
if $positions[$index] == $pos
|
|
|
|
loop_break
|
|
|
|
end
|
2016-06-30 22:36:38 +03:00
|
|
|
end
|
2018-02-10 09:02:37 +03:00
|
|
|
else
|
|
|
|
# get_insn_info_succinct_bitvector
|
|
|
|
set $sd = $iseq->body->insns_info.succ_index_table
|
|
|
|
set $immediate_table_size = sizeof($sd->imm_part) / sizeof(uint64_t) * 9
|
|
|
|
if $pos < $immediate_table_size
|
|
|
|
set $i = $pos / 9
|
|
|
|
set $j = $pos % 9
|
|
|
|
set $index = ((int)($sd->imm_part[$i] >> ($j * 7))) & 0x7f
|
|
|
|
else
|
|
|
|
set $block_index = ($pos - $immediate_table_size) / 512
|
|
|
|
set $block = &$sd->succ_part[$block_index]
|
|
|
|
set $block_bit_index = ($pos - $immediate_table_size) % 512
|
|
|
|
set $small_block_index = $block_bit_index / 64
|
|
|
|
set $small_block_popcount = $small_block_index == 0 ? 0 : (((int)($block->small_block_ranks >> (($small_block_index - 1) * 9))) & 0x1ff)
|
|
|
|
set $x = $block->bits[$small_block_index] << (63 - $block_bit_index % 64)
|
|
|
|
set $x = ($x & 0x5555555555555555) + ($x >> 1 & 0x5555555555555555)
|
|
|
|
set $x = ($x & 0x3333333333333333) + ($x >> 2 & 0x3333333333333333)
|
|
|
|
set $x = ($x & 0x0707070707070707) + ($x >> 4 & 0x0707070707070707)
|
|
|
|
set $x = ($x & 0x001f001f001f001f) + ($x >> 8 & 0x001f001f001f001f)
|
|
|
|
set $x = ($x & 0x0000003f0000003f) + ($x >>16 & 0x0000003f0000003f)
|
|
|
|
set $popcnt = ($x & 0x7f) + ($x >>32 & 0x7f)
|
|
|
|
set $index = $block->rank + $small_block_popcount + $popcnt
|
2016-06-30 22:36:38 +03:00
|
|
|
end
|
|
|
|
end
|
2018-02-10 09:02:37 +03:00
|
|
|
printf "%d", $table[$index-1].line_no
|
|
|
|
end
|
2016-06-30 22:36:38 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-07-01 12:24:59 +03:00
|
|
|
define check_method_entry
|
|
|
|
set $imemo = (struct RBasic *)$arg0
|
2016-08-24 10:56:51 +03:00
|
|
|
if $imemo != RUBY_Qfalse
|
2016-07-01 12:24:59 +03:00
|
|
|
set $type = ($imemo->flags >> 12) & 0x07
|
|
|
|
if $type == imemo_ment
|
|
|
|
set $me = (rb_callable_method_entry_t *)$imemo
|
|
|
|
else
|
|
|
|
if $type == imemo_svar
|
2017-09-11 11:50:08 +03:00
|
|
|
set $imemo = ((struct vm_svar *)$imemo)->cref_or_me
|
|
|
|
check_method_entry $imemo
|
2016-07-01 12:24:59 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-09-12 15:49:38 +03:00
|
|
|
define print_id
|
2016-07-01 12:24:59 +03:00
|
|
|
set $id = $arg0
|
|
|
|
# rb_id_to_serial
|
|
|
|
if $id > tLAST_OP_ID
|
2016-08-24 10:56:51 +03:00
|
|
|
set $serial = (rb_id_serial_t)($id >> RUBY_ID_SCOPE_SHIFT)
|
2016-07-01 12:24:59 +03:00
|
|
|
else
|
|
|
|
set $serial = (rb_id_serial_t)$id
|
|
|
|
end
|
2019-05-16 09:43:16 +03:00
|
|
|
if $serial && $serial <= ruby_global_symbols.last_id
|
2016-07-01 12:24:59 +03:00
|
|
|
set $idx = $serial / ID_ENTRY_UNIT
|
2019-05-16 09:43:16 +03:00
|
|
|
set $ids = (struct RArray *)ruby_global_symbols.ids
|
2016-07-01 12:24:59 +03:00
|
|
|
set $flags = $ids->basic.flags
|
|
|
|
if ($flags & RUBY_FL_USER1)
|
|
|
|
set $idsptr = $ids->as.ary
|
|
|
|
set $idslen = (($flags & (RUBY_FL_USER3|RUBY_FL_USER4)) >> (RUBY_FL_USHIFT+3))
|
|
|
|
else
|
|
|
|
set $idsptr = $ids->as.heap.ptr
|
|
|
|
set $idslen = $ids->as.heap.len
|
|
|
|
end
|
|
|
|
if $idx < $idslen
|
|
|
|
set $t = 0
|
|
|
|
set $ary = (struct RArray *)$idsptr[$idx]
|
2016-08-24 10:56:51 +03:00
|
|
|
if $ary != RUBY_Qnil
|
2016-07-01 12:24:59 +03:00
|
|
|
set $flags = $ary->basic.flags
|
|
|
|
if ($flags & RUBY_FL_USER1)
|
|
|
|
set $aryptr = $ary->as.ary
|
|
|
|
set $arylen = (($flags & (RUBY_FL_USER3|RUBY_FL_USER4)) >> (RUBY_FL_USHIFT+3))
|
|
|
|
else
|
|
|
|
set $aryptr = $ary->as.heap.ptr
|
|
|
|
set $arylen = $ary->as.heap.len
|
|
|
|
end
|
|
|
|
set $result = $aryptr[($serial % ID_ENTRY_UNIT) * ID_ENTRY_SIZE + $t]
|
2017-10-06 09:11:25 +03:00
|
|
|
if $result != RUBY_Qnil
|
|
|
|
print_string $result
|
|
|
|
else
|
2017-10-08 08:14:18 +03:00
|
|
|
echo undef
|
2017-10-06 09:11:25 +03:00
|
|
|
end
|
2016-07-01 12:24:59 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-09-12 15:49:38 +03:00
|
|
|
define print_pathobj
|
2017-09-11 11:50:08 +03:00
|
|
|
set $flags = ((struct RBasic*)($arg0))->flags
|
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_STRING
|
2017-09-12 15:49:38 +03:00
|
|
|
print_string $arg0
|
2017-09-11 11:50:08 +03:00
|
|
|
end
|
|
|
|
if ($flags & RUBY_T_MASK) == RUBY_T_ARRAY
|
|
|
|
if $flags & RUBY_FL_USER1
|
|
|
|
set $str = ((struct RArray*)($arg0))->as.ary[0]
|
|
|
|
else
|
|
|
|
set $str = ((struct RArray*)($arg0))->as.heap.ptr[0]
|
|
|
|
end
|
2017-11-18 09:24:52 +03:00
|
|
|
print_string $str
|
2017-09-11 11:50:08 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2009-10-19 06:34:40 +04:00
|
|
|
define rb_ps_thread
|
|
|
|
set $ps_thread = (struct RTypedData*)$arg0
|
2015-07-29 04:39:17 +03:00
|
|
|
set $ps_thread_th = (rb_thread_t*)$ps_thread->data
|
|
|
|
printf "* #<Thread:%p rb_thread_t:%p native_thread:%p>\n", \
|
|
|
|
$ps_thread, $ps_thread_th, $ps_thread_th->thread_id
|
2017-10-26 11:32:49 +03:00
|
|
|
set $cfp = $ps_thread_th->ec->cfp
|
2017-11-08 17:14:54 +03:00
|
|
|
set $cfpend = (rb_control_frame_t *)($ps_thread_th->ec->vm_stack + $ps_thread_th->ec->vm_stack_size)-1
|
2016-06-30 22:36:38 +03:00
|
|
|
while $cfp < $cfpend
|
|
|
|
if $cfp->iseq
|
2017-10-25 02:19:57 +03:00
|
|
|
if !((VALUE)$cfp->iseq & RUBY_IMMEDIATE_MASK) && (((imemo_ifunc << RUBY_FL_USHIFT) | RUBY_T_IMEMO)==$cfp->iseq->flags & ((RUBY_IMEMO_MASK << RUBY_FL_USHIFT) | RUBY_T_MASK))
|
2017-09-12 15:49:38 +03:00
|
|
|
printf "%d:ifunc ", $cfpend-$cfp
|
2017-09-11 11:50:08 +03:00
|
|
|
set print symbol-filename on
|
|
|
|
output/a $cfp->iseq.body
|
|
|
|
set print symbol-filename off
|
|
|
|
printf "\n"
|
|
|
|
else
|
2016-06-30 22:36:38 +03:00
|
|
|
if $cfp->pc
|
|
|
|
set $location = $cfp->iseq->body->location
|
2017-09-12 15:49:38 +03:00
|
|
|
printf "%d:", $cfpend-$cfp
|
|
|
|
print_pathobj $location.pathobj
|
2016-06-30 22:36:38 +03:00
|
|
|
printf ":"
|
|
|
|
print_lineno $cfp
|
|
|
|
printf ":in `"
|
2017-09-12 15:49:38 +03:00
|
|
|
print_string $location.label
|
2016-06-30 22:36:38 +03:00
|
|
|
printf "'\n"
|
|
|
|
else
|
2017-09-12 15:49:38 +03:00
|
|
|
printf "%d: ???.rb:???:in `???'\n", $cfpend-$cfp
|
2016-06-30 22:36:38 +03:00
|
|
|
end
|
2017-09-11 11:50:08 +03:00
|
|
|
end
|
2016-06-30 22:36:38 +03:00
|
|
|
else
|
2016-08-24 10:56:51 +03:00
|
|
|
# if VM_FRAME_TYPE($cfp->flag) == VM_FRAME_MAGIC_CFUNC
|
|
|
|
set $ep = $cfp->ep
|
|
|
|
if ($ep[0] & 0xffff0001) == 0x55550001
|
|
|
|
#define VM_ENV_FLAG_LOCAL 0x02
|
|
|
|
#define VM_ENV_PREV_EP(ep) GC_GUARDED_PTR_REF(ep[VM_ENV_DATA_INDEX_SPECVAL])
|
|
|
|
set $me = 0
|
|
|
|
set $env_specval = $ep[-1]
|
|
|
|
set $env_me_cref = $ep[-2]
|
|
|
|
while ($env_specval & 0x02) != 0
|
2017-09-11 11:50:08 +03:00
|
|
|
check_method_entry $env_me_cref
|
2016-08-24 10:56:51 +03:00
|
|
|
if $me != 0
|
2016-07-01 12:24:59 +03:00
|
|
|
loop_break
|
|
|
|
end
|
|
|
|
set $ep = $ep[0]
|
2016-08-24 10:56:51 +03:00
|
|
|
set $env_specval = $ep[-1]
|
|
|
|
set $env_me_cref = $ep[-2]
|
2016-07-01 12:24:59 +03:00
|
|
|
end
|
2016-08-24 10:56:51 +03:00
|
|
|
if $me == 0
|
2017-09-11 11:50:08 +03:00
|
|
|
check_method_entry $env_me_cref
|
2016-07-01 12:24:59 +03:00
|
|
|
end
|
2017-09-12 15:49:38 +03:00
|
|
|
printf "%d:", $cfpend-$cfp
|
2016-07-01 12:24:59 +03:00
|
|
|
set print symbol-filename on
|
|
|
|
output/a $me->def->body.cfunc.func
|
|
|
|
set print symbol-filename off
|
|
|
|
set $mid = $me->def->original_id
|
|
|
|
printf ":in `"
|
2017-09-12 15:49:38 +03:00
|
|
|
print_id $mid
|
2016-07-01 12:24:59 +03:00
|
|
|
printf "'\n"
|
2016-06-30 22:36:38 +03:00
|
|
|
else
|
2017-09-12 15:49:38 +03:00
|
|
|
printf "%d:unknown_frame:???:in `???'\n", $cfpend-$cfp
|
2016-06-30 22:36:38 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
set $cfp = $cfp + 1
|
|
|
|
end
|
2009-10-19 06:34:40 +04:00
|
|
|
end
|
2012-06-07 10:54:24 +04:00
|
|
|
|
2016-07-01 06:13:41 +03:00
|
|
|
define rb_count_objects
|
2017-10-29 09:16:10 +03:00
|
|
|
set $objspace = ruby_current_vm_ptr->objspace
|
2016-07-01 06:13:41 +03:00
|
|
|
set $counts_00 = 0
|
|
|
|
set $counts_01 = 0
|
|
|
|
set $counts_02 = 0
|
|
|
|
set $counts_03 = 0
|
|
|
|
set $counts_04 = 0
|
|
|
|
set $counts_05 = 0
|
|
|
|
set $counts_06 = 0
|
|
|
|
set $counts_07 = 0
|
|
|
|
set $counts_08 = 0
|
|
|
|
set $counts_09 = 0
|
|
|
|
set $counts_0a = 0
|
|
|
|
set $counts_0b = 0
|
|
|
|
set $counts_0c = 0
|
|
|
|
set $counts_0d = 0
|
|
|
|
set $counts_0e = 0
|
|
|
|
set $counts_0f = 0
|
|
|
|
set $counts_10 = 0
|
|
|
|
set $counts_11 = 0
|
|
|
|
set $counts_12 = 0
|
|
|
|
set $counts_13 = 0
|
|
|
|
set $counts_14 = 0
|
|
|
|
set $counts_15 = 0
|
|
|
|
set $counts_16 = 0
|
|
|
|
set $counts_17 = 0
|
|
|
|
set $counts_18 = 0
|
|
|
|
set $counts_19 = 0
|
|
|
|
set $counts_1a = 0
|
|
|
|
set $counts_1b = 0
|
|
|
|
set $counts_1c = 0
|
|
|
|
set $counts_1d = 0
|
|
|
|
set $counts_1e = 0
|
|
|
|
set $counts_1f = 0
|
|
|
|
set $total = 0
|
|
|
|
set $i = 0
|
|
|
|
while $i < $objspace->heap_pages.allocated_pages
|
|
|
|
printf "\rcounting... %d/%d", $i, $objspace->heap_pages.allocated_pages
|
|
|
|
set $page = $objspace->heap_pages.sorted[$i]
|
|
|
|
set $p = $page->start
|
|
|
|
set $pend = $p + $page->total_slots
|
|
|
|
while $p < $pend
|
|
|
|
set $flags = $p->as.basic.flags & 0x1f
|
|
|
|
eval "set $counts_%02x = $counts_%02x + 1", $flags, $flags
|
|
|
|
set $p = $p + 1
|
|
|
|
end
|
|
|
|
set $total = $total + $page->total_slots
|
|
|
|
set $i = $i + 1
|
|
|
|
end
|
|
|
|
printf "\rTOTAL: %d, FREE: %d\n", $total, $counts_00
|
|
|
|
printf "T_OBJECT: %d\n", $counts_01
|
|
|
|
printf "T_CLASS: %d\n", $counts_02
|
|
|
|
printf "T_MODULE: %d\n", $counts_03
|
|
|
|
printf "T_FLOAT: %d\n", $counts_04
|
|
|
|
printf "T_STRING: %d\n", $counts_05
|
|
|
|
printf "T_REGEXP: %d\n", $counts_06
|
|
|
|
printf "T_ARRAY: %d\n", $counts_07
|
|
|
|
printf "T_HASH: %d\n", $counts_08
|
|
|
|
printf "T_STRUCT: %d\n", $counts_09
|
|
|
|
printf "T_BIGNUM: %d\n", $counts_0a
|
|
|
|
printf "T_FILE: %d\n", $counts_0b
|
|
|
|
printf "T_DATA: %d\n", $counts_0c
|
|
|
|
printf "T_MATCH: %d\n", $counts_0d
|
|
|
|
printf "T_COMPLEX: %d\n", $counts_0e
|
|
|
|
printf "T_RATIONAL: %d\n", $counts_0f
|
|
|
|
#printf "UNKNOWN_10: %d\n", $counts_10
|
|
|
|
printf "T_NIL: %d\n", $counts_11
|
|
|
|
printf "T_TRUE: %d\n", $counts_12
|
|
|
|
printf "T_FALSE: %d\n", $counts_13
|
|
|
|
printf "T_SYMBOL: %d\n", $counts_14
|
|
|
|
printf "T_FIXNUM: %d\n", $counts_15
|
|
|
|
printf "T_UNDEF: %d\n", $counts_16
|
|
|
|
#printf "UNKNOWN_17: %d\n", $counts_17
|
|
|
|
#printf "UNKNOWN_18: %d\n", $counts_18
|
|
|
|
#printf "UNKNOWN_19: %d\n", $counts_19
|
|
|
|
printf "T_IMEMO: %d\n", $counts_1a
|
|
|
|
printf "T_NODE: %d\n", $counts_1b
|
|
|
|
printf "T_ICLASS: %d\n", $counts_1c
|
|
|
|
printf "T_ZOMBIE: %d\n", $counts_1d
|
|
|
|
#printf "UNKNOWN_1E: %d\n", $counts_1e
|
|
|
|
printf "T_MASK: %d\n", $counts_1f
|
|
|
|
end
|
|
|
|
document rb_count_objects
|
|
|
|
Counts all objects grouped by type.
|
|
|
|
end
|
|
|
|
|
2020-01-01 09:06:18 +03:00
|
|
|
# Details: https://bugs.ruby-lang.org/projects/ruby-master/wiki/MachineInstructionsTraceWithGDB
|
2012-06-07 10:54:24 +04:00
|
|
|
define trace_machine_instructions
|
|
|
|
set logging on
|
|
|
|
set height 0
|
|
|
|
set width 0
|
|
|
|
display/i $pc
|
|
|
|
while !$exit_code
|
|
|
|
info line *$pc
|
|
|
|
si
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-11 00:24:43 +04:00
|
|
|
define SDR
|
|
|
|
call rb_vmdebug_stack_dump_raw_current()
|
|
|
|
end
|
|
|
|
|
2015-11-10 06:36:08 +03:00
|
|
|
define rbi
|
|
|
|
if ((LINK_ELEMENT*)$arg0)->type == ISEQ_ELEMENT_LABEL
|
|
|
|
p *(LABEL*)$arg0
|
|
|
|
else
|
|
|
|
if ((LINK_ELEMENT*)$arg0)->type == ISEQ_ELEMENT_INSN
|
|
|
|
p *(INSN*)$arg0
|
|
|
|
else
|
|
|
|
if ((LINK_ELEMENT*)$arg0)->type == ISEQ_ELEMENT_ADJUST
|
|
|
|
p *(ADJUST*)$arg0
|
|
|
|
else
|
|
|
|
print *$arg0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-01-15 16:16:53 +03:00
|
|
|
|
|
|
|
define dump_node
|
|
|
|
set $str = rb_parser_dump_tree($arg0, 0)
|
|
|
|
set $flags = ((struct RBasic*)($str))->flags
|
|
|
|
printf "%s", (char *)(($flags & RUBY_FL_USER1) ? \
|
|
|
|
((struct RString*)$str)->as.heap.ptr : \
|
|
|
|
((struct RString*)$str)->as.ary)
|
|
|
|
end
|
2018-06-13 05:50:21 +03:00
|
|
|
|
|
|
|
define print_flags
|
2018-06-14 06:18:10 +03:00
|
|
|
printf "RUBY_FL_WB_PROTECTED: %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_WB_PROTECTED ? "1" : "0"
|
|
|
|
printf "RUBY_FL_PROMOTED0 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_PROMOTED0 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_PROMOTED1 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_PROMOTED1 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_FINALIZE : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_FINALIZE ? "1" : "0"
|
|
|
|
printf "RUBY_FL_TAINT : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_TAINT ? "1" : "0"
|
|
|
|
printf "RUBY_FL_UNTRUSTED : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_UNTRUSTED ? "1" : "0"
|
|
|
|
printf "RUBY_FL_EXIVAR : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_EXIVAR ? "1" : "0"
|
|
|
|
printf "RUBY_FL_FREEZE : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_FREEZE ? "1" : "0"
|
|
|
|
|
|
|
|
printf "RUBY_FL_USER0 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER0 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER1 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER1 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER2 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER2 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER3 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER3 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER4 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER4 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER5 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER5 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER6 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER6 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER7 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER7 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER8 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER8 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER9 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER9 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER10 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER10 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER11 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER11 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER12 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER12 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER13 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER13 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER14 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER14 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER15 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER15 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER16 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER16 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER17 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER17 ? "1" : "0"
|
|
|
|
printf "RUBY_FL_USER18 : %s\n", ((struct RBasic*)($arg0))->flags & RUBY_FL_USER18 ? "1" : "0"
|
2018-06-13 05:50:21 +03:00
|
|
|
end
|