Coverage Report

Created: 2025-06-13 07:32

/src/mruby/src/kernel.c
Line
Count
Source (jump to first uncovered line)
1
/*
2
** kernel.c - Kernel module
3
**
4
** See Copyright Notice in mruby.h
5
*/
6
7
#include <mruby.h>
8
#include <mruby/array.h>
9
#include <mruby/hash.h>
10
#include <mruby/class.h>
11
#include <mruby/proc.h>
12
#include <mruby/string.h>
13
#include <mruby/variable.h>
14
#include <mruby/error.h>
15
#include <mruby/istruct.h>
16
#include <mruby/internal.h>
17
#include <mruby/presym.h>
18
19
/*
20
 * Checks if the method `mid` for object `obj` is implemented by
21
 * the C function `func`.
22
 */
23
MRB_API mrb_bool
24
mrb_func_basic_p(mrb_state *mrb, mrb_value obj, mrb_sym mid, mrb_func_t func)
25
1.19M
{
26
1.19M
  struct RClass *c = mrb_class(mrb, obj);
27
1.19M
  mrb_method_t m = mrb_method_search_vm(mrb, &c, mid);
28
1.19M
  const struct RProc *p;
29
30
1.19M
  if (MRB_METHOD_UNDEF_P(m)) return FALSE;
31
1.19M
  if (MRB_METHOD_FUNC_P(m))
32
1.19M
    return MRB_METHOD_FUNC(m) == func;
33
0
  p = MRB_METHOD_PROC(m);
34
0
  if (MRB_PROC_CFUNC_P(p) && (MRB_PROC_CFUNC(p) == func))
35
0
    return TRUE;
36
0
  return FALSE;
37
0
}
38
39
static mrb_bool
40
mrb_obj_basic_to_s_p(mrb_state *mrb, mrb_value obj)
41
0
{
42
0
  return mrb_func_basic_p(mrb, obj, MRB_SYM(to_s), mrb_any_to_s);
43
0
}
44
45
/* 15.3.1.3.17 */
46
/*
47
 *  call-seq:
48
 *     obj.inspect   -> string
49
 *
50
 *  Returns a string containing a human-readable representation of
51
 *  <i>obj</i>. If not overridden and no instance variables, uses the
52
 *  <code>to_s</code> method to generate the string.
53
 *  <i>obj</i>.  If not overridden, uses the <code>to_s</code> method to
54
 *  generate the string.
55
 *
56
 *     [ 1, 2, 3..4, 'five' ].inspect   #=> "[1, 2, 3..4, \"five\"]"
57
 *     Time.new.inspect                 #=> "2008-03-08 19:43:39 +0900"
58
 */
59
MRB_API mrb_value
60
mrb_obj_inspect(mrb_state *mrb, mrb_value obj)
61
0
{
62
0
  if (mrb_object_p(obj) && mrb_obj_basic_to_s_p(mrb, obj)) {
63
0
    return mrb_obj_iv_inspect(mrb, mrb_obj_ptr(obj));
64
0
  }
65
0
  return mrb_any_to_s(mrb, obj);
66
0
}
67
68
/* 15.3.1.3.2  */
69
/*
70
 *  call-seq:
71
 *     obj === other   -> true or false
72
 *
73
 *  Case Equality---For class <code>Object</code>, effectively the same
74
 *  as calling  <code>#==</code>, but typically overridden by descendants
75
 *  to provide meaningful semantics in <code>case</code> statements.
76
 */
77
static mrb_value
78
mrb_eqq_m(mrb_state *mrb, mrb_value self)
79
0
{
80
0
  mrb_value arg = mrb_get_arg1(mrb);
81
82
0
  return mrb_bool_value(mrb_equal(mrb, self, arg));
83
0
}
84
85
static mrb_value
86
mrb_cmp_m(mrb_state *mrb, mrb_value self)
87
0
{
88
0
  mrb_value arg = mrb_get_arg1(mrb);
89
90
  /* recursion check */
91
0
  for (mrb_callinfo *ci=&mrb->c->ci[-1]; ci>=mrb->c->cibase; ci--) {
92
0
    if (ci->mid == MRB_OPSYM(cmp) &&
93
0
        mrb_obj_eq(mrb, self, ci->stack[0]) &&
94
0
        mrb_obj_eq(mrb, arg, ci->stack[1])) {
95
      /* recursive <=> calling returns `nil` */
96
0
      return mrb_nil_value();
97
0
    }
98
0
  }
99
100
0
  if (mrb_equal(mrb, self, arg))
101
0
    return mrb_fixnum_value(0);
102
0
  return mrb_nil_value();
103
0
}
104
105
static mrb_bool
106
inspect_recursive_p(mrb_state *mrb, mrb_value obj, int n)
107
0
{
108
0
  for (mrb_callinfo *ci=&mrb->c->ci[-1-n]; ci>=mrb->c->cibase; ci--) {
109
0
    if (ci->mid == MRB_SYM(inspect) &&
110
0
        mrb_obj_eq(mrb, obj, ci->stack[0])) {
111
0
      return TRUE;
112
0
    }
113
0
  }
114
0
  return FALSE;
115
0
}
116
117
mrb_bool
118
mrb_inspect_recursive_p(mrb_state *mrb, mrb_value obj)
119
0
{
120
0
  return inspect_recursive_p(mrb, obj, 0);
121
0
}
122
123
static mrb_value
124
mrb_obj_inspect_recursive_p(mrb_state *mrb, mrb_value obj)
125
0
{
126
0
  return mrb_bool_value(inspect_recursive_p(mrb, obj, 1));
127
0
}
128
129
/* 15.3.1.3.3  */
130
/* 15.3.1.3.33 */
131
/*
132
 *  Document-method: __id__
133
 *  Document-method: object_id
134
 *
135
 *  call-seq:
136
 *     obj.__id__       -> int
137
 *     obj.object_id    -> int
138
 *
139
 *  Returns an integer identifier for <i>obj</i>. The same number will
140
 *  be returned on all calls to <code>id</code> for a given object, and
141
 *  no two active objects will share an id.
142
 *  <code>Object#object_id</code> is a different concept from the
143
 *  <code>:name</code> notation, which returns the symbol id of
144
 *  <code>name</code>. Replaces the deprecated <code>Object#id</code>.
145
 */
146
mrb_value
147
mrb_obj_id_m(mrb_state *mrb, mrb_value self)
148
0
{
149
0
  return mrb_fixnum_value(mrb_obj_id(self));
150
0
}
151
152
static int
153
env_bidx(struct REnv *e)
154
0
{
155
0
  int bidx;
156
157
  /* use saved block arg position */
158
0
  bidx = MRB_ENV_BIDX(e);
159
  /* bidx may be useless (e.g. define_method) */
160
0
  if (bidx >= MRB_ENV_LEN(e)) return -1;
161
0
  return bidx;
162
0
}
163
164
/* 15.3.1.2.2  */
165
/* 15.3.1.2.5  */
166
/* 15.3.1.3.6  */
167
/* 15.3.1.3.25 */
168
/*
169
 *  call-seq:
170
 *     block_given?   -> true or false
171
 *     iterator?      -> true or false
172
 *
173
 *  Returns <code>true</code> if <code>yield</code> would execute a
174
 *  block in the current context. The <code>iterator?</code> form
175
 *  is mildly deprecated.
176
 *
177
 *     def try
178
 *       if block_given?
179
 *         yield
180
 *       else
181
 *         "no block"
182
 *       end
183
 *     end
184
 *     try                  #=> "no block"
185
 *     try { "hello" }      #=> "hello"
186
 *     try do "hello" end   #=> "hello"
187
 */
188
static mrb_value
189
mrb_f_block_given_p_m(mrb_state *mrb, mrb_value self)
190
0
{
191
0
  mrb_callinfo *ci = &mrb->c->ci[-1];
192
0
  mrb_callinfo *cibase = mrb->c->cibase;
193
0
  mrb_value *bp;
194
0
  int bidx;
195
0
  struct REnv *e = NULL;
196
0
  const struct RProc *p;
197
198
0
  if (ci <= cibase) {
199
    /* toplevel does not have block */
200
0
    return mrb_false_value();
201
0
  }
202
0
  p = ci->proc;
203
  /* search method/class/module proc */
204
0
  while (p) {
205
0
    if (MRB_PROC_SCOPE_P(p)) break;
206
0
    e = MRB_PROC_ENV(p);
207
0
    p = p->upper;
208
0
  }
209
0
  if (p == NULL) return mrb_false_value();
210
0
  if (e) {
211
0
    bidx = env_bidx(e);
212
0
    if (bidx < 0) return mrb_false_value();
213
0
    bp = &e->stack[bidx];
214
0
    goto block_given;
215
0
  }
216
  /* search ci corresponding to proc */
217
0
  while (cibase < ci) {
218
0
    if (ci->proc == p) break;
219
0
    ci--;
220
0
  }
221
0
  if (ci == cibase) {
222
    /* proc is closure */
223
0
    if (!MRB_PROC_ENV_P(p)) return mrb_false_value();
224
0
    e = MRB_PROC_ENV(p);
225
0
    bidx = env_bidx(e);
226
0
    if (bidx < 0) return mrb_false_value();
227
0
    bp = &e->stack[bidx];
228
0
  }
229
0
  else if ((e = mrb_vm_ci_env(ci)) != NULL) {
230
    /* top-level does not have block slot (always false) */
231
0
    if (e->stack == mrb->c->stbase) return mrb_false_value();
232
0
    bidx = env_bidx(e);
233
    /* bidx may be useless (e.g. define_method) */
234
0
    if (bidx < 0) return mrb_false_value();
235
0
    bp = &e->stack[bidx];
236
0
  }
237
0
  else {
238
0
    uint8_t n = ci->n == 15 ? 1 : ci->n;
239
0
    uint8_t k = ci->nk == 15 ? 1 : ci->nk*2;
240
0
    bidx = n + k + 1;      /* self + args + kargs => bidx */
241
0
    bp = &ci->stack[bidx];
242
0
  }
243
0
 block_given:
244
0
  if (mrb_nil_p(*bp))
245
0
    return mrb_false_value();
246
0
  return mrb_true_value();
247
0
}
248
249
/* 15.3.1.3.7  */
250
/*
251
 *  call-seq:
252
 *     obj.class    -> class
253
 *
254
 *  Returns the class of <i>obj</i>. This method must always be
255
 *  called with an explicit receiver, as <code>class</code> is also a
256
 *  reserved word in Ruby.
257
 *
258
 *     1.class      #=> Integer
259
 *     self.class   #=> Object
260
 */
261
static mrb_value
262
mrb_obj_class_m(mrb_state *mrb, mrb_value self)
263
0
{
264
0
  return mrb_obj_value(mrb_obj_class(mrb, self));
265
0
}
266
267
/*
268
 * Freezes the object `self`, preventing further modifications.
269
 * Immediate values cannot be frozen.
270
 */
271
MRB_API mrb_value
272
mrb_obj_freeze(mrb_state *mrb, mrb_value self)
273
123
{
274
123
  if (!mrb_immediate_p(self)) {
275
123
    struct RBasic *b = mrb_basic_ptr(self);
276
123
    if (!mrb_frozen_p(b)) {
277
123
      b->frozen = 1;
278
123
      if (b->c->tt == MRB_TT_SCLASS) b->c->frozen = 1;
279
123
    }
280
123
  }
281
123
  return self;
282
123
}
283
284
static mrb_value
285
mrb_obj_frozen(mrb_state *mrb, mrb_value self)
286
0
{
287
0
  return mrb_bool_value(mrb_immediate_p(self) || mrb_frozen_p(mrb_basic_ptr(self)));
288
0
}
289
290
/* 15.3.1.3.15 */
291
/*
292
 *  call-seq:
293
 *     obj.hash    -> int
294
 *
295
 *  Generates a <code>Integer</code> hash value for this object. This
296
 *  function must have the property that <code>a.eql?(b)</code> implies
297
 *  <code>a.hash == b.hash</code>. The hash value is used by class
298
 *  <code>Hash</code>. Any hash value that exceeds the capacity of a
299
 *  <code>Integer</code> will be truncated before being used.
300
 */
301
static mrb_value
302
mrb_obj_hash(mrb_state *mrb, mrb_value self)
303
0
{
304
0
#ifdef MRB_USE_BIGINT
305
0
  if (mrb_bigint_p(self)) {
306
0
    return mrb_bint_hash(mrb, self);
307
0
  }
308
0
#endif
309
0
  return mrb_int_value(mrb, mrb_obj_id(self));
310
0
}
311
312
/* 15.3.1.3.16 */
313
mrb_value
314
mrb_obj_init_copy(mrb_state *mrb, mrb_value self)
315
0
{
316
0
  mrb_value orig = mrb_get_arg1(mrb);
317
318
0
  if (mrb_obj_equal(mrb, self, orig)) return self;
319
0
  if ((mrb_type(self) != mrb_type(orig)) || (mrb_obj_class(mrb, self) != mrb_obj_class(mrb, orig))) {
320
0
      mrb_raise(mrb, E_TYPE_ERROR, "initialize_copy should take same class object");
321
0
  }
322
0
  return self;
323
0
}
324
325
/*
326
 * Checks if the object `obj` is an instance of the class `c`.
327
 */
328
MRB_API mrb_bool
329
mrb_obj_is_instance_of(mrb_state *mrb, mrb_value obj, const struct RClass* c)
330
0
{
331
0
  if (mrb_obj_class(mrb, obj) == c) return TRUE;
332
0
  return FALSE;
333
0
}
334
335
/* 15.3.1.3.19 */
336
/*
337
 *  call-seq:
338
 *     obj.instance_of?(class)    -> true or false
339
 *
340
 *  Returns <code>true</code> if <i>obj</i> is an instance of the given
341
 *  class. See also <code>Object#kind_of?</code>.
342
 */
343
static mrb_value
344
obj_is_instance_of(mrb_state *mrb, mrb_value self)
345
0
{
346
0
  struct RClass *c;
347
348
0
  mrb_get_args(mrb, "c", &c);
349
350
0
  return mrb_bool_value(mrb_obj_is_instance_of(mrb, self, c));
351
0
}
352
353
/* 15.3.1.3.24 */
354
/* 15.3.1.3.26 */
355
/*
356
 *  call-seq:
357
 *     obj.is_a?(class)       -> true or false
358
 *     obj.kind_of?(class)    -> true or false
359
 *
360
 *  Returns <code>true</code> if <i>class</i> is the class of
361
 *  <i>obj</i>, or if <i>class</i> is one of the superclasses of
362
 *  <i>obj</i> or modules included in <i>obj</i>.
363
 *
364
 *     module M;    end
365
 *     class A
366
 *       include M
367
 *     end
368
 *     class B < A; end
369
 *     class C < B; end
370
 *     b = B.new
371
 *     b.instance_of? A   #=> false
372
 *     b.instance_of? B   #=> true
373
 *     b.instance_of? C   #=> false
374
 *     b.instance_of? M   #=> false
375
 *     b.kind_of? A       #=> true
376
 *     b.kind_of? B       #=> true
377
 *     b.kind_of? C       #=> false
378
 *     b.kind_of? M       #=> true
379
 */
380
static mrb_value
381
mrb_obj_is_kind_of_m(mrb_state *mrb, mrb_value self)
382
66.5k
{
383
66.5k
  struct RClass *c;
384
385
66.5k
  mrb_get_args(mrb, "c", &c);
386
387
66.5k
  return mrb_bool_value(mrb_obj_is_kind_of(mrb, self, c));
388
66.5k
}
389
390
/* 15.3.1.3.32 */
391
/*
392
 * call_seq:
393
 *   nil.nil?               -> true
394
 *   <anything_else>.nil?   -> false
395
 *
396
 * Only the object <i>nil</i> responds <code>true</code> to <code>nil?</code>.
397
 */
398
static mrb_value
399
mrb_false(mrb_state *mrb, mrb_value self)
400
3.68k
{
401
3.68k
  return mrb_false_value();
402
3.68k
}
403
404
/* 15.3.1.2.12  */
405
/* 15.3.1.3.40 */
406
/*
407
 *  call-seq:
408
 *     raise
409
 *     raise(string)
410
 *     raise(exception [, string])
411
 *
412
 *  With no arguments, raises a <code>RuntimeError</code>
413
 *  With a single +String+ argument, raises a
414
 *  +RuntimeError+ with the string as a message. Otherwise,
415
 *  the first parameter should be the name of an +Exception+
416
 *  class (or an object that returns an +Exception+ object when sent
417
 *  an +exception+ message). The optional second parameter sets the
418
 *  message associated with the exception, and the third parameter is an
419
 *  array of callback information. Exceptions are caught by the
420
 *  +rescue+ clause of <code>begin...end</code> blocks.
421
 *
422
 *     raise "Failed to create socket"
423
 *     raise ArgumentError, "No parameters", caller
424
 */
425
mrb_value
426
mrb_f_raise(mrb_state *mrb, mrb_value self)
427
40
{
428
40
  mrb_value exc, mesg;
429
40
  mrb_int argc;
430
431
40
  argc = mrb_get_args(mrb, "|oo", &exc, &mesg);
432
40
  mrb->c->ci->mid = 0;
433
40
  switch (argc) {
434
0
  case 0:
435
0
    mrb_raise(mrb, E_RUNTIME_ERROR, "");
436
0
    break;
437
0
  case 1:
438
0
    if (mrb_string_p(exc)) {
439
0
      mesg = exc;
440
0
      exc = mrb_obj_value(E_RUNTIME_ERROR);
441
0
    }
442
0
    else {
443
0
      mesg = mrb_nil_value();
444
0
    }
445
    /* fall through */
446
40
  default:
447
40
    exc = mrb_make_exception(mrb, exc, mesg);
448
40
    mrb_exc_raise(mrb, exc);
449
0
    break;
450
40
  }
451
0
  return mrb_nil_value();            /* not reached */
452
40
}
453
454
/* 15.3.1.3.41 */
455
/*
456
 *  call-seq:
457
 *     obj.remove_instance_variable(symbol)    -> obj
458
 *
459
 *  Removes the named instance variable from <i>obj</i>, returning that
460
 *  variable's value.
461
 *
462
 *     class Dummy
463
 *       attr_reader :var
464
 *       def initialize
465
 *         @var = 99
466
 *       end
467
 *       def remove
468
 *         remove_instance_variable(:@var)
469
 *       end
470
 *     end
471
 *     d = Dummy.new
472
 *     d.var      #=> 99
473
 *     d.remove   #=> 99
474
 *     d.var      #=> nil
475
 */
476
static mrb_value
477
mrb_obj_remove_instance_variable(mrb_state *mrb, mrb_value self)
478
0
{
479
0
  mrb_sym sym;
480
0
  mrb_value val;
481
482
0
  mrb_get_args(mrb, "n", &sym);
483
0
  mrb_iv_name_sym_check(mrb, sym);
484
0
  val = mrb_iv_remove(mrb, self, sym);
485
0
  if (mrb_undef_p(val)) {
486
0
    mrb_name_error(mrb, sym, "instance variable %n not defined", sym);
487
0
  }
488
0
  return val;
489
0
}
490
491
/* 15.3.1.3.43 */
492
/*
493
 *  call-seq:
494
 *     obj.respond_to?(symbol, include_private=false) -> true or false
495
 *
496
 *  Returns +true+ if _obj_ responds to the given
497
 *  method. Private methods are included in the search only if the
498
 *  optional second parameter evaluates to +true+.
499
 *
500
 *  If the method is not implemented,
501
 *  as Process.fork on Windows, File.lchmod on GNU/Linux, etc.,
502
 *  false is returned.
503
 *
504
 *  If the method is not defined, <code>respond_to_missing?</code>
505
 *  method is called and the result is returned.
506
 */
507
static mrb_value
508
obj_respond_to(mrb_state *mrb, mrb_value self)
509
0
{
510
0
  mrb_sym id;
511
0
  mrb_bool priv = FALSE, respond_to_p;
512
513
0
  mrb_get_args(mrb, "n|b", &id, &priv);
514
0
  respond_to_p = mrb_respond_to(mrb, self, id);
515
0
  if (!respond_to_p) {
516
0
    mrb_sym rtm_id = MRB_SYM_Q(respond_to_missing);
517
0
    if (!mrb_func_basic_p(mrb, self, rtm_id, mrb_false)) {
518
0
      mrb_value v;
519
0
      v = mrb_funcall_id(mrb, self, rtm_id, 2, mrb_symbol_value(id), mrb_bool_value(priv));
520
0
      return mrb_bool_value(mrb_bool(v));
521
0
    }
522
0
  }
523
0
  return mrb_bool_value(respond_to_p);
524
0
}
525
526
static mrb_value
527
mrb_obj_ceqq(mrb_state *mrb, mrb_value self)
528
0
{
529
0
  mrb_value v = mrb_get_arg1(mrb);
530
0
  mrb_int i, len;
531
0
  mrb_sym eqq = MRB_OPSYM(eqq);
532
0
  mrb_value ary;
533
534
0
  mrb->c->ci->mid = 0;
535
0
  if (mrb_array_p(self)) {
536
0
    ary = self;
537
0
  }
538
0
  else if (mrb_nil_p(self)) {
539
0
    return mrb_false_value();
540
0
  }
541
0
  else if (!mrb_respond_to(mrb, self, MRB_SYM(to_a))) {
542
0
    mrb_value c = mrb_funcall_argv(mrb, self, eqq, 1, &v);
543
0
    if (mrb_test(c)) return mrb_true_value();
544
0
    return mrb_false_value();
545
0
  }
546
0
  else {
547
0
    ary = mrb_funcall_argv(mrb, self, MRB_SYM(to_a), 0, NULL);
548
0
    if (mrb_nil_p(ary)) {
549
0
      return mrb_funcall_argv(mrb, self, eqq, 1, &v);
550
0
    }
551
0
    mrb_ensure_array_type(mrb, ary);
552
0
  }
553
0
  len = RARRAY_LEN(ary);
554
0
  for (i=0; i<len; i++) {
555
0
    mrb_value c = mrb_funcall_argv(mrb, RARRAY_PTR(ary)[i], eqq, 1, &v);
556
0
    if (mrb_test(c)) return mrb_true_value();
557
0
  }
558
0
  return mrb_false_value();
559
0
}
560
561
// ISO 15.3.1.2.10 Kernel.print
562
// ISO 15.3.1.3.35 Kernel#print
563
mrb_value mrb_print_m(mrb_state *mrb, mrb_value self);
564
565
#ifndef HAVE_MRUBY_IO_GEM
566
// ISO 15.3.1.2.9   Kernel.p
567
// ISO 15.3.1.3.34  Kernel#p
568
//
569
// Print human readable object description
570
//
571
static mrb_value
572
mrb_p_m(mrb_state *mrb, mrb_value self)
573
{
574
  mrb_int argc;
575
  mrb_value *argv;
576
577
  mrb_get_args(mrb, "*", &argv, &argc);
578
  if (argc == 0) return mrb_nil_value();
579
  for (mrb_int i=0; i<argc; i++) {
580
    mrb_p(mrb, argv[i]);
581
  }
582
  if (argc == 1) return argv[0];
583
  return mrb_ary_new_from_values(mrb, argc, argv);
584
}
585
#endif
586
587
void
588
mrb_init_kernel(mrb_state *mrb)
589
2.05k
{
590
2.05k
  struct RClass *krn;
591
592
2.05k
  mrb->kernel_module = krn = mrb_define_module_id(mrb, MRB_SYM(Kernel));                                                    /* 15.3.1 */
593
#if 0
594
  mrb_define_class_method_id(mrb, krn, MRB_SYM_Q(block_given),        mrb_f_block_given_p_m,           MRB_ARGS_NONE());    /* 15.3.1.2.2  */
595
  mrb_define_class_method_id(mrb, krn, MRB_SYM_Q(iterator),           mrb_f_block_given_p_m,           MRB_ARGS_NONE());    /* 15.3.1.2.5  */
596
#endif
597
2.05k
  mrb_define_class_method_id(mrb, krn, MRB_SYM(raise),                mrb_f_raise,                     MRB_ARGS_OPT(2));    /* 15.3.1.2.12 */
598
599
2.05k
  mrb_define_method_id(mrb, krn, MRB_OPSYM(eqq),                      mrb_eqq_m,                       MRB_ARGS_REQ(1));    /* 15.3.1.3.2  */
600
2.05k
  mrb_define_method_id(mrb, krn, MRB_OPSYM(cmp),                      mrb_cmp_m,                       MRB_ARGS_REQ(1));
601
2.05k
  mrb_define_private_method_id(mrb, krn, MRB_SYM_Q(block_given),      mrb_f_block_given_p_m,           MRB_ARGS_NONE());    /* 15.3.1.3.6  */
602
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(class),                      mrb_obj_class_m,                 MRB_ARGS_NONE());    /* 15.3.1.3.7  */
603
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(clone),                      mrb_obj_clone,                   MRB_ARGS_NONE());    /* 15.3.1.3.8  */
604
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(dup),                        mrb_obj_dup,                     MRB_ARGS_NONE());    /* 15.3.1.3.9  */
605
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(eql),                      mrb_obj_equal_m,                 MRB_ARGS_REQ(1));    /* 15.3.1.3.10 */
606
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(freeze),                     mrb_obj_freeze,                  MRB_ARGS_NONE());
607
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(frozen),                   mrb_obj_frozen,                  MRB_ARGS_NONE());
608
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(extend),                     mrb_obj_extend,                  MRB_ARGS_ANY());     /* 15.3.1.3.13 */
609
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(hash),                       mrb_obj_hash,                    MRB_ARGS_NONE());    /* 15.3.1.3.15 */
610
2.05k
  mrb_define_private_method_id(mrb, krn, MRB_SYM(initialize_copy),    mrb_obj_init_copy,               MRB_ARGS_REQ(1));    /* 15.3.1.3.16 */
611
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(inspect),                    mrb_obj_inspect,                 MRB_ARGS_NONE());    /* 15.3.1.3.17 */
612
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(instance_of),              obj_is_instance_of,              MRB_ARGS_REQ(1));    /* 15.3.1.3.19 */
613
614
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(is_a),                     mrb_obj_is_kind_of_m,            MRB_ARGS_REQ(1));    /* 15.3.1.3.24 */
615
2.05k
  mrb_define_private_method_id(mrb, krn, MRB_SYM_Q(iterator),         mrb_f_block_given_p_m,           MRB_ARGS_NONE());    /* 15.3.1.3.25 */
616
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(kind_of),                  mrb_obj_is_kind_of_m,            MRB_ARGS_REQ(1));    /* 15.3.1.3.26 */
617
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(nil),                      mrb_false,                       MRB_ARGS_NONE());    /* 15.3.1.3.32 */
618
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(object_id),                  mrb_obj_id_m,                    MRB_ARGS_NONE());    /* 15.3.1.3.33 */
619
#ifndef HAVE_MRUBY_IO_GEM
620
  mrb_define_private_method_id(mrb, krn, MRB_SYM(p),                  mrb_p_m,                         MRB_ARGS_ANY());     /* 15.3.1.3.34 */
621
  mrb_define_private_method_id(mrb, krn, MRB_SYM(print),              mrb_print_m,                     MRB_ARGS_ANY());     /* 15.3.1.3.35 */
622
#endif
623
2.05k
  mrb_define_private_method_id(mrb, krn, MRB_SYM(raise),              mrb_f_raise,                     MRB_ARGS_OPT(2));    /* 15.3.1.3.40 */
624
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(remove_instance_variable),   mrb_obj_remove_instance_variable,MRB_ARGS_REQ(1));    /* 15.3.1.3.41 */
625
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(respond_to),               obj_respond_to,                  MRB_ARGS_ARG(1,1));  /* 15.3.1.3.43 */
626
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(to_s),                       mrb_any_to_s,                    MRB_ARGS_NONE());    /* 15.3.1.3.46 */
627
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(__case_eqq),                 mrb_obj_ceqq,                    MRB_ARGS_REQ(1));    /* internal */
628
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM(__to_int),                   mrb_ensure_int_type,             MRB_ARGS_NONE());    /* internal */
629
2.05k
  mrb_define_private_method_id(mrb, krn, MRB_SYM_Q(respond_to_missing), mrb_false,                     MRB_ARGS_ARG(1,1));
630
2.05k
  mrb_define_method_id(mrb, krn, MRB_SYM_Q(__inspect_recursive),      mrb_obj_inspect_recursive_p,     MRB_ARGS_NONE());
631
632
2.05k
  mrb_include_module(mrb, mrb->object_class, mrb->kernel_module);
633
2.05k
}