summaryrefslogtreecommitdiff
path: root/ext/objspace
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-11-09 06:16:53 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-11-09 06:16:53 +0000
commit90feeb6ab9c9f02a174ac27a5c3bcee6f23aa463 (patch)
treed606408f42f4c0d14111fd8db7a705fd29c575d2 /ext/objspace
parenta50bbcfecb852fea2f90b5c97ce80653ab5c0010 (diff)
objspace_dump.c: extract output option utilities
* ext/objspace/objspace_dump.c (dump_output, dump_result): extract output option utility functions from objspace_dump() and objspace_dump_all(). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43607 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/objspace')
-rw-r--r--ext/objspace/objspace_dump.c89
1 files changed, 44 insertions, 45 deletions
diff --git a/ext/objspace/objspace_dump.c b/ext/objspace/objspace_dump.c
index e3124b0af5..f52b194497 100644
--- a/ext/objspace/objspace_dump.c
+++ b/ext/objspace/objspace_dump.c
@@ -290,6 +290,46 @@ root_obj_i(const char *category, VALUE obj, void *data)
dc->roots++;
}
+static VALUE
+dump_output(struct dump_config *dc, VALUE opts, VALUE output, char *filename)
+{
+ if (RTEST(opts))
+ output = rb_hash_aref(opts, sym_output);
+
+ if (output == sym_stdout) {
+ dc->stream = stdout;
+ dc->string = Qnil;
+ }
+ else if (output == sym_file) {
+ int fd = mkstemp(filename);
+ dc->string = rb_filesystem_str_new_cstr(filename);
+ if (fd == -1) rb_sys_fail_path(dc->string);
+ dc->stream = fdopen(fd, "w");
+ }
+ else if (output == sym_string) {
+ dc->string = rb_str_new_cstr("");
+ }
+ else {
+ rb_raise(rb_eArgError, "wrong output option: %"PRIsVALUE, output);
+ }
+ return output;
+}
+
+static VALUE
+dump_result(struct dump_config *dc, VALUE output)
+{
+ if (output == sym_string) {
+ return dc->string;
+ }
+ else if (output == sym_file) {
+ fclose(dc->stream);
+ return dc->string;
+ }
+ else {
+ return Qnil;
+ }
+}
+
/*
* call-seq:
* ObjectSpace.dump(obj[, output: :string]) # => "{ ... }"
@@ -307,38 +347,17 @@ root_obj_i(const char *category, VALUE obj, void *data)
static VALUE
objspace_dump(int argc, VALUE *argv, VALUE os)
{
- int fd;
char filename[] = "/tmp/rubyobjXXXXXX";
VALUE obj = Qnil, opts = Qnil, output;
struct dump_config dc = {0,};
rb_scan_args(argc, argv, "1:", &obj, &opts);
- if (RTEST(opts))
- output = rb_hash_aref(opts, sym_output);
-
- if (output == sym_stdout)
- dc.stream = stdout;
- else if (output == sym_file) {
- fd = mkstemp(filename);
- if (fd == -1) rb_sys_fail_path(rb_str_new_cstr(filename));
- dc.stream = fdopen(fd, "w");
- }
- else {
- output = sym_string;
- dc.string = rb_str_new2("");
- }
+ output = dump_output(&dc, opts, sym_string, filename);
dump_object(obj, &dc);
- if (output == sym_string)
- return dc.string;
- else if (output == sym_file) {
- fclose(dc.stream);
- return rb_str_new2(filename);
- }
- else
- return Qnil;
+ return dump_result(&dc, output);
}
/*
@@ -358,26 +377,13 @@ objspace_dump(int argc, VALUE *argv, VALUE os)
static VALUE
objspace_dump_all(int argc, VALUE *argv, VALUE os)
{
- int fd;
char filename[] = "/tmp/rubyheapXXXXXX";
VALUE opts = Qnil, output;
struct dump_config dc = {0,};
rb_scan_args(argc, argv, "0:", &opts);
- if (RTEST(opts))
- output = rb_hash_aref(opts, sym_output);
-
- if (output == sym_string)
- dc.string = rb_str_new2("");
- else if (output == sym_stdout)
- dc.stream = stdout;
- else {
- output = sym_file;
- fd = mkstemp(filename);
- if (fd == -1) rb_sys_fail_path(rb_str_new_cstr(filename));
- dc.stream = fdopen(fd, "w");
- }
+ output = dump_output(&dc, opts, sym_file, filename);
/* dump roots */
rb_objspace_reachable_objects_from_root(root_obj_i, &dc);
@@ -386,14 +392,7 @@ objspace_dump_all(int argc, VALUE *argv, VALUE os)
/* dump all objects */
rb_objspace_each_objects(heap_i, &dc);
- if (output == sym_string)
- return dc.string;
- else if (output == sym_file) {
- fclose(dc.stream);
- return rb_str_new2(filename);
- }
- else
- return Qnil;
+ return dump_result(&dc, output);
}
void