Ignore:
Timestamp:
Jul 9, 2020, 8:51:43 AM (4 years ago)
Author:
coas-nagasima
Message:

mrubyを2.1.1に更新

Location:
EcnlProtoTool/trunk/mruby-2.1.1
Files:
4 edited
1 moved

Legend:

Unmodified
Added
Removed
  • EcnlProtoTool/trunk/mruby-2.1.1/mrbgems/mruby-proc-ext/mrblib/proc.rb

    r321 r439  
    2828    pproc = self
    2929    make_curry = proc do |given_args=[]|
    30       send(type) do |*args|
     30      __send__(type) do |*args|
    3131        new_args = given_args + args
    3232        if new_args.size >= arity
     
    4040  end
    4141
     42  def <<(other)
     43    ->(*args, &block) { call(other.call(*args, &block)) }
     44  end
     45
     46  def >>(other)
     47    ->(*args, &block) { other.call(call(*args, &block)) }
     48  end
     49
    4250end
  • EcnlProtoTool/trunk/mruby-2.1.1/mrbgems/mruby-proc-ext/src/proc.c

    r331 r439  
    2626    const char *filename;
    2727
    28     filename = mrb_debug_get_filename(irep, 0);
    29     line = mrb_debug_get_line(irep, 0);
     28    filename = mrb_debug_get_filename(mrb, irep, 0);
     29    line = mrb_debug_get_line(mrb, irep, 0);
    3030
    3131    return (!filename && line == -1)? mrb_nil_value()
     
    3939  struct RProc *p = mrb_proc_ptr(self);
    4040  mrb_value str = mrb_str_new_lit(mrb, "#<Proc:");
    41   mrb_str_concat(mrb, str, mrb_ptr_to_str(mrb, mrb_cptr(self)));
     41  mrb_str_cat_str(mrb, str, mrb_ptr_to_str(mrb, mrb_cptr(self)));
    4242
    4343  if (!MRB_PROC_CFUNC_P(p)) {
     
    4747    mrb_str_cat_lit(mrb, str, "@");
    4848
    49     filename = mrb_debug_get_filename(irep, 0);
     49    filename = mrb_debug_get_filename(mrb, irep, 0);
    5050    mrb_str_cat_cstr(mrb, str, filename ? filename : "-");
    5151    mrb_str_cat_lit(mrb, str, ":");
    5252
    53     line = mrb_debug_get_line(irep, 0);
     53    line = mrb_debug_get_line(mrb, irep, 0);
    5454    if (line != -1) {
    55       str = mrb_format(mrb, "%S:%S", str, mrb_fixnum_value(line));
     55      mrb_str_concat(mrb, str, mrb_fixnum_value(line));
    5656    }
    5757    else {
     
    7373  mrb_value blk;
    7474
    75   mrb_get_args(mrb, "&", &blk);
    76   if (mrb_nil_p(blk)) {
    77     mrb_raise(mrb, E_ARGUMENT_ERROR, "tried to create Proc object without a block");
    78   }
     75  mrb_get_args(mrb, "&!", &blk);
    7976
    8077  return blk;
     
    9592{
    9693  struct parameters_type {
     94    size_t len;
     95    const char *name;
    9796    int size;
    98     const char *name;
    9997  } *p, parameters_list [] = {
    100     {0, "req"},
    101     {0, "opt"},
    102     {0, "rest"},
    103     {0, "req"},
    104     {0, "block"},
    105     {0, NULL}
     98    {sizeof("req")   - 1, "req",   0},
     99    {sizeof("opt")   - 1, "opt",   0},
     100    {sizeof("rest")  - 1, "rest",  0},
     101    {sizeof("req")   - 1, "req",   0},
     102    {sizeof("block") - 1, "block", 0},
     103    {0, NULL, 0}
    106104  };
    107105  const struct RProc *proc = mrb_proc_ptr(self);
    108106  const struct mrb_irep *irep = proc->body.irep;
    109107  mrb_aspec aspec;
    110   mrb_value sname, parameters;
     108  mrb_value parameters;
    111109  int i, j;
     110  int max = -1;
    112111
    113112  if (MRB_PROC_CFUNC_P(proc)) {
     
    121120    return mrb_ary_new(mrb);
    122121  }
    123   if (GET_OPCODE(*irep->iseq) != OP_ENTER) {
     122  if (*irep->iseq != OP_ENTER) {
    124123    return mrb_ary_new(mrb);
    125124  }
    126125
    127126  if (!MRB_PROC_STRICT_P(proc)) {
     127    parameters_list[0].len = sizeof("opt") - 1;
    128128    parameters_list[0].name = "opt";
     129    parameters_list[3].len = sizeof("opt") - 1;
    129130    parameters_list[3].name = "opt";
    130131  }
    131132
    132   aspec = GETARG_Ax(*irep->iseq);
     133  aspec = PEEK_W(irep->iseq+1);
    133134  parameters_list[0].size = MRB_ASPEC_REQ(aspec);
    134135  parameters_list[1].size = MRB_ASPEC_OPT(aspec);
     
    139140  parameters = mrb_ary_new_capa(mrb, irep->nlocals-1);
    140141
     142  max = irep->nlocals-1;
    141143  for (i = 0, p = parameters_list; p->name; p++) {
    142     if (p->size <= 0) continue;
    143     sname = mrb_symbol_value(mrb_intern_cstr(mrb, p->name));
     144    mrb_value sname = mrb_symbol_value(mrb_intern_static(mrb, p->name, p->len));
     145
    144146    for (j = 0; j < p->size; i++, j++) {
    145       mrb_value a = mrb_ary_new(mrb);
     147      mrb_value a;
     148
     149      a = mrb_ary_new(mrb);
    146150      mrb_ary_push(mrb, a, sname);
    147       if (irep->lv[i].name) {
    148         mrb_ary_push(mrb, a, mrb_symbol_value(irep->lv[i].name));
     151      if (i < max && irep->lv[i].name) {
     152        mrb_sym sym = irep->lv[i].name;
     153        const char *name = mrb_sym_name(mrb, sym);
     154        switch (name[0]) {
     155        case '*': case '&':
     156          break;
     157        default:
     158          mrb_ary_push(mrb, a, mrb_symbol_value(sym));
     159          break;
     160        }
    149161      }
    150162      mrb_ary_push(mrb, parameters, a);
     
    164176  mrb_define_method(mrb, p, "parameters",      mrb_proc_parameters,      MRB_ARGS_NONE());
    165177
    166   mrb_define_class_method(mrb, mrb->kernel_module, "proc", mrb_kernel_proc, MRB_ARGS_NONE());
    167   mrb_define_method(mrb, mrb->kernel_module,       "proc", mrb_kernel_proc, MRB_ARGS_NONE());
     178  mrb_define_class_method(mrb, mrb->kernel_module, "proc", mrb_kernel_proc, MRB_ARGS_NONE()|MRB_ARGS_BLOCK());
     179  mrb_define_method(mrb, mrb->kernel_module,       "proc", mrb_kernel_proc, MRB_ARGS_NONE()|MRB_ARGS_BLOCK());
    168180}
    169181
  • EcnlProtoTool/trunk/mruby-2.1.1/mrbgems/mruby-proc-ext/test/proc.c

    r331 r439  
    1414  mrb_sym n;
    1515  mrb_value n_val;
     16  mrb_method_t m;
     17  struct RProc *p;
    1618  mrb_get_args(mrb, "n", &n);
    1719  n_val = mrb_symbol_value(n);
    18   mrb_define_method_raw(mrb, mrb_class_ptr(self), n,
    19                         mrb_proc_new_cfunc_with_env(mrb, return_func_name, 1, &n_val));
     20  p = mrb_proc_new_cfunc_with_env(mrb, return_func_name, 1, &n_val);
     21  MRB_METHOD_FROM_PROC(m, p);
     22  mrb_define_method_raw(mrb, mrb_class_ptr(self), n, m);
    2023  return self;
    2124}
     
    3437  mrb_sym n;
    3538  mrb_value *argv; mrb_int argc;
     39  mrb_method_t m;
     40  struct RProc *p;
    3641  mrb_get_args(mrb, "na", &n, &argv, &argc);
    37   mrb_define_method_raw(mrb, mrb_class_ptr(self), n,
    38                         mrb_proc_new_cfunc_with_env(mrb, return_env, argc, argv));
     42  p = mrb_proc_new_cfunc_with_env(mrb, return_env, argc, argv);
     43  MRB_METHOD_FROM_PROC(m, p);
     44  mrb_define_method_raw(mrb, mrb_class_ptr(self), n, m);
    3945  return self;
    4046}
  • EcnlProtoTool/trunk/mruby-2.1.1/mrbgems/mruby-proc-ext/test/proc.rb

    r331 r439  
    22# Proc(Ext) Test
    33
     4def enable_debug_info?
     5  return @enable_debug_info unless @enable_debug_info == nil
     6  begin
     7    raise
     8  rescue => e
     9    @enable_debug_info = !e.backtrace.empty?
     10  end
     11end
     12
    413assert('Proc#source_location') do
    5   loc = Proc.new {}.source_location
    6   next true if loc.nil?
    7   assert_equal loc[0][-7, 7], 'proc.rb'
    8   assert_equal loc[1], 5
     14  skip unless enable_debug_info?
     15  file, line = Proc.new{}.source_location
     16  assert_equal __FILE__, file
     17  assert_equal __LINE__ - 2, line
    918end
    1019
    1120assert('Proc#inspect') do
    1221  ins = Proc.new{}.inspect
    13   assert_kind_of String, ins
     22  if enable_debug_info?
     23    metas = %w(\\ * ? [ ] { })
     24    file = __FILE__.split("").map{|c| metas.include?(c) ? "\\#{c}" : c}.join
     25    line = __LINE__ - 4
     26  else
     27    file = line = "-"
     28  end
     29  assert_match "#<Proc:0x*@#{file}:#{line}>", ins
     30end
     31
     32assert('Proc#parameters') do
     33  parameters = Proc.new{|x,y=42,*other|}.parameters
     34  assert_equal [[:opt, :x], [:opt, :y], [:rest, :other]], parameters
    1435end
    1536
     
    6788assert('Kernel#proc') do
    6889  assert_true !proc{|a|}.lambda?
     90
     91  assert_raise LocalJumpError do
     92    proc{ break }.call
     93  end
     94end
     95
     96assert "Proc#<< and Proc#>>" do
     97  add3 = ->(n) { n + 3 }
     98  mul2 = ->(n) { n * 2 }
     99
     100  f1 = mul2 << add3
     101  assert_kind_of Proc, f1
     102  assert_equal 16, f1.call(5)
     103
     104  f2 = mul2 >> add3
     105  assert_kind_of Proc, f2
     106  assert_equal 13, f2.call(5)
    69107end
    70108
Note: See TracChangeset for help on using the changeset viewer.