diff options
| author | dearblue <[email protected]> | 2019-04-06 14:37:25 +0900 |
|---|---|---|
| committer | dearblue <[email protected]> | 2019-04-24 22:56:39 +0900 |
| commit | 8f6f36f6540408d3b1b5a0dddf440d53b43e53e4 (patch) | |
| tree | 51a942ed97819436bc4961e7785060507ff13457 /src | |
| parent | 58d525c9fafcc78af25d22f984821eda19d0913c (diff) | |
| download | mruby-8f6f36f6540408d3b1b5a0dddf440d53b43e53e4.tar.gz mruby-8f6f36f6540408d3b1b5a0dddf440d53b43e53e4.zip | |
Add mruby binary loader functions from buffer memory
Add new functions (with `MRB_API`):
- `mrb_read_irep_buf()`
- `mrb_load_irep_buf()`
- `mrb_load_irep_buf_cxt()`
Diffstat (limited to 'src')
| -rw-r--r-- | src/load.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/src/load.c b/src/load.c index cc011fba7..0274f30d4 100644 --- a/src/load.c +++ b/src/load.c @@ -629,6 +629,12 @@ mrb_read_irep(mrb_state *mrb, const uint8_t *bin) return read_irep(mrb, bin, (size_t)-1, flags); } +MRB_API mrb_irep* +mrb_read_irep_buf(mrb_state *mrb, const void *buf, size_t bufsize) +{ + return read_irep(mrb, (const uint8_t *)buf, bufsize, FLAG_SRC_MALLOC); +} + void mrb_exc_set(mrb_state *mrb, mrb_value exc); static void @@ -663,11 +669,23 @@ mrb_load_irep_cxt(mrb_state *mrb, const uint8_t *bin, mrbc_context *c) } MRB_API mrb_value +mrb_load_irep_buf_cxt(mrb_state *mrb, const void *buf, size_t bufsize, mrbc_context *c) +{ + return load_irep(mrb, mrb_read_irep_buf(mrb, buf, bufsize), c); +} + +MRB_API mrb_value mrb_load_irep(mrb_state *mrb, const uint8_t *bin) { return mrb_load_irep_cxt(mrb, bin, NULL); } +MRB_API mrb_value +mrb_load_irep_buf(mrb_state *mrb, const void *buf, size_t bufsize) +{ + return mrb_load_irep_buf_cxt(mrb, buf, bufsize, NULL); +} + #ifndef MRB_DISABLE_STDIO mrb_irep* |
