]> granicus.if.org Git - vim/commitdiff
patch 8.2.2104: build problem with Ruby 2.7 v8.2.2104
authorBram Moolenaar <Bram@vim.org>
Sun, 6 Dec 2020 20:11:31 +0000 (21:11 +0100)
committerBram Moolenaar <Bram@vim.org>
Sun, 6 Dec 2020 20:11:31 +0000 (21:11 +0100)
Problem:    Build problem with Ruby 2.7.
Solution:   Adjust function declarations. (Ozaki Kiichi, closes #7430)

src/auto/configure
src/configure.ac
src/if_ruby.c
src/version.c

index 205312a3bd8fa61e4a6c0603f408af73edbf3a6a..ef1acd848db5a0aae1866dc89aea59dd6adf3a5e 100755 (executable)
@@ -7617,8 +7617,7 @@ $as_echo "$rubyhdrdir" >&6; }
        librubyarg=`$vi_cv_path_ruby -r rbconfig -e "print $ruby_rbconfig.expand($ruby_rbconfig::CONFIG['LIBRUBYARG'])"`
        librubya=`$vi_cv_path_ruby -r rbconfig -e "print $ruby_rbconfig.expand($ruby_rbconfig::CONFIG['LIBRUBY_A'])"`
        rubylibdir=`$vi_cv_path_ruby -r rbconfig -e "print $ruby_rbconfig.expand($ruby_rbconfig::CONFIG['libdir'])"`
-       if test -f "$rubylibdir/$librubya"; then
-         librubyarg="$librubyarg"
+       if test -f "$rubylibdir/$librubya" || expr "$librubyarg" : "-lruby"; then
          RUBY_LIBS="$RUBY_LIBS -L$rubylibdir"
        elif test "$librubyarg" = "libruby.a"; then
                  librubyarg="-lruby"
index 4b6794a29eeeb62d29031c237a9d9e8671705080..062c75a20ac63549fb670f9996ec5139c4b0943c 100644 (file)
@@ -1965,8 +1965,7 @@ if test "$enable_rubyinterp" = "yes" -o "$enable_rubyinterp" = "dynamic"; then
        librubyarg=`$vi_cv_path_ruby -r rbconfig -e "print $ruby_rbconfig.expand($ruby_rbconfig::CONFIG[['LIBRUBYARG']])"`
        librubya=`$vi_cv_path_ruby -r rbconfig -e "print $ruby_rbconfig.expand($ruby_rbconfig::CONFIG[['LIBRUBY_A']])"`
        rubylibdir=`$vi_cv_path_ruby -r rbconfig -e "print $ruby_rbconfig.expand($ruby_rbconfig::CONFIG[['libdir']])"`
-       if test -f "$rubylibdir/$librubya"; then
-         librubyarg="$librubyarg"
+       if test -f "$rubylibdir/$librubya" || expr "$librubyarg" : "-lruby"; then
          RUBY_LIBS="$RUBY_LIBS -L$rubylibdir"
        elif test "$librubyarg" = "libruby.a"; then
          dnl required on Mac OS 10.3 where libruby.a doesn't exist
index 692af4cb2e5bd07f285d60ff50cd8cd62116a9a8..1619205e31a039b7b8dde7eded2f13615ab04327 100644 (file)
@@ -1300,13 +1300,19 @@ vim_blob(VALUE self UNUSED, VALUE str)
 }
 
     static VALUE
-buffer_s_current(void)
+buffer_s_current(VALUE self UNUSED)
 {
     return buffer_new(curbuf);
 }
 
     static VALUE
-buffer_s_count(void)
+buffer_s_current_getter(ID id UNUSED, VALUE *x UNUSED)
+{
+    return buffer_new(curbuf);
+}
+
+    static VALUE
+buffer_s_count(VALUE self UNUSED)
 {
     buf_T *b;
     int n = 0;
@@ -1566,7 +1572,13 @@ get_win(VALUE obj)
 }
 
     static VALUE
-window_s_current(void)
+window_s_current(VALUE self UNUSED)
+{
+    return window_new(curwin);
+}
+
+    static VALUE
+window_s_current_getter(ID id UNUSED, VALUE *x UNUSED)
 {
     return window_new(curwin);
 }
@@ -1576,7 +1588,7 @@ window_s_current(void)
  *    SegPhault - 03/07/05
  */
     static VALUE
-line_s_current(void)
+line_s_current(VALUE self UNUSED)
 {
     return get_buffer_line(curbuf, curwin->w_cursor.lnum);
 }
@@ -1588,13 +1600,13 @@ set_current_line(VALUE self UNUSED, VALUE str)
 }
 
     static VALUE
-current_line_number(void)
+current_line_number(VALUE self UNUSED)
 {
     return INT2FIX((int)curwin->w_cursor.lnum);
 }
 
     static VALUE
-window_s_count(void)
+window_s_count(VALUE self UNUSED)
 {
     win_T      *w;
     int n = 0;
@@ -1794,8 +1806,8 @@ ruby_vim_init(void)
     rb_define_method(cVimWindow, "cursor", window_cursor, 0);
     rb_define_method(cVimWindow, "cursor=", window_set_cursor, 1);
 
-    rb_define_virtual_variable("$curbuf", buffer_s_current, 0);
-    rb_define_virtual_variable("$curwin", window_s_current, 0);
+    rb_define_virtual_variable("$curbuf", buffer_s_current_getter, 0);
+    rb_define_virtual_variable("$curwin", window_s_current_getter, 0);
 }
 
     void
index 2444f0bda538be11cb7d76bf576b73e00276d511..08594a562576a13d763b733b66e98c8204d78ec1 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2104,
 /**/
     2103,
 /**/