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:
1 edited
1 moved

Legend:

Unmodified
Added
Removed
  • 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
Note: See TracChangeset for help on using the changeset viewer.