summaryrefslogtreecommitdiff
path: root/src/window.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/window.c')
-rw-r--r--src/window.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/window.c b/src/window.c
index c96bb9755..7cd2f0224 100644
--- a/src/window.c
+++ b/src/window.c
@@ -74,6 +74,11 @@ static void win_new_height __ARGS((win_T *, int));
#define NOWIN (win_T *)-1 /* non-exisiting window */
+#ifdef FEAT_WINDOWS
+static long p_ch_used = 1L; /* value of 'cmdheight' when frame
+ size was set */
+#endif
+
#if defined(FEAT_WINDOWS) || defined(PROTO)
/*
* all CTRL-W window commands are handled here, called from normal_cmd().
@@ -498,6 +503,23 @@ do_window(nchar, Prenum, xchar)
break;
#endif
+ case K_KENTER:
+ case CAR:
+#if defined(FEAT_QUICKFIX)
+ /*
+ * In a quickfix window a <CR> jumps to the error under the
+ * cursor in a new window.
+ */
+ if (bt_quickfix(curbuf))
+ {
+ sprintf((char *)cbuf, "split +%ldcc",
+ (long)curwin->w_cursor.lnum);
+ do_cmdline_cmd(cbuf);
+ }
+#endif
+ break;
+
+
/* CTRL-W g extended commands */
case 'g':
case Ctrl_G:
@@ -2680,6 +2702,9 @@ win_alloc_first()
topframe->fr_width = Columns;
#endif
topframe->fr_height = Rows - p_ch;
+#ifdef FEAT_WINDOWS
+ p_ch_used = p_ch;
+#endif
topframe->fr_win = curwin;
curwin->w_frame = topframe;
}
@@ -3308,6 +3333,10 @@ shell_new_rows()
win_new_height(firstwin, h);
#endif
compute_cmdrow();
+#ifdef FEAT_WINDOWS
+ p_ch_used = p_ch;
+#endif
+
#if 0
/* Disabled: don't want making the screen smaller make a window larger. */
if (p_ea)
@@ -4315,6 +4344,13 @@ command_height(old_p_ch)
int h;
frame_T *frp;
+ /* When passed a negative value use the value of p_ch that we remembered.
+ * This is needed for when the GUI starts up, we can't be sure in what
+ * order things happen. */
+ if (old_p_ch < 0)
+ old_p_ch = p_ch_used;
+ p_ch_used = p_ch;
+
/* Find bottom frame with width of screen. */
frp = lastwin->w_frame;
# ifdef FEAT_VERTSPLIT