14#include "ruby/internal/config.h"
25#include "internal/error.h"
26#include "internal/hash.h"
27#include "internal/numeric.h"
28#include "internal/object.h"
29#include "internal/sanitizers.h"
30#include "internal/symbol.h"
35#define BIT_DIGITS(N) (((N)*146)/485 + 1)
37static char *fmt_setup(
char*,
size_t,
int,
int,
int,
int);
38static char *ruby_ultoa(
unsigned long val,
char *endp,
int base,
int octzero);
41sign_bits(
int base,
const char *p)
47 if (*p ==
'X') c =
'F';
69expand_result(
VALUE result,
long bsiz,
long blen,
long l)
73 while (l > bsiz - blen) {
75 if (bsiz < 0) rb_raise(rb_eArgError,
"too big specifier");
77 rb_str_resize(result, bsiz);
83 bsiz = expand_result(result, bsiz, blen, l);\
84 buf = RSTRING_PTR(result);\
87#define CHECK_WIDTH(l, w) do { \
88 if ((l) > INT_MAX - (w)) rb_raise(rb_eArgError, "width too big");\
92#define PUSH(s, l) do { \
97#define PUSH_(s, l) do { \
98 memcpy(&buf[blen], (s), (l));\
102#define FILL(c, l) do { \
103 if ((l) <= 0) break;\
108#define FILL_(c, l) do { \
109 memset(&buf[blen], (c), (l));\
113#define GETARG() (!UNDEF_P(nextvalue) ? nextvalue : \
116#define GETNEXTARG() ( \
117 check_next_arg(posarg, nextarg), \
118 (posarg = nextarg++, GETNTHARG(posarg)))
120#define GETPOSARG(n) ( \
121 check_pos_arg(posarg, (n)), \
122 (posarg = -1, GETNTHARG(n)))
124#define GETNTHARG(nth) \
125 (((nth) >= argc) ? (rb_raise(rb_eArgError, "too few arguments"), 0) : argv[(nth)])
127#define CHECKNAMEARG(name, len, enc) ( \
128 check_name_arg(posarg, name, len, enc), \
131#define GETNUM(n, val) \
132 (!(p = get_num(p, end, enc, &(n))) ? \
133 rb_raise(rb_eArgError, #val " too big") : (void)0)
135#define GETASTER(val) do { \
140 tmp = GETPOSARG(n); \
143 tmp = GETNEXTARG(); \
146 (val) = NUM2INT(tmp); \
150get_num(
const char *p,
const char *end,
rb_encoding *enc,
int *valp)
154 if (MUL_OVERFLOW_INT_P(10, next_n))
157 if (INT_MAX - (*p -
'0') < next_n)
162 rb_raise(rb_eArgError,
"malformed format string - %%*[0-9]");
169check_next_arg(
int posarg,
int nextarg)
173 rb_raise(rb_eArgError,
"unnumbered(%d) mixed with numbered", nextarg);
175 rb_raise(rb_eArgError,
"unnumbered(%d) mixed with named", nextarg);
180check_pos_arg(
int posarg,
int n)
183 rb_raise(rb_eArgError,
"numbered(%d) after unnumbered(%d)", n, posarg);
186 rb_raise(rb_eArgError,
"numbered(%d) after named", n);
189 rb_raise(rb_eArgError,
"invalid index - %d$", n);
194check_name_arg(
int posarg,
const char *name,
int len,
rb_encoding *enc)
197 rb_enc_raise(enc, rb_eArgError,
"named%.*s after unnumbered(%d)",
len, name, posarg);
200 rb_enc_raise(enc, rb_eArgError,
"named%.*s after numbered",
len, name);
205get_hash(
volatile VALUE *hash,
int argc,
const VALUE *argv)
209 if (!UNDEF_P(*hash))
return *hash;
211 rb_raise(rb_eArgError,
"one hash required");
213 tmp = rb_check_hash_type(argv[1]);
215 rb_raise(rb_eArgError,
"one hash required");
217 return (*hash = tmp);
229 enum {default_float_precision = 6};
238 int width, prec, flags = FNONE;
247#define CHECK_FOR_WIDTH(f) \
248 if ((f) & FWIDTH) { \
249 rb_raise(rb_eArgError, "width given twice"); \
251 if ((f) & FPREC0) { \
252 rb_raise(rb_eArgError, "width after precision"); \
254#define CHECK_FOR_FLAGS(f) \
255 if ((f) & FWIDTH) { \
256 rb_raise(rb_eArgError, "flag after width"); \
258 if ((f) & FPREC0) { \
259 rb_raise(rb_eArgError, "flag after precision"); \
262#define update_coderange(partial) do { \
263 if (coderange != ENC_CODERANGE_BROKEN && scanned < blen) { \
264 int cr = coderange; \
265 scanned += rb_str_coderange_scan_restartable(buf+scanned, buf+blen, enc, &cr); \
266 ENC_CODERANGE_SET(result, \
267 (partial && cr == ENC_CODERANGE_UNKNOWN ? \
268 ENC_CODERANGE_BROKEN : (coderange = cr))); \
274 enc = rb_enc_get(fmt);
277 fmt = rb_str_tmp_frozen_acquire(fmt);
278 p = RSTRING_PTR(fmt);
279 end = p + RSTRING_LEN(fmt);
283 rb_enc_associate(result, enc);
284 buf = RSTRING_PTR(result);
285 memset(buf, 0, bsiz);
288 for (; p < end; p++) {
293 for (t = p; t < end && *t !=
'%'; t++) ;
295 rb_raise(rb_eArgError,
"incomplete format specifier; use %%%% (double %%) instead");
298 update_coderange(FALSE);
311 rb_raise(rb_eArgError,
"malformed format string - %%%c", *p);
313 rb_raise(rb_eArgError,
"malformed format string");
317 CHECK_FOR_FLAGS(flags);
323 CHECK_FOR_FLAGS(flags);
329 CHECK_FOR_FLAGS(flags);
335 CHECK_FOR_FLAGS(flags);
341 CHECK_FOR_FLAGS(flags);
346 case '1':
case '2':
case '3':
case '4':
347 case '5':
case '6':
case '7':
case '8':
case '9':
351 if (!UNDEF_P(nextvalue)) {
352 rb_raise(rb_eArgError,
"value given twice - %d$", n);
354 nextvalue = GETPOSARG(n);
358 CHECK_FOR_WIDTH(flags);
366 const char *start = p;
367 char term = (*p ==
'<') ?
'>' :
'}';
370 for (; p < end && *p != term; ) {
371 p += rb_enc_mbclen(p, end, enc);
374 rb_raise(rb_eArgError,
"malformed name - unmatched parenthesis");
376#if SIZEOF_INT < SIZEOF_SIZE_T
377 if ((
size_t)(p - start) >= INT_MAX) {
378 const int message_limit = 20;
381 "too long name (%"PRIuSIZE
" bytes) - %.*s...%c",
382 (
size_t)(p - start - 2),
len, start, term);
385 len = (int)(p - start + 1);
387 rb_enc_raise(enc, rb_eArgError,
"named%.*s after <%"PRIsVALUE
">",
390 CHECKNAMEARG(start,
len, enc);
391 get_hash(&hash, argc, argv);
395 if (!
NIL_P(sym)) nextvalue = rb_hash_lookup2(hash, sym,
Qundef);
396 if (UNDEF_P(nextvalue)) {
398 sym = rb_sym_intern(start + 1,
402 nextvalue = rb_hash_default_value(hash, sym);
403 if (
NIL_P(nextvalue)) {
404 rb_key_err_raise(
rb_enc_sprintf(enc,
"key%.*s not found",
len, start), hash, sym);
407 if (term ==
'}')
goto format_s;
413 CHECK_FOR_WIDTH(flags);
419 if (width < 0) rb_raise(rb_eArgError,
"width too big");
425 if (flags & FPREC0) {
426 rb_raise(rb_eArgError,
"precision given twice");
428 flags |= FPREC|FPREC0;
441 GETNUM(prec, precision);
445 if (flags != FNONE) {
446 rb_raise(rb_eArgError,
"invalid format character - %%");
453 VALUE val = GETARG();
467 n = rb_enc_codelen((c = n), enc);
468 encidx = rb_ascii8bit_appendable_encoding_index(enc, c);
471 rb_raise(rb_eArgError,
"invalid character");
473 if (encidx >= 0 && encidx != rb_enc_to_index(enc)) {
475 rb_enc_associate_index(result, encidx);
476 enc = rb_enc_from_index(encidx);
479 if (!(flags & FWIDTH)) {
481 rb_enc_mbcput(c, &buf[blen], enc);
486 CHECK_WIDTH(n, (width > 0 ? width : 0));
487 if (!(flags & FMINUS) && (width > 0)) FILL_(
' ', width);
488 rb_enc_mbcput(c, &buf[blen], enc);
490 if ((flags & FMINUS) && (width > 0)) FILL_(
' ', width);
499 VALUE arg = GETARG();
509 len = RSTRING_LEN(str);
511 update_coderange(TRUE);
512 enc = rb_enc_check(result, str);
513 if (flags&(FPREC|FWIDTH)) {
516 rb_raise(rb_eArgError,
"invalid mbstring sequence");
518 if ((flags&FPREC) && (prec < slen)) {
522 len = p - RSTRING_PTR(str);
525 if ((flags&FWIDTH) && (width > slen)) {
527 CHECK_WIDTH(
len, width);
528 if (!(flags&FMINUS)) {
532 memcpy(&buf[blen], RSTRING_PTR(str),
len);
538 rb_enc_associate(result, enc);
542 PUSH(RSTRING_PTR(str),
len);
544 rb_enc_associate(result, enc);
557 volatile VALUE val = GETARG();
559 char nbuf[BIT_DIGITS(SIZEOF_LONG*CHAR_BIT)+2], *s;
560 const char *prefix = 0;
561 int sign = 0, dots = 0;
564 int base, bignum = 0;
577 if (flags&(FPLUS|FSPACE)) sign = 1;
580 if (flags & FSHARP) {
585 prefix =
"0x";
break;
587 prefix =
"0X";
break;
589 prefix =
"0b";
break;
591 prefix =
"0B";
break;
607 val = rb_str_to_inum(val, 0, TRUE);
637 int numbits = ffs(base)-1;
639 size_t numdigits = rb_absint_numwords(val, numbits, &abs_nlz_bits);
641 if (INT_MAX-1 < numdigits)
642 rb_raise(rb_eArgError,
"size too big");
647 valsign = rb_integer_pack(val, RSTRING_PTR(tmp), RSTRING_LEN(tmp),
649 for (i = 0; i < RSTRING_LEN(tmp); i++)
650 RSTRING_PTR(tmp)[i] = ruby_digitmap[((
unsigned char *)RSTRING_PTR(tmp))[i]];
651 s = RSTRING_PTR(tmp);
656 else if (flags & FPLUS) {
660 else if (flags & FSPACE) {
675 if (numdigits == 0 ||
676 ((abs_nlz_bits != (
size_t)(numbits-1) ||
677 !rb_absint_singlebit_p(val)) &&
678 (!bignum ? v < 0 : BIGNUM_NEGATIVE_P(val))))
681 valsign = rb_integer_pack(val, RSTRING_PTR(tmp), RSTRING_LEN(tmp),
683 for (i = 0; i < RSTRING_LEN(tmp); i++)
684 RSTRING_PTR(tmp)[i] = ruby_digitmap[((
unsigned char *)RSTRING_PTR(tmp))[i]];
685 s = RSTRING_PTR(tmp);
698 else if (flags & FPLUS) {
702 else if (flags & FSPACE) {
706 s = ruby_ultoa((
unsigned long)v, nbuf +
sizeof(nbuf), 10, 0);
707 len = (int)(nbuf +
sizeof(nbuf) - s);
710 tmp = rb_big2str(val, 10);
711 s = RSTRING_PTR(tmp);
719 else if (flags & FPLUS) {
723 else if (flags & FSPACE) {
738 while ((c = (
int)(
unsigned char)*pp) != 0) {
739 *pp = rb_enc_toupper(c, enc);
743 if (prefix && !prefix[1]) {
747 else if (
len == 1 && *s ==
'0') {
749 if (flags & FPREC) prec--;
751 else if ((flags & FPREC) && (prec >
len)) {
755 else if (
len == 1 && *s ==
'0') {
759 width -= (int)strlen(prefix);
761 if ((flags & (FZERO|FMINUS|FPREC)) == FZERO) {
767 if (!prefix && prec == 0 &&
len == 1 && *s ==
'0')
len = 0;
772 if (!(flags&FMINUS)) {
776 if (sc) PUSH(&sc, 1);
778 int plen = (int)strlen(prefix);
781 if (dots) PUSH(
"..", 2);
784 if (!sign && valsign < 0) {
785 char c = sign_bits(base, p);
786 FILL_(c, prec -
len);
788 else if ((flags & (FMINUS|FPREC)) != FMINUS) {
789 FILL_(
'0', prec -
len);
800 VALUE val = GETARG(), num, den;
801 int sign = (flags&FPLUS) ? 1 : 0, zero = 0;
815 if (!(flags&FPREC)) prec = default_float_precision;
823 else if (BIGNUM_NEGATIVE_P(num)) {
825 num = rb_big_uminus(num);
829 num = rb_int_plus(num, rb_int_idiv(den,
INT2FIX(2)));
830 num = rb_int_idiv(num, den);
832 else if (prec >= 0) {
835 val = rb_int2str(num, 10);
836 len = RSTRING_LEN(val) + zero;
837 if (prec >=
len)
len = prec + 1;
838 if (sign || (flags&FSPACE)) ++
len;
840 fill = width >
len ? width -
len : 0;
842 if (fill && !(flags&(FMINUS|FZERO))) {
845 if (sign || (flags&FSPACE)) {
846 buf[blen++] = sign > 0 ?
'+' : sign < 0 ?
'-' :
' ';
848 if (fill && (flags&(FMINUS|FZERO)) == FZERO) {
851 len = RSTRING_LEN(val) + zero;
852 t = RSTRING_PTR(val);
854 PUSH_(t,
len - prec);
865 else if (prec >
len) {
866 FILL_(
'0', prec -
len);
870 PUSH_(t +
len - prec, prec);
872 if (fill && (flags&FMINUS)) {
887 VALUE val = GETARG();
891 if (!isfinite(fval)) {
903 need = (int)strlen(expr);
905 if (!isnan(fval) && fval < 0.0)
907 else if (flags & (FPLUS|FSPACE))
908 sign = (flags & FPLUS) ?
'+' :
' ';
911 if ((flags & FWIDTH) && need < width)
915 if (flags & FMINUS) {
917 buf[blen - need--] = sign;
918 memcpy(&buf[blen - need], expr, elen);
922 buf[blen - elen - 1] = sign;
923 memcpy(&buf[blen - elen], expr, elen);
929 char fbuf[2*BIT_DIGITS(SIZEOF_INT*CHAR_BIT)+10];
930 char *fmt = fmt_setup(fbuf,
sizeof(fbuf), *p, flags, width, prec);
932 rb_str_catf(result, fmt, fval);
943 update_coderange(FALSE);
945 rb_str_tmp_frozen_release(orig, fmt);
948 if (posarg >= 0 && nextarg < argc && !(argc == 2 &&
RB_TYPE_P(argv[1],
T_HASH))) {
949 const char *mesg =
"too many arguments for format string";
953 rb_str_resize(result, blen);
959fmt_setup(
char *buf,
size_t size,
int c,
int flags,
int width,
int prec)
966 buf = ruby_ultoa(prec, buf, 10, 0);
970 if (flags & FWIDTH) {
971 buf = ruby_ultoa(width, buf, 10, 0);
974 if (flags & FSPACE) *--buf =
' ';
975 if (flags & FZERO) *--buf =
'0';
976 if (flags & FMINUS) *--buf =
'-';
977 if (flags & FPLUS) *--buf =
'+';
978 if (flags & FSHARP) *--buf =
'#';
984#define FILE rb_printf_buffer
985#define __sbuf rb_printf_sbuf
986#define __sFILE rb_printf_sfile
991#if SIZEOF_LONG < SIZEOF_LONG_LONG
992# if SIZEOF_LONG_LONG == SIZEOF_VOIDP
997# define _HAVE_SANE_QUAD_
998# define quad_t LONG_LONG
999# define u_quad_t unsigned LONG_LONG
1001#define FLOATING_POINT 1
1002#define BSD__dtoa ruby_dtoa
1003#define BSD__hdtoa ruby_hdtoa
1004#ifdef RUBY_PRI_VALUE_MARK
1005# define PRI_EXTRA_MARK RUBY_PRI_VALUE_MARK
1007#define lower_hexdigits (ruby_hexdigits+0)
1008#define upper_hexdigits (ruby_hexdigits+16)
1009#include "vsnprintf.c"
1012ruby_ultoa(
unsigned long val,
char *endp,
int base,
int flags)
1014 const char *xdigs = lower_hexdigits;
1015 int octzero = flags & FSHARP;
1016 return BSD__ultoa(val, endp, base, octzero, xdigs);
1019static int ruby_do_vsnprintf(
char *str,
size_t n,
const char *fmt, va_list ap);
1024 if (str && (ssize_t)n < 1)
1026 return ruby_do_vsnprintf(str, n, fmt, ap);
1030ruby_do_vsnprintf(
char *str,
size_t n,
const char *fmt, va_list ap)
1035 f._flags = __SWR | __SSTR;
1036 f._bf._base = f._p = (
unsigned char *)str;
1037 f._bf._size = f._w = str ? (n - 1) : 0;
1038 f.vwrite = BSD__sfvwrite;
1040 ret = BSD_vfprintf(&f, fmt, ap);
1042#if SIZEOF_SIZE_T > SIZEOF_INT
1043 if (n > INT_MAX)
return INT_MAX;
1054 if (str && (ssize_t)n < 1)
1058 ret = ruby_do_vsnprintf(str, n, fmt, ap);
1064 rb_printf_buffer base;
1065 volatile VALUE value;
1069ruby__sfvwrite(
register rb_printf_buffer *fp,
register struct __suio *uio)
1073 char *buf = (
char*)fp->_p;
1075 long blen = buf - RSTRING_PTR(result), bsiz = fp->_w;
1077 if (
RBASIC(result)->klass) {
1080 if (uio->uio_resid == 0)
1082#if SIZE_MAX > LONG_MAX
1083 if (uio->uio_resid >= LONG_MAX)
1086 len = (long)uio->uio_resid;
1090 for (iov = uio->uio_iov;
len > 0; ++iov) {
1091 MEMCPY(buf, iov->iov_base,
char, n = iov->iov_len);
1095 fp->_p = (
unsigned char *)buf;
1101ruby__sfvextra(rb_printf_buffer *fp,
size_t valsize,
void *valp,
long *sz,
int sign)
1107 if (valsize !=
sizeof(
VALUE))
return 0;
1108 value = *(
VALUE *)valp;
1109 if (
RBASIC(result)->klass) {
1113# define LITERAL(str) (*sz = rb_strlen_lit(str), str)
1116# define LITERAL_CASE(x) case Q##x: return LITERAL(#x)
1119 LITERAL_CASE(
false);
1127 if (sign ==
' ' && !rb_str_symname_p(value)) {
1128 value = rb_str_escape(value);
1133 if (sign ==
' ') value = QUOTE(value);
1135 enc = rb_enc_compatible(result, value);
1136 if (enc && rb_enc_asciicompat(enc)) {
1137 rb_enc_associate(result, enc);
1140 enc = rb_enc_get(result);
1144 *(
volatile VALUE *)valp = value;
1153ruby_vsprintf0(
VALUE result,
char *p,
const char *fmt, va_list ap)
1156#define f buffer.base
1163 f._flags = __SWR | __SSTR;
1166 f._bf._base = (
unsigned char *)result;
1167 f._p = (
unsigned char *)p;
1168 RBASIC_CLEAR_CLASS(result);
1169 f.vwrite = ruby__sfvwrite;
1170 f.vextra = ruby__sfvextra;
1172 BSD_vfprintf(&f, fmt, ap);
1173 RBASIC_SET_CLASS_RAW(result, klass);
1174 p = RSTRING_PTR(result);
1175 long blen = (
char *)f._p - p;
1182 rb_str_resize(result, blen);
1189 if (!rb_enc_asciicompat(enc)) {
1198 const int initial_len = 120;
1203 rb_enc_associate(result, enc_check(enc));
1205 ruby_vsprintf0(result, RSTRING_PTR(result), fmt, ap);
1215 va_start(ap, format);
1229rb_sprintf(
const char *format, ...)
1234 va_start(ap, format);
1242rb_str_vcatf(
VALUE str,
const char *fmt, va_list ap)
1245 enc_check(rb_enc_get(str));
1253rb_str_catf(
VALUE str,
const char *format, ...)
1257 va_start(ap, format);
1258 str = rb_str_vcatf(str, format, ap);
#define RUBY_ASSERT(...)
Asserts that the given expression is truthy if and only if RUBY_DEBUG is truthy.
ruby_coderange_type
What rb_enc_str_coderange() returns.
static bool rb_enc_isprint(OnigCodePoint c, rb_encoding *enc)
Identical to rb_isprint(), except it additionally takes an encoding.
static bool rb_enc_isdigit(OnigCodePoint c, rb_encoding *enc)
Identical to rb_isdigit(), except it additionally takes an encoding.
VALUE rb_enc_vsprintf(rb_encoding *enc, const char *fmt, va_list ap)
Identical to rb_enc_sprintf(), except it takes a va_list instead of variadic arguments.
VALUE rb_enc_sprintf(rb_encoding *enc, const char *fmt,...)
Identical to rb_sprintf(), except it additionally takes an encoding.
#define TYPE(_)
Old name of rb_type.
#define RB_INTEGER_TYPE_P
Old name of rb_integer_type_p.
#define ENC_CODERANGE_7BIT
Old name of RUBY_ENC_CODERANGE_7BIT.
#define ENC_CODERANGE_VALID
Old name of RUBY_ENC_CODERANGE_VALID.
#define RFLOAT_VALUE
Old name of rb_float_value.
#define T_STRING
Old name of RUBY_T_STRING.
#define Qundef
Old name of RUBY_Qundef.
#define INT2FIX
Old name of RB_INT2FIX.
#define T_FLOAT
Old name of RUBY_T_FLOAT.
#define T_BIGNUM
Old name of RUBY_T_BIGNUM.
#define ECONV_UNDEF_REPLACE
Old name of RUBY_ECONV_UNDEF_REPLACE.
#define T_FIXNUM
Old name of RUBY_T_FIXNUM.
#define ENC_CODERANGE(obj)
Old name of RB_ENC_CODERANGE.
#define ENC_CODERANGE_UNKNOWN
Old name of RUBY_ENC_CODERANGE_UNKNOWN.
#define FIXABLE
Old name of RB_FIXABLE.
#define LONG2FIX
Old name of RB_INT2FIX.
#define ECONV_INVALID_REPLACE
Old name of RUBY_ECONV_INVALID_REPLACE.
#define T_RATIONAL
Old name of RUBY_T_RATIONAL.
#define T_HASH
Old name of RUBY_T_HASH.
#define LONG2NUM
Old name of RB_LONG2NUM.
#define NUM2INT
Old name of RB_NUM2INT.
#define Qnil
Old name of RUBY_Qnil.
#define FIX2LONG
Old name of RB_FIX2LONG.
#define NIL_P
Old name of RB_NIL_P.
#define FIXNUM_P
Old name of RB_FIXNUM_P.
#define ENC_CODERANGE_SET(obj, cr)
Old name of RB_ENC_CODERANGE_SET.
#define SYMBOL_P
Old name of RB_SYMBOL_P.
#define ruby_debug
This variable controls whether the interpreter is in debug mode.
#define ruby_verbose
This variable controls whether the interpreter is in debug mode.
VALUE rb_eEncCompatError
Encoding::CompatibilityError exception.
VALUE rb_eRuntimeError
RuntimeError exception.
void rb_warn(const char *fmt,...)
Identical to rb_warning(), except it reports unless $VERBOSE is nil.
void rb_enc_raise(rb_encoding *enc, VALUE exc, const char *fmt,...)
Identical to rb_raise(), except it additionally takes an encoding.
VALUE rb_Float(VALUE val)
This is the logic behind Kernel#Float.
VALUE rb_Integer(VALUE val)
This is the logic behind Kernel#Integer.
VALUE rb_inspect(VALUE obj)
Generates a human-readable textual representation of the given object.
static char * rb_enc_right_char_head(const char *s, const char *p, const char *e, rb_encoding *enc)
Queries the right boundary of a character.
char * rb_enc_nth(const char *head, const char *tail, long nth, rb_encoding *enc)
Queries the n-th character.
VALUE rb_str_conv_enc_opts(VALUE str, rb_encoding *from, rb_encoding *to, int ecflags, VALUE ecopts)
Identical to rb_str_conv_enc(), except it additionally takes IO encoder options.
long rb_enc_strlen(const char *head, const char *tail, rb_encoding *enc)
Counts the number of characters of the passed string, according to the passed encoding.
long rb_str_coderange_scan_restartable(const char *str, const char *end, rb_encoding *enc, int *cr)
Scans the passed string until it finds something odd.
VALUE rb_check_symbol_cstr(const char *ptr, long len, rb_encoding *enc)
Identical to rb_check_id_cstr(), except for the return type.
#define INTEGER_PACK_BIG_ENDIAN
Big endian combination.
#define INTEGER_PACK_2COMP
Uses 2's complement representation.
VALUE rb_int_positive_pow(long x, unsigned long y)
Raises the passed x to the power of y.
VALUE rb_rational_num(VALUE rat)
Queries the numerator of the passed Rational.
VALUE rb_rational_den(VALUE rat)
Queries the denominator of the passed Rational.
#define rb_str_new(str, len)
Allocates an instance of rb_cString.
size_t rb_str_capacity(VALUE str)
Queries the capacity of the given string.
void rb_str_set_len(VALUE str, long len)
Overwrites the length of the string.
void rb_must_asciicompat(VALUE obj)
Asserts that the given string's encoding is (Ruby's definition of) ASCII compatible.
VALUE rb_check_string_type(VALUE obj)
Try converting an object to its stringised representation using its to_str method,...
VALUE rb_str_buf_new(long capa)
Allocates a "string buffer".
VALUE rb_obj_as_string(VALUE obj)
Try converting an object to its stringised representation using its to_s method, if any.
VALUE rb_sym2str(VALUE symbol)
Obtain a frozen string representation of a symbol (not including the leading colon).
int len
Length of the buffer.
VALUE rb_str_format(int argc, const VALUE *argv, VALUE fmt)
Formats a string.
VALUE rb_f_sprintf(int argc, const VALUE *argv)
Identical to rb_str_format(), except how the arguments are arranged.
VALUE rb_vsprintf(const char *fmt, va_list ap)
Identical to rb_sprintf(), except it takes a va_list.
#define rb_long2int
Just another name of rb_long2int_inline.
#define MEMCPY(p1, p2, type, n)
Handy macro to call memcpy.
#define RB_GC_GUARD(v)
Prevents premature destruction of local objects.
#define RBASIC(obj)
Convenient casting macro.
#define StringValue(v)
Ensures that the parameter object is a String.
static char * RSTRING_END(VALUE str)
Queries the end of the contents pointer of the string.
#define RSTRING_GETMEM(str, ptrvar, lenvar)
Convenient macro to obtain the contents and length at once.
#define StringValueCStr(v)
Identical to StringValuePtr, except it additionally checks for the contents for viability as a C stri...
int ruby_vsnprintf(char *str, size_t n, char const *fmt, va_list ap)
Identical to ruby_snprintf(), except it takes a va_list.
int ruby_snprintf(char *str, size_t n, char const *fmt,...)
Our own locale-insensitive version of snprintf(3).
#define RTEST
This is an old name of RB_TEST.
intptr_t SIGNED_VALUE
A signed integer type that has the same width with VALUE.
uintptr_t VALUE
Type that represents a Ruby object.
static bool RB_TYPE_P(VALUE obj, enum ruby_value_type t)
Queries if the given object is of given type.