summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKjell Wooding <kjell@cvs.openbsd.org>2005-11-18 23:37:32 +0000
committerKjell Wooding <kjell@cvs.openbsd.org>2005-11-18 23:37:32 +0000
commitf7421fa03f090fc3948fb1c3000a32097b40a48e (patch)
tree493553cc492083ddde7a2b1be03d829088d5f14a
parentc266de03a8e6cebc8867a41a73d94f8464193ecf (diff)
Split kill buffer code into a separate function.
-rw-r--r--usr.bin/mg/def.h3
-rw-r--r--usr.bin/mg/line.c57
2 files changed, 37 insertions, 23 deletions
diff --git a/usr.bin/mg/def.h b/usr.bin/mg/def.h
index 06a86b1e924..fc40a519fa8 100644
--- a/usr.bin/mg/def.h
+++ b/usr.bin/mg/def.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: def.h,v 1.75 2005/11/18 23:15:00 kjell Exp $ */
+/* $OpenBSD: def.h,v 1.76 2005/11/18 23:37:30 kjell Exp $ */
/* This file is in the public domain. */
@@ -356,6 +356,7 @@ int lreplace(RSIZE, char *);
void kdelete(void);
int kinsert(int, int);
int kremove(int);
+int kchunk(char *, RSIZE, int);
/* window.c X */
struct mgwin *new_window(struct buffer *);
diff --git a/usr.bin/mg/line.c b/usr.bin/mg/line.c
index 34b11f0b169..8c84474d967 100644
--- a/usr.bin/mg/line.c
+++ b/usr.bin/mg/line.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: line.c,v 1.28 2005/11/18 20:56:53 deraadt Exp $ */
+/* $OpenBSD: line.c,v 1.29 2005/11/18 23:37:31 kjell Exp $ */
/* This file is in the public domain. */
@@ -427,13 +427,6 @@ ldelete(RSIZE n, int kflag)
undo_add_delete(curwp->w_dotp, curwp->w_doto, n);
- /*
- * HACK - doesn't matter, and fixes back-over-nl bug for empty
- * kill buffers.
- */
- if (kused == kstart)
- kflag = KFORW;
-
while (n != 0) {
dotp = curwp->w_dotp;
doto = curwp->w_doto;
@@ -460,20 +453,8 @@ ldelete(RSIZE n, int kflag)
lchange(WFEDIT);
/* Scrunch text */
cp1 = &dotp->l_text[doto];
- if (kflag == KFORW) {
- while (ksize - kused < chunk)
- if (kgrow(kflag) == FALSE)
- return (FALSE);
- bcopy(cp1, &(kbufp[kused]), (int)chunk);
- kused += chunk;
- } else if (kflag == KBACK) {
- while (kstart < chunk)
- if (kgrow(kflag) == FALSE)
- return (FALSE);
- bcopy(cp1, &(kbufp[kstart - chunk]), (int)chunk);
- kstart -= chunk;
- } else if (kflag != KNONE)
- panic("broken ldelete call");
+ if (kchunk(cp1, chunk, kflag) == FALSE)
+ return(FALSE);
for (cp2 = cp1 + chunk; cp2 < &dotp->l_text[dotp->l_used];
cp2++)
*cp1++ = *cp2;
@@ -681,3 +662,35 @@ kremove(int n)
return (-1);
return (CHARMASK(kbufp[n + kstart]));
}
+
+/*
+ * Copy a string into the kill buffer. kflag gives direction.
+ * if KNONE, do nothing.
+ */
+int
+kchunk(char *cp1, RSIZE chunk, int kflag)
+{
+ /*
+ * HACK - doesn't matter, and fixes back-over-nl bug for empty
+ * kill buffers.
+ */
+ if (kused == kstart)
+ kflag = KFORW;
+
+ if (kflag == KFORW) {
+ while (ksize - kused < chunk)
+ if (kgrow(kflag) == FALSE)
+ return (FALSE);
+ bcopy(cp1, &(kbufp[kused]), (int)chunk);
+ kused += chunk;
+ } else if (kflag == KBACK) {
+ while (kstart < chunk)
+ if (kgrow(kflag) == FALSE)
+ return (FALSE);
+ bcopy(cp1, &(kbufp[kstart - chunk]), (int)chunk);
+ kstart -= chunk;
+ } else if (kflag != KNONE)
+ panic("broken ldelete call");
+
+ return (TRUE);
+}