Module Name:    src
Committed By:   rillig
Date:           Fri Nov 26 14:33:13 UTC 2021

Modified Files:
        src/usr.bin/indent: io.c

Log Message:
indent: extract inp_from_file from inp_read_line

No functional change.


To generate a diff of this commit:
cvs rdiff -u -r1.135 -r1.136 src/usr.bin/indent/io.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/usr.bin/indent/io.c
diff -u src/usr.bin/indent/io.c:1.135 src/usr.bin/indent/io.c:1.136
--- src/usr.bin/indent/io.c:1.135	Fri Nov 26 14:27:19 2021
+++ src/usr.bin/indent/io.c	Fri Nov 26 14:33:12 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: io.c,v 1.135 2021/11/26 14:27:19 rillig Exp $	*/
+/*	$NetBSD: io.c,v 1.136 2021/11/26 14:33:12 rillig Exp $	*/
 
 /*-
  * SPDX-License-Identifier: BSD-4-Clause
@@ -43,7 +43,7 @@ static char sccsid[] = "@(#)io.c	8.1 (Be
 
 #include <sys/cdefs.h>
 #if defined(__NetBSD__)
-__RCSID("$NetBSD: io.c,v 1.135 2021/11/26 14:27:19 rillig Exp $");
+__RCSID("$NetBSD: io.c,v 1.136 2021/11/26 14:33:12 rillig Exp $");
 #elif defined(__FreeBSD__)
 __FBSDID("$FreeBSD: head/usr.bin/indent/io.c 334927 2018-06-10 16:44:18Z pstef $");
 #endif
@@ -282,6 +282,23 @@ inp_from_comment(void)
     debug_inp(__func__);
 }
 
+/*
+ * After having read from save_com, continue with the rest of the input line
+ * before reading the next line from the input file.
+ */
+static bool
+inp_from_file(void)
+{
+    if (inbuf.saved_inp_s == NULL)
+	return false;
+
+    inbuf.inp.s = inbuf.saved_inp_s;
+    inbuf.inp.e = inbuf.saved_inp_e;
+    inbuf.saved_inp_s = inbuf.saved_inp_e = NULL;
+    debug_println("switched inp.s back to saved_inp_s");
+    return inbuf.inp.s < inbuf.inp.e;
+}
+
 void
 inp_comment_insert_lbrace(void)
 {
@@ -617,15 +634,8 @@ inp_read_line(void)
     int ch;
     FILE *f = input;
 
-    if (inbuf.saved_inp_s != NULL) {	/* there is a partly filled input buffer left */
-	inbuf.inp.s = inbuf.saved_inp_s;	/* do not read anything, just switch buffers */
-	inbuf.inp.e = inbuf.saved_inp_e;
-	inbuf.saved_inp_s = inbuf.saved_inp_e = NULL;
-	debug_println("switched inp.s back to saved_inp_s");
-	if (inbuf.inp.s < inbuf.inp.e)
-	    return;		/* only return if there is really something in
-				 * this buffer */
-    }
+    if (inp_from_file())
+	return;
 
     for (p = inbuf.inp.buf;;) {
 	if (p >= inbuf.inp.l) {

Reply via email to