summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-08-04 10:51:32 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-08-04 10:51:32 +0900
commit0fa3668e917c45409acd56ba624db24d95699895 (patch)
tree76085b468fb85bb932b2f7b0c2e8538aa245900e /src
parent29bfbac86ddd829326df025c009264cebd243610 (diff)
parentb6e27218ad1ffdba6d2103b85d5d9231b6380008 (diff)
downloadmruby-0fa3668e917c45409acd56ba624db24d95699895.tar.gz
mruby-0fa3668e917c45409acd56ba624db24d95699895.zip
Merge pull request #2498 from cremno/msvc-snprintf
MSVC: add simple (v)snprintf implementation
Diffstat (limited to 'src')
-rw-r--r--src/etc.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/etc.c b/src/etc.c
index 4aee04ec0..9125aa16a 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 */