summaryrefslogtreecommitdiffhomepage
path: root/src/etc.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-08-04 16:28:02 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-08-04 16:28:02 +0900
commitea80e8285247992fc4308621571eed9a0e215184 (patch)
tree4fb483d7d65372558052cdc4baf378ac104e4116 /src/etc.c
parentdb7b01c0b360b2909b14dbd399ee5a3eb2fce0c5 (diff)
parent0fa3668e917c45409acd56ba624db24d95699895 (diff)
downloadmruby-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.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/etc.c b/src/etc.c
index 41f6b5609..68b26b024 100644
--- a/src/etc.c
+++ b/src/etc.c
@@ -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 */