summaryrefslogtreecommitdiff
path: root/src/regexp.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2013-06-04 18:28:48 +0200
committerBram Moolenaar <Bram@vim.org>2013-06-04 18:28:48 +0200
commitdacd7de3fd5edd8f3a41ba3c9c389b653b6a9e5d (patch)
treeb7c94afb57d66ab24bdc53e9362501e177ed0aee /src/regexp.c
parentf811509c036306595be026f5e49dde170abb216c (diff)
downloadvim-git-dacd7de3fd5edd8f3a41ba3c9c389b653b6a9e5d.tar.gz
updated for version 7.3.1112v7.3.1112
Problem: New regexp engine: \%V not supported. Solution: Implement \%V. Add tests.
Diffstat (limited to 'src/regexp.c')
-rw-r--r--src/regexp.c154
1 files changed, 81 insertions, 73 deletions
diff --git a/src/regexp.c b/src/regexp.c
index 369516aed..b0c8a2192 100644
--- a/src/regexp.c
+++ b/src/regexp.c
@@ -4165,6 +4165,85 @@ reg_prev_class()
}
#endif
+#ifdef FEAT_VISUAL
+static int reg_match_visual __ARGS((void));
+
+/*
+ * Return TRUE if the current reginput position matches the Visual area.
+ */
+ static int
+reg_match_visual()
+{
+ pos_T top, bot;
+ linenr_T lnum;
+ colnr_T col;
+ win_T *wp = reg_win == NULL ? curwin : reg_win;
+ int mode;
+ colnr_T start, end;
+ colnr_T start2, end2;
+ colnr_T cols;
+
+ /* Check if the buffer is the current buffer. */
+ if (reg_buf != curbuf || VIsual.lnum == 0)
+ return FALSE;
+
+ if (VIsual_active)
+ {
+ if (lt(VIsual, wp->w_cursor))
+ {
+ top = VIsual;
+ bot = wp->w_cursor;
+ }
+ else
+ {
+ top = wp->w_cursor;
+ bot = VIsual;
+ }
+ mode = VIsual_mode;
+ }
+ else
+ {
+ if (lt(curbuf->b_visual.vi_start, curbuf->b_visual.vi_end))
+ {
+ top = curbuf->b_visual.vi_start;
+ bot = curbuf->b_visual.vi_end;
+ }
+ else
+ {
+ top = curbuf->b_visual.vi_end;
+ bot = curbuf->b_visual.vi_start;
+ }
+ mode = curbuf->b_visual.vi_mode;
+ }
+ lnum = reglnum + reg_firstlnum;
+ if (lnum < top.lnum || lnum > bot.lnum)
+ return FALSE;
+
+ if (mode == 'v')
+ {
+ col = (colnr_T)(reginput - regline);
+ if ((lnum == top.lnum && col < top.col)
+ || (lnum == bot.lnum && col >= bot.col + (*p_sel != 'e')))
+ return FALSE;
+ }
+ else if (mode == Ctrl_V)
+ {
+ getvvcol(wp, &top, &start, NULL, &end);
+ getvvcol(wp, &bot, &start2, NULL, &end2);
+ if (start2 < start)
+ start = start2;
+ if (end2 > end)
+ end = end2;
+ if (top.col == MAXCOL || bot.col == MAXCOL)
+ end = MAXCOL;
+ cols = win_linetabsize(wp, regline, (colnr_T)(reginput - regline));
+ if (cols < start || cols > end - (*p_sel == 'e'))
+ return FALSE;
+ }
+ return TRUE;
+}
+#endif
+
#define ADVANCE_REGINPUT() mb_ptr_adv(reginput)
/*
@@ -4347,80 +4426,9 @@ regmatch(scan)
case RE_VISUAL:
#ifdef FEAT_VISUAL
- /* Check if the buffer is the current buffer. and whether the
- * position is inside the Visual area. */
- if (reg_buf != curbuf || VIsual.lnum == 0)
- status = RA_NOMATCH;
- else
- {
- pos_T top, bot;
- linenr_T lnum;
- colnr_T col;
- win_T *wp = reg_win == NULL ? curwin : reg_win;
- int mode;
-
- if (VIsual_active)
- {
- if (lt(VIsual, wp->w_cursor))
- {
- top = VIsual;
- bot = wp->w_cursor;
- }
- else
- {
- top = wp->w_cursor;
- bot = VIsual;
- }
- mode = VIsual_mode;
- }
- else
- {
- if (lt(curbuf->b_visual.vi_start, curbuf->b_visual.vi_end))
- {
- top = curbuf->b_visual.vi_start;
- bot = curbuf->b_visual.vi_end;
- }
- else
- {
- top = curbuf->b_visual.vi_end;
- bot = curbuf->b_visual.vi_start;
- }
- mode = curbuf->b_visual.vi_mode;
- }
- lnum = reglnum + reg_firstlnum;
- col = (colnr_T)(reginput - regline);
- if (lnum < top.lnum || lnum > bot.lnum)
- status = RA_NOMATCH;
- else if (mode == 'v')
- {
- if ((lnum == top.lnum && col < top.col)
- || (lnum == bot.lnum
- && col >= bot.col + (*p_sel != 'e')))
- status = RA_NOMATCH;
- }
- else if (mode == Ctrl_V)
- {
- colnr_T start, end;
- colnr_T start2, end2;
- colnr_T cols;
-
- getvvcol(wp, &top, &start, NULL, &end);
- getvvcol(wp, &bot, &start2, NULL, &end2);
- if (start2 < start)
- start = start2;
- if (end2 > end)
- end = end2;
- if (top.col == MAXCOL || bot.col == MAXCOL)
- end = MAXCOL;
- cols = win_linetabsize(wp,
- regline, (colnr_T)(reginput - regline));
- if (cols < start || cols > end - (*p_sel == 'e'))
- status = RA_NOMATCH;
- }
- }
-#else
- status = RA_NOMATCH;
+ if (!reg_match_visual())
#endif
+ status = RA_NOMATCH;
break;
case RE_LNUM: