- 30 Apr, 2021 1 commit
-
-
Yukihiro "Matz" Matsumoto authored
As CRuby behaves.
-
- 29 Apr, 2021 2 commits
-
-
Yukihiro "Matz" Matsumoto authored
Fix typo in `mrbgems/mruby-io/mrblib/io.rb`; ref cb55e7ec
-
KOBAYASHI Shuji authored
-
- 28 Apr, 2021 5 commits
-
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
When the receiver is the instance of subclass of `String`. - `String#each_char` - `String#each_line` - `String#partition`
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
It used to be an alias to `IO#each_byte` but those methods should have behave differently.
-
Yukihiro "Matz" Matsumoto authored
Even called for subclass of `Array`, according to new Ruby3.0 behavior. Other methods of `Array` behave as Ruby3.0 from the first hand.
-
- 27 Apr, 2021 1 commit
-
-
Yukihiro "Matz" Matsumoto authored
-
- 26 Apr, 2021 4 commits
-
-
Yukihiro "Matz" Matsumoto authored
Fix symbol leak in `exc_to_s()`
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
Fix annotations for inline iseq of `Class.new` [ci skip]
-
- 25 Apr, 2021 4 commits
-
-
Yukihiro "Matz" Matsumoto authored
Introduce `MRB_GC_RED`
-
Yukihiro "Matz" Matsumoto authored
- stop cross building - add more gems for tests - add `bintest`
-
Yukihiro "Matz" Matsumoto authored
Avoid ill-advised `goto`
-
dearblue authored
-
- 24 Apr, 2021 8 commits
-
-
dearblue authored
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
Following functions are defined in `mrblib/numeric.c`: - `Integer#ceil` - `Integer#floor` - `Integer#round` - `Integer#truncate`
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
- `Random.rand` with `MRB_NO_FLOAT` behaves as `Random.rand(100)` - `Random.rand(i)` where `i<0` raises `ArgumentError`
-
Yukihiro "Matz" Matsumoto authored
-
dearblue authored
Replaces the magic number `7` except in `src/gc.c`.
-
Yukihiro "Matz" Matsumoto authored
-
- 23 Apr, 2021 2 commits
-
-
dearblue authored
ref #5362
-
Yukihiro "Matz" Matsumoto authored
-
- 22 Apr, 2021 2 commits
-
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
- `_raw` does not describe the nature of the function - the function protect errors during C function execution
-
- 21 Apr, 2021 3 commits
-
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
-
Yukihiro "Matz" Matsumoto authored
-
- 20 Apr, 2021 6 commits
-
-
Yukihiro "Matz" Matsumoto authored
Remove unused struct in `include/mruby/variable.h`
-
Yukihiro "Matz" Matsumoto authored
Remove unused `#include` in `complex.c` and `rational.c`
-
Yukihiro "Matz" Matsumoto authored
Remove `MRB_API` from `mrb_get_backtrace` definition
-
KOBAYASHI Shuji authored
-
KOBAYASHI Shuji authored
-
KOBAYASHI Shuji authored
-
- 19 Apr, 2021 2 commits
-
-
Yukihiro "Matz" Matsumoto authored
Introducing the `mrb_protect_raw()` API function
-
dearblue authored
The purpose is two-fold: 1. to be able to specify a pointer directly when user data is used When using `mrb_protect()`, it is necessary to allocate objects by `mrb_obj_cptr()` function when using user data. Adding `mrb_protect_raw()` will make it simpler to reimplement `mrbgems/mruby-error`. 2. to correctly unwind callinfo when an exception is raised from a C function defined as a method (the main topic) If a method call is made directly under `mrb_protect()` and a C function is called, control is returned from `mrb_protect()` if an exception occurs there. In this case, callinfo is not restored, so it is out of sync. Moreover, returning to mruby VM (`mrb_vm_exec()` function) in this state will indicate `ci->pc` of C function which is equal to `NULL`, and subsequent `JUMP` will cause `SIGSEGV`. Following is an example that actually causes `SIGSEGV`: - `crash.c` ```c #include <mruby.h> #include <mruby/compile.h> #include <mruby/error.h> static mrb_value level1_body(mrb_state *mrb, mrb_value self) { return mrb_funcall(mrb, self, "level2", 0); } static mrb_value level1(mrb_state *mrb, mrb_value self) { return mrb_protect(mrb, level1_body, self, NULL); } static mrb_value level2(mrb_state *mrb, mrb_value self) { mrb_raise(mrb, E_RUNTIME_ERROR, "error!"); return mrb_nil_value(); } int main(int argc, char *argv[]) { mrb_state *mrb = mrb_open(); mrb_define_method(mrb, mrb->object_class, "level1", level1, MRB_ARGS_NONE()); mrb_define_method(mrb, mrb->object_class, "level2", level2, MRB_ARGS_NONE()); mrb_p(mrb, mrb_load_string(mrb, "p level1")); mrb_close(mrb); return 0; } ``` - compile & run ```console % `bin/mruby-config --cc --cflags --ldflags` crash.c `bin/mruby-config --libs` % ./a.out zsh: segmentation fault (core dumped) ./a.out ``` After applying this patch, it will print exception object and exit normally. The `mrb_protect()`, `mrb_ensure()` and `mrb_rescue_exceptions()` in `mrbgems/mruby-error` have been rewritten using `mrb_protect_raw()`.
-