From bbb367841a7ea6bdc420342d31d7c0f33afaa128 Mon Sep 17 00:00:00 2001 From: Masaki Muranaka Date: Sat, 23 Mar 2013 19:33:25 +0900 Subject: Add new API mrb_ptr_as_string(). --- include/mruby/string.h | 1 + src/string.c | 30 ++++++++++++++++++++++++++++++ 2 files changed, 31 insertions(+) diff --git a/include/mruby/string.h b/include/mruby/string.h index 3dc4094aa..df41497ab 100644 --- a/include/mruby/string.h +++ b/include/mruby/string.h @@ -43,6 +43,7 @@ void mrb_str_decref(mrb_state*, mrb_shared_string*); mrb_value mrb_str_literal(mrb_state*, mrb_value); void mrb_str_concat(mrb_state*, mrb_value, mrb_value); mrb_value mrb_str_plus(mrb_state*, mrb_value, mrb_value); +mrb_value mrb_ptr_as_string(mrb_state *, void *); mrb_value mrb_obj_as_string(mrb_state *mrb, mrb_value obj); mrb_value mrb_str_resize(mrb_state *mrb, mrb_value str, int len); /* mrb_str_resize */ mrb_value mrb_string_value(mrb_state *mrb, mrb_value *ptr); /* StringValue */ diff --git a/src/string.c b/src/string.c index 165cdbccd..15abb47d7 100644 --- a/src/string.c +++ b/src/string.c @@ -1534,6 +1534,36 @@ mrb_obj_as_string(mrb_state *mrb, mrb_value obj) return str; } +mrb_value +mrb_ptr_as_string(mrb_state *mrb, void *p) +{ + struct RString *p_str; + char *p1; + char *p2; + intptr_t n = (intptr_t)p; + + p_str = str_new(mrb, NULL, 2 + sizeof(uintptr_t) * CHAR_BIT / 4); + p1 = p_str->ptr; + *p1++ = '0'; + *p1++ = 'x'; + p2 = p1; + + do { + *p2++ = mrb_digitmap[n % 16]; + n /= 16; + } while (n > 0); + *p2 = '\0'; + p_str->len = (mrb_int)(p2 - p_str->ptr); + + while (p1 < p2) { + const char c = *p1; + *p1++ = *--p2; + *p2 = c; + } + + return mrb_obj_value(p_str); +} + mrb_value mrb_check_string_type(mrb_state *mrb, mrb_value str) { -- cgit v1.2.3 From bdd8f7b4a7321675d72322f518e8252e0f7422ef Mon Sep 17 00:00:00 2001 From: Masaki Muranaka Date: Sat, 23 Mar 2013 20:11:33 +0900 Subject: Remove *printf() that have "%p" format as possible. Use tomrb_ptr_as_string() instead. --- src/class.c | 42 ++++++++++++++++++++++-------------------- src/object.c | 9 ++++++++- src/variable.c | 7 ++++++- 3 files changed, 36 insertions(+), 22 deletions(-) diff --git a/src/class.c b/src/class.c index da898383d..bdb9e016c 100644 --- a/src/class.c +++ b/src/class.c @@ -1228,10 +1228,9 @@ mrb_class_name(mrb_state *mrb, struct RClass* c) { mrb_value path = mrb_class_path(mrb, c); if (mrb_nil_p(path)) { - char buf[32]; - - snprintf(buf, 32, "#", c); - path = mrb_str_new_cstr(mrb, buf); + path = mrb_str_new(mrb, "#", 1); } return mrb_str_ptr(path)->ptr; } @@ -1350,51 +1349,54 @@ mrb_define_alias(mrb_state *mrb, struct RClass *klass, const char *name1, const static mrb_value mrb_mod_to_s(mrb_state *mrb, mrb_value klass) { + mrb_value str; + if (mrb_type(klass) == MRB_TT_SCLASS) { - mrb_value s = mrb_str_new(mrb, "#<", 2); mrb_value v = mrb_iv_get(mrb, klass, mrb_intern2(mrb, "__attached__", 12)); - mrb_str_cat(mrb, s, "Class:", 6); + str = mrb_str_new(mrb, "#", 1); - - return s; + mrb_str_cat(mrb, str, ">", 1); } else { + str = mrb_str_buf_new(mrb, 32); struct RClass *c = mrb_class_ptr(klass); - const char *cn = mrb_class_name(mrb, c); - - if (!cn) { - char buf[256]; - int n = 0; + mrb_value path = mrb_class_path(mrb, c); + if (mrb_nil_p(path)) { switch (mrb_type(klass)) { case MRB_TT_CLASS: - n = snprintf(buf, sizeof(buf), "#", c); + mrb_str_cat(mrb, str, "#", c); + mrb_str_cat(mrb, str, "#", 1); } else { - return mrb_str_dup(mrb, mrb_str_new_cstr(mrb, cn)); + str = path; } } + + return str; } mrb_value diff --git a/src/object.c b/src/object.c index 99f11540b..bf0956acd 100644 --- a/src/object.c +++ b/src/object.c @@ -439,8 +439,15 @@ mrb_check_type(mrb_state *mrb, mrb_value x, enum mrb_vtype t) mrb_value mrb_any_to_s(mrb_state *mrb, mrb_value obj) { + mrb_value str = mrb_str_buf_new(mrb, 20); const char *cname = mrb_obj_classname(mrb, obj); - return mrb_sprintf(mrb, "#<%s:%p>", cname, mrb_voidp(obj)); + + mrb_str_buf_cat(mrb, str, "#<", 2); + mrb_str_cat2(mrb, str, cname); + mrb_str_concat(mrb, str, mrb_ptr_as_string(mrb, mrb_voidp(obj))); + mrb_str_buf_cat(mrb, str, ">", 1); + + return str; } /* diff --git a/src/variable.c b/src/variable.c index df89397d7..3f1424ee5 100644 --- a/src/variable.c +++ b/src/variable.c @@ -545,7 +545,12 @@ mrb_obj_iv_inspect(mrb_state *mrb, struct RObject *obj) if (len > 0) { const char *cn = mrb_obj_classname(mrb, mrb_obj_value(obj)); - mrb_value str = mrb_sprintf(mrb, "-<%s:%p", cn, (void*)obj); + mrb_value str = mrb_str_buf_new(mrb, 30); + + mrb_str_buf_cat(mrb, str, "-<", 2); + mrb_str_cat2(mrb, str, cn); + mrb_str_cat(mrb, str, ":", 1); + mrb_str_concat(mrb, str, mrb_ptr_as_string(mrb, obj)); iv_foreach(mrb, t, inspect_i, &str); mrb_str_cat(mrb, str, ">", 1); -- cgit v1.2.3