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-kernel-ext/src/kernel.c

    r331 r439  
    2121      break;
    2222    case 1:
    23       if (mrb_type(v) == MRB_TT_RANGE) {
     23      if (mrb_range_p(v)) {
    2424        mrb_int beg, len;
    25         if (mrb_range_beg_len(mrb, v, &beg, &len, bt_len, TRUE) == 1) {
     25        if (mrb_range_beg_len(mrb, v, &beg, &len, bt_len, TRUE) == MRB_RANGE_OK) {
    2626          lev = beg;
    2727          n = len;
     
    3232      }
    3333      else {
    34         v = mrb_to_int(mrb, v);
    35         lev = mrb_fixnum(v);
     34        lev = mrb_int(mrb, v);
    3635        if (lev < 0) {
    37           mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative level (%S)", v);
     36          mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative level (%v)", v);
    3837        }
    3938        n = bt_len - lev;
     
    4140      break;
    4241    case 2:
    43       lev = mrb_fixnum(mrb_to_int(mrb, v));
    44       n = mrb_fixnum(mrb_to_int(mrb, length));
     42      lev = mrb_int(mrb, v);
     43      n = mrb_int(mrb, length);
    4544      if (lev < 0) {
    46         mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative level (%S)", v);
     45        mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative level (%v)", v);
    4746      }
    4847      if (n < 0) {
    49         mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative size (%S)", length);
     48        mrb_raisef(mrb, E_ARGUMENT_ERROR, "negative size (%v)", length);
    5049      }
    5150      break;
     
    9493 *  In any case, strings should be strictly conformed to numeric
    9594 *  representation. This behavior is different from that of
    96  *  <code>String#to_i</code>.  Non string values will be converted using
    97  *  <code>to_int</code>, and <code>to_i</code>. Passing <code>nil</code>
    98  *  raises a TypeError.
     95 *  <code>String#to_i</code>.  Non string values will be treated as integers.
     96 *  Passing <code>nil</code> raises a TypeError.
    9997 *
    10098 *     Integer(123.999)    #=> 123
     
    115113}
    116114
     115#ifndef MRB_WITHOUT_FLOAT
    117116/*
    118117 *  call-seq:
     
    135134  return mrb_Float(mrb, arg);
    136135}
     136#endif
    137137
    138138/*
     
    141141 *
    142142 *  Returns <i>arg</i> as an <code>String</code>.
    143  *
    144  *  First tries to call its <code>to_str</code> method, then its to_s method.
     143 *  converted using <code>to_s</code> method.
    145144 *
    146145 *     String(self)        #=> "main"
     
    154153
    155154  mrb_get_args(mrb, "o", &arg);
    156   tmp = mrb_check_convert_type(mrb, arg, MRB_TT_STRING, "String", "to_str");
    157   if (mrb_nil_p(tmp)) {
    158     tmp = mrb_check_convert_type(mrb, arg, MRB_TT_STRING, "String", "to_s");
    159   }
     155  tmp = mrb_convert_type(mrb, arg, MRB_TT_STRING, "String", "to_s");
    160156  return tmp;
    161157}
     
    165161 *     Array(arg)    -> array
    166162 *
    167  *  Returns +arg+ as an Array.
    168  *
    169  *  First tries to call Array#to_ary on +arg+, then Array#to_a.
     163 *  Returns +arg+ as an Array using to_a method.
    170164 *
    171165 *     Array(1..5)   #=> [1, 2, 3, 4, 5]
     
    178172
    179173  mrb_get_args(mrb, "o", &arg);
    180   tmp = mrb_check_convert_type(mrb, arg, MRB_TT_ARRAY, "Array", "to_ary");
    181   if (mrb_nil_p(tmp)) {
    182     tmp = mrb_check_convert_type(mrb, arg, MRB_TT_ARRAY, "Array", "to_a");
    183   }
     174  tmp = mrb_check_convert_type(mrb, arg, MRB_TT_ARRAY, "Array", "to_a");
    184175  if (mrb_nil_p(tmp)) {
    185176    return mrb_ary_new_from_values(mrb, 1, &arg);
     
    193184 *     Hash(arg)    -> hash
    194185 *
    195  *  Converts <i>arg</i> to a <code>Hash</code> by calling
    196  *  <i>arg</i><code>.to_hash</code>. Returns an empty <code>Hash</code> when
    197  *  <i>arg</i> is <tt>nil</tt> or <tt>[]</tt>.
     186 *  Returns a <code>Hash</code> if <i>arg</i> is a <code>Hash</code>.
     187 *  Returns an empty <code>Hash</code> when <i>arg</i> is <tt>nil</tt>
     188 *  or <tt>[]</tt>.
    198189 *
    199190 *      Hash([])          #=> {}
     
    206197mrb_f_hash(mrb_state *mrb, mrb_value self)
    207198{
    208   mrb_value arg, tmp;
    209 
    210   mrb_get_args(mrb, "o", &arg);
    211   if (mrb_nil_p(arg)) {
     199  mrb_value arg;
     200
     201  mrb_get_args(mrb, "o", &arg);
     202  if (mrb_nil_p(arg) || (mrb_array_p(arg) && RARRAY_LEN(arg) == 0)) {
    212203    return mrb_hash_new(mrb);
    213204  }
    214   tmp = mrb_check_convert_type(mrb, arg, MRB_TT_HASH, "Hash", "to_hash");
    215   if (mrb_nil_p(tmp)) {
    216     if (mrb_array_p(arg) && RARRAY_LEN(arg) == 0) {
    217       return mrb_hash_new(mrb);
    218     }
    219     mrb_raisef(mrb, E_TYPE_ERROR, "can't convert %S into Hash",
    220       mrb_str_new_cstr(mrb, mrb_obj_classname(mrb, arg)));
    221   }
    222   return tmp;
     205  return mrb_ensure_hash_type(mrb, arg);
    223206}
    224207
     
    231214  mrb_define_module_function(mrb, krn, "caller", mrb_f_caller, MRB_ARGS_OPT(2));
    232215  mrb_define_method(mrb, krn, "__method__", mrb_f_method, MRB_ARGS_NONE());
    233   mrb_define_module_function(mrb, krn, "Integer", mrb_f_integer, MRB_ARGS_ANY());
     216  mrb_define_module_function(mrb, krn, "Integer", mrb_f_integer, MRB_ARGS_ARG(1,1));
     217#ifndef MRB_WITHOUT_FLOAT
    234218  mrb_define_module_function(mrb, krn, "Float", mrb_f_float, MRB_ARGS_REQ(1));
     219#endif
    235220  mrb_define_module_function(mrb, krn, "String", mrb_f_string, MRB_ARGS_REQ(1));
    236221  mrb_define_module_function(mrb, krn, "Array", mrb_f_array, MRB_ARGS_REQ(1));
Note: See TracChangeset for help on using the changeset viewer.