summaryrefslogtreecommitdiff
path: root/debug.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-06-29 07:57:24 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-06-29 07:57:24 +0000
commiteae8a9143f04d6598b564787a45f03b27111cf9d (patch)
tree18c4c0ed798e4464c39750100cf67b8a5957ddd0 /debug.c
parente648fc492344f07744ad3c32d9fbe405c9dd8a43 (diff)
* debug.c (ruby_set_debug_option): separated from main.c.
* gc.c (ruby_gc_stress), signal.c (ruby_enable_coredump): prefixed. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@12665 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'debug.c')
-rw-r--r--debug.c41
1 files changed, 36 insertions, 5 deletions
diff --git a/debug.c b/debug.c
index 1612e80eb5..cd1b80f58c 100644
--- a/debug.c
+++ b/debug.c
@@ -12,6 +12,7 @@
#include "ruby/ruby.h"
#include "debug.h"
+#include "yarvcore.h"
void
ruby_debug_print_indent(int level, int debug_level, int indent_level)
@@ -26,7 +27,7 @@ ruby_debug_print_indent(int level, int debug_level, int indent_level)
}
VALUE
-ruby_debug_print_value(int level, int debug_level, char *header, VALUE obj)
+ruby_debug_print_value(int level, int debug_level, const char *header, VALUE obj)
{
if (level < debug_level) {
VALUE str;
@@ -45,7 +46,7 @@ ruby_debug_print_v(VALUE v)
}
ID
-ruby_debug_print_id(int level, int debug_level, char *header, ID id)
+ruby_debug_print_id(int level, int debug_level, const char *header, ID id)
{
if (level < debug_level) {
fprintf(stderr, "DBG> %s: %s\n", header, rb_id2name(id));
@@ -55,13 +56,13 @@ ruby_debug_print_id(int level, int debug_level, char *header, ID id)
}
NODE *
-ruby_debug_print_node(int level, int debug_level, char *header, NODE *node)
+ruby_debug_print_node(int level, int debug_level, const char *header, const NODE *node)
{
if (level < debug_level) {
- fprintf(stderr, "DBG> %s: %s (%d)\n", header,
+ fprintf(stderr, "DBG> %s: %s (%lu)\n", header,
ruby_node_name(nd_type(node)), nd_line(node));
}
- return node;
+ return (NODE *)node;
}
void
@@ -69,3 +70,33 @@ ruby_debug_breakpoint(void)
{
/* */
}
+
+#ifdef RUBY_DEBUG_ENV
+#include <ctype.h>
+
+void
+ruby_set_debug_option(const char *str)
+{
+ const char *end;
+ int len;
+
+ if (!str) return;
+ for (; *str; str = end) {
+ while (ISSPACE(*str) || *str == ',') str++;
+ if (!*str) break;
+ end = str;
+ while (*end && !ISSPACE(*end) && *end != ',') end++;
+ len = end - str;
+#define SET_WHEN(name, var) \
+ if (len == sizeof(name) - 1 && \
+ strncmp(str, name, len) == 0) { \
+ extern int ruby_##var; \
+ ruby_##var = 1; \
+ continue; \
+ }
+ SET_WHEN("gc_stress", gc_stress);
+ SET_WHEN("core", enable_coredump);
+ fprintf(stderr, "unexpected debug option: %.*s\n", len, str);
+ }
+}
+#endif