Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/indent indent: extract lex_number, lex_word, lex_cha...



details:   https://anonhg.NetBSD.org/src/rev/31f9503061ae
branches:  trunk
changeset: 985454:31f9503061ae
user:      rillig <rillig%NetBSD.org@localhost>
date:      Thu Aug 26 07:03:00 2021 +0000

description:
indent: extract lex_number, lex_word, lex_char_or_string

No functional change.

diffstat:

 usr.bin/indent/lexi.c |  130 ++++++++++++++++++++++++++++---------------------
 1 files changed, 74 insertions(+), 56 deletions(-)

diffs (177 lines):

diff -r 02934c0e27f4 -r 31f9503061ae usr.bin/indent/lexi.c
--- a/usr.bin/indent/lexi.c     Thu Aug 26 06:25:59 2021 +0000
+++ b/usr.bin/indent/lexi.c     Thu Aug 26 07:03:00 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: lexi.c,v 1.42 2021/08/25 22:26:30 rillig Exp $ */
+/*     $NetBSD: lexi.c,v 1.43 2021/08/26 07:03:00 rillig Exp $ */
 
 /*-
  * SPDX-License-Identifier: BSD-4-Clause
@@ -46,7 +46,7 @@
 #include <sys/cdefs.h>
 #ifndef lint
 #if defined(__NetBSD__)
-__RCSID("$NetBSD: lexi.c,v 1.42 2021/08/25 22:26:30 rillig Exp $");
+__RCSID("$NetBSD: lexi.c,v 1.43 2021/08/26 07:03:00 rillig Exp $");
 #elif defined(__FreeBSD__)
 __FBSDID("$FreeBSD: head/usr.bin/indent/lexi.c 337862 2018-08-15 18:19:45Z pstef $");
 #endif
@@ -284,13 +284,78 @@
 #  define lexi_end(tk) (tk)
 #endif
 
+static void
+lex_number(void)
+{
+    char s;
+    unsigned char i;
+
+    for (s = 'A'; s != 'f' && s != 'i' && s != 'u'; ) {
+       i = (unsigned char)*buf_ptr;
+       if (i >= nitems(table) || table[i] == NULL ||
+           table[i][s - 'A'] == ' ') {
+           s = table[0][s - 'A'];
+           break;
+       }
+       s = table[i][s - 'A'];
+       check_size_token(1);
+       *e_token++ = inbuf_next();
+    }
+    /* s now indicates the type: f(loating), i(integer), u(nknown) */
+}
+
+static void
+lex_word(void)
+{
+    while (isalnum((unsigned char)*buf_ptr) ||
+          *buf_ptr == '\\' ||
+          *buf_ptr == '_' || *buf_ptr == '$') {
+       /* fill_buffer() terminates buffer with newline */
+       if (*buf_ptr == '\\') {
+           if (buf_ptr[1] == '\n') {
+               buf_ptr += 2;
+               if (buf_ptr >= buf_end)
+                   fill_buffer();
+           } else
+               break;
+       }
+       check_size_token(1);
+       *e_token++ = inbuf_next();
+    }
+}
+
+static void
+lex_char_or_string(void)
+{
+    char delim;
+
+    delim = *token;
+    do {                       /* copy the string */
+       for (;;) {              /* move one character or [/<char>]<char> */
+           if (*buf_ptr == '\n') {
+               diag(1, "Unterminated literal");
+               return;
+           }
+           check_size_token(2);
+           *e_token = inbuf_next();
+           if (*e_token == '\\') {     /* if escape, copy extra char */
+               if (*buf_ptr == '\n')   /* check for escaped newline */
+                   ++line_no;
+               *++e_token = inbuf_next();
+               ++e_token;      /* we must increment this again because we
+                                * copied two chars */
+           } else
+               break;          /* we copied one character */
+       }                       /* end of while (1) */
+    } while (*e_token++ != delim);
+}
+
 token_type
 lexi(struct parser_state *state)
 {
     int         unary_delim;   /* this is set to 1 if the current token
                                 * forces a following operator to be unary */
     token_type  code;          /* internal code to be returned */
-    char        qchar;         /* the delimiter character for a string */
 
     e_token = s_token;         /* point to start of place to save token */
     unary_delim = false;
@@ -310,43 +375,15 @@
        *buf_ptr == '_' || *buf_ptr == '$' ||
        (buf_ptr[0] == '.' && isdigit((unsigned char)buf_ptr[1]))) {
        /*
-        * we have a character or number
+        * we have a letter or number
         */
        struct templ *p;
 
        if (isdigit((unsigned char)*buf_ptr) ||
            (buf_ptr[0] == '.' && isdigit((unsigned char)buf_ptr[1]))) {
-           char s;
-           unsigned char i;
-
-           for (s = 'A'; s != 'f' && s != 'i' && s != 'u'; ) {
-               i = (unsigned char)*buf_ptr;
-               if (i >= nitems(table) || table[i] == NULL ||
-                   table[i][s - 'A'] == ' ') {
-                   s = table[0][s - 'A'];
-                   break;
-               }
-               s = table[i][s - 'A'];
-               check_size_token(1);
-               *e_token++ = inbuf_next();
-           }
-           /* s now indicates the type: f(loating), i(integer), u(nknown) */
+           lex_number();
        } else {
-           while (isalnum((unsigned char)*buf_ptr) ||
-                  *buf_ptr == '\\' ||
-                  *buf_ptr == '_' || *buf_ptr == '$') {
-               /* fill_buffer() terminates buffer with newline */
-               if (*buf_ptr == '\\') {
-                   if (buf_ptr[1] == '\n') {
-                       buf_ptr += 2;
-                       if (buf_ptr >= buf_end)
-                           fill_buffer();
-                   } else
-                       break;
-               }
-               check_size_token(1);
-               *e_token++ = inbuf_next();
-           }
+           lex_word();
        }
        *e_token = '\0';
 
@@ -477,28 +514,9 @@
         */
        break;
 
-    case '\'':                 /* start of quoted character */
-    case '"':                  /* start of string */
-       qchar = *token;
-       do {                    /* copy the string */
-           for (;;) {          /* move one character or [/<char>]<char> */
-               if (*buf_ptr == '\n') {
-                   diag(1, "Unterminated literal");
-                   goto stop_lit;
-               }
-               check_size_token(2);
-               *e_token = inbuf_next();
-               if (*e_token == '\\') {         /* if escape, copy extra char */
-                   if (*buf_ptr == '\n')       /* check for escaped newline */
-                       ++line_no;
-                   *++e_token = inbuf_next();
-                   ++e_token;  /* we must increment this again because we
-                                * copied two chars */
-               } else
-                   break;      /* we copied one character */
-           }                   /* end of while (1) */
-       } while (*e_token++ != qchar);
-stop_lit:
+    case '\'':
+    case '"':
+       lex_char_or_string();
        code = ident;
        break;
 



Home | Main Index | Thread Index | Old Index