summaryrefslogtreecommitdiffhomepage
path: root/src/print.c
diff options
context:
space:
mode:
authorAsmod4n <[email protected]>2015-09-17 13:24:17 +0200
committerAsmod4n <[email protected]>2015-09-17 13:24:17 +0200
commite6d9b450bab46f218e6bee2c95114b733660951a (patch)
treee6e296d99ad3780e769a5bae0d71bb5a6de75c9a /src/print.c
parent13a2cc3e5d27c33db7f4cf06ece4c44a79c79c53 (diff)
parent070e04ea22d832c323e56ff75242f08ca3022fa8 (diff)
downloadmruby-e6d9b450bab46f218e6bee2c95114b733660951a.tar.gz
mruby-e6d9b450bab46f218e6bee2c95114b733660951a.zip
Merge remote-tracking branch 'mruby/master'
Diffstat (limited to 'src/print.c')
-rw-r--r--src/print.c40
1 files changed, 12 insertions, 28 deletions
diff --git a/src/print.c b/src/print.c
index b43936b13..077fa4f06 100644
--- a/src/print.c
+++ b/src/print.c
@@ -8,49 +8,35 @@
#include "mruby/string.h"
#include "mruby/variable.h"
+#ifdef ENABLE_STDIO
static void
-printstr(mrb_state *mrb, mrb_value obj)
+printstr(mrb_value obj, FILE *stream)
{
-#ifdef ENABLE_STDIO
- char *s;
- int len;
-
if (mrb_string_p(obj)) {
- s = RSTRING_PTR(obj);
- len = RSTRING_LEN(obj);
- fwrite(s, len, 1, stdout);
+ fwrite(RSTRING_PTR(obj), RSTRING_LEN(obj), 1, stream);
+ putc('\n', stream);
}
-#endif
}
+#else
+# define printstr(obj, stream) (void)0
+#endif
MRB_API void
mrb_p(mrb_state *mrb, mrb_value obj)
{
-#ifdef ENABLE_STDIO
- mrb_value val;
+ mrb_value val = mrb_inspect(mrb, obj);
- val = mrb_funcall(mrb, obj, "inspect", 0);
- if (!mrb_string_p(val)) {
- val = mrb_obj_as_string(mrb, obj);
- }
- printstr(mrb, val);
- putc('\n', stdout);
-#endif
+ printstr(val, stdout);
}
MRB_API void
mrb_print_error(mrb_state *mrb)
{
-#ifdef ENABLE_STDIO
mrb_value s;
mrb_print_backtrace(mrb);
s = mrb_funcall(mrb, mrb_obj_value(mrb->exc), "inspect", 0);
- if (mrb_string_p(s)) {
- fwrite(RSTRING_PTR(s), RSTRING_LEN(s), 1, stderr);
- putc('\n', stderr);
- }
-#endif
+ printstr(s, stderr);
}
MRB_API void
@@ -59,8 +45,7 @@ mrb_show_version(mrb_state *mrb)
mrb_value msg;
msg = mrb_const_get(mrb, mrb_obj_value(mrb->object_class), mrb_intern_lit(mrb, "MRUBY_DESCRIPTION"));
- printstr(mrb, msg);
- printstr(mrb, mrb_str_new_lit(mrb, "\n"));
+ printstr(msg, stdout);
}
MRB_API void
@@ -69,6 +54,5 @@ mrb_show_copyright(mrb_state *mrb)
mrb_value msg;
msg = mrb_const_get(mrb, mrb_obj_value(mrb->object_class), mrb_intern_lit(mrb, "MRUBY_COPYRIGHT"));
- printstr(mrb, msg);
- printstr(mrb, mrb_str_new_lit(mrb, "\n"));
+ printstr(msg, stdout);
}