Module Name:    src
Committed By:   christos
Date:           Sun Nov 18 17:09:39 UTC 2018

Modified Files:
        src/lib/libedit: chartype.c editline.3 el.c el.h read.c

Log Message:
Remove utf-8 requirement (Yuichiro NAITO)


To generate a diff of this commit:
cvs rdiff -u -r1.31 -r1.32 src/lib/libedit/chartype.c
cvs rdiff -u -r1.98 -r1.99 src/lib/libedit/editline.3
cvs rdiff -u -r1.96 -r1.97 src/lib/libedit/el.c
cvs rdiff -u -r1.43 -r1.44 src/lib/libedit/el.h
cvs rdiff -u -r1.103 -r1.104 src/lib/libedit/read.c

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

Modified files:

Index: src/lib/libedit/chartype.c
diff -u src/lib/libedit/chartype.c:1.31 src/lib/libedit/chartype.c:1.32
--- src/lib/libedit/chartype.c:1.31	Sun Jan  8 21:54:18 2017
+++ src/lib/libedit/chartype.c	Sun Nov 18 12:09:39 2018
@@ -1,4 +1,4 @@
-/*	$NetBSD: chartype.c,v 1.31 2017/01/09 02:54:18 christos Exp $	*/
+/*	$NetBSD: chartype.c,v 1.32 2018/11/18 17:09:39 christos Exp $	*/
 
 /*-
  * Copyright (c) 2009 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
  */
 #include "config.h"
 #if !defined(lint) && !defined(SCCSID)
-__RCSID("$NetBSD: chartype.c,v 1.31 2017/01/09 02:54:18 christos Exp $");
+__RCSID("$NetBSD: chartype.c,v 1.32 2018/11/18 17:09:39 christos Exp $");
 #endif /* not lint && not SCCSID */
 
 #include <ctype.h>
@@ -183,17 +183,11 @@ ct_decode_argv(int argc, const char *arg
 libedit_private size_t
 ct_enc_width(wchar_t c)
 {
-	/* UTF-8 encoding specific values */
-	if (c < 0x80)
-		return 1;
-	else if (c < 0x0800)
-		return 2;
-	else if (c < 0x10000)
-		return 3;
-	else if (c < 0x110000)
-		return 4;
-	else
-		return 0; /* not a valid codepoint */
+	char buf[MB_LEN_MAX];
+	int size;
+	if ((size = ct_wctomb(buf, c)) < 0)
+		return 0;
+	return size;
 }
 
 libedit_private ssize_t

Index: src/lib/libedit/editline.3
diff -u src/lib/libedit/editline.3:1.98 src/lib/libedit/editline.3:1.99
--- src/lib/libedit/editline.3:1.98	Sat Sep  2 02:48:10 2017
+++ src/lib/libedit/editline.3	Sun Nov 18 12:09:39 2018
@@ -1,4 +1,4 @@
-.\"	$NetBSD: editline.3,v 1.98 2017/09/02 06:48:10 wiz Exp $
+.\"	$NetBSD: editline.3,v 1.99 2018/11/18 17:09:39 christos Exp $
 .\"
 .\" Copyright (c) 1997-2014 The NetBSD Foundation, Inc.
 .\" All rights reserved.
@@ -26,7 +26,7 @@
 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 .\" POSSIBILITY OF SUCH DAMAGE.
 .\"
-.Dd September 1, 2017
+.Dd November 9, 2018
 .Dt EDITLINE 3
 .Os
 .Sh NAME
@@ -181,8 +181,6 @@ library respects the
 locale set by the application program and never uses
 .Xr setlocale 3
 to change the locale.
-The only locales supported are UTF-8 and the default C or POSIX locale.
-If any other locale is set, behaviour is undefined.
 .Sh LINE EDITING FUNCTIONS
 The line editing functions use a common data structure,
 .Fa EditLine ,

Index: src/lib/libedit/el.c
diff -u src/lib/libedit/el.c:1.96 src/lib/libedit/el.c:1.97
--- src/lib/libedit/el.c:1.96	Mon Jan  1 17:32:46 2018
+++ src/lib/libedit/el.c	Sun Nov 18 12:09:39 2018
@@ -1,4 +1,4 @@
-/*	$NetBSD: el.c,v 1.96 2018/01/01 22:32:46 christos Exp $	*/
+/*	$NetBSD: el.c,v 1.97 2018/11/18 17:09:39 christos Exp $	*/
 
 /*-
  * Copyright (c) 1992, 1993
@@ -37,7 +37,7 @@
 #if 0
 static char sccsid[] = "@(#)el.c	8.2 (Berkeley) 1/3/94";
 #else
-__RCSID("$NetBSD: el.c,v 1.96 2018/01/01 22:32:46 christos Exp $");
+__RCSID("$NetBSD: el.c,v 1.97 2018/11/18 17:09:39 christos Exp $");
 #endif
 #endif /* not lint && not SCCSID */
 
@@ -96,10 +96,6 @@ el_init_internal(const char *prog, FILE 
          * Initialize all the modules. Order is important!!!
          */
 	el->el_flags = flags;
-	if (setlocale(LC_CTYPE, NULL) != NULL){
-		if (strcmp(nl_langinfo(CODESET), "UTF-8") == 0)
-			el->el_flags |= CHARSET_IS_UTF8;
-	}
 
 	if (terminal_init(el) == -1) {
 		el_free(el->el_prog);
@@ -301,7 +297,7 @@ el_wset(EditLine *el, int op, ...)
 		void *ptr = va_arg(ap, void *);
 
 		rv = hist_set(el, func, ptr);
-		if (!(el->el_flags & CHARSET_IS_UTF8))
+		if (MB_CUR_MAX == 1)
 			el->el_flags &= ~NARROW_HISTORY;
 		break;
 	}

Index: src/lib/libedit/el.h
diff -u src/lib/libedit/el.h:1.43 src/lib/libedit/el.h:1.44
--- src/lib/libedit/el.h:1.43	Tue Sep  5 14:07:59 2017
+++ src/lib/libedit/el.h	Sun Nov 18 12:09:39 2018
@@ -1,4 +1,4 @@
-/*	$NetBSD: el.h,v 1.43 2017/09/05 18:07:59 christos Exp $	*/
+/*	$NetBSD: el.h,v 1.44 2018/11/18 17:09:39 christos Exp $	*/
 
 /*-
  * Copyright (c) 1992, 1993
@@ -55,7 +55,6 @@
 #define	NO_TTY		0x02
 #define	EDIT_DISABLED	0x04
 #define	UNBUFFERED	0x08
-#define	CHARSET_IS_UTF8 0x10
 #define	NARROW_HISTORY	0x40
 #define	NO_RESET	0x80
 

Index: src/lib/libedit/read.c
diff -u src/lib/libedit/read.c:1.103 src/lib/libedit/read.c:1.104
--- src/lib/libedit/read.c:1.103	Tue Jun 27 19:24:19 2017
+++ src/lib/libedit/read.c	Sun Nov 18 12:09:39 2018
@@ -1,4 +1,4 @@
-/*	$NetBSD: read.c,v 1.103 2017/06/27 23:24:19 christos Exp $	*/
+/*	$NetBSD: read.c,v 1.104 2018/11/18 17:09:39 christos Exp $	*/
 
 /*-
  * Copyright (c) 1992, 1993
@@ -37,7 +37,7 @@
 #if 0
 static char sccsid[] = "@(#)read.c	8.1 (Berkeley) 6/4/93";
 #else
-__RCSID("$NetBSD: read.c,v 1.103 2017/06/27 23:24:19 christos Exp $");
+__RCSID("$NetBSD: read.c,v 1.104 2018/11/18 17:09:39 christos Exp $");
 #endif
 #endif /* not lint && not SCCSID */
 
@@ -335,17 +335,6 @@ read_char(EditLine *el, wchar_t *cp)
 				goto again;
 			}
 		case (size_t)-2:
-			/*
-			 * We don't support other multibyte charsets.
-			 * The second condition shouldn't happen
-			 * and is here merely for additional safety.
-			 */
-			if ((el->el_flags & CHARSET_IS_UTF8) == 0 ||
-			    cbp >= MB_LEN_MAX) {
-				errno = EILSEQ;
-				*cp = L'\0';
-				return -1;
-			}
 			/* Incomplete sequence, read another byte. */
 			goto again;
 		default:

Reply via email to