ash: make ${#var} unicode-aware
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
841f8331d7
commit
e9ab07c211
39
shell/ash.c
39
shell/ash.c
@ -2121,6 +2121,22 @@ lookupvar(const char *name)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void reinit_unicode_for_ash(void)
|
||||||
|
{
|
||||||
|
/* Unicode support should be activated even if LANG is set
|
||||||
|
* _during_ shell execution, not only if it was set when
|
||||||
|
* shell was started. Therefore, re-check LANG every time:
|
||||||
|
*/
|
||||||
|
if (ENABLE_FEATURE_CHECK_UNICODE_IN_ENV
|
||||||
|
|| ENABLE_UNICODE_USING_LOCALE
|
||||||
|
) {
|
||||||
|
const char *s = lookupvar("LC_ALL");
|
||||||
|
if (!s) s = lookupvar("LC_CTYPE");
|
||||||
|
if (!s) s = lookupvar("LANG");
|
||||||
|
reinit_unicode(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Search the environment of a builtin command.
|
* Search the environment of a builtin command.
|
||||||
*/
|
*/
|
||||||
@ -6798,7 +6814,15 @@ evalvar(char *p, int flags, struct strlist *var_str_list)
|
|||||||
varunset(p, var, 0, 0);
|
varunset(p, var, 0, 0);
|
||||||
|
|
||||||
if (subtype == VSLENGTH) {
|
if (subtype == VSLENGTH) {
|
||||||
cvtnum(varlen > 0 ? varlen : 0);
|
ssize_t n = varlen;
|
||||||
|
if (n > 0) {
|
||||||
|
reinit_unicode_for_ash();
|
||||||
|
if (unicode_status == UNICODE_ON) {
|
||||||
|
const char *val = lookupvar(var);
|
||||||
|
n = unicode_strlen(val);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cvtnum(n > 0 ? n : 0);
|
||||||
goto record;
|
goto record;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -9657,18 +9681,7 @@ preadfd(void)
|
|||||||
# if ENABLE_FEATURE_TAB_COMPLETION
|
# if ENABLE_FEATURE_TAB_COMPLETION
|
||||||
line_input_state->path_lookup = pathval();
|
line_input_state->path_lookup = pathval();
|
||||||
# endif
|
# endif
|
||||||
/* Unicode support should be activated even if LANG is set
|
reinit_unicode_for_ash();
|
||||||
* _during_ shell execution, not only if it was set when
|
|
||||||
* shell was started. Therefore, re-check LANG every time:
|
|
||||||
*/
|
|
||||||
if (ENABLE_FEATURE_CHECK_UNICODE_IN_ENV
|
|
||||||
|| ENABLE_UNICODE_USING_LOCALE
|
|
||||||
) {
|
|
||||||
const char *s = lookupvar("LC_ALL");
|
|
||||||
if (!s) s = lookupvar("LC_CTYPE");
|
|
||||||
if (!s) s = lookupvar("LANG");
|
|
||||||
reinit_unicode(s);
|
|
||||||
}
|
|
||||||
nr = read_line_input(line_input_state, cmdedit_prompt, buf, IBUFSIZ, timeout);
|
nr = read_line_input(line_input_state, cmdedit_prompt, buf, IBUFSIZ, timeout);
|
||||||
if (nr == 0) {
|
if (nr == 0) {
|
||||||
/* Ctrl+C pressed */
|
/* Ctrl+C pressed */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user