summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRay Lai <ray@cvs.openbsd.org>2006-03-11 06:54:13 +0000
committerRay Lai <ray@cvs.openbsd.org>2006-03-11 06:54:13 +0000
commitc7609c72cac3f734b6c209a1a452df39ab80bec6 (patch)
treeb8bde2d7c2708b82a69eace5ddc1d6bbab31b958
parent7df6fa68506ab78ad29638ee0585b15ed12ba642 (diff)
Make FLUSH macro more function-like, so there are no hidden surprises.
No binary change. ok miod, otto
-rw-r--r--usr.bin/vi/vi/vs_line.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/usr.bin/vi/vi/vs_line.c b/usr.bin/vi/vi/vs_line.c
index 69804d6914f..9628d52a596 100644
--- a/usr.bin/vi/vi/vs_line.c
+++ b/usr.bin/vi/vi/vs_line.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vs_line.c,v 1.8 2006/01/08 21:05:40 miod Exp $ */
+/* $OpenBSD: vs_line.c,v 1.9 2006/03/11 06:54:12 ray Exp $ */
/*-
* Copyright (c) 1993, 1994
@@ -404,11 +404,11 @@ display:
if (is_cached)
continue;
-#define FLUSH { \
- *cbp = '\0'; \
- (void)gp->scr_addstr(sp, cbuf, cbp - cbuf); \
- cbp = cbuf; \
-}
+#define FLUSH(gp, sp, cbp, cbuf) do { \
+ *(cbp) = '\0'; \
+ (void)(gp)->scr_addstr((sp), (cbuf), (cbp) - (cbuf)); \
+ (cbp) = (cbuf); \
+} while (0)
/*
* Display the character. We do tab expansion here because
* the screen interface doesn't have any way to set the tab
@@ -419,12 +419,12 @@ display:
if (is_tab)
while (chlen--) {
if (cbp >= ecbp)
- FLUSH;
+ FLUSH(gp, sp, cbp, cbuf);
*cbp++ = TABCH;
}
else {
if (cbp + chlen >= ecbp)
- FLUSH;
+ FLUSH(gp, sp, cbp, cbuf);
for (kp = KEY_NAME(sp, ch) + offset_in_char; chlen--;)
*cbp++ = *kp++;
}
@@ -445,7 +445,7 @@ display:
chlen = KEY_LEN(sp, '$');
if (cbp + chlen >= ecbp)
- FLUSH;
+ FLUSH(gp, sp, cbp, cbuf);
for (kp = KEY_NAME(sp, '$'); chlen--;)
*cbp++ = *kp++;
}
@@ -457,7 +457,7 @@ display:
/* Flush any buffered characters. */
if (cbp > cbuf)
- FLUSH;
+ FLUSH(gp, sp, cbp, cbuf);
ret1: (void)gp->scr_move(sp, oldy, oldx);
return (0);