summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorJon <[email protected]>2012-06-03 10:04:51 -0400
committerJon <[email protected]>2012-06-03 11:11:35 -0400
commit2fff59dc8674ad6689acc5080463eede4c5bb2ab (patch)
tree605bd27f9e7b00abde90d0df0e57956ed39c9c0b /src
parent49aa42f3a99195bb64f97f37ebb4748716be5ecd (diff)
downloadmruby-2fff59dc8674ad6689acc5080463eede4c5bb2ab.tar.gz
mruby-2fff59dc8674ad6689acc5080463eede4c5bb2ab.zip
Check mrb_open return value for NULL
Diffstat (limited to 'src')
-rw-r--r--src/codegen.c5
-rw-r--r--src/gc.c40
-rw-r--r--src/parse.y5
3 files changed, 50 insertions, 0 deletions
diff --git a/src/codegen.c b/src/codegen.c
index 117588b6e..027b6777f 100644
--- a/src/codegen.c
+++ b/src/codegen.c
@@ -2292,6 +2292,11 @@ main()
mrb_state *mrb = mrb_open();
int n;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting codegen test");
+ return EXIT_FAILURE;
+ }
+
#if 1
n = mrb_compile_string(mrb, "p(__FILE__)\np(__LINE__)");
#else
diff --git a/src/gc.c b/src/gc.c
index b7c08de65..64a92d11e 100644
--- a/src/gc.c
+++ b/src/gc.c
@@ -934,6 +934,11 @@ test_mrb_field_write_barrier(void)
mrb_state *mrb = mrb_open();
struct RBasic *obj, *value;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_mrb_field_write_barrier");
+ return;
+ }
+
puts("test_mrb_field_write_barrier");
obj = RBASIC(mrb_ary_new(mrb));
value = RBASIC(mrb_str_new_cstr(mrb, "value"));
@@ -997,6 +1002,11 @@ test_mrb_write_barrier(void)
mrb_state *mrb = mrb_open();
struct RBasic *obj;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_mrb_write_barrier");
+ return;
+ }
+
puts("test_mrb_write_barrier");
obj = RBASIC(mrb_ary_new(mrb));
paint_black(obj);
@@ -1024,6 +1034,11 @@ test_add_gray_list(void)
mrb_state *mrb = mrb_open();
struct RBasic *obj1, *obj2;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_add_gray_list");
+ return;
+ }
+
puts("test_add_gray_list");
gc_assert(mrb->gray_list == NULL);
obj1 = RBASIC(mrb_str_new_cstr(mrb, "test"));
@@ -1048,6 +1063,11 @@ test_gc_gray_mark(void)
struct RBasic *obj;
size_t gray_num = 0;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_gc_gray_mark");
+ return;
+ }
+
puts("test_gc_gray_mark");
puts(" in MRB_TT_CLASS");
@@ -1079,6 +1099,11 @@ test_incremental_gc(void)
RVALUE *free;
struct heap_page *page;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_incremental_gc");
+ return;
+ }
+
puts("test_incremental_gc");
mrb_garbage_collect(mrb);
@@ -1135,6 +1160,11 @@ test_incremental_sweep_phase(void)
{
mrb_state *mrb = mrb_open();
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_incremental_sweep_phase");
+ return;
+ }
+
puts("test_incremental_sweep_phase");
add_heap(mrb);
@@ -1158,6 +1188,11 @@ test_gc_api(void)
mrb_value argv[1];
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting test_gc_api");
+ return;
+ }
+
puts("test_gc_api");
gc_start(mrb, mrb_nil_value());
@@ -1191,6 +1226,11 @@ test_many_object_benchmark(void)
mrb_value ary = mrb_ary_new(mrb);
int save_point = mrb_gc_arena_save(mrb);
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, test_many_object_benchmark");
+ return;
+ }
+
puts("test_many_object_benchmark");
for (i=0; i<1000; i++) {
diff --git a/src/parse.y b/src/parse.y
index eae9fb373..884290961 100644
--- a/src/parse.y
+++ b/src/parse.y
@@ -5518,6 +5518,11 @@ main()
mrb_state *mrb = mrb_open();
int n;
+ if (mrb == NULL) {
+ fprintf(stderr, "Invalid mrb_state, exiting parser test");
+ return EXIT_FAILURE;
+ }
+
n = mrb_compile_string(mrb, "\
def fib(n)\n\
if n<2\n\