diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-08-04 16:28:02 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-08-04 16:28:02 +0900 |
| commit | ea80e8285247992fc4308621571eed9a0e215184 (patch) | |
| tree | 4fb483d7d65372558052cdc4baf378ac104e4116 /src/etc.c | |
| parent | db7b01c0b360b2909b14dbd399ee5a3eb2fce0c5 (diff) | |
| parent | 0fa3668e917c45409acd56ba624db24d95699895 (diff) | |
| download | mruby-ea80e8285247992fc4308621571eed9a0e215184.tar.gz mruby-ea80e8285247992fc4308621571eed9a0e215184.zip | |
Merge branch 'master' of github.com:mruby/mruby
Diffstat (limited to 'src/etc.c')
| -rw-r--r-- | src/etc.c | 37 |
1 files changed, 37 insertions, 0 deletions
@@ -183,3 +183,40 @@ mrb_regexp_p(mrb_state *mrb, mrb_value v) { return mrb_class_defined(mrb, REGEXP_CLASS) && mrb_obj_is_kind_of(mrb, v, mrb_class_get(mrb, REGEXP_CLASS)); } + +#if defined _MSC_VER && _MSC_VER < 1900 + +#ifndef va_copy +static void +mrb_msvc_va_copy(va_list *dest, va_list src) +{ + *dest = src; +} +#define va_copy(dest, src) msvc_va_copy(&(dest), src) +#endif + +MRB_API int +mrb_msvc_vsnprintf(char *s, size_t n, const char *format, va_list arg) +{ + int cnt; + va_list argcp; + va_copy(argcp, arg); + if (n == 0 || (cnt = _vsnprintf_s(s, n, _TRUNCATE, format, argcp)) < 0) { + cnt = _vscprintf(format, arg); + } + va_end(argcp); + return cnt; +} + +MRB_API int +mrb_msvc_snprintf(char *s, size_t n, const char *format, ...) +{ + va_list arg; + int ret; + va_start(arg, format); + ret = mrb_msvc_vsnprintf(s, n, format, arg); + va_end(arg); + return ret; +} + +#endif /* defined _MSC_VER && _MSC_VER < 1900 */ |
