* lib/yesno.c [!ENABLE_NLS]: Don't include getline.h.
authorPaul Eggert <eggert@cs.ucla.edu>
Thu, 14 Dec 2006 18:47:36 +0000 (18:47 +0000)
committerPaul Eggert <eggert@cs.ucla.edu>
Thu, 14 Dec 2006 18:47:36 +0000 (18:47 +0000)
(yesno) [!ENABLE_NLS]: Don't invoke getline or rpmatch.
This is for the benefit of gzip, which doesn't do i18n.

ChangeLog
lib/yesno.c

index 90d5d9c..02b9a1e 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2006-12-14  Paul Eggert  <eggert@cs.ucla.edu>
+
+       * lib/yesno.c [!ENABLE_NLS]: Don't include getline.h.
+       (yesno) [!ENABLE_NLS]: Don't invoke getline or rpmatch.
+       This is for the benefit of gzip, which doesn't do i18n.
+
 2006-12-12  Jim Meyering  <jim@meyering.net>
 
        * m4/acl.m4 (gl_ACL_GET_FILE): Fix logic error.
index 930bfb0..2400628 100644 (file)
@@ -24,7 +24,9 @@
 #include <stdlib.h>
 #include <stdio.h>
 
-#include "getline.h"
+#if ENABLE_NLS
+# include "getline.h"
+#endif
 
 /* Return true if we read an affirmative line from standard input.  */
 
@@ -33,10 +35,12 @@ extern int rpmatch (char const *response);
 bool
 yesno (void)
 {
+  bool yes;
+
+#if ENABLE_NLS
   char *response = NULL;
   size_t response_size = 0;
   ssize_t response_len = getline (&response, &response_size, stdin);
-  bool yes;
 
   if (response_len <= 0)
     yes = false;
@@ -47,5 +51,14 @@ yesno (void)
     }
 
   free (response);
+#else
+  /* Test against "^[yY]", hardcoded to avoid requiring getline,
+     regex, and rpmatch.  */
+  int c = getchar ();
+  yes = (c == 'y' || c == 'Y');
+  while (c != '\n' && c != EOF)
+    c = getchar ();
+#endif
+
   return yes;
 }