]> granicus.if.org Git - vim/commitdiff
updated for version 7.4.359 v7.4.359
authorBram Moolenaar <Bram@vim.org>
Wed, 9 Jul 2014 17:13:49 +0000 (19:13 +0200)
committerBram Moolenaar <Bram@vim.org>
Wed, 9 Jul 2014 17:13:49 +0000 (19:13 +0200)
Problem:    When 'ttymouse' is set to 'uxterm' the xterm version is not
            requested. (Tomas Janousek)
Solution:   Do not mark uxterm as a conflict mouse and add
            resume_get_esc_sequence().

src/os_unix.c
src/proto/term.pro
src/term.c
src/version.c

index db64fb45fb0d913a57d9cd230740df7e93078e7e..033ce3cc3b9c07a4c69ddd9496d1b7818db60e7e 100644 (file)
@@ -3780,9 +3780,6 @@ check_mouse_termcode()
 # ifdef FEAT_MOUSE_URXVT
     /* same as the dec mouse */
     if (use_xterm_mouse() == 3
-#  ifdef FEAT_TERMRESPONSE
-           && !did_request_esc_sequence()
-#  endif
 #  ifdef FEAT_GUI
            && !gui.in_use
 #  endif
@@ -3797,7 +3794,8 @@ check_mouse_termcode()
            mch_setmouse(FALSE);
            setmouse();
        }
-       xterm_conflict_mouse = TRUE;
+       /* It's OK to request the xterm version for uxterm. */
+       resume_get_esc_sequence();
     }
     else
        del_mouse_termcode(KS_URXVT_MOUSE);
index 2ae91c45f239f3816b16d9371868d3527dfdbc23..89d58a0d0f74f5123ec56356c7459d9d28c397b9 100644 (file)
@@ -35,6 +35,7 @@ void settmode __ARGS((int tmode));
 void starttermcap __ARGS((void));
 void stoptermcap __ARGS((void));
 int did_request_esc_sequence __ARGS((void));
+void resume_get_esc_sequence __ARGS((void));
 void may_req_termresponse __ARGS((void));
 void may_req_ambiguous_char_width __ARGS((void));
 int swapping_screen __ARGS((void));
index bd54421202c720a518996a43e591070f11ece8ac..949b6fa4bcded44fb98b7212dab5221a7e3cd25a 100644 (file)
@@ -3330,6 +3330,19 @@ did_request_esc_sequence()
     return crv_status == CRV_SENT || u7_status == U7_SENT
                                                || xt_index_out > xt_index_in;
 }
+
+/*
+ * If requesting the version was disabled in did_request_esc_sequence(),
+ * enable it again.
+ */
+    void
+resume_get_esc_sequence()
+{
+    if (crv_status == 0)
+       crv_status = CRV_GET;
+    if (u7_status == 0)
+       u7_status = U7_GET;
+}
 # endif
 
 
index d9cf7a368d8f7a7f2a1a861131df9890b9856efc..faaaf76ad6f59f22c73d985370d834c46b8bab4d 100644 (file)
@@ -734,6 +734,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    359,
 /**/
     358,
 /**/