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: