]> granicus.if.org Git - vim/commitdiff
patch 8.0.0191: can't build with Ruby on some systems v8.0.0191
authorBram Moolenaar <Bram@vim.org>
Sun, 15 Jan 2017 15:59:07 +0000 (16:59 +0100)
committerBram Moolenaar <Bram@vim.org>
Sun, 15 Jan 2017 15:59:07 +0000 (16:59 +0100)
Problem:    Some systems do not have ruby_sysinit(), causing the build to
            fail.
Solution:   Clean up how ruby_sysinit() and NtInitialize() are used. (Taro
            Muraoka)

src/if_ruby.c
src/version.c

index 509d2f6cf1d5e6137739b5899145e7491501f999..afa27abe2ca5f8aead825b91967012c252abc391 100644 (file)
@@ -303,6 +303,7 @@ static void ruby_vim_init(void);
 # define ruby_init_loadpath            dll_ruby_init_loadpath
 # ifdef WIN3264
 #  define NtInitialize                 dll_NtInitialize
+#  define ruby_sysinit                 dll_ruby_sysinit
 #  if defined(DYNAMIC_RUBY_VER) && DYNAMIC_RUBY_VER >= 18
 #   define rb_w32_snprintf             dll_rb_w32_snprintf
 #  endif
@@ -405,6 +406,7 @@ static void (*dll_ruby_init) (void);
 static void (*dll_ruby_init_loadpath) (void);
 # ifdef WIN3264
 static void (*dll_NtInitialize) (int*, char***);
+static void (*dll_ruby_sysinit) (int*, char***);
 #  if defined(DYNAMIC_RUBY_VER) && DYNAMIC_RUBY_VER >= 18
 static int (*dll_rb_w32_snprintf)(char*, size_t, const char*, ...);
 #  endif
@@ -594,13 +596,11 @@ static struct
     {"ruby_init", (RUBY_PROC*)&dll_ruby_init},
     {"ruby_init_loadpath", (RUBY_PROC*)&dll_ruby_init_loadpath},
 # ifdef WIN3264
-    {
 #  if defined(DYNAMIC_RUBY_VER) && DYNAMIC_RUBY_VER < 19
-    "NtInitialize",
+    {"NtInitialize", (RUBY_PROC*)&dll_NtInitialize},
 #  else
-    "ruby_sysinit",
+    {"ruby_sysinit", (RUBY_PROC*)&dll_ruby_sysinit},
 #  endif
-                       (RUBY_PROC*)&dll_NtInitialize},
 #  if defined(DYNAMIC_RUBY_VER) && DYNAMIC_RUBY_VER >= 18
     {"rb_w32_snprintf", (RUBY_PROC*)&dll_rb_w32_snprintf},
 #  endif
index 2094db704beba8b4ebd09b7192339f3ecd2b6a3b..bf4b82d10cf690c47f03937016607733408e2413 100644 (file)
@@ -764,6 +764,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    191,
 /**/
     190,
 /**/