diff options
| author | Miura Hideki <[email protected]> | 2013-11-17 16:33:39 +0900 |
|---|---|---|
| committer | Miura Hideki <[email protected]> | 2013-11-19 20:38:02 +0900 |
| commit | 54c5b12fb7bc5fdd57326780e970ee467387f81a (patch) | |
| tree | cd4d15d20ef543b5ca20f3186ea49d50d4f52129 /src/load.c | |
| parent | 2bda9652585616b49449904aad0195d8b23e58a4 (diff) | |
| download | mruby-54c5b12fb7bc5fdd57326780e970ee467387f81a.tar.gz mruby-54c5b12fb7bc5fdd57326780e970ee467387f81a.zip | |
irep->pool struct pool -> mrb_value
Diffstat (limited to 'src/load.c')
| -rw-r--r-- | src/load.c | 32 |
1 files changed, 8 insertions, 24 deletions
diff --git a/src/load.c b/src/load.c index 68ebb1f7b..989325f0b 100644 --- a/src/load.c +++ b/src/load.c @@ -87,7 +87,7 @@ read_irep_record_1(mrb_state *mrb, const uint8_t *bin, uint32_t *len) if (SIZE_ERROR_MUL(sizeof(mrb_value), plen)) { return NULL; } - irep->pool = (struct irep_pool*)mrb_malloc(mrb, sizeof(struct irep_pool) * plen); + irep->pool = (struct mrb_value*)mrb_malloc(mrb, sizeof(mrb_value) * plen); if (irep->pool == NULL) { return NULL; } @@ -100,38 +100,22 @@ read_irep_record_1(mrb_state *mrb, const uint8_t *bin, uint32_t *len) src += sizeof(uint16_t); s = mrb_str_new(mrb, (char *)src, pool_data_len); src += pool_data_len; - irep->pool[i].type = tt; switch (tt) { //pool data - case IREP_TT_FIXNUM: - { - mrb_value v = mrb_str_to_inum(mrb, s, 10, FALSE); - - switch (mrb_type(v)) { - case MRB_TT_FIXNUM: - irep->pool[i].value.i = mrb_fixnum(v); - break; - case MRB_TT_FLOAT: - irep->pool[i].type = MRB_TT_FLOAT; - irep->pool[i].value.f = mrb_float(v); - default: - /* broken data; should not happen */ - irep->pool[i].value.i = 0; - } - } + case MRB_TT_FIXNUM: + irep->pool[i] = mrb_str_to_inum(mrb, s, 10, FALSE); break; - case IREP_TT_FLOAT: - irep->pool[i].value.f = mrb_str_to_dbl(mrb, s, FALSE); + case MRB_TT_FLOAT: + irep->pool[i] = mrb_float_value(mrb, mrb_str_to_dbl(mrb, s, FALSE)); break; - case IREP_TT_STRING: - irep->pool[i].value.s = (struct irep_pool_string*)mrb_malloc(mrb, sizeof(struct irep_pool_string) + pool_data_len); - irep->pool[i].value.s->len = pool_data_len; - memcpy(irep->pool[i].value.s->buf, src-pool_data_len, pool_data_len); + case MRB_TT_STRING: + irep->pool[i] = mrb_str_dup_static(mrb, s); break; default: /* should not happen */ + irep->pool[i] = mrb_nil_value(); break; } irep->plen++; |
