2 ** @file mruby/range.h - Range class
4 ** See Copyright Notice in mruby.h
17 #if defined(MRB_NAN_BOXING) && defined(MRB_64BIT) || defined(MRB_WORD_BOXING)
18 # define MRB_RANGE_EMBED
21 #ifdef MRB_RANGE_EMBED
28 # define mrb_gc_free_range(mrb, p) ((void)0)
29 # define RANGE_BEG(p) ((p)->beg)
30 # define RANGE_END(p) ((p)->end)
32 typedef struct mrb_range_edges
{
38 mrb_range_edges
*edges
;
41 # define mrb_gc_free_range(mrb, p) mrb_free(mrb, (p)->edges)
42 # define RANGE_BEG(p) ((p)->edges->beg)
43 # define RANGE_END(p) ((p)->edges->end)
46 #define mrb_range_beg(mrb, r) RANGE_BEG(mrb_range_ptr(mrb, r))
47 #define mrb_range_end(mrb, r) RANGE_END(mrb_range_ptr(mrb, r))
48 #define mrb_range_excl_p(mrb, r) RANGE_EXCL(mrb_range_ptr(mrb, r))
49 #define mrb_range_raw_ptr(r) ((struct RRange*)mrb_ptr(r))
50 #define mrb_range_value(p) mrb_obj_value((void*)(p))
51 #define RANGE_EXCL(p) ((p)->excl)
53 MRB_API
struct RRange
* mrb_range_ptr(mrb_state
*mrb
, mrb_value range
);
56 * Initializes a Range.
58 * If the third parameter is FALSE then it includes the last value in the range.
59 * If the third parameter is TRUE then it excludes the last value in the range.
61 * @param start the beginning value.
62 * @param end the ending value.
63 * @param exclude represents the inclusion or exclusion of the last value.
65 MRB_API mrb_value
mrb_range_new(mrb_state
*mrb
, mrb_value start
, mrb_value end
, mrb_bool exclude
);
67 enum mrb_range_beg_len
{
68 MRB_RANGE_TYPE_MISMATCH
= 0, /* (failure) not range */
69 MRB_RANGE_OK
= 1, /* (success) range */
70 MRB_RANGE_OUT
= 2 /* (failure) out of range */
73 MRB_API
enum mrb_range_beg_len
mrb_range_beg_len(mrb_state
*mrb
, mrb_value range
, mrb_int
*begp
, mrb_int
*lenp
, mrb_int len
, mrb_bool trunc
);
74 mrb_value
mrb_get_values_at(mrb_state
*mrb
, mrb_value obj
, mrb_int olen
, mrb_int argc
, const mrb_value
*argv
, mrb_value (*func
)(mrb_state
*, mrb_value
, mrb_int
));
75 void mrb_gc_mark_range(mrb_state
*mrb
, struct RRange
*r
);
79 #endif /* MRUBY_RANGE_H */